@zeniai/client-epic-state 5.1.0-betaSS3 → 5.1.1-beta0ND

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 (514) hide show
  1. package/lib/common/aiCfo/aiCfoSuggestedQuestionsPageContext.d.ts +1 -1
  2. package/lib/commonStateTypes/amount.d.ts +1 -0
  3. package/lib/commonStateTypes/amount.js +9 -1
  4. package/lib/commonStateTypes/animations.d.ts +1 -1
  5. package/lib/commonStateTypes/animations.js +1 -0
  6. package/lib/commonStateTypes/viewAndReport/viewAndReport.d.ts +2 -2
  7. package/lib/commonStateTypes/viewAndReport/viewAndReport.js +2 -0
  8. package/lib/commonStateTypes/workingDayHelper.d.ts +9 -0
  9. package/lib/commonStateTypes/workingDayHelper.js +28 -1
  10. package/lib/entity/account/accountSelector.d.ts +9 -0
  11. package/lib/entity/account/accountSelector.js +14 -1
  12. package/lib/entity/account/accountState.d.ts +1 -1
  13. package/lib/entity/accountGroup/accountGroupState.d.ts +1 -1
  14. package/lib/entity/aiCfo/aiCfoPayload.d.ts +64 -5
  15. package/lib/entity/aiCfo/aiCfoReducer.d.ts +23 -2
  16. package/lib/entity/aiCfo/aiCfoReducer.js +252 -10
  17. package/lib/entity/aiCfo/aiCfoSelector.d.ts +4 -1
  18. package/lib/entity/aiCfo/aiCfoSelector.js +19 -1
  19. package/lib/entity/aiCfo/aiCfoState.d.ts +98 -4
  20. package/lib/entity/aiCfo/aiCfoState.js +20 -1
  21. package/lib/entity/approvalRule/approvalRuleConflict.d.ts +56 -0
  22. package/lib/entity/approvalRule/approvalRuleConflict.js +77 -0
  23. package/lib/entity/approvalRule/approvalRulePayload.d.ts +34 -5
  24. package/lib/entity/approvalRule/approvalRulePayload.js +145 -10
  25. package/lib/entity/approvalRule/approvalRuleSelector.d.ts +25 -1
  26. package/lib/entity/approvalRule/approvalRuleSelector.js +40 -0
  27. package/lib/entity/approvalRule/approvalRuleState.d.ts +59 -7
  28. package/lib/entity/cardPolicy/cardPolicyPayload.d.ts +277 -0
  29. package/lib/entity/cardPolicy/cardPolicyPayload.js +143 -0
  30. package/lib/entity/cardPolicy/cardPolicyReducer.d.ts +19 -0
  31. package/lib/entity/cardPolicy/cardPolicyReducer.js +175 -0
  32. package/lib/entity/cardPolicy/cardPolicySelector.d.ts +32 -0
  33. package/lib/entity/cardPolicy/cardPolicySelector.js +99 -0
  34. package/lib/entity/cardPolicy/cardPolicyState.d.ts +205 -0
  35. package/lib/entity/cardPolicy/cardPolicyState.js +14 -0
  36. package/lib/entity/cardPolicy/extractPolicyDocumentEpic.d.ts +18 -0
  37. package/lib/entity/cardPolicy/extractPolicyDocumentEpic.js +68 -0
  38. package/lib/entity/cardPolicy/fetchCardPolicyVendorOptionsEpic.d.ts +26 -0
  39. package/lib/entity/cardPolicy/fetchCardPolicyVendorOptionsEpic.js +47 -0
  40. package/lib/entity/cardPolicy/policyDocumentExtractionToRecommendationBridgeEpic.d.ts +25 -0
  41. package/lib/entity/cardPolicy/policyDocumentExtractionToRecommendationBridgeEpic.js +39 -0
  42. package/lib/entity/cardPolicy/policyRecommendationFromUploadEpic.d.ts +24 -0
  43. package/lib/entity/cardPolicy/policyRecommendationFromUploadEpic.js +105 -0
  44. package/lib/entity/class/classReducer.d.ts +4 -4
  45. package/lib/entity/class/classState.d.ts +1 -1
  46. package/lib/entity/company/companyPayload.d.ts +4 -0
  47. package/lib/entity/company/companyPayload.js +4 -0
  48. package/lib/entity/company/companyStateTypes.d.ts +4 -0
  49. package/lib/entity/forecast/forecastState.d.ts +1 -1
  50. package/lib/entity/jeSchedules/jeSchedulesPayload.d.ts +1 -0
  51. package/lib/entity/jeSchedules/jeSchedulesPayload.js +19 -0
  52. package/lib/entity/jeSchedules/jeSchedulesState.d.ts +2 -0
  53. package/lib/entity/jeSchedules/jeSchedulesTypes.d.ts +1 -1
  54. package/lib/entity/monthEndCloseChecks/monthEndCloseChecksState.d.ts +1 -1
  55. package/lib/entity/paymentAccount/paymentAccountSelector.d.ts +1 -0
  56. package/lib/entity/paymentAccount/paymentAccountSelector.js +9 -0
  57. package/lib/entity/sectionAccountsView/sectionAccountsView.d.ts +1 -1
  58. package/lib/entity/sectionClassesViewV2/sectionClassesView.d.ts +1 -1
  59. package/lib/entity/sectionClassesViewV2/sectionClassesViewReducer.d.ts +2 -2
  60. package/lib/entity/sectionProjectView/sectionProjectView.d.ts +1 -1
  61. package/lib/entity/sectionProjectView/sectionProjectViewReducer.d.ts +2 -2
  62. package/lib/entity/snackbar/snackbarTypes.d.ts +1 -1
  63. package/lib/entity/snackbar/snackbarTypes.js +7 -0
  64. package/lib/entity/task/taskPayload.d.ts +3 -1
  65. package/lib/entity/task/taskPayload.js +2 -0
  66. package/lib/entity/task/taskState.d.ts +2 -0
  67. package/lib/entity/tenant/clearAllEpic.d.ts +9 -2
  68. package/lib/entity/tenant/clearAllEpic.js +14 -0
  69. package/lib/entity/tenant/epic/deleteConnectionEpic.d.ts +1 -1
  70. package/lib/entity/tenant/epic/initEmailConnectOAuthEpic.d.ts +21 -0
  71. package/lib/entity/tenant/epic/initEmailConnectOAuthEpic.js +54 -0
  72. package/lib/entity/tenant/epic/saveAPIKeyConnectionEpic.d.ts +1 -1
  73. package/lib/entity/tenant/epic/saveConnectorCredentialsEpic.d.ts +3 -3
  74. package/lib/entity/tenant/epic/saveOAuthConnectionEpic.d.ts +1 -1
  75. package/lib/entity/tenant/tenantPayload.d.ts +22 -0
  76. package/lib/entity/tenant/tenantReducer.d.ts +52 -30
  77. package/lib/entity/tenant/tenantReducer.js +195 -11
  78. package/lib/entity/tenant/tenantState.d.ts +25 -1
  79. package/lib/entity/transaction/payloadTypes/transactionPayload.d.ts +4 -0
  80. package/lib/entity/transaction/payloadTypes/transactionPayload.js +17 -7
  81. package/lib/entity/transaction/stateTypes/transaction.d.ts +3 -0
  82. package/lib/entity/transaction/stateTypes/transactionLine.d.ts +2 -1
  83. package/lib/entity/transaction/stateTypes/transactionLine.js +2 -1
  84. package/lib/epic.d.ts +36 -2
  85. package/lib/epic.js +37 -2
  86. package/lib/esm/commonStateTypes/amount.js +7 -0
  87. package/lib/esm/commonStateTypes/animations.js +1 -0
  88. package/lib/esm/commonStateTypes/viewAndReport/viewAndReport.js +2 -0
  89. package/lib/esm/commonStateTypes/workingDayHelper.js +26 -0
  90. package/lib/esm/entity/account/accountSelector.js +11 -0
  91. package/lib/esm/entity/aiCfo/aiCfoReducer.js +252 -10
  92. package/lib/esm/entity/aiCfo/aiCfoSelector.js +17 -1
  93. package/lib/esm/entity/aiCfo/aiCfoState.js +17 -0
  94. package/lib/esm/entity/approvalRule/approvalRuleConflict.js +74 -0
  95. package/lib/esm/entity/approvalRule/approvalRulePayload.js +145 -10
  96. package/lib/esm/entity/approvalRule/approvalRuleSelector.js +35 -0
  97. package/lib/esm/entity/cardPolicy/cardPolicyPayload.js +130 -0
  98. package/lib/esm/entity/cardPolicy/cardPolicyReducer.js +171 -0
  99. package/lib/esm/entity/cardPolicy/cardPolicySelector.js +75 -0
  100. package/lib/esm/entity/cardPolicy/cardPolicyState.js +9 -0
  101. package/lib/esm/entity/cardPolicy/extractPolicyDocumentEpic.js +64 -0
  102. package/lib/esm/entity/cardPolicy/fetchCardPolicyVendorOptionsEpic.js +43 -0
  103. package/lib/esm/entity/cardPolicy/policyDocumentExtractionToRecommendationBridgeEpic.js +35 -0
  104. package/lib/esm/entity/cardPolicy/policyRecommendationFromUploadEpic.js +101 -0
  105. package/lib/esm/entity/company/companyPayload.js +4 -0
  106. package/lib/esm/entity/jeSchedules/jeSchedulesPayload.js +19 -0
  107. package/lib/esm/entity/paymentAccount/paymentAccountSelector.js +8 -0
  108. package/lib/esm/entity/snackbar/snackbarTypes.js +7 -0
  109. package/lib/esm/entity/task/taskPayload.js +2 -0
  110. package/lib/esm/entity/tenant/clearAllEpic.js +14 -0
  111. package/lib/esm/entity/tenant/epic/initEmailConnectOAuthEpic.js +50 -0
  112. package/lib/esm/entity/tenant/tenantReducer.js +192 -9
  113. package/lib/esm/entity/transaction/payloadTypes/transactionPayload.js +17 -7
  114. package/lib/esm/entity/transaction/stateTypes/transactionLine.js +1 -0
  115. package/lib/esm/epic.js +37 -2
  116. package/lib/esm/index.js +77 -34
  117. package/lib/esm/reducer.js +21 -0
  118. package/lib/esm/view/aiCfoView/aiCfoViewReducer.js +6 -3
  119. package/lib/esm/view/aiCfoView/epics/createSessionAndSubmitEpic.js +5 -2
  120. package/lib/esm/view/aiCfoView/epics/createSessionEpic.js +2 -1
  121. package/lib/esm/view/aiCfoView/epics/fetchSuggestedQuestionsEpic.js +12 -2
  122. package/lib/esm/view/companyTaskManagerView/companyTaskManagerViewReducer.js +39 -11
  123. package/lib/esm/view/companyTaskManagerView/companyTaskManagerViewSelector.js +14 -4
  124. package/lib/esm/view/companyTaskManagerView/epics/fetchCockpitContextEpic.js +38 -0
  125. package/lib/esm/view/companyTaskManagerView/epics/fetchCompanyTaskManagerViewEpic.js +37 -28
  126. package/lib/esm/view/companyTaskManagerView/epics/updateCompanyTaskManagerViewFiltersEpic.js +16 -0
  127. package/lib/esm/view/companyView/companyViewReducer.js +46 -1
  128. package/lib/esm/view/companyView/epic/companyPassport/dismissCapitalizationOnboardingEpic.js +25 -0
  129. package/lib/esm/view/companyView/epic/companyPassport/updateCapitalizationAccountThresholdEpic.js +98 -0
  130. package/lib/esm/view/companyView/epic/fetchAllCockpitViewsEpic.js +2 -2
  131. package/lib/esm/view/companyView/types/companyPassport/companyPassportViewState.js +4 -0
  132. package/lib/esm/view/createTransferEntry/createTransferEntryReducer.js +82 -0
  133. package/lib/esm/view/createTransferEntry/createTransferEntrySelector.js +64 -0
  134. package/lib/esm/view/createTransferEntry/createTransferEntryState.js +17 -0
  135. package/lib/esm/view/createTransferEntry/epics/createTransferEntryEpic.js +136 -0
  136. package/lib/esm/view/createTransferEntry/epics/fetchTransferAccountsEpic.js +36 -0
  137. package/lib/esm/view/dashboard/dashboardReducer.js +11 -1
  138. package/lib/esm/view/expenseAutomationView/epics/common/fetchAllExpenseAutomationTabsEpic.js +3 -3
  139. package/lib/esm/view/expenseAutomationView/epics/common/refreshExpenseAutomationCurrentTabEpic.js +3 -4
  140. package/lib/esm/view/expenseAutomationView/epics/missingReceipts/searchTransactionsForManualMatchEpic.js +13 -9
  141. package/lib/esm/view/expenseAutomationView/epics/transactionCategorization/backgroundRefetchReviewTabEpic.js +3 -16
  142. package/lib/esm/view/expenseAutomationView/epics/transactionCategorization/fetchTransactionCategorizationEpic.js +9 -16
  143. package/lib/esm/view/expenseAutomationView/epics/transactionCategorization/fetchTransactionCategorizationViewEpic.js +2 -2
  144. package/lib/esm/view/expenseAutomationView/epics/transactionCategorization/markTransactionAsNotMiscategorizedEpic.js +2 -13
  145. package/lib/esm/view/expenseAutomationView/epics/transactionCategorization/saveTransactionCategorizationEpic.js +2 -6
  146. package/lib/esm/view/expenseAutomationView/epics/transactionCategorization/triggerReviewTabRefetchEpic.js +2 -2
  147. package/lib/esm/view/expenseAutomationView/epics/transactionCategorization/updateTransactionCategorizationEpic.js +2 -6
  148. package/lib/esm/view/expenseAutomationView/expenseAutomationViewReducer.js +3 -20
  149. package/lib/esm/view/expenseAutomationView/reducers/transactionsViewReducer.js +21 -49
  150. package/lib/esm/view/expenseAutomationView/selectors/transactionCategorizationSelector.js +14 -7
  151. package/lib/esm/view/expenseAutomationView/transactionFilterHelpers.js +106 -18
  152. package/lib/esm/view/fileView/epic/deleteFileEpic.js +2 -2
  153. package/lib/esm/view/fileView/epic/deleteFileListEpic.js +2 -2
  154. package/lib/esm/view/fileView/epic/updateFileNameEpic.js +2 -2
  155. package/lib/esm/view/onboardingView/customerView/epic/aiAgentsActivation/fetchAiAgentsActivationStatusEpic.js +40 -0
  156. package/lib/esm/view/onboardingView/customerView/epic/customerDetails/acknowledgeOnboardingAiActivationViewedEpic.js +29 -0
  157. package/lib/esm/view/onboardingView/customerView/epic/customerDetails/acknowledgeOnboardingAiFinanceTeamEpic.js +40 -0
  158. package/lib/esm/view/onboardingView/customerView/onboardingCustomerViewReducer.js +218 -50
  159. package/lib/esm/view/onboardingView/customerView/onboardingCustomerViewSelector.js +12 -2
  160. package/lib/esm/view/onboardingView/customerView/onboardingCustomerViewState.js +12 -0
  161. package/lib/esm/view/spendManagement/autotransferRules/autoTransferRulesSelector.js +22 -2
  162. package/lib/esm/view/spendManagement/billPay/billPayReview/billPayReviewSelector.js +14 -0
  163. package/lib/esm/view/spendManagement/billPay/billPaySetupApproverView/billPaySetupApproverViewReducer.js +109 -12
  164. package/lib/esm/view/spendManagement/billPay/billPaySetupApproverView/epic/deleteBillPayApprovalRuleEpic.js +10 -2
  165. package/lib/esm/view/spendManagement/billPay/billPaySetupApproverView/epic/fetchBillPaySetupApproverViewEpic.js +8 -4
  166. package/lib/esm/view/spendManagement/billPay/billPaySetupApproverView/epic/initializeBillPaySetupApproverViewUpdateDataEpic.js +11 -7
  167. package/lib/esm/view/spendManagement/billPay/billPaySetupApproverView/epic/reorderBillPayApprovalRulesEpic.js +54 -0
  168. package/lib/esm/view/spendManagement/billPay/billPaySetupApproverView/epic/saveBillPaySetupApproverViewUpdatesEpic.js +13 -4
  169. package/lib/esm/view/spendManagement/billPay/billPaySetupApproverView/types/commonPayload.js +140 -16
  170. package/lib/esm/view/spendManagement/billPay/editBillView/editBillViewSelector.js +60 -4
  171. package/lib/esm/view/spendManagement/billPay/editBillView/epics/fetchEditBillDetailPageEpic.js +8 -2
  172. package/lib/esm/view/spendManagement/cashManagement/autoSweepFlow/autoSweepFlowPayload.js +29 -0
  173. package/lib/esm/view/spendManagement/cashManagement/autoSweepFlow/autoSweepFlowReducer.js +78 -0
  174. package/lib/esm/view/spendManagement/cashManagement/autoSweepFlow/autoSweepFlowSelector.js +47 -0
  175. package/lib/esm/view/spendManagement/cashManagement/autoSweepFlow/autoSweepFlowState.js +47 -0
  176. package/lib/esm/view/spendManagement/cashManagement/autoSweepFlow/epics/fetchCashManagementSettingsEpic.js +32 -0
  177. package/lib/esm/view/spendManagement/cashManagement/autoSweepFlow/epics/saveAutoSweepSettingsEpic.js +32 -0
  178. package/lib/esm/view/spendManagement/cashManagement/cashManagementOverview/cashManagementOverviewPayload.js +54 -0
  179. package/lib/esm/view/spendManagement/cashManagement/cashManagementOverview/cashManagementOverviewReducer.js +92 -0
  180. package/lib/esm/view/spendManagement/cashManagement/cashManagementOverview/cashManagementOverviewSelector.js +224 -0
  181. package/lib/esm/view/spendManagement/cashManagement/cashManagementOverview/cashManagementOverviewState.js +10 -0
  182. package/lib/esm/view/spendManagement/cashManagement/cashManagementOverview/epics/fetchCashManagementBannerEpic.js +23 -0
  183. package/lib/esm/view/spendManagement/cashManagement/cashManagementOverview/epics/fetchCashManagementOverviewPageEpic.js +36 -0
  184. package/lib/esm/view/spendManagement/cashManagement/cashManagementOverview/epics/fetchCashManagementRecommendationEpic.js +27 -0
  185. package/lib/esm/view/spendManagement/cashManagement/cashManagementOverview/epics/fetchRecentTransferEpic.js +28 -0
  186. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/cardPolicyDetail/cardPolicyDetailReducer.js +52 -0
  187. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/cardPolicyDetail/cardPolicyDetailSelector.js +22 -0
  188. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/cardPolicyDetail/cardPolicyDetailState.js +1 -0
  189. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/cardPolicyDetail/fetchCardPolicyDetailEpic.js +36 -0
  190. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/cardPolicyDetail/updateCardPolicyEpic.js +39 -0
  191. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/cardPolicyList/archiveCardPolicyEpic.js +34 -0
  192. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/cardPolicyList/cardPolicyListReducer.js +71 -0
  193. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/cardPolicyList/cardPolicyListSelector.js +21 -0
  194. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/cardPolicyList/cardPolicyListState.js +1 -0
  195. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/cardPolicyList/fetchCardPolicyListEpic.js +38 -0
  196. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/applyAiCardPolicyFormDraftUpdate.js +289 -0
  197. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/applyExtractedPolicyToAiCardPolicyDraft.js +109 -0
  198. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/applyExtractedPolicyToDraftEpic.js +44 -0
  199. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/applyExtractedPolicyToManualCardPolicyDraft.js +111 -0
  200. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/applyUploadPlanToAiCardPolicyDraft.js +25 -0
  201. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/buildAiCardPolicyFormDraftSeed.js +363 -0
  202. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/buildManualCardPolicyFormDraftSeed.js +36 -0
  203. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/cardPolicyChipIds.js +19 -0
  204. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/cardPolicyFormDraftTypes.js +6 -0
  205. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/cardPolicyRequestParts.js +119 -0
  206. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/createCardPolicyReducer.js +154 -0
  207. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/createCardPolicySelector.js +22 -0
  208. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/createCardPolicyState.js +1 -0
  209. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/createCardPolicyTemplateEpic.js +49 -0
  210. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/deriveAiPolicyReviewRowsFromInputs.js +140 -0
  211. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/fetchCardPolicyMccCategoriesEpic.js +20 -0
  212. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/seedAiCardPolicyFormDraftEpic.js +100 -0
  213. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/toBulkCardPolicyTemplateRequestsFromDraft.js +96 -0
  214. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/toCardPolicyTemplateRequestFromDraft.js +59 -0
  215. package/lib/esm/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/toManualCardPolicyTemplateRequestFromDraft.js +24 -0
  216. package/lib/esm/view/spendManagement/chargeCards/chargeCardList/chargeCardListSelector.js +25 -0
  217. package/lib/esm/view/spendManagement/chargeCards/issueChargeCard/aiCardCreationFormDraftTypes.js +1 -0
  218. package/lib/esm/view/spendManagement/chargeCards/issueChargeCard/applyAiCardCreationFormDraftUpdate.js +34 -0
  219. package/lib/esm/view/spendManagement/chargeCards/issueChargeCard/buildAiCardCreationFormDraftSeed.js +57 -0
  220. package/lib/esm/view/spendManagement/chargeCards/issueChargeCard/deriveAiCardRowsFromTeams.js +35 -0
  221. package/lib/esm/view/spendManagement/chargeCards/issueChargeCard/issueChargeCardEpic.js +2 -2
  222. package/lib/esm/view/spendManagement/chargeCards/issueChargeCard/issueChargeCardReducer.js +42 -4
  223. package/lib/esm/view/spendManagement/chargeCards/issueChargeCard/issueChargeCardSelector.js +35 -0
  224. package/lib/esm/view/spendManagement/chargeCards/issueChargeCard/seedAiCardCreationFormDraftEpic.js +62 -0
  225. package/lib/esm/view/spendManagement/chargeCards/issueChargeCard/toIssueChargeCardLocalDataFromDraft.js +44 -0
  226. package/lib/esm/view/spendManagement/commonSetup/epic/setup/parseUploadedKybDocumentEpic.js +58 -0
  227. package/lib/esm/view/spendManagement/commonSetup/epic/setup/parseUploadedKycDocumentEpic.js +77 -0
  228. package/lib/esm/view/spendManagement/commonSetup/kycKybAutofillActions.js +14 -0
  229. package/lib/esm/view/spendManagement/commonSetup/kycKybParseMapper.js +207 -0
  230. package/lib/esm/view/spendManagement/commonSetup/setupViewReducer.js +106 -52
  231. package/lib/esm/view/spendManagement/commonSetup/setupViewSelector.js +6 -1
  232. package/lib/esm/view/spendManagement/commonSetup/types/kycKybAutofill.js +41 -0
  233. package/lib/esm/view/spendManagement/reimbursement/editRemiView/epics/fetchEditRemiDetailPageEpic.js +5 -1
  234. package/lib/esm/view/spendManagement/reimbursement/remiSetupApproverView/epic/deleteRemiApprovalRuleEpic.js +10 -2
  235. package/lib/esm/view/spendManagement/reimbursement/remiSetupApproverView/epic/fetchRemiSetupApproverViewEpic.js +8 -2
  236. package/lib/esm/view/spendManagement/reimbursement/remiSetupApproverView/epic/initializeRemiSetupApproverViewUpdateDataEpic.js +11 -7
  237. package/lib/esm/view/spendManagement/reimbursement/remiSetupApproverView/epic/reorderRemiApprovalRulesEpic.js +61 -0
  238. package/lib/esm/view/spendManagement/reimbursement/remiSetupApproverView/epic/saveRemiSetupApproverViewUpdatesEpic.js +13 -4
  239. package/lib/esm/view/spendManagement/reimbursement/remiSetupApproverView/remiSetupApproverViewReducer.js +80 -11
  240. package/lib/esm/view/spendManagement/treasury/treasurySetUp/epic/updateTreasuryPromoIntroClosedByOutsideClickEpic.js +18 -0
  241. package/lib/esm/view/spendManagement/treasury/treasurySetUp/epic/updateTreasuryPromoRemindMeLaterClickedEpic.js +18 -0
  242. package/lib/esm/view/spendManagement/treasury/treasurySetUp/epic/updateTreasuryVideoViewedEpic.js +1 -1
  243. package/lib/esm/view/spendManagement/treasury/treasurySetUp/treasurySetupViewReducer.js +45 -1
  244. package/lib/esm/view/transactionDetail/journalEntryLinesViewModel.js +149 -0
  245. package/lib/esm/view/transactionDetail/transactionDetailSelector.js +6 -1
  246. package/lib/index.d.ts +94 -40
  247. package/lib/index.js +281 -37
  248. package/lib/reducer.d.ts +21 -0
  249. package/lib/reducer.js +21 -0
  250. package/lib/view/aiCfoView/aiCfoViewReducer.d.ts +11 -2
  251. package/lib/view/aiCfoView/aiCfoViewReducer.js +6 -3
  252. package/lib/view/aiCfoView/epics/createSessionAndSubmitEpic.js +5 -2
  253. package/lib/view/aiCfoView/epics/createSessionEpic.js +2 -1
  254. package/lib/view/aiCfoView/epics/fetchSuggestedQuestionsEpic.d.ts +8 -1
  255. package/lib/view/aiCfoView/epics/fetchSuggestedQuestionsEpic.js +12 -2
  256. package/lib/view/auditReportView/auditReportViewState.d.ts +1 -1
  257. package/lib/view/billPayCard/billPayCardSelector.d.ts +1 -1
  258. package/lib/view/cardBalance/cardBalanceSelector.d.ts +1 -1
  259. package/lib/view/cashBalance/cashBalanceSelector.d.ts +1 -1
  260. package/lib/view/cashInCashOut/cashInCashOutSelector.d.ts +1 -1
  261. package/lib/view/cashPosition/cashPositionSelector.d.ts +1 -1
  262. package/lib/view/companyTaskManagerView/companyTaskManagerViewPayload.d.ts +19 -11
  263. package/lib/view/companyTaskManagerView/companyTaskManagerViewReducer.d.ts +11 -5
  264. package/lib/view/companyTaskManagerView/companyTaskManagerViewReducer.js +40 -12
  265. package/lib/view/companyTaskManagerView/companyTaskManagerViewSelector.d.ts +2 -0
  266. package/lib/view/companyTaskManagerView/companyTaskManagerViewSelector.js +13 -3
  267. package/lib/view/companyTaskManagerView/companyTaskManagerViewState.d.ts +11 -3
  268. package/lib/view/companyTaskManagerView/epics/fetchCockpitContextEpic.d.ts +10 -0
  269. package/lib/view/companyTaskManagerView/epics/fetchCockpitContextEpic.js +42 -0
  270. package/lib/view/companyTaskManagerView/epics/fetchCompanyTaskManagerViewEpic.d.ts +1 -3
  271. package/lib/view/companyTaskManagerView/epics/fetchCompanyTaskManagerViewEpic.js +37 -28
  272. package/lib/view/companyTaskManagerView/epics/updateCompanyTaskManagerViewFiltersEpic.d.ts +6 -0
  273. package/lib/view/companyTaskManagerView/epics/updateCompanyTaskManagerViewFiltersEpic.js +20 -0
  274. package/lib/view/companyView/companyViewReducer.d.ts +12 -1
  275. package/lib/view/companyView/companyViewReducer.js +48 -3
  276. package/lib/view/companyView/epic/companyPassport/dismissCapitalizationOnboardingEpic.d.ts +9 -0
  277. package/lib/view/companyView/epic/companyPassport/dismissCapitalizationOnboardingEpic.js +29 -0
  278. package/lib/view/companyView/epic/companyPassport/updateCapitalizationAccountThresholdEpic.d.ts +10 -0
  279. package/lib/view/companyView/epic/companyPassport/updateCapitalizationAccountThresholdEpic.js +102 -0
  280. package/lib/view/companyView/epic/fetchAllCockpitViewsEpic.js +2 -2
  281. package/lib/view/companyView/types/cockpitTypes.d.ts +3 -2
  282. package/lib/view/companyView/types/companyPassport/companyPassportViewState.d.ts +1 -0
  283. package/lib/view/companyView/types/companyPassport/companyPassportViewState.js +4 -0
  284. package/lib/view/createTransferEntry/createTransferEntryReducer.d.ts +32 -0
  285. package/lib/view/createTransferEntry/createTransferEntryReducer.js +86 -0
  286. package/lib/view/createTransferEntry/createTransferEntrySelector.d.ts +39 -0
  287. package/lib/view/createTransferEntry/createTransferEntrySelector.js +69 -0
  288. package/lib/view/createTransferEntry/createTransferEntryState.d.ts +30 -0
  289. package/lib/view/createTransferEntry/createTransferEntryState.js +20 -0
  290. package/lib/view/createTransferEntry/epics/createTransferEntryEpic.d.ts +11 -0
  291. package/lib/view/createTransferEntry/epics/createTransferEntryEpic.js +140 -0
  292. package/lib/view/createTransferEntry/epics/fetchTransferAccountsEpic.d.ts +14 -0
  293. package/lib/view/createTransferEntry/epics/fetchTransferAccountsEpic.js +40 -0
  294. package/lib/view/dashboard/dashboardReducer.d.ts +2 -2
  295. package/lib/view/dashboard/dashboardReducer.js +11 -1
  296. package/lib/view/expenseAutomationView/epics/common/fetchAllExpenseAutomationTabsEpic.js +3 -3
  297. package/lib/view/expenseAutomationView/epics/common/refreshExpenseAutomationCurrentTabEpic.js +3 -4
  298. package/lib/view/expenseAutomationView/epics/missingReceipts/searchTransactionsForManualMatchEpic.d.ts +6 -0
  299. package/lib/view/expenseAutomationView/epics/missingReceipts/searchTransactionsForManualMatchEpic.js +14 -10
  300. package/lib/view/expenseAutomationView/epics/transactionCategorization/backgroundRefetchReviewTabEpic.js +3 -16
  301. package/lib/view/expenseAutomationView/epics/transactionCategorization/fetchTransactionCategorizationEpic.js +9 -16
  302. package/lib/view/expenseAutomationView/epics/transactionCategorization/fetchTransactionCategorizationViewEpic.js +2 -2
  303. package/lib/view/expenseAutomationView/epics/transactionCategorization/markTransactionAsNotMiscategorizedEpic.js +2 -13
  304. package/lib/view/expenseAutomationView/epics/transactionCategorization/saveTransactionCategorizationEpic.js +2 -6
  305. package/lib/view/expenseAutomationView/epics/transactionCategorization/triggerReviewTabRefetchEpic.js +2 -2
  306. package/lib/view/expenseAutomationView/epics/transactionCategorization/updateTransactionCategorizationEpic.js +2 -6
  307. package/lib/view/expenseAutomationView/expenseAutomationViewReducer.d.ts +2 -6
  308. package/lib/view/expenseAutomationView/expenseAutomationViewReducer.js +3 -20
  309. package/lib/view/expenseAutomationView/helpers/transactionCategorizationLocalDataHelper.d.ts +1 -1
  310. package/lib/view/expenseAutomationView/payload/transactionCategorizationPayload.d.ts +20 -9
  311. package/lib/view/expenseAutomationView/reducers/transactionsViewReducer.d.ts +11 -18
  312. package/lib/view/expenseAutomationView/reducers/transactionsViewReducer.js +22 -50
  313. package/lib/view/expenseAutomationView/selectorTypes/transactionsViewSelectorTypes.d.ts +8 -6
  314. package/lib/view/expenseAutomationView/selectors/transactionCategorizationSelector.d.ts +2 -1
  315. package/lib/view/expenseAutomationView/selectors/transactionCategorizationSelector.js +16 -8
  316. package/lib/view/expenseAutomationView/transactionFilterHelpers.js +106 -18
  317. package/lib/view/expenseAutomationView/types/reconciliationViewState.d.ts +1 -1
  318. package/lib/view/expenseAutomationView/types/transactionsViewState.d.ts +2 -3
  319. package/lib/view/fileView/epic/deleteFileEpic.js +1 -1
  320. package/lib/view/fileView/epic/deleteFileListEpic.js +1 -1
  321. package/lib/view/fileView/epic/updateFileNameEpic.js +1 -1
  322. package/lib/view/financeStatement/financeStatementReducer.d.ts +1 -1
  323. package/lib/view/globalMerchantView/globalMerchantViewReducer.d.ts +2 -2
  324. package/lib/view/onboardingView/customerView/epic/aiAgentsActivation/fetchAiAgentsActivationStatusEpic.d.ts +7 -0
  325. package/lib/view/onboardingView/customerView/epic/aiAgentsActivation/fetchAiAgentsActivationStatusEpic.js +44 -0
  326. package/lib/view/onboardingView/customerView/epic/customerDetails/acknowledgeOnboardingAiActivationViewedEpic.d.ts +8 -0
  327. package/lib/view/onboardingView/customerView/epic/customerDetails/acknowledgeOnboardingAiActivationViewedEpic.js +33 -0
  328. package/lib/view/onboardingView/customerView/epic/customerDetails/acknowledgeOnboardingAiFinanceTeamEpic.d.ts +9 -0
  329. package/lib/view/onboardingView/customerView/epic/customerDetails/acknowledgeOnboardingAiFinanceTeamEpic.js +44 -0
  330. package/lib/view/onboardingView/customerView/onboardingCustomerViewPayload.d.ts +3 -0
  331. package/lib/view/onboardingView/customerView/onboardingCustomerViewReducer.d.ts +41 -4
  332. package/lib/view/onboardingView/customerView/onboardingCustomerViewReducer.js +220 -51
  333. package/lib/view/onboardingView/customerView/onboardingCustomerViewSelector.d.ts +5 -1
  334. package/lib/view/onboardingView/customerView/onboardingCustomerViewSelector.js +15 -2
  335. package/lib/view/onboardingView/customerView/onboardingCustomerViewState.d.ts +40 -0
  336. package/lib/view/onboardingView/customerView/onboardingCustomerViewState.js +13 -1
  337. package/lib/view/people/peopleTypes.d.ts +1 -1
  338. package/lib/view/reimbursementCard/reimbursementCardSelector.d.ts +1 -1
  339. package/lib/view/reportsResync/reportsResyncReducer.d.ts +2 -2
  340. package/lib/view/scheduleView/scheduleListView/scheduleListTypes.d.ts +1 -1
  341. package/lib/view/spendManagement/autotransferRules/autoTransferRulesSelector.d.ts +8 -1
  342. package/lib/view/spendManagement/autotransferRules/autoTransferRulesSelector.js +21 -1
  343. package/lib/view/spendManagement/autotransferRules/autoTransferRulesState.d.ts +22 -0
  344. package/lib/view/spendManagement/billPay/billPayReview/billPayReviewSelector.d.ts +7 -0
  345. package/lib/view/spendManagement/billPay/billPayReview/billPayReviewSelector.js +14 -0
  346. package/lib/view/spendManagement/billPay/billPaySetupApproverView/billPaySetupApproverViewReducer.d.ts +14 -3
  347. package/lib/view/spendManagement/billPay/billPaySetupApproverView/billPaySetupApproverViewReducer.js +110 -13
  348. package/lib/view/spendManagement/billPay/billPaySetupApproverView/billPaySetupApproverViewState.d.ts +16 -0
  349. package/lib/view/spendManagement/billPay/billPaySetupApproverView/epic/deleteBillPayApprovalRuleEpic.js +10 -2
  350. package/lib/view/spendManagement/billPay/billPaySetupApproverView/epic/fetchBillPaySetupApproverViewEpic.js +8 -4
  351. package/lib/view/spendManagement/billPay/billPaySetupApproverView/epic/initializeBillPaySetupApproverViewUpdateDataEpic.js +10 -6
  352. package/lib/view/spendManagement/billPay/billPaySetupApproverView/epic/reorderBillPayApprovalRulesEpic.d.ts +23 -0
  353. package/lib/view/spendManagement/billPay/billPaySetupApproverView/epic/reorderBillPayApprovalRulesEpic.js +58 -0
  354. package/lib/view/spendManagement/billPay/billPaySetupApproverView/epic/saveBillPaySetupApproverViewUpdatesEpic.js +12 -3
  355. package/lib/view/spendManagement/billPay/billPaySetupApproverView/types/commonPayload.d.ts +59 -1
  356. package/lib/view/spendManagement/billPay/billPaySetupApproverView/types/commonPayload.js +142 -17
  357. package/lib/view/spendManagement/billPay/billPaySetupApproverView/types/commonState.d.ts +31 -5
  358. package/lib/view/spendManagement/billPay/editBillView/editBillViewSelector.d.ts +8 -1
  359. package/lib/view/spendManagement/billPay/editBillView/editBillViewSelector.js +60 -4
  360. package/lib/view/spendManagement/billPay/editBillView/epics/fetchEditBillDetailPageEpic.js +8 -2
  361. package/lib/view/spendManagement/cashManagement/autoSweepFlow/autoSweepFlowPayload.d.ts +47 -0
  362. package/lib/view/spendManagement/cashManagement/autoSweepFlow/autoSweepFlowPayload.js +34 -0
  363. package/lib/view/spendManagement/cashManagement/autoSweepFlow/autoSweepFlowReducer.d.ts +23 -0
  364. package/lib/view/spendManagement/cashManagement/autoSweepFlow/autoSweepFlowReducer.js +82 -0
  365. package/lib/view/spendManagement/cashManagement/autoSweepFlow/autoSweepFlowSelector.d.ts +40 -0
  366. package/lib/view/spendManagement/cashManagement/autoSweepFlow/autoSweepFlowSelector.js +51 -0
  367. package/lib/view/spendManagement/cashManagement/autoSweepFlow/autoSweepFlowState.d.ts +37 -0
  368. package/lib/view/spendManagement/cashManagement/autoSweepFlow/autoSweepFlowState.js +53 -0
  369. package/lib/view/spendManagement/cashManagement/autoSweepFlow/epics/fetchCashManagementSettingsEpic.d.ts +14 -0
  370. package/lib/view/spendManagement/cashManagement/autoSweepFlow/epics/fetchCashManagementSettingsEpic.js +36 -0
  371. package/lib/view/spendManagement/cashManagement/autoSweepFlow/epics/saveAutoSweepSettingsEpic.d.ts +7 -0
  372. package/lib/view/spendManagement/cashManagement/autoSweepFlow/epics/saveAutoSweepSettingsEpic.js +36 -0
  373. package/lib/view/spendManagement/cashManagement/cashManagementOverview/cashManagementOverviewPayload.d.ts +56 -0
  374. package/lib/view/spendManagement/cashManagement/cashManagementOverview/cashManagementOverviewPayload.js +60 -0
  375. package/lib/view/spendManagement/cashManagement/cashManagementOverview/cashManagementOverviewReducer.d.ts +22 -0
  376. package/lib/view/spendManagement/cashManagement/cashManagementOverview/cashManagementOverviewReducer.js +96 -0
  377. package/lib/view/spendManagement/cashManagement/cashManagementOverview/cashManagementOverviewSelector.d.ts +59 -0
  378. package/lib/view/spendManagement/cashManagement/cashManagementOverview/cashManagementOverviewSelector.js +229 -0
  379. package/lib/view/spendManagement/cashManagement/cashManagementOverview/cashManagementOverviewState.d.ts +122 -0
  380. package/lib/view/spendManagement/cashManagement/cashManagementOverview/cashManagementOverviewState.js +13 -0
  381. package/lib/view/spendManagement/cashManagement/cashManagementOverview/epics/fetchCashManagementBannerEpic.d.ts +7 -0
  382. package/lib/view/spendManagement/cashManagement/cashManagementOverview/epics/fetchCashManagementBannerEpic.js +27 -0
  383. package/lib/view/spendManagement/cashManagement/cashManagementOverview/epics/fetchCashManagementOverviewPageEpic.d.ts +9 -0
  384. package/lib/view/spendManagement/cashManagement/cashManagementOverview/epics/fetchCashManagementOverviewPageEpic.js +40 -0
  385. package/lib/view/spendManagement/cashManagement/cashManagementOverview/epics/fetchCashManagementRecommendationEpic.d.ts +7 -0
  386. package/lib/view/spendManagement/cashManagement/cashManagementOverview/epics/fetchCashManagementRecommendationEpic.js +31 -0
  387. package/lib/view/spendManagement/cashManagement/cashManagementOverview/epics/fetchRecentTransferEpic.d.ts +15 -0
  388. package/lib/view/spendManagement/cashManagement/cashManagementOverview/epics/fetchRecentTransferEpic.js +32 -0
  389. package/lib/view/spendManagement/chargeCards/cardPolicy/cardPolicyDetail/cardPolicyDetailReducer.d.ts +14 -0
  390. package/lib/view/spendManagement/chargeCards/cardPolicy/cardPolicyDetail/cardPolicyDetailReducer.js +56 -0
  391. package/lib/view/spendManagement/chargeCards/cardPolicy/cardPolicyDetail/cardPolicyDetailSelector.d.ts +15 -0
  392. package/lib/view/spendManagement/chargeCards/cardPolicy/cardPolicyDetail/cardPolicyDetailSelector.js +28 -0
  393. package/lib/view/spendManagement/chargeCards/cardPolicy/cardPolicyDetail/cardPolicyDetailState.d.ts +8 -0
  394. package/lib/view/spendManagement/chargeCards/cardPolicy/cardPolicyDetail/cardPolicyDetailState.js +2 -0
  395. package/lib/view/spendManagement/chargeCards/cardPolicy/cardPolicyDetail/fetchCardPolicyDetailEpic.d.ts +8 -0
  396. package/lib/view/spendManagement/chargeCards/cardPolicy/cardPolicyDetail/fetchCardPolicyDetailEpic.js +40 -0
  397. package/lib/view/spendManagement/chargeCards/cardPolicy/cardPolicyDetail/updateCardPolicyEpic.d.ts +8 -0
  398. package/lib/view/spendManagement/chargeCards/cardPolicy/cardPolicyDetail/updateCardPolicyEpic.js +43 -0
  399. package/lib/view/spendManagement/chargeCards/cardPolicy/cardPolicyList/archiveCardPolicyEpic.d.ts +8 -0
  400. package/lib/view/spendManagement/chargeCards/cardPolicy/cardPolicyList/archiveCardPolicyEpic.js +38 -0
  401. package/lib/view/spendManagement/chargeCards/cardPolicy/cardPolicyList/cardPolicyListReducer.d.ts +15 -0
  402. package/lib/view/spendManagement/chargeCards/cardPolicy/cardPolicyList/cardPolicyListReducer.js +75 -0
  403. package/lib/view/spendManagement/chargeCards/cardPolicy/cardPolicyList/cardPolicyListSelector.d.ts +15 -0
  404. package/lib/view/spendManagement/chargeCards/cardPolicy/cardPolicyList/cardPolicyListSelector.js +27 -0
  405. package/lib/view/spendManagement/chargeCards/cardPolicy/cardPolicyList/cardPolicyListState.d.ts +7 -0
  406. package/lib/view/spendManagement/chargeCards/cardPolicy/cardPolicyList/cardPolicyListState.js +2 -0
  407. package/lib/view/spendManagement/chargeCards/cardPolicy/cardPolicyList/fetchCardPolicyListEpic.d.ts +8 -0
  408. package/lib/view/spendManagement/chargeCards/cardPolicy/cardPolicyList/fetchCardPolicyListEpic.js +42 -0
  409. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/applyAiCardPolicyFormDraftUpdate.d.ts +8 -0
  410. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/applyAiCardPolicyFormDraftUpdate.js +294 -0
  411. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/applyExtractedPolicyToAiCardPolicyDraft.d.ts +8 -0
  412. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/applyExtractedPolicyToAiCardPolicyDraft.js +113 -0
  413. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/applyExtractedPolicyToDraftEpic.d.ts +9 -0
  414. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/applyExtractedPolicyToDraftEpic.js +48 -0
  415. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/applyExtractedPolicyToManualCardPolicyDraft.d.ts +8 -0
  416. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/applyExtractedPolicyToManualCardPolicyDraft.js +115 -0
  417. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/applyUploadPlanToAiCardPolicyDraft.d.ts +13 -0
  418. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/applyUploadPlanToAiCardPolicyDraft.js +29 -0
  419. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/buildAiCardPolicyFormDraftSeed.d.ts +14 -0
  420. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/buildAiCardPolicyFormDraftSeed.js +369 -0
  421. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/buildManualCardPolicyFormDraftSeed.d.ts +6 -0
  422. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/buildManualCardPolicyFormDraftSeed.js +40 -0
  423. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/cardPolicyChipIds.d.ts +7 -0
  424. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/cardPolicyChipIds.js +26 -0
  425. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/cardPolicyFormDraftTypes.d.ts +116 -0
  426. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/cardPolicyFormDraftTypes.js +10 -0
  427. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/cardPolicyRequestParts.d.ts +33 -0
  428. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/cardPolicyRequestParts.js +126 -0
  429. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/createCardPolicyReducer.d.ts +52 -0
  430. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/createCardPolicyReducer.js +158 -0
  431. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/createCardPolicySelector.d.ts +11 -0
  432. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/createCardPolicySelector.js +31 -0
  433. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/createCardPolicyState.d.ts +12 -0
  434. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/createCardPolicyState.js +2 -0
  435. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/createCardPolicyTemplateEpic.d.ts +9 -0
  436. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/createCardPolicyTemplateEpic.js +53 -0
  437. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/deriveAiPolicyReviewRowsFromInputs.d.ts +10 -0
  438. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/deriveAiPolicyReviewRowsFromInputs.js +144 -0
  439. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/fetchCardPolicyMccCategoriesEpic.d.ts +7 -0
  440. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/fetchCardPolicyMccCategoriesEpic.js +24 -0
  441. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/seedAiCardPolicyFormDraftEpic.d.ts +11 -0
  442. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/seedAiCardPolicyFormDraftEpic.js +104 -0
  443. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/toBulkCardPolicyTemplateRequestsFromDraft.d.ts +22 -0
  444. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/toBulkCardPolicyTemplateRequestsFromDraft.js +100 -0
  445. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/toCardPolicyTemplateRequestFromDraft.d.ts +8 -0
  446. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/toCardPolicyTemplateRequestFromDraft.js +63 -0
  447. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/toManualCardPolicyTemplateRequestFromDraft.d.ts +3 -0
  448. package/lib/view/spendManagement/chargeCards/cardPolicy/createCardPolicy/toManualCardPolicyTemplateRequestFromDraft.js +28 -0
  449. package/lib/view/spendManagement/chargeCards/chargeCardList/chargeCardList.d.ts +1 -1
  450. package/lib/view/spendManagement/chargeCards/chargeCardList/chargeCardListSelector.d.ts +14 -0
  451. package/lib/view/spendManagement/chargeCards/chargeCardList/chargeCardListSelector.js +27 -1
  452. package/lib/view/spendManagement/chargeCards/issueChargeCard/aiCardCreationFormDraftTypes.d.ts +34 -0
  453. package/lib/view/spendManagement/chargeCards/issueChargeCard/aiCardCreationFormDraftTypes.js +2 -0
  454. package/lib/view/spendManagement/chargeCards/issueChargeCard/applyAiCardCreationFormDraftUpdate.d.ts +7 -0
  455. package/lib/view/spendManagement/chargeCards/issueChargeCard/applyAiCardCreationFormDraftUpdate.js +38 -0
  456. package/lib/view/spendManagement/chargeCards/issueChargeCard/buildAiCardCreationFormDraftSeed.d.ts +12 -0
  457. package/lib/view/spendManagement/chargeCards/issueChargeCard/buildAiCardCreationFormDraftSeed.js +61 -0
  458. package/lib/view/spendManagement/chargeCards/issueChargeCard/deriveAiCardRowsFromTeams.d.ts +9 -0
  459. package/lib/view/spendManagement/chargeCards/issueChargeCard/deriveAiCardRowsFromTeams.js +39 -0
  460. package/lib/view/spendManagement/chargeCards/issueChargeCard/issueChargeCardEpic.d.ts +2 -2
  461. package/lib/view/spendManagement/chargeCards/issueChargeCard/issueChargeCardEpic.js +1 -1
  462. package/lib/view/spendManagement/chargeCards/issueChargeCard/issueChargeCardReducer.d.ts +12 -2
  463. package/lib/view/spendManagement/chargeCards/issueChargeCard/issueChargeCardReducer.js +43 -5
  464. package/lib/view/spendManagement/chargeCards/issueChargeCard/issueChargeCardSelector.d.ts +7 -0
  465. package/lib/view/spendManagement/chargeCards/issueChargeCard/issueChargeCardSelector.js +42 -1
  466. package/lib/view/spendManagement/chargeCards/issueChargeCard/issueChargeCardState.d.ts +5 -0
  467. package/lib/view/spendManagement/chargeCards/issueChargeCard/seedAiCardCreationFormDraftEpic.d.ts +11 -0
  468. package/lib/view/spendManagement/chargeCards/issueChargeCard/seedAiCardCreationFormDraftEpic.js +66 -0
  469. package/lib/view/spendManagement/chargeCards/issueChargeCard/toIssueChargeCardLocalDataFromDraft.d.ts +3 -0
  470. package/lib/view/spendManagement/chargeCards/issueChargeCard/toIssueChargeCardLocalDataFromDraft.js +48 -0
  471. package/lib/view/spendManagement/commonSetup/epic/setup/parseUploadedKybDocumentEpic.d.ts +28 -0
  472. package/lib/view/spendManagement/commonSetup/epic/setup/parseUploadedKybDocumentEpic.js +62 -0
  473. package/lib/view/spendManagement/commonSetup/epic/setup/parseUploadedKycDocumentEpic.d.ts +9 -0
  474. package/lib/view/spendManagement/commonSetup/epic/setup/parseUploadedKycDocumentEpic.js +81 -0
  475. package/lib/view/spendManagement/commonSetup/kycKybAutofillActions.d.ts +24 -0
  476. package/lib/view/spendManagement/commonSetup/kycKybAutofillActions.js +17 -0
  477. package/lib/view/spendManagement/commonSetup/kycKybParseMapper.d.ts +29 -0
  478. package/lib/view/spendManagement/commonSetup/kycKybParseMapper.js +215 -0
  479. package/lib/view/spendManagement/commonSetup/setupViewReducer.d.ts +28 -2
  480. package/lib/view/spendManagement/commonSetup/setupViewReducer.js +107 -53
  481. package/lib/view/spendManagement/commonSetup/setupViewSelector.d.ts +7 -2
  482. package/lib/view/spendManagement/commonSetup/setupViewSelector.js +6 -1
  483. package/lib/view/spendManagement/commonSetup/setupViewState.d.ts +19 -0
  484. package/lib/view/spendManagement/commonSetup/types/kycKybAutofill.d.ts +154 -0
  485. package/lib/view/spendManagement/commonSetup/types/kycKybAutofill.js +46 -0
  486. package/lib/view/spendManagement/reimbursement/editRemiView/epics/fetchEditRemiDetailPageEpic.js +5 -1
  487. package/lib/view/spendManagement/reimbursement/remiSetupApproverView/epic/deleteRemiApprovalRuleEpic.js +10 -2
  488. package/lib/view/spendManagement/reimbursement/remiSetupApproverView/epic/fetchRemiSetupApproverViewEpic.js +8 -2
  489. package/lib/view/spendManagement/reimbursement/remiSetupApproverView/epic/initializeRemiSetupApproverViewUpdateDataEpic.js +10 -6
  490. package/lib/view/spendManagement/reimbursement/remiSetupApproverView/epic/reorderRemiApprovalRulesEpic.d.ts +14 -0
  491. package/lib/view/spendManagement/reimbursement/remiSetupApproverView/epic/reorderRemiApprovalRulesEpic.js +65 -0
  492. package/lib/view/spendManagement/reimbursement/remiSetupApproverView/epic/saveRemiSetupApproverViewUpdatesEpic.js +12 -3
  493. package/lib/view/spendManagement/reimbursement/remiSetupApproverView/remiSetupApproverViewReducer.d.ts +14 -3
  494. package/lib/view/spendManagement/reimbursement/remiSetupApproverView/remiSetupApproverViewReducer.js +81 -12
  495. package/lib/view/spendManagement/reimbursement/remiSetupApproverView/remiSetupApproverViewState.d.ts +12 -0
  496. package/lib/view/spendManagement/treasury/treasurySetUp/epic/updateTreasuryPromoIntroClosedByOutsideClickEpic.d.ts +8 -0
  497. package/lib/view/spendManagement/treasury/treasurySetUp/epic/updateTreasuryPromoIntroClosedByOutsideClickEpic.js +22 -0
  498. package/lib/view/spendManagement/treasury/treasurySetUp/epic/updateTreasuryPromoRemindMeLaterClickedEpic.d.ts +8 -0
  499. package/lib/view/spendManagement/treasury/treasurySetUp/epic/updateTreasuryPromoRemindMeLaterClickedEpic.js +22 -0
  500. package/lib/view/spendManagement/treasury/treasurySetUp/epic/updateTreasuryVideoViewedEpic.js +1 -1
  501. package/lib/view/spendManagement/treasury/treasurySetUp/treasurySetupViewReducer.d.ts +1 -1
  502. package/lib/view/spendManagement/treasury/treasurySetUp/treasurySetupViewReducer.js +46 -2
  503. package/lib/view/spendManagement/treasury/treasurySetUp/treasurySetupViewState.d.ts +2 -0
  504. package/lib/view/taskManager/taskListView/taskList.d.ts +3 -3
  505. package/lib/view/taskManager/taskListView/taskListReducer.d.ts +1 -1
  506. package/lib/view/tasksCard/tasksCardSelector.d.ts +1 -1
  507. package/lib/view/topEx/topExSelector.d.ts +1 -1
  508. package/lib/view/transactionDetail/journalEntryLinesViewModel.d.ts +102 -0
  509. package/lib/view/transactionDetail/journalEntryLinesViewModel.js +160 -0
  510. package/lib/view/transactionDetail/transactionDetailPayload.d.ts +1 -1
  511. package/lib/view/transactionDetail/transactionDetailSelector.d.ts +6 -1
  512. package/lib/view/transactionDetail/transactionDetailSelector.js +6 -1
  513. package/lib/zeniAPI.d.ts +1 -0
  514. package/package.json +1 -1
@@ -0,0 +1,111 @@
1
+ import { buildMccCategoryChipId, buildVendorChipId } from './cardPolicyChipIds';
2
+ import { CARD_POLICY_LIMIT_ROW_ID_REQUIRE_RECEIPT, CARD_POLICY_LIMIT_ROW_ID_TRANSACTION, } from './cardPolicyFormDraftTypes';
3
+ // Mirrors the AI variant plus name overwrite from `extracted.policyName`;
4
+ // description / mode / cardSelections are preserved (extract API doesn't return them).
5
+ export const applyExtractedPolicyToManualCardPolicyDraft = ({ extracted, current, vendorSearchOptions, categorySearchOptions, }) => ({
6
+ ...current,
7
+ name: extracted.policyName ?? current.name,
8
+ description: current.description,
9
+ vendorPolicy: buildAllowBlockField({
10
+ allowList: extracted.allowedEntity.merchantNames,
11
+ blockList: extracted.blockedEntity.merchantNames,
12
+ currentAllowItems: current.vendorPolicy.allowItems,
13
+ currentBlockItems: current.vendorPolicy.blockItems,
14
+ universe: vendorSearchOptions,
15
+ matchOnCode: false,
16
+ }),
17
+ categoryPolicy: buildAllowBlockField({
18
+ allowList: extracted.allowedEntity.categoryCodes,
19
+ blockList: extracted.blockedEntity.categoryCodes,
20
+ currentAllowItems: current.categoryPolicy.allowItems,
21
+ currentBlockItems: current.categoryPolicy.blockItems,
22
+ universe: categorySearchOptions,
23
+ matchOnCode: true,
24
+ }),
25
+ limits: buildLimitRows({
26
+ current: current.limits,
27
+ transactionLimit: extracted.transactionLimit,
28
+ requiredReceiptThreshold: extracted.requiredReceiptThreshold,
29
+ }),
30
+ });
31
+ const buildAllowBlockField = ({ allowList, blockList, currentAllowItems, currentBlockItems, universe, matchOnCode, }) => {
32
+ const allowItems = buildSideItems({
33
+ selectedValues: allowList,
34
+ currentItems: currentAllowItems,
35
+ universe,
36
+ matchOnCode,
37
+ });
38
+ const blockItems = buildSideItems({
39
+ selectedValues: blockList,
40
+ currentItems: currentBlockItems,
41
+ universe,
42
+ matchOnCode,
43
+ });
44
+ const mode = allowList.length === 0 && blockList.length > 0 ? 'block' : 'allow';
45
+ return { mode, allowItems, blockItems };
46
+ };
47
+ const buildSideItems = ({ selectedValues, currentItems, universe, matchOnCode, }) => {
48
+ const selectedKeys = new Set(selectedValues
49
+ .map((value) => normalizeKey(value))
50
+ .filter((key) => key != null));
51
+ const items = [];
52
+ const seenIds = new Set();
53
+ for (const item of currentItems) {
54
+ const key = normalizeKey(matchOnCode ? item.optionalCode : item.label);
55
+ const isSelected = key != null && selectedKeys.has(key);
56
+ items.push({ ...item, isSelected });
57
+ seenIds.add(item.id);
58
+ if (isSelected && key != null) {
59
+ selectedKeys.delete(key);
60
+ }
61
+ }
62
+ for (const option of universe) {
63
+ if (selectedKeys.size === 0) {
64
+ break;
65
+ }
66
+ const key = normalizeKey(matchOnCode ? option.optionalCode : option.label);
67
+ if (key == null || !selectedKeys.has(key) || seenIds.has(option.id)) {
68
+ continue;
69
+ }
70
+ items.push({ ...option, isSelected: true });
71
+ seenIds.add(option.id);
72
+ selectedKeys.delete(key);
73
+ }
74
+ for (const value of selectedValues) {
75
+ const key = normalizeKey(value);
76
+ if (key == null || !selectedKeys.has(key)) {
77
+ continue;
78
+ }
79
+ const id = matchOnCode
80
+ ? buildMccCategoryChipId(value)
81
+ : buildVendorChipId(value);
82
+ if (seenIds.has(id)) {
83
+ continue;
84
+ }
85
+ items.push({
86
+ id,
87
+ label: value,
88
+ isSelected: true,
89
+ ...(matchOnCode ? { optionalCode: value } : {}),
90
+ });
91
+ seenIds.add(id);
92
+ selectedKeys.delete(key);
93
+ }
94
+ return items;
95
+ };
96
+ const buildLimitRows = ({ current, transactionLimit, requiredReceiptThreshold, }) => current.map((row) => {
97
+ if (row.id === CARD_POLICY_LIMIT_ROW_ID_TRANSACTION) {
98
+ return amountToLimitRow(row, transactionLimit);
99
+ }
100
+ if (row.id === CARD_POLICY_LIMIT_ROW_ID_REQUIRE_RECEIPT) {
101
+ return amountToLimitRow(row, requiredReceiptThreshold);
102
+ }
103
+ return row;
104
+ });
105
+ const amountToLimitRow = (row, amount) => {
106
+ if (amount > 0) {
107
+ return { ...row, isEnabled: true, amount };
108
+ }
109
+ return { ...row, isEnabled: false, amount: row.amount };
110
+ };
111
+ const normalizeKey = (value) => value == null || value.length === 0 ? undefined : value.toLowerCase().trim();
@@ -0,0 +1,25 @@
1
+ import { buildUploadReviewRows } from './buildAiCardPolicyFormDraftSeed';
2
+ // Re-derives Step 5 review from a fresh `wizardPlan` while preserving the
3
+ // user's Step 2 `cardSelections` and Step 1 `limits`. No-op outside upload mode.
4
+ export const applyUploadPlanToAiCardPolicyDraft = ({ current, context, wizardPlan, source, }) => {
5
+ if (current.policyKind !== 'upload') {
6
+ return { draft: current, context };
7
+ }
8
+ const policiesReview = buildUploadReviewRows(wizardPlan.step5Review.draftPolicies, context.cardsMasterList, context.categorySearchOptions);
9
+ return {
10
+ draft: {
11
+ ...current,
12
+ policiesReview,
13
+ },
14
+ context: {
15
+ ...context,
16
+ wizardPlan,
17
+ source: source ?? context.source,
18
+ suggestedPoliciesSeed: wizardPlan.step5Review.draftPolicies.map((draft) => ({
19
+ id: draft.id,
20
+ name: draft.name,
21
+ isChecked: true,
22
+ })),
23
+ },
24
+ };
25
+ };
@@ -0,0 +1,363 @@
1
+ import { buildVendorChipId, toMccCategoryChipFieldValue, toVendorChipFieldValue, } from './cardPolicyChipIds';
2
+ import { CARD_POLICY_LIMIT_ROW_ID_REQUIRE_RECEIPT, CARD_POLICY_LIMIT_ROW_ID_TRANSACTION, } from './cardPolicyFormDraftTypes';
3
+ const EMPTY_ALLOW_BLOCK = {
4
+ mode: 'allow',
5
+ allowItems: [],
6
+ blockItems: [],
7
+ };
8
+ const EMPTY_FORM_VALUES = {
9
+ vendorPolicy: EMPTY_ALLOW_BLOCK,
10
+ categoryPolicy: EMPTY_ALLOW_BLOCK,
11
+ cardSelections: [],
12
+ limits: [],
13
+ policiesReview: [],
14
+ };
15
+ export const buildEmptyLimitRows = () => [
16
+ { id: CARD_POLICY_LIMIT_ROW_ID_TRANSACTION, isEnabled: false },
17
+ { id: CARD_POLICY_LIMIT_ROW_ID_REQUIRE_RECEIPT, isEnabled: false },
18
+ ];
19
+ // Build the initial draft + seed context per `policyKind`:
20
+ // - auto: 1-step review with chip groups built eagerly from `draftPolicies`.
21
+ // - guided: 5-step wizard; Steps 1–4 from `draftPolicies[0]`, review re-derived.
22
+ // - upload: empty scaffold pre-recommendation; post-recommendation seeds review.
23
+ export const buildAiCardPolicyFormDraftSeed = ({ initialData, cardsMasterList = [], categorySearchOptions, suggestedAllowMerchants, suggestedBlockMerchants, suggestedAllowCategories, suggestedBlockCategories, }) => {
24
+ const suggestedPoliciesSeed = buildSuggestedPoliciesSeed(initialData);
25
+ const wizardPlan = 'wizardPlan' in initialData ? initialData.wizardPlan : undefined;
26
+ const source = initialData.policyKind === 'upload' ? initialData.source : undefined;
27
+ const context = {
28
+ policyKind: initialData.policyKind,
29
+ cardsMasterList,
30
+ categorySearchOptions: categorySearchOptions ?? [],
31
+ suggestedAllowMerchants,
32
+ suggestedBlockMerchants,
33
+ suggestedAllowCategories,
34
+ suggestedBlockCategories,
35
+ suggestedPoliciesSeed,
36
+ wizardPlan,
37
+ source,
38
+ };
39
+ const draft = buildDraftFromInitialData({
40
+ initialData,
41
+ cardsMasterList,
42
+ categorySearchOptions,
43
+ suggestedAllowMerchants,
44
+ suggestedBlockMerchants,
45
+ suggestedAllowCategories,
46
+ suggestedBlockCategories,
47
+ });
48
+ return { draft, context };
49
+ };
50
+ const buildDraftFromInitialData = ({ initialData, cardsMasterList, categorySearchOptions, suggestedAllowMerchants, suggestedBlockMerchants, suggestedAllowCategories, suggestedBlockCategories, }) => {
51
+ const vendorAllowSeed = merchantsToChips(suggestedAllowMerchants);
52
+ const vendorBlockSeed = merchantsToChips(suggestedBlockMerchants);
53
+ const categoryAllowSeed = categoriesToChips(suggestedAllowCategories);
54
+ const categoryBlockSeed = categoriesToChips(suggestedBlockCategories);
55
+ if (initialData.policyKind === 'auto') {
56
+ const autoDraftPolicies = initialData.wizardPlan?.step5Review?.draftPolicies ?? [];
57
+ return {
58
+ ...EMPTY_FORM_VALUES,
59
+ policyKind: 'auto',
60
+ policiesReview: buildAutoReviewRows(autoDraftPolicies, cardsMasterList, categorySearchOptions),
61
+ };
62
+ }
63
+ if (initialData.policyKind === 'upload') {
64
+ const uploadDraftPolicies = initialData.wizardPlan?.step5Review?.draftPolicies;
65
+ if (uploadDraftPolicies == null) {
66
+ return {
67
+ ...EMPTY_FORM_VALUES,
68
+ policyKind: 'upload',
69
+ cardSelections: cardsMasterList.map((row) => ({
70
+ ...row,
71
+ isChecked: false,
72
+ })),
73
+ limits: buildEmptyLimitRows(),
74
+ };
75
+ }
76
+ return {
77
+ ...EMPTY_FORM_VALUES,
78
+ policyKind: 'upload',
79
+ cardSelections: cardsMasterList.map((row) => ({
80
+ ...row,
81
+ isChecked: false,
82
+ })),
83
+ limits: buildEmptyLimitRows(),
84
+ policiesReview: buildUploadReviewRows(uploadDraftPolicies, cardsMasterList, categorySearchOptions),
85
+ };
86
+ }
87
+ // Guided
88
+ const draftPolicies = initialData.wizardPlan?.step5Review?.draftPolicies ?? [];
89
+ const primary = draftPolicies[0];
90
+ if (primary == null) {
91
+ return {
92
+ policyKind: 'guided',
93
+ vendorPolicy: buildAllowBlockFromSeeds(vendorAllowSeed, vendorBlockSeed),
94
+ categoryPolicy: buildAllowBlockFromSeeds(categoryAllowSeed, categoryBlockSeed),
95
+ cardSelections: cardsMasterList.map((row) => ({
96
+ ...row,
97
+ isChecked: false,
98
+ })),
99
+ limits: buildEmptyLimitRows(),
100
+ policiesReview: [],
101
+ };
102
+ }
103
+ const mccCodeToCategory = buildMccCodeToCategoryMap(categorySearchOptions);
104
+ const vendorMode = inferAllowBlockMode(primary.allowedEntity.merchantNames.length, primary.blockedEntity.merchantNames.length);
105
+ const aiVendorAllow = draftMerchantsToChips(primary.allowedEntity.merchantNames);
106
+ const aiVendorBlock = draftMerchantsToChips(primary.blockedEntity.merchantNames);
107
+ const vendorPolicy = {
108
+ mode: vendorMode,
109
+ allowItems: mergeAiAndSeedChips(aiVendorAllow, vendorAllowSeed),
110
+ blockItems: mergeAiAndSeedChips(aiVendorBlock, vendorBlockSeed),
111
+ };
112
+ const categoryMode = inferAllowBlockMode(primary.allowedEntity.categoryCodes.length, primary.blockedEntity.categoryCodes.length);
113
+ const aiCategoryAllow = draftCategoryCodesToChips(primary.allowedEntity.categoryCodes, mccCodeToCategory);
114
+ const aiCategoryBlock = draftCategoryCodesToChips(primary.blockedEntity.categoryCodes, mccCodeToCategory);
115
+ const categoryPolicy = {
116
+ mode: categoryMode,
117
+ allowItems: mergeAiAndSeedChips(aiCategoryAllow, categoryAllowSeed),
118
+ blockItems: mergeAiAndSeedChips(aiCategoryBlock, categoryBlockSeed),
119
+ };
120
+ const cardSelections = cardsMasterList.map((row) => ({
121
+ ...row,
122
+ isChecked: primary.applyToCards.includes(row.id),
123
+ }));
124
+ const limits = [
125
+ {
126
+ id: CARD_POLICY_LIMIT_ROW_ID_TRANSACTION,
127
+ isEnabled: primary.spendLimits.transaction > 0,
128
+ amount: primary.spendLimits.transaction > 0
129
+ ? primary.spendLimits.transaction
130
+ : undefined,
131
+ },
132
+ {
133
+ id: CARD_POLICY_LIMIT_ROW_ID_REQUIRE_RECEIPT,
134
+ isEnabled: primary.requiredReceiptThreshold > 0,
135
+ amount: primary.requiredReceiptThreshold > 0
136
+ ? primary.requiredReceiptThreshold
137
+ : undefined,
138
+ },
139
+ ];
140
+ return {
141
+ policyKind: 'guided',
142
+ vendorPolicy,
143
+ categoryPolicy,
144
+ cardSelections,
145
+ limits,
146
+ policiesReview: draftPolicies.map((p) => ({
147
+ id: p.id,
148
+ isChecked: true,
149
+ name: p.name,
150
+ chipGroups: [],
151
+ })),
152
+ };
153
+ };
154
+ const buildSuggestedPoliciesSeed = (initialData) => (initialData.wizardPlan?.step5Review?.draftPolicies ?? []).map((draft) => ({
155
+ id: draft.id,
156
+ name: draft.name,
157
+ isChecked: true,
158
+ }));
159
+ const merchantsToChips = (names) => (names ?? []).map((name) => toVendorChipFieldValue(name, false));
160
+ const categoriesToChips = (categories) => (categories ?? []).map((category) => toMccCategoryChipFieldValue(category, false));
161
+ const buildAllowBlockFromSeeds = (allowItems, blockItems) => {
162
+ if (allowItems.length === 0 && blockItems.length === 0) {
163
+ return EMPTY_ALLOW_BLOCK;
164
+ }
165
+ return { mode: 'allow', allowItems, blockItems };
166
+ };
167
+ const buildMccCodeToCategoryMap = (categories) => {
168
+ const map = new Map();
169
+ for (const category of categories ?? []) {
170
+ for (const code of category.mccCodes) {
171
+ if (!map.has(code)) {
172
+ map.set(code, category);
173
+ }
174
+ }
175
+ }
176
+ return map;
177
+ };
178
+ const buildOwnerSummaries = (cardIds, cardsMasterList) => {
179
+ const cardsById = new Map(cardsMasterList.map((card) => [card.id, card]));
180
+ const summaries = new Map();
181
+ for (const cardId of cardIds) {
182
+ const card = cardsById.get(cardId);
183
+ if (card == null) {
184
+ continue;
185
+ }
186
+ const existing = summaries.get(card.owner.userId);
187
+ if (existing != null) {
188
+ existing.cardIds.push(cardId);
189
+ continue;
190
+ }
191
+ summaries.set(card.owner.userId, {
192
+ userId: card.owner.userId,
193
+ displayName: card.owner.displayName,
194
+ cardIds: [cardId],
195
+ });
196
+ }
197
+ return Array.from(summaries.values());
198
+ };
199
+ const buildAutoReviewChipGroupsForDraft = (draft, cardsMasterList, mccCodeToCategory) => {
200
+ const groups = [];
201
+ if (draft.allowedEntity.merchantNames.length > 0) {
202
+ groups.push({
203
+ id: 'allowed-vendors',
204
+ label: 'Allowed Vendors',
205
+ chips: draft.allowedEntity.merchantNames.map((name) => ({
206
+ id: buildVendorChipId(name),
207
+ label: name,
208
+ chipKind: 'positive',
209
+ isSelected: true,
210
+ })),
211
+ });
212
+ }
213
+ if (draft.blockedEntity.merchantNames.length > 0) {
214
+ groups.push({
215
+ id: 'blocked-vendors',
216
+ label: 'Blocked Vendors',
217
+ chips: draft.blockedEntity.merchantNames.map((name) => ({
218
+ id: buildVendorChipId(name),
219
+ label: name,
220
+ chipKind: 'negative',
221
+ isSelected: true,
222
+ })),
223
+ });
224
+ }
225
+ if (draft.allowedEntity.categoryCodes.length > 0) {
226
+ groups.push({
227
+ id: 'allowed-categories',
228
+ label: 'Allowed Categories',
229
+ chips: draft.allowedEntity.categoryCodes.map((code) => {
230
+ const category = mccCodeToCategory.get(code);
231
+ const label = category != null ? `${category.name} (${code})` : code;
232
+ return {
233
+ id: code,
234
+ label,
235
+ chipKind: 'positive',
236
+ isSelected: true,
237
+ optionalCode: code,
238
+ };
239
+ }),
240
+ });
241
+ }
242
+ if (draft.blockedEntity.categoryCodes.length > 0) {
243
+ groups.push({
244
+ id: 'restricted-categories',
245
+ label: 'Restricted Categories',
246
+ chips: draft.blockedEntity.categoryCodes.map((code) => {
247
+ const category = mccCodeToCategory.get(code);
248
+ const label = category != null ? `${category.name} (${code})` : code;
249
+ return {
250
+ id: code,
251
+ label,
252
+ chipKind: 'negative',
253
+ isSelected: true,
254
+ optionalCode: code,
255
+ };
256
+ }),
257
+ });
258
+ }
259
+ if (draft.applyToCards.length > 0) {
260
+ const owners = buildOwnerSummaries(draft.applyToCards, cardsMasterList);
261
+ if (owners.length > 0) {
262
+ groups.push({
263
+ id: 'applied-to-cards',
264
+ label: 'Applied to Cards',
265
+ chips: owners.map((owner) => ({
266
+ id: owner.userId,
267
+ label: owner.displayName,
268
+ chipKind: 'avatar',
269
+ cardIds: owner.cardIds,
270
+ isSelected: true,
271
+ })),
272
+ });
273
+ }
274
+ }
275
+ return groups;
276
+ };
277
+ const buildAutoReviewRows = (draftPolicies, cardsMasterList, categorySearchOptions) => {
278
+ const mccCodeToCategory = buildMccCodeToCategoryMap(categorySearchOptions);
279
+ return draftPolicies.map((draft) => ({
280
+ id: draft.id,
281
+ isChecked: true,
282
+ name: draft.name,
283
+ chipGroups: buildAutoReviewChipGroupsForDraft(draft, cardsMasterList, mccCodeToCategory),
284
+ }));
285
+ };
286
+ // Numeric value stashed on `optionalCode` so the bulk-submit builder can
287
+ // recover it without re-parsing the label.
288
+ const buildUploadLimitsChipGroup = (draft) => {
289
+ const transactionEnabled = draft.spendLimits.transaction > 0;
290
+ const receiptEnabled = draft.requiredReceiptThreshold > 0;
291
+ return {
292
+ id: 'limits',
293
+ label: 'Limits',
294
+ kind: 'limits',
295
+ chips: [
296
+ {
297
+ id: 'limit-transaction',
298
+ label: 'Transaction Limit',
299
+ helperText: 'Maximum amount per single transaction',
300
+ placeholder: '$0',
301
+ chipKind: 'positive',
302
+ isSelected: transactionEnabled,
303
+ optionalCode: transactionEnabled
304
+ ? String(draft.spendLimits.transaction)
305
+ : undefined,
306
+ },
307
+ {
308
+ id: 'limit-receipt',
309
+ label: 'Require Receipt',
310
+ helperText: 'Require a receipt above this amount',
311
+ placeholder: '$0',
312
+ chipKind: 'positive',
313
+ isSelected: receiptEnabled,
314
+ optionalCode: receiptEnabled
315
+ ? String(draft.requiredReceiptThreshold)
316
+ : undefined,
317
+ },
318
+ ],
319
+ };
320
+ };
321
+ export const buildUploadReviewRows = (draftPolicies, cardsMasterList, categorySearchOptions) => {
322
+ const mccCodeToCategory = buildMccCodeToCategoryMap(categorySearchOptions);
323
+ return draftPolicies.map((draft) => {
324
+ const chipGroups = buildAutoReviewChipGroupsForDraft(draft, cardsMasterList, mccCodeToCategory);
325
+ chipGroups.push(buildUploadLimitsChipGroup(draft));
326
+ return {
327
+ id: draft.id,
328
+ isChecked: true,
329
+ name: draft.name,
330
+ chipGroups,
331
+ };
332
+ });
333
+ };
334
+ // BE doesn't pre-select the radio: allow-wins when either side is populated,
335
+ // otherwise default to allow. Matches `applyExtractedPolicyTo*FormValues`.
336
+ const inferAllowBlockMode = (allowCount, blockCount) => {
337
+ if (allowCount > 0) {
338
+ return 'allow';
339
+ }
340
+ if (blockCount > 0) {
341
+ return 'block';
342
+ }
343
+ return 'allow';
344
+ };
345
+ const draftMerchantsToChips = (names) => names.map((name) => toVendorChipFieldValue(name, true));
346
+ const draftCategoryCodesToChips = (codes, mccCodeToCategory) => codes.map((code) => {
347
+ const category = mccCodeToCategory.get(code);
348
+ if (category != null) {
349
+ return toMccCategoryChipFieldValue(category, true);
350
+ }
351
+ return {
352
+ id: code,
353
+ label: code,
354
+ isSelected: true,
355
+ optionalCode: code,
356
+ optionalCodes: [code],
357
+ };
358
+ });
359
+ const mergeAiAndSeedChips = (aiChips, seedChips) => {
360
+ const seenIds = new Set(aiChips.map((chip) => chip.id));
361
+ const extraSeeds = seedChips.filter((chip) => !seenIds.has(chip.id));
362
+ return [...aiChips, ...extraSeeds];
363
+ };
@@ -0,0 +1,36 @@
1
+ import { buildEmptyLimitRows } from './buildAiCardPolicyFormDraftSeed';
2
+ import { toMccCategoryChipFieldValue, toVendorChipFieldValue, } from './cardPolicyChipIds';
3
+ import { CARD_POLICY_LIMIT_ROW_ID_REQUIRE_RECEIPT, } from './cardPolicyFormDraftTypes';
4
+ const EMPTY_ALLOW_BLOCK = {
5
+ mode: 'allow',
6
+ allowItems: [],
7
+ blockItems: [],
8
+ };
9
+ // Mirrors the AI guided seed minus the wizard plan: BE suggestions land
10
+ // `isSelected: false` so the user opts in explicitly.
11
+ export const buildManualCardPolicyFormDraftSeed = ({ cardsMasterList = [], defaultRequireReceiptAmount, suggestedAllowMerchants, suggestedBlockMerchants, suggestedAllowCategories, suggestedBlockCategories, }) => {
12
+ const vendorAllow = (suggestedAllowMerchants ?? []).map((name) => toVendorChipFieldValue(name, false));
13
+ const vendorBlock = (suggestedBlockMerchants ?? []).map((name) => toVendorChipFieldValue(name, false));
14
+ const categoryAllow = (suggestedAllowCategories ?? []).map((category) => toMccCategoryChipFieldValue(category, false));
15
+ const categoryBlock = (suggestedBlockCategories ?? []).map((category) => toMccCategoryChipFieldValue(category, false));
16
+ const vendorPolicy = vendorAllow.length === 0 && vendorBlock.length === 0
17
+ ? EMPTY_ALLOW_BLOCK
18
+ : { mode: 'allow', allowItems: vendorAllow, blockItems: vendorBlock };
19
+ const categoryPolicy = categoryAllow.length === 0 && categoryBlock.length === 0
20
+ ? EMPTY_ALLOW_BLOCK
21
+ : { mode: 'allow', allowItems: categoryAllow, blockItems: categoryBlock };
22
+ const limits = buildEmptyLimitRows().map((row) => row.id === CARD_POLICY_LIMIT_ROW_ID_REQUIRE_RECEIPT &&
23
+ defaultRequireReceiptAmount != null &&
24
+ defaultRequireReceiptAmount > 0
25
+ ? { ...row, amount: defaultRequireReceiptAmount }
26
+ : row);
27
+ return {
28
+ name: '',
29
+ description: '',
30
+ mode: 'strict',
31
+ vendorPolicy,
32
+ categoryPolicy,
33
+ cardSelections: cardsMasterList.map((row) => ({ ...row, isChecked: false })),
34
+ limits,
35
+ };
36
+ };
@@ -0,0 +1,19 @@
1
+ // All chip-id producers MUST funnel through here — the picker's dedupe is content-blind
2
+ // (`existing.id === option.id`), so vendors collapse on display name and MCC ids must
3
+ // match the legacy convention saved templates use.
4
+ export const VENDOR_CHIP_ID_PREFIX = 'vendor-';
5
+ export const MCC_CHIP_ID_PREFIX = 'mcc-';
6
+ export const buildVendorChipId = (name) => `${VENDOR_CHIP_ID_PREFIX}${name.trim().toLowerCase()}`;
7
+ export const buildMccCategoryChipId = (name) => `${MCC_CHIP_ID_PREFIX}${name}`;
8
+ export const toVendorChipFieldValue = (name, isSelected) => ({
9
+ id: buildVendorChipId(name),
10
+ label: name,
11
+ isSelected,
12
+ });
13
+ export const toMccCategoryChipFieldValue = (category, isSelected) => ({
14
+ id: buildMccCategoryChipId(category.name),
15
+ label: category.name,
16
+ isSelected,
17
+ optionalCode: category.mccCodes[0],
18
+ optionalCodes: [...category.mccCodes],
19
+ });
@@ -0,0 +1,6 @@
1
+ export const CARD_POLICY_LIMIT_ROW_ID_TRANSACTION = 'transactionLimit';
2
+ export const CARD_POLICY_LIMIT_ROW_ID_REQUIRE_RECEIPT = 'requireReceipt';
3
+ export const toMccCategoryLike = (category) => ({
4
+ name: category.name,
5
+ mccCodes: category.mccCodes,
6
+ });
@@ -0,0 +1,119 @@
1
+ // Wire builders shared by manual and AI CFO drafts.
2
+ // Inactive-side chips stay in form state for fast mode-flip but never go on the wire.
3
+ export const collectMerchantNames = (field, forMode) => {
4
+ if (field.mode !== forMode) {
5
+ return [];
6
+ }
7
+ const items = forMode === 'allow' ? field.allowItems : field.blockItems;
8
+ return items.filter((item) => item.isSelected).map((item) => item.label);
9
+ };
10
+ // `optionalCodes` (plural) emits every code; falls back to the singular
11
+ // `optionalCode`; chips with neither are dropped silently.
12
+ export const collectCategoryCodes = (field, forMode) => {
13
+ if (field.mode !== forMode) {
14
+ return [];
15
+ }
16
+ const items = forMode === 'allow' ? field.allowItems : field.blockItems;
17
+ return items
18
+ .filter((item) => item.isSelected)
19
+ .flatMap((item) => {
20
+ if (item.optionalCodes != null && item.optionalCodes.length > 0) {
21
+ return item.optionalCodes;
22
+ }
23
+ return item.optionalCode != null ? [item.optionalCode] : [];
24
+ });
25
+ };
26
+ // `null` when the toggle is off (BE: "no threshold"); else `amount` (or 0).
27
+ export const amountFromLimitRow = (limits, rowId) => {
28
+ const row = limits.find((entry) => entry.id === rowId);
29
+ if (row == null || !row.isEnabled) {
30
+ return null;
31
+ }
32
+ return row.amount ?? 0;
33
+ };
34
+ const REVIEW_GROUP_ID_ALLOWED_VENDORS = 'allowed-vendors';
35
+ const REVIEW_GROUP_ID_BLOCKED_VENDORS = 'blocked-vendors';
36
+ const REVIEW_GROUP_ID_ALLOWED_CATEGORIES = 'allowed-categories';
37
+ const REVIEW_GROUP_ID_RESTRICTED_CATEGORIES = 'restricted-categories';
38
+ const REVIEW_GROUP_ID_APPLIED_TO_CARDS = 'applied-to-cards';
39
+ const REVIEW_GROUP_ID_LIMITS = 'limits';
40
+ const REVIEW_LIMIT_CHIP_ID_TRANSACTION = 'limit-transaction';
41
+ const REVIEW_LIMIT_CHIP_ID_RECEIPT = 'limit-receipt';
42
+ const isChipOn = (chip) => chip.isSelected !== false;
43
+ const findGroup = (row, groupId) => row.chipGroups.find((group) => group.id === groupId);
44
+ const projectMerchantNamesFromGroup = (group) => group == null ? [] : group.chips.filter(isChipOn).map((chip) => chip.label);
45
+ const projectCategoryCodesFromGroup = (group) => {
46
+ if (group == null) {
47
+ return [];
48
+ }
49
+ const codes = [];
50
+ for (const chip of group.chips) {
51
+ if (!isChipOn(chip)) {
52
+ continue;
53
+ }
54
+ if (chip.optionalCode != null && chip.optionalCode.length > 0) {
55
+ codes.push(chip.optionalCode);
56
+ }
57
+ }
58
+ return codes;
59
+ };
60
+ const projectApplyToCardsFromGroup = (group) => {
61
+ if (group == null) {
62
+ return [];
63
+ }
64
+ const cardIds = [];
65
+ for (const chip of group.chips) {
66
+ if (!isChipOn(chip)) {
67
+ continue;
68
+ }
69
+ if (chip.cardIds != null && chip.cardIds.length > 0) {
70
+ cardIds.push(...chip.cardIds);
71
+ continue;
72
+ }
73
+ cardIds.push(chip.id);
74
+ }
75
+ return cardIds;
76
+ };
77
+ const amountFromLimitsChip = (chip) => {
78
+ if (chip == null || chip.isSelected !== true) {
79
+ return null;
80
+ }
81
+ if (chip.optionalCode == null || chip.optionalCode.length === 0) {
82
+ return 0;
83
+ }
84
+ const parsed = Number(chip.optionalCode);
85
+ return Number.isFinite(parsed) ? parsed : 0;
86
+ };
87
+ // Used when `policyKind === "auto"`, where the row's chip groups are canonical
88
+ // and source slices are empty.
89
+ export const projectAutoReviewRowToCardPolicyRequestParts = (row) => {
90
+ const limitsGroup = findGroup(row, REVIEW_GROUP_ID_LIMITS);
91
+ const transactionChip = limitsGroup?.chips.find((chip) => chip.id === REVIEW_LIMIT_CHIP_ID_TRANSACTION);
92
+ const receiptChip = limitsGroup?.chips.find((chip) => chip.id === REVIEW_LIMIT_CHIP_ID_RECEIPT);
93
+ return {
94
+ allowedEntity: {
95
+ merchantNames: projectMerchantNamesFromGroup(findGroup(row, REVIEW_GROUP_ID_ALLOWED_VENDORS)),
96
+ categoryCodes: projectCategoryCodesFromGroup(findGroup(row, REVIEW_GROUP_ID_ALLOWED_CATEGORIES)),
97
+ },
98
+ blockedEntity: {
99
+ merchantNames: projectMerchantNamesFromGroup(findGroup(row, REVIEW_GROUP_ID_BLOCKED_VENDORS)),
100
+ categoryCodes: projectCategoryCodesFromGroup(findGroup(row, REVIEW_GROUP_ID_RESTRICTED_CATEGORIES)),
101
+ },
102
+ applyToCards: projectApplyToCardsFromGroup(findGroup(row, REVIEW_GROUP_ID_APPLIED_TO_CARDS)),
103
+ spendLimits: { transaction: amountFromLimitsChip(transactionChip) },
104
+ requiredReceiptThreshold: amountFromLimitsChip(receiptChip),
105
+ };
106
+ };
107
+ // Shared by both auto and bulk wire builders.
108
+ export const REVIEW_GROUP_IDS = {
109
+ allowedVendors: REVIEW_GROUP_ID_ALLOWED_VENDORS,
110
+ blockedVendors: REVIEW_GROUP_ID_BLOCKED_VENDORS,
111
+ allowedCategories: REVIEW_GROUP_ID_ALLOWED_CATEGORIES,
112
+ restrictedCategories: REVIEW_GROUP_ID_RESTRICTED_CATEGORIES,
113
+ appliedToCards: REVIEW_GROUP_ID_APPLIED_TO_CARDS,
114
+ limits: REVIEW_GROUP_ID_LIMITS,
115
+ };
116
+ export const REVIEW_LIMIT_CHIP_IDS = {
117
+ transaction: REVIEW_LIMIT_CHIP_ID_TRANSACTION,
118
+ receipt: REVIEW_LIMIT_CHIP_ID_RECEIPT,
119
+ };