@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,259 @@
|
|
|
1
|
+
import { useMemo as j, useEffect as Me } from "react";
|
|
2
|
+
import { useForm as ge, useWatch as I } from "react-hook-form";
|
|
3
|
+
import { zodResolver as Ee } from "@hookform/resolvers/zod";
|
|
4
|
+
import { useJobsAndCompensationsGetJobs as he } from "@gusto/embedded-api/react-query/jobsAndCompensationsGetJobs";
|
|
5
|
+
import { useJobsAndCompensationsCreateJobMutation as Oe } from "@gusto/embedded-api/react-query/jobsAndCompensationsCreateJob";
|
|
6
|
+
import { useJobsAndCompensationsUpdateMutation as Fe } from "@gusto/embedded-api/react-query/jobsAndCompensationsUpdate";
|
|
7
|
+
import { useJobsAndCompensationsUpdateCompensationMutation as Pe } from "@gusto/embedded-api/react-query/jobsAndCompensationsUpdateCompensation";
|
|
8
|
+
import { useLocationsGetMinimumWages as Ue } from "@gusto/embedded-api/react-query/locationsGetMinimumWages";
|
|
9
|
+
import { useEmployeeAddressesGetWorkAddresses as De } from "@gusto/embedded-api/react-query/employeeAddressesGetWorkAddresses";
|
|
10
|
+
import { useEmployeesGet as Te } from "@gusto/embedded-api/react-query/employeesGet";
|
|
11
|
+
import { useFederalTaxDetailsGet as Ae } from "@gusto/embedded-api/react-query/federalTaxDetailsGet";
|
|
12
|
+
import { useErrorHandling as Ne } from "../../useErrorHandling.js";
|
|
13
|
+
import { withOptions as f } from "../../form/withOptions.js";
|
|
14
|
+
import { deriveFieldsMetadata as we } from "../../form/deriveFieldsMetadata.js";
|
|
15
|
+
import { createGetFormSubmissionValues as je } from "../../form/getFormSubmissionValues.js";
|
|
16
|
+
import { createCompensationSchema as Ie } from "./compensationSchema.js";
|
|
17
|
+
import { StateWcClassCodeField as Le, StateWcCoveredField as Je, TwoPercentShareholderField as Re, MinimumWageIdField as _e, AdjustForMinimumWageField as qe, PaymentUnitField as Ve, RateField as Ye, FlsaStatusField as He, JobTitleField as Xe, StartDateField as ke } from "./fields.js";
|
|
18
|
+
import { PAY_PERIODS as u, FlsaStatus as s, TIP_CREDITS_UNSUPPORTED_STATES as xe } from "../../../../shared/constants.js";
|
|
19
|
+
import { useBaseSubmit as Ge } from "../../../Base/useBaseSubmit.js";
|
|
20
|
+
import { SDKInternalError as Z } from "../../../../types/sdkError.js";
|
|
21
|
+
import { WA_RISK_CLASS_CODES as ee } from "../../../../models/WA_RISK_CODES.js";
|
|
22
|
+
function Ke(e) {
|
|
23
|
+
return e?.compensations?.find((m) => m.uuid === e.currentCompensationUuid);
|
|
24
|
+
}
|
|
25
|
+
function Qe(e) {
|
|
26
|
+
return e.reduce((m, l) => {
|
|
27
|
+
const S = l.compensations?.find(
|
|
28
|
+
(c) => c.uuid === l.currentCompensationUuid
|
|
29
|
+
);
|
|
30
|
+
return !l.primary || !S ? m : S.flsaStatus ?? m;
|
|
31
|
+
}, void 0);
|
|
32
|
+
}
|
|
33
|
+
const te = Object.keys(s).map((e) => s[e]), $e = te.map((e) => ({
|
|
34
|
+
value: e,
|
|
35
|
+
label: e
|
|
36
|
+
})), oe = [
|
|
37
|
+
u.HOUR,
|
|
38
|
+
u.WEEK,
|
|
39
|
+
u.MONTH,
|
|
40
|
+
u.YEAR,
|
|
41
|
+
u.PAYCHECK
|
|
42
|
+
], Be = oe.map((e) => ({
|
|
43
|
+
value: e,
|
|
44
|
+
label: e
|
|
45
|
+
}));
|
|
46
|
+
function gt({
|
|
47
|
+
employeeId: e,
|
|
48
|
+
withStartDateField: m = !0,
|
|
49
|
+
jobId: l,
|
|
50
|
+
requiredFields: S,
|
|
51
|
+
defaultValues: c,
|
|
52
|
+
validationMode: ae = "onSubmit",
|
|
53
|
+
shouldFocusError: se = !0
|
|
54
|
+
}) {
|
|
55
|
+
const g = he(
|
|
56
|
+
{ employeeId: e ?? "" },
|
|
57
|
+
{ enabled: !!e }
|
|
58
|
+
), E = De(
|
|
59
|
+
{ employeeId: e ?? "" },
|
|
60
|
+
{ enabled: !!e }
|
|
61
|
+
), h = Te({ employeeId: e ?? "" }, { enabled: !!e }), n = g.data?.jobList, L = E.data?.employeeWorkAddressesList, O = L?.find((t) => t.active), J = O?.locationUuid, R = h.data?.employee, F = R?.companyUuid, P = Ue(
|
|
62
|
+
{ locationUuid: J ?? "" },
|
|
63
|
+
{ enabled: !!J }
|
|
64
|
+
), U = Ae(
|
|
65
|
+
{ companyId: F ?? "" },
|
|
66
|
+
{ enabled: !!F }
|
|
67
|
+
), W = P.data?.minimumWageList ?? [], _ = U.data?.federalTaxDetails, q = _?.taxPayerType === "S-Corporation", o = j(() => n ? l ? n.find((t) => t.uuid === l) ?? null : n.length === 1 ? n[0] ?? null : null : null, [n, l]), C = j(() => Ke(o), [o]), ne = j(() => {
|
|
68
|
+
if (n)
|
|
69
|
+
return Qe(n);
|
|
70
|
+
}, [n]), b = !o, D = Ie({
|
|
71
|
+
mode: b ? "create" : "update",
|
|
72
|
+
requiredFields: S,
|
|
73
|
+
withStartDateField: m
|
|
74
|
+
}), T = O?.state, ie = o?.hireDate, y = {
|
|
75
|
+
jobTitle: o?.title || c?.jobTitle || "",
|
|
76
|
+
flsaStatus: C?.flsaStatus ?? ne ?? c?.flsaStatus ?? s.NONEXEMPT,
|
|
77
|
+
rate: Number(C?.rate ?? c?.rate ?? 0),
|
|
78
|
+
adjustForMinimumWage: C?.adjustForMinimumWage ?? !1,
|
|
79
|
+
minimumWageId: C?.minimumWages?.[0]?.uuid ?? "",
|
|
80
|
+
paymentUnit: C?.paymentUnit ?? c?.paymentUnit ?? u.HOUR,
|
|
81
|
+
stateWcCovered: o?.stateWcCovered ?? !1,
|
|
82
|
+
stateWcClassCode: o?.stateWcClassCode ?? "",
|
|
83
|
+
twoPercentShareholder: o?.twoPercentShareholder ?? !1,
|
|
84
|
+
startDate: ie ?? c?.startDate ?? null
|
|
85
|
+
}, a = ge({
|
|
86
|
+
resolver: Ee(D),
|
|
87
|
+
mode: ae,
|
|
88
|
+
shouldFocusError: se,
|
|
89
|
+
defaultValues: y,
|
|
90
|
+
values: y,
|
|
91
|
+
resetOptions: { keepDirtyValues: !0 }
|
|
92
|
+
}), d = I({
|
|
93
|
+
control: a.control,
|
|
94
|
+
name: "flsaStatus"
|
|
95
|
+
}), re = I({
|
|
96
|
+
control: a.control,
|
|
97
|
+
name: "adjustForMinimumWage"
|
|
98
|
+
}), de = I({
|
|
99
|
+
control: a.control,
|
|
100
|
+
name: "stateWcCovered"
|
|
101
|
+
});
|
|
102
|
+
Me(() => {
|
|
103
|
+
d === s.OWNER ? a.setValue("paymentUnit", u.PAYCHECK) : d === s.COMMISSION_ONLY_NONEXEMPT || d === s.COMMISSION_ONLY_EXEMPT ? (a.setValue("paymentUnit", u.YEAR), a.setValue("rate", 0)) : a.setValue("paymentUnit", y.paymentUnit);
|
|
104
|
+
}, [d, a.setValue, y.paymentUnit]);
|
|
105
|
+
const V = Pe(), Y = Oe(), H = Fe(), me = V.isPending || Y.isPending || H.isPending, { baseSubmitHandler: ue, error: le, setError: ce } = Ge("CompensationForm"), X = Ne(e ? [g, E, h, P, U] : [], { error: le, setError: ce }), k = d === s.COMMISSION_ONLY_NONEXEMPT || d === s.COMMISSION_ONLY_EXEMPT, pe = d === s.OWNER, Ce = d !== s.NONEXEMPT || o?.primary === !0 || b, A = d === s.NONEXEMPT && W.length > 0 && T !== void 0 && !xe.includes(T), v = T === "WA", fe = W.map((t) => ({
|
|
106
|
+
value: t.uuid,
|
|
107
|
+
label: `${t.wage} - ${t.authority}: ${t.notes ?? ""}`
|
|
108
|
+
})), Se = ee.map(({ code: t, description: M }) => ({
|
|
109
|
+
value: t,
|
|
110
|
+
label: `${t}: ${M}`
|
|
111
|
+
})), i = we(D), We = {
|
|
112
|
+
startDate: i.startDate,
|
|
113
|
+
jobTitle: i.jobTitle,
|
|
114
|
+
flsaStatus: f(
|
|
115
|
+
i.flsaStatus,
|
|
116
|
+
$e,
|
|
117
|
+
te
|
|
118
|
+
),
|
|
119
|
+
rate: { ...i.rate, isDisabled: k },
|
|
120
|
+
paymentUnit: f(
|
|
121
|
+
{ ...i.paymentUnit, isDisabled: pe || k },
|
|
122
|
+
Be,
|
|
123
|
+
oe
|
|
124
|
+
),
|
|
125
|
+
adjustForMinimumWage: {
|
|
126
|
+
...i.adjustForMinimumWage,
|
|
127
|
+
isDisabled: !A
|
|
128
|
+
},
|
|
129
|
+
minimumWageId: f(
|
|
130
|
+
i.minimumWageId,
|
|
131
|
+
fe,
|
|
132
|
+
W
|
|
133
|
+
),
|
|
134
|
+
twoPercentShareholder: {
|
|
135
|
+
...i.twoPercentShareholder,
|
|
136
|
+
isDisabled: !q
|
|
137
|
+
},
|
|
138
|
+
stateWcCovered: f(
|
|
139
|
+
{ ...i.stateWcCovered, isDisabled: !v },
|
|
140
|
+
[
|
|
141
|
+
{ label: "Yes", value: "true" },
|
|
142
|
+
{ label: "No", value: "false" }
|
|
143
|
+
],
|
|
144
|
+
["yes", "no"]
|
|
145
|
+
),
|
|
146
|
+
stateWcClassCode: f(
|
|
147
|
+
{ ...i.stateWcClassCode, isDisabled: !v },
|
|
148
|
+
Se,
|
|
149
|
+
ee
|
|
150
|
+
)
|
|
151
|
+
}, be = async (t, M) => {
|
|
152
|
+
let x;
|
|
153
|
+
return await new Promise((G) => {
|
|
154
|
+
a.handleSubmit(
|
|
155
|
+
async (ye) => {
|
|
156
|
+
await ue(ye, async (ve) => {
|
|
157
|
+
const K = M?.employeeId ?? e;
|
|
158
|
+
if (!K)
|
|
159
|
+
throw new Z("employeeId is required to submit compensation");
|
|
160
|
+
const {
|
|
161
|
+
jobTitle: Q,
|
|
162
|
+
twoPercentShareholder: $,
|
|
163
|
+
startDate: B,
|
|
164
|
+
...r
|
|
165
|
+
} = ve, N = m && B ? B : M?.startDate;
|
|
166
|
+
let p;
|
|
167
|
+
if (o)
|
|
168
|
+
p = (await H.mutateAsync({
|
|
169
|
+
request: {
|
|
170
|
+
jobId: o.uuid,
|
|
171
|
+
requestBody: {
|
|
172
|
+
title: Q,
|
|
173
|
+
version: o.version,
|
|
174
|
+
hireDate: N,
|
|
175
|
+
stateWcClassCode: r.stateWcCovered ? r.stateWcClassCode : null,
|
|
176
|
+
stateWcCovered: r.stateWcCovered,
|
|
177
|
+
twoPercentShareholder: $ ?? !1
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
})).job, t?.onJobUpdated?.(p);
|
|
181
|
+
else {
|
|
182
|
+
if (!N)
|
|
183
|
+
throw new Z("Start date is required");
|
|
184
|
+
p = (await Y.mutateAsync({
|
|
185
|
+
request: {
|
|
186
|
+
employeeId: K,
|
|
187
|
+
requestBody: {
|
|
188
|
+
title: Q,
|
|
189
|
+
hireDate: N,
|
|
190
|
+
stateWcCovered: r.stateWcCovered,
|
|
191
|
+
stateWcClassCode: r.stateWcCovered ? r.stateWcClassCode : null,
|
|
192
|
+
twoPercentShareholder: $ ?? !1
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
})).job, t?.onJobCreated?.(p);
|
|
196
|
+
}
|
|
197
|
+
const { compensation: z } = await V.mutateAsync({
|
|
198
|
+
request: {
|
|
199
|
+
compensationId: p.currentCompensationUuid,
|
|
200
|
+
compensationsUpdateRequestBody: {
|
|
201
|
+
// eslint-disable-next-line @typescript-eslint/no-non-null-asserted-optional-chain
|
|
202
|
+
version: p.compensations?.find(
|
|
203
|
+
(w) => w.uuid === p.currentCompensationUuid
|
|
204
|
+
)?.version,
|
|
205
|
+
...r,
|
|
206
|
+
rate: String(r.rate),
|
|
207
|
+
minimumWages: r.adjustForMinimumWage ? [{ uuid: r.minimumWageId }] : []
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
});
|
|
211
|
+
t?.onCompensationUpdated?.(z), x = {
|
|
212
|
+
mode: b ? "create" : "update",
|
|
213
|
+
data: z
|
|
214
|
+
};
|
|
215
|
+
}), G();
|
|
216
|
+
},
|
|
217
|
+
() => {
|
|
218
|
+
G();
|
|
219
|
+
}
|
|
220
|
+
)();
|
|
221
|
+
}), x;
|
|
222
|
+
};
|
|
223
|
+
return (e ? g.isLoading || E.isLoading || h.isLoading || P.isLoading || U.isLoading : !1) || e && (!n || !L || !O || !R || !F || !_) ? { isLoading: !0, errorHandling: X } : {
|
|
224
|
+
isLoading: !1,
|
|
225
|
+
data: {
|
|
226
|
+
compensation: C ?? null,
|
|
227
|
+
jobs: n,
|
|
228
|
+
currentJob: o,
|
|
229
|
+
minimumWages: W
|
|
230
|
+
},
|
|
231
|
+
status: {
|
|
232
|
+
isPending: me,
|
|
233
|
+
mode: b ? "create" : "update"
|
|
234
|
+
},
|
|
235
|
+
actions: { onSubmit: be },
|
|
236
|
+
errorHandling: X,
|
|
237
|
+
form: {
|
|
238
|
+
Fields: {
|
|
239
|
+
StartDate: m ? ke : void 0,
|
|
240
|
+
JobTitle: Xe,
|
|
241
|
+
FlsaStatus: Ce ? He : void 0,
|
|
242
|
+
Rate: Ye,
|
|
243
|
+
PaymentUnit: Ve,
|
|
244
|
+
AdjustForMinimumWage: A ? qe : void 0,
|
|
245
|
+
MinimumWageId: A && re ? _e : void 0,
|
|
246
|
+
TwoPercentShareholder: q ? Re : void 0,
|
|
247
|
+
StateWcCovered: v ? Je : void 0,
|
|
248
|
+
StateWcClassCode: v && de ? Le : void 0
|
|
249
|
+
},
|
|
250
|
+
fieldsMetadata: We,
|
|
251
|
+
hookFormInternals: { formMethods: a },
|
|
252
|
+
getFormSubmissionValues: je(a, D)
|
|
253
|
+
}
|
|
254
|
+
};
|
|
255
|
+
}
|
|
256
|
+
export {
|
|
257
|
+
gt as useCompensationForm
|
|
258
|
+
};
|
|
259
|
+
//# sourceMappingURL=useCompensationForm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useCompensationForm.js","sources":["../../../../../src/components/UNSTABLE_Hooks/hooks/useCompensationForm/useCompensationForm.tsx"],"sourcesContent":["import { useEffect, useMemo } from 'react'\nimport { useForm, useWatch } from 'react-hook-form'\nimport type { Resolver, UseFormProps } from 'react-hook-form'\nimport { zodResolver } from '@hookform/resolvers/zod'\nimport type { Compensation, PaymentUnit } from '@gusto/embedded-api/models/components/compensation'\nimport type { Job } from '@gusto/embedded-api/models/components/job'\nimport type { FlsaStatusType } from '@gusto/embedded-api/models/components/flsastatustype'\nimport type { MinimumWage } from '@gusto/embedded-api/models/components/minimumwage'\nimport { useJobsAndCompensationsGetJobs } from '@gusto/embedded-api/react-query/jobsAndCompensationsGetJobs'\nimport { useJobsAndCompensationsCreateJobMutation } from '@gusto/embedded-api/react-query/jobsAndCompensationsCreateJob'\nimport { useJobsAndCompensationsUpdateMutation } from '@gusto/embedded-api/react-query/jobsAndCompensationsUpdate'\nimport { useJobsAndCompensationsUpdateCompensationMutation } from '@gusto/embedded-api/react-query/jobsAndCompensationsUpdateCompensation'\nimport { useLocationsGetMinimumWages } from '@gusto/embedded-api/react-query/locationsGetMinimumWages'\nimport { useEmployeeAddressesGetWorkAddresses } from '@gusto/embedded-api/react-query/employeeAddressesGetWorkAddresses'\nimport { useEmployeesGet } from '@gusto/embedded-api/react-query/employeesGet'\nimport { useFederalTaxDetailsGet } from '@gusto/embedded-api/react-query/federalTaxDetailsGet'\nimport type { HookSubmitResult } from '../../types'\nimport { useErrorHandling } from '../../useErrorHandling'\nimport { withOptions } from '../../form/withOptions'\nimport { deriveFieldsMetadata } from '../../form/deriveFieldsMetadata'\nimport { createGetFormSubmissionValues } from '../../form/getFormSubmissionValues'\nimport type { RequiredFields } from '../../form/resolveRequiredFields'\nimport {\n createCompensationSchema,\n type CompensationField,\n type CompensationFormData,\n type CompensationFormOutputs,\n} from './compensationSchema'\nimport {\n JobTitleField,\n FlsaStatusField,\n RateField,\n PaymentUnitField,\n AdjustForMinimumWageField,\n MinimumWageIdField,\n TwoPercentShareholderField,\n StateWcCoveredField,\n StateWcClassCodeField,\n StartDateField,\n} from './fields'\nimport { FlsaStatus, PAY_PERIODS, TIP_CREDITS_UNSUPPORTED_STATES } from '@/shared/constants'\nimport { useBaseSubmit } from '@/components/Base/useBaseSubmit'\nimport { SDKInternalError } from '@/types/sdkError'\nimport { WA_RISK_CLASS_CODES, type WARiskClassCode } from '@/models/WA_RISK_CODES'\n\nexport interface CompensationSubmitCallbacks {\n onJobCreated?: (job: Job) => void\n onJobUpdated?: (job: Job) => void\n onCompensationUpdated?: (compensation: Compensation | undefined) => void\n}\n\nexport interface CompensationSubmitOptions {\n employeeId?: string\n startDate?: string\n}\n\nexport type CompensationRequiredFields = RequiredFields<CompensationField>\n\nexport interface UseCompensationFormProps {\n employeeId?: string\n withStartDateField?: boolean\n jobId?: string\n requiredFields?: CompensationRequiredFields\n defaultValues?: Partial<CompensationFormData>\n validationMode?: UseFormProps['mode']\n shouldFocusError?: boolean\n}\n\nfunction findCurrentCompensation(job?: Job | null): Compensation | undefined {\n return job?.compensations?.find(comp => comp.uuid === job.currentCompensationUuid)\n}\n\ntype FlsaStatusValue = CompensationFormData['flsaStatus']\n\nfunction derivePrimaryFlsaStatus(jobs: Job[]): FlsaStatusValue | undefined {\n return jobs.reduce<FlsaStatusValue | undefined>((prev, curr) => {\n const compensation = curr.compensations?.find(\n comp => comp.uuid === curr.currentCompensationUuid,\n )\n if (!curr.primary || !compensation) return prev\n return compensation.flsaStatus ?? prev\n }, undefined)\n}\n\nconst flsaStatusEntries: FlsaStatusType[] = (\n Object.keys(FlsaStatus) as Array<keyof typeof FlsaStatus>\n).map(key => FlsaStatus[key])\n\nconst flsaOptions = flsaStatusEntries.map(status => ({\n value: status,\n label: status,\n}))\n\nconst paymentUnitEntries: PaymentUnit[] = [\n PAY_PERIODS.HOUR,\n PAY_PERIODS.WEEK,\n PAY_PERIODS.MONTH,\n PAY_PERIODS.YEAR,\n PAY_PERIODS.PAYCHECK,\n]\n\nconst paymentUnitOptions = paymentUnitEntries.map(unit => ({\n value: unit,\n label: unit,\n}))\n\nexport function useCompensationForm({\n employeeId,\n withStartDateField = true,\n jobId,\n requiredFields,\n defaultValues: partnerDefaults,\n validationMode = 'onSubmit',\n shouldFocusError = true,\n}: UseCompensationFormProps) {\n const jobsQuery = useJobsAndCompensationsGetJobs(\n { employeeId: employeeId ?? '' },\n { enabled: !!employeeId },\n )\n const addressesQuery = useEmployeeAddressesGetWorkAddresses(\n { employeeId: employeeId ?? '' },\n { enabled: !!employeeId },\n )\n const employeeQuery = useEmployeesGet({ employeeId: employeeId ?? '' }, { enabled: !!employeeId })\n\n const employeeJobs = jobsQuery.data?.jobList\n const workAddresses = addressesQuery.data?.employeeWorkAddressesList\n const currentWorkAddress = workAddresses?.find(address => address.active)\n const locationUuid = currentWorkAddress?.locationUuid\n const employee = employeeQuery.data?.employee\n const companyUuid = employee?.companyUuid\n\n const minWagesQuery = useLocationsGetMinimumWages(\n { locationUuid: locationUuid ?? '' },\n { enabled: !!locationUuid },\n )\n\n const taxQuery = useFederalTaxDetailsGet(\n { companyId: companyUuid ?? '' },\n { enabled: !!companyUuid },\n )\n\n const minimumWages = minWagesQuery.data?.minimumWageList ?? []\n const federalTaxDetails = taxQuery.data?.federalTaxDetails\n const showTwoPercentStakeholder = federalTaxDetails?.taxPayerType === 'S-Corporation'\n\n const currentJob = useMemo<Job | null>(() => {\n if (!employeeJobs) return null\n if (jobId) {\n return employeeJobs.find(j => j.uuid === jobId) ?? null\n }\n return employeeJobs.length === 1 ? (employeeJobs[0] ?? null) : null\n }, [employeeJobs, jobId])\n\n const currentCompensation = useMemo(() => findCurrentCompensation(currentJob), [currentJob])\n\n const primaryFlsaStatus = useMemo(() => {\n if (!employeeJobs) return undefined\n return derivePrimaryFlsaStatus(employeeJobs)\n }, [employeeJobs])\n\n const isCreateMode = !currentJob\n const mode = isCreateMode ? 'create' : 'update'\n\n const schema = createCompensationSchema({\n mode,\n requiredFields,\n withStartDateField,\n })\n\n const state = currentWorkAddress?.state\n\n const hireDate = currentJob?.hireDate\n const resolvedDefaults: CompensationFormData = {\n jobTitle: currentJob?.title || partnerDefaults?.jobTitle || '',\n flsaStatus:\n currentCompensation?.flsaStatus ??\n primaryFlsaStatus ??\n partnerDefaults?.flsaStatus ??\n FlsaStatus.NONEXEMPT,\n rate: Number(currentCompensation?.rate ?? partnerDefaults?.rate ?? 0),\n adjustForMinimumWage: currentCompensation?.adjustForMinimumWage ?? false,\n minimumWageId: currentCompensation?.minimumWages?.[0]?.uuid ?? '',\n paymentUnit:\n currentCompensation?.paymentUnit ?? partnerDefaults?.paymentUnit ?? PAY_PERIODS.HOUR,\n stateWcCovered: currentJob?.stateWcCovered ?? false,\n stateWcClassCode: currentJob?.stateWcClassCode ?? '',\n twoPercentShareholder: currentJob?.twoPercentShareholder ?? false,\n startDate: hireDate ?? partnerDefaults?.startDate ?? null,\n }\n\n const formMethods = useForm<CompensationFormData, unknown, CompensationFormOutputs>({\n resolver: zodResolver(schema) as unknown as Resolver<CompensationFormData>,\n mode: validationMode,\n shouldFocusError,\n defaultValues: resolvedDefaults,\n values: resolvedDefaults,\n resetOptions: { keepDirtyValues: true },\n })\n\n const watchedFlsaStatus = useWatch({\n control: formMethods.control,\n name: 'flsaStatus',\n })\n const watchedAdjustForMinimumWage = useWatch({\n control: formMethods.control,\n name: 'adjustForMinimumWage',\n })\n const watchedStateWcCovered = useWatch({\n control: formMethods.control,\n name: 'stateWcCovered',\n })\n\n useEffect(() => {\n if (watchedFlsaStatus === FlsaStatus.OWNER) {\n formMethods.setValue('paymentUnit', PAY_PERIODS.PAYCHECK)\n } else if (\n watchedFlsaStatus === FlsaStatus.COMMISSION_ONLY_NONEXEMPT ||\n watchedFlsaStatus === FlsaStatus.COMMISSION_ONLY_EXEMPT\n ) {\n formMethods.setValue('paymentUnit', PAY_PERIODS.YEAR)\n formMethods.setValue('rate', 0)\n } else {\n formMethods.setValue('paymentUnit', resolvedDefaults.paymentUnit)\n }\n }, [watchedFlsaStatus, formMethods.setValue, resolvedDefaults.paymentUnit])\n\n const updateCompensationMutation = useJobsAndCompensationsUpdateCompensationMutation()\n const createJobMutation = useJobsAndCompensationsCreateJobMutation()\n const updateJobMutation = useJobsAndCompensationsUpdateMutation()\n\n const isPending =\n updateCompensationMutation.isPending ||\n createJobMutation.isPending ||\n updateJobMutation.isPending\n\n const { baseSubmitHandler, error: submitError, setError } = useBaseSubmit('CompensationForm')\n\n const queries = employeeId\n ? [jobsQuery, addressesQuery, employeeQuery, minWagesQuery, taxQuery]\n : []\n const errorHandling = useErrorHandling(queries, { error: submitError, setError })\n\n const isCommissionOnly =\n watchedFlsaStatus === FlsaStatus.COMMISSION_ONLY_NONEXEMPT ||\n watchedFlsaStatus === FlsaStatus.COMMISSION_ONLY_EXEMPT\n\n const isOwner = watchedFlsaStatus === FlsaStatus.OWNER\n\n const isFlsaSelectionEnabled =\n watchedFlsaStatus !== FlsaStatus.NONEXEMPT || currentJob?.primary === true || isCreateMode\n\n const isAdjustMinimumWageEnabled =\n watchedFlsaStatus === FlsaStatus.NONEXEMPT &&\n minimumWages.length > 0 &&\n state !== undefined &&\n !TIP_CREDITS_UNSUPPORTED_STATES.includes(state)\n\n const isWaState = state === 'WA'\n\n const minimumWageOptions = minimumWages.map(wage => ({\n value: wage.uuid,\n label: `${wage.wage} - ${wage.authority}: ${wage.notes ?? ''}`,\n }))\n\n const stateWcClassCodeOptions = WA_RISK_CLASS_CODES.map(({ code, description }) => ({\n value: code,\n label: `${code}: ${description}`,\n }))\n\n const baseMetadata = deriveFieldsMetadata(schema)\n const fieldsMetadata = {\n startDate: baseMetadata.startDate,\n jobTitle: baseMetadata.jobTitle,\n flsaStatus: withOptions<FlsaStatusType>(\n baseMetadata.flsaStatus,\n flsaOptions,\n flsaStatusEntries,\n ),\n rate: { ...baseMetadata.rate, isDisabled: isCommissionOnly },\n paymentUnit: withOptions<PaymentUnit>(\n { ...baseMetadata.paymentUnit, isDisabled: isOwner || isCommissionOnly },\n paymentUnitOptions,\n paymentUnitEntries,\n ),\n adjustForMinimumWage: {\n ...baseMetadata.adjustForMinimumWage,\n isDisabled: !isAdjustMinimumWageEnabled,\n },\n minimumWageId: withOptions<MinimumWage>(\n baseMetadata.minimumWageId,\n minimumWageOptions,\n minimumWages,\n ),\n twoPercentShareholder: {\n ...baseMetadata.twoPercentShareholder,\n isDisabled: !showTwoPercentStakeholder,\n },\n stateWcCovered: withOptions<string>(\n { ...baseMetadata.stateWcCovered, isDisabled: !isWaState },\n [\n { label: 'Yes', value: 'true' },\n { label: 'No', value: 'false' },\n ],\n ['yes', 'no'],\n ),\n stateWcClassCode: withOptions<WARiskClassCode>(\n { ...baseMetadata.stateWcClassCode, isDisabled: !isWaState },\n stateWcClassCodeOptions,\n WA_RISK_CLASS_CODES,\n ),\n }\n\n const onSubmit = async (\n callbacks?: CompensationSubmitCallbacks,\n options?: CompensationSubmitOptions,\n ): Promise<HookSubmitResult<Compensation | undefined> | undefined> => {\n let submitResult: HookSubmitResult<Compensation | undefined> | undefined\n\n await new Promise<void>(resolve => {\n void formMethods.handleSubmit(\n async (data: CompensationFormOutputs) => {\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 compensation')\n }\n\n const {\n jobTitle,\n twoPercentShareholder,\n startDate: formStartDate,\n ...compensationData\n } = payload\n\n const resolvedHireDate =\n withStartDateField && formStartDate ? formStartDate : options?.startDate\n\n let updatedJobData: Job\n\n if (!currentJob) {\n if (!resolvedHireDate) {\n throw new SDKInternalError('Start date is required')\n }\n\n const result = await createJobMutation.mutateAsync({\n request: {\n employeeId: resolvedEmployeeId,\n requestBody: {\n title: jobTitle,\n hireDate: resolvedHireDate,\n stateWcCovered: compensationData.stateWcCovered,\n stateWcClassCode: compensationData.stateWcCovered\n ? compensationData.stateWcClassCode\n : null,\n twoPercentShareholder: twoPercentShareholder ?? false,\n },\n },\n })\n updatedJobData = result.job!\n callbacks?.onJobCreated?.(updatedJobData)\n } else {\n const result = await updateJobMutation.mutateAsync({\n request: {\n jobId: currentJob.uuid,\n requestBody: {\n title: jobTitle,\n version: currentJob.version as string,\n hireDate: resolvedHireDate,\n stateWcClassCode: compensationData.stateWcCovered\n ? compensationData.stateWcClassCode\n : null,\n stateWcCovered: compensationData.stateWcCovered,\n twoPercentShareholder: twoPercentShareholder ?? false,\n },\n },\n })\n updatedJobData = result.job!\n callbacks?.onJobUpdated?.(updatedJobData)\n }\n\n const { compensation } = await updateCompensationMutation.mutateAsync({\n request: {\n compensationId: updatedJobData.currentCompensationUuid!,\n compensationsUpdateRequestBody: {\n // eslint-disable-next-line @typescript-eslint/no-non-null-asserted-optional-chain\n version: updatedJobData.compensations?.find(\n comp => comp.uuid === updatedJobData.currentCompensationUuid,\n )?.version!,\n ...compensationData,\n rate: String(compensationData.rate),\n minimumWages: compensationData.adjustForMinimumWage\n ? [{ uuid: compensationData.minimumWageId }]\n : [],\n },\n },\n })\n\n callbacks?.onCompensationUpdated?.(compensation)\n\n submitResult = {\n mode: isCreateMode ? 'create' : 'update',\n data: compensation,\n }\n })\n resolve()\n },\n () => {\n resolve()\n },\n )()\n })\n\n return submitResult\n }\n\n const isDataLoading = employeeId\n ? jobsQuery.isLoading ||\n addressesQuery.isLoading ||\n employeeQuery.isLoading ||\n minWagesQuery.isLoading ||\n taxQuery.isLoading\n : false\n\n if (\n isDataLoading ||\n (employeeId &&\n (!employeeJobs ||\n !workAddresses ||\n !currentWorkAddress ||\n !employee ||\n !companyUuid ||\n !federalTaxDetails))\n ) {\n return { isLoading: true as const, errorHandling }\n }\n\n return {\n isLoading: false as const,\n data: {\n compensation: currentCompensation ?? null,\n jobs: employeeJobs,\n currentJob,\n minimumWages,\n },\n status: {\n isPending,\n mode: isCreateMode ? 'create' : 'update',\n },\n actions: { onSubmit },\n errorHandling,\n form: {\n Fields: {\n StartDate: withStartDateField ? StartDateField : undefined,\n JobTitle: JobTitleField,\n FlsaStatus: isFlsaSelectionEnabled ? FlsaStatusField : undefined,\n Rate: RateField,\n PaymentUnit: PaymentUnitField,\n AdjustForMinimumWage: isAdjustMinimumWageEnabled ? AdjustForMinimumWageField : undefined,\n MinimumWageId:\n isAdjustMinimumWageEnabled && watchedAdjustForMinimumWage\n ? MinimumWageIdField\n : undefined,\n TwoPercentShareholder: showTwoPercentStakeholder ? TwoPercentShareholderField : undefined,\n StateWcCovered: isWaState ? StateWcCoveredField : undefined,\n StateWcClassCode: isWaState && watchedStateWcCovered ? StateWcClassCodeField : undefined,\n },\n fieldsMetadata,\n hookFormInternals: { formMethods },\n getFormSubmissionValues: createGetFormSubmissionValues(formMethods, schema),\n },\n }\n}\n\nexport type UseCompensationFormResult = ReturnType<typeof useCompensationForm>\nexport type UseCompensationFormReady = Extract<UseCompensationFormResult, { data: object }>\nexport type CompensationFieldsMetadata = UseCompensationFormReady['form']['fieldsMetadata']\nexport type CompensationFormFields = UseCompensationFormReady['form']['Fields']\n"],"names":["findCurrentCompensation","job","comp","derivePrimaryFlsaStatus","jobs","prev","curr","compensation","flsaStatusEntries","FlsaStatus","key","flsaOptions","status","paymentUnitEntries","PAY_PERIODS","paymentUnitOptions","unit","useCompensationForm","employeeId","withStartDateField","jobId","requiredFields","partnerDefaults","validationMode","shouldFocusError","jobsQuery","useJobsAndCompensationsGetJobs","addressesQuery","useEmployeeAddressesGetWorkAddresses","employeeQuery","useEmployeesGet","employeeJobs","workAddresses","currentWorkAddress","address","locationUuid","employee","companyUuid","minWagesQuery","useLocationsGetMinimumWages","taxQuery","useFederalTaxDetailsGet","minimumWages","federalTaxDetails","showTwoPercentStakeholder","currentJob","useMemo","j","currentCompensation","primaryFlsaStatus","isCreateMode","schema","createCompensationSchema","state","hireDate","resolvedDefaults","formMethods","useForm","zodResolver","watchedFlsaStatus","useWatch","watchedAdjustForMinimumWage","watchedStateWcCovered","useEffect","updateCompensationMutation","useJobsAndCompensationsUpdateCompensationMutation","createJobMutation","useJobsAndCompensationsCreateJobMutation","updateJobMutation","useJobsAndCompensationsUpdateMutation","isPending","baseSubmitHandler","submitError","setError","useBaseSubmit","errorHandling","useErrorHandling","isCommissionOnly","isOwner","isFlsaSelectionEnabled","isAdjustMinimumWageEnabled","TIP_CREDITS_UNSUPPORTED_STATES","isWaState","minimumWageOptions","wage","stateWcClassCodeOptions","WA_RISK_CLASS_CODES","code","description","baseMetadata","deriveFieldsMetadata","fieldsMetadata","withOptions","onSubmit","callbacks","options","submitResult","resolve","data","payload","resolvedEmployeeId","SDKInternalError","jobTitle","twoPercentShareholder","formStartDate","compensationData","resolvedHireDate","updatedJobData","StartDateField","JobTitleField","FlsaStatusField","RateField","PaymentUnitField","AdjustForMinimumWageField","MinimumWageIdField","TwoPercentShareholderField","StateWcCoveredField","StateWcClassCodeField","createGetFormSubmissionValues"],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { UseEmployeeDetailsFormProps } from './useEmployeeDetailsForm';
|
|
2
|
+
import { BaseComponentInterface } from '../../../Base';
|
|
3
|
+
export interface EmployeeDetailsFormProps extends UseEmployeeDetailsFormProps, Omit<BaseComponentInterface, 'defaultValues'> {
|
|
4
|
+
}
|
|
5
|
+
export declare function EmployeeDetailsForm({ FallbackComponent, ...props }: EmployeeDetailsFormProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
import { jsx as i, jsxs as D } from "react/jsx-runtime";
|
|
2
|
+
import { useTranslation as L } from "react-i18next";
|
|
3
|
+
import { SDKFormProvider as I } from "../../form/SDKFormProvider.js";
|
|
4
|
+
import { useEmployeeDetailsForm as f } from "./useEmployeeDetailsForm.js";
|
|
5
|
+
import { useComponentContext as N } from "../../../../contexts/ComponentAdapter/useComponentContext.js";
|
|
6
|
+
import { BaseBoundaries as u, BaseLayout as d } from "../../../Base/Base.js";
|
|
7
|
+
import "../../../Base/useBase.js";
|
|
8
|
+
import { Form as c } from "../../../Common/Form/Form.js";
|
|
9
|
+
import { componentEvents as s } from "../../../../shared/constants.js";
|
|
10
|
+
import "classnames";
|
|
11
|
+
import { ActionsLayout as A } from "../../../Common/ActionsLayout/ActionsLayout.js";
|
|
12
|
+
import "react";
|
|
13
|
+
import { useI18n as R, useComponentDictionary as b } from "../../../../i18n/I18n.js";
|
|
14
|
+
function _({ onEvent: t, dictionary: n, ...E }) {
|
|
15
|
+
R("UNSTABLE.EmployeeDetailsForm"), b("UNSTABLE.EmployeeDetailsForm", n);
|
|
16
|
+
const { t: e } = L("UNSTABLE.EmployeeDetailsForm"), m = N(), a = f({
|
|
17
|
+
...E,
|
|
18
|
+
requiredFields: { update: ["ssn"] }
|
|
19
|
+
});
|
|
20
|
+
if (a.isLoading)
|
|
21
|
+
return /* @__PURE__ */ i(d, { isLoading: !0, error: a.errorHandling.errors });
|
|
22
|
+
const { Fields: o } = a.form, p = async () => {
|
|
23
|
+
const l = await a.actions.onSubmit({
|
|
24
|
+
onEmployeeCreated: (r) => {
|
|
25
|
+
t(s.EMPLOYEE_CREATED, r);
|
|
26
|
+
},
|
|
27
|
+
onEmployeeUpdated: (r) => {
|
|
28
|
+
t(s.EMPLOYEE_UPDATED, r);
|
|
29
|
+
},
|
|
30
|
+
onOnboardingStatusUpdated: (r) => {
|
|
31
|
+
t(s.EMPLOYEE_ONBOARDING_STATUS_UPDATED, r);
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
l && t(s.EMPLOYEE_PROFILE_DONE, l.data);
|
|
35
|
+
};
|
|
36
|
+
return /* @__PURE__ */ i(d, { error: a.errorHandling.errors, children: /* @__PURE__ */ i(I, { formHookResult: a, children: /* @__PURE__ */ D(
|
|
37
|
+
c,
|
|
38
|
+
{
|
|
39
|
+
onSubmit: (l) => {
|
|
40
|
+
l.preventDefault(), p();
|
|
41
|
+
},
|
|
42
|
+
children: [
|
|
43
|
+
/* @__PURE__ */ i(m.Heading, { as: "h2", children: a.status.mode === "create" ? e("addTitle") : e("editTitle") }),
|
|
44
|
+
/* @__PURE__ */ i(
|
|
45
|
+
o.FirstName,
|
|
46
|
+
{
|
|
47
|
+
label: e("firstNameLabel"),
|
|
48
|
+
validationMessages: {
|
|
49
|
+
REQUIRED: e("fieldValidations.firstName.REQUIRED"),
|
|
50
|
+
INVALID_NAME: e("fieldValidations.firstName.INVALID_NAME")
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
),
|
|
54
|
+
/* @__PURE__ */ i(o.MiddleInitial, { label: e("middleInitialLabel") }),
|
|
55
|
+
/* @__PURE__ */ i(
|
|
56
|
+
o.LastName,
|
|
57
|
+
{
|
|
58
|
+
label: e("lastNameLabel"),
|
|
59
|
+
validationMessages: {
|
|
60
|
+
REQUIRED: e("fieldValidations.lastName.REQUIRED"),
|
|
61
|
+
INVALID_NAME: e("fieldValidations.lastName.INVALID_NAME")
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
),
|
|
65
|
+
/* @__PURE__ */ i(
|
|
66
|
+
o.Email,
|
|
67
|
+
{
|
|
68
|
+
label: e("emailLabel"),
|
|
69
|
+
description: e("emailDescription"),
|
|
70
|
+
validationMessages: {
|
|
71
|
+
REQUIRED: e("fieldValidations.email.REQUIRED"),
|
|
72
|
+
INVALID_EMAIL: e("fieldValidations.email.INVALID_EMAIL"),
|
|
73
|
+
EMAIL_REQUIRED_FOR_SELF_ONBOARDING: e(
|
|
74
|
+
"fieldValidations.email.EMAIL_REQUIRED_FOR_SELF_ONBOARDING"
|
|
75
|
+
)
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
),
|
|
79
|
+
o.SelfOnboarding && /* @__PURE__ */ i(
|
|
80
|
+
o.SelfOnboarding,
|
|
81
|
+
{
|
|
82
|
+
label: e("selfOnboardingLabel"),
|
|
83
|
+
description: e("selfOnboardingDescription")
|
|
84
|
+
}
|
|
85
|
+
),
|
|
86
|
+
/* @__PURE__ */ i(o.DateOfBirth, { label: e("dateOfBirthLabel") }),
|
|
87
|
+
/* @__PURE__ */ i(
|
|
88
|
+
o.Ssn,
|
|
89
|
+
{
|
|
90
|
+
label: e("ssnLabel"),
|
|
91
|
+
validationMessages: {
|
|
92
|
+
INVALID_SSN: e("fieldValidations.ssn.INVALID_SSN")
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
),
|
|
96
|
+
/* @__PURE__ */ i(A, { children: /* @__PURE__ */ i(m.Button, { type: "submit", isLoading: a.status.isPending, children: a.status.mode === "create" ? e("createCta") : e("updateCta") }) })
|
|
97
|
+
]
|
|
98
|
+
}
|
|
99
|
+
) }) });
|
|
100
|
+
}
|
|
101
|
+
function Q({ FallbackComponent: t, ...n }) {
|
|
102
|
+
return /* @__PURE__ */ i(
|
|
103
|
+
u,
|
|
104
|
+
{
|
|
105
|
+
componentName: "UNSTABLE.EmployeeDetailsForm",
|
|
106
|
+
FallbackComponent: t,
|
|
107
|
+
children: /* @__PURE__ */ i(_, { ...n })
|
|
108
|
+
}
|
|
109
|
+
);
|
|
110
|
+
}
|
|
111
|
+
export {
|
|
112
|
+
Q as EmployeeDetailsForm
|
|
113
|
+
};
|
|
114
|
+
//# sourceMappingURL=EmployeeDetailsForm.js.map
|
package/dist/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/EmployeeDetailsForm.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EmployeeDetailsForm.js","sources":["../../../../../src/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/EmployeeDetailsForm.tsx"],"sourcesContent":["import { useTranslation } from 'react-i18next'\nimport { SDKFormProvider } from '../../form/SDKFormProvider'\nimport { useEmployeeDetailsForm } from './useEmployeeDetailsForm'\nimport type { UseEmployeeDetailsFormProps } from './useEmployeeDetailsForm'\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'\n\nexport interface EmployeeDetailsFormProps\n extends UseEmployeeDetailsFormProps, Omit<BaseComponentInterface, 'defaultValues'> {}\n\nfunction EmployeeDetailsFormRoot({ onEvent, dictionary, ...hookProps }: EmployeeDetailsFormProps) {\n useI18n('UNSTABLE.EmployeeDetailsForm')\n useComponentDictionary('UNSTABLE.EmployeeDetailsForm', dictionary)\n const { t } = useTranslation('UNSTABLE.EmployeeDetailsForm')\n const Components = useComponentContext()\n const employeeDetails = useEmployeeDetailsForm({\n ...hookProps,\n requiredFields: { update: ['ssn'] },\n })\n\n if (employeeDetails.isLoading) {\n return <BaseLayout isLoading error={employeeDetails.errorHandling.errors} />\n }\n\n const { Fields } = employeeDetails.form\n\n const handleSubmit = async () => {\n const result = await employeeDetails.actions.onSubmit({\n onEmployeeCreated: employee => {\n onEvent(componentEvents.EMPLOYEE_CREATED, employee)\n },\n onEmployeeUpdated: employee => {\n onEvent(componentEvents.EMPLOYEE_UPDATED, employee)\n },\n onOnboardingStatusUpdated: status => {\n onEvent(componentEvents.EMPLOYEE_ONBOARDING_STATUS_UPDATED, status)\n },\n })\n if (result) {\n onEvent(componentEvents.EMPLOYEE_PROFILE_DONE, result.data)\n }\n }\n\n return (\n <BaseLayout error={employeeDetails.errorHandling.errors}>\n <SDKFormProvider formHookResult={employeeDetails}>\n <Form\n onSubmit={e => {\n e.preventDefault()\n void handleSubmit()\n }}\n >\n <Components.Heading as=\"h2\">\n {employeeDetails.status.mode === 'create' ? t('addTitle') : t('editTitle')}\n </Components.Heading>\n\n <Fields.FirstName\n label={t('firstNameLabel')}\n validationMessages={{\n REQUIRED: t('fieldValidations.firstName.REQUIRED'),\n INVALID_NAME: t('fieldValidations.firstName.INVALID_NAME'),\n }}\n />\n\n <Fields.MiddleInitial label={t('middleInitialLabel')} />\n\n <Fields.LastName\n label={t('lastNameLabel')}\n validationMessages={{\n REQUIRED: t('fieldValidations.lastName.REQUIRED'),\n INVALID_NAME: t('fieldValidations.lastName.INVALID_NAME'),\n }}\n />\n\n <Fields.Email\n label={t('emailLabel')}\n description={t('emailDescription')}\n validationMessages={{\n REQUIRED: t('fieldValidations.email.REQUIRED'),\n INVALID_EMAIL: t('fieldValidations.email.INVALID_EMAIL'),\n EMAIL_REQUIRED_FOR_SELF_ONBOARDING: t(\n 'fieldValidations.email.EMAIL_REQUIRED_FOR_SELF_ONBOARDING',\n ),\n }}\n />\n\n {Fields.SelfOnboarding && (\n <Fields.SelfOnboarding\n label={t('selfOnboardingLabel')}\n description={t('selfOnboardingDescription')}\n />\n )}\n\n <Fields.DateOfBirth label={t('dateOfBirthLabel')} />\n\n <Fields.Ssn\n label={t('ssnLabel')}\n validationMessages={{\n INVALID_SSN: t('fieldValidations.ssn.INVALID_SSN'),\n }}\n />\n\n <ActionsLayout>\n <Components.Button type=\"submit\" isLoading={employeeDetails.status.isPending}>\n {employeeDetails.status.mode === 'create' ? t('createCta') : t('updateCta')}\n </Components.Button>\n </ActionsLayout>\n </Form>\n </SDKFormProvider>\n </BaseLayout>\n )\n}\n\nexport function EmployeeDetailsForm({ FallbackComponent, ...props }: EmployeeDetailsFormProps) {\n return (\n <BaseBoundaries\n componentName=\"UNSTABLE.EmployeeDetailsForm\"\n FallbackComponent={FallbackComponent}\n >\n <EmployeeDetailsFormRoot {...props} />\n </BaseBoundaries>\n )\n}\n"],"names":["EmployeeDetailsFormRoot","onEvent","dictionary","hookProps","useI18n","useComponentDictionary","t","useTranslation","Components","useComponentContext","employeeDetails","useEmployeeDetailsForm","BaseLayout","Fields","handleSubmit","result","employee","componentEvents","status","jsx","SDKFormProvider","jsxs","Form","e","ActionsLayout","EmployeeDetailsForm","FallbackComponent","props","BaseBoundaries"],"mappings":"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"}
|
package/dist/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/employeeDetailsSchema.d.ts
ADDED
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
import { RequiredFields } from '../../form/resolveRequiredFields';
|
|
3
|
+
export declare const EmployeeDetailsErrorCodes: {
|
|
4
|
+
readonly REQUIRED: "REQUIRED";
|
|
5
|
+
readonly INVALID_NAME: "INVALID_NAME";
|
|
6
|
+
readonly INVALID_EMAIL: "INVALID_EMAIL";
|
|
7
|
+
readonly INVALID_SSN: "INVALID_SSN";
|
|
8
|
+
readonly EMAIL_REQUIRED_FOR_SELF_ONBOARDING: "EMAIL_REQUIRED_FOR_SELF_ONBOARDING";
|
|
9
|
+
};
|
|
10
|
+
export type EmployeeDetailsErrorCode = (typeof EmployeeDetailsErrorCodes)[keyof typeof EmployeeDetailsErrorCodes];
|
|
11
|
+
declare const fieldValidators: {
|
|
12
|
+
firstName: z.ZodString;
|
|
13
|
+
middleInitial: z.ZodString;
|
|
14
|
+
lastName: z.ZodString;
|
|
15
|
+
email: z.ZodEmail;
|
|
16
|
+
dateOfBirth: z.ZodISODate;
|
|
17
|
+
ssn: z.ZodString;
|
|
18
|
+
selfOnboarding: z.ZodBoolean;
|
|
19
|
+
};
|
|
20
|
+
export type EmployeeDetailsField = Exclude<keyof typeof fieldValidators, 'selfOnboarding'>;
|
|
21
|
+
export type EmployeeDetailsFormData = {
|
|
22
|
+
[K in keyof typeof fieldValidators]: z.infer<(typeof fieldValidators)[K]>;
|
|
23
|
+
};
|
|
24
|
+
export type EmployeeDetailsFormOutputs = EmployeeDetailsFormData;
|
|
25
|
+
interface EmployeeDetailsSchemaOptions {
|
|
26
|
+
mode?: 'create' | 'update';
|
|
27
|
+
requiredFields?: RequiredFields<EmployeeDetailsField>;
|
|
28
|
+
hasSsn?: boolean;
|
|
29
|
+
}
|
|
30
|
+
export declare function createEmployeeDetailsSchema(options?: EmployeeDetailsSchemaOptions): z.ZodObject<{
|
|
31
|
+
firstName: z.ZodString;
|
|
32
|
+
middleInitial: z.ZodString;
|
|
33
|
+
lastName: z.ZodString;
|
|
34
|
+
email: z.ZodEmail;
|
|
35
|
+
dateOfBirth: z.ZodISODate;
|
|
36
|
+
ssn: z.ZodString;
|
|
37
|
+
selfOnboarding: z.ZodBoolean;
|
|
38
|
+
}, z.core.$strip>;
|
|
39
|
+
export {};
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { z as r } from "zod";
|
|
2
|
+
import { composeFormSchema as D } from "../../form/composeFormSchema.js";
|
|
3
|
+
import { filterRequiredFields as d } from "../../form/resolveRequiredFields.js";
|
|
4
|
+
import { SSN_REGEX as l, NAME_REGEX as o } from "../../../../helpers/validations.js";
|
|
5
|
+
const e = {
|
|
6
|
+
REQUIRED: "REQUIRED",
|
|
7
|
+
INVALID_NAME: "INVALID_NAME",
|
|
8
|
+
INVALID_EMAIL: "INVALID_EMAIL",
|
|
9
|
+
INVALID_SSN: "INVALID_SSN",
|
|
10
|
+
EMAIL_REQUIRED_FOR_SELF_ONBOARDING: "EMAIL_REQUIRED_FOR_SELF_ONBOARDING"
|
|
11
|
+
}, _ = {
|
|
12
|
+
firstName: r.string().min(1, { message: e.REQUIRED }).regex(o, { message: e.INVALID_NAME }),
|
|
13
|
+
middleInitial: r.string(),
|
|
14
|
+
lastName: r.string().min(1, { message: e.REQUIRED }).regex(o, { message: e.INVALID_NAME }),
|
|
15
|
+
email: r.email({
|
|
16
|
+
error: (s) => typeof s.input == "string" && s.input.length === 0 ? e.REQUIRED : e.INVALID_EMAIL
|
|
17
|
+
}),
|
|
18
|
+
dateOfBirth: r.iso.date({ error: () => e.REQUIRED }),
|
|
19
|
+
ssn: r.string({ error: () => e.REQUIRED }).refine((s) => l.test(s.replace(/\D/g, "")), {
|
|
20
|
+
message: e.INVALID_SSN
|
|
21
|
+
}),
|
|
22
|
+
selfOnboarding: r.boolean()
|
|
23
|
+
}, A = /* @__PURE__ */ new Set(["selfOnboarding"]), f = /* @__PURE__ */ new Set(["firstName", "lastName"]);
|
|
24
|
+
function O(s = {}) {
|
|
25
|
+
const { mode: i = "create", requiredFields: t, hasSsn: a = !1 } = s, n = a ? d(t, "ssn") : t, E = D({
|
|
26
|
+
fieldValidators: _,
|
|
27
|
+
fixedFields: A,
|
|
28
|
+
requiredOnCreate: f,
|
|
29
|
+
mode: i,
|
|
30
|
+
requiredFields: n
|
|
31
|
+
});
|
|
32
|
+
return i === "create" ? E.superRefine((m, R) => {
|
|
33
|
+
const { selfOnboarding: N, email: I } = m;
|
|
34
|
+
N && (!I || I.trim() === "") && R.addIssue({
|
|
35
|
+
code: r.ZodIssueCode.custom,
|
|
36
|
+
path: ["email"],
|
|
37
|
+
message: e.EMAIL_REQUIRED_FOR_SELF_ONBOARDING
|
|
38
|
+
});
|
|
39
|
+
}) : E;
|
|
40
|
+
}
|
|
41
|
+
export {
|
|
42
|
+
e as EmployeeDetailsErrorCodes,
|
|
43
|
+
O as createEmployeeDetailsSchema
|
|
44
|
+
};
|
|
45
|
+
//# sourceMappingURL=employeeDetailsSchema.js.map
|
package/dist/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/employeeDetailsSchema.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"employeeDetailsSchema.js","sources":["../../../../../src/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/employeeDetailsSchema.ts"],"sourcesContent":["import { z } from 'zod'\nimport { composeFormSchema } from '../../form/composeFormSchema'\nimport { filterRequiredFields, type RequiredFields } from '../../form/resolveRequiredFields'\nimport { SSN_REGEX, NAME_REGEX } from '@/helpers/validations'\n\nexport const EmployeeDetailsErrorCodes = {\n REQUIRED: 'REQUIRED',\n INVALID_NAME: 'INVALID_NAME',\n INVALID_EMAIL: 'INVALID_EMAIL',\n INVALID_SSN: 'INVALID_SSN',\n EMAIL_REQUIRED_FOR_SELF_ONBOARDING: 'EMAIL_REQUIRED_FOR_SELF_ONBOARDING',\n} as const\n\nexport type EmployeeDetailsErrorCode =\n (typeof EmployeeDetailsErrorCodes)[keyof typeof EmployeeDetailsErrorCodes]\n\nconst fieldValidators = {\n firstName: z\n .string()\n .min(1, { message: EmployeeDetailsErrorCodes.REQUIRED })\n .regex(NAME_REGEX, { message: EmployeeDetailsErrorCodes.INVALID_NAME }),\n middleInitial: z.string(),\n lastName: z\n .string()\n .min(1, { message: EmployeeDetailsErrorCodes.REQUIRED })\n .regex(NAME_REGEX, { message: EmployeeDetailsErrorCodes.INVALID_NAME }),\n email: z.email({\n error: issue =>\n typeof issue.input === 'string' && issue.input.length === 0\n ? EmployeeDetailsErrorCodes.REQUIRED\n : EmployeeDetailsErrorCodes.INVALID_EMAIL,\n }),\n dateOfBirth: z.iso.date({ error: () => EmployeeDetailsErrorCodes.REQUIRED }),\n ssn: z\n .string({ error: () => EmployeeDetailsErrorCodes.REQUIRED })\n .refine((v: string) => SSN_REGEX.test(v.replace(/\\D/g, '')), {\n message: EmployeeDetailsErrorCodes.INVALID_SSN,\n }),\n selfOnboarding: z.boolean(),\n}\n\nexport type EmployeeDetailsField = Exclude<keyof typeof fieldValidators, 'selfOnboarding'>\n\nexport type EmployeeDetailsFormData = {\n [K in keyof typeof fieldValidators]: z.infer<(typeof fieldValidators)[K]>\n}\nexport type EmployeeDetailsFormOutputs = EmployeeDetailsFormData\n\nconst FIXED_FIELDS = new Set(['selfOnboarding'])\nconst REQUIRED_ON_CREATE = new Set<EmployeeDetailsField>(['firstName', 'lastName'])\n\ninterface EmployeeDetailsSchemaOptions {\n mode?: 'create' | 'update'\n requiredFields?: RequiredFields<EmployeeDetailsField>\n hasSsn?: boolean\n}\n\nexport function createEmployeeDetailsSchema(options: EmployeeDetailsSchemaOptions = {}) {\n const { mode = 'create', requiredFields, hasSsn = false } = options\n\n const effectiveRequiredFields = hasSsn\n ? filterRequiredFields(requiredFields, 'ssn')\n : requiredFields\n\n const baseSchema = composeFormSchema({\n fieldValidators,\n fixedFields: FIXED_FIELDS,\n requiredOnCreate: REQUIRED_ON_CREATE,\n mode,\n requiredFields: effectiveRequiredFields,\n })\n\n if (mode === 'create') {\n return baseSchema.superRefine((data, ctx) => {\n const { selfOnboarding, email } = data as EmployeeDetailsFormData\n if (selfOnboarding && (!email || email.trim() === '')) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n path: ['email'],\n message: EmployeeDetailsErrorCodes.EMAIL_REQUIRED_FOR_SELF_ONBOARDING,\n })\n }\n })\n }\n\n return baseSchema\n}\n"],"names":["EmployeeDetailsErrorCodes","fieldValidators","z","NAME_REGEX","issue","v","SSN_REGEX","FIXED_FIELDS","REQUIRED_ON_CREATE","createEmployeeDetailsSchema","options","mode","requiredFields","hasSsn","effectiveRequiredFields","filterRequiredFields","baseSchema","composeFormSchema","data","ctx","selfOnboarding","email"],"mappings":";;;;AAKO,MAAMA,IAA4B;AAAA,EACvC,UAAU;AAAA,EACV,cAAc;AAAA,EACd,eAAe;AAAA,EACf,aAAa;AAAA,EACb,oCAAoC;AACtC,GAKMC,IAAkB;AAAA,EACtB,WAAWC,EACR,OAAA,EACA,IAAI,GAAG,EAAE,SAASF,EAA0B,SAAA,CAAU,EACtD,MAAMG,GAAY,EAAE,SAASH,EAA0B,cAAc;AAAA,EACxE,eAAeE,EAAE,OAAA;AAAA,EACjB,UAAUA,EACP,OAAA,EACA,IAAI,GAAG,EAAE,SAASF,EAA0B,SAAA,CAAU,EACtD,MAAMG,GAAY,EAAE,SAASH,EAA0B,cAAc;AAAA,EACxE,OAAOE,EAAE,MAAM;AAAA,IACb,OAAO,CAAAE,MACL,OAAOA,EAAM,SAAU,YAAYA,EAAM,MAAM,WAAW,IACtDJ,EAA0B,WAC1BA,EAA0B;AAAA,EAAA,CACjC;AAAA,EACD,aAAaE,EAAE,IAAI,KAAK,EAAE,OAAO,MAAMF,EAA0B,UAAU;AAAA,EAC3E,KAAKE,EACF,OAAO,EAAE,OAAO,MAAMF,EAA0B,UAAU,EAC1D,OAAO,CAACK,MAAcC,EAAU,KAAKD,EAAE,QAAQ,OAAO,EAAE,CAAC,GAAG;AAAA,IAC3D,SAASL,EAA0B;AAAA,EAAA,CACpC;AAAA,EACH,gBAAgBE,EAAE,QAAA;AACpB,GASMK,IAAe,oBAAI,IAAI,CAAC,gBAAgB,CAAC,GACzCC,IAAqB,oBAAI,IAA0B,CAAC,aAAa,UAAU,CAAC;AAQ3E,SAASC,EAA4BC,IAAwC,IAAI;AACtF,QAAM,EAAE,MAAAC,IAAO,UAAU,gBAAAC,GAAgB,QAAAC,IAAS,OAAUH,GAEtDI,IAA0BD,IAC5BE,EAAqBH,GAAgB,KAAK,IAC1CA,GAEEI,IAAaC,EAAkB;AAAA,IACnC,iBAAAhB;AAAA,IACA,aAAaM;AAAA,IACb,kBAAkBC;AAAA,IAClB,MAAAG;AAAA,IACA,gBAAgBG;AAAA,EAAA,CACjB;AAED,SAAIH,MAAS,WACJK,EAAW,YAAY,CAACE,GAAMC,MAAQ;AAC3C,UAAM,EAAE,gBAAAC,GAAgB,OAAAC,EAAA,IAAUH;AAClC,IAAIE,MAAmB,CAACC,KAASA,EAAM,KAAA,MAAW,OAChDF,EAAI,SAAS;AAAA,MACX,MAAMjB,EAAE,aAAa;AAAA,MACrB,MAAM,CAAC,OAAO;AAAA,MACd,SAASF,EAA0B;AAAA,IAAA,CACpC;AAAA,EAEL,CAAC,IAGIgB;AACT;"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { HookFieldProps } from '../../form/types';
|
|
2
|
+
import { TextInputHookFieldProps } from '../../form/fields/TextInputHookField';
|
|
3
|
+
import { DatePickerHookFieldProps } from '../../form/fields/DatePickerHookField';
|
|
4
|
+
import { SwitchHookFieldProps } from '../../form/fields/SwitchHookField';
|
|
5
|
+
import { EmployeeDetailsErrorCodes } from './employeeDetailsSchema';
|
|
6
|
+
export type RequiredValidation = typeof EmployeeDetailsErrorCodes.REQUIRED;
|
|
7
|
+
export type NameValidation = (typeof EmployeeDetailsErrorCodes)['REQUIRED' | 'INVALID_NAME'];
|
|
8
|
+
export type EmailValidation = (typeof EmployeeDetailsErrorCodes)['REQUIRED' | 'INVALID_EMAIL' | 'EMAIL_REQUIRED_FOR_SELF_ONBOARDING'];
|
|
9
|
+
export type SsnValidation = typeof EmployeeDetailsErrorCodes.INVALID_SSN;
|
|
10
|
+
export type FirstNameFieldProps = HookFieldProps<TextInputHookFieldProps<NameValidation>>;
|
|
11
|
+
export declare function FirstNameField(props: FirstNameFieldProps): import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
export type MiddleInitialFieldProps = HookFieldProps<TextInputHookFieldProps>;
|
|
13
|
+
export declare function MiddleInitialField(props: MiddleInitialFieldProps): import("react/jsx-runtime").JSX.Element;
|
|
14
|
+
export type LastNameFieldProps = HookFieldProps<TextInputHookFieldProps<NameValidation>>;
|
|
15
|
+
export declare function LastNameField(props: LastNameFieldProps): import("react/jsx-runtime").JSX.Element;
|
|
16
|
+
export type EmailFieldProps = HookFieldProps<TextInputHookFieldProps<EmailValidation>>;
|
|
17
|
+
export declare function EmailField(props: EmailFieldProps): import("react/jsx-runtime").JSX.Element;
|
|
18
|
+
export type DateOfBirthFieldProps = HookFieldProps<DatePickerHookFieldProps>;
|
|
19
|
+
export declare function DateOfBirthField(props: DateOfBirthFieldProps): import("react/jsx-runtime").JSX.Element;
|
|
20
|
+
export type SsnFieldProps = HookFieldProps<TextInputHookFieldProps<SsnValidation>>;
|
|
21
|
+
export declare function SsnField(props: SsnFieldProps): import("react/jsx-runtime").JSX.Element;
|
|
22
|
+
export type SelfOnboardingFieldProps = HookFieldProps<SwitchHookFieldProps>;
|
|
23
|
+
export declare function SelfOnboardingField(props: SelfOnboardingFieldProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { jsx as t } from "react/jsx-runtime";
|
|
2
|
+
import { useFieldsMetadata as a } from "../../form/useFieldsMetadata.js";
|
|
3
|
+
import { usePlaceholderSSN as o, normalizeSSN as m } from "../../../../helpers/ssn.js";
|
|
4
|
+
import { SwitchHookField as l } from "../../form/fields/SwitchHookField.js";
|
|
5
|
+
import { TextInputHookField as n } from "../../form/fields/TextInputHookField.js";
|
|
6
|
+
import { DatePickerHookField as d } from "../../form/fields/DatePickerHookField.js";
|
|
7
|
+
function S(e) {
|
|
8
|
+
return /* @__PURE__ */ t(n, { ...e, name: "firstName" });
|
|
9
|
+
}
|
|
10
|
+
function h(e) {
|
|
11
|
+
return /* @__PURE__ */ t(n, { ...e, name: "middleInitial" });
|
|
12
|
+
}
|
|
13
|
+
function N(e) {
|
|
14
|
+
return /* @__PURE__ */ t(n, { ...e, name: "lastName" });
|
|
15
|
+
}
|
|
16
|
+
function k(e) {
|
|
17
|
+
return /* @__PURE__ */ t(n, { ...e, name: "email" });
|
|
18
|
+
}
|
|
19
|
+
function O(e) {
|
|
20
|
+
return /* @__PURE__ */ t(d, { ...e, name: "dateOfBirth" });
|
|
21
|
+
}
|
|
22
|
+
function x(e) {
|
|
23
|
+
const i = a(), r = o(i.ssn?.hasRedactedValue);
|
|
24
|
+
return /* @__PURE__ */ t(
|
|
25
|
+
n,
|
|
26
|
+
{
|
|
27
|
+
...e,
|
|
28
|
+
name: "ssn",
|
|
29
|
+
transform: m,
|
|
30
|
+
placeholder: r
|
|
31
|
+
}
|
|
32
|
+
);
|
|
33
|
+
}
|
|
34
|
+
function H(e) {
|
|
35
|
+
return /* @__PURE__ */ t(l, { ...e, name: "selfOnboarding" });
|
|
36
|
+
}
|
|
37
|
+
export {
|
|
38
|
+
O as DateOfBirthField,
|
|
39
|
+
k as EmailField,
|
|
40
|
+
S as FirstNameField,
|
|
41
|
+
N as LastNameField,
|
|
42
|
+
h as MiddleInitialField,
|
|
43
|
+
H as SelfOnboardingField,
|
|
44
|
+
x as SsnField
|
|
45
|
+
};
|
|
46
|
+
//# sourceMappingURL=fields.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fields.js","sources":["../../../../../src/components/UNSTABLE_Hooks/hooks/useEmployeeDetailsForm/fields.tsx"],"sourcesContent":["import type { HookFieldProps } from '../../form/types'\nimport type { TextInputHookFieldProps } from '../../form/fields/TextInputHookField'\nimport type { DatePickerHookFieldProps } from '../../form/fields/DatePickerHookField'\nimport type { SwitchHookFieldProps } from '../../form/fields/SwitchHookField'\nimport { TextInputHookField, DatePickerHookField, SwitchHookField } from '../../form/fields'\nimport { useFieldsMetadata } from '../../form/useFieldsMetadata'\nimport type { EmployeeDetailsErrorCodes } from './employeeDetailsSchema'\nimport { normalizeSSN, usePlaceholderSSN } from '@/helpers/ssn'\n\nexport type RequiredValidation = typeof EmployeeDetailsErrorCodes.REQUIRED\nexport type NameValidation = (typeof EmployeeDetailsErrorCodes)['REQUIRED' | 'INVALID_NAME']\nexport type EmailValidation = (typeof EmployeeDetailsErrorCodes)[\n | 'REQUIRED'\n | 'INVALID_EMAIL'\n | 'EMAIL_REQUIRED_FOR_SELF_ONBOARDING']\nexport type SsnValidation = typeof EmployeeDetailsErrorCodes.INVALID_SSN\n\nexport type FirstNameFieldProps = HookFieldProps<TextInputHookFieldProps<NameValidation>>\n\nexport function FirstNameField(props: FirstNameFieldProps) {\n return <TextInputHookField {...props} name=\"firstName\" />\n}\n\nexport type MiddleInitialFieldProps = HookFieldProps<TextInputHookFieldProps>\n\nexport function MiddleInitialField(props: MiddleInitialFieldProps) {\n return <TextInputHookField {...props} name=\"middleInitial\" />\n}\n\nexport type LastNameFieldProps = HookFieldProps<TextInputHookFieldProps<NameValidation>>\n\nexport function LastNameField(props: LastNameFieldProps) {\n return <TextInputHookField {...props} name=\"lastName\" />\n}\n\nexport type EmailFieldProps = HookFieldProps<TextInputHookFieldProps<EmailValidation>>\n\nexport function EmailField(props: EmailFieldProps) {\n return <TextInputHookField {...props} name=\"email\" />\n}\n\nexport type DateOfBirthFieldProps = HookFieldProps<DatePickerHookFieldProps>\n\nexport function DateOfBirthField(props: DateOfBirthFieldProps) {\n return <DatePickerHookField {...props} name=\"dateOfBirth\" />\n}\n\nexport type SsnFieldProps = HookFieldProps<TextInputHookFieldProps<SsnValidation>>\n\nexport function SsnField(props: SsnFieldProps) {\n const metadata = useFieldsMetadata()\n const placeholderSSN = usePlaceholderSSN(metadata.ssn?.hasRedactedValue)\n return (\n <TextInputHookField\n {...props}\n name=\"ssn\"\n transform={normalizeSSN}\n placeholder={placeholderSSN}\n />\n )\n}\n\nexport type SelfOnboardingFieldProps = HookFieldProps<SwitchHookFieldProps>\n\nexport function SelfOnboardingField(props: SelfOnboardingFieldProps) {\n return <SwitchHookField {...props} name=\"selfOnboarding\" />\n}\n"],"names":["FirstNameField","props","jsx","TextInputHookField","MiddleInitialField","LastNameField","EmailField","DateOfBirthField","DatePickerHookField","SsnField","metadata","useFieldsMetadata","placeholderSSN","usePlaceholderSSN","normalizeSSN","SelfOnboardingField","SwitchHookField"],"mappings":";;;;;;AAmBO,SAASA,EAAeC,GAA4B;AACzD,SAAO,gBAAAC,EAACC,GAAA,EAAoB,GAAGF,GAAO,MAAK,aAAY;AACzD;AAIO,SAASG,EAAmBH,GAAgC;AACjE,SAAO,gBAAAC,EAACC,GAAA,EAAoB,GAAGF,GAAO,MAAK,iBAAgB;AAC7D;AAIO,SAASI,EAAcJ,GAA2B;AACvD,SAAO,gBAAAC,EAACC,GAAA,EAAoB,GAAGF,GAAO,MAAK,YAAW;AACxD;AAIO,SAASK,EAAWL,GAAwB;AACjD,SAAO,gBAAAC,EAACC,GAAA,EAAoB,GAAGF,GAAO,MAAK,SAAQ;AACrD;AAIO,SAASM,EAAiBN,GAA8B;AAC7D,SAAO,gBAAAC,EAACM,GAAA,EAAqB,GAAGP,GAAO,MAAK,eAAc;AAC5D;AAIO,SAASQ,EAASR,GAAsB;AAC7C,QAAMS,IAAWC,EAAA,GACXC,IAAiBC,EAAkBH,EAAS,KAAK,gBAAgB;AACvE,SACE,gBAAAR;AAAA,IAACC;AAAA,IAAA;AAAA,MACE,GAAGF;AAAA,MACJ,MAAK;AAAA,MACL,WAAWa;AAAA,MACX,aAAaF;AAAA,IAAA;AAAA,EAAA;AAGnB;AAIO,SAASG,EAAoBd,GAAiC;AACnE,SAAO,gBAAAC,EAACc,GAAA,EAAiB,GAAGf,GAAO,MAAK,kBAAiB;AAC3D;"}
|