@gusto/embedded-react-sdk 0.14.0 → 0.15.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 +34 -0
- package/dist/assets/icons/feature-icon-check.svg.js +10 -0
- package/dist/assets/icons/feature-icon-check.svg.js.map +1 -0
- package/dist/assets/icons/plus-circle.svg.js +10 -0
- package/dist/assets/icons/plus-circle.svg.js.map +1 -0
- package/dist/assets/icons/x-circle.svg.js +10 -0
- package/dist/assets/icons/x-circle.svg.js.map +1 -0
- package/dist/components/Base/Base.js +4 -4
- package/dist/components/Common/DataView/DataView.d.ts +2 -1
- package/dist/components/Common/DataView/DataView.js +19 -18
- package/dist/components/Common/DataView/DataView.js.map +1 -1
- package/dist/components/Common/PaginationControl/PaginationControl.js +36 -36
- package/dist/components/Common/PaginationControl/PaginationControl.js.map +1 -1
- package/dist/components/Common/PaginationControl/PaginationControlTypes.d.ts +3 -1
- package/dist/components/Common/SignatureForm/SignatureForm.js +13 -10
- package/dist/components/Common/SignatureForm/SignatureForm.js.map +1 -1
- package/dist/components/Common/SignatureForm/SignatureFormActions.js +8 -6
- package/dist/components/Common/SignatureForm/SignatureFormActions.js.map +1 -1
- package/dist/components/Common/SignatureForm/SignatureFormFields.js +14 -11
- package/dist/components/Common/SignatureForm/SignatureFormFields.js.map +1 -1
- package/dist/components/Common/UI/Alert/Alert.module.scss.js +14 -14
- package/dist/components/Common/UI/Button/ButtonIcon.module.scss.js +1 -1
- package/dist/components/Common/index.d.ts +1 -0
- package/dist/components/Company/AssignSignatory/AssignSignatory.js +10 -7
- package/dist/components/Company/AssignSignatory/AssignSignatory.js.map +1 -1
- package/dist/components/Company/AssignSignatory/AssignSignatorySelection.js +4 -2
- package/dist/components/Company/AssignSignatory/AssignSignatorySelection.js.map +1 -1
- package/dist/components/Company/AssignSignatory/CreateSignatory/Actions.js +3 -2
- package/dist/components/Company/AssignSignatory/CreateSignatory/Actions.js.map +1 -1
- package/dist/components/Company/AssignSignatory/CreateSignatory/CreateSignatory.js +9 -6
- package/dist/components/Company/AssignSignatory/CreateSignatory/CreateSignatory.js.map +1 -1
- package/dist/components/Company/AssignSignatory/CreateSignatory/CreateSignatoryForm.js +15 -13
- package/dist/components/Company/AssignSignatory/CreateSignatory/CreateSignatoryForm.js.map +1 -1
- package/dist/components/Company/AssignSignatory/CreateSignatory/useCreateSignatory.js +1 -1
- package/dist/components/Company/AssignSignatory/InviteSignatory/Actions.js +3 -2
- package/dist/components/Company/AssignSignatory/InviteSignatory/Actions.js.map +1 -1
- package/dist/components/Company/AssignSignatory/InviteSignatory/InviteSignatory.js +13 -10
- package/dist/components/Company/AssignSignatory/InviteSignatory/InviteSignatory.js.map +1 -1
- package/dist/components/Company/AssignSignatory/InviteSignatory/InviteSignatoryForm.js +14 -12
- package/dist/components/Company/AssignSignatory/InviteSignatory/InviteSignatoryForm.js.map +1 -1
- package/dist/components/Company/AssignSignatory/InviteSignatory/useInviteSignatory.js +1 -1
- package/dist/components/Company/AssignSignatory/TitleSelect.js +5 -3
- package/dist/components/Company/AssignSignatory/TitleSelect.js.map +1 -1
- package/dist/components/Company/AssignSignatory/useAssignSignatory.js +1 -1
- package/dist/components/Company/BankAccount/BankAccountForm/Actions.js +9 -8
- package/dist/components/Company/BankAccount/BankAccountForm/Actions.js.map +1 -1
- package/dist/components/Company/BankAccount/BankAccountForm/Form.js +6 -4
- package/dist/components/Company/BankAccount/BankAccountForm/Form.js.map +1 -1
- package/dist/components/Company/BankAccount/BankAccountForm/context.js +1 -1
- package/dist/components/Company/BankAccount/BankAccountList/Actions.js +3 -2
- package/dist/components/Company/BankAccount/BankAccountList/Actions.js.map +1 -1
- package/dist/components/Company/BankAccount/BankAccountVerify/Actions.js +7 -6
- package/dist/components/Company/BankAccount/BankAccountVerify/Actions.js.map +1 -1
- package/dist/components/Company/BankAccount/BankAccountVerify/Form.js +6 -4
- package/dist/components/Company/BankAccount/BankAccountVerify/Form.js.map +1 -1
- package/dist/components/Company/DocumentSigner/DocumentList/Actions.js +3 -2
- package/dist/components/Company/DocumentSigner/DocumentList/Actions.js.map +1 -1
- package/dist/components/Company/DocumentSigner/DocumentList/DocumentList.js +11 -8
- package/dist/components/Company/DocumentSigner/DocumentList/DocumentList.js.map +1 -1
- package/dist/components/Company/DocumentSigner/DocumentList/useDocumentList.js +1 -1
- package/dist/components/Company/DocumentSigner/SignatureForm/SignatureForm.js +14 -11
- package/dist/components/Company/DocumentSigner/SignatureForm/SignatureForm.js.map +1 -1
- package/dist/components/Company/DocumentSigner/SignatureForm/useSignatureForm.js +1 -1
- package/dist/components/Company/FederalTaxes/Actions.js +7 -6
- package/dist/components/Company/FederalTaxes/Actions.js.map +1 -1
- package/dist/components/Company/FederalTaxes/FederalTaxes.js +15 -12
- package/dist/components/Company/FederalTaxes/FederalTaxes.js.map +1 -1
- package/dist/components/Company/FederalTaxes/Form.js +4 -4
- package/dist/components/Company/FederalTaxes/useFederalTaxes.js +1 -1
- package/dist/components/Company/Industry/Actions.js +8 -7
- package/dist/components/Company/Industry/Actions.js.map +1 -1
- package/dist/components/Company/Industry/Context.js +1 -1
- package/dist/components/Company/Industry/Edit.js +4 -2
- package/dist/components/Company/Industry/Edit.js.map +1 -1
- package/dist/components/Company/Locations/LocationForm/Actions.js +7 -6
- package/dist/components/Company/Locations/LocationForm/Actions.js.map +1 -1
- package/dist/components/Company/Locations/LocationForm/Form.js +7 -4
- package/dist/components/Company/Locations/LocationForm/Form.js.map +1 -1
- package/dist/components/Company/Locations/LocationForm/LocationForm.js +17 -14
- package/dist/components/Company/Locations/LocationForm/LocationForm.js.map +1 -1
- package/dist/components/Company/Locations/LocationForm/useLocationForm.js +1 -1
- package/dist/components/Company/Locations/LocationsList/Actions.js +3 -2
- package/dist/components/Company/Locations/LocationsList/Actions.js.map +1 -1
- package/dist/components/Company/Locations/LocationsList/List.js +22 -20
- package/dist/components/Company/Locations/LocationsList/List.js.map +1 -1
- package/dist/components/Company/Locations/LocationsList/LocationsList.js +12 -9
- package/dist/components/Company/Locations/LocationsList/LocationsList.js.map +1 -1
- package/dist/components/Company/Locations/LocationsList/useLocationsList.d.ts +3 -1
- package/dist/components/Company/Locations/LocationsList/useLocationsList.js +1 -1
- package/dist/components/Company/Locations/LocationsList/useLocationsList.js.map +1 -1
- package/dist/components/Company/OnboardingOverview/Completed.js +3 -2
- package/dist/components/Company/OnboardingOverview/Completed.js.map +1 -1
- package/dist/components/Company/OnboardingOverview/MissingRequirements.js +7 -6
- package/dist/components/Company/OnboardingOverview/MissingRequirements.js.map +1 -1
- package/dist/components/Company/OnboardingOverview/OnboardingOverview.js +9 -6
- package/dist/components/Company/OnboardingOverview/OnboardingOverview.js.map +1 -1
- package/dist/components/Company/OnboardingOverview/context.js +1 -1
- package/dist/components/Company/PaySchedule/PaySchedule.js +34 -32
- package/dist/components/Company/PaySchedule/PaySchedule.js.map +1 -1
- package/dist/components/Company/PaySchedule/_parts/Actions.js +3 -2
- package/dist/components/Company/PaySchedule/_parts/Actions.js.map +1 -1
- package/dist/components/Company/PaySchedule/_parts/Edit.js +3 -2
- package/dist/components/Company/PaySchedule/_parts/Edit.js.map +1 -1
- package/dist/components/Company/PaySchedule/_parts/Head.js +8 -7
- package/dist/components/Company/PaySchedule/_parts/Head.js.map +1 -1
- package/dist/components/Company/PaySchedule/_parts/List.js +6 -6
- package/dist/components/Company/PaySchedule/usePaySchedule.js +1 -1
- package/dist/components/Company/StateTaxes/StateTaxesForm/Actions.js +3 -2
- package/dist/components/Company/StateTaxes/StateTaxesForm/Actions.js.map +1 -1
- package/dist/components/Company/StateTaxes/StateTaxesForm/context.js +1 -1
- package/dist/components/Company/StateTaxes/StateTaxesList/Actions.js +3 -2
- package/dist/components/Company/StateTaxes/StateTaxesList/Actions.js.map +1 -1
- package/dist/components/Company/StateTaxes/StateTaxesList/List.js +3 -2
- package/dist/components/Company/StateTaxes/StateTaxesList/List.js.map +1 -1
- package/dist/components/Company/StateTaxes/StateTaxesList/context.js +1 -1
- package/dist/components/Contractor/Address/Address.js +6 -3
- package/dist/components/Contractor/Address/Address.js.map +1 -1
- package/dist/components/Contractor/Address/Form.js +9 -6
- package/dist/components/Contractor/Address/Form.js.map +1 -1
- package/dist/components/Contractor/Address/useAddress.js +1 -1
- package/dist/components/Contractor/ContractorList/index.js +57 -55
- package/dist/components/Contractor/ContractorList/index.js.map +1 -1
- package/dist/components/Contractor/ContractorList/useContractorList.d.ts +3 -1
- package/dist/components/Contractor/ContractorList/useContractorList.js +7 -6
- package/dist/components/Contractor/ContractorList/useContractorList.js.map +1 -1
- package/dist/components/Contractor/PaymentMethod/BankAccountForm.js +12 -10
- package/dist/components/Contractor/PaymentMethod/BankAccountForm.js.map +1 -1
- package/dist/components/Contractor/PaymentMethod/PaymentTypeForm.js +4 -2
- package/dist/components/Contractor/PaymentMethod/PaymentTypeForm.js.map +1 -1
- package/dist/components/Contractor/Profile/useContractorProfile.js +1 -1
- package/dist/components/Contractor/Submit/Submit.js +20 -19
- package/dist/components/Contractor/Submit/Submit.js.map +1 -1
- package/dist/components/Employee/Compensation/Actions.js +13 -12
- package/dist/components/Employee/Compensation/Actions.js.map +1 -1
- package/dist/components/Employee/Compensation/Compensation.js +144 -147
- package/dist/components/Employee/Compensation/Compensation.js.map +1 -1
- package/dist/components/Employee/Compensation/Edit.js +27 -26
- package/dist/components/Employee/Compensation/Edit.js.map +1 -1
- package/dist/components/Employee/Deductions/DeductionsForm/DeductionsForm.js +4 -4
- package/dist/components/Employee/Deductions/DeductionsList/DeductionsList.js +6 -6
- package/dist/components/Employee/Deductions/IncludeDeductionsForm/IncludeDeductionsForm.js +20 -19
- package/dist/components/Employee/Deductions/IncludeDeductionsForm/IncludeDeductionsForm.js.map +1 -1
- package/dist/components/Employee/DocumentSigner/DocumentList/Actions.js +3 -2
- package/dist/components/Employee/DocumentSigner/DocumentList/Actions.js.map +1 -1
- package/dist/components/Employee/DocumentSigner/DocumentList/DocumentList.js +10 -7
- package/dist/components/Employee/DocumentSigner/DocumentList/DocumentList.js.map +1 -1
- package/dist/components/Employee/DocumentSigner/DocumentList/List.js +4 -2
- package/dist/components/Employee/DocumentSigner/DocumentList/List.js.map +1 -1
- package/dist/components/Employee/DocumentSigner/DocumentList/useDocumentList.js +1 -1
- package/dist/components/Employee/DocumentSigner/SignatureForm/SignatureForm.js +12 -9
- package/dist/components/Employee/DocumentSigner/SignatureForm/SignatureForm.js.map +1 -1
- package/dist/components/Employee/DocumentSigner/SignatureForm/useSignatureForm.js +1 -1
- package/dist/components/Employee/EmployeeList/Actions.js +7 -6
- package/dist/components/Employee/EmployeeList/Actions.js.map +1 -1
- package/dist/components/Employee/EmployeeList/EmployeeList.js +15 -12
- package/dist/components/Employee/EmployeeList/EmployeeList.js.map +1 -1
- package/dist/components/Employee/EmployeeList/Head.js +3 -2
- package/dist/components/Employee/EmployeeList/Head.js.map +1 -1
- package/dist/components/Employee/EmployeeList/List.js +43 -41
- package/dist/components/Employee/EmployeeList/List.js.map +1 -1
- package/dist/components/Employee/EmployeeList/useEmployeeList.d.ts +3 -1
- package/dist/components/Employee/EmployeeList/useEmployeeList.js +1 -1
- package/dist/components/Employee/EmployeeList/useEmployeeList.js.map +1 -1
- package/dist/components/Employee/FederalTaxes/Actions.js +6 -5
- package/dist/components/Employee/FederalTaxes/Actions.js.map +1 -1
- package/dist/components/Employee/FederalTaxes/FederalForm.js +5 -4
- package/dist/components/Employee/FederalTaxes/FederalForm.js.map +1 -1
- package/dist/components/Employee/FederalTaxes/useFederalTaxes.js +1 -1
- package/dist/components/Employee/Landing/Landing.js +3 -2
- package/dist/components/Employee/Landing/Landing.js.map +1 -1
- package/dist/components/Employee/PaymentMethod/Actions.js +6 -5
- package/dist/components/Employee/PaymentMethod/Actions.js.map +1 -1
- package/dist/components/Employee/PaymentMethod/BankAccountEdit.js +4 -2
- package/dist/components/Employee/PaymentMethod/BankAccountEdit.js.map +1 -1
- package/dist/components/Employee/PaymentMethod/BankAccountsList.js +4 -4
- package/dist/components/Employee/PaymentMethod/PaymentTypeForm.js +4 -2
- package/dist/components/Employee/PaymentMethod/PaymentTypeForm.js.map +1 -1
- package/dist/components/Employee/PaymentMethod/Split.js +4 -4
- package/dist/components/Employee/PaymentMethod/usePaymentMethod.js +1 -1
- package/dist/components/Employee/Profile/Actions.js +6 -5
- package/dist/components/Employee/Profile/Actions.js.map +1 -1
- package/dist/components/Employee/Profile/AdminPersonalDetails.js +7 -6
- package/dist/components/Employee/Profile/AdminPersonalDetails.js.map +1 -1
- package/dist/components/Employee/Profile/HomeAddress.js +6 -4
- package/dist/components/Employee/Profile/HomeAddress.js.map +1 -1
- package/dist/components/Employee/Profile/PersonalDetailsInputs.js +31 -28
- package/dist/components/Employee/Profile/PersonalDetailsInputs.js.map +1 -1
- package/dist/components/Employee/Profile/useProfile.js +1 -1
- package/dist/components/Employee/StateTaxes/Actions.js +6 -5
- package/dist/components/Employee/StateTaxes/Actions.js.map +1 -1
- package/dist/components/Employee/StateTaxes/useStateTaxes.js +1 -1
- package/dist/components/Employee/Taxes/Actions.js +7 -6
- package/dist/components/Employee/Taxes/Actions.js.map +1 -1
- package/dist/components/Employee/Taxes/FederalForm.js +5 -4
- package/dist/components/Employee/Taxes/FederalForm.js.map +1 -1
- package/dist/components/Employee/Taxes/useTaxes.js +1 -1
- package/dist/components/Payroll/PayrollBlocker/PayrollBlocker.d.ts +6 -0
- package/dist/components/Payroll/PayrollBlocker/PayrollBlocker.js +32 -0
- package/dist/components/Payroll/PayrollBlocker/PayrollBlocker.js.map +1 -0
- package/dist/components/Payroll/PayrollBlocker/{PayrollBlockerAlerts.d.ts → components/PayrollBlockerAlerts.d.ts} +1 -1
- package/dist/components/Payroll/PayrollBlocker/{PayrollBlockerAlerts.js → components/PayrollBlockerAlerts.js} +18 -17
- package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerAlerts.js.map +1 -0
- package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerList.js +41 -0
- package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerList.js.map +1 -0
- package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerList.module.scss.js +8 -0
- package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerList.module.scss.js.map +1 -0
- package/dist/components/Payroll/PayrollBlocker/index.d.ts +3 -1
- package/dist/components/Payroll/PayrollConfiguration/PayrollConfiguration.js +129 -67
- package/dist/components/Payroll/PayrollConfiguration/PayrollConfiguration.js.map +1 -1
- package/dist/components/Payroll/PayrollConfiguration/PayrollConfigurationPresentation.d.ts +6 -1
- package/dist/components/Payroll/PayrollConfiguration/PayrollConfigurationPresentation.js +85 -71
- package/dist/components/Payroll/PayrollConfiguration/PayrollConfigurationPresentation.js.map +1 -1
- package/dist/components/Payroll/PayrollEditEmployee/PayrollEditEmployee.js +21 -20
- package/dist/components/Payroll/PayrollEditEmployee/PayrollEditEmployee.js.map +1 -1
- package/dist/components/Payroll/PayrollEditEmployee/PayrollEditEmployeePresentation.js +47 -46
- package/dist/components/Payroll/PayrollEditEmployee/PayrollEditEmployeePresentation.js.map +1 -1
- package/dist/components/Payroll/PayrollFlow/PayrollFlowComponents.d.ts +1 -0
- package/dist/components/Payroll/PayrollFlow/PayrollFlowComponents.js +32 -26
- package/dist/components/Payroll/PayrollFlow/PayrollFlowComponents.js.map +1 -1
- package/dist/components/Payroll/PayrollFlow/payrollStateMachine.d.ts +1 -0
- package/dist/components/Payroll/PayrollFlow/payrollStateMachine.js +72 -48
- package/dist/components/Payroll/PayrollFlow/payrollStateMachine.js.map +1 -1
- package/dist/components/Payroll/PayrollHistory/PayrollHistory.js +21 -20
- package/dist/components/Payroll/PayrollHistory/PayrollHistory.js.map +1 -1
- package/dist/components/Payroll/PayrollHistory/PayrollHistoryPresentation.js +15 -15
- package/dist/components/Payroll/PayrollHistory/PayrollHistoryPresentation.js.map +1 -1
- package/dist/components/Payroll/PayrollList/PayrollList.d.ts +1 -1
- package/dist/components/Payroll/PayrollList/PayrollList.js +65 -24
- package/dist/components/Payroll/PayrollList/PayrollList.js.map +1 -1
- package/dist/components/Payroll/PayrollList/PayrollListPresentation.d.ts +13 -1
- package/dist/components/Payroll/PayrollList/PayrollListPresentation.js +153 -50
- package/dist/components/Payroll/PayrollList/PayrollListPresentation.js.map +1 -1
- package/dist/components/Payroll/PayrollList/PayrollListPresentation.module.scss.js +10 -0
- package/dist/components/Payroll/PayrollList/PayrollListPresentation.module.scss.js.map +1 -0
- package/dist/components/Payroll/PayrollOverview/PayrollOverview.js +98 -74
- package/dist/components/Payroll/PayrollOverview/PayrollOverview.js.map +1 -1
- package/dist/components/Payroll/PayrollOverview/PayrollOverviewPresentation.js +73 -72
- package/dist/components/Payroll/PayrollOverview/PayrollOverviewPresentation.js.map +1 -1
- package/dist/components/Payroll/helpers.d.ts +2 -0
- package/dist/components/Payroll/helpers.js +38 -37
- package/dist/components/Payroll/helpers.js.map +1 -1
- package/dist/components/Payroll/usePreparedPayrollData.d.ts +4 -1
- package/dist/components/Payroll/usePreparedPayrollData.js +25 -19
- package/dist/components/Payroll/usePreparedPayrollData.js.map +1 -1
- package/dist/components/index.d.ts +1 -1
- package/dist/contexts/GustoProvider/GustoProviderCustomUIAdapter.js +3 -2
- package/dist/contexts/GustoProvider/GustoProviderCustomUIAdapter.js.map +1 -1
- package/dist/i18n/en/Payroll.PayrollConfiguration.json.js +9 -9
- package/dist/i18n/en/Payroll.PayrollHistory.json.js +9 -9
- package/dist/i18n/en/Payroll.PayrollList.json.js +24 -14
- package/dist/i18n/en/Payroll.PayrollList.json.js.map +1 -1
- package/dist/i18n/en/Payroll.PayrollOverview.json.js +16 -16
- package/dist/index.js +1 -1
- package/dist/shared/constants.d.ts +6 -0
- package/dist/shared/constants.js +11 -8
- package/dist/shared/constants.js.map +1 -1
- package/dist/style.css +1 -1
- package/dist/types/i18next.d.ts +15 -1
- package/package.json +14 -14
- package/dist/components/Payroll/PayrollBlocker/PayrollBlockerAlerts.js.map +0 -1
- package/dist/components/Payroll/RunPayrollFlow/RunPayroll.d.ts +0 -23
- package/dist/components/Payroll/RunPayrollFlow/RunPayrollFlow.d.ts +0 -6
- /package/dist/components/Payroll/PayrollBlocker/{PayrollBlockerList.d.ts → components/PayrollBlockerList.d.ts} +0 -0
|
@@ -1,55 +1,55 @@
|
|
|
1
|
-
import { jsx as s, jsxs as
|
|
2
|
-
import { zodResolver as
|
|
3
|
-
import { useState as
|
|
4
|
-
import { useForm as
|
|
5
|
-
import { useTranslation as
|
|
6
|
-
import { useJobsAndCompensationsGetJobsSuspense as
|
|
7
|
-
import { useJobsAndCompensationsCreateJobMutation as
|
|
8
|
-
import { useJobsAndCompensationsUpdateMutation as
|
|
9
|
-
import { useJobsAndCompensationsDeleteMutation as
|
|
10
|
-
import { useJobsAndCompensationsUpdateCompensationMutation as
|
|
11
|
-
import { useLocationsGetMinimumWagesSuspense as
|
|
12
|
-
import { useEmployeeAddressesGetWorkAddressesSuspense as
|
|
13
|
-
import { useFederalTaxDetailsGetSuspense as
|
|
14
|
-
import { useEmployeesGetSuspense as
|
|
15
|
-
import { List as
|
|
16
|
-
import { Head as
|
|
17
|
-
import { Edit as
|
|
18
|
-
import { Actions as
|
|
19
|
-
import { CompensationSchema as
|
|
20
|
-
import { Form as
|
|
1
|
+
import { jsx as s, jsxs as z, Fragment as K } from "react/jsx-runtime";
|
|
2
|
+
import { zodResolver as Q } from "@hookform/resolvers/zod";
|
|
3
|
+
import { useState as W, useMemo as F, useEffect as Z } from "react";
|
|
4
|
+
import { useForm as $, FormProvider as ee } from "react-hook-form";
|
|
5
|
+
import { useTranslation as te } from "react-i18next";
|
|
6
|
+
import { useJobsAndCompensationsGetJobsSuspense as oe } from "@gusto/embedded-api/react-query/jobsAndCompensationsGetJobs";
|
|
7
|
+
import { useJobsAndCompensationsCreateJobMutation as ne } from "@gusto/embedded-api/react-query/jobsAndCompensationsCreateJob";
|
|
8
|
+
import { useJobsAndCompensationsUpdateMutation as se } from "@gusto/embedded-api/react-query/jobsAndCompensationsUpdate";
|
|
9
|
+
import { useJobsAndCompensationsDeleteMutation as ae } from "@gusto/embedded-api/react-query/jobsAndCompensationsDelete";
|
|
10
|
+
import { useJobsAndCompensationsUpdateCompensationMutation as re } from "@gusto/embedded-api/react-query/jobsAndCompensationsUpdateCompensation";
|
|
11
|
+
import { useLocationsGetMinimumWagesSuspense as ie } from "@gusto/embedded-api/react-query/locationsGetMinimumWages";
|
|
12
|
+
import { useEmployeeAddressesGetWorkAddressesSuspense as me } from "@gusto/embedded-api/react-query/employeeAddressesGetWorkAddresses";
|
|
13
|
+
import { useFederalTaxDetailsGetSuspense as ue } from "@gusto/embedded-api/react-query/federalTaxDetailsGet";
|
|
14
|
+
import { useEmployeesGetSuspense as de } from "@gusto/embedded-api/react-query/employeesGet";
|
|
15
|
+
import { List as le } from "./List.js";
|
|
16
|
+
import { Head as ce } from "./Head.js";
|
|
17
|
+
import { Edit as fe } from "./Edit.js";
|
|
18
|
+
import { Actions as pe } from "./Actions.js";
|
|
19
|
+
import { CompensationSchema as Ce, CompensationProvider as Ee } from "./useCompensation.js";
|
|
20
|
+
import { Form as he } from "../../Common/Form/Form.js";
|
|
21
21
|
import { FlsaStatus as h, componentEvents as C } from "../../../shared/constants.js";
|
|
22
|
-
import { useComponentDictionary as
|
|
23
|
-
import { BaseComponent as
|
|
24
|
-
import { useBase as
|
|
25
|
-
import { useFlow as
|
|
26
|
-
function
|
|
27
|
-
return
|
|
22
|
+
import { useComponentDictionary as Ae, useI18n as De } from "../../../i18n/I18n.js";
|
|
23
|
+
import { BaseComponent as Se } from "../../Base/Base.js";
|
|
24
|
+
import { useBase as Oe } from "../../Base/useBase.js";
|
|
25
|
+
import { useFlow as ye } from "../../Flow/useFlow.js";
|
|
26
|
+
function Ie(t) {
|
|
27
|
+
return Ae("Employee.Compensation", t.dictionary), /* @__PURE__ */ s(Se, { ...t, children: /* @__PURE__ */ s(Pe, { ...t, children: t.children }) });
|
|
28
28
|
}
|
|
29
|
-
const
|
|
30
|
-
|
|
31
|
-
const { baseSubmitHandler:
|
|
32
|
-
data: { minimumWageList:
|
|
33
|
-
} =
|
|
34
|
-
locationUuid:
|
|
35
|
-
}),
|
|
29
|
+
const B = (t) => t?.compensations?.find((d) => d.uuid === t.currentCompensationUuid), Pe = ({ employeeId: t, startDate: d, className: A, children: D, ...m }) => {
|
|
30
|
+
De("Employee.Compensation");
|
|
31
|
+
const { baseSubmitHandler: j, onEvent: l } = Oe(), { data: V } = oe({ employeeId: t }), n = V.jobList, { data: Y } = me({ employeeId: t }), M = Y.employeeWorkAddressesList.find((e) => e.active), {
|
|
32
|
+
data: { minimumWageList: k }
|
|
33
|
+
} = ie({
|
|
34
|
+
locationUuid: M.locationUuid
|
|
35
|
+
}), x = k, {
|
|
36
36
|
data: { employee: g }
|
|
37
|
-
} =
|
|
37
|
+
} = de({ employeeId: t });
|
|
38
38
|
if (!g)
|
|
39
39
|
throw new Error("Employee not found");
|
|
40
|
-
const { data:
|
|
40
|
+
const { data: q } = ue({ companyId: g.companyUuid }), G = q.federalTaxDetails.taxPayerType === "S-Corporation", N = re(), _ = ne(), L = se(), J = ae(), [o, S] = W(
|
|
41
41
|
n.length === 1 ? n[0] ?? null : null
|
|
42
|
-
), [
|
|
42
|
+
), [y, c] = W(() => {
|
|
43
43
|
if (!n.length)
|
|
44
44
|
return "ADD_INITIAL_JOB";
|
|
45
|
-
const e =
|
|
45
|
+
const e = B(n[0]);
|
|
46
46
|
return n.length === 1 && e?.flsaStatus !== h.NONEXEMPT ? "EDIT_INITIAL_JOB" : "LIST";
|
|
47
|
-
}), [
|
|
48
|
-
const
|
|
49
|
-
(
|
|
47
|
+
}), [R, w] = W(!1), a = B(o), I = F(() => n.reduce((e, i) => {
|
|
48
|
+
const p = i.compensations?.find(
|
|
49
|
+
(O) => O.uuid === i.currentCompensationUuid
|
|
50
50
|
);
|
|
51
|
-
return !
|
|
52
|
-
}, void 0), [n]), f =
|
|
51
|
+
return !i.primary || !p ? e : p.flsaStatus ?? e;
|
|
52
|
+
}, void 0), [n]), f = F(() => ({
|
|
53
53
|
jobTitle: o?.title && o.title !== "" ? o.title : m.defaultValues?.title ?? "",
|
|
54
54
|
flsaStatus: a?.flsaStatus ?? I ?? m.defaultValues?.flsaStatus,
|
|
55
55
|
rate: Number(a?.rate ?? m.defaultValues?.rate ?? 0),
|
|
@@ -57,119 +57,116 @@ const F = (t) => t?.compensations?.find((l) => l.uuid === t.currentCompensationU
|
|
|
57
57
|
minimumWageId: a?.minimumWages?.[0]?.uuid ?? "",
|
|
58
58
|
paymentUnit: a?.paymentUnit ?? m.defaultValues?.paymentUnit ?? "Hour",
|
|
59
59
|
stateWcCovered: o?.stateWcCovered ?? !1,
|
|
60
|
-
stateWcClassCode: o?.stateWcClassCode ?? ""
|
|
61
|
-
|
|
62
|
-
|
|
60
|
+
stateWcClassCode: o?.stateWcClassCode ?? "",
|
|
61
|
+
twoPercentShareholder: o?.twoPercentShareholder ?? !1
|
|
62
|
+
}), [o, a, I, m.defaultValues]), v = $({
|
|
63
|
+
resolver: Q(Ce),
|
|
63
64
|
defaultValues: f
|
|
64
|
-
}), { resetField:
|
|
65
|
-
|
|
65
|
+
}), { resetField: P, setValue: b, handleSubmit: X, reset: E } = v;
|
|
66
|
+
return Z(() => {
|
|
66
67
|
E(f);
|
|
67
|
-
}, [o, f, E])
|
|
68
|
-
|
|
69
|
-
if (A === "LIST" && e === "PROCEED") {
|
|
70
|
-
c(C.EMPLOYEE_COMPENSATION_DONE);
|
|
71
|
-
return;
|
|
72
|
-
}
|
|
73
|
-
if (!o && A === "LIST") {
|
|
74
|
-
p("ADD_ADDITIONAL_JOB");
|
|
75
|
-
return;
|
|
76
|
-
}
|
|
77
|
-
await R(async (r) => {
|
|
78
|
-
switch (await $(r), e) {
|
|
79
|
-
case "LIST":
|
|
80
|
-
p("LIST"), S(null), E(f);
|
|
81
|
-
break;
|
|
82
|
-
default:
|
|
83
|
-
c(C.EMPLOYEE_COMPENSATION_DONE);
|
|
84
|
-
}
|
|
85
|
-
})();
|
|
86
|
-
}, H = () => {
|
|
87
|
-
p("ADD_ADDITIONAL_JOB"), S(null), E(f);
|
|
88
|
-
}, z = () => {
|
|
89
|
-
n.length > 0 ? p("LIST") : p("ADD_INITIAL_JOB"), S(null), E(f);
|
|
90
|
-
}, K = (e) => {
|
|
91
|
-
const r = n.find((u) => e === u.uuid);
|
|
92
|
-
r && (p("EDIT_ADDITIONAL_JOB"), S(r));
|
|
93
|
-
}, Q = async (e) => {
|
|
94
|
-
await J.mutateAsync({ request: { jobId: e } }), c(C.EMPLOYEE_JOB_DELETED);
|
|
95
|
-
}, Z = (e) => {
|
|
96
|
-
a?.flsaStatus === h.NONEXEMPT && n.length > 1 && w(!0), e === h.OWNER ? (b("paymentUnit", "Paycheck"), T("rate", { defaultValue: Number(a?.rate) })) : e === h.COMMISSION_ONLY_NONEXEMPT || e === h.COMMISSION_ONLY_EXEMPT ? (b("paymentUnit", "Year"), b("rate", 0)) : (T("paymentUnit", { defaultValue: a?.paymentUnit }), T("rate", { defaultValue: Number(a?.rate) }));
|
|
97
|
-
}, $ = async (e) => {
|
|
98
|
-
await B(e, async (r) => {
|
|
99
|
-
const { jobTitle: u, twoPercentShareholder: y, ...i } = r;
|
|
100
|
-
let d;
|
|
101
|
-
o ? (d = (await L.mutateAsync({
|
|
102
|
-
request: {
|
|
103
|
-
jobId: o.uuid,
|
|
104
|
-
requestBody: {
|
|
105
|
-
title: u,
|
|
106
|
-
version: o.version,
|
|
107
|
-
hireDate: l,
|
|
108
|
-
stateWcClassCode: i.stateWcCovered ? i.stateWcClassCode : null,
|
|
109
|
-
stateWcCovered: i.stateWcCovered,
|
|
110
|
-
twoPercentShareholder: y ?? !1
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
})).job, c(C.EMPLOYEE_JOB_UPDATED, d)) : (d = (await _.mutateAsync({
|
|
114
|
-
request: {
|
|
115
|
-
employeeId: t,
|
|
116
|
-
requestBody: {
|
|
117
|
-
title: u,
|
|
118
|
-
hireDate: l,
|
|
119
|
-
stateWcCovered: i.stateWcCovered,
|
|
120
|
-
stateWcClassCode: i.stateWcCovered ? i.stateWcClassCode : null,
|
|
121
|
-
twoPercentShareholder: y ?? !1
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
})).job, c(C.EMPLOYEE_JOB_CREATED, d));
|
|
125
|
-
const { compensation: ee } = await N.mutateAsync({
|
|
126
|
-
request: {
|
|
127
|
-
compensationId: d.currentCompensationUuid,
|
|
128
|
-
requestBody: {
|
|
129
|
-
// eslint-disable-next-line @typescript-eslint/no-non-null-asserted-optional-chain
|
|
130
|
-
version: d.compensations?.find(
|
|
131
|
-
(M) => M.uuid === d.currentCompensationUuid
|
|
132
|
-
)?.version,
|
|
133
|
-
...i,
|
|
134
|
-
rate: String(i.rate),
|
|
135
|
-
minimumWages: i.adjustForMinimumWage ? [{ uuid: i.minimumWageId }] : []
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
});
|
|
139
|
-
w(!1), c(C.EMPLOYEE_COMPENSATION_UPDATED, ee);
|
|
140
|
-
});
|
|
141
|
-
};
|
|
142
|
-
return /* @__PURE__ */ s("section", { className: D, children: /* @__PURE__ */ s(
|
|
143
|
-
Ae,
|
|
68
|
+
}, [o, f, E]), /* @__PURE__ */ s("section", { className: A, children: /* @__PURE__ */ s(
|
|
69
|
+
Ee,
|
|
144
70
|
{
|
|
145
71
|
value: {
|
|
146
72
|
employeeJobs: n,
|
|
147
73
|
currentJob: o,
|
|
148
74
|
primaryFlsaStatus: I,
|
|
149
|
-
showFlsaChangeWarning:
|
|
150
|
-
mode:
|
|
151
|
-
minimumWages:
|
|
152
|
-
handleFlsaChange:
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
75
|
+
showFlsaChangeWarning: R,
|
|
76
|
+
mode: y,
|
|
77
|
+
minimumWages: x,
|
|
78
|
+
handleFlsaChange: (e) => {
|
|
79
|
+
a?.flsaStatus === h.NONEXEMPT && n.length > 1 && w(!0), e === h.OWNER ? (b("paymentUnit", "Paycheck"), P("rate", { defaultValue: Number(a?.rate) })) : e === h.COMMISSION_ONLY_NONEXEMPT || e === h.COMMISSION_ONLY_EXEMPT ? (b("paymentUnit", "Year"), b("rate", 0)) : (P("paymentUnit", { defaultValue: a?.paymentUnit }), P("rate", { defaultValue: Number(a?.rate) }));
|
|
80
|
+
},
|
|
81
|
+
handleDelete: async (e) => {
|
|
82
|
+
await J.mutateAsync({ request: { jobId: e } }), l(C.EMPLOYEE_JOB_DELETED);
|
|
83
|
+
},
|
|
84
|
+
handleEdit: (e) => {
|
|
85
|
+
const i = n.find((p) => e === p.uuid);
|
|
86
|
+
i && (c("EDIT_ADDITIONAL_JOB"), S(i));
|
|
87
|
+
},
|
|
88
|
+
handleAdd: () => {
|
|
89
|
+
c("ADD_ADDITIONAL_JOB"), S(null), E(f);
|
|
90
|
+
},
|
|
91
|
+
submitWithEffect: async (e) => {
|
|
92
|
+
if (y === "LIST" && e === "PROCEED") {
|
|
93
|
+
l(C.EMPLOYEE_COMPENSATION_DONE);
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
if (!o && y === "LIST") {
|
|
97
|
+
c("ADD_ADDITIONAL_JOB");
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
await X(async (i) => {
|
|
101
|
+
await j(i, async (p) => {
|
|
102
|
+
const { jobTitle: O, twoPercentShareholder: U, ...r } = p;
|
|
103
|
+
let u;
|
|
104
|
+
o ? (u = (await L.mutateAsync({
|
|
105
|
+
request: {
|
|
106
|
+
jobId: o.uuid,
|
|
107
|
+
requestBody: {
|
|
108
|
+
title: O,
|
|
109
|
+
version: o.version,
|
|
110
|
+
hireDate: d,
|
|
111
|
+
stateWcClassCode: r.stateWcCovered ? r.stateWcClassCode : null,
|
|
112
|
+
stateWcCovered: r.stateWcCovered,
|
|
113
|
+
twoPercentShareholder: U ?? !1
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
})).job, l(C.EMPLOYEE_JOB_UPDATED, u)) : (u = (await _.mutateAsync({
|
|
117
|
+
request: {
|
|
118
|
+
employeeId: t,
|
|
119
|
+
requestBody: {
|
|
120
|
+
title: O,
|
|
121
|
+
hireDate: d,
|
|
122
|
+
stateWcCovered: r.stateWcCovered,
|
|
123
|
+
stateWcClassCode: r.stateWcCovered ? r.stateWcClassCode : null,
|
|
124
|
+
twoPercentShareholder: U ?? !1
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
})).job, l(C.EMPLOYEE_JOB_CREATED, u));
|
|
128
|
+
const { compensation: H } = await N.mutateAsync({
|
|
129
|
+
request: {
|
|
130
|
+
compensationId: u.currentCompensationUuid,
|
|
131
|
+
requestBody: {
|
|
132
|
+
// eslint-disable-next-line @typescript-eslint/no-non-null-asserted-optional-chain
|
|
133
|
+
version: u.compensations?.find(
|
|
134
|
+
(T) => T.uuid === u.currentCompensationUuid
|
|
135
|
+
)?.version,
|
|
136
|
+
...r,
|
|
137
|
+
rate: String(r.rate),
|
|
138
|
+
minimumWages: r.adjustForMinimumWage ? [{ uuid: r.minimumWageId }] : []
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
});
|
|
142
|
+
switch (w(!1), l(C.EMPLOYEE_COMPENSATION_UPDATED, H), e) {
|
|
143
|
+
case "LIST":
|
|
144
|
+
c("LIST"), S(null), E(f);
|
|
145
|
+
break;
|
|
146
|
+
default:
|
|
147
|
+
l(C.EMPLOYEE_COMPENSATION_DONE);
|
|
148
|
+
}
|
|
149
|
+
});
|
|
150
|
+
})();
|
|
151
|
+
},
|
|
152
|
+
handleCancelAddJob: () => {
|
|
153
|
+
n.length > 0 ? c("LIST") : c("ADD_INITIAL_JOB"), S(null), E(f);
|
|
154
|
+
},
|
|
158
155
|
isPending: N.isPending || _.isPending || L.isPending || J.isPending,
|
|
159
|
-
state:
|
|
160
|
-
showTwoPercentStakeholder:
|
|
156
|
+
state: M.state,
|
|
157
|
+
showTwoPercentStakeholder: G
|
|
161
158
|
},
|
|
162
|
-
children: /* @__PURE__ */ s(
|
|
163
|
-
/* @__PURE__ */ s(
|
|
164
|
-
/* @__PURE__ */ s(
|
|
165
|
-
/* @__PURE__ */ s(
|
|
166
|
-
/* @__PURE__ */ s(
|
|
159
|
+
children: /* @__PURE__ */ s(ee, { ...v, children: /* @__PURE__ */ s(he, { children: D || /* @__PURE__ */ z(K, { children: [
|
|
160
|
+
/* @__PURE__ */ s(ce, {}),
|
|
161
|
+
/* @__PURE__ */ s(le, {}),
|
|
162
|
+
/* @__PURE__ */ s(fe, {}),
|
|
163
|
+
/* @__PURE__ */ s(pe, {})
|
|
167
164
|
] }) }) })
|
|
168
165
|
}
|
|
169
166
|
) });
|
|
170
167
|
}, nt = () => {
|
|
171
|
-
const { employeeId: t, onEvent:
|
|
172
|
-
if (!t || !
|
|
168
|
+
const { employeeId: t, onEvent: d, startDate: A, defaultValues: D } = ye(), { t: m } = te("common");
|
|
169
|
+
if (!t || !A)
|
|
173
170
|
throw new Error(
|
|
174
171
|
m("errors.missingParamsOrContext", {
|
|
175
172
|
component: "Compensation",
|
|
@@ -178,17 +175,17 @@ const F = (t) => t?.compensations?.find((l) => l.uuid === t.currentCompensationU
|
|
|
178
175
|
})
|
|
179
176
|
);
|
|
180
177
|
return /* @__PURE__ */ s(
|
|
181
|
-
|
|
178
|
+
Ie,
|
|
182
179
|
{
|
|
183
180
|
employeeId: t,
|
|
184
|
-
startDate:
|
|
185
|
-
onEvent:
|
|
186
|
-
defaultValues:
|
|
181
|
+
startDate: A,
|
|
182
|
+
onEvent: d,
|
|
183
|
+
defaultValues: D?.compensation
|
|
187
184
|
}
|
|
188
185
|
);
|
|
189
186
|
};
|
|
190
187
|
export {
|
|
191
|
-
|
|
188
|
+
Ie as Compensation,
|
|
192
189
|
nt as CompensationContextual
|
|
193
190
|
};
|
|
194
191
|
//# sourceMappingURL=Compensation.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Compensation.js","sources":["../../../../src/components/Employee/Compensation/Compensation.tsx"],"sourcesContent":["import { zodResolver } from '@hookform/resolvers/zod'\nimport { useEffect, useMemo, useState } from 'react'\nimport { FormProvider, useForm, type SubmitHandler } from 'react-hook-form'\nimport { useTranslation } from 'react-i18next'\nimport { useJobsAndCompensationsGetJobsSuspense } 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 { useJobsAndCompensationsDeleteMutation } from '@gusto/embedded-api/react-query/jobsAndCompensationsDelete'\nimport { useJobsAndCompensationsUpdateCompensationMutation } from '@gusto/embedded-api/react-query/jobsAndCompensationsUpdateCompensation'\nimport { useLocationsGetMinimumWagesSuspense } from '@gusto/embedded-api/react-query/locationsGetMinimumWages'\nimport { useEmployeeAddressesGetWorkAddressesSuspense } from '@gusto/embedded-api/react-query/employeeAddressesGetWorkAddresses'\nimport { type Job } from '@gusto/embedded-api/models/components/job'\nimport type { FlsaStatusType } from '@gusto/embedded-api/models/components/flsastatustype'\nimport { useFederalTaxDetailsGetSuspense } from '@gusto/embedded-api/react-query/federalTaxDetailsGet'\nimport { useEmployeesGetSuspense } from '@gusto/embedded-api/react-query/employeesGet'\nimport type { OnboardingContextInterface } from '../OnboardingFlow/OnboardingFlowComponents'\nimport { List } from './List'\nimport { Head } from './Head'\nimport { Edit } from './Edit'\nimport { Actions } from './Actions'\nimport {\n type CompensationInputs,\n type CompensationOutputs,\n CompensationProvider,\n CompensationSchema,\n type MODE,\n} from './useCompensation'\nimport { Form } from '@/components/Common/Form'\nimport type { RequireAtLeastOne } from '@/types/Helpers'\nimport type { PAY_PERIODS } from '@/shared/constants'\nimport { componentEvents, FlsaStatus } from '@/shared/constants'\nimport { useComponentDictionary, useI18n } from '@/i18n'\nimport {\n BaseComponent,\n type BaseComponentInterface,\n useBase,\n type CommonComponentInterface,\n} from '@/components/Base'\nimport { useFlow } from '@/components/Flow/useFlow'\n\nexport type CompensationDefaultValues = RequireAtLeastOne<{\n rate?: Job['rate']\n title?: Job['title']\n paymentUnit?: (typeof PAY_PERIODS)[keyof typeof PAY_PERIODS]\n flsaStatus?: FlsaStatusType\n}>\n\ninterface CompensationProps extends CommonComponentInterface<'Employee.Compensation'> {\n employeeId: string\n startDate: string\n defaultValues?: CompensationDefaultValues\n}\n\nexport function Compensation(props: CompensationProps & BaseComponentInterface) {\n useComponentDictionary('Employee.Compensation', props.dictionary)\n return (\n <BaseComponent {...props}>\n <Root {...props}>{props.children}</Root>\n </BaseComponent>\n )\n}\n\nconst findCurrentCompensation = (employeeJob?: Job | null) => {\n return employeeJob?.compensations?.find(comp => comp.uuid === employeeJob.currentCompensationUuid)\n}\n\nconst Root = ({ employeeId, startDate, className, children, ...props }: CompensationProps) => {\n useI18n('Employee.Compensation')\n const { baseSubmitHandler, onEvent } = useBase()\n\n const { data: jobsData } = useJobsAndCompensationsGetJobsSuspense({ employeeId })\n const employeeJobs = jobsData.jobList!\n\n const { data: addressesData } = useEmployeeAddressesGetWorkAddressesSuspense({ employeeId })\n const workAddresses = addressesData.employeeWorkAddressesList!\n\n const currentWorkAddress = workAddresses.find(address => address.active)!\n\n const {\n data: { minimumWageList },\n } = useLocationsGetMinimumWagesSuspense({\n locationUuid: currentWorkAddress.locationUuid!,\n })\n const minimumWages = minimumWageList!\n\n const {\n data: { employee },\n } = useEmployeesGetSuspense({ employeeId })\n\n if (!employee) {\n throw new Error('Employee not found')\n }\n\n const { data } = useFederalTaxDetailsGetSuspense({ companyId: employee.companyUuid! })\n const showTwoPercentStakeholder = data.federalTaxDetails!.taxPayerType === 'S-Corporation'\n\n const updateCompensationMutation = useJobsAndCompensationsUpdateCompensationMutation()\n const createEmployeeJobMutation = useJobsAndCompensationsCreateJobMutation()\n const updateEmployeeJobMutation = useJobsAndCompensationsUpdateMutation()\n const deleteEmployeeJobMutation = useJobsAndCompensationsDeleteMutation()\n\n //Job being edited/created\n const [currentJob, setCurrentJob] = useState<Job | null>(\n employeeJobs.length === 1 ? (employeeJobs[0] ?? null) : null,\n )\n\n const [mode, setMode] = useState<MODE>(() => {\n if (!employeeJobs.length) {\n return 'ADD_INITIAL_JOB'\n }\n\n const currentCompensation = findCurrentCompensation(employeeJobs[0])\n\n if (employeeJobs.length === 1 && currentCompensation?.flsaStatus !== FlsaStatus.NONEXEMPT) {\n return 'EDIT_INITIAL_JOB'\n }\n\n return 'LIST'\n })\n\n const [showFlsaChangeWarning, setShowFlsaChangeWarning] = useState(false)\n //Getting current compensation for a job -> the one with the most recent effective date\n const currentCompensation = findCurrentCompensation(currentJob)\n /** Returns FLSA status of a current compensation of a primary job:\n * Employees can have multiple jobs, with multiple compensations, but only 1 job is primary with 1 current compensation\n */\n const primaryFlsaStatus = useMemo<string | undefined>(() => {\n return employeeJobs.reduce<string | 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 }, [employeeJobs])\n\n const defaultValues: CompensationInputs = useMemo(() => {\n return {\n jobTitle:\n currentJob?.title && currentJob.title !== ''\n ? currentJob.title\n : (props.defaultValues?.title ?? ''),\n flsaStatus:\n currentCompensation?.flsaStatus ?? primaryFlsaStatus ?? props.defaultValues?.flsaStatus,\n rate: Number(currentCompensation?.rate ?? props.defaultValues?.rate ?? 0),\n adjustForMinimumWage: currentCompensation?.adjustForMinimumWage ?? false,\n minimumWageId: currentCompensation?.minimumWages?.[0]?.uuid ?? '',\n paymentUnit: currentCompensation?.paymentUnit ?? props.defaultValues?.paymentUnit ?? 'Hour',\n stateWcCovered: currentJob?.stateWcCovered ?? false,\n stateWcClassCode: currentJob?.stateWcClassCode ?? '',\n } as CompensationInputs\n }, [currentJob, currentCompensation, primaryFlsaStatus, props.defaultValues])\n\n const formMethods = useForm<CompensationInputs, unknown, CompensationOutputs>({\n resolver: zodResolver(CompensationSchema),\n defaultValues,\n })\n const { resetField, setValue, handleSubmit, reset } = formMethods\n useEffect(() => {\n reset(defaultValues)\n }, [currentJob, defaultValues, reset])\n\n const submitWithEffect = async (newMode?: MODE) => {\n if (mode === 'LIST' && newMode === 'PROCEED') {\n onEvent(componentEvents.EMPLOYEE_COMPENSATION_DONE)\n return\n }\n //If no job has been modified, switch to edit mode\n if (!currentJob && mode === 'LIST') {\n setMode('ADD_ADDITIONAL_JOB')\n return\n }\n //Performing post-submit state setting only on success\n await handleSubmit(async (data: CompensationOutputs) => {\n await onSubmit(data)\n switch (newMode) {\n case 'LIST':\n setMode('LIST')\n setCurrentJob(null)\n reset(defaultValues)\n break\n default:\n onEvent(componentEvents.EMPLOYEE_COMPENSATION_DONE)\n }\n })()\n }\n const handleAdd = () => {\n setMode('ADD_ADDITIONAL_JOB')\n setCurrentJob(null)\n reset(defaultValues)\n }\n\n const handleCancelAddJob = () => {\n if (employeeJobs.length > 0) {\n setMode('LIST')\n } else {\n setMode('ADD_INITIAL_JOB')\n }\n\n setCurrentJob(null)\n reset(defaultValues)\n }\n\n const handleEdit = (uuid: string) => {\n const selectedJob = employeeJobs.find(job => uuid === job.uuid)\n if (selectedJob) {\n setMode('EDIT_ADDITIONAL_JOB')\n setCurrentJob(selectedJob)\n }\n }\n\n const handleDelete = async (jobId: string) => {\n await deleteEmployeeJobMutation.mutateAsync({ request: { jobId } })\n onEvent(componentEvents.EMPLOYEE_JOB_DELETED)\n }\n\n /**Update dependent field values upon change in FLSA type */\n const handleFlsaChange = (value: string | number) => {\n //Attempting to change flsa status from nonexempt should prompt user about deletion of other jobs associated with the employee\n if (currentCompensation?.flsaStatus === FlsaStatus.NONEXEMPT && employeeJobs.length > 1) {\n setShowFlsaChangeWarning(true)\n }\n if (value === FlsaStatus.OWNER) {\n setValue('paymentUnit', 'Paycheck')\n resetField('rate', { defaultValue: Number(currentCompensation?.rate) })\n } else if (\n value === FlsaStatus.COMMISSION_ONLY_NONEXEMPT ||\n value === FlsaStatus.COMMISSION_ONLY_EXEMPT\n ) {\n setValue('paymentUnit', 'Year')\n setValue('rate', 0)\n } else {\n //reset fields\n resetField('paymentUnit', { defaultValue: currentCompensation?.paymentUnit })\n resetField('rate', { defaultValue: Number(currentCompensation?.rate) })\n }\n }\n\n const onSubmit: SubmitHandler<CompensationOutputs> = async data => {\n await baseSubmitHandler(data, async payload => {\n const { jobTitle, twoPercentShareholder, ...compensationData } = payload\n let updatedJobData\n //Note: some of the type fixes below are due to the fact that API incorrectly defines current_compensation_uuid as optional\n if (!currentJob) {\n //Adding new job for NONEXEMPT\n const data = await createEmployeeJobMutation.mutateAsync({\n request: {\n employeeId,\n requestBody: {\n title: jobTitle,\n hireDate: startDate,\n stateWcCovered: compensationData.stateWcCovered,\n stateWcClassCode: compensationData.stateWcCovered\n ? compensationData.stateWcClassCode\n : null,\n twoPercentShareholder: twoPercentShareholder ?? false,\n },\n },\n })\n updatedJobData = data.job!\n onEvent(componentEvents.EMPLOYEE_JOB_CREATED, updatedJobData)\n } else {\n const data = await updateEmployeeJobMutation.mutateAsync({\n request: {\n jobId: currentJob.uuid,\n requestBody: {\n title: jobTitle,\n version: currentJob.version as string,\n hireDate: startDate,\n stateWcClassCode: compensationData.stateWcCovered\n ? compensationData.stateWcClassCode\n : null,\n stateWcCovered: compensationData.stateWcCovered,\n twoPercentShareholder: twoPercentShareholder ?? false,\n },\n },\n })\n updatedJobData = data.job!\n onEvent(componentEvents.EMPLOYEE_JOB_UPDATED, updatedJobData)\n }\n\n const { compensation } = await updateCompensationMutation.mutateAsync({\n request: {\n compensationId: updatedJobData.currentCompensationUuid!,\n requestBody: {\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 setShowFlsaChangeWarning(false)\n onEvent(componentEvents.EMPLOYEE_COMPENSATION_UPDATED, compensation)\n })\n }\n return (\n <section className={className}>\n <CompensationProvider\n value={{\n employeeJobs,\n currentJob,\n primaryFlsaStatus,\n showFlsaChangeWarning,\n mode,\n minimumWages,\n handleFlsaChange,\n handleDelete,\n handleEdit,\n handleAdd,\n submitWithEffect,\n handleCancelAddJob,\n isPending:\n updateCompensationMutation.isPending ||\n createEmployeeJobMutation.isPending ||\n updateEmployeeJobMutation.isPending ||\n deleteEmployeeJobMutation.isPending,\n state: currentWorkAddress.state,\n showTwoPercentStakeholder,\n }}\n >\n <FormProvider {...formMethods}>\n <Form>\n {children ? (\n children\n ) : (\n <>\n <Head />\n <List />\n <Edit />\n <Actions />\n </>\n )}\n </Form>\n </FormProvider>\n </CompensationProvider>\n </section>\n )\n}\n\nexport const CompensationContextual = () => {\n const { employeeId, onEvent, startDate, defaultValues } = useFlow<OnboardingContextInterface>()\n const { t } = useTranslation('common')\n\n if (!employeeId || !startDate) {\n throw new Error(\n t('errors.missingParamsOrContext', {\n component: 'Compensation',\n param: !employeeId ? 'employeeId' : 'startDate',\n provider: 'FlowProvider',\n }),\n )\n }\n return (\n <Compensation\n employeeId={employeeId}\n startDate={startDate}\n onEvent={onEvent}\n defaultValues={defaultValues?.compensation}\n />\n )\n}\n"],"names":["Compensation","props","useComponentDictionary","jsx","BaseComponent","Root","findCurrentCompensation","employeeJob","comp","employeeId","startDate","className","children","useI18n","baseSubmitHandler","onEvent","useBase","jobsData","useJobsAndCompensationsGetJobsSuspense","employeeJobs","addressesData","useEmployeeAddressesGetWorkAddressesSuspense","currentWorkAddress","address","minimumWageList","useLocationsGetMinimumWagesSuspense","minimumWages","employee","useEmployeesGetSuspense","data","useFederalTaxDetailsGetSuspense","showTwoPercentStakeholder","updateCompensationMutation","useJobsAndCompensationsUpdateCompensationMutation","createEmployeeJobMutation","useJobsAndCompensationsCreateJobMutation","updateEmployeeJobMutation","useJobsAndCompensationsUpdateMutation","deleteEmployeeJobMutation","useJobsAndCompensationsDeleteMutation","currentJob","setCurrentJob","useState","mode","setMode","currentCompensation","FlsaStatus","showFlsaChangeWarning","setShowFlsaChangeWarning","primaryFlsaStatus","useMemo","prev","curr","compensation","defaultValues","formMethods","useForm","zodResolver","CompensationSchema","resetField","setValue","handleSubmit","reset","useEffect","submitWithEffect","newMode","componentEvents","onSubmit","handleAdd","handleCancelAddJob","handleEdit","uuid","selectedJob","job","handleDelete","jobId","handleFlsaChange","value","payload","jobTitle","twoPercentShareholder","compensationData","updatedJobData","CompensationProvider","FormProvider","Form","jsxs","Fragment","Head","List","Edit","Actions","CompensationContextual","useFlow","t","useTranslation"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"Compensation.js","sources":["../../../../src/components/Employee/Compensation/Compensation.tsx"],"sourcesContent":["import { zodResolver } from '@hookform/resolvers/zod'\nimport { useEffect, useMemo, useState } from 'react'\nimport { FormProvider, useForm } from 'react-hook-form'\nimport { useTranslation } from 'react-i18next'\nimport { useJobsAndCompensationsGetJobsSuspense } 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 { useJobsAndCompensationsDeleteMutation } from '@gusto/embedded-api/react-query/jobsAndCompensationsDelete'\nimport { useJobsAndCompensationsUpdateCompensationMutation } from '@gusto/embedded-api/react-query/jobsAndCompensationsUpdateCompensation'\nimport { useLocationsGetMinimumWagesSuspense } from '@gusto/embedded-api/react-query/locationsGetMinimumWages'\nimport { useEmployeeAddressesGetWorkAddressesSuspense } from '@gusto/embedded-api/react-query/employeeAddressesGetWorkAddresses'\nimport { type Job } from '@gusto/embedded-api/models/components/job'\nimport type { FlsaStatusType } from '@gusto/embedded-api/models/components/flsastatustype'\nimport { useFederalTaxDetailsGetSuspense } from '@gusto/embedded-api/react-query/federalTaxDetailsGet'\nimport { useEmployeesGetSuspense } from '@gusto/embedded-api/react-query/employeesGet'\nimport type { OnboardingContextInterface } from '../OnboardingFlow/OnboardingFlowComponents'\nimport { List } from './List'\nimport { Head } from './Head'\nimport { Edit } from './Edit'\nimport { Actions } from './Actions'\nimport {\n type CompensationInputs,\n type CompensationOutputs,\n CompensationProvider,\n CompensationSchema,\n type MODE,\n} from './useCompensation'\nimport { Form } from '@/components/Common/Form'\nimport type { RequireAtLeastOne } from '@/types/Helpers'\nimport type { PAY_PERIODS } from '@/shared/constants'\nimport { componentEvents, FlsaStatus } from '@/shared/constants'\nimport { useComponentDictionary, useI18n } from '@/i18n'\nimport {\n BaseComponent,\n type BaseComponentInterface,\n useBase,\n type CommonComponentInterface,\n} from '@/components/Base'\nimport { useFlow } from '@/components/Flow/useFlow'\n\nexport type CompensationDefaultValues = RequireAtLeastOne<{\n rate?: Job['rate']\n title?: Job['title']\n paymentUnit?: (typeof PAY_PERIODS)[keyof typeof PAY_PERIODS]\n flsaStatus?: FlsaStatusType\n}>\n\ninterface CompensationProps extends CommonComponentInterface<'Employee.Compensation'> {\n employeeId: string\n startDate: string\n defaultValues?: CompensationDefaultValues\n}\n\nexport function Compensation(props: CompensationProps & BaseComponentInterface) {\n useComponentDictionary('Employee.Compensation', props.dictionary)\n return (\n <BaseComponent {...props}>\n <Root {...props}>{props.children}</Root>\n </BaseComponent>\n )\n}\n\nconst findCurrentCompensation = (employeeJob?: Job | null) => {\n return employeeJob?.compensations?.find(comp => comp.uuid === employeeJob.currentCompensationUuid)\n}\n\nconst Root = ({ employeeId, startDate, className, children, ...props }: CompensationProps) => {\n useI18n('Employee.Compensation')\n const { baseSubmitHandler, onEvent } = useBase()\n\n const { data: jobsData } = useJobsAndCompensationsGetJobsSuspense({ employeeId })\n const employeeJobs = jobsData.jobList!\n\n const { data: addressesData } = useEmployeeAddressesGetWorkAddressesSuspense({ employeeId })\n const workAddresses = addressesData.employeeWorkAddressesList!\n\n const currentWorkAddress = workAddresses.find(address => address.active)!\n\n const {\n data: { minimumWageList },\n } = useLocationsGetMinimumWagesSuspense({\n locationUuid: currentWorkAddress.locationUuid!,\n })\n const minimumWages = minimumWageList!\n\n const {\n data: { employee },\n } = useEmployeesGetSuspense({ employeeId })\n\n if (!employee) {\n throw new Error('Employee not found')\n }\n\n const { data } = useFederalTaxDetailsGetSuspense({ companyId: employee.companyUuid! })\n const showTwoPercentStakeholder = data.federalTaxDetails!.taxPayerType === 'S-Corporation'\n\n const updateCompensationMutation = useJobsAndCompensationsUpdateCompensationMutation()\n const createEmployeeJobMutation = useJobsAndCompensationsCreateJobMutation()\n const updateEmployeeJobMutation = useJobsAndCompensationsUpdateMutation()\n const deleteEmployeeJobMutation = useJobsAndCompensationsDeleteMutation()\n\n //Job being edited/created\n const [currentJob, setCurrentJob] = useState<Job | null>(\n employeeJobs.length === 1 ? (employeeJobs[0] ?? null) : null,\n )\n\n const [mode, setMode] = useState<MODE>(() => {\n if (!employeeJobs.length) {\n return 'ADD_INITIAL_JOB'\n }\n\n const currentCompensation = findCurrentCompensation(employeeJobs[0])\n\n if (employeeJobs.length === 1 && currentCompensation?.flsaStatus !== FlsaStatus.NONEXEMPT) {\n return 'EDIT_INITIAL_JOB'\n }\n\n return 'LIST'\n })\n\n const [showFlsaChangeWarning, setShowFlsaChangeWarning] = useState(false)\n //Getting current compensation for a job -> the one with the most recent effective date\n const currentCompensation = findCurrentCompensation(currentJob)\n /** Returns FLSA status of a current compensation of a primary job:\n * Employees can have multiple jobs, with multiple compensations, but only 1 job is primary with 1 current compensation\n */\n const primaryFlsaStatus = useMemo<string | undefined>(() => {\n return employeeJobs.reduce<string | 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 }, [employeeJobs])\n\n const defaultValues: CompensationInputs = useMemo(() => {\n return {\n jobTitle:\n currentJob?.title && currentJob.title !== ''\n ? currentJob.title\n : (props.defaultValues?.title ?? ''),\n flsaStatus:\n currentCompensation?.flsaStatus ?? primaryFlsaStatus ?? props.defaultValues?.flsaStatus,\n rate: Number(currentCompensation?.rate ?? props.defaultValues?.rate ?? 0),\n adjustForMinimumWage: currentCompensation?.adjustForMinimumWage ?? false,\n minimumWageId: currentCompensation?.minimumWages?.[0]?.uuid ?? '',\n paymentUnit: currentCompensation?.paymentUnit ?? props.defaultValues?.paymentUnit ?? 'Hour',\n stateWcCovered: currentJob?.stateWcCovered ?? false,\n stateWcClassCode: currentJob?.stateWcClassCode ?? '',\n twoPercentShareholder: currentJob?.twoPercentShareholder ?? false,\n } as CompensationInputs\n }, [currentJob, currentCompensation, primaryFlsaStatus, props.defaultValues])\n\n const formMethods = useForm<CompensationInputs, unknown, CompensationOutputs>({\n resolver: zodResolver(CompensationSchema),\n defaultValues,\n })\n const { resetField, setValue, handleSubmit, reset } = formMethods\n useEffect(() => {\n reset(defaultValues)\n }, [currentJob, defaultValues, reset])\n\n const submitWithEffect = async (newMode?: MODE) => {\n if (mode === 'LIST' && newMode === 'PROCEED') {\n onEvent(componentEvents.EMPLOYEE_COMPENSATION_DONE)\n return\n }\n //If no job has been modified, switch to edit mode\n if (!currentJob && mode === 'LIST') {\n setMode('ADD_ADDITIONAL_JOB')\n return\n }\n //Performing post-submit state setting only on success\n await handleSubmit(async (data: CompensationOutputs) => {\n await baseSubmitHandler(data, async payload => {\n const { jobTitle, twoPercentShareholder, ...compensationData } = payload\n let updatedJobData\n //Note: some of the type fixes below are due to the fact that API incorrectly defines current_compensation_uuid as optional\n if (!currentJob) {\n //Adding new job for NONEXEMPT\n const data = await createEmployeeJobMutation.mutateAsync({\n request: {\n employeeId,\n requestBody: {\n title: jobTitle,\n hireDate: startDate,\n stateWcCovered: compensationData.stateWcCovered,\n stateWcClassCode: compensationData.stateWcCovered\n ? compensationData.stateWcClassCode\n : null,\n twoPercentShareholder: twoPercentShareholder ?? false,\n },\n },\n })\n updatedJobData = data.job!\n onEvent(componentEvents.EMPLOYEE_JOB_CREATED, updatedJobData)\n } else {\n const data = await updateEmployeeJobMutation.mutateAsync({\n request: {\n jobId: currentJob.uuid,\n requestBody: {\n title: jobTitle,\n version: currentJob.version as string,\n hireDate: startDate,\n stateWcClassCode: compensationData.stateWcCovered\n ? compensationData.stateWcClassCode\n : null,\n stateWcCovered: compensationData.stateWcCovered,\n twoPercentShareholder: twoPercentShareholder ?? false,\n },\n },\n })\n updatedJobData = data.job!\n onEvent(componentEvents.EMPLOYEE_JOB_UPDATED, updatedJobData)\n }\n\n const { compensation } = await updateCompensationMutation.mutateAsync({\n request: {\n compensationId: updatedJobData.currentCompensationUuid!,\n requestBody: {\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 setShowFlsaChangeWarning(false)\n onEvent(componentEvents.EMPLOYEE_COMPENSATION_UPDATED, compensation)\n\n // Success logic only runs if no errors were thrown above\n switch (newMode) {\n case 'LIST':\n setMode('LIST')\n setCurrentJob(null)\n reset(defaultValues)\n break\n default:\n onEvent(componentEvents.EMPLOYEE_COMPENSATION_DONE)\n }\n })\n })()\n }\n const handleAdd = () => {\n setMode('ADD_ADDITIONAL_JOB')\n setCurrentJob(null)\n reset(defaultValues)\n }\n\n const handleCancelAddJob = () => {\n if (employeeJobs.length > 0) {\n setMode('LIST')\n } else {\n setMode('ADD_INITIAL_JOB')\n }\n\n setCurrentJob(null)\n reset(defaultValues)\n }\n\n const handleEdit = (uuid: string) => {\n const selectedJob = employeeJobs.find(job => uuid === job.uuid)\n if (selectedJob) {\n setMode('EDIT_ADDITIONAL_JOB')\n setCurrentJob(selectedJob)\n }\n }\n\n const handleDelete = async (jobId: string) => {\n await deleteEmployeeJobMutation.mutateAsync({ request: { jobId } })\n onEvent(componentEvents.EMPLOYEE_JOB_DELETED)\n }\n\n /**Update dependent field values upon change in FLSA type */\n const handleFlsaChange = (value: string | number) => {\n //Attempting to change flsa status from nonexempt should prompt user about deletion of other jobs associated with the employee\n if (currentCompensation?.flsaStatus === FlsaStatus.NONEXEMPT && employeeJobs.length > 1) {\n setShowFlsaChangeWarning(true)\n }\n if (value === FlsaStatus.OWNER) {\n setValue('paymentUnit', 'Paycheck')\n resetField('rate', { defaultValue: Number(currentCompensation?.rate) })\n } else if (\n value === FlsaStatus.COMMISSION_ONLY_NONEXEMPT ||\n value === FlsaStatus.COMMISSION_ONLY_EXEMPT\n ) {\n setValue('paymentUnit', 'Year')\n setValue('rate', 0)\n } else {\n //reset fields\n resetField('paymentUnit', { defaultValue: currentCompensation?.paymentUnit })\n resetField('rate', { defaultValue: Number(currentCompensation?.rate) })\n }\n }\n return (\n <section className={className}>\n <CompensationProvider\n value={{\n employeeJobs,\n currentJob,\n primaryFlsaStatus,\n showFlsaChangeWarning,\n mode,\n minimumWages,\n handleFlsaChange,\n handleDelete,\n handleEdit,\n handleAdd,\n submitWithEffect,\n handleCancelAddJob,\n isPending:\n updateCompensationMutation.isPending ||\n createEmployeeJobMutation.isPending ||\n updateEmployeeJobMutation.isPending ||\n deleteEmployeeJobMutation.isPending,\n state: currentWorkAddress.state,\n showTwoPercentStakeholder,\n }}\n >\n <FormProvider {...formMethods}>\n <Form>\n {children ? (\n children\n ) : (\n <>\n <Head />\n <List />\n <Edit />\n <Actions />\n </>\n )}\n </Form>\n </FormProvider>\n </CompensationProvider>\n </section>\n )\n}\n\nexport const CompensationContextual = () => {\n const { employeeId, onEvent, startDate, defaultValues } = useFlow<OnboardingContextInterface>()\n const { t } = useTranslation('common')\n\n if (!employeeId || !startDate) {\n throw new Error(\n t('errors.missingParamsOrContext', {\n component: 'Compensation',\n param: !employeeId ? 'employeeId' : 'startDate',\n provider: 'FlowProvider',\n }),\n )\n }\n return (\n <Compensation\n employeeId={employeeId}\n startDate={startDate}\n onEvent={onEvent}\n defaultValues={defaultValues?.compensation}\n />\n )\n}\n"],"names":["Compensation","props","useComponentDictionary","jsx","BaseComponent","Root","findCurrentCompensation","employeeJob","comp","employeeId","startDate","className","children","useI18n","baseSubmitHandler","onEvent","useBase","jobsData","useJobsAndCompensationsGetJobsSuspense","employeeJobs","addressesData","useEmployeeAddressesGetWorkAddressesSuspense","currentWorkAddress","address","minimumWageList","useLocationsGetMinimumWagesSuspense","minimumWages","employee","useEmployeesGetSuspense","data","useFederalTaxDetailsGetSuspense","showTwoPercentStakeholder","updateCompensationMutation","useJobsAndCompensationsUpdateCompensationMutation","createEmployeeJobMutation","useJobsAndCompensationsCreateJobMutation","updateEmployeeJobMutation","useJobsAndCompensationsUpdateMutation","deleteEmployeeJobMutation","useJobsAndCompensationsDeleteMutation","currentJob","setCurrentJob","useState","mode","setMode","currentCompensation","FlsaStatus","showFlsaChangeWarning","setShowFlsaChangeWarning","primaryFlsaStatus","useMemo","prev","curr","compensation","defaultValues","formMethods","useForm","zodResolver","CompensationSchema","resetField","setValue","handleSubmit","reset","useEffect","CompensationProvider","value","jobId","componentEvents","uuid","selectedJob","job","newMode","payload","jobTitle","twoPercentShareholder","compensationData","updatedJobData","FormProvider","Form","jsxs","Fragment","Head","List","Edit","Actions","CompensationContextual","useFlow","t","useTranslation"],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { jsxs as
|
|
1
|
+
import { jsxs as u, Fragment as d, jsx as t } from "react/jsx-runtime";
|
|
2
2
|
import { useMemo as F, useEffect as U } from "react";
|
|
3
3
|
import { useFormContext as k, useWatch as M } from "react-hook-form";
|
|
4
4
|
import { useTranslation as P, Trans as I } from "react-i18next";
|
|
@@ -12,21 +12,22 @@ import { NumberInputField as B } from "../../Common/Fields/NumberInputField/Numb
|
|
|
12
12
|
import { SwitchField as J } from "../../Common/Fields/SwitchField/SwitchField.js";
|
|
13
13
|
import { useComponentContext as K } from "../../../contexts/ComponentAdapter/useComponentContext.js";
|
|
14
14
|
import { WA_RISK_CLASS_CODES as q } from "../../../models/WA_RISK_CODES.js";
|
|
15
|
-
import { SelectField as
|
|
16
|
-
import {
|
|
17
|
-
|
|
18
|
-
|
|
15
|
+
import { SelectField as O } from "../../Common/Fields/SelectField/SelectField.js";
|
|
16
|
+
import { CheckboxField as H } from "../../Common/Fields/CheckboxField/CheckboxField.js";
|
|
17
|
+
import { ComboBoxField as $ } from "../../Common/Fields/ComboBoxField/ComboBoxField.js";
|
|
18
|
+
const ue = () => {
|
|
19
|
+
const { t: e } = P("Employee.Compensation"), l = x("currency"), b = K(), S = F(
|
|
19
20
|
() => q.map(({ code: o, description: D }) => ({ value: o, label: D })),
|
|
20
21
|
[]
|
|
21
22
|
), {
|
|
22
23
|
control: f,
|
|
23
24
|
register: h,
|
|
24
25
|
setValue: s,
|
|
25
|
-
formState: { errors: C, defaultValues:
|
|
26
|
+
formState: { errors: C, defaultValues: m }
|
|
26
27
|
} = k(), i = M({ control: f, name: "flsaStatus" }), _ = M({ control: f, name: "stateWcCovered" }), { currentJob: y, mode: n, minimumWages: E, handleFlsaChange: T, state: W, showTwoPercentStakeholder: v } = R();
|
|
27
28
|
if (U(() => {
|
|
28
|
-
i === a.OWNER ? s("paymentUnit", "Paycheck") : i === a.COMMISSION_ONLY_NONEXEMPT || i === a.COMMISSION_ONLY_EXEMPT ? (s("paymentUnit", "Year"), s("rate", 0)) :
|
|
29
|
-
}, [i, s,
|
|
29
|
+
i === a.OWNER ? s("paymentUnit", "Paycheck") : i === a.COMMISSION_ONLY_NONEXEMPT || i === a.COMMISSION_ONLY_EXEMPT ? (s("paymentUnit", "Year"), s("rate", 0)) : m?.paymentUnit && s("paymentUnit", m.paymentUnit);
|
|
30
|
+
}, [i, s, m?.paymentUnit]), !(n === "ADD_INITIAL_JOB" || n === "ADD_ADDITIONAL_JOB" || n === "EDIT_INITIAL_JOB" || n === "EDIT_ADDITIONAL_JOB"))
|
|
30
31
|
return;
|
|
31
32
|
const L = Object.keys(a).map(
|
|
32
33
|
(o) => ({
|
|
@@ -39,11 +40,11 @@ const pe = () => {
|
|
|
39
40
|
{ value: r.MONTH, label: e("paymentUnitOptions.Month") },
|
|
40
41
|
{ value: r.YEAR, label: e("paymentUnitOptions.Year") },
|
|
41
42
|
{ value: r.PAYCHECK, label: e("paymentUnitOptions.Paycheck") }
|
|
42
|
-
],
|
|
43
|
-
let
|
|
44
|
-
return C.rate?.message === Y ?
|
|
43
|
+
], p = i !== a.NONEXEMPT || y?.primary || n === "ADD_INITIAL_JOB", A = i === a.NONEXEMPT && E.length > 0;
|
|
44
|
+
let c = e("validations.rate");
|
|
45
|
+
return C.rate?.message === Y ? c = e("validations.nonZeroRate") : C.rate?.message === w && (c = e("validations.rateExemptThreshold", {
|
|
45
46
|
limit: l(N)
|
|
46
|
-
})), /* @__PURE__ */ d
|
|
47
|
+
})), /* @__PURE__ */ u(d, { children: [
|
|
47
48
|
/* @__PURE__ */ t(
|
|
48
49
|
X,
|
|
49
50
|
{
|
|
@@ -53,9 +54,9 @@ const pe = () => {
|
|
|
53
54
|
errorMessage: e("validations.title")
|
|
54
55
|
}
|
|
55
56
|
),
|
|
56
|
-
!
|
|
57
|
-
|
|
58
|
-
|
|
57
|
+
!p && /* @__PURE__ */ t("input", { type: "hidden", ...h("flsaStatus") }),
|
|
58
|
+
p && /* @__PURE__ */ t(
|
|
59
|
+
O,
|
|
59
60
|
{
|
|
60
61
|
name: "flsaStatus",
|
|
61
62
|
label: e("employeeClassification"),
|
|
@@ -64,7 +65,7 @@ const pe = () => {
|
|
|
64
65
|
{
|
|
65
66
|
t: e,
|
|
66
67
|
i18nKey: "classificationCTA",
|
|
67
|
-
components: { classificationCta: /* @__PURE__ */ t(
|
|
68
|
+
components: { classificationCta: /* @__PURE__ */ t(b.Link, {}) }
|
|
68
69
|
}
|
|
69
70
|
),
|
|
70
71
|
errorMessage: e("validations.exemptThreshold", {
|
|
@@ -72,7 +73,7 @@ const pe = () => {
|
|
|
72
73
|
}),
|
|
73
74
|
options: L,
|
|
74
75
|
isRequired: !0,
|
|
75
|
-
isDisabled: !
|
|
76
|
+
isDisabled: !p,
|
|
76
77
|
onChange: T
|
|
77
78
|
}
|
|
78
79
|
),
|
|
@@ -83,12 +84,12 @@ const pe = () => {
|
|
|
83
84
|
label: e("amount"),
|
|
84
85
|
format: "currency",
|
|
85
86
|
min: 0,
|
|
86
|
-
errorMessage:
|
|
87
|
+
errorMessage: c,
|
|
87
88
|
isRequired: !0,
|
|
88
89
|
isDisabled: i === a.COMMISSION_ONLY_NONEXEMPT || i === a.COMMISSION_ONLY_EXEMPT
|
|
89
90
|
}
|
|
90
91
|
),
|
|
91
|
-
A && /* @__PURE__ */ d
|
|
92
|
+
A && /* @__PURE__ */ u(d, { children: [
|
|
92
93
|
/* @__PURE__ */ t(
|
|
93
94
|
J,
|
|
94
95
|
{
|
|
@@ -98,7 +99,7 @@ const pe = () => {
|
|
|
98
99
|
}
|
|
99
100
|
),
|
|
100
101
|
/* @__PURE__ */ t(
|
|
101
|
-
|
|
102
|
+
O,
|
|
102
103
|
{
|
|
103
104
|
name: "minimumWageId",
|
|
104
105
|
label: e("minimumWageLabel"),
|
|
@@ -112,7 +113,7 @@ const pe = () => {
|
|
|
112
113
|
)
|
|
113
114
|
] }),
|
|
114
115
|
/* @__PURE__ */ t(
|
|
115
|
-
|
|
116
|
+
O,
|
|
116
117
|
{
|
|
117
118
|
name: "paymentUnit",
|
|
118
119
|
label: e("paymentUnitLabel"),
|
|
@@ -123,8 +124,8 @@ const pe = () => {
|
|
|
123
124
|
isDisabled: i === a.OWNER || i === a.COMMISSION_ONLY_NONEXEMPT || i === a.COMMISSION_ONLY_EXEMPT
|
|
124
125
|
}
|
|
125
126
|
),
|
|
126
|
-
v && /* @__PURE__ */ t(
|
|
127
|
-
W === "WA" && /* @__PURE__ */ d
|
|
127
|
+
v && /* @__PURE__ */ t(H, { label: e("twoPercentStakeholderLabel"), name: "twoPercentShareholder" }),
|
|
128
|
+
W === "WA" && /* @__PURE__ */ u(d, { children: [
|
|
128
129
|
/* @__PURE__ */ t(
|
|
129
130
|
j,
|
|
130
131
|
{
|
|
@@ -137,7 +138,7 @@ const pe = () => {
|
|
|
137
138
|
i18nKey: "stateWcCoveredDescription",
|
|
138
139
|
components: {
|
|
139
140
|
wcLink: /* @__PURE__ */ t(
|
|
140
|
-
|
|
141
|
+
b.Link,
|
|
141
142
|
{
|
|
142
143
|
href: "https://www.lni.wa.gov/insurance/rates-risk-classes/risk-classes-for-workers-compensation/risk-class-lookup#/",
|
|
143
144
|
target: "_blank",
|
|
@@ -154,7 +155,7 @@ const pe = () => {
|
|
|
154
155
|
}
|
|
155
156
|
),
|
|
156
157
|
_ && /* @__PURE__ */ t(
|
|
157
|
-
|
|
158
|
+
$,
|
|
158
159
|
{
|
|
159
160
|
name: "stateWcClassCode",
|
|
160
161
|
label: e("stateWcClassCodeLabel"),
|
|
@@ -167,6 +168,6 @@ const pe = () => {
|
|
|
167
168
|
] });
|
|
168
169
|
};
|
|
169
170
|
export {
|
|
170
|
-
|
|
171
|
+
ue as Edit
|
|
171
172
|
};
|
|
172
173
|
//# sourceMappingURL=Edit.js.map
|