forked from Expensify/App
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request Expensify#31699 from fvlvte/25047-migrate-confirmC…
…ontent [TS migration] Migrate 'ConfirmContent.js' component to TypeScript
- Loading branch information
Showing
2 changed files
with
163 additions
and
173 deletions.
There are no files selected for viewing
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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; |