@gusto/embedded-react-sdk 0.36.0 → 0.37.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +58 -0
- package/README.md +6 -0
- package/dist/UNSTABLE_Hooks.d.ts +1 -1
- package/dist/UNSTABLE_Hooks.js +50 -6
- package/dist/UNSTABLE_Hooks.js.map +1 -1
- package/dist/components/Base/Base.d.ts +8 -9
- package/dist/components/Base/Base.js +123 -101
- package/dist/components/Base/Base.js.map +1 -1
- package/dist/components/Base/index.d.ts +1 -1
- package/dist/components/Base/useBase.d.ts +3 -7
- package/dist/components/Base/useBase.js.map +1 -1
- package/dist/components/Base/useBaseSubmit.d.ts +3 -5
- package/dist/components/Base/useBaseSubmit.js +27 -50
- package/dist/components/Base/useBaseSubmit.js.map +1 -1
- package/dist/components/Common/Fields/CheckboxField/CheckboxField.d.ts +2 -0
- package/dist/components/Common/Fields/CheckboxField/CheckboxField.js +17 -16
- package/dist/components/Common/Fields/CheckboxField/CheckboxField.js.map +1 -1
- package/dist/components/Common/Fields/DatePickerField/DatePickerField.d.ts +5 -3
- package/dist/components/Common/Fields/DatePickerField/DatePickerField.js +46 -36
- package/dist/components/Common/Fields/DatePickerField/DatePickerField.js.map +1 -1
- package/dist/components/Common/Fields/NumberInputField/NumberInputField.d.ts +2 -0
- package/dist/components/Common/Fields/NumberInputField/NumberInputField.js +21 -20
- package/dist/components/Common/Fields/NumberInputField/NumberInputField.js.map +1 -1
- package/dist/components/Common/Fields/RadioGroupField/RadioGroupField.d.ts +3 -1
- package/dist/components/Common/Fields/RadioGroupField/RadioGroupField.js +20 -19
- package/dist/components/Common/Fields/RadioGroupField/RadioGroupField.js.map +1 -1
- package/dist/components/Common/Fields/SelectField/SelectField.d.ts +3 -1
- package/dist/components/Common/Fields/SelectField/SelectField.js +19 -18
- package/dist/components/Common/Fields/SelectField/SelectField.js.map +1 -1
- package/dist/components/Common/Fields/SwitchField/SwitchField.d.ts +2 -0
- package/dist/components/Common/Fields/SwitchField/SwitchField.js +19 -18
- package/dist/components/Common/Fields/SwitchField/SwitchField.js.map +1 -1
- package/dist/components/Common/Fields/TextInputField/TextInputField.d.ts +2 -0
- package/dist/components/Common/Fields/TextInputField/TextInputField.js +10 -9
- package/dist/components/Common/Fields/TextInputField/TextInputField.js.map +1 -1
- package/dist/components/Common/UI/Breadcrumbs/Breadcrumbs.js +1 -1
- package/dist/components/Common/UI/DescriptionList/DescriptionList.module.scss.js +2 -2
- package/dist/components/Common/UI/FileInput/FileInput.js +1 -1
- package/dist/components/Common/UI/ProgressBar/ProgressBar.js +4 -4
- package/dist/components/Company/AssignSignatory/CreateSignatory/useCreateSignatory.js +8 -7
- package/dist/components/Company/AssignSignatory/CreateSignatory/useCreateSignatory.js.map +1 -1
- package/dist/components/Company/AssignSignatory/InviteSignatory/useInviteSignatory.js +8 -7
- package/dist/components/Company/AssignSignatory/InviteSignatory/useInviteSignatory.js.map +1 -1
- package/dist/components/Company/AssignSignatory/useAssignSignatory.js +10 -9
- package/dist/components/Company/AssignSignatory/useAssignSignatory.js.map +1 -1
- package/dist/components/Company/BankAccount/BankAccountForm/context.js +8 -7
- package/dist/components/Company/BankAccount/BankAccountForm/context.js.map +1 -1
- package/dist/components/Company/DocumentSigner/DocumentList/useDocumentList.js +8 -7
- package/dist/components/Company/DocumentSigner/DocumentList/useDocumentList.js.map +1 -1
- package/dist/components/Company/DocumentSigner/SignatureForm/useSignatureForm.js +8 -7
- package/dist/components/Company/DocumentSigner/SignatureForm/useSignatureForm.js.map +1 -1
- package/dist/components/Company/FederalTaxes/useFederalTaxes.js +13 -12
- package/dist/components/Company/FederalTaxes/useFederalTaxes.js.map +1 -1
- package/dist/components/Company/Industry/Context.js +11 -10
- package/dist/components/Company/Industry/Context.js.map +1 -1
- package/dist/components/Company/Locations/LocationForm/useLocationForm.js +8 -7
- package/dist/components/Company/Locations/LocationForm/useLocationForm.js.map +1 -1
- package/dist/components/Company/Locations/LocationsList/useLocationsList.js +8 -7
- package/dist/components/Company/Locations/LocationsList/useLocationsList.js.map +1 -1
- package/dist/components/Company/OnboardingOverview/context.js +8 -7
- package/dist/components/Company/OnboardingOverview/context.js.map +1 -1
- package/dist/components/Company/PaySchedule/PaySchedule.js +60 -60
- package/dist/components/Company/PaySchedule/PaySchedule.js.map +1 -1
- package/dist/components/Company/PaySchedule/usePaySchedule.js +10 -9
- package/dist/components/Company/PaySchedule/usePaySchedule.js.map +1 -1
- package/dist/components/Company/StateTaxes/StateTaxesForm/context.js +8 -7
- package/dist/components/Company/StateTaxes/StateTaxesForm/context.js.map +1 -1
- package/dist/components/Company/StateTaxes/StateTaxesList/context.js +8 -7
- package/dist/components/Company/StateTaxes/StateTaxesList/context.js.map +1 -1
- package/dist/components/Contractor/Address/useAddress.js +10 -9
- package/dist/components/Contractor/Address/useAddress.js.map +1 -1
- package/dist/components/Contractor/Profile/ContractorProfileForm.js +15 -15
- package/dist/components/Contractor/Profile/useContractorProfile.js +41 -38
- package/dist/components/Contractor/Profile/useContractorProfile.js.map +1 -1
- package/dist/components/Employee/Deductions/DeductionsForm/ChildSupportForm.js +7 -6
- package/dist/components/Employee/Deductions/DeductionsForm/ChildSupportForm.js.map +1 -1
- package/dist/components/Employee/Deductions/DeductionsForm/CustomDeductionForm.js +14 -13
- package/dist/components/Employee/Deductions/DeductionsForm/CustomDeductionForm.js.map +1 -1
- package/dist/components/Employee/Deductions/DeductionsForm/GarnishmentForm.js +7 -6
- package/dist/components/Employee/Deductions/DeductionsForm/GarnishmentForm.js.map +1 -1
- package/dist/components/Employee/DocumentSigner/DocumentList/useDocumentList.js +8 -7
- package/dist/components/Employee/DocumentSigner/DocumentList/useDocumentList.js.map +1 -1
- package/dist/components/Employee/DocumentSigner/SignatureForm/useSignatureForm.js +8 -7
- package/dist/components/Employee/DocumentSigner/SignatureForm/useSignatureForm.js.map +1 -1
- package/dist/components/Employee/EmployeeList/useEmployeeList.js +8 -7
- package/dist/components/Employee/EmployeeList/useEmployeeList.js.map +1 -1
- package/dist/components/Employee/FederalTaxes/FederalTaxes.js +42 -42
- package/dist/components/Employee/FederalTaxes/FederalTaxes.js.map +1 -1
- package/dist/components/Employee/FederalTaxes/useFederalTaxes.js +8 -7
- package/dist/components/Employee/FederalTaxes/useFederalTaxes.js.map +1 -1
- package/dist/components/Employee/PaymentMethod/usePaymentMethod.js +10 -9
- package/dist/components/Employee/PaymentMethod/usePaymentMethod.js.map +1 -1
- package/dist/components/Employee/Profile/HomeAddress.d.ts +3 -3
- package/dist/components/Employee/Profile/HomeAddress.js +38 -36
- package/dist/components/Employee/Profile/HomeAddress.js.map +1 -1
- package/dist/components/Employee/Profile/Profile.js +30 -29
- package/dist/components/Employee/Profile/Profile.js.map +1 -1
- package/dist/components/Employee/Profile/useProfile.js +8 -7
- package/dist/components/Employee/Profile/useProfile.js.map +1 -1
- package/dist/components/Employee/StateTaxes/StateTaxes.js +50 -50
- package/dist/components/Employee/StateTaxes/StateTaxes.js.map +1 -1
- package/dist/components/Employee/StateTaxes/useStateTaxes.js +8 -7
- package/dist/components/Employee/StateTaxes/useStateTaxes.js.map +1 -1
- package/dist/components/Employee/Taxes/Taxes.js +53 -53
- package/dist/components/Employee/Taxes/Taxes.js.map +1 -1
- package/dist/components/Employee/Taxes/useTaxes.js +8 -7
- package/dist/components/Employee/Taxes/useTaxes.js.map +1 -1
- package/dist/components/Employee/Terminations/TerminateEmployee/TerminateEmployee.d.ts +11 -0
- package/dist/components/Employee/Terminations/TerminateEmployee/TerminateEmployee.js +123 -0
- package/dist/components/Employee/Terminations/TerminateEmployee/TerminateEmployee.js.map +1 -0
- package/dist/components/Employee/Terminations/TerminateEmployee/TerminateEmployeePresentation.d.ts +11 -0
- package/dist/components/Employee/Terminations/TerminateEmployee/TerminateEmployeePresentation.js +92 -0
- package/dist/components/Employee/Terminations/TerminateEmployee/TerminateEmployeePresentation.js.map +1 -0
- package/dist/components/Employee/Terminations/TerminationFlow/TerminationFlow.d.ts +2 -0
- package/dist/components/Employee/Terminations/TerminationFlow/TerminationFlow.js +30 -0
- package/dist/components/Employee/Terminations/TerminationFlow/TerminationFlow.js.map +1 -0
- package/dist/components/Employee/Terminations/TerminationFlow/TerminationFlowComponents.d.ts +23 -0
- package/dist/components/Employee/Terminations/TerminationFlow/TerminationFlowComponents.js +72 -0
- package/dist/components/Employee/Terminations/TerminationFlow/TerminationFlowComponents.js.map +1 -0
- package/dist/components/Employee/Terminations/TerminationFlow/index.d.ts +3 -0
- package/dist/components/Employee/Terminations/TerminationFlow/terminationStateMachine.d.ts +7 -0
- package/dist/components/Employee/Terminations/TerminationFlow/terminationStateMachine.js +165 -0
- package/dist/components/Employee/Terminations/TerminationFlow/terminationStateMachine.js.map +1 -0
- package/dist/components/Employee/Terminations/TerminationFlow/terminationStateMachine.test.d.ts +1 -0
- package/dist/components/Employee/Terminations/TerminationSummary/TerminationSummary.d.ts +9 -0
- package/dist/components/Employee/Terminations/TerminationSummary/TerminationSummary.js +86 -0
- package/dist/components/Employee/Terminations/TerminationSummary/TerminationSummary.js.map +1 -0
- package/dist/components/Employee/Terminations/TerminationSummary/TerminationSummaryPresentation.d.ts +20 -0
- package/dist/components/Employee/Terminations/TerminationSummary/TerminationSummaryPresentation.js +103 -0
- package/dist/components/Employee/Terminations/TerminationSummary/TerminationSummaryPresentation.js.map +1 -0
- package/dist/components/Employee/Terminations/TerminationsData.d.ts +6 -0
- package/dist/components/Employee/Terminations/index.d.ts +8 -0
- package/dist/components/Employee/Terminations/types.d.ts +1 -0
- package/dist/components/Employee/index.d.ts +7 -0
- package/dist/components/Employee/index.js +34 -28
- package/dist/components/Employee/index.js.map +1 -1
- package/dist/components/InformationRequests/InformationRequests.js +31 -31
- package/dist/components/InformationRequests/InformationRequests.js.map +1 -1
- package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetails.js +41 -41
- package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetails.js.map +1 -1
- package/dist/components/Payroll/Dismissal/DismissalFlow.d.ts +2 -0
- package/dist/components/Payroll/Dismissal/DismissalFlow.js +32 -0
- package/dist/components/Payroll/Dismissal/DismissalFlow.js.map +1 -0
- package/dist/components/Payroll/Dismissal/DismissalFlowComponents.d.ts +16 -0
- package/dist/components/Payroll/Dismissal/DismissalFlowComponents.js +52 -0
- package/dist/components/Payroll/Dismissal/DismissalFlowComponents.js.map +1 -0
- package/dist/components/Payroll/Dismissal/DismissalPayPeriodSelection/DismissalPayPeriodSelection.d.ts +6 -0
- package/dist/components/Payroll/Dismissal/DismissalPayPeriodSelection/DismissalPayPeriodSelection.js +69 -0
- package/dist/components/Payroll/Dismissal/DismissalPayPeriodSelection/DismissalPayPeriodSelection.js.map +1 -0
- package/dist/components/Payroll/Dismissal/DismissalPayPeriodSelection/DismissalPayPeriodSelectionPresentation.d.ts +9 -0
- package/dist/components/Payroll/Dismissal/DismissalPayPeriodSelection/DismissalPayPeriodSelectionPresentation.js +53 -0
- package/dist/components/Payroll/Dismissal/DismissalPayPeriodSelection/DismissalPayPeriodSelectionPresentation.js.map +1 -0
- package/dist/components/Payroll/Dismissal/DismissalPayPeriodSelection/index.d.ts +3 -0
- package/dist/components/Payroll/Dismissal/dismissalStateMachine.d.ts +6 -0
- package/dist/components/Payroll/Dismissal/dismissalStateMachine.js +51 -0
- package/dist/components/Payroll/Dismissal/dismissalStateMachine.js.map +1 -0
- package/dist/components/Payroll/Dismissal/dismissalStateMachine.test.d.ts +1 -0
- package/dist/components/Payroll/Dismissal/index.d.ts +3 -0
- package/dist/components/Payroll/GrossUpModal/GrossUpModal.js +18 -15
- package/dist/components/Payroll/GrossUpModal/GrossUpModal.js.map +1 -1
- package/dist/components/Payroll/OffCycle/OffCycleFlow.d.ts +1 -1
- package/dist/components/Payroll/OffCycle/OffCycleFlow.js +19 -18
- package/dist/components/Payroll/OffCycle/OffCycleFlow.js.map +1 -1
- package/dist/components/Payroll/OffCycle/OffCycleFlowComponents.d.ts +3 -0
- package/dist/components/Payroll/OffCycle/OffCycleFlowComponents.js +32 -24
- package/dist/components/Payroll/OffCycle/OffCycleFlowComponents.js.map +1 -1
- package/dist/components/Payroll/OffCycleCreation/OffCycleCreation.js +45 -45
- package/dist/components/Payroll/OffCycleCreation/OffCycleCreation.js.map +1 -1
- package/dist/components/Payroll/OffCycleCreation/OffCycleCreationPresentation.d.ts +1 -1
- package/dist/components/Payroll/OffCycleCreation/OffCycleCreationPresentation.js +75 -66
- package/dist/components/Payroll/OffCycleCreation/OffCycleCreationPresentation.js.map +1 -1
- package/dist/components/Payroll/OffCycleCreation/OffCycleCreationPresentation.module.scss.js +8 -0
- package/dist/components/Payroll/OffCycleCreation/OffCycleCreationPresentation.module.scss.js.map +1 -0
- package/dist/components/Payroll/OffCycleCreation/OffCycleCreationTypes.d.ts +0 -1
- package/dist/components/Payroll/OffCyclePayPeriodDateForm/OffCyclePayPeriodDateFormPresentation.module.scss.js +4 -4
- package/dist/components/Payroll/OffCyclePayPeriodDateForm/OffCyclePayPeriodDateFormTypes.js +2 -2
- package/dist/components/Payroll/OffCyclePayPeriodDateForm/OffCyclePayPeriodDateFormTypes.js.map +1 -1
- package/dist/components/Payroll/OffCyclePayPeriodDateForm/useOffCyclePayPeriodDateValidation.d.ts +1 -0
- package/dist/components/Payroll/OffCyclePayPeriodDateForm/useOffCyclePayPeriodDateValidation.js +1 -0
- package/dist/components/Payroll/OffCyclePayPeriodDateForm/useOffCyclePayPeriodDateValidation.js.map +1 -1
- package/dist/components/Payroll/PayrollConfiguration/PayrollConfiguration.js +186 -159
- package/dist/components/Payroll/PayrollConfiguration/PayrollConfiguration.js.map +1 -1
- package/dist/components/Payroll/PayrollConfiguration/PayrollConfigurationPresentation.d.ts +3 -3
- package/dist/components/Payroll/PayrollConfiguration/PayrollConfigurationPresentation.js +69 -69
- package/dist/components/Payroll/PayrollConfiguration/PayrollConfigurationPresentation.js.map +1 -1
- package/dist/components/Payroll/PayrollConfiguration/grossUpHelpers.d.ts +3 -2
- package/dist/components/Payroll/PayrollConfiguration/grossUpHelpers.js +8 -8
- package/dist/components/Payroll/PayrollConfiguration/grossUpHelpers.js.map +1 -1
- package/dist/components/Payroll/PayrollConfiguration/usePayrollConfigurationData.d.ts +5 -3
- package/dist/components/Payroll/PayrollConfiguration/usePayrollConfigurationData.js +76 -70
- package/dist/components/Payroll/PayrollConfiguration/usePayrollConfigurationData.js.map +1 -1
- package/dist/components/Payroll/PayrollEditEmployee/PayrollEditEmployee.js +47 -42
- package/dist/components/Payroll/PayrollEditEmployee/PayrollEditEmployee.js.map +1 -1
- package/dist/components/Payroll/PayrollEditEmployee/PayrollEditEmployeePresentation.d.ts +4 -2
- package/dist/components/Payroll/PayrollEditEmployee/PayrollEditEmployeePresentation.js +235 -196
- package/dist/components/Payroll/PayrollEditEmployee/PayrollEditEmployeePresentation.js.map +1 -1
- package/dist/components/Payroll/PayrollFlow/OffCycleFlowContextual.d.ts +1 -0
- package/dist/components/Payroll/PayrollFlow/OffCycleFlowContextual.js +12 -0
- package/dist/components/Payroll/PayrollFlow/OffCycleFlowContextual.js.map +1 -0
- package/dist/components/Payroll/PayrollFlow/PayrollFlowComponents.d.ts +3 -0
- package/dist/components/Payroll/PayrollFlow/PayrollFlowComponents.js.map +1 -1
- package/dist/components/Payroll/PayrollFlow/TransitionFlowContextual.d.ts +1 -0
- package/dist/components/Payroll/PayrollFlow/TransitionFlowContextual.js +21 -0
- package/dist/components/Payroll/PayrollFlow/TransitionFlowContextual.js.map +1 -0
- package/dist/components/Payroll/PayrollFlow/payrollStateMachine.d.ts +2 -0
- package/dist/components/Payroll/PayrollFlow/payrollStateMachine.js +95 -64
- package/dist/components/Payroll/PayrollFlow/payrollStateMachine.js.map +1 -1
- package/dist/components/Payroll/PayrollHistory/PayrollHistory.js +53 -47
- package/dist/components/Payroll/PayrollHistory/PayrollHistory.js.map +1 -1
- package/dist/components/Payroll/PayrollHistory/PayrollHistoryPresentation.js +8 -8
- package/dist/components/Payroll/PayrollHistory/PayrollHistoryPresentation.js.map +1 -1
- package/dist/components/Payroll/PayrollLanding/PayrollLandingFlowComponents.js +25 -23
- package/dist/components/Payroll/PayrollLanding/PayrollLandingFlowComponents.js.map +1 -1
- package/dist/components/Payroll/PayrollList/PayrollList.js +40 -32
- package/dist/components/Payroll/PayrollList/PayrollList.js.map +1 -1
- package/dist/components/Payroll/PayrollList/PayrollListPresentation.d.ts +2 -1
- package/dist/components/Payroll/PayrollList/PayrollListPresentation.js +110 -93
- package/dist/components/Payroll/PayrollList/PayrollListPresentation.js.map +1 -1
- package/dist/components/Payroll/PayrollList/PayrollListPresentation.module.scss.js +12 -8
- package/dist/components/Payroll/PayrollList/PayrollListPresentation.module.scss.js.map +1 -1
- package/dist/components/Payroll/Transition/TransitionFlow.d.ts +2 -0
- package/dist/components/Payroll/Transition/TransitionFlow.js +38 -0
- package/dist/components/Payroll/Transition/TransitionFlow.js.map +1 -0
- package/dist/components/Payroll/Transition/TransitionFlowComponents.d.ts +19 -0
- package/dist/components/Payroll/Transition/TransitionFlowComponents.js +54 -0
- package/dist/components/Payroll/Transition/TransitionFlowComponents.js.map +1 -0
- package/dist/components/Payroll/Transition/index.d.ts +3 -0
- package/dist/components/Payroll/Transition/transitionStateMachine.d.ts +6 -0
- package/dist/components/Payroll/Transition/transitionStateMachine.js +58 -0
- package/dist/components/Payroll/Transition/transitionStateMachine.js.map +1 -0
- package/dist/components/Payroll/Transition/transitionStateMachine.test.d.ts +1 -0
- package/dist/components/Payroll/TransitionCreation/TransitionCreation.d.ts +2 -0
- package/dist/components/Payroll/TransitionCreation/TransitionCreation.js +92 -0
- package/dist/components/Payroll/TransitionCreation/TransitionCreation.js.map +1 -0
- package/dist/components/Payroll/TransitionCreation/TransitionCreationPresentation.d.ts +2 -0
- package/dist/components/Payroll/TransitionCreation/TransitionCreationPresentation.js +111 -0
- package/dist/components/Payroll/TransitionCreation/TransitionCreationPresentation.js.map +1 -0
- package/dist/components/Payroll/TransitionCreation/TransitionCreationPresentation.module.scss.js +8 -0
- package/dist/components/Payroll/TransitionCreation/TransitionCreationPresentation.module.scss.js.map +1 -0
- package/dist/components/Payroll/TransitionCreation/TransitionCreationTypes.d.ts +28 -0
- package/dist/components/Payroll/TransitionCreation/TransitionCreationTypes.js +21 -0
- package/dist/components/Payroll/TransitionCreation/TransitionCreationTypes.js.map +1 -0
- package/dist/components/Payroll/TransitionCreation/index.d.ts +3 -0
- package/dist/components/Payroll/TransitionPayrollAlert/TransitionPayrollAlert.d.ts +8 -0
- package/dist/components/Payroll/TransitionPayrollAlert/TransitionPayrollAlert.js +83 -0
- package/dist/components/Payroll/TransitionPayrollAlert/TransitionPayrollAlert.js.map +1 -0
- package/dist/components/Payroll/TransitionPayrollAlert/TransitionPayrollAlertPresentation.d.ts +16 -0
- package/dist/components/Payroll/TransitionPayrollAlert/TransitionPayrollAlertPresentation.js +100 -0
- package/dist/components/Payroll/TransitionPayrollAlert/TransitionPayrollAlertPresentation.js.map +1 -0
- package/dist/components/Payroll/TransitionPayrollAlert/index.d.ts +2 -0
- package/dist/components/Payroll/helpers.d.ts +2 -1
- package/dist/components/Payroll/helpers.js +98 -87
- package/dist/components/Payroll/helpers.js.map +1 -1
- package/dist/components/Payroll/index.d.ts +6 -0
- package/dist/components/Payroll/index.js +32 -26
- package/dist/components/Payroll/index.js.map +1 -1
- package/dist/components/Payroll/payrollTypes.d.ts +21 -0
- package/dist/components/Payroll/payrollTypes.js +27 -0
- package/dist/components/Payroll/payrollTypes.js.map +1 -0
- package/dist/components/Payroll/usePreparedPayrollData.js +4 -4
- package/dist/components/UNSTABLE_Hooks/collectErrors.d.ts +6 -0
- package/dist/components/UNSTABLE_Hooks/collectErrors.js +9 -0
- package/dist/components/UNSTABLE_Hooks/collectErrors.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/form/FormFieldsMetadataContext.d.ts +8 -0
- package/dist/components/UNSTABLE_Hooks/form/FormFieldsMetadataContext.js +13 -0
- package/dist/components/UNSTABLE_Hooks/form/FormFieldsMetadataContext.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/form/FormFieldsMetadataProvider.d.ts +10 -0
- package/dist/components/UNSTABLE_Hooks/form/FormFieldsMetadataProvider.js +13 -0
- package/dist/components/UNSTABLE_Hooks/form/FormFieldsMetadataProvider.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/form/SDKFormProvider.d.ts +23 -0
- package/dist/components/UNSTABLE_Hooks/form/SDKFormProvider.js +24 -0
- package/dist/components/UNSTABLE_Hooks/form/SDKFormProvider.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/form/composeFormSchema.d.ts +26 -0
- package/dist/components/UNSTABLE_Hooks/form/composeFormSchema.js +24 -0
- package/dist/components/UNSTABLE_Hooks/form/composeFormSchema.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/form/composeSubmitHandler.d.ts +53 -0
- package/dist/components/UNSTABLE_Hooks/form/composeSubmitHandler.js +34 -0
- package/dist/components/UNSTABLE_Hooks/form/composeSubmitHandler.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/form/composeSubmitHandler.test.d.ts +1 -0
- package/dist/components/UNSTABLE_Hooks/form/deriveFieldsMetadata.d.ts +3 -0
- package/dist/components/UNSTABLE_Hooks/form/deriveFieldsMetadata.js +14 -0
- package/dist/components/UNSTABLE_Hooks/form/deriveFieldsMetadata.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/form/deriveFieldsMetadata.test.d.ts +1 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/CheckboxHookField.d.ts +9 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/CheckboxHookField.js +34 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/CheckboxHookField.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/DatePickerHookField.d.ts +9 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/DatePickerHookField.js +29 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/DatePickerHookField.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/NumberInputHookField.d.ts +12 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/NumberInputHookField.js +40 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/NumberInputHookField.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/RadioGroupHookField.d.ts +10 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/RadioGroupHookField.js +40 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/RadioGroupHookField.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/SelectHookField.d.ts +10 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/SelectHookField.js +40 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/SelectHookField.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/SwitchHookField.d.ts +9 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/SwitchHookField.js +34 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/SwitchHookField.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/TextInputHookField.d.ts +11 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/TextInputHookField.js +38 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/TextInputHookField.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/form/fields/index.d.ts +15 -0
- package/dist/components/UNSTABLE_Hooks/form/getFieldWithOptions.d.ts +2 -0
- package/dist/components/UNSTABLE_Hooks/form/getFieldWithOptions.js +8 -0
- package/dist/components/UNSTABLE_Hooks/form/getFieldWithOptions.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/form/getFormSubmissionValues.d.ts +18 -0
- package/dist/components/UNSTABLE_Hooks/form/getFormSubmissionValues.js +10 -0
- package/dist/components/UNSTABLE_Hooks/form/getFormSubmissionValues.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/form/getFormSubmissionValues.test.d.ts +1 -0
- package/dist/components/UNSTABLE_Hooks/form/index.d.ts +14 -0
- package/dist/components/UNSTABLE_Hooks/form/resolveRequiredFields.d.ts +6 -0
- package/dist/components/UNSTABLE_Hooks/form/resolveRequiredFields.js +14 -0
- package/dist/components/UNSTABLE_Hooks/form/resolveRequiredFields.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/form/types.d.ts +27 -0
- package/dist/components/UNSTABLE_Hooks/form/useFieldErrorMessage.d.ts +2 -0
- package/dist/components/UNSTABLE_Hooks/form/useFieldErrorMessage.js +17 -0
- package/dist/components/UNSTABLE_Hooks/form/useFieldErrorMessage.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/form/useFieldsMetadata.d.ts +4 -0
- package/dist/components/UNSTABLE_Hooks/form/useFieldsMetadata.js +9 -0
- package/dist/components/UNSTABLE_Hooks/form/useFieldsMetadata.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/form/withOptions.d.ts +5 -0
- package/dist/components/UNSTABLE_Hooks/form/withOptions.js +7 -0
- package/dist/components/UNSTABLE_Hooks/form/withOptions.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useCompensationForm/CompensationForm.d.ts +5 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useCompensationForm/CompensationForm.js +151 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useCompensationForm/CompensationForm.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useCompensationForm/compensationSchema.d.ts +97 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useCompensationForm/compensationSchema.js +121 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useCompensationForm/compensationSchema.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useCompensationForm/fields.d.ts +34 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useCompensationForm/fields.js +50 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useCompensationForm/fields.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useCompensationForm/index.d.ts +7 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useCompensationForm/useCompensationForm.d.ts +104 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useCompensationForm/useCompensationForm.js +259 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useCompensationForm/useCompensationForm.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/EmployeeDetailsForm.d.ts +5 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/EmployeeDetailsForm.js +114 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/EmployeeDetailsForm.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/employeeDetailsSchema.d.ts +39 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/employeeDetailsSchema.js +45 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/employeeDetailsSchema.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/fields.d.ts +23 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/fields.js +46 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/fields.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/index.d.ts +7 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/useEmployeeDetailsForm.d.ts +77 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/useEmployeeDetailsForm.js +153 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/useEmployeeDetailsForm.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useWorkAddressForm/WorkAddressForm.d.ts +5 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useWorkAddressForm/WorkAddressForm.js +71 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useWorkAddressForm/WorkAddressForm.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useWorkAddressForm/fields.d.ts +10 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useWorkAddressForm/fields.js +14 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useWorkAddressForm/fields.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useWorkAddressForm/index.d.ts +7 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useWorkAddressForm/useWorkAddressForm.d.ts +68 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useWorkAddressForm/useWorkAddressForm.js +129 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useWorkAddressForm/useWorkAddressForm.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useWorkAddressForm/workAddressSchema.d.ts +25 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useWorkAddressForm/workAddressSchema.js +24 -0
- package/dist/components/UNSTABLE_Hooks/hooks/useWorkAddressForm/workAddressSchema.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/index.d.ts +9 -0
- package/dist/components/UNSTABLE_Hooks/types.d.ts +49 -0
- package/dist/components/UNSTABLE_Hooks/useErrorHandling.d.ts +9 -0
- package/dist/components/UNSTABLE_Hooks/useErrorHandling.js +12 -0
- package/dist/components/UNSTABLE_Hooks/useErrorHandling.js.map +1 -0
- package/dist/components/UNSTABLE_Hooks/useErrorHandling.test.d.ts +1 -0
- package/dist/contexts/ApiProvider/ApiProvider.js +11 -11
- package/dist/contexts/ApiProvider/ApiProvider.js.map +1 -1
- package/dist/contexts/GustoProvider/GustoProviderCustomUIAdapter.js +43 -47
- package/dist/contexts/GustoProvider/GustoProviderCustomUIAdapter.js.map +1 -1
- package/dist/contexts/ObservabilityProvider/index.d.ts +1 -1
- package/dist/contexts/ObservabilityProvider/sanitization.d.ts +0 -14
- package/dist/contexts/ObservabilityProvider/sanitization.js +51 -51
- package/dist/contexts/ObservabilityProvider/sanitization.js.map +1 -1
- package/dist/contexts/ObservabilityProvider/useSanitizedObservability.d.ts +0 -3
- package/dist/contexts/ObservabilityProvider/useSanitizedObservability.js.map +1 -1
- package/dist/helpers/requiredIf.d.ts +13 -0
- package/dist/helpers/requiredIf.js +8 -0
- package/dist/helpers/requiredIf.js.map +1 -0
- package/dist/i18n/I18n.js +13 -13
- package/dist/i18n/I18n.js.map +1 -1
- package/dist/i18n/en/Employee.Terminations.TerminateEmployee.json.js +18 -0
- package/dist/i18n/en/Employee.Terminations.TerminateEmployee.json.js.map +1 -0
- package/dist/i18n/en/Employee.Terminations.TerminationFlow.json.js +12 -0
- package/dist/i18n/en/Employee.Terminations.TerminationFlow.json.js.map +1 -0
- package/dist/i18n/en/Employee.Terminations.TerminationSummary.json.js +20 -0
- package/dist/i18n/en/Employee.Terminations.TerminationSummary.json.js.map +1 -0
- package/dist/i18n/en/Payroll.Dismissal.json.js +22 -0
- package/dist/i18n/en/Payroll.Dismissal.json.js.map +1 -0
- package/dist/i18n/en/Payroll.OffCycleCreation.json.js +15 -11
- package/dist/i18n/en/Payroll.OffCycleCreation.json.js.map +1 -1
- package/dist/i18n/en/Payroll.OffCyclePayPeriodDateForm.json.js +1 -1
- package/dist/i18n/en/Payroll.PayrollEditEmployee.json.js +20 -18
- package/dist/i18n/en/Payroll.PayrollEditEmployee.json.js.map +1 -1
- package/dist/i18n/en/Payroll.PayrollList.json.js +20 -18
- package/dist/i18n/en/Payroll.PayrollList.json.js.map +1 -1
- package/dist/i18n/en/Payroll.Transition.json.js +8 -0
- package/dist/i18n/en/Payroll.Transition.json.js.map +1 -0
- package/dist/i18n/en/Payroll.TransitionCreation.json.js +26 -0
- package/dist/i18n/en/Payroll.TransitionCreation.json.js.map +1 -0
- package/dist/i18n/en/Payroll.TransitionPayrollAlert.json.js +18 -0
- package/dist/i18n/en/Payroll.TransitionPayrollAlert.json.js.map +1 -0
- package/dist/i18n/en/UNSTABLE.CompensationForm.json.js +58 -0
- package/dist/i18n/en/UNSTABLE.CompensationForm.json.js.map +1 -0
- package/dist/i18n/en/UNSTABLE.EmployeeDetailsForm.json.js +34 -0
- package/dist/i18n/en/UNSTABLE.EmployeeDetailsForm.json.js.map +1 -0
- package/dist/i18n/en/UNSTABLE.WorkAddressForm.json.js +24 -0
- package/dist/i18n/en/UNSTABLE.WorkAddressForm.json.js.map +1 -0
- package/dist/i18n/en/common.json.d.ts +2 -1
- package/dist/i18n/en/common.json.js +9 -9
- package/dist/index.d.ts +3 -2
- package/dist/index.js +14 -13
- package/dist/models/WA_RISK_CODES.d.ts +5 -2866
- package/dist/models/WA_RISK_CODES.js.map +1 -1
- package/dist/shared/constants.d.ts +32 -0
- package/dist/shared/constants.js +83 -65
- package/dist/shared/constants.js.map +1 -1
- package/dist/style.css +1 -1
- package/dist/types/i18next.d.ts +279 -1
- package/dist/types/observability.d.ts +31 -65
- package/dist/types/sdkError.d.ts +97 -0
- package/dist/types/sdkError.js +95 -0
- package/dist/types/sdkError.js.map +1 -0
- package/dist/types/sdkError.test.d.ts +1 -0
- package/docs/reference/endpoint-inventory.json +212 -14
- package/package.json +16 -16
- package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfiguration.d.ts +0 -6
- package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfiguration.js +0 -70
- package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfiguration.js.map +0 -1
- package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfigurationContext.d.ts +0 -7
- package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfigurationContext.js +0 -6
- package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfigurationContext.js.map +0 -1
- package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfigurationProvider.d.ts +0 -9
- package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfigurationProvider.js +0 -40
- package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfigurationProvider.js.map +0 -1
- package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/index.d.ts +0 -5
- package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/usePayrollConfiguration.d.ts +0 -2
- package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/usePayrollConfiguration.js +0 -12
- package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/usePayrollConfiguration.js.map +0 -1
- package/dist/components/Payroll/UNSTABLE_PayrollHooks/index.d.ts +0 -2
- package/dist/contexts/ObservabilityProvider/observabilityUtils.d.ts +0 -5
- package/dist/contexts/ObservabilityProvider/observabilityUtils.js +0 -45
- package/dist/contexts/ObservabilityProvider/observabilityUtils.js.map +0 -1
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import "./types/i18next.d.ts"
|
|
2
|
+
export { useEmployeeDetailsForm } from './useEmployeeDetailsForm';
|
|
3
|
+
export type { EmployeeDetailsSubmitCallbacks, EmployeeDetailsRequiredFields, UseEmployeeDetailsFormProps, UseEmployeeDetailsFormResult, UseEmployeeDetailsFormReady, EmployeeDetailsFieldsMetadata, EmployeeDetailsFormFields, } from './useEmployeeDetailsForm';
|
|
4
|
+
export { EmployeeDetailsForm } from './EmployeeDetailsForm';
|
|
5
|
+
export type { EmployeeDetailsFormProps } from './EmployeeDetailsForm';
|
|
6
|
+
export { createEmployeeDetailsSchema, EmployeeDetailsErrorCodes, type EmployeeDetailsErrorCode, type EmployeeDetailsFormData, type EmployeeDetailsFormOutputs, type EmployeeDetailsField, } from './employeeDetailsSchema';
|
|
7
|
+
export type { RequiredValidation as EmployeeDetailsRequiredValidation, NameValidation, EmailValidation, SsnValidation, FirstNameFieldProps, MiddleInitialFieldProps, LastNameFieldProps, EmailFieldProps, DateOfBirthFieldProps, SsnFieldProps, SelfOnboardingFieldProps, } from './fields';
|
package/dist/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/useEmployeeDetailsForm.d.ts
ADDED
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import { UseFormProps } from 'react-hook-form';
|
|
2
|
+
import { Employee } from '@gusto/embedded-api/models/components/employee';
|
|
3
|
+
import { HookSubmitResult } from '../../types';
|
|
4
|
+
import { RequiredFields } from '../../form/resolveRequiredFields';
|
|
5
|
+
import { EmployeeDetailsFormData, EmployeeDetailsField } from './employeeDetailsSchema';
|
|
6
|
+
import { FirstNameField, MiddleInitialField, LastNameField, EmailField, DateOfBirthField, SsnField, SelfOnboardingField } from './fields';
|
|
7
|
+
export type EmployeeDetailsRequiredFields = RequiredFields<EmployeeDetailsField>;
|
|
8
|
+
export interface EmployeeDetailsSubmitCallbacks {
|
|
9
|
+
onEmployeeCreated?: (employee: Employee) => void;
|
|
10
|
+
onEmployeeUpdated?: (employee: Employee) => void;
|
|
11
|
+
onOnboardingStatusUpdated?: (status: unknown) => void;
|
|
12
|
+
}
|
|
13
|
+
export interface UseEmployeeDetailsFormProps {
|
|
14
|
+
companyId: string;
|
|
15
|
+
employeeId?: string;
|
|
16
|
+
withSelfOnboardingField?: boolean;
|
|
17
|
+
requiredFields?: EmployeeDetailsRequiredFields;
|
|
18
|
+
defaultValues?: Partial<EmployeeDetailsFormData>;
|
|
19
|
+
validationMode?: UseFormProps['mode'];
|
|
20
|
+
shouldFocusError?: boolean;
|
|
21
|
+
}
|
|
22
|
+
export declare function useEmployeeDetailsForm({ companyId, employeeId, withSelfOnboardingField, requiredFields, defaultValues: partnerDefaults, validationMode, shouldFocusError, }: UseEmployeeDetailsFormProps): {
|
|
23
|
+
isLoading: true;
|
|
24
|
+
errorHandling: import('../..').HookErrorHandling;
|
|
25
|
+
data?: undefined;
|
|
26
|
+
status?: undefined;
|
|
27
|
+
actions?: undefined;
|
|
28
|
+
form?: undefined;
|
|
29
|
+
} | {
|
|
30
|
+
isLoading: false;
|
|
31
|
+
data: {
|
|
32
|
+
employee: Employee | null;
|
|
33
|
+
};
|
|
34
|
+
status: {
|
|
35
|
+
isPending: boolean;
|
|
36
|
+
mode: "create" | "update";
|
|
37
|
+
};
|
|
38
|
+
actions: {
|
|
39
|
+
onSubmit: (callbacks?: EmployeeDetailsSubmitCallbacks) => Promise<HookSubmitResult<Employee> | undefined>;
|
|
40
|
+
};
|
|
41
|
+
errorHandling: import('../..').HookErrorHandling;
|
|
42
|
+
form: {
|
|
43
|
+
Fields: {
|
|
44
|
+
FirstName: typeof FirstNameField;
|
|
45
|
+
MiddleInitial: typeof MiddleInitialField;
|
|
46
|
+
LastName: typeof LastNameField;
|
|
47
|
+
Email: typeof EmailField;
|
|
48
|
+
DateOfBirth: typeof DateOfBirthField;
|
|
49
|
+
Ssn: typeof SsnField;
|
|
50
|
+
SelfOnboarding: typeof SelfOnboardingField | undefined;
|
|
51
|
+
};
|
|
52
|
+
fieldsMetadata: {
|
|
53
|
+
ssn: {
|
|
54
|
+
hasRedactedValue: boolean;
|
|
55
|
+
name: string;
|
|
56
|
+
isRequired?: boolean;
|
|
57
|
+
isDisabled?: boolean;
|
|
58
|
+
};
|
|
59
|
+
email: import('../..').FieldMetadata;
|
|
60
|
+
firstName: import('../..').FieldMetadata;
|
|
61
|
+
lastName: import('../..').FieldMetadata;
|
|
62
|
+
selfOnboarding: import('../..').FieldMetadata;
|
|
63
|
+
middleInitial: import('../..').FieldMetadata;
|
|
64
|
+
dateOfBirth: import('../..').FieldMetadata;
|
|
65
|
+
};
|
|
66
|
+
hookFormInternals: {
|
|
67
|
+
formMethods: import('react-hook-form').UseFormReturn<EmployeeDetailsFormData, unknown, EmployeeDetailsFormData>;
|
|
68
|
+
};
|
|
69
|
+
getFormSubmissionValues: () => EmployeeDetailsFormData | undefined;
|
|
70
|
+
};
|
|
71
|
+
};
|
|
72
|
+
export type UseEmployeeDetailsFormResult = ReturnType<typeof useEmployeeDetailsForm>;
|
|
73
|
+
export type UseEmployeeDetailsFormReady = Extract<UseEmployeeDetailsFormResult, {
|
|
74
|
+
data: object;
|
|
75
|
+
}>;
|
|
76
|
+
export type EmployeeDetailsFieldsMetadata = UseEmployeeDetailsFormReady['form']['fieldsMetadata'];
|
|
77
|
+
export type EmployeeDetailsFormFields = UseEmployeeDetailsFormReady['form']['Fields'];
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
import { useForm as W } from "react-hook-form";
|
|
2
|
+
import { zodResolver as Y } from "@hookform/resolvers/zod";
|
|
3
|
+
import { useEmployeesGet as x } from "@gusto/embedded-api/react-query/employeesGet";
|
|
4
|
+
import { useEmployeesCreateMutation as z } from "@gusto/embedded-api/react-query/employeesCreate";
|
|
5
|
+
import { useEmployeesUpdateMutation as K } from "@gusto/embedded-api/react-query/employeesUpdate";
|
|
6
|
+
import { useEmployeesUpdateOnboardingStatusMutation as Q } from "@gusto/embedded-api/react-query/employeesUpdateOnboardingStatus";
|
|
7
|
+
import { RFCDate as j } from "@gusto/embedded-api/types/rfcdate";
|
|
8
|
+
import { useErrorHandling as k } from "../../useErrorHandling.js";
|
|
9
|
+
import { deriveFieldsMetadata as J } from "../../form/deriveFieldsMetadata.js";
|
|
10
|
+
import { createGetFormSubmissionValues as X } from "../../form/getFormSubmissionValues.js";
|
|
11
|
+
import { createEmployeeDetailsSchema as Z } from "./employeeDetailsSchema.js";
|
|
12
|
+
import { SelfOnboardingField as $, SsnField as ee, DateOfBirthField as te, EmailField as oe, LastNameField as ae, MiddleInitialField as ie, FirstNameField as se } from "./fields.js";
|
|
13
|
+
import { EmployeeOnboardingStatus as t } from "../../../../shared/constants.js";
|
|
14
|
+
import { useBaseSubmit as ne } from "../../../Base/useBaseSubmit.js";
|
|
15
|
+
import { SDKInternalError as O } from "../../../../types/sdkError.js";
|
|
16
|
+
import { removeNonDigits as re } from "../../../../helpers/formattedStrings.js";
|
|
17
|
+
const de = (o) => o?.onboardingStatus ? [
|
|
18
|
+
t.SELF_ONBOARDING_PENDING_INVITE,
|
|
19
|
+
t.SELF_ONBOARDING_INVITED,
|
|
20
|
+
t.SELF_ONBOARDING_INVITED_STARTED,
|
|
21
|
+
t.SELF_ONBOARDING_INVITED_OVERDUE,
|
|
22
|
+
t.SELF_ONBOARDING_COMPLETED_BY_EMPLOYEE,
|
|
23
|
+
t.SELF_ONBOARDING_AWAITING_ADMIN_REVIEW
|
|
24
|
+
].includes(o.onboardingStatus) : !1, me = (o) => o ? o.onboardingStatus === t.ADMIN_ONBOARDING_INCOMPLETE || o.onboardingStatus === t.SELF_ONBOARDING_PENDING_INVITE : !0;
|
|
25
|
+
function Le({
|
|
26
|
+
companyId: o,
|
|
27
|
+
employeeId: a,
|
|
28
|
+
withSelfOnboardingField: A = !0,
|
|
29
|
+
requiredFields: L,
|
|
30
|
+
defaultValues: i,
|
|
31
|
+
validationMode: M = "onSubmit",
|
|
32
|
+
shouldFocusError: G = !0
|
|
33
|
+
}) {
|
|
34
|
+
const m = x({ employeeId: a ?? "" }, { enabled: !!a }), e = m.data?.employee, r = !a, c = me(e), l = Z({
|
|
35
|
+
mode: r ? "create" : "update",
|
|
36
|
+
requiredFields: L,
|
|
37
|
+
hasSsn: e?.hasSsn
|
|
38
|
+
}), p = {
|
|
39
|
+
firstName: e?.firstName ?? i?.firstName ?? "",
|
|
40
|
+
middleInitial: e?.middleInitial ?? i?.middleInitial ?? "",
|
|
41
|
+
lastName: e?.lastName ?? i?.lastName ?? "",
|
|
42
|
+
email: e?.email ?? i?.email ?? "",
|
|
43
|
+
dateOfBirth: e?.dateOfBirth ?? i?.dateOfBirth ?? "",
|
|
44
|
+
ssn: i?.ssn ?? "",
|
|
45
|
+
selfOnboarding: i?.selfOnboarding ?? de(e)
|
|
46
|
+
}, u = W({
|
|
47
|
+
resolver: Y(l),
|
|
48
|
+
mode: M,
|
|
49
|
+
shouldFocusError: G,
|
|
50
|
+
defaultValues: p,
|
|
51
|
+
values: p,
|
|
52
|
+
resetOptions: { keepDirtyValues: !0 }
|
|
53
|
+
}), S = z(), I = K(), g = Q(), R = S.isPending || I.isPending || g.isPending, { baseSubmitHandler: v, error: T, setError: V } = ne("EmployeeDetailsForm"), b = k(a ? [m] : [], { error: T, setError: V }), y = J(l), w = {
|
|
54
|
+
...y,
|
|
55
|
+
ssn: { ...y.ssn, hasRedactedValue: e?.hasSsn ?? !1 }
|
|
56
|
+
}, P = async (E) => {
|
|
57
|
+
let _;
|
|
58
|
+
return await new Promise((D) => {
|
|
59
|
+
u.handleSubmit(
|
|
60
|
+
async (q) => {
|
|
61
|
+
await v(q, async (C) => {
|
|
62
|
+
const { selfOnboarding: f, dateOfBirth: N, ssn: F, ...B } = C, d = F ? re(F) : void 0, h = d && d.length > 0;
|
|
63
|
+
let s;
|
|
64
|
+
if (r) {
|
|
65
|
+
const n = await S.mutateAsync({
|
|
66
|
+
request: {
|
|
67
|
+
companyId: o,
|
|
68
|
+
requestBody: {
|
|
69
|
+
...B,
|
|
70
|
+
selfOnboarding: f,
|
|
71
|
+
dateOfBirth: N ? new j(new Date(N)) : void 0,
|
|
72
|
+
ssn: h ? d : void 0
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
if (!n.employee)
|
|
77
|
+
throw new O("Employee creation failed");
|
|
78
|
+
s = n.employee, E?.onEmployeeCreated?.(s);
|
|
79
|
+
} else {
|
|
80
|
+
if (!e)
|
|
81
|
+
throw new O("Employee data is not available");
|
|
82
|
+
if (c) {
|
|
83
|
+
const U = e.onboardingStatus === t.SELF_ONBOARDING_PENDING_INVITE;
|
|
84
|
+
if (f !== U) {
|
|
85
|
+
const { employeeOnboardingStatus: H } = await g.mutateAsync({
|
|
86
|
+
request: {
|
|
87
|
+
employeeId: e.uuid,
|
|
88
|
+
requestBody: {
|
|
89
|
+
onboardingStatus: f ? t.SELF_ONBOARDING_PENDING_INVITE : t.ADMIN_ONBOARDING_INCOMPLETE
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
});
|
|
93
|
+
E?.onOnboardingStatusUpdated?.(H);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
const n = await I.mutateAsync({
|
|
97
|
+
request: {
|
|
98
|
+
employeeId: e.uuid,
|
|
99
|
+
requestBody: {
|
|
100
|
+
version: e.version,
|
|
101
|
+
...B,
|
|
102
|
+
dateOfBirth: N || void 0,
|
|
103
|
+
ssn: h ? d : void 0
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
});
|
|
107
|
+
if (!n.employee)
|
|
108
|
+
throw new O("Employee update failed");
|
|
109
|
+
s = n.employee, E?.onEmployeeUpdated?.(s);
|
|
110
|
+
}
|
|
111
|
+
_ = {
|
|
112
|
+
mode: r ? "create" : "update",
|
|
113
|
+
data: s
|
|
114
|
+
};
|
|
115
|
+
}), D();
|
|
116
|
+
},
|
|
117
|
+
() => {
|
|
118
|
+
D();
|
|
119
|
+
}
|
|
120
|
+
)();
|
|
121
|
+
}), _;
|
|
122
|
+
};
|
|
123
|
+
return (a ? m.isLoading : !1) || a && !e ? { isLoading: !0, errorHandling: b } : {
|
|
124
|
+
isLoading: !1,
|
|
125
|
+
data: {
|
|
126
|
+
employee: e ?? null
|
|
127
|
+
},
|
|
128
|
+
status: {
|
|
129
|
+
isPending: R,
|
|
130
|
+
mode: r ? "create" : "update"
|
|
131
|
+
},
|
|
132
|
+
actions: { onSubmit: P },
|
|
133
|
+
errorHandling: b,
|
|
134
|
+
form: {
|
|
135
|
+
Fields: {
|
|
136
|
+
FirstName: se,
|
|
137
|
+
MiddleInitial: ie,
|
|
138
|
+
LastName: ae,
|
|
139
|
+
Email: oe,
|
|
140
|
+
DateOfBirth: te,
|
|
141
|
+
Ssn: ee,
|
|
142
|
+
SelfOnboarding: A && c ? $ : void 0
|
|
143
|
+
},
|
|
144
|
+
fieldsMetadata: w,
|
|
145
|
+
hookFormInternals: { formMethods: u },
|
|
146
|
+
getFormSubmissionValues: X(u, l)
|
|
147
|
+
}
|
|
148
|
+
};
|
|
149
|
+
}
|
|
150
|
+
export {
|
|
151
|
+
Le as useEmployeeDetailsForm
|
|
152
|
+
};
|
|
153
|
+
//# sourceMappingURL=useEmployeeDetailsForm.js.map
|
package/dist/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/useEmployeeDetailsForm.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useEmployeeDetailsForm.js","sources":["../../../../../src/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/useEmployeeDetailsForm.tsx"],"sourcesContent":["import { useForm } from 'react-hook-form'\nimport type { UseFormProps } from 'react-hook-form'\nimport { zodResolver } from '@hookform/resolvers/zod'\nimport type { Employee } from '@gusto/embedded-api/models/components/employee'\nimport { useEmployeesGet } from '@gusto/embedded-api/react-query/employeesGet'\nimport { useEmployeesCreateMutation } from '@gusto/embedded-api/react-query/employeesCreate'\nimport { useEmployeesUpdateMutation } from '@gusto/embedded-api/react-query/employeesUpdate'\nimport { useEmployeesUpdateOnboardingStatusMutation } from '@gusto/embedded-api/react-query/employeesUpdateOnboardingStatus'\nimport { RFCDate } from '@gusto/embedded-api/types/rfcdate'\nimport type { HookSubmitResult } from '../../types'\nimport { useErrorHandling } from '../../useErrorHandling'\nimport { deriveFieldsMetadata } from '../../form/deriveFieldsMetadata'\nimport { createGetFormSubmissionValues } from '../../form/getFormSubmissionValues'\nimport type { RequiredFields } from '../../form/resolveRequiredFields'\nimport {\n createEmployeeDetailsSchema,\n type EmployeeDetailsFormData,\n type EmployeeDetailsFormOutputs,\n type EmployeeDetailsField,\n} from './employeeDetailsSchema'\nimport {\n FirstNameField,\n MiddleInitialField,\n LastNameField,\n EmailField,\n DateOfBirthField,\n SsnField,\n SelfOnboardingField,\n} from './fields'\nimport { EmployeeOnboardingStatus } from '@/shared/constants'\nimport { useBaseSubmit } from '@/components/Base/useBaseSubmit'\nimport { SDKInternalError } from '@/types/sdkError'\nimport { removeNonDigits } from '@/helpers/formattedStrings'\n\nexport type EmployeeDetailsRequiredFields = RequiredFields<EmployeeDetailsField>\n\nexport interface EmployeeDetailsSubmitCallbacks {\n onEmployeeCreated?: (employee: Employee) => void\n onEmployeeUpdated?: (employee: Employee) => void\n onOnboardingStatusUpdated?: (status: unknown) => void\n}\n\nexport interface UseEmployeeDetailsFormProps {\n companyId: string\n employeeId?: string\n withSelfOnboardingField?: boolean\n requiredFields?: EmployeeDetailsRequiredFields\n defaultValues?: Partial<EmployeeDetailsFormData>\n validationMode?: UseFormProps['mode']\n shouldFocusError?: boolean\n}\n\nconst isCurrentlySelfOnboarding = (employee?: Employee) => {\n if (!employee?.onboardingStatus) return false\n const selfOnboardingStatuses: string[] = [\n EmployeeOnboardingStatus.SELF_ONBOARDING_PENDING_INVITE,\n EmployeeOnboardingStatus.SELF_ONBOARDING_INVITED,\n EmployeeOnboardingStatus.SELF_ONBOARDING_INVITED_STARTED,\n EmployeeOnboardingStatus.SELF_ONBOARDING_INVITED_OVERDUE,\n EmployeeOnboardingStatus.SELF_ONBOARDING_COMPLETED_BY_EMPLOYEE,\n EmployeeOnboardingStatus.SELF_ONBOARDING_AWAITING_ADMIN_REVIEW,\n ]\n return selfOnboardingStatuses.includes(employee.onboardingStatus)\n}\n\nconst canToggleSelfOnboarding = (employee?: Employee) => {\n if (!employee) return true\n return (\n employee.onboardingStatus === EmployeeOnboardingStatus.ADMIN_ONBOARDING_INCOMPLETE ||\n employee.onboardingStatus === EmployeeOnboardingStatus.SELF_ONBOARDING_PENDING_INVITE\n )\n}\n\nexport function useEmployeeDetailsForm({\n companyId,\n employeeId,\n withSelfOnboardingField = true,\n requiredFields,\n defaultValues: partnerDefaults,\n validationMode = 'onSubmit',\n shouldFocusError = true,\n}: UseEmployeeDetailsFormProps) {\n const employeeQuery = useEmployeesGet({ employeeId: employeeId ?? '' }, { enabled: !!employeeId })\n\n const employee = employeeQuery.data?.employee\n\n const isCreateMode = !employeeId\n const isSelfOnboardingToggleable = canToggleSelfOnboarding(employee)\n\n const mode = isCreateMode ? 'create' : 'update'\n\n const schema = createEmployeeDetailsSchema({\n mode,\n requiredFields,\n hasSsn: employee?.hasSsn,\n })\n\n const resolvedDefaults: EmployeeDetailsFormData = {\n firstName: employee?.firstName ?? partnerDefaults?.firstName ?? '',\n middleInitial: employee?.middleInitial ?? partnerDefaults?.middleInitial ?? '',\n lastName: employee?.lastName ?? partnerDefaults?.lastName ?? '',\n email: employee?.email ?? partnerDefaults?.email ?? '',\n dateOfBirth: employee?.dateOfBirth ?? partnerDefaults?.dateOfBirth ?? '',\n ssn: partnerDefaults?.ssn ?? '',\n selfOnboarding: partnerDefaults?.selfOnboarding ?? isCurrentlySelfOnboarding(employee),\n }\n\n const formMethods = useForm<EmployeeDetailsFormData, unknown, EmployeeDetailsFormOutputs>({\n resolver: zodResolver(schema),\n mode: validationMode,\n shouldFocusError,\n defaultValues: resolvedDefaults,\n values: resolvedDefaults,\n resetOptions: { keepDirtyValues: true },\n })\n\n const createEmployeeMutation = useEmployeesCreateMutation()\n const updateEmployeeMutation = useEmployeesUpdateMutation()\n const updateOnboardingStatusMutation = useEmployeesUpdateOnboardingStatusMutation()\n\n const isPending =\n createEmployeeMutation.isPending ||\n updateEmployeeMutation.isPending ||\n updateOnboardingStatusMutation.isPending\n\n const { baseSubmitHandler, error: submitError, setError } = useBaseSubmit('EmployeeDetailsForm')\n\n const queries = employeeId ? [employeeQuery] : []\n const errorHandling = useErrorHandling(queries, { error: submitError, setError })\n\n const baseMetadata = deriveFieldsMetadata(schema)\n const fieldsMetadata = {\n ...baseMetadata,\n ssn: { ...baseMetadata.ssn, hasRedactedValue: employee?.hasSsn ?? false },\n }\n\n const onSubmit = async (\n callbacks?: EmployeeDetailsSubmitCallbacks,\n ): Promise<HookSubmitResult<Employee> | undefined> => {\n let submitResult: HookSubmitResult<Employee> | undefined\n\n await new Promise<void>(resolve => {\n void formMethods.handleSubmit(\n async (data: EmployeeDetailsFormOutputs) => {\n await baseSubmitHandler(data, async payload => {\n const { selfOnboarding, dateOfBirth, ssn, ...body } = payload\n\n const cleanedSsn = ssn ? removeNonDigits(ssn) : undefined\n const hasSsnInput = cleanedSsn && cleanedSsn.length > 0\n\n let updatedEmployee: Employee\n\n if (isCreateMode) {\n const result = await createEmployeeMutation.mutateAsync({\n request: {\n companyId,\n requestBody: {\n ...body,\n selfOnboarding,\n dateOfBirth: dateOfBirth ? new RFCDate(new Date(dateOfBirth)) : undefined,\n ssn: hasSsnInput ? cleanedSsn : undefined,\n },\n },\n })\n\n if (!result.employee) {\n throw new SDKInternalError('Employee creation failed')\n }\n\n updatedEmployee = result.employee\n callbacks?.onEmployeeCreated?.(updatedEmployee)\n } else {\n if (!employee) {\n throw new SDKInternalError('Employee data is not available')\n }\n\n if (isSelfOnboardingToggleable) {\n const currentIsSelfOnboarding =\n employee.onboardingStatus ===\n EmployeeOnboardingStatus.SELF_ONBOARDING_PENDING_INVITE\n\n if (selfOnboarding !== currentIsSelfOnboarding) {\n const { employeeOnboardingStatus } =\n await updateOnboardingStatusMutation.mutateAsync({\n request: {\n employeeId: employee.uuid,\n requestBody: {\n onboardingStatus: selfOnboarding\n ? EmployeeOnboardingStatus.SELF_ONBOARDING_PENDING_INVITE\n : EmployeeOnboardingStatus.ADMIN_ONBOARDING_INCOMPLETE,\n },\n },\n })\n\n callbacks?.onOnboardingStatusUpdated?.(employeeOnboardingStatus)\n }\n }\n\n const result = await updateEmployeeMutation.mutateAsync({\n request: {\n employeeId: employee.uuid,\n requestBody: {\n version: employee.version as string,\n ...body,\n dateOfBirth: dateOfBirth || undefined,\n ssn: hasSsnInput ? cleanedSsn : undefined,\n },\n },\n })\n\n if (!result.employee) {\n throw new SDKInternalError('Employee update failed')\n }\n\n updatedEmployee = result.employee\n callbacks?.onEmployeeUpdated?.(updatedEmployee)\n }\n\n submitResult = {\n mode: isCreateMode ? 'create' : 'update',\n data: updatedEmployee,\n }\n })\n resolve()\n },\n () => {\n resolve()\n },\n )()\n })\n\n return submitResult\n }\n\n const isDataLoading = employeeId ? employeeQuery.isLoading : false\n\n if (isDataLoading || (employeeId && !employee)) {\n return { isLoading: true as const, errorHandling }\n }\n\n return {\n isLoading: false as const,\n data: {\n employee: employee ?? null,\n },\n status: {\n isPending,\n mode: isCreateMode ? ('create' as const) : ('update' as const),\n },\n actions: { onSubmit },\n errorHandling,\n form: {\n Fields: {\n FirstName: FirstNameField,\n MiddleInitial: MiddleInitialField,\n LastName: LastNameField,\n Email: EmailField,\n DateOfBirth: DateOfBirthField,\n Ssn: SsnField,\n SelfOnboarding:\n withSelfOnboardingField && isSelfOnboardingToggleable ? SelfOnboardingField : undefined,\n },\n fieldsMetadata,\n hookFormInternals: { formMethods },\n getFormSubmissionValues: createGetFormSubmissionValues(formMethods, schema),\n },\n }\n}\n\nexport type UseEmployeeDetailsFormResult = ReturnType<typeof useEmployeeDetailsForm>\nexport type UseEmployeeDetailsFormReady = Extract<UseEmployeeDetailsFormResult, { data: object }>\nexport type EmployeeDetailsFieldsMetadata = UseEmployeeDetailsFormReady['form']['fieldsMetadata']\nexport type EmployeeDetailsFormFields = UseEmployeeDetailsFormReady['form']['Fields']\n"],"names":["isCurrentlySelfOnboarding","employee","EmployeeOnboardingStatus","canToggleSelfOnboarding","useEmployeeDetailsForm","companyId","employeeId","withSelfOnboardingField","requiredFields","partnerDefaults","validationMode","shouldFocusError","employeeQuery","useEmployeesGet","isCreateMode","isSelfOnboardingToggleable","schema","createEmployeeDetailsSchema","resolvedDefaults","formMethods","useForm","zodResolver","createEmployeeMutation","useEmployeesCreateMutation","updateEmployeeMutation","useEmployeesUpdateMutation","updateOnboardingStatusMutation","useEmployeesUpdateOnboardingStatusMutation","isPending","baseSubmitHandler","submitError","setError","useBaseSubmit","errorHandling","useErrorHandling","baseMetadata","deriveFieldsMetadata","fieldsMetadata","onSubmit","callbacks","submitResult","resolve","data","payload","selfOnboarding","dateOfBirth","ssn","body","cleanedSsn","removeNonDigits","hasSsnInput","updatedEmployee","result","RFCDate","SDKInternalError","currentIsSelfOnboarding","employeeOnboardingStatus","FirstNameField","MiddleInitialField","LastNameField","EmailField","DateOfBirthField","SsnField","SelfOnboardingField","createGetFormSubmissionValues"],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { UseWorkAddressFormProps } from './useWorkAddressForm';
|
|
2
|
+
import { BaseComponentInterface } from '../../../Base';
|
|
3
|
+
export interface WorkAddressFormProps extends UseWorkAddressFormProps, Omit<BaseComponentInterface, 'defaultValues'> {
|
|
4
|
+
}
|
|
5
|
+
export declare function WorkAddressForm({ FallbackComponent, ...props }: WorkAddressFormProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { jsx as r, jsxs as p } from "react/jsx-runtime";
|
|
2
|
+
import { useTranslation as E } from "react-i18next";
|
|
3
|
+
import { SDKFormProvider as u } from "../../form/SDKFormProvider.js";
|
|
4
|
+
import { useWorkAddressForm as D } from "./useWorkAddressForm.js";
|
|
5
|
+
import { useComponentContext as A } from "../../../../contexts/ComponentAdapter/useComponentContext.js";
|
|
6
|
+
import { BaseBoundaries as R, BaseLayout as c } from "../../../Base/Base.js";
|
|
7
|
+
import "../../../Base/useBase.js";
|
|
8
|
+
import { Form as L } from "../../../Common/Form/Form.js";
|
|
9
|
+
import { componentEvents as d } from "../../../../shared/constants.js";
|
|
10
|
+
import "classnames";
|
|
11
|
+
import { ActionsLayout as S } from "../../../Common/ActionsLayout/ActionsLayout.js";
|
|
12
|
+
import "react";
|
|
13
|
+
import { useI18n as W, useComponentDictionary as k } from "../../../../i18n/I18n.js";
|
|
14
|
+
import { addressInline as U } from "../../../../helpers/formattedStrings.js";
|
|
15
|
+
function g({ onEvent: i, dictionary: s, ...l }) {
|
|
16
|
+
W("UNSTABLE.WorkAddressForm"), k("UNSTABLE.WorkAddressForm", s);
|
|
17
|
+
const { t: o } = E("UNSTABLE.WorkAddressForm"), m = A(), e = D(l);
|
|
18
|
+
if (e.isLoading)
|
|
19
|
+
return /* @__PURE__ */ r(c, { isLoading: !0, error: e.errorHandling.errors });
|
|
20
|
+
const { Fields: n } = e.form, f = async () => {
|
|
21
|
+
const t = await e.actions.onSubmit({
|
|
22
|
+
onWorkAddressCreated: (a) => {
|
|
23
|
+
i(d.EMPLOYEE_WORK_ADDRESS_CREATED, a);
|
|
24
|
+
},
|
|
25
|
+
onWorkAddressUpdated: (a) => {
|
|
26
|
+
i(d.EMPLOYEE_WORK_ADDRESS_UPDATED, a);
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
t && i(d.EMPLOYEE_WORK_ADDRESS, t.data);
|
|
30
|
+
};
|
|
31
|
+
return /* @__PURE__ */ r(c, { error: e.errorHandling.errors, children: /* @__PURE__ */ r(u, { formHookResult: e, children: /* @__PURE__ */ p(
|
|
32
|
+
L,
|
|
33
|
+
{
|
|
34
|
+
onSubmit: (t) => {
|
|
35
|
+
t.preventDefault(), f();
|
|
36
|
+
},
|
|
37
|
+
children: [
|
|
38
|
+
/* @__PURE__ */ r(m.Heading, { as: "h2", children: e.status.mode === "create" ? o("addTitle") : o("editTitle") }),
|
|
39
|
+
/* @__PURE__ */ r(
|
|
40
|
+
n.Location,
|
|
41
|
+
{
|
|
42
|
+
label: o("locationLabel"),
|
|
43
|
+
description: o("locationDescription"),
|
|
44
|
+
getOptionLabel: (t) => U(t),
|
|
45
|
+
validationMessages: {
|
|
46
|
+
REQUIRED: o("fieldValidations.locationUuid.REQUIRED")
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
),
|
|
50
|
+
n.EffectiveDate && /* @__PURE__ */ r(
|
|
51
|
+
n.EffectiveDate,
|
|
52
|
+
{
|
|
53
|
+
label: o("effectiveDateLabel"),
|
|
54
|
+
description: o("effectiveDateDescription"),
|
|
55
|
+
validationMessages: {
|
|
56
|
+
REQUIRED: o("fieldValidations.effectiveDate.REQUIRED")
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
),
|
|
60
|
+
/* @__PURE__ */ r(S, { children: /* @__PURE__ */ r(m.Button, { type: "submit", isLoading: e.status.isPending, children: e.status.mode === "create" ? o("createCta") : o("updateCta") }) })
|
|
61
|
+
]
|
|
62
|
+
}
|
|
63
|
+
) }) });
|
|
64
|
+
}
|
|
65
|
+
function x({ FallbackComponent: i, ...s }) {
|
|
66
|
+
return /* @__PURE__ */ r(R, { componentName: "UNSTABLE.WorkAddressForm", FallbackComponent: i, children: /* @__PURE__ */ r(g, { ...s }) });
|
|
67
|
+
}
|
|
68
|
+
export {
|
|
69
|
+
x as WorkAddressForm
|
|
70
|
+
};
|
|
71
|
+
//# sourceMappingURL=WorkAddressForm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WorkAddressForm.js","sources":["../../../../../src/components/UNSTABLE_Hooks/hooks/useWorkAddressForm/WorkAddressForm.tsx"],"sourcesContent":["import { useTranslation } from 'react-i18next'\nimport { SDKFormProvider } from '../../form/SDKFormProvider'\nimport { useWorkAddressForm } from './useWorkAddressForm'\nimport type { UseWorkAddressFormProps } from './useWorkAddressForm'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { BaseBoundaries, BaseLayout, type BaseComponentInterface } from '@/components/Base'\nimport { Form } from '@/components/Common/Form'\nimport { ActionsLayout } from '@/components/Common'\nimport { componentEvents } from '@/shared/constants'\nimport { useComponentDictionary, useI18n } from '@/i18n'\nimport { addressInline } from '@/helpers/formattedStrings'\n\nexport interface WorkAddressFormProps\n extends UseWorkAddressFormProps, Omit<BaseComponentInterface, 'defaultValues'> {}\n\nfunction WorkAddressFormRoot({ onEvent, dictionary, ...hookProps }: WorkAddressFormProps) {\n useI18n('UNSTABLE.WorkAddressForm')\n useComponentDictionary('UNSTABLE.WorkAddressForm', dictionary)\n const { t } = useTranslation('UNSTABLE.WorkAddressForm')\n const Components = useComponentContext()\n const workAddress = useWorkAddressForm(hookProps)\n\n if (workAddress.isLoading) {\n return <BaseLayout isLoading error={workAddress.errorHandling.errors} />\n }\n\n const { Fields } = workAddress.form\n\n const handleSubmit = async () => {\n const result = await workAddress.actions.onSubmit({\n onWorkAddressCreated: wa => {\n onEvent(componentEvents.EMPLOYEE_WORK_ADDRESS_CREATED, wa)\n },\n onWorkAddressUpdated: wa => {\n onEvent(componentEvents.EMPLOYEE_WORK_ADDRESS_UPDATED, wa)\n },\n })\n if (result) {\n onEvent(componentEvents.EMPLOYEE_WORK_ADDRESS, result.data)\n }\n }\n\n return (\n <BaseLayout error={workAddress.errorHandling.errors}>\n <SDKFormProvider formHookResult={workAddress}>\n <Form\n onSubmit={e => {\n e.preventDefault()\n void handleSubmit()\n }}\n >\n <Components.Heading as=\"h2\">\n {workAddress.status.mode === 'create' ? t('addTitle') : t('editTitle')}\n </Components.Heading>\n\n <Fields.Location\n label={t('locationLabel')}\n description={t('locationDescription')}\n getOptionLabel={location => addressInline(location)}\n validationMessages={{\n REQUIRED: t('fieldValidations.locationUuid.REQUIRED'),\n }}\n />\n\n {Fields.EffectiveDate && (\n <Fields.EffectiveDate\n label={t('effectiveDateLabel')}\n description={t('effectiveDateDescription')}\n validationMessages={{\n REQUIRED: t('fieldValidations.effectiveDate.REQUIRED'),\n }}\n />\n )}\n\n <ActionsLayout>\n <Components.Button type=\"submit\" isLoading={workAddress.status.isPending}>\n {workAddress.status.mode === 'create' ? t('createCta') : t('updateCta')}\n </Components.Button>\n </ActionsLayout>\n </Form>\n </SDKFormProvider>\n </BaseLayout>\n )\n}\n\nexport function WorkAddressForm({ FallbackComponent, ...props }: WorkAddressFormProps) {\n return (\n <BaseBoundaries componentName=\"UNSTABLE.WorkAddressForm\" FallbackComponent={FallbackComponent}>\n <WorkAddressFormRoot {...props} />\n </BaseBoundaries>\n )\n}\n"],"names":["WorkAddressFormRoot","onEvent","dictionary","hookProps","useI18n","useComponentDictionary","t","useTranslation","Components","useComponentContext","workAddress","useWorkAddressForm","BaseLayout","Fields","handleSubmit","result","wa","componentEvents","jsx","SDKFormProvider","jsxs","Form","e","location","addressInline","ActionsLayout","WorkAddressForm","FallbackComponent","props","BaseBoundaries"],"mappings":";;;;;;;;;;;;;;AAeA,SAASA,EAAoB,EAAE,SAAAC,GAAS,YAAAC,GAAY,GAAGC,KAAmC;AACxF,EAAAC,EAAQ,0BAA0B,GAClCC,EAAuB,4BAA4BH,CAAU;AAC7D,QAAM,EAAE,GAAAI,EAAA,IAAMC,EAAe,0BAA0B,GACjDC,IAAaC,EAAA,GACbC,IAAcC,EAAmBR,CAAS;AAEhD,MAAIO,EAAY;AACd,6BAAQE,GAAA,EAAW,WAAS,IAAC,OAAOF,EAAY,cAAc,QAAQ;AAGxE,QAAM,EAAE,QAAAG,MAAWH,EAAY,MAEzBI,IAAe,YAAY;AAC/B,UAAMC,IAAS,MAAML,EAAY,QAAQ,SAAS;AAAA,MAChD,sBAAsB,CAAAM,MAAM;AAC1B,QAAAf,EAAQgB,EAAgB,+BAA+BD,CAAE;AAAA,MAC3D;AAAA,MACA,sBAAsB,CAAAA,MAAM;AAC1B,QAAAf,EAAQgB,EAAgB,+BAA+BD,CAAE;AAAA,MAC3D;AAAA,IAAA,CACD;AACD,IAAID,KACFd,EAAQgB,EAAgB,uBAAuBF,EAAO,IAAI;AAAA,EAE9D;AAEA,SACE,gBAAAG,EAACN,KAAW,OAAOF,EAAY,cAAc,QAC3C,UAAA,gBAAAQ,EAACC,GAAA,EAAgB,gBAAgBT,GAC/B,UAAA,gBAAAU;AAAA,IAACC;AAAA,IAAA;AAAA,MACC,UAAU,CAAAC,MAAK;AACb,QAAAA,EAAE,eAAA,GACGR,EAAA;AAAA,MACP;AAAA,MAEA,UAAA;AAAA,QAAA,gBAAAI,EAACV,EAAW,SAAX,EAAmB,IAAG,MACpB,UAAAE,EAAY,OAAO,SAAS,WAAWJ,EAAE,UAAU,IAAIA,EAAE,WAAW,GACvE;AAAA,QAEA,gBAAAY;AAAA,UAACL,EAAO;AAAA,UAAP;AAAA,YACC,OAAOP,EAAE,eAAe;AAAA,YACxB,aAAaA,EAAE,qBAAqB;AAAA,YACpC,gBAAgB,CAAAiB,MAAYC,EAAcD,CAAQ;AAAA,YAClD,oBAAoB;AAAA,cAClB,UAAUjB,EAAE,wCAAwC;AAAA,YAAA;AAAA,UACtD;AAAA,QAAA;AAAA,QAGDO,EAAO,iBACN,gBAAAK;AAAA,UAACL,EAAO;AAAA,UAAP;AAAA,YACC,OAAOP,EAAE,oBAAoB;AAAA,YAC7B,aAAaA,EAAE,0BAA0B;AAAA,YACzC,oBAAoB;AAAA,cAClB,UAAUA,EAAE,yCAAyC;AAAA,YAAA;AAAA,UACvD;AAAA,QAAA;AAAA,QAIJ,gBAAAY,EAACO,KACC,UAAA,gBAAAP,EAACV,EAAW,QAAX,EAAkB,MAAK,UAAS,WAAWE,EAAY,OAAO,WAC5D,UAAAA,EAAY,OAAO,SAAS,WAAWJ,EAAE,WAAW,IAAIA,EAAE,WAAW,EAAA,CACxE,EAAA,CACF;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA,GAEJ,EAAA,CACF;AAEJ;AAEO,SAASoB,EAAgB,EAAE,mBAAAC,GAAmB,GAAGC,KAA+B;AACrF,SACE,gBAAAV,EAACW,KAAe,eAAc,4BAA2B,mBAAAF,GACvD,UAAA,gBAAAT,EAAClB,GAAA,EAAqB,GAAG4B,EAAA,CAAO,EAAA,CAClC;AAEJ;"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Location } from '@gusto/embedded-api/models/components/location';
|
|
2
|
+
import { HookFieldProps } from '../../form/types';
|
|
3
|
+
import { SelectHookFieldProps } from '../../form/fields/SelectHookField';
|
|
4
|
+
import { DatePickerHookFieldProps } from '../../form/fields/DatePickerHookField';
|
|
5
|
+
import { WorkAddressErrorCodes } from './workAddressSchema';
|
|
6
|
+
export type RequiredValidation = typeof WorkAddressErrorCodes.REQUIRED;
|
|
7
|
+
export type LocationFieldProps = HookFieldProps<SelectHookFieldProps<RequiredValidation, Location>>;
|
|
8
|
+
export declare function LocationField(props: LocationFieldProps): import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
export type EffectiveDateFieldProps = HookFieldProps<DatePickerHookFieldProps<RequiredValidation>>;
|
|
10
|
+
export declare function EffectiveDateField(props: EffectiveDateFieldProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { jsx as o } from "react/jsx-runtime";
|
|
2
|
+
import { DatePickerHookField as t } from "../../form/fields/DatePickerHookField.js";
|
|
3
|
+
import { SelectHookField as i } from "../../form/fields/SelectHookField.js";
|
|
4
|
+
function c(e) {
|
|
5
|
+
return /* @__PURE__ */ o(i, { ...e, name: "locationUuid" });
|
|
6
|
+
}
|
|
7
|
+
function m(e) {
|
|
8
|
+
return /* @__PURE__ */ o(t, { ...e, name: "effectiveDate" });
|
|
9
|
+
}
|
|
10
|
+
export {
|
|
11
|
+
m as EffectiveDateField,
|
|
12
|
+
c as LocationField
|
|
13
|
+
};
|
|
14
|
+
//# sourceMappingURL=fields.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fields.js","sources":["../../../../../src/components/UNSTABLE_Hooks/hooks/useWorkAddressForm/fields.tsx"],"sourcesContent":["import type { Location } from '@gusto/embedded-api/models/components/location'\nimport type { HookFieldProps } from '../../form/types'\nimport type { SelectHookFieldProps } from '../../form/fields/SelectHookField'\nimport type { DatePickerHookFieldProps } from '../../form/fields/DatePickerHookField'\nimport { SelectHookField, DatePickerHookField } from '../../form/fields'\nimport type { WorkAddressErrorCodes } from './workAddressSchema'\n\nexport type RequiredValidation = typeof WorkAddressErrorCodes.REQUIRED\n\nexport type LocationFieldProps = HookFieldProps<SelectHookFieldProps<RequiredValidation, Location>>\n\nexport function LocationField(props: LocationFieldProps) {\n return <SelectHookField {...props} name=\"locationUuid\" />\n}\n\nexport type EffectiveDateFieldProps = HookFieldProps<DatePickerHookFieldProps<RequiredValidation>>\n\nexport function EffectiveDateField(props: EffectiveDateFieldProps) {\n return <DatePickerHookField {...props} name=\"effectiveDate\" />\n}\n"],"names":["LocationField","props","jsx","SelectHookField","EffectiveDateField","DatePickerHookField"],"mappings":";;;AAWO,SAASA,EAAcC,GAA2B;AACvD,SAAO,gBAAAC,EAACC,GAAA,EAAiB,GAAGF,GAAO,MAAK,gBAAe;AACzD;AAIO,SAASG,EAAmBH,GAAgC;AACjE,SAAO,gBAAAC,EAACG,GAAA,EAAqB,GAAGJ,GAAO,MAAK,iBAAgB;AAC9D;"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import "./types/i18next.d.ts"
|
|
2
|
+
export { useWorkAddressForm } from './useWorkAddressForm';
|
|
3
|
+
export type { WorkAddressSubmitCallbacks, WorkAddressSubmitOptions, WorkAddressRequiredFields, UseWorkAddressFormProps, UseWorkAddressFormResult, UseWorkAddressFormReady, WorkAddressFieldsMetadata, WorkAddressFormFields, } from './useWorkAddressForm';
|
|
4
|
+
export { WorkAddressForm } from './WorkAddressForm';
|
|
5
|
+
export type { WorkAddressFormProps } from './WorkAddressForm';
|
|
6
|
+
export { createWorkAddressSchema, WorkAddressErrorCodes, type WorkAddressErrorCode, type WorkAddressFormData, type WorkAddressFormOutputs, type WorkAddressField, } from './workAddressSchema';
|
|
7
|
+
export type { RequiredValidation as WorkAddressRequiredValidation, LocationFieldProps, EffectiveDateFieldProps, } from './fields';
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { UseFormProps } from 'react-hook-form';
|
|
2
|
+
import { Location } from '@gusto/embedded-api/models/components/location';
|
|
3
|
+
import { EmployeeWorkAddress } from '@gusto/embedded-api/models/components/employeeworkaddress';
|
|
4
|
+
import { HookSubmitResult } from '../../types';
|
|
5
|
+
import { RequiredFields } from '../../form/resolveRequiredFields';
|
|
6
|
+
import { WorkAddressFormData, WorkAddressField } from './workAddressSchema';
|
|
7
|
+
import { LocationField, EffectiveDateField } from './fields';
|
|
8
|
+
export type WorkAddressRequiredFields = RequiredFields<WorkAddressField>;
|
|
9
|
+
export interface WorkAddressSubmitCallbacks {
|
|
10
|
+
onWorkAddressCreated?: (workAddress: EmployeeWorkAddress) => void;
|
|
11
|
+
onWorkAddressUpdated?: (workAddress: EmployeeWorkAddress) => void;
|
|
12
|
+
}
|
|
13
|
+
export interface WorkAddressSubmitOptions {
|
|
14
|
+
employeeId?: string;
|
|
15
|
+
effectiveDate?: string;
|
|
16
|
+
}
|
|
17
|
+
export interface UseWorkAddressFormProps {
|
|
18
|
+
companyId: string;
|
|
19
|
+
employeeId?: string;
|
|
20
|
+
withEffectiveDateField?: boolean;
|
|
21
|
+
requiredFields?: WorkAddressRequiredFields;
|
|
22
|
+
defaultValues?: Partial<WorkAddressFormData>;
|
|
23
|
+
validationMode?: UseFormProps['mode'];
|
|
24
|
+
shouldFocusError?: boolean;
|
|
25
|
+
}
|
|
26
|
+
export declare function useWorkAddressForm({ companyId, employeeId, withEffectiveDateField, requiredFields, defaultValues: partnerDefaults, validationMode, shouldFocusError, }: UseWorkAddressFormProps): {
|
|
27
|
+
isLoading: true;
|
|
28
|
+
errorHandling: import('../..').HookErrorHandling;
|
|
29
|
+
data?: undefined;
|
|
30
|
+
status?: undefined;
|
|
31
|
+
actions?: undefined;
|
|
32
|
+
form?: undefined;
|
|
33
|
+
} | {
|
|
34
|
+
isLoading: false;
|
|
35
|
+
data: {
|
|
36
|
+
workAddress: EmployeeWorkAddress | null;
|
|
37
|
+
workAddresses: EmployeeWorkAddress[] | undefined;
|
|
38
|
+
companyLocations: Location[];
|
|
39
|
+
};
|
|
40
|
+
status: {
|
|
41
|
+
isPending: boolean;
|
|
42
|
+
mode: "create" | "update";
|
|
43
|
+
};
|
|
44
|
+
actions: {
|
|
45
|
+
onSubmit: (callbacks?: WorkAddressSubmitCallbacks, options?: WorkAddressSubmitOptions) => Promise<HookSubmitResult<EmployeeWorkAddress> | undefined>;
|
|
46
|
+
};
|
|
47
|
+
errorHandling: import('../..').HookErrorHandling;
|
|
48
|
+
form: {
|
|
49
|
+
Fields: {
|
|
50
|
+
Location: typeof LocationField;
|
|
51
|
+
EffectiveDate: typeof EffectiveDateField | undefined;
|
|
52
|
+
};
|
|
53
|
+
fieldsMetadata: {
|
|
54
|
+
locationUuid: import('../..').FieldMetadataWithOptions<Location>;
|
|
55
|
+
effectiveDate: import('../..').FieldMetadata;
|
|
56
|
+
};
|
|
57
|
+
hookFormInternals: {
|
|
58
|
+
formMethods: import('react-hook-form').UseFormReturn<WorkAddressFormData, unknown, WorkAddressFormData>;
|
|
59
|
+
};
|
|
60
|
+
getFormSubmissionValues: () => WorkAddressFormData | undefined;
|
|
61
|
+
};
|
|
62
|
+
};
|
|
63
|
+
export type UseWorkAddressFormResult = ReturnType<typeof useWorkAddressForm>;
|
|
64
|
+
export type UseWorkAddressFormReady = Extract<UseWorkAddressFormResult, {
|
|
65
|
+
data: object;
|
|
66
|
+
}>;
|
|
67
|
+
export type WorkAddressFieldsMetadata = UseWorkAddressFormReady['form']['fieldsMetadata'];
|
|
68
|
+
export type WorkAddressFormFields = UseWorkAddressFormReady['form']['Fields'];
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
import { useForm as I } from "react-hook-form";
|
|
2
|
+
import { zodResolver as O } from "@hookform/resolvers/zod";
|
|
3
|
+
import { useLocationsGet as R } from "@gusto/embedded-api/react-query/locationsGet";
|
|
4
|
+
import { useEmployeeAddressesGetWorkAddresses as Q } from "@gusto/embedded-api/react-query/employeeAddressesGetWorkAddresses";
|
|
5
|
+
import { useEmployeeAddressesCreateWorkAddressMutation as x } from "@gusto/embedded-api/react-query/employeeAddressesCreateWorkAddress";
|
|
6
|
+
import { useEmployeeAddressesUpdateWorkAddressMutation as z } from "@gusto/embedded-api/react-query/employeeAddressesUpdateWorkAddress";
|
|
7
|
+
import { RFCDate as K } from "@gusto/embedded-api/types/rfcdate";
|
|
8
|
+
import { useErrorHandling as j } from "../../useErrorHandling.js";
|
|
9
|
+
import { deriveFieldsMetadata as J } from "../../form/deriveFieldsMetadata.js";
|
|
10
|
+
import { createGetFormSubmissionValues as N } from "../../form/getFormSubmissionValues.js";
|
|
11
|
+
import { withOptions as T } from "../../form/withOptions.js";
|
|
12
|
+
import { createWorkAddressSchema as X } from "./workAddressSchema.js";
|
|
13
|
+
import { EffectiveDateField as Y, LocationField as Z } from "./fields.js";
|
|
14
|
+
import { useBaseSubmit as _ } from "../../../Base/useBaseSubmit.js";
|
|
15
|
+
import { SDKInternalError as p } from "../../../../types/sdkError.js";
|
|
16
|
+
import { addressInline as $ } from "../../../../helpers/formattedStrings.js";
|
|
17
|
+
function we({
|
|
18
|
+
companyId: E,
|
|
19
|
+
employeeId: o,
|
|
20
|
+
withEffectiveDateField: u = !0,
|
|
21
|
+
requiredFields: F,
|
|
22
|
+
defaultValues: A,
|
|
23
|
+
validationMode: M = "onSubmit",
|
|
24
|
+
shouldFocusError: S = !0
|
|
25
|
+
}) {
|
|
26
|
+
const d = R({ companyId: E }), m = Q(
|
|
27
|
+
{ employeeId: o ?? "" },
|
|
28
|
+
{ enabled: !!o }
|
|
29
|
+
), a = d.data?.companyLocationsList, c = m.data?.employeeWorkAddressesList, t = c?.find((e) => e.active), s = !t, f = X({
|
|
30
|
+
mode: s ? "create" : "update",
|
|
31
|
+
requiredFields: F,
|
|
32
|
+
withEffectiveDateField: u
|
|
33
|
+
}), k = {
|
|
34
|
+
locationUuid: t?.locationUuid ?? A?.locationUuid ?? "",
|
|
35
|
+
effectiveDate: t?.effectiveDate ?? A?.effectiveDate ?? ""
|
|
36
|
+
}, l = I({
|
|
37
|
+
resolver: O(f),
|
|
38
|
+
mode: M,
|
|
39
|
+
shouldFocusError: S,
|
|
40
|
+
defaultValues: k,
|
|
41
|
+
values: k,
|
|
42
|
+
resetOptions: { keepDirtyValues: !0 }
|
|
43
|
+
}), v = x(), W = z(), h = v.isPending || W.isPending, { baseSubmitHandler: q, error: V, setError: C } = _("WorkAddressForm"), w = j(o ? [d, m] : [d], { error: V, setError: C }), P = (a ?? []).map((e) => ({
|
|
44
|
+
value: e.uuid,
|
|
45
|
+
label: $(e)
|
|
46
|
+
})), y = J(f), B = {
|
|
47
|
+
locationUuid: T(
|
|
48
|
+
y.locationUuid,
|
|
49
|
+
P,
|
|
50
|
+
a ?? []
|
|
51
|
+
),
|
|
52
|
+
effectiveDate: y.effectiveDate
|
|
53
|
+
}, G = async (e, D) => {
|
|
54
|
+
let b;
|
|
55
|
+
return await new Promise((L) => {
|
|
56
|
+
l.handleSubmit(
|
|
57
|
+
async (H) => {
|
|
58
|
+
await q(H, async (n) => {
|
|
59
|
+
const g = D?.employeeId ?? o;
|
|
60
|
+
if (!g)
|
|
61
|
+
throw new p("employeeId is required to submit work address");
|
|
62
|
+
let r;
|
|
63
|
+
if (s) {
|
|
64
|
+
const i = u && n.effectiveDate ? n.effectiveDate : D?.effectiveDate, U = await v.mutateAsync({
|
|
65
|
+
request: {
|
|
66
|
+
employeeId: g,
|
|
67
|
+
requestBody: {
|
|
68
|
+
locationUuid: n.locationUuid,
|
|
69
|
+
effectiveDate: i ? new K(new Date(i)) : void 0
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
if (!U.employeeWorkAddress)
|
|
74
|
+
throw new p("Work address creation failed");
|
|
75
|
+
r = U.employeeWorkAddress, e?.onWorkAddressCreated?.(r);
|
|
76
|
+
} else {
|
|
77
|
+
const i = await W.mutateAsync({
|
|
78
|
+
request: {
|
|
79
|
+
workAddressUuid: t.uuid,
|
|
80
|
+
requestBody: {
|
|
81
|
+
version: t.version,
|
|
82
|
+
locationUuid: n.locationUuid
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
});
|
|
86
|
+
if (!i.employeeWorkAddress)
|
|
87
|
+
throw new p("Work address update failed");
|
|
88
|
+
r = i.employeeWorkAddress, e?.onWorkAddressUpdated?.(r);
|
|
89
|
+
}
|
|
90
|
+
b = {
|
|
91
|
+
mode: s ? "create" : "update",
|
|
92
|
+
data: r
|
|
93
|
+
};
|
|
94
|
+
}), L();
|
|
95
|
+
},
|
|
96
|
+
() => {
|
|
97
|
+
L();
|
|
98
|
+
}
|
|
99
|
+
)();
|
|
100
|
+
}), b;
|
|
101
|
+
};
|
|
102
|
+
return d.isLoading || (o ? m.isLoading : !1) || !a || o && !c ? { isLoading: !0, errorHandling: w } : {
|
|
103
|
+
isLoading: !1,
|
|
104
|
+
data: {
|
|
105
|
+
workAddress: t ?? null,
|
|
106
|
+
workAddresses: c,
|
|
107
|
+
companyLocations: a
|
|
108
|
+
},
|
|
109
|
+
status: {
|
|
110
|
+
isPending: h,
|
|
111
|
+
mode: s ? "create" : "update"
|
|
112
|
+
},
|
|
113
|
+
actions: { onSubmit: G },
|
|
114
|
+
errorHandling: w,
|
|
115
|
+
form: {
|
|
116
|
+
Fields: {
|
|
117
|
+
Location: Z,
|
|
118
|
+
EffectiveDate: u && s ? Y : void 0
|
|
119
|
+
},
|
|
120
|
+
fieldsMetadata: B,
|
|
121
|
+
hookFormInternals: { formMethods: l },
|
|
122
|
+
getFormSubmissionValues: N(l, f)
|
|
123
|
+
}
|
|
124
|
+
};
|
|
125
|
+
}
|
|
126
|
+
export {
|
|
127
|
+
we as useWorkAddressForm
|
|
128
|
+
};
|
|
129
|
+
//# sourceMappingURL=useWorkAddressForm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWorkAddressForm.js","sources":["../../../../../src/components/UNSTABLE_Hooks/hooks/useWorkAddressForm/useWorkAddressForm.tsx"],"sourcesContent":["import { useForm } from 'react-hook-form'\nimport type { UseFormProps } from 'react-hook-form'\nimport { zodResolver } from '@hookform/resolvers/zod'\nimport type { Location } from '@gusto/embedded-api/models/components/location'\nimport type { EmployeeWorkAddress } from '@gusto/embedded-api/models/components/employeeworkaddress'\nimport { useLocationsGet } from '@gusto/embedded-api/react-query/locationsGet'\nimport { useEmployeeAddressesGetWorkAddresses } from '@gusto/embedded-api/react-query/employeeAddressesGetWorkAddresses'\nimport { useEmployeeAddressesCreateWorkAddressMutation } from '@gusto/embedded-api/react-query/employeeAddressesCreateWorkAddress'\nimport { useEmployeeAddressesUpdateWorkAddressMutation } from '@gusto/embedded-api/react-query/employeeAddressesUpdateWorkAddress'\nimport { RFCDate } from '@gusto/embedded-api/types/rfcdate'\nimport type { HookSubmitResult } from '../../types'\nimport { useErrorHandling } from '../../useErrorHandling'\nimport { deriveFieldsMetadata } from '../../form/deriveFieldsMetadata'\nimport { createGetFormSubmissionValues } from '../../form/getFormSubmissionValues'\nimport { withOptions } from '../../form/withOptions'\nimport type { RequiredFields } from '../../form/resolveRequiredFields'\nimport {\n createWorkAddressSchema,\n type WorkAddressFormData,\n type WorkAddressFormOutputs,\n type WorkAddressField,\n} from './workAddressSchema'\nimport { LocationField, EffectiveDateField } from './fields'\nimport { useBaseSubmit } from '@/components/Base/useBaseSubmit'\nimport { SDKInternalError } from '@/types/sdkError'\nimport { addressInline } from '@/helpers/formattedStrings'\n\nexport type WorkAddressRequiredFields = RequiredFields<WorkAddressField>\n\nexport interface WorkAddressSubmitCallbacks {\n onWorkAddressCreated?: (workAddress: EmployeeWorkAddress) => void\n onWorkAddressUpdated?: (workAddress: EmployeeWorkAddress) => void\n}\n\nexport interface WorkAddressSubmitOptions {\n employeeId?: string\n effectiveDate?: string\n}\n\nexport interface UseWorkAddressFormProps {\n companyId: string\n employeeId?: string\n withEffectiveDateField?: boolean\n requiredFields?: WorkAddressRequiredFields\n defaultValues?: Partial<WorkAddressFormData>\n validationMode?: UseFormProps['mode']\n shouldFocusError?: boolean\n}\n\nexport function useWorkAddressForm({\n companyId,\n employeeId,\n withEffectiveDateField = true,\n requiredFields,\n defaultValues: partnerDefaults,\n validationMode = 'onSubmit',\n shouldFocusError = true,\n}: UseWorkAddressFormProps) {\n const locationsQuery = useLocationsGet({ companyId })\n const workAddressesQuery = useEmployeeAddressesGetWorkAddresses(\n { employeeId: employeeId ?? '' },\n { enabled: !!employeeId },\n )\n\n const companyLocations = locationsQuery.data?.companyLocationsList\n const workAddresses = workAddressesQuery.data?.employeeWorkAddressesList\n const currentWorkAddress = workAddresses?.find(address => address.active)\n\n const isCreateMode = !currentWorkAddress\n const mode = isCreateMode ? 'create' : 'update'\n\n const schema = createWorkAddressSchema({\n mode,\n requiredFields,\n withEffectiveDateField,\n })\n\n const resolvedDefaults: WorkAddressFormData = {\n locationUuid: currentWorkAddress?.locationUuid ?? partnerDefaults?.locationUuid ?? '',\n effectiveDate: currentWorkAddress?.effectiveDate ?? partnerDefaults?.effectiveDate ?? '',\n }\n\n const formMethods = useForm<WorkAddressFormData, unknown, WorkAddressFormOutputs>({\n resolver: zodResolver(schema),\n mode: validationMode,\n shouldFocusError,\n defaultValues: resolvedDefaults,\n values: resolvedDefaults,\n resetOptions: { keepDirtyValues: true },\n })\n\n const createWorkAddressMutation = useEmployeeAddressesCreateWorkAddressMutation()\n const updateWorkAddressMutation = useEmployeeAddressesUpdateWorkAddressMutation()\n\n const isPending = createWorkAddressMutation.isPending || updateWorkAddressMutation.isPending\n\n const { baseSubmitHandler, error: submitError, setError } = useBaseSubmit('WorkAddressForm')\n\n const queries = employeeId ? [locationsQuery, workAddressesQuery] : [locationsQuery]\n const errorHandling = useErrorHandling(queries, { error: submitError, setError })\n\n const locationOptions = (companyLocations ?? []).map(location => ({\n value: location.uuid,\n label: addressInline(location),\n }))\n\n const baseMetadata = deriveFieldsMetadata(schema)\n const fieldsMetadata = {\n locationUuid: withOptions<Location>(\n baseMetadata.locationUuid,\n locationOptions,\n companyLocations ?? [],\n ),\n effectiveDate: baseMetadata.effectiveDate,\n }\n\n const onSubmit = async (\n callbacks?: WorkAddressSubmitCallbacks,\n options?: WorkAddressSubmitOptions,\n ): Promise<HookSubmitResult<EmployeeWorkAddress> | undefined> => {\n let submitResult: HookSubmitResult<EmployeeWorkAddress> | undefined\n\n await new Promise<void>(resolve => {\n void formMethods.handleSubmit(\n async (data: WorkAddressFormOutputs) => {\n await baseSubmitHandler(data, async payload => {\n const resolvedEmployeeId = options?.employeeId ?? employeeId\n\n if (!resolvedEmployeeId) {\n throw new SDKInternalError('employeeId is required to submit work address')\n }\n\n let updatedWorkAddress: EmployeeWorkAddress\n\n if (isCreateMode) {\n const resolvedEffectiveDate =\n withEffectiveDateField && payload.effectiveDate\n ? payload.effectiveDate\n : options?.effectiveDate\n\n const result = await createWorkAddressMutation.mutateAsync({\n request: {\n employeeId: resolvedEmployeeId,\n requestBody: {\n locationUuid: payload.locationUuid,\n effectiveDate: resolvedEffectiveDate\n ? new RFCDate(new Date(resolvedEffectiveDate))\n : undefined,\n },\n },\n })\n\n if (!result.employeeWorkAddress) {\n throw new SDKInternalError('Work address creation failed')\n }\n\n updatedWorkAddress = result.employeeWorkAddress\n callbacks?.onWorkAddressCreated?.(updatedWorkAddress)\n } else {\n const result = await updateWorkAddressMutation.mutateAsync({\n request: {\n workAddressUuid: currentWorkAddress.uuid,\n requestBody: {\n version: currentWorkAddress.version,\n locationUuid: payload.locationUuid,\n },\n },\n })\n\n if (!result.employeeWorkAddress) {\n throw new SDKInternalError('Work address update failed')\n }\n\n updatedWorkAddress = result.employeeWorkAddress\n callbacks?.onWorkAddressUpdated?.(updatedWorkAddress)\n }\n\n submitResult = {\n mode: isCreateMode ? 'create' : 'update',\n data: updatedWorkAddress,\n }\n })\n resolve()\n },\n () => {\n resolve()\n },\n )()\n })\n\n return submitResult\n }\n\n const isDataLoading =\n locationsQuery.isLoading || (employeeId ? workAddressesQuery.isLoading : false)\n\n if (isDataLoading || !companyLocations || (employeeId && !workAddresses)) {\n return { isLoading: true as const, errorHandling }\n }\n\n return {\n isLoading: false as const,\n data: {\n workAddress: currentWorkAddress ?? null,\n workAddresses,\n companyLocations,\n },\n status: {\n isPending,\n mode: isCreateMode ? ('create' as const) : ('update' as const),\n },\n actions: { onSubmit },\n errorHandling,\n form: {\n Fields: {\n Location: LocationField,\n EffectiveDate: withEffectiveDateField && isCreateMode ? EffectiveDateField : undefined,\n },\n fieldsMetadata,\n hookFormInternals: { formMethods },\n getFormSubmissionValues: createGetFormSubmissionValues(formMethods, schema),\n },\n }\n}\n\nexport type UseWorkAddressFormResult = ReturnType<typeof useWorkAddressForm>\nexport type UseWorkAddressFormReady = Extract<UseWorkAddressFormResult, { data: object }>\nexport type WorkAddressFieldsMetadata = UseWorkAddressFormReady['form']['fieldsMetadata']\nexport type WorkAddressFormFields = UseWorkAddressFormReady['form']['Fields']\n"],"names":["useWorkAddressForm","companyId","employeeId","withEffectiveDateField","requiredFields","partnerDefaults","validationMode","shouldFocusError","locationsQuery","useLocationsGet","workAddressesQuery","useEmployeeAddressesGetWorkAddresses","companyLocations","workAddresses","currentWorkAddress","address","isCreateMode","schema","createWorkAddressSchema","resolvedDefaults","formMethods","useForm","zodResolver","createWorkAddressMutation","useEmployeeAddressesCreateWorkAddressMutation","updateWorkAddressMutation","useEmployeeAddressesUpdateWorkAddressMutation","isPending","baseSubmitHandler","submitError","setError","useBaseSubmit","errorHandling","useErrorHandling","locationOptions","location","addressInline","baseMetadata","deriveFieldsMetadata","fieldsMetadata","withOptions","onSubmit","callbacks","options","submitResult","resolve","data","payload","resolvedEmployeeId","SDKInternalError","updatedWorkAddress","resolvedEffectiveDate","result","RFCDate","LocationField","EffectiveDateField","createGetFormSubmissionValues"],"mappings":"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"}
|