@nextclaw/ui 0.12.10 → 0.12.12
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +103 -10
- package/dist/assets/api-DnPN4SyA.js +15 -0
- package/dist/assets/app-manager-provider-M7TngYxx.js +1 -0
- package/dist/assets/app-navigation.config-B5YIdRju.js +1 -0
- package/dist/assets/{book-open-DzdUViDm.js → book-open-B4mOKdz8.js} +1 -1
- package/dist/assets/channels-list-page-Cm-Bbu6u.js +8 -0
- package/dist/assets/chat-C0ZNZtS3.js +58 -0
- package/dist/assets/chat-page-CGHNhXaw.js +1 -0
- package/dist/assets/chunk-JZWAC4HX-BJer-fqD.js +3 -0
- package/dist/assets/config-split-page-B3PRA_AV.js +1 -0
- package/dist/assets/{createLucideIcon-dy5ie7Ox.js → createLucideIcon-C_GFKVuW.js} +1 -1
- package/dist/assets/desktop-update-config-Dfh-3uma.js +1 -0
- package/dist/assets/dialog-D-I7ONHQ.js +5 -0
- package/dist/assets/{dist-Cy7_j6hA.js → dist-DreLBS93.js} +1 -1
- package/dist/assets/doc-browser-CoKIUCJj.js +1 -0
- package/dist/assets/doc-browser-CwgI7ipB.js +1 -0
- package/dist/assets/doc-browser-DYKpRqe-.js +1 -0
- package/dist/assets/doc-browser-context-Dib9sS83.js +1 -0
- package/dist/assets/es2015-DMSUl3fm.js +41 -0
- package/dist/assets/{external-link-kZSAO8nT.js → external-link-DP2IJ7AM.js} +1 -1
- package/dist/assets/folder-BPwc278w.js +1 -0
- package/dist/assets/{hash-BHJC2Ovu.js → hash-CvcvtMBq.js} +1 -1
- package/dist/assets/i18n-BnNAQpVM.js +1 -0
- package/dist/assets/index-Bc6c1kIx.js +2 -0
- package/dist/assets/index-mRmSAB-e.css +1 -0
- package/dist/assets/key-round-BQXmPSxD.js +1 -0
- package/dist/assets/loader-circle-C6gg2m2a.js +1 -0
- package/dist/assets/{LogoBadge-hO7tY7hE.js → logo-badge-uB4SwANR.js} +1 -1
- package/dist/assets/{logos-B7gRObP8.js → logos-BcELLmYh.js} +1 -1
- package/dist/assets/marketplace-page-BCrS-jH6.js +49 -0
- package/dist/assets/marketplace-page-DVrlpB68.js +1 -0
- package/dist/assets/mcp-marketplace-page-CjrxT6wI.js +40 -0
- package/dist/assets/mcp-marketplace-page-pQ_A38fH.js +1 -0
- package/dist/assets/message-square-CLVODA23.js +1 -0
- package/dist/assets/model-config-D4myteLK.js +1 -0
- package/dist/assets/notice-card-DX_NEZTQ.js +1 -0
- package/dist/assets/play-DeNVUA5C.js +1 -0
- package/dist/assets/plus-BptLViq1.js +1 -0
- package/dist/assets/popover-Dm_NQ3Cs.js +1 -0
- package/dist/assets/provider-scoped-model-input-BLHImwI5.js +1 -0
- package/dist/assets/providers-list-DsBFslNi.js +1 -0
- package/dist/assets/{refresh-ccw-COVhNHtN.js → refresh-ccw-CeG203yU.js} +1 -1
- package/dist/assets/remote-CQQykOYe.js +1 -0
- package/dist/assets/{rotate-cw-oHMKJMC8.js → rotate-cw-F7aThvYj.js} +1 -1
- package/dist/assets/runtime-config-page-Bz9r68Rf.js +1 -0
- package/dist/assets/{save-EqJPOF0G.js → save-7ztImRj7.js} +1 -1
- package/dist/assets/search-DZSNKEGp.js +1 -0
- package/dist/assets/search-config-C-6KpgRQ.js +1 -0
- package/dist/assets/secrets-config-MiMElvpm.js +3 -0
- package/dist/assets/select-RgeHgn_-.js +1 -0
- package/dist/assets/sessions-config-page-0KNW9QC_.js +2 -0
- package/dist/assets/setting-row-vwm4XKv2.js +1 -0
- package/dist/assets/settings-DjvNMJde.js +1 -0
- package/dist/assets/skeleton-5Mg6vZHN.js +1 -0
- package/dist/assets/sparkles-CyDTgTM4.js +1 -0
- package/dist/assets/{status-dot-DpPtVzQT.js → status-dot-aQU9Mia4.js} +1 -1
- package/dist/assets/{tabs-custom-YcZUWn3o.js → tabs-custom-C4P7g4vR.js} +1 -1
- package/dist/assets/tag-chip-DGqz3TON.js +1 -0
- package/dist/assets/theme-provider-CUppbOyN.js +1 -0
- package/dist/assets/tooltip-DQlSKhZ_.js +1 -0
- package/dist/assets/{trash-2-mJT6oWa2.js → trash-2-C1cdqL6V.js} +1 -1
- package/dist/assets/use-config-CrsavfWZ.js +1 -0
- package/dist/assets/use-confirm-dialog-D1AnLFlc.js +1 -0
- package/dist/assets/use-infinite-scroll-loader-DZhv-rmv.js +1 -0
- package/dist/assets/use-viewport-layout-CytJAPWM.js +1 -0
- package/dist/assets/x-BjMO7v8q.js +1 -0
- package/dist/index.html +39 -22
- package/module-structure.config.json +7 -0
- package/package.json +5 -5
- package/src/app/components/app-manager-provider.tsx +20 -0
- package/src/{components/providers/I18nProvider.tsx → app/components/i18n-provider.tsx} +1 -1
- package/src/{components → app/components}/layout/app-layout.test.tsx +50 -3
- package/src/app/components/layout/app-layout.tsx +54 -0
- package/src/{components → app/components}/layout/page-layout.tsx +1 -1
- package/src/app/components/layout/runtime-status-entry.test.tsx +101 -0
- package/src/app/components/layout/runtime-status-entry.tsx +95 -0
- package/src/app/components/layout/settings-entry-page.test.tsx +65 -0
- package/src/app/components/layout/settings-entry-page.tsx +13 -0
- package/src/{components → app/components}/layout/sidebar-items.tsx +2 -2
- package/src/{components → app/components}/layout/sidebar.layout.test.tsx +19 -12
- package/src/{components/layout/Sidebar.tsx → app/components/layout/sidebar.tsx} +25 -89
- package/src/{components/providers/ThemeProvider.tsx → app/components/theme-provider.tsx} +2 -2
- package/src/app/configs/app-navigation.config.ts +246 -0
- package/src/{hooks → app/hooks}/use-realtime-query-bridge.ts +36 -20
- package/src/app/hooks/use-viewport-layout.ts +15 -0
- package/src/app/index.tsx +261 -0
- package/src/app/managers/app.manager.ts +12 -0
- package/src/app/managers/viewport-layout.manager.ts +73 -0
- package/src/app/stores/viewport-layout.store.ts +32 -0
- package/src/{test/setup.ts → app/test/vitest-setup.ts} +3 -3
- package/src/{account → features/account}/components/account-panel.tsx +19 -19
- package/src/{components/auth → features/account/components}/login-page.tsx +4 -4
- package/src/{hooks → features/account/hooks}/use-auth.test.ts +1 -1
- package/src/{hooks → features/account/hooks}/use-auth.ts +3 -3
- package/src/features/account/index.ts +7 -0
- package/src/{account → features/account}/managers/account.manager.ts +6 -6
- package/src/{components/agents → features/agents/components}/agent-dialogs.tsx +11 -11
- package/src/{components/agents → features/agents/components}/agents-page.test.tsx +12 -9
- package/src/{components/agents → features/agents/components}/agents-page.tsx +17 -17
- package/src/features/agents/index.ts +1 -0
- package/src/{components/config → features/channels/components}/channel-form-fields-section.tsx +11 -32
- package/src/{components/config/ChannelForm.test.tsx → features/channels/components/config/channel-form.test.tsx} +4 -4
- package/src/features/channels/components/config/channel-form.tsx +382 -0
- package/src/{components → features/channels/components}/config/weixin-channel-auth-section.test.tsx +6 -3
- package/src/features/channels/components/config/weixin-channel-auth-section.tsx +245 -0
- package/src/{hooks → features/channels/hooks}/use-channel-auth.ts +1 -1
- package/src/features/channels/index.ts +5 -0
- package/src/features/channels/pages/channels-list-page.test.tsx +288 -0
- package/src/{components/config/ChannelsList.tsx → features/channels/pages/channels-list-page.tsx} +57 -83
- package/src/{components/config/channel-form-fields.test.ts → features/channels/utils/channel-form-fields.utils.test.ts} +1 -1
- package/src/{components/config/channel-form-fields.ts → features/channels/utils/channel-form-fields.utils.ts} +1 -1
- package/src/{lib/channel-tutorials.ts → features/channels/utils/channel-tutorials.utils.ts} +2 -2
- package/src/{components/chat → features/chat/components}/chat-session-type-option-item.test.tsx +1 -1
- package/src/{components/chat → features/chat/components}/chat-session-type-option-item.tsx +4 -4
- package/src/{components/chat → features/chat/components}/chat-session-workspace-file-preview.test.tsx +4 -4
- package/src/{components/chat → features/chat/components}/chat-session-workspace-file-preview.tsx +12 -32
- package/src/{components/chat → features/chat/components}/chat-session-workspace-panel-nav.tsx +8 -20
- package/src/{components/chat → features/chat/components}/chat-session-workspace-panel.tsx +105 -65
- package/src/features/chat/components/chat-sidebar-list-mode-switch.tsx +28 -0
- package/src/{components/chat → features/chat/components}/chat-sidebar-project-groups.tsx +6 -6
- package/src/{components/chat → features/chat/components}/chat-sidebar-session-item.tsx +10 -10
- package/src/{components/chat/ChatWelcome.test.tsx → features/chat/components/chat-welcome.test.tsx} +1 -1
- package/src/{components/chat/ChatWelcome.tsx → features/chat/components/chat-welcome.tsx} +5 -10
- package/src/features/chat/components/config/sessions-config-detail-pane.tsx +244 -0
- package/src/{components/chat → features/chat/components/conversation}/chat-attachment-upload-limit.test.ts +1 -4
- package/src/features/chat/components/conversation/chat-conversation-header.tsx +146 -0
- package/src/{components/chat → features/chat/components/conversation}/chat-conversation-panel.test.tsx +41 -19
- package/src/{components/chat → features/chat/components/conversation}/chat-conversation-panel.tsx +28 -140
- package/src/{components/chat/containers → features/chat/components/conversation}/chat-input-bar.container.tsx +137 -128
- package/src/{components/chat/containers → features/chat/components/conversation}/chat-message-list.container.test.tsx +2 -2
- package/src/{components/chat/containers → features/chat/components/conversation}/chat-message-list.container.tsx +6 -6
- package/src/{components/chat → features/chat/components/conversation}/session-header/chat-session-header-actions.test.tsx +3 -3
- package/src/{components/chat → features/chat/components/conversation}/session-header/chat-session-header-actions.tsx +6 -6
- package/src/{components/chat → features/chat/components/conversation}/session-header/chat-session-header-menu-item.tsx +1 -1
- package/src/{components/chat → features/chat/components/conversation}/session-header/chat-session-project-badge.test.tsx +3 -3
- package/src/{components/chat → features/chat/components/conversation}/session-header/chat-session-project-badge.tsx +5 -5
- package/src/{components/chat → features/chat/components/conversation}/session-header/chat-session-project-dialog.tsx +2 -2
- package/src/features/chat/components/layout/chat-page-shell.test.tsx +61 -0
- package/src/{components/chat → features/chat/components/layout}/chat-page-shell.tsx +14 -17
- package/src/features/chat/components/layout/chat-sidebar-session-entry.tsx +82 -0
- package/src/features/chat/components/layout/chat-sidebar-toolbar.tsx +205 -0
- package/src/{components/chat/ChatSidebar.test.tsx → features/chat/components/layout/chat-sidebar.test.tsx} +59 -16
- package/src/features/chat/components/layout/chat-sidebar.tsx +415 -0
- package/src/{components/chat/presenter/chat-presenter-context.tsx → features/chat/components/providers/chat-presenter.provider.tsx} +10 -31
- package/src/{components/common → features/chat/components/session}/session-context-icon.tsx +5 -5
- package/src/{components/common/SessionRunBadge.tsx → features/chat/components/session/session-run-badge.tsx} +3 -3
- package/src/{components/chat → features/chat/components}/workspace/chat-session-workspace-file-breadcrumbs.tsx +5 -15
- package/src/{components/chat/chat-input/chat-input-bar.controller.test.tsx → features/chat/hooks/use-chat-input-bar-controller.test.tsx} +1 -1
- package/src/{components → features}/chat/hooks/use-chat-session-label.ts +3 -4
- package/src/{components → features}/chat/hooks/use-chat-session-project.test.tsx +19 -19
- package/src/features/chat/hooks/use-chat-session-project.ts +34 -0
- package/src/{components/chat/useChatSessionTypeState.test.tsx → features/chat/hooks/use-chat-session-type-state.test.tsx} +2 -2
- package/src/{components/chat/useChatSessionTypeState.ts → features/chat/hooks/use-chat-session-type-state.ts} +3 -16
- package/src/{components → features}/chat/hooks/use-chat-session-update.test.tsx +19 -21
- package/src/{components → features}/chat/hooks/use-chat-session-update.ts +5 -7
- package/src/features/chat/hooks/use-chat-sidebar-session-label-editor.ts +49 -0
- package/src/{components/chat/useHydratedNcpAgent.test.tsx → features/chat/hooks/use-hydrated-ncp-agent.test.tsx} +2 -2
- package/src/{components/chat/useNcpAgentRuntime.test.tsx → features/chat/hooks/use-ncp-agent-runtime.test.tsx} +1 -1
- package/src/{components/chat/ncp/page/ncp-chat-derived-state.ts → features/chat/hooks/use-ncp-chat-derived-state.ts} +8 -8
- package/src/{components/chat/ncp/ncp-chat-page-data.ts → features/chat/hooks/use-ncp-chat-page-data.ts} +137 -80
- package/src/{hooks → features/chat/hooks}/use-ncp-chat-session-types.ts +1 -1
- package/src/{components/chat/ncp/session-conversation → features/chat/hooks}/use-ncp-child-session-tabs-view.ts +7 -7
- package/src/{components/chat/ncp/session-conversation → features/chat/hooks}/use-ncp-session-conversation.test.tsx +55 -7
- package/src/features/chat/hooks/use-ncp-session-conversation.ts +121 -0
- package/src/{components/chat/ncp → features/chat/hooks}/use-ncp-session-list-view.ts +6 -6
- package/src/features/chat/index.ts +6 -0
- package/src/{components/chat → features/chat/managers}/chat-recent-models.manager.ts +1 -1
- package/src/{components/chat → features/chat/managers}/chat-recent-skills.manager.ts +1 -1
- package/src/{components → features}/chat/managers/chat-session-list.manager.test.ts +11 -7
- package/src/{components → features}/chat/managers/chat-session-list.manager.ts +8 -10
- package/src/{components/chat/chat-session-preference-sync.test.ts → features/chat/managers/chat-session-preference-sync.manager.test.ts} +18 -14
- package/src/{components/chat/chat-session-preference-sync.ts → features/chat/managers/chat-session-preference-sync.manager.ts} +7 -14
- package/src/{components → features}/chat/managers/chat-stream-actions.manager.ts +3 -2
- package/src/{components → features}/chat/managers/chat-ui.manager.ts +11 -3
- package/src/{components/chat/ncp/tests → features/chat/managers}/ncp-chat-input.manager.test.ts +55 -5
- package/src/{components/chat/ncp → features/chat/managers}/ncp-chat-input.manager.ts +28 -20
- package/src/{components/chat/ncp/ncp-chat.presenter.ts → features/chat/managers/ncp-chat-presenter.manager.ts} +5 -5
- package/src/{components/chat/ncp/tests → features/chat/managers}/ncp-chat-thread.manager.test.ts +11 -10
- package/src/{components/chat/ncp → features/chat/managers}/ncp-chat-thread.manager.ts +11 -13
- package/src/{lib → features/chat/managers}/recent-selection.manager.test.ts +1 -1
- package/src/{lib → features/chat/managers}/recent-selection.manager.ts +14 -14
- package/src/features/chat/pages/chat-page.tsx +6 -0
- package/src/{components/chat/chat-page-runtime.test.ts → features/chat/pages/ncp-chat-page.test.ts} +69 -4
- package/src/{components/chat/ncp → features/chat/pages}/ncp-chat-page.tsx +180 -109
- package/src/features/chat/pages/sessions-config-page.test.tsx +152 -0
- package/src/features/chat/pages/sessions-config-page.tsx +192 -0
- package/src/{components → features}/chat/stores/chat-input.store.ts +3 -3
- package/src/{components → features}/chat/stores/chat-session-list.store.ts +2 -4
- package/src/{components → features}/chat/stores/chat-thread.store.ts +3 -3
- package/src/features/chat/types/chat-input-bar.types.ts +44 -0
- package/src/{components/chat → features/chat/types}/chat-input.types.ts +1 -1
- package/src/features/chat/types/chat-message.types.ts +58 -0
- package/src/{components/chat/chat-stream/types.ts → features/chat/types/chat-stream.types.ts} +1 -1
- package/src/{components/chat/chat-composer-state.test.ts → features/chat/utils/chat-composer-state.utils.test.ts} +1 -1
- package/src/{components/chat/chat-composer-state.ts → features/chat/utils/chat-composer-state.utils.ts} +17 -19
- package/src/features/chat/utils/chat-inline-token.utils.test.ts +87 -0
- package/src/{components/chat → features/chat/utils}/chat-inline-token.utils.ts +22 -39
- package/src/{components/chat/adapters/chat-input-bar.adapter.test.ts → features/chat/utils/chat-input-bar.utils.test.ts} +2 -2
- package/src/{components/chat/adapters/chat-input-bar.adapter.ts → features/chat/utils/chat-input-bar.utils.ts} +18 -196
- package/src/features/chat/utils/chat-input-toolbar.utils.ts +191 -0
- package/src/{lib/chat-message.ts → features/chat/utils/chat-message-core.utils.ts} +1 -1
- package/src/{components/chat/adapters/chat-message-inline-content.adapter.ts → features/chat/utils/chat-message-inline-content.utils.ts} +2 -2
- package/src/features/chat/utils/chat-message-part.utils.ts +233 -0
- package/src/{components/chat/adapters/chat-message.session-request-tool-card.ts → features/chat/utils/chat-message-session-request-tool-card.utils.ts} +2 -2
- package/src/{components/chat/adapters/chat-message.session-spawn-tool-card.test.ts → features/chat/utils/chat-message-session-spawn-tool-card.utils.test.ts} +2 -2
- package/src/{components/chat/adapters/chat-message.summary-truncation.test.ts → features/chat/utils/chat-message-summary-truncation.utils.test.ts} +2 -2
- package/src/{components/chat/adapters/chat-message-tool-agent-id.test.ts → features/chat/utils/chat-message-tool-agent-id.utils.test.ts} +1 -1
- package/src/features/chat/utils/chat-message-tool-card.utils.ts +216 -0
- package/src/{components/chat/adapters/chat-message.adapter.test.ts → features/chat/utils/chat-message.utils.test.ts} +2 -2
- package/src/{components/chat/adapters/chat-message.adapter.ts → features/chat/utils/chat-message.utils.ts} +4 -4
- package/src/features/chat/utils/chat-runtime.utils.ts +235 -0
- package/src/{components/chat/chat-session-display.test.ts → features/chat/utils/chat-session-display.utils.test.ts} +2 -2
- package/src/{components/chat/chat-session-display.ts → features/chat/utils/chat-session-display.utils.ts} +5 -9
- package/src/{components/chat/chat-session-preference-governance.ts → features/chat/utils/chat-session-preference-governance.utils.ts} +51 -64
- package/src/{components/chat/chat-session-route.ts → features/chat/utils/chat-session-route.utils.ts} +1 -1
- package/src/{components/chat/adapters/file-operation/card.ts → features/chat/utils/file-operation/card.utils.ts} +3 -3
- package/src/{components/chat/adapters/file-operation/diff.ts → features/chat/utils/file-operation/diff.utils.ts} +9 -99
- package/src/features/chat/utils/file-operation/parsed-block.utils.ts +98 -0
- package/src/{components/chat/adapters/file-operation/record-readers.ts → features/chat/utils/file-operation/record-readers.utils.ts} +1 -1
- package/src/{components/chat/ncp/ncp-app-client-fetch.test.ts → features/chat/utils/ncp-app-client-fetch.utils.test.ts} +1 -1
- package/src/{components/chat/ncp/ncp-app-client-fetch.ts → features/chat/utils/ncp-app-client-fetch.utils.ts} +3 -0
- package/src/features/chat/utils/ncp-chat-input-availability.utils.test.ts +92 -0
- package/src/features/chat/utils/ncp-chat-input-availability.utils.ts +45 -0
- package/src/{components/chat/ncp/__tests__/ncp-session-adapter.cancelled-tool.test.ts → features/chat/utils/ncp-session-adapter.utils.cancelled-tool.test.ts} +2 -2
- package/src/{components/chat/ncp/ncp-session-adapter.test.ts → features/chat/utils/ncp-session-adapter.utils.test.ts} +3 -3
- package/src/{components/chat/ncp/ncp-session-adapter.ts → features/chat/utils/ncp-session-adapter.utils.ts} +3 -3
- package/src/{lib → features/chat/utils}/session-context.utils.test.ts +3 -3
- package/src/{lib → features/chat/utils}/session-context.utils.ts +3 -3
- package/src/{components/marketplace → features/marketplace/components}/marketplace-list-card.tsx +69 -124
- package/src/{components/marketplace → features/marketplace/components}/marketplace-localization.ts +1 -1
- package/src/{components/marketplace → features/marketplace/components}/marketplace-page-data.ts +2 -2
- package/src/features/marketplace/components/marketplace-page-detail.test.tsx +336 -0
- package/src/features/marketplace/components/marketplace-page-parts.tsx +121 -0
- package/src/{components/marketplace → features/marketplace/components}/marketplace-page.test.tsx +6 -6
- package/src/{components/marketplace → features/marketplace/components}/marketplace-page.tsx +92 -91
- package/src/{components/marketplace → features/marketplace/components}/mcp/mcp-marketplace-card.tsx +4 -4
- package/src/{components/marketplace → features/marketplace/components}/mcp/mcp-marketplace-dialogs.tsx +7 -7
- package/src/{components/marketplace → features/marketplace/components}/mcp/mcp-marketplace-doc.ts +3 -3
- package/src/{components/marketplace → features/marketplace/components}/mcp/mcp-marketplace-page.test.tsx +13 -9
- package/src/features/marketplace/components/mcp/mcp-marketplace-page.tsx +446 -0
- package/src/{hooks/useMarketplace.ts → features/marketplace/hooks/use-marketplace.ts} +5 -5
- package/src/{hooks/useMcpMarketplace.ts → features/marketplace/hooks/use-mcp-marketplace.ts} +3 -3
- package/src/features/marketplace/index.ts +26 -0
- package/src/{components/marketplace/marketplace-installed-cache.test.ts → features/marketplace/utils/marketplace-installed-cache.utils.test.ts} +2 -2
- package/src/{components/marketplace/marketplace-installed-cache.ts → features/marketplace/utils/marketplace-installed-cache.utils.ts} +1 -1
- package/src/{hooks/marketplace-list-pages.ts → features/marketplace/utils/marketplace-list-pages.utils.ts} +1 -1
- package/src/{pwa → features/pwa}/components/pwa-install-entry.test.tsx +2 -2
- package/src/{pwa → features/pwa}/components/pwa-install-entry.tsx +7 -7
- package/src/features/pwa/index.ts +4 -0
- package/src/{pwa/register-pwa.ts → features/pwa/managers/pwa-bootstrap.manager.ts} +2 -2
- package/src/{pwa → features/pwa}/managers/pwa-install.manager.test.ts +3 -3
- package/src/{pwa → features/pwa}/managers/pwa-install.manager.ts +5 -5
- package/src/{pwa → features/pwa}/managers/pwa-runtime.manager.ts +1 -1
- package/src/{pwa → features/pwa}/managers/pwa-shell-theme.manager.test.ts +1 -1
- package/src/{pwa → features/pwa}/managers/pwa-shell-theme.manager.ts +1 -1
- package/src/{pwa → features/pwa}/stores/pwa.store.ts +2 -2
- package/src/{components/remote → features/remote/components}/remote-access-page.test.tsx +5 -6
- package/src/{components/remote → features/remote/components}/remote-access-page.tsx +21 -19
- package/src/{hooks/useRemoteAccess.ts → features/remote/hooks/use-remote-access.ts} +3 -3
- package/src/features/remote/index.ts +27 -0
- package/src/{remote → features/remote}/managers/remote-access.manager.ts +6 -7
- package/src/{remote → features/remote/services}/remote-access-feedback.service.test.ts +3 -3
- package/src/{remote → features/remote/services}/remote-access-feedback.service.ts +2 -2
- package/src/{remote/remote-access.query.ts → features/remote/services/remote-access-query.service.ts} +2 -2
- package/src/{remote → features/remote}/stores/remote-access.store.ts +1 -1
- package/src/features/settings/hooks/use-language-preference.ts +30 -0
- package/src/features/settings/index.ts +2 -0
- package/src/features/settings/pages/language-settings-page.test.tsx +36 -0
- package/src/features/settings/pages/language-settings-page.tsx +56 -0
- package/src/features/system-status/components/config/runtime-agent-list-card.tsx +72 -0
- package/src/features/system-status/components/config/runtime-binding-list-card.tsx +85 -0
- package/src/features/system-status/components/config/runtime-config-editor.tsx +131 -0
- package/src/features/system-status/components/config/runtime-config-overview.tsx +16 -0
- package/src/features/system-status/components/config/runtime-entry-list-card.tsx +58 -0
- package/src/features/system-status/components/config/runtime-settings-card.tsx +73 -0
- package/src/{components/config → features/system-status/components}/desktop-update-config.test.tsx +12 -6
- package/src/features/system-status/components/desktop-update-config.tsx +219 -0
- package/src/features/system-status/components/runtime-control-card.test.tsx +213 -0
- package/src/features/system-status/components/runtime-control-card.tsx +260 -0
- package/src/{components/config → features/system-status/components}/runtime-presence-card.test.tsx +12 -16
- package/src/{components/config → features/system-status/components}/runtime-presence-card.tsx +38 -51
- package/src/features/system-status/components/runtime-security-card.tsx +263 -0
- package/src/{components/config → features/system-status/components}/security-config.tsx +3 -3
- package/src/features/system-status/hooks/use-system-status.ts +104 -0
- package/src/features/system-status/index.ts +4 -0
- package/src/features/system-status/managers/system-status.manager.bootstrap-polling.test.ts +126 -0
- package/src/features/system-status/managers/system-status.manager.test.ts +142 -0
- package/src/features/system-status/managers/system-status.manager.ts +511 -0
- package/src/features/system-status/pages/runtime-config-page.test.tsx +140 -0
- package/src/features/system-status/pages/runtime-config-page.tsx +15 -0
- package/src/features/system-status/stores/system-status.store.ts +32 -0
- package/src/features/system-status/types/system-status.types.ts +73 -0
- package/src/features/system-status/utils/runtime-config-agent.utils.ts +152 -0
- package/src/features/system-status/utils/system-status.utils.test.ts +132 -0
- package/src/features/system-status/utils/system-status.utils.ts +202 -0
- package/src/index.css +1 -1
- package/src/platforms/desktop/components/desktop-app-shell.tsx +52 -0
- package/src/platforms/desktop/index.ts +21 -0
- package/src/{desktop → platforms/desktop}/managers/desktop-presence.manager.ts +3 -3
- package/src/{desktop → platforms/desktop}/managers/desktop-update.manager.ts +3 -3
- package/src/{desktop → platforms/desktop}/stores/desktop-presence.store.ts +1 -1
- package/src/{desktop → platforms/desktop}/stores/desktop-update.store.ts +1 -1
- package/src/{desktop → platforms/desktop/types}/desktop-update.types.ts +4 -0
- package/src/platforms/mobile/components/chat-mobile-shell.tsx +20 -0
- package/src/platforms/mobile/components/mobile-app-shell.test.tsx +42 -0
- package/src/platforms/mobile/components/mobile-app-shell.tsx +48 -0
- package/src/platforms/mobile/components/mobile-bottom-nav.test.tsx +45 -0
- package/src/platforms/mobile/components/mobile-bottom-nav.tsx +71 -0
- package/src/platforms/mobile/components/mobile-settings-shell.tsx +39 -0
- package/src/platforms/mobile/components/mobile-topbar.tsx +41 -0
- package/src/platforms/mobile/index.ts +3 -0
- package/src/shared/components/__tests__/config-split-page.test.tsx +47 -0
- package/src/{components/common/AgentAvatar.tsx → shared/components/common/agent-avatar.tsx} +1 -1
- package/src/{components → shared/components}/common/agent-identity/agent-identity-avatar.tsx +2 -2
- package/src/shared/components/common/agent-identity/index.ts +3 -0
- package/src/{components → shared/components}/common/agent-identity/use-agent-identity.ts +3 -3
- package/src/{components/common/BrandHeader.tsx → shared/components/common/brand-header.tsx} +2 -2
- package/src/{components/common/KeyValueEditor.tsx → shared/components/common/key-value-editor.tsx} +4 -4
- package/src/{components/common/LogoBadge.tsx → shared/components/common/logo-badge.tsx} +1 -1
- package/src/{components/common/MaskedInput.tsx → shared/components/common/masked-input.tsx} +3 -3
- package/src/{components/common/ProviderScopedModelInput.tsx → shared/components/common/provider-scoped-model-input.tsx} +6 -6
- package/src/{components/common/SearchableModelInput.tsx → shared/components/common/searchable-model-input.tsx} +2 -2
- package/src/{components/common/StatusBadge.tsx → shared/components/common/status-badge.tsx} +3 -3
- package/src/{components → shared/components}/common/tag-input.tsx +3 -3
- package/src/{components → shared/components}/config/provider-form-support.ts +3 -3
- package/src/{components/config/ProviderForm.tsx → shared/components/config/provider-form.tsx} +14 -14
- package/src/{components → shared/components}/config/provider-models-section.tsx +7 -7
- package/src/{components → shared/components}/config/providers-list.test.tsx +19 -19
- package/src/{components/config/ProvidersList.tsx → shared/components/config/providers-list.tsx} +56 -54
- package/src/shared/components/config/secrets-config-form.tsx +407 -0
- package/src/shared/components/config/secrets-config.test.tsx +90 -0
- package/src/shared/components/config/secrets-config.tsx +25 -0
- package/src/{components/config → shared/components}/config-split-page.tsx +55 -9
- package/src/{components/config/CronConfig.tsx → shared/components/cron-config.tsx} +63 -96
- package/src/shared/components/doc-browser/doc-browser-context.test.tsx +102 -0
- package/src/{components/doc-browser/DocBrowserContext.tsx → shared/components/doc-browser/doc-browser-context.tsx} +98 -45
- package/src/shared/components/doc-browser/doc-browser.test.tsx +72 -0
- package/src/{components/doc-browser/DocBrowser.tsx → shared/components/doc-browser/doc-browser.tsx} +60 -34
- package/src/shared/components/doc-browser/index.ts +3 -0
- package/src/{components/doc-browser/useDocLinkInterceptor.ts → shared/components/doc-browser/use-doc-link-interceptor.ts} +1 -1
- package/src/{components/config/ModelConfig.test.tsx → shared/components/model-config.test.tsx} +4 -4
- package/src/shared/components/model-config.tsx +151 -0
- package/src/{components → shared/components}/path-picker/server-path-picker-dialog.test.tsx +3 -3
- package/src/{components → shared/components}/path-picker/server-path-picker-dialog.tsx +7 -7
- package/src/{components/config → shared/components}/provider-advanced-settings-section.tsx +5 -18
- package/src/{components/config → shared/components}/provider-auth-section.tsx +7 -24
- package/src/{components/config → shared/components}/provider-enabled-field.tsx +4 -8
- package/src/{components/config → shared/components}/provider-pill-selector.tsx +3 -15
- package/src/{components/config → shared/components}/provider-status-badge.tsx +3 -9
- package/src/{components/config/SearchConfig.test.tsx → shared/components/search-config.test.tsx} +3 -3
- package/src/shared/components/search-config.tsx +496 -0
- package/src/{components → shared/components}/ui/action-link.tsx +1 -1
- package/src/{components → shared/components}/ui/button.tsx +1 -1
- package/src/{components → shared/components}/ui/card.tsx +1 -1
- package/src/{components → shared/components}/ui/config-card.tsx +1 -1
- package/src/{components → shared/components}/ui/confirm-dialog.tsx +3 -3
- package/src/{components → shared/components}/ui/dialog.tsx +1 -1
- package/src/{components/ui/HighlightCard.tsx → shared/components/ui/highlight-card.tsx} +1 -1
- package/src/{components → shared/components}/ui/input.tsx +1 -1
- package/src/{components → shared/components}/ui/label.tsx +1 -1
- package/src/{components → shared/components}/ui/notice-card.tsx +1 -1
- package/src/{components → shared/components}/ui/popover.tsx +1 -1
- package/src/{components → shared/components}/ui/scroll-area.tsx +1 -1
- package/src/{components → shared/components}/ui/select.tsx +1 -1
- package/src/{components → shared/components}/ui/setting-row.tsx +1 -1
- package/src/{components → shared/components}/ui/skeleton.tsx +1 -1
- package/src/{components → shared/components}/ui/status-dot.tsx +1 -1
- package/src/{components → shared/components}/ui/switch.tsx +1 -1
- package/src/{components → shared/components}/ui/tabs-custom.tsx +2 -2
- package/src/{components → shared/components}/ui/tabs.tsx +1 -1
- package/src/{components → shared/components}/ui/tag-chip.tsx +1 -1
- package/src/{components → shared/components}/ui/textarea.tsx +1 -1
- package/src/{components → shared/components}/ui/tooltip.tsx +1 -1
- package/src/{hooks/agents/useAgents.ts → shared/hooks/use-agents.ts} +2 -2
- package/src/{hooks/useConfig.ts → shared/hooks/use-config.ts} +4 -4
- package/src/{hooks/useConfirmDialog.tsx → shared/hooks/use-confirm-dialog.tsx} +2 -2
- package/src/{hooks/server-path → shared/hooks}/use-server-path-browse.ts +1 -1
- package/src/{hooks/server-path → shared/hooks}/use-server-path-read.ts +1 -1
- package/src/{api → shared/lib/api}/api-base.test.ts +2 -2
- package/src/{api → shared/lib/api}/client.test.ts +2 -2
- package/src/{api → shared/lib/api}/client.ts +1 -1
- package/src/{api → shared/lib/api}/config.ts +10 -0
- package/src/shared/lib/api/index.ts +20 -0
- package/src/{api → shared/lib/api}/ncp-session-query-cache.test.ts +2 -2
- package/src/{api → shared/lib/api}/ncp-session-query-cache.ts +1 -1
- package/src/{api → shared/lib/api}/ncp-session.test.ts +3 -3
- package/src/{api → shared/lib/api}/raw-client.test.ts +1 -1
- package/src/{api/raw-client.ts → shared/lib/api/raw-client.utils.ts} +2 -0
- package/src/{api → shared/lib/api}/types.ts +40 -0
- package/src/{lib → shared/lib/app-resource-uri}/app-resource-uri.test.ts +1 -1
- package/src/{lib/config-hints.ts → shared/lib/config-hints/index.ts} +1 -1
- package/src/{lib/i18n.chat.ts → shared/lib/i18n/chat.ts} +8 -0
- package/src/{lib/i18n.ts → shared/lib/i18n/index.ts} +11 -11
- package/src/shared/lib/i18n/runtime/i18n-language-owner.test.ts +94 -0
- package/src/{lib/i18n-runtime → shared/lib/i18n/runtime}/i18n-language-owner.ts +15 -1
- package/src/{lib/provider-models.ts → shared/lib/provider-models/index.ts} +1 -1
- package/src/shared/lib/session-project/index.ts +2 -0
- package/src/{lib → shared/lib}/session-project/workspace-file-breadcrumb.test.ts +1 -1
- package/src/{lib → shared/lib}/session-project/workspace-file-breadcrumb.ts +1 -1
- package/src/{transport/app-client.ts → shared/lib/transport/app-client.service.ts} +11 -12
- package/src/{transport → shared/lib/transport}/app-client.test.ts +15 -5
- package/src/{transport → shared/lib/transport}/index.ts +1 -1
- package/src/{transport/local.transport.ts → shared/lib/transport/local-transport.service.ts} +19 -19
- package/src/{transport/remote.transport.ts → shared/lib/transport/remote-transport.service.ts} +14 -15
- package/src/{transport → shared/lib/transport}/remote.transport.test.ts +5 -5
- package/src/{transport → shared/lib/transport}/sse-stream.test.ts +2 -2
- package/src/{transport/sse-stream.ts → shared/lib/transport/sse-stream.utils.ts} +13 -11
- package/src/{transport → shared/lib/transport}/transport.types.ts +1 -1
- package/src/{lib/ui-document-title.ts → shared/lib/ui-document-title/index.ts} +1 -1
- package/tsconfig.json +20 -0
- package/vite.config.ts +62 -2
- package/vitest.config.ts +21 -1
- package/dist/assets/ChannelsList-M9FTK1Ak.js +0 -8
- package/dist/assets/DocBrowser-CH7-GxlL.js +0 -1
- package/dist/assets/DocBrowser-DMfr0Oow.js +0 -1
- package/dist/assets/DocBrowserContext-BXydqby-.js +0 -1
- package/dist/assets/ModelConfig-CNIgLf0e.js +0 -1
- package/dist/assets/ProviderScopedModelInput-B3HWP4oz.js +0 -1
- package/dist/assets/ProvidersList-CHjMnRhX.js +0 -1
- package/dist/assets/RuntimeConfig-psp8nMSG.js +0 -1
- package/dist/assets/SearchConfig-CSoKip1f.js +0 -1
- package/dist/assets/SecretsConfig-MEt6MjuD.js +0 -3
- package/dist/assets/SessionsConfig-DifCiXwR.js +0 -2
- package/dist/assets/app-query-client-9jNewezV.js +0 -1
- package/dist/assets/chat-page-CLp0UV0Y.js +0 -58
- package/dist/assets/chat-session-display-DsYHx0RZ.js +0 -1
- package/dist/assets/chunk-JZWAC4HX-C5dEc8hV.js +0 -3
- package/dist/assets/client-C-8fH7-c.js +0 -7
- package/dist/assets/config-CBScxsdV.js +0 -1
- package/dist/assets/config-split-page-BUout_Ak.js +0 -1
- package/dist/assets/desktop-update-config-2BS6BMkW.js +0 -1
- package/dist/assets/dist-BruyLa92.js +0 -9
- package/dist/assets/download-BD0ETkB-.js +0 -1
- package/dist/assets/i18n-CpTZLchQ.js +0 -1
- package/dist/assets/index-mW8W2FUu.css +0 -1
- package/dist/assets/index-zDZfXoI4.js +0 -6
- package/dist/assets/infiniteQueryBehavior-CyER9hv0.js +0 -1
- package/dist/assets/loader-circle-Bc2gCU33.js +0 -1
- package/dist/assets/marketplace-page-3qVMnF3d.js +0 -1
- package/dist/assets/marketplace-page-BhFIeQzI.js +0 -49
- package/dist/assets/mcp-marketplace-page-DYfteJ1D.js +0 -40
- package/dist/assets/page-layout-0UcO9H9Z.js +0 -1
- package/dist/assets/play-CKDjSQFL.js +0 -1
- package/dist/assets/plus-CG0QrVY_.js +0 -1
- package/dist/assets/refresh-cw-Bcv40SXy.js +0 -1
- package/dist/assets/remote-access-page-CWHG-sug.js +0 -1
- package/dist/assets/search-BCAlB8nz.js +0 -1
- package/dist/assets/security-config-Slh0Mayz.js +0 -1
- package/dist/assets/select-CVz0t7MF.js +0 -41
- package/dist/assets/setting-row-CbVHAuQt.js +0 -1
- package/dist/assets/skeleton-D5rdKvzy.js +0 -1
- package/dist/assets/switch-CM29eCAR.js +0 -1
- package/dist/assets/tag-chip-DMXdnLcj.js +0 -1
- package/dist/assets/use-infinite-scroll-loader-DJ1L81Dz.js +0 -1
- package/dist/assets/useConfirmDialog-BsVuqu1x.js +0 -1
- package/dist/assets/useMutation-CNcz2fgt.js +0 -1
- package/dist/assets/x-Czwxm82I.js +0 -1
- package/src/app.tsx +0 -271
- package/src/components/chat/ChatSidebar.tsx +0 -486
- package/src/components/chat/README.md +0 -2
- package/src/components/chat/adapters/chat-message-part.adapter.ts +0 -472
- package/src/components/chat/chat-inline-token.utils.test.ts +0 -87
- package/src/components/chat/chat-page.tsx +0 -6
- package/src/components/chat/chat-sidebar-list-mode-switch.tsx +0 -43
- package/src/components/chat/hooks/use-chat-session-project.ts +0 -35
- package/src/components/chat/index.ts +0 -1
- package/src/components/chat/ncp/README.md +0 -3
- package/src/components/chat/ncp/ncp-chat-page-data.test.ts +0 -79
- package/src/components/chat/ncp/session-conversation/use-ncp-session-conversation.ts +0 -72
- package/src/components/chat/nextclaw/index.ts +0 -23
- package/src/components/common/agent-identity/index.ts +0 -3
- package/src/components/config/ChannelForm.tsx +0 -338
- package/src/components/config/ChannelsList.test.tsx +0 -309
- package/src/components/config/ModelConfig.tsx +0 -156
- package/src/components/config/README.md +0 -2
- package/src/components/config/RuntimeConfig.tsx +0 -588
- package/src/components/config/SearchConfig.tsx +0 -513
- package/src/components/config/SecretsConfig.tsx +0 -469
- package/src/components/config/SessionsConfig.tsx +0 -437
- package/src/components/config/desktop-update-config.tsx +0 -271
- package/src/components/config/runtime-config-agent.utils.ts +0 -96
- package/src/components/config/runtime-control-card.test.tsx +0 -311
- package/src/components/config/runtime-control-card.tsx +0 -326
- package/src/components/config/runtime-security-card.tsx +0 -276
- package/src/components/config/weixin-channel-auth-section.tsx +0 -305
- package/src/components/doc-browser/index.ts +0 -3
- package/src/components/layout/AppLayout.tsx +0 -82
- package/src/components/layout/runtime-status-entry.test.tsx +0 -157
- package/src/components/layout/runtime-status-entry.tsx +0 -143
- package/src/components/marketplace/marketplace-page-parts.tsx +0 -94
- package/src/components/marketplace/mcp/mcp-marketplace-page.tsx +0 -414
- package/src/hooks/README.md +0 -3
- package/src/hooks/use-runtime-control.ts +0 -24
- package/src/hooks/useObservable.ts +0 -20
- package/src/lib/chat-runtime-utils.ts +0 -250
- package/src/presenter/app-presenter-context.tsx +0 -20
- package/src/presenter/app.presenter.ts +0 -12
- package/src/runtime-control/runtime-control.manager.ts +0 -118
- package/src/stores/ui.store.ts +0 -23
- /package/dist/assets/{config-hints-BhTmc9P1.js → config-hints-CPNzbMEp.js} +0 -0
- /package/src/{components/layout/Header.tsx → app/components/layout/header.tsx} +0 -0
- /package/src/{styles → app/styles}/design-system.css +0 -0
- /package/src/{account → features/account}/stores/account.store.ts +0 -0
- /package/src/{components/chat/chat-input/chat-input-bar.controller.ts → features/chat/hooks/use-chat-input-bar-controller.ts} +0 -0
- /package/src/{lib/session-run-status.ts → features/chat/types/session-run-status.types.ts} +0 -0
- /package/src/{components/chat/adapters/chat-message.partial-json.ts → features/chat/utils/chat-message-partial-json.utils.ts} +0 -0
- /package/src/{components/chat/adapters/chat-message-tool-agent-id.ts → features/chat/utils/chat-message-tool-agent-id.utils.ts} +0 -0
- /package/src/{components/chat/adapters/file-operation/line-builder.ts → features/chat/utils/file-operation/line-builder.utils.ts} +0 -0
- /package/src/{components/marketplace → features/marketplace/components}/marketplace-detail-doc.ts +0 -0
- /package/src/{pwa → features/pwa/types}/pwa.types.ts +0 -0
- /package/src/{pwa/pwa-install-banner.storage.ts → features/pwa/utils/pwa-install-banner.utils.ts} +0 -0
- /package/src/{hooks → shared/hooks}/use-infinite-scroll-loader.ts +0 -0
- /package/src/{api → shared/lib/api}/agents.ts +0 -0
- /package/src/{api → shared/lib/api}/api-base.ts +0 -0
- /package/src/{api → shared/lib/api}/auth.types.ts +0 -0
- /package/src/{api → shared/lib/api}/channel-auth.ts +0 -0
- /package/src/{api → shared/lib/api}/channel-auth.types.ts +0 -0
- /package/src/{api → shared/lib/api}/chat-session-type.types.ts +0 -0
- /package/src/{api → shared/lib/api}/marketplace.ts +0 -0
- /package/src/{api → shared/lib/api}/mcp-marketplace.ts +0 -0
- /package/src/{api → shared/lib/api}/ncp-attachments.ts +0 -0
- /package/src/{api → shared/lib/api}/ncp-session.ts +0 -0
- /package/src/{api → shared/lib/api}/remote.ts +0 -0
- /package/src/{api → shared/lib/api}/remote.types.ts +0 -0
- /package/src/{api → shared/lib/api}/runtime-control.ts +0 -0
- /package/src/{api → shared/lib/api}/runtime-control.types.ts +0 -0
- /package/src/{api → shared/lib/api}/server-path.ts +0 -0
- /package/src/{lib/app-resource-uri.ts → shared/lib/app-resource-uri/index.ts} +0 -0
- /package/src/{lib/i18n.agents.ts → shared/lib/i18n/agents.ts} +0 -0
- /package/src/{lib/i18n.channel-auth.ts → shared/lib/i18n/channel-auth.ts} +0 -0
- /package/src/{lib/i18n.channels.ts → shared/lib/i18n/channels.ts} +0 -0
- /package/src/{lib → shared/lib/i18n}/desktop-update-labels.utils.ts +0 -0
- /package/src/{lib/i18n.marketplace.ts → shared/lib/i18n/marketplace.ts} +0 -0
- /package/src/{lib/i18n.pwa.ts → shared/lib/i18n/pwa.ts} +0 -0
- /package/src/{lib/i18n.remote.ts → shared/lib/i18n/remote.ts} +0 -0
- /package/src/{lib/i18n-runtime → shared/lib/i18n/runtime}/i18n.path-picker.ts +0 -0
- /package/src/{lib/i18n.runtime-control.ts → shared/lib/i18n/runtime-control.ts} +0 -0
- /package/src/{lib/i18n.search.ts → shared/lib/i18n/search.ts} +0 -0
- /package/src/{lib/logos.ts → shared/lib/logos/index.ts} +0 -0
- /package/src/{lib → shared/lib}/session-project/session-project.utils.ts +0 -0
- /package/src/{lib/theme.ts → shared/lib/theme/index.ts} +0 -0
- /package/src/{transport/transport-websocket-url.ts → shared/lib/transport/transport-websocket-url.utils.ts} +0 -0
- /package/src/{lib/utils.ts → shared/lib/utils/index.ts} +0 -0
package/src/{transport/local.transport.ts → shared/lib/transport/local-transport.service.ts}
RENAMED
|
@@ -1,15 +1,13 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { requestRawApiResponse } from '@/api/raw-client';
|
|
3
|
-
import type { ApiResponse } from '@/api/types';
|
|
1
|
+
import { systemStatusManager } from '@/features/system-status';
|
|
4
2
|
import type { AppEvent, AppTransport, RequestInput, StreamInput, StreamSession } from './transport.types';
|
|
5
|
-
import { readSseStreamResult } from './sse-stream';
|
|
6
|
-
import { resolveTransportWebSocketUrl } from './transport-websocket-url';
|
|
3
|
+
import { readSseStreamResult } from './sse-stream.utils';
|
|
4
|
+
import { resolveTransportWebSocketUrl } from './transport-websocket-url.utils';
|
|
7
5
|
|
|
8
6
|
type EventHandler = (event: AppEvent) => void;
|
|
9
7
|
|
|
10
|
-
function createTransportError(response:
|
|
8
|
+
function createTransportError(response: { ok: boolean; error?: { message?: string } }, fallback: string): Error {
|
|
11
9
|
if (!response.ok) {
|
|
12
|
-
return new Error(response.error
|
|
10
|
+
return new Error(response.error?.message || fallback);
|
|
13
11
|
}
|
|
14
12
|
return new Error(fallback);
|
|
15
13
|
}
|
|
@@ -42,7 +40,7 @@ class LocalRealtimeGateway {
|
|
|
42
40
|
|
|
43
41
|
constructor(private readonly wsUrl: string) {}
|
|
44
42
|
|
|
45
|
-
subscribe(handler: EventHandler): () => void {
|
|
43
|
+
subscribe = (handler: EventHandler): () => void => {
|
|
46
44
|
this.subscribers.add(handler);
|
|
47
45
|
if (this.subscribers.size === 1) {
|
|
48
46
|
this.connect();
|
|
@@ -56,15 +54,15 @@ class LocalRealtimeGateway {
|
|
|
56
54
|
this.disconnect();
|
|
57
55
|
}
|
|
58
56
|
};
|
|
59
|
-
}
|
|
57
|
+
};
|
|
60
58
|
|
|
61
|
-
private emit(event: AppEvent): void {
|
|
59
|
+
private emit = (event: AppEvent): void => {
|
|
62
60
|
for (const subscriber of this.subscribers) {
|
|
63
61
|
subscriber(event);
|
|
64
62
|
}
|
|
65
|
-
}
|
|
63
|
+
};
|
|
66
64
|
|
|
67
|
-
private connect(): void {
|
|
65
|
+
private connect = (): void => {
|
|
68
66
|
if (this.socket && (this.socket.readyState === WebSocket.CONNECTING || this.socket.readyState === WebSocket.OPEN)) {
|
|
69
67
|
return;
|
|
70
68
|
}
|
|
@@ -96,9 +94,9 @@ class LocalRealtimeGateway {
|
|
|
96
94
|
this.scheduleReconnect();
|
|
97
95
|
}
|
|
98
96
|
};
|
|
99
|
-
}
|
|
97
|
+
};
|
|
100
98
|
|
|
101
|
-
private scheduleReconnect(): void {
|
|
99
|
+
private scheduleReconnect = (): void => {
|
|
102
100
|
if (this.reconnectTimer !== null) {
|
|
103
101
|
return;
|
|
104
102
|
}
|
|
@@ -106,9 +104,9 @@ class LocalRealtimeGateway {
|
|
|
106
104
|
this.reconnectTimer = null;
|
|
107
105
|
this.connect();
|
|
108
106
|
}, 3_000);
|
|
109
|
-
}
|
|
107
|
+
};
|
|
110
108
|
|
|
111
|
-
private disconnect(): void {
|
|
109
|
+
private disconnect = (): void => {
|
|
112
110
|
this.manualClose = true;
|
|
113
111
|
if (this.reconnectTimer !== null) {
|
|
114
112
|
window.clearTimeout(this.reconnectTimer);
|
|
@@ -116,7 +114,7 @@ class LocalRealtimeGateway {
|
|
|
116
114
|
}
|
|
117
115
|
this.socket?.close();
|
|
118
116
|
this.socket = null;
|
|
119
|
-
}
|
|
117
|
+
};
|
|
120
118
|
}
|
|
121
119
|
|
|
122
120
|
export class LocalAppTransport implements AppTransport {
|
|
@@ -129,7 +127,7 @@ export class LocalAppTransport implements AppTransport {
|
|
|
129
127
|
wsPath?: string;
|
|
130
128
|
} = {}
|
|
131
129
|
) {
|
|
132
|
-
this.apiBase = options.apiBase ??
|
|
130
|
+
this.apiBase = options.apiBase ?? (import.meta.env.VITE_API_BASE?.trim().replace(/\/$/, '') || (typeof window !== 'undefined' ? window.location.origin : 'http://127.0.0.1:55667'));
|
|
133
131
|
this.realtimeGateway = new LocalRealtimeGateway(resolveTransportWebSocketUrl(this.apiBase, options.wsPath ?? '/ws'));
|
|
134
132
|
}
|
|
135
133
|
|
|
@@ -143,6 +141,7 @@ export class LocalAppTransport implements AppTransport {
|
|
|
143
141
|
: null;
|
|
144
142
|
|
|
145
143
|
try {
|
|
144
|
+
const { requestRawApiResponse } = await import('@/shared/lib/api');
|
|
146
145
|
const response = await requestRawApiResponse<T>(input.path, {
|
|
147
146
|
method: input.method,
|
|
148
147
|
...(input.body !== undefined ? { body: JSON.stringify(input.body) } : {}),
|
|
@@ -154,7 +153,7 @@ export class LocalAppTransport implements AppTransport {
|
|
|
154
153
|
return response.data;
|
|
155
154
|
} catch (error) {
|
|
156
155
|
if (controller?.signal.aborted) {
|
|
157
|
-
const reason = controller.signal
|
|
156
|
+
const { reason } = controller.signal;
|
|
158
157
|
throw new Error(typeof reason === 'string' && reason.trim() ? reason : `Request timed out: ${input.method} ${input.path}`);
|
|
159
158
|
}
|
|
160
159
|
if (error instanceof Error) {
|
|
@@ -196,6 +195,7 @@ export class LocalAppTransport implements AppTransport {
|
|
|
196
195
|
signal: controller.signal
|
|
197
196
|
});
|
|
198
197
|
} catch (error) {
|
|
198
|
+
systemStatusManager.reportTransportFailure(formatUnknownTransportError(error));
|
|
199
199
|
throw createErrorWithCause(
|
|
200
200
|
`Stream request failed for ${input.method} ${input.path} | ${formatUnknownTransportError(error)}`,
|
|
201
201
|
error
|
package/src/{transport/remote.transport.ts → shared/lib/transport/remote-transport.service.ts}
RENAMED
|
@@ -1,7 +1,6 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import type { ApiError } from '@/api/types';
|
|
1
|
+
import type { ApiError } from '@/shared/lib/api';
|
|
3
2
|
import type { AppEvent, AppTransport, RemoteRuntimeInfo, RequestInput, StreamInput, StreamSession } from './transport.types';
|
|
4
|
-
import { resolveTransportWebSocketUrl } from './transport-websocket-url';
|
|
3
|
+
import { resolveTransportWebSocketUrl } from './transport-websocket-url.utils';
|
|
5
4
|
|
|
6
5
|
type RemoteTarget = {
|
|
7
6
|
method: string;
|
|
@@ -84,10 +83,10 @@ export class RemoteSessionMultiplexTransport implements AppTransport {
|
|
|
84
83
|
|
|
85
84
|
constructor(
|
|
86
85
|
private readonly runtime: RemoteRuntimeInfo,
|
|
87
|
-
private readonly apiBase: string =
|
|
86
|
+
private readonly apiBase: string = import.meta.env.VITE_API_BASE?.trim().replace(/\/$/, '') || (typeof window !== 'undefined' ? window.location.origin : 'http://127.0.0.1:55667')
|
|
88
87
|
) {}
|
|
89
88
|
|
|
90
|
-
async
|
|
89
|
+
request = async <T>(input: RequestInput): Promise<T> => {
|
|
91
90
|
await this.ensureSocket();
|
|
92
91
|
const id = createId('req');
|
|
93
92
|
const timeoutMs = Number.isFinite(input.timeoutMs) && (input.timeoutMs ?? 0) > 0
|
|
@@ -115,7 +114,7 @@ export class RemoteSessionMultiplexTransport implements AppTransport {
|
|
|
115
114
|
});
|
|
116
115
|
}
|
|
117
116
|
|
|
118
|
-
openStream<TFinal = unknown>(input: StreamInput): StreamSession<TFinal> {
|
|
117
|
+
openStream = <TFinal = unknown>(input: StreamInput): StreamSession<TFinal> => {
|
|
119
118
|
const streamId = createId('stream');
|
|
120
119
|
let settled = false;
|
|
121
120
|
const rejectEarly = (error: Error) => {
|
|
@@ -198,7 +197,7 @@ export class RemoteSessionMultiplexTransport implements AppTransport {
|
|
|
198
197
|
};
|
|
199
198
|
}
|
|
200
199
|
|
|
201
|
-
subscribe(handler: (event: AppEvent) => void): () => void {
|
|
200
|
+
subscribe = (handler: (event: AppEvent) => void): () => void => {
|
|
202
201
|
this.subscribers.add(handler);
|
|
203
202
|
void this.ensureSocket().catch((error) => {
|
|
204
203
|
handler({
|
|
@@ -211,20 +210,20 @@ export class RemoteSessionMultiplexTransport implements AppTransport {
|
|
|
211
210
|
};
|
|
212
211
|
}
|
|
213
212
|
|
|
214
|
-
private emit(event: AppEvent): void {
|
|
213
|
+
private emit = (event: AppEvent): void => {
|
|
215
214
|
for (const subscriber of this.subscribers) {
|
|
216
215
|
subscriber(event);
|
|
217
216
|
}
|
|
218
217
|
}
|
|
219
218
|
|
|
220
|
-
private send(frame: RemoteBrowserCommand): void {
|
|
219
|
+
private send = (frame: RemoteBrowserCommand): void => {
|
|
221
220
|
if (!this.socket || this.socket.readyState !== WebSocket.OPEN) {
|
|
222
221
|
throw new Error('Remote transport websocket is not connected.');
|
|
223
222
|
}
|
|
224
223
|
this.socket.send(JSON.stringify(frame));
|
|
225
224
|
}
|
|
226
225
|
|
|
227
|
-
private async
|
|
226
|
+
private ensureSocket = async (): Promise<void> => {
|
|
228
227
|
if (this.socket?.readyState === WebSocket.OPEN && this.connectPromise === null) {
|
|
229
228
|
return;
|
|
230
229
|
}
|
|
@@ -296,7 +295,7 @@ export class RemoteSessionMultiplexTransport implements AppTransport {
|
|
|
296
295
|
return await connectPromise;
|
|
297
296
|
}
|
|
298
297
|
|
|
299
|
-
private scheduleReconnect(): void {
|
|
298
|
+
private scheduleReconnect = (): void => {
|
|
300
299
|
if (this.reconnectTimer !== null) {
|
|
301
300
|
return;
|
|
302
301
|
}
|
|
@@ -306,7 +305,7 @@ export class RemoteSessionMultiplexTransport implements AppTransport {
|
|
|
306
305
|
}, 3_000);
|
|
307
306
|
}
|
|
308
307
|
|
|
309
|
-
private failPendingWork(error: Error): void {
|
|
308
|
+
private failPendingWork = (error: Error): void => {
|
|
310
309
|
for (const pending of this.pendingRequests.values()) {
|
|
311
310
|
window.clearTimeout(pending.timeoutId);
|
|
312
311
|
pending.reject(error);
|
|
@@ -319,7 +318,7 @@ export class RemoteSessionMultiplexTransport implements AppTransport {
|
|
|
319
318
|
this.pendingStreams.clear();
|
|
320
319
|
}
|
|
321
320
|
|
|
322
|
-
private handleFrame(frame: RemoteBrowserFrame): void {
|
|
321
|
+
private handleFrame = (frame: RemoteBrowserFrame): void => {
|
|
323
322
|
if (frame.type === 'response' || frame.type === 'request.error') {
|
|
324
323
|
this.handleRequestFrame(frame);
|
|
325
324
|
return;
|
|
@@ -337,7 +336,7 @@ export class RemoteSessionMultiplexTransport implements AppTransport {
|
|
|
337
336
|
}
|
|
338
337
|
}
|
|
339
338
|
|
|
340
|
-
private handleRequestFrame(frame: Extract<RemoteBrowserFrame, { type: 'response' | 'request.error' }>): void {
|
|
339
|
+
private handleRequestFrame = (frame: Extract<RemoteBrowserFrame, { type: 'response' | 'request.error' }>): void => {
|
|
341
340
|
const pending = this.pendingRequests.get(frame.id);
|
|
342
341
|
if (!pending) {
|
|
343
342
|
return;
|
|
@@ -359,7 +358,7 @@ export class RemoteSessionMultiplexTransport implements AppTransport {
|
|
|
359
358
|
}
|
|
360
359
|
}
|
|
361
360
|
|
|
362
|
-
private handleStreamFrame(frame: Extract<RemoteBrowserFrame, { type: 'stream.event' | 'stream.end' | 'stream.error' }>): void {
|
|
361
|
+
private handleStreamFrame = (frame: Extract<RemoteBrowserFrame, { type: 'stream.event' | 'stream.end' | 'stream.error' }>): void => {
|
|
363
362
|
const pending = this.pendingStreams.get(frame.streamId);
|
|
364
363
|
if (!pending) {
|
|
365
364
|
return;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest';
|
|
2
|
-
import { RemoteSessionMultiplexTransport } from '
|
|
2
|
+
import { RemoteSessionMultiplexTransport } from './remote-transport.service';
|
|
3
3
|
|
|
4
4
|
class MockWebSocket {
|
|
5
5
|
static readonly CONNECTING = 0;
|
|
@@ -19,21 +19,21 @@ class MockWebSocket {
|
|
|
19
19
|
MockWebSocket.instances.push(this);
|
|
20
20
|
}
|
|
21
21
|
|
|
22
|
-
send(data: string): void {
|
|
22
|
+
send = (data: string): void => {
|
|
23
23
|
this.sent.push(data);
|
|
24
24
|
}
|
|
25
25
|
|
|
26
|
-
close(): void {
|
|
26
|
+
close = (): void => {
|
|
27
27
|
this.readyState = MockWebSocket.CLOSED;
|
|
28
28
|
this.onclose?.({} as CloseEvent);
|
|
29
29
|
}
|
|
30
30
|
|
|
31
|
-
open(): void {
|
|
31
|
+
open = (): void => {
|
|
32
32
|
this.readyState = MockWebSocket.OPEN;
|
|
33
33
|
this.onopen?.({} as Event);
|
|
34
34
|
}
|
|
35
35
|
|
|
36
|
-
receive(frame: unknown): void {
|
|
36
|
+
receive = (frame: unknown): void => {
|
|
37
37
|
this.onmessage?.({
|
|
38
38
|
data: JSON.stringify(frame)
|
|
39
39
|
} as MessageEvent);
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { describe, expect, it } from 'vitest';
|
|
2
|
-
import { readSseStreamResult } from './sse-stream';
|
|
2
|
+
import { readSseStreamResult } from './sse-stream.utils';
|
|
3
3
|
|
|
4
4
|
function createSseResponse(frames: string[]): Response {
|
|
5
5
|
const payload = new TextEncoder().encode(frames.join(''));
|
|
6
6
|
const stream = new ReadableStream<Uint8Array>({
|
|
7
|
-
start(controller) {
|
|
7
|
+
start: (controller) => {
|
|
8
8
|
controller.enqueue(payload);
|
|
9
9
|
controller.close();
|
|
10
10
|
}
|
|
@@ -52,16 +52,18 @@ function processSseFrame(
|
|
|
52
52
|
}
|
|
53
53
|
|
|
54
54
|
function flushBufferedFrames(
|
|
55
|
-
|
|
55
|
+
buffer: string,
|
|
56
56
|
onEvent: (event: StreamEvent) => void,
|
|
57
57
|
setFinalResult: FinalResultSink
|
|
58
|
-
):
|
|
59
|
-
let
|
|
58
|
+
): string {
|
|
59
|
+
let remainingBuffer = buffer;
|
|
60
|
+
let boundary = remainingBuffer.indexOf('\n\n');
|
|
60
61
|
while (boundary !== -1) {
|
|
61
|
-
processSseFrame(
|
|
62
|
-
|
|
63
|
-
boundary =
|
|
62
|
+
processSseFrame(remainingBuffer.slice(0, boundary), onEvent, setFinalResult);
|
|
63
|
+
remainingBuffer = remainingBuffer.slice(boundary + 2);
|
|
64
|
+
boundary = remainingBuffer.indexOf('\n\n');
|
|
64
65
|
}
|
|
66
|
+
return remainingBuffer;
|
|
65
67
|
}
|
|
66
68
|
|
|
67
69
|
export async function readSseStreamResult<TFinal>(
|
|
@@ -74,7 +76,7 @@ export async function readSseStreamResult<TFinal>(
|
|
|
74
76
|
}
|
|
75
77
|
|
|
76
78
|
const decoder = new TextDecoder();
|
|
77
|
-
|
|
79
|
+
let buffer = '';
|
|
78
80
|
let finalResult: unknown = undefined;
|
|
79
81
|
try {
|
|
80
82
|
while (true) {
|
|
@@ -82,13 +84,13 @@ export async function readSseStreamResult<TFinal>(
|
|
|
82
84
|
if (done) {
|
|
83
85
|
break;
|
|
84
86
|
}
|
|
85
|
-
|
|
86
|
-
flushBufferedFrames(
|
|
87
|
+
buffer += decoder.decode(value, { stream: true });
|
|
88
|
+
buffer = flushBufferedFrames(buffer, onEvent, (nextValue) => {
|
|
87
89
|
finalResult = nextValue;
|
|
88
90
|
});
|
|
89
91
|
}
|
|
90
|
-
if (
|
|
91
|
-
processSseFrame(
|
|
92
|
+
if (buffer.trim()) {
|
|
93
|
+
processSseFrame(buffer, onEvent, (nextValue) => {
|
|
92
94
|
finalResult = nextValue;
|
|
93
95
|
});
|
|
94
96
|
}
|
package/tsconfig.json
CHANGED
|
@@ -11,6 +11,26 @@
|
|
|
11
11
|
"types": ["vite/client", "vitest/globals"],
|
|
12
12
|
"baseUrl": ".",
|
|
13
13
|
"paths": {
|
|
14
|
+
"@/components/auth/login-page": ["./src/features/account/components/login-page.tsx"],
|
|
15
|
+
"@/components/chat/chat-page": ["./src/features/chat/pages/chat-page.tsx"],
|
|
16
|
+
"@/components/config/ChannelsList": ["./src/features/channels/pages/channels-list-page.tsx"],
|
|
17
|
+
"@/components/config/desktop-update-config": ["./src/features/system-status/components/desktop-update-config.tsx"],
|
|
18
|
+
"@/components/config/ModelConfig": ["./src/shared/components/model-config.tsx"],
|
|
19
|
+
"@/components/config/ProvidersList": ["./src/shared/components/config/providers-list.tsx"],
|
|
20
|
+
"@/components/config/RuntimeConfig": ["./src/features/system-status/pages/runtime-config-page.tsx"],
|
|
21
|
+
"@/components/config/SearchConfig": ["./src/shared/components/search-config.tsx"],
|
|
22
|
+
"@/components/config/SecretsConfig": ["./src/shared/components/config/secrets-config.tsx"],
|
|
23
|
+
"@/components/config/security-config": ["./src/features/system-status/components/security-config.tsx"],
|
|
24
|
+
"@/components/config/SessionsConfig": ["./src/features/chat/pages/sessions-config-page.tsx"],
|
|
25
|
+
"@/components/layout/AppLayout": ["./src/app/components/layout/app-layout.tsx"],
|
|
26
|
+
"@/components/marketplace/marketplace-page": ["./src/features/marketplace/components/marketplace-page.tsx"],
|
|
27
|
+
"@/components/marketplace/mcp/mcp-marketplace-page": ["./src/features/marketplace/components/mcp/mcp-marketplace-page.tsx"],
|
|
28
|
+
"@/components/providers/I18nProvider": ["./src/app/components/i18n-provider.tsx"],
|
|
29
|
+
"@/components/providers/ThemeProvider": ["./src/app/components/theme-provider.tsx"],
|
|
30
|
+
"@/hooks/use-auth": ["./src/features/account/hooks/use-auth.ts"],
|
|
31
|
+
"@/hooks/use-realtime-query-bridge": ["./src/app/hooks/use-realtime-query-bridge.ts"],
|
|
32
|
+
"@/pwa/components/pwa-install-entry": ["./src/features/pwa/components/pwa-install-entry.tsx"],
|
|
33
|
+
"@/pwa/register-pwa": ["./src/features/pwa/managers/pwa-bootstrap.manager.ts"],
|
|
14
34
|
"@/*": ["./src/*"],
|
|
15
35
|
"@nextclaw/agent-chat": ["../nextclaw-agent-chat/src/index.ts"],
|
|
16
36
|
"@nextclaw/agent-chat-ui": ["../nextclaw-agent-chat-ui/src/index.ts"],
|
package/vite.config.ts
CHANGED
|
@@ -1,14 +1,68 @@
|
|
|
1
1
|
import { defineConfig } from 'vite';
|
|
2
2
|
import react from '@vitejs/plugin-react';
|
|
3
3
|
import path from 'path';
|
|
4
|
+
import type { IncomingMessage, ServerResponse } from 'node:http';
|
|
5
|
+
import type { Socket } from 'node:net';
|
|
4
6
|
|
|
5
7
|
const devProxyApiBase = process.env.VITE_DEV_PROXY_API_BASE ?? 'http://127.0.0.1:18792';
|
|
6
8
|
const devProxyWsBase = devProxyApiBase.replace(/^http/i, 'ws');
|
|
7
9
|
|
|
10
|
+
function isBackendNotReadyError(error: Error & { code?: string }): boolean {
|
|
11
|
+
return error.code === 'ECONNREFUSED';
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
function writeBackendStartingResponse(res: ServerResponse): void {
|
|
15
|
+
if (res.headersSent) {
|
|
16
|
+
res.end();
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
res.writeHead(503, {
|
|
20
|
+
'content-type': 'application/json',
|
|
21
|
+
});
|
|
22
|
+
res.end(JSON.stringify({
|
|
23
|
+
error: 'backend_starting',
|
|
24
|
+
message: 'NextClaw backend is still starting. Please retry shortly.',
|
|
25
|
+
}));
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
function handleDevProxyError(error: Error & { code?: string }, _req: IncomingMessage, res?: ServerResponse | Socket): void {
|
|
29
|
+
if (!isBackendNotReadyError(error)) {
|
|
30
|
+
console.warn(`[vite] proxy error: ${error.message}`);
|
|
31
|
+
}
|
|
32
|
+
if (!res) {
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
if ('writeHead' in res) {
|
|
36
|
+
writeBackendStartingResponse(res);
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
res.destroy();
|
|
40
|
+
}
|
|
41
|
+
|
|
8
42
|
export default defineConfig({
|
|
9
43
|
plugins: [react()],
|
|
10
44
|
resolve: {
|
|
11
45
|
alias: {
|
|
46
|
+
'@/components/auth/login-page': path.resolve(__dirname, './src/features/account/components/login-page.tsx'),
|
|
47
|
+
'@/components/chat/chat-page': path.resolve(__dirname, './src/features/chat/pages/chat-page.tsx'),
|
|
48
|
+
'@/components/config/ChannelsList': path.resolve(__dirname, './src/features/channels/pages/channels-list-page.tsx'),
|
|
49
|
+
'@/components/config/desktop-update-config': path.resolve(__dirname, './src/features/system-status/components/desktop-update-config.tsx'),
|
|
50
|
+
'@/components/config/ModelConfig': path.resolve(__dirname, './src/shared/components/model-config.tsx'),
|
|
51
|
+
'@/components/config/ProvidersList': path.resolve(__dirname, './src/shared/components/config/providers-list.tsx'),
|
|
52
|
+
'@/components/config/RuntimeConfig': path.resolve(__dirname, './src/features/system-status/pages/runtime-config-page.tsx'),
|
|
53
|
+
'@/components/config/SearchConfig': path.resolve(__dirname, './src/shared/components/search-config.tsx'),
|
|
54
|
+
'@/components/config/SecretsConfig': path.resolve(__dirname, './src/shared/components/config/secrets-config.tsx'),
|
|
55
|
+
'@/components/config/security-config': path.resolve(__dirname, './src/features/system-status/components/security-config.tsx'),
|
|
56
|
+
'@/components/config/SessionsConfig': path.resolve(__dirname, './src/features/chat/pages/sessions-config-page.tsx'),
|
|
57
|
+
'@/components/layout/AppLayout': path.resolve(__dirname, './src/app/components/layout/app-layout.tsx'),
|
|
58
|
+
'@/components/marketplace/marketplace-page': path.resolve(__dirname, './src/features/marketplace/components/marketplace-page.tsx'),
|
|
59
|
+
'@/components/marketplace/mcp/mcp-marketplace-page': path.resolve(__dirname, './src/features/marketplace/components/mcp/mcp-marketplace-page.tsx'),
|
|
60
|
+
'@/components/providers/I18nProvider': path.resolve(__dirname, './src/app/components/i18n-provider.tsx'),
|
|
61
|
+
'@/components/providers/ThemeProvider': path.resolve(__dirname, './src/app/components/theme-provider.tsx'),
|
|
62
|
+
'@/hooks/use-auth': path.resolve(__dirname, './src/features/account/hooks/use-auth.ts'),
|
|
63
|
+
'@/hooks/use-realtime-query-bridge': path.resolve(__dirname, './src/app/hooks/use-realtime-query-bridge.ts'),
|
|
64
|
+
'@/pwa/components/pwa-install-entry': path.resolve(__dirname, './src/features/pwa/components/pwa-install-entry.tsx'),
|
|
65
|
+
'@/pwa/register-pwa': path.resolve(__dirname, './src/features/pwa/managers/pwa-bootstrap.manager.ts'),
|
|
12
66
|
'@': path.resolve(__dirname, './src'),
|
|
13
67
|
'@nextclaw/agent-chat': path.resolve(__dirname, '../nextclaw-agent-chat/src/index.ts'),
|
|
14
68
|
'@nextclaw/agent-chat-ui': path.resolve(__dirname, '../nextclaw-agent-chat-ui/src/index.ts')
|
|
@@ -21,11 +75,17 @@ export default defineConfig({
|
|
|
21
75
|
proxy: {
|
|
22
76
|
'/api': {
|
|
23
77
|
target: devProxyApiBase,
|
|
24
|
-
changeOrigin: true
|
|
78
|
+
changeOrigin: true,
|
|
79
|
+
configure: (proxy) => {
|
|
80
|
+
proxy.on('error', handleDevProxyError);
|
|
81
|
+
}
|
|
25
82
|
},
|
|
26
83
|
'/ws': {
|
|
27
84
|
target: devProxyWsBase,
|
|
28
|
-
ws: true
|
|
85
|
+
ws: true,
|
|
86
|
+
configure: (proxy) => {
|
|
87
|
+
proxy.on('error', handleDevProxyError);
|
|
88
|
+
}
|
|
29
89
|
}
|
|
30
90
|
}
|
|
31
91
|
}
|
package/vitest.config.ts
CHANGED
|
@@ -4,6 +4,26 @@ import { defineConfig } from 'vitest/config';
|
|
|
4
4
|
export default defineConfig({
|
|
5
5
|
resolve: {
|
|
6
6
|
alias: {
|
|
7
|
+
'@/components/auth/login-page': path.resolve(__dirname, './src/features/account/components/login-page.tsx'),
|
|
8
|
+
'@/components/chat/chat-page': path.resolve(__dirname, './src/features/chat/pages/chat-page.tsx'),
|
|
9
|
+
'@/components/config/ChannelsList': path.resolve(__dirname, './src/features/channels/pages/channels-list-page.tsx'),
|
|
10
|
+
'@/components/config/desktop-update-config': path.resolve(__dirname, './src/features/system-status/components/desktop-update-config.tsx'),
|
|
11
|
+
'@/components/config/ModelConfig': path.resolve(__dirname, './src/shared/components/model-config.tsx'),
|
|
12
|
+
'@/components/config/ProvidersList': path.resolve(__dirname, './src/shared/components/config/providers-list.tsx'),
|
|
13
|
+
'@/components/config/RuntimeConfig': path.resolve(__dirname, './src/features/system-status/pages/runtime-config-page.tsx'),
|
|
14
|
+
'@/components/config/SearchConfig': path.resolve(__dirname, './src/shared/components/search-config.tsx'),
|
|
15
|
+
'@/components/config/SecretsConfig': path.resolve(__dirname, './src/shared/components/config/secrets-config.tsx'),
|
|
16
|
+
'@/components/config/security-config': path.resolve(__dirname, './src/features/system-status/components/security-config.tsx'),
|
|
17
|
+
'@/components/config/SessionsConfig': path.resolve(__dirname, './src/features/chat/pages/sessions-config-page.tsx'),
|
|
18
|
+
'@/components/layout/AppLayout': path.resolve(__dirname, './src/app/components/layout/app-layout.tsx'),
|
|
19
|
+
'@/components/marketplace/marketplace-page': path.resolve(__dirname, './src/features/marketplace/components/marketplace-page.tsx'),
|
|
20
|
+
'@/components/marketplace/mcp/mcp-marketplace-page': path.resolve(__dirname, './src/features/marketplace/components/mcp/mcp-marketplace-page.tsx'),
|
|
21
|
+
'@/components/providers/I18nProvider': path.resolve(__dirname, './src/app/components/i18n-provider.tsx'),
|
|
22
|
+
'@/components/providers/ThemeProvider': path.resolve(__dirname, './src/app/components/theme-provider.tsx'),
|
|
23
|
+
'@/hooks/use-auth': path.resolve(__dirname, './src/features/account/hooks/use-auth.ts'),
|
|
24
|
+
'@/hooks/use-realtime-query-bridge': path.resolve(__dirname, './src/app/hooks/use-realtime-query-bridge.ts'),
|
|
25
|
+
'@/pwa/components/pwa-install-entry': path.resolve(__dirname, './src/features/pwa/components/pwa-install-entry.tsx'),
|
|
26
|
+
'@/pwa/register-pwa': path.resolve(__dirname, './src/features/pwa/managers/pwa-bootstrap.manager.ts'),
|
|
7
27
|
'@': path.resolve(__dirname, './src'),
|
|
8
28
|
'@nextclaw/agent-chat': path.resolve(__dirname, '../nextclaw-agent-chat/src/index.ts')
|
|
9
29
|
}
|
|
@@ -11,6 +31,6 @@ export default defineConfig({
|
|
|
11
31
|
test: {
|
|
12
32
|
environment: 'jsdom',
|
|
13
33
|
globals: true,
|
|
14
|
-
setupFiles: ['./src/test/setup.ts']
|
|
34
|
+
setupFiles: ['./src/app/test/vitest-setup.ts']
|
|
15
35
|
}
|
|
16
36
|
});
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import{_ as e,h as t,i as n,m as r,n as i,o as a,p as o,u as s}from"./i18n-CpTZLchQ.js";import{n as c,r as l}from"./dist-BruyLa92.js";import{n as u,s as d,t as f}from"./client-C-8fH7-c.js";import{t as p}from"./useMutation-CNcz2fgt.js";import{O as m,a as h,i as g,n as _,r as v,t as y}from"./select-CVz0t7MF.js";import{t as b}from"./createLucideIcon-dy5ie7Ox.js";import{t as x}from"./book-open-DzdUViDm.js";import{t as S}from"./external-link-kZSAO8nT.js";import{n as C,t as w}from"./logos-B7gRObP8.js";import{t as T}from"./hash-BHJC2Ovu.js";import{t as E}from"./loader-circle-Bc2gCU33.js";import{t as D}from"./search-BCAlB8nz.js";import{t as O}from"./x-Czwxm82I.js";import{Et as k,O as ee,R as te,S as A,b as j,kt as M,mt as N,pt as ne,wt as re,x as ie}from"./index-zDZfXoI4.js";import{t as P}from"./LogoBadge-hO7tY7hE.js";import{t as F}from"./tag-chip-DMXdnLcj.js";import{n as I,t as L}from"./page-layout-0UcO9H9Z.js";import{t as R}from"./tabs-custom-YcZUWn3o.js";import{t as z}from"./status-dot-DpPtVzQT.js";import{t as B}from"./config-hints-BhTmc9P1.js";import{a as V,c as H,i as ae,n as oe,o as U,r as se,s as ce,t as le}from"./config-split-page-BUout_Ak.js";import{t as ue}from"./switch-CM29eCAR.js";var de=b(`Mail`,[[`rect`,{width:`20`,height:`16`,x:`2`,y:`4`,rx:`2`,key:`18n3k1`}],[`path`,{d:`m22 7-8.97 5.7a1.94 1.94 0 0 1-2.06 0L2 7`,key:`1ocrg3`}]]),fe=b(`MessageCircleMore`,[[`path`,{d:`M7.9 20A9 9 0 1 0 4 16.1L2 22Z`,key:`vv11sd`}],[`path`,{d:`M8 12h.01`,key:`czm47f`}],[`path`,{d:`M12 12h.01`,key:`1mp3jc`}],[`path`,{d:`M16 12h.01`,key:`1l6xoz`}]]),W=b(`QrCode`,[[`rect`,{width:`5`,height:`5`,x:`3`,y:`3`,rx:`1`,key:`1tu5fj`}],[`rect`,{width:`5`,height:`5`,x:`16`,y:`3`,rx:`1`,key:`1v8r4q`}],[`rect`,{width:`5`,height:`5`,x:`3`,y:`16`,rx:`1`,key:`1x03jg`}],[`path`,{d:`M21 16h-3a2 2 0 0 0-2 2v3`,key:`177gqh`}],[`path`,{d:`M21 21v.01`,key:`ents32`}],[`path`,{d:`M12 7v3a2 2 0 0 1-2 2H7`,key:`8crl2c`}],[`path`,{d:`M3 12h.01`,key:`nlz23k`}],[`path`,{d:`M12 3h.01`,key:`n36tog`}],[`path`,{d:`M12 16v.01`,key:`133mhm`}],[`path`,{d:`M16 12h1`,key:`1slzba`}],[`path`,{d:`M21 12v.01`,key:`1lwtk9`}],[`path`,{d:`M12 21v-1`,key:`1880an`}]]),pe=b(`ToggleLeft`,[[`rect`,{width:`20`,height:`12`,x:`2`,y:`6`,rx:`6`,ry:`6`,key:`f2vt7d`}],[`circle`,{cx:`8`,cy:`12`,r:`2`,key:`1nvbw3`}]]),G=e(r(),1);function K(e){let t=a();return e.tutorialUrls?.[t]||e.tutorialUrls?.default||e.tutorialUrl}var q=[{value:`pairing`,label:`pairing`},{value:`allowlist`,label:`allowlist`},{value:`open`,label:`open`},{value:`disabled`,label:`disabled`}],J=[{value:`open`,label:`open`},{value:`allowlist`,label:`allowlist`},{value:`disabled`,label:`disabled`}],me=[{value:`off`,label:`off`},{value:`partial`,label:`partial`},{value:`block`,label:`block`},{value:`progress`,label:`progress`}];function he(){return{telegram:{fields:[{name:`enabled`,type:`boolean`,label:n(`enabled`)},{name:`token`,type:`password`,label:n(`botToken`)},{name:`allowFrom`,type:`tags`,label:n(`allowFrom`)},{name:`proxy`,type:`text`,label:n(`proxy`)},{name:`accountId`,type:`text`,label:n(`accountId`)},{name:`dmPolicy`,type:`select`,label:n(`dmPolicy`),options:q},{name:`groupPolicy`,type:`select`,label:n(`groupPolicy`),options:J},{name:`groupAllowFrom`,type:`tags`,label:n(`groupAllowFrom`)},{name:`requireMention`,type:`boolean`,label:n(`requireMention`)},{name:`mentionPatterns`,type:`tags`,label:n(`mentionPatterns`)},{name:`groups`,type:`json`,label:n(`groupRulesJson`)}]},discord:{fields:[{name:`enabled`,type:`boolean`,label:n(`enabled`)},{name:`token`,type:`password`,label:n(`botToken`)},{name:`allowBots`,type:`boolean`,label:n(`allowBotMessages`)},{name:`allowFrom`,type:`tags`,label:n(`allowFrom`)},{name:`gatewayUrl`,type:`text`,label:n(`gatewayUrl`)},{name:`intents`,type:`number`,label:n(`intents`)},{name:`proxy`,type:`text`,label:n(`proxy`)},{name:`mediaMaxMb`,type:`number`,label:n(`attachmentMaxSizeMb`)},{name:`streaming`,type:`select`,label:n(`streamingMode`),options:me},{name:`draftChunk`,type:`json`,label:n(`draftChunkingJson`)},{name:`textChunkLimit`,type:`number`,label:n(`textChunkLimit`)},{name:`accountId`,type:`text`,label:n(`accountId`)},{name:`dmPolicy`,type:`select`,label:n(`dmPolicy`),options:q},{name:`groupPolicy`,type:`select`,label:n(`groupPolicy`),options:J},{name:`groupAllowFrom`,type:`tags`,label:n(`groupAllowFrom`)},{name:`requireMention`,type:`boolean`,label:n(`requireMention`)},{name:`mentionPatterns`,type:`tags`,label:n(`mentionPatterns`)},{name:`groups`,type:`json`,label:n(`groupRulesJson`)}]},whatsapp:{fields:[{name:`enabled`,type:`boolean`,label:n(`enabled`)},{name:`bridgeUrl`,type:`text`,label:n(`bridgeUrl`)},{name:`allowFrom`,type:`tags`,label:n(`allowFrom`)}]},feishu:{fields:[{name:`enabled`,type:`boolean`,label:n(`enabled`)},{name:`appId`,type:`text`,label:n(`appId`)},{name:`appSecret`,type:`password`,label:n(`appSecret`)},{name:`encryptKey`,type:`password`,label:n(`encryptKey`)},{name:`verificationToken`,type:`password`,label:n(`verificationToken`)},{name:`domain`,type:`text`,label:`Domain`},{name:`allowFrom`,type:`tags`,label:n(`allowFrom`)},{name:`dmPolicy`,type:`select`,label:n(`dmPolicy`),options:q},{name:`groupPolicy`,type:`select`,label:n(`groupPolicy`),options:J},{name:`groupAllowFrom`,type:`tags`,label:n(`groupAllowFrom`)},{name:`requireMention`,type:`boolean`,label:n(`requireMention`)},{name:`mentionPatterns`,type:`tags`,label:n(`mentionPatterns`)},{name:`groups`,type:`json`,label:n(`groupRulesJson`)},{name:`accounts`,type:`json`,label:n(`accountsJson`)}]},dingtalk:{fields:[{name:`enabled`,type:`boolean`,label:n(`enabled`)},{name:`clientId`,type:`text`,label:n(`clientId`)},{name:`clientSecret`,type:`password`,label:n(`clientSecret`)},{name:`allowFrom`,type:`tags`,label:n(`allowFrom`)}]},wecom:{fields:[{name:`enabled`,type:`boolean`,label:n(`enabled`)},{name:`corpId`,type:`text`,label:n(`corpId`)},{name:`agentId`,type:`text`,label:n(`agentId`)},{name:`secret`,type:`password`,label:n(`secret`)},{name:`token`,type:`password`,label:n(`token`)},{name:`callbackPort`,type:`number`,label:n(`callbackPort`)},{name:`callbackPath`,type:`text`,label:n(`callbackPath`)},{name:`allowFrom`,type:`tags`,label:n(`allowFrom`)}]},weixin:{fields:[{name:`enabled`,type:`boolean`,label:n(`enabled`),section:`primary`},{name:`defaultAccountId`,type:`text`,label:n(`defaultAccountId`)},{name:`baseUrl`,type:`text`,label:n(`baseUrl`)},{name:`pollTimeoutMs`,type:`number`,label:n(`pollTimeoutMs`)},{name:`allowFrom`,type:`tags`,label:n(`allowFrom`)},{name:`accounts`,type:`json`,label:n(`accountsJson`)}],layout:[{type:`fields`,section:`primary`},{type:`custom`,sectionId:`weixin-auth`},{type:`fields`,section:`advanced`,collapsible:{title:n(`weixinAuthAdvancedTitle`),description:n(`weixinAuthAdvancedDescription`)}}]},slack:{fields:[{name:`enabled`,type:`boolean`,label:n(`enabled`)},{name:`mode`,type:`text`,label:n(`mode`)},{name:`webhookPath`,type:`text`,label:n(`webhookPath`)},{name:`allowBots`,type:`boolean`,label:n(`allowBotMessages`)},{name:`botToken`,type:`password`,label:n(`botToken`)},{name:`appToken`,type:`password`,label:n(`appToken`)}]},email:{fields:[{name:`enabled`,type:`boolean`,label:n(`enabled`)},{name:`consentGranted`,type:`boolean`,label:n(`consentGranted`)},{name:`imapHost`,type:`text`,label:n(`imapHost`)},{name:`imapPort`,type:`number`,label:n(`imapPort`)},{name:`imapUsername`,type:`text`,label:n(`imapUsername`)},{name:`imapPassword`,type:`password`,label:n(`imapPassword`)},{name:`fromAddress`,type:`email`,label:n(`fromAddress`)}]},mochat:{fields:[{name:`enabled`,type:`boolean`,label:n(`enabled`)},{name:`baseUrl`,type:`text`,label:n(`baseUrl`)},{name:`clawToken`,type:`password`,label:n(`clawToken`)},{name:`agentUserId`,type:`text`,label:n(`agentUserId`)},{name:`allowFrom`,type:`tags`,label:n(`allowFrom`)}]},qq:{fields:[{name:`enabled`,type:`boolean`,label:n(`enabled`)},{name:`appId`,type:`text`,label:n(`appId`)},{name:`secret`,type:`password`,label:n(`appSecret`)},{name:`markdownSupport`,type:`boolean`,label:n(`markdownSupport`)},{name:`allowFrom`,type:`tags`,label:n(`allowFrom`)}]}}}var Y=o();function ge({value:e,onChange:t,className:r,placeholder:i=``}){let[a,o]=(0,G.useState)(``),c=n=>{n.key===`Enter`&&a.trim()?(n.preventDefault(),t([...e,a.trim()]),o(``)):n.key===`Backspace`&&!a&&e.length>0&&t(e.slice(0,-1))},l=n=>{t(e.filter((e,t)=>t!==n))};return(0,Y.jsxs)(`div`,{className:s(`flex min-h-[42px] flex-wrap gap-2 rounded-xl border border-gray-200/80 bg-white p-2`,r),children:[e.map((e,t)=>(0,Y.jsxs)(F,{tone:`info`,className:`gap-1 px-2 py-1 text-sm`,children:[e,(0,Y.jsx)(`button`,{type:`button`,onClick:()=>l(t),className:`transition-colors hover:text-rose-200`,children:(0,Y.jsx)(O,{className:`h-3 w-3`})})]},t)),(0,Y.jsx)(`input`,{type:`text`,value:a,onChange:e=>o(e.target.value),onKeyDown:c,className:`flex-1 outline-none min-w-[100px] bg-transparent text-sm`,placeholder:i||n(`enterTag`)})]})}function _e(e){return e.includes(`token`)||e.includes(`secret`)||e.includes(`password`)?(0,Y.jsx)(M,{className:`h-3.5 w-3.5 text-gray-500`}):e.includes(`url`)||e.includes(`host`)?(0,Y.jsx)(C,{className:`h-3.5 w-3.5 text-gray-500`}):e.includes(`email`)||e.includes(`mail`)?(0,Y.jsx)(de,{className:`h-3.5 w-3.5 text-gray-500`}):e.includes(`id`)||e.includes(`from`)?(0,Y.jsx)(T,{className:`h-3.5 w-3.5 text-gray-500`}):e===`enabled`||e===`consentGranted`?(0,Y.jsx)(pe,{className:`h-3.5 w-3.5 text-gray-500`}):(0,Y.jsx)(re,{className:`h-3.5 w-3.5 text-gray-500`})}function ve({channelName:e,fields:t,formData:r,jsonDrafts:i,setJsonDrafts:a,updateField:o,uiHints:s}){return(0,Y.jsx)(Y.Fragment,{children:t.map(t=>{let c=B(`channels.${e}.${t.name}`,s),l=c?.label??t.label,u=c?.placeholder;return(0,Y.jsxs)(`div`,{className:`space-y-2.5`,children:[(0,Y.jsxs)(ne,{htmlFor:t.name,className:`flex items-center gap-2 text-sm font-medium text-gray-900`,children:[_e(t.name),l]}),t.type===`boolean`&&(0,Y.jsxs)(`div`,{className:`flex items-center justify-between rounded-xl bg-gray-50 p-3`,children:[(0,Y.jsx)(`span`,{className:`text-sm text-gray-500`,children:r[t.name]?n(`enabled`):n(`disabled`)}),(0,Y.jsx)(ue,{id:t.name,checked:r[t.name]||!1,onCheckedChange:e=>o(t.name,e),className:`data-[state=checked]:bg-emerald-500`})]}),(t.type===`text`||t.type===`email`)&&(0,Y.jsx)(N,{id:t.name,type:t.type,value:r[t.name]||``,onChange:e=>o(t.name,e.target.value),placeholder:u,className:`rounded-xl`}),t.type===`password`&&(0,Y.jsx)(N,{id:t.name,type:`password`,value:r[t.name]||``,onChange:e=>o(t.name,e.target.value),placeholder:u??n(`leaveBlankToKeepUnchanged`),className:`rounded-xl`}),t.type===`number`&&(0,Y.jsx)(N,{id:t.name,type:`number`,value:r[t.name]||0,onChange:e=>o(t.name,parseInt(e.target.value,10)||0),placeholder:u,className:`rounded-xl`}),t.type===`tags`&&(0,Y.jsx)(ge,{value:r[t.name]||[],onChange:e=>o(t.name,e)}),t.type===`select`&&(0,Y.jsxs)(y,{value:r[t.name]||``,onValueChange:e=>o(t.name,e),children:[(0,Y.jsx)(g,{className:`rounded-xl`,children:(0,Y.jsx)(h,{})}),(0,Y.jsx)(_,{children:(t.options??[]).map(e=>(0,Y.jsx)(v,{value:e.value,children:e.label},e.value))})]}),t.type===`json`&&(0,Y.jsx)(`textarea`,{id:t.name,value:i[t.name]??`{}`,onChange:e=>a(n=>({...n,[t.name]:e.target.value})),className:`min-h-[120px] w-full resize-none rounded-lg border border-gray-200 bg-white px-3 py-2 text-xs font-mono`})]},t.name)})})}var ye=t(((e,t)=>{t.exports=function(){return typeof Promise==`function`&&Promise.prototype&&Promise.prototype.then}})),X=t((e=>{var t,n=[0,26,44,70,100,134,172,196,242,292,346,404,466,532,581,655,733,815,901,991,1085,1156,1258,1364,1474,1588,1706,1828,1921,2051,2185,2323,2465,2611,2761,2876,3034,3196,3362,3532,3706];e.getSymbolSize=function(e){if(!e)throw Error(`"version" cannot be null or undefined`);if(e<1||e>40)throw Error(`"version" should be in range from 1 to 40`);return e*4+17},e.getSymbolTotalCodewords=function(e){return n[e]},e.getBCHDigit=function(e){let t=0;for(;e!==0;)t++,e>>>=1;return t},e.setToSJISFunction=function(e){if(typeof e!=`function`)throw Error(`"toSJISFunc" is not a valid function.`);t=e},e.isKanjiModeEnabled=function(){return t!==void 0},e.toSJIS=function(e){return t(e)}})),Z=t((e=>{e.L={bit:1},e.M={bit:0},e.Q={bit:3},e.H={bit:2};function t(t){if(typeof t!=`string`)throw Error(`Param is not a string`);switch(t.toLowerCase()){case`l`:case`low`:return e.L;case`m`:case`medium`:return e.M;case`q`:case`quartile`:return e.Q;case`h`:case`high`:return e.H;default:throw Error(`Unknown EC Level: `+t)}}e.isValid=function(e){return e&&e.bit!==void 0&&e.bit>=0&&e.bit<4},e.from=function(n,r){if(e.isValid(n))return n;try{return t(n)}catch{return r}}})),be=t(((e,t)=>{function n(){this.buffer=[],this.length=0}n.prototype={get:function(e){let t=Math.floor(e/8);return(this.buffer[t]>>>7-e%8&1)==1},put:function(e,t){for(let n=0;n<t;n++)this.putBit((e>>>t-n-1&1)==1)},getLengthInBits:function(){return this.length},putBit:function(e){let t=Math.floor(this.length/8);this.buffer.length<=t&&this.buffer.push(0),e&&(this.buffer[t]|=128>>>this.length%8),this.length++}},t.exports=n})),xe=t(((e,t)=>{function n(e){if(!e||e<1)throw Error(`BitMatrix size must be defined and greater than 0`);this.size=e,this.data=new Uint8Array(e*e),this.reservedBit=new Uint8Array(e*e)}n.prototype.set=function(e,t,n,r){let i=e*this.size+t;this.data[i]=n,r&&(this.reservedBit[i]=!0)},n.prototype.get=function(e,t){return this.data[e*this.size+t]},n.prototype.xor=function(e,t,n){this.data[e*this.size+t]^=n},n.prototype.isReserved=function(e,t){return this.reservedBit[e*this.size+t]},t.exports=n})),Se=t((e=>{var t=X().getSymbolSize;e.getRowColCoords=function(e){if(e===1)return[];let n=Math.floor(e/7)+2,r=t(e),i=r===145?26:Math.ceil((r-13)/(2*n-2))*2,a=[r-7];for(let e=1;e<n-1;e++)a[e]=a[e-1]-i;return a.push(6),a.reverse()},e.getPositions=function(t){let n=[],r=e.getRowColCoords(t),i=r.length;for(let e=0;e<i;e++)for(let t=0;t<i;t++)e===0&&t===0||e===0&&t===i-1||e===i-1&&t===0||n.push([r[e],r[t]]);return n}})),Ce=t((e=>{var t=X().getSymbolSize,n=7;e.getPositions=function(e){let r=t(e);return[[0,0],[r-n,0],[0,r-n]]}})),we=t((e=>{e.Patterns={PATTERN000:0,PATTERN001:1,PATTERN010:2,PATTERN011:3,PATTERN100:4,PATTERN101:5,PATTERN110:6,PATTERN111:7};var t={N1:3,N2:3,N3:40,N4:10};e.isValid=function(e){return e!=null&&e!==``&&!isNaN(e)&&e>=0&&e<=7},e.from=function(t){return e.isValid(t)?parseInt(t,10):void 0},e.getPenaltyN1=function(e){let n=e.size,r=0,i=0,a=0,o=null,s=null;for(let c=0;c<n;c++){i=a=0,o=s=null;for(let l=0;l<n;l++){let n=e.get(c,l);n===o?i++:(i>=5&&(r+=t.N1+(i-5)),o=n,i=1),n=e.get(l,c),n===s?a++:(a>=5&&(r+=t.N1+(a-5)),s=n,a=1)}i>=5&&(r+=t.N1+(i-5)),a>=5&&(r+=t.N1+(a-5))}return r},e.getPenaltyN2=function(e){let n=e.size,r=0;for(let t=0;t<n-1;t++)for(let i=0;i<n-1;i++){let n=e.get(t,i)+e.get(t,i+1)+e.get(t+1,i)+e.get(t+1,i+1);(n===4||n===0)&&r++}return r*t.N2},e.getPenaltyN3=function(e){let n=e.size,r=0,i=0,a=0;for(let t=0;t<n;t++){i=a=0;for(let o=0;o<n;o++)i=i<<1&2047|e.get(t,o),o>=10&&(i===1488||i===93)&&r++,a=a<<1&2047|e.get(o,t),o>=10&&(a===1488||a===93)&&r++}return r*t.N3},e.getPenaltyN4=function(e){let n=0,r=e.data.length;for(let t=0;t<r;t++)n+=e.data[t];return Math.abs(Math.ceil(n*100/r/5)-10)*t.N4};function n(t,n,r){switch(t){case e.Patterns.PATTERN000:return(n+r)%2==0;case e.Patterns.PATTERN001:return n%2==0;case e.Patterns.PATTERN010:return r%3==0;case e.Patterns.PATTERN011:return(n+r)%3==0;case e.Patterns.PATTERN100:return(Math.floor(n/2)+Math.floor(r/3))%2==0;case e.Patterns.PATTERN101:return n*r%2+n*r%3==0;case e.Patterns.PATTERN110:return(n*r%2+n*r%3)%2==0;case e.Patterns.PATTERN111:return(n*r%3+(n+r)%2)%2==0;default:throw Error(`bad maskPattern:`+t)}}e.applyMask=function(e,t){let r=t.size;for(let i=0;i<r;i++)for(let a=0;a<r;a++)t.isReserved(a,i)||t.xor(a,i,n(e,a,i))},e.getBestMask=function(t,n){let r=Object.keys(e.Patterns).length,i=0,a=1/0;for(let o=0;o<r;o++){n(o),e.applyMask(o,t);let r=e.getPenaltyN1(t)+e.getPenaltyN2(t)+e.getPenaltyN3(t)+e.getPenaltyN4(t);e.applyMask(o,t),r<a&&(a=r,i=o)}return i}})),Te=t((e=>{var t=Z(),n=[1,1,1,1,1,1,1,1,1,1,2,2,1,2,2,4,1,2,4,4,2,4,4,4,2,4,6,5,2,4,6,6,2,5,8,8,4,5,8,8,4,5,8,11,4,8,10,11,4,9,12,16,4,9,16,16,6,10,12,18,6,10,17,16,6,11,16,19,6,13,18,21,7,14,21,25,8,16,20,25,8,17,23,25,9,17,23,34,9,18,25,30,10,20,27,32,12,21,29,35,12,23,34,37,12,25,34,40,13,26,35,42,14,28,38,45,15,29,40,48,16,31,43,51,17,33,45,54,18,35,48,57,19,37,51,60,19,38,53,63,20,40,56,66,21,43,59,70,22,45,62,74,24,47,65,77,25,49,68,81],r=[7,10,13,17,10,16,22,28,15,26,36,44,20,36,52,64,26,48,72,88,36,64,96,112,40,72,108,130,48,88,132,156,60,110,160,192,72,130,192,224,80,150,224,264,96,176,260,308,104,198,288,352,120,216,320,384,132,240,360,432,144,280,408,480,168,308,448,532,180,338,504,588,196,364,546,650,224,416,600,700,224,442,644,750,252,476,690,816,270,504,750,900,300,560,810,960,312,588,870,1050,336,644,952,1110,360,700,1020,1200,390,728,1050,1260,420,784,1140,1350,450,812,1200,1440,480,868,1290,1530,510,924,1350,1620,540,980,1440,1710,570,1036,1530,1800,570,1064,1590,1890,600,1120,1680,1980,630,1204,1770,2100,660,1260,1860,2220,720,1316,1950,2310,750,1372,2040,2430];e.getBlocksCount=function(e,r){switch(r){case t.L:return n[(e-1)*4+0];case t.M:return n[(e-1)*4+1];case t.Q:return n[(e-1)*4+2];case t.H:return n[(e-1)*4+3];default:return}},e.getTotalCodewordsCount=function(e,n){switch(n){case t.L:return r[(e-1)*4+0];case t.M:return r[(e-1)*4+1];case t.Q:return r[(e-1)*4+2];case t.H:return r[(e-1)*4+3];default:return}}})),Ee=t((e=>{var t=new Uint8Array(512),n=new Uint8Array(256);(function(){let e=1;for(let r=0;r<255;r++)t[r]=e,n[e]=r,e<<=1,e&256&&(e^=285);for(let e=255;e<512;e++)t[e]=t[e-255]})(),e.log=function(e){if(e<1)throw Error(`log(`+e+`)`);return n[e]},e.exp=function(e){return t[e]},e.mul=function(e,r){return e===0||r===0?0:t[n[e]+n[r]]}})),De=t((e=>{var t=Ee();e.mul=function(e,n){let r=new Uint8Array(e.length+n.length-1);for(let i=0;i<e.length;i++)for(let a=0;a<n.length;a++)r[i+a]^=t.mul(e[i],n[a]);return r},e.mod=function(e,n){let r=new Uint8Array(e);for(;r.length-n.length>=0;){let e=r[0];for(let i=0;i<n.length;i++)r[i]^=t.mul(n[i],e);let i=0;for(;i<r.length&&r[i]===0;)i++;r=r.slice(i)}return r},e.generateECPolynomial=function(n){let r=new Uint8Array([1]);for(let i=0;i<n;i++)r=e.mul(r,new Uint8Array([1,t.exp(i)]));return r}})),Oe=t(((e,t)=>{var n=De();function r(e){this.genPoly=void 0,this.degree=e,this.degree&&this.initialize(this.degree)}r.prototype.initialize=function(e){this.degree=e,this.genPoly=n.generateECPolynomial(this.degree)},r.prototype.encode=function(e){if(!this.genPoly)throw Error(`Encoder not initialized`);let t=new Uint8Array(e.length+this.degree);t.set(e);let r=n.mod(t,this.genPoly),i=this.degree-r.length;if(i>0){let e=new Uint8Array(this.degree);return e.set(r,i),e}return r},t.exports=r})),ke=t((e=>{e.isValid=function(e){return!isNaN(e)&&e>=1&&e<=40}})),Ae=t((e=>{var t=`[0-9]+`,n=`[A-Z $%*+\\-./:]+`,r=`(?:[u3000-u303F]|[u3040-u309F]|[u30A0-u30FF]|[uFF00-uFFEF]|[u4E00-u9FAF]|[u2605-u2606]|[u2190-u2195]|u203B|[u2010u2015u2018u2019u2025u2026u201Cu201Du2225u2260]|[u0391-u0451]|[u00A7u00A8u00B1u00B4u00D7u00F7])+`;r=r.replace(/u/g,`\\u`);var i=`(?:(?![A-Z0-9 $%*+\\-./:]|`+r+`)(?:.|[\r
|
|
2
|
-
]))+`;e.KANJI=new RegExp(r,`g`),e.BYTE_KANJI=RegExp(`[^A-Z0-9 $%*+\\-./:]+`,`g`),e.BYTE=new RegExp(i,`g`),e.NUMERIC=new RegExp(t,`g`),e.ALPHANUMERIC=new RegExp(n,`g`);var a=RegExp(`^`+r+`$`),o=RegExp(`^`+t+`$`),s=RegExp(`^[A-Z0-9 $%*+\\-./:]+$`);e.testKanji=function(e){return a.test(e)},e.testNumeric=function(e){return o.test(e)},e.testAlphanumeric=function(e){return s.test(e)}})),Q=t((e=>{var t=ke(),n=Ae();e.NUMERIC={id:`Numeric`,bit:1,ccBits:[10,12,14]},e.ALPHANUMERIC={id:`Alphanumeric`,bit:2,ccBits:[9,11,13]},e.BYTE={id:`Byte`,bit:4,ccBits:[8,16,16]},e.KANJI={id:`Kanji`,bit:8,ccBits:[8,10,12]},e.MIXED={bit:-1},e.getCharCountIndicator=function(e,n){if(!e.ccBits)throw Error(`Invalid mode: `+e);if(!t.isValid(n))throw Error(`Invalid version: `+n);return n>=1&&n<10?e.ccBits[0]:n<27?e.ccBits[1]:e.ccBits[2]},e.getBestModeForData=function(t){return n.testNumeric(t)?e.NUMERIC:n.testAlphanumeric(t)?e.ALPHANUMERIC:n.testKanji(t)?e.KANJI:e.BYTE},e.toString=function(e){if(e&&e.id)return e.id;throw Error(`Invalid mode`)},e.isValid=function(e){return e&&e.bit&&e.ccBits};function r(t){if(typeof t!=`string`)throw Error(`Param is not a string`);switch(t.toLowerCase()){case`numeric`:return e.NUMERIC;case`alphanumeric`:return e.ALPHANUMERIC;case`kanji`:return e.KANJI;case`byte`:return e.BYTE;default:throw Error(`Unknown mode: `+t)}}e.from=function(t,n){if(e.isValid(t))return t;try{return r(t)}catch{return n}}})),je=t((e=>{var t=X(),n=Te(),r=Z(),i=Q(),a=ke(),o=7973,s=t.getBCHDigit(o);function c(t,n,r){for(let i=1;i<=40;i++)if(n<=e.getCapacity(i,r,t))return i}function l(e,t){return i.getCharCountIndicator(e,t)+4}function u(e,t){let n=0;return e.forEach(function(e){let r=l(e.mode,t);n+=r+e.getBitsLength()}),n}function d(t,n){for(let r=1;r<=40;r++)if(u(t,r)<=e.getCapacity(r,n,i.MIXED))return r}e.from=function(e,t){return a.isValid(e)?parseInt(e,10):t},e.getCapacity=function(e,r,o){if(!a.isValid(e))throw Error(`Invalid QR Code version`);o===void 0&&(o=i.BYTE);let s=(t.getSymbolTotalCodewords(e)-n.getTotalCodewordsCount(e,r))*8;if(o===i.MIXED)return s;let c=s-l(o,e);switch(o){case i.NUMERIC:return Math.floor(c/10*3);case i.ALPHANUMERIC:return Math.floor(c/11*2);case i.KANJI:return Math.floor(c/13);case i.BYTE:default:return Math.floor(c/8)}},e.getBestVersionForData=function(e,t){let n,i=r.from(t,r.M);if(Array.isArray(e)){if(e.length>1)return d(e,i);if(e.length===0)return 1;n=e[0]}else n=e;return c(n.mode,n.getLength(),i)},e.getEncodedBits=function(e){if(!a.isValid(e)||e<7)throw Error(`Invalid QR Code version`);let n=e<<12;for(;t.getBCHDigit(n)-s>=0;)n^=o<<t.getBCHDigit(n)-s;return e<<12|n}})),Me=t((e=>{var t=X(),n=1335,r=21522,i=t.getBCHDigit(n);e.getEncodedBits=function(e,a){let o=e.bit<<3|a,s=o<<10;for(;t.getBCHDigit(s)-i>=0;)s^=n<<t.getBCHDigit(s)-i;return(o<<10|s)^r}})),Ne=t(((e,t)=>{var n=Q();function r(e){this.mode=n.NUMERIC,this.data=e.toString()}r.getBitsLength=function(e){return 10*Math.floor(e/3)+(e%3?e%3*3+1:0)},r.prototype.getLength=function(){return this.data.length},r.prototype.getBitsLength=function(){return r.getBitsLength(this.data.length)},r.prototype.write=function(e){let t,n,r;for(t=0;t+3<=this.data.length;t+=3)n=this.data.substr(t,3),r=parseInt(n,10),e.put(r,10);let i=this.data.length-t;i>0&&(n=this.data.substr(t),r=parseInt(n,10),e.put(r,i*3+1))},t.exports=r})),Pe=t(((e,t)=>{var n=Q(),r=`0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ $%*+-./:`.split(``);function i(e){this.mode=n.ALPHANUMERIC,this.data=e}i.getBitsLength=function(e){return 11*Math.floor(e/2)+e%2*6},i.prototype.getLength=function(){return this.data.length},i.prototype.getBitsLength=function(){return i.getBitsLength(this.data.length)},i.prototype.write=function(e){let t;for(t=0;t+2<=this.data.length;t+=2){let n=r.indexOf(this.data[t])*45;n+=r.indexOf(this.data[t+1]),e.put(n,11)}this.data.length%2&&e.put(r.indexOf(this.data[t]),6)},t.exports=i})),Fe=t(((e,t)=>{var n=Q();function r(e){this.mode=n.BYTE,typeof e==`string`?this.data=new TextEncoder().encode(e):this.data=new Uint8Array(e)}r.getBitsLength=function(e){return e*8},r.prototype.getLength=function(){return this.data.length},r.prototype.getBitsLength=function(){return r.getBitsLength(this.data.length)},r.prototype.write=function(e){for(let t=0,n=this.data.length;t<n;t++)e.put(this.data[t],8)},t.exports=r})),Ie=t(((e,t)=>{var n=Q(),r=X();function i(e){this.mode=n.KANJI,this.data=e}i.getBitsLength=function(e){return e*13},i.prototype.getLength=function(){return this.data.length},i.prototype.getBitsLength=function(){return i.getBitsLength(this.data.length)},i.prototype.write=function(e){let t;for(t=0;t<this.data.length;t++){let n=r.toSJIS(this.data[t]);if(n>=33088&&n<=40956)n-=33088;else if(n>=57408&&n<=60351)n-=49472;else throw Error(`Invalid SJIS character: `+this.data[t]+`
|
|
3
|
-
Make sure your charset is UTF-8`);n=(n>>>8&255)*192+(n&255),e.put(n,13)}},t.exports=i})),Le=t(((e,t)=>{var n={single_source_shortest_paths:function(e,t,r){var i={},a={};a[t]=0;var o=n.PriorityQueue.make();o.push(t,0);for(var s,c,l,u,d,f,p,m,h;!o.empty();)for(l in s=o.pop(),c=s.value,u=s.cost,d=e[c]||{},d)d.hasOwnProperty(l)&&(f=d[l],p=u+f,m=a[l],h=a[l]===void 0,(h||m>p)&&(a[l]=p,o.push(l,p),i[l]=c));if(r!==void 0&&a[r]===void 0){var g=[`Could not find a path from `,t,` to `,r,`.`].join(``);throw Error(g)}return i},extract_shortest_path_from_predecessor_list:function(e,t){for(var n=[],r=t;r;)n.push(r),e[r],r=e[r];return n.reverse(),n},find_path:function(e,t,r){var i=n.single_source_shortest_paths(e,t,r);return n.extract_shortest_path_from_predecessor_list(i,r)},PriorityQueue:{make:function(e){var t=n.PriorityQueue,r={},i;for(i in e||={},t)t.hasOwnProperty(i)&&(r[i]=t[i]);return r.queue=[],r.sorter=e.sorter||t.default_sorter,r},default_sorter:function(e,t){return e.cost-t.cost},push:function(e,t){var n={value:e,cost:t};this.queue.push(n),this.queue.sort(this.sorter)},pop:function(){return this.queue.shift()},empty:function(){return this.queue.length===0}}};t!==void 0&&(t.exports=n)})),Re=t((e=>{var t=Q(),n=Ne(),r=Pe(),i=Fe(),a=Ie(),o=Ae(),s=X(),c=Le();function l(e){return unescape(encodeURIComponent(e)).length}function u(e,t,n){let r=[],i;for(;(i=e.exec(n))!==null;)r.push({data:i[0],index:i.index,mode:t,length:i[0].length});return r}function d(e){let n=u(o.NUMERIC,t.NUMERIC,e),r=u(o.ALPHANUMERIC,t.ALPHANUMERIC,e),i,a;return s.isKanjiModeEnabled()?(i=u(o.BYTE,t.BYTE,e),a=u(o.KANJI,t.KANJI,e)):(i=u(o.BYTE_KANJI,t.BYTE,e),a=[]),n.concat(r,i,a).sort(function(e,t){return e.index-t.index}).map(function(e){return{data:e.data,mode:e.mode,length:e.length}})}function f(e,o){switch(o){case t.NUMERIC:return n.getBitsLength(e);case t.ALPHANUMERIC:return r.getBitsLength(e);case t.KANJI:return a.getBitsLength(e);case t.BYTE:return i.getBitsLength(e)}}function p(e){return e.reduce(function(e,t){let n=e.length-1>=0?e[e.length-1]:null;return n&&n.mode===t.mode?(e[e.length-1].data+=t.data,e):(e.push(t),e)},[])}function m(e){let n=[];for(let r=0;r<e.length;r++){let i=e[r];switch(i.mode){case t.NUMERIC:n.push([i,{data:i.data,mode:t.ALPHANUMERIC,length:i.length},{data:i.data,mode:t.BYTE,length:i.length}]);break;case t.ALPHANUMERIC:n.push([i,{data:i.data,mode:t.BYTE,length:i.length}]);break;case t.KANJI:n.push([i,{data:i.data,mode:t.BYTE,length:l(i.data)}]);break;case t.BYTE:n.push([{data:i.data,mode:t.BYTE,length:l(i.data)}])}}return n}function h(e,n){let r={},i={start:{}},a=[`start`];for(let o=0;o<e.length;o++){let s=e[o],c=[];for(let e=0;e<s.length;e++){let l=s[e],u=``+o+e;c.push(u),r[u]={node:l,lastCount:0},i[u]={};for(let e=0;e<a.length;e++){let o=a[e];r[o]&&r[o].node.mode===l.mode?(i[o][u]=f(r[o].lastCount+l.length,l.mode)-f(r[o].lastCount,l.mode),r[o].lastCount+=l.length):(r[o]&&(r[o].lastCount=l.length),i[o][u]=f(l.length,l.mode)+4+t.getCharCountIndicator(l.mode,n))}}a=c}for(let e=0;e<a.length;e++)i[a[e]].end=0;return{map:i,table:r}}function g(e,o){let c,l=t.getBestModeForData(e);if(c=t.from(o,l),c!==t.BYTE&&c.bit<l.bit)throw Error(`"`+e+`" cannot be encoded with mode `+t.toString(c)+`.
|
|
4
|
-
Suggested mode is: `+t.toString(l));switch(c===t.KANJI&&!s.isKanjiModeEnabled()&&(c=t.BYTE),c){case t.NUMERIC:return new n(e);case t.ALPHANUMERIC:return new r(e);case t.KANJI:return new a(e);case t.BYTE:return new i(e)}}e.fromArray=function(e){return e.reduce(function(e,t){return typeof t==`string`?e.push(g(t,null)):t.data&&e.push(g(t.data,t.mode)),e},[])},e.fromString=function(t,n){let r=h(m(d(t,s.isKanjiModeEnabled())),n),i=c.find_path(r.map,`start`,`end`),a=[];for(let e=1;e<i.length-1;e++)a.push(r.table[i[e]].node);return e.fromArray(p(a))},e.rawSplit=function(t){return e.fromArray(d(t,s.isKanjiModeEnabled()))}})),ze=t((e=>{var t=X(),n=Z(),r=be(),i=xe(),a=Se(),o=Ce(),s=we(),c=Te(),l=Oe(),u=je(),d=Me(),f=Q(),p=Re();function m(e,t){let n=e.size,r=o.getPositions(t);for(let t=0;t<r.length;t++){let i=r[t][0],a=r[t][1];for(let t=-1;t<=7;t++)if(!(i+t<=-1||n<=i+t))for(let r=-1;r<=7;r++)a+r<=-1||n<=a+r||(t>=0&&t<=6&&(r===0||r===6)||r>=0&&r<=6&&(t===0||t===6)||t>=2&&t<=4&&r>=2&&r<=4?e.set(i+t,a+r,!0,!0):e.set(i+t,a+r,!1,!0))}}function h(e){let t=e.size;for(let n=8;n<t-8;n++){let t=n%2==0;e.set(n,6,t,!0),e.set(6,n,t,!0)}}function g(e,t){let n=a.getPositions(t);for(let t=0;t<n.length;t++){let r=n[t][0],i=n[t][1];for(let t=-2;t<=2;t++)for(let n=-2;n<=2;n++)t===-2||t===2||n===-2||n===2||t===0&&n===0?e.set(r+t,i+n,!0,!0):e.set(r+t,i+n,!1,!0)}}function _(e,t){let n=e.size,r=u.getEncodedBits(t),i,a,o;for(let t=0;t<18;t++)i=Math.floor(t/3),a=t%3+n-8-3,o=(r>>t&1)==1,e.set(i,a,o,!0),e.set(a,i,o,!0)}function v(e,t,n){let r=e.size,i=d.getEncodedBits(t,n),a,o;for(a=0;a<15;a++)o=(i>>a&1)==1,a<6?e.set(a,8,o,!0):a<8?e.set(a+1,8,o,!0):e.set(r-15+a,8,o,!0),a<8?e.set(8,r-a-1,o,!0):a<9?e.set(8,15-a-1+1,o,!0):e.set(8,15-a-1,o,!0);e.set(r-8,8,1,!0)}function y(e,t){let n=e.size,r=-1,i=n-1,a=7,o=0;for(let s=n-1;s>0;s-=2)for(s===6&&s--;;){for(let n=0;n<2;n++)if(!e.isReserved(i,s-n)){let r=!1;o<t.length&&(r=(t[o]>>>a&1)==1),e.set(i,s-n,r),a--,a===-1&&(o++,a=7)}if(i+=r,i<0||n<=i){i-=r,r=-r;break}}}function b(e,n,i){let a=new r;i.forEach(function(t){a.put(t.mode.bit,4),a.put(t.getLength(),f.getCharCountIndicator(t.mode,e)),t.write(a)});let o=(t.getSymbolTotalCodewords(e)-c.getTotalCodewordsCount(e,n))*8;for(a.getLengthInBits()+4<=o&&a.put(0,4);a.getLengthInBits()%8!=0;)a.putBit(0);let s=(o-a.getLengthInBits())/8;for(let e=0;e<s;e++)a.put(e%2?17:236,8);return x(a,e,n)}function x(e,n,r){let i=t.getSymbolTotalCodewords(n),a=i-c.getTotalCodewordsCount(n,r),o=c.getBlocksCount(n,r),s=o-i%o,u=Math.floor(i/o),d=Math.floor(a/o),f=d+1,p=u-d,m=new l(p),h=0,g=Array(o),_=Array(o),v=0,y=new Uint8Array(e.buffer);for(let e=0;e<o;e++){let t=e<s?d:f;g[e]=y.slice(h,h+t),_[e]=m.encode(g[e]),h+=t,v=Math.max(v,t)}let b=new Uint8Array(i),x=0,S,C;for(S=0;S<v;S++)for(C=0;C<o;C++)S<g[C].length&&(b[x++]=g[C][S]);for(S=0;S<p;S++)for(C=0;C<o;C++)b[x++]=_[C][S];return b}function S(e,n,r,a){let o;if(Array.isArray(e))o=p.fromArray(e);else if(typeof e==`string`){let t=n;if(!t){let n=p.rawSplit(e);t=u.getBestVersionForData(n,r)}o=p.fromString(e,t||40)}else throw Error(`Invalid data`);let c=u.getBestVersionForData(o,r);if(!c)throw Error(`The amount of data is too big to be stored in a QR Code`);if(!n)n=c;else if(n<c)throw Error(`
|
|
5
|
-
The chosen QR Code version cannot contain this amount of data.
|
|
6
|
-
Minimum version required to store current data is: `+c+`.
|
|
7
|
-
`);let l=b(n,r,o),d=new i(t.getSymbolSize(n));return m(d,n),h(d),g(d,n),v(d,r,0),n>=7&&_(d,n),y(d,l),isNaN(a)&&(a=s.getBestMask(d,v.bind(null,d,r))),s.applyMask(a,d),v(d,r,a),{modules:d,version:n,errorCorrectionLevel:r,maskPattern:a,segments:o}}e.create=function(e,r){if(e===void 0||e===``)throw Error(`No input text`);let i=n.M,a,o;return r!==void 0&&(i=n.from(r.errorCorrectionLevel,n.M),a=u.from(r.version),o=s.from(r.maskPattern),r.toSJISFunc&&t.setToSJISFunction(r.toSJISFunc)),S(e,a,i,o)}})),Be=t((e=>{function t(e){if(typeof e==`number`&&(e=e.toString()),typeof e!=`string`)throw Error(`Color should be defined as hex string`);let t=e.slice().replace(`#`,``).split(``);if(t.length<3||t.length===5||t.length>8)throw Error(`Invalid hex color: `+e);(t.length===3||t.length===4)&&(t=Array.prototype.concat.apply([],t.map(function(e){return[e,e]}))),t.length===6&&t.push(`F`,`F`);let n=parseInt(t.join(``),16);return{r:n>>24&255,g:n>>16&255,b:n>>8&255,a:n&255,hex:`#`+t.slice(0,6).join(``)}}e.getOptions=function(e){e||={},e.color||={};let n=e.margin===void 0||e.margin===null||e.margin<0?4:e.margin,r=e.width&&e.width>=21?e.width:void 0,i=e.scale||4;return{width:r,scale:r?4:i,margin:n,color:{dark:t(e.color.dark||`#000000ff`),light:t(e.color.light||`#ffffffff`)},type:e.type,rendererOpts:e.rendererOpts||{}}},e.getScale=function(e,t){return t.width&&t.width>=e+t.margin*2?t.width/(e+t.margin*2):t.scale},e.getImageWidth=function(t,n){let r=e.getScale(t,n);return Math.floor((t+n.margin*2)*r)},e.qrToImageData=function(t,n,r){let i=n.modules.size,a=n.modules.data,o=e.getScale(i,r),s=Math.floor((i+r.margin*2)*o),c=r.margin*o,l=[r.color.light,r.color.dark];for(let e=0;e<s;e++)for(let n=0;n<s;n++){let u=(e*s+n)*4,d=r.color.light;if(e>=c&&n>=c&&e<s-c&&n<s-c){let t=Math.floor((e-c)/o),r=Math.floor((n-c)/o);d=l[a[t*i+r]?1:0]}t[u++]=d.r,t[u++]=d.g,t[u++]=d.b,t[u]=d.a}}})),Ve=t((e=>{var t=Be();function n(e,t,n){e.clearRect(0,0,t.width,t.height),t.style||={},t.height=n,t.width=n,t.style.height=n+`px`,t.style.width=n+`px`}function r(){try{return document.createElement(`canvas`)}catch{throw Error(`You need to specify a canvas element`)}}e.render=function(e,i,a){let o=a,s=i;o===void 0&&(!i||!i.getContext)&&(o=i,i=void 0),i||(s=r()),o=t.getOptions(o);let c=t.getImageWidth(e.modules.size,o),l=s.getContext(`2d`),u=l.createImageData(c,c);return t.qrToImageData(u.data,e,o),n(l,s,c),l.putImageData(u,0,0),s},e.renderToDataURL=function(t,n,r){let i=r;i===void 0&&(!n||!n.getContext)&&(i=n,n=void 0),i||={};let a=e.render(t,n,i),o=i.type||`image/png`,s=i.rendererOpts||{};return a.toDataURL(o,s.quality)}})),He=t((e=>{var t=Be();function n(e,t){let n=e.a/255,r=t+`="`+e.hex+`"`;return n<1?r+` `+t+`-opacity="`+n.toFixed(2).slice(1)+`"`:r}function r(e,t,n){let r=e+t;return n!==void 0&&(r+=` `+n),r}function i(e,t,n){let i=``,a=0,o=!1,s=0;for(let c=0;c<e.length;c++){let l=Math.floor(c%t),u=Math.floor(c/t);!l&&!o&&(o=!0),e[c]?(s++,c>0&&l>0&&e[c-1]||(i+=o?r(`M`,l+n,.5+u+n):r(`m`,a,0),a=0,o=!1),l+1<t&&e[c+1]||(i+=r(`h`,s),s=0)):a++}return i}e.render=function(e,r,a){let o=t.getOptions(r),s=e.modules.size,c=e.modules.data,l=s+o.margin*2,u=o.color.light.a?`<path `+n(o.color.light,`fill`)+` d="M0 0h`+l+`v`+l+`H0z"/>`:``,d=`<path `+n(o.color.dark,`stroke`)+` d="`+i(c,s,o.margin)+`"/>`,f=`viewBox="0 0 `+l+` `+l+`"`,p=`<svg xmlns="http://www.w3.org/2000/svg" `+(o.width?`width="`+o.width+`" height="`+o.width+`" `:``)+f+` shape-rendering="crispEdges">`+u+d+`</svg>
|
|
8
|
-
`;return typeof a==`function`&&a(null,p),p}})),Ue=t((e=>{var t=ye(),n=ze(),r=Ve(),i=He();function a(e,r,i,a,o){let s=[].slice.call(arguments,1),c=s.length,l=typeof s[c-1]==`function`;if(!l&&!t())throw Error(`Callback required as last argument`);if(l){if(c<2)throw Error(`Too few arguments provided`);c===2?(o=i,i=r,r=a=void 0):c===3&&(r.getContext&&o===void 0?(o=a,a=void 0):(o=a,a=i,i=r,r=void 0))}else{if(c<1)throw Error(`Too few arguments provided`);return c===1?(i=r,r=a=void 0):c===2&&!r.getContext&&(a=i,i=r,r=void 0),new Promise(function(t,o){try{t(e(n.create(i,a),r,a))}catch(e){o(e)}})}try{let t=n.create(i,a);o(null,e(t,r,a))}catch(e){o(e)}}e.create=n.create,e.toCanvas=a.bind(null,r.render),e.toDataURL=a.bind(null,r.renderToDataURL),e.toString=a.bind(null,function(e,t,n){return i.render(e,n)})}))();async function We(e,t={}){let n=await f.post(`/api/config/channels/${e}/auth/start`,t);if(!n.ok)throw Error(n.error.message);return n.data}async function Ge(e,t){let n=await f.post(`/api/config/channels/${e}/auth/poll`,t);if(!n.ok)throw Error(n.error.message);return n.data}function Ke(){return p({mutationFn:({channel:e,data:t})=>We(e,t)})}function qe(){return p({mutationFn:({channel:e,data:t})=>Ge(e,t)})}function Je(e){let t=e.accounts,n=new Set;if(typeof e.defaultAccountId==`string`&&e.defaultAccountId.trim()&&n.add(e.defaultAccountId.trim()),t&&typeof t==`object`&&!Array.isArray(t))for(let e of Object.keys(t)){let t=e.trim();t&&n.add(t)}return[...n]}function Ye(e,t){if(typeof e.baseUrl==`string`&&e.baseUrl.trim())return e.baseUrl.trim();if(typeof t.baseUrl==`string`&&t.baseUrl.trim())return t.baseUrl.trim()}function Xe({channelConfig:e,formData:t,channelEnabled:r,disabled:a=!1}){let o=d(),u=Ke(),f=qe(),[p,m]=(0,G.useState)(null),[h,g]=(0,G.useState)(null),[_,v]=(0,G.useState)(null),y=(0,G.useMemo)(()=>Je(e),[e]),b=y[0],x=Ye(t,e),C=y.length>0;(0,G.useEffect)(()=>{C&&(m(null),g(e=>e?.status===`authorized`?e:{channel:`weixin`,status:`authorized`,message:n(`weixinAuthAuthorized`),accountId:b??null}))},[C,b]),(0,G.useEffect)(()=>{if(!p){v(null);return}let e=!1;return(0,Ue.toDataURL)(p.qrCodeUrl,{errorCorrectionLevel:`M`,margin:1,width:480}).then(t=>{e||v(t)}).catch(()=>{e||v(null)}),()=>{e=!0}},[p]),(0,G.useEffect)(()=>{if(!p)return;let e=!1,t=null,r=async()=>{try{let i=await f.mutateAsync({channel:`weixin`,data:{sessionId:p.sessionId}});if(e)return;if(g(i),i.status===`authorized`){await o.invalidateQueries({queryKey:[`config`]}),await o.invalidateQueries({queryKey:[`config-meta`]}),c.success(i.message||n(`weixinAuthAuthorized`)),m(null);return}if(i.status===`expired`||i.status===`error`){c.error(i.message||n(`weixinAuthRetryRequired`)),m(null);return}t=setTimeout(r,i.nextPollMs??p.intervalMs)}catch(t){if(e)return;let r=t instanceof Error?t.message:String(t);c.error(`${n(`error`)}: ${r}`),m(null)}};return t=setTimeout(r,p.intervalMs),()=>{e=!0,t&&clearTimeout(t)}},[p,f,o]);let w=async()=>{try{let e=await u.mutateAsync({channel:`weixin`,data:{baseUrl:x,accountId:typeof t.defaultAccountId==`string`&&t.defaultAccountId.trim()?t.defaultAccountId.trim():void 0}});m(e),g({channel:`weixin`,status:`pending`,message:e.note,nextPollMs:e.intervalMs})}catch(e){let t=e instanceof Error?e.message:String(e);c.error(`${n(`error`)}: ${t}`)}},T=p?h?.status===`scanned`?n(`weixinAuthScanned`):n(`weixinAuthWaiting`):n(C?r?`weixinAuthAuthorized`:`weixinAuthConnectedDisabled`:`weixinAuthNotConnected`),D=u.isPending?n(`weixinAuthStarting`):n(p?`weixinAuthWaiting`:C?`weixinAuthReconnect`:`weixinAuthConnect`);return(0,Y.jsx)(`section`,{className:`rounded-2xl border border-primary/20 bg-gradient-to-br from-primary-50/70 via-white to-emerald-50/60 p-5`,children:(0,Y.jsxs)(`div`,{className:`flex flex-col gap-4 lg:flex-row lg:items-start lg:justify-between`,children:[(0,Y.jsxs)(`div`,{className:`space-y-3`,children:[(0,Y.jsxs)(`div`,{className:`inline-flex items-center gap-2 rounded-full bg-white/90 px-3 py-1 text-xs font-medium text-primary shadow-sm`,children:[(0,Y.jsx)(W,{className:`h-3.5 w-3.5`}),n(`weixinAuthTitle`)]}),(0,Y.jsxs)(`div`,{children:[(0,Y.jsx)(`h4`,{className:`text-base font-semibold text-gray-900`,children:n(`weixinAuthDescription`)}),(0,Y.jsx)(`p`,{className:`mt-1 text-sm text-gray-600`,children:n(`weixinAuthHint`)})]}),(0,Y.jsxs)(`div`,{className:s(`inline-flex w-fit items-center gap-2 rounded-full px-3 py-1 text-xs font-medium`,p?`bg-amber-50 text-amber-700`:C?`bg-emerald-50 text-emerald-700`:`bg-gray-100 text-gray-600`),children:[p?(0,Y.jsx)(E,{className:`h-3.5 w-3.5 animate-spin`}):(0,Y.jsx)(fe,{className:`h-3.5 w-3.5`}),T]}),(0,Y.jsxs)(`div`,{className:`space-y-1 text-sm text-gray-600`,children:[(0,Y.jsx)(`p`,{children:n(r||!C?`weixinAuthCapabilityHint`:`weixinAuthDisabledHint`)}),b?(0,Y.jsxs)(`p`,{children:[n(`weixinAuthPrimaryAccount`),`: `,(0,Y.jsx)(`span`,{className:`font-mono text-xs text-gray-900`,children:b})]}):null,y.length>1?(0,Y.jsxs)(`p`,{children:[n(`weixinAuthConnectedAccounts`),`: `,(0,Y.jsx)(`span`,{className:`font-mono text-xs text-gray-900`,children:y.join(`, `)})]}):null,x?(0,Y.jsxs)(`p`,{children:[n(`weixinAuthBaseUrl`),`: `,(0,Y.jsx)(`span`,{className:`font-mono text-xs text-gray-900`,children:x})]}):null]}),(0,Y.jsx)(l,{type:`button`,onClick:w,disabled:a||u.isPending||!!p,className:`rounded-xl`,children:D})]}),(0,Y.jsx)(`div`,{className:`w-full max-w-sm rounded-2xl border border-dashed border-primary/25 bg-white/85 p-4 shadow-sm`,children:p?(0,Y.jsxs)(`div`,{className:`space-y-3`,children:[(0,Y.jsx)(`div`,{className:`overflow-hidden rounded-2xl border border-gray-100 bg-white p-3`,children:_?(0,Y.jsx)(`img`,{src:_,alt:n(`weixinAuthQrAlt`),className:`mx-auto aspect-square w-full max-w-[240px] object-contain`}):(0,Y.jsx)(`div`,{className:`flex aspect-square w-full items-center justify-center rounded-xl bg-gray-50 text-gray-500`,children:(0,Y.jsxs)(`div`,{className:`flex flex-col items-center gap-2 text-center`,children:[(0,Y.jsx)(E,{className:`h-5 w-5 animate-spin`}),(0,Y.jsx)(`p`,{className:`text-xs`,children:n(`weixinAuthStarting`)})]})})}),(0,Y.jsxs)(`div`,{className:`space-y-1 text-xs text-gray-500`,children:[(0,Y.jsx)(`p`,{children:h?.message||p.note||n(`weixinAuthScanPrompt`)}),(0,Y.jsxs)(`p`,{children:[n(`weixinAuthExpiresAt`),`: `,i(p.expiresAt)]})]}),(0,Y.jsxs)(`a`,{href:p.qrCodeUrl,target:`_blank`,rel:`noreferrer`,className:`inline-flex items-center gap-1.5 text-xs text-primary transition-colors hover:text-primary-hover`,children:[(0,Y.jsx)(S,{className:`h-3.5 w-3.5`}),n(`weixinAuthOpenQr`)]})]}):(0,Y.jsxs)(`div`,{className:`flex min-h-[280px] flex-col items-center justify-center rounded-2xl bg-gray-50/80 px-6 text-center`,children:[(0,Y.jsx)(W,{className:`h-9 w-9 text-gray-300`}),(0,Y.jsx)(`p`,{className:`mt-3 text-sm font-medium text-gray-700`,children:n(`weixinAuthReadyTitle`)}),(0,Y.jsx)(`p`,{className:`mt-1 text-xs leading-5 text-gray-500`,children:n(`weixinAuthReadyDescription`)})]})})]})})}var Ze=[],Qe=[{type:`fields`,section:`all`}];function $(e){return typeof e==`object`&&!!e&&!Array.isArray(e)}function $e(e,t){let n={...e};for(let[e,r]of Object.entries(t))n[e]=$(n[e])&&$(r)?$e(n[e],r):r;return n}function et(e,t){let n={},r=n,i=e.split(`.`);for(let e=0;e<i.length-1;e+=1)r[i[e]]={},r=r[i[e]];return r[i[i.length-1]]=t,n}function tt(e,t){return t===`all`?e:e.filter(e=>t===`primary`?e.section===`primary`:e.section!==`primary`)}function nt(e,t){let n={};return t.filter(e=>e.type===`json`).forEach(t=>{n[t.name]=JSON.stringify(e[t.name]??{},null,2)}),n}function rt(e){let[t,n]=(0,G.useState)(null);return(0,G.useEffect)(()=>{if(!e){n(null);return}return u.subscribe(t=>{t.type!==`channel.config.apply-status`||t.payload.channel!==e||n(t.payload.status===`started`?{status:`applying`}:t.payload.status===`succeeded`?{status:`applied`}:{status:`failed`,message:t.payload.message})})},[e]),t}function it(e){return e?e.status===`applying`?{className:`text-amber-600`,label:n(`channelConfigApplying`)}:e.status===`applied`?{className:`text-emerald-600`,label:n(`channelConfigApplied`)}:{className:`text-red-600`,label:`${n(`channelConfigApplyFailed`)}${e.message?`: ${e.message}`:``}`}:null}function at({channelName:e}){let{data:t}=j(),{data:r}=ie(),{data:i}=A(),a=te(),o=ee(),[u,d]=(0,G.useState)({}),[f,p]=(0,G.useState)({}),[h,g]=(0,G.useState)(null),_=rt(e),v=(0,G.useRef)(null),y=e?t?.channels[e]:null,b=(0,G.useMemo)(()=>he()[e||``],[e]),S=b?.fields??Ze,C=b?.layout??Qe,T=i?.uiHints,E=e?`channels.${e}`:null,D=i?.actions?.filter(e=>e.scope===E)??[],O=r?.channels.find(t=>t.name===e),k=e&&(B(`channels.${e}`,T)?.label??e),M=O?K(O):void 0,N=e&&y?JSON.stringify({channelName:e,channelConfig:y,jsonFields:S.filter(e=>e.type===`json`).map(e=>e.name)}):`empty:${e??``}`;(0,G.useEffect)(()=>{if(v.current!==N){if(v.current=N,y){d({...y}),p(nt(y,S));return}d({}),p({})}},[y,S,N]);let ne=(e,t)=>d(n=>({...n,[e]:t})),re=t=>{if(t.preventDefault(),!e)return;let r={...u};for(let e of S){if(e.type===`password`){let t=r[e.name];(typeof t!=`string`||t.length===0)&&delete r[e.name]}if(e.type===`json`)try{r[e.name]=(f[e.name]??``).trim()?JSON.parse(f[e.name]):{}}catch{c.error(`${n(`invalidJson`)}: ${e.name}`);return}}a.mutate({channel:e,data:r})},F=t=>{if(!t||!e||!$(t.channels)||!$(t.channels[e]))return;let n=t.channels[e];d(e=>$e(e,n)),p(e=>{let t={...e},r=!1;for(let e of S)e.type!==`json`||!Object.prototype.hasOwnProperty.call(n,e.name)||(t[e.name]=JSON.stringify(n[e.name]??{},null,2),r=!0);return r?t:e})},I=async t=>{if(!(!e||!E)){g(t.id);try{let r={...u};t.saveBeforeRun&&(r={...r,...t.savePatch??{}},d(r),await a.mutateAsync({channel:e,data:r}));let i=await o.mutateAsync({actionId:t.id,data:{scope:E,draftConfig:et(E,r)}});F(i.patch),i.ok?c.success(i.message||n(`success`)):c.error(i.message||n(`error`))}catch(e){c.error(`${n(`error`)}: ${e instanceof Error?e.message:String(e)}`)}finally{g(null)}}};if(!e||!O||!y)return(0,Y.jsx)(oe,{children:(0,Y.jsxs)(`div`,{children:[(0,Y.jsx)(`h3`,{className:`text-base font-semibold text-gray-900`,children:n(`channelsSelectTitle`)}),(0,Y.jsx)(`p`,{className:`mt-2 text-sm text-gray-500`,children:n(`channelsSelectDescription`)})]})});let L=typeof u.enabled==`boolean`?u.enabled:!!y.enabled,R=it(_);return(0,Y.jsxs)(V,{children:[(0,Y.jsx)(H,{className:`px-6 py-5`,children:(0,Y.jsxs)(`div`,{className:`flex flex-wrap items-center justify-between gap-3`,children:[(0,Y.jsxs)(`div`,{className:`min-w-0`,children:[(0,Y.jsxs)(`div`,{className:`flex items-center gap-3`,children:[(0,Y.jsx)(P,{name:e,src:w(e),className:s(`h-9 w-9 rounded-lg border`,L?`border-primary/30 bg-white`:`border-gray-200/70 bg-white`),imgClassName:`h-5 w-5 object-contain`,fallback:(0,Y.jsx)(`span`,{className:`text-sm font-semibold uppercase text-gray-500`,children:e[0]})}),(0,Y.jsx)(`h3`,{className:`truncate text-lg font-semibold text-gray-900 capitalize`,children:k})]}),(0,Y.jsx)(`p`,{className:`mt-2 text-sm text-gray-500`,children:n(`channelsFormDescription`)}),R?(0,Y.jsx)(`p`,{className:s(`mt-2 text-xs font-medium`,R.className),children:R.label}):null,M?(0,Y.jsxs)(`a`,{href:M,className:`mt-2 inline-flex items-center gap-1.5 text-xs text-primary transition-colors hover:text-primary-hover`,children:[(0,Y.jsx)(x,{className:`h-3.5 w-3.5`}),n(`channelsGuideTitle`)]}):null]}),(0,Y.jsx)(z,{status:L?`active`:`inactive`,label:n(L?`statusActive`:`statusInactive`)})]})}),(0,Y.jsxs)(`form`,{onSubmit:re,className:`flex min-h-0 flex-1 flex-col`,children:[(0,Y.jsx)(U,{className:`space-y-6 px-6 py-5`,children:C.map((t,n)=>{if(t.type===`fields`){let r=tt(S,t.section);if(r.length===0)return null;let i=(0,Y.jsx)(ve,{channelName:e,fields:r,formData:u,jsonDrafts:f,setJsonDrafts:p,updateField:ne,uiHints:T});return t.collapsible?(0,Y.jsxs)(`details`,{className:`group rounded-2xl border border-gray-200/80 bg-white`,children:[(0,Y.jsxs)(`summary`,{className:`flex cursor-pointer list-none items-center justify-between gap-3 px-5 py-4 text-sm font-medium text-gray-900`,children:[(0,Y.jsxs)(`div`,{children:[(0,Y.jsx)(`p`,{children:t.collapsible.title}),t.collapsible.description?(0,Y.jsx)(`p`,{className:`mt-1 text-xs font-normal text-gray-500`,children:t.collapsible.description}):null]}),(0,Y.jsx)(m,{className:`h-4 w-4 text-gray-400 transition-transform group-open:rotate-180`})]}),(0,Y.jsx)(`div`,{className:`space-y-6 border-t border-gray-100 px-5 py-5`,children:i})]},`${t.type}-${t.section}-${n}`):(0,Y.jsx)(`div`,{children:i},`${t.type}-${t.section}-${n}`)}return t.sectionId===`weixin-auth`?(0,Y.jsx)(Xe,{channelConfig:y,formData:u,channelEnabled:L,disabled:a.isPending||!!h},`${t.type}-${t.sectionId}-${n}`):null})}),(0,Y.jsxs)(ce,{className:`flex flex-wrap items-center justify-between gap-3 px-6 py-4`,children:[(0,Y.jsx)(`div`,{className:`flex flex-wrap items-center gap-2`,children:D.filter(e=>e.trigger===`manual`).map(e=>(0,Y.jsx)(l,{type:`button`,onClick:()=>I(e),disabled:a.isPending||!!h,variant:`secondary`,children:h===e.id?n(`connecting`):e.title},e.id))}),(0,Y.jsx)(l,{type:`submit`,disabled:a.isPending||!!h,children:a.isPending?n(`saving`):n(`save`)})]})]})]})}var ot={telegram:`channelDescTelegram`,slack:`channelDescSlack`,email:`channelDescEmail`,webhook:`channelDescWebhook`,discord:`channelDescDiscord`,feishu:`channelDescFeishu`,weixin:`channelDescWeixin`},st=[`weixin`,`feishu`,`discord`,`qq`];function ct(e){let t=new Map(st.map((e,t)=>[e,t]));return e.map((e,t)=>({channel:e,index:t})).sort((e,n)=>{let r=t.get(e.channel.name)??1/0,i=t.get(n.channel.name)??1/0;return r===i?e.index-n.index:r-i}).map(({channel:e})=>e)}function lt(){let{data:e}=j(),{data:t}=ie(),{data:r}=A(),[i,a]=(0,G.useState)(`enabled`),[o,c]=(0,G.useState)(),[l,u]=(0,G.useState)(``),d=(0,G.useMemo)(()=>ct(t?.channels??[]),[t?.channels]),f=e?.channels,p=(0,G.useMemo)(()=>{let e=l.trim().toLowerCase();return d.filter(e=>i!==`enabled`||!!f?.[e.name]?.enabled).filter(t=>e?(t.displayName||t.name).toLowerCase().includes(e)||t.name.toLowerCase().includes(e):!0)},[i,f,d,l]);return(0,G.useEffect)(()=>{c(p.some(e=>e.name===o)?o:p[0]?.name)},[p,o]),!e||!t?(0,Y.jsx)(`div`,{className:`p-8 text-gray-400`,children:n(`channelsLoading`)}):(0,Y.jsxs)(I,{className:`pb-0 xl:flex xl:h-full xl:min-h-0 xl:flex-col`,children:[(0,Y.jsx)(L,{title:n(`channelsPageTitle`),description:n(`channelsPageDescription`)}),(0,Y.jsxs)(ae,{className:`xl:min-h-0`,children:[(0,Y.jsxs)(V,{children:[(0,Y.jsx)(H,{className:`px-4 pt-4`,children:(0,Y.jsx)(R,{tabs:[{id:`enabled`,label:n(`channelsTabEnabled`),count:d.filter(e=>f?.[e.name]?.enabled).length},{id:`all`,label:n(`channelsTabAll`),count:d.length}],activeTab:i,onChange:a,className:`mb-0`})}),(0,Y.jsx)(`div`,{className:`border-b border-gray-100 px-4 py-3`,children:(0,Y.jsxs)(`div`,{className:`relative`,children:[(0,Y.jsx)(D,{className:`pointer-events-none absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-gray-400`}),(0,Y.jsx)(N,{value:l,onChange:e=>u(e.target.value),placeholder:n(`channelsFilterPlaceholder`),className:`h-10 rounded-xl pl-9`})]})}),(0,Y.jsxs)(U,{className:`space-y-2 p-3`,children:[p.map(t=>{let i=!!e.channels[t.name]?.enabled,a=K(t),l=B(`channels.${t.name}`,r?.uiHints)?.help||n(ot[t.name]||`channelDescriptionDefault`);return(0,Y.jsx)(le,{onClick:()=>c(t.name),active:o===t.name,children:(0,Y.jsxs)(`div`,{className:`flex items-start justify-between gap-3`,children:[(0,Y.jsxs)(`div`,{className:`flex min-w-0 items-center gap-3`,children:[(0,Y.jsx)(P,{name:t.name,src:w(t.name),className:s(`h-10 w-10 rounded-lg border`,i?`border-primary/30 bg-white`:`border-gray-200/70 bg-white`),imgClassName:`h-5 w-5 object-contain`,fallback:(0,Y.jsx)(`span`,{className:`text-sm font-semibold uppercase text-gray-500`,children:t.name[0]})}),(0,Y.jsxs)(`div`,{className:`min-w-0`,children:[(0,Y.jsx)(`p`,{className:`truncate text-sm font-semibold text-gray-900`,children:t.displayName||t.name}),(0,Y.jsx)(`p`,{className:`line-clamp-1 text-[11px] text-gray-500`,children:l})]})]}),(0,Y.jsxs)(`div`,{className:`flex items-center gap-2`,children:[a?(0,Y.jsx)(`a`,{href:a,onClick:e=>e.stopPropagation(),className:`inline-flex h-7 w-7 items-center justify-center rounded-md text-gray-300 transition-colors hover:bg-gray-100/70 hover:text-gray-500`,title:n(`channelsGuideTitle`),children:(0,Y.jsx)(S,{className:`h-3.5 w-3.5`})}):null,(0,Y.jsx)(z,{status:i?`active`:`inactive`,label:n(i?`statusActive`:`statusInactive`),className:`min-w-[56px] justify-center`})]})]})},t.name)}),p.length===0?(0,Y.jsx)(se,{icon:k,title:n(`channelsNoMatch`)}):null]})]}),(0,Y.jsx)(at,{channelName:o})]})]})}export{lt as ChannelsList};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{t as e}from"./DocBrowser-DMfr0Oow.js";export{e as DocBrowser};
|