@gusto/embedded-react-sdk 0.20.0 → 0.22.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 (485) hide show
  1. package/CHANGELOG.md +62 -0
  2. package/README.md +32 -17
  3. package/dist/UNSTABLE_Hooks.d.ts +1 -0
  4. package/dist/UNSTABLE_Hooks.js +9 -0
  5. package/dist/UNSTABLE_Hooks.js.map +1 -0
  6. package/dist/assets/icons/coins-hand.svg.js +10 -0
  7. package/dist/assets/icons/coins-hand.svg.js.map +1 -0
  8. package/dist/assets/icons/icon-file-outline.svg.js +10 -0
  9. package/dist/assets/icons/icon-file-outline.svg.js.map +1 -0
  10. package/dist/assets/icons/icon-receipt-outline.svg.js +10 -0
  11. package/dist/assets/icons/icon-receipt-outline.svg.js.map +1 -0
  12. package/dist/components/Base/Base.d.ts +19 -4
  13. package/dist/components/Base/Base.js +67 -61
  14. package/dist/components/Base/Base.js.map +1 -1
  15. package/dist/components/Base/index.d.ts +1 -1
  16. package/dist/components/Base/useBase.d.ts +1 -1
  17. package/dist/components/Base/useBase.js.map +1 -1
  18. package/dist/components/Base/useBaseSubmit.d.ts +10 -0
  19. package/dist/components/Base/useBaseSubmit.js +33 -0
  20. package/dist/components/Base/useBaseSubmit.js.map +1 -0
  21. package/dist/components/Common/Fields/CheckboxField/CheckboxField.js.map +1 -1
  22. package/dist/components/Common/Fields/CheckboxGroupField/CheckboxGroupField.js.map +1 -1
  23. package/dist/components/Common/Fields/ComboBoxField/ComboBoxField.js.map +1 -1
  24. package/dist/components/Common/Fields/DatePickerField/DatePickerField.js.map +1 -1
  25. package/dist/components/Common/Fields/NumberInputField/NumberInputField.js.map +1 -1
  26. package/dist/components/Common/Fields/RadioGroupField/RadioGroupField.js.map +1 -1
  27. package/dist/components/Common/Fields/SelectField/SelectField.js.map +1 -1
  28. package/dist/components/Common/Fields/SwitchField/SwitchField.js.map +1 -1
  29. package/dist/components/Common/Fields/TextAreaField/TextAreaField.d.ts +5 -0
  30. package/dist/components/Common/Fields/TextAreaField/TextAreaField.js +34 -0
  31. package/dist/components/Common/Fields/TextAreaField/TextAreaField.js.map +1 -0
  32. package/dist/components/Common/Fields/TextAreaField/index.d.ts +3 -0
  33. package/dist/components/Common/Fields/TextInputField/TextInputField.js.map +1 -1
  34. package/dist/components/Common/Fieldset/Fieldset.js.map +1 -1
  35. package/dist/components/Common/FlowBreadcrumbs/FlowBreadcrumbs.js +10 -10
  36. package/dist/components/Common/FlowBreadcrumbs/FlowBreadcrumbs.js.map +1 -1
  37. package/dist/components/Common/FlowBreadcrumbs/breadcrumbTransitionHelpers.d.ts +1 -0
  38. package/dist/components/Common/FlowBreadcrumbs/breadcrumbTransitionHelpers.js +14 -0
  39. package/dist/components/Common/FlowBreadcrumbs/breadcrumbTransitionHelpers.js.map +1 -0
  40. package/dist/components/Common/FlowBreadcrumbs/index.d.ts +1 -0
  41. package/dist/components/Common/SignatureForm/SignatureForm.js +4 -2
  42. package/dist/components/Common/SignatureForm/SignatureForm.js.map +1 -1
  43. package/dist/components/Common/SignatureForm/SignatureFormActions.js +8 -6
  44. package/dist/components/Common/SignatureForm/SignatureFormActions.js.map +1 -1
  45. package/dist/components/Common/SignatureForm/SignatureFormFields.js +14 -11
  46. package/dist/components/Common/SignatureForm/SignatureFormFields.js.map +1 -1
  47. package/dist/components/Common/UI/Alert/Alert.js +23 -22
  48. package/dist/components/Common/UI/Alert/Alert.js.map +1 -1
  49. package/dist/components/Common/UI/Alert/AlertTypes.d.ts +4 -0
  50. package/dist/components/Common/UI/Alert/AlertTypes.js.map +1 -1
  51. package/dist/components/Common/UI/Badge/BadgeTypes.js.map +1 -1
  52. package/dist/components/Common/UI/Banner/BannerTypes.js.map +1 -1
  53. package/dist/components/Common/UI/Breadcrumbs/Breadcrumbs.js +1 -1
  54. package/dist/components/Common/UI/Button/ButtonTypes.js.map +1 -1
  55. package/dist/components/Common/UI/Checkbox/CheckboxTypes.js.map +1 -1
  56. package/dist/components/Common/UI/CheckboxGroup/CheckboxGroupTypes.js.map +1 -1
  57. package/dist/components/Common/UI/ComboBox/ComboBox.module.scss.js +1 -1
  58. package/dist/components/Common/UI/DatePicker/DatePicker.d.ts +1 -1
  59. package/dist/components/Common/UI/DatePicker/DatePicker.js +38 -37
  60. package/dist/components/Common/UI/DatePicker/DatePicker.js.map +1 -1
  61. package/dist/components/Common/UI/DatePicker/DatePicker.module.scss.js +7 -7
  62. package/dist/components/Common/UI/DatePicker/DatePickerTypes.d.ts +4 -0
  63. package/dist/components/Common/UI/Input/InputTypes.js.map +1 -1
  64. package/dist/components/Common/UI/LoadingSpinner/LoadingSpinnerTypes.js.map +1 -1
  65. package/dist/components/Common/UI/Modal/Modal.module.scss.js +17 -17
  66. package/dist/components/Common/UI/ProgressBar/ProgressBar.js +4 -4
  67. package/dist/components/Common/UI/Radio/RadioTypes.js.map +1 -1
  68. package/dist/components/Common/UI/RadioGroup/RadioGroupTypes.js.map +1 -1
  69. package/dist/components/Common/UI/Select/Select.d.ts +1 -1
  70. package/dist/components/Common/UI/Select/Select.js +27 -26
  71. package/dist/components/Common/UI/Select/Select.js.map +1 -1
  72. package/dist/components/Common/UI/Select/Select.module.scss.js +6 -6
  73. package/dist/components/Common/UI/Select/SelectTypes.d.ts +4 -0
  74. package/dist/components/Common/UI/Switch/SwitchTypes.js.map +1 -1
  75. package/dist/components/Common/UI/Table/Table.module.scss.js +1 -1
  76. package/dist/components/Common/UI/Table/TableTypes.js.map +1 -1
  77. package/dist/components/Common/UI/TextArea/TextArea.d.ts +2 -0
  78. package/dist/components/Common/UI/TextArea/TextArea.js +79 -0
  79. package/dist/components/Common/UI/TextArea/TextArea.js.map +1 -0
  80. package/dist/components/Common/UI/TextArea/TextArea.module.scss.js +12 -0
  81. package/dist/components/Common/UI/TextArea/TextArea.module.scss.js.map +1 -0
  82. package/dist/components/Common/UI/TextArea/TextAreaTypes.d.ts +37 -0
  83. package/dist/components/Common/UI/TextArea/TextAreaTypes.js +9 -0
  84. package/dist/components/Common/UI/TextArea/TextAreaTypes.js.map +1 -0
  85. package/dist/components/Common/UI/TextArea/index.d.ts +4 -0
  86. package/dist/components/Common/UI/TextInput/TextInputTypes.js.map +1 -1
  87. package/dist/components/Company/AssignSignatory/AssignSignatory.js +7 -5
  88. package/dist/components/Company/AssignSignatory/AssignSignatory.js.map +1 -1
  89. package/dist/components/Company/AssignSignatory/AssignSignatorySelection.js +5 -2
  90. package/dist/components/Company/AssignSignatory/AssignSignatorySelection.js.map +1 -1
  91. package/dist/components/Company/AssignSignatory/CreateSignatory/Actions.js +4 -2
  92. package/dist/components/Company/AssignSignatory/CreateSignatory/Actions.js.map +1 -1
  93. package/dist/components/Company/AssignSignatory/CreateSignatory/CreateSignatory.js +8 -6
  94. package/dist/components/Company/AssignSignatory/CreateSignatory/CreateSignatory.js.map +1 -1
  95. package/dist/components/Company/AssignSignatory/CreateSignatory/CreateSignatoryForm.js +14 -13
  96. package/dist/components/Company/AssignSignatory/CreateSignatory/CreateSignatoryForm.js.map +1 -1
  97. package/dist/components/Company/AssignSignatory/CreateSignatory/useCreateSignatory.js +3 -4
  98. package/dist/components/Company/AssignSignatory/CreateSignatory/useCreateSignatory.js.map +1 -1
  99. package/dist/components/Company/AssignSignatory/InviteSignatory/Actions.js +4 -2
  100. package/dist/components/Company/AssignSignatory/InviteSignatory/Actions.js.map +1 -1
  101. package/dist/components/Company/AssignSignatory/InviteSignatory/InviteSignatory.js +11 -9
  102. package/dist/components/Company/AssignSignatory/InviteSignatory/InviteSignatory.js.map +1 -1
  103. package/dist/components/Company/AssignSignatory/InviteSignatory/InviteSignatoryForm.js +9 -8
  104. package/dist/components/Company/AssignSignatory/InviteSignatory/InviteSignatoryForm.js.map +1 -1
  105. package/dist/components/Company/AssignSignatory/InviteSignatory/useInviteSignatory.js +3 -4
  106. package/dist/components/Company/AssignSignatory/InviteSignatory/useInviteSignatory.js.map +1 -1
  107. package/dist/components/Company/AssignSignatory/TitleSelect.js +6 -4
  108. package/dist/components/Company/AssignSignatory/TitleSelect.js.map +1 -1
  109. package/dist/components/Company/AssignSignatory/useAssignSignatory.js +5 -6
  110. package/dist/components/Company/AssignSignatory/useAssignSignatory.js.map +1 -1
  111. package/dist/components/Company/BankAccount/BankAccountForm/Actions.js +10 -9
  112. package/dist/components/Company/BankAccount/BankAccountForm/Actions.js.map +1 -1
  113. package/dist/components/Company/BankAccount/BankAccountForm/Form.js +10 -8
  114. package/dist/components/Company/BankAccount/BankAccountForm/Form.js.map +1 -1
  115. package/dist/components/Company/BankAccount/BankAccountForm/context.js +3 -4
  116. package/dist/components/Company/BankAccount/BankAccountForm/context.js.map +1 -1
  117. package/dist/components/Company/BankAccount/BankAccountList/Actions.js +10 -8
  118. package/dist/components/Company/BankAccount/BankAccountList/Actions.js.map +1 -1
  119. package/dist/components/Company/BankAccount/BankAccountVerify/Actions.js +10 -8
  120. package/dist/components/Company/BankAccount/BankAccountVerify/Actions.js.map +1 -1
  121. package/dist/components/Company/BankAccount/BankAccountVerify/Form.js +6 -4
  122. package/dist/components/Company/BankAccount/BankAccountVerify/Form.js.map +1 -1
  123. package/dist/components/Company/DocumentSigner/DocumentList/Actions.js +4 -2
  124. package/dist/components/Company/DocumentSigner/DocumentList/Actions.js.map +1 -1
  125. package/dist/components/Company/DocumentSigner/DocumentList/DocumentList.js +10 -8
  126. package/dist/components/Company/DocumentSigner/DocumentList/DocumentList.js.map +1 -1
  127. package/dist/components/Company/DocumentSigner/DocumentList/useDocumentList.js +3 -4
  128. package/dist/components/Company/DocumentSigner/DocumentList/useDocumentList.js.map +1 -1
  129. package/dist/components/Company/DocumentSigner/SignatureForm/SignatureForm.js +9 -7
  130. package/dist/components/Company/DocumentSigner/SignatureForm/SignatureForm.js.map +1 -1
  131. package/dist/components/Company/DocumentSigner/SignatureForm/useSignatureForm.js +3 -4
  132. package/dist/components/Company/DocumentSigner/SignatureForm/useSignatureForm.js.map +1 -1
  133. package/dist/components/Company/FederalTaxes/Actions.js +9 -7
  134. package/dist/components/Company/FederalTaxes/Actions.js.map +1 -1
  135. package/dist/components/Company/FederalTaxes/FederalTaxes.js +4 -2
  136. package/dist/components/Company/FederalTaxes/FederalTaxes.js.map +1 -1
  137. package/dist/components/Company/FederalTaxes/Form.js +4 -4
  138. package/dist/components/Company/FederalTaxes/useFederalTaxes.js +8 -9
  139. package/dist/components/Company/FederalTaxes/useFederalTaxes.js.map +1 -1
  140. package/dist/components/Company/Industry/Actions.js +9 -7
  141. package/dist/components/Company/Industry/Actions.js.map +1 -1
  142. package/dist/components/Company/Industry/Context.js +6 -7
  143. package/dist/components/Company/Industry/Context.js.map +1 -1
  144. package/dist/components/Company/Industry/Edit.js +7 -4
  145. package/dist/components/Company/Industry/Edit.js.map +1 -1
  146. package/dist/components/Company/Locations/LocationForm/Actions.js +10 -8
  147. package/dist/components/Company/Locations/LocationForm/Actions.js.map +1 -1
  148. package/dist/components/Company/Locations/LocationForm/Form.js +6 -4
  149. package/dist/components/Company/Locations/LocationForm/Form.js.map +1 -1
  150. package/dist/components/Company/Locations/LocationForm/LocationForm.js +10 -8
  151. package/dist/components/Company/Locations/LocationForm/LocationForm.js.map +1 -1
  152. package/dist/components/Company/Locations/LocationForm/useLocationForm.js +3 -4
  153. package/dist/components/Company/Locations/LocationForm/useLocationForm.js.map +1 -1
  154. package/dist/components/Company/Locations/LocationsList/Actions.js +8 -6
  155. package/dist/components/Company/Locations/LocationsList/Actions.js.map +1 -1
  156. package/dist/components/Company/Locations/LocationsList/List.js +16 -15
  157. package/dist/components/Company/Locations/LocationsList/List.js.map +1 -1
  158. package/dist/components/Company/Locations/LocationsList/LocationsList.js +3 -2
  159. package/dist/components/Company/Locations/LocationsList/LocationsList.js.map +1 -1
  160. package/dist/components/Company/Locations/LocationsList/useLocationsList.js +3 -4
  161. package/dist/components/Company/Locations/LocationsList/useLocationsList.js.map +1 -1
  162. package/dist/components/Company/OnboardingOverview/Completed.js +11 -10
  163. package/dist/components/Company/OnboardingOverview/Completed.js.map +1 -1
  164. package/dist/components/Company/OnboardingOverview/MissingRequirements.js +10 -9
  165. package/dist/components/Company/OnboardingOverview/MissingRequirements.js.map +1 -1
  166. package/dist/components/Company/OnboardingOverview/OnboardingOverview.js +8 -6
  167. package/dist/components/Company/OnboardingOverview/OnboardingOverview.js.map +1 -1
  168. package/dist/components/Company/OnboardingOverview/context.js +3 -4
  169. package/dist/components/Company/OnboardingOverview/context.js.map +1 -1
  170. package/dist/components/Company/PaySchedule/PaySchedule.js +3 -2
  171. package/dist/components/Company/PaySchedule/PaySchedule.js.map +1 -1
  172. package/dist/components/Company/PaySchedule/_parts/Actions.js +11 -9
  173. package/dist/components/Company/PaySchedule/_parts/Actions.js.map +1 -1
  174. package/dist/components/Company/PaySchedule/_parts/Head.js +9 -8
  175. package/dist/components/Company/PaySchedule/_parts/Head.js.map +1 -1
  176. package/dist/components/Company/PaySchedule/_parts/List.js +8 -8
  177. package/dist/components/Company/PaySchedule/usePaySchedule.js +5 -6
  178. package/dist/components/Company/PaySchedule/usePaySchedule.js.map +1 -1
  179. package/dist/components/Company/StateTaxes/StateTaxesForm/Actions.js +4 -2
  180. package/dist/components/Company/StateTaxes/StateTaxesForm/Actions.js.map +1 -1
  181. package/dist/components/Company/StateTaxes/StateTaxesForm/context.js +3 -4
  182. package/dist/components/Company/StateTaxes/StateTaxesForm/context.js.map +1 -1
  183. package/dist/components/Company/StateTaxes/StateTaxesList/Actions.js +4 -2
  184. package/dist/components/Company/StateTaxes/StateTaxesList/Actions.js.map +1 -1
  185. package/dist/components/Company/StateTaxes/StateTaxesList/List.js +4 -2
  186. package/dist/components/Company/StateTaxes/StateTaxesList/List.js.map +1 -1
  187. package/dist/components/Company/StateTaxes/StateTaxesList/context.js +3 -4
  188. package/dist/components/Company/StateTaxes/StateTaxesList/context.js.map +1 -1
  189. package/dist/components/Contractor/Address/Address.js +5 -3
  190. package/dist/components/Contractor/Address/Address.js.map +1 -1
  191. package/dist/components/Contractor/Address/Form.js +11 -9
  192. package/dist/components/Contractor/Address/Form.js.map +1 -1
  193. package/dist/components/Contractor/Address/useAddress.js +5 -6
  194. package/dist/components/Contractor/Address/useAddress.js.map +1 -1
  195. package/dist/components/Contractor/ContractorList/index.js +4 -4
  196. package/dist/components/Contractor/PaymentMethod/BankAccountForm.js +13 -10
  197. package/dist/components/Contractor/PaymentMethod/BankAccountForm.js.map +1 -1
  198. package/dist/components/Contractor/PaymentMethod/PaymentTypeForm.js +5 -3
  199. package/dist/components/Contractor/PaymentMethod/PaymentTypeForm.js.map +1 -1
  200. package/dist/components/Contractor/Payments/CreatePayment/CreatePayment.d.ts +7 -0
  201. package/dist/components/Contractor/Payments/CreatePayment/CreatePayment.js +48 -0
  202. package/dist/components/Contractor/Payments/CreatePayment/CreatePayment.js.map +1 -0
  203. package/dist/components/Contractor/Payments/CreatePayment/CreatePaymentPresentation.d.ts +14 -0
  204. package/dist/components/Contractor/Payments/CreatePayment/CreatePaymentPresentation.js +109 -0
  205. package/dist/components/Contractor/Payments/CreatePayment/CreatePaymentPresentation.js.map +1 -0
  206. package/dist/components/Contractor/Payments/Detail/DetailPresentation.d.ts +19 -0
  207. package/dist/components/Contractor/Payments/EditPayment/EditPayment.d.ts +7 -0
  208. package/dist/components/Contractor/Payments/EditPayment/EditPayment.js +34 -0
  209. package/dist/components/Contractor/Payments/EditPayment/EditPayment.js.map +1 -0
  210. package/dist/components/Contractor/Payments/EditPayment/EditPaymentPresentation.d.ts +6 -0
  211. package/dist/components/Contractor/Payments/EditPayment/EditPaymentPresentation.js +84 -0
  212. package/dist/components/Contractor/Payments/EditPayment/EditPaymentPresentation.js.map +1 -0
  213. package/dist/components/Contractor/Payments/Overview/Overview.d.ts +7 -0
  214. package/dist/components/Contractor/Payments/Overview/Overview.js +72 -0
  215. package/dist/components/Contractor/Payments/Overview/Overview.js.map +1 -0
  216. package/dist/components/Contractor/Payments/Overview/OverviewPresentation.d.ts +18 -0
  217. package/dist/components/Contractor/Payments/Overview/OverviewPresentation.js +131 -0
  218. package/dist/components/Contractor/Payments/Overview/OverviewPresentation.js.map +1 -0
  219. package/dist/components/Contractor/Payments/PaymentFlow/PaymentFlow.d.ts +2 -0
  220. package/dist/components/Contractor/Payments/PaymentFlow/PaymentFlow.js +26 -0
  221. package/dist/components/Contractor/Payments/PaymentFlow/PaymentFlow.js.map +1 -0
  222. package/dist/components/Contractor/Payments/PaymentFlow/PaymentFlowComponents.d.ts +15 -0
  223. package/dist/components/Contractor/Payments/PaymentFlow/PaymentFlowComponents.js +30 -0
  224. package/dist/components/Contractor/Payments/PaymentFlow/PaymentFlowComponents.js.map +1 -0
  225. package/dist/components/Contractor/Payments/PaymentFlow/index.d.ts +3 -0
  226. package/dist/components/Contractor/Payments/PaymentFlow/paymentStateMachine.d.ts +8 -0
  227. package/dist/components/Contractor/Payments/PaymentFlow/paymentStateMachine.js +158 -0
  228. package/dist/components/Contractor/Payments/PaymentFlow/paymentStateMachine.js.map +1 -0
  229. package/dist/components/Contractor/Payments/PaymentsList/PaymentsList.d.ts +7 -0
  230. package/dist/components/Contractor/Payments/PaymentsList/PaymentsList.js +29 -0
  231. package/dist/components/Contractor/Payments/PaymentsList/PaymentsList.js.map +1 -0
  232. package/dist/components/Contractor/Payments/PaymentsList/PaymentsListPresentation.d.ts +18 -0
  233. package/dist/components/Contractor/Payments/PaymentsList/PaymentsListPresentation.js +108 -0
  234. package/dist/components/Contractor/Payments/PaymentsList/PaymentsListPresentation.js.map +1 -0
  235. package/dist/components/Contractor/Payments/PaymentsList/PaymentsListPresentation.module.scss.js +10 -0
  236. package/dist/components/Contractor/Payments/PaymentsList/PaymentsListPresentation.module.scss.js.map +1 -0
  237. package/dist/components/Contractor/Payments/types.d.ts +4 -0
  238. package/dist/components/Contractor/Profile/ContractorProfileForm.js +11 -11
  239. package/dist/components/Contractor/Profile/useContractorProfile.d.ts +26 -26
  240. package/dist/components/Contractor/Profile/useContractorProfile.js +2 -3
  241. package/dist/components/Contractor/Profile/useContractorProfile.js.map +1 -1
  242. package/dist/components/Contractor/Submit/Submit.js +20 -19
  243. package/dist/components/Contractor/Submit/Submit.js.map +1 -1
  244. package/dist/components/Contractor/index.d.ts +1 -0
  245. package/dist/components/Contractor/index.js +4 -2
  246. package/dist/components/Contractor/index.js.map +1 -1
  247. package/dist/components/Employee/Compensation/Actions.js +14 -13
  248. package/dist/components/Employee/Compensation/Actions.js.map +1 -1
  249. package/dist/components/Employee/Compensation/List.js +23 -22
  250. package/dist/components/Employee/Compensation/List.js.map +1 -1
  251. package/dist/components/Employee/Deductions/Deductions.d.ts +1 -1
  252. package/dist/components/Employee/Deductions/Deductions.js +10 -10
  253. package/dist/components/Employee/Deductions/Deductions.js.map +1 -1
  254. package/dist/components/Employee/Deductions/DeductionsComponents.d.ts +2 -0
  255. package/dist/components/Employee/Deductions/DeductionsComponents.js +6 -6
  256. package/dist/components/Employee/Deductions/DeductionsComponents.js.map +1 -1
  257. package/dist/components/Employee/Deductions/DeductionsForm/ChildSupportForm.js +220 -0
  258. package/dist/components/Employee/Deductions/DeductionsForm/ChildSupportForm.js.map +1 -0
  259. package/dist/components/Employee/Deductions/DeductionsForm/ChildSupportForm.module.scss.js +8 -0
  260. package/dist/components/Employee/Deductions/DeductionsForm/ChildSupportForm.module.scss.js.map +1 -0
  261. package/dist/components/Employee/Deductions/DeductionsForm/CustomDeductionForm.d.ts +2 -2
  262. package/dist/components/Employee/Deductions/DeductionsForm/CustomDeductionForm.js +163 -0
  263. package/dist/components/Employee/Deductions/DeductionsForm/CustomDeductionForm.js.map +1 -0
  264. package/dist/components/Employee/Deductions/DeductionsForm/DeductionsForm.d.ts +0 -34
  265. package/dist/components/Employee/Deductions/DeductionsForm/DeductionsForm.js +121 -125
  266. package/dist/components/Employee/Deductions/DeductionsForm/DeductionsForm.js.map +1 -1
  267. package/dist/components/Employee/Deductions/DeductionsForm/DeductionsForm.module.scss.js +14 -0
  268. package/dist/components/Employee/Deductions/DeductionsForm/DeductionsForm.module.scss.js.map +1 -0
  269. package/dist/components/Employee/Deductions/DeductionsForm/GarnishmentForm.d.ts +56 -0
  270. package/dist/components/Employee/Deductions/DeductionsForm/GarnishmentForm.js +158 -0
  271. package/dist/components/Employee/Deductions/DeductionsForm/GarnishmentForm.js.map +1 -0
  272. package/dist/components/Employee/Deductions/DeductionsList/DeductionsList.js +55 -55
  273. package/dist/components/Employee/Deductions/DeductionsList/DeductionsList.js.map +1 -1
  274. package/dist/components/Employee/Deductions/IncludeDeductions/IncludeDeductions.d.ts +6 -0
  275. package/dist/components/Employee/Deductions/IncludeDeductions/IncludeDeductions.js +54 -0
  276. package/dist/components/Employee/Deductions/IncludeDeductions/IncludeDeductions.js.map +1 -0
  277. package/dist/components/Employee/Deductions/IncludeDeductions/IncludeDeductions.module.scss.js +14 -0
  278. package/dist/components/Employee/Deductions/IncludeDeductions/IncludeDeductions.module.scss.js.map +1 -0
  279. package/dist/components/Employee/Deductions/stateMachine.js +49 -29
  280. package/dist/components/Employee/Deductions/stateMachine.js.map +1 -1
  281. package/dist/components/Employee/DocumentSigner/DocumentList/Actions.js +8 -6
  282. package/dist/components/Employee/DocumentSigner/DocumentList/Actions.js.map +1 -1
  283. package/dist/components/Employee/DocumentSigner/DocumentList/DocumentList.js +4 -2
  284. package/dist/components/Employee/DocumentSigner/DocumentList/DocumentList.js.map +1 -1
  285. package/dist/components/Employee/DocumentSigner/DocumentList/List.js +4 -2
  286. package/dist/components/Employee/DocumentSigner/DocumentList/List.js.map +1 -1
  287. package/dist/components/Employee/DocumentSigner/DocumentList/useDocumentList.js +3 -4
  288. package/dist/components/Employee/DocumentSigner/DocumentList/useDocumentList.js.map +1 -1
  289. package/dist/components/Employee/DocumentSigner/SignatureForm/SignatureForm.js +4 -2
  290. package/dist/components/Employee/DocumentSigner/SignatureForm/SignatureForm.js.map +1 -1
  291. package/dist/components/Employee/DocumentSigner/SignatureForm/useSignatureForm.js +3 -4
  292. package/dist/components/Employee/DocumentSigner/SignatureForm/useSignatureForm.js.map +1 -1
  293. package/dist/components/Employee/EmployeeList/Actions.js +8 -6
  294. package/dist/components/Employee/EmployeeList/Actions.js.map +1 -1
  295. package/dist/components/Employee/EmployeeList/EmployeeList.js +4 -2
  296. package/dist/components/Employee/EmployeeList/EmployeeList.js.map +1 -1
  297. package/dist/components/Employee/EmployeeList/Head.js +6 -5
  298. package/dist/components/Employee/EmployeeList/Head.js.map +1 -1
  299. package/dist/components/Employee/EmployeeList/List.js +14 -14
  300. package/dist/components/Employee/EmployeeList/useEmployeeList.js +3 -4
  301. package/dist/components/Employee/EmployeeList/useEmployeeList.js.map +1 -1
  302. package/dist/components/Employee/FederalTaxes/Actions.js +9 -7
  303. package/dist/components/Employee/FederalTaxes/Actions.js.map +1 -1
  304. package/dist/components/Employee/FederalTaxes/FederalForm.d.ts +22 -7
  305. package/dist/components/Employee/FederalTaxes/FederalForm.js +85 -29
  306. package/dist/components/Employee/FederalTaxes/FederalForm.js.map +1 -1
  307. package/dist/components/Employee/FederalTaxes/FederalTaxes.js +62 -46
  308. package/dist/components/Employee/FederalTaxes/FederalTaxes.js.map +1 -1
  309. package/dist/components/Employee/FederalTaxes/useFederalTaxes.js +3 -4
  310. package/dist/components/Employee/FederalTaxes/useFederalTaxes.js.map +1 -1
  311. package/dist/components/Employee/Landing/Landing.js +3 -2
  312. package/dist/components/Employee/Landing/Landing.js.map +1 -1
  313. package/dist/components/Employee/PaymentMethod/Actions.js +8 -6
  314. package/dist/components/Employee/PaymentMethod/Actions.js.map +1 -1
  315. package/dist/components/Employee/PaymentMethod/BankAccountEdit.js +5 -3
  316. package/dist/components/Employee/PaymentMethod/BankAccountEdit.js.map +1 -1
  317. package/dist/components/Employee/PaymentMethod/BankAccountsList.js +12 -11
  318. package/dist/components/Employee/PaymentMethod/BankAccountsList.js.map +1 -1
  319. package/dist/components/Employee/PaymentMethod/PaymentTypeForm.js +8 -6
  320. package/dist/components/Employee/PaymentMethod/PaymentTypeForm.js.map +1 -1
  321. package/dist/components/Employee/PaymentMethod/Split.js +5 -5
  322. package/dist/components/Employee/PaymentMethod/usePaymentMethod.js +5 -6
  323. package/dist/components/Employee/PaymentMethod/usePaymentMethod.js.map +1 -1
  324. package/dist/components/Employee/Profile/Actions.js +9 -7
  325. package/dist/components/Employee/Profile/Actions.js.map +1 -1
  326. package/dist/components/Employee/Profile/AdminPersonalDetails.d.ts +6 -6
  327. package/dist/components/Employee/Profile/AdminPersonalDetails.js +10 -8
  328. package/dist/components/Employee/Profile/AdminPersonalDetails.js.map +1 -1
  329. package/dist/components/Employee/Profile/HomeAddress.js +9 -8
  330. package/dist/components/Employee/Profile/HomeAddress.js.map +1 -1
  331. package/dist/components/Employee/Profile/PersonalDetailsInputs.d.ts +2 -2
  332. package/dist/components/Employee/Profile/PersonalDetailsInputs.js +26 -23
  333. package/dist/components/Employee/Profile/PersonalDetailsInputs.js.map +1 -1
  334. package/dist/components/Employee/Profile/useProfile.js +3 -4
  335. package/dist/components/Employee/Profile/useProfile.js.map +1 -1
  336. package/dist/components/Employee/StateTaxes/Actions.js +10 -8
  337. package/dist/components/Employee/StateTaxes/Actions.js.map +1 -1
  338. package/dist/components/Employee/StateTaxes/useStateTaxes.js +3 -4
  339. package/dist/components/Employee/StateTaxes/useStateTaxes.js.map +1 -1
  340. package/dist/components/Employee/Taxes/Actions.js +10 -8
  341. package/dist/components/Employee/Taxes/Actions.js.map +1 -1
  342. package/dist/components/Employee/Taxes/FederalForm.d.ts +22 -7
  343. package/dist/components/Employee/Taxes/FederalForm.js +85 -29
  344. package/dist/components/Employee/Taxes/FederalForm.js.map +1 -1
  345. package/dist/components/Employee/Taxes/Taxes.js +97 -81
  346. package/dist/components/Employee/Taxes/Taxes.js.map +1 -1
  347. package/dist/components/Employee/Taxes/useTaxes.js +3 -4
  348. package/dist/components/Employee/Taxes/useTaxes.js.map +1 -1
  349. package/dist/components/Flow/Flow.js +14 -13
  350. package/dist/components/Flow/Flow.js.map +1 -1
  351. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetails.d.ts +1 -1
  352. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetails.js +63 -34
  353. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetails.js.map +1 -1
  354. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetails.module.scss.js +8 -0
  355. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetails.module.scss.js.map +1 -0
  356. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsBanner/ConfirmWireDetailsBanner.d.ts +2 -0
  357. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsBanner/ConfirmWireDetailsBanner.js +71 -54
  358. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsBanner/ConfirmWireDetailsBanner.js.map +1 -1
  359. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsComponents.d.ts +23 -0
  360. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsComponents.js +27 -15
  361. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsComponents.js.map +1 -1
  362. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsForm/ConfirmWireDetailsForm.d.ts +25 -2
  363. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsForm/ConfirmWireDetailsForm.js +152 -23
  364. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsForm/ConfirmWireDetailsForm.js.map +1 -1
  365. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsForm/ConfirmWireDetailsForm.module.scss.js +10 -0
  366. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsForm/ConfirmWireDetailsForm.module.scss.js.map +1 -0
  367. package/dist/components/Payroll/ConfirmWireDetails/WireInstructions/WireInstructions.d.ts +9 -1
  368. package/dist/components/Payroll/ConfirmWireDetails/WireInstructions/WireInstructions.js +194 -22
  369. package/dist/components/Payroll/ConfirmWireDetails/WireInstructions/WireInstructions.js.map +1 -1
  370. package/dist/components/Payroll/ConfirmWireDetails/WireInstructions/WireInstructions.module.scss.js +18 -0
  371. package/dist/components/Payroll/ConfirmWireDetails/WireInstructions/WireInstructions.module.scss.js.map +1 -0
  372. package/dist/components/Payroll/ConfirmWireDetails/confirmWireDetailsStateMachine.d.ts +10 -2
  373. package/dist/components/Payroll/ConfirmWireDetails/confirmWireDetailsStateMachine.js +44 -30
  374. package/dist/components/Payroll/ConfirmWireDetails/confirmWireDetailsStateMachine.js.map +1 -1
  375. package/dist/components/Payroll/ConfirmWireDetails/index.d.ts +1 -0
  376. package/dist/components/Payroll/ConfirmWireDetails/types.d.ts +5 -0
  377. package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerAlerts.js +3 -2
  378. package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerAlerts.js.map +1 -1
  379. package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerList.js +7 -6
  380. package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerList.js.map +1 -1
  381. package/dist/components/Payroll/PayrollConfiguration/PayrollConfigurationPresentation.js +15 -15
  382. package/dist/components/Payroll/PayrollConfiguration/PayrollConfigurationPresentation.js.map +1 -1
  383. package/dist/components/Payroll/PayrollFlow/PayrollFlowComponents.d.ts +1 -0
  384. package/dist/components/Payroll/PayrollFlow/PayrollFlowComponents.js.map +1 -1
  385. package/dist/components/Payroll/PayrollFlow/payrollStateMachine.js +32 -40
  386. package/dist/components/Payroll/PayrollFlow/payrollStateMachine.js.map +1 -1
  387. package/dist/components/Payroll/PayrollHistory/PayrollHistory.d.ts +0 -12
  388. package/dist/components/Payroll/PayrollHistory/PayrollHistory.js +44 -52
  389. package/dist/components/Payroll/PayrollHistory/PayrollHistory.js.map +1 -1
  390. package/dist/components/Payroll/PayrollHistory/PayrollHistoryPresentation.d.ts +9 -6
  391. package/dist/components/Payroll/PayrollHistory/PayrollHistoryPresentation.js +104 -101
  392. package/dist/components/Payroll/PayrollHistory/PayrollHistoryPresentation.js.map +1 -1
  393. package/dist/components/Payroll/PayrollList/PayrollList.js +58 -59
  394. package/dist/components/Payroll/PayrollList/PayrollList.js.map +1 -1
  395. package/dist/components/Payroll/PayrollList/PayrollListPresentation.d.ts +4 -6
  396. package/dist/components/Payroll/PayrollList/PayrollListPresentation.js +77 -69
  397. package/dist/components/Payroll/PayrollList/PayrollListPresentation.js.map +1 -1
  398. package/dist/components/Payroll/PayrollOverview/PayrollOverview.js +127 -103
  399. package/dist/components/Payroll/PayrollOverview/PayrollOverview.js.map +1 -1
  400. package/dist/components/Payroll/PayrollOverview/PayrollOverviewPresentation.js +254 -185
  401. package/dist/components/Payroll/PayrollOverview/PayrollOverviewPresentation.js.map +1 -1
  402. package/dist/components/Payroll/PayrollOverview/SubmissionBlockers/FastAchThresholdExceeded.js +3 -2
  403. package/dist/components/Payroll/PayrollOverview/SubmissionBlockers/FastAchThresholdExceeded.js.map +1 -1
  404. package/dist/components/Payroll/PayrollReceipts/PayrollReceiptsPresentation.module.scss.js +1 -1
  405. package/dist/components/Payroll/PayrollStatusBadges/PayrollStatusBadges.d.ts +7 -0
  406. package/dist/components/Payroll/PayrollStatusBadges/PayrollStatusBadges.js +19 -0
  407. package/dist/components/Payroll/PayrollStatusBadges/PayrollStatusBadges.js.map +1 -0
  408. package/dist/components/Payroll/PayrollStatusBadges/PayrollStatusBadges.module.scss.js +10 -0
  409. package/dist/components/Payroll/PayrollStatusBadges/PayrollStatusBadges.module.scss.js.map +1 -0
  410. package/dist/components/Payroll/PayrollStatusBadges/index.d.ts +4 -0
  411. package/dist/components/Payroll/PayrollStatusBadges/payrollStatusConfig.d.ts +33 -0
  412. package/dist/components/Payroll/PayrollStatusBadges/payrollStatusConfig.js +161 -0
  413. package/dist/components/Payroll/PayrollStatusBadges/payrollStatusConfig.js.map +1 -0
  414. package/dist/components/Payroll/PayrollStatusBadges/usePayrollStatusBadges.d.ts +3 -0
  415. package/dist/components/Payroll/PayrollStatusBadges/usePayrollStatusBadges.js +17 -0
  416. package/dist/components/Payroll/PayrollStatusBadges/usePayrollStatusBadges.js.map +1 -0
  417. package/dist/components/Payroll/PayrollStatusBadges/usePayrollStatusBadges.test.d.ts +1 -0
  418. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfiguration.d.ts +6 -0
  419. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfiguration.js +70 -0
  420. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfiguration.js.map +1 -0
  421. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfigurationContext.d.ts +7 -0
  422. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfigurationContext.js +6 -0
  423. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfigurationContext.js.map +1 -0
  424. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfigurationProvider.d.ts +9 -0
  425. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfigurationProvider.js +40 -0
  426. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfigurationProvider.js.map +1 -0
  427. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/index.d.ts +5 -0
  428. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/usePayrollConfiguration.d.ts +2 -0
  429. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/usePayrollConfiguration.js +12 -0
  430. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/usePayrollConfiguration.js.map +1 -0
  431. package/dist/components/Payroll/UNSTABLE_PayrollHooks/index.d.ts +2 -0
  432. package/dist/components/Payroll/helpers.d.ts +0 -5
  433. package/dist/components/Payroll/helpers.js +106 -112
  434. package/dist/components/Payroll/helpers.js.map +1 -1
  435. package/dist/components/Payroll/usePreparedPayrollData.js +5 -6
  436. package/dist/components/Payroll/usePreparedPayrollData.js.map +1 -1
  437. package/dist/contexts/ComponentAdapter/adapters/defaultComponentAdapter.js +48 -46
  438. package/dist/contexts/ComponentAdapter/adapters/defaultComponentAdapter.js.map +1 -1
  439. package/dist/contexts/ComponentAdapter/useComponentContext.d.ts +2 -0
  440. package/dist/contexts/ComponentAdapter/useComponentContext.js +3 -3
  441. package/dist/contexts/ComponentAdapter/useComponentContext.js.map +1 -1
  442. package/dist/contexts/GustoProvider/GustoProviderCustomUIAdapter.js +7 -5
  443. package/dist/contexts/GustoProvider/GustoProviderCustomUIAdapter.js.map +1 -1
  444. package/dist/helpers/dateFormatting.d.ts +9 -0
  445. package/dist/helpers/dateFormatting.js +65 -52
  446. package/dist/helpers/dateFormatting.js.map +1 -1
  447. package/dist/i18n/I18n.js +3 -3
  448. package/dist/i18n/I18n.js.map +1 -1
  449. package/dist/i18n/en/Contractor.Payments.CreatePayment.json.js +34 -0
  450. package/dist/i18n/en/Contractor.Payments.CreatePayment.json.js.map +1 -0
  451. package/dist/i18n/en/Contractor.Payments.EditPayment.json.js +36 -0
  452. package/dist/i18n/en/Contractor.Payments.EditPayment.json.js.map +1 -0
  453. package/dist/i18n/en/Contractor.Payments.Overview.json.js +34 -0
  454. package/dist/i18n/en/Contractor.Payments.Overview.json.js.map +1 -0
  455. package/dist/i18n/en/Contractor.Payments.PaymentsList.json.js +34 -0
  456. package/dist/i18n/en/Contractor.Payments.PaymentsList.json.js.map +1 -0
  457. package/dist/i18n/en/ContractorPayment.ContractorPaymentDetail.json.js +24 -0
  458. package/dist/i18n/en/ContractorPayment.ContractorPaymentDetail.json.js.map +1 -0
  459. package/dist/i18n/en/Employee.Deductions.json.js +58 -46
  460. package/dist/i18n/en/Employee.Deductions.json.js.map +1 -1
  461. package/dist/i18n/en/Employee.FederalTaxes.json.js +49 -41
  462. package/dist/i18n/en/Employee.FederalTaxes.json.js.map +1 -1
  463. package/dist/i18n/en/Employee.Taxes.json.js +53 -45
  464. package/dist/i18n/en/Employee.Taxes.json.js.map +1 -1
  465. package/dist/i18n/en/Payroll.Common.json.js +8 -0
  466. package/dist/i18n/en/Payroll.Common.json.js.map +1 -0
  467. package/dist/i18n/en/Payroll.ConfirmWireDetailsForm.json.js +25 -5
  468. package/dist/i18n/en/Payroll.ConfirmWireDetailsForm.json.js.map +1 -1
  469. package/dist/i18n/en/Payroll.PayrollList.json.js +14 -16
  470. package/dist/i18n/en/Payroll.PayrollList.json.js.map +1 -1
  471. package/dist/i18n/en/Payroll.PayrollOverview.json.js +34 -30
  472. package/dist/i18n/en/Payroll.PayrollOverview.json.js.map +1 -1
  473. package/dist/i18n/en/Payroll.WireInstructions.json.js +22 -6
  474. package/dist/i18n/en/Payroll.WireInstructions.json.js.map +1 -1
  475. package/dist/shared/constants.d.ts +18 -0
  476. package/dist/shared/constants.js +66 -55
  477. package/dist/shared/constants.js.map +1 -1
  478. package/dist/style.css +1 -1
  479. package/dist/types/i18next.d.ts +236 -15
  480. package/package.json +19 -15
  481. package/dist/components/Employee/Deductions/DeductionsForm/UNSTABLE_DeductionsForm.d.ts +0 -7
  482. package/dist/components/Employee/Deductions/EmptyState/EmptyState.d.ts +0 -6
  483. package/dist/components/Employee/Deductions/IncludeDeductionsForm/IncludeDeductionsForm.d.ts +0 -15
  484. package/dist/components/Employee/Deductions/IncludeDeductionsForm/IncludeDeductionsForm.js +0 -49
  485. package/dist/components/Employee/Deductions/IncludeDeductionsForm/IncludeDeductionsForm.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"FederalForm.js","sources":["../../../../src/components/Employee/Taxes/FederalForm.tsx"],"sourcesContent":["import { Trans, useTranslation } from 'react-i18next'\nimport { z } from 'zod'\nimport { NumberInputField, RadioGroupField, SelectField } from '@/components/Common'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\n\nexport const FederalFormSchema = z.object({\n filingStatus: z.string().min(1),\n twoJobs: z.string().min(1),\n dependentsAmount: z.number().transform(String),\n otherIncome: z.number().transform(String),\n deductions: z.number().transform(String),\n extraWithholding: z.number().transform(String),\n w4DataType: z.enum(['pre_2020_w4', 'rev_2020_w4']),\n})\n\nexport type FederalFormInputs = z.input<typeof FederalFormSchema>\nexport type FederalFormPayload = z.output<typeof FederalFormSchema>\n\nexport function FederalForm() {\n const { t } = useTranslation('Employee.Taxes')\n const Components = useComponentContext()\n\n const filingStatusCategories = [\n { value: 'Single', label: t('filingStatusSingle') },\n { value: 'Married', label: t('filingStatusMarried') },\n { value: 'Head of Household', label: t('filingStatusHeadOfHousehold') },\n { value: 'Exempt from withholding', label: t('filingStatusExemptFromWithholding') },\n ]\n\n return (\n <>\n <SelectField\n name=\"filingStatus\"\n label={t('federalFilingStatus1c')}\n placeholder={t('federalFillingStatusPlaceholder')}\n options={filingStatusCategories}\n isRequired\n errorMessage={t('validations.federalFilingStatus')}\n />\n <RadioGroupField\n name=\"twoJobs\"\n isRequired\n label={t('multipleJobs2c')}\n errorMessage={t('validations.federalTwoJobs')}\n description={\n <Components.Text>\n <Trans\n i18nKey={'includesSpouseExplanation'}\n t={t}\n components={{\n IrsLink: <Components.Link />,\n }}\n />\n </Components.Text>\n }\n options={[\n { value: 'true', label: t('twoJobYesLabel') },\n { value: 'false', label: t('twoJobNoLabel') },\n ]}\n />\n <NumberInputField\n name=\"dependentsAmount\"\n isRequired\n label={t('dependentsTotalIfApplicable')}\n errorMessage={t('fieldIsRequired')}\n />\n <NumberInputField\n name=\"otherIncome\"\n isRequired\n label={t('otherIncome')}\n format=\"currency\"\n min={0}\n errorMessage={t('fieldIsRequired')}\n />\n <NumberInputField\n name=\"deductions\"\n isRequired\n label={t('deductions')}\n format=\"currency\"\n min={0}\n errorMessage={t('fieldIsRequired')}\n />\n <NumberInputField\n name=\"extraWithholding\"\n isRequired\n label={t('extraWithholding')}\n format=\"currency\"\n min={0}\n errorMessage={t('fieldIsRequired')}\n />\n </>\n )\n}\n"],"names":["FederalFormSchema","z","FederalForm","t","useTranslation","Components","useComponentContext","filingStatusCategories","jsxs","Fragment","jsx","SelectField","RadioGroupField","Trans","NumberInputField"],"mappings":"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"}
1
+ {"version":3,"file":"FederalForm.js","sources":["../../../../src/components/Employee/Taxes/FederalForm.tsx"],"sourcesContent":["import { Trans, useTranslation } from 'react-i18next'\nimport { useFormContext } from 'react-hook-form'\nimport { z } from 'zod'\nimport { NumberInputField, RadioGroupField, SelectField, TextInputField } from '@/components/Common'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\n\nconst Rev2020Schema = z.object({\n w4DataType: z.literal('rev_2020_w4'),\n filingStatus: z.string().min(1),\n twoJobs: z.string().min(1),\n dependentsAmount: z.number().transform(String),\n otherIncome: z.number().transform(String),\n deductions: z.number().transform(String),\n extraWithholding: z.number().transform(String),\n})\n\nconst Pre2020Schema = z.object({\n w4DataType: z.literal('pre_2020_w4'),\n filingStatus: z.string().min(1),\n federalWithholdingAllowance: z.number().int(),\n additionalWithholding: z.string(),\n})\n\nexport const FederalFormSchema = z.discriminatedUnion('w4DataType', [Rev2020Schema, Pre2020Schema])\n\nexport type FederalFormInputs = z.input<typeof FederalFormSchema>\nexport type FederalFormPayload = z.output<typeof FederalFormSchema>\n\nexport function FederalForm() {\n const { watch } = useFormContext<FederalFormInputs>()\n const w4DataType = watch('w4DataType')\n\n if (w4DataType === 'rev_2020_w4') {\n return <Rev2020Form />\n }\n\n return <Pre2020Form />\n}\n\nfunction Rev2020Form() {\n const { t } = useTranslation('Employee.Taxes')\n const Components = useComponentContext()\n\n const filingStatusOptions = [\n { value: 'Single', label: t('filingStatusSingle') },\n { value: 'Married', label: t('filingStatusMarried') },\n { value: 'Head of Household', label: t('filingStatusHeadOfHousehold') },\n { value: 'Exempt from withholding', label: t('filingStatusExemptFromWithholding') },\n ]\n\n return (\n <>\n <SelectField\n name=\"filingStatus\"\n label={t('federalFilingStatus1c')}\n placeholder={t('federalFilingStatusPlaceholder')}\n options={filingStatusOptions}\n isRequired\n errorMessage={t('validations.federalFilingStatus')}\n />\n <RadioGroupField\n name=\"twoJobs\"\n isRequired\n label={t('multipleJobs2c')}\n errorMessage={t('validations.federalTwoJobs')}\n description={\n <Components.Text>\n <Trans\n i18nKey={'includesSpouseExplanation'}\n t={t}\n components={{\n IrsLink: <Components.Link />,\n }}\n />\n </Components.Text>\n }\n options={[\n { value: 'true', label: t('twoJobYesLabel') },\n { value: 'false', label: t('twoJobNoLabel') },\n ]}\n />\n <NumberInputField\n name=\"dependentsAmount\"\n isRequired\n label={t('dependentsTotalIfApplicable')}\n errorMessage={t('fieldIsRequired')}\n />\n <NumberInputField\n name=\"otherIncome\"\n isRequired\n label={t('otherIncome')}\n format=\"currency\"\n min={0}\n errorMessage={t('fieldIsRequired')}\n />\n <NumberInputField\n name=\"deductions\"\n isRequired\n label={t('deductions')}\n format=\"currency\"\n min={0}\n errorMessage={t('fieldIsRequired')}\n />\n <NumberInputField\n name=\"extraWithholding\"\n isRequired\n label={t('extraWithholding')}\n format=\"currency\"\n min={0}\n errorMessage={t('fieldIsRequired')}\n />\n </>\n )\n}\n\nfunction Pre2020Form() {\n const { t } = useTranslation('Employee.Taxes')\n\n const filingStatusOptions = [\n { value: 'Single', label: t('filingStatusSingle') },\n { value: 'Married', label: t('filingStatusMarried') },\n { value: 'Head of Household', label: t('filingStatusHeadOfHousehold') },\n { value: 'Exempt from withholding', label: t('filingStatusExemptFromWithholding') },\n { value: 'Married, but withhold as Single', label: t('filingStatusMarriedWithholdAsSingle') },\n ]\n\n return (\n <>\n <NumberInputField\n name=\"federalWithholdingAllowance\"\n isRequired\n label={t('federalWithholdingAllowance')}\n min={0}\n maximumFractionDigits={0}\n errorMessage={t('fieldIsRequired')}\n />\n <SelectField\n name=\"filingStatus\"\n label={t('filingStatus')}\n placeholder={t('federalFilingStatusPlaceholder')}\n description={t('selectWithholdingDescription')}\n options={filingStatusOptions}\n isRequired\n errorMessage={t('validations.federalFilingStatus')}\n />\n <TextInputField\n name=\"additionalWithholding\"\n label={t('additionalWithholding')}\n type=\"number\"\n errorMessage={t('fieldIsRequired')}\n />\n </>\n )\n}\n"],"names":["Rev2020Schema","z","Pre2020Schema","FederalFormSchema","FederalForm","watch","useFormContext","Rev2020Form","Pre2020Form","t","useTranslation","Components","useComponentContext","filingStatusOptions","jsxs","Fragment","jsx","SelectField","RadioGroupField","Trans","NumberInputField","TextInputField"],"mappings":"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"}
@@ -1,117 +1,133 @@
1
- import { jsx as t, jsxs as M, Fragment as I } from "react/jsx-runtime";
2
- import { zodResolver as O } from "@hookform/resolvers/zod";
3
- import { useForm as C, FormProvider as J } from "react-hook-form";
1
+ import { jsx as o, jsxs as O, Fragment as C } from "react/jsx-runtime";
2
+ import { zodResolver as J } from "@hookform/resolvers/zod";
3
+ import { useForm as V, FormProvider as X } from "react-hook-form";
4
4
  import "react-i18next";
5
- import { useEffect as X } from "react";
6
- import { useEmployeeTaxSetupGetFederalTaxesSuspense as q } from "@gusto/embedded-api/react-query/employeeTaxSetupGetFederalTaxes";
7
- import { useEmployeeTaxSetupUpdateFederalTaxesMutation as B } from "@gusto/embedded-api/react-query/employeeTaxSetupUpdateFederalTaxes";
8
- import { useEmployeeTaxSetupGetStateTaxesSuspense as H } from "@gusto/embedded-api/react-query/employeeTaxSetupGetStateTaxes";
9
- import { useEmployeeTaxSetupUpdateStateTaxesMutation as V } from "@gusto/embedded-api/react-query/employeeTaxSetupUpdateStateTaxes";
10
- import { Actions as W } from "./Actions.js";
11
- import { FederalFormSchema as Y, FederalForm as j } from "./FederalForm.js";
12
- import { FederalHead as G } from "./FederalHead.js";
13
- import { StateFormSchema as z, StateForm as K } from "./StateForm.js";
14
- import { TaxesProvider as Q } from "./useTaxes.js";
15
- import { BaseComponent as Z } from "../../Base/Base.js";
16
- import { useBase as $ } from "../../Base/useBase.js";
5
+ import { useEffect as q } from "react";
6
+ import { useEmployeeTaxSetupGetFederalTaxesSuspense as B } from "@gusto/embedded-api/react-query/employeeTaxSetupGetFederalTaxes";
7
+ import { useEmployeeTaxSetupUpdateFederalTaxesMutation as H } from "@gusto/embedded-api/react-query/employeeTaxSetupUpdateFederalTaxes";
8
+ import { useEmployeeTaxSetupGetStateTaxesSuspense as Y } from "@gusto/embedded-api/react-query/employeeTaxSetupGetStateTaxes";
9
+ import { useEmployeeTaxSetupUpdateStateTaxesMutation as j } from "@gusto/embedded-api/react-query/employeeTaxSetupUpdateStateTaxes";
10
+ import { Actions as G } from "./Actions.js";
11
+ import { FederalFormSchema as z, FederalForm as K } from "./FederalForm.js";
12
+ import { FederalHead as Q } from "./FederalHead.js";
13
+ import { StateFormSchema as Z, StateForm as $ } from "./StateForm.js";
14
+ import { TaxesProvider as ee } from "./useTaxes.js";
15
+ import { BaseComponent as te } from "../../Base/Base.js";
16
+ import { useBase as oe } from "../../Base/useBase.js";
17
17
  import "../../Flow/useFlow.js";
18
- import { useI18n as ee, useComponentDictionary as te } from "../../../i18n/I18n.js";
19
- import { componentEvents as E } from "../../../shared/constants.js";
20
- import { snakeCaseToCamelCase as v } from "../../../helpers/formattedStrings.js";
21
- import { Form as oe } from "../../Common/Form/Form.js";
22
- const se = "2010-01-01";
23
- function we(i) {
24
- return /* @__PURE__ */ t(Z, { ...i, children: /* @__PURE__ */ t(re, { ...i, children: i.children }) });
18
+ import { useI18n as ae, useComponentDictionary as se } from "../../../i18n/I18n.js";
19
+ import { componentEvents as T } from "../../../shared/constants.js";
20
+ import { snakeCaseToCamelCase as A } from "../../../helpers/formattedStrings.js";
21
+ import { Form as ne } from "../../Common/Form/Form.js";
22
+ const re = "2010-01-01";
23
+ function We(i) {
24
+ return /* @__PURE__ */ o(te, { ...i, children: /* @__PURE__ */ o(ie, { ...i, children: i.children }) });
25
25
  }
26
- const re = (i) => {
27
- const { employeeId: d, className: A, children: x, isAdmin: S = !1, dictionary: b } = i, { onEvent: c, fieldErrors: u, baseSubmitHandler: g } = $();
28
- ee("Employee.Taxes"), te("Employee.Taxes", b);
29
- const { data: P } = q({
30
- employeeUuid: d
31
- }), e = P.employeeFederalTax, { mutateAsync: w, isPending: _ } = B(), { data: D } = H({
32
- employeeUuid: d
33
- }), f = D.employeeStateTaxesList, { mutateAsync: U, isPending: N } = V(), k = {
34
- ...e,
35
- filingStatus: e.filingStatus ?? void 0,
26
+ const ie = (i) => {
27
+ const { employeeId: m, className: F, children: S, isAdmin: E = !1, dictionary: D } = i, { onEvent: c, fieldErrors: u, baseSubmitHandler: _ } = oe();
28
+ ae("Employee.Taxes"), se("Employee.Taxes", D);
29
+ const { data: b } = B({
30
+ employeeUuid: m
31
+ }), e = b.employeeFederalTax, { mutateAsync: P, isPending: W } = H(), { data: U } = Y({
32
+ employeeUuid: m
33
+ }), f = U.employeeStateTaxesList, { mutateAsync: N, isPending: R } = j(), k = e.w4DataType === "rev_2020_w4", x = f.reduce((a, s) => (s.state && (a[s.state] = s.questions?.reduce((n, t) => {
34
+ const l = t.answers[0]?.value, d = A(t.key);
35
+ return d === "fileNewHireReport" ? n[d] = typeof l > "u" ? !0 : l : n[d] = l, n;
36
+ }, {})), a), {}), I = k ? {
37
+ w4DataType: "rev_2020_w4",
38
+ filingStatus: e.filingStatus ?? "",
36
39
  twoJobs: e.twoJobs ? "true" : "false",
37
40
  deductions: e.deductions ? Number(e.deductions) : 0,
38
41
  dependentsAmount: e.dependentsAmount ? Number(e.dependentsAmount) : 0,
39
42
  otherIncome: e.otherIncome ? Number(e.otherIncome) : 0,
40
43
  extraWithholding: e.extraWithholding ? Number(e.extraWithholding) : 0,
41
- states: f.reduce((o, s) => (s.state && (o[s.state] = s.questions?.reduce((r, m) => {
42
- const l = m.answers[0]?.value, n = v(m.key);
43
- return n === "fileNewHireReport" ? r[n] = typeof l > "u" ? !0 : l : r[n] = l, r;
44
- }, {})), o), {})
45
- }, h = C({
46
- resolver: O(Y.merge(z)),
47
- defaultValues: k
48
- }), { handleSubmit: R, setError: F } = h;
49
- return X(() => {
50
- u && u.length > 0 && u.forEach((o) => {
51
- const s = o.errorKey.replace(".value", "");
52
- F(s, { type: "custom", message: o.message });
44
+ states: x
45
+ } : {
46
+ w4DataType: "pre_2020_w4",
47
+ filingStatus: e.filingStatus ?? "",
48
+ federalWithholdingAllowance: e.federalWithholdingAllowance ?? 0,
49
+ additionalWithholding: e.additionalWithholding,
50
+ states: x
51
+ }, g = V({
52
+ resolver: J(z.and(Z)),
53
+ defaultValues: I
54
+ }), { handleSubmit: L, setError: w } = g;
55
+ return q(() => {
56
+ u && u.length > 0 && u.forEach((a) => {
57
+ const s = a.errorKey.replace(".value", "");
58
+ w(s, { type: "custom", message: a.message });
53
59
  });
54
- }, [u, F]), /* @__PURE__ */ t("section", { className: A, children: /* @__PURE__ */ t(
55
- Q,
60
+ }, [u, w]), /* @__PURE__ */ o("section", { className: F, children: /* @__PURE__ */ o(
61
+ ee,
56
62
  {
57
63
  value: {
58
64
  employeeStateTaxes: f,
59
- isAdmin: S,
60
- isPending: _ || N
65
+ isAdmin: E,
66
+ isPending: W || R
61
67
  },
62
- children: /* @__PURE__ */ t(J, { ...h, children: /* @__PURE__ */ t(oe, { onSubmit: R(async (o) => {
63
- await g(o, async (s) => {
64
- const { states: r, ...m } = s, l = await w({
68
+ children: /* @__PURE__ */ o(X, { ...g, children: /* @__PURE__ */ o(ne, { onSubmit: L(async (a) => {
69
+ await _(a, async (s) => {
70
+ const { states: n, ...t } = s, l = t.w4DataType === "rev_2020_w4" ? {
71
+ filingStatus: t.filingStatus,
72
+ twoJobs: t.twoJobs === "true",
73
+ dependentsAmount: t.dependentsAmount,
74
+ otherIncome: t.otherIncome,
75
+ deductions: t.deductions,
76
+ extraWithholding: t.extraWithholding,
77
+ w4DataType: t.w4DataType,
78
+ version: e.version
79
+ } : {
80
+ filingStatus: t.filingStatus,
81
+ federalWithholdingAllowance: t.federalWithholdingAllowance,
82
+ additionalWithholding: t.additionalWithholding,
83
+ w4DataType: t.w4DataType,
84
+ version: e.version
85
+ }, d = await P({
65
86
  request: {
66
- employeeUuid: d,
67
- requestBody: {
68
- ...m,
69
- twoJobs: m.twoJobs === "true",
70
- version: e.version
71
- }
87
+ employeeUuid: m,
88
+ requestBody: l
72
89
  }
73
90
  });
74
- if (c(E.EMPLOYEE_FEDERAL_TAXES_UPDATED, l), r && Object.keys(r).length > 0) {
75
- const n = [];
76
- for (const y of f) {
77
- const T = y.state;
78
- T && y.questions !== void 0 && n.push({
79
- state: T,
80
- questions: y.questions.map((a) => {
81
- if (a.isQuestionForAdminOnly && !S)
91
+ if (c(T.EMPLOYEE_FEDERAL_TAXES_UPDATED, d), n && Object.keys(n).length > 0) {
92
+ const v = [];
93
+ for (const h of f) {
94
+ const y = h.state;
95
+ y && h.questions !== void 0 && v.push({
96
+ state: y,
97
+ questions: h.questions.map((r) => {
98
+ if (r.isQuestionForAdminOnly && !E)
82
99
  return null;
83
- const p = r[T]?.[v(a.key)];
100
+ const p = n[y]?.[A(r.key)];
84
101
  return {
85
- key: a.key,
102
+ key: r.key,
86
103
  answers: [
87
104
  {
88
- validFrom: a.answers[0]?.validFrom ?? se,
89
- validUpTo: a.answers[0]?.validUpTo ?? null,
105
+ validFrom: r.answers[0]?.validFrom ?? re,
106
+ validUpTo: r.answers[0]?.validUpTo ?? null,
90
107
  value: p == null || typeof p == "number" && isNaN(p) ? "" : p
91
108
  }
92
109
  ]
93
110
  };
94
- }).filter((a) => a !== null)
95
- //Filtering out questions in non-admin setup
111
+ }).filter((r) => r !== null)
96
112
  });
97
113
  }
98
- const L = await U({
99
- request: { employeeUuid: d, employeeStateTaxesRequest: { states: n } }
114
+ const M = await N({
115
+ request: { employeeUuid: m, employeeStateTaxesRequest: { states: v } }
100
116
  });
101
- c(E.EMPLOYEE_STATE_TAXES_UPDATED, L);
117
+ c(T.EMPLOYEE_STATE_TAXES_UPDATED, M);
102
118
  }
103
- c(E.EMPLOYEE_TAXES_DONE);
119
+ c(T.EMPLOYEE_TAXES_DONE);
104
120
  });
105
- }), children: x || /* @__PURE__ */ M(I, { children: [
106
- /* @__PURE__ */ t(G, {}),
107
- /* @__PURE__ */ t(j, {}),
108
- /* @__PURE__ */ t(K, {}),
109
- /* @__PURE__ */ t(W, {})
121
+ }), children: S || /* @__PURE__ */ O(C, { children: [
122
+ /* @__PURE__ */ o(Q, {}),
123
+ /* @__PURE__ */ o(K, {}),
124
+ /* @__PURE__ */ o($, {}),
125
+ /* @__PURE__ */ o(G, {})
110
126
  ] }) }) })
111
127
  }
112
128
  ) });
113
129
  };
114
130
  export {
115
- we as Taxes
131
+ We as Taxes
116
132
  };
117
133
  //# sourceMappingURL=Taxes.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Taxes.js","sources":["../../../../src/components/Employee/Taxes/Taxes.tsx"],"sourcesContent":["import { zodResolver } from '@hookform/resolvers/zod'\nimport { FormProvider, useForm, type SubmitHandler } from 'react-hook-form'\nimport { useTranslation } from 'react-i18next'\nimport { useEffect } from 'react'\nimport { useEmployeeTaxSetupGetFederalTaxesSuspense } from '@gusto/embedded-api/react-query/employeeTaxSetupGetFederalTaxes'\nimport { useEmployeeTaxSetupUpdateFederalTaxesMutation } from '@gusto/embedded-api/react-query/employeeTaxSetupUpdateFederalTaxes'\nimport { useEmployeeTaxSetupGetStateTaxesSuspense } from '@gusto/embedded-api/react-query/employeeTaxSetupGetStateTaxes'\nimport { useEmployeeTaxSetupUpdateStateTaxesMutation } from '@gusto/embedded-api/react-query/employeeTaxSetupUpdateStateTaxes'\nimport type { OnboardingContextInterface } from '../OnboardingFlow/OnboardingFlowComponents'\nimport { Actions } from './Actions'\nimport {\n FederalForm,\n FederalFormSchema,\n type FederalFormInputs,\n type FederalFormPayload,\n} from './FederalForm'\nimport { FederalHead } from './FederalHead'\nimport { StateForm, StateFormSchema, type StateFormPayload } from './StateForm'\nimport { TaxesProvider } from './useTaxes'\nimport {\n useBase,\n BaseComponent,\n type BaseComponentInterface,\n type CommonComponentInterface,\n} from '@/components/Base'\nimport { useFlow } from '@/components/Flow/useFlow'\nimport { useI18n } from '@/i18n'\nimport { componentEvents } from '@/shared/constants'\nimport { snakeCaseToCamelCase } from '@/helpers/formattedStrings'\nimport { Form } from '@/components/Common/Form'\nimport { useComponentDictionary } from '@/i18n/I18n'\n\nconst DEFAULT_TAX_VALID_FROM = '2010-01-01'\n\ninterface TaxesProps extends CommonComponentInterface<'Employee.Taxes'> {\n employeeId: string\n isAdmin?: boolean\n}\n\n/**\n * @deprecated The Taxes component has been deprecated and will be removed in a future release.\n * The component has been split into separate components for state and federal. Use Employee.FederalTaxes\n * and Employee.StateTaxes components instead.\n */\nexport function Taxes(props: TaxesProps & BaseComponentInterface) {\n return (\n <BaseComponent {...props}>\n <Root {...props}>{props.children}</Root>\n </BaseComponent>\n )\n}\n\nconst Root = (props: TaxesProps) => {\n const { employeeId, className, children, isAdmin = false, dictionary } = props\n const { onEvent, fieldErrors, baseSubmitHandler } = useBase()\n useI18n('Employee.Taxes')\n useComponentDictionary('Employee.Taxes', dictionary)\n\n const { data: fedData } = useEmployeeTaxSetupGetFederalTaxesSuspense({\n employeeUuid: employeeId,\n })\n const employeeFederalTax = fedData.employeeFederalTax!\n\n const { mutateAsync: updateFederalTaxes, isPending: isPendingFederalTaxes } =\n useEmployeeTaxSetupUpdateFederalTaxesMutation()\n\n const { data: stateData } = useEmployeeTaxSetupGetStateTaxesSuspense({\n employeeUuid: employeeId,\n })\n const employeeStateTaxes = stateData.employeeStateTaxesList!\n const { mutateAsync: updateStateTaxes, isPending: isPendingStateTaxes } =\n useEmployeeTaxSetupUpdateStateTaxesMutation()\n\n const defaultValues = {\n ...employeeFederalTax,\n filingStatus: employeeFederalTax.filingStatus ?? undefined,\n twoJobs: employeeFederalTax.twoJobs ? 'true' : 'false',\n deductions: employeeFederalTax.deductions ? Number(employeeFederalTax.deductions) : 0,\n dependentsAmount: employeeFederalTax.dependentsAmount\n ? Number(employeeFederalTax.dependentsAmount)\n : 0,\n otherIncome: employeeFederalTax.otherIncome ? Number(employeeFederalTax.otherIncome) : 0,\n extraWithholding: employeeFederalTax.extraWithholding\n ? Number(employeeFederalTax.extraWithholding)\n : 0,\n states: employeeStateTaxes.reduce((acc: Record<string, unknown>, state) => {\n if (state.state) {\n acc[state.state] = state.questions?.reduce((acc: Record<string, unknown>, question) => {\n const value = question.answers[0]?.value\n const key = snakeCaseToCamelCase(question.key)\n // Default new hire report to true if not specified\n if (key === 'fileNewHireReport') {\n acc[key] = typeof value === 'undefined' ? true : value\n } else {\n acc[key] = value\n }\n return acc\n }, {})\n }\n return acc\n }, {}),\n }\n\n const formMethods = useForm<FederalFormInputs, unknown, FederalFormPayload & StateFormPayload>({\n resolver: zodResolver(FederalFormSchema.merge(StateFormSchema)),\n defaultValues,\n })\n const { handleSubmit, setError: _setError } = formMethods\n\n useEffect(() => {\n //If list of field specific errors from API is present, mark corresponding fields as invalid\n if (fieldErrors && fieldErrors.length > 0) {\n fieldErrors.forEach(msgObject => {\n const key = msgObject.errorKey.replace('.value', '')\n _setError(key as keyof FederalFormInputs, { type: 'custom', message: msgObject.message })\n })\n }\n }, [fieldErrors, _setError])\n\n const onSubmit: SubmitHandler<FederalFormPayload & StateFormPayload> = async data => {\n await baseSubmitHandler(data, async payload => {\n const { states: statesPayload, ...federalPayload } = payload\n\n const federalTaxesResponse = await updateFederalTaxes({\n request: {\n employeeUuid: employeeId,\n requestBody: {\n ...federalPayload,\n twoJobs: federalPayload.twoJobs === 'true',\n version: employeeFederalTax.version,\n },\n },\n })\n onEvent(componentEvents.EMPLOYEE_FEDERAL_TAXES_UPDATED, federalTaxesResponse)\n\n //State Taxes - only process if statesPayload exists\n if (statesPayload && Object.keys(statesPayload).length > 0) {\n const states = []\n\n for (const state of employeeStateTaxes) {\n const stateName = state.state\n\n if (stateName && state.questions !== undefined) {\n states.push({\n state: stateName,\n questions: state.questions\n .map(question => {\n if (question.isQuestionForAdminOnly && !isAdmin) {\n return null\n }\n const formValue = statesPayload[stateName]?.[snakeCaseToCamelCase(question.key)]\n return {\n key: question.key,\n answers: [\n {\n validFrom: question.answers[0]?.validFrom ?? DEFAULT_TAX_VALID_FROM,\n validUpTo: question.answers[0]?.validUpTo ?? null,\n value:\n formValue == null || (typeof formValue === 'number' && isNaN(formValue))\n ? ''\n : (formValue as string | number | boolean),\n },\n ],\n }\n })\n .filter(q => q !== null), //Filtering out questions in non-admin setup\n })\n }\n }\n\n const stateTaxesResponse = await updateStateTaxes({\n request: { employeeUuid: employeeId, employeeStateTaxesRequest: { states } },\n })\n onEvent(componentEvents.EMPLOYEE_STATE_TAXES_UPDATED, stateTaxesResponse)\n }\n\n onEvent(componentEvents.EMPLOYEE_TAXES_DONE)\n })\n }\n\n return (\n <section className={className}>\n <TaxesProvider\n value={{\n employeeStateTaxes,\n isAdmin: isAdmin,\n isPending: isPendingFederalTaxes || isPendingStateTaxes,\n }}\n >\n <FormProvider {...formMethods}>\n <Form onSubmit={handleSubmit(onSubmit)}>\n {children ? (\n children\n ) : (\n <>\n <FederalHead />\n <FederalForm />\n <StateForm />\n <Actions />\n </>\n )}\n </Form>\n </FormProvider>\n </TaxesProvider>\n </section>\n )\n}\n\nexport const TaxesContextual = () => {\n const { employeeId, onEvent, isAdmin } = useFlow<OnboardingContextInterface>()\n const { t } = useTranslation()\n if (!employeeId) {\n throw new Error(\n t('errors.missingParamsOrContext', {\n component: 'EmployeeTaxes',\n param: 'employeeId',\n provider: 'FlowProvider',\n }),\n )\n }\n return <Taxes employeeId={employeeId} onEvent={onEvent} isAdmin={isAdmin ?? false} />\n}\n"],"names":["DEFAULT_TAX_VALID_FROM","Taxes","props","jsx","BaseComponent","Root","employeeId","className","children","isAdmin","dictionary","onEvent","fieldErrors","baseSubmitHandler","useBase","useI18n","useComponentDictionary","fedData","useEmployeeTaxSetupGetFederalTaxesSuspense","employeeFederalTax","updateFederalTaxes","isPendingFederalTaxes","useEmployeeTaxSetupUpdateFederalTaxesMutation","stateData","useEmployeeTaxSetupGetStateTaxesSuspense","employeeStateTaxes","updateStateTaxes","isPendingStateTaxes","useEmployeeTaxSetupUpdateStateTaxesMutation","defaultValues","acc","state","question","value","key","snakeCaseToCamelCase","formMethods","useForm","zodResolver","FederalFormSchema","StateFormSchema","handleSubmit","_setError","useEffect","msgObject","TaxesProvider","FormProvider","Form","data","payload","statesPayload","federalPayload","federalTaxesResponse","componentEvents","states","stateName","formValue","q","stateTaxesResponse","jsxs","Fragment","FederalHead","FederalForm","StateForm","Actions"],"mappings":"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"}
1
+ {"version":3,"file":"Taxes.js","sources":["../../../../src/components/Employee/Taxes/Taxes.tsx"],"sourcesContent":["import { zodResolver } from '@hookform/resolvers/zod'\nimport { FormProvider, useForm, type SubmitHandler } from 'react-hook-form'\nimport { useTranslation } from 'react-i18next'\nimport { useEffect } from 'react'\nimport { useEmployeeTaxSetupGetFederalTaxesSuspense } from '@gusto/embedded-api/react-query/employeeTaxSetupGetFederalTaxes'\nimport { useEmployeeTaxSetupUpdateFederalTaxesMutation } from '@gusto/embedded-api/react-query/employeeTaxSetupUpdateFederalTaxes'\nimport { useEmployeeTaxSetupGetStateTaxesSuspense } from '@gusto/embedded-api/react-query/employeeTaxSetupGetStateTaxes'\nimport { useEmployeeTaxSetupUpdateStateTaxesMutation } from '@gusto/embedded-api/react-query/employeeTaxSetupUpdateStateTaxes'\nimport type { OnboardingContextInterface } from '../OnboardingFlow/OnboardingFlowComponents'\nimport { Actions } from './Actions'\nimport {\n FederalForm,\n FederalFormSchema,\n type FederalFormInputs,\n type FederalFormPayload,\n} from './FederalForm'\nimport { FederalHead } from './FederalHead'\nimport { StateForm, StateFormSchema, type StateFormPayload } from './StateForm'\nimport { TaxesProvider } from './useTaxes'\nimport {\n useBase,\n BaseComponent,\n type BaseComponentInterface,\n type CommonComponentInterface,\n} from '@/components/Base'\nimport { useFlow } from '@/components/Flow/useFlow'\nimport { useI18n } from '@/i18n'\nimport { componentEvents } from '@/shared/constants'\nimport { snakeCaseToCamelCase } from '@/helpers/formattedStrings'\nimport { Form } from '@/components/Common/Form'\nimport { useComponentDictionary } from '@/i18n/I18n'\n\nconst DEFAULT_TAX_VALID_FROM = '2010-01-01'\n\ninterface TaxesProps extends CommonComponentInterface<'Employee.Taxes'> {\n employeeId: string\n isAdmin?: boolean\n}\n\n/**\n * @deprecated The Taxes component has been deprecated and will be removed in a future release.\n * The component has been split into separate components for state and federal. Use Employee.FederalTaxes\n * and Employee.StateTaxes components instead.\n */\nexport function Taxes(props: TaxesProps & BaseComponentInterface) {\n return (\n <BaseComponent {...props}>\n <Root {...props}>{props.children}</Root>\n </BaseComponent>\n )\n}\n\nconst Root = (props: TaxesProps) => {\n const { employeeId, className, children, isAdmin = false, dictionary } = props\n const { onEvent, fieldErrors, baseSubmitHandler } = useBase()\n useI18n('Employee.Taxes')\n useComponentDictionary('Employee.Taxes', dictionary)\n\n const { data: fedData } = useEmployeeTaxSetupGetFederalTaxesSuspense({\n employeeUuid: employeeId,\n })\n const employeeFederalTax = fedData.employeeFederalTax!\n\n const { mutateAsync: updateFederalTaxes, isPending: isPendingFederalTaxes } =\n useEmployeeTaxSetupUpdateFederalTaxesMutation()\n\n const { data: stateData } = useEmployeeTaxSetupGetStateTaxesSuspense({\n employeeUuid: employeeId,\n })\n const employeeStateTaxes = stateData.employeeStateTaxesList!\n const { mutateAsync: updateStateTaxes, isPending: isPendingStateTaxes } =\n useEmployeeTaxSetupUpdateStateTaxesMutation()\n\n const isRev2020 = employeeFederalTax.w4DataType === 'rev_2020_w4'\n\n const statesDefaultValues = employeeStateTaxes.reduce((acc: Record<string, unknown>, state) => {\n if (state.state) {\n acc[state.state] = state.questions?.reduce((acc: Record<string, unknown>, question) => {\n const value = question.answers[0]?.value\n const key = snakeCaseToCamelCase(question.key)\n if (key === 'fileNewHireReport') {\n acc[key] = typeof value === 'undefined' ? true : value\n } else {\n acc[key] = value\n }\n return acc\n }, {})\n }\n return acc\n }, {})\n\n const defaultValues: FederalFormInputs & { states: typeof statesDefaultValues } = isRev2020\n ? {\n w4DataType: 'rev_2020_w4',\n filingStatus: employeeFederalTax.filingStatus ?? '',\n twoJobs: employeeFederalTax.twoJobs ? 'true' : 'false',\n deductions: employeeFederalTax.deductions ? Number(employeeFederalTax.deductions) : 0,\n dependentsAmount: employeeFederalTax.dependentsAmount\n ? Number(employeeFederalTax.dependentsAmount)\n : 0,\n otherIncome: employeeFederalTax.otherIncome ? Number(employeeFederalTax.otherIncome) : 0,\n extraWithholding: employeeFederalTax.extraWithholding\n ? Number(employeeFederalTax.extraWithholding)\n : 0,\n states: statesDefaultValues,\n }\n : {\n w4DataType: 'pre_2020_w4',\n filingStatus: employeeFederalTax.filingStatus ?? '',\n federalWithholdingAllowance: employeeFederalTax.federalWithholdingAllowance ?? 0,\n additionalWithholding: employeeFederalTax.additionalWithholding,\n states: statesDefaultValues,\n }\n\n const formMethods = useForm<FederalFormInputs, unknown, FederalFormPayload & StateFormPayload>({\n resolver: zodResolver(FederalFormSchema.and(StateFormSchema)),\n defaultValues,\n })\n const { handleSubmit, setError: _setError } = formMethods\n\n useEffect(() => {\n if (fieldErrors && fieldErrors.length > 0) {\n fieldErrors.forEach(msgObject => {\n const key = msgObject.errorKey.replace('.value', '')\n _setError(key as keyof FederalFormInputs, { type: 'custom', message: msgObject.message })\n })\n }\n }, [fieldErrors, _setError])\n\n const onSubmit: SubmitHandler<FederalFormPayload & StateFormPayload> = async data => {\n await baseSubmitHandler(data, async payload => {\n const { states: statesPayload, ...federalPayload } = payload\n\n const requestBody =\n federalPayload.w4DataType === 'rev_2020_w4'\n ? {\n filingStatus: federalPayload.filingStatus,\n twoJobs: federalPayload.twoJobs === 'true',\n dependentsAmount: federalPayload.dependentsAmount,\n otherIncome: federalPayload.otherIncome,\n deductions: federalPayload.deductions,\n extraWithholding: federalPayload.extraWithholding,\n w4DataType: federalPayload.w4DataType,\n version: employeeFederalTax.version,\n }\n : {\n filingStatus: federalPayload.filingStatus,\n federalWithholdingAllowance: federalPayload.federalWithholdingAllowance,\n additionalWithholding: federalPayload.additionalWithholding,\n w4DataType: federalPayload.w4DataType,\n version: employeeFederalTax.version,\n }\n\n const federalTaxesResponse = await updateFederalTaxes({\n request: {\n employeeUuid: employeeId,\n requestBody,\n },\n })\n onEvent(componentEvents.EMPLOYEE_FEDERAL_TAXES_UPDATED, federalTaxesResponse)\n\n if (statesPayload && Object.keys(statesPayload).length > 0) {\n const states = []\n\n for (const state of employeeStateTaxes) {\n const stateName = state.state\n\n if (stateName && state.questions !== undefined) {\n states.push({\n state: stateName,\n questions: state.questions\n .map(question => {\n if (question.isQuestionForAdminOnly && !isAdmin) {\n return null\n }\n const formValue = statesPayload[stateName]?.[snakeCaseToCamelCase(question.key)]\n return {\n key: question.key,\n answers: [\n {\n validFrom: question.answers[0]?.validFrom ?? DEFAULT_TAX_VALID_FROM,\n validUpTo: question.answers[0]?.validUpTo ?? null,\n value:\n formValue == null || (typeof formValue === 'number' && isNaN(formValue))\n ? ''\n : (formValue as string | number | boolean),\n },\n ],\n }\n })\n .filter(q => q !== null),\n })\n }\n }\n\n const stateTaxesResponse = await updateStateTaxes({\n request: { employeeUuid: employeeId, employeeStateTaxesRequest: { states } },\n })\n onEvent(componentEvents.EMPLOYEE_STATE_TAXES_UPDATED, stateTaxesResponse)\n }\n\n onEvent(componentEvents.EMPLOYEE_TAXES_DONE)\n })\n }\n\n return (\n <section className={className}>\n <TaxesProvider\n value={{\n employeeStateTaxes,\n isAdmin: isAdmin,\n isPending: isPendingFederalTaxes || isPendingStateTaxes,\n }}\n >\n <FormProvider {...formMethods}>\n <Form onSubmit={handleSubmit(onSubmit)}>\n {children ? (\n children\n ) : (\n <>\n <FederalHead />\n <FederalForm />\n <StateForm />\n <Actions />\n </>\n )}\n </Form>\n </FormProvider>\n </TaxesProvider>\n </section>\n )\n}\n\nexport const TaxesContextual = () => {\n const { employeeId, onEvent, isAdmin } = useFlow<OnboardingContextInterface>()\n const { t } = useTranslation()\n if (!employeeId) {\n throw new Error(\n t('errors.missingParamsOrContext', {\n component: 'EmployeeTaxes',\n param: 'employeeId',\n provider: 'FlowProvider',\n }),\n )\n }\n return <Taxes employeeId={employeeId} onEvent={onEvent} isAdmin={isAdmin ?? false} />\n}\n"],"names":["DEFAULT_TAX_VALID_FROM","Taxes","props","jsx","BaseComponent","Root","employeeId","className","children","isAdmin","dictionary","onEvent","fieldErrors","baseSubmitHandler","useBase","useI18n","useComponentDictionary","fedData","useEmployeeTaxSetupGetFederalTaxesSuspense","employeeFederalTax","updateFederalTaxes","isPendingFederalTaxes","useEmployeeTaxSetupUpdateFederalTaxesMutation","stateData","useEmployeeTaxSetupGetStateTaxesSuspense","employeeStateTaxes","updateStateTaxes","isPendingStateTaxes","useEmployeeTaxSetupUpdateStateTaxesMutation","isRev2020","statesDefaultValues","acc","state","question","value","key","snakeCaseToCamelCase","defaultValues","formMethods","useForm","zodResolver","FederalFormSchema","StateFormSchema","handleSubmit","_setError","useEffect","msgObject","TaxesProvider","FormProvider","Form","data","payload","statesPayload","federalPayload","requestBody","federalTaxesResponse","componentEvents","states","stateName","formValue","q","stateTaxesResponse","jsxs","Fragment","FederalHead","FederalForm","StateForm","Actions"],"mappings":"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"}
@@ -4,7 +4,6 @@ import "react-error-boundary";
4
4
  import "react-i18next";
5
5
  import "@gusto/embedded-api/models/errors/apierror";
6
6
  import "@gusto/embedded-api/models/errors/sdkvalidationerror";
7
- import "@gusto/embedded-api/models/errors/unprocessableentityerrorobject";
8
7
  import "@tanstack/react-query";
9
8
  import "../../Base/useBase.js";
10
9
  import "../../../shared/constants.js";
@@ -12,9 +11,9 @@ import "classnames";
12
11
  import "../../../contexts/ComponentAdapter/useComponentContext.js";
13
12
  import "dompurify";
14
13
  import { createCompoundContext as o } from "../../Base/createCompoundContext.js";
15
- const [u, f] = o("TaxesContext");
14
+ const [d, u] = o("TaxesContext");
16
15
  export {
17
- f as TaxesProvider,
18
- u as useTaxes
16
+ u as TaxesProvider,
17
+ d as useTaxes
19
18
  };
20
19
  //# sourceMappingURL=useTaxes.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useTaxes.js","sources":["../../../../src/components/Employee/Taxes/useTaxes.ts"],"sourcesContent":["import type { EmployeeStateTaxesList } from '@gusto/embedded-api/models/components/employeestatetaxeslist'\nimport { createCompoundContext } from '@/components/Base'\n\ntype TaxesContextType = {\n employeeStateTaxes: EmployeeStateTaxesList[]\n isPending: boolean\n isAdmin: boolean\n}\n\nconst [useTaxes, TaxesProvider] = createCompoundContext<TaxesContextType>('TaxesContext')\nexport { useTaxes, TaxesProvider }\n"],"names":["useTaxes","TaxesProvider","createCompoundContext"],"mappings":";;;;;;;;;;;;;;AASA,MAAM,CAACA,GAAUC,CAAa,IAAIC,EAAwC,cAAc;"}
1
+ {"version":3,"file":"useTaxes.js","sources":["../../../../src/components/Employee/Taxes/useTaxes.ts"],"sourcesContent":["import type { EmployeeStateTaxesList } from '@gusto/embedded-api/models/components/employeestatetaxeslist'\nimport { createCompoundContext } from '@/components/Base'\n\ntype TaxesContextType = {\n employeeStateTaxes: EmployeeStateTaxesList[]\n isPending: boolean\n isAdmin: boolean\n}\n\nconst [useTaxes, TaxesProvider] = createCompoundContext<TaxesContextType>('TaxesContext')\nexport { useTaxes, TaxesProvider }\n"],"names":["useTaxes","TaxesProvider","createCompoundContext"],"mappings":";;;;;;;;;;;;;AASA,MAAM,CAACA,GAAUC,CAAa,IAAIC,EAAwC,cAAc;"}
@@ -4,31 +4,32 @@ import { useTranslation as C } from "react-i18next";
4
4
  import { FlowBreadcrumbs as v } from "../Common/FlowBreadcrumbs/FlowBreadcrumbs.js";
5
5
  import { Flex as l, FlexItem as u } from "../Common/Flex/Flex.js";
6
6
  import "classnames";
7
- import { FlowContext as w } from "./useFlow.js";
8
- import { useComponentContext as F } from "../../contexts/ComponentAdapter/useComponentContext.js";
9
- const G = ({ onEvent: d, machine: x }) => {
10
- const f = F(), { t: b } = C(), [r, g, a] = B(x, {
11
- onEvent: m,
7
+ import { useComponentContext as w } from "../../contexts/ComponentAdapter/useComponentContext.js";
8
+ import "react";
9
+ import { FlowContext as F } from "./useFlow.js";
10
+ const L = ({ onEvent: d, machine: x }) => {
11
+ const f = w(), { t: b } = C(), [r, g, i] = B(x, {
12
+ onEvent: a,
12
13
  component: null,
13
14
  progressBarCta: null
14
15
  }), {
15
- progressBarType: i = null,
16
+ progressBarType: m = null,
16
17
  totalSteps: o = null,
17
18
  currentStep: t = null,
18
19
  currentBreadcrumbId: n,
19
20
  breadcrumbs: h = {}
20
21
  } = r.context;
21
- function m(s, c) {
22
- a.child ? a.child.send({ type: s, payload: c }) : g({ type: s, payload: c }), d(s, c);
22
+ function a(s, c) {
23
+ i.child ? i.child.send({ type: s, payload: c }) : g({ type: s, payload: c }), d(s, c);
23
24
  }
24
25
  return /* @__PURE__ */ e(l, { children: /* @__PURE__ */ e(
25
- w.Provider,
26
+ F.Provider,
26
27
  {
27
28
  value: {
28
29
  ...r.context
29
30
  },
30
31
  children: /* @__PURE__ */ p(l, { flexDirection: "column", gap: 32, children: [
31
- i === "progress" && t && o && /* @__PURE__ */ e(
32
+ m === "progress" && t && o && /* @__PURE__ */ e(
32
33
  f.ProgressBar,
33
34
  {
34
35
  totalSteps: o,
@@ -37,13 +38,13 @@ const G = ({ onEvent: d, machine: x }) => {
37
38
  cta: r.context.progressBarCta
38
39
  }
39
40
  ),
40
- i === "breadcrumbs" && /* @__PURE__ */ p(l, { flexDirection: "row", justifyContent: "space-between", alignItems: "center", children: [
41
+ m === "breadcrumbs" && /* @__PURE__ */ p(l, { flexDirection: "row", justifyContent: "space-between", alignItems: "center", children: [
41
42
  /* @__PURE__ */ e(u, { flexGrow: 1, children: /* @__PURE__ */ e(
42
43
  v,
43
44
  {
44
45
  breadcrumbs: n ? h[n] ?? [] : [],
45
46
  currentBreadcrumbId: n,
46
- onEvent: m
47
+ onEvent: a
47
48
  }
48
49
  ) }),
49
50
  /* @__PURE__ */ e(u, { children: r.context.progressBarCta && /* @__PURE__ */ e(r.context.progressBarCta, {}) })
@@ -54,6 +55,6 @@ const G = ({ onEvent: d, machine: x }) => {
54
55
  ) });
55
56
  };
56
57
  export {
57
- G as Flow
58
+ L as Flow
58
59
  };
59
60
  //# sourceMappingURL=Flow.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Flow.js","sources":["../../../src/components/Flow/Flow.tsx"],"sourcesContent":["import { useMachine } from 'react-robot'\nimport { type Machine } from 'robot3'\nimport { useTranslation } from 'react-i18next'\nimport type { OnEventType } from '../Base/useBase'\nimport { FlowBreadcrumbs } from '../Common/FlowBreadcrumbs/FlowBreadcrumbs'\nimport { Flex } from '../Common/Flex'\nimport { FlexItem } from '../Common'\nimport type { FlowContextInterface } from './useFlow'\nimport { FlowContext } from './useFlow'\nimport { type EventType } from '@/shared/constants'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\n\ntype FlowProps = {\n machine: Machine<object, FlowContextInterface>\n onEvent: OnEventType<EventType, unknown>\n}\n\nexport const Flow = ({ onEvent, machine }: FlowProps) => {\n const Components = useComponentContext()\n const { t } = useTranslation()\n const [current, send, service] = useMachine(machine, {\n onEvent: handleEvent,\n component: null,\n progressBarCta: null,\n })\n\n const {\n progressBarType = null,\n totalSteps = null,\n currentStep = null,\n currentBreadcrumbId,\n breadcrumbs = {},\n } = current.context\n\n function handleEvent(type: EventType, data: unknown): void {\n //When dealing with nested state machine, correct machine needs to recieve an event\n if (service.child) {\n //@ts-expect-error: not sure why 'type' type is incorrectly derived here\n service.child.send({ type: type, payload: data })\n } else {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-call\n send({ type: type, payload: data })\n }\n // Pass event upstream - onEvent can be optional on Flow component\n onEvent(type, data)\n }\n\n return (\n <Flex>\n <FlowContext.Provider\n value={{\n ...current.context,\n }}\n >\n <Flex flexDirection=\"column\" gap={32}>\n {progressBarType === 'progress' && currentStep && totalSteps && (\n <Components.ProgressBar\n totalSteps={totalSteps}\n currentStep={currentStep}\n label={t('progressBarLabel', { totalSteps, currentStep })}\n cta={current.context.progressBarCta}\n />\n )}\n {progressBarType === 'breadcrumbs' && (\n <Flex flexDirection=\"row\" justifyContent=\"space-between\" alignItems=\"center\">\n <FlexItem flexGrow={1}>\n <FlowBreadcrumbs\n breadcrumbs={currentBreadcrumbId ? (breadcrumbs[currentBreadcrumbId] ?? []) : []}\n currentBreadcrumbId={currentBreadcrumbId}\n onEvent={handleEvent}\n />\n </FlexItem>\n <FlexItem>\n {current.context.progressBarCta && <current.context.progressBarCta />}\n </FlexItem>\n </Flex>\n )}\n {current.context.component && <current.context.component />}\n </Flex>\n </FlowContext.Provider>\n </Flex>\n )\n}\n"],"names":["Flow","onEvent","machine","Components","useComponentContext","t","useTranslation","current","send","service","useMachine","handleEvent","progressBarType","totalSteps","currentStep","currentBreadcrumbId","breadcrumbs","type","data","Flex","jsx","FlowContext","jsxs","FlexItem","FlowBreadcrumbs"],"mappings":";;;;;;;;AAiBO,MAAMA,IAAO,CAAC,EAAE,SAAAC,GAAS,SAAAC,QAAyB;AACvD,QAAMC,IAAaC,EAAA,GACb,EAAE,GAAAC,EAAA,IAAMC,EAAA,GACR,CAACC,GAASC,GAAMC,CAAO,IAAIC,EAAWR,GAAS;AAAA,IACnD,SAASS;AAAA,IACT,WAAW;AAAA,IACX,gBAAgB;AAAA,EAAA,CACjB,GAEK;AAAA,IACJ,iBAAAC,IAAkB;AAAA,IAClB,YAAAC,IAAa;AAAA,IACb,aAAAC,IAAc;AAAA,IACd,qBAAAC;AAAA,IACA,aAAAC,IAAc,CAAA;AAAA,EAAC,IACbT,EAAQ;AAEZ,WAASI,EAAYM,GAAiBC,GAAqB;AAEzD,IAAIT,EAAQ,QAEVA,EAAQ,MAAM,KAAK,EAAE,MAAAQ,GAAY,SAASC,GAAM,IAGhDV,EAAK,EAAE,MAAAS,GAAY,SAASC,EAAA,CAAM,GAGpCjB,EAAQgB,GAAMC,CAAI;AAAA,EACpB;AAEA,2BACGC,GAAA,EACC,UAAA,gBAAAC;AAAA,IAACC,EAAY;AAAA,IAAZ;AAAA,MACC,OAAO;AAAA,QACL,GAAGd,EAAQ;AAAA,MAAA;AAAA,MAGb,UAAA,gBAAAe,EAACH,GAAA,EAAK,eAAc,UAAS,KAAK,IAC/B,UAAA;AAAA,QAAAP,MAAoB,cAAcE,KAAeD,KAChD,gBAAAO;AAAA,UAACjB,EAAW;AAAA,UAAX;AAAA,YACC,YAAAU;AAAA,YACA,aAAAC;AAAA,YACA,OAAOT,EAAE,oBAAoB,EAAE,YAAAQ,GAAY,aAAAC,GAAa;AAAA,YACxD,KAAKP,EAAQ,QAAQ;AAAA,UAAA;AAAA,QAAA;AAAA,QAGxBK,MAAoB,iBACnB,gBAAAU,EAACH,GAAA,EAAK,eAAc,OAAM,gBAAe,iBAAgB,YAAW,UAClE,UAAA;AAAA,UAAA,gBAAAC,EAACG,GAAA,EAAS,UAAU,GAClB,UAAA,gBAAAH;AAAA,YAACI;AAAA,YAAA;AAAA,cACC,aAAaT,IAAuBC,EAAYD,CAAmB,KAAK,CAAA,IAAM,CAAA;AAAA,cAC9E,qBAAAA;AAAA,cACA,SAASJ;AAAA,YAAA;AAAA,UAAA,GAEb;AAAA,UACA,gBAAAS,EAACG,GAAA,EACE,UAAAhB,EAAQ,QAAQ,oCAAmBA,EAAQ,QAAQ,gBAAhB,CAAA,CAA+B,EAAA,CACrE;AAAA,QAAA,GACF;AAAA,QAEDA,EAAQ,QAAQ,+BAAcA,EAAQ,QAAQ,WAAhB,CAAA,CAA0B;AAAA,MAAA,EAAA,CAC3D;AAAA,IAAA;AAAA,EAAA,GAEJ;AAEJ;"}
1
+ {"version":3,"file":"Flow.js","sources":["../../../src/components/Flow/Flow.tsx"],"sourcesContent":["import { useMachine } from 'react-robot'\nimport { type Machine } from 'robot3'\nimport { useTranslation } from 'react-i18next'\nimport type { OnEventType } from '../Base/useBase'\nimport { FlowBreadcrumbs } from '../Common/FlowBreadcrumbs/FlowBreadcrumbs'\nimport { Flex } from '../Common/Flex'\nimport { FlexItem } from '../Common'\nimport type { FlowContextInterface } from './useFlow'\nimport { FlowContext } from './useFlow'\nimport { type EventType } from '@/shared/constants'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\n\ntype FlowProps = {\n machine: Machine<object, FlowContextInterface>\n onEvent: OnEventType<EventType, unknown>\n}\n\nexport const Flow = ({ onEvent, machine }: FlowProps) => {\n const Components = useComponentContext()\n const { t } = useTranslation()\n const [current, send, service] = useMachine(machine, {\n onEvent: handleEvent,\n component: null,\n progressBarCta: null,\n })\n\n const {\n progressBarType = null,\n totalSteps = null,\n currentStep = null,\n currentBreadcrumbId,\n breadcrumbs = {},\n } = current.context\n\n function handleEvent(type: EventType, data: unknown): void {\n //When dealing with nested state machine, correct machine needs to recieve an event\n if (service.child) {\n //@ts-expect-error: not sure why 'type' type is incorrectly derived here\n service.child.send({ type: type, payload: data })\n } else {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-call\n send({ type: type, payload: data })\n }\n // Pass event upstream - onEvent can be optional on Flow component\n onEvent(type, data)\n }\n\n return (\n <Flex>\n <FlowContext.Provider\n value={{\n ...current.context,\n }}\n >\n <Flex flexDirection=\"column\" gap={32}>\n {progressBarType === 'progress' && currentStep && totalSteps && (\n <Components.ProgressBar\n totalSteps={totalSteps}\n currentStep={currentStep}\n label={t('progressBarLabel', { totalSteps, currentStep })}\n cta={current.context.progressBarCta}\n />\n )}\n {progressBarType === 'breadcrumbs' && (\n <Flex flexDirection=\"row\" justifyContent=\"space-between\" alignItems=\"center\">\n <FlexItem flexGrow={1}>\n <FlowBreadcrumbs\n breadcrumbs={currentBreadcrumbId ? (breadcrumbs[currentBreadcrumbId] ?? []) : []}\n currentBreadcrumbId={currentBreadcrumbId}\n onEvent={handleEvent}\n />\n </FlexItem>\n <FlexItem>\n {current.context.progressBarCta && <current.context.progressBarCta />}\n </FlexItem>\n </Flex>\n )}\n {current.context.component && <current.context.component />}\n </Flex>\n </FlowContext.Provider>\n </Flex>\n )\n}\n"],"names":["Flow","onEvent","machine","Components","useComponentContext","t","useTranslation","current","send","service","useMachine","handleEvent","progressBarType","totalSteps","currentStep","currentBreadcrumbId","breadcrumbs","type","data","Flex","jsx","FlowContext","jsxs","FlexItem","FlowBreadcrumbs"],"mappings":";;;;;;;;;AAiBO,MAAMA,IAAO,CAAC,EAAE,SAAAC,GAAS,SAAAC,QAAyB;AACvD,QAAMC,IAAaC,EAAA,GACb,EAAE,GAAAC,EAAA,IAAMC,EAAA,GACR,CAACC,GAASC,GAAMC,CAAO,IAAIC,EAAWR,GAAS;AAAA,IACnD,SAASS;AAAA,IACT,WAAW;AAAA,IACX,gBAAgB;AAAA,EAAA,CACjB,GAEK;AAAA,IACJ,iBAAAC,IAAkB;AAAA,IAClB,YAAAC,IAAa;AAAA,IACb,aAAAC,IAAc;AAAA,IACd,qBAAAC;AAAA,IACA,aAAAC,IAAc,CAAA;AAAA,EAAC,IACbT,EAAQ;AAEZ,WAASI,EAAYM,GAAiBC,GAAqB;AAEzD,IAAIT,EAAQ,QAEVA,EAAQ,MAAM,KAAK,EAAE,MAAAQ,GAAY,SAASC,GAAM,IAGhDV,EAAK,EAAE,MAAAS,GAAY,SAASC,EAAA,CAAM,GAGpCjB,EAAQgB,GAAMC,CAAI;AAAA,EACpB;AAEA,2BACGC,GAAA,EACC,UAAA,gBAAAC;AAAA,IAACC,EAAY;AAAA,IAAZ;AAAA,MACC,OAAO;AAAA,QACL,GAAGd,EAAQ;AAAA,MAAA;AAAA,MAGb,UAAA,gBAAAe,EAACH,GAAA,EAAK,eAAc,UAAS,KAAK,IAC/B,UAAA;AAAA,QAAAP,MAAoB,cAAcE,KAAeD,KAChD,gBAAAO;AAAA,UAACjB,EAAW;AAAA,UAAX;AAAA,YACC,YAAAU;AAAA,YACA,aAAAC;AAAA,YACA,OAAOT,EAAE,oBAAoB,EAAE,YAAAQ,GAAY,aAAAC,GAAa;AAAA,YACxD,KAAKP,EAAQ,QAAQ;AAAA,UAAA;AAAA,QAAA;AAAA,QAGxBK,MAAoB,iBACnB,gBAAAU,EAACH,GAAA,EAAK,eAAc,OAAM,gBAAe,iBAAgB,YAAW,UAClE,UAAA;AAAA,UAAA,gBAAAC,EAACG,GAAA,EAAS,UAAU,GAClB,UAAA,gBAAAH;AAAA,YAACI;AAAA,YAAA;AAAA,cACC,aAAaT,IAAuBC,EAAYD,CAAmB,KAAK,CAAA,IAAM,CAAA;AAAA,cAC9E,qBAAAA;AAAA,cACA,SAASJ;AAAA,YAAA;AAAA,UAAA,GAEb;AAAA,UACA,gBAAAS,EAACG,GAAA,EACE,UAAAhB,EAAQ,QAAQ,oCAAmBA,EAAQ,QAAQ,gBAAhB,CAAA,CAA+B,EAAA,CACrE;AAAA,QAAA,GACF;AAAA,QAEDA,EAAQ,QAAQ,+BAAcA,EAAQ,QAAQ,WAAhB,CAAA,CAA0B;AAAA,MAAA,EAAA,CAC3D;AAAA,IAAA;AAAA,EAAA,GAEJ;AAEJ;"}
@@ -3,4 +3,4 @@ export interface ConfirmWireDetailsProps extends BaseComponentInterface {
3
3
  companyId: string;
4
4
  wireInId?: string;
5
5
  }
6
- export declare function ConfirmWireDetails({ companyId, wireInId, onEvent }: ConfirmWireDetailsProps): import("react/jsx-runtime").JSX.Element;
6
+ export declare function ConfirmWireDetails(props: ConfirmWireDetailsProps): import("react/jsx-runtime").JSX.Element;
@@ -1,57 +1,86 @@
1
- import { jsxs as u, jsx as s } from "react/jsx-runtime";
2
- import { createMachine as L } from "robot3";
3
- import { useMachine as O } from "react-robot";
4
- import { useState as W, useMemo as A } from "react";
5
- import { confirmWireDetailsMachine as M } from "./confirmWireDetailsStateMachine.js";
6
- import { useComponentContext as T } from "../../../contexts/ComponentAdapter/useComponentContext.js";
7
- import { FlowContext as h } from "../../Flow/useFlow.js";
8
- import { payrollWireEvents as e } from "../../../shared/constants.js";
9
- import { ConfirmWireDetailsBanner as S } from "./ConfirmWireDetailsBanner/ConfirmWireDetailsBanner.js";
10
- function j({ companyId: n, wireInId: r, onEvent: a }) {
11
- const { Modal: f } = T(), [R, t] = W(!1), _ = A(
12
- () => L(
1
+ import { jsx as e, jsxs as M } from "react/jsx-runtime";
2
+ import { createMachine as S } from "robot3";
3
+ import { useMachine as T } from "react-robot";
4
+ import { useState as v, useRef as x, useMemo as d } from "react";
5
+ import { useWireInRequestsListSuspense as N } from "@gusto/embedded-api/react-query/wireInRequestsList";
6
+ import { confirmWireDetailsMachine as F } from "./confirmWireDetailsStateMachine.js";
7
+ import D from "./ConfirmWireDetails.module.scss.js";
8
+ import { BaseComponent as P, BaseBoundaries as Y } from "../../Base/Base.js";
9
+ import "../../Base/useBase.js";
10
+ import { useComponentContext as q } from "../../../contexts/ComponentAdapter/useComponentContext.js";
11
+ import { FlowContext as B } from "../../Flow/useFlow.js";
12
+ import { payrollWireEvents as r } from "../../../shared/constants.js";
13
+ import { ConfirmWireDetailsBanner as g } from "./ConfirmWireDetailsBanner/ConfirmWireDetailsBanner.js";
14
+ function $(n) {
15
+ return /* @__PURE__ */ e(P, { ...n, children: /* @__PURE__ */ e(j, { ...n }) });
16
+ }
17
+ function j({ companyId: n, wireInId: t, onEvent: c }) {
18
+ const { Modal: p, LoadingSpinner: C } = q(), [L, s] = v(!1), l = x(null), { data: _ } = N({
19
+ companyUuid: n
20
+ }), f = (_.wireInRequestList || []).filter(
21
+ (o) => o.status === "awaiting_funds"
22
+ ), W = d(() => t || f[0]?.uuid, [t, f[0]?.uuid]), E = d(
23
+ () => S(
13
24
  "banner",
14
- M,
25
+ F,
15
26
  () => ({
16
27
  component: null,
17
28
  companyId: n,
18
- wireInId: r,
19
- onEvent: i
29
+ wireInId: t,
30
+ selectedWireInId: W,
31
+ onEvent: i,
32
+ modalContainerRef: l
20
33
  })
21
34
  ),
22
- [n, r]
23
- ), [l, C] = O(_);
24
- function i(o, c) {
25
- C({ type: o, payload: c }), o === e.PAYROLL_WIRE_START_TRANSFER && t(!0), (o === e.PAYROLL_WIRE_INSTRUCTIONS_CANCEL || o === e.PAYROLL_WIRE_FORM_CANCEL || o === e.PAYROLL_WIRE_FORM_DONE) && t(!1), a(o, c);
35
+ [n, t]
36
+ ), [a, A] = T(E);
37
+ function i(o, R) {
38
+ A({ type: o, payload: R }), o === r.PAYROLL_WIRE_START_TRANSFER && s(!0), (o === r.PAYROLL_WIRE_INSTRUCTIONS_CANCEL || o === r.PAYROLL_WIRE_FORM_CANCEL || o === r.PAYROLL_WIRE_FORM_DONE) && s(!1), c(o, R);
26
39
  }
27
- const E = () => {
28
- i(e.PAYROLL_WIRE_START_TRANSFER);
29
- }, p = () => {
30
- t(!1);
31
- }, m = l.context.component;
32
- return /* @__PURE__ */ u(
33
- h.Provider,
40
+ const h = () => {
41
+ i(r.PAYROLL_WIRE_START_TRANSFER);
42
+ }, O = () => {
43
+ s(!1);
44
+ }, m = a.context.component, u = m?.Footer || void 0;
45
+ return /* @__PURE__ */ M(
46
+ B.Provider,
34
47
  {
35
48
  value: {
36
- ...l.context,
49
+ ...a.context,
37
50
  onEvent: i
38
51
  },
39
52
  children: [
40
- /* @__PURE__ */ s(
41
- S,
53
+ /* @__PURE__ */ e(
54
+ g,
42
55
  {
43
56
  companyId: n,
44
- wireInId: r,
45
- onStartWireTransfer: E,
46
- onEvent: a
57
+ wireInId: t,
58
+ onStartWireTransfer: h,
59
+ onEvent: c,
60
+ confirmationAlert: a.context.confirmationAlert
47
61
  }
48
62
  ),
49
- /* @__PURE__ */ s(f, { isOpen: R, onClose: p, children: m && /* @__PURE__ */ s(m, {}) })
63
+ /* @__PURE__ */ e(
64
+ p,
65
+ {
66
+ isOpen: L,
67
+ onClose: O,
68
+ containerRef: l,
69
+ footer: u && /* @__PURE__ */ e(
70
+ Y,
71
+ {
72
+ LoaderComponent: () => /* @__PURE__ */ e("div", { className: D.footer, children: /* @__PURE__ */ e(C, { size: "sm" }) }),
73
+ children: /* @__PURE__ */ e(u, { onEvent: i })
74
+ }
75
+ ),
76
+ children: m && /* @__PURE__ */ e(m, {})
77
+ }
78
+ )
50
79
  ]
51
80
  }
52
81
  );
53
82
  }
54
83
  export {
55
- j as ConfirmWireDetails
84
+ $ as ConfirmWireDetails
56
85
  };
57
86
  //# sourceMappingURL=ConfirmWireDetails.js.map