|
1 |
| -import React from 'react'; |
| 1 | +import React, {useCallback} from 'react'; |
| 2 | +import {useOnyx} from 'react-native-onyx'; |
| 3 | +import CheckboxWithLabel from '@components/CheckboxWithLabel'; |
2 | 4 | import FormProvider from '@components/Form/FormProvider';
|
| 5 | +import InputWrapper from '@components/Form/InputWrapper'; |
| 6 | +import type {FormInputErrors, FormOnyxValues} from '@components/Form/types'; |
3 | 7 | import Text from '@components/Text';
|
| 8 | +import TextLink from '@components/TextLink'; |
4 | 9 | import useLocalize from '@hooks/useLocalize';
|
5 | 10 | import type {SubStepProps} from '@hooks/useSubStep/types';
|
6 | 11 | import useThemeStyles from '@hooks/useThemeStyles';
|
| 12 | +import * as ValidationUtils from '@libs/ValidationUtils'; |
7 | 13 | import ONYXKEYS from '@src/ONYXKEYS';
|
| 14 | +import INPUT_IDS from '@src/types/form/ReimbursementAccountForm'; |
| 15 | + |
| 16 | +const {AUTHORIZED_TO_BIND_CLIENT_TO_AGREEMENT, PROVIDE_TRUTHFUL_INFORMATION, AGREE_TO_TERMS_AND_CONDITIONS} = INPUT_IDS.ADDITIONAL_DATA.CORPAY; |
| 17 | +const STEP_FIELDS = [AUTHORIZED_TO_BIND_CLIENT_TO_AGREEMENT, PROVIDE_TRUTHFUL_INFORMATION, AGREE_TO_TERMS_AND_CONDITIONS]; |
| 18 | + |
| 19 | +function IsAuthorizedToUseBankAccountLabel() { |
| 20 | + const {translate} = useLocalize(); |
| 21 | + return <Text>{translate('agreementsStep.iAmAuthorized')}</Text>; |
| 22 | +} |
| 23 | + |
| 24 | +function CertifyTrueAndAccurateLabel() { |
| 25 | + const {translate} = useLocalize(); |
| 26 | + return <Text>{translate('agreementsStep.iCertify')}</Text>; |
| 27 | +} |
| 28 | + |
| 29 | +function TermsAndConditionsLabel() { |
| 30 | + const {translate} = useLocalize(); |
| 31 | + return ( |
| 32 | + <Text> |
| 33 | + {translate('common.iAcceptThe')} |
| 34 | + <TextLink href="https://cross-border.corpay.com/tc/">{`${translate('agreementsStep.termsAndConditions')}`}</TextLink> |
| 35 | + </Text> |
| 36 | + ); |
| 37 | +} |
8 | 38 |
|
9 | 39 | function Confirmation({onNext}: SubStepProps) {
|
10 | 40 | const {translate} = useLocalize();
|
11 | 41 | const styles = useThemeStyles();
|
12 | 42 |
|
| 43 | + const [reimbursementAccount] = useOnyx(ONYXKEYS.REIMBURSEMENT_ACCOUNT); |
| 44 | + const [reimbursementAccountDraft] = useOnyx(ONYXKEYS.FORMS.REIMBURSEMENT_ACCOUNT_FORM_DRAFT); |
| 45 | + |
| 46 | + const defaultValues = { |
| 47 | + [AUTHORIZED_TO_BIND_CLIENT_TO_AGREEMENT]: |
| 48 | + !!reimbursementAccount?.achData?.additionalData?.corpay?.[AUTHORIZED_TO_BIND_CLIENT_TO_AGREEMENT] ?? reimbursementAccountDraft?.[AUTHORIZED_TO_BIND_CLIENT_TO_AGREEMENT] ?? '', |
| 49 | + [PROVIDE_TRUTHFUL_INFORMATION]: |
| 50 | + !!reimbursementAccount?.achData?.additionalData?.corpay?.[PROVIDE_TRUTHFUL_INFORMATION] ?? reimbursementAccountDraft?.[PROVIDE_TRUTHFUL_INFORMATION] ?? '', |
| 51 | + [AGREE_TO_TERMS_AND_CONDITIONS]: |
| 52 | + !!reimbursementAccount?.achData?.additionalData?.corpay?.[AGREE_TO_TERMS_AND_CONDITIONS] ?? reimbursementAccountDraft?.[AGREE_TO_TERMS_AND_CONDITIONS] ?? '', |
| 53 | + }; |
| 54 | + |
| 55 | + const validate = useCallback( |
| 56 | + (values: FormOnyxValues<typeof ONYXKEYS.FORMS.REIMBURSEMENT_ACCOUNT_FORM>): FormInputErrors<typeof ONYXKEYS.FORMS.REIMBURSEMENT_ACCOUNT_FORM> => { |
| 57 | + const errors = ValidationUtils.getFieldRequiredErrors(values, STEP_FIELDS); |
| 58 | + |
| 59 | + if (!ValidationUtils.isRequiredFulfilled(values[AUTHORIZED_TO_BIND_CLIENT_TO_AGREEMENT])) { |
| 60 | + errors[AUTHORIZED_TO_BIND_CLIENT_TO_AGREEMENT] = translate('agreementsStep.error.authorized'); |
| 61 | + } |
| 62 | + |
| 63 | + if (!ValidationUtils.isRequiredFulfilled(values[PROVIDE_TRUTHFUL_INFORMATION])) { |
| 64 | + errors[PROVIDE_TRUTHFUL_INFORMATION] = translate('agreementsStep.error.certify'); |
| 65 | + } |
| 66 | + |
| 67 | + if (!ValidationUtils.isRequiredFulfilled(values[AGREE_TO_TERMS_AND_CONDITIONS])) { |
| 68 | + errors[AGREE_TO_TERMS_AND_CONDITIONS] = translate('common.error.acceptTerms'); |
| 69 | + } |
| 70 | + |
| 71 | + return errors; |
| 72 | + }, |
| 73 | + [translate], |
| 74 | + ); |
| 75 | + |
13 | 76 | return (
|
14 | 77 | <FormProvider
|
15 | 78 | formID={ONYXKEYS.FORMS.REIMBURSEMENT_ACCOUNT_FORM}
|
16 | 79 | onSubmit={onNext}
|
| 80 | + validate={validate} |
17 | 81 | submitButtonText={translate('agreementsStep.accept')}
|
18 | 82 | style={[styles.mh5, styles.flexGrow1]}
|
19 | 83 | enabledWhenOffline={false}
|
20 | 84 | >
|
21 | 85 | <Text style={[styles.textHeadlineLineHeightXXL]}>{translate('agreementsStep.pleaseConfirm')}</Text>
|
| 86 | + <Text style={[styles.pv3, styles.textSupporting]}>{translate('agreementsStep.regulationRequiresUs')}</Text> |
| 87 | + <InputWrapper |
| 88 | + InputComponent={CheckboxWithLabel} |
| 89 | + accessibilityLabel={translate('agreementsStep.iAmAuthorized')} |
| 90 | + inputID={AUTHORIZED_TO_BIND_CLIENT_TO_AGREEMENT} |
| 91 | + style={styles.mt6} |
| 92 | + LabelComponent={IsAuthorizedToUseBankAccountLabel} |
| 93 | + defaultValue={defaultValues[AUTHORIZED_TO_BIND_CLIENT_TO_AGREEMENT]} |
| 94 | + shouldSaveDraft |
| 95 | + /> |
| 96 | + <InputWrapper |
| 97 | + InputComponent={CheckboxWithLabel} |
| 98 | + accessibilityLabel={translate('agreementsStep.iCertify')} |
| 99 | + inputID={PROVIDE_TRUTHFUL_INFORMATION} |
| 100 | + style={styles.mt6} |
| 101 | + LabelComponent={CertifyTrueAndAccurateLabel} |
| 102 | + defaultValue={defaultValues[PROVIDE_TRUTHFUL_INFORMATION]} |
| 103 | + shouldSaveDraft |
| 104 | + /> |
| 105 | + <InputWrapper |
| 106 | + InputComponent={CheckboxWithLabel} |
| 107 | + accessibilityLabel={`${translate('common.iAcceptThe')} ${translate('agreementsStep.termsAndConditions')}`} |
| 108 | + inputID={AGREE_TO_TERMS_AND_CONDITIONS} |
| 109 | + style={styles.mt6} |
| 110 | + LabelComponent={TermsAndConditionsLabel} |
| 111 | + defaultValue={defaultValues[AGREE_TO_TERMS_AND_CONDITIONS]} |
| 112 | + shouldSaveDraft |
| 113 | + /> |
22 | 114 | </FormProvider>
|
23 | 115 | );
|
24 | 116 | }
|
|
0 commit comments