@gusto/embedded-react-sdk 0.45.0 → 0.46.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 (113) hide show
  1. package/CHANGELOG.md +14 -0
  2. package/dist/components/Company/AssignSignatory/CreateSignatory/useCreateSignatory.js +20 -4
  3. package/dist/components/Company/AssignSignatory/CreateSignatory/useCreateSignatory.js.map +1 -1
  4. package/dist/components/Company/AssignSignatory/InviteSignatory/useInviteSignatory.js +20 -4
  5. package/dist/components/Company/AssignSignatory/InviteSignatory/useInviteSignatory.js.map +1 -1
  6. package/dist/components/Company/AssignSignatory/useAssignSignatory.js +22 -6
  7. package/dist/components/Company/AssignSignatory/useAssignSignatory.js.map +1 -1
  8. package/dist/components/Company/BankAccount/BankAccountForm/context.js +20 -4
  9. package/dist/components/Company/BankAccount/BankAccountForm/context.js.map +1 -1
  10. package/dist/components/Company/DocumentSigner/DocumentList/useDocumentList.js +20 -4
  11. package/dist/components/Company/DocumentSigner/DocumentList/useDocumentList.js.map +1 -1
  12. package/dist/components/Company/DocumentSigner/shared/useSignCompanyForm/fields.js +4 -4
  13. package/dist/components/Company/FederalTaxes/useFederalTaxes.js +28 -12
  14. package/dist/components/Company/FederalTaxes/useFederalTaxes.js.map +1 -1
  15. package/dist/components/Company/Industry/Context.js +23 -7
  16. package/dist/components/Company/Industry/Context.js.map +1 -1
  17. package/dist/components/Company/Locations/LocationForm/useLocationForm.js +20 -4
  18. package/dist/components/Company/Locations/LocationForm/useLocationForm.js.map +1 -1
  19. package/dist/components/Company/Locations/LocationsList/useLocationsList.js +20 -4
  20. package/dist/components/Company/Locations/LocationsList/useLocationsList.js.map +1 -1
  21. package/dist/components/Company/OnboardingOverview/context.js +20 -4
  22. package/dist/components/Company/OnboardingOverview/context.js.map +1 -1
  23. package/dist/components/Company/PaySchedule/shared/usePayScheduleForm/fields.js +5 -5
  24. package/dist/components/Company/StateTaxes/StateTaxesForm/context.js +20 -4
  25. package/dist/components/Company/StateTaxes/StateTaxesForm/context.js.map +1 -1
  26. package/dist/components/Company/StateTaxes/StateTaxesList/context.js +20 -4
  27. package/dist/components/Company/StateTaxes/StateTaxesList/context.js.map +1 -1
  28. package/dist/components/Contractor/Address/useAddress.js +22 -6
  29. package/dist/components/Contractor/Address/useAddress.js.map +1 -1
  30. package/dist/components/Contractor/Profile/useContractorProfile.js +52 -42
  31. package/dist/components/Contractor/Profile/useContractorProfile.js.map +1 -1
  32. package/dist/components/Employee/Compensation/management/EditCompensation/EditCompensation.d.ts +11 -0
  33. package/dist/components/Employee/Compensation/management/EditCompensation/EditCompensation.js +230 -0
  34. package/dist/components/Employee/Compensation/management/EditCompensation/EditCompensation.js.map +1 -0
  35. package/dist/components/Employee/Compensation/management/EditCompensation/EditCompensation.module.scss.js +8 -0
  36. package/dist/components/Employee/Compensation/management/EditCompensation/EditCompensation.module.scss.js.map +1 -0
  37. package/dist/components/Employee/Compensation/management/EditCompensation/index.d.ts +3 -0
  38. package/dist/components/Employee/Compensation/management/index.d.ts +3 -0
  39. package/dist/components/Employee/Compensation/onboarding/EditCompensation/EditCompensation.js +6 -6
  40. package/dist/components/Employee/Compensation/onboarding/EditCompensation/EditCompensation.js.map +1 -1
  41. package/dist/components/Employee/Compensation/shared/useCompensationForm/fields.js +4 -4
  42. package/dist/components/Employee/Compensation/shared/useCompensationForm/useCompensationForm.js +114 -111
  43. package/dist/components/Employee/Compensation/shared/useCompensationForm/useCompensationForm.js.map +1 -1
  44. package/dist/components/Employee/Compensation/shared/useJobForm/fields.js +6 -6
  45. package/dist/components/Employee/Compensation/shared/useJobForm/jobSchema.d.ts +8 -0
  46. package/dist/components/Employee/Compensation/shared/useJobForm/jobSchema.js +22 -17
  47. package/dist/components/Employee/Compensation/shared/useJobForm/jobSchema.js.map +1 -1
  48. package/dist/components/Employee/Compensation/shared/useJobForm/useJobForm.d.ts +12 -2
  49. package/dist/components/Employee/Compensation/shared/useJobForm/useJobForm.js +115 -110
  50. package/dist/components/Employee/Compensation/shared/useJobForm/useJobForm.js.map +1 -1
  51. package/dist/components/Employee/Dashboard/BasicDetailsView.d.ts +8 -3
  52. package/dist/components/Employee/Dashboard/BasicDetailsView.js +108 -84
  53. package/dist/components/Employee/Dashboard/BasicDetailsView.js.map +1 -1
  54. package/dist/components/Employee/Dashboard/Dashboard.d.ts +2 -0
  55. package/dist/components/Employee/Dashboard/Dashboard.js +64 -58
  56. package/dist/components/Employee/Dashboard/Dashboard.js.map +1 -1
  57. package/dist/components/Employee/Dashboard/DashboardComponents.d.ts +5 -1
  58. package/dist/components/Employee/Dashboard/DashboardComponents.js +82 -65
  59. package/dist/components/Employee/Dashboard/DashboardComponents.js.map +1 -1
  60. package/dist/components/Employee/Dashboard/DocumentsView.js +18 -11
  61. package/dist/components/Employee/Dashboard/DocumentsView.js.map +1 -1
  62. package/dist/components/Employee/Dashboard/JobAndPayView.js +358 -338
  63. package/dist/components/Employee/Dashboard/JobAndPayView.js.map +1 -1
  64. package/dist/components/Employee/Dashboard/JobAndPayView.module.scss.js +8 -0
  65. package/dist/components/Employee/Dashboard/JobAndPayView.module.scss.js.map +1 -0
  66. package/dist/components/Employee/Dashboard/TaxesView.d.ts +7 -2
  67. package/dist/components/Employee/Dashboard/TaxesView.js +68 -54
  68. package/dist/components/Employee/Dashboard/TaxesView.js.map +1 -1
  69. package/dist/components/Employee/Dashboard/dashboardStateMachine.js +16 -5
  70. package/dist/components/Employee/Dashboard/dashboardStateMachine.js.map +1 -1
  71. package/dist/components/Employee/Dashboard/hooks/useEmployeeBasicDetails.d.ts +12 -5
  72. package/dist/components/Employee/Dashboard/hooks/useEmployeeBasicDetails.js +21 -21
  73. package/dist/components/Employee/Dashboard/hooks/useEmployeeBasicDetails.js.map +1 -1
  74. package/dist/components/Employee/Dashboard/hooks/useEmployeeCompensation.d.ts +13 -3
  75. package/dist/components/Employee/Dashboard/hooks/useEmployeeCompensation.js +55 -56
  76. package/dist/components/Employee/Dashboard/hooks/useEmployeeCompensation.js.map +1 -1
  77. package/dist/components/Employee/Dashboard/hooks/useEmployeeForms.d.ts +10 -4
  78. package/dist/components/Employee/Dashboard/hooks/useEmployeeForms.js +10 -12
  79. package/dist/components/Employee/Dashboard/hooks/useEmployeeForms.js.map +1 -1
  80. package/dist/components/Employee/Dashboard/hooks/useEmployeeTaxes.d.ts +10 -3
  81. package/dist/components/Employee/Dashboard/hooks/useEmployeeTaxes.js +19 -14
  82. package/dist/components/Employee/Dashboard/hooks/useEmployeeTaxes.js.map +1 -1
  83. package/dist/components/Employee/Deductions/shared/useChildSupportGarnishmentForm/fields.js +8 -8
  84. package/dist/components/Employee/Deductions/shared/useDeductionForm/fields.js +4 -4
  85. package/dist/components/Employee/Documents/onboarding/DocumentSigner/DocumentList/useDocumentList.js +20 -4
  86. package/dist/components/Employee/Documents/onboarding/DocumentSigner/DocumentList/useDocumentList.js.map +1 -1
  87. package/dist/components/Employee/Documents/shared/useSignEmployeeForm/fields.js +1 -1
  88. package/dist/components/Employee/FederalTaxes/shared/useFederalTaxesForm/fields.js +4 -4
  89. package/dist/components/Employee/PaymentMethod/shared/useBankForm/fields.js +1 -1
  90. package/dist/components/Employee/PaymentMethod/shared/useSplitPaymentsForm/splitFieldFactory.js +4 -4
  91. package/dist/components/Employee/Profile/shared/useEmployeeDetailsForm/fields.js +8 -8
  92. package/dist/components/Employee/Profile/shared/useHomeAddressForm/fields.js +5 -5
  93. package/dist/components/Employee/Profile/shared/useWorkAddressForm/fields.js +4 -4
  94. package/dist/components/Employee/StateTaxes/shared/useEmployeeStateTaxesForm/fieldComponents.js +8 -8
  95. package/dist/components/Employee/Taxes/useTaxes.js +20 -4
  96. package/dist/components/Employee/Taxes/useTaxes.js.map +1 -1
  97. package/dist/components/Payroll/GrossUpModal/GrossUpModal.js +34 -26
  98. package/dist/components/Payroll/GrossUpModal/GrossUpModal.js.map +1 -1
  99. package/dist/components/Payroll/usePreparedPayrollData.js +36 -22
  100. package/dist/components/Payroll/usePreparedPayrollData.js.map +1 -1
  101. package/dist/components/TimeOff/PolicySettings/PolicySettingsPresentation.js +52 -40
  102. package/dist/components/TimeOff/PolicySettings/PolicySettingsPresentation.js.map +1 -1
  103. package/dist/i18n/en/Employee.Compensation.json.js +48 -44
  104. package/dist/i18n/en/Employee.Compensation.json.js.map +1 -1
  105. package/dist/i18n/en/Employee.Dashboard.json.js +1 -1
  106. package/dist/i18n/en/Employee.DocumentManager.json.js +1 -1
  107. package/dist/i18n/en/common.json.d.ts +7 -0
  108. package/dist/shared/constants.d.ts +2 -0
  109. package/dist/shared/constants.js +19 -18
  110. package/dist/shared/constants.js.map +1 -1
  111. package/dist/style.css +1 -1
  112. package/dist/types/i18next.d.ts +22 -2
  113. package/package.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"JobAndPayView.js","sources":["../../../../src/components/Employee/Dashboard/JobAndPayView.tsx"],"sourcesContent":["import { useCallback, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { useGustoEmbeddedContext } from '@gusto/embedded-api/react-query/_context'\nimport { payrollsGetPayStub } from '@gusto/embedded-api/funcs/payrollsGetPayStub'\nimport { useErrorBoundary } from 'react-error-boundary'\nimport { useJobsAndCompensationsDeleteMutation } from '@gusto/embedded-api/react-query/jobsAndCompensationsDelete'\nimport type { Job } from '@gusto/embedded-api/models/components/job'\nimport type { EmployeeBankAccount } from '@gusto/embedded-api/models/components/employeebankaccount'\nimport type { Garnishment } from '@gusto/embedded-api/models/components/garnishment'\nimport type { GetV1EmployeesEmployeeUuidPayStubsResponse } from '@gusto/embedded-api/models/operations/getv1employeesemployeeuuidpaystubs'\nimport { useEmployeeCompensation } from './hooks'\nimport type { PendingCompensationChange } from './getPendingCompensationChanges'\nimport { usePendingChangeDetailRenderer } from './usePendingChangeDetailRenderer'\nimport { PendingChangesReviewModal } from './PendingChangesReviewModal'\nimport { Flex } from '@/components/Common/Flex/Flex'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { DataView, useDataView, EmptyData } from '@/components/Common'\nimport { HamburgerMenu } from '@/components/Common/HamburgerMenu'\nimport { BaseLayout } from '@/components/Base/Base'\nimport { composeErrorHandler } from '@/partner-hook-utils/composeErrorHandler'\nimport { readableStreamToBlob } from '@/helpers/readableStreamToBlob'\nimport { formatDateLongWithYear } from '@/helpers/dateFormatting'\nimport { useFormatCompensationRate } from '@/helpers/formattedStrings'\nimport useNumberFormatter from '@/hooks/useNumberFormatter'\nimport { useI18n } from '@/i18n'\nimport {\n usePaymentMethodList,\n useDeleteBankAccount,\n DeleteBankAccountDialog,\n} from '@/components/Employee/PaymentMethod/shared'\nimport {\n useDeductionsList,\n useDeleteDeduction,\n DeleteDeductionDialog,\n formatDeductionAmount,\n} from '@/components/Employee/Deductions/shared'\nimport { componentEvents, FlsaStatus, PAYMENT_METHODS, type EventType } from '@/shared/constants'\nimport type { OnEventType } from '@/components/Base/useBase'\nimport PlusCircleIcon from '@/assets/icons/plus-circle.svg?react'\nimport PercentCircleIcon from '@/assets/icons/percent-circle.svg?react'\nimport DownloadCloudIcon from '@/assets/icons/download-cloud.svg?react'\nimport TrashCanSvg from '@/assets/icons/trashcan.svg?react'\nimport PencilSvg from '@/assets/icons/pencil.svg?react'\n\ntype EmployeePayStub = NonNullable<\n GetV1EmployeesEmployeeUuidPayStubsResponse['employeePayStubsList']\n>[number]\n\nfunction parseJobRate(rate: Job['rate']): number | null {\n if (rate === undefined) return null\n const numericRate = parseFloat(rate)\n return Number.isFinite(numericRate) ? numericRate : null\n}\n\nexport interface JobAndPayViewProps {\n employeeId: string\n onEvent: OnEventType<EventType, unknown>\n onEditCompensation?: (job: Job) => void\n onAddJob?: () => void\n onAddAnotherJob?: () => void\n onAddDeduction?: () => void\n onEditDeduction?: (deduction: Garnishment) => void\n}\n\nexport function JobAndPayView({\n employeeId,\n onEvent,\n onEditCompensation,\n onAddJob,\n onAddAnotherJob,\n onAddDeduction,\n onEditDeduction,\n}: JobAndPayViewProps) {\n useI18n('Employee.PaymentMethod')\n useI18n('Employee.Compensation')\n useI18n('Employee.Deductions')\n const { t } = useTranslation('Employee.Dashboard')\n const { t: tPayment } = useTranslation('Employee.PaymentMethod')\n const { t: tCompensation } = useTranslation('Employee.Compensation')\n const { t: tDeductions } = useTranslation('Employee.Deductions')\n const Components = useComponentContext()\n const formatCompensationRate = useFormatCompensationRate()\n const formatCurrency = useNumberFormatter('currency')\n const formatPercent = useNumberFormatter('percent')\n const gustoEmbedded = useGustoEmbeddedContext()\n const { showBoundary } = useErrorBoundary()\n\n const compensation = useEmployeeCompensation({ employeeId })\n const jobs = compensation.isLoading ? [] : compensation.data.jobs\n const primaryFlsaStatus = compensation.isLoading ? undefined : compensation.data.primaryFlsaStatus\n const pendingChanges = compensation.isLoading ? [] : compensation.data.pendingChanges\n const hasMultipleJobsFromHook = compensation.isLoading ? false : compensation.data.hasMultipleJobs\n const payStubs = compensation.isLoading ? [] : compensation.data.payStubs\n const payStubsPagination = compensation.isLoading ? undefined : compensation.pagination.payStubs\n const cancellingCompensationUuid = compensation.isLoading\n ? null\n : compensation.status.cancellingCompensationUuid\n const cancelPendingChange = compensation.isLoading\n ? undefined\n : compensation.actions.cancelPendingChange\n const employeeFirstName = compensation.isLoading ? undefined : compensation.data.employeeFirstName\n\n const handleCancelChange = useCallback(\n async (pendingChange: PendingCompensationChange) => {\n if (!cancelPendingChange) return\n const result = await cancelPendingChange(pendingChange)\n if (result) {\n onEvent(componentEvents.EMPLOYEE_COMPENSATION_CHANGE_CANCELLED, {\n employeeId,\n compensationId: pendingChange.compensationUuid,\n })\n }\n },\n [cancelPendingChange, onEvent, employeeId],\n )\n\n const [downloadingPayrollUuids, setDownloadingPayrollUuids] = useState<ReadonlySet<string>>(\n () => new Set(),\n )\n\n const handlePaystubDownload = useCallback(\n async (payrollUuid: string) => {\n const newWindow = window.open('', '_blank', 'noopener,noreferrer')\n const loadingMessage = t('jobAndPay.paystubs.downloadLoadingMessage')\n if (newWindow) {\n // Avoid the user staring at about:blank while we fetch the PDF. The\n // navigation to the Blob URL below replaces this document.\n const doc = newWindow.document\n doc.title = loadingMessage\n const style = doc.createElement('style')\n style.textContent =\n 'body{font-family:system-ui,-apple-system,sans-serif;display:flex;align-items:center;' +\n 'justify-content:center;height:100vh;margin:0;color:#444;gap:12px}' +\n '.spinner{width:20px;height:20px;border:2px solid #ccc;border-top-color:#444;' +\n 'border-radius:50%;animation:spin .8s linear infinite}' +\n '@keyframes spin{to{transform:rotate(360deg)}}'\n doc.head.appendChild(style)\n const spinner = doc.createElement('div')\n spinner.className = 'spinner'\n spinner.setAttribute('aria-hidden', 'true')\n const label = doc.createElement('span')\n label.textContent = loadingMessage\n doc.body.replaceChildren(spinner, label)\n }\n setDownloadingPayrollUuids(prev => {\n const next = new Set(prev)\n next.add(payrollUuid)\n return next\n })\n try {\n const response = await payrollsGetPayStub(gustoEmbedded, {\n payrollId: payrollUuid,\n employeeId,\n })\n if (!response.value?.responseStream) {\n throw new Error(t('jobAndPay.paystubs.downloadError'))\n }\n const pdfBlob = await readableStreamToBlob(response.value.responseStream, 'application/pdf')\n const url = URL.createObjectURL(pdfBlob)\n if (newWindow) {\n newWindow.location.href = url\n }\n URL.revokeObjectURL(url)\n } catch (err) {\n if (newWindow) {\n newWindow.close()\n }\n showBoundary(err instanceof Error ? err : new Error(String(err)))\n } finally {\n setDownloadingPayrollUuids(prev => {\n const next = new Set(prev)\n next.delete(payrollUuid)\n return next\n })\n }\n },\n [gustoEmbedded, employeeId, t, showBoundary],\n )\n\n const [pendingDeleteJob, setPendingDeleteJob] = useState<{\n uuid: string\n title: string\n } | null>(null)\n\n const { mutateAsync: deleteEmployeeJob, isPending: isDeletingJob } =\n useJobsAndCompensationsDeleteMutation()\n\n const handleConfirmDeleteJob = async () => {\n if (!pendingDeleteJob) return\n const jobId = pendingDeleteJob.uuid\n await deleteEmployeeJob({ request: { jobId } })\n onEvent(componentEvents.EMPLOYEE_JOB_DELETED, { employeeId, jobId })\n setPendingDeleteJob(null)\n }\n\n const singleJob = jobs.length === 1 ? jobs[0]! : undefined\n const hasMultipleJobs = hasMultipleJobsFromHook\n const canAddAnotherJob = jobs.length >= 1 && primaryFlsaStatus === FlsaStatus.NONEXEMPT\n const singleJobNumericRate = singleJob ? parseJobRate(singleJob.rate) : null\n\n const [isReviewOpen, setIsReviewOpen] = useState(false)\n const renderDetail = usePendingChangeDetailRenderer(employeeFirstName)\n\n const hasPendingChanges = pendingChanges.length > 0\n const showSummaryAlert = hasMultipleJobs && pendingChanges.length > 1\n const showInlineAlert = hasPendingChanges && !showSummaryAlert\n const nextChange = pendingChanges[0]\n\n const paymentMethodList = usePaymentMethodList({ employeeId })\n const paymentMethod = paymentMethodList.isLoading\n ? undefined\n : paymentMethodList.data.paymentMethod\n const bankAccounts = paymentMethodList.isLoading ? [] : paymentMethodList.data.bankAccounts\n const deletePendingBankAccountUuid = paymentMethodList.isLoading\n ? undefined\n : paymentMethodList.status.deletePendingBankAccountUuid\n\n const { pendingDeleteAccount, setPendingDeleteAccount, handleConfirmDelete } =\n useDeleteBankAccount(async uuid => {\n if (paymentMethodList.isLoading) return\n const result = await paymentMethodList.actions.onDelete(uuid)\n if (result) {\n onEvent(componentEvents.EMPLOYEE_BANK_ACCOUNT_DELETED, result.data)\n }\n })\n\n const deductionsList = useDeductionsList({ employeeId })\n const deductions = deductionsList.isLoading ? [] : deductionsList.data.deductions\n const deletingGarnishmentUuid = deductionsList.isLoading\n ? undefined\n : deductionsList.status.deletingGarnishmentUuid\n\n const {\n pendingDeleteDeduction,\n setPendingDeleteDeduction,\n handleConfirmDelete: handleConfirmDeleteDeduction,\n } = useDeleteDeduction(async garnishment => {\n if (deductionsList.isLoading) return\n const result = await deductionsList.actions.onDelete(garnishment)\n if (result) {\n onEvent(componentEvents.EMPLOYEE_DEDUCTION_DELETED, result.data.garnishment)\n }\n })\n\n // All three hooks own their own error state; merge into one error\n // surface so the BaseLayout below shows whatever failed (read errors\n // from the queries, submit errors from delete/cancel actions).\n const errorHandling = composeErrorHandler([compensation, paymentMethodList, deductionsList])\n\n const jobsColumns = [\n {\n key: 'jobTitle',\n title: t('jobAndPay.compensation.columns.jobTitle'),\n render: (job: Job) => {\n const numericRate = parseJobRate(job.rate)\n return (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text>{job.title || '-'}</Components.Text>\n {numericRate !== null && job.paymentUnit ? (\n <Components.Text variant=\"supporting\">\n {formatCompensationRate(numericRate, job.paymentUnit)}\n </Components.Text>\n ) : null}\n </Flex>\n )\n },\n },\n {\n key: 'payType',\n title: t('jobAndPay.compensation.columns.payType'),\n render: (job: Job) => {\n const flsaStatus = job.compensations?.find(\n comp => comp.uuid === job.currentCompensationUuid,\n )?.flsaStatus\n return flsaStatus !== undefined ? tCompensation(`flsaStatusLabels.${flsaStatus}`) : '-'\n },\n },\n {\n key: 'startDate',\n title: t('jobAndPay.compensation.columns.startDate'),\n render: (job: Job) => (job.hireDate ? formatDateLongWithYear(job.hireDate) : '-'),\n },\n ]\n\n const jobsDataView = useDataView({\n data: jobs,\n columns: jobsColumns,\n itemMenu: (job: Job) => (\n <HamburgerMenu\n triggerLabel={t('jobAndPay.compensation.hamburgerTitle')}\n isLoading={isDeletingJob}\n items={[\n {\n label: t('jobAndPay.compensation.editJobCta'),\n icon: <PencilSvg aria-hidden />,\n onClick: () => {\n onEditCompensation?.(job)\n },\n },\n ...(!job.primary\n ? [\n {\n label: t('jobAndPay.compensation.deleteJobCta'),\n icon: <TrashCanSvg aria-hidden />,\n onClick: () => {\n setPendingDeleteJob({ uuid: job.uuid, title: job.title ?? '' })\n },\n },\n ]\n : []),\n ]}\n />\n ),\n })\n\n const bankAccountsColumns = [\n {\n key: 'nickname',\n title: t('jobAndPay.payment.nickname'),\n render: (bankAccount: EmployeeBankAccount) => bankAccount.name || '-',\n },\n {\n key: 'routingNumber',\n title: t('jobAndPay.payment.routingNumber'),\n render: (bankAccount: EmployeeBankAccount) => bankAccount.routingNumber || '-',\n },\n {\n key: 'accountType',\n title: t('jobAndPay.payment.accountType'),\n render: (bankAccount: EmployeeBankAccount) => bankAccount.accountType || '-',\n },\n ]\n\n const garnishmentsColumns = [\n {\n key: 'description',\n title: t('jobAndPay.deductions.deduction'),\n render: (garnishment: Garnishment) => garnishment.description || '-',\n },\n {\n key: 'frequency',\n title: t('jobAndPay.deductions.frequency'),\n render: (garnishment: Garnishment) =>\n garnishment.recurring\n ? t('jobAndPay.deductions.recurring')\n : t('jobAndPay.deductions.oneTime'),\n },\n {\n key: 'amount',\n title: t('jobAndPay.deductions.withhold'),\n render: (garnishment: Garnishment) =>\n formatDeductionAmount(garnishment, {\n formatCurrency,\n formatPercent,\n formatPerPaycheck: (value: string) =>\n t('jobAndPay.deductions.amountPerPaycheck', { value }),\n }),\n },\n ]\n\n const payStubsColumns = [\n {\n key: 'payday',\n title: t('jobAndPay.paystubs.payday'),\n render: (payStub: EmployeePayStub) => formatDateLongWithYear(payStub.checkDate) || '-',\n },\n {\n key: 'checkAmount',\n title: t('jobAndPay.paystubs.checkAmount'),\n render: (payStub: EmployeePayStub) => {\n if (!payStub.netPay) return '-'\n const amount = parseFloat(payStub.netPay)\n return isNaN(amount) ? '-' : formatCurrency(amount)\n },\n },\n {\n key: 'grossPay',\n title: t('jobAndPay.paystubs.grossPay'),\n render: (payStub: EmployeePayStub) => {\n if (!payStub.grossPay) return '-'\n const amount = parseFloat(payStub.grossPay)\n return isNaN(amount) ? '-' : formatCurrency(amount)\n },\n },\n {\n key: 'paymentMethod',\n title: t('jobAndPay.paystubs.paymentMethod'),\n render: () => paymentMethod?.type || t('jobAndPay.paystubs.noPaymentMethod'),\n },\n ]\n\n const bankAccountsDataView = useDataView({\n data: bankAccounts,\n columns: bankAccountsColumns,\n itemMenu: (bankAccount: EmployeeBankAccount) => (\n <HamburgerMenu\n items={[\n {\n label: tPayment('deleteBankAccountCta'),\n onClick: () => {\n setPendingDeleteAccount({\n uuid: bankAccount.uuid,\n hiddenAccountNumber: bankAccount.hiddenAccountNumber,\n })\n },\n icon: <TrashCanSvg aria-hidden />,\n },\n ]}\n triggerLabel={tPayment('hamburgerTitle')}\n />\n ),\n })\n\n const garnishmentsDataView = useDataView({\n data: deductions,\n columns: garnishmentsColumns,\n itemMenu: (garnishment: Garnishment) => (\n <HamburgerMenu\n isLoading={deletingGarnishmentUuid === garnishment.uuid}\n items={[\n {\n label: tDeductions('editCta'),\n onClick: () => onEditDeduction?.(garnishment),\n icon: <PencilSvg aria-hidden />,\n },\n {\n label: tDeductions('deleteCta'),\n onClick: () => {\n setPendingDeleteDeduction(garnishment)\n },\n icon: <TrashCanSvg aria-hidden />,\n },\n ]}\n triggerLabel={tDeductions('hamburgerTitle')}\n />\n ),\n emptyState: () => (\n <EmptyData\n title={t('jobAndPay.deductions.emptyState.title')}\n description={t('jobAndPay.deductions.emptyState.description')}\n />\n ),\n })\n\n const payStubsDataView = useDataView({\n data: payStubs,\n columns: payStubsColumns,\n pagination: payStubsPagination,\n itemMenu: payStub => {\n const isDownloading =\n !!payStub.payrollUuid && downloadingPayrollUuids.has(payStub.payrollUuid)\n return (\n <Components.ButtonIcon\n variant=\"tertiary\"\n aria-label={t('jobAndPay.paystubs.downloadCta')}\n isDisabled={!payStub.payrollUuid}\n isLoading={isDownloading}\n onClick={() => {\n if (payStub.payrollUuid) {\n void handlePaystubDownload(payStub.payrollUuid)\n }\n }}\n >\n <DownloadCloudIcon aria-hidden />\n </Components.ButtonIcon>\n )\n },\n emptyState: () => (\n <EmptyData\n title={t('jobAndPay.paystubs.emptyState.title')}\n description={t('jobAndPay.paystubs.emptyState.description')}\n />\n ),\n })\n\n if (compensation.isLoading || paymentMethodList.isLoading || deductionsList.isLoading) {\n return <BaseLayout isLoading error={errorHandling.errors} />\n }\n\n const isDirectDeposit = paymentMethod?.type === PAYMENT_METHODS.directDeposit\n\n return (\n <BaseLayout error={errorHandling.errors}>\n <Flex flexDirection=\"column\" gap={24}>\n <Components.Box\n withPadding={!hasMultipleJobs}\n header={\n <Components.BoxHeader\n title={t('jobAndPay.compensation.title')}\n action={\n hasMultipleJobs ? null : singleJob ? (\n <Components.Button\n variant=\"secondary\"\n onClick={() => {\n onEditCompensation?.(singleJob)\n }}\n >\n {t('jobAndPay.compensation.editCta')}\n </Components.Button>\n ) : (\n <Components.Button\n variant=\"secondary\"\n onClick={onAddJob}\n icon={<PlusCircleIcon />}\n >\n {t('jobAndPay.compensation.addJobCta')}\n </Components.Button>\n )\n }\n />\n }\n footer={\n canAddAnotherJob ? (\n <Components.Button\n variant=\"secondary\"\n onClick={onAddAnotherJob}\n icon={<PlusCircleIcon />}\n >\n {t('jobAndPay.compensation.addAnotherJobCta')}\n </Components.Button>\n ) : undefined\n }\n >\n <Flex flexDirection=\"column\" gap={16}>\n {showInlineAlert && nextChange && (\n <Components.Alert\n status=\"warning\"\n disableScrollIntoView\n label={\n hasMultipleJobs\n ? t('jobAndPay.compensation.pendingChange.alertLabelWithJob', {\n jobTitle: nextChange.jobTitle,\n date: formatDateLongWithYear(nextChange.effectiveDate),\n })\n : t('jobAndPay.compensation.pendingChange.alertLabel', {\n date: formatDateLongWithYear(nextChange.effectiveDate),\n })\n }\n >\n <Flex flexDirection=\"column\" gap={12}>\n <Components.UnorderedList\n items={nextChange.details.map(detail => renderDetail(detail))}\n />\n <div>\n <Components.Button\n variant=\"secondary\"\n isLoading={cancellingCompensationUuid === nextChange.compensationUuid}\n onClick={() => {\n void handleCancelChange(nextChange)\n }}\n >\n {t('jobAndPay.compensation.pendingChange.cancelCta')}\n </Components.Button>\n </div>\n </Flex>\n </Components.Alert>\n )}\n {showSummaryAlert && (\n <Components.Alert\n status=\"warning\"\n disableScrollIntoView\n label={t('jobAndPay.compensation.pendingChange.summaryLabel', {\n name: employeeFirstName ?? '',\n })}\n action={\n <Components.Button\n variant=\"secondary\"\n onClick={() => {\n setIsReviewOpen(true)\n }}\n >\n {t('jobAndPay.compensation.pendingChange.reviewCta')}\n </Components.Button>\n }\n />\n )}\n {hasMultipleJobs ? (\n <DataView\n label={t('jobAndPay.compensation.tableLabel')}\n isWithinBox\n {...jobsDataView}\n />\n ) : singleJob ? (\n <Flex flexDirection=\"column\" gap={12}>\n {singleJob.title && (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {t('jobAndPay.compensation.jobTitle')}\n </Components.Text>\n <Components.Text>{singleJob.title}</Components.Text>\n </Flex>\n )}\n\n {singleJob.paymentUnit && (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {t('jobAndPay.compensation.type')}\n </Components.Text>\n <Components.Text>\n {singleJob.paymentUnit === 'Hour'\n ? t('jobAndPay.compensation.types.hourly')\n : singleJob.paymentUnit === 'Salary' || singleJob.paymentUnit === 'Year'\n ? t('jobAndPay.compensation.types.salary')\n : singleJob.paymentUnit}\n </Components.Text>\n </Flex>\n )}\n\n {singleJobNumericRate !== null && singleJob.paymentUnit && (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {t('jobAndPay.compensation.wage')}\n </Components.Text>\n <Components.Text>\n {formatCompensationRate(singleJobNumericRate, singleJob.paymentUnit)}\n </Components.Text>\n </Flex>\n )}\n\n {singleJob.hireDate && (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {t('jobAndPay.compensation.startDate')}\n </Components.Text>\n <Components.Text>{formatDateLongWithYear(singleJob.hireDate)}</Components.Text>\n </Flex>\n )}\n </Flex>\n ) : (\n <EmptyData\n title={t('jobAndPay.compensation.emptyState.title')}\n description={t('jobAndPay.compensation.emptyState.description')}\n />\n )}\n </Flex>\n </Components.Box>\n\n <Components.Box\n withPadding={bankAccounts.length === 0}\n header={\n <Components.BoxHeader\n title={t('jobAndPay.payment.title')}\n action={\n <Flex gap={8} alignItems=\"center\" justifyContent=\"flex-end\">\n {isDirectDeposit && bankAccounts.length > 1 && (\n <Components.Button\n variant=\"secondary\"\n onClick={() => {\n onEvent(componentEvents.EMPLOYEE_SPLIT_PAYCHECK, { employeeId })\n }}\n icon={<PercentCircleIcon />}\n >\n {t('jobAndPay.payment.splitPaycheckCta')}\n </Components.Button>\n )}\n <Components.Button\n variant=\"secondary\"\n onClick={() => {\n onEvent(componentEvents.EMPLOYEE_BANK_ACCOUNT_CREATE, { employeeId })\n }}\n icon={<PlusCircleIcon />}\n >\n {t('jobAndPay.payment.addBankAccountCta')}\n </Components.Button>\n </Flex>\n }\n />\n }\n >\n {bankAccounts.length === 0 ? (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {tPayment('paymentMethodLabel')}\n </Components.Text>\n <Components.Text>\n {isDirectDeposit ? tPayment('directDepositLabel') : tPayment('checkLabel')}\n </Components.Text>\n </Flex>\n ) : (\n <DataView\n label={t('jobAndPay.payment.listLabel')}\n isWithinBox\n {...bankAccountsDataView}\n />\n )}\n </Components.Box>\n\n <Components.Box\n withPadding={false}\n header={\n <Components.BoxHeader\n title={t('jobAndPay.deductions.title')}\n action={\n <Components.Button\n variant=\"secondary\"\n onClick={onAddDeduction}\n icon={<PlusCircleIcon />}\n >\n {t('jobAndPay.deductions.addDeductionCta')}\n </Components.Button>\n }\n />\n }\n >\n <DataView\n label={t('jobAndPay.deductions.listLabel')}\n isWithinBox\n {...garnishmentsDataView}\n />\n </Components.Box>\n\n <Components.Box\n withPadding={false}\n header={<Components.BoxHeader title={t('jobAndPay.paystubs.title')} />}\n >\n <DataView label={t('jobAndPay.paystubs.listLabel')} isWithinBox {...payStubsDataView} />\n </Components.Box>\n\n <PendingChangesReviewModal\n isOpen={isReviewOpen}\n pendingChanges={pendingChanges}\n employeeFirstName={employeeFirstName}\n cancellingCompensationUuid={cancellingCompensationUuid}\n onClose={() => {\n setIsReviewOpen(false)\n }}\n onCancelChange={change => {\n void handleCancelChange(change)\n }}\n />\n\n <DeleteBankAccountDialog\n pendingDeleteAccount={pendingDeleteAccount}\n isPrimaryActionLoading={deletePendingBankAccountUuid === pendingDeleteAccount?.uuid}\n onClose={() => {\n setPendingDeleteAccount(null)\n }}\n onConfirm={() => {\n void handleConfirmDelete()\n }}\n />\n\n <DeleteDeductionDialog\n pendingDeleteDeduction={pendingDeleteDeduction}\n isPrimaryActionLoading={deletingGarnishmentUuid === pendingDeleteDeduction?.uuid}\n onClose={() => {\n setPendingDeleteDeduction(null)\n }}\n onConfirm={() => {\n void handleConfirmDeleteDeduction()\n }}\n />\n\n <Components.Dialog\n isOpen={pendingDeleteJob !== null}\n onClose={() => {\n setPendingDeleteJob(null)\n }}\n onPrimaryActionClick={() => {\n void handleConfirmDeleteJob()\n }}\n isPrimaryActionLoading={isDeletingJob}\n isDestructive\n title={t('jobAndPay.compensation.deleteJobDialog.title')}\n primaryActionLabel={t('jobAndPay.compensation.deleteJobDialog.confirmCta')}\n closeActionLabel={t('jobAndPay.compensation.deleteJobDialog.cancelCta')}\n >\n {pendingDeleteJob\n ? t('jobAndPay.compensation.deleteJobDialog.description', {\n jobTitle: pendingDeleteJob.title,\n })\n : null}\n </Components.Dialog>\n </Flex>\n </BaseLayout>\n )\n}\n"],"names":["parseJobRate","rate","numericRate","JobAndPayView","employeeId","onEvent","onEditCompensation","onAddJob","onAddAnotherJob","onAddDeduction","onEditDeduction","useI18n","useTranslation","tPayment","tCompensation","tDeductions","Components","useComponentContext","formatCompensationRate","useFormatCompensationRate","formatCurrency","useNumberFormatter","formatPercent","gustoEmbedded","useGustoEmbeddedContext","showBoundary","useErrorBoundary","compensation","useEmployeeCompensation","jobs","primaryFlsaStatus","pendingChanges","hasMultipleJobsFromHook","payStubs","payStubsPagination","cancellingCompensationUuid","cancelPendingChange","employeeFirstName","handleCancelChange","useCallback","pendingChange","componentEvents","downloadingPayrollUuids","setDownloadingPayrollUuids","useState","handlePaystubDownload","payrollUuid","newWindow","loadingMessage","doc","style","spinner","label","prev","next","response","payrollsGetPayStub","pdfBlob","readableStreamToBlob","url","err","pendingDeleteJob","setPendingDeleteJob","deleteEmployeeJob","isDeletingJob","useJobsAndCompensationsDeleteMutation","handleConfirmDeleteJob","jobId","singleJob","hasMultipleJobs","canAddAnotherJob","FlsaStatus","singleJobNumericRate","isReviewOpen","setIsReviewOpen","renderDetail","usePendingChangeDetailRenderer","hasPendingChanges","showSummaryAlert","showInlineAlert","nextChange","paymentMethodList","usePaymentMethodList","paymentMethod","bankAccounts","deletePendingBankAccountUuid","pendingDeleteAccount","setPendingDeleteAccount","handleConfirmDelete","useDeleteBankAccount","uuid","result","deductionsList","useDeductionsList","deductions","deletingGarnishmentUuid","pendingDeleteDeduction","setPendingDeleteDeduction","handleConfirmDeleteDeduction","useDeleteDeduction","garnishment","errorHandling","composeErrorHandler","jobsColumns","job","jsxs","Flex","jsx","flsaStatus","comp","formatDateLongWithYear","jobsDataView","useDataView","HamburgerMenu","PencilSvg","TrashCanSvg","bankAccountsColumns","bankAccount","garnishmentsColumns","formatDeductionAmount","value","payStubsColumns","payStub","amount","bankAccountsDataView","garnishmentsDataView","EmptyData","payStubsDataView","isDownloading","DownloadCloudIcon","BaseLayout","isDirectDeposit","PAYMENT_METHODS","PlusCircleIcon","detail","DataView","PercentCircleIcon","PendingChangesReviewModal","change","DeleteBankAccountDialog","DeleteDeductionDialog"],"mappings":"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"}
1
+ {"version":3,"file":"JobAndPayView.js","sources":["../../../../src/components/Employee/Dashboard/JobAndPayView.tsx"],"sourcesContent":["import { useCallback, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { useGustoEmbeddedContext } from '@gusto/embedded-api/react-query/_context'\nimport { payrollsGetPayStub } from '@gusto/embedded-api/funcs/payrollsGetPayStub'\nimport { useErrorBoundary } from 'react-error-boundary'\nimport { useJobsAndCompensationsDeleteMutation } from '@gusto/embedded-api/react-query/jobsAndCompensationsDelete'\nimport type { Job } from '@gusto/embedded-api/models/components/job'\nimport type { EmployeeBankAccount } from '@gusto/embedded-api/models/components/employeebankaccount'\nimport type { Garnishment } from '@gusto/embedded-api/models/components/garnishment'\nimport type { GetV1EmployeesEmployeeUuidPayStubsResponse } from '@gusto/embedded-api/models/operations/getv1employeesemployeeuuidpaystubs'\nimport { useEmployeeCompensation } from './hooks'\nimport type { PendingCompensationChange } from './getPendingCompensationChanges'\nimport { usePendingChangeDetailRenderer } from './usePendingChangeDetailRenderer'\nimport { PendingChangesReviewModal } from './PendingChangesReviewModal'\nimport styles from './JobAndPayView.module.scss'\nimport { Flex } from '@/components/Common/Flex/Flex'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { DataView, useDataView, EmptyData, Loading } from '@/components/Common'\nimport { HamburgerMenu } from '@/components/Common/HamburgerMenu'\nimport { BaseLayout } from '@/components/Base/Base'\nimport { composeErrorHandler } from '@/partner-hook-utils/composeErrorHandler'\nimport { readableStreamToBlob } from '@/helpers/readableStreamToBlob'\nimport { formatDateLongWithYear, formatDateToStringDate } from '@/helpers/dateFormatting'\nimport { useFormatCompensationRate } from '@/helpers/formattedStrings'\nimport useNumberFormatter from '@/hooks/useNumberFormatter'\nimport { useI18n } from '@/i18n'\nimport {\n usePaymentMethodList,\n useDeleteBankAccount,\n DeleteBankAccountDialog,\n} from '@/components/Employee/PaymentMethod/shared'\nimport {\n useDeductionsList,\n useDeleteDeduction,\n DeleteDeductionDialog,\n formatDeductionAmount,\n} from '@/components/Employee/Deductions/shared'\nimport { componentEvents, FlsaStatus, PAYMENT_METHODS, type EventType } from '@/shared/constants'\nimport type { OnEventType } from '@/components/Base/useBase'\nimport PlusCircleIcon from '@/assets/icons/plus-circle.svg?react'\nimport PercentCircleIcon from '@/assets/icons/percent-circle.svg?react'\nimport DownloadCloudIcon from '@/assets/icons/download-cloud.svg?react'\nimport TrashCanSvg from '@/assets/icons/trashcan.svg?react'\nimport PencilSvg from '@/assets/icons/pencil.svg?react'\n\ntype EmployeePayStub = NonNullable<\n GetV1EmployeesEmployeeUuidPayStubsResponse['employeePayStubsList']\n>[number]\n\nfunction parseJobRate(rate: Job['rate']): number | null {\n if (rate === undefined) return null\n const numericRate = parseFloat(rate)\n return Number.isFinite(numericRate) ? numericRate : null\n}\n\nexport interface JobAndPayViewProps {\n employeeId: string\n onEvent: OnEventType<EventType, unknown>\n onEditCompensation?: (job: Job) => void\n onAddJob?: () => void\n onAddAnotherJob?: () => void\n onAddDeduction?: () => void\n onEditDeduction?: (deduction: Garnishment) => void\n}\n\nexport function JobAndPayView({\n employeeId,\n onEvent,\n onEditCompensation,\n onAddJob,\n onAddAnotherJob,\n onAddDeduction,\n onEditDeduction,\n}: JobAndPayViewProps) {\n useI18n('Employee.PaymentMethod')\n useI18n('Employee.Compensation')\n useI18n('Employee.Deductions')\n const { t } = useTranslation('Employee.Dashboard')\n const { t: tPayment } = useTranslation('Employee.PaymentMethod')\n const { t: tCompensation } = useTranslation('Employee.Compensation')\n const { t: tDeductions } = useTranslation('Employee.Deductions')\n const Components = useComponentContext()\n const formatCompensationRate = useFormatCompensationRate()\n const formatCurrency = useNumberFormatter('currency')\n const formatPercent = useNumberFormatter('percent')\n const gustoEmbedded = useGustoEmbeddedContext()\n const { showBoundary } = useErrorBoundary()\n\n const compensation = useEmployeeCompensation({ employeeId })\n const {\n jobs,\n primaryFlsaStatus,\n pendingChanges,\n hasMultipleJobs: hasMultipleJobsFromHook,\n payStubs,\n employeeFirstName,\n } = compensation.data\n const payStubsPagination = compensation.pagination.payStubs\n const cancellingCompensationUuid = compensation.status.cancellingCompensationUuid\n const { cancelPendingChange } = compensation.actions\n const isCompensationCardLoading = compensation.status.isEmployeeLoading\n const isPayStubsLoading = compensation.status.isPayStubsLoading\n\n const handleCancelChange = useCallback(\n async (pendingChange: PendingCompensationChange) => {\n const result = await cancelPendingChange(pendingChange)\n if (result) {\n onEvent(componentEvents.EMPLOYEE_COMPENSATION_CHANGE_CANCELLED, {\n employeeId,\n compensationId: pendingChange.compensationUuid,\n })\n }\n },\n [cancelPendingChange, onEvent, employeeId],\n )\n\n const [downloadingPayrollUuids, setDownloadingPayrollUuids] = useState<ReadonlySet<string>>(\n () => new Set(),\n )\n\n const handlePaystubDownload = useCallback(\n async (payrollUuid: string) => {\n const newWindow = window.open('', '_blank', 'noopener,noreferrer')\n const loadingMessage = t('jobAndPay.paystubs.downloadLoadingMessage')\n if (newWindow) {\n // Avoid the user staring at about:blank while we fetch the PDF. The\n // navigation to the Blob URL below replaces this document.\n const doc = newWindow.document\n doc.title = loadingMessage\n const style = doc.createElement('style')\n style.textContent =\n 'body{font-family:system-ui,-apple-system,sans-serif;display:flex;align-items:center;' +\n 'justify-content:center;height:100vh;margin:0;color:#444;gap:12px}' +\n '.spinner{width:20px;height:20px;border:2px solid #ccc;border-top-color:#444;' +\n 'border-radius:50%;animation:spin .8s linear infinite}' +\n '@keyframes spin{to{transform:rotate(360deg)}}'\n doc.head.appendChild(style)\n const spinner = doc.createElement('div')\n spinner.className = 'spinner'\n spinner.setAttribute('aria-hidden', 'true')\n const label = doc.createElement('span')\n label.textContent = loadingMessage\n doc.body.replaceChildren(spinner, label)\n }\n setDownloadingPayrollUuids(prev => {\n const next = new Set(prev)\n next.add(payrollUuid)\n return next\n })\n try {\n const response = await payrollsGetPayStub(gustoEmbedded, {\n payrollId: payrollUuid,\n employeeId,\n })\n if (!response.value?.responseStream) {\n throw new Error(t('jobAndPay.paystubs.downloadError'))\n }\n const pdfBlob = await readableStreamToBlob(response.value.responseStream, 'application/pdf')\n const url = URL.createObjectURL(pdfBlob)\n if (newWindow) {\n newWindow.location.href = url\n }\n URL.revokeObjectURL(url)\n } catch (err) {\n if (newWindow) {\n newWindow.close()\n }\n showBoundary(err instanceof Error ? err : new Error(String(err)))\n } finally {\n setDownloadingPayrollUuids(prev => {\n const next = new Set(prev)\n next.delete(payrollUuid)\n return next\n })\n }\n },\n [gustoEmbedded, employeeId, t, showBoundary],\n )\n\n const [pendingDeleteJob, setPendingDeleteJob] = useState<{\n uuid: string\n title: string\n } | null>(null)\n\n const { mutateAsync: deleteEmployeeJob, isPending: isDeletingJob } =\n useJobsAndCompensationsDeleteMutation()\n\n const handleConfirmDeleteJob = async () => {\n if (!pendingDeleteJob) return\n const jobId = pendingDeleteJob.uuid\n await deleteEmployeeJob({ request: { jobId } })\n onEvent(componentEvents.EMPLOYEE_JOB_DELETED, { employeeId, jobId })\n setPendingDeleteJob(null)\n }\n\n const singleJob = jobs.length === 1 ? jobs[0]! : undefined\n const hasMultipleJobs = hasMultipleJobsFromHook\n // Block adding a secondary if the primary already has a future-dated\n // compensation that isn't Nonexempt — that comp will delete secondary jobs\n // at its effective date, matching the gws-flows guard on the new-job action.\n // Use local date (not UTC) so the comparison matches how effectiveDate strings\n // are handled throughout the dashboard (same as getPendingCompensationChanges).\n const localTodayISO = formatDateToStringDate(new Date()) ?? ''\n const primaryJob = jobs.find(j => j.primary)\n const hasFutureNonNonexemptComp =\n primaryJob?.compensations?.some(\n c =>\n c.effectiveDate !== undefined &&\n c.effectiveDate > localTodayISO &&\n c.flsaStatus !== FlsaStatus.NONEXEMPT,\n ) ?? false\n const canAddAnotherJob =\n jobs.length >= 1 && primaryFlsaStatus === FlsaStatus.NONEXEMPT && !hasFutureNonNonexemptComp\n const singleJobNumericRate = singleJob ? parseJobRate(singleJob.rate) : null\n const singleJobCurrentComp = singleJob?.compensations?.find(\n c => c.uuid === singleJob.currentCompensationUuid,\n )\n const singleJobEffectiveDateRow = singleJobCurrentComp?.effectiveDate ? (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {t('jobAndPay.compensation.effectiveDate')}\n </Components.Text>\n <Components.Text>\n {formatDateLongWithYear(singleJobCurrentComp.effectiveDate)}\n </Components.Text>\n </Flex>\n ) : null\n\n const [isReviewOpen, setIsReviewOpen] = useState(false)\n const renderDetail = usePendingChangeDetailRenderer(employeeFirstName)\n\n const hasPendingChanges = pendingChanges.length > 0\n const showSummaryAlert = hasMultipleJobs && pendingChanges.length > 1\n const showInlineAlert = hasPendingChanges && !showSummaryAlert\n const nextChange = pendingChanges[0]\n\n const paymentMethodList = usePaymentMethodList({ employeeId })\n const paymentMethod = paymentMethodList.isLoading\n ? undefined\n : paymentMethodList.data.paymentMethod\n const bankAccounts = paymentMethodList.isLoading ? [] : paymentMethodList.data.bankAccounts\n const deletePendingBankAccountUuid = paymentMethodList.isLoading\n ? undefined\n : paymentMethodList.status.deletePendingBankAccountUuid\n\n const { pendingDeleteAccount, setPendingDeleteAccount, handleConfirmDelete } =\n useDeleteBankAccount(async uuid => {\n if (paymentMethodList.isLoading) return\n const result = await paymentMethodList.actions.onDelete(uuid)\n if (result) {\n onEvent(componentEvents.EMPLOYEE_BANK_ACCOUNT_DELETED, result.data)\n }\n })\n\n const deductionsList = useDeductionsList({ employeeId })\n const deductions = deductionsList.isLoading ? [] : deductionsList.data.deductions\n const deletingGarnishmentUuid = deductionsList.isLoading\n ? undefined\n : deductionsList.status.deletingGarnishmentUuid\n\n const {\n pendingDeleteDeduction,\n setPendingDeleteDeduction,\n handleConfirmDelete: handleConfirmDeleteDeduction,\n } = useDeleteDeduction(async garnishment => {\n if (deductionsList.isLoading) return\n const result = await deductionsList.actions.onDelete(garnishment)\n if (result) {\n onEvent(componentEvents.EMPLOYEE_DEDUCTION_DELETED, result.data.garnishment)\n }\n })\n\n // All three hooks own their own error state; merge into one error\n // surface so the BaseLayout below shows whatever failed (read errors\n // from the queries, submit errors from delete/cancel actions).\n const errorHandling = composeErrorHandler([compensation, paymentMethodList, deductionsList])\n\n const jobsColumns = [\n {\n key: 'jobTitle',\n title: t('jobAndPay.compensation.columns.jobTitle'),\n render: (job: Job) => {\n const numericRate = parseJobRate(job.rate)\n return (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text>{job.title || '-'}</Components.Text>\n {numericRate !== null && job.paymentUnit ? (\n <Components.Text variant=\"supporting\">\n {formatCompensationRate(numericRate, job.paymentUnit)}\n </Components.Text>\n ) : null}\n </Flex>\n )\n },\n },\n {\n key: 'payType',\n title: t('jobAndPay.compensation.columns.payType'),\n render: (job: Job) => {\n const flsaStatus = job.compensations?.find(\n comp => comp.uuid === job.currentCompensationUuid,\n )?.flsaStatus\n return flsaStatus !== undefined ? tCompensation(`flsaStatusLabels.${flsaStatus}`) : '-'\n },\n },\n {\n key: 'effectiveDate',\n title: t('jobAndPay.compensation.columns.effectiveDate'),\n render: (job: Job) => {\n const currentComp = job.compensations?.find(c => c.uuid === job.currentCompensationUuid)\n return currentComp?.effectiveDate ? formatDateLongWithYear(currentComp.effectiveDate) : '-'\n },\n },\n ]\n\n const jobsDataView = useDataView({\n data: jobs,\n columns: jobsColumns,\n itemMenu: (job: Job) => (\n <HamburgerMenu\n triggerLabel={t('jobAndPay.compensation.hamburgerTitle')}\n isLoading={isDeletingJob}\n items={[\n {\n label: t('jobAndPay.compensation.editJobCta'),\n icon: <PencilSvg aria-hidden />,\n onClick: () => {\n onEditCompensation?.(job)\n },\n },\n ...(!job.primary\n ? [\n {\n label: t('jobAndPay.compensation.deleteJobCta'),\n icon: <TrashCanSvg aria-hidden />,\n onClick: () => {\n setPendingDeleteJob({ uuid: job.uuid, title: job.title ?? '' })\n },\n },\n ]\n : []),\n ]}\n />\n ),\n })\n\n const bankAccountsColumns = [\n {\n key: 'nickname',\n title: t('jobAndPay.payment.nickname'),\n render: (bankAccount: EmployeeBankAccount) => bankAccount.name || '-',\n },\n {\n key: 'routingNumber',\n title: t('jobAndPay.payment.routingNumber'),\n render: (bankAccount: EmployeeBankAccount) => bankAccount.routingNumber || '-',\n },\n {\n key: 'accountType',\n title: t('jobAndPay.payment.accountType'),\n render: (bankAccount: EmployeeBankAccount) => bankAccount.accountType || '-',\n },\n ]\n\n const garnishmentsColumns = [\n {\n key: 'description',\n title: t('jobAndPay.deductions.deduction'),\n render: (garnishment: Garnishment) => garnishment.description || '-',\n },\n {\n key: 'frequency',\n title: t('jobAndPay.deductions.frequency'),\n render: (garnishment: Garnishment) =>\n garnishment.recurring\n ? t('jobAndPay.deductions.recurring')\n : t('jobAndPay.deductions.oneTime'),\n },\n {\n key: 'amount',\n title: t('jobAndPay.deductions.withhold'),\n render: (garnishment: Garnishment) =>\n formatDeductionAmount(garnishment, {\n formatCurrency,\n formatPercent,\n formatPerPaycheck: (value: string) =>\n t('jobAndPay.deductions.amountPerPaycheck', { value }),\n }),\n },\n ]\n\n const payStubsColumns = [\n {\n key: 'payday',\n title: t('jobAndPay.paystubs.payday'),\n render: (payStub: EmployeePayStub) => formatDateLongWithYear(payStub.checkDate) || '-',\n },\n {\n key: 'checkAmount',\n title: t('jobAndPay.paystubs.checkAmount'),\n render: (payStub: EmployeePayStub) => {\n if (!payStub.netPay) return '-'\n const amount = parseFloat(payStub.netPay)\n return isNaN(amount) ? '-' : formatCurrency(amount)\n },\n },\n {\n key: 'grossPay',\n title: t('jobAndPay.paystubs.grossPay'),\n render: (payStub: EmployeePayStub) => {\n if (!payStub.grossPay) return '-'\n const amount = parseFloat(payStub.grossPay)\n return isNaN(amount) ? '-' : formatCurrency(amount)\n },\n },\n {\n key: 'paymentMethod',\n title: t('jobAndPay.paystubs.paymentMethod'),\n render: () => paymentMethod?.type || t('jobAndPay.paystubs.noPaymentMethod'),\n },\n ]\n\n const bankAccountsDataView = useDataView({\n data: bankAccounts,\n columns: bankAccountsColumns,\n itemMenu: (bankAccount: EmployeeBankAccount) => (\n <HamburgerMenu\n items={[\n {\n label: tPayment('deleteBankAccountCta'),\n onClick: () => {\n setPendingDeleteAccount({\n uuid: bankAccount.uuid,\n hiddenAccountNumber: bankAccount.hiddenAccountNumber,\n })\n },\n icon: <TrashCanSvg aria-hidden />,\n },\n ]}\n triggerLabel={tPayment('hamburgerTitle')}\n />\n ),\n })\n\n const garnishmentsDataView = useDataView({\n data: deductions,\n columns: garnishmentsColumns,\n itemMenu: (garnishment: Garnishment) => (\n <HamburgerMenu\n isLoading={deletingGarnishmentUuid === garnishment.uuid}\n items={[\n {\n label: tDeductions('editCta'),\n onClick: () => onEditDeduction?.(garnishment),\n icon: <PencilSvg aria-hidden />,\n },\n {\n label: tDeductions('deleteCta'),\n onClick: () => {\n setPendingDeleteDeduction(garnishment)\n },\n icon: <TrashCanSvg aria-hidden />,\n },\n ]}\n triggerLabel={tDeductions('hamburgerTitle')}\n />\n ),\n emptyState: () => (\n <EmptyData\n title={t('jobAndPay.deductions.emptyState.title')}\n description={t('jobAndPay.deductions.emptyState.description')}\n />\n ),\n })\n\n const payStubsDataView = useDataView({\n data: payStubs,\n columns: payStubsColumns,\n pagination: payStubsPagination,\n itemMenu: payStub => {\n const isDownloading =\n !!payStub.payrollUuid && downloadingPayrollUuids.has(payStub.payrollUuid)\n return (\n <Components.ButtonIcon\n variant=\"tertiary\"\n aria-label={t('jobAndPay.paystubs.downloadCta')}\n isDisabled={!payStub.payrollUuid}\n isLoading={isDownloading}\n onClick={() => {\n if (payStub.payrollUuid) {\n void handlePaystubDownload(payStub.payrollUuid)\n }\n }}\n >\n <DownloadCloudIcon aria-hidden />\n </Components.ButtonIcon>\n )\n },\n emptyState: () => (\n <EmptyData\n title={t('jobAndPay.paystubs.emptyState.title')}\n description={t('jobAndPay.paystubs.emptyState.description')}\n />\n ),\n })\n\n // `usePaymentMethodList` and `useDeductionsList` still use the older\n // `HookLoadingResult | Ready` shape, which returns `isLoading: true`\n // when the query has errored AND data is missing. Treat those rows\n // as \"not loading\" so the section doesn't show a perpetual skeleton\n // while BaseLayout already renders the error alert above.\n const isPaymentMethodLoading =\n paymentMethodList.isLoading && paymentMethodList.errorHandling.errors.length === 0\n const isDeductionsLoading =\n deductionsList.isLoading && deductionsList.errorHandling.errors.length === 0\n const isDirectDeposit = paymentMethod?.type === PAYMENT_METHODS.directDeposit\n\n return (\n <BaseLayout error={errorHandling.errors}>\n <Flex flexDirection=\"column\" gap={24}>\n <Components.Box\n withPadding={!hasMultipleJobs}\n header={\n <Components.BoxHeader\n title={t('jobAndPay.compensation.title')}\n action={\n // While the compensation card is loading we don't yet\n // know if the employee has jobs — suppress the action\n // so we don't surface an \"Add job\" CTA against an\n // employee who already has one.\n isCompensationCardLoading ? null : hasMultipleJobs ? null : singleJob ? (\n <Components.Button\n variant=\"secondary\"\n onClick={() => {\n onEditCompensation?.(singleJob)\n }}\n >\n {t('jobAndPay.compensation.editCta')}\n </Components.Button>\n ) : (\n <Components.Button\n variant=\"secondary\"\n onClick={onAddJob}\n icon={<PlusCircleIcon />}\n >\n {t('jobAndPay.compensation.addJobCta')}\n </Components.Button>\n )\n }\n />\n }\n footer={\n !isCompensationCardLoading && canAddAnotherJob ? (\n <Components.Button\n variant=\"secondary\"\n onClick={onAddAnotherJob}\n icon={<PlusCircleIcon />}\n >\n {t('jobAndPay.compensation.addAnotherJobCta')}\n </Components.Button>\n ) : undefined\n }\n >\n {isCompensationCardLoading ? (\n <Loading />\n ) : (\n <Flex flexDirection=\"column\" gap={16}>\n {hasPendingChanges && (\n <div className={hasMultipleJobs ? styles.alertWrapper : undefined}>\n <Flex flexDirection=\"column\" gap={16}>\n {showInlineAlert && nextChange && (\n <Components.Alert\n status=\"warning\"\n disableScrollIntoView\n label={\n hasMultipleJobs\n ? t('jobAndPay.compensation.pendingChange.alertLabelWithJob', {\n jobTitle: nextChange.jobTitle,\n date: formatDateLongWithYear(nextChange.effectiveDate),\n })\n : t('jobAndPay.compensation.pendingChange.alertLabel', {\n date: formatDateLongWithYear(nextChange.effectiveDate),\n })\n }\n >\n <Flex flexDirection=\"column\" gap={12}>\n <Components.UnorderedList\n items={nextChange.details.map(detail => renderDetail(detail))}\n />\n <div>\n <Components.Button\n variant=\"secondary\"\n isLoading={cancellingCompensationUuid === nextChange.compensationUuid}\n onClick={() => {\n void handleCancelChange(nextChange)\n }}\n >\n {t('jobAndPay.compensation.pendingChange.cancelCta')}\n </Components.Button>\n </div>\n </Flex>\n </Components.Alert>\n )}\n {showSummaryAlert && (\n <Components.Alert\n status=\"warning\"\n disableScrollIntoView\n label={t('jobAndPay.compensation.pendingChange.summaryLabel', {\n name: employeeFirstName ?? '',\n })}\n action={\n <Components.Button\n variant=\"secondary\"\n onClick={() => {\n setIsReviewOpen(true)\n }}\n >\n {t('jobAndPay.compensation.pendingChange.reviewCta')}\n </Components.Button>\n }\n />\n )}\n </Flex>\n </div>\n )}\n {hasMultipleJobs ? (\n <DataView\n label={t('jobAndPay.compensation.tableLabel')}\n isWithinBox\n {...jobsDataView}\n />\n ) : singleJob ? (\n <Flex flexDirection=\"column\" gap={12}>\n {singleJob.title && (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {t('jobAndPay.compensation.jobTitle')}\n </Components.Text>\n <Components.Text>{singleJob.title}</Components.Text>\n </Flex>\n )}\n\n {singleJob.paymentUnit && (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {t('jobAndPay.compensation.type')}\n </Components.Text>\n <Components.Text>\n {singleJob.paymentUnit === 'Hour'\n ? t('jobAndPay.compensation.types.hourly')\n : singleJob.paymentUnit === 'Salary' || singleJob.paymentUnit === 'Year'\n ? t('jobAndPay.compensation.types.salary')\n : singleJob.paymentUnit}\n </Components.Text>\n </Flex>\n )}\n\n {singleJobNumericRate !== null && singleJob.paymentUnit && (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {t('jobAndPay.compensation.wage')}\n </Components.Text>\n <Components.Text>\n {formatCompensationRate(singleJobNumericRate, singleJob.paymentUnit)}\n </Components.Text>\n </Flex>\n )}\n\n {singleJobEffectiveDateRow}\n </Flex>\n ) : (\n <EmptyData\n title={t('jobAndPay.compensation.emptyState.title')}\n description={t('jobAndPay.compensation.emptyState.description')}\n />\n )}\n </Flex>\n )}\n </Components.Box>\n\n <Components.Box\n withPadding={bankAccounts.length === 0}\n header={\n <Components.BoxHeader\n title={t('jobAndPay.payment.title')}\n action={\n <Flex gap={8} alignItems=\"center\" justifyContent=\"flex-end\">\n {isDirectDeposit && bankAccounts.length > 1 && (\n <Components.Button\n variant=\"secondary\"\n onClick={() => {\n onEvent(componentEvents.EMPLOYEE_SPLIT_PAYCHECK, { employeeId })\n }}\n icon={<PercentCircleIcon />}\n >\n {t('jobAndPay.payment.splitPaycheckCta')}\n </Components.Button>\n )}\n <Components.Button\n variant=\"secondary\"\n onClick={() => {\n onEvent(componentEvents.EMPLOYEE_BANK_ACCOUNT_CREATE, { employeeId })\n }}\n icon={<PlusCircleIcon />}\n >\n {t('jobAndPay.payment.addBankAccountCta')}\n </Components.Button>\n </Flex>\n }\n />\n }\n >\n {isPaymentMethodLoading ? (\n <Loading />\n ) : bankAccounts.length === 0 ? (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {tPayment('paymentMethodLabel')}\n </Components.Text>\n <Components.Text>\n {isDirectDeposit ? tPayment('directDepositLabel') : tPayment('checkLabel')}\n </Components.Text>\n </Flex>\n ) : (\n <DataView\n label={t('jobAndPay.payment.listLabel')}\n isWithinBox\n {...bankAccountsDataView}\n />\n )}\n </Components.Box>\n\n <Components.Box\n withPadding={false}\n header={\n <Components.BoxHeader\n title={t('jobAndPay.deductions.title')}\n action={\n <Components.Button\n variant=\"secondary\"\n onClick={onAddDeduction}\n icon={<PlusCircleIcon />}\n >\n {t('jobAndPay.deductions.addDeductionCta')}\n </Components.Button>\n }\n />\n }\n >\n {isDeductionsLoading ? (\n <Loading />\n ) : (\n <DataView\n label={t('jobAndPay.deductions.listLabel')}\n isWithinBox\n {...garnishmentsDataView}\n />\n )}\n </Components.Box>\n\n <Components.Box\n withPadding={false}\n header={<Components.BoxHeader title={t('jobAndPay.paystubs.title')} />}\n >\n {isPayStubsLoading ? (\n <Loading />\n ) : (\n <DataView label={t('jobAndPay.paystubs.listLabel')} isWithinBox {...payStubsDataView} />\n )}\n </Components.Box>\n\n <PendingChangesReviewModal\n isOpen={isReviewOpen}\n pendingChanges={pendingChanges}\n employeeFirstName={employeeFirstName}\n cancellingCompensationUuid={cancellingCompensationUuid}\n onClose={() => {\n setIsReviewOpen(false)\n }}\n onCancelChange={change => {\n void handleCancelChange(change)\n }}\n />\n\n <DeleteBankAccountDialog\n pendingDeleteAccount={pendingDeleteAccount}\n isPrimaryActionLoading={deletePendingBankAccountUuid === pendingDeleteAccount?.uuid}\n onClose={() => {\n setPendingDeleteAccount(null)\n }}\n onConfirm={() => {\n void handleConfirmDelete()\n }}\n />\n\n <DeleteDeductionDialog\n pendingDeleteDeduction={pendingDeleteDeduction}\n isPrimaryActionLoading={deletingGarnishmentUuid === pendingDeleteDeduction?.uuid}\n onClose={() => {\n setPendingDeleteDeduction(null)\n }}\n onConfirm={() => {\n void handleConfirmDeleteDeduction()\n }}\n />\n\n <Components.Dialog\n isOpen={pendingDeleteJob !== null}\n onClose={() => {\n setPendingDeleteJob(null)\n }}\n onPrimaryActionClick={() => {\n void handleConfirmDeleteJob()\n }}\n isPrimaryActionLoading={isDeletingJob}\n isDestructive\n title={t('jobAndPay.compensation.deleteJobDialog.title')}\n primaryActionLabel={t('jobAndPay.compensation.deleteJobDialog.confirmCta')}\n closeActionLabel={t('jobAndPay.compensation.deleteJobDialog.cancelCta')}\n >\n {pendingDeleteJob\n ? t('jobAndPay.compensation.deleteJobDialog.description', {\n jobTitle: pendingDeleteJob.title,\n })\n : null}\n </Components.Dialog>\n </Flex>\n </BaseLayout>\n )\n}\n"],"names":["parseJobRate","rate","numericRate","JobAndPayView","employeeId","onEvent","onEditCompensation","onAddJob","onAddAnotherJob","onAddDeduction","onEditDeduction","useI18n","t","useTranslation","tPayment","tCompensation","tDeductions","Components","useComponentContext","formatCompensationRate","useFormatCompensationRate","formatCurrency","useNumberFormatter","formatPercent","gustoEmbedded","useGustoEmbeddedContext","showBoundary","useErrorBoundary","compensation","useEmployeeCompensation","jobs","primaryFlsaStatus","pendingChanges","hasMultipleJobsFromHook","payStubs","employeeFirstName","payStubsPagination","cancellingCompensationUuid","cancelPendingChange","isCompensationCardLoading","isPayStubsLoading","handleCancelChange","useCallback","pendingChange","componentEvents","downloadingPayrollUuids","setDownloadingPayrollUuids","useState","handlePaystubDownload","payrollUuid","newWindow","loadingMessage","doc","style","spinner","label","prev","next","response","payrollsGetPayStub","pdfBlob","readableStreamToBlob","url","err","pendingDeleteJob","setPendingDeleteJob","deleteEmployeeJob","isDeletingJob","useJobsAndCompensationsDeleteMutation","handleConfirmDeleteJob","jobId","singleJob","hasMultipleJobs","localTodayISO","formatDateToStringDate","hasFutureNonNonexemptComp","j","c","FlsaStatus","canAddAnotherJob","singleJobNumericRate","singleJobCurrentComp","singleJobEffectiveDateRow","jsxs","Flex","jsx","formatDateLongWithYear","isReviewOpen","setIsReviewOpen","renderDetail","usePendingChangeDetailRenderer","hasPendingChanges","showSummaryAlert","showInlineAlert","nextChange","paymentMethodList","usePaymentMethodList","paymentMethod","bankAccounts","deletePendingBankAccountUuid","pendingDeleteAccount","setPendingDeleteAccount","handleConfirmDelete","useDeleteBankAccount","uuid","result","deductionsList","useDeductionsList","deductions","deletingGarnishmentUuid","pendingDeleteDeduction","setPendingDeleteDeduction","handleConfirmDeleteDeduction","useDeleteDeduction","garnishment","errorHandling","composeErrorHandler","jobsColumns","job","flsaStatus","comp","currentComp","jobsDataView","useDataView","HamburgerMenu","PencilSvg","TrashCanSvg","bankAccountsColumns","bankAccount","garnishmentsColumns","formatDeductionAmount","value","payStubsColumns","payStub","amount","bankAccountsDataView","garnishmentsDataView","EmptyData","payStubsDataView","isDownloading","DownloadCloudIcon","isPaymentMethodLoading","isDeductionsLoading","isDirectDeposit","PAYMENT_METHODS","BaseLayout","PlusCircleIcon","Loading","styles","detail","DataView","PercentCircleIcon","PendingChangesReviewModal","change","DeleteBankAccountDialog","DeleteDeductionDialog"],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ const r = "_alertWrapper_1uhr1_1", e = {
2
+ alertWrapper: r
3
+ };
4
+ export {
5
+ r as alertWrapper,
6
+ e as default
7
+ };
8
+ //# sourceMappingURL=JobAndPayView.module.scss.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JobAndPayView.module.scss.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;"}
@@ -5,7 +5,11 @@ type EmployeeStateTax = NonNullable<GetV1EmployeesEmployeeIdStateTaxesResponse['
5
5
  export interface TaxesViewProps {
6
6
  federalTaxes?: EmployeeFederalTax;
7
7
  stateTaxes?: EmployeeStateTax[];
8
+ /** Loads both cards. Override per-card via `isFederalTaxesLoading` /
9
+ * `isStateTaxesLoading` when the queries resolve independently. */
8
10
  isLoading?: boolean;
11
+ isFederalTaxesLoading?: boolean;
12
+ isStateTaxesLoading?: boolean;
9
13
  onEditFederalTaxes?: () => void;
10
14
  onEditStateTaxes?: () => void;
11
15
  }
@@ -19,8 +23,9 @@ export interface TaxesViewWithDataProps {
19
23
  /**
20
24
  * Tab-mounted container for the Taxes tab. Owns the `useEmployeeTaxes`
21
25
  * fetch so federal/state tax requests only fire when the tab is mounted.
22
- * The presentational `TaxesView` stays pure for testing/stories.
26
+ * Federal and state queries run independently — each card paints its
27
+ * own skeleton + content as data arrives.
23
28
  */
24
29
  export declare function TaxesViewWithData({ employeeId, onEditFederalTaxes, onEditStateTaxes, }: TaxesViewWithDataProps): import("react/jsx-runtime").JSX.Element;
25
- export declare function TaxesView({ federalTaxes, stateTaxes, isLoading, onEditFederalTaxes, onEditStateTaxes, }: TaxesViewProps): import("react/jsx-runtime").JSX.Element;
30
+ export declare function TaxesView({ federalTaxes, stateTaxes, isLoading, isFederalTaxesLoading, isStateTaxesLoading, onEditFederalTaxes, onEditStateTaxes, }: TaxesViewProps): import("react/jsx-runtime").JSX.Element;
26
31
  export {};
@@ -1,43 +1,41 @@
1
1
  import { jsx as t, jsxs as c } from "react/jsx-runtime";
2
- import { useTranslation as y } from "react-i18next";
3
- import { Flex as i } from "../../Common/Flex/Flex.js";
4
- import { useComponentContext as D } from "../../../contexts/ComponentAdapter/useComponentContext.js";
2
+ import { useTranslation as F } from "react-i18next";
3
+ import { Flex as o } from "../../Common/Flex/Flex.js";
4
+ import { useComponentContext as b } from "../../../contexts/ComponentAdapter/useComponentContext.js";
5
5
  import "classnames";
6
6
  import "../../../shared/constants.js";
7
- import { Loading as F } from "../../Common/Loading/Loading.js";
8
- import { BaseLayout as g } from "../../Base/Base.js";
9
- import v from "../../../hooks/useNumberFormatter.js";
10
- import { useEmployeeTaxes as b } from "./hooks/useEmployeeTaxes.js";
11
- function E({
7
+ import { Loading as g } from "../../Common/Loading/Loading.js";
8
+ import { BaseLayout as v } from "../../Base/Base.js";
9
+ import C from "../../../hooks/useNumberFormatter.js";
10
+ import { useEmployeeTaxes as S } from "./hooks/useEmployeeTaxes.js";
11
+ function N({
12
12
  employeeId: n,
13
13
  onEditFederalTaxes: d,
14
- onEditStateTaxes: s
14
+ onEditStateTaxes: m
15
15
  }) {
16
- const u = b({ employeeId: n });
17
- if (u.isLoading)
18
- return /* @__PURE__ */ t(g, { isLoading: !0, error: u.errorHandling.errors });
19
- const m = u.data.employeeFederalTax;
20
- return /* @__PURE__ */ t(g, { error: u.errorHandling.errors, children: /* @__PURE__ */ t(
21
- C,
16
+ const u = S({ employeeId: n }), s = u.data.employeeFederalTax;
17
+ return /* @__PURE__ */ t(v, { error: u.errorHandling.errors, children: /* @__PURE__ */ t(
18
+ B,
22
19
  {
23
- federalTaxes: m,
20
+ federalTaxes: s,
24
21
  stateTaxes: u.data.employeeStateTaxesList,
25
- onEditFederalTaxes: () => d?.(m),
26
- onEditStateTaxes: s
22
+ isFederalTaxesLoading: u.status.isFederalTaxesLoading,
23
+ isStateTaxesLoading: u.status.isStateTaxesLoading,
24
+ onEditFederalTaxes: () => d?.(s),
25
+ onEditStateTaxes: m
27
26
  }
28
27
  ) });
29
28
  }
30
- function C({
29
+ function B({
31
30
  federalTaxes: n,
32
31
  stateTaxes: d,
33
- isLoading: s = !1,
34
- onEditFederalTaxes: u,
35
- onEditStateTaxes: m
32
+ isLoading: m = !1,
33
+ isFederalTaxesLoading: u = m,
34
+ isStateTaxesLoading: s = m,
35
+ onEditFederalTaxes: f,
36
+ onEditStateTaxes: y
36
37
  }) {
37
- const { t: o } = y("Employee.Dashboard"), e = D(), p = v("currency");
38
- if (s)
39
- return /* @__PURE__ */ t(F, {});
40
- const f = (l, r) => {
38
+ const { t: i } = F("Employee.Dashboard"), e = b(), p = C("currency"), D = (l, r) => {
41
39
  if (l.inputQuestionFormat.type === "Select" && l.inputQuestionFormat.options && l.inputQuestionFormat.options.length > 0) {
42
40
  const a = l.inputQuestionFormat.options.find((h) => h.value === r);
43
41
  if (a?.label)
@@ -49,45 +47,53 @@ function C({
49
47
  const a = parseFloat(r);
50
48
  return l.inputQuestionFormat.type === "Currency" ? p(a) : r;
51
49
  }
52
- return typeof r == "boolean" ? o(r ? "common.yes" : "common.no") : r;
50
+ return typeof r == "boolean" ? i(r ? "common.yes" : "common.no") : r;
53
51
  };
54
- return /* @__PURE__ */ c(i, { flexDirection: "column", gap: 24, children: [
52
+ return /* @__PURE__ */ c(o, { flexDirection: "column", gap: 24, children: [
55
53
  /* @__PURE__ */ t(
56
54
  e.Box,
57
55
  {
58
56
  header: /* @__PURE__ */ t(
59
57
  e.BoxHeader,
60
58
  {
61
- title: o("taxes.federal.title"),
62
- action: /* @__PURE__ */ t(e.Button, { variant: "secondary", onClick: u, children: o("taxes.federal.editCta") })
59
+ title: i("taxes.federal.title"),
60
+ action: /* @__PURE__ */ t(
61
+ e.Button,
62
+ {
63
+ variant: "secondary",
64
+ onClick: f,
65
+ isDisabled: u,
66
+ children: i("taxes.federal.editCta")
67
+ }
68
+ )
63
69
  }
64
70
  ),
65
- children: /* @__PURE__ */ t(i, { flexDirection: "column", gap: 16, children: n && /* @__PURE__ */ c(i, { flexDirection: "column", gap: 12, children: [
66
- n.filingStatus && /* @__PURE__ */ c(i, { flexDirection: "column", gap: 0, children: [
67
- /* @__PURE__ */ t(e.Text, { variant: "supporting", children: o("taxes.federal.filingStatus") }),
71
+ children: /* @__PURE__ */ t(o, { flexDirection: "column", gap: 16, children: u ? /* @__PURE__ */ t(g, {}) : n ? /* @__PURE__ */ c(o, { flexDirection: "column", gap: 12, children: [
72
+ n.filingStatus && /* @__PURE__ */ c(o, { flexDirection: "column", gap: 0, children: [
73
+ /* @__PURE__ */ t(e.Text, { variant: "supporting", children: i("taxes.federal.filingStatus") }),
68
74
  /* @__PURE__ */ t(e.Text, { children: n.filingStatus })
69
75
  ] }),
70
- "twoJobs" in n && n.twoJobs !== null && /* @__PURE__ */ c(i, { flexDirection: "column", gap: 0, children: [
71
- /* @__PURE__ */ t(e.Text, { variant: "supporting", children: o("taxes.federal.multipleJobs") }),
72
- /* @__PURE__ */ t(e.Text, { children: n.twoJobs ? o("common.yes") : o("common.no") })
76
+ "twoJobs" in n && n.twoJobs !== null && /* @__PURE__ */ c(o, { flexDirection: "column", gap: 0, children: [
77
+ /* @__PURE__ */ t(e.Text, { variant: "supporting", children: i("taxes.federal.multipleJobs") }),
78
+ /* @__PURE__ */ t(e.Text, { children: n.twoJobs ? i("common.yes") : i("common.no") })
73
79
  ] }),
74
- "dependentsAmount" in n && n.dependentsAmount && /* @__PURE__ */ c(i, { flexDirection: "column", gap: 0, children: [
75
- /* @__PURE__ */ t(e.Text, { variant: "supporting", children: o("taxes.federal.dependentsAndOtherCredits") }),
80
+ "dependentsAmount" in n && n.dependentsAmount && /* @__PURE__ */ c(o, { flexDirection: "column", gap: 0, children: [
81
+ /* @__PURE__ */ t(e.Text, { variant: "supporting", children: i("taxes.federal.dependentsAndOtherCredits") }),
76
82
  /* @__PURE__ */ t(e.Text, { children: p(parseFloat(n.dependentsAmount)) })
77
83
  ] }),
78
- "otherIncome" in n && n.otherIncome && /* @__PURE__ */ c(i, { flexDirection: "column", gap: 0, children: [
79
- /* @__PURE__ */ t(e.Text, { variant: "supporting", children: o("taxes.federal.otherIncome") }),
84
+ "otherIncome" in n && n.otherIncome && /* @__PURE__ */ c(o, { flexDirection: "column", gap: 0, children: [
85
+ /* @__PURE__ */ t(e.Text, { variant: "supporting", children: i("taxes.federal.otherIncome") }),
80
86
  /* @__PURE__ */ t(e.Text, { children: p(parseFloat(n.otherIncome)) })
81
87
  ] }),
82
- "deductions" in n && n.deductions && /* @__PURE__ */ c(i, { flexDirection: "column", gap: 0, children: [
83
- /* @__PURE__ */ t(e.Text, { variant: "supporting", children: o("taxes.federal.deductions") }),
88
+ "deductions" in n && n.deductions && /* @__PURE__ */ c(o, { flexDirection: "column", gap: 0, children: [
89
+ /* @__PURE__ */ t(e.Text, { variant: "supporting", children: i("taxes.federal.deductions") }),
84
90
  /* @__PURE__ */ t(e.Text, { children: p(parseFloat(n.deductions)) })
85
91
  ] }),
86
- "extraWithholding" in n && n.extraWithholding && /* @__PURE__ */ c(i, { flexDirection: "column", gap: 0, children: [
87
- /* @__PURE__ */ t(e.Text, { variant: "supporting", children: o("taxes.federal.extraWithholding") }),
92
+ "extraWithholding" in n && n.extraWithholding && /* @__PURE__ */ c(o, { flexDirection: "column", gap: 0, children: [
93
+ /* @__PURE__ */ t(e.Text, { variant: "supporting", children: i("taxes.federal.extraWithholding") }),
88
94
  /* @__PURE__ */ t(e.Text, { children: p(parseFloat(n.extraWithholding)) })
89
95
  ] })
90
- ] }) })
96
+ ] }) : null })
91
97
  }
92
98
  ),
93
99
  /* @__PURE__ */ t(
@@ -96,26 +102,34 @@ function C({
96
102
  header: /* @__PURE__ */ t(
97
103
  e.BoxHeader,
98
104
  {
99
- title: o("taxes.state.title"),
100
- action: /* @__PURE__ */ t(e.Button, { variant: "secondary", onClick: m, children: o("taxes.state.editCta") })
105
+ title: i("taxes.state.title"),
106
+ action: /* @__PURE__ */ t(
107
+ e.Button,
108
+ {
109
+ variant: "secondary",
110
+ onClick: y,
111
+ isDisabled: s,
112
+ children: i("taxes.state.editCta")
113
+ }
114
+ )
101
115
  }
102
116
  ),
103
- children: /* @__PURE__ */ t(i, { flexDirection: "column", gap: 16, children: d && d.length > 0 ? /* @__PURE__ */ t(i, { flexDirection: "column", gap: 24, children: d.map((l, r) => /* @__PURE__ */ c(i, { flexDirection: "column", gap: 16, children: [
117
+ children: /* @__PURE__ */ t(o, { flexDirection: "column", gap: 16, children: s ? /* @__PURE__ */ t(g, {}) : d && d.length > 0 ? /* @__PURE__ */ t(o, { flexDirection: "column", gap: 24, children: d.map((l, r) => /* @__PURE__ */ c(o, { flexDirection: "column", gap: 16, children: [
104
118
  /* @__PURE__ */ t(e.Heading, { as: "h4", children: l.state }),
105
- l.questions && l.questions.length > 0 && /* @__PURE__ */ t(i, { flexDirection: "column", gap: 12, children: l.questions.map((a, h) => {
119
+ l.questions && l.questions.length > 0 && /* @__PURE__ */ t(o, { flexDirection: "column", gap: 12, children: l.questions.map((a, h) => {
106
120
  const x = a.answers[0]?.value;
107
- return x == null ? null : /* @__PURE__ */ c(i, { flexDirection: "column", gap: 0, children: [
121
+ return x == null ? null : /* @__PURE__ */ c(o, { flexDirection: "column", gap: 0, children: [
108
122
  /* @__PURE__ */ t(e.Text, { variant: "supporting", children: a.label }),
109
- /* @__PURE__ */ t(e.Text, { children: f(a, x) })
123
+ /* @__PURE__ */ t(e.Text, { children: D(a, x) })
110
124
  ] }, a.key || h);
111
125
  }) })
112
- ] }, l.state || r)) }) : /* @__PURE__ */ t(e.Text, { children: o("taxes.state.noStateTaxes") }) })
126
+ ] }, l.state || r)) }) : /* @__PURE__ */ t(e.Text, { children: i("taxes.state.noStateTaxes") }) })
113
127
  }
114
128
  )
115
129
  ] });
116
130
  }
117
131
  export {
118
- C as TaxesView,
119
- E as TaxesViewWithData
132
+ B as TaxesView,
133
+ N as TaxesViewWithData
120
134
  };
121
135
  //# sourceMappingURL=TaxesView.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TaxesView.js","sources":["../../../../src/components/Employee/Dashboard/TaxesView.tsx"],"sourcesContent":["import { useTranslation } from 'react-i18next'\nimport type { GetV1EmployeesEmployeeIdFederalTaxesResponse } from '@gusto/embedded-api/models/operations/getv1employeesemployeeidfederaltaxes'\nimport type { GetV1EmployeesEmployeeIdStateTaxesResponse } from '@gusto/embedded-api/models/operations/getv1employeesemployeeidstatetaxes'\nimport type { EmployeeStateTaxQuestion } from '@gusto/embedded-api/models/components/employeestatetaxquestion'\nimport { useEmployeeTaxes } from './hooks'\nimport { Flex } from '@/components/Common/Flex/Flex'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { Loading } from '@/components/Common'\nimport { BaseLayout } from '@/components/Base/Base'\nimport useNumberFormatter from '@/hooks/useNumberFormatter'\n\ntype EmployeeFederalTax = NonNullable<\n GetV1EmployeesEmployeeIdFederalTaxesResponse['employeeFederalTax']\n>\ntype EmployeeStateTax = NonNullable<\n GetV1EmployeesEmployeeIdStateTaxesResponse['employeeStateTaxesList']\n>[number]\n\nexport interface TaxesViewProps {\n federalTaxes?: EmployeeFederalTax\n stateTaxes?: EmployeeStateTax[]\n isLoading?: boolean\n onEditFederalTaxes?: () => void\n onEditStateTaxes?: () => void\n}\n\nexport interface TaxesViewWithDataProps {\n employeeId: string\n /** Receives the federal-tax record so the parent can preserve the\n * existing event payload (`{ employeeId, federalTaxes }`). */\n onEditFederalTaxes?: (federalTaxes: EmployeeFederalTax | undefined) => void\n onEditStateTaxes?: () => void\n}\n\n/**\n * Tab-mounted container for the Taxes tab. Owns the `useEmployeeTaxes`\n * fetch so federal/state tax requests only fire when the tab is mounted.\n * The presentational `TaxesView` stays pure for testing/stories.\n */\nexport function TaxesViewWithData({\n employeeId,\n onEditFederalTaxes,\n onEditStateTaxes,\n}: TaxesViewWithDataProps) {\n const taxes = useEmployeeTaxes({ employeeId })\n\n if (taxes.isLoading) {\n return <BaseLayout isLoading error={taxes.errorHandling.errors} />\n }\n\n const federalTaxes = taxes.data.employeeFederalTax\n return (\n <BaseLayout error={taxes.errorHandling.errors}>\n <TaxesView\n federalTaxes={federalTaxes}\n stateTaxes={taxes.data.employeeStateTaxesList}\n onEditFederalTaxes={() => onEditFederalTaxes?.(federalTaxes)}\n onEditStateTaxes={onEditStateTaxes}\n />\n </BaseLayout>\n )\n}\n\nexport function TaxesView({\n federalTaxes,\n stateTaxes,\n isLoading = false,\n onEditFederalTaxes,\n onEditStateTaxes,\n}: TaxesViewProps) {\n const { t } = useTranslation('Employee.Dashboard')\n const Components = useComponentContext()\n const formatCurrency = useNumberFormatter('currency')\n\n if (isLoading) {\n return <Loading />\n }\n\n // Helper function to format state tax answer values\n const formatStateTaxAnswer = (\n question: EmployeeStateTaxQuestion,\n answer: string | number | boolean,\n ) => {\n // For Select type questions, look up the label from options\n if (\n question.inputQuestionFormat.type === 'Select' &&\n question.inputQuestionFormat.options &&\n question.inputQuestionFormat.options.length > 0\n ) {\n const option = question.inputQuestionFormat.options.find(opt => opt.value === answer)\n if (option?.label) {\n return option.label\n }\n }\n\n // For numeric values, only format as currency for Currency questions\n if (typeof answer === 'number') {\n if (question.inputQuestionFormat.type === 'Currency') {\n return formatCurrency(answer)\n }\n return answer\n }\n\n // For string currency values (like \"0.0\")\n if (typeof answer === 'string' && !isNaN(parseFloat(answer))) {\n const numValue = parseFloat(answer)\n // Check if this looks like a currency (has decimal point or question type is Currency)\n if (question.inputQuestionFormat.type === 'Currency') {\n return formatCurrency(numValue)\n }\n // For non-currency numeric strings, return as-is\n return answer\n }\n\n // For boolean values\n if (typeof answer === 'boolean') {\n return answer ? t('common.yes') : t('common.no')\n }\n\n // Default: return string value as-is\n return answer\n }\n\n return (\n <Flex flexDirection=\"column\" gap={24}>\n <Components.Box\n header={\n <Components.BoxHeader\n title={t('taxes.federal.title')}\n action={\n <Components.Button variant=\"secondary\" onClick={onEditFederalTaxes}>\n {t('taxes.federal.editCta')}\n </Components.Button>\n }\n />\n }\n >\n <Flex flexDirection=\"column\" gap={16}>\n {federalTaxes && (\n <Flex flexDirection=\"column\" gap={12}>\n {federalTaxes.filingStatus && (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {t('taxes.federal.filingStatus')}\n </Components.Text>\n <Components.Text>{federalTaxes.filingStatus}</Components.Text>\n </Flex>\n )}\n\n {'twoJobs' in federalTaxes && federalTaxes.twoJobs !== null && (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {t('taxes.federal.multipleJobs')}\n </Components.Text>\n <Components.Text>\n {federalTaxes.twoJobs ? t('common.yes') : t('common.no')}\n </Components.Text>\n </Flex>\n )}\n\n {'dependentsAmount' in federalTaxes && federalTaxes.dependentsAmount && (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {t('taxes.federal.dependentsAndOtherCredits')}\n </Components.Text>\n <Components.Text>\n {formatCurrency(parseFloat(federalTaxes.dependentsAmount))}\n </Components.Text>\n </Flex>\n )}\n\n {'otherIncome' in federalTaxes && federalTaxes.otherIncome && (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {t('taxes.federal.otherIncome')}\n </Components.Text>\n <Components.Text>\n {formatCurrency(parseFloat(federalTaxes.otherIncome))}\n </Components.Text>\n </Flex>\n )}\n\n {'deductions' in federalTaxes && federalTaxes.deductions && (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {t('taxes.federal.deductions')}\n </Components.Text>\n <Components.Text>\n {formatCurrency(parseFloat(federalTaxes.deductions))}\n </Components.Text>\n </Flex>\n )}\n\n {'extraWithholding' in federalTaxes && federalTaxes.extraWithholding && (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {t('taxes.federal.extraWithholding')}\n </Components.Text>\n <Components.Text>\n {formatCurrency(parseFloat(federalTaxes.extraWithholding))}\n </Components.Text>\n </Flex>\n )}\n </Flex>\n )}\n </Flex>\n </Components.Box>\n\n <Components.Box\n header={\n <Components.BoxHeader\n title={t('taxes.state.title')}\n action={\n <Components.Button variant=\"secondary\" onClick={onEditStateTaxes}>\n {t('taxes.state.editCta')}\n </Components.Button>\n }\n />\n }\n >\n <Flex flexDirection=\"column\" gap={16}>\n {stateTaxes && stateTaxes.length > 0 ? (\n <Flex flexDirection=\"column\" gap={24}>\n {stateTaxes.map((stateTax, index) => (\n <Flex key={stateTax.state || index} flexDirection=\"column\" gap={16}>\n <Components.Heading as=\"h4\">{stateTax.state}</Components.Heading>\n\n {stateTax.questions && stateTax.questions.length > 0 && (\n <Flex flexDirection=\"column\" gap={12}>\n {stateTax.questions.map((question, qIndex) => {\n const answer = question.answers[0]?.value\n if (answer === null || answer === undefined) return null\n\n return (\n <Flex key={question.key || qIndex} flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">{question.label}</Components.Text>\n <Components.Text>\n {formatStateTaxAnswer(question, answer)}\n </Components.Text>\n </Flex>\n )\n })}\n </Flex>\n )}\n </Flex>\n ))}\n </Flex>\n ) : (\n <Components.Text>{t('taxes.state.noStateTaxes')}</Components.Text>\n )}\n </Flex>\n </Components.Box>\n </Flex>\n )\n}\n"],"names":["TaxesViewWithData","employeeId","onEditFederalTaxes","onEditStateTaxes","taxes","useEmployeeTaxes","BaseLayout","federalTaxes","jsx","TaxesView","stateTaxes","isLoading","t","useTranslation","Components","useComponentContext","formatCurrency","useNumberFormatter","Loading","formatStateTaxAnswer","question","answer","option","opt","numValue","jsxs","Flex","stateTax","index","qIndex"],"mappings":"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"}
1
+ {"version":3,"file":"TaxesView.js","sources":["../../../../src/components/Employee/Dashboard/TaxesView.tsx"],"sourcesContent":["import { useTranslation } from 'react-i18next'\nimport type { GetV1EmployeesEmployeeIdFederalTaxesResponse } from '@gusto/embedded-api/models/operations/getv1employeesemployeeidfederaltaxes'\nimport type { GetV1EmployeesEmployeeIdStateTaxesResponse } from '@gusto/embedded-api/models/operations/getv1employeesemployeeidstatetaxes'\nimport type { EmployeeStateTaxQuestion } from '@gusto/embedded-api/models/components/employeestatetaxquestion'\nimport { useEmployeeTaxes } from './hooks'\nimport { Flex } from '@/components/Common/Flex/Flex'\nimport { useComponentContext } from '@/contexts/ComponentAdapter/useComponentContext'\nimport { Loading } from '@/components/Common'\nimport { BaseLayout } from '@/components/Base/Base'\nimport useNumberFormatter from '@/hooks/useNumberFormatter'\n\ntype EmployeeFederalTax = NonNullable<\n GetV1EmployeesEmployeeIdFederalTaxesResponse['employeeFederalTax']\n>\ntype EmployeeStateTax = NonNullable<\n GetV1EmployeesEmployeeIdStateTaxesResponse['employeeStateTaxesList']\n>[number]\n\nexport interface TaxesViewProps {\n federalTaxes?: EmployeeFederalTax\n stateTaxes?: EmployeeStateTax[]\n /** Loads both cards. Override per-card via `isFederalTaxesLoading` /\n * `isStateTaxesLoading` when the queries resolve independently. */\n isLoading?: boolean\n isFederalTaxesLoading?: boolean\n isStateTaxesLoading?: boolean\n onEditFederalTaxes?: () => void\n onEditStateTaxes?: () => void\n}\n\nexport interface TaxesViewWithDataProps {\n employeeId: string\n /** Receives the federal-tax record so the parent can preserve the\n * existing event payload (`{ employeeId, federalTaxes }`). */\n onEditFederalTaxes?: (federalTaxes: EmployeeFederalTax | undefined) => void\n onEditStateTaxes?: () => void\n}\n\n/**\n * Tab-mounted container for the Taxes tab. Owns the `useEmployeeTaxes`\n * fetch so federal/state tax requests only fire when the tab is mounted.\n * Federal and state queries run independently — each card paints its\n * own skeleton + content as data arrives.\n */\nexport function TaxesViewWithData({\n employeeId,\n onEditFederalTaxes,\n onEditStateTaxes,\n}: TaxesViewWithDataProps) {\n const taxes = useEmployeeTaxes({ employeeId })\n\n const federalTaxes = taxes.data.employeeFederalTax\n return (\n <BaseLayout error={taxes.errorHandling.errors}>\n <TaxesView\n federalTaxes={federalTaxes}\n stateTaxes={taxes.data.employeeStateTaxesList}\n isFederalTaxesLoading={taxes.status.isFederalTaxesLoading}\n isStateTaxesLoading={taxes.status.isStateTaxesLoading}\n onEditFederalTaxes={() => onEditFederalTaxes?.(federalTaxes)}\n onEditStateTaxes={onEditStateTaxes}\n />\n </BaseLayout>\n )\n}\n\nexport function TaxesView({\n federalTaxes,\n stateTaxes,\n isLoading = false,\n isFederalTaxesLoading = isLoading,\n isStateTaxesLoading = isLoading,\n onEditFederalTaxes,\n onEditStateTaxes,\n}: TaxesViewProps) {\n const { t } = useTranslation('Employee.Dashboard')\n const Components = useComponentContext()\n const formatCurrency = useNumberFormatter('currency')\n\n // Helper function to format state tax answer values\n const formatStateTaxAnswer = (\n question: EmployeeStateTaxQuestion,\n answer: string | number | boolean,\n ) => {\n // For Select type questions, look up the label from options\n if (\n question.inputQuestionFormat.type === 'Select' &&\n question.inputQuestionFormat.options &&\n question.inputQuestionFormat.options.length > 0\n ) {\n const option = question.inputQuestionFormat.options.find(opt => opt.value === answer)\n if (option?.label) {\n return option.label\n }\n }\n\n // For numeric values, only format as currency for Currency questions\n if (typeof answer === 'number') {\n if (question.inputQuestionFormat.type === 'Currency') {\n return formatCurrency(answer)\n }\n return answer\n }\n\n // For string currency values (like \"0.0\")\n if (typeof answer === 'string' && !isNaN(parseFloat(answer))) {\n const numValue = parseFloat(answer)\n // Check if this looks like a currency (has decimal point or question type is Currency)\n if (question.inputQuestionFormat.type === 'Currency') {\n return formatCurrency(numValue)\n }\n // For non-currency numeric strings, return as-is\n return answer\n }\n\n // For boolean values\n if (typeof answer === 'boolean') {\n return answer ? t('common.yes') : t('common.no')\n }\n\n // Default: return string value as-is\n return answer\n }\n\n return (\n <Flex flexDirection=\"column\" gap={24}>\n <Components.Box\n header={\n <Components.BoxHeader\n title={t('taxes.federal.title')}\n action={\n <Components.Button\n variant=\"secondary\"\n onClick={onEditFederalTaxes}\n isDisabled={isFederalTaxesLoading}\n >\n {t('taxes.federal.editCta')}\n </Components.Button>\n }\n />\n }\n >\n <Flex flexDirection=\"column\" gap={16}>\n {isFederalTaxesLoading ? (\n <Loading />\n ) : federalTaxes ? (\n <Flex flexDirection=\"column\" gap={12}>\n {federalTaxes.filingStatus && (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {t('taxes.federal.filingStatus')}\n </Components.Text>\n <Components.Text>{federalTaxes.filingStatus}</Components.Text>\n </Flex>\n )}\n\n {'twoJobs' in federalTaxes && federalTaxes.twoJobs !== null && (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {t('taxes.federal.multipleJobs')}\n </Components.Text>\n <Components.Text>\n {federalTaxes.twoJobs ? t('common.yes') : t('common.no')}\n </Components.Text>\n </Flex>\n )}\n\n {'dependentsAmount' in federalTaxes && federalTaxes.dependentsAmount && (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {t('taxes.federal.dependentsAndOtherCredits')}\n </Components.Text>\n <Components.Text>\n {formatCurrency(parseFloat(federalTaxes.dependentsAmount))}\n </Components.Text>\n </Flex>\n )}\n\n {'otherIncome' in federalTaxes && federalTaxes.otherIncome && (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {t('taxes.federal.otherIncome')}\n </Components.Text>\n <Components.Text>\n {formatCurrency(parseFloat(federalTaxes.otherIncome))}\n </Components.Text>\n </Flex>\n )}\n\n {'deductions' in federalTaxes && federalTaxes.deductions && (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {t('taxes.federal.deductions')}\n </Components.Text>\n <Components.Text>\n {formatCurrency(parseFloat(federalTaxes.deductions))}\n </Components.Text>\n </Flex>\n )}\n\n {'extraWithholding' in federalTaxes && federalTaxes.extraWithholding && (\n <Flex flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">\n {t('taxes.federal.extraWithholding')}\n </Components.Text>\n <Components.Text>\n {formatCurrency(parseFloat(federalTaxes.extraWithholding))}\n </Components.Text>\n </Flex>\n )}\n </Flex>\n ) : null}\n </Flex>\n </Components.Box>\n\n <Components.Box\n header={\n <Components.BoxHeader\n title={t('taxes.state.title')}\n action={\n <Components.Button\n variant=\"secondary\"\n onClick={onEditStateTaxes}\n isDisabled={isStateTaxesLoading}\n >\n {t('taxes.state.editCta')}\n </Components.Button>\n }\n />\n }\n >\n <Flex flexDirection=\"column\" gap={16}>\n {isStateTaxesLoading ? (\n <Loading />\n ) : stateTaxes && stateTaxes.length > 0 ? (\n <Flex flexDirection=\"column\" gap={24}>\n {stateTaxes.map((stateTax, index) => (\n <Flex key={stateTax.state || index} flexDirection=\"column\" gap={16}>\n <Components.Heading as=\"h4\">{stateTax.state}</Components.Heading>\n\n {stateTax.questions && stateTax.questions.length > 0 && (\n <Flex flexDirection=\"column\" gap={12}>\n {stateTax.questions.map((question, qIndex) => {\n const answer = question.answers[0]?.value\n if (answer === null || answer === undefined) return null\n\n return (\n <Flex key={question.key || qIndex} flexDirection=\"column\" gap={0}>\n <Components.Text variant=\"supporting\">{question.label}</Components.Text>\n <Components.Text>\n {formatStateTaxAnswer(question, answer)}\n </Components.Text>\n </Flex>\n )\n })}\n </Flex>\n )}\n </Flex>\n ))}\n </Flex>\n ) : (\n <Components.Text>{t('taxes.state.noStateTaxes')}</Components.Text>\n )}\n </Flex>\n </Components.Box>\n </Flex>\n )\n}\n"],"names":["TaxesViewWithData","employeeId","onEditFederalTaxes","onEditStateTaxes","taxes","useEmployeeTaxes","federalTaxes","jsx","BaseLayout","TaxesView","stateTaxes","isLoading","isFederalTaxesLoading","isStateTaxesLoading","t","useTranslation","Components","useComponentContext","formatCurrency","useNumberFormatter","formatStateTaxAnswer","question","answer","option","opt","numValue","jsxs","Flex","Loading","stateTax","index","qIndex"],"mappings":"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"}