@gusto/embedded-react-sdk 0.14.1 → 0.16.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +51 -0
- package/dist/assets/icons/feature-icon-check.svg.js +10 -0
- package/dist/assets/icons/feature-icon-check.svg.js.map +1 -0
- package/dist/components/Common/DataView/DataView.d.ts +2 -1
- package/dist/components/Common/DataView/DataView.js +19 -18
- package/dist/components/Common/DataView/DataView.js.map +1 -1
- package/dist/components/Common/FlowBreadcrumbs/FlowBreadcrumbs.d.ts +2 -0
- package/dist/components/Common/FlowBreadcrumbs/FlowBreadcrumbs.js +52 -0
- package/dist/components/Common/FlowBreadcrumbs/FlowBreadcrumbs.js.map +1 -0
- package/dist/components/Common/FlowBreadcrumbs/FlowBreadcrumbsTypes.d.ts +44 -0
- package/dist/components/Common/FlowBreadcrumbs/index.d.ts +3 -0
- package/dist/components/Common/PaginationControl/PaginationControl.js +36 -36
- package/dist/components/Common/PaginationControl/PaginationControl.js.map +1 -1
- package/dist/components/Common/PaginationControl/PaginationControlTypes.d.ts +3 -1
- package/dist/components/Common/UI/Breadcrumbs/Breadcrumbs.d.ts +2 -0
- package/dist/components/Common/UI/Breadcrumbs/Breadcrumbs.js +38 -0
- package/dist/components/Common/UI/Breadcrumbs/Breadcrumbs.js.map +1 -0
- package/dist/components/Common/UI/Breadcrumbs/Breadcrumbs.module.scss.js +16 -0
- package/dist/components/Common/UI/Breadcrumbs/Breadcrumbs.module.scss.js.map +1 -0
- package/dist/components/Common/UI/Breadcrumbs/BreadcrumbsTypes.d.ts +27 -0
- package/dist/components/Common/UI/Breadcrumbs/index.d.ts +3 -0
- package/dist/components/Common/UI/ProgressBar/ProgressBar.js +4 -4
- package/dist/components/Company/Locations/LocationsList/List.js +28 -26
- package/dist/components/Company/Locations/LocationsList/List.js.map +1 -1
- package/dist/components/Company/Locations/LocationsList/LocationsList.js +7 -6
- package/dist/components/Company/Locations/LocationsList/LocationsList.js.map +1 -1
- package/dist/components/Company/Locations/LocationsList/useLocationsList.d.ts +3 -1
- package/dist/components/Company/Locations/LocationsList/useLocationsList.js.map +1 -1
- package/dist/components/Company/OnboardingFlow/OnboardingFlow.js +10 -10
- package/dist/components/Company/OnboardingFlow/OnboardingFlow.js.map +1 -1
- package/dist/components/Company/OnboardingFlow/onboardingStateMachine.js +16 -10
- package/dist/components/Company/OnboardingFlow/onboardingStateMachine.js.map +1 -1
- package/dist/components/Company/PaySchedule/_parts/Edit.js +6 -6
- package/dist/components/Company/PaySchedule/_parts/Edit.js.map +1 -1
- package/dist/components/Contractor/ContractorList/index.js +59 -57
- package/dist/components/Contractor/ContractorList/index.js.map +1 -1
- package/dist/components/Contractor/ContractorList/useContractorList.d.ts +3 -1
- package/dist/components/Contractor/ContractorList/useContractorList.js +7 -6
- package/dist/components/Contractor/ContractorList/useContractorList.js.map +1 -1
- package/dist/components/Contractor/OnboardingFlow/onboardingStateMachine.js +37 -37
- package/dist/components/Contractor/OnboardingFlow/onboardingStateMachine.js.map +1 -1
- package/dist/components/Contractor/Profile/ContractorProfileForm.js +11 -11
- package/dist/components/Employee/EmployeeList/EmployeeList.js +11 -10
- package/dist/components/Employee/EmployeeList/EmployeeList.js.map +1 -1
- package/dist/components/Employee/EmployeeList/List.js +45 -43
- package/dist/components/Employee/EmployeeList/List.js.map +1 -1
- package/dist/components/Employee/EmployeeList/useEmployeeList.d.ts +3 -1
- package/dist/components/Employee/EmployeeList/useEmployeeList.js.map +1 -1
- package/dist/components/Flow/Flow.js +44 -24
- package/dist/components/Flow/Flow.js.map +1 -1
- package/dist/components/Flow/useFlow.d.ts +10 -1
- package/dist/components/Flow/useFlow.js.map +1 -1
- package/dist/components/Payroll/PayrollBlocker/PayrollBlocker.d.ts +1 -1
- package/dist/components/Payroll/PayrollBlocker/PayrollBlocker.js +16 -16
- package/dist/components/Payroll/PayrollBlocker/PayrollBlocker.js.map +1 -1
- package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerAlerts.js +20 -20
- package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerAlerts.js.map +1 -1
- package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerList.js +9 -9
- package/dist/components/Payroll/PayrollBlocker/components/PayrollBlockerList.js.map +1 -1
- package/dist/components/Payroll/PayrollConfiguration/PayrollConfiguration.js +128 -94
- package/dist/components/Payroll/PayrollConfiguration/PayrollConfiguration.js.map +1 -1
- package/dist/components/Payroll/PayrollConfiguration/PayrollConfigurationPresentation.d.ts +3 -1
- package/dist/components/Payroll/PayrollConfiguration/PayrollConfigurationPresentation.js +72 -76
- package/dist/components/Payroll/PayrollConfiguration/PayrollConfigurationPresentation.js.map +1 -1
- package/dist/components/Payroll/PayrollEditEmployee/PayrollEditEmployee.js +42 -42
- package/dist/components/Payroll/PayrollEditEmployee/PayrollEditEmployee.js.map +1 -1
- package/dist/components/Payroll/PayrollFlow/PayrollFlow.d.ts +1 -1
- package/dist/components/Payroll/PayrollFlow/PayrollFlow.js +20 -19
- package/dist/components/Payroll/PayrollFlow/PayrollFlow.js.map +1 -1
- package/dist/components/Payroll/PayrollFlow/PayrollFlowComponents.d.ts +5 -3
- package/dist/components/Payroll/PayrollFlow/PayrollFlowComponents.js +65 -45
- package/dist/components/Payroll/PayrollFlow/PayrollFlowComponents.js.map +1 -1
- package/dist/components/Payroll/PayrollFlow/index.d.ts +1 -1
- package/dist/components/Payroll/PayrollFlow/payrollStateMachine.d.ts +2 -0
- package/dist/components/Payroll/PayrollFlow/payrollStateMachine.js +233 -96
- package/dist/components/Payroll/PayrollFlow/payrollStateMachine.js.map +1 -1
- package/dist/components/Payroll/PayrollHistory/PayrollHistory.js +21 -20
- package/dist/components/Payroll/PayrollHistory/PayrollHistory.js.map +1 -1
- package/dist/components/Payroll/PayrollHistory/PayrollHistoryPresentation.js +12 -12
- package/dist/components/Payroll/PayrollHistory/PayrollHistoryPresentation.js.map +1 -1
- package/dist/components/Payroll/PayrollLanding/PayrollLandingFlowComponents.js +8 -9
- package/dist/components/Payroll/PayrollLanding/PayrollLandingFlowComponents.js.map +1 -1
- package/dist/components/Payroll/PayrollList/PayrollListPresentation.js +83 -78
- package/dist/components/Payroll/PayrollList/PayrollListPresentation.js.map +1 -1
- package/dist/components/Payroll/PayrollOverview/PayrollOverview.d.ts +1 -2
- package/dist/components/Payroll/PayrollOverview/PayrollOverview.js +41 -45
- package/dist/components/Payroll/PayrollOverview/PayrollOverview.js.map +1 -1
- package/dist/components/Payroll/PayrollOverview/PayrollOverviewPresentation.d.ts +1 -2
- package/dist/components/Payroll/PayrollOverview/PayrollOverviewPresentation.js +118 -119
- package/dist/components/Payroll/PayrollOverview/PayrollOverviewPresentation.js.map +1 -1
- package/dist/components/Payroll/PayrollReceipts/PayrollReceipts.d.ts +1 -2
- package/dist/components/Payroll/PayrollReceipts/PayrollReceipts.js +12 -26
- package/dist/components/Payroll/PayrollReceipts/PayrollReceipts.js.map +1 -1
- package/dist/components/Payroll/PayrollReceipts/PayrollReceiptsPresentation.d.ts +1 -2
- package/dist/components/Payroll/PayrollReceipts/PayrollReceiptsPresentation.js +40 -44
- package/dist/components/Payroll/PayrollReceipts/PayrollReceiptsPresentation.js.map +1 -1
- package/dist/components/Payroll/helpers.d.ts +2 -0
- package/dist/components/Payroll/helpers.js +38 -37
- package/dist/components/Payroll/helpers.js.map +1 -1
- package/dist/components/Payroll/usePreparedPayrollData.d.ts +4 -1
- package/dist/components/Payroll/usePreparedPayrollData.js +24 -18
- package/dist/components/Payroll/usePreparedPayrollData.js.map +1 -1
- package/dist/components/index.d.ts +1 -1
- package/dist/contexts/ComponentAdapter/adapters/defaultComponentAdapter.js +41 -39
- package/dist/contexts/ComponentAdapter/adapters/defaultComponentAdapter.js.map +1 -1
- package/dist/contexts/ComponentAdapter/componentAdapterTypes.d.ts +1 -0
- package/dist/contexts/ComponentAdapter/useComponentContext.d.ts +2 -0
- package/dist/contexts/ComponentAdapter/useComponentContext.js.map +1 -1
- package/dist/helpers/breadcrumbHelpers.d.ts +33 -0
- package/dist/helpers/breadcrumbHelpers.js +46 -0
- package/dist/helpers/breadcrumbHelpers.js.map +1 -0
- package/dist/helpers/breadcrumbHelpers.test.d.ts +1 -0
- package/dist/i18n/I18n.d.ts +1 -1
- package/dist/i18n/I18n.js +32 -23
- package/dist/i18n/I18n.js.map +1 -1
- package/dist/i18n/en/Company.PaySchedule.json.js +2 -2
- package/dist/i18n/en/Payroll.PayrollBlocker.json.js +28 -0
- package/dist/i18n/en/Payroll.PayrollBlocker.json.js.map +1 -0
- package/dist/i18n/en/Payroll.PayrollConfiguration.json.js +28 -24
- package/dist/i18n/en/Payroll.PayrollConfiguration.json.js.map +1 -1
- package/dist/i18n/en/Payroll.PayrollEditEmployee.json.js +28 -26
- package/dist/i18n/en/Payroll.PayrollEditEmployee.json.js.map +1 -1
- package/dist/i18n/en/Payroll.PayrollFlow.json.js +8 -0
- package/dist/i18n/en/Payroll.PayrollFlow.json.js.map +1 -0
- package/dist/i18n/en/Payroll.PayrollHistory.json.js +9 -9
- package/dist/i18n/en/Payroll.PayrollLanding.json.js +2 -2
- package/dist/i18n/en/Payroll.PayrollOverview.json.js +60 -56
- package/dist/i18n/en/Payroll.PayrollOverview.json.js.map +1 -1
- package/dist/i18n/en/Payroll.PayrollReceipts.json.js +16 -12
- package/dist/i18n/en/Payroll.PayrollReceipts.json.js.map +1 -1
- package/dist/index.js +1 -1
- package/dist/shared/constants.d.ts +3 -0
- package/dist/shared/constants.js +11 -9
- package/dist/shared/constants.js.map +1 -1
- package/dist/style.css +1 -1
- package/dist/types/i18next.d.ts +157 -150
- package/package.json +12 -12
- package/dist/components/Payroll/RunPayrollFlow/RunPayroll.d.ts +0 -23
- package/dist/components/Payroll/RunPayrollFlow/RunPayrollFlow.d.ts +0 -6
- package/dist/i18n/en/Payroll.RunPayroll.json.js +0 -8
- package/dist/i18n/en/Payroll.RunPayroll.json.js.map +0 -1
- package/dist/i18n/en/PayrollBlocker.json.js +0 -24
- package/dist/i18n/en/PayrollBlocker.json.js.map +0 -1
|
@@ -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 {
|
|
7
|
-
import { PayrollHistoryPresentation as
|
|
8
|
-
import { BaseComponent as
|
|
9
|
-
import { useBase as
|
|
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
|
|
12
|
-
import { useLocale as
|
|
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
|
|
15
|
-
return /* @__PURE__ */ d(
|
|
14
|
+
function v(t) {
|
|
15
|
+
return /* @__PURE__ */ d(V, { ...t, children: /* @__PURE__ */ d(b, { ...t, children: t.children }) });
|
|
16
16
|
}
|
|
17
|
-
const
|
|
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
|
-
},
|
|
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:
|
|
63
|
-
amount:
|
|
62
|
+
status: T(t),
|
|
63
|
+
amount: I(t),
|
|
64
64
|
payroll: t
|
|
65
65
|
};
|
|
66
|
-
},
|
|
67
|
-
|
|
68
|
-
const [i, a] = p("3months"), [n, s] = p(null), { locale: l } =
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
112
|
-
|
|
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:
|
|
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":"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"}
|
|
@@ -30,13 +30,13 @@ const _ = (m) => {
|
|
|
30
30
|
onTimeFilterChange: w,
|
|
31
31
|
onViewSummary: P,
|
|
32
32
|
onViewReceipt: C,
|
|
33
|
-
onCancelPayroll:
|
|
33
|
+
onCancelPayroll: v,
|
|
34
34
|
cancelDialogItem: a,
|
|
35
|
-
onCancelDialogOpen:
|
|
35
|
+
onCancelDialogOpen: T,
|
|
36
36
|
onCancelDialogClose: F,
|
|
37
37
|
isLoading: x = !1
|
|
38
38
|
}) => {
|
|
39
|
-
const { Heading:
|
|
39
|
+
const { Heading: f, Text: o, Badge: A, Select: k, Dialog: H } = R();
|
|
40
40
|
Z("Payroll.PayrollHistory");
|
|
41
41
|
const { t } = j("Payroll.PayrollHistory"), V = [
|
|
42
42
|
{ value: "3months", label: t("timeFilter.options.3months") },
|
|
@@ -47,12 +47,12 @@ const _ = (m) => {
|
|
|
47
47
|
if (!(r === "Unprocessed" || r === "Submitted" || r === "Pending" || r === "In progress") || i.payrollStatusMeta?.cancellable === !1)
|
|
48
48
|
return !1;
|
|
49
49
|
if (i.processed && i.payrollDeadline) {
|
|
50
|
-
const s = /* @__PURE__ */ new Date(), d = new Date(i.payrollDeadline), p = h(s),
|
|
50
|
+
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
51
|
d.getTime() + h(d) * 60 * 60 * 1e3
|
|
52
52
|
);
|
|
53
|
-
if (
|
|
53
|
+
if (y.toDateString() === D.toDateString()) {
|
|
54
54
|
const g = new Date(D);
|
|
55
|
-
if (g.setHours(15, 30, 0, 0),
|
|
55
|
+
if (g.setHours(15, 30, 0, 0), y > g)
|
|
56
56
|
return !1;
|
|
57
57
|
}
|
|
58
58
|
}
|
|
@@ -78,9 +78,9 @@ const _ = (m) => {
|
|
|
78
78
|
}), p = s.format(i);
|
|
79
79
|
return `${d.format(i)} on ${p}`;
|
|
80
80
|
}, N = (e) => {
|
|
81
|
-
|
|
81
|
+
T(e);
|
|
82
82
|
}, O = () => {
|
|
83
|
-
a &&
|
|
83
|
+
a && v(a.id);
|
|
84
84
|
}, U = (e) => {
|
|
85
85
|
const r = [
|
|
86
86
|
{
|
|
@@ -108,7 +108,7 @@ const _ = (m) => {
|
|
|
108
108
|
}), r;
|
|
109
109
|
};
|
|
110
110
|
return m.length === 0 ? /* @__PURE__ */ u(c, { flexDirection: "column", alignItems: "center", gap: 24, children: [
|
|
111
|
-
/* @__PURE__ */ n(
|
|
111
|
+
/* @__PURE__ */ n(f, { as: "h3", children: t("emptyState.title") }),
|
|
112
112
|
/* @__PURE__ */ n(o, { children: t("emptyState.description") })
|
|
113
113
|
] }) : /* @__PURE__ */ u(c, { flexDirection: "column", gap: 16, children: [
|
|
114
114
|
/* @__PURE__ */ u(
|
|
@@ -119,7 +119,7 @@ const _ = (m) => {
|
|
|
119
119
|
alignItems: "flex-start",
|
|
120
120
|
gap: { base: 12, medium: 24 },
|
|
121
121
|
children: [
|
|
122
|
-
/* @__PURE__ */ n(c, { children: /* @__PURE__ */ n(
|
|
122
|
+
/* @__PURE__ */ n(c, { children: /* @__PURE__ */ n(f, { as: "h2", children: t("title") }) }),
|
|
123
123
|
/* @__PURE__ */ n("div", { className: I.timeFilterContainer, children: /* @__PURE__ */ n(
|
|
124
124
|
k,
|
|
125
125
|
{
|
|
@@ -158,8 +158,8 @@ const _ = (m) => {
|
|
|
158
158
|
render: (e) => /* @__PURE__ */ n(A, { status: _(e.status), children: e.status })
|
|
159
159
|
},
|
|
160
160
|
{
|
|
161
|
-
title: t("columns.
|
|
162
|
-
render: (e) => /* @__PURE__ */ n(o, { weight: "semibold", children: e.amount ? Y(e.amount) : t("labels.noAmount") })
|
|
161
|
+
title: t("columns.totalPayroll"),
|
|
162
|
+
render: (e) => /* @__PURE__ */ n(o, { weight: "semibold", children: e.amount !== void 0 ? Y(e.amount) : t("labels.noAmount") })
|
|
163
163
|
}
|
|
164
164
|
],
|
|
165
165
|
data: m,
|
|
@@ -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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"}
|
|
@@ -9,7 +9,7 @@ import { useFlow as e } from "../../Flow/useFlow.js";
|
|
|
9
9
|
import { useI18n as P } from "../../../i18n/I18n.js";
|
|
10
10
|
import { useComponentContext as I } from "../../../contexts/ComponentAdapter/useComponentContext.js";
|
|
11
11
|
import { ensureRequired as n } from "../../../helpers/ensureRequired.js";
|
|
12
|
-
function
|
|
12
|
+
function O() {
|
|
13
13
|
const {
|
|
14
14
|
companyId: o,
|
|
15
15
|
onEvent: r,
|
|
@@ -38,25 +38,24 @@ function k() {
|
|
|
38
38
|
}
|
|
39
39
|
);
|
|
40
40
|
}
|
|
41
|
-
function
|
|
41
|
+
function S() {
|
|
42
42
|
const { payrollId: o, onEvent: r } = e();
|
|
43
|
-
return /* @__PURE__ */ t(b, { onEvent: r, payrollId: n(o)
|
|
43
|
+
return /* @__PURE__ */ t(b, { onEvent: r, payrollId: n(o) });
|
|
44
44
|
}
|
|
45
|
-
function
|
|
45
|
+
function j() {
|
|
46
46
|
const { companyId: o, payrollId: r, onEvent: a } = e();
|
|
47
47
|
return /* @__PURE__ */ t(
|
|
48
48
|
f,
|
|
49
49
|
{
|
|
50
50
|
onEvent: a,
|
|
51
51
|
companyId: n(o),
|
|
52
|
-
payrollId: n(r)
|
|
53
|
-
showBackButton: !0
|
|
52
|
+
payrollId: n(r)
|
|
54
53
|
}
|
|
55
54
|
);
|
|
56
55
|
}
|
|
57
56
|
export {
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
57
|
+
j as PayrollLandingOverviewContextual,
|
|
58
|
+
S as PayrollLandingReceiptsContextual,
|
|
59
|
+
O as PayrollLandingTabsContextual
|
|
61
60
|
};
|
|
62
61
|
//# sourceMappingURL=PayrollLandingFlowComponents.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PayrollLandingFlowComponents.js","sources":["../../../../src/components/Payroll/PayrollLanding/PayrollLandingFlowComponents.tsx"],"sourcesContent":["import { useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { PayrollHistory } from '../PayrollHistory/PayrollHistory'\nimport { PayrollList } from '../PayrollList/PayrollList'\nimport { PayrollOverview } from '../PayrollOverview/PayrollOverview'\nimport { PayrollReceipts } from '../PayrollReceipts/PayrollReceipts'\nimport type { BaseComponentInterface } from '@/components/Base/Base'\nimport { useFlow } from '@/components/Flow/useFlow'\nimport { useI18n } from '@/i18n'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { ensureRequired } from '@/helpers/ensureRequired'\nimport type { FlowContextInterface } from '@/components/Flow/useFlow'\n\nexport interface PayrollLandingFlowProps extends BaseComponentInterface<'Payroll.PayrollLanding'> {\n companyId: string\n}\n\nexport interface PayrollLandingFlowContextInterface extends FlowContextInterface {\n component: (() => React.JSX.Element) | null\n companyId: string\n payrollId?: string\n previousState?: 'tabs' | 'overview'\n selectedTab?: string\n}\n\nexport function PayrollLandingTabsContextual() {\n const {\n companyId,\n onEvent,\n selectedTab = 'run-payroll',\n } = useFlow<PayrollLandingFlowContextInterface>()\n const [currentTab, setCurrentTab] = useState(selectedTab)\n const { Tabs } = useComponentContext()\n\n useI18n('Payroll.PayrollLanding')\n const { t } = useTranslation('Payroll.PayrollLanding')\n\n const tabs = [\n {\n id: 'run-payroll',\n label: t('tabs.runPayroll'),\n content: <PayrollList companyId={ensureRequired(companyId)} onEvent={onEvent} />,\n },\n {\n id: 'payroll-history',\n label: t('tabs.payrollHistory'),\n content: <PayrollHistory companyId={ensureRequired(companyId)} onEvent={onEvent} />,\n },\n ]\n\n return (\n <Tabs\n tabs={tabs}\n selectedId={currentTab}\n onSelectionChange={setCurrentTab}\n aria-label={t('aria.tabNavigation')}\n />\n )\n}\n\nexport function PayrollLandingReceiptsContextual() {\n const { payrollId, onEvent } = useFlow<PayrollLandingFlowContextInterface>()\n\n return <PayrollReceipts onEvent={onEvent} payrollId={ensureRequired(payrollId)}
|
|
1
|
+
{"version":3,"file":"PayrollLandingFlowComponents.js","sources":["../../../../src/components/Payroll/PayrollLanding/PayrollLandingFlowComponents.tsx"],"sourcesContent":["import { useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { PayrollHistory } from '../PayrollHistory/PayrollHistory'\nimport { PayrollList } from '../PayrollList/PayrollList'\nimport { PayrollOverview } from '../PayrollOverview/PayrollOverview'\nimport { PayrollReceipts } from '../PayrollReceipts/PayrollReceipts'\nimport type { BaseComponentInterface } from '@/components/Base/Base'\nimport { useFlow } from '@/components/Flow/useFlow'\nimport { useI18n } from '@/i18n'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { ensureRequired } from '@/helpers/ensureRequired'\nimport type { FlowContextInterface } from '@/components/Flow/useFlow'\n\nexport interface PayrollLandingFlowProps extends BaseComponentInterface<'Payroll.PayrollLanding'> {\n companyId: string\n}\n\nexport interface PayrollLandingFlowContextInterface extends FlowContextInterface {\n component: (() => React.JSX.Element) | null\n companyId: string\n payrollId?: string\n previousState?: 'tabs' | 'overview'\n selectedTab?: string\n}\n\nexport function PayrollLandingTabsContextual() {\n const {\n companyId,\n onEvent,\n selectedTab = 'run-payroll',\n } = useFlow<PayrollLandingFlowContextInterface>()\n const [currentTab, setCurrentTab] = useState(selectedTab)\n const { Tabs } = useComponentContext()\n\n useI18n('Payroll.PayrollLanding')\n const { t } = useTranslation('Payroll.PayrollLanding')\n\n const tabs = [\n {\n id: 'run-payroll',\n label: t('tabs.runPayroll'),\n content: <PayrollList companyId={ensureRequired(companyId)} onEvent={onEvent} />,\n },\n {\n id: 'payroll-history',\n label: t('tabs.payrollHistory'),\n content: <PayrollHistory companyId={ensureRequired(companyId)} onEvent={onEvent} />,\n },\n ]\n\n return (\n <Tabs\n tabs={tabs}\n selectedId={currentTab}\n onSelectionChange={setCurrentTab}\n aria-label={t('aria.tabNavigation')}\n />\n )\n}\n\nexport function PayrollLandingReceiptsContextual() {\n const { payrollId, onEvent } = useFlow<PayrollLandingFlowContextInterface>()\n\n return <PayrollReceipts onEvent={onEvent} payrollId={ensureRequired(payrollId)} />\n}\n\nexport function PayrollLandingOverviewContextual() {\n const { companyId, payrollId, onEvent } = useFlow<PayrollLandingFlowContextInterface>()\n\n return (\n <PayrollOverview\n onEvent={onEvent}\n companyId={ensureRequired(companyId)}\n payrollId={ensureRequired(payrollId)}\n />\n )\n}\n"],"names":["PayrollLandingTabsContextual","companyId","onEvent","selectedTab","useFlow","currentTab","setCurrentTab","useState","Tabs","useComponentContext","useI18n","t","useTranslation","tabs","jsx","PayrollList","ensureRequired","PayrollHistory","PayrollLandingReceiptsContextual","payrollId","PayrollReceipts","PayrollLandingOverviewContextual","PayrollOverview"],"mappings":";;;;;;;;;;;AAyBO,SAASA,IAA+B;AAC7C,QAAM;AAAA,IACJ,WAAAC;AAAA,IACA,SAAAC;AAAA,IACA,aAAAC,IAAc;AAAA,EAAA,IACZC,EAAA,GACE,CAACC,GAAYC,CAAa,IAAIC,EAASJ,CAAW,GAClD,EAAE,MAAAK,EAAA,IAASC,EAAA;AAEjB,EAAAC,EAAQ,wBAAwB;AAChC,QAAM,EAAE,GAAAC,EAAA,IAAMC,EAAe,wBAAwB,GAE/CC,IAAO;AAAA,IACX;AAAA,MACE,IAAI;AAAA,MACJ,OAAOF,EAAE,iBAAiB;AAAA,MAC1B,SAAS,gBAAAG,EAACC,GAAA,EAAY,WAAWC,EAAef,CAAS,GAAG,SAAAC,EAAA,CAAkB;AAAA,IAAA;AAAA,IAEhF;AAAA,MACE,IAAI;AAAA,MACJ,OAAOS,EAAE,qBAAqB;AAAA,MAC9B,SAAS,gBAAAG,EAACG,GAAA,EAAe,WAAWD,EAAef,CAAS,GAAG,SAAAC,EAAA,CAAkB;AAAA,IAAA;AAAA,EACnF;AAGF,SACE,gBAAAY;AAAA,IAACN;AAAA,IAAA;AAAA,MACC,MAAAK;AAAA,MACA,YAAYR;AAAA,MACZ,mBAAmBC;AAAA,MACnB,cAAYK,EAAE,oBAAoB;AAAA,IAAA;AAAA,EAAA;AAGxC;AAEO,SAASO,IAAmC;AACjD,QAAM,EAAE,WAAAC,GAAW,SAAAjB,EAAA,IAAYE,EAAA;AAE/B,2BAAQgB,GAAA,EAAgB,SAAAlB,GAAkB,WAAWc,EAAeG,CAAS,GAAG;AAClF;AAEO,SAASE,IAAmC;AACjD,QAAM,EAAE,WAAApB,GAAW,WAAAkB,GAAW,SAAAjB,EAAA,IAAYE,EAAA;AAE1C,SACE,gBAAAU;AAAA,IAACQ;AAAA,IAAA;AAAA,MACC,SAAApB;AAAA,MACA,WAAWc,EAAef,CAAS;AAAA,MACnC,WAAWe,EAAeG,CAAS;AAAA,IAAA;AAAA,EAAA;AAGzC;"}
|
|
@@ -1,110 +1,115 @@
|
|
|
1
|
-
import { jsxs as
|
|
2
|
-
import { useState as
|
|
3
|
-
import { useTranslation as
|
|
4
|
-
import { PayrollBlockerAlerts as
|
|
5
|
-
import
|
|
6
|
-
import { Flex as
|
|
1
|
+
import { jsxs as i, jsx as l } from "react/jsx-runtime";
|
|
2
|
+
import { useState as V } from "react";
|
|
3
|
+
import { useTranslation as E } from "react-i18next";
|
|
4
|
+
import { PayrollBlockerAlerts as q } from "../PayrollBlocker/components/PayrollBlockerAlerts.js";
|
|
5
|
+
import b from "./PayrollListPresentation.module.scss.js";
|
|
6
|
+
import { Flex as s } from "../../Common/Flex/Flex.js";
|
|
7
7
|
import "classnames";
|
|
8
|
-
import { useComponentContext as
|
|
9
|
-
import { useI18n as
|
|
10
|
-
import { parseDateStringToLocal as
|
|
11
|
-
import { useLocale as
|
|
12
|
-
import
|
|
13
|
-
import {
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
8
|
+
import { useComponentContext as z } from "../../../contexts/ComponentAdapter/useComponentContext.js";
|
|
9
|
+
import { useI18n as G } from "../../../i18n/I18n.js";
|
|
10
|
+
import { formatDateToStringDate as J, parseDateStringToLocal as c } from "../../../helpers/dateFormatting.js";
|
|
11
|
+
import { useLocale as K } from "../../../contexts/LocaleProvider/useLocale.js";
|
|
12
|
+
import Q from "../../../assets/icons/feature-icon-check.svg.js";
|
|
13
|
+
import { HamburgerMenu as R } from "../../Common/HamburgerMenu/HamburgerMenu.js";
|
|
14
|
+
import { DataView as W } from "../../Common/DataView/DataView.js";
|
|
15
|
+
const ce = ({
|
|
16
|
+
onRunPayroll: L,
|
|
17
|
+
onSubmitPayroll: C,
|
|
18
|
+
onSkipPayroll: x,
|
|
19
|
+
onViewBlockers: I,
|
|
20
|
+
payrolls: v,
|
|
20
21
|
paySchedules: p,
|
|
21
|
-
showSkipSuccessAlert:
|
|
22
|
-
onDismissSkipSuccessAlert:
|
|
23
|
-
skippingPayrollId:
|
|
24
|
-
blockers:
|
|
22
|
+
showSkipSuccessAlert: w,
|
|
23
|
+
onDismissSkipSuccessAlert: A,
|
|
24
|
+
skippingPayrollId: H,
|
|
25
|
+
blockers: y
|
|
25
26
|
}) => {
|
|
26
|
-
const { Badge:
|
|
27
|
-
|
|
28
|
-
const { t } =
|
|
27
|
+
const { Badge: O, Button: h, Dialog: T, Heading: B, Text: n, Alert: M } = z();
|
|
28
|
+
G("Payroll.PayrollList");
|
|
29
|
+
const { t } = E("Payroll.PayrollList"), { locale: d } = K(), [m, D] = V({
|
|
29
30
|
isOpen: !1,
|
|
30
31
|
payrollId: null,
|
|
31
32
|
payPeriod: null
|
|
32
|
-
}),
|
|
33
|
-
|
|
33
|
+
}), j = (e, a) => {
|
|
34
|
+
D({
|
|
34
35
|
isOpen: !0,
|
|
35
36
|
payrollId: e,
|
|
36
|
-
payPeriod:
|
|
37
|
+
payPeriod: a
|
|
37
38
|
});
|
|
38
|
-
},
|
|
39
|
-
|
|
39
|
+
}, f = () => {
|
|
40
|
+
D({
|
|
40
41
|
isOpen: !1,
|
|
41
42
|
payrollId: null,
|
|
42
43
|
payPeriod: null
|
|
43
44
|
});
|
|
44
|
-
},
|
|
45
|
-
|
|
46
|
-
}, g = (e,
|
|
47
|
-
const
|
|
45
|
+
}, N = () => {
|
|
46
|
+
m.payrollId && (x({ payrollId: m.payrollId }), f());
|
|
47
|
+
}, g = (e, a) => {
|
|
48
|
+
const o = e ? c(e)?.toLocaleDateString(d, {
|
|
48
49
|
month: "short",
|
|
49
50
|
day: "numeric"
|
|
50
|
-
}) : null, r =
|
|
51
|
+
}) : null, r = a ? c(a)?.toLocaleDateString(d, {
|
|
51
52
|
month: "short",
|
|
52
53
|
day: "numeric",
|
|
53
54
|
year: "numeric"
|
|
54
55
|
}) : null;
|
|
55
56
|
return {
|
|
56
|
-
startDate:
|
|
57
|
+
startDate: o,
|
|
57
58
|
endDate: r,
|
|
58
|
-
fullPeriod:
|
|
59
|
+
fullPeriod: o && r ? `${o} – ${r}` : ""
|
|
59
60
|
};
|
|
60
61
|
};
|
|
61
|
-
return /* @__PURE__ */
|
|
62
|
-
|
|
63
|
-
|
|
62
|
+
return /* @__PURE__ */ i(s, { flexDirection: "column", gap: 16, children: [
|
|
63
|
+
w && /* @__PURE__ */ l("div", { className: b.alertContainer, children: /* @__PURE__ */ l(
|
|
64
|
+
M,
|
|
64
65
|
{
|
|
65
66
|
status: "info",
|
|
66
67
|
label: t("skipSuccessAlert"),
|
|
67
|
-
onDismiss:
|
|
68
|
+
onDismiss: A
|
|
68
69
|
}
|
|
69
70
|
) }),
|
|
70
|
-
/* @__PURE__ */ l(
|
|
71
|
+
/* @__PURE__ */ l(q, { blockers: y, onMultipleViewClick: I }),
|
|
71
72
|
/* @__PURE__ */ l(
|
|
72
|
-
|
|
73
|
+
s,
|
|
73
74
|
{
|
|
74
75
|
flexDirection: { base: "column", medium: "row" },
|
|
75
76
|
justifyContent: "space-between",
|
|
76
77
|
alignItems: "flex-start",
|
|
77
78
|
gap: { base: 12, medium: 24 },
|
|
78
|
-
children: /* @__PURE__ */ l(
|
|
79
|
+
children: /* @__PURE__ */ l(s, { children: /* @__PURE__ */ l(B, { as: "h2", children: t("title") }) })
|
|
79
80
|
}
|
|
80
81
|
),
|
|
81
82
|
/* @__PURE__ */ l(
|
|
82
|
-
|
|
83
|
+
W,
|
|
83
84
|
{
|
|
85
|
+
emptyState: () => /* @__PURE__ */ i(s, { flexDirection: "column", alignItems: "center", gap: 24, children: [
|
|
86
|
+
/* @__PURE__ */ l(Q, {}),
|
|
87
|
+
/* @__PURE__ */ l(n, { children: t("emptyState") })
|
|
88
|
+
] }),
|
|
84
89
|
columns: [
|
|
85
90
|
{
|
|
86
91
|
render: ({ payPeriod: e }) => {
|
|
87
|
-
const { startDate:
|
|
92
|
+
const { startDate: a, endDate: o } = g(
|
|
88
93
|
e?.startDate,
|
|
89
94
|
e?.endDate
|
|
90
95
|
);
|
|
91
|
-
return /* @__PURE__ */
|
|
92
|
-
/* @__PURE__ */
|
|
93
|
-
|
|
96
|
+
return /* @__PURE__ */ i(s, { flexDirection: "column", gap: 0, children: [
|
|
97
|
+
/* @__PURE__ */ i(n, { children: [
|
|
98
|
+
a,
|
|
94
99
|
" - ",
|
|
95
|
-
|
|
100
|
+
o
|
|
96
101
|
] }),
|
|
97
|
-
/* @__PURE__ */ l(
|
|
102
|
+
/* @__PURE__ */ l(n, { variant: "supporting", children: p.find((r) => r.uuid === e?.payScheduleUuid)?.name || p.find((r) => r.uuid === e?.payScheduleUuid)?.customName })
|
|
98
103
|
] });
|
|
99
104
|
},
|
|
100
105
|
title: t("tableHeaders.0")
|
|
101
106
|
},
|
|
102
107
|
{
|
|
103
|
-
render: ({ payrollType: e }) => /* @__PURE__ */ l(
|
|
108
|
+
render: ({ payrollType: e }) => /* @__PURE__ */ l(n, { children: t(`type.${e}`) }),
|
|
104
109
|
title: t("tableHeaders.1")
|
|
105
110
|
},
|
|
106
111
|
{
|
|
107
|
-
render: ({ checkDate: e }) => /* @__PURE__ */ l(
|
|
112
|
+
render: ({ checkDate: e }) => /* @__PURE__ */ l(n, { children: e ? c(e)?.toLocaleDateString(d, {
|
|
108
113
|
weekday: "short",
|
|
109
114
|
month: "short",
|
|
110
115
|
day: "numeric",
|
|
@@ -114,7 +119,7 @@ const le = ({
|
|
|
114
119
|
},
|
|
115
120
|
{
|
|
116
121
|
title: t("tableHeaders.3"),
|
|
117
|
-
render: ({ payrollDeadline: e }) => /* @__PURE__ */ l(
|
|
122
|
+
render: ({ payrollDeadline: e }) => /* @__PURE__ */ l(n, { children: e?.toLocaleDateString(d, {
|
|
118
123
|
weekday: "short",
|
|
119
124
|
month: "short",
|
|
120
125
|
day: "numeric",
|
|
@@ -123,52 +128,52 @@ const le = ({
|
|
|
123
128
|
},
|
|
124
129
|
{
|
|
125
130
|
title: t("tableHeaders.4"),
|
|
126
|
-
render: ({ processed: e }) => /* @__PURE__ */ l(
|
|
131
|
+
render: ({ processed: e }) => /* @__PURE__ */ l(O, { children: t(e ? "status.processed" : "status.unprocessed") })
|
|
127
132
|
}
|
|
128
133
|
],
|
|
129
|
-
data:
|
|
134
|
+
data: v,
|
|
130
135
|
label: t("payrollsListLabel"),
|
|
131
|
-
itemMenu: ({ payrollUuid: e, calculatedAt:
|
|
132
|
-
if (
|
|
136
|
+
itemMenu: ({ payrollUuid: e, calculatedAt: a, processed: o, payPeriod: r }) => {
|
|
137
|
+
if (o)
|
|
133
138
|
return null;
|
|
134
|
-
const
|
|
139
|
+
const u = H === e, { fullPeriod: $ } = g(
|
|
135
140
|
r?.startDate,
|
|
136
141
|
r?.endDate
|
|
137
|
-
);
|
|
138
|
-
return /* @__PURE__ */
|
|
139
|
-
|
|
140
|
-
|
|
142
|
+
), P = J(/* @__PURE__ */ new Date()), S = P ? c(P) : null, k = r?.startDate ? c(r.startDate) : null, F = y.length === 0 && S && k && S >= k;
|
|
143
|
+
return /* @__PURE__ */ i("div", { className: b.actionsContainer, children: [
|
|
144
|
+
a ? /* @__PURE__ */ l(
|
|
145
|
+
h,
|
|
141
146
|
{
|
|
142
|
-
isLoading:
|
|
147
|
+
isLoading: u,
|
|
143
148
|
onClick: () => {
|
|
144
|
-
|
|
149
|
+
C({ payrollId: e });
|
|
145
150
|
},
|
|
146
151
|
title: t("submitPayrollCta"),
|
|
147
152
|
variant: "secondary",
|
|
148
153
|
children: t("submitPayrollCta")
|
|
149
154
|
}
|
|
150
155
|
) : /* @__PURE__ */ l(
|
|
151
|
-
|
|
156
|
+
h,
|
|
152
157
|
{
|
|
153
|
-
isLoading:
|
|
158
|
+
isLoading: u,
|
|
154
159
|
onClick: () => {
|
|
155
|
-
|
|
160
|
+
L({ payrollId: e });
|
|
156
161
|
},
|
|
157
162
|
title: t("runPayrollTitle"),
|
|
158
163
|
variant: "secondary",
|
|
159
164
|
children: t("runPayrollTitle")
|
|
160
165
|
}
|
|
161
166
|
),
|
|
162
|
-
/* @__PURE__ */ l(
|
|
163
|
-
|
|
167
|
+
F && /* @__PURE__ */ l(
|
|
168
|
+
R,
|
|
164
169
|
{
|
|
165
|
-
isLoading:
|
|
170
|
+
isLoading: u,
|
|
166
171
|
menuLabel: t("payrollMenuLabel"),
|
|
167
172
|
items: [
|
|
168
173
|
{
|
|
169
174
|
label: t("skipPayrollCta"),
|
|
170
175
|
onClick: () => {
|
|
171
|
-
|
|
176
|
+
j(e, $);
|
|
172
177
|
}
|
|
173
178
|
}
|
|
174
179
|
]
|
|
@@ -179,13 +184,13 @@ const le = ({
|
|
|
179
184
|
}
|
|
180
185
|
),
|
|
181
186
|
/* @__PURE__ */ l(
|
|
182
|
-
|
|
187
|
+
T,
|
|
183
188
|
{
|
|
184
|
-
isOpen:
|
|
185
|
-
onClose:
|
|
186
|
-
onPrimaryActionClick:
|
|
189
|
+
isOpen: m.isOpen,
|
|
190
|
+
onClose: f,
|
|
191
|
+
onPrimaryActionClick: N,
|
|
187
192
|
isDestructive: !0,
|
|
188
|
-
title: t("skipPayrollDialog.title", { payPeriod:
|
|
193
|
+
title: t("skipPayrollDialog.title", { payPeriod: m.payPeriod }),
|
|
189
194
|
primaryActionLabel: t("skipPayrollDialog.confirmButton"),
|
|
190
195
|
closeActionLabel: t("skipPayrollDialog.cancelButton"),
|
|
191
196
|
children: t("skipPayrollDialog.body")
|
|
@@ -194,6 +199,6 @@ const le = ({
|
|
|
194
199
|
] });
|
|
195
200
|
};
|
|
196
201
|
export {
|
|
197
|
-
|
|
202
|
+
ce as PayrollListPresentation
|
|
198
203
|
};
|
|
199
204
|
//# sourceMappingURL=PayrollListPresentation.js.map
|