@gusto/embedded-react-sdk 0.8.2 → 0.10.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.
Files changed (223) hide show
  1. package/CHANGELOG.md +91 -2
  2. package/dist/components/Common/DataView/DataCards/DataCards.js +21 -21
  3. package/dist/components/Common/DataView/DataCards/DataCards.js.map +1 -1
  4. package/dist/components/Common/OnboardingStatusBadge/index.d.ts +21 -0
  5. package/dist/components/Common/OnboardingStatusBadge/index.js +17 -0
  6. package/dist/components/Common/OnboardingStatusBadge/index.js.map +1 -0
  7. package/dist/components/Common/SignatureForm/SignatureFormActions.js +8 -7
  8. package/dist/components/Common/SignatureForm/SignatureFormActions.js.map +1 -1
  9. package/dist/components/Common/SignatureForm/SignatureFormFields.js +5 -4
  10. package/dist/components/Common/SignatureForm/SignatureFormFields.js.map +1 -1
  11. package/dist/components/Common/TaxInputs/TaxInputs.js +42 -36
  12. package/dist/components/Common/TaxInputs/TaxInputs.js.map +1 -1
  13. package/dist/components/Common/UI/ComboBox/ComboBox.js +28 -27
  14. package/dist/components/Common/UI/ComboBox/ComboBox.js.map +1 -1
  15. package/dist/components/Common/UI/ComboBox/ComboBox.module.scss.js +6 -6
  16. package/dist/components/Company/AssignSignatory/AssignSignatorySelection.js +7 -6
  17. package/dist/components/Company/AssignSignatory/AssignSignatorySelection.js.map +1 -1
  18. package/dist/components/Company/AssignSignatory/CreateSignatory/Actions.js +9 -8
  19. package/dist/components/Company/AssignSignatory/CreateSignatory/Actions.js.map +1 -1
  20. package/dist/components/Company/AssignSignatory/CreateSignatory/useCreateSignatory.js +5 -3
  21. package/dist/components/Company/AssignSignatory/CreateSignatory/useCreateSignatory.js.map +1 -1
  22. package/dist/components/Company/AssignSignatory/InviteSignatory/Actions.js +7 -6
  23. package/dist/components/Company/AssignSignatory/InviteSignatory/Actions.js.map +1 -1
  24. package/dist/components/Company/AssignSignatory/InviteSignatory/useInviteSignatory.js +5 -3
  25. package/dist/components/Company/AssignSignatory/InviteSignatory/useInviteSignatory.js.map +1 -1
  26. package/dist/components/Company/AssignSignatory/useAssignSignatory.js +7 -5
  27. package/dist/components/Company/AssignSignatory/useAssignSignatory.js.map +1 -1
  28. package/dist/components/Company/BankAccount/BankAccountForm/Actions.js +3 -2
  29. package/dist/components/Company/BankAccount/BankAccountForm/Actions.js.map +1 -1
  30. package/dist/components/Company/BankAccount/BankAccountForm/context.js +5 -3
  31. package/dist/components/Company/BankAccount/BankAccountForm/context.js.map +1 -1
  32. package/dist/components/Company/BankAccount/BankAccountList/Actions.js +7 -6
  33. package/dist/components/Company/BankAccount/BankAccountList/Actions.js.map +1 -1
  34. package/dist/components/Company/BankAccount/BankAccountVerify/Actions.js +8 -7
  35. package/dist/components/Company/BankAccount/BankAccountVerify/Actions.js.map +1 -1
  36. package/dist/components/Company/DocumentSigner/DocumentList/Actions.js +6 -5
  37. package/dist/components/Company/DocumentSigner/DocumentList/Actions.js.map +1 -1
  38. package/dist/components/Company/DocumentSigner/DocumentList/useDocumentList.js +5 -3
  39. package/dist/components/Company/DocumentSigner/DocumentList/useDocumentList.js.map +1 -1
  40. package/dist/components/Company/DocumentSigner/SignatureForm/useSignatureForm.js +5 -3
  41. package/dist/components/Company/DocumentSigner/SignatureForm/useSignatureForm.js.map +1 -1
  42. package/dist/components/Company/FederalTaxes/Actions.js +7 -6
  43. package/dist/components/Company/FederalTaxes/Actions.js.map +1 -1
  44. package/dist/components/Company/FederalTaxes/useFederalTaxes.js +13 -11
  45. package/dist/components/Company/FederalTaxes/useFederalTaxes.js.map +1 -1
  46. package/dist/components/Company/Industry/Actions.js +6 -5
  47. package/dist/components/Company/Industry/Actions.js.map +1 -1
  48. package/dist/components/Company/Industry/Context.js +8 -6
  49. package/dist/components/Company/Industry/Context.js.map +1 -1
  50. package/dist/components/Company/Industry/Edit.js +11 -10
  51. package/dist/components/Company/Industry/Edit.js.map +1 -1
  52. package/dist/components/Company/Locations/LocationForm/Actions.js +3 -2
  53. package/dist/components/Company/Locations/LocationForm/Actions.js.map +1 -1
  54. package/dist/components/Company/Locations/LocationForm/useLocationForm.js +5 -3
  55. package/dist/components/Company/Locations/LocationForm/useLocationForm.js.map +1 -1
  56. package/dist/components/Company/Locations/LocationsList/Actions.js +3 -2
  57. package/dist/components/Company/Locations/LocationsList/Actions.js.map +1 -1
  58. package/dist/components/Company/Locations/LocationsList/List.js +7 -6
  59. package/dist/components/Company/Locations/LocationsList/List.js.map +1 -1
  60. package/dist/components/Company/Locations/LocationsList/useLocationsList.js +5 -3
  61. package/dist/components/Company/Locations/LocationsList/useLocationsList.js.map +1 -1
  62. package/dist/components/Company/OnboardingOverview/context.js +5 -3
  63. package/dist/components/Company/OnboardingOverview/context.js.map +1 -1
  64. package/dist/components/Company/PaySchedule/_parts/Actions.js +11 -10
  65. package/dist/components/Company/PaySchedule/_parts/Actions.js.map +1 -1
  66. package/dist/components/Company/PaySchedule/usePaySchedule.js +7 -5
  67. package/dist/components/Company/PaySchedule/usePaySchedule.js.map +1 -1
  68. package/dist/components/Company/StateTaxes/StateTaxesForm/Actions.js +10 -9
  69. package/dist/components/Company/StateTaxes/StateTaxesForm/Actions.js.map +1 -1
  70. package/dist/components/Company/StateTaxes/StateTaxesForm/Form.js +1 -1
  71. package/dist/components/Company/StateTaxes/StateTaxesForm/Form.js.map +1 -1
  72. package/dist/components/Company/StateTaxes/StateTaxesForm/StateTaxesForm.js +29 -29
  73. package/dist/components/Company/StateTaxes/StateTaxesForm/StateTaxesForm.js.map +1 -1
  74. package/dist/components/Company/StateTaxes/StateTaxesForm/context.js +5 -3
  75. package/dist/components/Company/StateTaxes/StateTaxesForm/context.js.map +1 -1
  76. package/dist/components/Company/StateTaxes/StateTaxesList/Actions.js +7 -6
  77. package/dist/components/Company/StateTaxes/StateTaxesList/Actions.js.map +1 -1
  78. package/dist/components/Company/StateTaxes/StateTaxesList/List.js +6 -5
  79. package/dist/components/Company/StateTaxes/StateTaxesList/List.js.map +1 -1
  80. package/dist/components/Company/StateTaxes/StateTaxesList/context.js +5 -3
  81. package/dist/components/Company/StateTaxes/StateTaxesList/context.js.map +1 -1
  82. package/dist/components/Contractor/Address/Actions.d.ts +1 -0
  83. package/dist/components/Contractor/Address/Actions.js +13 -0
  84. package/dist/components/Contractor/Address/Actions.js.map +1 -0
  85. package/dist/components/Contractor/Address/Address.d.ts +16 -0
  86. package/dist/components/Contractor/Address/Address.js +74 -0
  87. package/dist/components/Contractor/Address/Address.js.map +1 -0
  88. package/dist/components/Contractor/Address/Form.d.ts +1 -0
  89. package/dist/components/Contractor/Address/Form.js +57 -0
  90. package/dist/components/Contractor/Address/Form.js.map +1 -0
  91. package/dist/components/Contractor/Address/Head.d.ts +1 -0
  92. package/dist/components/Contractor/Address/Head.js +15 -0
  93. package/dist/components/Contractor/Address/Head.js.map +1 -0
  94. package/dist/components/Contractor/Address/index.d.ts +2 -0
  95. package/dist/components/Contractor/Address/useAddress.d.ts +33 -0
  96. package/dist/components/Contractor/Address/useAddress.js +28 -0
  97. package/dist/components/Contractor/Address/useAddress.js.map +1 -0
  98. package/dist/components/Contractor/List/index.d.ts +25 -0
  99. package/dist/components/Contractor/List/index.js +84 -0
  100. package/dist/components/Contractor/List/index.js.map +1 -0
  101. package/dist/components/Contractor/List/useContractorList.d.ts +20 -0
  102. package/dist/components/Contractor/List/useContractorList.js +31 -0
  103. package/dist/components/Contractor/List/useContractorList.js.map +1 -0
  104. package/dist/components/Contractor/PaymentMethod/BankAccountForm.d.ts +2 -0
  105. package/dist/components/Contractor/PaymentMethod/BankAccountForm.js +53 -0
  106. package/dist/components/Contractor/PaymentMethod/BankAccountForm.js.map +1 -0
  107. package/dist/components/Contractor/PaymentMethod/PaymentMethod.d.ts +31 -0
  108. package/dist/components/Contractor/PaymentMethod/PaymentMethod.js +108 -0
  109. package/dist/components/Contractor/PaymentMethod/PaymentMethod.js.map +1 -0
  110. package/dist/components/Contractor/PaymentMethod/PaymentTypeForm.d.ts +11 -0
  111. package/dist/components/Contractor/PaymentMethod/PaymentTypeForm.js +35 -0
  112. package/dist/components/Contractor/PaymentMethod/PaymentTypeForm.js.map +1 -0
  113. package/dist/components/Contractor/PaymentMethod/types.d.ts +8 -0
  114. package/dist/components/Contractor/index.d.ts +4 -0
  115. package/dist/components/Contractor/index.js +9 -0
  116. package/dist/components/Contractor/index.js.map +1 -0
  117. package/dist/components/Employee/Compensation/Actions.js +1 -1
  118. package/dist/components/Employee/Compensation/Compensation.js +1 -1
  119. package/dist/components/Employee/Compensation/Compensation.js.map +1 -1
  120. package/dist/components/Employee/Compensation/Edit.js +59 -56
  121. package/dist/components/Employee/Compensation/Edit.js.map +1 -1
  122. package/dist/components/Employee/Compensation/List.js +6 -5
  123. package/dist/components/Employee/Compensation/List.js.map +1 -1
  124. package/dist/components/Employee/Compensation/useCompensation.d.ts +2 -0
  125. package/dist/components/Employee/Compensation/useCompensation.js +16 -14
  126. package/dist/components/Employee/Compensation/useCompensation.js.map +1 -1
  127. package/dist/components/Employee/Deductions/Actions.js +9 -8
  128. package/dist/components/Employee/Deductions/Actions.js.map +1 -1
  129. package/dist/components/Employee/Deductions/DeductionForm.js +14 -5
  130. package/dist/components/Employee/Deductions/DeductionForm.js.map +1 -1
  131. package/dist/components/Employee/Deductions/Deductions.js +25 -25
  132. package/dist/components/Employee/Deductions/Deductions.js.map +1 -1
  133. package/dist/components/Employee/Deductions/DeductionsList.js +3 -2
  134. package/dist/components/Employee/Deductions/DeductionsList.js.map +1 -1
  135. package/dist/components/Employee/Deductions/IncludeDeductionsForm.js +3 -2
  136. package/dist/components/Employee/Deductions/IncludeDeductionsForm.js.map +1 -1
  137. package/dist/components/Employee/Deductions/useDeductions.js +8 -6
  138. package/dist/components/Employee/Deductions/useDeductions.js.map +1 -1
  139. package/dist/components/Employee/DocumentSigner/DocumentList/Actions.js +5 -4
  140. package/dist/components/Employee/DocumentSigner/DocumentList/Actions.js.map +1 -1
  141. package/dist/components/Employee/DocumentSigner/DocumentList/useDocumentList.js +5 -3
  142. package/dist/components/Employee/DocumentSigner/DocumentList/useDocumentList.js.map +1 -1
  143. package/dist/components/Employee/DocumentSigner/SignatureForm/useSignatureForm.js +5 -3
  144. package/dist/components/Employee/DocumentSigner/SignatureForm/useSignatureForm.js.map +1 -1
  145. package/dist/components/Employee/EmployeeList/Actions.js +5 -4
  146. package/dist/components/Employee/EmployeeList/Actions.js.map +1 -1
  147. package/dist/components/Employee/EmployeeList/EmployeeList.js +1 -1
  148. package/dist/components/Employee/EmployeeList/EmployeeList.js.map +1 -1
  149. package/dist/components/Employee/EmployeeList/List.js +56 -51
  150. package/dist/components/Employee/EmployeeList/List.js.map +1 -1
  151. package/dist/components/Employee/EmployeeList/useEmployeeList.d.ts +2 -1
  152. package/dist/components/Employee/EmployeeList/useEmployeeList.js +5 -3
  153. package/dist/components/Employee/EmployeeList/useEmployeeList.js.map +1 -1
  154. package/dist/components/Employee/OnboardingSummary/OnboardingSummary.js +48 -43
  155. package/dist/components/Employee/OnboardingSummary/OnboardingSummary.js.map +1 -1
  156. package/dist/components/Employee/PaymentMethod/Actions.js +6 -5
  157. package/dist/components/Employee/PaymentMethod/Actions.js.map +1 -1
  158. package/dist/components/Employee/PaymentMethod/BankAccountEdit.js +1 -1
  159. package/dist/components/Employee/PaymentMethod/BankAccountEdit.js.map +1 -1
  160. package/dist/components/Employee/PaymentMethod/BankAccountsList.js +3 -2
  161. package/dist/components/Employee/PaymentMethod/BankAccountsList.js.map +1 -1
  162. package/dist/components/Employee/PaymentMethod/PaymentMethod.js +3 -4
  163. package/dist/components/Employee/PaymentMethod/PaymentMethod.js.map +1 -1
  164. package/dist/components/Employee/PaymentMethod/PaymentTypeForm.js +1 -1
  165. package/dist/components/Employee/PaymentMethod/PaymentTypeForm.js.map +1 -1
  166. package/dist/components/Employee/PaymentMethod/Split.js +88 -76
  167. package/dist/components/Employee/PaymentMethod/Split.js.map +1 -1
  168. package/dist/components/Employee/PaymentMethod/usePaymentMethod.d.ts +2 -2
  169. package/dist/components/Employee/PaymentMethod/usePaymentMethod.js +35 -29
  170. package/dist/components/Employee/PaymentMethod/usePaymentMethod.js.map +1 -1
  171. package/dist/components/Employee/Profile/Actions.js +7 -6
  172. package/dist/components/Employee/Profile/Actions.js.map +1 -1
  173. package/dist/components/Employee/Profile/AdminPersonalDetails.d.ts +49 -20
  174. package/dist/components/Employee/Profile/AdminPersonalDetails.js +27 -25
  175. package/dist/components/Employee/Profile/AdminPersonalDetails.js.map +1 -1
  176. package/dist/components/Employee/Profile/PersonalDetailsInputs.js +10 -9
  177. package/dist/components/Employee/Profile/PersonalDetailsInputs.js.map +1 -1
  178. package/dist/components/Employee/Profile/Profile.js +124 -116
  179. package/dist/components/Employee/Profile/Profile.js.map +1 -1
  180. package/dist/components/Employee/Profile/useProfile.js +5 -3
  181. package/dist/components/Employee/Profile/useProfile.js.map +1 -1
  182. package/dist/components/Employee/Taxes/Actions.js +8 -7
  183. package/dist/components/Employee/Taxes/Actions.js.map +1 -1
  184. package/dist/components/Employee/Taxes/FederalForm.js +5 -4
  185. package/dist/components/Employee/Taxes/FederalForm.js.map +1 -1
  186. package/dist/components/Employee/Taxes/StateForm.d.ts +1 -1
  187. package/dist/components/Employee/Taxes/StateForm.js +27 -25
  188. package/dist/components/Employee/Taxes/StateForm.js.map +1 -1
  189. package/dist/components/Employee/Taxes/Taxes.d.ts +1 -1
  190. package/dist/components/Employee/Taxes/Taxes.js +90 -83
  191. package/dist/components/Employee/Taxes/Taxes.js.map +1 -1
  192. package/dist/components/Employee/Taxes/useTaxes.d.ts +2 -2
  193. package/dist/components/Employee/Taxes/useTaxes.js +5 -3
  194. package/dist/components/Employee/Taxes/useTaxes.js.map +1 -1
  195. package/dist/components/index.d.ts +1 -0
  196. package/dist/contexts/GustoProvider/GustoProviderCustomUIAdapter.js +8 -7
  197. package/dist/contexts/GustoProvider/GustoProviderCustomUIAdapter.js.map +1 -1
  198. package/dist/i18n/I18n.js +5 -5
  199. package/dist/i18n/I18n.js.map +1 -1
  200. package/dist/i18n/en/Contractor.Address.json.js +35 -0
  201. package/dist/i18n/en/Contractor.Address.json.js.map +1 -0
  202. package/dist/i18n/en/Contractor.ContractorList.json.js +25 -0
  203. package/dist/i18n/en/Contractor.ContractorList.json.js.map +1 -0
  204. package/dist/i18n/en/Contractor.PaymentMethod.json.js +35 -0
  205. package/dist/i18n/en/Contractor.PaymentMethod.json.js.map +1 -0
  206. package/dist/i18n/en/Employee.Compensation.json.js +22 -20
  207. package/dist/i18n/en/Employee.Compensation.json.js.map +1 -1
  208. package/dist/i18n/en/Employee.PaymentMethod.json.js +18 -17
  209. package/dist/i18n/en/Employee.PaymentMethod.json.js.map +1 -1
  210. package/dist/i18n/en/common.json.d.ts +21 -9
  211. package/dist/i18n/en/common.json.js +35 -23
  212. package/dist/i18n/en/common.json.js.map +1 -1
  213. package/dist/index.js +11 -9
  214. package/dist/index.js.map +1 -1
  215. package/dist/shared/constants.d.ts +20 -0
  216. package/dist/shared/constants.js +62 -45
  217. package/dist/shared/constants.js.map +1 -1
  218. package/dist/style.css +1 -1
  219. package/dist/types/i18next.d.ts +71 -1
  220. package/package.json +7 -3
  221. package/dist/components/Employee/PaymentMethod/Constants.d.ts +0 -8
  222. package/dist/components/Employee/PaymentMethod/Constants.js +0 -6
  223. package/dist/components/Employee/PaymentMethod/Constants.js.map +0 -1
@@ -1,69 +1,98 @@
1
1
  import { z } from 'zod';
2
- export declare const AdminPersonalDetailsSchema: z.ZodDiscriminatedUnion<"selfOnboarding", [z.ZodObject<{
2
+ export declare const AdminSelfOnboardingPersonalDetailsSchema: z.ZodObject<{
3
+ workAddress: z.ZodString;
4
+ startDate: z.ZodEffects<z.ZodDate, string | undefined, Date>;
5
+ email: z.ZodString;
6
+ } & {
3
7
  firstName: z.ZodString;
4
8
  middleInitial: z.ZodOptional<z.ZodString>;
5
9
  lastName: z.ZodString;
6
10
  } & {
11
+ selfOnboarding: z.ZodBoolean;
12
+ }, "strip", z.ZodTypeAny, {
13
+ email: string;
14
+ firstName: string;
15
+ lastName: string;
16
+ workAddress: string;
17
+ selfOnboarding: boolean;
18
+ middleInitial?: string | undefined;
19
+ startDate?: string | undefined;
20
+ }, {
21
+ email: string;
22
+ firstName: string;
23
+ lastName: string;
24
+ workAddress: string;
25
+ startDate: Date;
26
+ selfOnboarding: boolean;
27
+ middleInitial?: string | undefined;
28
+ }>;
29
+ export declare const AdminPersonalDetailsSchema: z.ZodDiscriminatedUnion<"enableSsn", [z.ZodObject<{
7
30
  workAddress: z.ZodString;
8
31
  startDate: z.ZodEffects<z.ZodDate, string | undefined, Date>;
9
32
  email: z.ZodString;
33
+ firstName: z.ZodString;
34
+ middleInitial: z.ZodOptional<z.ZodString>;
35
+ lastName: z.ZodString;
36
+ selfOnboarding: z.ZodBoolean;
37
+ ssn: z.ZodEffects<z.ZodEffects<z.ZodString, string, string>, string, string>;
38
+ dateOfBirth: z.ZodEffects<z.ZodDate, string | undefined, Date>;
10
39
  } & {
11
- selfOnboarding: z.ZodLiteral<true>;
12
- enableSsn: z.ZodOptional<z.ZodBoolean>;
40
+ enableSsn: z.ZodLiteral<true>;
13
41
  }, "strip", z.ZodTypeAny, {
14
42
  email: string;
43
+ ssn: string;
15
44
  firstName: string;
16
45
  lastName: string;
17
46
  workAddress: string;
18
- selfOnboarding: true;
47
+ enableSsn: true;
48
+ selfOnboarding: boolean;
19
49
  middleInitial?: string | undefined;
20
50
  startDate?: string | undefined;
21
- enableSsn?: boolean | undefined;
51
+ dateOfBirth?: string | undefined;
22
52
  }, {
23
53
  email: string;
54
+ ssn: string;
24
55
  firstName: string;
25
56
  lastName: string;
26
57
  workAddress: string;
27
58
  startDate: Date;
28
- selfOnboarding: true;
59
+ enableSsn: true;
60
+ dateOfBirth: Date;
61
+ selfOnboarding: boolean;
29
62
  middleInitial?: string | undefined;
30
- enableSsn?: boolean | undefined;
31
63
  }>, z.ZodObject<{
32
- firstName: z.ZodString;
33
- middleInitial: z.ZodOptional<z.ZodString>;
34
- lastName: z.ZodString;
35
- } & {
36
64
  workAddress: z.ZodString;
37
65
  startDate: z.ZodEffects<z.ZodDate, string | undefined, Date>;
38
66
  email: z.ZodString;
39
67
  } & {
40
- ssn: z.ZodEffects<z.ZodEffects<z.ZodString, string, string>, string, string>;
41
- enableSsn: z.ZodBoolean;
68
+ firstName: z.ZodString;
69
+ middleInitial: z.ZodOptional<z.ZodString>;
70
+ lastName: z.ZodString;
71
+ } & {
72
+ selfOnboarding: z.ZodBoolean;
42
73
  } & {
43
74
  dateOfBirth: z.ZodEffects<z.ZodDate, string | undefined, Date>;
44
75
  } & {
45
- selfOnboarding: z.ZodLiteral<false>;
76
+ enableSsn: z.ZodLiteral<false>;
46
77
  }, "strip", z.ZodTypeAny, {
47
78
  email: string;
48
- ssn: string;
49
79
  firstName: string;
50
80
  lastName: string;
51
81
  workAddress: string;
52
- enableSsn: boolean;
53
- selfOnboarding: false;
82
+ enableSsn: false;
83
+ selfOnboarding: boolean;
54
84
  middleInitial?: string | undefined;
55
85
  startDate?: string | undefined;
56
86
  dateOfBirth?: string | undefined;
57
87
  }, {
58
88
  email: string;
59
- ssn: string;
60
89
  firstName: string;
61
90
  lastName: string;
62
91
  workAddress: string;
63
92
  startDate: Date;
64
- enableSsn: boolean;
93
+ enableSsn: false;
65
94
  dateOfBirth: Date;
66
- selfOnboarding: false;
95
+ selfOnboarding: boolean;
67
96
  middleInitial?: string | undefined;
68
97
  }>]>;
69
98
  export declare const AdminPersonalDetails: () => import("react/jsx-runtime").JSX.Element | null;
@@ -1,45 +1,47 @@
1
1
  import { jsxs as a, Fragment as s, jsx as n } from "react/jsx-runtime";
2
- import { useEffect as p } from "react";
3
- import { useFormContext as g } from "react-hook-form";
2
+ import { useEffect as g } from "react";
3
+ import { useFormContext as h } from "react-hook-form";
4
4
  import { useTranslation as O } from "react-i18next";
5
- import { z as o } from "zod";
6
- import { NameInputsSchema as h, SocialSecurityNumberSchema as D, DateOfBirthSchema as I, NameInputs as A, AdminInputs as N, SocialSecurityNumberInput as E, DateOfBirthInput as y, AdminInputsSchema as x } from "./PersonalDetailsInputs.js";
5
+ import { z as t } from "zod";
6
+ import { AdminInputsSchema as D, SocialSecurityNumberSchema as I, DateOfBirthSchema as l, NameInputsSchema as A, NameInputs as N, AdminInputs as E, SocialSecurityNumberInput as x, DateOfBirthInput as y } from "./PersonalDetailsInputs.js";
7
7
  import { useProfile as P } from "./useProfile.js";
8
- import { EmployeeOnboardingStatus as l } from "../../../shared/constants.js";
9
- import { CheckboxField as B } from "../../Common/Fields/CheckboxField/CheckboxField.js";
10
- const m = h.merge(x), M = o.discriminatedUnion("selfOnboarding", [
11
- // Case 1: Self onboarding is true - only base fields required
12
- m.extend({
13
- selfOnboarding: o.literal(!0),
14
- enableSsn: o.boolean().optional()
8
+ import { EmployeeOnboardingStatus as m } from "../../../shared/constants.js";
9
+ import { CheckboxField as F } from "../../Common/Fields/CheckboxField/CheckboxField.js";
10
+ const d = D.merge(
11
+ A
12
+ ).extend({
13
+ selfOnboarding: t.boolean()
14
+ }), M = t.discriminatedUnion("enableSsn", [
15
+ d.merge(I).merge(l).extend({
16
+ enableSsn: t.literal(!0)
15
17
  }),
16
- // Case 2: Self onboarding is false - additional fields required
17
- m.merge(D).merge(I).extend({
18
- selfOnboarding: o.literal(!1)
18
+ d.merge(l).extend({
19
+ enableSsn: t.literal(!1)
19
20
  })
20
21
  ]), V = () => {
21
- const { companyLocations: d, employee: e, isAdmin: c, isSelfOnboardingEnabled: f } = P(), { t: b } = O("Employee.Profile"), { watch: u, setValue: t, getFieldState: S } = g(), r = u("selfOnboarding"), { isDirty: i } = S("ssn");
22
- return p(() => {
23
- r ? t("enableSsn", !1) : t("enableSsn", i ? !0 : !e?.hasSsn);
24
- }, [r, e?.hasSsn, i, t]), c ? /* @__PURE__ */ a(s, { children: [
25
- /* @__PURE__ */ n(A, {}),
26
- /* @__PURE__ */ n(N, { companyLocations: d }),
27
- f && /* @__PURE__ */ n(
28
- B,
22
+ const { companyLocations: c, employee: e, isAdmin: f, isSelfOnboardingEnabled: S } = P(), { t: b } = O("Employee.Profile"), { watch: u, setValue: o, getFieldState: p } = h(), r = u("selfOnboarding"), { isDirty: i } = p("ssn");
23
+ return g(() => {
24
+ r ? o("enableSsn", !1) : o("enableSsn", i ? !0 : !e?.hasSsn);
25
+ }, [r, e?.hasSsn, i, o]), f ? /* @__PURE__ */ a(s, { children: [
26
+ /* @__PURE__ */ n(N, {}),
27
+ /* @__PURE__ */ n(E, { companyLocations: c }),
28
+ S && /* @__PURE__ */ n(
29
+ F,
29
30
  {
30
31
  name: "selfOnboarding",
31
32
  label: b("selfOnboardingLabel"),
32
- isDisabled: e?.onboarded || e?.onboardingStatus === l.ONBOARDING_COMPLETED || e?.onboardingStatus === l.SELF_ONBOARDING_AWAITING_ADMIN_REVIEW
33
+ isDisabled: e?.onboarded || e?.onboardingStatus === m.ONBOARDING_COMPLETED || e?.onboardingStatus === m.SELF_ONBOARDING_AWAITING_ADMIN_REVIEW
33
34
  }
34
35
  ),
35
36
  !r && /* @__PURE__ */ a(s, { children: [
36
- /* @__PURE__ */ n(E, { employee: e }),
37
+ /* @__PURE__ */ n(x, { employee: e }),
37
38
  /* @__PURE__ */ n(y, {})
38
39
  ] })
39
40
  ] }) : null;
40
41
  };
41
42
  export {
42
43
  V as AdminPersonalDetails,
43
- M as AdminPersonalDetailsSchema
44
+ M as AdminPersonalDetailsSchema,
45
+ d as AdminSelfOnboardingPersonalDetailsSchema
44
46
  };
45
47
  //# sourceMappingURL=AdminPersonalDetails.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"AdminPersonalDetails.js","sources":["../../../../src/components/Employee/Profile/AdminPersonalDetails.tsx"],"sourcesContent":["import { useEffect } from 'react'\nimport { useFormContext } from 'react-hook-form'\nimport { useTranslation } from 'react-i18next'\nimport { z } from 'zod'\nimport {\n AdminInputs,\n AdminInputsSchema,\n NameInputs,\n NameInputsSchema,\n SocialSecurityNumberInput,\n SocialSecurityNumberSchema,\n DateOfBirthInput,\n DateOfBirthSchema,\n type PersonalDetailsInputs,\n} from './PersonalDetailsInputs'\nimport { useProfile } from './useProfile'\nimport { EmployeeOnboardingStatus } from '@/shared/constants'\nimport { CheckboxField } from '@/components/Common'\n\n// Base schema with common fields\nconst PersonalDetailsBaseSchema = NameInputsSchema.merge(AdminInputsSchema)\n\n// Use Zod's discriminated union with proper composition\nexport const AdminPersonalDetailsSchema = z.discriminatedUnion('selfOnboarding', [\n // Case 1: Self onboarding is true - only base fields required\n PersonalDetailsBaseSchema.extend({\n selfOnboarding: z.literal(true),\n enableSsn: z.boolean().optional(),\n }),\n // Case 2: Self onboarding is false - additional fields required\n PersonalDetailsBaseSchema.merge(SocialSecurityNumberSchema)\n .merge(DateOfBirthSchema)\n .extend({\n selfOnboarding: z.literal(false),\n }),\n])\n\nexport const AdminPersonalDetails = () => {\n const { companyLocations, employee, isAdmin, isSelfOnboardingEnabled } = useProfile()\n const { t } = useTranslation('Employee.Profile')\n const { watch, setValue, getFieldState } = useFormContext<PersonalDetailsInputs>()\n\n const isSelfOnboardingChecked = watch('selfOnboarding')\n const { isDirty: isSsnDirty } = getFieldState('ssn')\n\n useEffect(() => {\n if (isSelfOnboardingChecked) {\n setValue('enableSsn', false)\n } else {\n setValue('enableSsn', isSsnDirty ? true : !employee?.hasSsn)\n }\n }, [isSelfOnboardingChecked, employee?.hasSsn, isSsnDirty, setValue])\n\n if (!isAdmin) {\n return null\n }\n\n return (\n <>\n <NameInputs />\n <AdminInputs companyLocations={companyLocations} />\n {isSelfOnboardingEnabled && (\n <CheckboxField\n name=\"selfOnboarding\"\n label={t('selfOnboardingLabel')}\n isDisabled={\n employee?.onboarded ||\n employee?.onboardingStatus === EmployeeOnboardingStatus.ONBOARDING_COMPLETED ||\n employee?.onboardingStatus ===\n EmployeeOnboardingStatus.SELF_ONBOARDING_AWAITING_ADMIN_REVIEW\n }\n />\n )}\n\n {!isSelfOnboardingChecked && (\n <>\n <SocialSecurityNumberInput employee={employee} />\n <DateOfBirthInput />\n </>\n )}\n </>\n )\n}\n"],"names":["PersonalDetailsBaseSchema","NameInputsSchema","AdminInputsSchema","AdminPersonalDetailsSchema","z","SocialSecurityNumberSchema","DateOfBirthSchema","AdminPersonalDetails","companyLocations","employee","isAdmin","isSelfOnboardingEnabled","useProfile","t","useTranslation","watch","setValue","getFieldState","useFormContext","isSelfOnboardingChecked","isSsnDirty","useEffect","jsxs","Fragment","jsx","NameInputs","AdminInputs","CheckboxField","EmployeeOnboardingStatus","SocialSecurityNumberInput","DateOfBirthInput"],"mappings":";;;;;;;;;AAoBA,MAAMA,IAA4BC,EAAiB,MAAMC,CAAiB,GAG7DC,IAA6BC,EAAE,mBAAmB,kBAAkB;AAAA;AAAA,EAE/EJ,EAA0B,OAAO;AAAA,IAC/B,gBAAgBI,EAAE,QAAQ,EAAI;AAAA,IAC9B,WAAWA,EAAE,QAAQ,EAAE,SAAS;AAAA,EAAA,CACjC;AAAA;AAAA,EAEDJ,EAA0B,MAAMK,CAA0B,EACvD,MAAMC,CAAiB,EACvB,OAAO;AAAA,IACN,gBAAgBF,EAAE,QAAQ,EAAK;AAAA,EAChC,CAAA;AACL,CAAC,GAEYG,IAAuB,MAAM;AACxC,QAAM,EAAE,kBAAAC,GAAkB,UAAAC,GAAU,SAAAC,GAAS,yBAAAC,EAAA,IAA4BC,EAAW,GAC9E,EAAE,GAAAC,EAAA,IAAMC,EAAe,kBAAkB,GACzC,EAAE,OAAAC,GAAO,UAAAC,GAAU,eAAAC,EAAA,IAAkBC,EAAsC,GAE3EC,IAA0BJ,EAAM,gBAAgB,GAChD,EAAE,SAASK,MAAeH,EAAc,KAAK;AAUnD,SARAI,EAAU,MAAM;AACd,IAAIF,IACFH,EAAS,aAAa,EAAK,IAE3BA,EAAS,aAAaI,IAAa,KAAO,CAACX,GAAU,MAAM;AAAA,EAC7D,GACC,CAACU,GAAyBV,GAAU,QAAQW,GAAYJ,CAAQ,CAAC,GAE/DN,IAMD,gBAAAY,EAAAC,GAAA,EAAA,UAAA;AAAA,IAAA,gBAAAC,EAACC,GAAW,EAAA;AAAA,IACZ,gBAAAD,EAACE,KAAY,kBAAAlB,GAAoC;AAAA,IAChDG,KACC,gBAAAa;AAAA,MAACG;AAAA,MAAA;AAAA,QACC,MAAK;AAAA,QACL,OAAOd,EAAE,qBAAqB;AAAA,QAC9B,YACEJ,GAAU,aACVA,GAAU,qBAAqBmB,EAAyB,wBACxDnB,GAAU,qBACRmB,EAAyB;AAAA,MAAA;AAAA,IAE/B;AAAA,IAGD,CAACT,KAEE,gBAAAG,EAAAC,GAAA,EAAA,UAAA;AAAA,MAAA,gBAAAC,EAACK,KAA0B,UAAApB,GAAoB;AAAA,wBAC9CqB,GAAiB,CAAA,CAAA;AAAA,IAAA,EACpB,CAAA;AAAA,EAAA,GAEJ,IA1BO;AA4BX;"}
1
+ {"version":3,"file":"AdminPersonalDetails.js","sources":["../../../../src/components/Employee/Profile/AdminPersonalDetails.tsx"],"sourcesContent":["import { useEffect } from 'react'\nimport { useFormContext } from 'react-hook-form'\nimport { useTranslation } from 'react-i18next'\nimport { z } from 'zod'\nimport {\n AdminInputs,\n AdminInputsSchema,\n NameInputs,\n NameInputsSchema,\n SocialSecurityNumberInput,\n SocialSecurityNumberSchema,\n DateOfBirthInput,\n DateOfBirthSchema,\n type PersonalDetailsInputs,\n} from './PersonalDetailsInputs'\nimport { useProfile } from './useProfile'\nimport { EmployeeOnboardingStatus } from '@/shared/constants'\nimport { CheckboxField } from '@/components/Common'\n\nexport const AdminSelfOnboardingPersonalDetailsSchema = AdminInputsSchema.merge(\n NameInputsSchema,\n).extend({\n selfOnboarding: z.boolean(),\n})\n\nexport const AdminPersonalDetailsSchema = z.discriminatedUnion('enableSsn', [\n AdminSelfOnboardingPersonalDetailsSchema.merge(SocialSecurityNumberSchema)\n .merge(DateOfBirthSchema)\n .extend({\n enableSsn: z.literal(true),\n }),\n AdminSelfOnboardingPersonalDetailsSchema.merge(DateOfBirthSchema).extend({\n enableSsn: z.literal(false),\n }),\n])\n\nexport const AdminPersonalDetails = () => {\n const { companyLocations, employee, isAdmin, isSelfOnboardingEnabled } = useProfile()\n const { t } = useTranslation('Employee.Profile')\n const { watch, setValue, getFieldState } = useFormContext<PersonalDetailsInputs>()\n\n const isSelfOnboardingChecked = watch('selfOnboarding')\n const { isDirty: isSsnDirty } = getFieldState('ssn')\n\n useEffect(() => {\n if (isSelfOnboardingChecked) {\n setValue('enableSsn', false)\n } else {\n setValue('enableSsn', isSsnDirty ? true : !employee?.hasSsn)\n }\n }, [isSelfOnboardingChecked, employee?.hasSsn, isSsnDirty, setValue])\n\n if (!isAdmin) {\n return null\n }\n\n return (\n <>\n <NameInputs />\n <AdminInputs companyLocations={companyLocations} />\n {isSelfOnboardingEnabled && (\n <CheckboxField\n name=\"selfOnboarding\"\n label={t('selfOnboardingLabel')}\n isDisabled={\n employee?.onboarded ||\n employee?.onboardingStatus === EmployeeOnboardingStatus.ONBOARDING_COMPLETED ||\n employee?.onboardingStatus ===\n EmployeeOnboardingStatus.SELF_ONBOARDING_AWAITING_ADMIN_REVIEW\n }\n />\n )}\n\n {!isSelfOnboardingChecked && (\n <>\n <SocialSecurityNumberInput employee={employee} />\n <DateOfBirthInput />\n </>\n )}\n </>\n )\n}\n"],"names":["AdminSelfOnboardingPersonalDetailsSchema","AdminInputsSchema","NameInputsSchema","z","AdminPersonalDetailsSchema","SocialSecurityNumberSchema","DateOfBirthSchema","AdminPersonalDetails","companyLocations","employee","isAdmin","isSelfOnboardingEnabled","useProfile","t","useTranslation","watch","setValue","getFieldState","useFormContext","isSelfOnboardingChecked","isSsnDirty","useEffect","jsxs","Fragment","jsx","NameInputs","AdminInputs","CheckboxField","EmployeeOnboardingStatus","SocialSecurityNumberInput","DateOfBirthInput"],"mappings":";;;;;;;;;AAmBO,MAAMA,IAA2CC,EAAkB;AAAA,EACxEC;AACF,EAAE,OAAO;AAAA,EACP,gBAAgBC,EAAE,QAAQ;AAC5B,CAAC,GAEYC,IAA6BD,EAAE,mBAAmB,aAAa;AAAA,EAC1EH,EAAyC,MAAMK,CAA0B,EACtE,MAAMC,CAAiB,EACvB,OAAO;AAAA,IACN,WAAWH,EAAE,QAAQ,EAAI;AAAA,EAAA,CAC1B;AAAA,EACHH,EAAyC,MAAMM,CAAiB,EAAE,OAAO;AAAA,IACvE,WAAWH,EAAE,QAAQ,EAAK;AAAA,EAC3B,CAAA;AACH,CAAC,GAEYI,IAAuB,MAAM;AACxC,QAAM,EAAE,kBAAAC,GAAkB,UAAAC,GAAU,SAAAC,GAAS,yBAAAC,EAAA,IAA4BC,EAAW,GAC9E,EAAE,GAAAC,EAAA,IAAMC,EAAe,kBAAkB,GACzC,EAAE,OAAAC,GAAO,UAAAC,GAAU,eAAAC,EAAA,IAAkBC,EAAsC,GAE3EC,IAA0BJ,EAAM,gBAAgB,GAChD,EAAE,SAASK,MAAeH,EAAc,KAAK;AAUnD,SARAI,EAAU,MAAM;AACd,IAAIF,IACFH,EAAS,aAAa,EAAK,IAE3BA,EAAS,aAAaI,IAAa,KAAO,CAACX,GAAU,MAAM;AAAA,EAC7D,GACC,CAACU,GAAyBV,GAAU,QAAQW,GAAYJ,CAAQ,CAAC,GAE/DN,IAMD,gBAAAY,EAAAC,GAAA,EAAA,UAAA;AAAA,IAAA,gBAAAC,EAACC,GAAW,EAAA;AAAA,IACZ,gBAAAD,EAACE,KAAY,kBAAAlB,GAAoC;AAAA,IAChDG,KACC,gBAAAa;AAAA,MAACG;AAAA,MAAA;AAAA,QACC,MAAK;AAAA,QACL,OAAOd,EAAE,qBAAqB;AAAA,QAC9B,YACEJ,GAAU,aACVA,GAAU,qBAAqBmB,EAAyB,wBACxDnB,GAAU,qBACRmB,EAAyB;AAAA,MAAA;AAAA,IAE/B;AAAA,IAGD,CAACT,KAEE,gBAAAG,EAAAC,GAAA,EAAA,UAAA;AAAA,MAAA,gBAAAC,EAACK,KAA0B,UAAApB,GAAoB;AAAA,wBAC9CqB,GAAiB,CAAA,CAAA;AAAA,IAAA,EACpB,CAAA;AAAA,EAAA,GAEJ,IA1BO;AA4BX;"}
@@ -2,10 +2,11 @@ import { jsxs as l, Fragment as d, jsx as a } from "react/jsx-runtime";
2
2
  import { z as r } from "zod";
3
3
  import { useFormContext as c } from "react-hook-form";
4
4
  import { useTranslation as i } from "react-i18next";
5
+ import "../../../shared/constants.js";
5
6
  import { Grid as b } from "../../Common/Grid/Grid.js";
6
7
  import { removeNonDigits as S, addressInline as g } from "../../../helpers/formattedStrings.js";
7
8
  import { usePlaceholderSSN as h, normalizeSSN as N } from "../../../helpers/ssn.js";
8
- import { nameValidation as m, SSN_REGEX as D } from "../../../helpers/validations.js";
9
+ import { SSN_REGEX as D, nameValidation as m } from "../../../helpers/validations.js";
9
10
  import { TextInputField as s } from "../../Common/Fields/TextInputField/TextInputField.js";
10
11
  import { SelectField as I } from "../../Common/Fields/SelectField/SelectField.js";
11
12
  import { DatePickerField as p } from "../../Common/Fields/DatePickerField/DatePickerField.js";
@@ -14,7 +15,7 @@ const v = r.object({
14
15
  middleInitial: r.string().optional(),
15
16
  lastName: m
16
17
  });
17
- function B() {
18
+ function C() {
18
19
  const { t: e } = i("Employee.Profile");
19
20
  return /* @__PURE__ */ l(d, { children: [
20
21
  /* @__PURE__ */ l(b, { gap: { base: 20, small: 8 }, gridTemplateColumns: { base: "1fr", small: ["1fr", 200] }, children: [
@@ -45,7 +46,7 @@ const O = r.object({
45
46
  startDate: r.date().transform((e) => e.toISOString().split("T")[0]),
46
47
  email: r.string().email()
47
48
  });
48
- function C({ companyLocations: e }) {
49
+ function L({ companyLocations: e }) {
49
50
  const { t } = i("Employee.Profile"), {
50
51
  formState: { errors: n }
51
52
  } = c();
@@ -91,7 +92,7 @@ const y = r.object({
91
92
  ssn: r.string().transform((e) => S(e)).refine((e) => D.test(e)),
92
93
  enableSsn: r.boolean()
93
94
  });
94
- function L({ employee: e, onChange: t }) {
95
+ function z({ employee: e, onChange: t }) {
95
96
  const { setValue: n } = c(), { t: o } = i("Employee.Profile"), u = h(e?.hasSsn);
96
97
  return /* @__PURE__ */ a(
97
98
  s,
@@ -111,7 +112,7 @@ function L({ employee: e, onChange: t }) {
111
112
  const A = r.object({
112
113
  dateOfBirth: r.date().transform((e) => e.toISOString().split("T")[0])
113
114
  });
114
- function z() {
115
+ function G() {
115
116
  const { t: e } = i("Employee.Profile");
116
117
  return /* @__PURE__ */ a(
117
118
  p,
@@ -127,13 +128,13 @@ v.merge(O).merge(y).merge(A).extend({
127
128
  enableSsn: r.boolean()
128
129
  });
129
130
  export {
130
- C as AdminInputs,
131
+ L as AdminInputs,
131
132
  O as AdminInputsSchema,
132
- z as DateOfBirthInput,
133
+ G as DateOfBirthInput,
133
134
  A as DateOfBirthSchema,
134
- B as NameInputs,
135
+ C as NameInputs,
135
136
  v as NameInputsSchema,
136
- L as SocialSecurityNumberInput,
137
+ z as SocialSecurityNumberInput,
137
138
  y as SocialSecurityNumberSchema
138
139
  };
139
140
  //# sourceMappingURL=PersonalDetailsInputs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PersonalDetailsInputs.js","sources":["../../../../src/components/Employee/Profile/PersonalDetailsInputs.tsx"],"sourcesContent":["import { z } from 'zod'\nimport { useFormContext } from 'react-hook-form'\nimport { useTranslation } from 'react-i18next'\nimport { type Location } from '@gusto/embedded-api/models/components/location'\nimport { type Employee } from '@gusto/embedded-api/models/components/employee'\nimport { SelectField, TextInputField, Grid, DatePickerField } from '@/components/Common'\nimport { addressInline, removeNonDigits } from '@/helpers/formattedStrings'\nimport { normalizeSSN, usePlaceholderSSN } from '@/helpers/ssn'\nimport { nameValidation, SSN_REGEX } from '@/helpers/validations'\n\nexport const NameInputsSchema = z.object({\n firstName: nameValidation,\n middleInitial: z.string().optional(),\n lastName: nameValidation,\n})\n\nexport function NameInputs() {\n const { t } = useTranslation('Employee.Profile')\n\n return (\n <>\n <Grid gap={{ base: 20, small: 8 }} gridTemplateColumns={{ base: '1fr', small: ['1fr', 200] }}>\n <TextInputField\n name=\"firstName\"\n isRequired\n label={t('firstName')}\n errorMessage={t('validations.firstName')}\n />\n <TextInputField name=\"middleInitial\" label={t('middleInitial')} />\n </Grid>\n <TextInputField\n name=\"lastName\"\n isRequired\n label={t('lastName')}\n errorMessage={t('validations.lastName')}\n />\n </>\n )\n}\n\nexport const AdminInputsSchema = z.object({\n workAddress: z.string().min(1),\n startDate: z.date().transform(date => date.toISOString().split('T')[0]),\n email: z.string().email(),\n})\n\ntype AdminInputsSchemaType = z.infer<typeof AdminInputsSchema>\n\ninterface AdminInputsProps {\n companyLocations: Location[]\n}\n\nexport function AdminInputs({ companyLocations }: AdminInputsProps) {\n const { t } = useTranslation('Employee.Profile')\n const {\n formState: { errors },\n } = useFormContext<AdminInputsSchemaType>()\n\n return (\n <>\n <SelectField\n name=\"workAddress\"\n options={companyLocations.map(location => ({\n value: location.uuid,\n label: addressInline(location),\n }))}\n label={t('workAddress')}\n description={t('workAddressDescription')}\n placeholder={t('workAddressPlaceholder')}\n errorMessage={t('validations.location', { ns: 'common' })}\n isRequired\n />\n <DatePickerField\n name=\"startDate\"\n label={t('startDateLabel')}\n description={t('startDateDescription')}\n errorMessage={\n errors.startDate?.type === 'custom'\n ? t('validations.startDateOutOfRange')\n : t('validations.startDate')\n }\n />\n <TextInputField\n name=\"email\"\n label={t('email')}\n description={t('emailDescription')}\n errorMessage={t('validations.email')}\n isRequired\n type=\"email\"\n />\n </>\n )\n}\n\nexport const SocialSecurityNumberSchema = z.object({\n ssn: z\n .string()\n .transform(input => removeNonDigits(input))\n .refine(input => SSN_REGEX.test(input)),\n enableSsn: z.boolean(),\n})\n\ntype SocialSecurityNumberSchemaType = z.infer<typeof SocialSecurityNumberSchema>\n\ninterface SocialSecurityNumberInputProps {\n employee?: Employee\n onChange?: (updatedValue: string) => void\n}\n\nexport function SocialSecurityNumberInput({ employee, onChange }: SocialSecurityNumberInputProps) {\n const { setValue } = useFormContext<SocialSecurityNumberSchemaType>()\n const { t } = useTranslation('Employee.Profile')\n const placeholderSSN = usePlaceholderSSN(employee?.hasSsn)\n return (\n <TextInputField\n isRequired\n name=\"ssn\"\n label={t('ssnLabel')}\n errorMessage={t('validations.ssn', { ns: 'common' })}\n placeholder={placeholderSSN}\n transform={normalizeSSN}\n onChange={updatedValue => {\n setValue('enableSsn', true)\n onChange?.(updatedValue)\n }}\n />\n )\n}\n\nexport const DateOfBirthSchema = z.object({\n dateOfBirth: z.date().transform(date => date.toISOString().split('T')[0]),\n})\n\nexport function DateOfBirthInput() {\n const { t } = useTranslation('Employee.Profile')\n return (\n <DatePickerField\n name=\"dateOfBirth\"\n label={t('dobLabel')}\n errorMessage={t('validations.dob', { ns: 'common' })}\n />\n )\n}\n\n// All possible inputs for PersonalDetails forms\nconst PersonalDetailsTotalSchema = NameInputsSchema.merge(AdminInputsSchema)\n .merge(SocialSecurityNumberSchema)\n .merge(DateOfBirthSchema)\n .extend({\n selfOnboarding: z.boolean(),\n enableSsn: z.boolean(),\n })\n\ntype NullableDatesMapper<Source> = {\n [Property in keyof Source]: Source[Property] extends Date\n ? Source[Property] | null\n : Source[Property]\n}\n\nexport type PersonalDetailsPayload = z.infer<typeof PersonalDetailsTotalSchema>\n\n//Typescript magic to mark date fields as nullable for correct defaultvalues\nexport type PersonalDetailsInputs = NullableDatesMapper<z.input<typeof PersonalDetailsTotalSchema>>\n"],"names":["NameInputsSchema","z","nameValidation","NameInputs","t","useTranslation","jsxs","Fragment","Grid","jsx","TextInputField","AdminInputsSchema","date","AdminInputs","companyLocations","errors","useFormContext","SelectField","location","addressInline","DatePickerField","SocialSecurityNumberSchema","input","removeNonDigits","SSN_REGEX","SocialSecurityNumberInput","employee","onChange","setValue","placeholderSSN","usePlaceholderSSN","normalizeSSN","updatedValue","DateOfBirthSchema","DateOfBirthInput"],"mappings":"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"}
1
+ {"version":3,"file":"PersonalDetailsInputs.js","sources":["../../../../src/components/Employee/Profile/PersonalDetailsInputs.tsx"],"sourcesContent":["import { z } from 'zod'\nimport { useFormContext } from 'react-hook-form'\nimport { useTranslation } from 'react-i18next'\nimport { type Location } from '@gusto/embedded-api/models/components/location'\nimport { type Employee } from '@gusto/embedded-api/models/components/employee'\nimport { SelectField, TextInputField, Grid, DatePickerField } from '@/components/Common'\nimport { addressInline, removeNonDigits } from '@/helpers/formattedStrings'\nimport { normalizeSSN, usePlaceholderSSN } from '@/helpers/ssn'\nimport { nameValidation, SSN_REGEX } from '@/helpers/validations'\n\nexport const NameInputsSchema = z.object({\n firstName: nameValidation,\n middleInitial: z.string().optional(),\n lastName: nameValidation,\n})\n\nexport function NameInputs() {\n const { t } = useTranslation('Employee.Profile')\n\n return (\n <>\n <Grid gap={{ base: 20, small: 8 }} gridTemplateColumns={{ base: '1fr', small: ['1fr', 200] }}>\n <TextInputField\n name=\"firstName\"\n isRequired\n label={t('firstName')}\n errorMessage={t('validations.firstName')}\n />\n <TextInputField name=\"middleInitial\" label={t('middleInitial')} />\n </Grid>\n <TextInputField\n name=\"lastName\"\n isRequired\n label={t('lastName')}\n errorMessage={t('validations.lastName')}\n />\n </>\n )\n}\n\nexport const AdminInputsSchema = z.object({\n workAddress: z.string().min(1),\n startDate: z.date().transform(date => date.toISOString().split('T')[0]),\n email: z.string().email(),\n})\n\ntype AdminInputsSchemaType = z.infer<typeof AdminInputsSchema>\n\ninterface AdminInputsProps {\n companyLocations: Location[]\n}\n\nexport function AdminInputs({ companyLocations }: AdminInputsProps) {\n const { t } = useTranslation('Employee.Profile')\n const {\n formState: { errors },\n } = useFormContext<AdminInputsSchemaType>()\n\n return (\n <>\n <SelectField\n name=\"workAddress\"\n options={companyLocations.map(location => ({\n value: location.uuid,\n label: addressInline(location),\n }))}\n label={t('workAddress')}\n description={t('workAddressDescription')}\n placeholder={t('workAddressPlaceholder')}\n errorMessage={t('validations.location', { ns: 'common' })}\n isRequired\n />\n <DatePickerField\n name=\"startDate\"\n label={t('startDateLabel')}\n description={t('startDateDescription')}\n errorMessage={\n errors.startDate?.type === 'custom'\n ? t('validations.startDateOutOfRange')\n : t('validations.startDate')\n }\n />\n <TextInputField\n name=\"email\"\n label={t('email')}\n description={t('emailDescription')}\n errorMessage={t('validations.email')}\n isRequired\n type=\"email\"\n />\n </>\n )\n}\n\nexport const SocialSecurityNumberSchema = z.object({\n ssn: z\n .string()\n .transform(input => removeNonDigits(input))\n .refine(input => SSN_REGEX.test(input)),\n enableSsn: z.boolean(),\n})\n\ntype SocialSecurityNumberSchemaType = z.infer<typeof SocialSecurityNumberSchema>\n\ninterface SocialSecurityNumberInputProps {\n employee?: Employee\n onChange?: (updatedValue: string) => void\n}\n\nexport function SocialSecurityNumberInput({ employee, onChange }: SocialSecurityNumberInputProps) {\n const { setValue } = useFormContext<SocialSecurityNumberSchemaType>()\n const { t } = useTranslation('Employee.Profile')\n const placeholderSSN = usePlaceholderSSN(employee?.hasSsn)\n return (\n <TextInputField\n isRequired\n name=\"ssn\"\n label={t('ssnLabel')}\n errorMessage={t('validations.ssn', { ns: 'common' })}\n placeholder={placeholderSSN}\n transform={normalizeSSN}\n onChange={updatedValue => {\n setValue('enableSsn', true)\n onChange?.(updatedValue)\n }}\n />\n )\n}\n\nexport const DateOfBirthSchema = z.object({\n dateOfBirth: z.date().transform(date => date.toISOString().split('T')[0]),\n})\n\nexport function DateOfBirthInput() {\n const { t } = useTranslation('Employee.Profile')\n return (\n <DatePickerField\n name=\"dateOfBirth\"\n label={t('dobLabel')}\n errorMessage={t('validations.dob', { ns: 'common' })}\n />\n )\n}\n\n// All possible inputs for PersonalDetails forms\nconst PersonalDetailsTotalSchema = NameInputsSchema.merge(AdminInputsSchema)\n .merge(SocialSecurityNumberSchema)\n .merge(DateOfBirthSchema)\n .extend({\n selfOnboarding: z.boolean(),\n enableSsn: z.boolean(),\n })\n\ntype NullableDatesMapper<Source> = {\n [Property in keyof Source]: Source[Property] extends Date\n ? Source[Property] | null\n : Source[Property]\n}\n\nexport type PersonalDetailsPayload = z.infer<typeof PersonalDetailsTotalSchema>\n\n//Typescript magic to mark date fields as nullable for correct defaultvalues\nexport type PersonalDetailsInputs = NullableDatesMapper<z.input<typeof PersonalDetailsTotalSchema>>\n"],"names":["NameInputsSchema","z","nameValidation","NameInputs","t","useTranslation","jsxs","Fragment","Grid","jsx","TextInputField","AdminInputsSchema","date","AdminInputs","companyLocations","errors","useFormContext","SelectField","location","addressInline","DatePickerField","SocialSecurityNumberSchema","input","removeNonDigits","SSN_REGEX","SocialSecurityNumberInput","employee","onChange","setValue","placeholderSSN","usePlaceholderSSN","normalizeSSN","updatedValue","DateOfBirthSchema","DateOfBirthInput"],"mappings":"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"}