Skip to content

Commit

Permalink
Merge pull request Expensify#31699 from fvlvte/25047-migrate-confirmC…
Browse files Browse the repository at this point in the history
…ontent

[TS migration] Migrate 'ConfirmContent.js' component to TypeScript
  • Loading branch information
mountiny authored Dec 27, 2023
2 parents 4a1053d + 9d85314 commit 6a4770a
Show file tree
Hide file tree
Showing 2 changed files with 163 additions and 173 deletions.
173 changes: 0 additions & 173 deletions src/components/ConfirmContent.js

This file was deleted.

163 changes: 163 additions & 0 deletions src/components/ConfirmContent.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,163 @@
import React, {ReactNode} from 'react';
import {StyleProp, TextStyle, View, ViewStyle} from 'react-native';
import useLocalize from '@hooks/useLocalize';
import useNetwork from '@hooks/useNetwork';
import useTheme from '@hooks/useTheme';
import useThemeStyles from '@hooks/useThemeStyles';
import variables from '@styles/variables';
import IconAsset from '@src/types/utils/IconAsset';
import Button from './Button';
import Header from './Header';
import Icon from './Icon';
import Text from './Text';

type ConfirmContentProps = {
/** Title of the modal */
title: string;

/** A callback to call when the form has been submitted */
onConfirm: () => void;

/** A callback to call when the form has been closed */
onCancel?: () => void;

/** Confirm button text */
confirmText?: string;

/** Cancel button text */
cancelText?: string;

/** Modal content text/element */
prompt?: string | ReactNode;

/** Whether we should use the success button color */
success?: boolean;

/** Whether we should use the danger button color. Use if the action is destructive */
danger?: boolean;

/** Whether we should disable the confirm button when offline */
shouldDisableConfirmButtonWhenOffline?: boolean;

/** Whether we should show the cancel button */
shouldShowCancelButton?: boolean;

/** Icon to display above the title */
iconSource?: IconAsset;

/** Whether to center the icon / text content */
shouldCenterContent?: boolean;

/** Whether to stack the buttons */
shouldStackButtons?: boolean;

/** Styles for title */
titleStyles?: StyleProp<TextStyle>;

/** Styles for prompt */
promptStyles?: StyleProp<TextStyle>;

/** Styles for view */
contentStyles?: StyleProp<ViewStyle>;

/** Styles for icon */
iconAdditionalStyles?: StyleProp<ViewStyle>;
};

function ConfirmContent({
title,
onConfirm,
onCancel = () => {},
confirmText = '',
cancelText = '',
prompt = '',
success = true,
danger = false,
shouldDisableConfirmButtonWhenOffline = false,
shouldShowCancelButton = false,
iconSource,
shouldCenterContent = false,
shouldStackButtons = true,
titleStyles,
promptStyles,
contentStyles,
iconAdditionalStyles,
}: ConfirmContentProps) {
const styles = useThemeStyles();
const {translate} = useLocalize();
const theme = useTheme();
const {isOffline} = useNetwork();

const isCentered = shouldCenterContent;

return (
<View style={[styles.m5, contentStyles]}>
<View style={isCentered ? [styles.alignItemsCenter, styles.mb6] : []}>
{typeof iconSource === 'function' && (
<View style={[styles.flexRow, styles.mb3]}>
<Icon
src={iconSource}
fill={theme.icon}
width={variables.appModalAppIconSize}
height={variables.appModalAppIconSize}
additionalStyles={iconAdditionalStyles}
/>
</View>
)}
<View style={[styles.flexRow, isCentered ? {} : styles.mb4]}>
<Header
title={title}
textStyles={titleStyles}
/>
</View>
{typeof prompt === 'string' ? <Text style={[promptStyles, isCentered ? styles.textAlignCenter : {}]}>{prompt}</Text> : prompt}
</View>

{shouldStackButtons ? (
<>
<Button
success={success}
danger={danger}
style={[styles.mt4]}
onPress={onConfirm}
pressOnEnter
text={confirmText || translate('common.yes')}
isDisabled={isOffline && shouldDisableConfirmButtonWhenOffline}
/>
{shouldShowCancelButton && (
<Button
style={[styles.mt3, styles.noSelect]}
onPress={onCancel}
text={cancelText || translate('common.no')}
/>
)}
</>
) : (
<View style={[styles.flexRow, styles.gap4]}>
{shouldShowCancelButton && (
<Button
style={[styles.noSelect, styles.flex1]}
onPress={onCancel}
text={cancelText || translate('common.no')}
medium
/>
)}
<Button
success={success}
danger={danger}
style={[styles.flex1]}
onPress={onConfirm}
pressOnEnter
text={confirmText || translate('common.yes')}
isDisabled={isOffline && shouldDisableConfirmButtonWhenOffline}
medium
/>
</View>
)}
</View>
);
}

ConfirmContent.displayName = 'ConfirmContent';

export default ConfirmContent;

0 comments on commit 6a4770a

Please sign in to comment.