@rytass/bpm-core-react 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +56 -0
- package/dist/AdminDelegationsView.css +1 -0
- package/dist/AdminOrgsView.css +1 -0
- package/dist/AdminUsersView.css +1 -0
- package/dist/DelegationsView.css +1 -0
- package/dist/InstanceDetailView.css +1 -0
- package/dist/LoginView.css +1 -0
- package/dist/SettingsNotificationsView.css +1 -0
- package/dist/admin-pickers.css +1 -0
- package/dist/app-navigation.css +1 -0
- package/dist/approval-instance-list-page.css +1 -0
- package/dist/auth-provider.css +1 -0
- package/dist/chunks/AdminDelegationsView-CqNmlVWx.cjs +2 -0
- package/dist/chunks/AdminDelegationsView-CqNmlVWx.cjs.map +1 -0
- package/dist/chunks/AdminDelegationsView-DydMZ9ED.js +642 -0
- package/dist/chunks/AdminDelegationsView-DydMZ9ED.js.map +1 -0
- package/dist/chunks/AdminOrgsView-DZaVAbaQ.js +1945 -0
- package/dist/chunks/AdminOrgsView-DZaVAbaQ.js.map +1 -0
- package/dist/chunks/AdminOrgsView-bSsIyMvk.cjs +2 -0
- package/dist/chunks/AdminOrgsView-bSsIyMvk.cjs.map +1 -0
- package/dist/chunks/AdminUsersView-C0oO05Br.js +215 -0
- package/dist/chunks/AdminUsersView-C0oO05Br.js.map +1 -0
- package/dist/chunks/AdminUsersView-DlArLlIr.cjs +2 -0
- package/dist/chunks/AdminUsersView-DlArLlIr.cjs.map +1 -0
- package/dist/chunks/CcView-BsVsya5F.cjs +2 -0
- package/dist/chunks/CcView-BsVsya5F.cjs.map +1 -0
- package/dist/chunks/CcView-Bv0GzA5C.js +19 -0
- package/dist/chunks/CcView-Bv0GzA5C.js.map +1 -0
- package/dist/chunks/DashboardView-Dk1ZQmmk.js +11 -0
- package/dist/chunks/DashboardView-Dk1ZQmmk.js.map +1 -0
- package/dist/chunks/DashboardView-_0zh-rxT.cjs +2 -0
- package/dist/chunks/DashboardView-_0zh-rxT.cjs.map +1 -0
- package/dist/chunks/DelegationsView-DQUqOUV5.js +569 -0
- package/dist/chunks/DelegationsView-DQUqOUV5.js.map +1 -0
- package/dist/chunks/DelegationsView-pKeFV2LN.cjs +2 -0
- package/dist/chunks/DelegationsView-pKeFV2LN.cjs.map +1 -0
- package/dist/chunks/FormBuilderView-BKtyW55e.cjs +3 -0
- package/dist/chunks/FormBuilderView-BKtyW55e.cjs.map +1 -0
- package/dist/chunks/FormBuilderView-CvChAvgD.js +1300 -0
- package/dist/chunks/FormBuilderView-CvChAvgD.js.map +1 -0
- package/dist/chunks/FormRendererView-BwVsH2eX.cjs +2 -0
- package/dist/chunks/FormRendererView-BwVsH2eX.cjs.map +1 -0
- package/dist/chunks/FormRendererView-DrHsuSVo.js +220 -0
- package/dist/chunks/FormRendererView-DrHsuSVo.js.map +1 -0
- package/dist/chunks/FormsView-DYEuik8W.js +185 -0
- package/dist/chunks/FormsView-DYEuik8W.js.map +1 -0
- package/dist/chunks/FormsView-RjJEkIfZ.cjs +2 -0
- package/dist/chunks/FormsView-RjJEkIfZ.cjs.map +1 -0
- package/dist/chunks/InboxView-DDWwmWhA.cjs +2 -0
- package/dist/chunks/InboxView-DDWwmWhA.cjs.map +1 -0
- package/dist/chunks/InboxView-YSoyrYLk.js +291 -0
- package/dist/chunks/InboxView-YSoyrYLk.js.map +1 -0
- package/dist/chunks/InstanceDetailView-C-A-LOCG.js +1519 -0
- package/dist/chunks/InstanceDetailView-C-A-LOCG.js.map +1 -0
- package/dist/chunks/InstanceDetailView-l_kNDCz2.cjs +2 -0
- package/dist/chunks/InstanceDetailView-l_kNDCz2.cjs.map +1 -0
- package/dist/chunks/InstanceNewView-B5hz-FWd.js +190 -0
- package/dist/chunks/InstanceNewView-B5hz-FWd.js.map +1 -0
- package/dist/chunks/InstanceNewView-CdCsxQIu.cjs +2 -0
- package/dist/chunks/InstanceNewView-CdCsxQIu.cjs.map +1 -0
- package/dist/chunks/LoginView-BED07v-7.cjs +2 -0
- package/dist/chunks/LoginView-BED07v-7.cjs.map +1 -0
- package/dist/chunks/LoginView-a1iu3cfc.js +157 -0
- package/dist/chunks/LoginView-a1iu3cfc.js.map +1 -0
- package/dist/chunks/RootClientView-rXJt4TDd.cjs +2 -0
- package/dist/chunks/RootClientView-rXJt4TDd.cjs.map +1 -0
- package/dist/chunks/RootClientView-wAkXUEZw.js +34 -0
- package/dist/chunks/RootClientView-wAkXUEZw.js.map +1 -0
- package/dist/chunks/SearchView-CgXPssgE.cjs +2 -0
- package/dist/chunks/SearchView-CgXPssgE.cjs.map +1 -0
- package/dist/chunks/SearchView-WXMbZwRw.js +19 -0
- package/dist/chunks/SearchView-WXMbZwRw.js.map +1 -0
- package/dist/chunks/SentView-BTDoFBrG.cjs +2 -0
- package/dist/chunks/SentView-BTDoFBrG.cjs.map +1 -0
- package/dist/chunks/SentView-CdOL92Rq.js +19 -0
- package/dist/chunks/SentView-CdOL92Rq.js.map +1 -0
- package/dist/chunks/SettingsNotificationsView-B6F6fa7U.js +194 -0
- package/dist/chunks/SettingsNotificationsView-B6F6fa7U.js.map +1 -0
- package/dist/chunks/SettingsNotificationsView-Bnz0CmoJ.cjs +2 -0
- package/dist/chunks/SettingsNotificationsView-Bnz0CmoJ.cjs.map +1 -0
- package/dist/chunks/TemplateCategoriesView-CgZciaSd.js +382 -0
- package/dist/chunks/TemplateCategoriesView-CgZciaSd.js.map +1 -0
- package/dist/chunks/TemplateCategoriesView-U0stGUBc.cjs +2 -0
- package/dist/chunks/TemplateCategoriesView-U0stGUBc.cjs.map +1 -0
- package/dist/chunks/TemplateDesignerView-A38DyYD4.cjs +51 -0
- package/dist/chunks/TemplateDesignerView-A38DyYD4.cjs.map +1 -0
- package/dist/chunks/TemplateDesignerView-Dffx-VZ-.js +2272 -0
- package/dist/chunks/TemplateDesignerView-Dffx-VZ-.js.map +1 -0
- package/dist/chunks/TemplateVersionsView-6sVQbBem.js +110 -0
- package/dist/chunks/TemplateVersionsView-6sVQbBem.js.map +1 -0
- package/dist/chunks/TemplateVersionsView-CMqw3ieU.cjs +2 -0
- package/dist/chunks/TemplateVersionsView-CMqw3ieU.cjs.map +1 -0
- package/dist/chunks/TemplatesView-BLj9f-XI.js +380 -0
- package/dist/chunks/TemplatesView-BLj9f-XI.js.map +1 -0
- package/dist/chunks/TemplatesView-DIOQTUUl.cjs +2 -0
- package/dist/chunks/TemplatesView-DIOQTUUl.cjs.map +1 -0
- package/dist/chunks/admin-pickers-Btvij1at.cjs +2 -0
- package/dist/chunks/admin-pickers-Btvij1at.cjs.map +1 -0
- package/dist/chunks/admin-pickers-DLlG_1du.js +140 -0
- package/dist/chunks/admin-pickers-DLlG_1du.js.map +1 -0
- package/dist/chunks/app-navigation-CATITRM7.js +263 -0
- package/dist/chunks/app-navigation-CATITRM7.js.map +1 -0
- package/dist/chunks/app-navigation-DAC5gFbG.cjs +2 -0
- package/dist/chunks/app-navigation-DAC5gFbG.cjs.map +1 -0
- package/dist/chunks/approval-instance-list-page-B6vAGvOb.js +278 -0
- package/dist/chunks/approval-instance-list-page-B6vAGvOb.js.map +1 -0
- package/dist/chunks/approval-instance-list-page-DIAmwhvl.cjs +2 -0
- package/dist/chunks/approval-instance-list-page-DIAmwhvl.cjs.map +1 -0
- package/dist/chunks/auth-provider-D2P-qWmY.cjs +2 -0
- package/dist/chunks/auth-provider-D2P-qWmY.cjs.map +1 -0
- package/dist/chunks/auth-provider-TTO9eNZV.js +83 -0
- package/dist/chunks/auth-provider-TTO9eNZV.js.map +1 -0
- package/dist/chunks/bpm-form-field-Bc6k4ZEO.cjs +2 -0
- package/dist/chunks/bpm-form-field-Bc6k4ZEO.cjs.map +1 -0
- package/dist/chunks/bpm-form-field-Cao0rMol.js +17 -0
- package/dist/chunks/bpm-form-field-Cao0rMol.js.map +1 -0
- package/dist/chunks/dashboard-page-BsW8t104.js +115 -0
- package/dist/chunks/dashboard-page-BsW8t104.js.map +1 -0
- package/dist/chunks/dashboard-page-udYhnyMW.cjs +2 -0
- package/dist/chunks/dashboard-page-udYhnyMW.cjs.map +1 -0
- package/dist/chunks/form-name-modal-C3OEvkCV.js +64 -0
- package/dist/chunks/form-name-modal-C3OEvkCV.js.map +1 -0
- package/dist/chunks/form-name-modal-uZCHbtRH.cjs +2 -0
- package/dist/chunks/form-name-modal-uZCHbtRH.cjs.map +1 -0
- package/dist/chunks/format-date-time-BQyH5U8z.cjs +2 -0
- package/dist/chunks/format-date-time-BQyH5U8z.cjs.map +1 -0
- package/dist/chunks/format-date-time-CB-LxzqT.js +9 -0
- package/dist/chunks/format-date-time-CB-LxzqT.js.map +1 -0
- package/dist/chunks/router-adapter-BdHZXLS3.js +23 -0
- package/dist/chunks/router-adapter-BdHZXLS3.js.map +1 -0
- package/dist/chunks/router-adapter-BybHrCNP.cjs +2 -0
- package/dist/chunks/router-adapter-BybHrCNP.cjs.map +1 -0
- package/dist/chunks/templates.module-B5bg_goX.js +8 -0
- package/dist/chunks/templates.module-B5bg_goX.js.map +1 -0
- package/dist/chunks/templates.module-ClRnQQX4.cjs +2 -0
- package/dist/chunks/templates.module-ClRnQQX4.cjs.map +1 -0
- package/dist/components/admin-pickers.d.ts +65 -0
- package/dist/components/app-navigation.d.ts +34 -0
- package/dist/components/approval-instance-list-page.d.ts +18 -0
- package/dist/components/bpm-form-field.d.ts +10 -0
- package/dist/components/dashboard-page.d.ts +10 -0
- package/dist/components/notification-drawer.d.ts +10 -0
- package/dist/components/org-unit-tree-draft-editor.d.ts +24 -0
- package/dist/components/pdf-preview.d.ts +12 -0
- package/dist/dashboard-page.css +1 -0
- package/dist/index.cjs +2 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.ts +12 -0
- package/dist/index.js +209 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/auth-provider.d.ts +37 -0
- package/dist/lib/format-date-time.d.ts +5 -0
- package/dist/lib/notification-drawer-provider.d.ts +26 -0
- package/dist/lib/notification-unread-provider.d.ts +24 -0
- package/dist/lib/org-tree-draft.d.ts +27 -0
- package/dist/lib/providers.d.ts +30 -0
- package/dist/lib/router-adapter.d.ts +47 -0
- package/dist/pages/admin/delegations/AdminDelegationsClientView.cjs +2 -0
- package/dist/pages/admin/delegations/AdminDelegationsClientView.cjs.map +1 -0
- package/dist/pages/admin/delegations/AdminDelegationsClientView.d.ts +3 -0
- package/dist/pages/admin/delegations/AdminDelegationsClientView.js +28 -0
- package/dist/pages/admin/delegations/AdminDelegationsClientView.js.map +1 -0
- package/dist/pages/admin/delegations/index.cjs +2 -0
- package/dist/pages/admin/delegations/index.cjs.map +1 -0
- package/dist/pages/admin/delegations/index.d.ts +4 -0
- package/dist/pages/admin/delegations/index.js +14 -0
- package/dist/pages/admin/delegations/index.js.map +1 -0
- package/dist/pages/admin/orgs/AdminOrgsClientView.cjs +2 -0
- package/dist/pages/admin/orgs/AdminOrgsClientView.cjs.map +1 -0
- package/dist/pages/admin/orgs/AdminOrgsClientView.d.ts +3 -0
- package/dist/pages/admin/orgs/AdminOrgsClientView.js +28 -0
- package/dist/pages/admin/orgs/AdminOrgsClientView.js.map +1 -0
- package/dist/pages/admin/orgs/index.cjs +2 -0
- package/dist/pages/admin/orgs/index.cjs.map +1 -0
- package/dist/pages/admin/orgs/index.d.ts +4 -0
- package/dist/pages/admin/orgs/index.js +14 -0
- package/dist/pages/admin/orgs/index.js.map +1 -0
- package/dist/pages/admin/users/AdminUsersClientView.cjs +2 -0
- package/dist/pages/admin/users/AdminUsersClientView.cjs.map +1 -0
- package/dist/pages/admin/users/AdminUsersClientView.d.ts +3 -0
- package/dist/pages/admin/users/AdminUsersClientView.js +28 -0
- package/dist/pages/admin/users/AdminUsersClientView.js.map +1 -0
- package/dist/pages/admin/users/index.cjs +2 -0
- package/dist/pages/admin/users/index.cjs.map +1 -0
- package/dist/pages/admin/users/index.d.ts +4 -0
- package/dist/pages/admin/users/index.js +14 -0
- package/dist/pages/admin/users/index.js.map +1 -0
- package/dist/pages/cc/CcClientView.cjs +2 -0
- package/dist/pages/cc/CcClientView.cjs.map +1 -0
- package/dist/pages/cc/CcClientView.d.ts +7 -0
- package/dist/pages/cc/CcClientView.js +28 -0
- package/dist/pages/cc/CcClientView.js.map +1 -0
- package/dist/pages/cc/index.cjs +2 -0
- package/dist/pages/cc/index.cjs.map +1 -0
- package/dist/pages/cc/index.d.ts +16 -0
- package/dist/pages/cc/index.js +11 -0
- package/dist/pages/cc/index.js.map +1 -0
- package/dist/pages/dashboard/DashboardClientView.cjs +2 -0
- package/dist/pages/dashboard/DashboardClientView.cjs.map +1 -0
- package/dist/pages/dashboard/DashboardClientView.d.ts +9 -0
- package/dist/pages/dashboard/DashboardClientView.js +28 -0
- package/dist/pages/dashboard/DashboardClientView.js.map +1 -0
- package/dist/pages/dashboard/index.cjs +2 -0
- package/dist/pages/dashboard/index.cjs.map +1 -0
- package/dist/pages/dashboard/index.d.ts +16 -0
- package/dist/pages/dashboard/index.js +11 -0
- package/dist/pages/dashboard/index.js.map +1 -0
- package/dist/pages/delegations/DelegationsClientView.cjs +2 -0
- package/dist/pages/delegations/DelegationsClientView.cjs.map +1 -0
- package/dist/pages/delegations/DelegationsClientView.d.ts +3 -0
- package/dist/pages/delegations/DelegationsClientView.js +28 -0
- package/dist/pages/delegations/DelegationsClientView.js.map +1 -0
- package/dist/pages/delegations/index.cjs +2 -0
- package/dist/pages/delegations/index.cjs.map +1 -0
- package/dist/pages/delegations/index.d.ts +4 -0
- package/dist/pages/delegations/index.js +14 -0
- package/dist/pages/delegations/index.js.map +1 -0
- package/dist/pages/forms/FormsClientView.cjs +2 -0
- package/dist/pages/forms/FormsClientView.cjs.map +1 -0
- package/dist/pages/forms/FormsClientView.d.ts +10 -0
- package/dist/pages/forms/FormsClientView.js +28 -0
- package/dist/pages/forms/FormsClientView.js.map +1 -0
- package/dist/pages/forms/builder/FormBuilderClientView.cjs +2 -0
- package/dist/pages/forms/builder/FormBuilderClientView.cjs.map +1 -0
- package/dist/pages/forms/builder/FormBuilderClientView.d.ts +11 -0
- package/dist/pages/forms/builder/FormBuilderClientView.js +28 -0
- package/dist/pages/forms/builder/FormBuilderClientView.js.map +1 -0
- package/dist/pages/forms/builder/index.cjs +2 -0
- package/dist/pages/forms/builder/index.cjs.map +1 -0
- package/dist/pages/forms/builder/index.d.ts +23 -0
- package/dist/pages/forms/builder/index.js +15 -0
- package/dist/pages/forms/builder/index.js.map +1 -0
- package/dist/pages/forms/index.cjs +2 -0
- package/dist/pages/forms/index.cjs.map +1 -0
- package/dist/pages/forms/index.d.ts +17 -0
- package/dist/pages/forms/index.js +14 -0
- package/dist/pages/forms/index.js.map +1 -0
- package/dist/pages/inbox/InboxClientView.cjs +2 -0
- package/dist/pages/inbox/InboxClientView.cjs.map +1 -0
- package/dist/pages/inbox/InboxClientView.d.ts +9 -0
- package/dist/pages/inbox/InboxClientView.js +28 -0
- package/dist/pages/inbox/InboxClientView.js.map +1 -0
- package/dist/pages/inbox/index.cjs +2 -0
- package/dist/pages/inbox/index.cjs.map +1 -0
- package/dist/pages/inbox/index.d.ts +16 -0
- package/dist/pages/inbox/index.js +11 -0
- package/dist/pages/inbox/index.js.map +1 -0
- package/dist/pages/instances/detail/InstanceDetailClientView.cjs +2 -0
- package/dist/pages/instances/detail/InstanceDetailClientView.cjs.map +1 -0
- package/dist/pages/instances/detail/InstanceDetailClientView.d.ts +9 -0
- package/dist/pages/instances/detail/InstanceDetailClientView.js +28 -0
- package/dist/pages/instances/detail/InstanceDetailClientView.js.map +1 -0
- package/dist/pages/instances/detail/index.cjs +2 -0
- package/dist/pages/instances/detail/index.cjs.map +1 -0
- package/dist/pages/instances/detail/index.d.ts +23 -0
- package/dist/pages/instances/detail/index.js +12 -0
- package/dist/pages/instances/detail/index.js.map +1 -0
- package/dist/pages/instances/new/InstanceNewClientView.cjs +2 -0
- package/dist/pages/instances/new/InstanceNewClientView.cjs.map +1 -0
- package/dist/pages/instances/new/InstanceNewClientView.d.ts +8 -0
- package/dist/pages/instances/new/InstanceNewClientView.js +28 -0
- package/dist/pages/instances/new/InstanceNewClientView.js.map +1 -0
- package/dist/pages/instances/new/index.cjs +2 -0
- package/dist/pages/instances/new/index.cjs.map +1 -0
- package/dist/pages/instances/new/index.d.ts +16 -0
- package/dist/pages/instances/new/index.js +11 -0
- package/dist/pages/instances/new/index.js.map +1 -0
- package/dist/pages/login/LoginClientView.cjs +2 -0
- package/dist/pages/login/LoginClientView.cjs.map +1 -0
- package/dist/pages/login/LoginClientView.d.ts +11 -0
- package/dist/pages/login/LoginClientView.js +29 -0
- package/dist/pages/login/LoginClientView.js.map +1 -0
- package/dist/pages/login/index.cjs +2 -0
- package/dist/pages/login/index.cjs.map +1 -0
- package/dist/pages/login/index.d.ts +17 -0
- package/dist/pages/login/index.js +14 -0
- package/dist/pages/login/index.js.map +1 -0
- package/dist/pages/root/RootClientView.cjs +1 -0
- package/dist/pages/root/RootClientView.d.ts +8 -0
- package/dist/pages/root/RootClientView.js +2 -0
- package/dist/pages/root/index.cjs +2 -0
- package/dist/pages/root/index.cjs.map +1 -0
- package/dist/pages/root/index.d.ts +16 -0
- package/dist/pages/root/index.js +11 -0
- package/dist/pages/root/index.js.map +1 -0
- package/dist/pages/search/SearchClientView.cjs +2 -0
- package/dist/pages/search/SearchClientView.cjs.map +1 -0
- package/dist/pages/search/SearchClientView.d.ts +7 -0
- package/dist/pages/search/SearchClientView.js +28 -0
- package/dist/pages/search/SearchClientView.js.map +1 -0
- package/dist/pages/search/index.cjs +2 -0
- package/dist/pages/search/index.cjs.map +1 -0
- package/dist/pages/search/index.d.ts +16 -0
- package/dist/pages/search/index.js +11 -0
- package/dist/pages/search/index.js.map +1 -0
- package/dist/pages/sent/SentClientView.cjs +2 -0
- package/dist/pages/sent/SentClientView.cjs.map +1 -0
- package/dist/pages/sent/SentClientView.d.ts +7 -0
- package/dist/pages/sent/SentClientView.js +28 -0
- package/dist/pages/sent/SentClientView.js.map +1 -0
- package/dist/pages/sent/index.cjs +2 -0
- package/dist/pages/sent/index.cjs.map +1 -0
- package/dist/pages/sent/index.d.ts +16 -0
- package/dist/pages/sent/index.js +11 -0
- package/dist/pages/sent/index.js.map +1 -0
- package/dist/pages/settings/notifications/SettingsNotificationsClientView.cjs +2 -0
- package/dist/pages/settings/notifications/SettingsNotificationsClientView.cjs.map +1 -0
- package/dist/pages/settings/notifications/SettingsNotificationsClientView.d.ts +3 -0
- package/dist/pages/settings/notifications/SettingsNotificationsClientView.js +28 -0
- package/dist/pages/settings/notifications/SettingsNotificationsClientView.js.map +1 -0
- package/dist/pages/settings/notifications/index.cjs +2 -0
- package/dist/pages/settings/notifications/index.cjs.map +1 -0
- package/dist/pages/settings/notifications/index.d.ts +4 -0
- package/dist/pages/settings/notifications/index.js +14 -0
- package/dist/pages/settings/notifications/index.js.map +1 -0
- package/dist/pages/templates/TemplatesClientView.cjs +2 -0
- package/dist/pages/templates/TemplatesClientView.cjs.map +1 -0
- package/dist/pages/templates/TemplatesClientView.d.ts +3 -0
- package/dist/pages/templates/TemplatesClientView.js +28 -0
- package/dist/pages/templates/TemplatesClientView.js.map +1 -0
- package/dist/pages/templates/categories/TemplateCategoriesClientView.cjs +2 -0
- package/dist/pages/templates/categories/TemplateCategoriesClientView.cjs.map +1 -0
- package/dist/pages/templates/categories/TemplateCategoriesClientView.d.ts +3 -0
- package/dist/pages/templates/categories/TemplateCategoriesClientView.js +28 -0
- package/dist/pages/templates/categories/TemplateCategoriesClientView.js.map +1 -0
- package/dist/pages/templates/categories/index.cjs +2 -0
- package/dist/pages/templates/categories/index.cjs.map +1 -0
- package/dist/pages/templates/categories/index.d.ts +4 -0
- package/dist/pages/templates/categories/index.js +14 -0
- package/dist/pages/templates/categories/index.js.map +1 -0
- package/dist/pages/templates/designer/TemplateDesignerClientView.cjs +2 -0
- package/dist/pages/templates/designer/TemplateDesignerClientView.cjs.map +1 -0
- package/dist/pages/templates/designer/TemplateDesignerClientView.d.ts +3 -0
- package/dist/pages/templates/designer/TemplateDesignerClientView.js +28 -0
- package/dist/pages/templates/designer/TemplateDesignerClientView.js.map +1 -0
- package/dist/pages/templates/designer/index.cjs +2 -0
- package/dist/pages/templates/designer/index.cjs.map +1 -0
- package/dist/pages/templates/designer/index.d.ts +10 -0
- package/dist/pages/templates/designer/index.js +15 -0
- package/dist/pages/templates/designer/index.js.map +1 -0
- package/dist/pages/templates/index.cjs +2 -0
- package/dist/pages/templates/index.cjs.map +1 -0
- package/dist/pages/templates/index.d.ts +4 -0
- package/dist/pages/templates/index.js +14 -0
- package/dist/pages/templates/index.js.map +1 -0
- package/dist/pages/templates/versions/TemplateVersionsClientView.cjs +2 -0
- package/dist/pages/templates/versions/TemplateVersionsClientView.cjs.map +1 -0
- package/dist/pages/templates/versions/TemplateVersionsClientView.d.ts +3 -0
- package/dist/pages/templates/versions/TemplateVersionsClientView.js +28 -0
- package/dist/pages/templates/versions/TemplateVersionsClientView.js.map +1 -0
- package/dist/pages/templates/versions/index.cjs +2 -0
- package/dist/pages/templates/versions/index.cjs.map +1 -0
- package/dist/pages/templates/versions/index.d.ts +10 -0
- package/dist/pages/templates/versions/index.js +15 -0
- package/dist/pages/templates/versions/index.js.map +1 -0
- package/dist/templates.css +1 -0
- package/dist/views/admin/delegations/AdminDelegationsView.d.ts +5 -0
- package/dist/views/admin/delegations/index.cjs +1 -0
- package/dist/views/admin/delegations/index.d.ts +1 -0
- package/dist/views/admin/delegations/index.js +2 -0
- package/dist/views/admin/orgs/AdminOrgsView.d.ts +5 -0
- package/dist/views/admin/orgs/index.cjs +1 -0
- package/dist/views/admin/orgs/index.d.ts +1 -0
- package/dist/views/admin/orgs/index.js +2 -0
- package/dist/views/admin/users/AdminUsersView.d.ts +5 -0
- package/dist/views/admin/users/index.cjs +1 -0
- package/dist/views/admin/users/index.d.ts +1 -0
- package/dist/views/admin/users/index.js +2 -0
- package/dist/views/cc/CcView.d.ts +9 -0
- package/dist/views/cc/index.cjs +1 -0
- package/dist/views/cc/index.d.ts +1 -0
- package/dist/views/cc/index.js +2 -0
- package/dist/views/dashboard/DashboardView.d.ts +9 -0
- package/dist/views/dashboard/index.cjs +1 -0
- package/dist/views/dashboard/index.d.ts +1 -0
- package/dist/views/dashboard/index.js +2 -0
- package/dist/views/delegations/DelegationsView.d.ts +5 -0
- package/dist/views/delegations/index.cjs +1 -0
- package/dist/views/delegations/index.d.ts +1 -0
- package/dist/views/delegations/index.js +2 -0
- package/dist/views/forms/FormsView.d.ts +4 -0
- package/dist/views/forms/builder/FormBuilderView.d.ts +9 -0
- package/dist/views/forms/builder/index.cjs +1 -0
- package/dist/views/forms/builder/index.d.ts +1 -0
- package/dist/views/forms/builder/index.js +2 -0
- package/dist/views/forms/builder/json-code-editor.d.ts +11 -0
- package/dist/views/forms/form-name-modal.d.ts +12 -0
- package/dist/views/forms/index.cjs +1 -0
- package/dist/views/forms/index.d.ts +1 -0
- package/dist/views/forms/index.js +2 -0
- package/dist/views/forms/renderer/FormRendererView.d.ts +19 -0
- package/dist/views/forms/renderer/index.cjs +1 -0
- package/dist/views/forms/renderer/index.d.ts +1 -0
- package/dist/views/forms/renderer/index.js +2 -0
- package/dist/views/inbox/InboxView.d.ts +9 -0
- package/dist/views/inbox/index.cjs +1 -0
- package/dist/views/inbox/index.d.ts +1 -0
- package/dist/views/inbox/index.js +2 -0
- package/dist/views/instances/detail/InstanceDetailView.d.ts +12 -0
- package/dist/views/instances/detail/index.cjs +1 -0
- package/dist/views/instances/detail/index.d.ts +1 -0
- package/dist/views/instances/detail/index.js +2 -0
- package/dist/views/instances/new/InstanceNewView.d.ts +15 -0
- package/dist/views/instances/new/index.cjs +1 -0
- package/dist/views/instances/new/index.d.ts +1 -0
- package/dist/views/instances/new/index.js +2 -0
- package/dist/views/login/LoginView.d.ts +47 -0
- package/dist/views/login/index.cjs +1 -0
- package/dist/views/login/index.d.ts +1 -0
- package/dist/views/login/index.js +2 -0
- package/dist/views/root/RootView.d.ts +12 -0
- package/dist/views/root/index.d.ts +1 -0
- package/dist/views/search/SearchView.d.ts +9 -0
- package/dist/views/search/index.cjs +1 -0
- package/dist/views/search/index.d.ts +1 -0
- package/dist/views/search/index.js +2 -0
- package/dist/views/sent/SentView.d.ts +9 -0
- package/dist/views/sent/index.cjs +1 -0
- package/dist/views/sent/index.d.ts +1 -0
- package/dist/views/sent/index.js +2 -0
- package/dist/views/settings/notifications/SettingsNotificationsView.d.ts +5 -0
- package/dist/views/settings/notifications/index.cjs +1 -0
- package/dist/views/settings/notifications/index.d.ts +1 -0
- package/dist/views/settings/notifications/index.js +2 -0
- package/dist/views/templates/TemplatesView.d.ts +5 -0
- package/dist/views/templates/categories/TemplateCategoriesView.d.ts +5 -0
- package/dist/views/templates/categories/index.cjs +1 -0
- package/dist/views/templates/categories/index.d.ts +1 -0
- package/dist/views/templates/categories/index.js +2 -0
- package/dist/views/templates/designer/TemplateDesignerView.d.ts +6 -0
- package/dist/views/templates/designer/index.cjs +1 -0
- package/dist/views/templates/designer/index.d.ts +1 -0
- package/dist/views/templates/designer/index.js +2 -0
- package/dist/views/templates/index.cjs +1 -0
- package/dist/views/templates/index.d.ts +1 -0
- package/dist/views/templates/index.js +2 -0
- package/dist/views/templates/template-name-modal.d.ts +22 -0
- package/dist/views/templates/versions/TemplateVersionsView.d.ts +6 -0
- package/dist/views/templates/versions/index.cjs +1 -0
- package/dist/views/templates/versions/index.d.ts +1 -0
- package/dist/views/templates/versions/index.js +2 -0
- package/package.json +272 -0
|
@@ -0,0 +1,185 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { r as e } from "./router-adapter-BdHZXLS3.js";
|
|
3
|
+
import { t } from "./format-date-time-CB-LxzqT.js";
|
|
4
|
+
import { t as n } from "./app-navigation-CATITRM7.js";
|
|
5
|
+
import { t as r } from "./form-name-modal-C3OEvkCV.js";
|
|
6
|
+
import { useCallback as i, useEffect as a, useMemo as o, useState as s } from "react";
|
|
7
|
+
import { Badge as c, Button as l, Layout as u, PageHeader as d, Section as f, SectionGroup as p, Tab as m, TabItem as h, Table as g, Typography as _ } from "@mezzanine-ui/react";
|
|
8
|
+
import { Fragment as v, jsx as y, jsxs as b } from "react/jsx-runtime";
|
|
9
|
+
import { PlusIcon as x } from "@mezzanine-ui/icons";
|
|
10
|
+
import S from "@mezzanine-ui/react/ContentHeader";
|
|
11
|
+
import { createFormDefinition as C, listFormDefinitionsPage as w } from "@rytass/bpm-core-client/form";
|
|
12
|
+
//#region src/views/forms/FormsView.tsx
|
|
13
|
+
var T = [
|
|
14
|
+
10,
|
|
15
|
+
20,
|
|
16
|
+
50
|
|
17
|
+
], E = [
|
|
18
|
+
{
|
|
19
|
+
key: "ALL",
|
|
20
|
+
label: "全部"
|
|
21
|
+
},
|
|
22
|
+
{
|
|
23
|
+
key: "PUBLISHED",
|
|
24
|
+
label: "已發布"
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
key: "DRAFT",
|
|
28
|
+
label: "草稿"
|
|
29
|
+
}
|
|
30
|
+
];
|
|
31
|
+
function D(c = {}) {
|
|
32
|
+
let D = e(), [M, N] = s([]), [P, F] = s(null), [I, L] = s(!0), [R, z] = s(!1), [B, V] = s(!1), [H, U] = s(1), [W, G] = s(10), [K, q] = s("ALL"), [J, Y] = s(0), X = i(async () => {
|
|
33
|
+
L(!0), F(null);
|
|
34
|
+
try {
|
|
35
|
+
let e = await w({
|
|
36
|
+
page: H,
|
|
37
|
+
pageSize: W,
|
|
38
|
+
status: K === "ALL" ? null : K
|
|
39
|
+
});
|
|
40
|
+
N(e.forms), Y(e.totalCount);
|
|
41
|
+
} catch (e) {
|
|
42
|
+
F(O(e));
|
|
43
|
+
} finally {
|
|
44
|
+
L(!1);
|
|
45
|
+
}
|
|
46
|
+
}, [
|
|
47
|
+
H,
|
|
48
|
+
W,
|
|
49
|
+
K
|
|
50
|
+
]);
|
|
51
|
+
a(() => {
|
|
52
|
+
X();
|
|
53
|
+
}, [X]);
|
|
54
|
+
let Z = o(() => M.map((e) => ({
|
|
55
|
+
...e,
|
|
56
|
+
key: e.id,
|
|
57
|
+
status: e.currentVersionId ? "PUBLISHED" : "DRAFT",
|
|
58
|
+
updatedAt: t(e.updatedAt)
|
|
59
|
+
})), [M]), Q = o(() => [
|
|
60
|
+
{
|
|
61
|
+
dataIndex: "name",
|
|
62
|
+
key: "name",
|
|
63
|
+
title: "表單名稱",
|
|
64
|
+
width: 220
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
key: "status",
|
|
68
|
+
render: (e) => /* @__PURE__ */ y(k, { status: e.status }),
|
|
69
|
+
title: "狀態",
|
|
70
|
+
width: 120
|
|
71
|
+
},
|
|
72
|
+
{
|
|
73
|
+
key: "currentVersionId",
|
|
74
|
+
render: (e) => /* @__PURE__ */ y(j, { record: e }),
|
|
75
|
+
title: "目前版本",
|
|
76
|
+
width: 220
|
|
77
|
+
}
|
|
78
|
+
], []), $ = o(() => ({
|
|
79
|
+
render: (e) => [{
|
|
80
|
+
name: "編輯",
|
|
81
|
+
onClick: () => D.push(`/forms/${e.id}/builder`)
|
|
82
|
+
}],
|
|
83
|
+
variant: "base-secondary",
|
|
84
|
+
width: 88
|
|
85
|
+
}), [D]);
|
|
86
|
+
async function ee(e) {
|
|
87
|
+
V(!0), F(null);
|
|
88
|
+
try {
|
|
89
|
+
let t = await C(e);
|
|
90
|
+
z(!1), D.push(`/forms/${t}/builder`);
|
|
91
|
+
} finally {
|
|
92
|
+
V(!1);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
return /* @__PURE__ */ b(v, { children: [/* @__PURE__ */ b(u, { children: [/* @__PURE__ */ y(n, { activeHref: "/forms" }), /* @__PURE__ */ b(u.Main, { children: [/* @__PURE__ */ y(d, { children: /* @__PURE__ */ y(S, {
|
|
96
|
+
description: "建立表單定義、管理草稿與已發布版本,提供流程模板綁定使用。",
|
|
97
|
+
title: "表單設計",
|
|
98
|
+
children: /* @__PURE__ */ y(l, {
|
|
99
|
+
disabled: B,
|
|
100
|
+
icon: x,
|
|
101
|
+
iconType: "leading",
|
|
102
|
+
onClick: () => z(!0),
|
|
103
|
+
variant: "base-primary",
|
|
104
|
+
children: "建立表單"
|
|
105
|
+
})
|
|
106
|
+
}) }), /* @__PURE__ */ y(p, { children: /* @__PURE__ */ b(f, {
|
|
107
|
+
tab: /* @__PURE__ */ y(m, {
|
|
108
|
+
activeKey: K,
|
|
109
|
+
onChange: (e) => {
|
|
110
|
+
q(A(e)), U(1);
|
|
111
|
+
},
|
|
112
|
+
children: E.map((e) => /* @__PURE__ */ y(h, { children: e.label }, e.key))
|
|
113
|
+
}),
|
|
114
|
+
children: [P ? /* @__PURE__ */ y(_, {
|
|
115
|
+
color: "text-error",
|
|
116
|
+
variant: "body",
|
|
117
|
+
children: P
|
|
118
|
+
}) : null, /* @__PURE__ */ y(g, {
|
|
119
|
+
columns: Q,
|
|
120
|
+
actions: $,
|
|
121
|
+
dataSource: Z,
|
|
122
|
+
fullWidth: !0,
|
|
123
|
+
loading: I,
|
|
124
|
+
pagination: {
|
|
125
|
+
current: H,
|
|
126
|
+
onChange: (e) => {
|
|
127
|
+
U(e);
|
|
128
|
+
},
|
|
129
|
+
onChangePageSize: (e) => {
|
|
130
|
+
U(1), G(e);
|
|
131
|
+
},
|
|
132
|
+
pageSize: W,
|
|
133
|
+
pageSizeLabel: "每頁筆數",
|
|
134
|
+
pageSizeOptions: T,
|
|
135
|
+
renderResultSummary: (e, t, n) => `顯示 ${e}-${t} 筆,共 ${n} 筆`,
|
|
136
|
+
showPageSizeOptions: !0,
|
|
137
|
+
total: J
|
|
138
|
+
}
|
|
139
|
+
})]
|
|
140
|
+
}) })] })] }), /* @__PURE__ */ y(r, {
|
|
141
|
+
confirmText: "建立",
|
|
142
|
+
initialName: "",
|
|
143
|
+
loading: B,
|
|
144
|
+
onClose: () => z(!1),
|
|
145
|
+
onSubmit: ee,
|
|
146
|
+
open: R,
|
|
147
|
+
title: "建立表單"
|
|
148
|
+
})] });
|
|
149
|
+
}
|
|
150
|
+
function O(e) {
|
|
151
|
+
return e instanceof Error ? e.message : "發生未知錯誤";
|
|
152
|
+
}
|
|
153
|
+
function k({ status: e }) {
|
|
154
|
+
return e === "PUBLISHED" ? /* @__PURE__ */ y(c, {
|
|
155
|
+
size: "sub",
|
|
156
|
+
text: "已發布",
|
|
157
|
+
variant: "dot-success"
|
|
158
|
+
}) : /* @__PURE__ */ y(c, {
|
|
159
|
+
size: "sub",
|
|
160
|
+
text: "草稿",
|
|
161
|
+
variant: "dot-warning"
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
function A(e) {
|
|
165
|
+
return e === "PUBLISHED" || e === "DRAFT" ? e : "ALL";
|
|
166
|
+
}
|
|
167
|
+
function j({ record: e }) {
|
|
168
|
+
if (!e.currentVersionId || !e.currentVersionNumber) return /* @__PURE__ */ y(_, {
|
|
169
|
+
variant: "body",
|
|
170
|
+
children: "尚未發布"
|
|
171
|
+
});
|
|
172
|
+
let n = e.currentVersionPublishedAt ?? e.currentVersionCreatedAt;
|
|
173
|
+
return /* @__PURE__ */ b(_, {
|
|
174
|
+
variant: "body",
|
|
175
|
+
children: [
|
|
176
|
+
"v",
|
|
177
|
+
e.currentVersionNumber,
|
|
178
|
+
n ? ` · ${t(n)}` : ""
|
|
179
|
+
]
|
|
180
|
+
});
|
|
181
|
+
}
|
|
182
|
+
//#endregion
|
|
183
|
+
export { D as t };
|
|
184
|
+
|
|
185
|
+
//# sourceMappingURL=FormsView-DYEuik8W.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FormsView-DYEuik8W.js","names":[],"sources":["../../src/views/forms/FormsView.tsx"],"sourcesContent":["'use client';\n\nimport type { Key, ReactElement } from 'react';\nimport { useCallback, useEffect, useMemo, useState } from 'react';\nimport {\n Badge,\n Button,\n Layout,\n PageHeader,\n Section,\n SectionGroup,\n Tab,\n TabItem,\n Table,\n Typography,\n} from '@mezzanine-ui/react';\nimport ContentHeader from '@mezzanine-ui/react/ContentHeader';\nimport { PlusIcon } from '@mezzanine-ui/icons';\nimport type { TableActions, TableColumn } from '@mezzanine-ui/core/table';\nimport { formatDateTime } from '../../lib/format-date-time';\nimport { AppNavigation } from '../../components/app-navigation';\nimport {\n createFormDefinition,\n FormDefinitionListStatus,\n FormDefinitionRecord,\n listFormDefinitionsPage,\n} from '@rytass/bpm-core-client/form';\nimport { useRouterAdapter } from '../../lib/router-adapter';\nimport { FormNameModal } from './form-name-modal';\n\nconst FORM_PAGE_SIZE_OPTIONS = [10, 20, 50];\nconst FORM_STATUS_TABS: readonly {\n readonly key: FormStatusTabKey;\n readonly label: string;\n}[] = [\n { key: 'ALL', label: '全部' },\n { key: 'PUBLISHED', label: '已發布' },\n { key: 'DRAFT', label: '草稿' },\n];\n\ntype FormDefinitionRow = Readonly<\n Record<string, unknown> &\n FormDefinitionRecord & {\n key: string;\n status: FormDefinitionListStatus;\n }\n>;\n\ntype FormStatusTabKey = 'ALL' | FormDefinitionListStatus;\n\nexport interface FormsViewProps {}\n\nexport function FormsView(_props: FormsViewProps = {}): ReactElement {\n const router = useRouterAdapter();\n const [forms, setForms] = useState<readonly FormDefinitionRecord[]>([]);\n const [error, setError] = useState<string | null>(null);\n const [loading, setLoading] = useState(true);\n const [createModalOpen, setCreateModalOpen] = useState(false);\n const [creating, setCreating] = useState(false);\n const [formPage, setFormPage] = useState(1);\n const [formPageSize, setFormPageSize] = useState(10);\n const [formStatus, setFormStatus] = useState<FormStatusTabKey>('ALL');\n const [formTotalCount, setFormTotalCount] = useState(0);\n\n const refreshForms = useCallback(async (): Promise<void> => {\n setLoading(true);\n setError(null);\n\n try {\n const result = await listFormDefinitionsPage({\n page: formPage,\n pageSize: formPageSize,\n status: formStatus === 'ALL' ? null : formStatus,\n });\n\n setForms(result.forms);\n setFormTotalCount(result.totalCount);\n } catch (requestError: unknown) {\n setError(readErrorMessage(requestError));\n } finally {\n setLoading(false);\n }\n }, [formPage, formPageSize, formStatus]);\n\n useEffect((): void => {\n void refreshForms();\n }, [refreshForms]);\n\n const rows = useMemo(\n (): FormDefinitionRow[] =>\n forms.map((form) => ({\n ...form,\n key: form.id,\n status: form.currentVersionId ? 'PUBLISHED' : 'DRAFT',\n updatedAt: formatDateTime(form.updatedAt),\n })),\n [forms],\n );\n const columns = useMemo(\n (): TableColumn<FormDefinitionRow>[] => [\n { dataIndex: 'name', key: 'name', title: '表單名稱', width: 220 },\n {\n key: 'status',\n render: (record: FormDefinitionRow): ReactElement => (\n <FormStatusBadge status={record.status} />\n ),\n title: '狀態',\n width: 120,\n },\n {\n key: 'currentVersionId',\n render: (record: FormDefinitionRow): ReactElement => (\n <CurrentVersionLabel record={record} />\n ),\n title: '目前版本',\n width: 220,\n },\n ],\n [],\n );\n const tableActions = useMemo(\n (): TableActions<FormDefinitionRow> => ({\n render: (\n record,\n ): ReturnType<TableActions<FormDefinitionRow>['render']> => [\n {\n name: '編輯',\n onClick: (): void => router.push(`/forms/${record.id}/builder`),\n },\n ],\n variant: 'base-secondary',\n width: 88,\n }),\n [router],\n );\n\n async function handleCreateForm(name: string): Promise<void> {\n setCreating(true);\n setError(null);\n\n try {\n const formId = await createFormDefinition(name);\n setCreateModalOpen(false);\n router.push(`/forms/${formId}/builder`);\n } finally {\n setCreating(false);\n }\n }\n\n return (\n <>\n <Layout>\n <AppNavigation activeHref=\"/forms\" />\n\n <Layout.Main>\n <PageHeader>\n <ContentHeader\n description=\"建立表單定義、管理草稿與已發布版本,提供流程模板綁定使用。\"\n title=\"表單設計\"\n >\n <Button\n disabled={creating}\n icon={PlusIcon}\n iconType=\"leading\"\n onClick={(): void => setCreateModalOpen(true)}\n variant=\"base-primary\"\n >\n 建立表單\n </Button>\n </ContentHeader>\n </PageHeader>\n\n <SectionGroup>\n <Section\n tab={\n <Tab\n activeKey={formStatus}\n onChange={(activeKey): void => {\n setFormStatus(readFormStatusTabKey(activeKey));\n setFormPage(1);\n }}\n >\n {FORM_STATUS_TABS.map((statusTab) => (\n <TabItem key={statusTab.key}>{statusTab.label}</TabItem>\n ))}\n </Tab>\n }\n >\n {error ? (\n <Typography color=\"text-error\" variant=\"body\">\n {error}\n </Typography>\n ) : null}\n <Table\n columns={columns}\n actions={tableActions}\n dataSource={rows}\n fullWidth\n loading={loading}\n pagination={{\n current: formPage,\n onChange: (page): void => {\n setFormPage(page);\n },\n onChangePageSize: (pageSize): void => {\n setFormPage(1);\n setFormPageSize(pageSize);\n },\n pageSize: formPageSize,\n pageSizeLabel: '每頁筆數',\n pageSizeOptions: FORM_PAGE_SIZE_OPTIONS,\n renderResultSummary: (from, to, total): string =>\n `顯示 ${from}-${to} 筆,共 ${total} 筆`,\n showPageSizeOptions: true,\n total: formTotalCount,\n }}\n />\n </Section>\n </SectionGroup>\n </Layout.Main>\n </Layout>\n\n <FormNameModal\n confirmText=\"建立\"\n initialName=\"\"\n loading={creating}\n onClose={(): void => setCreateModalOpen(false)}\n onSubmit={handleCreateForm}\n open={createModalOpen}\n title=\"建立表單\"\n />\n </>\n );\n}\n\nfunction readErrorMessage(error: unknown): string {\n return error instanceof Error ? error.message : '發生未知錯誤';\n}\n\nfunction FormStatusBadge({\n status,\n}: {\n readonly status: FormDefinitionListStatus;\n}): ReactElement {\n if (status === 'PUBLISHED') {\n return <Badge size=\"sub\" text=\"已發布\" variant=\"dot-success\" />;\n }\n\n return <Badge size=\"sub\" text=\"草稿\" variant=\"dot-warning\" />;\n}\n\nfunction readFormStatusTabKey(activeKey: Key): FormStatusTabKey {\n if (activeKey === 'PUBLISHED' || activeKey === 'DRAFT') {\n return activeKey;\n }\n\n return 'ALL';\n}\n\nfunction CurrentVersionLabel({\n record,\n}: {\n readonly record: FormDefinitionRow;\n}): ReactElement {\n if (!record.currentVersionId || !record.currentVersionNumber) {\n return <Typography variant=\"body\">尚未發布</Typography>;\n }\n\n const versionTime =\n record.currentVersionPublishedAt ?? record.currentVersionCreatedAt;\n\n return (\n <Typography variant=\"body\">\n v{record.currentVersionNumber}\n {versionTime ? ` · ${formatDateTime(versionTime)}` : ''}\n </Typography>\n );\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use client";const e=require("./app-navigation-DAC5gFbG.cjs"),t=require("./router-adapter-BybHrCNP.cjs"),n=require("./format-date-time-BQyH5U8z.cjs"),r=require("./form-name-modal-uZCHbtRH.cjs");let i=require("react"),a=require("@mezzanine-ui/react"),o=require("react/jsx-runtime"),s=require("@mezzanine-ui/icons"),c=require("@mezzanine-ui/react/ContentHeader");c=e.o(c,1);let l=require("@rytass/bpm-core-client/form");var u=[10,20,50],d=[{key:`ALL`,label:`全部`},{key:`PUBLISHED`,label:`已發布`},{key:`DRAFT`,label:`草稿`}];function f(f={}){let _=t.r(),[v,y]=(0,i.useState)([]),[b,x]=(0,i.useState)(null),[S,C]=(0,i.useState)(!0),[w,T]=(0,i.useState)(!1),[E,D]=(0,i.useState)(!1),[O,k]=(0,i.useState)(1),[A,j]=(0,i.useState)(10),[M,N]=(0,i.useState)(`ALL`),[P,F]=(0,i.useState)(0),I=(0,i.useCallback)(async()=>{C(!0),x(null);try{let e=await(0,l.listFormDefinitionsPage)({page:O,pageSize:A,status:M===`ALL`?null:M});y(e.forms),F(e.totalCount)}catch(e){x(p(e))}finally{C(!1)}},[O,A,M]);(0,i.useEffect)(()=>{I()},[I]);let L=(0,i.useMemo)(()=>v.map(e=>({...e,key:e.id,status:e.currentVersionId?`PUBLISHED`:`DRAFT`,updatedAt:n.t(e.updatedAt)})),[v]),R=(0,i.useMemo)(()=>[{dataIndex:`name`,key:`name`,title:`表單名稱`,width:220},{key:`status`,render:e=>(0,o.jsx)(m,{status:e.status}),title:`狀態`,width:120},{key:`currentVersionId`,render:e=>(0,o.jsx)(g,{record:e}),title:`目前版本`,width:220}],[]),z=(0,i.useMemo)(()=>({render:e=>[{name:`編輯`,onClick:()=>_.push(`/forms/${e.id}/builder`)}],variant:`base-secondary`,width:88}),[_]);async function B(e){D(!0),x(null);try{let t=await(0,l.createFormDefinition)(e);T(!1),_.push(`/forms/${t}/builder`)}finally{D(!1)}}return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsxs)(a.Layout,{children:[(0,o.jsx)(e.t,{activeHref:`/forms`}),(0,o.jsxs)(a.Layout.Main,{children:[(0,o.jsx)(a.PageHeader,{children:(0,o.jsx)(c.default,{description:`建立表單定義、管理草稿與已發布版本,提供流程模板綁定使用。`,title:`表單設計`,children:(0,o.jsx)(a.Button,{disabled:E,icon:s.PlusIcon,iconType:`leading`,onClick:()=>T(!0),variant:`base-primary`,children:`建立表單`})})}),(0,o.jsx)(a.SectionGroup,{children:(0,o.jsxs)(a.Section,{tab:(0,o.jsx)(a.Tab,{activeKey:M,onChange:e=>{N(h(e)),k(1)},children:d.map(e=>(0,o.jsx)(a.TabItem,{children:e.label},e.key))}),children:[b?(0,o.jsx)(a.Typography,{color:`text-error`,variant:`body`,children:b}):null,(0,o.jsx)(a.Table,{columns:R,actions:z,dataSource:L,fullWidth:!0,loading:S,pagination:{current:O,onChange:e=>{k(e)},onChangePageSize:e=>{k(1),j(e)},pageSize:A,pageSizeLabel:`每頁筆數`,pageSizeOptions:u,renderResultSummary:(e,t,n)=>`顯示 ${e}-${t} 筆,共 ${n} 筆`,showPageSizeOptions:!0,total:P}})]})})]})]}),(0,o.jsx)(r.t,{confirmText:`建立`,initialName:``,loading:E,onClose:()=>T(!1),onSubmit:B,open:w,title:`建立表單`})]})}function p(e){return e instanceof Error?e.message:`發生未知錯誤`}function m({status:e}){return e===`PUBLISHED`?(0,o.jsx)(a.Badge,{size:`sub`,text:`已發布`,variant:`dot-success`}):(0,o.jsx)(a.Badge,{size:`sub`,text:`草稿`,variant:`dot-warning`})}function h(e){return e===`PUBLISHED`||e===`DRAFT`?e:`ALL`}function g({record:e}){if(!e.currentVersionId||!e.currentVersionNumber)return(0,o.jsx)(a.Typography,{variant:`body`,children:`尚未發布`});let t=e.currentVersionPublishedAt??e.currentVersionCreatedAt;return(0,o.jsxs)(a.Typography,{variant:`body`,children:[`v`,e.currentVersionNumber,t?` · ${n.t(t)}`:``]})}Object.defineProperty(exports,"t",{enumerable:!0,get:function(){return f}});
|
|
2
|
+
//# sourceMappingURL=FormsView-RjJEkIfZ.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FormsView-RjJEkIfZ.cjs","names":[],"sources":["../../src/views/forms/FormsView.tsx"],"sourcesContent":["'use client';\n\nimport type { Key, ReactElement } from 'react';\nimport { useCallback, useEffect, useMemo, useState } from 'react';\nimport {\n Badge,\n Button,\n Layout,\n PageHeader,\n Section,\n SectionGroup,\n Tab,\n TabItem,\n Table,\n Typography,\n} from '@mezzanine-ui/react';\nimport ContentHeader from '@mezzanine-ui/react/ContentHeader';\nimport { PlusIcon } from '@mezzanine-ui/icons';\nimport type { TableActions, TableColumn } from '@mezzanine-ui/core/table';\nimport { formatDateTime } from '../../lib/format-date-time';\nimport { AppNavigation } from '../../components/app-navigation';\nimport {\n createFormDefinition,\n FormDefinitionListStatus,\n FormDefinitionRecord,\n listFormDefinitionsPage,\n} from '@rytass/bpm-core-client/form';\nimport { useRouterAdapter } from '../../lib/router-adapter';\nimport { FormNameModal } from './form-name-modal';\n\nconst FORM_PAGE_SIZE_OPTIONS = [10, 20, 50];\nconst FORM_STATUS_TABS: readonly {\n readonly key: FormStatusTabKey;\n readonly label: string;\n}[] = [\n { key: 'ALL', label: '全部' },\n { key: 'PUBLISHED', label: '已發布' },\n { key: 'DRAFT', label: '草稿' },\n];\n\ntype FormDefinitionRow = Readonly<\n Record<string, unknown> &\n FormDefinitionRecord & {\n key: string;\n status: FormDefinitionListStatus;\n }\n>;\n\ntype FormStatusTabKey = 'ALL' | FormDefinitionListStatus;\n\nexport interface FormsViewProps {}\n\nexport function FormsView(_props: FormsViewProps = {}): ReactElement {\n const router = useRouterAdapter();\n const [forms, setForms] = useState<readonly FormDefinitionRecord[]>([]);\n const [error, setError] = useState<string | null>(null);\n const [loading, setLoading] = useState(true);\n const [createModalOpen, setCreateModalOpen] = useState(false);\n const [creating, setCreating] = useState(false);\n const [formPage, setFormPage] = useState(1);\n const [formPageSize, setFormPageSize] = useState(10);\n const [formStatus, setFormStatus] = useState<FormStatusTabKey>('ALL');\n const [formTotalCount, setFormTotalCount] = useState(0);\n\n const refreshForms = useCallback(async (): Promise<void> => {\n setLoading(true);\n setError(null);\n\n try {\n const result = await listFormDefinitionsPage({\n page: formPage,\n pageSize: formPageSize,\n status: formStatus === 'ALL' ? null : formStatus,\n });\n\n setForms(result.forms);\n setFormTotalCount(result.totalCount);\n } catch (requestError: unknown) {\n setError(readErrorMessage(requestError));\n } finally {\n setLoading(false);\n }\n }, [formPage, formPageSize, formStatus]);\n\n useEffect((): void => {\n void refreshForms();\n }, [refreshForms]);\n\n const rows = useMemo(\n (): FormDefinitionRow[] =>\n forms.map((form) => ({\n ...form,\n key: form.id,\n status: form.currentVersionId ? 'PUBLISHED' : 'DRAFT',\n updatedAt: formatDateTime(form.updatedAt),\n })),\n [forms],\n );\n const columns = useMemo(\n (): TableColumn<FormDefinitionRow>[] => [\n { dataIndex: 'name', key: 'name', title: '表單名稱', width: 220 },\n {\n key: 'status',\n render: (record: FormDefinitionRow): ReactElement => (\n <FormStatusBadge status={record.status} />\n ),\n title: '狀態',\n width: 120,\n },\n {\n key: 'currentVersionId',\n render: (record: FormDefinitionRow): ReactElement => (\n <CurrentVersionLabel record={record} />\n ),\n title: '目前版本',\n width: 220,\n },\n ],\n [],\n );\n const tableActions = useMemo(\n (): TableActions<FormDefinitionRow> => ({\n render: (\n record,\n ): ReturnType<TableActions<FormDefinitionRow>['render']> => [\n {\n name: '編輯',\n onClick: (): void => router.push(`/forms/${record.id}/builder`),\n },\n ],\n variant: 'base-secondary',\n width: 88,\n }),\n [router],\n );\n\n async function handleCreateForm(name: string): Promise<void> {\n setCreating(true);\n setError(null);\n\n try {\n const formId = await createFormDefinition(name);\n setCreateModalOpen(false);\n router.push(`/forms/${formId}/builder`);\n } finally {\n setCreating(false);\n }\n }\n\n return (\n <>\n <Layout>\n <AppNavigation activeHref=\"/forms\" />\n\n <Layout.Main>\n <PageHeader>\n <ContentHeader\n description=\"建立表單定義、管理草稿與已發布版本,提供流程模板綁定使用。\"\n title=\"表單設計\"\n >\n <Button\n disabled={creating}\n icon={PlusIcon}\n iconType=\"leading\"\n onClick={(): void => setCreateModalOpen(true)}\n variant=\"base-primary\"\n >\n 建立表單\n </Button>\n </ContentHeader>\n </PageHeader>\n\n <SectionGroup>\n <Section\n tab={\n <Tab\n activeKey={formStatus}\n onChange={(activeKey): void => {\n setFormStatus(readFormStatusTabKey(activeKey));\n setFormPage(1);\n }}\n >\n {FORM_STATUS_TABS.map((statusTab) => (\n <TabItem key={statusTab.key}>{statusTab.label}</TabItem>\n ))}\n </Tab>\n }\n >\n {error ? (\n <Typography color=\"text-error\" variant=\"body\">\n {error}\n </Typography>\n ) : null}\n <Table\n columns={columns}\n actions={tableActions}\n dataSource={rows}\n fullWidth\n loading={loading}\n pagination={{\n current: formPage,\n onChange: (page): void => {\n setFormPage(page);\n },\n onChangePageSize: (pageSize): void => {\n setFormPage(1);\n setFormPageSize(pageSize);\n },\n pageSize: formPageSize,\n pageSizeLabel: '每頁筆數',\n pageSizeOptions: FORM_PAGE_SIZE_OPTIONS,\n renderResultSummary: (from, to, total): string =>\n `顯示 ${from}-${to} 筆,共 ${total} 筆`,\n showPageSizeOptions: true,\n total: formTotalCount,\n }}\n />\n </Section>\n </SectionGroup>\n </Layout.Main>\n </Layout>\n\n <FormNameModal\n confirmText=\"建立\"\n initialName=\"\"\n loading={creating}\n onClose={(): void => setCreateModalOpen(false)}\n onSubmit={handleCreateForm}\n open={createModalOpen}\n title=\"建立表單\"\n />\n </>\n );\n}\n\nfunction readErrorMessage(error: unknown): string {\n return error instanceof Error ? error.message : '發生未知錯誤';\n}\n\nfunction FormStatusBadge({\n status,\n}: {\n readonly status: FormDefinitionListStatus;\n}): ReactElement {\n if (status === 'PUBLISHED') {\n return <Badge size=\"sub\" text=\"已發布\" variant=\"dot-success\" />;\n }\n\n return <Badge size=\"sub\" text=\"草稿\" variant=\"dot-warning\" />;\n}\n\nfunction readFormStatusTabKey(activeKey: Key): FormStatusTabKey {\n if (activeKey === 'PUBLISHED' || activeKey === 'DRAFT') {\n return activeKey;\n }\n\n return 'ALL';\n}\n\nfunction CurrentVersionLabel({\n record,\n}: {\n readonly record: FormDefinitionRow;\n}): ReactElement {\n if (!record.currentVersionId || !record.currentVersionNumber) {\n return <Typography variant=\"body\">尚未發布</Typography>;\n }\n\n const versionTime =\n record.currentVersionPublishedAt ?? record.currentVersionCreatedAt;\n\n return (\n <Typography variant=\"body\">\n v{record.currentVersionNumber}\n {versionTime ? ` · ${formatDateTime(versionTime)}` : ''}\n </Typography>\n );\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use client";const e=require("./app-navigation-DAC5gFbG.cjs"),t=require("./router-adapter-BybHrCNP.cjs"),n=require("./auth-provider-D2P-qWmY.cjs"),r=require("./format-date-time-BQyH5U8z.cjs");let i=require("react"),a=require("@mezzanine-ui/react"),o=require("react/jsx-runtime"),s=require("@rytass/bpm-core-client/workflow"),c=require("@mezzanine-ui/icons"),l=require("@mezzanine-ui/react/ContentHeader");l=e.o(l,1);function u(u={}){let p=t.r(),{member:m}=n.n(),h=m?.memberId??null,[g,_]=(0,i.useState)(`pending`),[y,x]=(0,i.useState)(null),[C,w]=(0,i.useState)([]),[T,E]=(0,i.useState)(!0),[O,k]=(0,i.useState)([]);(0,i.useEffect)(()=>{h&&I()},[h]);let A=(0,i.useMemo)(()=>[{dataIndex:`caseTitle`,key:`caseTitle`,title:`案件`,width:280},{dataIndex:`nodeId`,key:`nodeId`,title:`節點`,width:180},{dataIndex:`statusLabel`,key:`statusLabel`,title:`狀態`,width:120},{key:`slaDueAt`,render:e=>(0,o.jsx)(a.Typography,{color:e.slaStatusColor,component:`span`,variant:`body`,children:e.slaStatusText}),title:`SLA`,width:180},{key:`createdAt`,render:e=>(0,o.jsx)(a.Typography,{component:`span`,variant:`body`,children:r.t(e.createdAt)}),title:`建立時間`,width:220}],[]),j=(0,i.useMemo)(()=>({render:e=>[{name:`處理`,onClick:()=>p.push(`/instances/${e.instanceId}`)}],variant:`base-secondary`,width:88}),[p]),M=(0,i.useMemo)(()=>[{dataIndex:`caseTitle`,key:`caseTitle`,title:`案件`,width:280},{dataIndex:`nodeId`,key:`nodeId`,title:`節點`,width:180},{key:`decisionLabel`,render:e=>(0,o.jsx)(a.Typography,{color:v(e.decisionAction),component:`span`,variant:`body`,children:e.decisionLabel}),title:`決議`,width:120},{key:`decisionComment`,render:e=>(0,o.jsx)(a.Typography,{component:`span`,variant:`body`,children:e.decisionCommentText}),title:`意見`,width:240},{key:`instanceStateLabel`,render:e=>(0,o.jsx)(a.Typography,{color:b(e.instanceState),component:`span`,variant:`body`,children:e.instanceStateLabel}),title:`流程狀態`,width:140},{key:`decidedAt`,render:e=>(0,o.jsx)(a.Typography,{component:`span`,variant:`body`,children:S(e.decidedAt)}),title:`簽核時間`,width:220}],[]),N=(0,i.useMemo)(()=>({render:e=>[{name:`查看`,onClick:()=>p.push(`/instances/${e.instanceId}`)}],variant:`base-secondary`,width:88}),[p]),P=(0,i.useMemo)(()=>C.filter(e=>e.instanceState===`RUNNING`),[C]);function F(e){if(e===`history`||e===`pending`||e===`tracking`){_(e);return}_(`pending`)}async function I(){E(!0),x(null);try{if(!h){k([]),w([]);return}let[e,t]=await Promise.all([(0,s.listInboxTasks)(h),(0,s.listApprovalHistoryTasks)(h)]),[n,r]=await Promise.all([d(e),f(t)]);k(n),w(r)}catch(e){x(D(e))}finally{E(!1)}}return(0,o.jsxs)(a.Layout,{children:[(0,o.jsx)(e.t,{activeHref:`/inbox`}),(0,o.jsxs)(a.Layout.Main,{children:[(0,o.jsx)(a.PageHeader,{children:(0,o.jsx)(l.default,{description:`目前以 ${m?.name??h??`目前登入會員`} 查詢待處理與歷史簽核任務。`,title:`我的待簽`,children:(0,o.jsx)(a.Button,{icon:c.PlusIcon,iconType:`leading`,onClick:()=>p.push(`/instances/new`),variant:`base-primary`,children:`發起簽核`})})}),(0,o.jsx)(a.SectionGroup,{children:(0,o.jsxs)(a.Section,{children:[y?(0,o.jsx)(a.Typography,{color:`text-error`,variant:`body`,children:y}):null,(0,o.jsxs)(a.Tab,{activeKey:g,onChange:F,size:`sub`,children:[(0,o.jsx)(a.TabItem,{badgeCount:T?void 0:O.length,children:`待簽核`},`pending`),(0,o.jsx)(a.TabItem,{badgeCount:T?void 0:P.length,children:`已處理未結束`},`tracking`),(0,o.jsx)(a.TabItem,{children:`歷史簽核記錄`},`history`)]}),g===`pending`?(0,o.jsx)(a.Table,{actions:j,columns:A,dataSource:O,fullWidth:!0,loading:T}):null,g===`tracking`?(0,o.jsx)(a.Table,{actions:N,columns:M,dataSource:P,fullWidth:!0,loading:T}):null,g===`history`?(0,o.jsx)(a.Table,{actions:N,columns:M,dataSource:C,fullWidth:!0,loading:T}):null]})})]})]})}async function d(e){let t=await p(e);return e.map((e,n)=>({...e,caseTitle:m(e,t[n]??null),key:e.id,slaStatusColor:w(e.slaDueAt),slaStatusText:C(e.slaDueAt),statusLabel:E(e.status)}))}async function f(e){let[t,n]=await Promise.all([Promise.all(e.map(e=>(0,s.listTaskDecisions)(e.id))),p(e)]);return e.map((e,r)=>{let i=h(t[r]??[]),a=n[r]??null;return{...e,caseTitle:m(e,a),decisionAction:i?.action??null,decisionComment:i?.comment??null,decisionCommentText:x(i?.comment??null),decisionLabel:_(i?.action??null),decidedAt:i?.decidedAt??e.completedAt,instanceState:a?.state??null,instanceStateLabel:y(a?.state??null),key:e.id}})}async function p(e){return Promise.all(e.map(async e=>{try{return(await(0,s.readApprovalInstance)(e.instanceId)).instance}catch{return null}}))}function m(e,t){return t?(0,s.readApprovalInstanceCaseTitle)(t):e.instanceId}function h(e){return[...e].sort(g)[0]??null}function g(e,t){return new Date(t.decidedAt).getTime()-new Date(e.decidedAt).getTime()}function _(e){return e===`APPROVED`?`同意`:e===`REJECTED`?`拒絕`:e===`RETURNED`?`退回`:e===`TRANSFERRED`?`轉派`:`未記錄`}function v(e){return e===`APPROVED`?`text-success`:e===`REJECTED`||e===`RETURNED`?`text-error`:`text-neutral`}function y(e){return e===`RUNNING`?`進行中`:e===`APPROVED`?`已通過`:e===`REJECTED`?`已拒絕`:e===`RETURNED`?`已退回`:e===`CANCELLED`?`已取消`:e===`EXPIRED`?`已逾期`:e===`DRAFT`?`草稿`:`-`}function b(e){return e===`APPROVED`?`text-success`:e===`REJECTED`||e===`CANCELLED`||e===`EXPIRED`?`text-error`:`text-neutral`}function x(e){return(e?.trim()??``)||`-`}function S(e){return r.t(e)}function C(e){if(!e)return`-`;let t=new Date(e).getTime(),n=Date.now(),r=T(Math.abs(t-n));return t<n?`已逾期 ${r}`:`剩餘 ${r}`}function w(e){return e?new Date(e).getTime()<Date.now()?`text-error`:`text-success`:`text-neutral`}function T(e){let t=Math.max(1,Math.ceil(e/6e4)),n=Math.floor(t/1440),r=Math.floor(t%1440/60),i=t%60;return n>0?`${n}天 ${r}小時`:r>0?`${r}小時 ${i}分鐘`:`${i}分鐘`}function E(e){return e===`PENDING`?`待處理`:e===`IN_PROGRESS`?`處理中`:e===`COMPLETED`?`已完成`:e===`TRANSFERRED`?`已轉派`:e===`CANCELLED`?`已取消`:e}function D(e){return e instanceof Error?e.message:`發生未知錯誤`}Object.defineProperty(exports,"t",{enumerable:!0,get:function(){return u}});
|
|
2
|
+
//# sourceMappingURL=InboxView-DDWwmWhA.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"InboxView-DDWwmWhA.cjs","names":[],"sources":["../../src/views/inbox/InboxView.tsx"],"sourcesContent":["'use client';\n\nimport { type Key, ReactElement, useEffect, useMemo, useState } from 'react';\nimport {\n Button,\n Layout,\n PageHeader,\n Section,\n SectionGroup,\n Tab,\n TabItem,\n Table,\n Typography,\n} from '@mezzanine-ui/react';\nimport ContentHeader from '@mezzanine-ui/react/ContentHeader';\nimport { PlusIcon } from '@mezzanine-ui/icons';\nimport type { TableActions, TableColumn } from '@mezzanine-ui/core/table';\nimport {\n ApprovalInstanceRecord,\n listApprovalHistoryTasks,\n listInboxTasks,\n listTaskDecisions,\n readApprovalInstance,\n readApprovalInstanceCaseTitle,\n TaskDecisionRecord,\n TaskRecord,\n} from '@rytass/bpm-core-client/workflow';\nimport { formatDateTime } from '../../lib/format-date-time';\nimport { useAuth } from '../../lib/auth-provider';\nimport { useRouterAdapter } from '../../lib/router-adapter';\nimport { AppNavigation } from '../../components/app-navigation';\n\ntype InboxTabKey = 'history' | 'pending' | 'tracking';\n\ntype InboxTaskRow = Readonly<\n Record<string, unknown> &\n TaskRecord & {\n caseTitle: string;\n key: string;\n slaStatusColor: 'text-error' | 'text-neutral' | 'text-success';\n slaStatusText: string;\n statusLabel: string;\n }\n>;\n\ntype ApprovalHistoryRow = Readonly<\n Record<string, unknown> &\n TaskRecord & {\n caseTitle: string;\n decisionAction: TaskDecisionRecord['action'] | null;\n decisionComment: string | null;\n decisionCommentText: string;\n decisionLabel: string;\n decidedAt: string | null;\n instanceState: ApprovalInstanceRecord['state'] | null;\n instanceStateLabel: string;\n key: string;\n }\n>;\n\nexport interface InboxViewProps {}\n\n/**\n * Framework-agnostic view for the BPM \"我的待簽\" inbox. Mechanical port of\n * `apps/client/src/app/inbox/page.tsx` — renders pending tasks, tracking,\n * and history tabs.\n */\nexport function InboxView(_props: InboxViewProps = {}): ReactElement {\n const router = useRouterAdapter();\n const { member } = useAuth();\n const currentMemberId = member?.memberId ?? null;\n const [activeTab, setActiveTab] = useState<InboxTabKey>('pending');\n const [error, setError] = useState<string | null>(null);\n const [historyRows, setHistoryRows] = useState<ApprovalHistoryRow[]>([]);\n const [loading, setLoading] = useState(true);\n const [pendingRows, setPendingRows] = useState<InboxTaskRow[]>([]);\n\n useEffect((): void => {\n if (!currentMemberId) {\n return;\n }\n\n void refreshTasks();\n }, [currentMemberId]);\n\n const pendingColumns = useMemo(\n (): TableColumn<InboxTaskRow>[] => [\n { dataIndex: 'caseTitle', key: 'caseTitle', title: '案件', width: 280 },\n { dataIndex: 'nodeId', key: 'nodeId', title: '節點', width: 180 },\n {\n dataIndex: 'statusLabel',\n key: 'statusLabel',\n title: '狀態',\n width: 120,\n },\n {\n key: 'slaDueAt',\n render: (record: InboxTaskRow): ReactElement => (\n <Typography\n color={record.slaStatusColor}\n component=\"span\"\n variant=\"body\"\n >\n {record.slaStatusText}\n </Typography>\n ),\n title: 'SLA',\n width: 180,\n },\n {\n key: 'createdAt',\n render: (record: InboxTaskRow): ReactElement => (\n <Typography component=\"span\" variant=\"body\">\n {formatDateTime(record.createdAt)}\n </Typography>\n ),\n title: '建立時間',\n width: 220,\n },\n ],\n [],\n );\n const pendingTableActions = useMemo(\n (): TableActions<InboxTaskRow> => ({\n render: (record): ReturnType<TableActions<InboxTaskRow>['render']> => [\n {\n name: '處理',\n onClick: (): void => router.push(`/instances/${record.instanceId}`),\n },\n ],\n variant: 'base-secondary',\n width: 88,\n }),\n [router],\n );\n const historyColumns = useMemo(\n (): TableColumn<ApprovalHistoryRow>[] => [\n { dataIndex: 'caseTitle', key: 'caseTitle', title: '案件', width: 280 },\n { dataIndex: 'nodeId', key: 'nodeId', title: '節點', width: 180 },\n {\n key: 'decisionLabel',\n render: (record: ApprovalHistoryRow): ReactElement => (\n <Typography\n color={readTaskDecisionColor(record.decisionAction)}\n component=\"span\"\n variant=\"body\"\n >\n {record.decisionLabel}\n </Typography>\n ),\n title: '決議',\n width: 120,\n },\n {\n key: 'decisionComment',\n render: (record: ApprovalHistoryRow): ReactElement => (\n <Typography component=\"span\" variant=\"body\">\n {record.decisionCommentText}\n </Typography>\n ),\n title: '意見',\n width: 240,\n },\n {\n key: 'instanceStateLabel',\n render: (record: ApprovalHistoryRow): ReactElement => (\n <Typography\n color={readInstanceStateColor(record.instanceState)}\n component=\"span\"\n variant=\"body\"\n >\n {record.instanceStateLabel}\n </Typography>\n ),\n title: '流程狀態',\n width: 140,\n },\n {\n key: 'decidedAt',\n render: (record: ApprovalHistoryRow): ReactElement => (\n <Typography component=\"span\" variant=\"body\">\n {formatHistoryDateTime(record.decidedAt)}\n </Typography>\n ),\n title: '簽核時間',\n width: 220,\n },\n ],\n [],\n );\n const historyTableActions = useMemo(\n (): TableActions<ApprovalHistoryRow> => ({\n render: (\n record,\n ): ReturnType<TableActions<ApprovalHistoryRow>['render']> => [\n {\n name: '查看',\n onClick: (): void => router.push(`/instances/${record.instanceId}`),\n },\n ],\n variant: 'base-secondary',\n width: 88,\n }),\n [router],\n );\n const trackingRows = useMemo(\n (): ApprovalHistoryRow[] =>\n historyRows.filter((row) => row.instanceState === 'RUNNING'),\n [historyRows],\n );\n\n function handleTabChange(activeKey: Key): void {\n if (\n activeKey === 'history' ||\n activeKey === 'pending' ||\n activeKey === 'tracking'\n ) {\n setActiveTab(activeKey);\n return;\n }\n\n setActiveTab('pending');\n }\n\n async function refreshTasks(): Promise<void> {\n setLoading(true);\n setError(null);\n\n try {\n if (!currentMemberId) {\n setPendingRows([]);\n setHistoryRows([]);\n return;\n }\n\n const [nextPendingTasks, nextHistoryTasks] = await Promise.all([\n listInboxTasks(currentMemberId),\n listApprovalHistoryTasks(currentMemberId),\n ]);\n const [nextPendingRows, nextHistoryRows] = await Promise.all([\n readInboxTaskRows(nextPendingTasks),\n readApprovalHistoryRows(nextHistoryTasks),\n ]);\n\n setPendingRows(nextPendingRows);\n setHistoryRows(nextHistoryRows);\n } catch (requestError: unknown) {\n setError(readErrorMessage(requestError));\n } finally {\n setLoading(false);\n }\n }\n\n return (\n <Layout>\n <AppNavigation activeHref=\"/inbox\" />\n\n <Layout.Main>\n <PageHeader>\n <ContentHeader\n description={`目前以 ${member?.name ?? currentMemberId ?? '目前登入會員'} 查詢待處理與歷史簽核任務。`}\n title=\"我的待簽\"\n >\n <Button\n icon={PlusIcon}\n iconType=\"leading\"\n onClick={(): void => router.push('/instances/new')}\n variant=\"base-primary\"\n >\n 發起簽核\n </Button>\n </ContentHeader>\n </PageHeader>\n\n <SectionGroup>\n <Section>\n {error ? (\n <Typography color=\"text-error\" variant=\"body\">\n {error}\n </Typography>\n ) : null}\n <Tab activeKey={activeTab} onChange={handleTabChange} size=\"sub\">\n <TabItem\n badgeCount={loading ? undefined : pendingRows.length}\n key=\"pending\"\n >\n 待簽核\n </TabItem>\n <TabItem\n badgeCount={loading ? undefined : trackingRows.length}\n key=\"tracking\"\n >\n 已處理未結束\n </TabItem>\n <TabItem key=\"history\">歷史簽核記錄</TabItem>\n </Tab>\n\n {activeTab === 'pending' ? (\n <Table\n actions={pendingTableActions}\n columns={pendingColumns}\n dataSource={pendingRows}\n fullWidth\n loading={loading}\n />\n ) : null}\n {activeTab === 'tracking' ? (\n <Table\n actions={historyTableActions}\n columns={historyColumns}\n dataSource={trackingRows}\n fullWidth\n loading={loading}\n />\n ) : null}\n {activeTab === 'history' ? (\n <Table\n actions={historyTableActions}\n columns={historyColumns}\n dataSource={historyRows}\n fullWidth\n loading={loading}\n />\n ) : null}\n </Section>\n </SectionGroup>\n </Layout.Main>\n </Layout>\n );\n}\n\nasync function readInboxTaskRows(\n tasks: readonly TaskRecord[],\n): Promise<InboxTaskRow[]> {\n const instances = await readTaskInstances(tasks);\n\n return tasks.map(\n (task, index): InboxTaskRow => ({\n ...task,\n caseTitle: readTaskCaseTitle(task, instances[index] ?? null),\n key: task.id,\n slaStatusColor: readSlaStatusColor(task.slaDueAt),\n slaStatusText: readSlaStatusText(task.slaDueAt),\n statusLabel: readTaskStatusLabel(task.status),\n }),\n );\n}\n\nasync function readApprovalHistoryRows(\n tasks: readonly TaskRecord[],\n): Promise<ApprovalHistoryRow[]> {\n const [decisionLists, instances] = await Promise.all([\n Promise.all(tasks.map((task) => listTaskDecisions(task.id))),\n readTaskInstances(tasks),\n ]);\n\n return tasks.map((task, index): ApprovalHistoryRow => {\n const decision = readLatestTaskDecision(decisionLists[index] ?? []);\n const instance = instances[index] ?? null;\n\n return {\n ...task,\n caseTitle: readTaskCaseTitle(task, instance),\n decisionAction: decision?.action ?? null,\n decisionComment: decision?.comment ?? null,\n decisionCommentText: readDecisionCommentText(decision?.comment ?? null),\n decisionLabel: readTaskDecisionLabel(decision?.action ?? null),\n decidedAt: decision?.decidedAt ?? task.completedAt,\n instanceState: instance?.state ?? null,\n instanceStateLabel: readInstanceStateLabel(instance?.state ?? null),\n key: task.id,\n };\n });\n}\n\nasync function readTaskInstances(\n tasks: readonly TaskRecord[],\n): Promise<readonly (ApprovalInstanceRecord | null)[]> {\n return Promise.all(\n tasks.map(async (task): Promise<ApprovalInstanceRecord | null> => {\n try {\n return (await readApprovalInstance(task.instanceId)).instance;\n } catch {\n return null;\n }\n }),\n );\n}\n\nfunction readTaskCaseTitle(\n task: TaskRecord,\n instance: ApprovalInstanceRecord | null,\n): string {\n return instance ? readApprovalInstanceCaseTitle(instance) : task.instanceId;\n}\n\nfunction readLatestTaskDecision(\n decisions: readonly TaskDecisionRecord[],\n): TaskDecisionRecord | null {\n return [...decisions].sort(compareTaskDecisionDesc)[0] ?? null;\n}\n\nfunction compareTaskDecisionDesc(\n left: TaskDecisionRecord,\n right: TaskDecisionRecord,\n): number {\n return (\n new Date(right.decidedAt).getTime() - new Date(left.decidedAt).getTime()\n );\n}\n\nfunction readTaskDecisionLabel(\n action: TaskDecisionRecord['action'] | null,\n): string {\n if (action === 'APPROVED') {\n return '同意';\n }\n\n if (action === 'REJECTED') {\n return '拒絕';\n }\n\n if (action === 'RETURNED') {\n return '退回';\n }\n\n if (action === 'TRANSFERRED') {\n return '轉派';\n }\n\n return '未記錄';\n}\n\nfunction readTaskDecisionColor(\n action: TaskDecisionRecord['action'] | null,\n): 'text-error' | 'text-neutral' | 'text-success' {\n if (action === 'APPROVED') {\n return 'text-success';\n }\n\n if (action === 'REJECTED' || action === 'RETURNED') {\n return 'text-error';\n }\n\n return 'text-neutral';\n}\n\nfunction readInstanceStateLabel(\n state: ApprovalInstanceRecord['state'] | null,\n): string {\n if (state === 'RUNNING') {\n return '進行中';\n }\n\n if (state === 'APPROVED') {\n return '已通過';\n }\n\n if (state === 'REJECTED') {\n return '已拒絕';\n }\n\n if (state === 'RETURNED') {\n return '已退回';\n }\n\n if (state === 'CANCELLED') {\n return '已取消';\n }\n\n if (state === 'EXPIRED') {\n return '已逾期';\n }\n\n if (state === 'DRAFT') {\n return '草稿';\n }\n\n return '-';\n}\n\nfunction readInstanceStateColor(\n state: ApprovalInstanceRecord['state'] | null,\n): 'text-error' | 'text-neutral' | 'text-success' {\n if (state === 'APPROVED') {\n return 'text-success';\n }\n\n if (state === 'REJECTED' || state === 'CANCELLED' || state === 'EXPIRED') {\n return 'text-error';\n }\n\n return 'text-neutral';\n}\n\nfunction readDecisionCommentText(comment: string | null): string {\n const trimmedComment = comment?.trim() ?? '';\n\n return trimmedComment || '-';\n}\n\nfunction formatHistoryDateTime(value: string | null): string {\n return formatDateTime(value);\n}\n\nfunction readSlaStatusText(value: string | null): string {\n if (!value) {\n return '-';\n }\n\n const dueAt = new Date(value).getTime();\n const now = Date.now();\n const diffMs = Math.abs(dueAt - now);\n const label = formatDuration(diffMs);\n\n return dueAt < now ? `已逾期 ${label}` : `剩餘 ${label}`;\n}\n\nfunction readSlaStatusColor(\n value: string | null,\n): 'text-error' | 'text-neutral' | 'text-success' {\n if (!value) {\n return 'text-neutral';\n }\n\n return new Date(value).getTime() < Date.now() ? 'text-error' : 'text-success';\n}\n\nfunction formatDuration(value: number): string {\n const totalMinutes = Math.max(1, Math.ceil(value / 60_000));\n const days = Math.floor(totalMinutes / 1440);\n const hours = Math.floor((totalMinutes % 1440) / 60);\n const minutes = totalMinutes % 60;\n\n if (days > 0) {\n return `${days}天 ${hours}小時`;\n }\n\n if (hours > 0) {\n return `${hours}小時 ${minutes}分鐘`;\n }\n\n return `${minutes}分鐘`;\n}\n\nfunction readTaskStatusLabel(status: TaskRecord['status']): string {\n if (status === 'PENDING') {\n return '待處理';\n }\n\n if (status === 'IN_PROGRESS') {\n return '處理中';\n }\n\n if (status === 'COMPLETED') {\n return '已完成';\n }\n\n if (status === 'TRANSFERRED') {\n return '已轉派';\n }\n\n if (status === 'CANCELLED') {\n return '已取消';\n }\n\n return status;\n}\n\nfunction readErrorMessage(error: unknown): string {\n return error instanceof Error ? error.message : '發生未知錯誤';\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,291 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { r as e } from "./router-adapter-BdHZXLS3.js";
|
|
3
|
+
import { n as t } from "./auth-provider-TTO9eNZV.js";
|
|
4
|
+
import { t as n } from "./format-date-time-CB-LxzqT.js";
|
|
5
|
+
import { t as r } from "./app-navigation-CATITRM7.js";
|
|
6
|
+
import { useEffect as i, useMemo as a, useState as o } from "react";
|
|
7
|
+
import { Button as s, Layout as c, PageHeader as l, Section as u, SectionGroup as d, Tab as f, TabItem as p, Table as m, Typography as h } from "@mezzanine-ui/react";
|
|
8
|
+
import { jsx as g, jsxs as _ } from "react/jsx-runtime";
|
|
9
|
+
import { listApprovalHistoryTasks as v, listInboxTasks as y, listTaskDecisions as b, readApprovalInstance as x, readApprovalInstanceCaseTitle as S } from "@rytass/bpm-core-client/workflow";
|
|
10
|
+
import { PlusIcon as C } from "@mezzanine-ui/icons";
|
|
11
|
+
import w from "@mezzanine-ui/react/ContentHeader";
|
|
12
|
+
//#region src/views/inbox/InboxView.tsx
|
|
13
|
+
function T(b = {}) {
|
|
14
|
+
let x = e(), { member: S } = t(), T = S?.memberId ?? null, [O, k] = o("pending"), [A, j] = o(null), [M, P] = o([]), [I, R] = o(!0), [z, B] = o([]);
|
|
15
|
+
i(() => {
|
|
16
|
+
T && J();
|
|
17
|
+
}, [T]);
|
|
18
|
+
let V = a(() => [
|
|
19
|
+
{
|
|
20
|
+
dataIndex: "caseTitle",
|
|
21
|
+
key: "caseTitle",
|
|
22
|
+
title: "案件",
|
|
23
|
+
width: 280
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
dataIndex: "nodeId",
|
|
27
|
+
key: "nodeId",
|
|
28
|
+
title: "節點",
|
|
29
|
+
width: 180
|
|
30
|
+
},
|
|
31
|
+
{
|
|
32
|
+
dataIndex: "statusLabel",
|
|
33
|
+
key: "statusLabel",
|
|
34
|
+
title: "狀態",
|
|
35
|
+
width: 120
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
key: "slaDueAt",
|
|
39
|
+
render: (e) => /* @__PURE__ */ g(h, {
|
|
40
|
+
color: e.slaStatusColor,
|
|
41
|
+
component: "span",
|
|
42
|
+
variant: "body",
|
|
43
|
+
children: e.slaStatusText
|
|
44
|
+
}),
|
|
45
|
+
title: "SLA",
|
|
46
|
+
width: 180
|
|
47
|
+
},
|
|
48
|
+
{
|
|
49
|
+
key: "createdAt",
|
|
50
|
+
render: (e) => /* @__PURE__ */ g(h, {
|
|
51
|
+
component: "span",
|
|
52
|
+
variant: "body",
|
|
53
|
+
children: n(e.createdAt)
|
|
54
|
+
}),
|
|
55
|
+
title: "建立時間",
|
|
56
|
+
width: 220
|
|
57
|
+
}
|
|
58
|
+
], []), U = a(() => ({
|
|
59
|
+
render: (e) => [{
|
|
60
|
+
name: "處理",
|
|
61
|
+
onClick: () => x.push(`/instances/${e.instanceId}`)
|
|
62
|
+
}],
|
|
63
|
+
variant: "base-secondary",
|
|
64
|
+
width: 88
|
|
65
|
+
}), [x]), W = a(() => [
|
|
66
|
+
{
|
|
67
|
+
dataIndex: "caseTitle",
|
|
68
|
+
key: "caseTitle",
|
|
69
|
+
title: "案件",
|
|
70
|
+
width: 280
|
|
71
|
+
},
|
|
72
|
+
{
|
|
73
|
+
dataIndex: "nodeId",
|
|
74
|
+
key: "nodeId",
|
|
75
|
+
title: "節點",
|
|
76
|
+
width: 180
|
|
77
|
+
},
|
|
78
|
+
{
|
|
79
|
+
key: "decisionLabel",
|
|
80
|
+
render: (e) => /* @__PURE__ */ g(h, {
|
|
81
|
+
color: N(e.decisionAction),
|
|
82
|
+
component: "span",
|
|
83
|
+
variant: "body",
|
|
84
|
+
children: e.decisionLabel
|
|
85
|
+
}),
|
|
86
|
+
title: "決議",
|
|
87
|
+
width: 120
|
|
88
|
+
},
|
|
89
|
+
{
|
|
90
|
+
key: "decisionComment",
|
|
91
|
+
render: (e) => /* @__PURE__ */ g(h, {
|
|
92
|
+
component: "span",
|
|
93
|
+
variant: "body",
|
|
94
|
+
children: e.decisionCommentText
|
|
95
|
+
}),
|
|
96
|
+
title: "意見",
|
|
97
|
+
width: 240
|
|
98
|
+
},
|
|
99
|
+
{
|
|
100
|
+
key: "instanceStateLabel",
|
|
101
|
+
render: (e) => /* @__PURE__ */ g(h, {
|
|
102
|
+
color: F(e.instanceState),
|
|
103
|
+
component: "span",
|
|
104
|
+
variant: "body",
|
|
105
|
+
children: e.instanceStateLabel
|
|
106
|
+
}),
|
|
107
|
+
title: "流程狀態",
|
|
108
|
+
width: 140
|
|
109
|
+
},
|
|
110
|
+
{
|
|
111
|
+
key: "decidedAt",
|
|
112
|
+
render: (e) => /* @__PURE__ */ g(h, {
|
|
113
|
+
component: "span",
|
|
114
|
+
variant: "body",
|
|
115
|
+
children: L(e.decidedAt)
|
|
116
|
+
}),
|
|
117
|
+
title: "簽核時間",
|
|
118
|
+
width: 220
|
|
119
|
+
}
|
|
120
|
+
], []), G = a(() => ({
|
|
121
|
+
render: (e) => [{
|
|
122
|
+
name: "查看",
|
|
123
|
+
onClick: () => x.push(`/instances/${e.instanceId}`)
|
|
124
|
+
}],
|
|
125
|
+
variant: "base-secondary",
|
|
126
|
+
width: 88
|
|
127
|
+
}), [x]), K = a(() => M.filter((e) => e.instanceState === "RUNNING"), [M]);
|
|
128
|
+
function q(e) {
|
|
129
|
+
if (e === "history" || e === "pending" || e === "tracking") {
|
|
130
|
+
k(e);
|
|
131
|
+
return;
|
|
132
|
+
}
|
|
133
|
+
k("pending");
|
|
134
|
+
}
|
|
135
|
+
async function J() {
|
|
136
|
+
R(!0), j(null);
|
|
137
|
+
try {
|
|
138
|
+
if (!T) {
|
|
139
|
+
B([]), P([]);
|
|
140
|
+
return;
|
|
141
|
+
}
|
|
142
|
+
let [e, t] = await Promise.all([y(T), v(T)]), [n, r] = await Promise.all([E(e), D(t)]);
|
|
143
|
+
B(n), P(r);
|
|
144
|
+
} catch (e) {
|
|
145
|
+
j(H(e));
|
|
146
|
+
} finally {
|
|
147
|
+
R(!1);
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
return /* @__PURE__ */ _(c, { children: [/* @__PURE__ */ g(r, { activeHref: "/inbox" }), /* @__PURE__ */ _(c.Main, { children: [/* @__PURE__ */ g(l, { children: /* @__PURE__ */ g(w, {
|
|
151
|
+
description: `目前以 ${S?.name ?? T ?? "目前登入會員"} 查詢待處理與歷史簽核任務。`,
|
|
152
|
+
title: "我的待簽",
|
|
153
|
+
children: /* @__PURE__ */ g(s, {
|
|
154
|
+
icon: C,
|
|
155
|
+
iconType: "leading",
|
|
156
|
+
onClick: () => x.push("/instances/new"),
|
|
157
|
+
variant: "base-primary",
|
|
158
|
+
children: "發起簽核"
|
|
159
|
+
})
|
|
160
|
+
}) }), /* @__PURE__ */ g(d, { children: /* @__PURE__ */ _(u, { children: [
|
|
161
|
+
A ? /* @__PURE__ */ g(h, {
|
|
162
|
+
color: "text-error",
|
|
163
|
+
variant: "body",
|
|
164
|
+
children: A
|
|
165
|
+
}) : null,
|
|
166
|
+
/* @__PURE__ */ _(f, {
|
|
167
|
+
activeKey: O,
|
|
168
|
+
onChange: q,
|
|
169
|
+
size: "sub",
|
|
170
|
+
children: [
|
|
171
|
+
/* @__PURE__ */ g(p, {
|
|
172
|
+
badgeCount: I ? void 0 : z.length,
|
|
173
|
+
children: "待簽核"
|
|
174
|
+
}, "pending"),
|
|
175
|
+
/* @__PURE__ */ g(p, {
|
|
176
|
+
badgeCount: I ? void 0 : K.length,
|
|
177
|
+
children: "已處理未結束"
|
|
178
|
+
}, "tracking"),
|
|
179
|
+
/* @__PURE__ */ g(p, { children: "歷史簽核記錄" }, "history")
|
|
180
|
+
]
|
|
181
|
+
}),
|
|
182
|
+
O === "pending" ? /* @__PURE__ */ g(m, {
|
|
183
|
+
actions: U,
|
|
184
|
+
columns: V,
|
|
185
|
+
dataSource: z,
|
|
186
|
+
fullWidth: !0,
|
|
187
|
+
loading: I
|
|
188
|
+
}) : null,
|
|
189
|
+
O === "tracking" ? /* @__PURE__ */ g(m, {
|
|
190
|
+
actions: G,
|
|
191
|
+
columns: W,
|
|
192
|
+
dataSource: K,
|
|
193
|
+
fullWidth: !0,
|
|
194
|
+
loading: I
|
|
195
|
+
}) : null,
|
|
196
|
+
O === "history" ? /* @__PURE__ */ g(m, {
|
|
197
|
+
actions: G,
|
|
198
|
+
columns: W,
|
|
199
|
+
dataSource: M,
|
|
200
|
+
fullWidth: !0,
|
|
201
|
+
loading: I
|
|
202
|
+
}) : null
|
|
203
|
+
] }) })] })] });
|
|
204
|
+
}
|
|
205
|
+
async function E(e) {
|
|
206
|
+
let t = await O(e);
|
|
207
|
+
return e.map((e, n) => ({
|
|
208
|
+
...e,
|
|
209
|
+
caseTitle: k(e, t[n] ?? null),
|
|
210
|
+
key: e.id,
|
|
211
|
+
slaStatusColor: z(e.slaDueAt),
|
|
212
|
+
slaStatusText: R(e.slaDueAt),
|
|
213
|
+
statusLabel: V(e.status)
|
|
214
|
+
}));
|
|
215
|
+
}
|
|
216
|
+
async function D(e) {
|
|
217
|
+
let [t, n] = await Promise.all([Promise.all(e.map((e) => b(e.id))), O(e)]);
|
|
218
|
+
return e.map((e, r) => {
|
|
219
|
+
let i = A(t[r] ?? []), a = n[r] ?? null;
|
|
220
|
+
return {
|
|
221
|
+
...e,
|
|
222
|
+
caseTitle: k(e, a),
|
|
223
|
+
decisionAction: i?.action ?? null,
|
|
224
|
+
decisionComment: i?.comment ?? null,
|
|
225
|
+
decisionCommentText: I(i?.comment ?? null),
|
|
226
|
+
decisionLabel: M(i?.action ?? null),
|
|
227
|
+
decidedAt: i?.decidedAt ?? e.completedAt,
|
|
228
|
+
instanceState: a?.state ?? null,
|
|
229
|
+
instanceStateLabel: P(a?.state ?? null),
|
|
230
|
+
key: e.id
|
|
231
|
+
};
|
|
232
|
+
});
|
|
233
|
+
}
|
|
234
|
+
async function O(e) {
|
|
235
|
+
return Promise.all(e.map(async (e) => {
|
|
236
|
+
try {
|
|
237
|
+
return (await x(e.instanceId)).instance;
|
|
238
|
+
} catch {
|
|
239
|
+
return null;
|
|
240
|
+
}
|
|
241
|
+
}));
|
|
242
|
+
}
|
|
243
|
+
function k(e, t) {
|
|
244
|
+
return t ? S(t) : e.instanceId;
|
|
245
|
+
}
|
|
246
|
+
function A(e) {
|
|
247
|
+
return [...e].sort(j)[0] ?? null;
|
|
248
|
+
}
|
|
249
|
+
function j(e, t) {
|
|
250
|
+
return new Date(t.decidedAt).getTime() - new Date(e.decidedAt).getTime();
|
|
251
|
+
}
|
|
252
|
+
function M(e) {
|
|
253
|
+
return e === "APPROVED" ? "同意" : e === "REJECTED" ? "拒絕" : e === "RETURNED" ? "退回" : e === "TRANSFERRED" ? "轉派" : "未記錄";
|
|
254
|
+
}
|
|
255
|
+
function N(e) {
|
|
256
|
+
return e === "APPROVED" ? "text-success" : e === "REJECTED" || e === "RETURNED" ? "text-error" : "text-neutral";
|
|
257
|
+
}
|
|
258
|
+
function P(e) {
|
|
259
|
+
return e === "RUNNING" ? "進行中" : e === "APPROVED" ? "已通過" : e === "REJECTED" ? "已拒絕" : e === "RETURNED" ? "已退回" : e === "CANCELLED" ? "已取消" : e === "EXPIRED" ? "已逾期" : e === "DRAFT" ? "草稿" : "-";
|
|
260
|
+
}
|
|
261
|
+
function F(e) {
|
|
262
|
+
return e === "APPROVED" ? "text-success" : e === "REJECTED" || e === "CANCELLED" || e === "EXPIRED" ? "text-error" : "text-neutral";
|
|
263
|
+
}
|
|
264
|
+
function I(e) {
|
|
265
|
+
return (e?.trim() ?? "") || "-";
|
|
266
|
+
}
|
|
267
|
+
function L(e) {
|
|
268
|
+
return n(e);
|
|
269
|
+
}
|
|
270
|
+
function R(e) {
|
|
271
|
+
if (!e) return "-";
|
|
272
|
+
let t = new Date(e).getTime(), n = Date.now(), r = B(Math.abs(t - n));
|
|
273
|
+
return t < n ? `已逾期 ${r}` : `剩餘 ${r}`;
|
|
274
|
+
}
|
|
275
|
+
function z(e) {
|
|
276
|
+
return e ? new Date(e).getTime() < Date.now() ? "text-error" : "text-success" : "text-neutral";
|
|
277
|
+
}
|
|
278
|
+
function B(e) {
|
|
279
|
+
let t = Math.max(1, Math.ceil(e / 6e4)), n = Math.floor(t / 1440), r = Math.floor(t % 1440 / 60), i = t % 60;
|
|
280
|
+
return n > 0 ? `${n}天 ${r}小時` : r > 0 ? `${r}小時 ${i}分鐘` : `${i}分鐘`;
|
|
281
|
+
}
|
|
282
|
+
function V(e) {
|
|
283
|
+
return e === "PENDING" ? "待處理" : e === "IN_PROGRESS" ? "處理中" : e === "COMPLETED" ? "已完成" : e === "TRANSFERRED" ? "已轉派" : e === "CANCELLED" ? "已取消" : e;
|
|
284
|
+
}
|
|
285
|
+
function H(e) {
|
|
286
|
+
return e instanceof Error ? e.message : "發生未知錯誤";
|
|
287
|
+
}
|
|
288
|
+
//#endregion
|
|
289
|
+
export { T as t };
|
|
290
|
+
|
|
291
|
+
//# sourceMappingURL=InboxView-YSoyrYLk.js.map
|