diff --git a/src/components/FormAlertWrapper.js b/src/components/FormAlertWrapper.js deleted file mode 100644 index 6062ea8f7803..000000000000 --- a/src/components/FormAlertWrapper.js +++ /dev/null @@ -1,95 +0,0 @@ -import PropTypes from 'prop-types'; -import React from 'react'; -import {View} from 'react-native'; -import _ from 'underscore'; -import useThemeStyles from '@hooks/useThemeStyles'; -import compose from '@libs/compose'; -import FormHelpMessage from './FormHelpMessage'; -import networkPropTypes from './networkPropTypes'; -import {withNetwork} from './OnyxProvider'; -import RenderHTML from './RenderHTML'; -import Text from './Text'; -import TextLink from './TextLink'; -import withLocalize, {withLocalizePropTypes} from './withLocalize'; - -const propTypes = { - /** Wrapped child components */ - children: PropTypes.func.isRequired, - - /** Styles for container element */ - // eslint-disable-next-line react/forbid-prop-types - containerStyles: PropTypes.arrayOf(PropTypes.object), - - /** Whether to show the alert text */ - isAlertVisible: PropTypes.bool, - - /** Whether message is in html format */ - isMessageHtml: PropTypes.bool, - - /** Error message to display above button */ - message: PropTypes.string, - - /** Props to detect online status */ - network: networkPropTypes.isRequired, - - /** Callback fired when the "fix the errors" link is pressed */ - onFixTheErrorsLinkPressed: PropTypes.func, - - /** Style for the error message for submit button */ - errorMessageStyle: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.object), PropTypes.object]), - - ...withLocalizePropTypes, -}; - -const defaultProps = { - containerStyles: [], - errorMessageStyle: [], - isAlertVisible: false, - isMessageHtml: false, - message: '', - onFixTheErrorsLinkPressed: () => {}, -}; - -// The FormAlertWrapper offers a standardized way of showing error messages and offline functionality. -// -// This component takes other components as a child prop. It will then render any wrapped components as a function using "render props", -// and passes it a (bool) isOffline parameter. Child components can then use the isOffline variable to determine offline behavior. -function FormAlertWrapper(props) { - const styles = useThemeStyles(); - let children; - if (_.isEmpty(props.message)) { - children = ( - - {`${props.translate('common.please')} `} - - {props.translate('common.fixTheErrors')} - - {` ${props.translate('common.inTheFormBeforeContinuing')}.`} - - ); - } else if (props.isMessageHtml) { - children = ${props.message}`} />; - } - return ( - - {props.isAlertVisible && ( - - {children} - - )} - {props.children(props.network.isOffline)} - - ); -} - -FormAlertWrapper.propTypes = propTypes; -FormAlertWrapper.defaultProps = defaultProps; -FormAlertWrapper.displayName = 'FormAlertWrapper'; - -export default compose(withLocalize, withNetwork())(FormAlertWrapper); diff --git a/src/components/FormAlertWrapper.tsx b/src/components/FormAlertWrapper.tsx new file mode 100644 index 000000000000..a144bf069502 --- /dev/null +++ b/src/components/FormAlertWrapper.tsx @@ -0,0 +1,90 @@ +import React, {ReactNode} from 'react'; +import {StyleProp, View, ViewStyle} from 'react-native'; +import useLocalize from '@hooks/useLocalize'; +import useThemeStyles from '@hooks/useThemeStyles'; +import Network from '@src/types/onyx/Network'; +import FormHelpMessage from './FormHelpMessage'; +import {withNetwork} from './OnyxProvider'; +import RenderHTML from './RenderHTML'; +import Text from './Text'; +import TextLink from './TextLink'; + +type FormAlertWrapperProps = { + /** Wrapped child components */ + children: (isOffline?: boolean) => ReactNode; + + /** Styles for container element */ + containerStyles?: StyleProp; + + /** Style for the error message for submit button */ + errorMessageStyle?: StyleProp; + + /** Whether to show the alert text */ + isAlertVisible?: boolean; + + /** Whether message is in html format */ + isMessageHtml?: boolean; + + /** Error message to display above button */ + message?: string; + + /** Props to detect online status */ + network: Network; + + /** Callback fired when the "fix the errors" link is pressed */ + onFixTheErrorsLinkPressed?: () => void; +}; + +// The FormAlertWrapper offers a standardized way of showing error messages and offline functionality. +// +// This component takes other components as a child prop. It will then render any wrapped components as a function using "render props", +// and passes it a (bool) isOffline parameter. Child components can then use the isOffline variable to determine offline behavior. +function FormAlertWrapper({ + children, + containerStyles, + errorMessageStyle, + isAlertVisible = false, + isMessageHtml = false, + message = '', + network, + onFixTheErrorsLinkPressed = () => {}, +}: FormAlertWrapperProps) { + const styles = useThemeStyles(); + const {translate} = useLocalize(); + + let content; + if (!message?.length) { + content = ( + + {`${translate('common.please')} `} + + {translate('common.fixTheErrors')} + + {` ${translate('common.inTheFormBeforeContinuing')}.`} + + ); + } else if (isMessageHtml) { + content = ${message}`} />; + } + + return ( + + {isAlertVisible && ( + + {content} + + )} + {children(!!network.isOffline)} + + ); +} + +FormAlertWrapper.displayName = 'FormAlertWrapper'; + +export default withNetwork()(FormAlertWrapper);