@gusto/embedded-react-sdk 0.15.0 → 0.16.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 (311) hide show
  1. package/CHANGELOG.md +23 -0
  2. package/dist/components/Base/Base.js +4 -4
  3. package/dist/components/Common/FlowBreadcrumbs/FlowBreadcrumbs.d.ts +2 -0
  4. package/dist/components/Common/FlowBreadcrumbs/FlowBreadcrumbs.js +52 -0
  5. package/dist/components/Common/FlowBreadcrumbs/FlowBreadcrumbs.js.map +1 -0
  6. package/dist/components/Common/FlowBreadcrumbs/FlowBreadcrumbsTypes.d.ts +44 -0
  7. package/dist/components/Common/FlowBreadcrumbs/index.d.ts +3 -0
  8. package/dist/components/Common/SignatureForm/SignatureForm.js +11 -14
  9. package/dist/components/Common/SignatureForm/SignatureForm.js.map +1 -1
  10. package/dist/components/Common/SignatureForm/SignatureFormActions.js +7 -9
  11. package/dist/components/Common/SignatureForm/SignatureFormActions.js.map +1 -1
  12. package/dist/components/Common/SignatureForm/SignatureFormFields.js +12 -15
  13. package/dist/components/Common/SignatureForm/SignatureFormFields.js.map +1 -1
  14. package/dist/components/Common/UI/Breadcrumbs/Breadcrumbs.d.ts +2 -0
  15. package/dist/components/Common/UI/Breadcrumbs/Breadcrumbs.js +38 -0
  16. package/dist/components/Common/UI/Breadcrumbs/Breadcrumbs.js.map +1 -0
  17. package/dist/components/Common/UI/Breadcrumbs/Breadcrumbs.module.scss.js +16 -0
  18. package/dist/components/Common/UI/Breadcrumbs/Breadcrumbs.module.scss.js.map +1 -0
  19. package/dist/components/Common/UI/Breadcrumbs/BreadcrumbsTypes.d.ts +27 -0
  20. package/dist/components/Common/UI/Breadcrumbs/index.d.ts +3 -0
  21. package/dist/components/Common/UI/ProgressBar/ProgressBar.js +4 -4
  22. package/dist/components/Company/AssignSignatory/AssignSignatory.js +6 -8
  23. package/dist/components/Company/AssignSignatory/AssignSignatory.js.map +1 -1
  24. package/dist/components/Company/AssignSignatory/AssignSignatorySelection.js +2 -5
  25. package/dist/components/Company/AssignSignatory/AssignSignatorySelection.js.map +1 -1
  26. package/dist/components/Company/AssignSignatory/CreateSignatory/Actions.js +2 -4
  27. package/dist/components/Company/AssignSignatory/CreateSignatory/Actions.js.map +1 -1
  28. package/dist/components/Company/AssignSignatory/CreateSignatory/CreateSignatory.js +7 -9
  29. package/dist/components/Company/AssignSignatory/CreateSignatory/CreateSignatory.js.map +1 -1
  30. package/dist/components/Company/AssignSignatory/CreateSignatory/CreateSignatoryForm.js +15 -16
  31. package/dist/components/Company/AssignSignatory/CreateSignatory/CreateSignatoryForm.js.map +1 -1
  32. package/dist/components/Company/AssignSignatory/CreateSignatory/useCreateSignatory.js +4 -5
  33. package/dist/components/Company/AssignSignatory/CreateSignatory/useCreateSignatory.js.map +1 -1
  34. package/dist/components/Company/AssignSignatory/InviteSignatory/Actions.js +2 -4
  35. package/dist/components/Company/AssignSignatory/InviteSignatory/Actions.js.map +1 -1
  36. package/dist/components/Company/AssignSignatory/InviteSignatory/InviteSignatory.js +10 -12
  37. package/dist/components/Company/AssignSignatory/InviteSignatory/InviteSignatory.js.map +1 -1
  38. package/dist/components/Company/AssignSignatory/InviteSignatory/InviteSignatoryForm.js +9 -10
  39. package/dist/components/Company/AssignSignatory/InviteSignatory/InviteSignatoryForm.js.map +1 -1
  40. package/dist/components/Company/AssignSignatory/InviteSignatory/useInviteSignatory.js +4 -5
  41. package/dist/components/Company/AssignSignatory/InviteSignatory/useInviteSignatory.js.map +1 -1
  42. package/dist/components/Company/AssignSignatory/TitleSelect.js +3 -5
  43. package/dist/components/Company/AssignSignatory/TitleSelect.js.map +1 -1
  44. package/dist/components/Company/AssignSignatory/useAssignSignatory.js +6 -7
  45. package/dist/components/Company/AssignSignatory/useAssignSignatory.js.map +1 -1
  46. package/dist/components/Company/BankAccount/BankAccountForm/Actions.js +9 -10
  47. package/dist/components/Company/BankAccount/BankAccountForm/Actions.js.map +1 -1
  48. package/dist/components/Company/BankAccount/BankAccountForm/Form.js +8 -11
  49. package/dist/components/Company/BankAccount/BankAccountForm/Form.js.map +1 -1
  50. package/dist/components/Company/BankAccount/BankAccountForm/context.js +4 -5
  51. package/dist/components/Company/BankAccount/BankAccountForm/context.js.map +1 -1
  52. package/dist/components/Company/BankAccount/BankAccountList/Actions.js +8 -10
  53. package/dist/components/Company/BankAccount/BankAccountList/Actions.js.map +1 -1
  54. package/dist/components/Company/BankAccount/BankAccountVerify/Actions.js +8 -10
  55. package/dist/components/Company/BankAccount/BankAccountVerify/Actions.js.map +1 -1
  56. package/dist/components/Company/BankAccount/BankAccountVerify/Form.js +4 -7
  57. package/dist/components/Company/BankAccount/BankAccountVerify/Form.js.map +1 -1
  58. package/dist/components/Company/DocumentSigner/DocumentList/Actions.js +2 -4
  59. package/dist/components/Company/DocumentSigner/DocumentList/Actions.js.map +1 -1
  60. package/dist/components/Company/DocumentSigner/DocumentList/DocumentList.js +9 -11
  61. package/dist/components/Company/DocumentSigner/DocumentList/DocumentList.js.map +1 -1
  62. package/dist/components/Company/DocumentSigner/DocumentList/useDocumentList.js +4 -5
  63. package/dist/components/Company/DocumentSigner/DocumentList/useDocumentList.js.map +1 -1
  64. package/dist/components/Company/DocumentSigner/SignatureForm/SignatureForm.js +8 -10
  65. package/dist/components/Company/DocumentSigner/SignatureForm/SignatureForm.js.map +1 -1
  66. package/dist/components/Company/DocumentSigner/SignatureForm/useSignatureForm.js +4 -5
  67. package/dist/components/Company/DocumentSigner/SignatureForm/useSignatureForm.js.map +1 -1
  68. package/dist/components/Company/FederalTaxes/Actions.js +7 -9
  69. package/dist/components/Company/FederalTaxes/Actions.js.map +1 -1
  70. package/dist/components/Company/FederalTaxes/FederalTaxes.js +3 -5
  71. package/dist/components/Company/FederalTaxes/FederalTaxes.js.map +1 -1
  72. package/dist/components/Company/FederalTaxes/Form.js +6 -7
  73. package/dist/components/Company/FederalTaxes/Form.js.map +1 -1
  74. package/dist/components/Company/FederalTaxes/useFederalTaxes.js +9 -10
  75. package/dist/components/Company/FederalTaxes/useFederalTaxes.js.map +1 -1
  76. package/dist/components/Company/Industry/Actions.js +7 -9
  77. package/dist/components/Company/Industry/Actions.js.map +1 -1
  78. package/dist/components/Company/Industry/Context.js +7 -8
  79. package/dist/components/Company/Industry/Context.js.map +1 -1
  80. package/dist/components/Company/Industry/Edit.js +4 -7
  81. package/dist/components/Company/Industry/Edit.js.map +1 -1
  82. package/dist/components/Company/Locations/LocationForm/Actions.js +8 -10
  83. package/dist/components/Company/Locations/LocationForm/Actions.js.map +1 -1
  84. package/dist/components/Company/Locations/LocationForm/Form.js +5 -7
  85. package/dist/components/Company/Locations/LocationForm/Form.js.map +1 -1
  86. package/dist/components/Company/Locations/LocationForm/LocationForm.js +10 -12
  87. package/dist/components/Company/Locations/LocationForm/LocationForm.js.map +1 -1
  88. package/dist/components/Company/Locations/LocationForm/useLocationForm.js +4 -5
  89. package/dist/components/Company/Locations/LocationForm/useLocationForm.js.map +1 -1
  90. package/dist/components/Company/Locations/LocationsList/Actions.js +6 -8
  91. package/dist/components/Company/Locations/LocationsList/Actions.js.map +1 -1
  92. package/dist/components/Company/Locations/LocationsList/List.js +15 -16
  93. package/dist/components/Company/Locations/LocationsList/List.js.map +1 -1
  94. package/dist/components/Company/Locations/LocationsList/LocationsList.js +3 -4
  95. package/dist/components/Company/Locations/LocationsList/LocationsList.js.map +1 -1
  96. package/dist/components/Company/Locations/LocationsList/useLocationsList.js +4 -5
  97. package/dist/components/Company/Locations/LocationsList/useLocationsList.js.map +1 -1
  98. package/dist/components/Company/OnboardingFlow/OnboardingFlow.js +10 -10
  99. package/dist/components/Company/OnboardingFlow/OnboardingFlow.js.map +1 -1
  100. package/dist/components/Company/OnboardingFlow/onboardingStateMachine.js +16 -10
  101. package/dist/components/Company/OnboardingFlow/onboardingStateMachine.js.map +1 -1
  102. package/dist/components/Company/OnboardingOverview/Completed.js +10 -12
  103. package/dist/components/Company/OnboardingOverview/Completed.js.map +1 -1
  104. package/dist/components/Company/OnboardingOverview/MissingRequirements.js +9 -11
  105. package/dist/components/Company/OnboardingOverview/MissingRequirements.js.map +1 -1
  106. package/dist/components/Company/OnboardingOverview/OnboardingOverview.js +7 -9
  107. package/dist/components/Company/OnboardingOverview/OnboardingOverview.js.map +1 -1
  108. package/dist/components/Company/OnboardingOverview/context.js +4 -5
  109. package/dist/components/Company/OnboardingOverview/context.js.map +1 -1
  110. package/dist/components/Company/PaySchedule/PaySchedule.js +4 -5
  111. package/dist/components/Company/PaySchedule/PaySchedule.js.map +1 -1
  112. package/dist/components/Company/PaySchedule/_parts/Actions.js +9 -11
  113. package/dist/components/Company/PaySchedule/_parts/Actions.js.map +1 -1
  114. package/dist/components/Company/PaySchedule/_parts/Edit.js +17 -17
  115. package/dist/components/Company/PaySchedule/_parts/Edit.js.map +1 -1
  116. package/dist/components/Company/PaySchedule/_parts/Head.js +9 -11
  117. package/dist/components/Company/PaySchedule/_parts/Head.js.map +1 -1
  118. package/dist/components/Company/PaySchedule/_parts/List.js +17 -18
  119. package/dist/components/Company/PaySchedule/_parts/List.js.map +1 -1
  120. package/dist/components/Company/PaySchedule/usePaySchedule.js +6 -7
  121. package/dist/components/Company/PaySchedule/usePaySchedule.js.map +1 -1
  122. package/dist/components/Company/StateTaxes/StateTaxesForm/Actions.js +2 -4
  123. package/dist/components/Company/StateTaxes/StateTaxesForm/Actions.js.map +1 -1
  124. package/dist/components/Company/StateTaxes/StateTaxesForm/context.js +4 -5
  125. package/dist/components/Company/StateTaxes/StateTaxesForm/context.js.map +1 -1
  126. package/dist/components/Company/StateTaxes/StateTaxesList/Actions.js +2 -4
  127. package/dist/components/Company/StateTaxes/StateTaxesList/Actions.js.map +1 -1
  128. package/dist/components/Company/StateTaxes/StateTaxesList/List.js +2 -4
  129. package/dist/components/Company/StateTaxes/StateTaxesList/List.js.map +1 -1
  130. package/dist/components/Company/StateTaxes/StateTaxesList/context.js +4 -5
  131. package/dist/components/Company/StateTaxes/StateTaxesList/context.js.map +1 -1
  132. package/dist/components/Contractor/Address/Address.js +5 -7
  133. package/dist/components/Contractor/Address/Address.js.map +1 -1
  134. package/dist/components/Contractor/Address/Form.js +7 -9
  135. package/dist/components/Contractor/Address/Form.js.map +1 -1
  136. package/dist/components/Contractor/Address/useAddress.js +6 -7
  137. package/dist/components/Contractor/Address/useAddress.js.map +1 -1
  138. package/dist/components/Contractor/ContractorList/index.js +15 -15
  139. package/dist/components/Contractor/OnboardingFlow/onboardingStateMachine.js +37 -37
  140. package/dist/components/Contractor/OnboardingFlow/onboardingStateMachine.js.map +1 -1
  141. package/dist/components/Contractor/PaymentMethod/BankAccountForm.js +10 -13
  142. package/dist/components/Contractor/PaymentMethod/BankAccountForm.js.map +1 -1
  143. package/dist/components/Contractor/PaymentMethod/PaymentTypeForm.js +2 -4
  144. package/dist/components/Contractor/PaymentMethod/PaymentTypeForm.js.map +1 -1
  145. package/dist/components/Contractor/Profile/ContractorProfileForm.js +15 -15
  146. package/dist/components/Contractor/Profile/useContractorProfile.js +3 -4
  147. package/dist/components/Contractor/Profile/useContractorProfile.js.map +1 -1
  148. package/dist/components/Contractor/Submit/Submit.js +20 -21
  149. package/dist/components/Contractor/Submit/Submit.js.map +1 -1
  150. package/dist/components/Employee/Compensation/Actions.js +12 -13
  151. package/dist/components/Employee/Compensation/Actions.js.map +1 -1
  152. package/dist/components/Employee/Compensation/Edit.js +14 -14
  153. package/dist/components/Employee/Compensation/List.js +22 -23
  154. package/dist/components/Employee/Compensation/List.js.map +1 -1
  155. package/dist/components/Employee/Deductions/DeductionsForm/ChildSupportForm.js +10 -11
  156. package/dist/components/Employee/Deductions/DeductionsForm/ChildSupportForm.js.map +1 -1
  157. package/dist/components/Employee/Deductions/DeductionsForm/CustomDeductionForm.js +32 -33
  158. package/dist/components/Employee/Deductions/DeductionsForm/CustomDeductionForm.js.map +1 -1
  159. package/dist/components/Employee/Deductions/DeductionsForm/DeductionsForm.js +8 -8
  160. package/dist/components/Employee/Deductions/DeductionsList/DeductionsList.js +11 -11
  161. package/dist/components/Employee/Deductions/IncludeDeductionsForm/IncludeDeductionsForm.js +22 -23
  162. package/dist/components/Employee/Deductions/IncludeDeductionsForm/IncludeDeductionsForm.js.map +1 -1
  163. package/dist/components/Employee/DocumentSigner/DocumentList/Actions.js +6 -8
  164. package/dist/components/Employee/DocumentSigner/DocumentList/Actions.js.map +1 -1
  165. package/dist/components/Employee/DocumentSigner/DocumentList/DocumentList.js +3 -5
  166. package/dist/components/Employee/DocumentSigner/DocumentList/DocumentList.js.map +1 -1
  167. package/dist/components/Employee/DocumentSigner/DocumentList/List.js +2 -5
  168. package/dist/components/Employee/DocumentSigner/DocumentList/List.js.map +1 -1
  169. package/dist/components/Employee/DocumentSigner/DocumentList/useDocumentList.js +4 -5
  170. package/dist/components/Employee/DocumentSigner/DocumentList/useDocumentList.js.map +1 -1
  171. package/dist/components/Employee/DocumentSigner/SignatureForm/SignatureForm.js +3 -5
  172. package/dist/components/Employee/DocumentSigner/SignatureForm/SignatureForm.js.map +1 -1
  173. package/dist/components/Employee/DocumentSigner/SignatureForm/useSignatureForm.js +4 -5
  174. package/dist/components/Employee/DocumentSigner/SignatureForm/useSignatureForm.js.map +1 -1
  175. package/dist/components/Employee/EmployeeList/Actions.js +6 -8
  176. package/dist/components/Employee/EmployeeList/Actions.js.map +1 -1
  177. package/dist/components/Employee/EmployeeList/EmployeeList.js +3 -6
  178. package/dist/components/Employee/EmployeeList/EmployeeList.js.map +1 -1
  179. package/dist/components/Employee/EmployeeList/Head.js +5 -7
  180. package/dist/components/Employee/EmployeeList/Head.js.map +1 -1
  181. package/dist/components/Employee/EmployeeList/List.js +14 -14
  182. package/dist/components/Employee/EmployeeList/useEmployeeList.js +4 -5
  183. package/dist/components/Employee/EmployeeList/useEmployeeList.js.map +1 -1
  184. package/dist/components/Employee/FederalTaxes/Actions.js +7 -9
  185. package/dist/components/Employee/FederalTaxes/Actions.js.map +1 -1
  186. package/dist/components/Employee/FederalTaxes/FederalForm.js +11 -13
  187. package/dist/components/Employee/FederalTaxes/FederalForm.js.map +1 -1
  188. package/dist/components/Employee/FederalTaxes/useFederalTaxes.js +4 -5
  189. package/dist/components/Employee/FederalTaxes/useFederalTaxes.js.map +1 -1
  190. package/dist/components/Employee/Landing/Landing.js +10 -11
  191. package/dist/components/Employee/Landing/Landing.js.map +1 -1
  192. package/dist/components/Employee/OnboardingSummary/OnboardingSummary.js +7 -7
  193. package/dist/components/Employee/PaymentMethod/Actions.js +6 -8
  194. package/dist/components/Employee/PaymentMethod/Actions.js.map +1 -1
  195. package/dist/components/Employee/PaymentMethod/BankAccountEdit.js +3 -5
  196. package/dist/components/Employee/PaymentMethod/BankAccountEdit.js.map +1 -1
  197. package/dist/components/Employee/PaymentMethod/BankAccountsList.js +11 -12
  198. package/dist/components/Employee/PaymentMethod/BankAccountsList.js.map +1 -1
  199. package/dist/components/Employee/PaymentMethod/PaymentTypeForm.js +2 -4
  200. package/dist/components/Employee/PaymentMethod/PaymentTypeForm.js.map +1 -1
  201. package/dist/components/Employee/PaymentMethod/Split.js +7 -7
  202. package/dist/components/Employee/PaymentMethod/usePaymentMethod.js +6 -7
  203. package/dist/components/Employee/PaymentMethod/usePaymentMethod.js.map +1 -1
  204. package/dist/components/Employee/Profile/Actions.js +7 -9
  205. package/dist/components/Employee/Profile/Actions.js.map +1 -1
  206. package/dist/components/Employee/Profile/AdminPersonalDetails.js +6 -7
  207. package/dist/components/Employee/Profile/AdminPersonalDetails.js.map +1 -1
  208. package/dist/components/Employee/Profile/HomeAddress.js +5 -6
  209. package/dist/components/Employee/Profile/HomeAddress.js.map +1 -1
  210. package/dist/components/Employee/Profile/PersonalDetailsInputs.js +23 -25
  211. package/dist/components/Employee/Profile/PersonalDetailsInputs.js.map +1 -1
  212. package/dist/components/Employee/Profile/useProfile.js +4 -5
  213. package/dist/components/Employee/Profile/useProfile.js.map +1 -1
  214. package/dist/components/Employee/StateTaxes/Actions.js +8 -10
  215. package/dist/components/Employee/StateTaxes/Actions.js.map +1 -1
  216. package/dist/components/Employee/StateTaxes/useStateTaxes.js +4 -5
  217. package/dist/components/Employee/StateTaxes/useStateTaxes.js.map +1 -1
  218. package/dist/components/Employee/Taxes/Actions.js +8 -10
  219. package/dist/components/Employee/Taxes/Actions.js.map +1 -1
  220. package/dist/components/Employee/Taxes/FederalForm.js +12 -14
  221. package/dist/components/Employee/Taxes/FederalForm.js.map +1 -1
  222. package/dist/components/Employee/Taxes/useTaxes.js +4 -5
  223. package/dist/components/Employee/Taxes/useTaxes.js.map +1 -1
  224. package/dist/components/Flow/Flow.js +44 -24
  225. package/dist/components/Flow/Flow.js.map +1 -1
  226. package/dist/components/Flow/useFlow.d.ts +10 -1
  227. package/dist/components/Flow/useFlow.js.map +1 -1
  228. package/dist/components/Payroll/PayrollBlocker/PayrollBlocker.d.ts +1 -1
  229. package/dist/components/Payroll/PayrollBlocker/PayrollBlocker.js +16 -16
  230. package/dist/components/Payroll/PayrollBlocker/PayrollBlocker.js.map +1 -1
  231. package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerAlerts.js +20 -22
  232. package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerAlerts.js.map +1 -1
  233. package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerList.js +17 -19
  234. package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerList.js.map +1 -1
  235. package/dist/components/Payroll/PayrollConfiguration/PayrollConfiguration.js +38 -34
  236. package/dist/components/Payroll/PayrollConfiguration/PayrollConfiguration.js.map +1 -1
  237. package/dist/components/Payroll/PayrollConfiguration/PayrollConfigurationPresentation.js +14 -14
  238. package/dist/components/Payroll/PayrollConfiguration/PayrollConfigurationPresentation.js.map +1 -1
  239. package/dist/components/Payroll/PayrollEditEmployee/PayrollEditEmployee.js +39 -40
  240. package/dist/components/Payroll/PayrollEditEmployee/PayrollEditEmployee.js.map +1 -1
  241. package/dist/components/Payroll/PayrollEditEmployee/PayrollEditEmployeePresentation.js +27 -27
  242. package/dist/components/Payroll/PayrollEditEmployee/TimeOffField.js +8 -9
  243. package/dist/components/Payroll/PayrollEditEmployee/TimeOffField.js.map +1 -1
  244. package/dist/components/Payroll/PayrollFlow/PayrollFlow.d.ts +1 -1
  245. package/dist/components/Payroll/PayrollFlow/PayrollFlow.js +20 -19
  246. package/dist/components/Payroll/PayrollFlow/PayrollFlow.js.map +1 -1
  247. package/dist/components/Payroll/PayrollFlow/PayrollFlowComponents.d.ts +5 -3
  248. package/dist/components/Payroll/PayrollFlow/PayrollFlowComponents.js +65 -45
  249. package/dist/components/Payroll/PayrollFlow/PayrollFlowComponents.js.map +1 -1
  250. package/dist/components/Payroll/PayrollFlow/index.d.ts +1 -1
  251. package/dist/components/Payroll/PayrollFlow/payrollStateMachine.d.ts +2 -0
  252. package/dist/components/Payroll/PayrollFlow/payrollStateMachine.js +233 -96
  253. package/dist/components/Payroll/PayrollFlow/payrollStateMachine.js.map +1 -1
  254. package/dist/components/Payroll/PayrollHistory/PayrollHistoryPresentation.js +12 -13
  255. package/dist/components/Payroll/PayrollHistory/PayrollHistoryPresentation.js.map +1 -1
  256. package/dist/components/Payroll/PayrollLanding/PayrollLandingFlowComponents.js +8 -9
  257. package/dist/components/Payroll/PayrollLanding/PayrollLandingFlowComponents.js.map +1 -1
  258. package/dist/components/Payroll/PayrollList/PayrollListPresentation.js +14 -15
  259. package/dist/components/Payroll/PayrollList/PayrollListPresentation.js.map +1 -1
  260. package/dist/components/Payroll/PayrollOverview/PayrollOverview.d.ts +1 -2
  261. package/dist/components/Payroll/PayrollOverview/PayrollOverview.js +41 -45
  262. package/dist/components/Payroll/PayrollOverview/PayrollOverview.js.map +1 -1
  263. package/dist/components/Payroll/PayrollOverview/PayrollOverviewPresentation.d.ts +1 -2
  264. package/dist/components/Payroll/PayrollOverview/PayrollOverviewPresentation.js +94 -96
  265. package/dist/components/Payroll/PayrollOverview/PayrollOverviewPresentation.js.map +1 -1
  266. package/dist/components/Payroll/PayrollReceipts/PayrollReceipts.d.ts +1 -2
  267. package/dist/components/Payroll/PayrollReceipts/PayrollReceipts.js +12 -26
  268. package/dist/components/Payroll/PayrollReceipts/PayrollReceipts.js.map +1 -1
  269. package/dist/components/Payroll/PayrollReceipts/PayrollReceiptsPresentation.d.ts +1 -2
  270. package/dist/components/Payroll/PayrollReceipts/PayrollReceiptsPresentation.js +40 -45
  271. package/dist/components/Payroll/PayrollReceipts/PayrollReceiptsPresentation.js.map +1 -1
  272. package/dist/components/Payroll/usePreparedPayrollData.js +3 -4
  273. package/dist/components/Payroll/usePreparedPayrollData.js.map +1 -1
  274. package/dist/contexts/ComponentAdapter/adapters/defaultComponentAdapter.js +41 -39
  275. package/dist/contexts/ComponentAdapter/adapters/defaultComponentAdapter.js.map +1 -1
  276. package/dist/contexts/ComponentAdapter/componentAdapterTypes.d.ts +1 -0
  277. package/dist/contexts/ComponentAdapter/useComponentContext.d.ts +2 -0
  278. package/dist/contexts/ComponentAdapter/useComponentContext.js.map +1 -1
  279. package/dist/contexts/GustoProvider/GustoProviderCustomUIAdapter.js +2 -4
  280. package/dist/contexts/GustoProvider/GustoProviderCustomUIAdapter.js.map +1 -1
  281. package/dist/helpers/breadcrumbHelpers.d.ts +33 -0
  282. package/dist/helpers/breadcrumbHelpers.js +46 -0
  283. package/dist/helpers/breadcrumbHelpers.js.map +1 -0
  284. package/dist/helpers/breadcrumbHelpers.test.d.ts +1 -0
  285. package/dist/i18n/I18n.d.ts +1 -1
  286. package/dist/i18n/I18n.js +32 -23
  287. package/dist/i18n/I18n.js.map +1 -1
  288. package/dist/i18n/en/Company.PaySchedule.json.js +2 -2
  289. package/dist/i18n/en/Payroll.PayrollBlocker.json.js +28 -0
  290. package/dist/i18n/en/Payroll.PayrollBlocker.json.js.map +1 -0
  291. package/dist/i18n/en/Payroll.PayrollConfiguration.json.js +28 -24
  292. package/dist/i18n/en/Payroll.PayrollConfiguration.json.js.map +1 -1
  293. package/dist/i18n/en/Payroll.PayrollEditEmployee.json.js +28 -26
  294. package/dist/i18n/en/Payroll.PayrollEditEmployee.json.js.map +1 -1
  295. package/dist/i18n/en/Payroll.PayrollFlow.json.js +8 -0
  296. package/dist/i18n/en/Payroll.PayrollFlow.json.js.map +1 -0
  297. package/dist/i18n/en/Payroll.PayrollLanding.json.js +2 -2
  298. package/dist/i18n/en/Payroll.PayrollOverview.json.js +60 -56
  299. package/dist/i18n/en/Payroll.PayrollOverview.json.js.map +1 -1
  300. package/dist/i18n/en/Payroll.PayrollReceipts.json.js +16 -12
  301. package/dist/i18n/en/Payroll.PayrollReceipts.json.js.map +1 -1
  302. package/dist/shared/constants.d.ts +3 -0
  303. package/dist/shared/constants.js +11 -9
  304. package/dist/shared/constants.js.map +1 -1
  305. package/dist/style.css +1 -1
  306. package/dist/types/i18next.d.ts +156 -149
  307. package/package.json +8 -8
  308. package/dist/i18n/en/Payroll.RunPayroll.json.js +0 -8
  309. package/dist/i18n/en/Payroll.RunPayroll.json.js.map +0 -1
  310. package/dist/i18n/en/PayrollBlocker.json.js +0 -24
  311. package/dist/i18n/en/PayrollBlocker.json.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"PayrollConfigurationPresentation.js","sources":["../../../../src/components/Payroll/PayrollConfiguration/PayrollConfigurationPresentation.tsx"],"sourcesContent":["import type { ReactNode } from 'react'\nimport type { EmployeeCompensations } from '@gusto/embedded-api/models/components/payrollshow'\nimport type { Employee } from '@gusto/embedded-api/models/components/employee'\nimport type { PayrollPayPeriodType } from '@gusto/embedded-api/models/components/payrollpayperiodtype'\nimport type { PayScheduleObject } from '@gusto/embedded-api/models/components/payscheduleobject'\nimport { Trans, useTranslation } from 'react-i18next'\nimport type { PayrollEmployeeCompensationsType } from '@gusto/embedded-api/models/components/payrollemployeecompensationstype'\nimport {\n useFormatEmployeePayRate,\n getRegularHours,\n getOvertimeHours,\n getTotalPtoHours,\n getAdditionalEarnings,\n getReimbursements,\n formatHoursDisplay,\n calculateGrossPay,\n} from '../helpers'\nimport type { ApiPayrollBlocker } from '../PayrollBlocker/payrollHelpers'\nimport { PayrollBlockerAlerts } from '../PayrollBlocker/components/PayrollBlockerAlerts'\nimport styles from './PayrollConfigurationPresentation.module.scss'\nimport { useI18n } from '@/i18n'\nimport { DataView, Flex, FlexItem, Grid } from '@/components/Common'\nimport type { PaginationControlProps } from '@/components/Common/PaginationControl/PaginationControlTypes'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { HamburgerMenu } from '@/components/Common/HamburgerMenu'\nimport PencilSvg from '@/assets/icons/pencil.svg?react'\nimport XCircle from '@/assets/icons/x-circle.svg?react'\nimport PlusCircle from '@/assets/icons/plus-circle.svg?react'\nimport { firstLastName, formatNumberAsCurrency } from '@/helpers/formattedStrings'\nimport { parseDateStringToLocal } from '@/helpers/dateFormatting'\nimport { useLocale } from '@/contexts/LocaleProvider/useLocale'\nimport { useLoadingIndicator } from '@/contexts/LoadingIndicatorProvider/useLoadingIndicator'\n\ninterface PayrollConfigurationPresentationProps {\n employeeCompensations: EmployeeCompensations[]\n employeeDetails: Employee[]\n payPeriod?: PayrollPayPeriodType\n paySchedule?: PayScheduleObject\n onCalculatePayroll: () => void\n onEdit: (employee: Employee) => void\n onToggleExclude: (employeeCompensation: PayrollEmployeeCompensationsType) => void\n onViewBlockers: () => void\n isOffCycle?: boolean\n alerts?: ReactNode\n isPending?: boolean\n payrollBlockers?: ApiPayrollBlocker[]\n pagination?: PaginationControlProps\n}\n\nconst getPayrollConfigurationTitle = ({\n payPeriod,\n locale,\n}: {\n payPeriod?: PayrollPayPeriodType\n locale: string\n}) => {\n if (payPeriod?.startDate && payPeriod.endDate) {\n const startDate = parseDateStringToLocal(payPeriod.startDate)\n const endDate = parseDateStringToLocal(payPeriod.endDate)\n\n if (startDate && endDate) {\n const startFormatted = startDate.toLocaleDateString(locale, {\n month: 'long',\n day: 'numeric',\n })\n const endFormatted = endDate.toLocaleDateString(locale, {\n month: 'short',\n day: 'numeric',\n year: 'numeric',\n })\n return { startDate: startFormatted, endDate: endFormatted }\n }\n }\n return { startDate: '', endDate: '' }\n}\n\nexport const PayrollConfigurationPresentation = ({\n employeeCompensations,\n employeeDetails,\n payPeriod,\n paySchedule,\n onEdit,\n onToggleExclude,\n onCalculatePayroll,\n onViewBlockers,\n isOffCycle = false,\n alerts,\n isPending,\n payrollBlockers = [],\n pagination,\n}: PayrollConfigurationPresentationProps) => {\n const { Button, Heading, Text, Badge, LoadingSpinner } = useComponentContext()\n useI18n('Payroll.PayrollConfiguration')\n const { t } = useTranslation('Payroll.PayrollConfiguration')\n const { locale } = useLocale()\n const { LoadingIndicator } = useLoadingIndicator()\n const formatEmployeePayRate = useFormatEmployeePayRate()\n\n const employeeMap = new Map(employeeDetails.map(employee => [employee.uuid, employee]))\n\n const getEmployeeName = (employeeUuid: string) => {\n const employee = employeeMap.get(employeeUuid)\n return employee\n ? firstLastName({ first_name: employee.firstName, last_name: employee.lastName })\n : null\n }\n\n return (\n <Flex flexDirection=\"column\" gap={16}>\n <Flex justifyContent=\"space-between\" alignItems=\"center\">\n <FlexItem>\n <Heading as=\"h1\">{t('pageTitle')}</Heading>\n <Text>\n <Trans\n i18nKey=\"description\"\n t={t}\n components={{ dateWrapper: <Text weight=\"bold\" as=\"span\" /> }}\n values={getPayrollConfigurationTitle({ payPeriod, locale })}\n />\n </Text>\n </FlexItem>\n <Button\n title={t('calculatePayrollTitle')}\n onClick={onCalculatePayroll}\n isDisabled={isPending}\n >\n {t('calculatePayroll')}\n </Button>\n </Flex>\n\n {alerts && (\n <Grid gap={16} gridTemplateColumns=\"1fr\">\n {alerts}\n </Grid>\n )}\n\n {isPending ? (\n <LoadingIndicator>\n <Flex flexDirection=\"column\" alignItems=\"center\" gap={4}>\n <LoadingSpinner size=\"lg\" />\n <Heading as=\"h4\">{t('loadingTitle')}</Heading>\n <Text>{t('loadingDescription')}</Text>\n </Flex>\n </LoadingIndicator>\n ) : (\n <>\n <div className={styles.payrollBlockerContainer}>\n {payrollBlockers.length > 0 && (\n <PayrollBlockerAlerts\n blockers={payrollBlockers}\n onMultipleViewClick={onViewBlockers}\n />\n )}\n </div>\n <FlexItem>\n <Heading as=\"h3\">{t('hoursAndEarningsTitle')}</Heading>\n <Text>{t('hoursAndEarningsDescription')}</Text>\n </FlexItem>\n\n <DataView\n label={t('employeeCompensationsTitle')}\n columns={[\n {\n title: <Text weight=\"semibold\">{t('tableColumns.employees')}</Text>,\n render: (item: EmployeeCompensations) => {\n const employee = employeeMap.get(item.employeeUuid || '')\n const payRateDisplay = formatEmployeePayRate(employee)\n return (\n <Flex flexDirection=\"column\" gap={8 as const}>\n <Text weight=\"semibold\">{getEmployeeName(item.employeeUuid || '')}</Text>\n {payRateDisplay && <Text variant=\"supporting\">{payRateDisplay}</Text>}\n {item.excluded && <Badge status=\"warning\">{t('skippedBadge')}</Badge>}\n </Flex>\n )\n },\n },\n {\n title: <Text weight=\"semibold\">{t('tableColumns.hours')}</Text>,\n render: (item: EmployeeCompensations) => {\n const hours = getRegularHours(item)\n const overtimeHours = getOvertimeHours(item)\n return <Text>{formatHoursDisplay(hours + overtimeHours)}</Text>\n },\n },\n {\n title: <Text weight=\"semibold\">{t('tableColumns.timeOff')}</Text>,\n render: (item: EmployeeCompensations) => {\n const ptoHours = getTotalPtoHours(item)\n return <Text>{formatHoursDisplay(ptoHours)}</Text>\n },\n },\n {\n title: <Text weight=\"semibold\">{t('tableColumns.additionalEarnings')}</Text>,\n render: (item: EmployeeCompensations) => {\n const earnings = getAdditionalEarnings(item)\n return <Text>{formatNumberAsCurrency(earnings)}</Text>\n },\n },\n {\n title: <Text weight=\"semibold\">{t('tableColumns.reimbursements')}</Text>,\n render: (item: EmployeeCompensations) => {\n const reimbursements = getReimbursements(item)\n return <Text>{formatNumberAsCurrency(reimbursements)}</Text>\n },\n },\n {\n title: <Text weight=\"semibold\">{t('tableColumns.totalPay')}</Text>,\n render: (item: PayrollEmployeeCompensationsType) => {\n const employee = employeeMap.get(item.employeeUuid || '')\n const calculatedGrossPay = employee\n ? calculateGrossPay(\n item,\n employee,\n payPeriod?.startDate,\n paySchedule,\n isOffCycle,\n )\n : 0\n return <Text>{formatNumberAsCurrency(calculatedGrossPay)}</Text>\n },\n },\n ]}\n data={employeeCompensations}\n itemMenu={(item: EmployeeCompensations) => (\n <HamburgerMenu\n items={[\n {\n label: t('editMenu.edit'),\n icon: <PencilSvg aria-hidden />,\n onClick: () => {\n const employee = employeeMap.get(item.employeeUuid || '')\n if (employee) {\n onEdit(employee)\n }\n },\n },\n {\n label: t(item.excluded ? 'editMenu.unskip' : 'editMenu.skip'),\n icon: item.excluded ? <PlusCircle aria-hidden /> : <XCircle aria-hidden />,\n onClick: () => {\n const employee = employeeMap.get(item.employeeUuid || '')\n if (employee) {\n onToggleExclude(item)\n }\n },\n },\n ]}\n triggerLabel={t('editMenu.edit')}\n />\n )}\n pagination={pagination}\n />\n </>\n )}\n </Flex>\n )\n}\n"],"names":["getPayrollConfigurationTitle","payPeriod","locale","startDate","parseDateStringToLocal","endDate","startFormatted","endFormatted","PayrollConfigurationPresentation","employeeCompensations","employeeDetails","paySchedule","onEdit","onToggleExclude","onCalculatePayroll","onViewBlockers","isOffCycle","alerts","isPending","payrollBlockers","pagination","Button","Heading","Text","Badge","LoadingSpinner","useComponentContext","useI18n","t","useTranslation","useLocale","LoadingIndicator","useLoadingIndicator","formatEmployeePayRate","useFormatEmployeePayRate","employeeMap","employee","getEmployeeName","employeeUuid","firstLastName","jsxs","Flex","FlexItem","jsx","Trans","Grid","Fragment","styles","PayrollBlockerAlerts","DataView","item","payRateDisplay","hours","getRegularHours","overtimeHours","getOvertimeHours","formatHoursDisplay","ptoHours","getTotalPtoHours","earnings","getAdditionalEarnings","formatNumberAsCurrency","reimbursements","getReimbursements","calculatedGrossPay","calculateGrossPay","HamburgerMenu","PencilSvg","PlusCircle","XCircle"],"mappings":"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"}
1
+ {"version":3,"file":"PayrollConfigurationPresentation.js","sources":["../../../../src/components/Payroll/PayrollConfiguration/PayrollConfigurationPresentation.tsx"],"sourcesContent":["import type { ReactNode } from 'react'\nimport type { EmployeeCompensations } from '@gusto/embedded-api/models/components/payrollshow'\nimport type { Employee } from '@gusto/embedded-api/models/components/employee'\nimport type { PayrollPayPeriodType } from '@gusto/embedded-api/models/components/payrollpayperiodtype'\nimport type { PayScheduleObject } from '@gusto/embedded-api/models/components/payscheduleobject'\nimport { Trans, useTranslation } from 'react-i18next'\nimport type { PayrollEmployeeCompensationsType } from '@gusto/embedded-api/models/components/payrollemployeecompensationstype'\nimport {\n useFormatEmployeePayRate,\n getRegularHours,\n getOvertimeHours,\n getTotalPtoHours,\n getAdditionalEarnings,\n getReimbursements,\n formatHoursDisplay,\n calculateGrossPay,\n} from '../helpers'\nimport type { ApiPayrollBlocker } from '../PayrollBlocker/payrollHelpers'\nimport { PayrollBlockerAlerts } from '../PayrollBlocker/components/PayrollBlockerAlerts'\nimport styles from './PayrollConfigurationPresentation.module.scss'\nimport { useI18n } from '@/i18n'\nimport { DataView, Flex, FlexItem, Grid } from '@/components/Common'\nimport type { PaginationControlProps } from '@/components/Common/PaginationControl/PaginationControlTypes'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { HamburgerMenu } from '@/components/Common/HamburgerMenu'\nimport PencilSvg from '@/assets/icons/pencil.svg?react'\nimport XCircle from '@/assets/icons/x-circle.svg?react'\nimport PlusCircle from '@/assets/icons/plus-circle.svg?react'\nimport { firstLastName, formatNumberAsCurrency } from '@/helpers/formattedStrings'\nimport { parseDateStringToLocal } from '@/helpers/dateFormatting'\nimport { useLocale } from '@/contexts/LocaleProvider/useLocale'\nimport { useLoadingIndicator } from '@/contexts/LoadingIndicatorProvider/useLoadingIndicator'\n\ninterface PayrollConfigurationPresentationProps {\n employeeCompensations: EmployeeCompensations[]\n employeeDetails: Employee[]\n payPeriod?: PayrollPayPeriodType\n paySchedule?: PayScheduleObject\n onCalculatePayroll: () => void\n onEdit: (employee: Employee) => void\n onToggleExclude: (employeeCompensation: PayrollEmployeeCompensationsType) => void\n onViewBlockers: () => void\n isOffCycle?: boolean\n alerts?: ReactNode\n isPending?: boolean\n payrollBlockers?: ApiPayrollBlocker[]\n pagination?: PaginationControlProps\n}\n\nconst getPayrollConfigurationTitle = ({\n payPeriod,\n locale,\n}: {\n payPeriod?: PayrollPayPeriodType\n locale: string\n}) => {\n if (payPeriod?.startDate && payPeriod.endDate) {\n const startDate = parseDateStringToLocal(payPeriod.startDate)\n const endDate = parseDateStringToLocal(payPeriod.endDate)\n\n if (startDate && endDate) {\n const startFormatted = startDate.toLocaleDateString(locale, {\n month: 'long',\n day: 'numeric',\n })\n const endFormatted = endDate.toLocaleDateString(locale, {\n month: 'short',\n day: 'numeric',\n year: 'numeric',\n })\n return { startDate: startFormatted, endDate: endFormatted }\n }\n }\n return { startDate: '', endDate: '' }\n}\n\nexport const PayrollConfigurationPresentation = ({\n employeeCompensations,\n employeeDetails,\n payPeriod,\n paySchedule,\n onEdit,\n onToggleExclude,\n onCalculatePayroll,\n onViewBlockers,\n isOffCycle = false,\n alerts,\n isPending,\n payrollBlockers = [],\n pagination,\n}: PayrollConfigurationPresentationProps) => {\n const { Button, Heading, Text, Badge, LoadingSpinner } = useComponentContext()\n useI18n('Payroll.PayrollConfiguration')\n const { t } = useTranslation('Payroll.PayrollConfiguration')\n const { locale } = useLocale()\n const { LoadingIndicator } = useLoadingIndicator()\n const formatEmployeePayRate = useFormatEmployeePayRate()\n\n const employeeMap = new Map(employeeDetails.map(employee => [employee.uuid, employee]))\n\n const getEmployeeName = (employeeUuid: string) => {\n const employee = employeeMap.get(employeeUuid)\n return employee\n ? firstLastName({ first_name: employee.firstName, last_name: employee.lastName })\n : null\n }\n\n return (\n <Flex flexDirection=\"column\" gap={16}>\n <Flex justifyContent=\"space-between\" alignItems=\"center\">\n <FlexItem>\n <Heading as=\"h1\">{t('pageTitle')}</Heading>\n <Text>\n <Trans\n i18nKey=\"description\"\n t={t}\n components={{ dateWrapper: <Text weight=\"bold\" as=\"span\" /> }}\n values={getPayrollConfigurationTitle({ payPeriod, locale })}\n />\n </Text>\n </FlexItem>\n <Button\n title={t('calculatePayrollTitle')}\n onClick={onCalculatePayroll}\n isDisabled={isPending}\n >\n {t('calculatePayroll')}\n </Button>\n </Flex>\n\n {alerts && (\n <Grid gap={16} gridTemplateColumns=\"1fr\">\n {alerts}\n </Grid>\n )}\n\n {isPending ? (\n <LoadingIndicator>\n <Flex flexDirection=\"column\" alignItems=\"center\" gap={4}>\n <LoadingSpinner size=\"lg\" />\n <Heading as=\"h4\">{t('loadingTitle')}</Heading>\n <Text>{t('loadingDescription')}</Text>\n </Flex>\n </LoadingIndicator>\n ) : (\n <>\n <div className={styles.payrollBlockerContainer}>\n {payrollBlockers.length > 0 && (\n <PayrollBlockerAlerts\n blockers={payrollBlockers}\n onMultipleViewClick={onViewBlockers}\n />\n )}\n </div>\n <FlexItem>\n <Heading as=\"h3\">{t('hoursAndEarningsTitle')}</Heading>\n <Text>{t('hoursAndEarningsDescription')}</Text>\n </FlexItem>\n\n <DataView\n label={t('employeeCompensationsTitle')}\n columns={[\n {\n title: <Text weight=\"semibold\">{t('tableColumns.employees')}</Text>,\n render: (item: EmployeeCompensations) => {\n const employee = employeeMap.get(item.employeeUuid || '')\n const payRateDisplay = formatEmployeePayRate(employee)\n return (\n <Flex flexDirection=\"column\" gap={8 as const}>\n <Text weight=\"semibold\">{getEmployeeName(item.employeeUuid || '')}</Text>\n {payRateDisplay && <Text variant=\"supporting\">{payRateDisplay}</Text>}\n {item.excluded && <Badge status=\"warning\">{t('skippedBadge')}</Badge>}\n </Flex>\n )\n },\n },\n {\n title: <Text weight=\"semibold\">{t('tableColumns.hours')}</Text>,\n render: (item: EmployeeCompensations) => {\n const hours = getRegularHours(item)\n const overtimeHours = getOvertimeHours(item)\n return <Text>{formatHoursDisplay(hours + overtimeHours)}</Text>\n },\n },\n {\n title: <Text weight=\"semibold\">{t('tableColumns.timeOff')}</Text>,\n render: (item: EmployeeCompensations) => {\n const ptoHours = getTotalPtoHours(item)\n return <Text>{formatHoursDisplay(ptoHours)}</Text>\n },\n },\n {\n title: <Text weight=\"semibold\">{t('tableColumns.additionalEarnings')}</Text>,\n render: (item: EmployeeCompensations) => {\n const earnings = getAdditionalEarnings(item)\n return <Text>{formatNumberAsCurrency(earnings)}</Text>\n },\n },\n {\n title: <Text weight=\"semibold\">{t('tableColumns.reimbursements')}</Text>,\n render: (item: EmployeeCompensations) => {\n const reimbursements = getReimbursements(item)\n return <Text>{formatNumberAsCurrency(reimbursements)}</Text>\n },\n },\n {\n title: <Text weight=\"semibold\">{t('tableColumns.totalPay')}</Text>,\n render: (item: PayrollEmployeeCompensationsType) => {\n const employee = employeeMap.get(item.employeeUuid || '')\n const calculatedGrossPay = employee\n ? calculateGrossPay(\n item,\n employee,\n payPeriod?.startDate,\n paySchedule,\n isOffCycle,\n )\n : 0\n return <Text>{formatNumberAsCurrency(calculatedGrossPay)}</Text>\n },\n },\n ]}\n data={employeeCompensations}\n itemMenu={(item: EmployeeCompensations) => (\n <HamburgerMenu\n items={[\n {\n label: t('editMenu.edit'),\n icon: <PencilSvg aria-hidden />,\n onClick: () => {\n const employee = employeeMap.get(item.employeeUuid || '')\n if (employee) {\n onEdit(employee)\n }\n },\n },\n {\n label: t(item.excluded ? 'editMenu.unskip' : 'editMenu.skip'),\n icon: item.excluded ? <PlusCircle aria-hidden /> : <XCircle aria-hidden />,\n onClick: () => {\n const employee = employeeMap.get(item.employeeUuid || '')\n if (employee) {\n onToggleExclude(item)\n }\n },\n },\n ]}\n triggerLabel={t('editMenu.edit')}\n />\n )}\n pagination={pagination}\n />\n </>\n )}\n </Flex>\n )\n}\n"],"names":["getPayrollConfigurationTitle","payPeriod","locale","startDate","parseDateStringToLocal","endDate","startFormatted","endFormatted","PayrollConfigurationPresentation","employeeCompensations","employeeDetails","paySchedule","onEdit","onToggleExclude","onCalculatePayroll","onViewBlockers","isOffCycle","alerts","isPending","payrollBlockers","pagination","Button","Heading","Text","Badge","LoadingSpinner","useComponentContext","useI18n","t","useTranslation","useLocale","LoadingIndicator","useLoadingIndicator","formatEmployeePayRate","useFormatEmployeePayRate","employeeMap","employee","getEmployeeName","employeeUuid","firstLastName","jsxs","Flex","FlexItem","jsx","Trans","Grid","Fragment","styles","PayrollBlockerAlerts","DataView","item","payRateDisplay","hours","getRegularHours","overtimeHours","getOvertimeHours","formatHoursDisplay","ptoHours","getTotalPtoHours","earnings","getAdditionalEarnings","formatNumberAsCurrency","reimbursements","getReimbursements","calculatedGrossPay","calculateGrossPay","HamburgerMenu","PencilSvg","PlusCircle","XCircle"],"mappings":"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"}
@@ -1,73 +1,72 @@
1
- import { jsx as n } from "react/jsx-runtime";
2
- import { useEmployeesGetSuspense as _ } from "@gusto/embedded-api/react-query/employeesGet";
3
- import { usePayrollsUpdateMutation as A } from "@gusto/embedded-api/react-query/payrollsUpdate";
4
- import { usePreparedPayrollData as O } from "../usePreparedPayrollData.js";
5
- import { PayrollEditEmployeePresentation as R } from "./PayrollEditEmployeePresentation.js";
6
- import { componentEvents as m } from "../../../shared/constants.js";
7
- import { BaseComponent as x } from "../../Base/Base.js";
8
- import { useComponentDictionary as Y } from "../../../i18n/I18n.js";
9
- import { useBase as g } from "../../Base/useBase.js";
10
- function G(e) {
11
- return /* @__PURE__ */ n(x, { ...e, children: /* @__PURE__ */ n(N, { ...e, children: e.children }) });
1
+ import { jsx as a } from "react/jsx-runtime";
2
+ import { useEmployeesGetSuspense as O } from "@gusto/embedded-api/react-query/employeesGet";
3
+ import { usePayrollsUpdateMutation as R } from "@gusto/embedded-api/react-query/payrollsUpdate";
4
+ import { useMemo as U } from "react";
5
+ import { usePreparedPayrollData as x } from "../usePreparedPayrollData.js";
6
+ import { PayrollEditEmployeePresentation as Y } from "./PayrollEditEmployeePresentation.js";
7
+ import { componentEvents as l } from "../../../shared/constants.js";
8
+ import { BaseComponent as g } from "../../Base/Base.js";
9
+ import { useComponentDictionary as N } from "../../../i18n/I18n.js";
10
+ import { useBase as b } from "../../Base/useBase.js";
11
+ function V(e) {
12
+ return /* @__PURE__ */ a(g, { ...e, children: /* @__PURE__ */ a(h, { ...e, children: e.children }) });
12
13
  }
13
- const N = ({
14
+ const h = ({
14
15
  employeeId: e,
15
- companyId: a,
16
+ companyId: n,
16
17
  payrollId: s,
17
- onEvent: i,
18
+ onEvent: m,
18
19
  dictionary: p
19
20
  }) => {
20
- Y("Payroll.PayrollEditEmployee", p);
21
- const { LoadingIndicator: y, baseSubmitHandler: c } = g(), { data: d } = _({ employeeId: e }), { preparedPayroll: t, paySchedule: u, isLoading: f } = O({
22
- companyId: a,
21
+ N("Payroll.PayrollEditEmployee", p);
22
+ const { LoadingIndicator: y, baseSubmitHandler: c } = b(), { data: d } = O({ employeeId: e }), u = U(() => [e], []), { preparedPayroll: t, paySchedule: f, isLoading: P } = x({
23
+ companyId: n,
23
24
  payrollId: s,
24
- employeeUuids: [e]
25
- }), { mutateAsync: P, isPending: E } = A(), l = d.employee, C = t?.employeeCompensations?.find(
26
- (o) => o.employeeUuid === e
27
- ), L = ({
25
+ employeeUuids: u
26
+ }), { mutateAsync: E, isPending: C } = R(), i = d.employee, L = t?.employeeCompensations?.at(0), D = ({
28
27
  paymentMethod: o,
29
28
  ...r
30
29
  }) => ({
31
30
  ...r,
32
31
  ...o && o !== "Historical" ? { paymentMethod: o } : {},
33
32
  memo: r.memo || void 0
34
- }), D = async (o) => {
35
- const r = L(o);
33
+ }), S = async (o) => {
34
+ const r = D(o);
36
35
  await c(null, async () => {
37
- const U = await P({
36
+ const A = await E({
38
37
  request: {
39
- companyId: a,
38
+ companyId: n,
40
39
  payrollId: s,
41
40
  payrollUpdate: {
42
41
  employeeCompensations: [r]
43
42
  }
44
43
  }
45
44
  });
46
- i(m.RUN_PAYROLL_EMPLOYEE_SAVED, {
47
- payrollPrepared: U.payrollPrepared,
48
- employee: l
45
+ m(l.RUN_PAYROLL_EMPLOYEE_SAVED, {
46
+ payrollPrepared: A.payrollPrepared,
47
+ employee: i
49
48
  });
50
49
  });
51
- }, S = () => {
52
- i(m.RUN_PAYROLL_EMPLOYEE_CANCELLED);
50
+ }, _ = () => {
51
+ m(l.RUN_PAYROLL_EMPLOYEE_CANCELLED);
53
52
  };
54
- return f ? /* @__PURE__ */ n(y, {}) : /* @__PURE__ */ n(
55
- R,
53
+ return P ? /* @__PURE__ */ a(y, {}) : /* @__PURE__ */ a(
54
+ Y,
56
55
  {
57
- onSave: D,
58
- onCancel: S,
59
- employee: l,
60
- isPending: E,
61
- employeeCompensation: C,
56
+ onSave: S,
57
+ onCancel: _,
58
+ employee: i,
59
+ isPending: C,
60
+ employeeCompensation: L,
62
61
  fixedCompensationTypes: t?.fixedCompensationTypes || [],
63
62
  payPeriodStartDate: t?.payPeriod?.startDate,
64
- paySchedule: u,
63
+ paySchedule: f,
65
64
  isOffCycle: t?.offCycle
66
65
  }
67
66
  );
68
67
  };
69
68
  export {
70
- G as PayrollEditEmployee,
71
- N as Root
69
+ V as PayrollEditEmployee,
70
+ h as Root
72
71
  };
73
72
  //# sourceMappingURL=PayrollEditEmployee.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PayrollEditEmployee.js","sources":["../../../../src/components/Payroll/PayrollEditEmployee/PayrollEditEmployee.tsx"],"sourcesContent":["import { useEmployeesGetSuspense } from '@gusto/embedded-api/react-query/employeesGet'\nimport { usePayrollsUpdateMutation } from '@gusto/embedded-api/react-query/payrollsUpdate'\nimport type { PayrollEmployeeCompensationsType } from '@gusto/embedded-api/models/components/payrollemployeecompensationstype'\nimport type { PayrollUpdateEmployeeCompensations } from '@gusto/embedded-api/models/components/payrollupdate'\nimport { usePreparedPayrollData } from '../usePreparedPayrollData'\nimport { PayrollEditEmployeePresentation } from './PayrollEditEmployeePresentation'\nimport { componentEvents } from '@/shared/constants'\nimport type { BaseComponentInterface } from '@/components/Base/Base'\nimport { BaseComponent } from '@/components/Base/Base'\nimport { useComponentDictionary } from '@/i18n'\nimport { useBase } from '@/components/Base/useBase'\n\ninterface PayrollEditEmployeeProps extends BaseComponentInterface<'Payroll.PayrollEditEmployee'> {\n employeeId: string\n companyId: string\n payrollId: string\n}\n\nexport function PayrollEditEmployee(props: PayrollEditEmployeeProps & BaseComponentInterface) {\n return (\n <BaseComponent {...props}>\n <Root {...props}>{props.children}</Root>\n </BaseComponent>\n )\n}\n\nexport const Root = ({\n employeeId,\n companyId,\n payrollId,\n onEvent,\n dictionary,\n}: PayrollEditEmployeeProps) => {\n useComponentDictionary('Payroll.PayrollEditEmployee', dictionary)\n\n const { LoadingIndicator, baseSubmitHandler } = useBase()\n\n const { data: employeeData } = useEmployeesGetSuspense({ employeeId })\n const { preparedPayroll, paySchedule, isLoading } = usePreparedPayrollData({\n companyId,\n payrollId,\n employeeUuids: [employeeId],\n })\n\n const { mutateAsync: updatePayroll, isPending } = usePayrollsUpdateMutation()\n\n const employee = employeeData.employee!\n\n // @TODO: with filtering now supported in prepare payroll this can likely just be the 1st response\n // unless there is a case where an employee can have multiple payroll items within the same payroll\n const employeeCompensation = preparedPayroll?.employeeCompensations?.find(\n compensation => compensation.employeeUuid === employeeId,\n )\n\n const transformEmployeeCompensation = ({\n paymentMethod,\n ...compensation\n }: PayrollEmployeeCompensationsType): PayrollUpdateEmployeeCompensations => {\n return {\n ...compensation,\n ...(paymentMethod && paymentMethod !== 'Historical' ? { paymentMethod } : {}),\n memo: compensation.memo || undefined,\n }\n }\n\n const onSave = async (updatedCompensation: PayrollEmployeeCompensationsType) => {\n const transformedCompensation = transformEmployeeCompensation(updatedCompensation)\n await baseSubmitHandler(null, async () => {\n const result = await updatePayroll({\n request: {\n companyId,\n payrollId,\n payrollUpdate: {\n employeeCompensations: [transformedCompensation],\n },\n },\n })\n\n onEvent(componentEvents.RUN_PAYROLL_EMPLOYEE_SAVED, {\n payrollPrepared: result.payrollPrepared,\n employee,\n })\n })\n }\n\n const onCancel = () => {\n onEvent(componentEvents.RUN_PAYROLL_EMPLOYEE_CANCELLED)\n }\n\n if (isLoading) {\n return <LoadingIndicator />\n }\n\n return (\n <PayrollEditEmployeePresentation\n onSave={onSave}\n onCancel={onCancel}\n employee={employee}\n isPending={isPending}\n employeeCompensation={employeeCompensation}\n fixedCompensationTypes={preparedPayroll?.fixedCompensationTypes || []}\n payPeriodStartDate={preparedPayroll?.payPeriod?.startDate}\n paySchedule={paySchedule}\n isOffCycle={preparedPayroll?.offCycle}\n />\n )\n}\n"],"names":["PayrollEditEmployee","props","jsx","BaseComponent","Root","employeeId","companyId","payrollId","onEvent","dictionary","useComponentDictionary","LoadingIndicator","baseSubmitHandler","useBase","employeeData","useEmployeesGetSuspense","preparedPayroll","paySchedule","isLoading","usePreparedPayrollData","updatePayroll","isPending","usePayrollsUpdateMutation","employee","employeeCompensation","compensation","transformEmployeeCompensation","paymentMethod","onSave","updatedCompensation","transformedCompensation","result","componentEvents","onCancel","PayrollEditEmployeePresentation"],"mappings":";;;;;;;;;AAkBO,SAASA,EAAoBC,GAA0D;AAC5F,SACE,gBAAAC,EAACC,GAAA,EAAe,GAAGF,GACjB,UAAA,gBAAAC,EAACE,KAAM,GAAGH,GAAQ,UAAAA,EAAM,SAAA,CAAS,EAAA,CACnC;AAEJ;AAEO,MAAMG,IAAO,CAAC;AAAA,EACnB,YAAAC;AAAA,EACA,WAAAC;AAAA,EACA,WAAAC;AAAA,EACA,SAAAC;AAAA,EACA,YAAAC;AACF,MAAgC;AAC9B,EAAAC,EAAuB,+BAA+BD,CAAU;AAEhE,QAAM,EAAE,kBAAAE,GAAkB,mBAAAC,EAAA,IAAsBC,EAAA,GAE1C,EAAE,MAAMC,EAAA,IAAiBC,EAAwB,EAAE,YAAAV,GAAY,GAC/D,EAAE,iBAAAW,GAAiB,aAAAC,GAAa,WAAAC,EAAA,IAAcC,EAAuB;AAAA,IACzE,WAAAb;AAAA,IACA,WAAAC;AAAA,IACA,eAAe,CAACF,CAAU;AAAA,EAAA,CAC3B,GAEK,EAAE,aAAae,GAAe,WAAAC,EAAA,IAAcC,EAAA,GAE5CC,IAAWT,EAAa,UAIxBU,IAAuBR,GAAiB,uBAAuB;AAAA,IACnE,CAAAS,MAAgBA,EAAa,iBAAiBpB;AAAA,EAAA,GAG1CqB,IAAgC,CAAC;AAAA,IACrC,eAAAC;AAAA,IACA,GAAGF;AAAA,EAAA,OAEI;AAAA,IACL,GAAGA;AAAA,IACH,GAAIE,KAAiBA,MAAkB,eAAe,EAAE,eAAAA,EAAA,IAAkB,CAAA;AAAA,IAC1E,MAAMF,EAAa,QAAQ;AAAA,EAAA,IAIzBG,IAAS,OAAOC,MAA0D;AAC9E,UAAMC,IAA0BJ,EAA8BG,CAAmB;AACjF,UAAMjB,EAAkB,MAAM,YAAY;AACxC,YAAMmB,IAAS,MAAMX,EAAc;AAAA,QACjC,SAAS;AAAA,UACP,WAAAd;AAAA,UACA,WAAAC;AAAA,UACA,eAAe;AAAA,YACb,uBAAuB,CAACuB,CAAuB;AAAA,UAAA;AAAA,QACjD;AAAA,MACF,CACD;AAED,MAAAtB,EAAQwB,EAAgB,4BAA4B;AAAA,QAClD,iBAAiBD,EAAO;AAAA,QACxB,UAAAR;AAAA,MAAA,CACD;AAAA,IACH,CAAC;AAAA,EACH,GAEMU,IAAW,MAAM;AACrB,IAAAzB,EAAQwB,EAAgB,8BAA8B;AAAA,EACxD;AAEA,SAAId,sBACMP,GAAA,EAAiB,IAIzB,gBAAAT;AAAA,IAACgC;AAAA,IAAA;AAAA,MACC,QAAAN;AAAA,MACA,UAAAK;AAAA,MACA,UAAAV;AAAA,MACA,WAAAF;AAAA,MACA,sBAAAG;AAAA,MACA,wBAAwBR,GAAiB,0BAA0B,CAAA;AAAA,MACnE,oBAAoBA,GAAiB,WAAW;AAAA,MAChD,aAAAC;AAAA,MACA,YAAYD,GAAiB;AAAA,IAAA;AAAA,EAAA;AAGnC;"}
1
+ {"version":3,"file":"PayrollEditEmployee.js","sources":["../../../../src/components/Payroll/PayrollEditEmployee/PayrollEditEmployee.tsx"],"sourcesContent":["import { useEmployeesGetSuspense } from '@gusto/embedded-api/react-query/employeesGet'\nimport { usePayrollsUpdateMutation } from '@gusto/embedded-api/react-query/payrollsUpdate'\nimport type { PayrollEmployeeCompensationsType } from '@gusto/embedded-api/models/components/payrollemployeecompensationstype'\nimport type { PayrollUpdateEmployeeCompensations } from '@gusto/embedded-api/models/components/payrollupdate'\nimport { useMemo } from 'react'\nimport { usePreparedPayrollData } from '../usePreparedPayrollData'\nimport { PayrollEditEmployeePresentation } from './PayrollEditEmployeePresentation'\nimport { componentEvents } from '@/shared/constants'\nimport type { BaseComponentInterface } from '@/components/Base/Base'\nimport { BaseComponent } from '@/components/Base/Base'\nimport { useComponentDictionary } from '@/i18n'\nimport { useBase } from '@/components/Base/useBase'\n\ninterface PayrollEditEmployeeProps extends BaseComponentInterface<'Payroll.PayrollEditEmployee'> {\n employeeId: string\n companyId: string\n payrollId: string\n}\n\nexport function PayrollEditEmployee(props: PayrollEditEmployeeProps & BaseComponentInterface) {\n return (\n <BaseComponent {...props}>\n <Root {...props}>{props.children}</Root>\n </BaseComponent>\n )\n}\n\nexport const Root = ({\n employeeId,\n companyId,\n payrollId,\n onEvent,\n dictionary,\n}: PayrollEditEmployeeProps) => {\n useComponentDictionary('Payroll.PayrollEditEmployee', dictionary)\n\n const { LoadingIndicator, baseSubmitHandler } = useBase()\n\n const { data: employeeData } = useEmployeesGetSuspense({ employeeId })\n const memoizedEmployeeId = useMemo(() => [employeeId], [])\n const { preparedPayroll, paySchedule, isLoading } = usePreparedPayrollData({\n companyId,\n payrollId,\n employeeUuids: memoizedEmployeeId,\n })\n\n const { mutateAsync: updatePayroll, isPending } = usePayrollsUpdateMutation()\n\n const employee = employeeData.employee!\n const employeeCompensation = preparedPayroll?.employeeCompensations?.at(0)\n\n const transformEmployeeCompensation = ({\n paymentMethod,\n ...compensation\n }: PayrollEmployeeCompensationsType): PayrollUpdateEmployeeCompensations => {\n return {\n ...compensation,\n ...(paymentMethod && paymentMethod !== 'Historical' ? { paymentMethod } : {}),\n memo: compensation.memo || undefined,\n }\n }\n\n const onSave = async (updatedCompensation: PayrollEmployeeCompensationsType) => {\n const transformedCompensation = transformEmployeeCompensation(updatedCompensation)\n await baseSubmitHandler(null, async () => {\n const result = await updatePayroll({\n request: {\n companyId,\n payrollId,\n payrollUpdate: {\n employeeCompensations: [transformedCompensation],\n },\n },\n })\n\n onEvent(componentEvents.RUN_PAYROLL_EMPLOYEE_SAVED, {\n payrollPrepared: result.payrollPrepared,\n employee,\n })\n })\n }\n\n const onCancel = () => {\n onEvent(componentEvents.RUN_PAYROLL_EMPLOYEE_CANCELLED)\n }\n\n if (isLoading) {\n return <LoadingIndicator />\n }\n\n return (\n <PayrollEditEmployeePresentation\n onSave={onSave}\n onCancel={onCancel}\n employee={employee}\n isPending={isPending}\n employeeCompensation={employeeCompensation}\n fixedCompensationTypes={preparedPayroll?.fixedCompensationTypes || []}\n payPeriodStartDate={preparedPayroll?.payPeriod?.startDate}\n paySchedule={paySchedule}\n isOffCycle={preparedPayroll?.offCycle}\n />\n )\n}\n"],"names":["PayrollEditEmployee","props","jsx","BaseComponent","Root","employeeId","companyId","payrollId","onEvent","dictionary","useComponentDictionary","LoadingIndicator","baseSubmitHandler","useBase","employeeData","useEmployeesGetSuspense","memoizedEmployeeId","useMemo","preparedPayroll","paySchedule","isLoading","usePreparedPayrollData","updatePayroll","isPending","usePayrollsUpdateMutation","employee","employeeCompensation","transformEmployeeCompensation","paymentMethod","compensation","onSave","updatedCompensation","transformedCompensation","result","componentEvents","onCancel","PayrollEditEmployeePresentation"],"mappings":";;;;;;;;;;AAmBO,SAASA,EAAoBC,GAA0D;AAC5F,SACE,gBAAAC,EAACC,GAAA,EAAe,GAAGF,GACjB,UAAA,gBAAAC,EAACE,KAAM,GAAGH,GAAQ,UAAAA,EAAM,SAAA,CAAS,EAAA,CACnC;AAEJ;AAEO,MAAMG,IAAO,CAAC;AAAA,EACnB,YAAAC;AAAA,EACA,WAAAC;AAAA,EACA,WAAAC;AAAA,EACA,SAAAC;AAAA,EACA,YAAAC;AACF,MAAgC;AAC9B,EAAAC,EAAuB,+BAA+BD,CAAU;AAEhE,QAAM,EAAE,kBAAAE,GAAkB,mBAAAC,EAAA,IAAsBC,EAAA,GAE1C,EAAE,MAAMC,EAAA,IAAiBC,EAAwB,EAAE,YAAAV,GAAY,GAC/DW,IAAqBC,EAAQ,MAAM,CAACZ,CAAU,GAAG,CAAA,CAAE,GACnD,EAAE,iBAAAa,GAAiB,aAAAC,GAAa,WAAAC,EAAA,IAAcC,EAAuB;AAAA,IACzE,WAAAf;AAAA,IACA,WAAAC;AAAA,IACA,eAAeS;AAAA,EAAA,CAChB,GAEK,EAAE,aAAaM,GAAe,WAAAC,EAAA,IAAcC,EAAA,GAE5CC,IAAWX,EAAa,UACxBY,IAAuBR,GAAiB,uBAAuB,GAAG,CAAC,GAEnES,IAAgC,CAAC;AAAA,IACrC,eAAAC;AAAA,IACA,GAAGC;AAAA,EAAA,OAEI;AAAA,IACL,GAAGA;AAAA,IACH,GAAID,KAAiBA,MAAkB,eAAe,EAAE,eAAAA,EAAA,IAAkB,CAAA;AAAA,IAC1E,MAAMC,EAAa,QAAQ;AAAA,EAAA,IAIzBC,IAAS,OAAOC,MAA0D;AAC9E,UAAMC,IAA0BL,EAA8BI,CAAmB;AACjF,UAAMnB,EAAkB,MAAM,YAAY;AACxC,YAAMqB,IAAS,MAAMX,EAAc;AAAA,QACjC,SAAS;AAAA,UACP,WAAAhB;AAAA,UACA,WAAAC;AAAA,UACA,eAAe;AAAA,YACb,uBAAuB,CAACyB,CAAuB;AAAA,UAAA;AAAA,QACjD;AAAA,MACF,CACD;AAED,MAAAxB,EAAQ0B,EAAgB,4BAA4B;AAAA,QAClD,iBAAiBD,EAAO;AAAA,QACxB,UAAAR;AAAA,MAAA,CACD;AAAA,IACH,CAAC;AAAA,EACH,GAEMU,IAAW,MAAM;AACrB,IAAA3B,EAAQ0B,EAAgB,8BAA8B;AAAA,EACxD;AAEA,SAAId,sBACMT,GAAA,EAAiB,IAIzB,gBAAAT;AAAA,IAACkC;AAAA,IAAA;AAAA,MACC,QAAAN;AAAA,MACA,UAAAK;AAAA,MACA,UAAAV;AAAA,MACA,WAAAF;AAAA,MACA,sBAAAG;AAAA,MACA,wBAAwBR,GAAiB,0BAA0B,CAAA;AAAA,MACnE,oBAAoBA,GAAiB,WAAW;AAAA,MAChD,aAAAC;AAAA,MACA,YAAYD,GAAiB;AAAA,IAAA;AAAA,EAAA;AAGnC;"}
@@ -10,15 +10,15 @@ import { TimeOffField as ee } from "./TimeOffField.js";
10
10
  import { Flex as y } from "../../Common/Flex/Flex.js";
11
11
  import { Grid as S } from "../../Common/Grid/Grid.js";
12
12
  import "classnames";
13
- import { RadioGroupField as te } from "../../Common/Fields/RadioGroupField/RadioGroupField.js";
13
+ import { useComponentContext as te } from "../../../contexts/ComponentAdapter/useComponentContext.js";
14
+ import { useI18n as ne } from "../../../i18n/I18n.js";
15
+ import { Form as oe } from "../../Common/Form/Form.js";
16
+ import { firstLastName as ie, formatNumberAsCurrency as re } from "../../../helpers/formattedStrings.js";
17
+ import { getAdditionalEarningsCompensations as se, getReimbursementCompensation as ae, calculateGrossPay as G } from "../helpers.js";
18
+ import { HOURS_COMPENSATION_NAMES as k, EXCLUDED_ADDITIONAL_EARNINGS as me, COMPENSATION_NAME_DOUBLE_OVERTIME as de, COMPENSATION_NAME_OVERTIME as le, COMPENSATION_NAME_REGULAR_HOURS as ue, COMPENSATION_NAME_REIMBURSEMENT as ce, COMPENSATION_NAME_CASH_TIPS as pe, COMPENSATION_NAME_COMMISSION as fe, COMPENSATION_NAME_CORRECTION_PAYMENT as he, COMPENSATION_NAME_PAYCHECK_TIPS as Ce, COMPENSATION_NAME_BONUS as Ne } from "../../../shared/constants.js";
19
+ import { useContainerBreakpoints as Ee } from "../../../hooks/useContainerBreakpoints/useContainerBreakpoints.js";
14
20
  import { TextInputField as R } from "../../Common/Fields/TextInputField/TextInputField.js";
15
- import { useComponentContext as ne } from "../../../contexts/ComponentAdapter/useComponentContext.js";
16
- import { useI18n as oe } from "../../../i18n/I18n.js";
17
- import { Form as ie } from "../../Common/Form/Form.js";
18
- import { firstLastName as re, formatNumberAsCurrency as se } from "../../../helpers/formattedStrings.js";
19
- import { getAdditionalEarningsCompensations as ae, getReimbursementCompensation as me, calculateGrossPay as G } from "../helpers.js";
20
- import { HOURS_COMPENSATION_NAMES as k, EXCLUDED_ADDITIONAL_EARNINGS as de, COMPENSATION_NAME_DOUBLE_OVERTIME as le, COMPENSATION_NAME_OVERTIME as ue, COMPENSATION_NAME_REGULAR_HOURS as ce, COMPENSATION_NAME_REIMBURSEMENT as pe, COMPENSATION_NAME_CASH_TIPS as fe, COMPENSATION_NAME_COMMISSION as he, COMPENSATION_NAME_CORRECTION_PAYMENT as Ce, COMPENSATION_NAME_PAYCHECK_TIPS as Ne, COMPENSATION_NAME_BONUS as Ee } from "../../../shared/constants.js";
21
- import { useContainerBreakpoints as ge } from "../../../hooks/useContainerBreakpoints/useContainerBreakpoints.js";
21
+ import { RadioGroupField as ge } from "../../Common/Fields/RadioGroupField/RadioGroupField.js";
22
22
  const be = m.object({
23
23
  hourlyCompensations: m.record(m.string(), m.record(m.string(), m.string().optional())),
24
24
  timeOffCompensations: m.record(m.string(), m.string().optional()),
@@ -67,22 +67,22 @@ const be = m.object({
67
67
  paySchedule: d,
68
68
  isOffCycle: h = !1
69
69
  }) => {
70
- const { Button: P, Heading: c, Text: H } = ne(), { t } = Z("Payroll.PayrollEditEmployee");
71
- oe("Payroll.PayrollEditEmployee");
72
- const p = l.jobs?.find((e) => e.primary), T = p ? [p] : [], v = X(null), b = ge({
70
+ const { Button: P, Heading: c, Text: H } = te(), { t } = Z("Payroll.PayrollEditEmployee");
71
+ ne("Payroll.PayrollEditEmployee");
72
+ const p = l.jobs?.find((e) => e.primary), T = p ? [p] : [], v = X(null), b = Ee({
73
73
  ref: v
74
74
  }).includes("small");
75
75
  r?.hourlyCompensations?.forEach((e) => {
76
76
  const n = l.jobs?.find((s) => s.uuid === e.jobUuid);
77
77
  n && !T.find((s) => s.uuid === n.uuid) && T.push(n);
78
78
  });
79
- const x = (r?.paidTimeOff || []).filter((e) => e.name), _ = ae({
79
+ const x = (r?.paidTimeOff || []).filter((e) => e.name), _ = se({
80
80
  flsaStatus: p?.compensations?.[0]?.flsaStatus,
81
81
  existingFixedCompensations: r?.fixedCompensations || [],
82
82
  primaryJobUuid: p?.uuid,
83
83
  fixedCompensationTypes: g,
84
- excludedTypes: de
85
- }), C = me(
84
+ excludedTypes: me
85
+ }), C = ae(
86
86
  r?.fixedCompensations || [],
87
87
  g,
88
88
  p?.uuid
@@ -90,28 +90,28 @@ const be = m.object({
90
90
  (s) => s.jobUuid === e && s.name?.toLowerCase() === n.toLowerCase()
91
91
  ), w = (e) => {
92
92
  switch (e) {
93
- case ce:
94
- return t("compensationNames.regularHours");
95
93
  case ue:
96
- return t("compensationNames.overtime");
94
+ return t("compensationNames.regularHours");
97
95
  case le:
96
+ return t("compensationNames.overtime");
97
+ case de:
98
98
  return t("compensationNames.doubleOvertime");
99
99
  default:
100
100
  return e;
101
101
  }
102
102
  }, j = (e) => {
103
103
  switch (e) {
104
- case Ee:
105
- return t("fixedCompensationNames.bonus");
106
104
  case Ne:
107
- return t("fixedCompensationNames.paycheckTips");
105
+ return t("fixedCompensationNames.bonus");
108
106
  case Ce:
109
- return t("fixedCompensationNames.correctionPayment");
107
+ return t("fixedCompensationNames.paycheckTips");
110
108
  case he:
111
- return t("fixedCompensationNames.commission");
109
+ return t("fixedCompensationNames.correctionPayment");
112
110
  case fe:
113
- return t("fixedCompensationNames.cashTips");
111
+ return t("fixedCompensationNames.commission");
114
112
  case pe:
113
+ return t("fixedCompensationNames.cashTips");
114
+ case ce:
115
115
  return t("fixedCompensationNames.reimbursement");
116
116
  default:
117
117
  return e;
@@ -185,7 +185,7 @@ const be = m.object({
185
185
  i,
186
186
  d,
187
187
  h
188
- ]), V = re({
188
+ ]), V = ie({
189
189
  first_name: l.firstName,
190
190
  last_name: l.lastName
191
191
  }), z = (e) => {
@@ -196,7 +196,7 @@ const be = m.object({
196
196
  p?.uuid
197
197
  );
198
198
  N(n);
199
- }, L = se(q || 0), U = /* @__PURE__ */ a(y, { gap: 12, justifyContent: "flex-end", children: [
199
+ }, L = re(q || 0), U = /* @__PURE__ */ a(y, { gap: 12, justifyContent: "flex-end", children: [
200
200
  /* @__PURE__ */ o(P, { variant: "secondary", onClick: O, title: t("cancelButton"), children: t("cancelButton") }),
201
201
  /* @__PURE__ */ o(
202
202
  P,
@@ -226,7 +226,7 @@ const be = m.object({
226
226
  }
227
227
  ),
228
228
  /* @__PURE__ */ a(K, { ...I, children: [
229
- /* @__PURE__ */ a(ie, { children: [
229
+ /* @__PURE__ */ a(oe, { children: [
230
230
  T.length > 0 && /* @__PURE__ */ a("div", { className: u.fieldGroup, children: [
231
231
  /* @__PURE__ */ o(c, { as: "h3", children: t("regularHoursTitle") }),
232
232
  T.map((e) => /* @__PURE__ */ a(y, { flexDirection: "column", gap: 8, children: [
@@ -299,7 +299,7 @@ const be = m.object({
299
299
  /* @__PURE__ */ a("div", { className: u.fieldGroup, children: [
300
300
  /* @__PURE__ */ o(c, { as: "h4", children: t("paymentMethodTitle") }),
301
301
  /* @__PURE__ */ o(
302
- te,
302
+ ge,
303
303
  {
304
304
  name: "paymentMethod",
305
305
  isRequired: !0,
@@ -4,24 +4,23 @@ import { useFormContext as d, useWatch as f } from "react-hook-form";
4
4
  import { useTranslation as m } from "react-i18next";
5
5
  import { Flex as y } from "../../Common/Flex/Flex.js";
6
6
  import "classnames";
7
- import "../../../shared/constants.js";
8
- import { TextInputField as x } from "../../Common/Fields/TextInputField/TextInputField.js";
9
- import { useComponentContext as h } from "../../../contexts/ComponentAdapter/useComponentContext.js";
10
- import { useI18n as B } from "../../../i18n/I18n.js";
7
+ import { useComponentContext as x } from "../../../contexts/ComponentAdapter/useComponentContext.js";
8
+ import { useI18n as h } from "../../../i18n/I18n.js";
9
+ import { TextInputField as B } from "../../Common/Fields/TextInputField/TextInputField.js";
11
10
  const P = ({
12
11
  accrualBalance: e,
13
12
  accrualMethod: o,
14
13
  hoursUsed: r,
15
14
  id: t
16
15
  }) => {
17
- const { Text: n } = h(), { t: l } = m("Payroll.PayrollEditEmployee");
16
+ const { Text: n } = x(), { t: l } = m("Payroll.PayrollEditEmployee");
18
17
  if (o === "unlimited")
19
18
  return null;
20
19
  const a = parseFloat(e) - r;
21
20
  return /* @__PURE__ */ i(n, { size: "sm", variant: "supporting", "aria-live": "polite", "aria-atomic": !0, id: t, children: l("timeOffBalance.remaining", { balance: a.toFixed(1) }) });
22
- }, U = ({ timeOff: e, employee: o }) => {
21
+ }, M = ({ timeOff: e, employee: o }) => {
23
22
  const { t: r } = m("Payroll.PayrollEditEmployee");
24
- B("Payroll.PayrollEditEmployee");
23
+ h("Payroll.PayrollEditEmployee");
25
24
  const { control: t } = d(), n = p(), l = f({
26
25
  control: t,
27
26
  name: `timeOffCompensations.${e.name}`
@@ -31,7 +30,7 @@ const P = ({
31
30
  const c = parseFloat(l || "0"), a = o.eligiblePaidTimeOff?.find((s) => s.name === e.name);
32
31
  return /* @__PURE__ */ u(y, { flexDirection: "column", gap: 4, children: [
33
32
  /* @__PURE__ */ i(
34
- x,
33
+ B,
35
34
  {
36
35
  name: `timeOffCompensations.${e.name}`,
37
36
  type: "number",
@@ -54,6 +53,6 @@ const P = ({
54
53
  ] });
55
54
  };
56
55
  export {
57
- U as TimeOffField
56
+ M as TimeOffField
58
57
  };
59
58
  //# sourceMappingURL=TimeOffField.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TimeOffField.js","sources":["../../../../src/components/Payroll/PayrollEditEmployee/TimeOffField.tsx"],"sourcesContent":["import { useId } from 'react'\nimport { useWatch, useFormContext } from 'react-hook-form'\nimport { useTranslation } from 'react-i18next'\nimport type { Employee } from '@gusto/embedded-api/models/components/employee'\nimport type { PayrollEmployeeCompensationsTypePaidTimeOff } from '@gusto/embedded-api/models/components/payrollemployeecompensationstype'\nimport type { PayrollEditEmployeeFormValues } from './PayrollEditEmployeePresentation'\nimport { Flex, TextInputField } from '@/components/Common'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { useI18n } from '@/i18n'\n\nexport interface TimeOffFieldProps {\n timeOff: PayrollEmployeeCompensationsTypePaidTimeOff\n employee: Employee\n}\n\nconst TimeOffBalance = ({\n accrualBalance,\n accrualMethod,\n hoursUsed,\n id,\n}: {\n accrualBalance: string\n accrualMethod?: string\n hoursUsed: number\n id: string\n}) => {\n const { Text } = useComponentContext()\n const { t } = useTranslation('Payroll.PayrollEditEmployee')\n\n if (accrualMethod === 'unlimited') {\n return null\n }\n\n const currentBalance = parseFloat(accrualBalance)\n const remainingBalance = currentBalance - hoursUsed\n\n return (\n <Text size=\"sm\" variant=\"supporting\" aria-live=\"polite\" aria-atomic={true} id={id}>\n {t('timeOffBalance.remaining', { balance: remainingBalance.toFixed(1) })}\n </Text>\n )\n}\n\nexport const TimeOffField = ({ timeOff, employee }: TimeOffFieldProps) => {\n const { t } = useTranslation('Payroll.PayrollEditEmployee')\n useI18n('Payroll.PayrollEditEmployee')\n\n const { control } = useFormContext<PayrollEditEmployeeFormValues>()\n const id = useId()\n\n const watchedValue = useWatch({\n control,\n name: `timeOffCompensations.${timeOff.name}`,\n })\n\n if (!timeOff.name) {\n return null\n }\n\n const hoursUsed = parseFloat(watchedValue || '0')\n const eligiblePolicy = employee.eligiblePaidTimeOff?.find(policy => policy.name === timeOff.name)\n\n return (\n <Flex flexDirection=\"column\" gap={4}>\n <TextInputField\n key={timeOff.name}\n name={`timeOffCompensations.${timeOff.name}`}\n type=\"number\"\n adornmentEnd={t('hoursUnit')}\n isRequired\n label={timeOff.name}\n aria-describedby={id}\n />\n {eligiblePolicy?.accrualBalance && (\n <TimeOffBalance\n accrualBalance={eligiblePolicy.accrualBalance}\n accrualMethod={eligiblePolicy.accrualMethod ?? undefined}\n hoursUsed={hoursUsed}\n id={id}\n />\n )}\n </Flex>\n )\n}\n"],"names":["TimeOffBalance","accrualBalance","accrualMethod","hoursUsed","id","Text","useComponentContext","t","useTranslation","remainingBalance","jsx","TimeOffField","timeOff","employee","useI18n","control","useFormContext","useId","watchedValue","useWatch","eligiblePolicy","policy","jsxs","Flex","TextInputField"],"mappings":";;;;;;;;;;AAeA,MAAMA,IAAiB,CAAC;AAAA,EACtB,gBAAAC;AAAA,EACA,eAAAC;AAAA,EACA,WAAAC;AAAA,EACA,IAAAC;AACF,MAKM;AACJ,QAAM,EAAE,MAAAC,EAAA,IAASC,EAAA,GACX,EAAE,GAAAC,EAAA,IAAMC,EAAe,6BAA6B;AAE1D,MAAIN,MAAkB;AACpB,WAAO;AAIT,QAAMO,IADiB,WAAWR,CAAc,IACNE;AAE1C,SACE,gBAAAO,EAACL,KAAK,MAAK,MAAK,SAAQ,cAAa,aAAU,UAAS,eAAa,IAAM,IAAAD,GACxE,UAAAG,EAAE,4BAA4B,EAAE,SAASE,EAAiB,QAAQ,CAAC,EAAA,CAAG,GACzE;AAEJ,GAEaE,IAAe,CAAC,EAAE,SAAAC,GAAS,UAAAC,QAAkC;AACxE,QAAM,EAAE,GAAAN,EAAA,IAAMC,EAAe,6BAA6B;AAC1D,EAAAM,EAAQ,6BAA6B;AAErC,QAAM,EAAE,SAAAC,EAAA,IAAYC,EAAA,GACdZ,IAAKa,EAAA,GAELC,IAAeC,EAAS;AAAA,IAC5B,SAAAJ;AAAA,IACA,MAAM,wBAAwBH,EAAQ,IAAI;AAAA,EAAA,CAC3C;AAED,MAAI,CAACA,EAAQ;AACX,WAAO;AAGT,QAAMT,IAAY,WAAWe,KAAgB,GAAG,GAC1CE,IAAiBP,EAAS,qBAAqB,KAAK,OAAUQ,EAAO,SAAST,EAAQ,IAAI;AAEhG,SACE,gBAAAU,EAACC,GAAA,EAAK,eAAc,UAAS,KAAK,GAChC,UAAA;AAAA,IAAA,gBAAAb;AAAA,MAACc;AAAA,MAAA;AAAA,QAEC,MAAM,wBAAwBZ,EAAQ,IAAI;AAAA,QAC1C,MAAK;AAAA,QACL,cAAcL,EAAE,WAAW;AAAA,QAC3B,YAAU;AAAA,QACV,OAAOK,EAAQ;AAAA,QACf,oBAAkBR;AAAA,MAAA;AAAA,MANbQ,EAAQ;AAAA,IAAA;AAAA,IAQdQ,GAAgB,kBACf,gBAAAV;AAAA,MAACV;AAAA,MAAA;AAAA,QACC,gBAAgBoB,EAAe;AAAA,QAC/B,eAAeA,EAAe,iBAAiB;AAAA,QAC/C,WAAAjB;AAAA,QACA,IAAAC;AAAA,MAAA;AAAA,IAAA;AAAA,EACF,GAEJ;AAEJ;"}
1
+ {"version":3,"file":"TimeOffField.js","sources":["../../../../src/components/Payroll/PayrollEditEmployee/TimeOffField.tsx"],"sourcesContent":["import { useId } from 'react'\nimport { useWatch, useFormContext } from 'react-hook-form'\nimport { useTranslation } from 'react-i18next'\nimport type { Employee } from '@gusto/embedded-api/models/components/employee'\nimport type { PayrollEmployeeCompensationsTypePaidTimeOff } from '@gusto/embedded-api/models/components/payrollemployeecompensationstype'\nimport type { PayrollEditEmployeeFormValues } from './PayrollEditEmployeePresentation'\nimport { Flex, TextInputField } from '@/components/Common'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { useI18n } from '@/i18n'\n\nexport interface TimeOffFieldProps {\n timeOff: PayrollEmployeeCompensationsTypePaidTimeOff\n employee: Employee\n}\n\nconst TimeOffBalance = ({\n accrualBalance,\n accrualMethod,\n hoursUsed,\n id,\n}: {\n accrualBalance: string\n accrualMethod?: string\n hoursUsed: number\n id: string\n}) => {\n const { Text } = useComponentContext()\n const { t } = useTranslation('Payroll.PayrollEditEmployee')\n\n if (accrualMethod === 'unlimited') {\n return null\n }\n\n const currentBalance = parseFloat(accrualBalance)\n const remainingBalance = currentBalance - hoursUsed\n\n return (\n <Text size=\"sm\" variant=\"supporting\" aria-live=\"polite\" aria-atomic={true} id={id}>\n {t('timeOffBalance.remaining', { balance: remainingBalance.toFixed(1) })}\n </Text>\n )\n}\n\nexport const TimeOffField = ({ timeOff, employee }: TimeOffFieldProps) => {\n const { t } = useTranslation('Payroll.PayrollEditEmployee')\n useI18n('Payroll.PayrollEditEmployee')\n\n const { control } = useFormContext<PayrollEditEmployeeFormValues>()\n const id = useId()\n\n const watchedValue = useWatch({\n control,\n name: `timeOffCompensations.${timeOff.name}`,\n })\n\n if (!timeOff.name) {\n return null\n }\n\n const hoursUsed = parseFloat(watchedValue || '0')\n const eligiblePolicy = employee.eligiblePaidTimeOff?.find(policy => policy.name === timeOff.name)\n\n return (\n <Flex flexDirection=\"column\" gap={4}>\n <TextInputField\n key={timeOff.name}\n name={`timeOffCompensations.${timeOff.name}`}\n type=\"number\"\n adornmentEnd={t('hoursUnit')}\n isRequired\n label={timeOff.name}\n aria-describedby={id}\n />\n {eligiblePolicy?.accrualBalance && (\n <TimeOffBalance\n accrualBalance={eligiblePolicy.accrualBalance}\n accrualMethod={eligiblePolicy.accrualMethod ?? undefined}\n hoursUsed={hoursUsed}\n id={id}\n />\n )}\n </Flex>\n )\n}\n"],"names":["TimeOffBalance","accrualBalance","accrualMethod","hoursUsed","id","Text","useComponentContext","t","useTranslation","remainingBalance","jsx","TimeOffField","timeOff","employee","useI18n","control","useFormContext","useId","watchedValue","useWatch","eligiblePolicy","policy","jsxs","Flex","TextInputField"],"mappings":";;;;;;;;;AAeA,MAAMA,IAAiB,CAAC;AAAA,EACtB,gBAAAC;AAAA,EACA,eAAAC;AAAA,EACA,WAAAC;AAAA,EACA,IAAAC;AACF,MAKM;AACJ,QAAM,EAAE,MAAAC,EAAA,IAASC,EAAA,GACX,EAAE,GAAAC,EAAA,IAAMC,EAAe,6BAA6B;AAE1D,MAAIN,MAAkB;AACpB,WAAO;AAIT,QAAMO,IADiB,WAAWR,CAAc,IACNE;AAE1C,SACE,gBAAAO,EAACL,KAAK,MAAK,MAAK,SAAQ,cAAa,aAAU,UAAS,eAAa,IAAM,IAAAD,GACxE,UAAAG,EAAE,4BAA4B,EAAE,SAASE,EAAiB,QAAQ,CAAC,EAAA,CAAG,GACzE;AAEJ,GAEaE,IAAe,CAAC,EAAE,SAAAC,GAAS,UAAAC,QAAkC;AACxE,QAAM,EAAE,GAAAN,EAAA,IAAMC,EAAe,6BAA6B;AAC1D,EAAAM,EAAQ,6BAA6B;AAErC,QAAM,EAAE,SAAAC,EAAA,IAAYC,EAAA,GACdZ,IAAKa,EAAA,GAELC,IAAeC,EAAS;AAAA,IAC5B,SAAAJ;AAAA,IACA,MAAM,wBAAwBH,EAAQ,IAAI;AAAA,EAAA,CAC3C;AAED,MAAI,CAACA,EAAQ;AACX,WAAO;AAGT,QAAMT,IAAY,WAAWe,KAAgB,GAAG,GAC1CE,IAAiBP,EAAS,qBAAqB,KAAK,OAAUQ,EAAO,SAAST,EAAQ,IAAI;AAEhG,SACE,gBAAAU,EAACC,GAAA,EAAK,eAAc,UAAS,KAAK,GAChC,UAAA;AAAA,IAAA,gBAAAb;AAAA,MAACc;AAAA,MAAA;AAAA,QAEC,MAAM,wBAAwBZ,EAAQ,IAAI;AAAA,QAC1C,MAAK;AAAA,QACL,cAAcL,EAAE,WAAW;AAAA,QAC3B,YAAU;AAAA,QACV,OAAOK,EAAQ;AAAA,QACf,oBAAkBR;AAAA,MAAA;AAAA,MANbQ,EAAQ;AAAA,IAAA;AAAA,IAQdQ,GAAgB,kBACf,gBAAAV;AAAA,MAACV;AAAA,MAAA;AAAA,QACC,gBAAgBoB,EAAe;AAAA,QAC/B,eAAeA,EAAe,iBAAiB;AAAA,QAC/C,WAAAjB;AAAA,QACA,IAAAC;AAAA,MAAA;AAAA,IAAA;AAAA,EACF,GAEJ;AAEJ;"}
@@ -1,2 +1,2 @@
1
1
  import { PayrollFlowProps } from './PayrollFlowComponents';
2
- export declare const PayrollFlow: ({ companyId, onEvent, defaultValues }: PayrollFlowProps) => import("react/jsx-runtime").JSX.Element;
2
+ export declare const PayrollFlow: ({ companyId, onEvent }: PayrollFlowProps) => import("react/jsx-runtime").JSX.Element;
@@ -1,26 +1,27 @@
1
1
  import { jsx as l } from "react/jsx-runtime";
2
- import { createMachine as n } from "robot3";
3
- import { useMemo as i } from "react";
4
- import { payrollMachine as p } from "./payrollStateMachine.js";
5
- import { PayrollLandingContextual as a } from "./PayrollFlowComponents.js";
6
- import { Flow as s } from "../../Flow/Flow.js";
7
- const y = ({ companyId: o, onEvent: t, defaultValues: r }) => {
8
- const e = i(
9
- () => n("landing", p, (m) => ({
10
- ...m,
11
- component: a,
12
- companyId: o,
13
- defaultValues: r,
14
- totalSteps: 3,
15
- currentStep: 1,
16
- showProgress: !1
17
- // Landing step does not show progress bar
2
+ import { createMachine as m } from "robot3";
3
+ import { useMemo as t } from "react";
4
+ import { payrollMachine as n, payrollFlowBreadcrumbsNodes as i } from "./payrollStateMachine.js";
5
+ import { SaveAndExitCta as p, PayrollLandingContextual as s } from "./PayrollFlowComponents.js";
6
+ import { Flow as c } from "../../Flow/Flow.js";
7
+ import { buildBreadcrumbs as u } from "../../../helpers/breadcrumbHelpers.js";
8
+ const x = ({ companyId: r, onEvent: o }) => {
9
+ const a = t(
10
+ () => m("landing", n, (e) => ({
11
+ ...e,
12
+ component: s,
13
+ companyId: r,
14
+ progressBarType: null,
15
+ //landing step does not show progress bar/breadcrumbs
16
+ breadcrumbs: u(i),
17
+ currentBreadcrumb: "landing",
18
+ progressBarCta: p
18
19
  })),
19
- [o, r]
20
+ [r]
20
21
  );
21
- return /* @__PURE__ */ l(s, { machine: e, onEvent: t });
22
+ return /* @__PURE__ */ l(c, { machine: a, onEvent: o });
22
23
  };
23
24
  export {
24
- y as PayrollFlow
25
+ x as PayrollFlow
25
26
  };
26
27
  //# sourceMappingURL=PayrollFlow.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PayrollFlow.js","sources":["../../../../src/components/Payroll/PayrollFlow/PayrollFlow.tsx"],"sourcesContent":["import { createMachine } from 'robot3'\nimport { useMemo } from 'react'\nimport { payrollMachine } from './payrollStateMachine'\nimport type { PayrollFlowProps } from './PayrollFlowComponents'\nimport { PayrollLandingContextual, type PayrollFlowContextInterface } from './PayrollFlowComponents'\nimport { Flow } from '@/components/Flow/Flow'\n\nexport const PayrollFlow = ({ companyId, onEvent, defaultValues }: PayrollFlowProps) => {\n const payrollFlow = useMemo(\n () =>\n createMachine('landing', payrollMachine, (initialContext: PayrollFlowContextInterface) => ({\n ...initialContext,\n component: PayrollLandingContextual,\n companyId,\n defaultValues,\n totalSteps: 3,\n currentStep: 1,\n showProgress: false, // Landing step does not show progress bar\n })),\n [companyId, defaultValues],\n )\n return <Flow machine={payrollFlow} onEvent={onEvent} />\n}\n"],"names":["PayrollFlow","companyId","onEvent","defaultValues","payrollFlow","useMemo","createMachine","payrollMachine","initialContext","PayrollLandingContextual","jsx","Flow"],"mappings":";;;;;;AAOO,MAAMA,IAAc,CAAC,EAAE,WAAAC,GAAW,SAAAC,GAAS,eAAAC,QAAsC;AACtF,QAAMC,IAAcC;AAAA,IAClB,MACEC,EAAc,WAAWC,GAAgB,CAACC,OAAiD;AAAA,MACzF,GAAGA;AAAA,MACH,WAAWC;AAAA,MACX,WAAAR;AAAA,MACA,eAAAE;AAAA,MACA,YAAY;AAAA,MACZ,aAAa;AAAA,MACb,cAAc;AAAA;AAAA,IAAA,EACd;AAAA,IACJ,CAACF,GAAWE,CAAa;AAAA,EAAA;AAE3B,SAAO,gBAAAO,EAACC,GAAA,EAAK,SAASP,GAAa,SAAAF,EAAA,CAAkB;AACvD;"}
1
+ {"version":3,"file":"PayrollFlow.js","sources":["../../../../src/components/Payroll/PayrollFlow/PayrollFlow.tsx"],"sourcesContent":["import { createMachine } from 'robot3'\nimport { useMemo } from 'react'\nimport { payrollFlowBreadcrumbsNodes, payrollMachine } from './payrollStateMachine'\nimport type { PayrollFlowProps } from './PayrollFlowComponents'\nimport {\n SaveAndExitCta,\n PayrollLandingContextual,\n type PayrollFlowContextInterface,\n} from './PayrollFlowComponents'\nimport { Flow } from '@/components/Flow/Flow'\nimport { buildBreadcrumbs } from '@/helpers/breadcrumbHelpers'\n\nexport const PayrollFlow = ({ companyId, onEvent }: PayrollFlowProps) => {\n const payrollFlow = useMemo(\n () =>\n createMachine('landing', payrollMachine, (initialContext: PayrollFlowContextInterface) => ({\n ...initialContext,\n component: PayrollLandingContextual,\n companyId,\n progressBarType: null, //landing step does not show progress bar/breadcrumbs\n breadcrumbs: buildBreadcrumbs(payrollFlowBreadcrumbsNodes),\n currentBreadcrumb: 'landing',\n progressBarCta: SaveAndExitCta,\n })),\n [companyId],\n )\n return <Flow machine={payrollFlow} onEvent={onEvent} />\n}\n"],"names":["PayrollFlow","companyId","onEvent","payrollFlow","useMemo","createMachine","payrollMachine","initialContext","PayrollLandingContextual","buildBreadcrumbs","payrollFlowBreadcrumbsNodes","SaveAndExitCta","jsx","Flow"],"mappings":";;;;;;;AAYO,MAAMA,IAAc,CAAC,EAAE,WAAAC,GAAW,SAAAC,QAAgC;AACvE,QAAMC,IAAcC;AAAA,IAClB,MACEC,EAAc,WAAWC,GAAgB,CAACC,OAAiD;AAAA,MACzF,GAAGA;AAAA,MACH,WAAWC;AAAA,MACX,WAAAP;AAAA,MACA,iBAAiB;AAAA;AAAA,MACjB,aAAaQ,EAAiBC,CAA2B;AAAA,MACzD,mBAAmB;AAAA,MACnB,gBAAgBC;AAAA,IAAA,EAChB;AAAA,IACJ,CAACV,CAAS;AAAA,EAAA;AAEZ,SAAO,gBAAAW,EAACC,GAAA,EAAK,SAASV,GAAa,SAAAD,EAAA,CAAkB;AACvD;"}
@@ -1,10 +1,9 @@
1
1
  import { ReactNode } from 'react';
2
2
  import { FlowContextInterface } from '../../Flow/useFlow';
3
3
  import { BaseComponentInterface } from '../../Base';
4
- export type PayrollFlowDefaultValues = Record<string, unknown>;
4
+ import { BreadcrumbTrail } from '../../Common/FlowBreadcrumbs/FlowBreadcrumbsTypes';
5
5
  export interface PayrollFlowProps extends BaseComponentInterface {
6
6
  companyId: string;
7
- defaultValues?: PayrollFlowDefaultValues;
8
7
  }
9
8
  export type PayrollFlowAlert = {
10
9
  type: 'error' | 'info' | 'success';
@@ -13,10 +12,12 @@ export type PayrollFlowAlert = {
13
12
  };
14
13
  export interface PayrollFlowContextInterface extends FlowContextInterface {
15
14
  companyId: string;
16
- defaultValues?: PayrollFlowDefaultValues;
17
15
  payrollId?: string;
18
16
  employeeId?: string;
17
+ firstName?: string;
18
+ lastName?: string;
19
19
  alerts?: PayrollFlowAlert[];
20
+ breadcrumbs?: BreadcrumbTrail;
20
21
  }
21
22
  export declare function PayrollLandingContextual(): import("react/jsx-runtime").JSX.Element;
22
23
  export declare function PayrollConfigurationContextual(): import("react/jsx-runtime").JSX.Element;
@@ -24,3 +25,4 @@ export declare function PayrollOverviewContextual(): import("react/jsx-runtime")
24
25
  export declare function PayrollEditEmployeeContextual(): import("react/jsx-runtime").JSX.Element;
25
26
  export declare function PayrollReceiptsContextual(): import("react/jsx-runtime").JSX.Element;
26
27
  export declare function PayrollBlockerContextual(): import("react/jsx-runtime").JSX.Element;
28
+ export declare function SaveAndExitCta(): import("react/jsx-runtime").JSX.Element | null;