@gusto/embedded-react-sdk 0.19.0 → 0.21.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 (405) hide show
  1. package/CHANGELOG.md +48 -0
  2. package/dist/UNSTABLE_Hooks.d.ts +1 -0
  3. package/dist/UNSTABLE_Hooks.js +9 -0
  4. package/dist/UNSTABLE_Hooks.js.map +1 -0
  5. package/dist/assets/icons/coins-hand.svg.js +10 -0
  6. package/dist/assets/icons/coins-hand.svg.js.map +1 -0
  7. package/dist/components/Base/Base.d.ts +19 -4
  8. package/dist/components/Base/Base.js +68 -61
  9. package/dist/components/Base/Base.js.map +1 -1
  10. package/dist/components/Base/useBase.d.ts +1 -1
  11. package/dist/components/Base/useBase.js.map +1 -1
  12. package/dist/components/Base/useBaseSubmit.d.ts +10 -0
  13. package/dist/components/Base/useBaseSubmit.js +33 -0
  14. package/dist/components/Base/useBaseSubmit.js.map +1 -0
  15. package/dist/components/Common/Fields/TextAreaField/TextAreaField.d.ts +5 -0
  16. package/dist/components/Common/Fields/TextAreaField/TextAreaField.js +34 -0
  17. package/dist/components/Common/Fields/TextAreaField/TextAreaField.js.map +1 -0
  18. package/dist/components/Common/Fields/TextAreaField/index.d.ts +3 -0
  19. package/dist/components/Common/FlowBreadcrumbs/FlowBreadcrumbs.js +10 -10
  20. package/dist/components/Common/FlowBreadcrumbs/FlowBreadcrumbs.js.map +1 -1
  21. package/dist/components/Common/SignatureForm/SignatureForm.js +15 -10
  22. package/dist/components/Common/SignatureForm/SignatureForm.js.map +1 -1
  23. package/dist/components/Common/SignatureForm/SignatureFormActions.js +14 -10
  24. package/dist/components/Common/SignatureForm/SignatureFormActions.js.map +1 -1
  25. package/dist/components/Common/SignatureForm/SignatureFormFields.js +19 -14
  26. package/dist/components/Common/SignatureForm/SignatureFormFields.js.map +1 -1
  27. package/dist/components/Common/UI/Alert/Alert.js +23 -22
  28. package/dist/components/Common/UI/Alert/Alert.js.map +1 -1
  29. package/dist/components/Common/UI/Alert/AlertTypes.d.ts +4 -0
  30. package/dist/components/Common/UI/Alert/AlertTypes.js.map +1 -1
  31. package/dist/components/Common/UI/DatePicker/DatePicker.d.ts +1 -1
  32. package/dist/components/Common/UI/DatePicker/DatePicker.js +38 -37
  33. package/dist/components/Common/UI/DatePicker/DatePicker.js.map +1 -1
  34. package/dist/components/Common/UI/DatePicker/DatePickerTypes.d.ts +4 -0
  35. package/dist/components/Common/UI/Modal/Modal.module.scss.js +17 -17
  36. package/dist/components/Common/UI/Select/Select.d.ts +1 -1
  37. package/dist/components/Common/UI/Select/Select.js +27 -26
  38. package/dist/components/Common/UI/Select/Select.js.map +1 -1
  39. package/dist/components/Common/UI/Select/SelectTypes.d.ts +4 -0
  40. package/dist/components/Common/UI/TextArea/TextArea.d.ts +2 -0
  41. package/dist/components/Common/UI/TextArea/TextArea.js +79 -0
  42. package/dist/components/Common/UI/TextArea/TextArea.js.map +1 -0
  43. package/dist/components/Common/UI/TextArea/TextArea.module.scss.js +12 -0
  44. package/dist/components/Common/UI/TextArea/TextArea.module.scss.js.map +1 -0
  45. package/dist/components/Common/UI/TextArea/TextAreaTypes.d.ts +37 -0
  46. package/dist/components/Common/UI/TextArea/TextAreaTypes.js +9 -0
  47. package/dist/components/Common/UI/TextArea/TextAreaTypes.js.map +1 -0
  48. package/dist/components/Common/UI/TextArea/index.d.ts +4 -0
  49. package/dist/components/Company/AssignSignatory/AssignSignatory.js +11 -7
  50. package/dist/components/Company/AssignSignatory/AssignSignatory.js.map +1 -1
  51. package/dist/components/Company/AssignSignatory/AssignSignatorySelection.js +10 -6
  52. package/dist/components/Company/AssignSignatory/AssignSignatorySelection.js.map +1 -1
  53. package/dist/components/Company/AssignSignatory/CreateSignatory/Actions.js +11 -8
  54. package/dist/components/Company/AssignSignatory/CreateSignatory/Actions.js.map +1 -1
  55. package/dist/components/Company/AssignSignatory/CreateSignatory/CreateSignatory.js +9 -6
  56. package/dist/components/Company/AssignSignatory/CreateSignatory/CreateSignatory.js.map +1 -1
  57. package/dist/components/Company/AssignSignatory/CreateSignatory/CreateSignatoryForm.js +14 -13
  58. package/dist/components/Company/AssignSignatory/CreateSignatory/CreateSignatoryForm.js.map +1 -1
  59. package/dist/components/Company/AssignSignatory/CreateSignatory/useCreateSignatory.js +6 -4
  60. package/dist/components/Company/AssignSignatory/CreateSignatory/useCreateSignatory.js.map +1 -1
  61. package/dist/components/Company/AssignSignatory/InviteSignatory/Actions.js +9 -6
  62. package/dist/components/Company/AssignSignatory/InviteSignatory/Actions.js.map +1 -1
  63. package/dist/components/Company/AssignSignatory/InviteSignatory/InviteSignatory.js +13 -10
  64. package/dist/components/Company/AssignSignatory/InviteSignatory/InviteSignatory.js.map +1 -1
  65. package/dist/components/Company/AssignSignatory/InviteSignatory/InviteSignatoryForm.js +14 -13
  66. package/dist/components/Company/AssignSignatory/InviteSignatory/InviteSignatoryForm.js.map +1 -1
  67. package/dist/components/Company/AssignSignatory/InviteSignatory/useInviteSignatory.js +6 -4
  68. package/dist/components/Company/AssignSignatory/InviteSignatory/useInviteSignatory.js.map +1 -1
  69. package/dist/components/Company/AssignSignatory/TitleSelect.js +10 -7
  70. package/dist/components/Company/AssignSignatory/TitleSelect.js.map +1 -1
  71. package/dist/components/Company/AssignSignatory/useAssignSignatory.js +8 -6
  72. package/dist/components/Company/AssignSignatory/useAssignSignatory.js.map +1 -1
  73. package/dist/components/Company/BankAccount/BankAccountForm/Actions.js +11 -9
  74. package/dist/components/Company/BankAccount/BankAccountForm/Actions.js.map +1 -1
  75. package/dist/components/Company/BankAccount/BankAccountForm/Form.js +13 -9
  76. package/dist/components/Company/BankAccount/BankAccountForm/Form.js.map +1 -1
  77. package/dist/components/Company/BankAccount/BankAccountForm/context.js +6 -4
  78. package/dist/components/Company/BankAccount/BankAccountForm/context.js.map +1 -1
  79. package/dist/components/Company/BankAccount/BankAccountList/Actions.js +13 -10
  80. package/dist/components/Company/BankAccount/BankAccountList/Actions.js.map +1 -1
  81. package/dist/components/Company/BankAccount/BankAccountVerify/Actions.js +15 -12
  82. package/dist/components/Company/BankAccount/BankAccountVerify/Actions.js.map +1 -1
  83. package/dist/components/Company/BankAccount/BankAccountVerify/Form.js +8 -4
  84. package/dist/components/Company/BankAccount/BankAccountVerify/Form.js.map +1 -1
  85. package/dist/components/Company/DocumentSigner/DocumentList/Actions.js +8 -5
  86. package/dist/components/Company/DocumentSigner/DocumentList/Actions.js.map +1 -1
  87. package/dist/components/Company/DocumentSigner/DocumentList/DocumentList.js +15 -11
  88. package/dist/components/Company/DocumentSigner/DocumentList/DocumentList.js.map +1 -1
  89. package/dist/components/Company/DocumentSigner/DocumentList/useDocumentList.js +6 -4
  90. package/dist/components/Company/DocumentSigner/DocumentList/useDocumentList.js.map +1 -1
  91. package/dist/components/Company/DocumentSigner/SignatureForm/SignatureForm.js +15 -11
  92. package/dist/components/Company/DocumentSigner/SignatureForm/SignatureForm.js.map +1 -1
  93. package/dist/components/Company/DocumentSigner/SignatureForm/useSignatureForm.js +6 -4
  94. package/dist/components/Company/DocumentSigner/SignatureForm/useSignatureForm.js.map +1 -1
  95. package/dist/components/Company/FederalTaxes/Actions.js +11 -8
  96. package/dist/components/Company/FederalTaxes/Actions.js.map +1 -1
  97. package/dist/components/Company/FederalTaxes/FederalTaxes.js +19 -15
  98. package/dist/components/Company/FederalTaxes/FederalTaxes.js.map +1 -1
  99. package/dist/components/Company/FederalTaxes/Form.js +8 -6
  100. package/dist/components/Company/FederalTaxes/Form.js.map +1 -1
  101. package/dist/components/Company/FederalTaxes/useFederalTaxes.js +11 -9
  102. package/dist/components/Company/FederalTaxes/useFederalTaxes.js.map +1 -1
  103. package/dist/components/Company/Industry/Actions.js +11 -8
  104. package/dist/components/Company/Industry/Actions.js.map +1 -1
  105. package/dist/components/Company/Industry/Context.js +9 -7
  106. package/dist/components/Company/Industry/Context.js.map +1 -1
  107. package/dist/components/Company/Industry/Edit.js +14 -10
  108. package/dist/components/Company/Industry/Edit.js.map +1 -1
  109. package/dist/components/Company/Locations/LocationForm/Actions.js +11 -8
  110. package/dist/components/Company/Locations/LocationForm/Actions.js.map +1 -1
  111. package/dist/components/Company/Locations/LocationForm/Form.js +7 -5
  112. package/dist/components/Company/Locations/LocationForm/Form.js.map +1 -1
  113. package/dist/components/Company/Locations/LocationForm/LocationForm.js +19 -15
  114. package/dist/components/Company/Locations/LocationForm/LocationForm.js.map +1 -1
  115. package/dist/components/Company/Locations/LocationForm/useLocationForm.js +6 -4
  116. package/dist/components/Company/Locations/LocationForm/useLocationForm.js.map +1 -1
  117. package/dist/components/Company/Locations/LocationsList/Actions.js +9 -6
  118. package/dist/components/Company/Locations/LocationsList/Actions.js.map +1 -1
  119. package/dist/components/Company/Locations/LocationsList/List.js +17 -15
  120. package/dist/components/Company/Locations/LocationsList/List.js.map +1 -1
  121. package/dist/components/Company/Locations/LocationsList/LocationsList.js +15 -12
  122. package/dist/components/Company/Locations/LocationsList/LocationsList.js.map +1 -1
  123. package/dist/components/Company/Locations/LocationsList/useLocationsList.js +6 -4
  124. package/dist/components/Company/Locations/LocationsList/useLocationsList.js.map +1 -1
  125. package/dist/components/Company/OnboardingOverview/Completed.js +15 -12
  126. package/dist/components/Company/OnboardingOverview/Completed.js.map +1 -1
  127. package/dist/components/Company/OnboardingOverview/MissingRequirements.js +12 -9
  128. package/dist/components/Company/OnboardingOverview/MissingRequirements.js.map +1 -1
  129. package/dist/components/Company/OnboardingOverview/OnboardingOverview.js +10 -6
  130. package/dist/components/Company/OnboardingOverview/OnboardingOverview.js.map +1 -1
  131. package/dist/components/Company/OnboardingOverview/context.js +6 -4
  132. package/dist/components/Company/OnboardingOverview/context.js.map +1 -1
  133. package/dist/components/Company/PaySchedule/PaySchedule.js +36 -33
  134. package/dist/components/Company/PaySchedule/PaySchedule.js.map +1 -1
  135. package/dist/components/Company/PaySchedule/_parts/Actions.js +13 -10
  136. package/dist/components/Company/PaySchedule/_parts/Actions.js.map +1 -1
  137. package/dist/components/Company/PaySchedule/_parts/Edit.js +15 -15
  138. package/dist/components/Company/PaySchedule/_parts/Head.js +14 -11
  139. package/dist/components/Company/PaySchedule/_parts/Head.js.map +1 -1
  140. package/dist/components/Company/PaySchedule/_parts/List.js +21 -19
  141. package/dist/components/Company/PaySchedule/_parts/List.js.map +1 -1
  142. package/dist/components/Company/PaySchedule/usePaySchedule.js +8 -6
  143. package/dist/components/Company/PaySchedule/usePaySchedule.js.map +1 -1
  144. package/dist/components/Company/StateTaxes/StateTaxesForm/Actions.js +8 -5
  145. package/dist/components/Company/StateTaxes/StateTaxesForm/Actions.js.map +1 -1
  146. package/dist/components/Company/StateTaxes/StateTaxesForm/context.js +6 -4
  147. package/dist/components/Company/StateTaxes/StateTaxesForm/context.js.map +1 -1
  148. package/dist/components/Company/StateTaxes/StateTaxesList/Actions.js +9 -6
  149. package/dist/components/Company/StateTaxes/StateTaxesList/Actions.js.map +1 -1
  150. package/dist/components/Company/StateTaxes/StateTaxesList/List.js +8 -5
  151. package/dist/components/Company/StateTaxes/StateTaxesList/List.js.map +1 -1
  152. package/dist/components/Company/StateTaxes/StateTaxesList/context.js +6 -4
  153. package/dist/components/Company/StateTaxes/StateTaxesList/context.js.map +1 -1
  154. package/dist/components/Contractor/Address/Address.js +8 -4
  155. package/dist/components/Contractor/Address/Address.js.map +1 -1
  156. package/dist/components/Contractor/Address/Form.js +8 -6
  157. package/dist/components/Contractor/Address/Form.js.map +1 -1
  158. package/dist/components/Contractor/Address/useAddress.js +8 -6
  159. package/dist/components/Contractor/Address/useAddress.js.map +1 -1
  160. package/dist/components/Contractor/ContractorList/index.js +29 -28
  161. package/dist/components/Contractor/ContractorList/index.js.map +1 -1
  162. package/dist/components/Contractor/NewHireReport/NewHireReport.js +14 -13
  163. package/dist/components/Contractor/NewHireReport/NewHireReport.js.map +1 -1
  164. package/dist/components/Contractor/PaymentMethod/BankAccountForm.js +14 -10
  165. package/dist/components/Contractor/PaymentMethod/BankAccountForm.js.map +1 -1
  166. package/dist/components/Contractor/PaymentMethod/PaymentMethod.js +3 -2
  167. package/dist/components/Contractor/PaymentMethod/PaymentMethod.js.map +1 -1
  168. package/dist/components/Contractor/PaymentMethod/PaymentTypeForm.js +5 -2
  169. package/dist/components/Contractor/PaymentMethod/PaymentTypeForm.js.map +1 -1
  170. package/dist/components/Contractor/Payments/CreatePayment/CreatePaymentPresentation.d.ts +15 -0
  171. package/dist/components/Contractor/Payments/Detail/DetailPresentation.d.ts +19 -0
  172. package/dist/components/Contractor/Payments/Overview/OverviewPresentation.d.ts +18 -0
  173. package/dist/components/Contractor/Payments/PaymentEdit/PaymentEditPresentation.d.ts +6 -0
  174. package/dist/components/Contractor/Payments/PaymentHistory/PaymentHistoryPresentation.d.ts +18 -0
  175. package/dist/components/Contractor/Payments/types.d.ts +4 -0
  176. package/dist/components/Contractor/Profile/ContractorProfileForm.js +13 -13
  177. package/dist/components/Contractor/Profile/useContractorProfile.js +4 -3
  178. package/dist/components/Contractor/Profile/useContractorProfile.js.map +1 -1
  179. package/dist/components/Contractor/Submit/Submit.js +22 -20
  180. package/dist/components/Contractor/Submit/Submit.js.map +1 -1
  181. package/dist/components/Employee/Compensation/Actions.js +14 -12
  182. package/dist/components/Employee/Compensation/Actions.js.map +1 -1
  183. package/dist/components/Employee/Compensation/Edit.js +17 -16
  184. package/dist/components/Employee/Compensation/Edit.js.map +1 -1
  185. package/dist/components/Employee/Compensation/List.js +25 -23
  186. package/dist/components/Employee/Compensation/List.js.map +1 -1
  187. package/dist/components/Employee/Deductions/Deductions.d.ts +1 -1
  188. package/dist/components/Employee/Deductions/Deductions.js +10 -10
  189. package/dist/components/Employee/Deductions/Deductions.js.map +1 -1
  190. package/dist/components/Employee/Deductions/DeductionsComponents.d.ts +2 -0
  191. package/dist/components/Employee/Deductions/DeductionsComponents.js +6 -6
  192. package/dist/components/Employee/Deductions/DeductionsComponents.js.map +1 -1
  193. package/dist/components/Employee/Deductions/DeductionsForm/ChildSupportForm.js +222 -0
  194. package/dist/components/Employee/Deductions/DeductionsForm/ChildSupportForm.js.map +1 -0
  195. package/dist/components/Employee/Deductions/DeductionsForm/ChildSupportForm.module.scss.js +8 -0
  196. package/dist/components/Employee/Deductions/DeductionsForm/ChildSupportForm.module.scss.js.map +1 -0
  197. package/dist/components/Employee/Deductions/DeductionsForm/CustomDeductionForm.d.ts +2 -2
  198. package/dist/components/Employee/Deductions/DeductionsForm/CustomDeductionForm.js +165 -0
  199. package/dist/components/Employee/Deductions/DeductionsForm/CustomDeductionForm.js.map +1 -0
  200. package/dist/components/Employee/Deductions/DeductionsForm/DeductionsForm.d.ts +0 -34
  201. package/dist/components/Employee/Deductions/DeductionsForm/DeductionsForm.js +90 -126
  202. package/dist/components/Employee/Deductions/DeductionsForm/DeductionsForm.js.map +1 -1
  203. package/dist/components/Employee/Deductions/DeductionsForm/DeductionsForm.module.scss.js +14 -0
  204. package/dist/components/Employee/Deductions/DeductionsForm/DeductionsForm.module.scss.js.map +1 -0
  205. package/dist/components/Employee/Deductions/DeductionsList/DeductionsList.js +56 -55
  206. package/dist/components/Employee/Deductions/DeductionsList/DeductionsList.js.map +1 -1
  207. package/dist/components/Employee/Deductions/IncludeDeductions/IncludeDeductions.d.ts +6 -0
  208. package/dist/components/Employee/Deductions/IncludeDeductions/IncludeDeductions.js +53 -0
  209. package/dist/components/Employee/Deductions/IncludeDeductions/IncludeDeductions.js.map +1 -0
  210. package/dist/components/Employee/Deductions/IncludeDeductions/IncludeDeductions.module.scss.js +14 -0
  211. package/dist/components/Employee/Deductions/IncludeDeductions/IncludeDeductions.module.scss.js.map +1 -0
  212. package/dist/components/Employee/Deductions/stateMachine.js +49 -29
  213. package/dist/components/Employee/Deductions/stateMachine.js.map +1 -1
  214. package/dist/components/Employee/DocumentSigner/DocumentList/Actions.js +9 -6
  215. package/dist/components/Employee/DocumentSigner/DocumentList/Actions.js.map +1 -1
  216. package/dist/components/Employee/DocumentSigner/DocumentList/DocumentList.js +13 -9
  217. package/dist/components/Employee/DocumentSigner/DocumentList/DocumentList.js.map +1 -1
  218. package/dist/components/Employee/DocumentSigner/DocumentList/List.js +6 -2
  219. package/dist/components/Employee/DocumentSigner/DocumentList/List.js.map +1 -1
  220. package/dist/components/Employee/DocumentSigner/DocumentList/useDocumentList.js +6 -4
  221. package/dist/components/Employee/DocumentSigner/DocumentList/useDocumentList.js.map +1 -1
  222. package/dist/components/Employee/DocumentSigner/SignatureForm/SignatureForm.js +15 -11
  223. package/dist/components/Employee/DocumentSigner/SignatureForm/SignatureForm.js.map +1 -1
  224. package/dist/components/Employee/DocumentSigner/SignatureForm/useSignatureForm.js +6 -4
  225. package/dist/components/Employee/DocumentSigner/SignatureForm/useSignatureForm.js.map +1 -1
  226. package/dist/components/Employee/EmployeeList/Actions.js +9 -6
  227. package/dist/components/Employee/EmployeeList/Actions.js.map +1 -1
  228. package/dist/components/Employee/EmployeeList/EmployeeList.js +6 -3
  229. package/dist/components/Employee/EmployeeList/EmployeeList.js.map +1 -1
  230. package/dist/components/Employee/EmployeeList/Head.js +8 -5
  231. package/dist/components/Employee/EmployeeList/Head.js.map +1 -1
  232. package/dist/components/Employee/EmployeeList/List.js +17 -16
  233. package/dist/components/Employee/EmployeeList/List.js.map +1 -1
  234. package/dist/components/Employee/EmployeeList/useEmployeeList.js +6 -4
  235. package/dist/components/Employee/EmployeeList/useEmployeeList.js.map +1 -1
  236. package/dist/components/Employee/FederalTaxes/Actions.js +10 -7
  237. package/dist/components/Employee/FederalTaxes/Actions.js.map +1 -1
  238. package/dist/components/Employee/FederalTaxes/FederalForm.js +14 -11
  239. package/dist/components/Employee/FederalTaxes/FederalForm.js.map +1 -1
  240. package/dist/components/Employee/FederalTaxes/useFederalTaxes.js +6 -4
  241. package/dist/components/Employee/FederalTaxes/useFederalTaxes.js.map +1 -1
  242. package/dist/components/Employee/Landing/Landing.js +15 -13
  243. package/dist/components/Employee/Landing/Landing.js.map +1 -1
  244. package/dist/components/Employee/OnboardingSummary/OnboardingSummary.js +7 -7
  245. package/dist/components/Employee/PaymentMethod/Actions.js +11 -8
  246. package/dist/components/Employee/PaymentMethod/Actions.js.map +1 -1
  247. package/dist/components/Employee/PaymentMethod/BankAccountEdit.js +8 -5
  248. package/dist/components/Employee/PaymentMethod/BankAccountEdit.js.map +1 -1
  249. package/dist/components/Employee/PaymentMethod/BankAccountsList.js +13 -11
  250. package/dist/components/Employee/PaymentMethod/BankAccountsList.js.map +1 -1
  251. package/dist/components/Employee/PaymentMethod/PaymentTypeForm.js +10 -7
  252. package/dist/components/Employee/PaymentMethod/PaymentTypeForm.js.map +1 -1
  253. package/dist/components/Employee/PaymentMethod/Split.js +10 -9
  254. package/dist/components/Employee/PaymentMethod/Split.js.map +1 -1
  255. package/dist/components/Employee/PaymentMethod/usePaymentMethod.js +8 -6
  256. package/dist/components/Employee/PaymentMethod/usePaymentMethod.js.map +1 -1
  257. package/dist/components/Employee/Profile/Actions.js +11 -8
  258. package/dist/components/Employee/Profile/Actions.js.map +1 -1
  259. package/dist/components/Employee/Profile/AdminPersonalDetails.js +11 -8
  260. package/dist/components/Employee/Profile/AdminPersonalDetails.js.map +1 -1
  261. package/dist/components/Employee/Profile/HomeAddress.js +8 -7
  262. package/dist/components/Employee/Profile/HomeAddress.js.map +1 -1
  263. package/dist/components/Employee/Profile/PersonalDetailsInputs.js +31 -28
  264. package/dist/components/Employee/Profile/PersonalDetailsInputs.js.map +1 -1
  265. package/dist/components/Employee/Profile/useProfile.js +6 -4
  266. package/dist/components/Employee/Profile/useProfile.js.map +1 -1
  267. package/dist/components/Employee/StateTaxes/Actions.js +11 -8
  268. package/dist/components/Employee/StateTaxes/Actions.js.map +1 -1
  269. package/dist/components/Employee/StateTaxes/useStateTaxes.js +6 -4
  270. package/dist/components/Employee/StateTaxes/useStateTaxes.js.map +1 -1
  271. package/dist/components/Employee/Taxes/Actions.js +11 -8
  272. package/dist/components/Employee/Taxes/Actions.js.map +1 -1
  273. package/dist/components/Employee/Taxes/FederalForm.js +15 -12
  274. package/dist/components/Employee/Taxes/FederalForm.js.map +1 -1
  275. package/dist/components/Employee/Taxes/useTaxes.js +6 -4
  276. package/dist/components/Employee/Taxes/useTaxes.js.map +1 -1
  277. package/dist/components/Flow/Flow.js +30 -27
  278. package/dist/components/Flow/Flow.js.map +1 -1
  279. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetails.d.ts +1 -1
  280. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetails.js +58 -36
  281. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetails.js.map +1 -1
  282. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsBanner/ConfirmWireDetailsBanner.d.ts +2 -0
  283. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsBanner/ConfirmWireDetailsBanner.js +71 -54
  284. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsBanner/ConfirmWireDetailsBanner.js.map +1 -1
  285. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsComponents.d.ts +23 -0
  286. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsComponents.js +27 -15
  287. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsComponents.js.map +1 -1
  288. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsForm/ConfirmWireDetailsForm.d.ts +25 -2
  289. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsForm/ConfirmWireDetailsForm.js +153 -23
  290. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsForm/ConfirmWireDetailsForm.js.map +1 -1
  291. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsForm/ConfirmWireDetailsForm.module.scss.js +10 -0
  292. package/dist/components/Payroll/ConfirmWireDetails/ConfirmWireDetailsForm/ConfirmWireDetailsForm.module.scss.js.map +1 -0
  293. package/dist/components/Payroll/ConfirmWireDetails/WireInstructions/WireInstructions.d.ts +9 -1
  294. package/dist/components/Payroll/ConfirmWireDetails/WireInstructions/WireInstructions.js +195 -22
  295. package/dist/components/Payroll/ConfirmWireDetails/WireInstructions/WireInstructions.js.map +1 -1
  296. package/dist/components/Payroll/ConfirmWireDetails/WireInstructions/WireInstructions.module.scss.js +18 -0
  297. package/dist/components/Payroll/ConfirmWireDetails/WireInstructions/WireInstructions.module.scss.js.map +1 -0
  298. package/dist/components/Payroll/ConfirmWireDetails/confirmWireDetailsStateMachine.d.ts +10 -2
  299. package/dist/components/Payroll/ConfirmWireDetails/confirmWireDetailsStateMachine.js +39 -25
  300. package/dist/components/Payroll/ConfirmWireDetails/confirmWireDetailsStateMachine.js.map +1 -1
  301. package/dist/components/Payroll/ConfirmWireDetails/index.d.ts +1 -0
  302. package/dist/components/Payroll/ConfirmWireDetails/types.d.ts +5 -0
  303. package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerAlerts.js +16 -13
  304. package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerAlerts.js.map +1 -1
  305. package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerList.js +8 -6
  306. package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerList.js.map +1 -1
  307. package/dist/components/Payroll/PayrollConfiguration/PayrollConfigurationPresentation.js +15 -15
  308. package/dist/components/Payroll/PayrollConfiguration/PayrollConfigurationPresentation.js.map +1 -1
  309. package/dist/components/Payroll/PayrollEditEmployee/PayrollEditEmployeePresentation.js +27 -27
  310. package/dist/components/Payroll/PayrollEditEmployee/TimeOffField.js +13 -11
  311. package/dist/components/Payroll/PayrollEditEmployee/TimeOffField.js.map +1 -1
  312. package/dist/components/Payroll/PayrollHistory/PayrollHistory.d.ts +0 -12
  313. package/dist/components/Payroll/PayrollHistory/PayrollHistory.js +44 -52
  314. package/dist/components/Payroll/PayrollHistory/PayrollHistory.js.map +1 -1
  315. package/dist/components/Payroll/PayrollHistory/PayrollHistoryPresentation.d.ts +9 -6
  316. package/dist/components/Payroll/PayrollHistory/PayrollHistoryPresentation.js +97 -93
  317. package/dist/components/Payroll/PayrollHistory/PayrollHistoryPresentation.js.map +1 -1
  318. package/dist/components/Payroll/PayrollList/PayrollList.js +58 -59
  319. package/dist/components/Payroll/PayrollList/PayrollList.js.map +1 -1
  320. package/dist/components/Payroll/PayrollList/PayrollListPresentation.d.ts +4 -6
  321. package/dist/components/Payroll/PayrollList/PayrollListPresentation.js +82 -72
  322. package/dist/components/Payroll/PayrollList/PayrollListPresentation.js.map +1 -1
  323. package/dist/components/Payroll/PayrollOverview/PayrollOverview.js +3 -2
  324. package/dist/components/Payroll/PayrollOverview/PayrollOverview.js.map +1 -1
  325. package/dist/components/Payroll/PayrollOverview/PayrollOverviewPresentation.js +11 -10
  326. package/dist/components/Payroll/PayrollOverview/PayrollOverviewPresentation.js.map +1 -1
  327. package/dist/components/Payroll/PayrollOverview/SubmissionBlockers/FastAchThresholdExceeded.js +8 -5
  328. package/dist/components/Payroll/PayrollOverview/SubmissionBlockers/FastAchThresholdExceeded.js.map +1 -1
  329. package/dist/components/Payroll/PayrollReceipts/PayrollReceiptsPresentation.js +3 -2
  330. package/dist/components/Payroll/PayrollReceipts/PayrollReceiptsPresentation.js.map +1 -1
  331. package/dist/components/Payroll/PayrollStatusBadges/PayrollStatusBadges.d.ts +7 -0
  332. package/dist/components/Payroll/PayrollStatusBadges/PayrollStatusBadges.js +19 -0
  333. package/dist/components/Payroll/PayrollStatusBadges/PayrollStatusBadges.js.map +1 -0
  334. package/dist/components/Payroll/PayrollStatusBadges/PayrollStatusBadges.module.scss.js +10 -0
  335. package/dist/components/Payroll/PayrollStatusBadges/PayrollStatusBadges.module.scss.js.map +1 -0
  336. package/dist/components/Payroll/PayrollStatusBadges/index.d.ts +4 -0
  337. package/dist/components/Payroll/PayrollStatusBadges/payrollStatusConfig.d.ts +33 -0
  338. package/dist/components/Payroll/PayrollStatusBadges/payrollStatusConfig.js +161 -0
  339. package/dist/components/Payroll/PayrollStatusBadges/payrollStatusConfig.js.map +1 -0
  340. package/dist/components/Payroll/PayrollStatusBadges/usePayrollStatusBadges.d.ts +3 -0
  341. package/dist/components/Payroll/PayrollStatusBadges/usePayrollStatusBadges.js +17 -0
  342. package/dist/components/Payroll/PayrollStatusBadges/usePayrollStatusBadges.js.map +1 -0
  343. package/dist/components/Payroll/PayrollStatusBadges/usePayrollStatusBadges.test.d.ts +1 -0
  344. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfiguration.d.ts +6 -0
  345. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfiguration.js +70 -0
  346. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfiguration.js.map +1 -0
  347. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfigurationContext.d.ts +7 -0
  348. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfigurationContext.js +6 -0
  349. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfigurationContext.js.map +1 -0
  350. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfigurationProvider.d.ts +9 -0
  351. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfigurationProvider.js +40 -0
  352. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/PayrollConfigurationProvider.js.map +1 -0
  353. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/index.d.ts +5 -0
  354. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/usePayrollConfiguration.d.ts +2 -0
  355. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/usePayrollConfiguration.js +12 -0
  356. package/dist/components/Payroll/UNSTABLE_PayrollHooks/PayrollConfiguration/usePayrollConfiguration.js.map +1 -0
  357. package/dist/components/Payroll/UNSTABLE_PayrollHooks/index.d.ts +2 -0
  358. package/dist/components/Payroll/helpers.d.ts +0 -5
  359. package/dist/components/Payroll/helpers.js +106 -112
  360. package/dist/components/Payroll/helpers.js.map +1 -1
  361. package/dist/components/Payroll/usePreparedPayrollData.js +10 -8
  362. package/dist/components/Payroll/usePreparedPayrollData.js.map +1 -1
  363. package/dist/contexts/ComponentAdapter/adapters/defaultComponentAdapter.js +48 -46
  364. package/dist/contexts/ComponentAdapter/adapters/defaultComponentAdapter.js.map +1 -1
  365. package/dist/contexts/ComponentAdapter/useComponentContext.d.ts +2 -0
  366. package/dist/contexts/ComponentAdapter/useComponentContext.js +3 -3
  367. package/dist/contexts/ComponentAdapter/useComponentContext.js.map +1 -1
  368. package/dist/contexts/GustoProvider/GustoProviderCustomUIAdapter.js +9 -5
  369. package/dist/contexts/GustoProvider/GustoProviderCustomUIAdapter.js.map +1 -1
  370. package/dist/helpers/dateFormatting.d.ts +9 -0
  371. package/dist/helpers/dateFormatting.js +65 -52
  372. package/dist/helpers/dateFormatting.js.map +1 -1
  373. package/dist/helpers/formattedStrings.js +12 -11
  374. package/dist/helpers/formattedStrings.js.map +1 -1
  375. package/dist/helpers/validations.js +1 -1
  376. package/dist/helpers/validations.js.map +1 -1
  377. package/dist/i18n/I18n.js +10 -10
  378. package/dist/i18n/I18n.js.map +1 -1
  379. package/dist/i18n/en/ContractorPayment.ContractorPaymentCreatePayment.json.js +32 -0
  380. package/dist/i18n/en/ContractorPayment.ContractorPaymentCreatePayment.json.js.map +1 -0
  381. package/dist/i18n/en/ContractorPayment.ContractorPaymentDetail.json.js +24 -0
  382. package/dist/i18n/en/ContractorPayment.ContractorPaymentDetail.json.js.map +1 -0
  383. package/dist/i18n/en/ContractorPayment.ContractorPaymentOverview.json.js +32 -0
  384. package/dist/i18n/en/ContractorPayment.ContractorPaymentOverview.json.js.map +1 -0
  385. package/dist/i18n/en/ContractorPayment.ContractorPaymentPaymentHistory.json.js +32 -0
  386. package/dist/i18n/en/ContractorPayment.ContractorPaymentPaymentHistory.json.js.map +1 -0
  387. package/dist/i18n/en/Payroll.Common.json.js +8 -0
  388. package/dist/i18n/en/Payroll.Common.json.js.map +1 -0
  389. package/dist/i18n/en/Payroll.ConfirmWireDetailsForm.json.js +25 -5
  390. package/dist/i18n/en/Payroll.ConfirmWireDetailsForm.json.js.map +1 -1
  391. package/dist/i18n/en/Payroll.PayrollList.json.js +14 -16
  392. package/dist/i18n/en/Payroll.PayrollList.json.js.map +1 -1
  393. package/dist/i18n/en/Payroll.WireInstructions.json.js +22 -6
  394. package/dist/i18n/en/Payroll.WireInstructions.json.js.map +1 -1
  395. package/dist/shared/constants.d.ts +6 -0
  396. package/dist/shared/constants.js +15 -12
  397. package/dist/shared/constants.js.map +1 -1
  398. package/dist/style.css +1 -1
  399. package/dist/types/i18next.d.ts +183 -8
  400. package/package.json +13 -9
  401. package/dist/components/Employee/Deductions/DeductionsForm/UNSTABLE_DeductionsForm.d.ts +0 -7
  402. package/dist/components/Employee/Deductions/EmptyState/EmptyState.d.ts +0 -6
  403. package/dist/components/Employee/Deductions/IncludeDeductionsForm/IncludeDeductionsForm.d.ts +0 -15
  404. package/dist/components/Employee/Deductions/IncludeDeductionsForm/IncludeDeductionsForm.js +0 -48
  405. package/dist/components/Employee/Deductions/IncludeDeductionsForm/IncludeDeductionsForm.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"PayrollOverviewPresentation.js","sources":["../../../../src/components/Payroll/PayrollOverview/PayrollOverviewPresentation.tsx"],"sourcesContent":["import { Trans, useTranslation } from 'react-i18next'\nimport type {\n EmployeeCompensations,\n PayrollShow,\n} from '@gusto/embedded-api/models/components/payrollshow'\nimport type { PayrollPayPeriodType } from '@gusto/embedded-api/models/components/payrollpayperiodtype'\nimport type { CompanyBankAccount } from '@gusto/embedded-api/models/components/companybankaccount'\nimport { useState, useRef } from 'react'\nimport type { Employee } from '@gusto/embedded-api/models/components/employee'\nimport type { PayrollSubmissionBlockersType } from '@gusto/embedded-api/models/components/payrollsubmissionblockerstype'\nimport type { PayrollFlowAlert } from '../PayrollFlow/PayrollFlowComponents'\nimport { calculateTotalPayroll } from '../helpers'\nimport { FastAchThresholdExceeded, GenericBlocker } from './SubmissionBlockers'\nimport styles from './PayrollOverviewPresentation.module.scss'\nimport { DataView, Flex, FlexItem } from '@/components/Common'\nimport { useContainerBreakpoints } from '@/hooks/useContainerBreakpoints/useContainerBreakpoints'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { useI18n } from '@/i18n'\nimport { useDateFormatter } from '@/hooks/useDateFormatter'\nimport useNumberFormatter from '@/hooks/useNumberFormatter'\nimport { firstLastName } from '@/helpers/formattedStrings'\nimport {\n compensationTypeLabels,\n FlsaStatus,\n PAYROLL_RESOLVABLE_SUBMISSION_BLOCKER_TYPES,\n PAYMENT_METHODS,\n} from '@/shared/constants'\nimport DownloadIcon from '@/assets/icons/download-cloud.svg?react'\nimport { useLoadingIndicator } from '@/contexts/LoadingIndicatorProvider/useLoadingIndicator'\n\ninterface PayrollOverviewProps {\n payrollData: PayrollShow\n bankAccount?: CompanyBankAccount\n employeeDetails: Employee[]\n taxes: Record<string, { employee: number; employer: number }>\n isSubmitting?: boolean\n isProcessed: boolean\n alerts?: PayrollFlowAlert[]\n submissionBlockers?: PayrollSubmissionBlockersType[]\n selectedUnblockOptions?: Record<string, string>\n wireInConfirmationRequest?: React.ReactNode\n onEdit: () => void\n onSubmit: () => void\n onCancel: () => void\n onPayrollReceipt: () => void\n onPaystubDownload: (employeeId: string) => void\n onUnblockOptionChange?: (blockerType: string, value: string) => void\n}\n\nconst getPayrollOverviewTitle = (\n payPeriod: PayrollPayPeriodType | undefined,\n dateFormatter: ReturnType<typeof useDateFormatter>,\n) => {\n if (payPeriod?.startDate && payPeriod.endDate) {\n return dateFormatter.formatPayPeriod(payPeriod.startDate, payPeriod.endDate)\n }\n return { startDate: '', endDate: '' }\n}\n\nexport const PayrollOverviewPresentation = ({\n onEdit,\n onSubmit,\n onCancel,\n onPayrollReceipt,\n onPaystubDownload,\n employeeDetails,\n payrollData,\n bankAccount,\n taxes,\n isSubmitting = false,\n isProcessed,\n alerts = [],\n submissionBlockers = [],\n selectedUnblockOptions = {},\n onUnblockOptionChange,\n wireInConfirmationRequest,\n}: PayrollOverviewProps) => {\n const { Alert, Button, ButtonIcon, Dialog, Heading, Text, Tabs, LoadingSpinner } =\n useComponentContext()\n useI18n('Payroll.PayrollOverview')\n const dateFormatter = useDateFormatter()\n const { t } = useTranslation('Payroll.PayrollOverview')\n const formatCurrency = useNumberFormatter('currency')\n const [selectedTab, setSelectedTab] = useState('companyPays')\n const [isCancelDialogOpen, setIsCancelDialogOpen] = useState(false)\n const { LoadingIndicator } = useLoadingIndicator()\n const containerRef = useRef<HTMLDivElement>(null)\n const breakpoints = useContainerBreakpoints({ ref: containerRef })\n const isDesktop = breakpoints.includes('small')\n\n const totalPayroll = calculateTotalPayroll(payrollData)\n\n const expectedDebitDate =\n payrollData.payrollStatusMeta?.expectedDebitTime ?? payrollData.payrollDeadline\n\n const getCompanyTaxes = (employeeCompensation: EmployeeCompensations) => {\n return (\n employeeCompensation.taxes?.reduce(\n (acc, tax) => (tax.employer ? acc + tax.amount : acc),\n 0,\n ) ?? 0\n )\n }\n const getCompanyBenefits = (employeeCompensation: EmployeeCompensations) => {\n return (\n employeeCompensation.benefits?.reduce(\n (acc, benefit) => (benefit.companyContribution ? acc + benefit.companyContribution : acc),\n 0,\n ) ?? 0\n )\n }\n const getReimbursements = (employeeCompensation: EmployeeCompensations) => {\n return employeeCompensation.fixedCompensations?.length\n ? Number(\n employeeCompensation.fixedCompensations.find(\n c => c.name?.toLowerCase() === compensationTypeLabels.REIMBURSEMENT_NAME.toLowerCase(),\n )?.amount || 0,\n )\n : 0\n }\n\n const getCompanyCost = (employeeCompensation: EmployeeCompensations) => {\n return (\n employeeCompensation.grossPay! +\n getReimbursements(employeeCompensation) +\n getCompanyTaxes(employeeCompensation) +\n getCompanyBenefits(employeeCompensation)\n )\n }\n\n const employeeMap = new Map(employeeDetails.map(employee => [employee.uuid, employee]))\n\n const getEmployeeHours = (\n employeeCompensations: EmployeeCompensations,\n ): Record<string, number> => {\n return (\n employeeCompensations.hourlyCompensations?.reduce(\n (acc, hourlyCompensation) => {\n if (typeof hourlyCompensation.name === 'undefined') {\n return acc\n }\n const name = hourlyCompensation.name.toLowerCase()\n const currentHours = acc[name] ?? 0\n acc[name] = currentHours + Number(hourlyCompensation.hours || 0)\n return acc\n },\n {} as Record<string, number>,\n ) || {}\n )\n }\n const getEmployeePtoHours = (employeeCompensations: EmployeeCompensations) => {\n return (\n employeeCompensations.paidTimeOff?.reduce((acc, paidTimeOff) => {\n return acc + Number(paidTimeOff.hours || 0)\n }, 0) ?? 0\n )\n }\n\n const checkPaymentsCount =\n payrollData.employeeCompensations?.reduce(\n (acc, comp) =>\n !comp.excluded && comp.paymentMethod === PAYMENT_METHODS.check ? acc + 1 : acc,\n 0,\n ) ?? 0\n const companyPaysColumns = [\n {\n key: 'employeeName',\n title: t('tableHeaders.employees'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {firstLastName({\n first_name: employeeMap.get(employeeCompensations.employeeUuid!)?.firstName,\n last_name: employeeMap.get(employeeCompensations.employeeUuid!)?.lastName,\n })}\n </Text>\n ),\n },\n {\n key: 'grossPay',\n title: t('tableHeaders.grossPay'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>{formatCurrency(employeeCompensations.grossPay!)}</Text>\n ),\n },\n {\n key: 'reimbursements',\n title: t('tableHeaders.reimbursements'),\n render: (employeeCompensation: EmployeeCompensations) => (\n <Text>{formatCurrency(getReimbursements(employeeCompensation))}</Text>\n ),\n },\n {\n key: 'companyTaxes',\n title: t('tableHeaders.companyTaxes'),\n render: (employeeCompensation: EmployeeCompensations) => (\n <Text>{formatCurrency(getCompanyTaxes(employeeCompensation))}</Text>\n ),\n },\n {\n key: 'companyBenefits',\n title: t('tableHeaders.companyBenefits'),\n render: (employeeCompensation: EmployeeCompensations) => (\n <Text>{formatCurrency(getCompanyBenefits(employeeCompensation))}</Text>\n ),\n },\n {\n key: 'companyPays',\n title: t('tableHeaders.companyPays'),\n render: (employeeCompensation: EmployeeCompensations) => (\n <Text>{formatCurrency(getCompanyCost(employeeCompensation))}</Text>\n ),\n },\n ]\n if (isProcessed) {\n companyPaysColumns.push({\n key: 'paystubs',\n title: t('tableHeaders.paystub'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <ButtonIcon\n aria-label={t('downloadPaystubLabel')}\n variant=\"tertiary\"\n onClick={() => {\n if (employeeCompensations.employeeUuid) {\n onPaystubDownload(employeeCompensations.employeeUuid)\n }\n }}\n >\n <DownloadIcon />\n </ButtonIcon>\n ),\n })\n }\n const tabs = [\n {\n id: 'companyPays',\n label: t('dataViews.companyPaysTab'),\n content: (\n <DataView\n label={t('dataViews.companyPaysTable')}\n columns={companyPaysColumns}\n data={payrollData.employeeCompensations!}\n footer={() => ({\n employeeName: (\n <>\n <Text>{t('tableHeaders.footerTotalsLabel')}</Text>\n <Text>{t('tableHeaders.footerTotalsDescription')}</Text>\n </>\n ),\n grossPay: <Text>{formatCurrency(Number(payrollData.totals?.grossPay ?? 0))}</Text>,\n reimbursements: (\n <Text>{formatCurrency(Number(payrollData.totals?.reimbursements ?? 0))}</Text>\n ),\n companyTaxes: (\n <Text>{formatCurrency(Number(payrollData.totals?.employerTaxes ?? 0))}</Text>\n ),\n companyBenefits: (\n <Text>{formatCurrency(Number(payrollData.totals?.benefits ?? 0))}</Text>\n ),\n companyPays: <Text>{formatCurrency(totalPayroll)}</Text>,\n })}\n />\n ),\n },\n {\n id: 'hoursWorked',\n label: t('dataViews.hoursWorkedTab'),\n content: (\n <DataView\n label={t('dataViews.hoursWorkedTable')}\n columns={[\n {\n title: t('tableHeaders.employees'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {firstLastName({\n first_name: employeeMap.get(employeeCompensations.employeeUuid!)?.firstName,\n last_name: employeeMap.get(employeeCompensations.employeeUuid!)?.lastName,\n })}\n </Text>\n ),\n },\n {\n title: t('tableHeaders.compensationType'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {employeeMap\n .get(employeeCompensations.employeeUuid!)\n ?.jobs?.reduce((acc, job) => {\n if (job.primary) {\n const flsaStatus = job.compensations?.find(\n comp => comp.uuid === job.currentCompensationUuid,\n )?.flsaStatus\n\n switch (flsaStatus) {\n case FlsaStatus.EXEMPT:\n return t('compensationTypeLabels.exempt')\n case FlsaStatus.NONEXEMPT:\n return t('compensationTypeLabels.nonexempt')\n default:\n return flsaStatus ?? ''\n }\n }\n return acc\n }, '')}\n </Text>\n ),\n },\n {\n title: t('tableHeaders.regular'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {getEmployeeHours(employeeCompensations)[\n compensationTypeLabels.REGULAR_HOURS_NAME\n ] || 0}\n </Text>\n ),\n },\n {\n title: t('tableHeaders.overtime'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {getEmployeeHours(employeeCompensations)[compensationTypeLabels.OVERTIME_NAME] ||\n 0}\n </Text>\n ),\n },\n {\n title: t('tableHeaders.doubleOT'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {getEmployeeHours(employeeCompensations)[\n compensationTypeLabels.DOUBLE_OVERTIME_NAME\n ] || 0}\n </Text>\n ),\n },\n {\n title: t('tableHeaders.timeOff'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>{getEmployeePtoHours(employeeCompensations)}</Text>\n ),\n },\n {\n title: t('tableHeaders.totalHours'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {Object.values(getEmployeeHours(employeeCompensations)).reduce(\n (acc, hours) => acc + hours,\n 0,\n ) + getEmployeePtoHours(employeeCompensations)}\n </Text>\n ),\n },\n ]}\n data={payrollData.employeeCompensations!}\n />\n ),\n },\n {\n id: 'employeeTakeHome',\n label: t('dataViews.employeeTakeHomeTab'),\n content: (\n <DataView\n label={t('dataViews.employeeTakeHomeTable')}\n columns={[\n {\n title: t('tableHeaders.employees'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {firstLastName({\n first_name: employeeMap.get(employeeCompensations.employeeUuid!)?.firstName,\n last_name: employeeMap.get(employeeCompensations.employeeUuid!)?.lastName,\n })}\n </Text>\n ),\n },\n {\n title: t('tableHeaders.paymentType'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>{employeeCompensations.paymentMethod ?? ''}</Text>\n ),\n },\n {\n title: t('tableHeaders.grossPay'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>{formatCurrency(employeeCompensations.grossPay ?? 0)}</Text>\n ),\n },\n {\n title: t('tableHeaders.deductions'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {formatCurrency(\n employeeCompensations.deductions?.reduce(\n (acc, deduction) => acc + deduction.amount!,\n 0,\n ) ?? 0,\n )}\n </Text>\n ),\n },\n {\n title: t('tableHeaders.reimbursements'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>{formatCurrency(getReimbursements(employeeCompensations))}</Text>\n ),\n },\n {\n title: t('tableHeaders.employeeTaxes'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {formatCurrency(\n employeeCompensations.taxes?.reduce(\n (acc, tax) => (tax.employer ? acc : acc + tax.amount),\n 0,\n ) ?? 0,\n )}\n </Text>\n ),\n },\n {\n title: t('tableHeaders.employeeBenefits'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {formatCurrency(\n employeeCompensations.benefits?.reduce(\n (acc, benefit) => acc + (benefit.employeeDeduction ?? 0),\n 0,\n ) ?? 0,\n )}\n </Text>\n ),\n },\n {\n title: t('tableHeaders.payment'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>{formatCurrency(employeeCompensations.netPay ?? 0)}</Text>\n ),\n },\n ]}\n data={payrollData.employeeCompensations!}\n />\n ),\n },\n {\n id: 'taxes',\n label: t('dataViews.taxesTab'),\n content: (\n <Flex flexDirection=\"column\" gap={32}>\n <DataView\n label={t('dataViews.taxesTable')}\n columns={[\n {\n key: 'taxDescription',\n title: t('tableHeaders.taxDescription'),\n render: taxKey => <Text>{taxKey}</Text>,\n },\n {\n key: 'byYourEmployees',\n title: t('tableHeaders.byYourEmployees'),\n render: taxKey => <Text>{formatCurrency(taxes[taxKey]?.employee ?? 0)}</Text>,\n },\n {\n key: 'byYourCompany',\n title: t('tableHeaders.byYourCompany'),\n render: taxKey => <Text>{formatCurrency(taxes[taxKey]?.employer ?? 0)}</Text>,\n },\n ]}\n footer={() => ({\n taxDescription: <Text>{t('totalsLabel')}</Text>,\n byYourEmployees: (\n <Text>{formatCurrency(Number(payrollData.totals?.employeeTaxes ?? 0))}</Text>\n ),\n byYourCompany: (\n <Text>{formatCurrency(Number(payrollData.totals?.employerTaxes ?? 0))}</Text>\n ),\n })}\n data={Object.keys(taxes)}\n />\n\n <DataView\n label={t('dataViews.debitedTable')}\n columns={[\n {\n title: t('tableHeaders.debitedByGusto'),\n render: ({ label }) => <Text>{label}</Text>,\n },\n {\n title: t('tableHeaders.taxesTotal'),\n render: ({ value }) => <Text>{formatCurrency(Number(value))}</Text>,\n },\n ]}\n data={[\n { label: t('directDepositLabel'), value: payrollData.totals?.netPayDebit || '0' },\n {\n label: t('reimbursementLabel'),\n value: payrollData.totals?.reimbursementDebit || '0',\n },\n {\n label: t('garnishmentsLabel'),\n value: payrollData.totals?.childSupportDebit || '0',\n },\n { label: t('taxesLabel'), value: payrollData.totals?.taxDebit || '0' },\n ]}\n />\n </Flex>\n ),\n },\n ]\n\n return (\n <div ref={containerRef} className={styles.container}>\n <Flex flexDirection=\"column\" alignItems=\"stretch\">\n <Flex\n flexDirection={isDesktop ? 'row' : 'column'}\n justifyContent={isDesktop ? 'space-between' : 'normal'}\n alignItems={isDesktop ? 'flex-start' : 'stretch'}\n gap={isDesktop ? 0 : 16}\n >\n <FlexItem flexGrow={1}>\n <Heading as=\"h1\">{isProcessed ? t('summaryTitle') : t('overviewTitle')}</Heading>\n <Text>\n <Trans\n i18nKey=\"pageSubtitle\"\n t={t}\n components={{ dateWrapper: <Text weight=\"bold\" as=\"span\" /> }}\n values={getPayrollOverviewTitle(payrollData.payPeriod, dateFormatter)}\n />\n </Text>\n </FlexItem>\n <FlexItem flexGrow={isDesktop ? 1 : 0}>\n <Flex\n flexDirection={isDesktop ? 'row' : 'column'}\n justifyContent={isDesktop ? 'flex-end' : 'normal'}\n alignItems={isDesktop ? 'flex-start' : 'stretch'}\n gap={12}\n >\n {isProcessed ? (\n <>\n <Button onClick={onPayrollReceipt} variant=\"secondary\" isDisabled={isSubmitting}>\n {t('payrollReceiptCta')}\n </Button>\n <Button\n onClick={() => {\n setIsCancelDialogOpen(true)\n }}\n variant=\"error\"\n isDisabled={isSubmitting}\n >\n {t('cancelCta')}\n </Button>\n </>\n ) : (\n <>\n <Button onClick={onEdit} variant=\"secondary\" isDisabled={isSubmitting}>\n {t('editCta')}\n </Button>\n <Button\n onClick={onSubmit}\n isDisabled={\n isSubmitting ||\n (submissionBlockers.length > 0 &&\n (submissionBlockers.some(\n blocker =>\n !PAYROLL_RESOLVABLE_SUBMISSION_BLOCKER_TYPES.includes(\n blocker.blockerType || '',\n ),\n ) ||\n submissionBlockers.some(\n blocker => !selectedUnblockOptions[blocker.blockerType || ''],\n )))\n }\n >\n {t('submitCta')}\n </Button>\n </>\n )}\n </Flex>\n </FlexItem>\n </Flex>\n {isSubmitting ? (\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 {wireInConfirmationRequest}\n {alerts.length > 0 && (\n <Flex flexDirection={'column'} gap={16}>\n {alerts.map((alert, index) => (\n <Alert\n key={`${alert.type}-${alert.title}`}\n label={alert.title}\n status={alert.type}\n >\n {alert.content ?? null}\n </Alert>\n ))}\n </Flex>\n )}\n {submissionBlockers.length > 0 &&\n onUnblockOptionChange &&\n submissionBlockers.map(blocker => {\n const blockerType = blocker.blockerType || ''\n\n if (PAYROLL_RESOLVABLE_SUBMISSION_BLOCKER_TYPES.includes(blockerType)) {\n return (\n <FastAchThresholdExceeded\n key={blockerType}\n blocker={blocker}\n selectedValue={selectedUnblockOptions[blockerType]}\n onUnblockOptionChange={onUnblockOptionChange}\n />\n )\n }\n\n return <GenericBlocker key={blockerType} blocker={blocker} />\n })}\n <Heading as=\"h3\">{t('payrollSummaryTitle')}</Heading>\n <DataView\n label={t('payrollSummaryLabel')}\n columns={[\n {\n title: t('tableHeaders.totalPayroll'),\n render: () => <Text>{formatCurrency(totalPayroll)}</Text>,\n },\n {\n title: t('tableHeaders.debitAmount'),\n render: () => (\n <Text>{formatCurrency(Number(payrollData.totals?.companyDebit ?? 0))}</Text>\n ),\n },\n {\n title: t('tableHeaders.debitAccount'),\n render: () => <Text>{bankAccount?.hiddenAccountNumber ?? ''}</Text>,\n },\n {\n title: t('tableHeaders.debitDate'),\n render: () => <Text>{dateFormatter.formatShortWithYear(expectedDebitDate)}</Text>,\n },\n {\n title: t('tableHeaders.employeesPayDate'),\n render: () => (\n <Text>{dateFormatter.formatShortWithYear(payrollData.checkDate)}</Text>\n ),\n },\n ]}\n data={[{}]}\n />\n {checkPaymentsCount > 0 && (\n <Alert\n status=\"warning\"\n label={t('alerts.checkPaymentWarning', { count: checkPaymentsCount })}\n >\n <Text>{t('alerts.checkPaymentWarningDescription')}</Text>\n </Alert>\n )}\n <Tabs\n onSelectionChange={setSelectedTab}\n selectedId={selectedTab}\n aria-label={t('dataViews.label')}\n tabs={tabs}\n />\n {isCancelDialogOpen && (\n <Dialog\n isOpen={isCancelDialogOpen}\n onClose={() => {\n setIsCancelDialogOpen(false)\n }}\n onPrimaryActionClick={onCancel}\n shouldCloseOnBackdropClick={true}\n primaryActionLabel={t('confirmCancelCta')}\n isDestructive={true}\n closeActionLabel={t('declineCancelCta')}\n title={t('cancelDialogTitle', {\n startDate: dateFormatter.formatLong(payrollData.payPeriod?.startDate),\n endDate: dateFormatter.formatLongWithYear(payrollData.payPeriod?.endDate),\n })}\n >\n <Flex gap={14} flexDirection=\"column\">\n <Text>{t('cancelDialogDescription')}</Text>\n <Text>\n {t('cancelDialogDescriptionDeadline', {\n deadline: dateFormatter.formatWithTime(payrollData.payrollDeadline).time,\n })}\n </Text>\n </Flex>\n </Dialog>\n )}\n </>\n )}\n </Flex>\n </div>\n )\n}\n"],"names":["getPayrollOverviewTitle","payPeriod","dateFormatter","PayrollOverviewPresentation","onEdit","onSubmit","onCancel","onPayrollReceipt","onPaystubDownload","employeeDetails","payrollData","bankAccount","taxes","isSubmitting","isProcessed","alerts","submissionBlockers","selectedUnblockOptions","onUnblockOptionChange","wireInConfirmationRequest","Alert","Button","ButtonIcon","Dialog","Heading","Text","Tabs","LoadingSpinner","useComponentContext","useI18n","useDateFormatter","t","useTranslation","formatCurrency","useNumberFormatter","selectedTab","setSelectedTab","useState","isCancelDialogOpen","setIsCancelDialogOpen","LoadingIndicator","useLoadingIndicator","containerRef","useRef","isDesktop","useContainerBreakpoints","totalPayroll","calculateTotalPayroll","expectedDebitDate","getCompanyTaxes","employeeCompensation","acc","tax","getCompanyBenefits","benefit","getReimbursements","c","compensationTypeLabels","getCompanyCost","employeeMap","employee","getEmployeeHours","employeeCompensations","hourlyCompensation","name","currentHours","getEmployeePtoHours","paidTimeOff","checkPaymentsCount","comp","PAYMENT_METHODS","companyPaysColumns","jsx","firstLastName","DownloadIcon","tabs","DataView","jsxs","Fragment","job","flsaStatus","FlsaStatus","hours","deduction","Flex","taxKey","label","value","styles","FlexItem","Trans","blocker","PAYROLL_RESOLVABLE_SUBMISSION_BLOCKER_TYPES","alert","index","blockerType","FastAchThresholdExceeded","GenericBlocker"],"mappings":";;;;;;;;;;;;;;;;;;AAiDA,MAAMA,KAA0B,CAC9BC,GACAC,MAEID,GAAW,aAAaA,EAAU,UAC7BC,EAAc,gBAAgBD,EAAU,WAAWA,EAAU,OAAO,IAEtE,EAAE,WAAW,IAAI,SAAS,GAAA,GAGtBE,KAA8B,CAAC;AAAA,EAC1C,QAAAC;AAAA,EACA,UAAAC;AAAA,EACA,UAAAC;AAAA,EACA,kBAAAC;AAAA,EACA,mBAAAC;AAAA,EACA,iBAAAC;AAAA,EACA,aAAAC;AAAA,EACA,aAAAC;AAAA,EACA,OAAAC;AAAA,EACA,cAAAC,IAAe;AAAA,EACf,aAAAC;AAAA,EACA,QAAAC,IAAS,CAAA;AAAA,EACT,oBAAAC,IAAqB,CAAA;AAAA,EACrB,wBAAAC,IAAyB,CAAA;AAAA,EACzB,uBAAAC;AAAA,EACA,2BAAAC;AACF,MAA4B;AAC1B,QAAM,EAAE,OAAAC,GAAO,QAAAC,GAAQ,YAAAC,GAAY,QAAAC,GAAQ,SAAAC,GAAS,MAAAC,GAAM,MAAAC,IAAM,gBAAAC,GAAA,IAC9DC,GAAA;AACF,EAAAC,GAAQ,yBAAyB;AACjC,QAAM3B,IAAgB4B,GAAA,GAChB,EAAE,GAAAC,EAAA,IAAMC,GAAe,yBAAyB,GAChDC,IAAiBC,GAAmB,UAAU,GAC9C,CAACC,IAAaC,EAAc,IAAIC,EAAS,aAAa,GACtD,CAACC,GAAoBC,CAAqB,IAAIF,EAAS,EAAK,GAC5D,EAAE,kBAAAG,GAAA,IAAqBC,GAAA,GACvBC,IAAeC,GAAuB,IAAI,GAE1CC,IADcC,GAAwB,EAAE,KAAKH,GAAc,EACnC,SAAS,OAAO,GAExCI,IAAeC,GAAsBrC,CAAW,GAEhDsC,KACJtC,EAAY,mBAAmB,qBAAqBA,EAAY,iBAE5DuC,IAAkB,CAACC,MAErBA,EAAqB,OAAO;AAAA,IAC1B,CAACC,GAAKC,MAASA,EAAI,WAAWD,IAAMC,EAAI,SAASD;AAAA,IACjD;AAAA,EAAA,KACG,GAGHE,IAAqB,CAACH,MAExBA,EAAqB,UAAU;AAAA,IAC7B,CAACC,GAAKG,MAAaA,EAAQ,sBAAsBH,IAAMG,EAAQ,sBAAsBH;AAAA,IACrF;AAAA,EAAA,KACG,GAGHI,IAAoB,CAACL,MAClBA,EAAqB,oBAAoB,SAC5C;AAAA,IACEA,EAAqB,mBAAmB;AAAA,MACtC,OAAKM,EAAE,MAAM,kBAAkBC,EAAuB,mBAAmB,YAAA;AAAA,IAAY,GACpF,UAAU;AAAA,EAAA,IAEf,GAGAC,KAAiB,CAACR,MAEpBA,EAAqB,WACrBK,EAAkBL,CAAoB,IACtCD,EAAgBC,CAAoB,IACpCG,EAAmBH,CAAoB,GAIrCS,IAAc,IAAI,IAAIlD,EAAgB,IAAI,CAAAmD,MAAY,CAACA,EAAS,MAAMA,CAAQ,CAAC,CAAC,GAEhFC,IAAmB,CACvBC,MAGEA,EAAsB,qBAAqB;AAAA,IACzC,CAACX,GAAKY,MAAuB;AAC3B,UAAI,OAAOA,EAAmB,OAAS;AACrC,eAAOZ;AAET,YAAMa,IAAOD,EAAmB,KAAK,YAAA,GAC/BE,IAAed,EAAIa,CAAI,KAAK;AAClC,aAAAb,EAAIa,CAAI,IAAIC,IAAe,OAAOF,EAAmB,SAAS,CAAC,GACxDZ;AAAA,IACT;AAAA,IACA,CAAA;AAAA,EAAC,KACE,CAAA,GAGHe,IAAsB,CAACJ,MAEzBA,EAAsB,aAAa,OAAO,CAACX,GAAKgB,MACvChB,IAAM,OAAOgB,EAAY,SAAS,CAAC,GACzC,CAAC,KAAK,GAIPC,IACJ1D,EAAY,uBAAuB;AAAA,IACjC,CAACyC,GAAKkB,MACJ,CAACA,EAAK,YAAYA,EAAK,kBAAkBC,GAAgB,QAAQnB,IAAM,IAAIA;AAAA,IAC7E;AAAA,EAAA,KACG,GACDoB,IAAqB;AAAA,IACzB;AAAA,MACE,KAAK;AAAA,MACL,OAAOxC,EAAE,wBAAwB;AAAA,MACjC,QAAQ,CAAC+B,MACP,gBAAAU,EAAC/C,KACE,UAAAgD,EAAc;AAAA,QACb,YAAYd,EAAY,IAAIG,EAAsB,YAAa,GAAG;AAAA,QAClE,WAAWH,EAAY,IAAIG,EAAsB,YAAa,GAAG;AAAA,MAAA,CAClE,EAAA,CACH;AAAA,IAAA;AAAA,IAGJ;AAAA,MACE,KAAK;AAAA,MACL,OAAO/B,EAAE,uBAAuB;AAAA,MAChC,QAAQ,CAAC+B,MACP,gBAAAU,EAAC/C,KAAM,UAAAQ,EAAe6B,EAAsB,QAAS,EAAA,CAAE;AAAA,IAAA;AAAA,IAG3D;AAAA,MACE,KAAK;AAAA,MACL,OAAO/B,EAAE,6BAA6B;AAAA,MACtC,QAAQ,CAACmB,MACP,gBAAAsB,EAAC/C,KAAM,UAAAQ,EAAesB,EAAkBL,CAAoB,CAAC,EAAA,CAAE;AAAA,IAAA;AAAA,IAGnE;AAAA,MACE,KAAK;AAAA,MACL,OAAOnB,EAAE,2BAA2B;AAAA,MACpC,QAAQ,CAACmB,MACP,gBAAAsB,EAAC/C,KAAM,UAAAQ,EAAegB,EAAgBC,CAAoB,CAAC,EAAA,CAAE;AAAA,IAAA;AAAA,IAGjE;AAAA,MACE,KAAK;AAAA,MACL,OAAOnB,EAAE,8BAA8B;AAAA,MACvC,QAAQ,CAACmB,MACP,gBAAAsB,EAAC/C,KAAM,UAAAQ,EAAeoB,EAAmBH,CAAoB,CAAC,EAAA,CAAE;AAAA,IAAA;AAAA,IAGpE;AAAA,MACE,KAAK;AAAA,MACL,OAAOnB,EAAE,0BAA0B;AAAA,MACnC,QAAQ,CAACmB,MACP,gBAAAsB,EAAC/C,KAAM,UAAAQ,EAAeyB,GAAeR,CAAoB,CAAC,EAAA,CAAE;AAAA,IAAA;AAAA,EAEhE;AAEF,EAAIpC,KACFyD,EAAmB,KAAK;AAAA,IACtB,KAAK;AAAA,IACL,OAAOxC,EAAE,sBAAsB;AAAA,IAC/B,QAAQ,CAAC+B,MACP,gBAAAU;AAAA,MAAClD;AAAA,MAAA;AAAA,QACC,cAAYS,EAAE,sBAAsB;AAAA,QACpC,SAAQ;AAAA,QACR,SAAS,MAAM;AACb,UAAI+B,EAAsB,gBACxBtD,EAAkBsD,EAAsB,YAAY;AAAA,QAExD;AAAA,QAEA,4BAACY,IAAA,CAAA,CAAa;AAAA,MAAA;AAAA,IAAA;AAAA,EAChB,CAEH;AAEH,QAAMC,KAAO;AAAA,IACX;AAAA,MACE,IAAI;AAAA,MACJ,OAAO5C,EAAE,0BAA0B;AAAA,MACnC,SACE,gBAAAyC;AAAA,QAACI;AAAA,QAAA;AAAA,UACC,OAAO7C,EAAE,4BAA4B;AAAA,UACrC,SAASwC;AAAA,UACT,MAAM7D,EAAY;AAAA,UAClB,QAAQ,OAAO;AAAA,YACb,cACE,gBAAAmE,EAAAC,GAAA,EACE,UAAA;AAAA,cAAA,gBAAAN,EAAC/C,GAAA,EAAM,UAAAM,EAAE,gCAAgC,EAAA,CAAE;AAAA,cAC3C,gBAAAyC,EAAC/C,GAAA,EAAM,UAAAM,EAAE,sCAAsC,EAAA,CAAE;AAAA,YAAA,GACnD;AAAA,YAEF,UAAU,gBAAAyC,EAAC/C,GAAA,EAAM,UAAAQ,EAAe,OAAOvB,EAAY,QAAQ,YAAY,CAAC,CAAC,EAAA,CAAE;AAAA,YAC3E,gBACE,gBAAA8D,EAAC/C,GAAA,EAAM,UAAAQ,EAAe,OAAOvB,EAAY,QAAQ,kBAAkB,CAAC,CAAC,EAAA,CAAE;AAAA,YAEzE,cACE,gBAAA8D,EAAC/C,GAAA,EAAM,UAAAQ,EAAe,OAAOvB,EAAY,QAAQ,iBAAiB,CAAC,CAAC,EAAA,CAAE;AAAA,YAExE,iBACE,gBAAA8D,EAAC/C,GAAA,EAAM,UAAAQ,EAAe,OAAOvB,EAAY,QAAQ,YAAY,CAAC,CAAC,EAAA,CAAE;AAAA,YAEnE,aAAa,gBAAA8D,EAAC/C,GAAA,EAAM,UAAAQ,EAAea,CAAY,EAAA,CAAE;AAAA,UAAA;AAAA,QACnD;AAAA,MAAA;AAAA,IACF;AAAA,IAGJ;AAAA,MACE,IAAI;AAAA,MACJ,OAAOf,EAAE,0BAA0B;AAAA,MACnC,SACE,gBAAAyC;AAAA,QAACI;AAAA,QAAA;AAAA,UACC,OAAO7C,EAAE,4BAA4B;AAAA,UACrC,SAAS;AAAA,YACP;AAAA,cACE,OAAOA,EAAE,wBAAwB;AAAA,cACjC,QAAQ,CAAC+B,MACP,gBAAAU,EAAC/C,KACE,UAAAgD,EAAc;AAAA,gBACb,YAAYd,EAAY,IAAIG,EAAsB,YAAa,GAAG;AAAA,gBAClE,WAAWH,EAAY,IAAIG,EAAsB,YAAa,GAAG;AAAA,cAAA,CAClE,EAAA,CACH;AAAA,YAAA;AAAA,YAGJ;AAAA,cACE,OAAO/B,EAAE,+BAA+B;AAAA,cACxC,QAAQ,CAAC+B,MACP,gBAAAU,EAAC/C,KACE,UAAAkC,EACE,IAAIG,EAAsB,YAAa,GACtC,MAAM,OAAO,CAACX,GAAK4B,MAAQ;AAC3B,oBAAIA,EAAI,SAAS;AACf,wBAAMC,IAAaD,EAAI,eAAe;AAAA,oBACpC,CAAAV,MAAQA,EAAK,SAASU,EAAI;AAAA,kBAAA,GACzB;AAEH,0BAAQC,GAAA;AAAA,oBACN,KAAKC,EAAW;AACd,6BAAOlD,EAAE,+BAA+B;AAAA,oBAC1C,KAAKkD,EAAW;AACd,6BAAOlD,EAAE,kCAAkC;AAAA,oBAC7C;AACE,6BAAOiD,KAAc;AAAA,kBAAA;AAAA,gBAE3B;AACA,uBAAO7B;AAAA,cACT,GAAG,EAAE,EAAA,CACT;AAAA,YAAA;AAAA,YAGJ;AAAA,cACE,OAAOpB,EAAE,sBAAsB;AAAA,cAC/B,QAAQ,CAAC+B,MACP,gBAAAU,EAAC/C,GAAA,EACE,UAAAoC,EAAiBC,CAAqB,EACrCL,EAAuB,kBACzB,KAAK,EAAA,CACP;AAAA,YAAA;AAAA,YAGJ;AAAA,cACE,OAAO1B,EAAE,uBAAuB;AAAA,cAChC,QAAQ,CAAC+B,MACP,gBAAAU,EAAC/C,GAAA,EACE,UAAAoC,EAAiBC,CAAqB,EAAEL,EAAuB,aAAa,KAC3E,EAAA,CACJ;AAAA,YAAA;AAAA,YAGJ;AAAA,cACE,OAAO1B,EAAE,uBAAuB;AAAA,cAChC,QAAQ,CAAC+B,MACP,gBAAAU,EAAC/C,GAAA,EACE,UAAAoC,EAAiBC,CAAqB,EACrCL,EAAuB,oBACzB,KAAK,EAAA,CACP;AAAA,YAAA;AAAA,YAGJ;AAAA,cACE,OAAO1B,EAAE,sBAAsB;AAAA,cAC/B,QAAQ,CAAC+B,wBACNrC,GAAA,EAAM,UAAAyC,EAAoBJ,CAAqB,EAAA,CAAE;AAAA,YAAA;AAAA,YAGtD;AAAA,cACE,OAAO/B,EAAE,yBAAyB;AAAA,cAClC,QAAQ,CAAC+B,MACP,gBAAAU,EAAC/C,GAAA,EACE,iBAAO,OAAOoC,EAAiBC,CAAqB,CAAC,EAAE;AAAA,gBACtD,CAACX,GAAK+B,MAAU/B,IAAM+B;AAAA,gBACtB;AAAA,cAAA,IACEhB,EAAoBJ,CAAqB,EAAA,CAC/C;AAAA,YAAA;AAAA,UAEJ;AAAA,UAEF,MAAMpD,EAAY;AAAA,QAAA;AAAA,MAAA;AAAA,IACpB;AAAA,IAGJ;AAAA,MACE,IAAI;AAAA,MACJ,OAAOqB,EAAE,+BAA+B;AAAA,MACxC,SACE,gBAAAyC;AAAA,QAACI;AAAA,QAAA;AAAA,UACC,OAAO7C,EAAE,iCAAiC;AAAA,UAC1C,SAAS;AAAA,YACP;AAAA,cACE,OAAOA,EAAE,wBAAwB;AAAA,cACjC,QAAQ,CAAC+B,MACP,gBAAAU,EAAC/C,KACE,UAAAgD,EAAc;AAAA,gBACb,YAAYd,EAAY,IAAIG,EAAsB,YAAa,GAAG;AAAA,gBAClE,WAAWH,EAAY,IAAIG,EAAsB,YAAa,GAAG;AAAA,cAAA,CAClE,EAAA,CACH;AAAA,YAAA;AAAA,YAGJ;AAAA,cACE,OAAO/B,EAAE,0BAA0B;AAAA,cACnC,QAAQ,CAAC+B,wBACNrC,GAAA,EAAM,UAAAqC,EAAsB,iBAAiB,GAAA,CAAG;AAAA,YAAA;AAAA,YAGrD;AAAA,cACE,OAAO/B,EAAE,uBAAuB;AAAA,cAChC,QAAQ,CAAC+B,MACP,gBAAAU,EAAC/C,KAAM,UAAAQ,EAAe6B,EAAsB,YAAY,CAAC,EAAA,CAAE;AAAA,YAAA;AAAA,YAG/D;AAAA,cACE,OAAO/B,EAAE,yBAAyB;AAAA,cAClC,QAAQ,CAAC+B,MACP,gBAAAU,EAAC/C,GAAA,EACE,UAAAQ;AAAA,gBACC6B,EAAsB,YAAY;AAAA,kBAChC,CAACX,GAAKgC,MAAchC,IAAMgC,EAAU;AAAA,kBACpC;AAAA,gBAAA,KACG;AAAA,cAAA,EACP,CACF;AAAA,YAAA;AAAA,YAGJ;AAAA,cACE,OAAOpD,EAAE,6BAA6B;AAAA,cACtC,QAAQ,CAAC+B,MACP,gBAAAU,EAAC/C,KAAM,UAAAQ,EAAesB,EAAkBO,CAAqB,CAAC,EAAA,CAAE;AAAA,YAAA;AAAA,YAGpE;AAAA,cACE,OAAO/B,EAAE,4BAA4B;AAAA,cACrC,QAAQ,CAAC+B,MACP,gBAAAU,EAAC/C,GAAA,EACE,UAAAQ;AAAA,gBACC6B,EAAsB,OAAO;AAAA,kBAC3B,CAACX,GAAKC,MAASA,EAAI,WAAWD,IAAMA,IAAMC,EAAI;AAAA,kBAC9C;AAAA,gBAAA,KACG;AAAA,cAAA,EACP,CACF;AAAA,YAAA;AAAA,YAGJ;AAAA,cACE,OAAOrB,EAAE,+BAA+B;AAAA,cACxC,QAAQ,CAAC+B,MACP,gBAAAU,EAAC/C,GAAA,EACE,UAAAQ;AAAA,gBACC6B,EAAsB,UAAU;AAAA,kBAC9B,CAACX,GAAKG,MAAYH,KAAOG,EAAQ,qBAAqB;AAAA,kBACtD;AAAA,gBAAA,KACG;AAAA,cAAA,EACP,CACF;AAAA,YAAA;AAAA,YAGJ;AAAA,cACE,OAAOvB,EAAE,sBAAsB;AAAA,cAC/B,QAAQ,CAAC+B,MACP,gBAAAU,EAAC/C,KAAM,UAAAQ,EAAe6B,EAAsB,UAAU,CAAC,EAAA,CAAE;AAAA,YAAA;AAAA,UAE7D;AAAA,UAEF,MAAMpD,EAAY;AAAA,QAAA;AAAA,MAAA;AAAA,IACpB;AAAA,IAGJ;AAAA,MACE,IAAI;AAAA,MACJ,OAAOqB,EAAE,oBAAoB;AAAA,MAC7B,SACE,gBAAA8C,EAACO,GAAA,EAAK,eAAc,UAAS,KAAK,IAChC,UAAA;AAAA,QAAA,gBAAAZ;AAAA,UAACI;AAAA,UAAA;AAAA,YACC,OAAO7C,EAAE,sBAAsB;AAAA,YAC/B,SAAS;AAAA,cACP;AAAA,gBACE,KAAK;AAAA,gBACL,OAAOA,EAAE,6BAA6B;AAAA,gBACtC,QAAQ,CAAAsD,MAAU,gBAAAb,EAAC/C,GAAA,EAAM,UAAA4D,EAAA,CAAO;AAAA,cAAA;AAAA,cAElC;AAAA,gBACE,KAAK;AAAA,gBACL,OAAOtD,EAAE,8BAA8B;AAAA,gBACvC,QAAQ,CAAAsD,MAAU,gBAAAb,EAAC/C,GAAA,EAAM,UAAAQ,EAAerB,EAAMyE,CAAM,GAAG,YAAY,CAAC,EAAA,CAAE;AAAA,cAAA;AAAA,cAExE;AAAA,gBACE,KAAK;AAAA,gBACL,OAAOtD,EAAE,4BAA4B;AAAA,gBACrC,QAAQ,CAAAsD,MAAU,gBAAAb,EAAC/C,GAAA,EAAM,UAAAQ,EAAerB,EAAMyE,CAAM,GAAG,YAAY,CAAC,EAAA,CAAE;AAAA,cAAA;AAAA,YACxE;AAAA,YAEF,QAAQ,OAAO;AAAA,cACb,gBAAgB,gBAAAb,EAAC/C,GAAA,EAAM,UAAAM,EAAE,aAAa,GAAE;AAAA,cACxC,iBACE,gBAAAyC,EAAC/C,GAAA,EAAM,UAAAQ,EAAe,OAAOvB,EAAY,QAAQ,iBAAiB,CAAC,CAAC,EAAA,CAAE;AAAA,cAExE,eACE,gBAAA8D,EAAC/C,GAAA,EAAM,UAAAQ,EAAe,OAAOvB,EAAY,QAAQ,iBAAiB,CAAC,CAAC,EAAA,CAAE;AAAA,YAAA;AAAA,YAG1E,MAAM,OAAO,KAAKE,CAAK;AAAA,UAAA;AAAA,QAAA;AAAA,QAGzB,gBAAA4D;AAAA,UAACI;AAAA,UAAA;AAAA,YACC,OAAO7C,EAAE,wBAAwB;AAAA,YACjC,SAAS;AAAA,cACP;AAAA,gBACE,OAAOA,EAAE,6BAA6B;AAAA,gBACtC,QAAQ,CAAC,EAAE,OAAAuD,QAAY,gBAAAd,EAAC/C,KAAM,UAAA6D,EAAA,CAAM;AAAA,cAAA;AAAA,cAEtC;AAAA,gBACE,OAAOvD,EAAE,yBAAyB;AAAA,gBAClC,QAAQ,CAAC,EAAE,OAAAwD,EAAA,MAAY,gBAAAf,EAAC/C,GAAA,EAAM,UAAAQ,EAAe,OAAOsD,CAAK,CAAC,EAAA,CAAE;AAAA,cAAA;AAAA,YAC9D;AAAA,YAEF,MAAM;AAAA,cACJ,EAAE,OAAOxD,EAAE,oBAAoB,GAAG,OAAOrB,EAAY,QAAQ,eAAe,IAAA;AAAA,cAC5E;AAAA,gBACE,OAAOqB,EAAE,oBAAoB;AAAA,gBAC7B,OAAOrB,EAAY,QAAQ,sBAAsB;AAAA,cAAA;AAAA,cAEnD;AAAA,gBACE,OAAOqB,EAAE,mBAAmB;AAAA,gBAC5B,OAAOrB,EAAY,QAAQ,qBAAqB;AAAA,cAAA;AAAA,cAElD,EAAE,OAAOqB,EAAE,YAAY,GAAG,OAAOrB,EAAY,QAAQ,YAAY,IAAA;AAAA,YAAI;AAAA,UACvE;AAAA,QAAA;AAAA,MACF,EAAA,CACF;AAAA,IAAA;AAAA,EAEJ;AAGF,SACE,gBAAA8D,EAAC,OAAA,EAAI,KAAK9B,GAAc,WAAW8C,GAAO,WACxC,UAAA,gBAAAX,EAACO,GAAA,EAAK,eAAc,UAAS,YAAW,WACtC,UAAA;AAAA,IAAA,gBAAAP;AAAA,MAACO;AAAA,MAAA;AAAA,QACC,eAAexC,IAAY,QAAQ;AAAA,QACnC,gBAAgBA,IAAY,kBAAkB;AAAA,QAC9C,YAAYA,IAAY,eAAe;AAAA,QACvC,KAAKA,IAAY,IAAI;AAAA,QAErB,UAAA;AAAA,UAAA,gBAAAiC,EAACY,GAAA,EAAS,UAAU,GAClB,UAAA;AAAA,YAAA,gBAAAjB,EAAChD,GAAA,EAAQ,IAAG,MAAM,UAAcO,EAAdjB,IAAgB,iBAAoB,eAAN,EAAqB,CAAE;AAAA,8BACtEW,GAAA,EACC,UAAA,gBAAA+C;AAAA,cAACkB;AAAA,cAAA;AAAA,gBACC,SAAQ;AAAA,gBACR,GAAA3D;AAAA,gBACA,YAAY,EAAE,aAAa,gBAAAyC,EAAC/C,KAAK,QAAO,QAAO,IAAG,OAAA,CAAO,EAAA;AAAA,gBACzD,QAAQzB,GAAwBU,EAAY,WAAWR,CAAa;AAAA,cAAA;AAAA,YAAA,EACtE,CACF;AAAA,UAAA,GACF;AAAA,UACA,gBAAAsE,EAACiB,GAAA,EAAS,UAAU7C,IAAY,IAAI,GAClC,UAAA,gBAAA4B;AAAA,YAACY;AAAA,YAAA;AAAA,cACC,eAAexC,IAAY,QAAQ;AAAA,cACnC,gBAAgBA,IAAY,aAAa;AAAA,cACzC,YAAYA,IAAY,eAAe;AAAA,cACvC,KAAK;AAAA,cAEJ,cACC,gBAAAiC,EAAAC,GAAA,EACE,UAAA;AAAA,gBAAA,gBAAAN,EAACnD,GAAA,EAAO,SAASd,GAAkB,SAAQ,aAAY,YAAYM,GAChE,UAAAkB,EAAE,mBAAmB,EAAA,CACxB;AAAA,gBACA,gBAAAyC;AAAA,kBAACnD;AAAA,kBAAA;AAAA,oBACC,SAAS,MAAM;AACb,sBAAAkB,EAAsB,EAAI;AAAA,oBAC5B;AAAA,oBACA,SAAQ;AAAA,oBACR,YAAY1B;AAAA,oBAEX,YAAE,WAAW;AAAA,kBAAA;AAAA,gBAAA;AAAA,cAChB,EAAA,CACF,IAEA,gBAAAgE,EAAAC,GAAA,EACE,UAAA;AAAA,gBAAA,gBAAAN,EAACnD,GAAA,EAAO,SAASjB,GAAQ,SAAQ,aAAY,YAAYS,GACtD,UAAAkB,EAAE,SAAS,EAAA,CACd;AAAA,gBACA,gBAAAyC;AAAA,kBAACnD;AAAA,kBAAA;AAAA,oBACC,SAAShB;AAAA,oBACT,YACEQ,KACCG,EAAmB,SAAS,MAC1BA,EAAmB;AAAA,sBAClB,CAAA2E,MACE,CAACC,EAA4C;AAAA,wBAC3CD,EAAQ,eAAe;AAAA,sBAAA;AAAA,oBACzB,KAEF3E,EAAmB;AAAA,sBACjB,CAAA2E,MAAW,CAAC1E,EAAuB0E,EAAQ,eAAe,EAAE;AAAA,oBAAA;AAAA,oBAInE,YAAE,WAAW;AAAA,kBAAA;AAAA,gBAAA;AAAA,cAChB,EAAA,CACF;AAAA,YAAA;AAAA,UAAA,EAEJ,CACF;AAAA,QAAA;AAAA,MAAA;AAAA,IAAA;AAAA,IAED9E,IACC,gBAAA2D,EAAChC,IAAA,EACC,UAAA,gBAAAqC,EAACO,GAAA,EAAK,eAAc,UAAS,YAAW,UAAS,KAAK,GACpD,UAAA;AAAA,MAAA,gBAAAZ,EAAC7C,IAAA,EAAe,MAAK,KAAA,CAAK;AAAA,wBACzBH,GAAA,EAAQ,IAAG,MAAM,UAAAO,EAAE,cAAc,GAAE;AAAA,MACpC,gBAAAyC,EAAC/C,GAAA,EAAM,UAAAM,EAAE,oBAAoB,EAAA,CAAE;AAAA,IAAA,EAAA,CACjC,EAAA,CACF,IAEA,gBAAA8C,EAAAC,GAAA,EACG,UAAA;AAAA,MAAA3D;AAAA,MACAJ,EAAO,SAAS,KACf,gBAAAyD,EAACY,GAAA,EAAK,eAAe,UAAU,KAAK,IACjC,UAAArE,EAAO,IAAI,CAAC8E,GAAOC,MAClB,gBAAAtB;AAAA,QAACpD;AAAA,QAAA;AAAA,UAEC,OAAOyE,EAAM;AAAA,UACb,QAAQA,EAAM;AAAA,UAEb,YAAM,WAAW;AAAA,QAAA;AAAA,QAJb,GAAGA,EAAM,IAAI,IAAIA,EAAM,KAAK;AAAA,MAAA,CAMpC,GACH;AAAA,MAED7E,EAAmB,SAAS,KAC3BE,KACAF,EAAmB,IAAI,CAAA2E,MAAW;AAChC,cAAMI,IAAcJ,EAAQ,eAAe;AAE3C,eAAIC,EAA4C,SAASG,CAAW,IAEhE,gBAAAvB;AAAA,UAACwB;AAAA,UAAA;AAAA,YAEC,SAAAL;AAAA,YACA,eAAe1E,EAAuB8E,CAAW;AAAA,YACjD,uBAAA7E;AAAA,UAAA;AAAA,UAHK6E;AAAA,QAAA,IAQJ,gBAAAvB,EAACyB,IAAA,EAAiC,SAAAN,EAAA,GAAbI,CAA+B;AAAA,MAC7D,CAAC;AAAA,wBACFvE,GAAA,EAAQ,IAAG,MAAM,UAAAO,EAAE,qBAAqB,GAAE;AAAA,MAC3C,gBAAAyC;AAAA,QAACI;AAAA,QAAA;AAAA,UACC,OAAO7C,EAAE,qBAAqB;AAAA,UAC9B,SAAS;AAAA,YACP;AAAA,cACE,OAAOA,EAAE,2BAA2B;AAAA,cACpC,QAAQ,MAAM,gBAAAyC,EAAC/C,GAAA,EAAM,UAAAQ,EAAea,CAAY,EAAA,CAAE;AAAA,YAAA;AAAA,YAEpD;AAAA,cACE,OAAOf,EAAE,0BAA0B;AAAA,cACnC,QAAQ,MACN,gBAAAyC,EAAC/C,GAAA,EAAM,UAAAQ,EAAe,OAAOvB,EAAY,QAAQ,gBAAgB,CAAC,CAAC,EAAA,CAAE;AAAA,YAAA;AAAA,YAGzE;AAAA,cACE,OAAOqB,EAAE,2BAA2B;AAAA,cACpC,QAAQ,MAAM,gBAAAyC,EAAC/C,GAAA,EAAM,UAAAd,GAAa,uBAAuB,GAAA,CAAG;AAAA,YAAA;AAAA,YAE9D;AAAA,cACE,OAAOoB,EAAE,wBAAwB;AAAA,cACjC,QAAQ,MAAM,gBAAAyC,EAAC/C,KAAM,UAAAvB,EAAc,oBAAoB8C,EAAiB,EAAA,CAAE;AAAA,YAAA;AAAA,YAE5E;AAAA,cACE,OAAOjB,EAAE,+BAA+B;AAAA,cACxC,QAAQ,MACN,gBAAAyC,EAAC/C,GAAA,EAAM,YAAc,oBAAoBf,EAAY,SAAS,EAAA,CAAE;AAAA,YAAA;AAAA,UAEpE;AAAA,UAEF,MAAM,CAAC,CAAA,CAAE;AAAA,QAAA;AAAA,MAAA;AAAA,MAEV0D,IAAqB,KACpB,gBAAAI;AAAA,QAACpD;AAAA,QAAA;AAAA,UACC,QAAO;AAAA,UACP,OAAOW,EAAE,8BAA8B,EAAE,OAAOqC,GAAoB;AAAA,UAEpE,UAAA,gBAAAI,EAAC/C,GAAA,EAAM,UAAAM,EAAE,uCAAuC,EAAA,CAAE;AAAA,QAAA;AAAA,MAAA;AAAA,MAGtD,gBAAAyC;AAAA,QAAC9C;AAAA,QAAA;AAAA,UACC,mBAAmBU;AAAA,UACnB,YAAYD;AAAA,UACZ,cAAYJ,EAAE,iBAAiB;AAAA,UAC/B,MAAA4C;AAAA,QAAA;AAAA,MAAA;AAAA,MAEDrC,KACC,gBAAAkC;AAAA,QAACjD;AAAA,QAAA;AAAA,UACC,QAAQe;AAAA,UACR,SAAS,MAAM;AACb,YAAAC,EAAsB,EAAK;AAAA,UAC7B;AAAA,UACA,sBAAsBjC;AAAA,UACtB,4BAA4B;AAAA,UAC5B,oBAAoByB,EAAE,kBAAkB;AAAA,UACxC,eAAe;AAAA,UACf,kBAAkBA,EAAE,kBAAkB;AAAA,UACtC,OAAOA,EAAE,qBAAqB;AAAA,YAC5B,WAAW7B,EAAc,WAAWQ,EAAY,WAAW,SAAS;AAAA,YACpE,SAASR,EAAc,mBAAmBQ,EAAY,WAAW,OAAO;AAAA,UAAA,CACzE;AAAA,UAED,UAAA,gBAAAmE,EAACO,GAAA,EAAK,KAAK,IAAI,eAAc,UAC3B,UAAA;AAAA,YAAA,gBAAAZ,EAAC/C,GAAA,EAAM,UAAAM,EAAE,yBAAyB,EAAA,CAAE;AAAA,YACpC,gBAAAyC,EAAC/C,GAAA,EACE,UAAAM,EAAE,mCAAmC;AAAA,cACpC,UAAU7B,EAAc,eAAeQ,EAAY,eAAe,EAAE;AAAA,YAAA,CACrE,EAAA,CACH;AAAA,UAAA,EAAA,CACF;AAAA,QAAA;AAAA,MAAA;AAAA,IACF,EAAA,CAEJ;AAAA,EAAA,EAAA,CAEJ,EAAA,CACF;AAEJ;"}
1
+ {"version":3,"file":"PayrollOverviewPresentation.js","sources":["../../../../src/components/Payroll/PayrollOverview/PayrollOverviewPresentation.tsx"],"sourcesContent":["import { Trans, useTranslation } from 'react-i18next'\nimport type {\n EmployeeCompensations,\n PayrollShow,\n} from '@gusto/embedded-api/models/components/payrollshow'\nimport type { PayrollPayPeriodType } from '@gusto/embedded-api/models/components/payrollpayperiodtype'\nimport type { CompanyBankAccount } from '@gusto/embedded-api/models/components/companybankaccount'\nimport { useState, useRef } from 'react'\nimport type { Employee } from '@gusto/embedded-api/models/components/employee'\nimport type { PayrollSubmissionBlockersType } from '@gusto/embedded-api/models/components/payrollsubmissionblockerstype'\nimport type { PayrollFlowAlert } from '../PayrollFlow/PayrollFlowComponents'\nimport { calculateTotalPayroll } from '../helpers'\nimport { FastAchThresholdExceeded, GenericBlocker } from './SubmissionBlockers'\nimport styles from './PayrollOverviewPresentation.module.scss'\nimport { DataView, Flex, FlexItem } from '@/components/Common'\nimport { useContainerBreakpoints } from '@/hooks/useContainerBreakpoints/useContainerBreakpoints'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { useI18n } from '@/i18n'\nimport { useDateFormatter } from '@/hooks/useDateFormatter'\nimport useNumberFormatter from '@/hooks/useNumberFormatter'\nimport { firstLastName } from '@/helpers/formattedStrings'\nimport {\n compensationTypeLabels,\n FlsaStatus,\n PAYROLL_RESOLVABLE_SUBMISSION_BLOCKER_TYPES,\n PAYMENT_METHODS,\n} from '@/shared/constants'\nimport DownloadIcon from '@/assets/icons/download-cloud.svg?react'\nimport { useLoadingIndicator } from '@/contexts/LoadingIndicatorProvider/useLoadingIndicator'\n\ninterface PayrollOverviewProps {\n payrollData: PayrollShow\n bankAccount?: CompanyBankAccount\n employeeDetails: Employee[]\n taxes: Record<string, { employee: number; employer: number }>\n isSubmitting?: boolean\n isProcessed: boolean\n alerts?: PayrollFlowAlert[]\n submissionBlockers?: PayrollSubmissionBlockersType[]\n selectedUnblockOptions?: Record<string, string>\n wireInConfirmationRequest?: React.ReactNode\n onEdit: () => void\n onSubmit: () => void\n onCancel: () => void\n onPayrollReceipt: () => void\n onPaystubDownload: (employeeId: string) => void\n onUnblockOptionChange?: (blockerType: string, value: string) => void\n}\n\nconst getPayrollOverviewTitle = (\n payPeriod: PayrollPayPeriodType | undefined,\n dateFormatter: ReturnType<typeof useDateFormatter>,\n) => {\n if (payPeriod?.startDate && payPeriod.endDate) {\n return dateFormatter.formatPayPeriod(payPeriod.startDate, payPeriod.endDate)\n }\n return { startDate: '', endDate: '' }\n}\n\nexport const PayrollOverviewPresentation = ({\n onEdit,\n onSubmit,\n onCancel,\n onPayrollReceipt,\n onPaystubDownload,\n employeeDetails,\n payrollData,\n bankAccount,\n taxes,\n isSubmitting = false,\n isProcessed,\n alerts = [],\n submissionBlockers = [],\n selectedUnblockOptions = {},\n onUnblockOptionChange,\n wireInConfirmationRequest,\n}: PayrollOverviewProps) => {\n const { Alert, Button, ButtonIcon, Dialog, Heading, Text, Tabs, LoadingSpinner } =\n useComponentContext()\n useI18n('Payroll.PayrollOverview')\n const dateFormatter = useDateFormatter()\n const { t } = useTranslation('Payroll.PayrollOverview')\n const formatCurrency = useNumberFormatter('currency')\n const [selectedTab, setSelectedTab] = useState('companyPays')\n const [isCancelDialogOpen, setIsCancelDialogOpen] = useState(false)\n const { LoadingIndicator } = useLoadingIndicator()\n const containerRef = useRef<HTMLDivElement>(null)\n const breakpoints = useContainerBreakpoints({ ref: containerRef })\n const isDesktop = breakpoints.includes('small')\n\n const totalPayroll = calculateTotalPayroll(payrollData)\n\n const expectedDebitDate =\n payrollData.payrollStatusMeta?.expectedDebitTime ?? payrollData.payrollDeadline\n\n const getCompanyTaxes = (employeeCompensation: EmployeeCompensations) => {\n return (\n employeeCompensation.taxes?.reduce(\n (acc, tax) => (tax.employer ? acc + tax.amount : acc),\n 0,\n ) ?? 0\n )\n }\n const getCompanyBenefits = (employeeCompensation: EmployeeCompensations) => {\n return (\n employeeCompensation.benefits?.reduce(\n (acc, benefit) => (benefit.companyContribution ? acc + benefit.companyContribution : acc),\n 0,\n ) ?? 0\n )\n }\n const getReimbursements = (employeeCompensation: EmployeeCompensations) => {\n return employeeCompensation.fixedCompensations?.length\n ? Number(\n employeeCompensation.fixedCompensations.find(\n c => c.name?.toLowerCase() === compensationTypeLabels.REIMBURSEMENT_NAME.toLowerCase(),\n )?.amount || 0,\n )\n : 0\n }\n\n const getCompanyCost = (employeeCompensation: EmployeeCompensations) => {\n return (\n employeeCompensation.grossPay! +\n getReimbursements(employeeCompensation) +\n getCompanyTaxes(employeeCompensation) +\n getCompanyBenefits(employeeCompensation)\n )\n }\n\n const employeeMap = new Map(employeeDetails.map(employee => [employee.uuid, employee]))\n\n const getEmployeeHours = (\n employeeCompensations: EmployeeCompensations,\n ): Record<string, number> => {\n return (\n employeeCompensations.hourlyCompensations?.reduce(\n (acc, hourlyCompensation) => {\n if (typeof hourlyCompensation.name === 'undefined') {\n return acc\n }\n const name = hourlyCompensation.name.toLowerCase()\n const currentHours = acc[name] ?? 0\n acc[name] = currentHours + Number(hourlyCompensation.hours || 0)\n return acc\n },\n {} as Record<string, number>,\n ) || {}\n )\n }\n const getEmployeePtoHours = (employeeCompensations: EmployeeCompensations) => {\n return (\n employeeCompensations.paidTimeOff?.reduce((acc, paidTimeOff) => {\n return acc + Number(paidTimeOff.hours || 0)\n }, 0) ?? 0\n )\n }\n\n const checkPaymentsCount =\n payrollData.employeeCompensations?.reduce(\n (acc, comp) =>\n !comp.excluded && comp.paymentMethod === PAYMENT_METHODS.check ? acc + 1 : acc,\n 0,\n ) ?? 0\n const companyPaysColumns = [\n {\n key: 'employeeName',\n title: t('tableHeaders.employees'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {firstLastName({\n first_name: employeeMap.get(employeeCompensations.employeeUuid!)?.firstName,\n last_name: employeeMap.get(employeeCompensations.employeeUuid!)?.lastName,\n })}\n </Text>\n ),\n },\n {\n key: 'grossPay',\n title: t('tableHeaders.grossPay'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>{formatCurrency(employeeCompensations.grossPay!)}</Text>\n ),\n },\n {\n key: 'reimbursements',\n title: t('tableHeaders.reimbursements'),\n render: (employeeCompensation: EmployeeCompensations) => (\n <Text>{formatCurrency(getReimbursements(employeeCompensation))}</Text>\n ),\n },\n {\n key: 'companyTaxes',\n title: t('tableHeaders.companyTaxes'),\n render: (employeeCompensation: EmployeeCompensations) => (\n <Text>{formatCurrency(getCompanyTaxes(employeeCompensation))}</Text>\n ),\n },\n {\n key: 'companyBenefits',\n title: t('tableHeaders.companyBenefits'),\n render: (employeeCompensation: EmployeeCompensations) => (\n <Text>{formatCurrency(getCompanyBenefits(employeeCompensation))}</Text>\n ),\n },\n {\n key: 'companyPays',\n title: t('tableHeaders.companyPays'),\n render: (employeeCompensation: EmployeeCompensations) => (\n <Text>{formatCurrency(getCompanyCost(employeeCompensation))}</Text>\n ),\n },\n ]\n if (isProcessed) {\n companyPaysColumns.push({\n key: 'paystubs',\n title: t('tableHeaders.paystub'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <ButtonIcon\n aria-label={t('downloadPaystubLabel')}\n variant=\"tertiary\"\n onClick={() => {\n if (employeeCompensations.employeeUuid) {\n onPaystubDownload(employeeCompensations.employeeUuid)\n }\n }}\n >\n <DownloadIcon />\n </ButtonIcon>\n ),\n })\n }\n const tabs = [\n {\n id: 'companyPays',\n label: t('dataViews.companyPaysTab'),\n content: (\n <DataView\n label={t('dataViews.companyPaysTable')}\n columns={companyPaysColumns}\n data={payrollData.employeeCompensations!}\n footer={() => ({\n employeeName: (\n <>\n <Text>{t('tableHeaders.footerTotalsLabel')}</Text>\n <Text>{t('tableHeaders.footerTotalsDescription')}</Text>\n </>\n ),\n grossPay: <Text>{formatCurrency(Number(payrollData.totals?.grossPay ?? 0))}</Text>,\n reimbursements: (\n <Text>{formatCurrency(Number(payrollData.totals?.reimbursements ?? 0))}</Text>\n ),\n companyTaxes: (\n <Text>{formatCurrency(Number(payrollData.totals?.employerTaxes ?? 0))}</Text>\n ),\n companyBenefits: (\n <Text>{formatCurrency(Number(payrollData.totals?.benefits ?? 0))}</Text>\n ),\n companyPays: <Text>{formatCurrency(totalPayroll)}</Text>,\n })}\n />\n ),\n },\n {\n id: 'hoursWorked',\n label: t('dataViews.hoursWorkedTab'),\n content: (\n <DataView\n label={t('dataViews.hoursWorkedTable')}\n columns={[\n {\n title: t('tableHeaders.employees'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {firstLastName({\n first_name: employeeMap.get(employeeCompensations.employeeUuid!)?.firstName,\n last_name: employeeMap.get(employeeCompensations.employeeUuid!)?.lastName,\n })}\n </Text>\n ),\n },\n {\n title: t('tableHeaders.compensationType'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {employeeMap\n .get(employeeCompensations.employeeUuid!)\n ?.jobs?.reduce((acc, job) => {\n if (job.primary) {\n const flsaStatus = job.compensations?.find(\n comp => comp.uuid === job.currentCompensationUuid,\n )?.flsaStatus\n\n switch (flsaStatus) {\n case FlsaStatus.EXEMPT:\n return t('compensationTypeLabels.exempt')\n case FlsaStatus.NONEXEMPT:\n return t('compensationTypeLabels.nonexempt')\n default:\n return flsaStatus ?? ''\n }\n }\n return acc\n }, '')}\n </Text>\n ),\n },\n {\n title: t('tableHeaders.regular'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {getEmployeeHours(employeeCompensations)[\n compensationTypeLabels.REGULAR_HOURS_NAME\n ] || 0}\n </Text>\n ),\n },\n {\n title: t('tableHeaders.overtime'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {getEmployeeHours(employeeCompensations)[compensationTypeLabels.OVERTIME_NAME] ||\n 0}\n </Text>\n ),\n },\n {\n title: t('tableHeaders.doubleOT'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {getEmployeeHours(employeeCompensations)[\n compensationTypeLabels.DOUBLE_OVERTIME_NAME\n ] || 0}\n </Text>\n ),\n },\n {\n title: t('tableHeaders.timeOff'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>{getEmployeePtoHours(employeeCompensations)}</Text>\n ),\n },\n {\n title: t('tableHeaders.totalHours'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {Object.values(getEmployeeHours(employeeCompensations)).reduce(\n (acc, hours) => acc + hours,\n 0,\n ) + getEmployeePtoHours(employeeCompensations)}\n </Text>\n ),\n },\n ]}\n data={payrollData.employeeCompensations!}\n />\n ),\n },\n {\n id: 'employeeTakeHome',\n label: t('dataViews.employeeTakeHomeTab'),\n content: (\n <DataView\n label={t('dataViews.employeeTakeHomeTable')}\n columns={[\n {\n title: t('tableHeaders.employees'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {firstLastName({\n first_name: employeeMap.get(employeeCompensations.employeeUuid!)?.firstName,\n last_name: employeeMap.get(employeeCompensations.employeeUuid!)?.lastName,\n })}\n </Text>\n ),\n },\n {\n title: t('tableHeaders.paymentType'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>{employeeCompensations.paymentMethod ?? ''}</Text>\n ),\n },\n {\n title: t('tableHeaders.grossPay'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>{formatCurrency(employeeCompensations.grossPay ?? 0)}</Text>\n ),\n },\n {\n title: t('tableHeaders.deductions'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {formatCurrency(\n employeeCompensations.deductions?.reduce(\n (acc, deduction) => acc + deduction.amount!,\n 0,\n ) ?? 0,\n )}\n </Text>\n ),\n },\n {\n title: t('tableHeaders.reimbursements'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>{formatCurrency(getReimbursements(employeeCompensations))}</Text>\n ),\n },\n {\n title: t('tableHeaders.employeeTaxes'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {formatCurrency(\n employeeCompensations.taxes?.reduce(\n (acc, tax) => (tax.employer ? acc : acc + tax.amount),\n 0,\n ) ?? 0,\n )}\n </Text>\n ),\n },\n {\n title: t('tableHeaders.employeeBenefits'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>\n {formatCurrency(\n employeeCompensations.benefits?.reduce(\n (acc, benefit) => acc + (benefit.employeeDeduction ?? 0),\n 0,\n ) ?? 0,\n )}\n </Text>\n ),\n },\n {\n title: t('tableHeaders.payment'),\n render: (employeeCompensations: EmployeeCompensations) => (\n <Text>{formatCurrency(employeeCompensations.netPay ?? 0)}</Text>\n ),\n },\n ]}\n data={payrollData.employeeCompensations!}\n />\n ),\n },\n {\n id: 'taxes',\n label: t('dataViews.taxesTab'),\n content: (\n <Flex flexDirection=\"column\" gap={32}>\n <DataView\n label={t('dataViews.taxesTable')}\n columns={[\n {\n key: 'taxDescription',\n title: t('tableHeaders.taxDescription'),\n render: taxKey => <Text>{taxKey}</Text>,\n },\n {\n key: 'byYourEmployees',\n title: t('tableHeaders.byYourEmployees'),\n render: taxKey => <Text>{formatCurrency(taxes[taxKey]?.employee ?? 0)}</Text>,\n },\n {\n key: 'byYourCompany',\n title: t('tableHeaders.byYourCompany'),\n render: taxKey => <Text>{formatCurrency(taxes[taxKey]?.employer ?? 0)}</Text>,\n },\n ]}\n footer={() => ({\n taxDescription: <Text>{t('totalsLabel')}</Text>,\n byYourEmployees: (\n <Text>{formatCurrency(Number(payrollData.totals?.employeeTaxes ?? 0))}</Text>\n ),\n byYourCompany: (\n <Text>{formatCurrency(Number(payrollData.totals?.employerTaxes ?? 0))}</Text>\n ),\n })}\n data={Object.keys(taxes)}\n />\n\n <DataView\n label={t('dataViews.debitedTable')}\n columns={[\n {\n title: t('tableHeaders.debitedByGusto'),\n render: ({ label }) => <Text>{label}</Text>,\n },\n {\n title: t('tableHeaders.taxesTotal'),\n render: ({ value }) => <Text>{formatCurrency(Number(value))}</Text>,\n },\n ]}\n data={[\n { label: t('directDepositLabel'), value: payrollData.totals?.netPayDebit || '0' },\n {\n label: t('reimbursementLabel'),\n value: payrollData.totals?.reimbursementDebit || '0',\n },\n {\n label: t('garnishmentsLabel'),\n value: payrollData.totals?.childSupportDebit || '0',\n },\n { label: t('taxesLabel'), value: payrollData.totals?.taxDebit || '0' },\n ]}\n />\n </Flex>\n ),\n },\n ]\n\n return (\n <div ref={containerRef} className={styles.container}>\n <Flex flexDirection=\"column\" alignItems=\"stretch\">\n <Flex\n flexDirection={isDesktop ? 'row' : 'column'}\n justifyContent={isDesktop ? 'space-between' : 'normal'}\n alignItems={isDesktop ? 'flex-start' : 'stretch'}\n gap={isDesktop ? 0 : 16}\n >\n <FlexItem flexGrow={1}>\n <Heading as=\"h1\">{isProcessed ? t('summaryTitle') : t('overviewTitle')}</Heading>\n <Text>\n <Trans\n i18nKey=\"pageSubtitle\"\n t={t}\n components={{ dateWrapper: <Text weight=\"bold\" as=\"span\" /> }}\n values={getPayrollOverviewTitle(payrollData.payPeriod, dateFormatter)}\n />\n </Text>\n </FlexItem>\n <FlexItem flexGrow={isDesktop ? 1 : 0}>\n <Flex\n flexDirection={isDesktop ? 'row' : 'column'}\n justifyContent={isDesktop ? 'flex-end' : 'normal'}\n alignItems={isDesktop ? 'flex-start' : 'stretch'}\n gap={12}\n >\n {isProcessed ? (\n <>\n <Button onClick={onPayrollReceipt} variant=\"secondary\" isDisabled={isSubmitting}>\n {t('payrollReceiptCta')}\n </Button>\n <Button\n onClick={() => {\n setIsCancelDialogOpen(true)\n }}\n variant=\"error\"\n isDisabled={isSubmitting}\n >\n {t('cancelCta')}\n </Button>\n </>\n ) : (\n <>\n <Button onClick={onEdit} variant=\"secondary\" isDisabled={isSubmitting}>\n {t('editCta')}\n </Button>\n <Button\n onClick={onSubmit}\n isDisabled={\n isSubmitting ||\n (submissionBlockers.length > 0 &&\n (submissionBlockers.some(\n blocker =>\n !PAYROLL_RESOLVABLE_SUBMISSION_BLOCKER_TYPES.includes(\n blocker.blockerType || '',\n ),\n ) ||\n submissionBlockers.some(\n blocker => !selectedUnblockOptions[blocker.blockerType || ''],\n )))\n }\n >\n {t('submitCta')}\n </Button>\n </>\n )}\n </Flex>\n </FlexItem>\n </Flex>\n {isSubmitting ? (\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 {wireInConfirmationRequest}\n {alerts.length > 0 && (\n <Flex flexDirection={'column'} gap={16}>\n {alerts.map((alert, index) => (\n <Alert\n key={`${alert.type}-${alert.title}`}\n label={alert.title}\n status={alert.type}\n >\n {alert.content ?? null}\n </Alert>\n ))}\n </Flex>\n )}\n {submissionBlockers.length > 0 &&\n onUnblockOptionChange &&\n submissionBlockers.map(blocker => {\n const blockerType = blocker.blockerType || ''\n\n if (PAYROLL_RESOLVABLE_SUBMISSION_BLOCKER_TYPES.includes(blockerType)) {\n return (\n <FastAchThresholdExceeded\n key={blockerType}\n blocker={blocker}\n selectedValue={selectedUnblockOptions[blockerType]}\n onUnblockOptionChange={onUnblockOptionChange}\n />\n )\n }\n\n return <GenericBlocker key={blockerType} blocker={blocker} />\n })}\n <Heading as=\"h3\">{t('payrollSummaryTitle')}</Heading>\n <DataView\n label={t('payrollSummaryLabel')}\n columns={[\n {\n title: t('tableHeaders.totalPayroll'),\n render: () => <Text>{formatCurrency(totalPayroll)}</Text>,\n },\n {\n title: t('tableHeaders.debitAmount'),\n render: () => (\n <Text>{formatCurrency(Number(payrollData.totals?.companyDebit ?? 0))}</Text>\n ),\n },\n {\n title: t('tableHeaders.debitAccount'),\n render: () => <Text>{bankAccount?.hiddenAccountNumber ?? ''}</Text>,\n },\n {\n title: t('tableHeaders.debitDate'),\n render: () => <Text>{dateFormatter.formatShortWithYear(expectedDebitDate)}</Text>,\n },\n {\n title: t('tableHeaders.employeesPayDate'),\n render: () => (\n <Text>{dateFormatter.formatShortWithYear(payrollData.checkDate)}</Text>\n ),\n },\n ]}\n data={[{}]}\n />\n {checkPaymentsCount > 0 && (\n <Alert\n status=\"warning\"\n label={t('alerts.checkPaymentWarning', { count: checkPaymentsCount })}\n >\n <Text>{t('alerts.checkPaymentWarningDescription')}</Text>\n </Alert>\n )}\n <Tabs\n onSelectionChange={setSelectedTab}\n selectedId={selectedTab}\n aria-label={t('dataViews.label')}\n tabs={tabs}\n />\n {isCancelDialogOpen && (\n <Dialog\n isOpen={isCancelDialogOpen}\n onClose={() => {\n setIsCancelDialogOpen(false)\n }}\n onPrimaryActionClick={onCancel}\n shouldCloseOnBackdropClick={true}\n primaryActionLabel={t('confirmCancelCta')}\n isDestructive={true}\n closeActionLabel={t('declineCancelCta')}\n title={t('cancelDialogTitle', {\n startDate: dateFormatter.formatLong(payrollData.payPeriod?.startDate),\n endDate: dateFormatter.formatLongWithYear(payrollData.payPeriod?.endDate),\n })}\n >\n <Flex gap={14} flexDirection=\"column\">\n <Text>{t('cancelDialogDescription')}</Text>\n <Text>\n {t('cancelDialogDescriptionDeadline', {\n deadline: dateFormatter.formatWithTime(payrollData.payrollDeadline).time,\n })}\n </Text>\n </Flex>\n </Dialog>\n )}\n </>\n )}\n </Flex>\n </div>\n )\n}\n"],"names":["getPayrollOverviewTitle","payPeriod","dateFormatter","PayrollOverviewPresentation","onEdit","onSubmit","onCancel","onPayrollReceipt","onPaystubDownload","employeeDetails","payrollData","bankAccount","taxes","isSubmitting","isProcessed","alerts","submissionBlockers","selectedUnblockOptions","onUnblockOptionChange","wireInConfirmationRequest","Alert","Button","ButtonIcon","Dialog","Heading","Text","Tabs","LoadingSpinner","useComponentContext","useI18n","useDateFormatter","t","useTranslation","formatCurrency","useNumberFormatter","selectedTab","setSelectedTab","useState","isCancelDialogOpen","setIsCancelDialogOpen","LoadingIndicator","useLoadingIndicator","containerRef","useRef","isDesktop","useContainerBreakpoints","totalPayroll","calculateTotalPayroll","expectedDebitDate","getCompanyTaxes","employeeCompensation","acc","tax","getCompanyBenefits","benefit","getReimbursements","c","compensationTypeLabels","getCompanyCost","employeeMap","employee","getEmployeeHours","employeeCompensations","hourlyCompensation","name","currentHours","getEmployeePtoHours","paidTimeOff","checkPaymentsCount","comp","PAYMENT_METHODS","companyPaysColumns","jsx","firstLastName","DownloadIcon","tabs","DataView","jsxs","Fragment","job","flsaStatus","FlsaStatus","hours","deduction","Flex","taxKey","label","value","styles","FlexItem","Trans","blocker","PAYROLL_RESOLVABLE_SUBMISSION_BLOCKER_TYPES","alert","index","blockerType","FastAchThresholdExceeded","GenericBlocker"],"mappings":"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"}
@@ -1,19 +1,22 @@
1
1
  import { jsx as t, jsxs as r } from "react/jsx-runtime";
2
2
  import { useTranslation as b } from "react-i18next";
3
3
  import { Flex as a } from "../../../Common/Flex/Flex.js";
4
+ import "classnames";
5
+ import "../../../../shared/constants.js";
4
6
  import { useComponentContext as f } from "../../../../contexts/ComponentAdapter/useComponentContext.js";
7
+ import "react";
5
8
  import { useDateFormatter as x } from "../../../../hooks/useDateFormatter.js";
6
9
  import k from "../../../../assets/icons/icon-zap-fast.svg.js";
7
- const v = ({
10
+ const C = ({
8
11
  blocker: l,
9
12
  selectedValue: d,
10
13
  onUnblockOptionChange: n
11
14
  }) => {
12
- const { t: e } = b("Payroll.PayrollOverview"), { Banner: h, Text: i, RadioGroup: _, Badge: c } = f(), m = x();
15
+ const { t: e } = b("Payroll.PayrollOverview"), { Banner: h, Text: i, RadioGroup: m, Badge: c } = f(), _ = x();
13
16
  return /* @__PURE__ */ t(h, { status: "error", title: e("submissionBlockers.fast_ach_threshold_exceeded.title"), children: /* @__PURE__ */ r(a, { flexDirection: "column", gap: 16, children: [
14
17
  /* @__PURE__ */ t(i, { children: e("submissionBlockers.fast_ach_threshold_exceeded.description") }),
15
18
  /* @__PURE__ */ t(
16
- _,
19
+ m,
17
20
  {
18
21
  label: e("submissionBlockers.fast_ach_threshold_exceeded.fundingOptionsLabel"),
19
22
  shouldVisuallyHideLabel: !0,
@@ -29,7 +32,7 @@ const v = ({
29
32
  e("submissionBlockers.fast_ach_threshold_exceeded.wireFastestBadge")
30
33
  ] }),
31
34
  s.checkDate && /* @__PURE__ */ t(c, { status: "info", children: e("submissionBlockers.fast_ach_threshold_exceeded.employeePayDate", {
32
- date: m.formatShortWithYear(s.checkDate)
35
+ date: _.formatShortWithYear(s.checkDate)
33
36
  }) })
34
37
  ] }),
35
38
  description: p
@@ -44,6 +47,6 @@ const v = ({
44
47
  ] }) });
45
48
  };
46
49
  export {
47
- v as FastAchThresholdExceeded
50
+ C as FastAchThresholdExceeded
48
51
  };
49
52
  //# sourceMappingURL=FastAchThresholdExceeded.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"FastAchThresholdExceeded.js","sources":["../../../../../src/components/Payroll/PayrollOverview/SubmissionBlockers/FastAchThresholdExceeded.tsx"],"sourcesContent":["import { useTranslation } from 'react-i18next'\nimport type { PayrollSubmissionBlockersType } from '@gusto/embedded-api/models/components/payrollsubmissionblockerstype'\nimport { Flex } from '@/components/Common'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { useDateFormatter } from '@/hooks/useDateFormatter'\nimport IconFast from '@/assets/icons/icon-zap-fast.svg?react'\n\ninterface FastAchThresholdExceededProps {\n blocker: PayrollSubmissionBlockersType\n selectedValue?: string\n onUnblockOptionChange: (blockerType: string, value: string) => void\n}\n\nexport const FastAchThresholdExceeded = ({\n blocker,\n selectedValue,\n onUnblockOptionChange,\n}: FastAchThresholdExceededProps) => {\n const { t } = useTranslation('Payroll.PayrollOverview')\n const { Banner, Text, RadioGroup, Badge } = useComponentContext()\n const dateFormatter = useDateFormatter()\n\n return (\n <Banner status=\"error\" title={t('submissionBlockers.fast_ach_threshold_exceeded.title')}>\n <Flex flexDirection=\"column\" gap={16}>\n <Text>{t('submissionBlockers.fast_ach_threshold_exceeded.description')}</Text>\n <RadioGroup\n label={t('submissionBlockers.fast_ach_threshold_exceeded.fundingOptionsLabel')}\n shouldVisuallyHideLabel\n options={\n blocker.unblockOptions?.map(option => {\n const isWire = option.unblockType === 'wire_in'\n const label = isWire\n ? t('submissionBlockers.fast_ach_threshold_exceeded.wireLabel')\n : t('submissionBlockers.fast_ach_threshold_exceeded.directDepositLabel')\n const description = isWire\n ? t('submissionBlockers.fast_ach_threshold_exceeded.wireDescription')\n : t('submissionBlockers.fast_ach_threshold_exceeded.directDepositDescription')\n\n return {\n value: option.unblockType || '',\n label: (\n <Flex alignItems=\"center\" gap={8}>\n <Text weight=\"semibold\">{label}</Text>\n {isWire && (\n <Badge status=\"success\">\n <IconFast aria-hidden />{' '}\n {t('submissionBlockers.fast_ach_threshold_exceeded.wireFastestBadge')}\n </Badge>\n )}\n {option.checkDate && (\n <Badge status=\"info\">\n {t('submissionBlockers.fast_ach_threshold_exceeded.employeePayDate', {\n date: dateFormatter.formatShortWithYear(option.checkDate),\n })}\n </Badge>\n )}\n </Flex>\n ),\n description,\n }\n }) || []\n }\n value={selectedValue}\n onChange={value => {\n onUnblockOptionChange('fast_ach_threshold_exceeded', value)\n }}\n />\n </Flex>\n </Banner>\n )\n}\n"],"names":["FastAchThresholdExceeded","blocker","selectedValue","onUnblockOptionChange","t","useTranslation","Banner","Text","RadioGroup","Badge","useComponentContext","dateFormatter","useDateFormatter","jsx","jsxs","Flex","option","isWire","label","description","IconFast","value"],"mappings":";;;;;;AAaO,MAAMA,IAA2B,CAAC;AAAA,EACvC,SAAAC;AAAA,EACA,eAAAC;AAAA,EACA,uBAAAC;AACF,MAAqC;AACnC,QAAM,EAAE,GAAAC,EAAA,IAAMC,EAAe,yBAAyB,GAChD,EAAE,QAAAC,GAAQ,MAAAC,GAAM,YAAAC,GAAY,OAAAC,EAAA,IAAUC,EAAA,GACtCC,IAAgBC,EAAA;AAEtB,SACE,gBAAAC,EAACP,GAAA,EAAO,QAAO,SAAQ,OAAOF,EAAE,sDAAsD,GACpF,UAAA,gBAAAU,EAACC,GAAA,EAAK,eAAc,UAAS,KAAK,IAChC,UAAA;AAAA,IAAA,gBAAAF,EAACN,GAAA,EAAM,UAAAH,EAAE,4DAA4D,EAAA,CAAE;AAAA,IACvE,gBAAAS;AAAA,MAACL;AAAA,MAAA;AAAA,QACC,OAAOJ,EAAE,oEAAoE;AAAA,QAC7E,yBAAuB;AAAA,QACvB,SACEH,EAAQ,gBAAgB,IAAI,CAAAe,MAAU;AACpC,gBAAMC,IAASD,EAAO,gBAAgB,WAChCE,IACFd,EADUa,IACR,6DACA,mEAD0D,GAE1DE,IACFf,EADgBa,IACd,mEACA,yEADgE;AAGtE,iBAAO;AAAA,YACL,OAAOD,EAAO,eAAe;AAAA,YAC7B,OACE,gBAAAF,EAACC,GAAA,EAAK,YAAW,UAAS,KAAK,GAC7B,UAAA;AAAA,cAAA,gBAAAF,EAACN,GAAA,EAAK,QAAO,YAAY,UAAAW,GAAM;AAAA,cAC9BD,KACC,gBAAAH,EAACL,GAAA,EAAM,QAAO,WACZ,UAAA;AAAA,gBAAA,gBAAAI,EAACO,GAAA,EAAS,eAAW,GAAA,CAAC;AAAA,gBAAG;AAAA,gBACxBhB,EAAE,iEAAiE;AAAA,cAAA,GACtE;AAAA,cAEDY,EAAO,aACN,gBAAAH,EAACJ,KAAM,QAAO,QACX,YAAE,kEAAkE;AAAA,gBACnE,MAAME,EAAc,oBAAoBK,EAAO,SAAS;AAAA,cAAA,CACzD,EAAA,CACH;AAAA,YAAA,GAEJ;AAAA,YAEF,aAAAG;AAAA,UAAA;AAAA,QAEJ,CAAC,KAAK,CAAA;AAAA,QAER,OAAOjB;AAAA,QACP,UAAU,CAAAmB,MAAS;AACjB,UAAAlB,EAAsB,+BAA+BkB,CAAK;AAAA,QAC5D;AAAA,MAAA;AAAA,IAAA;AAAA,EACF,EAAA,CACF,EAAA,CACF;AAEJ;"}
1
+ {"version":3,"file":"FastAchThresholdExceeded.js","sources":["../../../../../src/components/Payroll/PayrollOverview/SubmissionBlockers/FastAchThresholdExceeded.tsx"],"sourcesContent":["import { useTranslation } from 'react-i18next'\nimport type { PayrollSubmissionBlockersType } from '@gusto/embedded-api/models/components/payrollsubmissionblockerstype'\nimport { Flex } from '@/components/Common'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { useDateFormatter } from '@/hooks/useDateFormatter'\nimport IconFast from '@/assets/icons/icon-zap-fast.svg?react'\n\ninterface FastAchThresholdExceededProps {\n blocker: PayrollSubmissionBlockersType\n selectedValue?: string\n onUnblockOptionChange: (blockerType: string, value: string) => void\n}\n\nexport const FastAchThresholdExceeded = ({\n blocker,\n selectedValue,\n onUnblockOptionChange,\n}: FastAchThresholdExceededProps) => {\n const { t } = useTranslation('Payroll.PayrollOverview')\n const { Banner, Text, RadioGroup, Badge } = useComponentContext()\n const dateFormatter = useDateFormatter()\n\n return (\n <Banner status=\"error\" title={t('submissionBlockers.fast_ach_threshold_exceeded.title')}>\n <Flex flexDirection=\"column\" gap={16}>\n <Text>{t('submissionBlockers.fast_ach_threshold_exceeded.description')}</Text>\n <RadioGroup\n label={t('submissionBlockers.fast_ach_threshold_exceeded.fundingOptionsLabel')}\n shouldVisuallyHideLabel\n options={\n blocker.unblockOptions?.map(option => {\n const isWire = option.unblockType === 'wire_in'\n const label = isWire\n ? t('submissionBlockers.fast_ach_threshold_exceeded.wireLabel')\n : t('submissionBlockers.fast_ach_threshold_exceeded.directDepositLabel')\n const description = isWire\n ? t('submissionBlockers.fast_ach_threshold_exceeded.wireDescription')\n : t('submissionBlockers.fast_ach_threshold_exceeded.directDepositDescription')\n\n return {\n value: option.unblockType || '',\n label: (\n <Flex alignItems=\"center\" gap={8}>\n <Text weight=\"semibold\">{label}</Text>\n {isWire && (\n <Badge status=\"success\">\n <IconFast aria-hidden />{' '}\n {t('submissionBlockers.fast_ach_threshold_exceeded.wireFastestBadge')}\n </Badge>\n )}\n {option.checkDate && (\n <Badge status=\"info\">\n {t('submissionBlockers.fast_ach_threshold_exceeded.employeePayDate', {\n date: dateFormatter.formatShortWithYear(option.checkDate),\n })}\n </Badge>\n )}\n </Flex>\n ),\n description,\n }\n }) || []\n }\n value={selectedValue}\n onChange={value => {\n onUnblockOptionChange('fast_ach_threshold_exceeded', value)\n }}\n />\n </Flex>\n </Banner>\n )\n}\n"],"names":["FastAchThresholdExceeded","blocker","selectedValue","onUnblockOptionChange","t","useTranslation","Banner","Text","RadioGroup","Badge","useComponentContext","dateFormatter","useDateFormatter","jsx","jsxs","Flex","option","isWire","label","description","IconFast","value"],"mappings":";;;;;;;;;AAaO,MAAMA,IAA2B,CAAC;AAAA,EACvC,SAAAC;AAAA,EACA,eAAAC;AAAA,EACA,uBAAAC;AACF,MAAqC;AACnC,QAAM,EAAE,GAAAC,EAAA,IAAMC,EAAe,yBAAyB,GAChD,EAAE,QAAAC,GAAQ,MAAAC,GAAM,YAAAC,GAAY,OAAAC,EAAA,IAAUC,EAAA,GACtCC,IAAgBC,EAAA;AAEtB,SACE,gBAAAC,EAACP,GAAA,EAAO,QAAO,SAAQ,OAAOF,EAAE,sDAAsD,GACpF,UAAA,gBAAAU,EAACC,GAAA,EAAK,eAAc,UAAS,KAAK,IAChC,UAAA;AAAA,IAAA,gBAAAF,EAACN,GAAA,EAAM,UAAAH,EAAE,4DAA4D,EAAA,CAAE;AAAA,IACvE,gBAAAS;AAAA,MAACL;AAAA,MAAA;AAAA,QACC,OAAOJ,EAAE,oEAAoE;AAAA,QAC7E,yBAAuB;AAAA,QACvB,SACEH,EAAQ,gBAAgB,IAAI,CAAAe,MAAU;AACpC,gBAAMC,IAASD,EAAO,gBAAgB,WAChCE,IACFd,EADUa,IACR,6DACA,mEAD0D,GAE1DE,IACFf,EADgBa,IACd,mEACA,yEADgE;AAGtE,iBAAO;AAAA,YACL,OAAOD,EAAO,eAAe;AAAA,YAC7B,OACE,gBAAAF,EAACC,GAAA,EAAK,YAAW,UAAS,KAAK,GAC7B,UAAA;AAAA,cAAA,gBAAAF,EAACN,GAAA,EAAK,QAAO,YAAY,UAAAW,GAAM;AAAA,cAC9BD,KACC,gBAAAH,EAACL,GAAA,EAAM,QAAO,WACZ,UAAA;AAAA,gBAAA,gBAAAI,EAACO,GAAA,EAAS,eAAW,GAAA,CAAC;AAAA,gBAAG;AAAA,gBACxBhB,EAAE,iEAAiE;AAAA,cAAA,GACtE;AAAA,cAEDY,EAAO,aACN,gBAAAH,EAACJ,KAAM,QAAO,QACX,YAAE,kEAAkE;AAAA,gBACnE,MAAME,EAAc,oBAAoBK,EAAO,SAAS;AAAA,cAAA,CACzD,EAAA,CACH;AAAA,YAAA,GAEJ;AAAA,YAEF,aAAAG;AAAA,UAAA;AAAA,QAEJ,CAAC,KAAK,CAAA;AAAA,QAER,OAAOjB;AAAA,QACP,UAAU,CAAAmB,MAAS;AACjB,UAAAlB,EAAsB,+BAA+BkB,CAAK;AAAA,QAC5D;AAAA,MAAA;AAAA,IAAA;AAAA,EACF,EAAA,CACF,EAAA,CACF;AAEJ;"}
@@ -4,6 +4,7 @@ import { useTranslation as R } from "react-i18next";
4
4
  import d from "classnames";
5
5
  import i from "./PayrollReceiptsPresentation.module.scss.js";
6
6
  import { Flex as a } from "../../Common/Flex/Flex.js";
7
+ import "../../../shared/constants.js";
7
8
  import { useComponentContext as L } from "../../../contexts/ComponentAdapter/useComponentContext.js";
8
9
  import { formatNumberAsCurrency as r } from "../../../helpers/formattedStrings.js";
9
10
  import { useI18n as I } from "../../../i18n/I18n.js";
@@ -11,7 +12,7 @@ import { useContainerBreakpoints as S } from "../../../hooks/useContainerBreakpo
11
12
  import z from "../../../assets/icons/receipt-check.svg.js";
12
13
  import { DataTable as b } from "../../Common/DataView/DataTable/DataTable.js";
13
14
  import { DataView as h } from "../../Common/DataView/DataView.js";
14
- const K = ({ receiptData: n }) => {
15
+ const Q = ({ receiptData: n }) => {
15
16
  const { Heading: p, Text: o } = L();
16
17
  I("Payroll.PayrollReceipts");
17
18
  const { t } = R("Payroll.PayrollReceipts"), u = P(null), c = !S({ ref: u }).includes("small"), y = (l) => `${l.employeeFirstName || ""} ${l.employeeLastName || ""}`.trim(), g = () => (n.employeeCompensations || []).reduce(
@@ -214,6 +215,6 @@ const K = ({ receiptData: n }) => {
214
215
  ] }) });
215
216
  };
216
217
  export {
217
- K as PayrollReceiptsPresentation
218
+ Q as PayrollReceiptsPresentation
218
219
  };
219
220
  //# sourceMappingURL=PayrollReceiptsPresentation.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PayrollReceiptsPresentation.js","sources":["../../../../src/components/Payroll/PayrollReceipts/PayrollReceiptsPresentation.tsx"],"sourcesContent":["import { useRef } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport classNames from 'classnames'\nimport type {\n PayrollReceipt,\n Taxes as TaxBreakdownItem,\n PayrollReceiptEmployeeCompensations as EmployeeBreakdownItem,\n} from '@gusto/embedded-api/models/components/payrollreceipt'\nimport styles from './PayrollReceiptsPresentation.module.scss'\nimport { DataView, DataTable, Flex } from '@/components/Common'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { formatNumberAsCurrency } from '@/helpers/formattedStrings'\nimport { useI18n } from '@/i18n'\nimport { useContainerBreakpoints } from '@/hooks/useContainerBreakpoints/useContainerBreakpoints'\nimport ReceiptCheck from '@/assets/icons/receipt-check.svg?react'\n\ninterface PayrollReceiptsPresentationProps {\n receiptData: PayrollReceipt\n}\n\nexport const PayrollReceiptsPresentation = ({ receiptData }: PayrollReceiptsPresentationProps) => {\n const { Heading, Text } = useComponentContext()\n useI18n('Payroll.PayrollReceipts')\n const { t } = useTranslation('Payroll.PayrollReceipts')\n\n const containerRef = useRef<HTMLDivElement>(null)\n const breakpoints = useContainerBreakpoints({ ref: containerRef })\n const isMobile = !breakpoints.includes('small')\n\n // Helper to get employee full name\n const getEmployeeFullName = (emp: EmployeeBreakdownItem) =>\n `${emp.employeeFirstName || ''} ${emp.employeeLastName || ''}`.trim()\n\n const getTotalChildSupport = () =>\n (receiptData.employeeCompensations || []).reduce(\n (sum, emp) => sum + parseFloat(emp.childSupportGarnishment || '0'),\n 0,\n )\n\n const getTotalReimbursements = () =>\n (receiptData.employeeCompensations || []).reduce(\n (sum, emp) => sum + parseFloat(emp.totalReimbursement || '0'),\n 0,\n )\n\n const getTotalNetPay = () =>\n (receiptData.employeeCompensations || []).reduce(\n (sum, emp) => sum + parseFloat(emp.netPay || '0'),\n 0,\n )\n\n const getTotalTaxes = () =>\n (receiptData.employeeCompensations || []).reduce(\n (sum, emp) => sum + parseFloat(emp.totalTax || '0'),\n 0,\n )\n\n const breakdownData = [\n {\n label: t('breakdown.directDeposits'),\n amount: parseFloat(receiptData.totals?.netPayDebit || '0'),\n },\n {\n label: t('breakdown.reimbursements'),\n amount: parseFloat(receiptData.totals?.reimbursementDebit || '0'),\n },\n {\n label: t('breakdown.garnishments'),\n amount: parseFloat(receiptData.totals?.childSupportDebit || '0'),\n },\n { label: t('breakdown.taxes'), amount: parseFloat(receiptData.totals?.taxDebit || '0') },\n ]\n\n const receiptDetailsConfig = [\n {\n label: t('receipt.receiptId'),\n value: receiptData.payrollUuid || '',\n },\n {\n label: t('receipt.from'),\n value: receiptData.nameOfSender || '',\n },\n {\n label: t('receipt.to'),\n value: receiptData.nameOfRecipient || 'Payroll Recipients',\n },\n {\n label: t('receipt.debitDate'),\n value: receiptData.debitDate || '',\n },\n ]\n\n const renderReceiptHeader = () => (\n <div className={classNames(styles.receiptHeader, isMobile && styles.receiptHeaderMobile)}>\n <Flex flexDirection=\"column\" gap={24}>\n <Flex flexDirection=\"column\" alignItems=\"center\" gap={16}>\n <div className={styles.receiptIcon}>\n <ReceiptCheck className={styles.checkmarkIcon} />\n </div>\n\n <Flex flexDirection=\"column\" alignItems=\"center\" gap={8}>\n <Text size=\"sm\" variant=\"supporting\">\n {t('receipt.totalLabel')}\n </Text>\n <Heading as=\"h1\" styledAs=\"h2\" className={styles.totalAmount}>\n {formatNumberAsCurrency(parseFloat(receiptData.totals?.companyDebit || '0'))}\n </Heading>\n </Flex>\n </Flex>\n\n <div className={styles.receiptDetailsTable}>\n <DataView\n label={t('receipt.detailsLabel')}\n variant=\"minimal\"\n breakAt=\"small\"\n breakpoints={{\n base: '0rem',\n small: '22rem',\n }}\n columns={[\n {\n title: '',\n render: (item: { label: string; value: string }) => (\n <Text size=\"sm\" variant=\"supporting\">\n {item.label}\n </Text>\n ),\n },\n {\n title: '',\n render: (item: { label: string; value: string }) => (\n <Text size=\"sm\">{item.value}</Text>\n ),\n },\n ]}\n data={receiptDetailsConfig}\n />\n </div>\n\n <Flex flexDirection=\"column\" alignItems=\"center\" gap={12}>\n <Text\n size=\"sm\"\n variant=\"supporting\"\n className={classNames(styles.disclaimer, isMobile && styles.textMobile)}\n >\n {receiptData.recipientNotice}\n </Text>\n\n <Text\n size=\"sm\"\n variant=\"supporting\"\n className={classNames(styles.companyInfo, isMobile && styles.textMobile)}\n >\n {receiptData.license}\n </Text>\n\n <Text\n size=\"sm\"\n variant=\"supporting\"\n className={classNames(styles.address, isMobile && styles.textMobile)}\n >\n {receiptData.licensee &&\n `${receiptData.licensee.address || ''}, ${receiptData.licensee.city || ''}, ${receiptData.licensee.state || ''} ${receiptData.licensee.postalCode || ''}`}\n </Text>\n </Flex>\n </Flex>\n </div>\n )\n\n const renderBreakdownSection = () => (\n <Flex flexDirection=\"column\" gap={16}>\n <DataTable\n label={t('sections.debitedLabel')}\n columns={[\n {\n title: t('sections.debitedLabel'),\n render: (item: { label: string; amount: number }) => <Text>{item.label}</Text>,\n },\n {\n title: t('breakdown.amount'),\n render: (item: { label: string; amount: number }) => (\n <Text>{formatNumberAsCurrency(item.amount)}</Text>\n ),\n },\n ]}\n data={breakdownData}\n footer={() => ({\n 'column-0': <Text weight=\"semibold\">{t('breakdown.totals')}</Text>,\n 'column-1': (\n <Text weight=\"semibold\">\n {formatNumberAsCurrency(parseFloat(receiptData.totals?.companyDebit || '0'))}\n </Text>\n ),\n })}\n />\n </Flex>\n )\n\n const renderTaxBreakdown = () => (\n <Flex flexDirection=\"column\" gap={16}>\n <DataTable\n label={t('sections.taxLabel')}\n columns={[\n {\n title: t('sections.taxLabel'),\n render: (tax: TaxBreakdownItem) => <Text>{tax.name}</Text>,\n },\n {\n title: t('tax.amount'),\n render: (tax: TaxBreakdownItem) => (\n <Text>{formatNumberAsCurrency(parseFloat(tax.amount || '0'))}</Text>\n ),\n },\n ]}\n data={receiptData.taxes || []}\n footer={() => ({\n 'column-0': <Text weight=\"semibold\">{t('breakdown.totals')}</Text>,\n 'column-1': (\n <Text weight=\"semibold\">\n {formatNumberAsCurrency(parseFloat(receiptData.totals?.taxDebit || '0'))}\n </Text>\n ),\n })}\n />\n </Flex>\n )\n\n const renderEmployeeBreakdown = () => (\n <Flex flexDirection=\"column\" gap={16}>\n {isMobile && <Heading as=\"h2\">{t('sections.employeesLabel')}</Heading>}\n <DataView\n label={t('sections.employeesLabel')}\n columns={[\n {\n title: t('employee.name'),\n render: (employee: EmployeeBreakdownItem) => (\n <Text>{getEmployeeFullName(employee)}</Text>\n ),\n },\n {\n title: t('employee.paymentMethod'),\n render: (employee: EmployeeBreakdownItem) => (\n <Text>{employee.paymentMethod || 'N/A'}</Text>\n ),\n },\n {\n title: t('employee.childSupport'),\n render: (employee: EmployeeBreakdownItem) => (\n <Text>\n {formatNumberAsCurrency(parseFloat(employee.childSupportGarnishment || '0'))}\n </Text>\n ),\n },\n {\n title: t('employee.reimbursement'),\n render: (employee: EmployeeBreakdownItem) => (\n <Text>{formatNumberAsCurrency(parseFloat(employee.totalReimbursement || '0'))}</Text>\n ),\n },\n {\n title: t('employee.totalTaxes'),\n render: (employee: EmployeeBreakdownItem) => (\n <Text>{formatNumberAsCurrency(parseFloat(employee.totalTax || '0'))}</Text>\n ),\n },\n {\n title: t('employee.netPay'),\n render: (employee: EmployeeBreakdownItem) => (\n <Text>{formatNumberAsCurrency(parseFloat(employee.netPay || '0'))}</Text>\n ),\n },\n ]}\n data={receiptData.employeeCompensations || []}\n footer={() => ({\n 'column-0': (\n <Flex flexDirection=\"column\" gap={4}>\n <Text weight=\"semibold\">{t('breakdown.totals')}</Text>\n <Text size=\"sm\" variant=\"supporting\">\n {t('employee.totalEmployees', {\n count: receiptData.employeeCompensations?.length || 0,\n })}\n </Text>\n </Flex>\n ),\n 'column-1': <Text>{'\\u00A0'}</Text>,\n 'column-2': (\n <Text weight=\"semibold\">{formatNumberAsCurrency(getTotalChildSupport())}</Text>\n ),\n 'column-3': (\n <Text weight=\"semibold\">{formatNumberAsCurrency(getTotalReimbursements())}</Text>\n ),\n 'column-4': <Text weight=\"semibold\">{formatNumberAsCurrency(getTotalTaxes())}</Text>,\n 'column-5': <Text weight=\"semibold\">{formatNumberAsCurrency(getTotalNetPay())}</Text>,\n })}\n />\n </Flex>\n )\n\n return (\n <div className={styles.container} ref={containerRef}>\n <Flex flexDirection=\"column\" gap={24}>\n {renderReceiptHeader()}\n {renderBreakdownSection()}\n {renderTaxBreakdown()}\n {renderEmployeeBreakdown()}\n </Flex>\n </div>\n )\n}\n"],"names":["PayrollReceiptsPresentation","receiptData","Heading","Text","useComponentContext","useI18n","useTranslation","containerRef","useRef","isMobile","useContainerBreakpoints","getEmployeeFullName","emp","getTotalChildSupport","sum","getTotalReimbursements","getTotalNetPay","getTotalTaxes","breakdownData","receiptDetailsConfig","renderReceiptHeader","jsx","classNames","styles","jsxs","Flex","ReceiptCheck","formatNumberAsCurrency","DataView","item","renderBreakdownSection","DataTable","renderTaxBreakdown","tax","renderEmployeeBreakdown","employee"],"mappings":"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"}
1
+ {"version":3,"file":"PayrollReceiptsPresentation.js","sources":["../../../../src/components/Payroll/PayrollReceipts/PayrollReceiptsPresentation.tsx"],"sourcesContent":["import { useRef } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport classNames from 'classnames'\nimport type {\n PayrollReceipt,\n Taxes as TaxBreakdownItem,\n PayrollReceiptEmployeeCompensations as EmployeeBreakdownItem,\n} from '@gusto/embedded-api/models/components/payrollreceipt'\nimport styles from './PayrollReceiptsPresentation.module.scss'\nimport { DataView, DataTable, Flex } from '@/components/Common'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { formatNumberAsCurrency } from '@/helpers/formattedStrings'\nimport { useI18n } from '@/i18n'\nimport { useContainerBreakpoints } from '@/hooks/useContainerBreakpoints/useContainerBreakpoints'\nimport ReceiptCheck from '@/assets/icons/receipt-check.svg?react'\n\ninterface PayrollReceiptsPresentationProps {\n receiptData: PayrollReceipt\n}\n\nexport const PayrollReceiptsPresentation = ({ receiptData }: PayrollReceiptsPresentationProps) => {\n const { Heading, Text } = useComponentContext()\n useI18n('Payroll.PayrollReceipts')\n const { t } = useTranslation('Payroll.PayrollReceipts')\n\n const containerRef = useRef<HTMLDivElement>(null)\n const breakpoints = useContainerBreakpoints({ ref: containerRef })\n const isMobile = !breakpoints.includes('small')\n\n // Helper to get employee full name\n const getEmployeeFullName = (emp: EmployeeBreakdownItem) =>\n `${emp.employeeFirstName || ''} ${emp.employeeLastName || ''}`.trim()\n\n const getTotalChildSupport = () =>\n (receiptData.employeeCompensations || []).reduce(\n (sum, emp) => sum + parseFloat(emp.childSupportGarnishment || '0'),\n 0,\n )\n\n const getTotalReimbursements = () =>\n (receiptData.employeeCompensations || []).reduce(\n (sum, emp) => sum + parseFloat(emp.totalReimbursement || '0'),\n 0,\n )\n\n const getTotalNetPay = () =>\n (receiptData.employeeCompensations || []).reduce(\n (sum, emp) => sum + parseFloat(emp.netPay || '0'),\n 0,\n )\n\n const getTotalTaxes = () =>\n (receiptData.employeeCompensations || []).reduce(\n (sum, emp) => sum + parseFloat(emp.totalTax || '0'),\n 0,\n )\n\n const breakdownData = [\n {\n label: t('breakdown.directDeposits'),\n amount: parseFloat(receiptData.totals?.netPayDebit || '0'),\n },\n {\n label: t('breakdown.reimbursements'),\n amount: parseFloat(receiptData.totals?.reimbursementDebit || '0'),\n },\n {\n label: t('breakdown.garnishments'),\n amount: parseFloat(receiptData.totals?.childSupportDebit || '0'),\n },\n { label: t('breakdown.taxes'), amount: parseFloat(receiptData.totals?.taxDebit || '0') },\n ]\n\n const receiptDetailsConfig = [\n {\n label: t('receipt.receiptId'),\n value: receiptData.payrollUuid || '',\n },\n {\n label: t('receipt.from'),\n value: receiptData.nameOfSender || '',\n },\n {\n label: t('receipt.to'),\n value: receiptData.nameOfRecipient || 'Payroll Recipients',\n },\n {\n label: t('receipt.debitDate'),\n value: receiptData.debitDate || '',\n },\n ]\n\n const renderReceiptHeader = () => (\n <div className={classNames(styles.receiptHeader, isMobile && styles.receiptHeaderMobile)}>\n <Flex flexDirection=\"column\" gap={24}>\n <Flex flexDirection=\"column\" alignItems=\"center\" gap={16}>\n <div className={styles.receiptIcon}>\n <ReceiptCheck className={styles.checkmarkIcon} />\n </div>\n\n <Flex flexDirection=\"column\" alignItems=\"center\" gap={8}>\n <Text size=\"sm\" variant=\"supporting\">\n {t('receipt.totalLabel')}\n </Text>\n <Heading as=\"h1\" styledAs=\"h2\" className={styles.totalAmount}>\n {formatNumberAsCurrency(parseFloat(receiptData.totals?.companyDebit || '0'))}\n </Heading>\n </Flex>\n </Flex>\n\n <div className={styles.receiptDetailsTable}>\n <DataView\n label={t('receipt.detailsLabel')}\n variant=\"minimal\"\n breakAt=\"small\"\n breakpoints={{\n base: '0rem',\n small: '22rem',\n }}\n columns={[\n {\n title: '',\n render: (item: { label: string; value: string }) => (\n <Text size=\"sm\" variant=\"supporting\">\n {item.label}\n </Text>\n ),\n },\n {\n title: '',\n render: (item: { label: string; value: string }) => (\n <Text size=\"sm\">{item.value}</Text>\n ),\n },\n ]}\n data={receiptDetailsConfig}\n />\n </div>\n\n <Flex flexDirection=\"column\" alignItems=\"center\" gap={12}>\n <Text\n size=\"sm\"\n variant=\"supporting\"\n className={classNames(styles.disclaimer, isMobile && styles.textMobile)}\n >\n {receiptData.recipientNotice}\n </Text>\n\n <Text\n size=\"sm\"\n variant=\"supporting\"\n className={classNames(styles.companyInfo, isMobile && styles.textMobile)}\n >\n {receiptData.license}\n </Text>\n\n <Text\n size=\"sm\"\n variant=\"supporting\"\n className={classNames(styles.address, isMobile && styles.textMobile)}\n >\n {receiptData.licensee &&\n `${receiptData.licensee.address || ''}, ${receiptData.licensee.city || ''}, ${receiptData.licensee.state || ''} ${receiptData.licensee.postalCode || ''}`}\n </Text>\n </Flex>\n </Flex>\n </div>\n )\n\n const renderBreakdownSection = () => (\n <Flex flexDirection=\"column\" gap={16}>\n <DataTable\n label={t('sections.debitedLabel')}\n columns={[\n {\n title: t('sections.debitedLabel'),\n render: (item: { label: string; amount: number }) => <Text>{item.label}</Text>,\n },\n {\n title: t('breakdown.amount'),\n render: (item: { label: string; amount: number }) => (\n <Text>{formatNumberAsCurrency(item.amount)}</Text>\n ),\n },\n ]}\n data={breakdownData}\n footer={() => ({\n 'column-0': <Text weight=\"semibold\">{t('breakdown.totals')}</Text>,\n 'column-1': (\n <Text weight=\"semibold\">\n {formatNumberAsCurrency(parseFloat(receiptData.totals?.companyDebit || '0'))}\n </Text>\n ),\n })}\n />\n </Flex>\n )\n\n const renderTaxBreakdown = () => (\n <Flex flexDirection=\"column\" gap={16}>\n <DataTable\n label={t('sections.taxLabel')}\n columns={[\n {\n title: t('sections.taxLabel'),\n render: (tax: TaxBreakdownItem) => <Text>{tax.name}</Text>,\n },\n {\n title: t('tax.amount'),\n render: (tax: TaxBreakdownItem) => (\n <Text>{formatNumberAsCurrency(parseFloat(tax.amount || '0'))}</Text>\n ),\n },\n ]}\n data={receiptData.taxes || []}\n footer={() => ({\n 'column-0': <Text weight=\"semibold\">{t('breakdown.totals')}</Text>,\n 'column-1': (\n <Text weight=\"semibold\">\n {formatNumberAsCurrency(parseFloat(receiptData.totals?.taxDebit || '0'))}\n </Text>\n ),\n })}\n />\n </Flex>\n )\n\n const renderEmployeeBreakdown = () => (\n <Flex flexDirection=\"column\" gap={16}>\n {isMobile && <Heading as=\"h2\">{t('sections.employeesLabel')}</Heading>}\n <DataView\n label={t('sections.employeesLabel')}\n columns={[\n {\n title: t('employee.name'),\n render: (employee: EmployeeBreakdownItem) => (\n <Text>{getEmployeeFullName(employee)}</Text>\n ),\n },\n {\n title: t('employee.paymentMethod'),\n render: (employee: EmployeeBreakdownItem) => (\n <Text>{employee.paymentMethod || 'N/A'}</Text>\n ),\n },\n {\n title: t('employee.childSupport'),\n render: (employee: EmployeeBreakdownItem) => (\n <Text>\n {formatNumberAsCurrency(parseFloat(employee.childSupportGarnishment || '0'))}\n </Text>\n ),\n },\n {\n title: t('employee.reimbursement'),\n render: (employee: EmployeeBreakdownItem) => (\n <Text>{formatNumberAsCurrency(parseFloat(employee.totalReimbursement || '0'))}</Text>\n ),\n },\n {\n title: t('employee.totalTaxes'),\n render: (employee: EmployeeBreakdownItem) => (\n <Text>{formatNumberAsCurrency(parseFloat(employee.totalTax || '0'))}</Text>\n ),\n },\n {\n title: t('employee.netPay'),\n render: (employee: EmployeeBreakdownItem) => (\n <Text>{formatNumberAsCurrency(parseFloat(employee.netPay || '0'))}</Text>\n ),\n },\n ]}\n data={receiptData.employeeCompensations || []}\n footer={() => ({\n 'column-0': (\n <Flex flexDirection=\"column\" gap={4}>\n <Text weight=\"semibold\">{t('breakdown.totals')}</Text>\n <Text size=\"sm\" variant=\"supporting\">\n {t('employee.totalEmployees', {\n count: receiptData.employeeCompensations?.length || 0,\n })}\n </Text>\n </Flex>\n ),\n 'column-1': <Text>{'\\u00A0'}</Text>,\n 'column-2': (\n <Text weight=\"semibold\">{formatNumberAsCurrency(getTotalChildSupport())}</Text>\n ),\n 'column-3': (\n <Text weight=\"semibold\">{formatNumberAsCurrency(getTotalReimbursements())}</Text>\n ),\n 'column-4': <Text weight=\"semibold\">{formatNumberAsCurrency(getTotalTaxes())}</Text>,\n 'column-5': <Text weight=\"semibold\">{formatNumberAsCurrency(getTotalNetPay())}</Text>,\n })}\n />\n </Flex>\n )\n\n return (\n <div className={styles.container} ref={containerRef}>\n <Flex flexDirection=\"column\" gap={24}>\n {renderReceiptHeader()}\n {renderBreakdownSection()}\n {renderTaxBreakdown()}\n {renderEmployeeBreakdown()}\n </Flex>\n </div>\n )\n}\n"],"names":["PayrollReceiptsPresentation","receiptData","Heading","Text","useComponentContext","useI18n","useTranslation","containerRef","useRef","isMobile","useContainerBreakpoints","getEmployeeFullName","emp","getTotalChildSupport","sum","getTotalReimbursements","getTotalNetPay","getTotalTaxes","breakdownData","receiptDetailsConfig","renderReceiptHeader","jsx","classNames","styles","jsxs","Flex","ReceiptCheck","formatNumberAsCurrency","DataView","item","renderBreakdownSection","DataTable","renderTaxBreakdown","tax","renderEmployeeBreakdown","employee"],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import { PayrollInput, WireInRequestInput } from './payrollStatusConfig';
2
+ interface PayrollStatusBadgesProps {
3
+ payroll: PayrollInput;
4
+ wireInRequest?: WireInRequestInput;
5
+ }
6
+ export declare const PayrollStatusBadges: ({ payroll, wireInRequest }: PayrollStatusBadgesProps) => import("react/jsx-runtime").JSX.Element;
7
+ export {};
@@ -0,0 +1,19 @@
1
+ import { jsx as s } from "react/jsx-runtime";
2
+ import { useTranslation as c } from "react-i18next";
3
+ import { usePayrollStatusBadges as d } from "./usePayrollStatusBadges.js";
4
+ import r from "./PayrollStatusBadges.module.scss.js";
5
+ import { useComponentContext as y } from "../../../contexts/ComponentAdapter/useComponentContext.js";
6
+ import { useI18n as f } from "../../../i18n/I18n.js";
7
+ const B = ({ payroll: a, wireInRequest: e }) => {
8
+ const { Badge: l } = y();
9
+ f("Payroll.Common");
10
+ const { t: i } = c("Payroll.Common"), { badges: m } = d(a, e), u = (t, o) => {
11
+ const n = { ...o };
12
+ return o?.hours !== void 0 ? n.count = o.hours : o?.days !== void 0 && (n.count = o.days), i(`status.${t}`, n);
13
+ };
14
+ return /* @__PURE__ */ s("div", { className: r.statusCell, children: /* @__PURE__ */ s("div", { className: r.badges, children: m.map((t) => /* @__PURE__ */ s("span", { children: /* @__PURE__ */ s(l, { status: t.variant, children: u(t.translationKey, t.translationParams) }) }, t.translationKey)) }) });
15
+ };
16
+ export {
17
+ B as PayrollStatusBadges
18
+ };
19
+ //# sourceMappingURL=PayrollStatusBadges.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PayrollStatusBadges.js","sources":["../../../../src/components/Payroll/PayrollStatusBadges/PayrollStatusBadges.tsx"],"sourcesContent":["import { useTranslation } from 'react-i18next'\nimport type {\n PayrollInput,\n WireInRequestInput,\n PayrollStatusTranslationKey,\n} from './payrollStatusConfig'\nimport { usePayrollStatusBadges } from './usePayrollStatusBadges'\nimport styles from './PayrollStatusBadges.module.scss'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { useI18n } from '@/i18n'\n\ninterface PayrollStatusBadgesProps {\n payroll: PayrollInput\n wireInRequest?: WireInRequestInput\n}\n\nexport const PayrollStatusBadges = ({ payroll, wireInRequest }: PayrollStatusBadgesProps) => {\n const { Badge } = useComponentContext()\n useI18n('Payroll.Common')\n const { t } = useTranslation('Payroll.Common')\n\n const { badges } = usePayrollStatusBadges(payroll, wireInRequest)\n\n const translateStatus = (\n translationKey: PayrollStatusTranslationKey,\n params?: Record<string, string | number>,\n ) => {\n const options = { ...params }\n\n if (params?.hours !== undefined) {\n options.count = params.hours\n } else if (params?.days !== undefined) {\n options.count = params.days\n }\n\n return t(`status.${translationKey}`, options)\n }\n\n return (\n <div className={styles.statusCell}>\n <div className={styles.badges}>\n {badges.map(badge => (\n <span key={badge.translationKey}>\n <Badge status={badge.variant}>\n {translateStatus(badge.translationKey, badge.translationParams)}\n </Badge>\n </span>\n ))}\n </div>\n </div>\n )\n}\n"],"names":["PayrollStatusBadges","payroll","wireInRequest","Badge","useComponentContext","useI18n","t","useTranslation","badges","usePayrollStatusBadges","translateStatus","translationKey","params","options","jsx","styles","badge"],"mappings":";;;;;;AAgBO,MAAMA,IAAsB,CAAC,EAAE,SAAAC,GAAS,eAAAC,QAA8C;AAC3F,QAAM,EAAE,OAAAC,EAAA,IAAUC,EAAA;AAClB,EAAAC,EAAQ,gBAAgB;AACxB,QAAM,EAAE,GAAAC,EAAA,IAAMC,EAAe,gBAAgB,GAEvC,EAAE,QAAAC,EAAA,IAAWC,EAAuBR,GAASC,CAAa,GAE1DQ,IAAkB,CACtBC,GACAC,MACG;AACH,UAAMC,IAAU,EAAE,GAAGD,EAAA;AAErB,WAAIA,GAAQ,UAAU,SACpBC,EAAQ,QAAQD,EAAO,QACdA,GAAQ,SAAS,WAC1BC,EAAQ,QAAQD,EAAO,OAGlBN,EAAE,UAAUK,CAAc,IAAIE,CAAO;AAAA,EAC9C;AAEA,SACE,gBAAAC,EAAC,OAAA,EAAI,WAAWC,EAAO,YACrB,UAAA,gBAAAD,EAAC,OAAA,EAAI,WAAWC,EAAO,QACpB,UAAAP,EAAO,IAAI,OACV,gBAAAM,EAAC,QAAA,EACC,UAAA,gBAAAA,EAACX,GAAA,EAAM,QAAQa,EAAM,SAClB,UAAAN,EAAgBM,EAAM,gBAAgBA,EAAM,iBAAiB,EAAA,CAChE,EAAA,GAHSA,EAAM,cAIjB,CACD,GACH,GACF;AAEJ;"}
@@ -0,0 +1,10 @@
1
+ const s = "_statusCell_oheue_1", e = "_badges_oheue_6", t = {
2
+ statusCell: s,
3
+ badges: e
4
+ };
5
+ export {
6
+ e as badges,
7
+ t as default,
8
+ s as statusCell
9
+ };
10
+ //# sourceMappingURL=PayrollStatusBadges.module.scss.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PayrollStatusBadges.module.scss.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
@@ -0,0 +1,4 @@
1
+ import "./types/i18next.d.ts"
2
+ export { PayrollStatusBadges } from './PayrollStatusBadges';
3
+ export { usePayrollStatusBadges, getPayrollStatusBadges } from './usePayrollStatusBadges';
4
+ export type { PayrollStatusBadge, PayrollStatusBadges as PayrollStatusBadgesResult, PayrollInput, WireInRequestInput, } from './payrollStatusConfig';
@@ -0,0 +1,33 @@
1
+ import { PayrollProcessingRequestStatus } from '@gusto/embedded-api/models/components/payrollprocessingrequest';
2
+ export type PayrollStatusTranslationKey = 'processed' | 'unprocessed' | 'calculating' | 'readyToSubmit' | 'processing' | 'failed' | 'waitingForWireIn' | 'pendingApproval' | 'dueInHours' | 'dueInDays' | 'daysLate' | 'pending' | 'paid' | 'complete' | 'submitted' | 'inProgress';
3
+ export type PayrollStatusBadge = {
4
+ label?: string;
5
+ variant: 'success' | 'warning' | 'error' | 'info';
6
+ translationKey: PayrollStatusTranslationKey;
7
+ translationParams?: Record<string, string | number>;
8
+ };
9
+ export type PayrollStatusBadges = {
10
+ badges: PayrollStatusBadge[];
11
+ };
12
+ export type PayrollInput = {
13
+ processed?: boolean;
14
+ checkDate?: string | null | Date;
15
+ payrollDeadline?: string | null | Date;
16
+ calculatedAt?: Date | null;
17
+ processingRequest?: {
18
+ status?: PayrollProcessingRequestStatus;
19
+ errors?: unknown[];
20
+ } | null;
21
+ };
22
+ export type WireInRequestInput = {
23
+ status?: string;
24
+ paymentUuid?: string;
25
+ wireInDeadline?: string;
26
+ } | null;
27
+ export type StatusConfig = {
28
+ name: string;
29
+ badge: PayrollStatusBadge | ((payroll: PayrollInput, wireInRequest?: WireInRequestInput) => PayrollStatusBadge);
30
+ condition: (payroll: PayrollInput, wireInRequest?: WireInRequestInput) => boolean;
31
+ continueChecking?: boolean;
32
+ };
33
+ export declare const STATUS_CONFIG: StatusConfig[];