@gusto/embedded-react-sdk 0.14.1 → 0.15.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (258) hide show
  1. package/CHANGELOG.md +28 -0
  2. package/dist/assets/icons/feature-icon-check.svg.js +10 -0
  3. package/dist/assets/icons/feature-icon-check.svg.js.map +1 -0
  4. package/dist/components/Base/Base.js +4 -4
  5. package/dist/components/Common/DataView/DataView.d.ts +2 -1
  6. package/dist/components/Common/DataView/DataView.js +19 -18
  7. package/dist/components/Common/DataView/DataView.js.map +1 -1
  8. package/dist/components/Common/PaginationControl/PaginationControl.js +36 -36
  9. package/dist/components/Common/PaginationControl/PaginationControl.js.map +1 -1
  10. package/dist/components/Common/PaginationControl/PaginationControlTypes.d.ts +3 -1
  11. package/dist/components/Common/SignatureForm/SignatureForm.js +14 -11
  12. package/dist/components/Common/SignatureForm/SignatureForm.js.map +1 -1
  13. package/dist/components/Common/SignatureForm/SignatureFormActions.js +9 -7
  14. package/dist/components/Common/SignatureForm/SignatureFormActions.js.map +1 -1
  15. package/dist/components/Common/SignatureForm/SignatureFormFields.js +15 -12
  16. package/dist/components/Common/SignatureForm/SignatureFormFields.js.map +1 -1
  17. package/dist/components/Company/AssignSignatory/AssignSignatory.js +8 -6
  18. package/dist/components/Company/AssignSignatory/AssignSignatory.js.map +1 -1
  19. package/dist/components/Company/AssignSignatory/AssignSignatorySelection.js +5 -2
  20. package/dist/components/Company/AssignSignatory/AssignSignatorySelection.js.map +1 -1
  21. package/dist/components/Company/AssignSignatory/CreateSignatory/Actions.js +4 -2
  22. package/dist/components/Company/AssignSignatory/CreateSignatory/Actions.js.map +1 -1
  23. package/dist/components/Company/AssignSignatory/CreateSignatory/CreateSignatory.js +9 -7
  24. package/dist/components/Company/AssignSignatory/CreateSignatory/CreateSignatory.js.map +1 -1
  25. package/dist/components/Company/AssignSignatory/CreateSignatory/CreateSignatoryForm.js +16 -15
  26. package/dist/components/Company/AssignSignatory/CreateSignatory/CreateSignatoryForm.js.map +1 -1
  27. package/dist/components/Company/AssignSignatory/CreateSignatory/useCreateSignatory.js +5 -4
  28. package/dist/components/Company/AssignSignatory/CreateSignatory/useCreateSignatory.js.map +1 -1
  29. package/dist/components/Company/AssignSignatory/InviteSignatory/Actions.js +4 -2
  30. package/dist/components/Company/AssignSignatory/InviteSignatory/Actions.js.map +1 -1
  31. package/dist/components/Company/AssignSignatory/InviteSignatory/InviteSignatory.js +12 -10
  32. package/dist/components/Company/AssignSignatory/InviteSignatory/InviteSignatory.js.map +1 -1
  33. package/dist/components/Company/AssignSignatory/InviteSignatory/InviteSignatoryForm.js +10 -9
  34. package/dist/components/Company/AssignSignatory/InviteSignatory/InviteSignatoryForm.js.map +1 -1
  35. package/dist/components/Company/AssignSignatory/InviteSignatory/useInviteSignatory.js +5 -4
  36. package/dist/components/Company/AssignSignatory/InviteSignatory/useInviteSignatory.js.map +1 -1
  37. package/dist/components/Company/AssignSignatory/TitleSelect.js +5 -3
  38. package/dist/components/Company/AssignSignatory/TitleSelect.js.map +1 -1
  39. package/dist/components/Company/AssignSignatory/useAssignSignatory.js +7 -6
  40. package/dist/components/Company/AssignSignatory/useAssignSignatory.js.map +1 -1
  41. package/dist/components/Company/BankAccount/BankAccountForm/Actions.js +10 -9
  42. package/dist/components/Company/BankAccount/BankAccountForm/Actions.js.map +1 -1
  43. package/dist/components/Company/BankAccount/BankAccountForm/Form.js +11 -8
  44. package/dist/components/Company/BankAccount/BankAccountForm/Form.js.map +1 -1
  45. package/dist/components/Company/BankAccount/BankAccountForm/context.js +5 -4
  46. package/dist/components/Company/BankAccount/BankAccountForm/context.js.map +1 -1
  47. package/dist/components/Company/BankAccount/BankAccountList/Actions.js +10 -8
  48. package/dist/components/Company/BankAccount/BankAccountList/Actions.js.map +1 -1
  49. package/dist/components/Company/BankAccount/BankAccountVerify/Actions.js +10 -8
  50. package/dist/components/Company/BankAccount/BankAccountVerify/Actions.js.map +1 -1
  51. package/dist/components/Company/BankAccount/BankAccountVerify/Form.js +7 -4
  52. package/dist/components/Company/BankAccount/BankAccountVerify/Form.js.map +1 -1
  53. package/dist/components/Company/DocumentSigner/DocumentList/Actions.js +4 -2
  54. package/dist/components/Company/DocumentSigner/DocumentList/Actions.js.map +1 -1
  55. package/dist/components/Company/DocumentSigner/DocumentList/DocumentList.js +11 -9
  56. package/dist/components/Company/DocumentSigner/DocumentList/DocumentList.js.map +1 -1
  57. package/dist/components/Company/DocumentSigner/DocumentList/useDocumentList.js +5 -4
  58. package/dist/components/Company/DocumentSigner/DocumentList/useDocumentList.js.map +1 -1
  59. package/dist/components/Company/DocumentSigner/SignatureForm/SignatureForm.js +10 -8
  60. package/dist/components/Company/DocumentSigner/SignatureForm/SignatureForm.js.map +1 -1
  61. package/dist/components/Company/DocumentSigner/SignatureForm/useSignatureForm.js +5 -4
  62. package/dist/components/Company/DocumentSigner/SignatureForm/useSignatureForm.js.map +1 -1
  63. package/dist/components/Company/FederalTaxes/Actions.js +9 -7
  64. package/dist/components/Company/FederalTaxes/Actions.js.map +1 -1
  65. package/dist/components/Company/FederalTaxes/FederalTaxes.js +5 -3
  66. package/dist/components/Company/FederalTaxes/FederalTaxes.js.map +1 -1
  67. package/dist/components/Company/FederalTaxes/Form.js +7 -6
  68. package/dist/components/Company/FederalTaxes/Form.js.map +1 -1
  69. package/dist/components/Company/FederalTaxes/useFederalTaxes.js +10 -9
  70. package/dist/components/Company/FederalTaxes/useFederalTaxes.js.map +1 -1
  71. package/dist/components/Company/Industry/Actions.js +9 -7
  72. package/dist/components/Company/Industry/Actions.js.map +1 -1
  73. package/dist/components/Company/Industry/Context.js +8 -7
  74. package/dist/components/Company/Industry/Context.js.map +1 -1
  75. package/dist/components/Company/Industry/Edit.js +7 -4
  76. package/dist/components/Company/Industry/Edit.js.map +1 -1
  77. package/dist/components/Company/Locations/LocationForm/Actions.js +10 -8
  78. package/dist/components/Company/Locations/LocationForm/Actions.js.map +1 -1
  79. package/dist/components/Company/Locations/LocationForm/Form.js +7 -5
  80. package/dist/components/Company/Locations/LocationForm/Form.js.map +1 -1
  81. package/dist/components/Company/Locations/LocationForm/LocationForm.js +12 -10
  82. package/dist/components/Company/Locations/LocationForm/LocationForm.js.map +1 -1
  83. package/dist/components/Company/Locations/LocationForm/useLocationForm.js +5 -4
  84. package/dist/components/Company/Locations/LocationForm/useLocationForm.js.map +1 -1
  85. package/dist/components/Company/Locations/LocationsList/Actions.js +8 -6
  86. package/dist/components/Company/Locations/LocationsList/Actions.js.map +1 -1
  87. package/dist/components/Company/Locations/LocationsList/List.js +25 -22
  88. package/dist/components/Company/Locations/LocationsList/List.js.map +1 -1
  89. package/dist/components/Company/Locations/LocationsList/LocationsList.js +11 -9
  90. package/dist/components/Company/Locations/LocationsList/LocationsList.js.map +1 -1
  91. package/dist/components/Company/Locations/LocationsList/useLocationsList.d.ts +3 -1
  92. package/dist/components/Company/Locations/LocationsList/useLocationsList.js +5 -4
  93. package/dist/components/Company/Locations/LocationsList/useLocationsList.js.map +1 -1
  94. package/dist/components/Company/OnboardingOverview/Completed.js +12 -10
  95. package/dist/components/Company/OnboardingOverview/Completed.js.map +1 -1
  96. package/dist/components/Company/OnboardingOverview/MissingRequirements.js +11 -9
  97. package/dist/components/Company/OnboardingOverview/MissingRequirements.js.map +1 -1
  98. package/dist/components/Company/OnboardingOverview/OnboardingOverview.js +9 -7
  99. package/dist/components/Company/OnboardingOverview/OnboardingOverview.js.map +1 -1
  100. package/dist/components/Company/OnboardingOverview/context.js +5 -4
  101. package/dist/components/Company/OnboardingOverview/context.js.map +1 -1
  102. package/dist/components/Company/PaySchedule/PaySchedule.js +5 -4
  103. package/dist/components/Company/PaySchedule/PaySchedule.js.map +1 -1
  104. package/dist/components/Company/PaySchedule/_parts/Actions.js +11 -9
  105. package/dist/components/Company/PaySchedule/_parts/Actions.js.map +1 -1
  106. package/dist/components/Company/PaySchedule/_parts/Edit.js +14 -14
  107. package/dist/components/Company/PaySchedule/_parts/Head.js +11 -9
  108. package/dist/components/Company/PaySchedule/_parts/Head.js.map +1 -1
  109. package/dist/components/Company/PaySchedule/_parts/List.js +18 -17
  110. package/dist/components/Company/PaySchedule/_parts/List.js.map +1 -1
  111. package/dist/components/Company/PaySchedule/usePaySchedule.js +7 -6
  112. package/dist/components/Company/PaySchedule/usePaySchedule.js.map +1 -1
  113. package/dist/components/Company/StateTaxes/StateTaxesForm/Actions.js +4 -2
  114. package/dist/components/Company/StateTaxes/StateTaxesForm/Actions.js.map +1 -1
  115. package/dist/components/Company/StateTaxes/StateTaxesForm/context.js +5 -4
  116. package/dist/components/Company/StateTaxes/StateTaxesForm/context.js.map +1 -1
  117. package/dist/components/Company/StateTaxes/StateTaxesList/Actions.js +4 -2
  118. package/dist/components/Company/StateTaxes/StateTaxesList/Actions.js.map +1 -1
  119. package/dist/components/Company/StateTaxes/StateTaxesList/List.js +4 -2
  120. package/dist/components/Company/StateTaxes/StateTaxesList/List.js.map +1 -1
  121. package/dist/components/Company/StateTaxes/StateTaxesList/context.js +5 -4
  122. package/dist/components/Company/StateTaxes/StateTaxesList/context.js.map +1 -1
  123. package/dist/components/Contractor/Address/Address.js +7 -5
  124. package/dist/components/Contractor/Address/Address.js.map +1 -1
  125. package/dist/components/Contractor/Address/Form.js +9 -7
  126. package/dist/components/Contractor/Address/Form.js.map +1 -1
  127. package/dist/components/Contractor/Address/useAddress.js +7 -6
  128. package/dist/components/Contractor/Address/useAddress.js.map +1 -1
  129. package/dist/components/Contractor/ContractorList/index.js +59 -57
  130. package/dist/components/Contractor/ContractorList/index.js.map +1 -1
  131. package/dist/components/Contractor/ContractorList/useContractorList.d.ts +3 -1
  132. package/dist/components/Contractor/ContractorList/useContractorList.js +7 -6
  133. package/dist/components/Contractor/ContractorList/useContractorList.js.map +1 -1
  134. package/dist/components/Contractor/PaymentMethod/BankAccountForm.js +13 -10
  135. package/dist/components/Contractor/PaymentMethod/BankAccountForm.js.map +1 -1
  136. package/dist/components/Contractor/PaymentMethod/PaymentTypeForm.js +4 -2
  137. package/dist/components/Contractor/PaymentMethod/PaymentTypeForm.js.map +1 -1
  138. package/dist/components/Contractor/Profile/ContractorProfileForm.js +13 -13
  139. package/dist/components/Contractor/Profile/useContractorProfile.js +4 -3
  140. package/dist/components/Contractor/Profile/useContractorProfile.js.map +1 -1
  141. package/dist/components/Contractor/Submit/Submit.js +21 -20
  142. package/dist/components/Contractor/Submit/Submit.js.map +1 -1
  143. package/dist/components/Employee/Compensation/Actions.js +13 -12
  144. package/dist/components/Employee/Compensation/Actions.js.map +1 -1
  145. package/dist/components/Employee/Compensation/Edit.js +14 -14
  146. package/dist/components/Employee/Compensation/List.js +23 -22
  147. package/dist/components/Employee/Compensation/List.js.map +1 -1
  148. package/dist/components/Employee/Deductions/DeductionsForm/ChildSupportForm.js +11 -10
  149. package/dist/components/Employee/Deductions/DeductionsForm/ChildSupportForm.js.map +1 -1
  150. package/dist/components/Employee/Deductions/DeductionsForm/CustomDeductionForm.js +33 -32
  151. package/dist/components/Employee/Deductions/DeductionsForm/CustomDeductionForm.js.map +1 -1
  152. package/dist/components/Employee/Deductions/DeductionsForm/DeductionsForm.js +8 -8
  153. package/dist/components/Employee/Deductions/DeductionsList/DeductionsList.js +11 -11
  154. package/dist/components/Employee/Deductions/IncludeDeductionsForm/IncludeDeductionsForm.js +23 -22
  155. package/dist/components/Employee/Deductions/IncludeDeductionsForm/IncludeDeductionsForm.js.map +1 -1
  156. package/dist/components/Employee/DocumentSigner/DocumentList/Actions.js +8 -6
  157. package/dist/components/Employee/DocumentSigner/DocumentList/Actions.js.map +1 -1
  158. package/dist/components/Employee/DocumentSigner/DocumentList/DocumentList.js +5 -3
  159. package/dist/components/Employee/DocumentSigner/DocumentList/DocumentList.js.map +1 -1
  160. package/dist/components/Employee/DocumentSigner/DocumentList/List.js +5 -2
  161. package/dist/components/Employee/DocumentSigner/DocumentList/List.js.map +1 -1
  162. package/dist/components/Employee/DocumentSigner/DocumentList/useDocumentList.js +5 -4
  163. package/dist/components/Employee/DocumentSigner/DocumentList/useDocumentList.js.map +1 -1
  164. package/dist/components/Employee/DocumentSigner/SignatureForm/SignatureForm.js +5 -3
  165. package/dist/components/Employee/DocumentSigner/SignatureForm/SignatureForm.js.map +1 -1
  166. package/dist/components/Employee/DocumentSigner/SignatureForm/useSignatureForm.js +5 -4
  167. package/dist/components/Employee/DocumentSigner/SignatureForm/useSignatureForm.js.map +1 -1
  168. package/dist/components/Employee/EmployeeList/Actions.js +8 -6
  169. package/dist/components/Employee/EmployeeList/Actions.js.map +1 -1
  170. package/dist/components/Employee/EmployeeList/EmployeeList.js +17 -13
  171. package/dist/components/Employee/EmployeeList/EmployeeList.js.map +1 -1
  172. package/dist/components/Employee/EmployeeList/Head.js +7 -5
  173. package/dist/components/Employee/EmployeeList/Head.js.map +1 -1
  174. package/dist/components/Employee/EmployeeList/List.js +45 -43
  175. package/dist/components/Employee/EmployeeList/List.js.map +1 -1
  176. package/dist/components/Employee/EmployeeList/useEmployeeList.d.ts +3 -1
  177. package/dist/components/Employee/EmployeeList/useEmployeeList.js +5 -4
  178. package/dist/components/Employee/EmployeeList/useEmployeeList.js.map +1 -1
  179. package/dist/components/Employee/FederalTaxes/Actions.js +9 -7
  180. package/dist/components/Employee/FederalTaxes/Actions.js.map +1 -1
  181. package/dist/components/Employee/FederalTaxes/FederalForm.js +13 -11
  182. package/dist/components/Employee/FederalTaxes/FederalForm.js.map +1 -1
  183. package/dist/components/Employee/FederalTaxes/useFederalTaxes.js +5 -4
  184. package/dist/components/Employee/FederalTaxes/useFederalTaxes.js.map +1 -1
  185. package/dist/components/Employee/Landing/Landing.js +11 -10
  186. package/dist/components/Employee/Landing/Landing.js.map +1 -1
  187. package/dist/components/Employee/OnboardingSummary/OnboardingSummary.js +7 -7
  188. package/dist/components/Employee/PaymentMethod/Actions.js +8 -6
  189. package/dist/components/Employee/PaymentMethod/Actions.js.map +1 -1
  190. package/dist/components/Employee/PaymentMethod/BankAccountEdit.js +5 -3
  191. package/dist/components/Employee/PaymentMethod/BankAccountEdit.js.map +1 -1
  192. package/dist/components/Employee/PaymentMethod/BankAccountsList.js +12 -11
  193. package/dist/components/Employee/PaymentMethod/BankAccountsList.js.map +1 -1
  194. package/dist/components/Employee/PaymentMethod/PaymentTypeForm.js +4 -2
  195. package/dist/components/Employee/PaymentMethod/PaymentTypeForm.js.map +1 -1
  196. package/dist/components/Employee/PaymentMethod/Split.js +7 -7
  197. package/dist/components/Employee/PaymentMethod/usePaymentMethod.js +7 -6
  198. package/dist/components/Employee/PaymentMethod/usePaymentMethod.js.map +1 -1
  199. package/dist/components/Employee/Profile/Actions.js +9 -7
  200. package/dist/components/Employee/Profile/Actions.js.map +1 -1
  201. package/dist/components/Employee/Profile/AdminPersonalDetails.js +7 -6
  202. package/dist/components/Employee/Profile/AdminPersonalDetails.js.map +1 -1
  203. package/dist/components/Employee/Profile/HomeAddress.js +6 -5
  204. package/dist/components/Employee/Profile/HomeAddress.js.map +1 -1
  205. package/dist/components/Employee/Profile/PersonalDetailsInputs.js +25 -23
  206. package/dist/components/Employee/Profile/PersonalDetailsInputs.js.map +1 -1
  207. package/dist/components/Employee/Profile/useProfile.js +5 -4
  208. package/dist/components/Employee/Profile/useProfile.js.map +1 -1
  209. package/dist/components/Employee/StateTaxes/Actions.js +10 -8
  210. package/dist/components/Employee/StateTaxes/Actions.js.map +1 -1
  211. package/dist/components/Employee/StateTaxes/useStateTaxes.js +5 -4
  212. package/dist/components/Employee/StateTaxes/useStateTaxes.js.map +1 -1
  213. package/dist/components/Employee/Taxes/Actions.js +10 -8
  214. package/dist/components/Employee/Taxes/Actions.js.map +1 -1
  215. package/dist/components/Employee/Taxes/FederalForm.js +14 -12
  216. package/dist/components/Employee/Taxes/FederalForm.js.map +1 -1
  217. package/dist/components/Employee/Taxes/useTaxes.js +5 -4
  218. package/dist/components/Employee/Taxes/useTaxes.js.map +1 -1
  219. package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerAlerts.js +15 -13
  220. package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerAlerts.js.map +1 -1
  221. package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerList.js +15 -13
  222. package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerList.js.map +1 -1
  223. package/dist/components/Payroll/PayrollConfiguration/PayrollConfiguration.js +118 -88
  224. package/dist/components/Payroll/PayrollConfiguration/PayrollConfiguration.js.map +1 -1
  225. package/dist/components/Payroll/PayrollConfiguration/PayrollConfigurationPresentation.d.ts +3 -1
  226. package/dist/components/Payroll/PayrollConfiguration/PayrollConfigurationPresentation.js +72 -76
  227. package/dist/components/Payroll/PayrollConfiguration/PayrollConfigurationPresentation.js.map +1 -1
  228. package/dist/components/Payroll/PayrollEditEmployee/PayrollEditEmployee.js +21 -20
  229. package/dist/components/Payroll/PayrollEditEmployee/PayrollEditEmployee.js.map +1 -1
  230. package/dist/components/Payroll/PayrollEditEmployee/PayrollEditEmployeePresentation.js +27 -27
  231. package/dist/components/Payroll/PayrollEditEmployee/TimeOffField.js +9 -8
  232. package/dist/components/Payroll/PayrollEditEmployee/TimeOffField.js.map +1 -1
  233. package/dist/components/Payroll/PayrollHistory/PayrollHistory.js +21 -20
  234. package/dist/components/Payroll/PayrollHistory/PayrollHistory.js.map +1 -1
  235. package/dist/components/Payroll/PayrollHistory/PayrollHistoryPresentation.js +23 -22
  236. package/dist/components/Payroll/PayrollHistory/PayrollHistoryPresentation.js.map +1 -1
  237. package/dist/components/Payroll/PayrollList/PayrollListPresentation.js +84 -78
  238. package/dist/components/Payroll/PayrollList/PayrollListPresentation.js.map +1 -1
  239. package/dist/components/Payroll/PayrollOverview/PayrollOverviewPresentation.js +75 -74
  240. package/dist/components/Payroll/PayrollOverview/PayrollOverviewPresentation.js.map +1 -1
  241. package/dist/components/Payroll/PayrollReceipts/PayrollReceiptsPresentation.js +3 -2
  242. package/dist/components/Payroll/PayrollReceipts/PayrollReceiptsPresentation.js.map +1 -1
  243. package/dist/components/Payroll/helpers.d.ts +2 -0
  244. package/dist/components/Payroll/helpers.js +38 -37
  245. package/dist/components/Payroll/helpers.js.map +1 -1
  246. package/dist/components/Payroll/usePreparedPayrollData.d.ts +4 -1
  247. package/dist/components/Payroll/usePreparedPayrollData.js +26 -19
  248. package/dist/components/Payroll/usePreparedPayrollData.js.map +1 -1
  249. package/dist/components/index.d.ts +1 -1
  250. package/dist/contexts/GustoProvider/GustoProviderCustomUIAdapter.js +4 -2
  251. package/dist/contexts/GustoProvider/GustoProviderCustomUIAdapter.js.map +1 -1
  252. package/dist/i18n/en/Payroll.PayrollHistory.json.js +9 -9
  253. package/dist/index.js +1 -1
  254. package/dist/style.css +1 -1
  255. package/dist/types/i18next.d.ts +1 -1
  256. package/package.json +7 -7
  257. package/dist/components/Payroll/RunPayrollFlow/RunPayroll.d.ts +0 -23
  258. package/dist/components/Payroll/RunPayrollFlow/RunPayrollFlow.d.ts +0 -6
@@ -4,23 +4,24 @@ import { useFormContext as d, useWatch as f } from "react-hook-form";
4
4
  import { useTranslation as m } from "react-i18next";
5
5
  import { Flex as y } from "../../Common/Flex/Flex.js";
6
6
  import "classnames";
7
- import { useComponentContext as x } from "../../../contexts/ComponentAdapter/useComponentContext.js";
8
- import { useI18n as h } from "../../../i18n/I18n.js";
9
- import { TextInputField as B } from "../../Common/Fields/TextInputField/TextInputField.js";
7
+ import "../../../shared/constants.js";
8
+ import { TextInputField as x } from "../../Common/Fields/TextInputField/TextInputField.js";
9
+ import { useComponentContext as h } from "../../../contexts/ComponentAdapter/useComponentContext.js";
10
+ import { useI18n as B } from "../../../i18n/I18n.js";
10
11
  const P = ({
11
12
  accrualBalance: e,
12
13
  accrualMethod: o,
13
14
  hoursUsed: r,
14
15
  id: t
15
16
  }) => {
16
- const { Text: n } = x(), { t: l } = m("Payroll.PayrollEditEmployee");
17
+ const { Text: n } = h(), { t: l } = m("Payroll.PayrollEditEmployee");
17
18
  if (o === "unlimited")
18
19
  return null;
19
20
  const a = parseFloat(e) - r;
20
21
  return /* @__PURE__ */ i(n, { size: "sm", variant: "supporting", "aria-live": "polite", "aria-atomic": !0, id: t, children: l("timeOffBalance.remaining", { balance: a.toFixed(1) }) });
21
- }, M = ({ timeOff: e, employee: o }) => {
22
+ }, U = ({ timeOff: e, employee: o }) => {
22
23
  const { t: r } = m("Payroll.PayrollEditEmployee");
23
- h("Payroll.PayrollEditEmployee");
24
+ B("Payroll.PayrollEditEmployee");
24
25
  const { control: t } = d(), n = p(), l = f({
25
26
  control: t,
26
27
  name: `timeOffCompensations.${e.name}`
@@ -30,7 +31,7 @@ const P = ({
30
31
  const c = parseFloat(l || "0"), a = o.eligiblePaidTimeOff?.find((s) => s.name === e.name);
31
32
  return /* @__PURE__ */ u(y, { flexDirection: "column", gap: 4, children: [
32
33
  /* @__PURE__ */ i(
33
- B,
34
+ x,
34
35
  {
35
36
  name: `timeOffCompensations.${e.name}`,
36
37
  type: "number",
@@ -53,6 +54,6 @@ const P = ({
53
54
  ] });
54
55
  };
55
56
  export {
56
- M as TimeOffField
57
+ U as TimeOffField
57
58
  };
58
59
  //# sourceMappingURL=TimeOffField.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TimeOffField.js","sources":["../../../../src/components/Payroll/PayrollEditEmployee/TimeOffField.tsx"],"sourcesContent":["import { useId } from 'react'\nimport { useWatch, useFormContext } from 'react-hook-form'\nimport { useTranslation } from 'react-i18next'\nimport type { Employee } from '@gusto/embedded-api/models/components/employee'\nimport type { PayrollEmployeeCompensationsTypePaidTimeOff } from '@gusto/embedded-api/models/components/payrollemployeecompensationstype'\nimport type { PayrollEditEmployeeFormValues } from './PayrollEditEmployeePresentation'\nimport { Flex, TextInputField } from '@/components/Common'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { useI18n } from '@/i18n'\n\nexport interface TimeOffFieldProps {\n timeOff: PayrollEmployeeCompensationsTypePaidTimeOff\n employee: Employee\n}\n\nconst TimeOffBalance = ({\n accrualBalance,\n accrualMethod,\n hoursUsed,\n id,\n}: {\n accrualBalance: string\n accrualMethod?: string\n hoursUsed: number\n id: string\n}) => {\n const { Text } = useComponentContext()\n const { t } = useTranslation('Payroll.PayrollEditEmployee')\n\n if (accrualMethod === 'unlimited') {\n return null\n }\n\n const currentBalance = parseFloat(accrualBalance)\n const remainingBalance = currentBalance - hoursUsed\n\n return (\n <Text size=\"sm\" variant=\"supporting\" aria-live=\"polite\" aria-atomic={true} id={id}>\n {t('timeOffBalance.remaining', { balance: remainingBalance.toFixed(1) })}\n </Text>\n )\n}\n\nexport const TimeOffField = ({ timeOff, employee }: TimeOffFieldProps) => {\n const { t } = useTranslation('Payroll.PayrollEditEmployee')\n useI18n('Payroll.PayrollEditEmployee')\n\n const { control } = useFormContext<PayrollEditEmployeeFormValues>()\n const id = useId()\n\n const watchedValue = useWatch({\n control,\n name: `timeOffCompensations.${timeOff.name}`,\n })\n\n if (!timeOff.name) {\n return null\n }\n\n const hoursUsed = parseFloat(watchedValue || '0')\n const eligiblePolicy = employee.eligiblePaidTimeOff?.find(policy => policy.name === timeOff.name)\n\n return (\n <Flex flexDirection=\"column\" gap={4}>\n <TextInputField\n key={timeOff.name}\n name={`timeOffCompensations.${timeOff.name}`}\n type=\"number\"\n adornmentEnd={t('hoursUnit')}\n isRequired\n label={timeOff.name}\n aria-describedby={id}\n />\n {eligiblePolicy?.accrualBalance && (\n <TimeOffBalance\n accrualBalance={eligiblePolicy.accrualBalance}\n accrualMethod={eligiblePolicy.accrualMethod ?? undefined}\n hoursUsed={hoursUsed}\n id={id}\n />\n )}\n </Flex>\n )\n}\n"],"names":["TimeOffBalance","accrualBalance","accrualMethod","hoursUsed","id","Text","useComponentContext","t","useTranslation","remainingBalance","jsx","TimeOffField","timeOff","employee","useI18n","control","useFormContext","useId","watchedValue","useWatch","eligiblePolicy","policy","jsxs","Flex","TextInputField"],"mappings":";;;;;;;;;AAeA,MAAMA,IAAiB,CAAC;AAAA,EACtB,gBAAAC;AAAA,EACA,eAAAC;AAAA,EACA,WAAAC;AAAA,EACA,IAAAC;AACF,MAKM;AACJ,QAAM,EAAE,MAAAC,EAAA,IAASC,EAAA,GACX,EAAE,GAAAC,EAAA,IAAMC,EAAe,6BAA6B;AAE1D,MAAIN,MAAkB;AACpB,WAAO;AAIT,QAAMO,IADiB,WAAWR,CAAc,IACNE;AAE1C,SACE,gBAAAO,EAACL,KAAK,MAAK,MAAK,SAAQ,cAAa,aAAU,UAAS,eAAa,IAAM,IAAAD,GACxE,UAAAG,EAAE,4BAA4B,EAAE,SAASE,EAAiB,QAAQ,CAAC,EAAA,CAAG,GACzE;AAEJ,GAEaE,IAAe,CAAC,EAAE,SAAAC,GAAS,UAAAC,QAAkC;AACxE,QAAM,EAAE,GAAAN,EAAA,IAAMC,EAAe,6BAA6B;AAC1D,EAAAM,EAAQ,6BAA6B;AAErC,QAAM,EAAE,SAAAC,EAAA,IAAYC,EAAA,GACdZ,IAAKa,EAAA,GAELC,IAAeC,EAAS;AAAA,IAC5B,SAAAJ;AAAA,IACA,MAAM,wBAAwBH,EAAQ,IAAI;AAAA,EAAA,CAC3C;AAED,MAAI,CAACA,EAAQ;AACX,WAAO;AAGT,QAAMT,IAAY,WAAWe,KAAgB,GAAG,GAC1CE,IAAiBP,EAAS,qBAAqB,KAAK,OAAUQ,EAAO,SAAST,EAAQ,IAAI;AAEhG,SACE,gBAAAU,EAACC,GAAA,EAAK,eAAc,UAAS,KAAK,GAChC,UAAA;AAAA,IAAA,gBAAAb;AAAA,MAACc;AAAA,MAAA;AAAA,QAEC,MAAM,wBAAwBZ,EAAQ,IAAI;AAAA,QAC1C,MAAK;AAAA,QACL,cAAcL,EAAE,WAAW;AAAA,QAC3B,YAAU;AAAA,QACV,OAAOK,EAAQ;AAAA,QACf,oBAAkBR;AAAA,MAAA;AAAA,MANbQ,EAAQ;AAAA,IAAA;AAAA,IAQdQ,GAAgB,kBACf,gBAAAV;AAAA,MAACV;AAAA,MAAA;AAAA,QACC,gBAAgBoB,EAAe;AAAA,QAC/B,eAAeA,EAAe,iBAAiB;AAAA,QAC/C,WAAAjB;AAAA,QACA,IAAAC;AAAA,MAAA;AAAA,IAAA;AAAA,EACF,GAEJ;AAEJ;"}
1
+ {"version":3,"file":"TimeOffField.js","sources":["../../../../src/components/Payroll/PayrollEditEmployee/TimeOffField.tsx"],"sourcesContent":["import { useId } from 'react'\nimport { useWatch, useFormContext } from 'react-hook-form'\nimport { useTranslation } from 'react-i18next'\nimport type { Employee } from '@gusto/embedded-api/models/components/employee'\nimport type { PayrollEmployeeCompensationsTypePaidTimeOff } from '@gusto/embedded-api/models/components/payrollemployeecompensationstype'\nimport type { PayrollEditEmployeeFormValues } from './PayrollEditEmployeePresentation'\nimport { Flex, TextInputField } from '@/components/Common'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { useI18n } from '@/i18n'\n\nexport interface TimeOffFieldProps {\n timeOff: PayrollEmployeeCompensationsTypePaidTimeOff\n employee: Employee\n}\n\nconst TimeOffBalance = ({\n accrualBalance,\n accrualMethod,\n hoursUsed,\n id,\n}: {\n accrualBalance: string\n accrualMethod?: string\n hoursUsed: number\n id: string\n}) => {\n const { Text } = useComponentContext()\n const { t } = useTranslation('Payroll.PayrollEditEmployee')\n\n if (accrualMethod === 'unlimited') {\n return null\n }\n\n const currentBalance = parseFloat(accrualBalance)\n const remainingBalance = currentBalance - hoursUsed\n\n return (\n <Text size=\"sm\" variant=\"supporting\" aria-live=\"polite\" aria-atomic={true} id={id}>\n {t('timeOffBalance.remaining', { balance: remainingBalance.toFixed(1) })}\n </Text>\n )\n}\n\nexport const TimeOffField = ({ timeOff, employee }: TimeOffFieldProps) => {\n const { t } = useTranslation('Payroll.PayrollEditEmployee')\n useI18n('Payroll.PayrollEditEmployee')\n\n const { control } = useFormContext<PayrollEditEmployeeFormValues>()\n const id = useId()\n\n const watchedValue = useWatch({\n control,\n name: `timeOffCompensations.${timeOff.name}`,\n })\n\n if (!timeOff.name) {\n return null\n }\n\n const hoursUsed = parseFloat(watchedValue || '0')\n const eligiblePolicy = employee.eligiblePaidTimeOff?.find(policy => policy.name === timeOff.name)\n\n return (\n <Flex flexDirection=\"column\" gap={4}>\n <TextInputField\n key={timeOff.name}\n name={`timeOffCompensations.${timeOff.name}`}\n type=\"number\"\n adornmentEnd={t('hoursUnit')}\n isRequired\n label={timeOff.name}\n aria-describedby={id}\n />\n {eligiblePolicy?.accrualBalance && (\n <TimeOffBalance\n accrualBalance={eligiblePolicy.accrualBalance}\n accrualMethod={eligiblePolicy.accrualMethod ?? undefined}\n hoursUsed={hoursUsed}\n id={id}\n />\n )}\n </Flex>\n )\n}\n"],"names":["TimeOffBalance","accrualBalance","accrualMethod","hoursUsed","id","Text","useComponentContext","t","useTranslation","remainingBalance","jsx","TimeOffField","timeOff","employee","useI18n","control","useFormContext","useId","watchedValue","useWatch","eligiblePolicy","policy","jsxs","Flex","TextInputField"],"mappings":";;;;;;;;;;AAeA,MAAMA,IAAiB,CAAC;AAAA,EACtB,gBAAAC;AAAA,EACA,eAAAC;AAAA,EACA,WAAAC;AAAA,EACA,IAAAC;AACF,MAKM;AACJ,QAAM,EAAE,MAAAC,EAAA,IAASC,EAAA,GACX,EAAE,GAAAC,EAAA,IAAMC,EAAe,6BAA6B;AAE1D,MAAIN,MAAkB;AACpB,WAAO;AAIT,QAAMO,IADiB,WAAWR,CAAc,IACNE;AAE1C,SACE,gBAAAO,EAACL,KAAK,MAAK,MAAK,SAAQ,cAAa,aAAU,UAAS,eAAa,IAAM,IAAAD,GACxE,UAAAG,EAAE,4BAA4B,EAAE,SAASE,EAAiB,QAAQ,CAAC,EAAA,CAAG,GACzE;AAEJ,GAEaE,IAAe,CAAC,EAAE,SAAAC,GAAS,UAAAC,QAAkC;AACxE,QAAM,EAAE,GAAAN,EAAA,IAAMC,EAAe,6BAA6B;AAC1D,EAAAM,EAAQ,6BAA6B;AAErC,QAAM,EAAE,SAAAC,EAAA,IAAYC,EAAA,GACdZ,IAAKa,EAAA,GAELC,IAAeC,EAAS;AAAA,IAC5B,SAAAJ;AAAA,IACA,MAAM,wBAAwBH,EAAQ,IAAI;AAAA,EAAA,CAC3C;AAED,MAAI,CAACA,EAAQ;AACX,WAAO;AAGT,QAAMT,IAAY,WAAWe,KAAgB,GAAG,GAC1CE,IAAiBP,EAAS,qBAAqB,KAAK,OAAUQ,EAAO,SAAST,EAAQ,IAAI;AAEhG,SACE,gBAAAU,EAACC,GAAA,EAAK,eAAc,UAAS,KAAK,GAChC,UAAA;AAAA,IAAA,gBAAAb;AAAA,MAACc;AAAA,MAAA;AAAA,QAEC,MAAM,wBAAwBZ,EAAQ,IAAI;AAAA,QAC1C,MAAK;AAAA,QACL,cAAcL,EAAE,WAAW;AAAA,QAC3B,YAAU;AAAA,QACV,OAAOK,EAAQ;AAAA,QACf,oBAAkBR;AAAA,MAAA;AAAA,MANbQ,EAAQ;AAAA,IAAA;AAAA,IAQdQ,GAAgB,kBACf,gBAAAV;AAAA,MAACV;AAAA,MAAA;AAAA,QACC,gBAAgBoB,EAAe;AAAA,QAC/B,eAAeA,EAAe,iBAAiB;AAAA,QAC/C,WAAAjB;AAAA,QACA,IAAAC;AAAA,MAAA;AAAA,IAAA;AAAA,EACF,GAEJ;AAEJ;"}
@@ -3,18 +3,18 @@ import { useState as p, useMemo as L } from "react";
3
3
  import { usePayrollsListSuspense as C } from "@gusto/embedded-api/react-query/payrollsList";
4
4
  import { usePayrollsCancelMutation as R } from "@gusto/embedded-api/react-query/payrollsCancel";
5
5
  import { ProcessingStatuses as w } from "@gusto/embedded-api/models/operations/getv1companiescompanyidpayrolls";
6
- import { getPayrollStatus as I, getPayrollType as F } from "../helpers.js";
7
- import { PayrollHistoryPresentation as T } from "./PayrollHistoryPresentation.js";
8
- import { BaseComponent as M } from "../../Base/Base.js";
9
- import { useBase as V } from "../../Base/useBase.js";
6
+ import { calculateTotalPayroll as I, getPayrollStatus as T, getPayrollType as F } from "../helpers.js";
7
+ import { PayrollHistoryPresentation as M } from "./PayrollHistoryPresentation.js";
8
+ import { BaseComponent as V } from "../../Base/Base.js";
9
+ import { useBase as _ } from "../../Base/useBase.js";
10
10
  import { componentEvents as u } from "../../../shared/constants.js";
11
- import { useComponentDictionary as _, useI18n as E } from "../../../i18n/I18n.js";
12
- import { useLocale as H } from "../../../contexts/LocaleProvider/useLocale.js";
11
+ import { useComponentDictionary as E, useI18n as H } from "../../../i18n/I18n.js";
12
+ import { useLocale as A } from "../../../contexts/LocaleProvider/useLocale.js";
13
13
  import { parseDateStringToLocal as y } from "../../../helpers/dateFormatting.js";
14
- function X(t) {
15
- return /* @__PURE__ */ d(M, { ...t, children: /* @__PURE__ */ d(O, { ...t, children: t.children }) });
14
+ function v(t) {
15
+ return /* @__PURE__ */ d(V, { ...t, children: /* @__PURE__ */ d(b, { ...t, children: t.children }) });
16
16
  }
17
- const b = (t) => {
17
+ const O = (t) => {
18
18
  const e = /* @__PURE__ */ new Date(), o = /* @__PURE__ */ new Date();
19
19
  switch (t) {
20
20
  case "3months":
@@ -31,7 +31,7 @@ const b = (t) => {
31
31
  startDate: o.toISOString().split("T")[0] || "",
32
32
  endDate: e.toISOString().split("T")[0] || ""
33
33
  };
34
- }, A = (t, e) => {
34
+ }, Y = (t, e) => {
35
35
  const o = (a, n) => {
36
36
  if (!a || !n) return "";
37
37
  const s = y(a), l = y(n);
@@ -59,20 +59,21 @@ const b = (t) => {
59
59
  payPeriod: o(t.payPeriod?.startDate, t.payPeriod?.endDate),
60
60
  type: F(t),
61
61
  payDate: i(t.checkDate),
62
- status: I(t),
63
- amount: t.totals?.netPay ? Number(t.totals.netPay) : void 0,
62
+ status: T(t),
63
+ amount: I(t),
64
64
  payroll: t
65
65
  };
66
- }, O = ({ onEvent: t, companyId: e, dictionary: o }) => {
67
- _("Payroll.PayrollHistory", o), E("Payroll.PayrollHistory");
68
- const [i, a] = p("3months"), [n, s] = p(null), { locale: l } = H(), { baseSubmitHandler: m } = V(), c = L(() => b(i), [i]), { data: D } = C({
66
+ }, b = ({ onEvent: t, companyId: e, dictionary: o }) => {
67
+ E("Payroll.PayrollHistory", o), H("Payroll.PayrollHistory");
68
+ const [i, a] = p("3months"), [n, s] = p(null), { locale: l } = A(), { baseSubmitHandler: m } = _(), c = L(() => O(i), [i]), { data: D } = C({
69
69
  companyId: e,
70
70
  processingStatuses: [w.Processed],
71
71
  startDate: c.startDate,
72
- endDate: c.endDate
73
- }), { mutateAsync: g, isPending: h } = R(), f = D.payrollList?.map((r) => A(r, l)) || [];
72
+ endDate: c.endDate,
73
+ include: ["totals"]
74
+ }), { mutateAsync: g, isPending: h } = R(), f = D.payrollList?.map((r) => Y(r, l)) || [];
74
75
  return /* @__PURE__ */ d(
75
- T,
76
+ M,
76
77
  {
77
78
  payrollHistory: f,
78
79
  selectedTimeFilter: i,
@@ -108,7 +109,7 @@ const b = (t) => {
108
109
  );
109
110
  };
110
111
  export {
111
- X as PayrollHistory,
112
- O as Root
112
+ v as PayrollHistory,
113
+ b as Root
113
114
  };
114
115
  //# sourceMappingURL=PayrollHistory.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PayrollHistory.js","sources":["../../../../src/components/Payroll/PayrollHistory/PayrollHistory.tsx"],"sourcesContent":["import { useState, useMemo } from 'react'\nimport { usePayrollsListSuspense } from '@gusto/embedded-api/react-query/payrollsList'\nimport { usePayrollsCancelMutation } from '@gusto/embedded-api/react-query/payrollsCancel'\nimport { ProcessingStatuses } from '@gusto/embedded-api/models/operations/getv1companiescompanyidpayrolls'\nimport type { Payroll } from '@gusto/embedded-api/models/components/payroll'\nimport { getPayrollType, getPayrollStatus } from '../helpers'\nimport type { PayrollType } from '../PayrollList/types'\nimport { PayrollHistoryPresentation } from './PayrollHistoryPresentation'\nimport type { BaseComponentInterface } from '@/components/Base/Base'\nimport { BaseComponent } from '@/components/Base/Base'\nimport { useBase } from '@/components/Base/useBase'\nimport { componentEvents } from '@/shared/constants'\nimport { useComponentDictionary, useI18n } from '@/i18n'\nimport { useLocale } from '@/contexts/LocaleProvider/useLocale'\nimport { parseDateStringToLocal } from '@/helpers/dateFormatting'\n\nexport type PayrollHistoryStatus =\n | 'Unprocessed'\n | 'Submitted'\n | 'Pending'\n | 'Paid'\n | 'Complete'\n | 'In progress'\n\nexport type TimeFilterOption = '3months' | '6months' | 'year'\n\nexport interface PayrollHistoryItem {\n id: string\n payPeriod: string\n type: PayrollType\n payDate: string\n status: PayrollHistoryStatus\n amount?: number\n payroll: Payroll\n}\n\nexport interface PayrollHistoryProps extends BaseComponentInterface<'Payroll.PayrollHistory'> {\n companyId: string\n}\n\nexport function PayrollHistory(props: PayrollHistoryProps) {\n return (\n <BaseComponent {...props}>\n <Root {...props}>{props.children}</Root>\n </BaseComponent>\n )\n}\n\nconst getDateRangeForFilter = (\n filter: TimeFilterOption,\n): { startDate: string; endDate: string } => {\n const now = new Date()\n const startDate = new Date()\n\n switch (filter) {\n case '3months':\n startDate.setMonth(now.getMonth() - 3)\n break\n case '6months':\n startDate.setMonth(now.getMonth() - 6)\n break\n case 'year':\n startDate.setFullYear(now.getFullYear() - 1)\n break\n }\n\n return {\n startDate: startDate.toISOString().split('T')[0] || '',\n endDate: now.toISOString().split('T')[0] || '',\n }\n}\n\nconst mapPayrollToHistoryItem = (payroll: Payroll, locale: string): PayrollHistoryItem => {\n const formatPayPeriod = (startDate?: string, endDate?: string): string => {\n if (!startDate || !endDate) return ''\n\n const start = parseDateStringToLocal(startDate)\n const end = parseDateStringToLocal(endDate)\n\n if (!start || !end) return ''\n\n const startFormatted = start.toLocaleDateString(locale, {\n month: 'long',\n day: 'numeric',\n })\n\n const endFormatted = end.toLocaleDateString(locale, {\n month: 'long',\n day: 'numeric',\n year: 'numeric',\n })\n\n return `${startFormatted}–${endFormatted}`\n }\n\n const formatPayDate = (dateString?: string): string => {\n if (!dateString) return ''\n\n const date = parseDateStringToLocal(dateString)\n if (!date) return ''\n\n return date.toLocaleDateString(locale, {\n month: 'short',\n day: 'numeric',\n year: 'numeric',\n })\n }\n\n return {\n id: payroll.payrollUuid || payroll.uuid!,\n payPeriod: formatPayPeriod(payroll.payPeriod?.startDate, payroll.payPeriod?.endDate),\n type: getPayrollType(payroll),\n payDate: formatPayDate(payroll.checkDate),\n status: getPayrollStatus(payroll),\n amount: payroll.totals?.netPay ? Number(payroll.totals.netPay) : undefined,\n payroll,\n }\n}\n\nexport const Root = ({ onEvent, companyId, dictionary }: PayrollHistoryProps) => {\n useComponentDictionary('Payroll.PayrollHistory', dictionary)\n useI18n('Payroll.PayrollHistory')\n\n const [selectedTimeFilter, setSelectedTimeFilter] = useState<TimeFilterOption>('3months')\n const [cancelDialogItem, setCancelDialogItem] = useState<PayrollHistoryItem | null>(null)\n const { locale } = useLocale()\n const { baseSubmitHandler } = useBase()\n\n const dateRange = useMemo(() => getDateRangeForFilter(selectedTimeFilter), [selectedTimeFilter])\n\n const { data: payrollsData } = usePayrollsListSuspense({\n companyId,\n processingStatuses: [ProcessingStatuses.Processed],\n startDate: dateRange.startDate,\n endDate: dateRange.endDate,\n })\n\n const { mutateAsync: cancelPayroll, isPending: isCancelling } = usePayrollsCancelMutation()\n\n const payrollHistory =\n payrollsData.payrollList?.map(payroll => mapPayrollToHistoryItem(payroll, locale)) || []\n\n const handleViewSummary = (payrollId: string) => {\n onEvent(componentEvents.RUN_PAYROLL_SUMMARY_VIEWED, { payrollId })\n }\n\n const handleViewReceipt = (payrollId: string) => {\n onEvent(componentEvents.RUN_PAYROLL_RECEIPT_VIEWED, { payrollId })\n }\n\n const handleCancelPayroll = async (payrollId: string) => {\n try {\n await baseSubmitHandler(payrollId, async id => {\n const result = await cancelPayroll({\n request: {\n companyId,\n payrollId: id,\n },\n })\n\n onEvent(componentEvents.RUN_PAYROLL_CANCELLED, { payrollId: id, result })\n })\n } finally {\n setCancelDialogItem(null)\n }\n }\n\n return (\n <PayrollHistoryPresentation\n payrollHistory={payrollHistory}\n selectedTimeFilter={selectedTimeFilter}\n onTimeFilterChange={setSelectedTimeFilter}\n onViewSummary={handleViewSummary}\n onViewReceipt={handleViewReceipt}\n onCancelPayroll={handleCancelPayroll}\n cancelDialogItem={cancelDialogItem}\n onCancelDialogOpen={setCancelDialogItem}\n onCancelDialogClose={() => {\n setCancelDialogItem(null)\n }}\n isLoading={isCancelling}\n />\n )\n}\n"],"names":["PayrollHistory","props","jsx","BaseComponent","Root","getDateRangeForFilter","filter","now","startDate","mapPayrollToHistoryItem","payroll","locale","formatPayPeriod","endDate","start","parseDateStringToLocal","end","startFormatted","endFormatted","formatPayDate","dateString","date","getPayrollType","getPayrollStatus","onEvent","companyId","dictionary","useComponentDictionary","useI18n","selectedTimeFilter","setSelectedTimeFilter","useState","cancelDialogItem","setCancelDialogItem","useLocale","baseSubmitHandler","useBase","dateRange","useMemo","payrollsData","usePayrollsListSuspense","ProcessingStatuses","cancelPayroll","isCancelling","usePayrollsCancelMutation","payrollHistory","PayrollHistoryPresentation","payrollId","componentEvents","id","result"],"mappings":"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"}
1
+ {"version":3,"file":"PayrollHistory.js","sources":["../../../../src/components/Payroll/PayrollHistory/PayrollHistory.tsx"],"sourcesContent":["import { useState, useMemo } from 'react'\nimport { usePayrollsListSuspense } from '@gusto/embedded-api/react-query/payrollsList'\nimport { usePayrollsCancelMutation } from '@gusto/embedded-api/react-query/payrollsCancel'\nimport { ProcessingStatuses } from '@gusto/embedded-api/models/operations/getv1companiescompanyidpayrolls'\nimport type { Payroll } from '@gusto/embedded-api/models/components/payroll'\nimport { getPayrollType, getPayrollStatus, calculateTotalPayroll } from '../helpers'\nimport type { PayrollType } from '../PayrollList/types'\nimport { PayrollHistoryPresentation } from './PayrollHistoryPresentation'\nimport type { BaseComponentInterface } from '@/components/Base/Base'\nimport { BaseComponent } from '@/components/Base/Base'\nimport { useBase } from '@/components/Base/useBase'\nimport { componentEvents } from '@/shared/constants'\nimport { useComponentDictionary, useI18n } from '@/i18n'\nimport { useLocale } from '@/contexts/LocaleProvider/useLocale'\nimport { parseDateStringToLocal } from '@/helpers/dateFormatting'\n\nexport type PayrollHistoryStatus =\n | 'Unprocessed'\n | 'Submitted'\n | 'Pending'\n | 'Paid'\n | 'Complete'\n | 'In progress'\n\nexport type TimeFilterOption = '3months' | '6months' | 'year'\n\nexport interface PayrollHistoryItem {\n id: string\n payPeriod: string\n type: PayrollType\n payDate: string\n status: PayrollHistoryStatus\n amount?: number\n payroll: Payroll\n}\n\nexport interface PayrollHistoryProps extends BaseComponentInterface<'Payroll.PayrollHistory'> {\n companyId: string\n}\n\nexport function PayrollHistory(props: PayrollHistoryProps) {\n return (\n <BaseComponent {...props}>\n <Root {...props}>{props.children}</Root>\n </BaseComponent>\n )\n}\n\nconst getDateRangeForFilter = (\n filter: TimeFilterOption,\n): { startDate: string; endDate: string } => {\n const now = new Date()\n const startDate = new Date()\n\n switch (filter) {\n case '3months':\n startDate.setMonth(now.getMonth() - 3)\n break\n case '6months':\n startDate.setMonth(now.getMonth() - 6)\n break\n case 'year':\n startDate.setFullYear(now.getFullYear() - 1)\n break\n }\n\n return {\n startDate: startDate.toISOString().split('T')[0] || '',\n endDate: now.toISOString().split('T')[0] || '',\n }\n}\n\nconst mapPayrollToHistoryItem = (payroll: Payroll, locale: string): PayrollHistoryItem => {\n const formatPayPeriod = (startDate?: string, endDate?: string): string => {\n if (!startDate || !endDate) return ''\n\n const start = parseDateStringToLocal(startDate)\n const end = parseDateStringToLocal(endDate)\n\n if (!start || !end) return ''\n\n const startFormatted = start.toLocaleDateString(locale, {\n month: 'long',\n day: 'numeric',\n })\n\n const endFormatted = end.toLocaleDateString(locale, {\n month: 'long',\n day: 'numeric',\n year: 'numeric',\n })\n\n return `${startFormatted}–${endFormatted}`\n }\n\n const formatPayDate = (dateString?: string): string => {\n if (!dateString) return ''\n\n const date = parseDateStringToLocal(dateString)\n if (!date) return ''\n\n return date.toLocaleDateString(locale, {\n month: 'short',\n day: 'numeric',\n year: 'numeric',\n })\n }\n\n return {\n id: payroll.payrollUuid || payroll.uuid!,\n payPeriod: formatPayPeriod(payroll.payPeriod?.startDate, payroll.payPeriod?.endDate),\n type: getPayrollType(payroll),\n payDate: formatPayDate(payroll.checkDate),\n status: getPayrollStatus(payroll),\n amount: calculateTotalPayroll(payroll),\n payroll,\n }\n}\n\nexport const Root = ({ onEvent, companyId, dictionary }: PayrollHistoryProps) => {\n useComponentDictionary('Payroll.PayrollHistory', dictionary)\n useI18n('Payroll.PayrollHistory')\n\n const [selectedTimeFilter, setSelectedTimeFilter] = useState<TimeFilterOption>('3months')\n const [cancelDialogItem, setCancelDialogItem] = useState<PayrollHistoryItem | null>(null)\n const { locale } = useLocale()\n const { baseSubmitHandler } = useBase()\n\n const dateRange = useMemo(() => getDateRangeForFilter(selectedTimeFilter), [selectedTimeFilter])\n\n const { data: payrollsData } = usePayrollsListSuspense({\n companyId,\n processingStatuses: [ProcessingStatuses.Processed],\n startDate: dateRange.startDate,\n endDate: dateRange.endDate,\n include: ['totals'],\n })\n\n const { mutateAsync: cancelPayroll, isPending: isCancelling } = usePayrollsCancelMutation()\n\n const payrollHistory =\n payrollsData.payrollList?.map(payroll => mapPayrollToHistoryItem(payroll, locale)) || []\n\n const handleViewSummary = (payrollId: string) => {\n onEvent(componentEvents.RUN_PAYROLL_SUMMARY_VIEWED, { payrollId })\n }\n\n const handleViewReceipt = (payrollId: string) => {\n onEvent(componentEvents.RUN_PAYROLL_RECEIPT_VIEWED, { payrollId })\n }\n\n const handleCancelPayroll = async (payrollId: string) => {\n try {\n await baseSubmitHandler(payrollId, async id => {\n const result = await cancelPayroll({\n request: {\n companyId,\n payrollId: id,\n },\n })\n\n onEvent(componentEvents.RUN_PAYROLL_CANCELLED, { payrollId: id, result })\n })\n } finally {\n setCancelDialogItem(null)\n }\n }\n\n return (\n <PayrollHistoryPresentation\n payrollHistory={payrollHistory}\n selectedTimeFilter={selectedTimeFilter}\n onTimeFilterChange={setSelectedTimeFilter}\n onViewSummary={handleViewSummary}\n onViewReceipt={handleViewReceipt}\n onCancelPayroll={handleCancelPayroll}\n cancelDialogItem={cancelDialogItem}\n onCancelDialogOpen={setCancelDialogItem}\n onCancelDialogClose={() => {\n setCancelDialogItem(null)\n }}\n isLoading={isCancelling}\n />\n )\n}\n"],"names":["PayrollHistory","props","jsx","BaseComponent","Root","getDateRangeForFilter","filter","now","startDate","mapPayrollToHistoryItem","payroll","locale","formatPayPeriod","endDate","start","parseDateStringToLocal","end","startFormatted","endFormatted","formatPayDate","dateString","date","getPayrollType","getPayrollStatus","calculateTotalPayroll","onEvent","companyId","dictionary","useComponentDictionary","useI18n","selectedTimeFilter","setSelectedTimeFilter","useState","cancelDialogItem","setCancelDialogItem","useLocale","baseSubmitHandler","useBase","dateRange","useMemo","payrollsData","usePayrollsListSuspense","ProcessingStatuses","cancelPayroll","isCancelling","usePayrollsCancelMutation","payrollHistory","PayrollHistoryPresentation","payrollId","componentEvents","id","result"],"mappings":";;;;;;;;;;;;;AAwCO,SAASA,EAAeC,GAA4B;AACzD,SACE,gBAAAC,EAACC,GAAA,EAAe,GAAGF,GACjB,UAAA,gBAAAC,EAACE,KAAM,GAAGH,GAAQ,UAAAA,EAAM,SAAA,CAAS,EAAA,CACnC;AAEJ;AAEA,MAAMI,IAAwB,CAC5BC,MAC2C;AAC3C,QAAMC,wBAAU,KAAA,GACVC,wBAAgB,KAAA;AAEtB,UAAQF,GAAA;AAAA,IACN,KAAK;AACH,MAAAE,EAAU,SAASD,EAAI,SAAA,IAAa,CAAC;AACrC;AAAA,IACF,KAAK;AACH,MAAAC,EAAU,SAASD,EAAI,SAAA,IAAa,CAAC;AACrC;AAAA,IACF,KAAK;AACH,MAAAC,EAAU,YAAYD,EAAI,YAAA,IAAgB,CAAC;AAC3C;AAAA,EAAA;AAGJ,SAAO;AAAA,IACL,WAAWC,EAAU,YAAA,EAAc,MAAM,GAAG,EAAE,CAAC,KAAK;AAAA,IACpD,SAASD,EAAI,YAAA,EAAc,MAAM,GAAG,EAAE,CAAC,KAAK;AAAA,EAAA;AAEhD,GAEME,IAA0B,CAACC,GAAkBC,MAAuC;AACxF,QAAMC,IAAkB,CAACJ,GAAoBK,MAA6B;AACxE,QAAI,CAACL,KAAa,CAACK,EAAS,QAAO;AAEnC,UAAMC,IAAQC,EAAuBP,CAAS,GACxCQ,IAAMD,EAAuBF,CAAO;AAE1C,QAAI,CAACC,KAAS,CAACE,EAAK,QAAO;AAE3B,UAAMC,IAAiBH,EAAM,mBAAmBH,GAAQ;AAAA,MACtD,OAAO;AAAA,MACP,KAAK;AAAA,IAAA,CACN,GAEKO,IAAeF,EAAI,mBAAmBL,GAAQ;AAAA,MAClD,OAAO;AAAA,MACP,KAAK;AAAA,MACL,MAAM;AAAA,IAAA,CACP;AAED,WAAO,GAAGM,CAAc,IAAIC,CAAY;AAAA,EAC1C,GAEMC,IAAgB,CAACC,MAAgC;AACrD,QAAI,CAACA,EAAY,QAAO;AAExB,UAAMC,IAAON,EAAuBK,CAAU;AAC9C,WAAKC,IAEEA,EAAK,mBAAmBV,GAAQ;AAAA,MACrC,OAAO;AAAA,MACP,KAAK;AAAA,MACL,MAAM;AAAA,IAAA,CACP,IANiB;AAAA,EAOpB;AAEA,SAAO;AAAA,IACL,IAAID,EAAQ,eAAeA,EAAQ;AAAA,IACnC,WAAWE,EAAgBF,EAAQ,WAAW,WAAWA,EAAQ,WAAW,OAAO;AAAA,IACnF,MAAMY,EAAeZ,CAAO;AAAA,IAC5B,SAASS,EAAcT,EAAQ,SAAS;AAAA,IACxC,QAAQa,EAAiBb,CAAO;AAAA,IAChC,QAAQc,EAAsBd,CAAO;AAAA,IACrC,SAAAA;AAAA,EAAA;AAEJ,GAEaN,IAAO,CAAC,EAAE,SAAAqB,GAAS,WAAAC,GAAW,YAAAC,QAAsC;AAC/E,EAAAC,EAAuB,0BAA0BD,CAAU,GAC3DE,EAAQ,wBAAwB;AAEhC,QAAM,CAACC,GAAoBC,CAAqB,IAAIC,EAA2B,SAAS,GAClF,CAACC,GAAkBC,CAAmB,IAAIF,EAAoC,IAAI,GAClF,EAAE,QAAArB,EAAA,IAAWwB,EAAA,GACb,EAAE,mBAAAC,EAAA,IAAsBC,EAAA,GAExBC,IAAYC,EAAQ,MAAMlC,EAAsByB,CAAkB,GAAG,CAACA,CAAkB,CAAC,GAEzF,EAAE,MAAMU,EAAA,IAAiBC,EAAwB;AAAA,IACrD,WAAAf;AAAA,IACA,oBAAoB,CAACgB,EAAmB,SAAS;AAAA,IACjD,WAAWJ,EAAU;AAAA,IACrB,SAASA,EAAU;AAAA,IACnB,SAAS,CAAC,QAAQ;AAAA,EAAA,CACnB,GAEK,EAAE,aAAaK,GAAe,WAAWC,EAAA,IAAiBC,EAAA,GAE1DC,IACJN,EAAa,aAAa,IAAI,CAAA9B,MAAWD,EAAwBC,GAASC,CAAM,CAAC,KAAK,CAAA;AA2BxF,SACE,gBAAAT;AAAA,IAAC6C;AAAA,IAAA;AAAA,MACC,gBAAAD;AAAA,MACA,oBAAAhB;AAAA,MACA,oBAAoBC;AAAA,MACpB,eA9BsB,CAACiB,MAAsB;AAC/C,QAAAvB,EAAQwB,EAAgB,4BAA4B,EAAE,WAAAD,EAAA,CAAW;AAAA,MACnE;AAAA,MA6BI,eA3BsB,CAACA,MAAsB;AAC/C,QAAAvB,EAAQwB,EAAgB,4BAA4B,EAAE,WAAAD,EAAA,CAAW;AAAA,MACnE;AAAA,MA0BI,iBAxBwB,OAAOA,MAAsB;AACvD,YAAI;AACF,gBAAMZ,EAAkBY,GAAW,OAAME,MAAM;AAC7C,kBAAMC,IAAS,MAAMR,EAAc;AAAA,cACjC,SAAS;AAAA,gBACP,WAAAjB;AAAA,gBACA,WAAWwB;AAAA,cAAA;AAAA,YACb,CACD;AAED,YAAAzB,EAAQwB,EAAgB,uBAAuB,EAAE,WAAWC,GAAI,QAAAC,GAAQ;AAAA,UAC1E,CAAC;AAAA,QACH,UAAA;AACE,UAAAjB,EAAoB,IAAI;AAAA,QAC1B;AAAA,MACF;AAAA,MAUI,kBAAAD;AAAA,MACA,oBAAoBC;AAAA,MACpB,qBAAqB,MAAM;AACzB,QAAAA,EAAoB,IAAI;AAAA,MAC1B;AAAA,MACA,WAAWU;AAAA,IAAA;AAAA,EAAA;AAGjB;"}
@@ -3,12 +3,13 @@ import { useTranslation as j } from "react-i18next";
3
3
  import I from "./PayrollHistoryPresentation.module.scss.js";
4
4
  import { Flex as c } from "../../Common/Flex/Flex.js";
5
5
  import "classnames";
6
- import { useComponentContext as R } from "../../../contexts/ComponentAdapter/useComponentContext.js";
7
- import { formatNumberAsCurrency as Y } from "../../../helpers/formattedStrings.js";
8
- import { useI18n as Z } from "../../../i18n/I18n.js";
6
+ import "../../../shared/constants.js";
7
+ import { HamburgerMenu as R } from "../../Common/HamburgerMenu/HamburgerMenu.js";
8
+ import { useComponentContext as Y } from "../../../contexts/ComponentAdapter/useComponentContext.js";
9
+ import { formatNumberAsCurrency as Z } from "../../../helpers/formattedStrings.js";
10
+ import { useI18n as $ } from "../../../i18n/I18n.js";
9
11
  import S from "../../../assets/icons/list.svg.js";
10
- import $ from "../../../assets/icons/trashcan.svg.js";
11
- import { HamburgerMenu as q } from "../../Common/HamburgerMenu/HamburgerMenu.js";
12
+ import q from "../../../assets/icons/trashcan.svg.js";
12
13
  import { DataView as B } from "../../Common/DataView/DataView.js";
13
14
  const _ = (m) => {
14
15
  switch (m) {
@@ -24,20 +25,20 @@ const _ = (m) => {
24
25
  default:
25
26
  return "info";
26
27
  }
27
- }, ae = ({
28
+ }, oe = ({
28
29
  payrollHistory: m,
29
30
  selectedTimeFilter: b,
30
31
  onTimeFilterChange: w,
31
32
  onViewSummary: P,
32
33
  onViewReceipt: C,
33
- onCancelPayroll: T,
34
+ onCancelPayroll: v,
34
35
  cancelDialogItem: a,
35
- onCancelDialogOpen: v,
36
+ onCancelDialogOpen: T,
36
37
  onCancelDialogClose: F,
37
38
  isLoading: x = !1
38
39
  }) => {
39
- const { Heading: y, Text: o, Badge: A, Select: k, Dialog: H } = R();
40
- Z("Payroll.PayrollHistory");
40
+ const { Heading: f, Text: o, Badge: A, Select: k, Dialog: H } = Y();
41
+ $("Payroll.PayrollHistory");
41
42
  const { t } = j("Payroll.PayrollHistory"), V = [
42
43
  { value: "3months", label: t("timeFilter.options.3months") },
43
44
  { value: "6months", label: t("timeFilter.options.6months") },
@@ -47,12 +48,12 @@ const _ = (m) => {
47
48
  if (!(r === "Unprocessed" || r === "Submitted" || r === "Pending" || r === "In progress") || i.payrollStatusMeta?.cancellable === !1)
48
49
  return !1;
49
50
  if (i.processed && i.payrollDeadline) {
50
- const s = /* @__PURE__ */ new Date(), d = new Date(i.payrollDeadline), p = h(s), f = new Date(s.getTime() + p * 60 * 60 * 1e3), D = new Date(
51
+ const s = /* @__PURE__ */ new Date(), d = new Date(i.payrollDeadline), p = h(s), y = new Date(s.getTime() + p * 60 * 60 * 1e3), D = new Date(
51
52
  d.getTime() + h(d) * 60 * 60 * 1e3
52
53
  );
53
- if (f.toDateString() === D.toDateString()) {
54
+ if (y.toDateString() === D.toDateString()) {
54
55
  const g = new Date(D);
55
- if (g.setHours(15, 30, 0, 0), f > g)
56
+ if (g.setHours(15, 30, 0, 0), y > g)
56
57
  return !1;
57
58
  }
58
59
  }
@@ -78,9 +79,9 @@ const _ = (m) => {
78
79
  }), p = s.format(i);
79
80
  return `${d.format(i)} on ${p}`;
80
81
  }, N = (e) => {
81
- v(e);
82
+ T(e);
82
83
  }, O = () => {
83
- a && T(a.id);
84
+ a && v(a.id);
84
85
  }, U = (e) => {
85
86
  const r = [
86
87
  {
@@ -100,7 +101,7 @@ const _ = (m) => {
100
101
  ];
101
102
  return L(e) && r.push({
102
103
  label: t("menu.cancelPayroll"),
103
- icon: /* @__PURE__ */ n($, { "aria-hidden": !0 }),
104
+ icon: /* @__PURE__ */ n(q, { "aria-hidden": !0 }),
104
105
  onClick: () => {
105
106
  N(e);
106
107
  },
@@ -108,7 +109,7 @@ const _ = (m) => {
108
109
  }), r;
109
110
  };
110
111
  return m.length === 0 ? /* @__PURE__ */ u(c, { flexDirection: "column", alignItems: "center", gap: 24, children: [
111
- /* @__PURE__ */ n(y, { as: "h3", children: t("emptyState.title") }),
112
+ /* @__PURE__ */ n(f, { as: "h3", children: t("emptyState.title") }),
112
113
  /* @__PURE__ */ n(o, { children: t("emptyState.description") })
113
114
  ] }) : /* @__PURE__ */ u(c, { flexDirection: "column", gap: 16, children: [
114
115
  /* @__PURE__ */ u(
@@ -119,7 +120,7 @@ const _ = (m) => {
119
120
  alignItems: "flex-start",
120
121
  gap: { base: 12, medium: 24 },
121
122
  children: [
122
- /* @__PURE__ */ n(c, { children: /* @__PURE__ */ n(y, { as: "h2", children: t("title") }) }),
123
+ /* @__PURE__ */ n(c, { children: /* @__PURE__ */ n(f, { as: "h2", children: t("title") }) }),
123
124
  /* @__PURE__ */ n("div", { className: I.timeFilterContainer, children: /* @__PURE__ */ n(
124
125
  k,
125
126
  {
@@ -158,12 +159,12 @@ const _ = (m) => {
158
159
  render: (e) => /* @__PURE__ */ n(A, { status: _(e.status), children: e.status })
159
160
  },
160
161
  {
161
- title: t("columns.amount"),
162
- render: (e) => /* @__PURE__ */ n(o, { weight: "semibold", children: e.amount ? Y(e.amount) : t("labels.noAmount") })
162
+ title: t("columns.totalPayroll"),
163
+ render: (e) => /* @__PURE__ */ n(o, { weight: "semibold", children: e.amount !== void 0 ? Z(e.amount) : t("labels.noAmount") })
163
164
  }
164
165
  ],
165
166
  data: m,
166
- itemMenu: (e) => /* @__PURE__ */ n(q, { items: U(e) })
167
+ itemMenu: (e) => /* @__PURE__ */ n(R, { items: U(e) })
167
168
  }
168
169
  ),
169
170
  /* @__PURE__ */ n(
@@ -188,6 +189,6 @@ const _ = (m) => {
188
189
  ] });
189
190
  };
190
191
  export {
191
- ae as PayrollHistoryPresentation
192
+ oe as PayrollHistoryPresentation
192
193
  };
193
194
  //# sourceMappingURL=PayrollHistoryPresentation.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PayrollHistoryPresentation.js","sources":["../../../../src/components/Payroll/PayrollHistory/PayrollHistoryPresentation.tsx"],"sourcesContent":["import { useTranslation } from 'react-i18next'\nimport type { PayrollHistoryItem, PayrollHistoryStatus, TimeFilterOption } from './PayrollHistory'\nimport styles from './PayrollHistoryPresentation.module.scss'\nimport type { MenuItem } from '@/components/Common/UI/Menu/MenuTypes'\nimport { DataView, Flex } from '@/components/Common'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { HamburgerMenu } from '@/components/Common/HamburgerMenu'\nimport { formatNumberAsCurrency } from '@/helpers/formattedStrings'\nimport { useI18n } from '@/i18n'\nimport ListIcon from '@/assets/icons/list.svg?react'\nimport TrashcanIcon from '@/assets/icons/trashcan.svg?react'\n\ninterface PayrollHistoryPresentationProps {\n payrollHistory: PayrollHistoryItem[]\n selectedTimeFilter: TimeFilterOption\n onTimeFilterChange: (value: TimeFilterOption) => void\n onViewSummary: (payrollId: string) => void\n onViewReceipt: (payrollId: string) => void\n onCancelPayroll: (payrollId: string) => void\n cancelDialogItem: PayrollHistoryItem | null\n onCancelDialogOpen: (item: PayrollHistoryItem) => void\n onCancelDialogClose: () => void\n isLoading?: boolean\n}\n\nconst getStatusVariant = (status: PayrollHistoryStatus) => {\n switch (status) {\n case 'Complete':\n case 'Paid':\n return 'success'\n case 'In progress':\n case 'Unprocessed':\n return 'warning'\n case 'Submitted':\n case 'Pending':\n return 'info'\n default:\n return 'info'\n }\n}\n\nexport const PayrollHistoryPresentation = ({\n payrollHistory,\n selectedTimeFilter,\n onTimeFilterChange,\n onViewSummary,\n onViewReceipt,\n onCancelPayroll,\n cancelDialogItem,\n onCancelDialogOpen,\n onCancelDialogClose,\n isLoading = false,\n}: PayrollHistoryPresentationProps) => {\n const { Heading, Text, Badge, Select, Dialog } = useComponentContext()\n useI18n('Payroll.PayrollHistory')\n const { t } = useTranslation('Payroll.PayrollHistory')\n\n const timeFilterOptions = [\n { value: '3months', label: t('timeFilter.options.3months') },\n { value: '6months', label: t('timeFilter.options.6months') },\n { value: 'year', label: t('timeFilter.options.year') },\n ]\n\n const canCancelPayroll = (item: PayrollHistoryItem) => {\n const { status, payroll } = item\n\n const hasValidStatus =\n status === 'Unprocessed' ||\n status === 'Submitted' ||\n status === 'Pending' ||\n status === 'In progress'\n if (!hasValidStatus) return false\n\n if (payroll.payrollStatusMeta?.cancellable === false) {\n return false\n }\n\n // If payroll is processed, check the 3:30 PM PT deadline constraint\n if (payroll.processed && payroll.payrollDeadline) {\n const now = new Date()\n const deadline = new Date(payroll.payrollDeadline)\n\n const ptOffset = getPacificTimeOffset(now)\n const nowInPT = new Date(now.getTime() + ptOffset * 60 * 60 * 1000)\n const deadlineInPT = new Date(\n deadline.getTime() + getPacificTimeOffset(deadline) * 60 * 60 * 1000,\n )\n\n const isSameDay = nowInPT.toDateString() === deadlineInPT.toDateString()\n if (isSameDay) {\n const cutoffTime = new Date(deadlineInPT)\n cutoffTime.setHours(15, 30, 0, 0)\n\n if (nowInPT > cutoffTime) {\n return false\n }\n }\n }\n\n return true\n }\n\n const getPacificTimeOffset = (date: Date): number => {\n const year = date.getFullYear()\n\n const secondSundayMarch = new Date(year, 2, 1)\n secondSundayMarch.setDate(1 + (7 - secondSundayMarch.getDay()) + 7)\n\n const firstSundayNovember = new Date(year, 10, 1)\n firstSundayNovember.setDate(1 + ((7 - firstSundayNovember.getDay()) % 7))\n\n const isDST = date >= secondSundayMarch && date < firstSundayNovember\n return isDST ? -7 : -8\n }\n\n const formatDeadlineForDialog = (item: PayrollHistoryItem): string => {\n const deadline = item.payroll.payrollDeadline\n if (!deadline) return ''\n\n const deadlineDate = new Date(deadline)\n const timeZone = 'America/New_York'\n\n const formatter = new Intl.DateTimeFormat('en-US', {\n weekday: 'short',\n month: 'short',\n day: 'numeric',\n timeZone,\n })\n\n const timeFormatter = new Intl.DateTimeFormat('en-US', {\n hour: 'numeric',\n minute: '2-digit',\n timeZoneName: 'short',\n timeZone,\n })\n\n const dateStr = formatter.format(deadlineDate)\n const timeStr = timeFormatter.format(deadlineDate)\n\n return `${timeStr} on ${dateStr}`\n }\n\n const handleCancelClick = (item: PayrollHistoryItem) => {\n onCancelDialogOpen(item)\n }\n\n const handleConfirmCancel = () => {\n if (cancelDialogItem) {\n onCancelPayroll(cancelDialogItem.id)\n }\n }\n\n const getMenuItems = (item: PayrollHistoryItem): MenuItem[] => {\n const items: MenuItem[] = [\n {\n label: t('menu.viewSummary'),\n icon: <ListIcon aria-hidden />,\n onClick: () => {\n onViewSummary(item.id)\n },\n },\n {\n label: t('menu.viewReceipt'),\n icon: <ListIcon aria-hidden />,\n onClick: () => {\n onViewReceipt(item.id)\n },\n },\n ]\n\n if (canCancelPayroll(item)) {\n items.push({\n label: t('menu.cancelPayroll'),\n icon: <TrashcanIcon aria-hidden />,\n onClick: () => {\n handleCancelClick(item)\n },\n 'data-destructive': 'true',\n })\n }\n\n return items\n }\n\n if (payrollHistory.length === 0) {\n return (\n <Flex flexDirection=\"column\" alignItems=\"center\" gap={24}>\n <Heading as=\"h3\">{t('emptyState.title')}</Heading>\n <Text>{t('emptyState.description')}</Text>\n </Flex>\n )\n }\n\n return (\n <Flex flexDirection=\"column\" gap={16}>\n <Flex\n flexDirection={{ base: 'column', medium: 'row' }}\n justifyContent=\"space-between\"\n alignItems=\"flex-start\"\n gap={{ base: 12, medium: 24 }}\n >\n <Flex>\n <Heading as=\"h2\">{t('title')}</Heading>\n </Flex>\n <div className={styles.timeFilterContainer}>\n <Select\n value={selectedTimeFilter}\n onChange={(value: string) => {\n onTimeFilterChange(value as TimeFilterOption)\n }}\n options={timeFilterOptions}\n label={t('timeFilter.placeholder')}\n shouldVisuallyHideLabel\n isRequired\n />\n </div>\n </Flex>\n\n <DataView\n label={t('dataView.label')}\n columns={[\n {\n title: t('columns.payPeriod'),\n render: (item: PayrollHistoryItem) => <Text>{item.payPeriod}</Text>,\n },\n {\n title: t('columns.type'),\n render: (item: PayrollHistoryItem) => <Text>{item.type}</Text>,\n },\n {\n title: t('columns.payDate'),\n render: (item: PayrollHistoryItem) => <Text>{item.payDate}</Text>,\n },\n {\n title: t('columns.status'),\n render: (item: PayrollHistoryItem) => (\n <Badge status={getStatusVariant(item.status)}>{item.status}</Badge>\n ),\n },\n {\n title: t('columns.amount'),\n render: (item: PayrollHistoryItem) => (\n <Text weight=\"semibold\">\n {item.amount ? formatNumberAsCurrency(item.amount) : t('labels.noAmount')}\n </Text>\n ),\n },\n ]}\n data={payrollHistory}\n itemMenu={(item: PayrollHistoryItem) => <HamburgerMenu items={getMenuItems(item)} />}\n />\n\n <Dialog\n isOpen={!!cancelDialogItem}\n onClose={onCancelDialogClose}\n onPrimaryActionClick={handleConfirmCancel}\n isDestructive\n isPrimaryActionLoading={isLoading}\n primaryActionLabel={t('cancelDialog.primaryAction')}\n closeActionLabel={t('cancelDialog.secondaryAction')}\n title={\n cancelDialogItem ? t('cancelDialog.title', { payPeriod: cancelDialogItem.payPeriod }) : ''\n }\n >\n {cancelDialogItem && (\n <Flex flexDirection=\"column\" gap={16}>\n <Text>{t('cancelDialog.body')}</Text>\n {cancelDialogItem.payroll.payrollDeadline && (\n <Text>\n {t('cancelDialog.deadline', {\n deadline: formatDeadlineForDialog(cancelDialogItem),\n })}\n </Text>\n )}\n </Flex>\n )}\n </Dialog>\n </Flex>\n )\n}\n"],"names":["getStatusVariant","status","PayrollHistoryPresentation","payrollHistory","selectedTimeFilter","onTimeFilterChange","onViewSummary","onViewReceipt","onCancelPayroll","cancelDialogItem","onCancelDialogOpen","onCancelDialogClose","isLoading","Heading","Text","Badge","Select","Dialog","useComponentContext","useI18n","useTranslation","timeFilterOptions","canCancelPayroll","item","payroll","now","deadline","ptOffset","getPacificTimeOffset","nowInPT","deadlineInPT","cutoffTime","date","year","secondSundayMarch","firstSundayNovember","formatDeadlineForDialog","deadlineDate","timeZone","formatter","timeFormatter","dateStr","handleCancelClick","handleConfirmCancel","getMenuItems","items","jsx","ListIcon","TrashcanIcon","Flex","jsxs","styles","value","DataView","formatNumberAsCurrency","HamburgerMenu"],"mappings":"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"}
1
+ {"version":3,"file":"PayrollHistoryPresentation.js","sources":["../../../../src/components/Payroll/PayrollHistory/PayrollHistoryPresentation.tsx"],"sourcesContent":["import { useTranslation } from 'react-i18next'\nimport type { PayrollHistoryItem, PayrollHistoryStatus, TimeFilterOption } from './PayrollHistory'\nimport styles from './PayrollHistoryPresentation.module.scss'\nimport type { MenuItem } from '@/components/Common/UI/Menu/MenuTypes'\nimport { DataView, Flex } from '@/components/Common'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { HamburgerMenu } from '@/components/Common/HamburgerMenu'\nimport { formatNumberAsCurrency } from '@/helpers/formattedStrings'\nimport { useI18n } from '@/i18n'\nimport ListIcon from '@/assets/icons/list.svg?react'\nimport TrashcanIcon from '@/assets/icons/trashcan.svg?react'\n\ninterface PayrollHistoryPresentationProps {\n payrollHistory: PayrollHistoryItem[]\n selectedTimeFilter: TimeFilterOption\n onTimeFilterChange: (value: TimeFilterOption) => void\n onViewSummary: (payrollId: string) => void\n onViewReceipt: (payrollId: string) => void\n onCancelPayroll: (payrollId: string) => void\n cancelDialogItem: PayrollHistoryItem | null\n onCancelDialogOpen: (item: PayrollHistoryItem) => void\n onCancelDialogClose: () => void\n isLoading?: boolean\n}\n\nconst getStatusVariant = (status: PayrollHistoryStatus) => {\n switch (status) {\n case 'Complete':\n case 'Paid':\n return 'success'\n case 'In progress':\n case 'Unprocessed':\n return 'warning'\n case 'Submitted':\n case 'Pending':\n return 'info'\n default:\n return 'info'\n }\n}\n\nexport const PayrollHistoryPresentation = ({\n payrollHistory,\n selectedTimeFilter,\n onTimeFilterChange,\n onViewSummary,\n onViewReceipt,\n onCancelPayroll,\n cancelDialogItem,\n onCancelDialogOpen,\n onCancelDialogClose,\n isLoading = false,\n}: PayrollHistoryPresentationProps) => {\n const { Heading, Text, Badge, Select, Dialog } = useComponentContext()\n useI18n('Payroll.PayrollHistory')\n const { t } = useTranslation('Payroll.PayrollHistory')\n\n const timeFilterOptions = [\n { value: '3months', label: t('timeFilter.options.3months') },\n { value: '6months', label: t('timeFilter.options.6months') },\n { value: 'year', label: t('timeFilter.options.year') },\n ]\n\n const canCancelPayroll = (item: PayrollHistoryItem) => {\n const { status, payroll } = item\n\n const hasValidStatus =\n status === 'Unprocessed' ||\n status === 'Submitted' ||\n status === 'Pending' ||\n status === 'In progress'\n if (!hasValidStatus) return false\n\n if (payroll.payrollStatusMeta?.cancellable === false) {\n return false\n }\n\n // If payroll is processed, check the 3:30 PM PT deadline constraint\n if (payroll.processed && payroll.payrollDeadline) {\n const now = new Date()\n const deadline = new Date(payroll.payrollDeadline)\n\n const ptOffset = getPacificTimeOffset(now)\n const nowInPT = new Date(now.getTime() + ptOffset * 60 * 60 * 1000)\n const deadlineInPT = new Date(\n deadline.getTime() + getPacificTimeOffset(deadline) * 60 * 60 * 1000,\n )\n\n const isSameDay = nowInPT.toDateString() === deadlineInPT.toDateString()\n if (isSameDay) {\n const cutoffTime = new Date(deadlineInPT)\n cutoffTime.setHours(15, 30, 0, 0)\n\n if (nowInPT > cutoffTime) {\n return false\n }\n }\n }\n\n return true\n }\n\n const getPacificTimeOffset = (date: Date): number => {\n const year = date.getFullYear()\n\n const secondSundayMarch = new Date(year, 2, 1)\n secondSundayMarch.setDate(1 + (7 - secondSundayMarch.getDay()) + 7)\n\n const firstSundayNovember = new Date(year, 10, 1)\n firstSundayNovember.setDate(1 + ((7 - firstSundayNovember.getDay()) % 7))\n\n const isDST = date >= secondSundayMarch && date < firstSundayNovember\n return isDST ? -7 : -8\n }\n\n const formatDeadlineForDialog = (item: PayrollHistoryItem): string => {\n const deadline = item.payroll.payrollDeadline\n if (!deadline) return ''\n\n const deadlineDate = new Date(deadline)\n const timeZone = 'America/New_York'\n\n const formatter = new Intl.DateTimeFormat('en-US', {\n weekday: 'short',\n month: 'short',\n day: 'numeric',\n timeZone,\n })\n\n const timeFormatter = new Intl.DateTimeFormat('en-US', {\n hour: 'numeric',\n minute: '2-digit',\n timeZoneName: 'short',\n timeZone,\n })\n\n const dateStr = formatter.format(deadlineDate)\n const timeStr = timeFormatter.format(deadlineDate)\n\n return `${timeStr} on ${dateStr}`\n }\n\n const handleCancelClick = (item: PayrollHistoryItem) => {\n onCancelDialogOpen(item)\n }\n\n const handleConfirmCancel = () => {\n if (cancelDialogItem) {\n onCancelPayroll(cancelDialogItem.id)\n }\n }\n\n const getMenuItems = (item: PayrollHistoryItem): MenuItem[] => {\n const items: MenuItem[] = [\n {\n label: t('menu.viewSummary'),\n icon: <ListIcon aria-hidden />,\n onClick: () => {\n onViewSummary(item.id)\n },\n },\n {\n label: t('menu.viewReceipt'),\n icon: <ListIcon aria-hidden />,\n onClick: () => {\n onViewReceipt(item.id)\n },\n },\n ]\n\n if (canCancelPayroll(item)) {\n items.push({\n label: t('menu.cancelPayroll'),\n icon: <TrashcanIcon aria-hidden />,\n onClick: () => {\n handleCancelClick(item)\n },\n 'data-destructive': 'true',\n })\n }\n\n return items\n }\n\n if (payrollHistory.length === 0) {\n return (\n <Flex flexDirection=\"column\" alignItems=\"center\" gap={24}>\n <Heading as=\"h3\">{t('emptyState.title')}</Heading>\n <Text>{t('emptyState.description')}</Text>\n </Flex>\n )\n }\n\n return (\n <Flex flexDirection=\"column\" gap={16}>\n <Flex\n flexDirection={{ base: 'column', medium: 'row' }}\n justifyContent=\"space-between\"\n alignItems=\"flex-start\"\n gap={{ base: 12, medium: 24 }}\n >\n <Flex>\n <Heading as=\"h2\">{t('title')}</Heading>\n </Flex>\n <div className={styles.timeFilterContainer}>\n <Select\n value={selectedTimeFilter}\n onChange={(value: string) => {\n onTimeFilterChange(value as TimeFilterOption)\n }}\n options={timeFilterOptions}\n label={t('timeFilter.placeholder')}\n shouldVisuallyHideLabel\n isRequired\n />\n </div>\n </Flex>\n\n <DataView\n label={t('dataView.label')}\n columns={[\n {\n title: t('columns.payPeriod'),\n render: (item: PayrollHistoryItem) => <Text>{item.payPeriod}</Text>,\n },\n {\n title: t('columns.type'),\n render: (item: PayrollHistoryItem) => <Text>{item.type}</Text>,\n },\n {\n title: t('columns.payDate'),\n render: (item: PayrollHistoryItem) => <Text>{item.payDate}</Text>,\n },\n {\n title: t('columns.status'),\n render: (item: PayrollHistoryItem) => (\n <Badge status={getStatusVariant(item.status)}>{item.status}</Badge>\n ),\n },\n {\n title: t('columns.totalPayroll'),\n render: (item: PayrollHistoryItem) => (\n <Text weight=\"semibold\">\n {item.amount !== undefined\n ? formatNumberAsCurrency(item.amount)\n : t('labels.noAmount')}\n </Text>\n ),\n },\n ]}\n data={payrollHistory}\n itemMenu={(item: PayrollHistoryItem) => <HamburgerMenu items={getMenuItems(item)} />}\n />\n\n <Dialog\n isOpen={!!cancelDialogItem}\n onClose={onCancelDialogClose}\n onPrimaryActionClick={handleConfirmCancel}\n isDestructive\n isPrimaryActionLoading={isLoading}\n primaryActionLabel={t('cancelDialog.primaryAction')}\n closeActionLabel={t('cancelDialog.secondaryAction')}\n title={\n cancelDialogItem ? t('cancelDialog.title', { payPeriod: cancelDialogItem.payPeriod }) : ''\n }\n >\n {cancelDialogItem && (\n <Flex flexDirection=\"column\" gap={16}>\n <Text>{t('cancelDialog.body')}</Text>\n {cancelDialogItem.payroll.payrollDeadline && (\n <Text>\n {t('cancelDialog.deadline', {\n deadline: formatDeadlineForDialog(cancelDialogItem),\n })}\n </Text>\n )}\n </Flex>\n )}\n </Dialog>\n </Flex>\n )\n}\n"],"names":["getStatusVariant","status","PayrollHistoryPresentation","payrollHistory","selectedTimeFilter","onTimeFilterChange","onViewSummary","onViewReceipt","onCancelPayroll","cancelDialogItem","onCancelDialogOpen","onCancelDialogClose","isLoading","Heading","Text","Badge","Select","Dialog","useComponentContext","useI18n","useTranslation","timeFilterOptions","canCancelPayroll","item","payroll","now","deadline","ptOffset","getPacificTimeOffset","nowInPT","deadlineInPT","cutoffTime","date","year","secondSundayMarch","firstSundayNovember","formatDeadlineForDialog","deadlineDate","timeZone","formatter","timeFormatter","dateStr","handleCancelClick","handleConfirmCancel","getMenuItems","items","jsx","ListIcon","TrashcanIcon","Flex","jsxs","styles","value","DataView","formatNumberAsCurrency","HamburgerMenu"],"mappings":"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"}