@lobehub/chat 1.0.0 → 1.0.2
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.
Potentially problematic release.
This version of @lobehub/chat might be problematic. Click here for more details.
- package/.bunfig.toml +3 -0
- package/.dockerignore +11 -0
- package/.env.example +131 -0
- package/.eslintignore +1 -2
- package/.eslintrc.js +32 -1
- package/.github/FUNDING.yml +13 -0
- package/.github/ISSUE_TEMPLATE/1_bug_report.yml +46 -22
- package/.github/ISSUE_TEMPLATE/1_bug_report_cn.yml +69 -0
- package/.github/ISSUE_TEMPLATE/2_feature_request.yml +6 -6
- package/.github/ISSUE_TEMPLATE/2_feature_request_cn.yml +21 -0
- package/.github/ISSUE_TEMPLATE/config.yml +4 -0
- package/.github/PULL_REQUEST_TEMPLATE.md +2 -0
- package/.github/workflows/docker.yml +45 -0
- package/.github/workflows/issue-auto-comments.yml +73 -0
- package/.github/workflows/issue-close-require.yml +26 -6
- package/.github/workflows/issues-translate.yml +14 -0
- package/.github/workflows/lighthouse.yml +72 -0
- package/.github/workflows/release.yml +46 -15
- package/.github/workflows/sync.yml +54 -0
- package/.github/workflows/test.yml +44 -16
- package/.github/workflows/wiki-sync.yml +19 -0
- package/.husky/pre-commit +0 -3
- package/.i18nrc.js +41 -7
- package/.nvmrc +1 -0
- package/.seorc.cjs +9 -0
- package/CHANGELOG.md +16675 -46
- package/CODE_OF_CONDUCT.md +128 -0
- package/CONTRIBUTING.md +88 -0
- package/Dockerfile +138 -0
- package/LICENSE +38 -0
- package/README.md +696 -80
- package/README.zh-CN.md +782 -0
- package/__mocks__/zustand/traditional.ts +25 -0
- package/codecov.yml +11 -0
- package/contributing/Basic/Add-New-Authentication-Providers.md +193 -0
- package/contributing/Basic/Add-New-Authentication-Providers.zh-CN.md +192 -0
- package/contributing/Basic/Architecture.md +47 -0
- package/contributing/Basic/Architecture.zh-CN.md +47 -0
- package/contributing/Basic/Chat-API.md +136 -0
- package/contributing/Basic/Chat-API.zh-CN.md +174 -0
- package/contributing/Basic/Contributing-Guidelines.md +83 -0
- package/contributing/Basic/Contributing-Guidelines.zh-CN.md +85 -0
- package/contributing/Basic/Feature-Development-Frontend.md +126 -0
- package/contributing/Basic/Feature-Development-Frontend.zh-CN.md +126 -0
- package/contributing/Basic/Feature-Development.md +713 -0
- package/contributing/Basic/Feature-Development.zh-CN.md +707 -0
- package/contributing/Basic/Folder-Structure.md +40 -0
- package/contributing/Basic/Folder-Structure.zh-CN.md +40 -0
- package/contributing/Basic/Intro.md +111 -0
- package/contributing/Basic/Intro.zh-CN.md +111 -0
- package/contributing/Basic/Resources.md +19 -0
- package/contributing/Basic/Resources.zh-CN.md +19 -0
- package/contributing/Basic/Setup-Development.md +69 -0
- package/contributing/Basic/Setup-Development.zh-CN.md +69 -0
- package/contributing/Basic/Test.md +87 -0
- package/contributing/Basic/Test.zh-CN.md +87 -0
- package/contributing/Home.md +87 -0
- package/contributing/Internationalization/Add-New-Locale.md +62 -0
- package/contributing/Internationalization/Add-New-Locale.zh-CN.md +62 -0
- package/contributing/Internationalization/Internationalization-Implementation.md +125 -0
- package/contributing/Internationalization/Internationalization-Implementation.zh-CN.md +125 -0
- package/contributing/Others/Lighthouse.md +65 -0
- package/contributing/Others/Lighthouse.zh-CN.md +65 -0
- package/contributing/State-Management/State-Management-Intro.md +224 -0
- package/contributing/State-Management/State-Management-Intro.zh-CN.md +216 -0
- package/contributing/State-Management/State-Management-Selectors.md +68 -0
- package/contributing/State-Management/State-Management-Selectors.zh-CN.md +49 -0
- package/contributing/Upstream-Sync.md +58 -0
- package/contributing/Upstream-Sync.zh-CN.md +58 -0
- package/contributing/_Footer.md +1 -0
- package/contributing/_Sidebar.md +48 -0
- package/docs/self-hosting/advanced/analytics.mdx +31 -0
- package/docs/self-hosting/advanced/analytics.zh-CN.mdx +28 -0
- package/docs/self-hosting/advanced/authentication.mdx +67 -0
- package/docs/self-hosting/advanced/authentication.zh-CN.mdx +65 -0
- package/docs/self-hosting/advanced/feature-flags.mdx +45 -0
- package/docs/self-hosting/advanced/feature-flags.zh-CN.mdx +42 -0
- package/docs/self-hosting/advanced/model-list.mdx +48 -0
- package/docs/self-hosting/advanced/model-list.zh-CN.mdx +46 -0
- package/docs/self-hosting/advanced/settings-url-share.mdx +132 -0
- package/docs/self-hosting/advanced/settings-url-share.zh-CN.mdx +131 -0
- package/docs/self-hosting/advanced/sso-providers/auth0.mdx +134 -0
- package/docs/self-hosting/advanced/sso-providers/auth0.zh-CN.mdx +126 -0
- package/docs/self-hosting/advanced/sso-providers/authentik.mdx +75 -0
- package/docs/self-hosting/advanced/sso-providers/authentik.zh-CN.mdx +69 -0
- package/docs/self-hosting/advanced/sso-providers/github.mdx +103 -0
- package/docs/self-hosting/advanced/sso-providers/github.zh-CN.mdx +95 -0
- package/docs/self-hosting/advanced/sso-providers/microsoft-entra-id.mdx +106 -0
- package/docs/self-hosting/advanced/sso-providers/microsoft-entra-id.zh-CN.mdx +100 -0
- package/docs/self-hosting/advanced/sso-providers/zitadel.mdx +120 -0
- package/docs/self-hosting/advanced/sso-providers/zitadel.zh-CN.mdx +112 -0
- package/docs/self-hosting/advanced/upstream-sync.mdx +161 -0
- package/docs/self-hosting/advanced/upstream-sync.zh-CN.mdx +153 -0
- package/docs/self-hosting/environment-variables/analytics.mdx +84 -0
- package/docs/self-hosting/environment-variables/analytics.zh-CN.mdx +82 -0
- package/docs/self-hosting/environment-variables/auth.mdx +171 -0
- package/docs/self-hosting/environment-variables/auth.zh-CN.mdx +168 -0
- package/docs/self-hosting/environment-variables/basic.mdx +118 -0
- package/docs/self-hosting/environment-variables/basic.zh-CN.mdx +114 -0
- package/docs/self-hosting/environment-variables/model-provider.mdx +299 -0
- package/docs/self-hosting/environment-variables/model-provider.zh-CN.mdx +297 -0
- package/docs/self-hosting/environment-variables.mdx +22 -0
- package/docs/self-hosting/environment-variables.zh-CN.mdx +20 -0
- package/docs/self-hosting/examples/azure-openai.mdx +46 -0
- package/docs/self-hosting/examples/azure-openai.zh-CN.mdx +48 -0
- package/docs/self-hosting/examples/ollama.mdx +104 -0
- package/docs/self-hosting/examples/ollama.zh-CN.mdx +103 -0
- package/docs/self-hosting/faq/no-v1-suffix.mdx +30 -0
- package/docs/self-hosting/faq/no-v1-suffix.zh-CN.mdx +27 -0
- package/docs/self-hosting/faq/proxy-with-unable-to-verify-leaf-signature.mdx +84 -0
- package/docs/self-hosting/faq/proxy-with-unable-to-verify-leaf-signature.zh-CN.mdx +81 -0
- package/docs/self-hosting/platform/docker-compose.mdx +143 -0
- package/docs/self-hosting/platform/docker-compose.zh-CN.mdx +134 -0
- package/docs/self-hosting/platform/docker.mdx +169 -0
- package/docs/self-hosting/platform/docker.zh-CN.mdx +167 -0
- package/docs/self-hosting/platform/netlify.mdx +154 -0
- package/docs/self-hosting/platform/netlify.zh-CN.mdx +148 -0
- package/docs/self-hosting/platform/railway.mdx +35 -0
- package/docs/self-hosting/platform/railway.zh-CN.mdx +34 -0
- package/docs/self-hosting/platform/repocloud.mdx +38 -0
- package/docs/self-hosting/platform/repocloud.zh-CN.mdx +36 -0
- package/docs/self-hosting/platform/sealos.mdx +37 -0
- package/docs/self-hosting/platform/sealos.zh-CN.mdx +36 -0
- package/docs/self-hosting/platform/vercel.mdx +46 -0
- package/docs/self-hosting/platform/vercel.zh-CN.mdx +47 -0
- package/docs/self-hosting/platform/zeabur.mdx +85 -0
- package/docs/self-hosting/platform/zeabur.zh-CN.mdx +84 -0
- package/docs/self-hosting/start.mdx +31 -0
- package/docs/self-hosting/start.zh-CN.mdx +32 -0
- package/docs/usage/agents/concepts.mdx +41 -0
- package/docs/usage/agents/concepts.zh-CN.mdx +38 -0
- package/docs/usage/agents/custom-agent.mdx +58 -0
- package/docs/usage/agents/custom-agent.zh-CN.mdx +53 -0
- package/docs/usage/agents/model.mdx +80 -0
- package/docs/usage/agents/model.zh-CN.mdx +75 -0
- package/docs/usage/agents/prompt.mdx +110 -0
- package/docs/usage/agents/prompt.zh-CN.mdx +106 -0
- package/docs/usage/agents/topics.mdx +27 -0
- package/docs/usage/agents/topics.zh-CN.mdx +25 -0
- package/docs/usage/features/agent-market.mdx +40 -0
- package/docs/usage/features/agent-market.zh-CN.mdx +36 -0
- package/docs/usage/features/local-llm.mdx +51 -0
- package/docs/usage/features/local-llm.zh-CN.mdx +43 -0
- package/docs/usage/features/mobile.mdx +24 -0
- package/docs/usage/features/mobile.zh-CN.mdx +23 -0
- package/docs/usage/features/more.mdx +33 -0
- package/docs/usage/features/more.zh-CN.mdx +28 -0
- package/docs/usage/features/multi-ai-providers.mdx +61 -0
- package/docs/usage/features/multi-ai-providers.zh-CN.mdx +61 -0
- package/docs/usage/features/plugin-system.mdx +89 -0
- package/docs/usage/features/plugin-system.zh-CN.mdx +77 -0
- package/docs/usage/features/pwa.mdx +73 -0
- package/docs/usage/features/pwa.zh-CN.mdx +73 -0
- package/docs/usage/features/text-to-image.mdx +26 -0
- package/docs/usage/features/text-to-image.zh-CN.mdx +26 -0
- package/docs/usage/features/theme.mdx +34 -0
- package/docs/usage/features/theme.zh-CN.mdx +30 -0
- package/docs/usage/features/tts.mdx +52 -0
- package/docs/usage/features/tts.zh-CN.mdx +46 -0
- package/docs/usage/features/vision.mdx +28 -0
- package/docs/usage/features/vision.zh-CN.mdx +25 -0
- package/docs/usage/plugins/basic-usage.mdx +69 -0
- package/docs/usage/plugins/basic-usage.zh-CN.mdx +67 -0
- package/docs/usage/plugins/custom-plugin.mdx +37 -0
- package/docs/usage/plugins/custom-plugin.zh-CN.mdx +35 -0
- package/docs/usage/plugins/development.mdx +329 -0
- package/docs/usage/plugins/development.zh-CN.mdx +323 -0
- package/docs/usage/plugins/store.mdx +30 -0
- package/docs/usage/plugins/store.zh-CN.mdx +27 -0
- package/docs/usage/providers/groq.mdx +76 -0
- package/docs/usage/providers/groq.zh-CN.mdx +70 -0
- package/docs/usage/providers/ollama/gemma.mdx +68 -0
- package/docs/usage/providers/ollama/gemma.zh-CN.mdx +67 -0
- package/docs/usage/providers/ollama/qwen.mdx +69 -0
- package/docs/usage/providers/ollama/qwen.zh-CN.mdx +66 -0
- package/docs/usage/providers/ollama.mdx +204 -0
- package/docs/usage/providers/ollama.zh-CN.mdx +202 -0
- package/docs/usage/start.mdx +46 -0
- package/docs/usage/start.zh-CN.mdx +38 -0
- package/drizzle.config.ts +29 -0
- package/locales/ar/auth.json +8 -0
- package/locales/ar/chat.json +138 -0
- package/locales/ar/clerk.json +769 -0
- package/locales/ar/common.json +224 -0
- package/locales/ar/components.json +16 -0
- package/locales/ar/error.json +114 -0
- package/locales/ar/market.json +32 -0
- package/locales/ar/metadata.json +18 -0
- package/locales/ar/migration.json +45 -0
- package/locales/ar/modelProvider.json +108 -0
- package/locales/ar/plugin.json +165 -0
- package/locales/ar/setting.json +404 -0
- package/locales/ar/tool.json +10 -0
- package/locales/ar/welcome.json +49 -0
- package/locales/bg-BG/auth.json +8 -0
- package/locales/bg-BG/chat.json +138 -0
- package/locales/bg-BG/clerk.json +769 -0
- package/locales/bg-BG/common.json +224 -0
- package/locales/bg-BG/components.json +16 -0
- package/locales/bg-BG/error.json +114 -0
- package/locales/bg-BG/market.json +32 -0
- package/locales/bg-BG/metadata.json +18 -0
- package/locales/bg-BG/migration.json +45 -0
- package/locales/bg-BG/modelProvider.json +108 -0
- package/locales/bg-BG/plugin.json +165 -0
- package/locales/bg-BG/setting.json +404 -0
- package/locales/bg-BG/tool.json +10 -0
- package/locales/bg-BG/welcome.json +49 -0
- package/locales/de-DE/auth.json +8 -0
- package/locales/de-DE/chat.json +138 -0
- package/locales/de-DE/clerk.json +769 -0
- package/locales/de-DE/common.json +224 -0
- package/locales/de-DE/components.json +16 -0
- package/locales/de-DE/error.json +114 -0
- package/locales/de-DE/market.json +32 -0
- package/locales/de-DE/metadata.json +18 -0
- package/locales/de-DE/migration.json +45 -0
- package/locales/de-DE/modelProvider.json +108 -0
- package/locales/de-DE/plugin.json +165 -0
- package/locales/de-DE/setting.json +404 -0
- package/locales/de-DE/tool.json +10 -0
- package/locales/de-DE/welcome.json +49 -0
- package/locales/en-US/auth.json +8 -0
- package/locales/en-US/chat.json +138 -0
- package/locales/en-US/clerk.json +769 -0
- package/locales/en-US/common.json +224 -0
- package/locales/en-US/components.json +16 -0
- package/locales/en-US/error.json +114 -0
- package/locales/en-US/market.json +32 -0
- package/locales/en-US/metadata.json +18 -0
- package/locales/en-US/migration.json +45 -0
- package/locales/en-US/modelProvider.json +108 -0
- package/locales/en-US/plugin.json +165 -0
- package/locales/en-US/setting.json +404 -0
- package/locales/en-US/tool.json +10 -0
- package/locales/en-US/welcome.json +49 -0
- package/locales/es-ES/auth.json +8 -0
- package/locales/es-ES/chat.json +138 -0
- package/locales/es-ES/clerk.json +769 -0
- package/locales/es-ES/common.json +224 -0
- package/locales/es-ES/components.json +16 -0
- package/locales/es-ES/error.json +114 -0
- package/locales/es-ES/market.json +32 -0
- package/locales/es-ES/metadata.json +18 -0
- package/locales/es-ES/migration.json +45 -0
- package/locales/es-ES/modelProvider.json +108 -0
- package/locales/es-ES/plugin.json +165 -0
- package/locales/es-ES/setting.json +404 -0
- package/locales/es-ES/tool.json +10 -0
- package/locales/es-ES/welcome.json +49 -0
- package/locales/fr-FR/auth.json +8 -0
- package/locales/fr-FR/chat.json +138 -0
- package/locales/fr-FR/clerk.json +769 -0
- package/locales/fr-FR/common.json +224 -0
- package/locales/fr-FR/components.json +16 -0
- package/locales/fr-FR/error.json +114 -0
- package/locales/fr-FR/market.json +32 -0
- package/locales/fr-FR/metadata.json +18 -0
- package/locales/fr-FR/migration.json +45 -0
- package/locales/fr-FR/modelProvider.json +108 -0
- package/locales/fr-FR/plugin.json +165 -0
- package/locales/fr-FR/setting.json +404 -0
- package/locales/fr-FR/tool.json +10 -0
- package/locales/fr-FR/welcome.json +49 -0
- package/locales/it-IT/auth.json +8 -0
- package/locales/it-IT/chat.json +138 -0
- package/locales/it-IT/clerk.json +769 -0
- package/locales/it-IT/common.json +224 -0
- package/locales/it-IT/components.json +16 -0
- package/locales/it-IT/error.json +114 -0
- package/locales/it-IT/market.json +32 -0
- package/locales/it-IT/metadata.json +18 -0
- package/locales/it-IT/migration.json +45 -0
- package/locales/it-IT/modelProvider.json +108 -0
- package/locales/it-IT/plugin.json +165 -0
- package/locales/it-IT/setting.json +404 -0
- package/locales/it-IT/tool.json +10 -0
- package/locales/it-IT/welcome.json +49 -0
- package/locales/ja-JP/auth.json +8 -0
- package/locales/ja-JP/chat.json +138 -0
- package/locales/ja-JP/clerk.json +769 -0
- package/locales/ja-JP/common.json +224 -0
- package/locales/ja-JP/components.json +16 -0
- package/locales/ja-JP/error.json +114 -0
- package/locales/ja-JP/market.json +32 -0
- package/locales/ja-JP/metadata.json +18 -0
- package/locales/ja-JP/migration.json +45 -0
- package/locales/ja-JP/modelProvider.json +108 -0
- package/locales/ja-JP/plugin.json +165 -0
- package/locales/ja-JP/setting.json +404 -0
- package/locales/ja-JP/tool.json +10 -0
- package/locales/ja-JP/welcome.json +49 -0
- package/locales/ko-KR/auth.json +8 -0
- package/locales/ko-KR/chat.json +138 -0
- package/locales/ko-KR/clerk.json +769 -0
- package/locales/ko-KR/common.json +224 -0
- package/locales/ko-KR/components.json +16 -0
- package/locales/ko-KR/error.json +114 -0
- package/locales/ko-KR/market.json +32 -0
- package/locales/ko-KR/metadata.json +18 -0
- package/locales/ko-KR/migration.json +45 -0
- package/locales/ko-KR/modelProvider.json +108 -0
- package/locales/ko-KR/plugin.json +165 -0
- package/locales/ko-KR/setting.json +404 -0
- package/locales/ko-KR/tool.json +10 -0
- package/locales/ko-KR/welcome.json +49 -0
- package/locales/nl-NL/auth.json +8 -0
- package/locales/nl-NL/chat.json +138 -0
- package/locales/nl-NL/clerk.json +769 -0
- package/locales/nl-NL/common.json +224 -0
- package/locales/nl-NL/components.json +16 -0
- package/locales/nl-NL/error.json +114 -0
- package/locales/nl-NL/market.json +32 -0
- package/locales/nl-NL/metadata.json +18 -0
- package/locales/nl-NL/migration.json +45 -0
- package/locales/nl-NL/modelProvider.json +108 -0
- package/locales/nl-NL/plugin.json +165 -0
- package/locales/nl-NL/setting.json +404 -0
- package/locales/nl-NL/tool.json +10 -0
- package/locales/nl-NL/welcome.json +49 -0
- package/locales/pl-PL/auth.json +8 -0
- package/locales/pl-PL/chat.json +138 -0
- package/locales/pl-PL/clerk.json +769 -0
- package/locales/pl-PL/common.json +224 -0
- package/locales/pl-PL/components.json +16 -0
- package/locales/pl-PL/error.json +114 -0
- package/locales/pl-PL/market.json +32 -0
- package/locales/pl-PL/metadata.json +18 -0
- package/locales/pl-PL/migration.json +45 -0
- package/locales/pl-PL/modelProvider.json +108 -0
- package/locales/pl-PL/plugin.json +165 -0
- package/locales/pl-PL/setting.json +404 -0
- package/locales/pl-PL/tool.json +10 -0
- package/locales/pl-PL/welcome.json +49 -0
- package/locales/pt-BR/auth.json +8 -0
- package/locales/pt-BR/chat.json +138 -0
- package/locales/pt-BR/clerk.json +769 -0
- package/locales/pt-BR/common.json +224 -0
- package/locales/pt-BR/components.json +16 -0
- package/locales/pt-BR/error.json +114 -0
- package/locales/pt-BR/market.json +32 -0
- package/locales/pt-BR/metadata.json +18 -0
- package/locales/pt-BR/migration.json +45 -0
- package/locales/pt-BR/modelProvider.json +108 -0
- package/locales/pt-BR/plugin.json +165 -0
- package/locales/pt-BR/setting.json +404 -0
- package/locales/pt-BR/tool.json +10 -0
- package/locales/pt-BR/welcome.json +49 -0
- package/locales/ru-RU/auth.json +8 -0
- package/locales/ru-RU/chat.json +138 -0
- package/locales/ru-RU/clerk.json +769 -0
- package/locales/ru-RU/common.json +224 -0
- package/locales/ru-RU/components.json +16 -0
- package/locales/ru-RU/error.json +114 -0
- package/locales/ru-RU/market.json +32 -0
- package/locales/ru-RU/metadata.json +18 -0
- package/locales/ru-RU/migration.json +45 -0
- package/locales/ru-RU/modelProvider.json +108 -0
- package/locales/ru-RU/plugin.json +165 -0
- package/locales/ru-RU/setting.json +404 -0
- package/locales/ru-RU/tool.json +10 -0
- package/locales/ru-RU/welcome.json +49 -0
- package/locales/tr-TR/auth.json +8 -0
- package/locales/tr-TR/chat.json +138 -0
- package/locales/tr-TR/clerk.json +769 -0
- package/locales/tr-TR/common.json +224 -0
- package/locales/tr-TR/components.json +16 -0
- package/locales/tr-TR/error.json +114 -0
- package/locales/tr-TR/market.json +32 -0
- package/locales/tr-TR/metadata.json +18 -0
- package/locales/tr-TR/migration.json +45 -0
- package/locales/tr-TR/modelProvider.json +108 -0
- package/locales/tr-TR/plugin.json +165 -0
- package/locales/tr-TR/setting.json +404 -0
- package/locales/tr-TR/tool.json +10 -0
- package/locales/tr-TR/welcome.json +49 -0
- package/locales/vi-VN/auth.json +8 -0
- package/locales/vi-VN/chat.json +138 -0
- package/locales/vi-VN/clerk.json +769 -0
- package/locales/vi-VN/common.json +224 -0
- package/locales/vi-VN/components.json +16 -0
- package/locales/vi-VN/error.json +114 -0
- package/locales/vi-VN/market.json +32 -0
- package/locales/vi-VN/metadata.json +18 -0
- package/locales/vi-VN/migration.json +45 -0
- package/locales/vi-VN/modelProvider.json +108 -0
- package/locales/vi-VN/plugin.json +165 -0
- package/locales/vi-VN/setting.json +404 -0
- package/locales/vi-VN/tool.json +10 -0
- package/locales/vi-VN/welcome.json +49 -0
- package/locales/zh-CN/auth.json +8 -0
- package/locales/zh-CN/chat.json +138 -0
- package/locales/zh-CN/clerk.json +769 -0
- package/locales/zh-CN/common.json +224 -0
- package/locales/zh-CN/components.json +16 -0
- package/locales/zh-CN/error.json +114 -0
- package/locales/zh-CN/market.json +32 -0
- package/locales/zh-CN/metadata.json +18 -0
- package/locales/zh-CN/migration.json +45 -0
- package/locales/zh-CN/modelProvider.json +108 -0
- package/locales/zh-CN/plugin.json +165 -0
- package/locales/zh-CN/setting.json +404 -0
- package/locales/zh-CN/tool.json +10 -0
- package/locales/zh-CN/welcome.json +49 -0
- package/locales/zh-TW/auth.json +8 -0
- package/locales/zh-TW/chat.json +138 -0
- package/locales/zh-TW/clerk.json +769 -0
- package/locales/zh-TW/common.json +224 -0
- package/locales/zh-TW/components.json +16 -0
- package/locales/zh-TW/error.json +114 -0
- package/locales/zh-TW/market.json +32 -0
- package/locales/zh-TW/metadata.json +18 -0
- package/locales/zh-TW/migration.json +45 -0
- package/locales/zh-TW/modelProvider.json +108 -0
- package/locales/zh-TW/plugin.json +165 -0
- package/locales/zh-TW/setting.json +404 -0
- package/locales/zh-TW/tool.json +10 -0
- package/locales/zh-TW/welcome.json +49 -0
- package/netlify.toml +10 -0
- package/next-sitemap.config.mjs +53 -0
- package/next.config.mjs +113 -16
- package/package.json +212 -83
- package/public/apple-touch-icon.png +0 -0
- package/public/favicon-32x32.ico +0 -0
- package/public/favicon.ico +0 -0
- package/public/icons/icon-192x192.maskable.png +0 -0
- package/public/icons/icon-192x192.png +0 -0
- package/public/icons/icon-512x512.maskable.png +0 -0
- package/public/icons/icon-512x512.png +0 -0
- package/public/images/banner_market_modal.webp +0 -0
- package/public/images/chatmode_chat_dark.webp +0 -0
- package/public/images/chatmode_chat_light.webp +0 -0
- package/public/images/chatmode_docs_dark.webp +0 -0
- package/public/images/chatmode_docs_light.webp +0 -0
- package/public/images/empty_topic_dark.webp +0 -0
- package/public/images/empty_topic_light.webp +0 -0
- package/public/images/logo.png +0 -0
- package/public/images/screenshot_background.webp +0 -0
- package/public/images/theme_auto.webp +0 -0
- package/public/images/theme_dark.webp +0 -0
- package/public/images/theme_light.webp +0 -0
- package/public/manifest.json +121 -0
- package/public/og/cover.png +0 -0
- package/public/screenshots/shot-1.desktop.png +0 -0
- package/public/screenshots/shot-1.mobile.png +0 -0
- package/public/screenshots/shot-2.desktop.png +0 -0
- package/public/screenshots/shot-2.mobile.png +0 -0
- package/public/screenshots/shot-3.desktop.png +0 -0
- package/public/screenshots/shot-3.mobile.png +0 -0
- package/public/screenshots/shot-4.desktop.png +0 -0
- package/public/screenshots/shot-4.mobile.png +0 -0
- package/public/screenshots/shot-5.desktop.png +0 -0
- package/public/screenshots/shot-5.mobile.png +0 -0
- package/public/videos/feedback.mp4 +0 -0
- package/public/videos/star.mp4 +0 -0
- package/renovate.json +13 -0
- package/scripts/docsWorkflow/const.ts +14 -0
- package/scripts/docsWorkflow/index.ts +82 -0
- package/scripts/docsWorkflow/toc.ts +60 -0
- package/scripts/docsWorkflow/utils.ts +38 -0
- package/scripts/i18nWorkflow/const.ts +18 -0
- package/scripts/i18nWorkflow/genDefaultLocale.ts +19 -0
- package/scripts/i18nWorkflow/genDiff.ts +50 -0
- package/scripts/i18nWorkflow/index.ts +11 -0
- package/scripts/i18nWorkflow/utils.ts +57 -0
- package/scripts/mdxWorkflow/index.ts +48 -0
- package/scripts/migrateServerDB/index.ts +30 -0
- package/scripts/readmeWorkflow/const.ts +19 -0
- package/scripts/readmeWorkflow/index.ts +12 -0
- package/scripts/readmeWorkflow/syncAgentIndex.ts +47 -0
- package/scripts/readmeWorkflow/syncPluginIndex.ts +42 -0
- package/scripts/readmeWorkflow/utlis.ts +52 -0
- package/sentry.client.config.ts +30 -0
- package/sentry.edge.config.ts +17 -0
- package/sentry.server.config.ts +19 -0
- package/src/app/(auth)/layout.tsx +19 -0
- package/src/app/(auth)/login/[[...login]]/page.tsx +21 -0
- package/src/app/(auth)/signup/[[...signup]]/page.tsx +21 -0
- package/src/app/(loading)/Client.tsx +13 -0
- package/src/app/(loading)/Redirect.tsx +51 -0
- package/src/app/(main)/(mobile)/me/(home)/__tests__/UserBanner.test.tsx +80 -0
- package/src/app/(main)/(mobile)/me/(home)/__tests__/useCategory.test.tsx +116 -0
- package/src/app/(main)/(mobile)/me/(home)/features/Category.tsx +15 -0
- package/src/app/(main)/(mobile)/me/(home)/features/Header.tsx +30 -0
- package/src/app/(main)/(mobile)/me/(home)/features/UserBanner.tsx +37 -0
- package/src/app/(main)/(mobile)/me/(home)/features/useCategory.tsx +118 -0
- package/src/app/(main)/(mobile)/me/(home)/layout.tsx +17 -0
- package/src/app/(main)/(mobile)/me/(home)/loading.tsx +38 -0
- package/src/app/(main)/(mobile)/me/(home)/page.tsx +38 -0
- package/src/app/(main)/(mobile)/me/data/features/Category.tsx +48 -0
- package/src/app/(main)/(mobile)/me/data/features/Header.tsx +33 -0
- package/src/app/(main)/(mobile)/me/data/layout.tsx +13 -0
- package/src/app/(main)/(mobile)/me/data/loading.tsx +5 -0
- package/src/app/(main)/(mobile)/me/data/page.tsx +27 -0
- package/src/app/(main)/(mobile)/me/profile/features/Category.tsx +45 -0
- package/src/app/(main)/(mobile)/me/profile/features/Header.tsx +33 -0
- package/src/app/(main)/(mobile)/me/profile/layout.tsx +16 -0
- package/src/app/(main)/(mobile)/me/profile/loading.tsx +5 -0
- package/src/app/(main)/(mobile)/me/profile/page.tsx +28 -0
- package/src/app/(main)/(mobile)/me/settings/features/Category.tsx +15 -0
- package/src/app/(main)/(mobile)/me/settings/features/Header.tsx +33 -0
- package/src/app/(main)/(mobile)/me/settings/features/useCategory.tsx +57 -0
- package/src/app/(main)/(mobile)/me/settings/layout.tsx +13 -0
- package/src/app/(main)/(mobile)/me/settings/loading.tsx +5 -0
- package/src/app/(main)/(mobile)/me/settings/page.tsx +28 -0
- package/src/app/(main)/@nav/_layout/Desktop/Avatar.test.tsx +55 -0
- package/src/app/(main)/@nav/_layout/Desktop/Avatar.tsx +53 -0
- package/src/app/(main)/@nav/_layout/Desktop/BottomActions.tsx +24 -0
- package/src/app/(main)/@nav/_layout/Desktop/TopActions.tsx +50 -0
- package/src/app/(main)/@nav/_layout/Desktop/index.tsx +26 -0
- package/src/app/(main)/@nav/_layout/Mobile.tsx +71 -0
- package/src/app/(main)/@nav/default.tsx +10 -0
- package/src/app/(main)/_layout/Desktop.tsx +33 -0
- package/src/app/(main)/_layout/Mobile.tsx +29 -0
- package/src/app/(main)/_layout/type.ts +6 -0
- package/src/app/(main)/chat/(workspace)/@conversation/default.tsx +23 -0
- package/src/app/(main)/chat/(workspace)/@conversation/features/ChatInput/Desktop/Footer/DragUpload.tsx +245 -0
- package/src/app/(main)/chat/(workspace)/@conversation/features/ChatInput/Desktop/Footer/LocalFiles.tsx +10 -0
- package/src/app/(main)/chat/(workspace)/@conversation/features/ChatInput/Desktop/Footer/SendMore.tsx +122 -0
- package/src/app/(main)/chat/(workspace)/@conversation/features/ChatInput/Desktop/Footer/index.tsx +173 -0
- package/src/app/(main)/chat/(workspace)/@conversation/features/ChatInput/Desktop/Header/index.tsx +25 -0
- package/src/app/(main)/chat/(workspace)/@conversation/features/ChatInput/Desktop/TextArea.test.tsx +316 -0
- package/src/app/(main)/chat/(workspace)/@conversation/features/ChatInput/Desktop/TextArea.tsx +129 -0
- package/src/app/(main)/chat/(workspace)/@conversation/features/ChatInput/Desktop/__tests__/useAutoFocus.test.ts +45 -0
- package/src/app/(main)/chat/(workspace)/@conversation/features/ChatInput/Desktop/index.tsx +60 -0
- package/src/app/(main)/chat/(workspace)/@conversation/features/ChatInput/Desktop/useAutoFocus.ts +13 -0
- package/src/app/(main)/chat/(workspace)/@conversation/features/ChatInput/Mobile/Files.tsx +19 -0
- package/src/app/(main)/chat/(workspace)/@conversation/features/ChatInput/Mobile/index.tsx +52 -0
- package/src/app/(main)/chat/(workspace)/@topic/_layout/Desktop.tsx +17 -0
- package/src/app/(main)/chat/(workspace)/@topic/_layout/Mobile.tsx +21 -0
- package/src/app/(main)/chat/(workspace)/@topic/default.tsx +32 -0
- package/src/app/(main)/chat/(workspace)/@topic/features/Header.tsx +88 -0
- package/src/app/(main)/chat/(workspace)/@topic/features/SkeletonList.tsx +57 -0
- package/src/app/(main)/chat/(workspace)/@topic/features/SystemRole/SystemRoleContent.tsx +128 -0
- package/src/app/(main)/chat/(workspace)/@topic/features/SystemRole/index.tsx +18 -0
- package/src/app/(main)/chat/(workspace)/@topic/features/SystemRole/style.ts +32 -0
- package/src/app/(main)/chat/(workspace)/@topic/features/TopicListContent/DefaultContent.tsx +29 -0
- package/src/app/(main)/chat/(workspace)/@topic/features/TopicListContent/TopicContent.tsx +211 -0
- package/src/app/(main)/chat/(workspace)/@topic/features/TopicListContent/TopicItem.tsx +81 -0
- package/src/app/(main)/chat/(workspace)/@topic/features/TopicListContent/index.tsx +107 -0
- package/src/app/(main)/chat/(workspace)/@topic/features/TopicSearchBar/index.tsx +42 -0
- package/src/app/(main)/chat/(workspace)/_layout/Desktop/ChatHeader/HeaderAction.tsx +40 -0
- package/src/app/(main)/chat/(workspace)/_layout/Desktop/ChatHeader/Main.tsx +91 -0
- package/src/app/(main)/chat/(workspace)/_layout/Desktop/ChatHeader/Tags.tsx +31 -0
- package/src/app/(main)/chat/(workspace)/_layout/Desktop/ChatHeader/index.tsx +8 -0
- package/src/app/(main)/chat/(workspace)/_layout/Desktop/HotKeys.tsx +49 -0
- package/src/app/(main)/chat/(workspace)/_layout/Desktop/TopicPanel.tsx +77 -0
- package/src/app/(main)/chat/(workspace)/_layout/Desktop/index.tsx +35 -0
- package/src/app/(main)/chat/(workspace)/_layout/Mobile/ChatHeader/ChatHeaderTitle.tsx +55 -0
- package/src/app/(main)/chat/(workspace)/_layout/Mobile/ChatHeader/index.tsx +37 -0
- package/src/app/(main)/chat/(workspace)/_layout/Mobile/TopicModal.tsx +35 -0
- package/src/app/(main)/chat/(workspace)/_layout/Mobile/index.tsx +21 -0
- package/src/app/(main)/chat/(workspace)/_layout/type.ts +7 -0
- package/src/app/(main)/chat/(workspace)/_layout/useInitAgentConfig.ts +10 -0
- package/src/app/(main)/chat/(workspace)/features/PluginTag/PluginStatus.tsx +108 -0
- package/src/app/(main)/chat/(workspace)/features/PluginTag/index.tsx +60 -0
- package/src/app/(main)/chat/(workspace)/features/SettingButton.tsx +25 -0
- package/src/app/(main)/chat/(workspace)/features/ShareButton/Preview.tsx +78 -0
- package/src/app/(main)/chat/(workspace)/features/ShareButton/ShareModal.tsx +164 -0
- package/src/app/(main)/chat/(workspace)/features/ShareButton/index.tsx +40 -0
- package/src/app/(main)/chat/(workspace)/features/ShareButton/style.ts +71 -0
- package/src/app/(main)/chat/(workspace)/features/ShareButton/type.ts +14 -0
- package/src/app/(main)/chat/(workspace)/features/ShareButton/useScreenshot.ts +60 -0
- package/src/app/(main)/chat/(workspace)/features/TelemetryNotification.tsx +93 -0
- package/src/app/(main)/chat/(workspace)/features/useWorkspaceModal.tsx +27 -0
- package/src/app/(main)/chat/(workspace)/layout.ts +11 -0
- package/src/app/(main)/chat/(workspace)/page.tsx +39 -0
- package/src/app/(main)/chat/@session/_layout/Desktop/PanelBody.tsx +22 -0
- package/src/app/(main)/chat/@session/_layout/Desktop/SessionHeader.tsx +59 -0
- package/src/app/(main)/chat/@session/_layout/Desktop/index.tsx +18 -0
- package/src/app/(main)/chat/@session/_layout/Mobile/SessionHeader.tsx +44 -0
- package/src/app/(main)/chat/@session/_layout/Mobile/index.tsx +22 -0
- package/src/app/(main)/chat/@session/default.tsx +29 -0
- package/src/app/(main)/chat/@session/features/SessionHydration.tsx +45 -0
- package/src/app/(main)/chat/@session/features/SessionListContent/CollapseGroup/Actions.tsx +141 -0
- package/src/app/(main)/chat/@session/features/SessionListContent/CollapseGroup/index.tsx +63 -0
- package/src/app/(main)/chat/@session/features/SessionListContent/DefaultMode.tsx +106 -0
- package/src/app/(main)/chat/@session/features/SessionListContent/Inbox/index.tsx +38 -0
- package/src/app/(main)/chat/@session/features/SessionListContent/List/AddButton.tsx +28 -0
- package/src/app/(main)/chat/@session/features/SessionListContent/List/Item/Actions.tsx +196 -0
- package/src/app/(main)/chat/@session/features/SessionListContent/List/Item/index.tsx +95 -0
- package/src/app/(main)/chat/@session/features/SessionListContent/List/index.tsx +67 -0
- package/src/app/(main)/chat/@session/features/SessionListContent/ListItem/index.tsx +67 -0
- package/src/app/(main)/chat/@session/features/SessionListContent/Modals/ConfigGroupModal/GroupItem.tsx +89 -0
- package/src/app/(main)/chat/@session/features/SessionListContent/Modals/ConfigGroupModal/index.tsx +85 -0
- package/src/app/(main)/chat/@session/features/SessionListContent/Modals/CreateGroupModal.tsx +70 -0
- package/src/app/(main)/chat/@session/features/SessionListContent/Modals/RenameGroupModal.tsx +59 -0
- package/src/app/(main)/chat/@session/features/SessionListContent/SearchMode.tsx +21 -0
- package/src/app/(main)/chat/@session/features/SessionListContent/index.tsx +18 -0
- package/src/app/(main)/chat/@session/features/SessionListContent/useSwitchSession.ts +26 -0
- package/src/app/(main)/chat/@session/features/SessionSearchBar.tsx +37 -0
- package/src/app/(main)/chat/@session/features/SkeletonList.tsx +51 -0
- package/src/app/(main)/chat/_layout/Desktop/SessionPanel.tsx +75 -0
- package/src/app/(main)/chat/_layout/Desktop/index.tsx +31 -0
- package/src/app/(main)/chat/_layout/Mobile.tsx +49 -0
- package/src/app/(main)/chat/_layout/type.ts +6 -0
- package/src/app/(main)/chat/error.tsx +5 -0
- package/src/app/(main)/chat/features/Migration/ExportConfigButton.tsx +33 -0
- package/src/app/(main)/chat/features/Migration/Failed.tsx +118 -0
- package/src/app/(main)/chat/features/Migration/Modal.tsx +80 -0
- package/src/app/(main)/chat/features/Migration/Start.tsx +106 -0
- package/src/app/(main)/chat/features/Migration/UpgradeButton.tsx +74 -0
- package/src/app/(main)/chat/features/Migration/const.ts +15 -0
- package/src/app/(main)/chat/features/Migration/index.tsx +39 -0
- package/src/app/(main)/chat/features/PageTitle/index.tsx +17 -0
- package/src/app/(main)/chat/layout.ts +11 -0
- package/src/app/(main)/chat/not-found.tsx +3 -0
- package/src/app/(main)/chat/settings/_layout/Desktop/Header.tsx +26 -0
- package/src/app/(main)/chat/settings/_layout/Desktop/index.tsx +21 -0
- package/src/app/(main)/chat/settings/_layout/Mobile/Header.tsx +27 -0
- package/src/app/(main)/chat/settings/_layout/Mobile/index.tsx +19 -0
- package/src/app/(main)/chat/settings/error.tsx +5 -0
- package/src/app/(main)/chat/settings/features/EditPage.tsx +40 -0
- package/src/app/(main)/chat/settings/features/HeaderContent.tsx +70 -0
- package/src/app/(main)/chat/settings/features/SubmitAgentButton/SubmitAgentModal.tsx +98 -0
- package/src/app/(main)/chat/settings/features/SubmitAgentButton/index.tsx +36 -0
- package/src/app/(main)/chat/settings/features/SubmitAgentButton/style.ts +46 -0
- package/src/app/(main)/chat/settings/layout.tsx +21 -0
- package/src/app/(main)/chat/settings/loading.tsx +3 -0
- package/src/app/(main)/chat/settings/modal/page.tsx +23 -0
- package/src/app/(main)/chat/settings/not-found.tsx +3 -0
- package/src/app/(main)/chat/settings/page.tsx +7 -0
- package/src/app/(main)/error.tsx +5 -0
- package/src/app/(main)/layout.tsx +11 -0
- package/src/app/(main)/market/@detail/default.tsx +12 -0
- package/src/app/(main)/market/@detail/features/AgentDetailContent.tsx +73 -0
- package/src/app/(main)/market/@detail/features/Banner.tsx +46 -0
- package/src/app/(main)/market/@detail/features/Comment.tsx +16 -0
- package/src/app/(main)/market/@detail/features/Header.tsx +81 -0
- package/src/app/(main)/market/@detail/features/Loading.tsx +63 -0
- package/src/app/(main)/market/@detail/features/TokenTag.tsx +26 -0
- package/src/app/(main)/market/@detail/features/style.ts +31 -0
- package/src/app/(main)/market/_layout/Desktop/DetailSidebar.tsx +84 -0
- package/src/app/(main)/market/_layout/Desktop/Header.tsx +27 -0
- package/src/app/(main)/market/_layout/Desktop/Hero.tsx +39 -0
- package/src/app/(main)/market/_layout/Desktop/index.tsx +46 -0
- package/src/app/(main)/market/_layout/Mobile/DetailModal.tsx +32 -0
- package/src/app/(main)/market/_layout/Mobile/Header.tsx +20 -0
- package/src/app/(main)/market/_layout/Mobile/index.tsx +25 -0
- package/src/app/(main)/market/_layout/type.ts +6 -0
- package/src/app/(main)/market/features/AgentCard/AgentCardBanner.tsx +59 -0
- package/src/app/(main)/market/features/AgentCard/index.tsx +139 -0
- package/src/app/(main)/market/features/AgentList.tsx +103 -0
- package/src/app/(main)/market/features/AgentSearchBar.tsx +42 -0
- package/src/app/(main)/market/features/ShareAgentButton/Inner.tsx +54 -0
- package/src/app/(main)/market/features/ShareAgentButton/index.tsx +50 -0
- package/src/app/(main)/market/features/TagList.tsx +69 -0
- package/src/app/(main)/market/layout.tsx +11 -0
- package/src/app/(main)/market/loading.tsx +15 -0
- package/src/app/(main)/market/page.tsx +44 -0
- package/src/app/(main)/not-found.tsx +3 -0
- package/src/app/(main)/profile/[[...slugs]]/Client.tsx +74 -0
- package/src/app/(main)/profile/[[...slugs]]/page.tsx +21 -0
- package/src/app/(main)/profile/_layout/Mobile/Header.tsx +26 -0
- package/src/app/(main)/profile/_layout/Mobile/index.tsx +16 -0
- package/src/app/(main)/profile/layout.tsx +20 -0
- package/src/app/(main)/profile/loading.tsx +23 -0
- package/src/app/(main)/settings/@category/default.tsx +15 -0
- package/src/app/(main)/settings/@category/features/CategoryContent.tsx +37 -0
- package/src/app/(main)/settings/@category/features/UpgradeAlert.tsx +38 -0
- package/src/app/(main)/settings/_layout/Desktop/Header.tsx +85 -0
- package/src/app/(main)/settings/_layout/Desktop/SideBar.tsx +59 -0
- package/src/app/(main)/settings/_layout/Desktop/index.tsx +54 -0
- package/src/app/(main)/settings/_layout/Mobile/Header.tsx +43 -0
- package/src/app/(main)/settings/_layout/Mobile/index.tsx +18 -0
- package/src/app/(main)/settings/_layout/type.ts +6 -0
- package/src/app/(main)/settings/about/features/AboutList.tsx +27 -0
- package/src/app/(main)/settings/about/features/Analytics.tsx +42 -0
- package/src/app/(main)/settings/about/features/ItemCard.tsx +45 -0
- package/src/app/(main)/settings/about/features/ItemLink.tsx +32 -0
- package/src/app/(main)/settings/about/features/Version.tsx +74 -0
- package/src/app/(main)/settings/about/index.tsx +139 -0
- package/src/app/(main)/settings/about/page.tsx +20 -0
- package/src/app/(main)/settings/agent/index.tsx +33 -0
- package/src/app/(main)/settings/agent/page.tsx +12 -0
- package/src/app/(main)/settings/common/features/Common.tsx +171 -0
- package/src/app/(main)/settings/common/features/Theme/ThemeSwatches/ThemeSwatchesNeutral.tsx +33 -0
- package/src/app/(main)/settings/common/features/Theme/ThemeSwatches/ThemeSwatchesPrimary.tsx +33 -0
- package/src/app/(main)/settings/common/features/Theme/ThemeSwatches/index.ts +2 -0
- package/src/app/(main)/settings/common/features/Theme/index.tsx +148 -0
- package/src/app/(main)/settings/common/index.tsx +15 -0
- package/src/app/(main)/settings/common/page.tsx +13 -0
- package/src/app/(main)/settings/error.tsx +5 -0
- package/src/app/(main)/settings/features/UpgradeAlert.tsx +42 -0
- package/src/app/(main)/settings/hooks/useCategory.tsx +94 -0
- package/src/app/(main)/settings/hooks/useSyncSettings.ts +23 -0
- package/src/app/(main)/settings/layout.ts +11 -0
- package/src/app/(main)/settings/llm/ProviderList/Azure/index.tsx +107 -0
- package/src/app/(main)/settings/llm/ProviderList/Bedrock/index.tsx +68 -0
- package/src/app/(main)/settings/llm/ProviderList/Ollama/Checker.tsx +73 -0
- package/src/app/(main)/settings/llm/ProviderList/Ollama/index.tsx +29 -0
- package/src/app/(main)/settings/llm/ProviderList/OpenAI/index.tsx +20 -0
- package/src/app/(main)/settings/llm/ProviderList/providers.tsx +141 -0
- package/src/app/(main)/settings/llm/components/Checker.tsx +111 -0
- package/src/app/(main)/settings/llm/components/Footer.tsx +35 -0
- package/src/app/(main)/settings/llm/components/ProviderConfig/index.tsx +214 -0
- package/src/app/(main)/settings/llm/components/ProviderModelList/CustomModelOption.tsx +93 -0
- package/src/app/(main)/settings/llm/components/ProviderModelList/ModelConfigModal/Form.tsx +98 -0
- package/src/app/(main)/settings/llm/components/ProviderModelList/ModelConfigModal/MaxTokenSlider.tsx +103 -0
- package/src/app/(main)/settings/llm/components/ProviderModelList/ModelConfigModal/index.tsx +78 -0
- package/src/app/(main)/settings/llm/components/ProviderModelList/ModelFetcher.tsx +86 -0
- package/src/app/(main)/settings/llm/components/ProviderModelList/Option.tsx +66 -0
- package/src/app/(main)/settings/llm/components/ProviderModelList/index.tsx +147 -0
- package/src/app/(main)/settings/llm/const.ts +20 -0
- package/src/app/(main)/settings/llm/index.tsx +25 -0
- package/src/app/(main)/settings/llm/page.tsx +23 -0
- package/src/app/(main)/settings/llm/type.ts +5 -0
- package/src/app/(main)/settings/loading.tsx +9 -0
- package/src/app/(main)/settings/modal/page.tsx +27 -0
- package/src/app/(main)/settings/not-found.tsx +3 -0
- package/src/app/(main)/settings/sync/features/Alert.tsx +39 -0
- package/src/app/(main)/settings/sync/features/DeviceInfo/Card.tsx +42 -0
- package/src/app/(main)/settings/sync/features/DeviceInfo/DeviceName.tsx +63 -0
- package/src/app/(main)/settings/sync/features/DeviceInfo/SystemIcon.tsx +29 -0
- package/src/app/(main)/settings/sync/features/DeviceInfo/index.tsx +103 -0
- package/src/app/(main)/settings/sync/features/WebRTC/ChannelNameInput.tsx +46 -0
- package/src/app/(main)/settings/sync/features/WebRTC/SyncSwitch/index.css +237 -0
- package/src/app/(main)/settings/sync/features/WebRTC/SyncSwitch/index.tsx +79 -0
- package/src/app/(main)/settings/sync/features/WebRTC/generateRandomRoomName.ts +4 -0
- package/src/app/(main)/settings/sync/features/WebRTC/index.tsx +98 -0
- package/src/app/(main)/settings/sync/index.tsx +17 -0
- package/src/app/(main)/settings/sync/page.tsx +26 -0
- package/src/app/(main)/settings/system-agent/features/Topic.tsx +56 -0
- package/src/app/(main)/settings/system-agent/features/Translation.tsx +56 -0
- package/src/app/(main)/settings/system-agent/features/useSync.ts +23 -0
- package/src/app/(main)/settings/system-agent/index.tsx +15 -0
- package/src/app/(main)/settings/system-agent/page.tsx +14 -0
- package/src/app/(main)/settings/tts/features/OpenAI.tsx +54 -0
- package/src/app/(main)/settings/tts/features/STT.tsx +58 -0
- package/src/app/(main)/settings/tts/features/const.ts +30 -0
- package/src/app/(main)/settings/tts/index.tsx +15 -0
- package/src/app/(main)/settings/tts/page.tsx +12 -0
- package/src/app/(main)/welcome/_layout/Desktop.tsx +36 -0
- package/src/app/(main)/welcome/_layout/Mobile.tsx +12 -0
- package/src/app/(main)/welcome/features/Actions.tsx +39 -0
- package/src/app/(main)/welcome/features/Hero.tsx +63 -0
- package/src/app/(main)/welcome/features/Logo.tsx +30 -0
- package/src/app/(main)/welcome/layout.tsx +10 -0
- package/src/app/(main)/welcome/page.tsx +41 -0
- package/src/app/@modal/(.)settings/modal/index.tsx +45 -0
- package/src/app/@modal/(.)settings/modal/layout.tsx +44 -0
- package/src/app/@modal/(.)settings/modal/loading.tsx +5 -0
- package/src/app/@modal/(.)settings/modal/page.tsx +19 -0
- package/src/app/@modal/_layout/SettingModalLayout.tsx +71 -0
- package/src/app/@modal/chat/(.)settings/modal/features/CategoryContent.tsx +37 -0
- package/src/app/@modal/chat/(.)settings/modal/features/useCategory.tsx +54 -0
- package/src/app/@modal/chat/(.)settings/modal/layout.tsx +58 -0
- package/src/app/@modal/chat/(.)settings/modal/loading.tsx +5 -0
- package/src/app/@modal/chat/(.)settings/modal/page.tsx +55 -0
- package/src/app/@modal/default.tsx +3 -0
- package/src/app/@modal/error.tsx +5 -0
- package/src/app/@modal/layout.tsx +34 -0
- package/src/app/@modal/loading.tsx +5 -0
- package/src/app/api/auth/[...nextauth]/route.ts +3 -0
- package/src/app/api/chat/[provider]/route.test.ts +222 -0
- package/src/app/api/chat/[provider]/route.ts +56 -0
- package/src/app/api/chat/agentRuntime.test.ts +333 -0
- package/src/app/api/chat/agentRuntime.ts +240 -0
- package/src/app/api/chat/anthropic/route.test.ts +28 -0
- package/src/app/api/chat/anthropic/route.ts +33 -0
- package/src/app/api/chat/apiKeyManager.test.ts +131 -0
- package/src/app/api/chat/apiKeyManager.ts +46 -0
- package/src/app/api/chat/google/route.test.ts +28 -0
- package/src/app/api/chat/google/route.ts +20 -0
- package/src/app/api/chat/minimax/route.test.ts +24 -0
- package/src/app/api/chat/minimax/route.ts +5 -0
- package/src/app/api/chat/models/[provider]/route.ts +45 -0
- package/src/app/api/config.test.ts +43 -0
- package/src/app/api/config.ts +14 -0
- package/src/app/api/errorResponse.test.ts +100 -0
- package/src/app/api/errorResponse.ts +54 -0
- package/src/app/api/market/AgentMarket.test.ts +55 -0
- package/src/app/api/market/AgentMarket.ts +25 -0
- package/src/app/api/market/[id]/route.ts +22 -0
- package/src/app/api/market/route.ts +23 -0
- package/src/app/api/middleware/auth/index.test.ts +77 -0
- package/src/app/api/middleware/auth/index.ts +62 -0
- package/src/app/api/middleware/auth/utils.test.ts +150 -0
- package/src/app/api/middleware/auth/utils.ts +83 -0
- package/src/app/api/openai/createBizOpenAI/auth.test.ts +53 -0
- package/src/app/api/openai/createBizOpenAI/auth.ts +31 -0
- package/src/app/api/openai/createBizOpenAI/createAzureOpenai.ts +33 -0
- package/src/app/api/openai/createBizOpenAI/createOpenai.ts +17 -0
- package/src/app/api/openai/createBizOpenAI/index.ts +37 -0
- package/src/app/api/openai/stt/route.ts +31 -0
- package/src/app/api/openai/tts/route.ts +19 -0
- package/src/app/api/plugin/gateway/route.ts +82 -0
- package/src/app/api/plugin/gateway/settings.test.ts +105 -0
- package/src/app/api/plugin/gateway/settings.ts +29 -0
- package/src/app/api/plugin/store/Store.test.ts +26 -0
- package/src/app/api/plugin/store/Store.ts +19 -0
- package/src/app/api/plugin/store/route.ts +23 -0
- package/src/app/api/proxy/route.ts +34 -0
- package/src/app/api/text-to-image/[provider]/route.ts +61 -0
- package/src/app/api/trace/route.ts +40 -0
- package/src/app/api/tts/edge-speech/route.ts +9 -0
- package/src/app/api/tts/microsoft-speech/route.ts +9 -0
- package/src/app/api/webhooks/clerk/__tests__/fixtures/createUser.json +73 -0
- package/src/app/api/webhooks/clerk/route.ts +159 -0
- package/src/app/api/webhooks/clerk/validateRequest.ts +22 -0
- package/src/app/error.tsx +5 -0
- package/src/app/global-error.tsx +20 -0
- package/src/app/layout.tsx +64 -0
- package/src/app/metadata.ts +58 -0
- package/src/app/not-found.tsx +3 -0
- package/src/app/page.tsx +23 -0
- package/src/app/trpc/edge/[trpc]/route.ts +28 -0
- package/src/app/trpc/lambda/[trpc]/route.ts +26 -0
- package/src/chains/__tests__/langDetect.test.ts +51 -0
- package/src/chains/__tests__/pickEmoji.test.ts +47 -0
- package/src/chains/__tests__/summaryAgentName.test.ts +57 -0
- package/src/chains/__tests__/summaryDescription.test.ts +83 -0
- package/src/chains/__tests__/summaryTags.test.ts +54 -0
- package/src/chains/__tests__/summaryTitle.test.ts +54 -0
- package/src/chains/__tests__/translate.test.ts +28 -0
- package/src/chains/langDetect.ts +31 -0
- package/src/chains/pickEmoji.ts +31 -0
- package/src/chains/summaryAgentName.ts +35 -0
- package/src/chains/summaryDescription.ts +49 -0
- package/src/chains/summaryTags.ts +28 -0
- package/src/chains/summaryTitle.ts +21 -0
- package/src/chains/translate.ts +17 -0
- package/src/components/404/index.tsx +43 -0
- package/src/components/Analytics/Clarity.tsx +28 -0
- package/src/components/Analytics/Google.tsx +7 -0
- package/src/components/Analytics/Plausible.tsx +16 -0
- package/src/components/Analytics/Posthog.tsx +22 -0
- package/src/components/Analytics/Umami.tsx +16 -0
- package/src/components/Analytics/Vercel.tsx +8 -0
- package/src/components/Analytics/index.tsx +44 -0
- package/src/components/AntdStaticMethods/index.test.tsx +43 -0
- package/src/components/AntdStaticMethods/index.tsx +20 -0
- package/src/components/BrandWatermark/index.tsx +39 -0
- package/src/components/BrowserIcon/components/Brave.tsx +56 -0
- package/src/components/BrowserIcon/components/Chrome.tsx +14 -0
- package/src/components/BrowserIcon/components/Chromium.tsx +14 -0
- package/src/components/BrowserIcon/components/Edge.tsx +36 -0
- package/src/components/BrowserIcon/components/Firefox.tsx +38 -0
- package/src/components/BrowserIcon/components/Opera.tsx +19 -0
- package/src/components/BrowserIcon/components/Safari.tsx +23 -0
- package/src/components/BrowserIcon/components/Samsung.tsx +21 -0
- package/src/components/BrowserIcon/index.tsx +50 -0
- package/src/components/BrowserIcon/types.ts +8 -0
- package/src/components/Cell/Divider.tsx +22 -0
- package/src/components/Cell/index.tsx +53 -0
- package/src/components/DataStyleModal/index.tsx +64 -0
- package/src/components/Error/index.tsx +58 -0
- package/src/components/Error/sentryCaptureException.ts +9 -0
- package/src/components/FetchErrorNotification/Description.tsx +48 -0
- package/src/components/FetchErrorNotification/index.tsx +15 -0
- package/src/components/FileList/EditableFileList.tsx +47 -0
- package/src/components/FileList/FileListViewer.tsx +19 -0
- package/src/components/FileList/index.ts +2 -0
- package/src/components/FileList/type.tsx +7 -0
- package/src/components/FullscreenLoading/index.tsx +20 -0
- package/src/components/GalleyGrid/Grid.tsx +36 -0
- package/src/components/GalleyGrid/index.tsx +58 -0
- package/src/components/GalleyGrid/style.ts +24 -0
- package/src/components/GuideModal/index.tsx +77 -0
- package/src/components/GuideVideo/index.tsx +30 -0
- package/src/components/HotKeys/index.tsx +77 -0
- package/src/components/ImageItem/index.tsx +75 -0
- package/src/components/ImageItem/style.ts +1 -0
- package/src/components/ManifestPreviewer/index.tsx +30 -0
- package/src/components/Menu/index.tsx +97 -0
- package/src/components/ModelIcon/index.tsx +97 -0
- package/src/components/ModelProviderIcon/index.tsx +118 -0
- package/src/components/ModelSelect/index.tsx +163 -0
- package/src/components/ModelTag/ModelIcon.tsx +93 -0
- package/src/components/ModelTag/index.tsx +13 -0
- package/src/components/Notification/index.tsx +95 -0
- package/src/components/PageTitle/index.tsx +11 -0
- package/src/components/SafeSpacing/index.tsx +27 -0
- package/src/components/SidebarHeader/index.tsx +38 -0
- package/src/components/SkeletonLoading/index.tsx +21 -0
- package/src/components/StopLoading.tsx +38 -0
- package/src/components/StoreHydration/ChatHydration/index.tsx +33 -0
- package/src/components/StructuredData/index.tsx +12 -0
- package/src/components/client/ClientResponsiveContent/index.tsx +32 -0
- package/src/components/client/ClientResponsiveLayout.tsx +32 -0
- package/src/components/server/MobileNavLayout.tsx +62 -0
- package/src/components/server/ServerLayout.tsx +19 -0
- package/src/config/__tests__/analytics.test.ts +70 -0
- package/src/config/__tests__/app.test.ts +48 -0
- package/src/config/__tests__/client.test.ts +40 -0
- package/src/config/analytics.ts +148 -0
- package/src/config/app.ts +60 -0
- package/src/config/auth.ts +149 -0
- package/src/config/db.ts +28 -0
- package/src/config/debug.ts +22 -0
- package/src/config/featureFlags/index.ts +31 -0
- package/src/config/featureFlags/schema.test.ts +59 -0
- package/src/config/featureFlags/schema.ts +57 -0
- package/src/config/featureFlags/utils/parser.test.ts +88 -0
- package/src/config/featureFlags/utils/parser.ts +32 -0
- package/src/config/file.ts +34 -0
- package/src/config/langfuse.ts +23 -0
- package/src/config/llm.ts +195 -0
- package/src/config/modelProviders/anthropic.ts +69 -0
- package/src/config/modelProviders/azure.ts +45 -0
- package/src/config/modelProviders/bedrock.ts +96 -0
- package/src/config/modelProviders/deepseek.ts +26 -0
- package/src/config/modelProviders/google.ts +108 -0
- package/src/config/modelProviders/groq.ts +48 -0
- package/src/config/modelProviders/index.ts +80 -0
- package/src/config/modelProviders/minimax.ts +50 -0
- package/src/config/modelProviders/mistral.ts +49 -0
- package/src/config/modelProviders/moonshot.ts +33 -0
- package/src/config/modelProviders/ollama.ts +190 -0
- package/src/config/modelProviders/openai.ts +142 -0
- package/src/config/modelProviders/openrouter.ts +125 -0
- package/src/config/modelProviders/perplexity.ts +52 -0
- package/src/config/modelProviders/qwen.ts +58 -0
- package/src/config/modelProviders/togetherai.ts +79 -0
- package/src/config/modelProviders/zeroone.ts +74 -0
- package/src/config/modelProviders/zhipu.ts +64 -0
- package/src/const/auth.ts +45 -0
- package/src/const/fetch.ts +27 -1
- package/src/const/guide.ts +86 -0
- package/src/const/hotkeys.ts +5 -0
- package/src/const/layoutTokens.ts +21 -0
- package/src/const/locale.ts +12 -0
- package/src/const/market.ts +15 -0
- package/src/const/message.test.ts +55 -0
- package/src/const/message.ts +15 -0
- package/src/const/meta.ts +8 -0
- package/src/const/plugin.ts +2 -0
- package/src/const/session.ts +25 -0
- package/src/const/settings/agent.ts +40 -0
- package/src/const/settings/common.ts +7 -0
- package/src/const/settings/index.ts +28 -0
- package/src/const/settings/llm.ts +96 -0
- package/src/const/settings/sync.ts +5 -0
- package/src/const/settings/systemAgent.ts +13 -0
- package/src/const/settings/tool.ts +5 -0
- package/src/const/settings/tts.ts +10 -0
- package/src/const/theme.ts +5 -0
- package/src/const/trace.ts +60 -0
- package/src/const/url.ts +59 -0
- package/src/const/user.ts +10 -0
- package/src/const/version.ts +6 -0
- package/src/database/client/core/__tests__/db-upgrade.test.ts +42 -0
- package/src/database/client/core/__tests__/db.test.ts +79 -0
- package/src/database/client/core/__tests__/model.test.ts +55 -0
- package/src/database/client/core/db.ts +246 -0
- package/src/database/client/core/index.ts +3 -0
- package/src/database/client/core/migrations/migrateSettingsToUser/fixtures/input.json +55 -0
- package/src/database/client/core/migrations/migrateSettingsToUser/fixtures/output.json +60 -0
- package/src/database/client/core/migrations/migrateSettingsToUser/index.test.ts +14 -0
- package/src/database/client/core/migrations/migrateSettingsToUser/index.ts +22 -0
- package/src/database/client/core/migrations/migrateSettingsToUser/type.ts +108 -0
- package/src/database/client/core/model.ts +252 -0
- package/src/database/client/core/schemas.ts +88 -0
- package/src/database/client/core/sync.ts +328 -0
- package/src/database/client/core/types/db.ts +15 -0
- package/src/database/client/models/__DEBUG.ts +124 -0
- package/src/database/client/models/__tests__/file.test.ts +83 -0
- package/src/database/client/models/__tests__/message.test.ts +417 -0
- package/src/database/client/models/__tests__/plugin.test.ts +81 -0
- package/src/database/client/models/__tests__/session.test.ts +254 -0
- package/src/database/client/models/__tests__/sessionGroup.test.ts +220 -0
- package/src/database/client/models/__tests__/topic.test.ts +523 -0
- package/src/database/client/models/__tests__/user.test.ts +82 -0
- package/src/database/client/models/file.ts +31 -0
- package/src/database/client/models/message.ts +262 -0
- package/src/database/client/models/plugin.ts +62 -0
- package/src/database/client/models/session.ts +271 -0
- package/src/database/client/models/sessionGroup.ts +90 -0
- package/src/database/client/models/topic.ts +244 -0
- package/src/database/client/models/user.ts +69 -0
- package/src/database/client/schemas/files.ts +39 -0
- package/src/database/client/schemas/message.ts +50 -0
- package/src/database/client/schemas/plugin.ts +12 -0
- package/src/database/client/schemas/session.ts +51 -0
- package/src/database/client/schemas/sessionGroup.ts +8 -0
- package/src/database/client/schemas/topic.ts +12 -0
- package/src/database/client/schemas/user.ts +40 -0
- package/src/database/server/core/db.ts +44 -0
- package/src/database/server/core/dbForTest.ts +45 -0
- package/src/database/server/index.ts +1 -0
- package/src/database/server/migrations/0000_init.sql +439 -0
- package/src/database/server/migrations/0001_add_client_id.sql +9 -0
- package/src/database/server/migrations/0002_amusing_puma.sql +9 -0
- package/src/database/server/migrations/meta/0000_snapshot.json +1583 -0
- package/src/database/server/migrations/meta/0001_snapshot.json +1636 -0
- package/src/database/server/migrations/meta/0002_snapshot.json +1630 -0
- package/src/database/server/migrations/meta/_journal.json +27 -0
- package/src/database/server/models/__tests__/file.test.ts +140 -0
- package/src/database/server/models/__tests__/message.test.ts +847 -0
- package/src/database/server/models/__tests__/plugin.test.ts +172 -0
- package/src/database/server/models/__tests__/session.test.ts +595 -0
- package/src/database/server/models/__tests__/topic.test.ts +623 -0
- package/src/database/server/models/__tests__/user.test.ts +173 -0
- package/src/database/server/models/_template.ts +44 -0
- package/src/database/server/models/file.ts +51 -0
- package/src/database/server/models/message.ts +378 -0
- package/src/database/server/models/plugin.ts +63 -0
- package/src/database/server/models/session.ts +290 -0
- package/src/database/server/models/sessionGroup.ts +69 -0
- package/src/database/server/models/topic.ts +265 -0
- package/src/database/server/models/user.ts +138 -0
- package/src/database/server/modules/DataImporter/__tests__/fixtures/messages.json +1101 -0
- package/src/database/server/modules/DataImporter/__tests__/index.test.ts +954 -0
- package/src/database/server/modules/DataImporter/index.ts +333 -0
- package/src/database/server/schemas/_id.ts +15 -0
- package/src/database/server/schemas/lobechat.ts +601 -0
- package/src/database/server/utils/idGenerator.test.ts +39 -0
- package/src/database/server/utils/idGenerator.ts +26 -0
- package/src/features/AgentInfo/index.tsx +70 -0
- package/src/features/AgentSetting/AgentChat/index.tsx +142 -0
- package/src/features/AgentSetting/AgentMeta/AutoGenerateInput.tsx +45 -0
- package/src/features/AgentSetting/AgentMeta/AutoGenerateSelect.tsx +50 -0
- package/src/features/AgentSetting/AgentMeta/BackgroundSwatches.tsx +27 -0
- package/src/features/AgentSetting/AgentMeta/index.tsx +135 -0
- package/src/features/AgentSetting/AgentModal/ModelSelect.tsx +20 -0
- package/src/features/AgentSetting/AgentModal/index.tsx +95 -0
- package/src/features/AgentSetting/AgentPlugin/AddPluginButton.tsx +49 -0
- package/src/features/AgentSetting/AgentPlugin/LoadingList.tsx +48 -0
- package/src/features/AgentSetting/AgentPlugin/LocalPluginItem.tsx +42 -0
- package/src/features/AgentSetting/AgentPlugin/PluginAction/index.tsx +36 -0
- package/src/features/AgentSetting/AgentPlugin/index.tsx +163 -0
- package/src/features/AgentSetting/AgentPrompt/TokenTag.tsx +39 -0
- package/src/features/AgentSetting/AgentPrompt/index.tsx +128 -0
- package/src/features/AgentSetting/AgentTTS/SelectWithTTSPreview.tsx +120 -0
- package/src/features/AgentSetting/AgentTTS/index.tsx +122 -0
- package/src/features/AgentSetting/AgentTTS/options.ts +16 -0
- package/src/features/AgentSetting/StoreUpdater.tsx +27 -0
- package/src/features/AgentSetting/index.tsx +26 -0
- package/src/features/AgentSetting/store/action.ts +287 -0
- package/src/features/AgentSetting/store/index.ts +16 -0
- package/src/features/AgentSetting/store/initialState.ts +28 -0
- package/src/features/AgentSetting/store/reducers/config.ts +54 -0
- package/src/features/AgentSetting/store/reducers/meta.ts +21 -0
- package/src/features/AgentSetting/store/selectors.ts +11 -0
- package/src/features/AgentSetting/useSyncAgemtSettings.ts +14 -0
- package/src/features/AvatarWithUpload/index.tsx +40 -0
- package/src/features/ChatInput/ActionBar/Clear.tsx +49 -0
- package/src/features/ChatInput/ActionBar/FileUpload.tsx +69 -0
- package/src/features/ChatInput/ActionBar/History.tsx +70 -0
- package/src/features/ChatInput/ActionBar/ModelSwitch.tsx +20 -0
- package/src/features/ChatInput/ActionBar/Temperature.tsx +49 -0
- package/src/features/ChatInput/ActionBar/Token/TokenProgress.tsx +80 -0
- package/src/features/ChatInput/ActionBar/Token/TokenTag.tsx +149 -0
- package/src/features/ChatInput/ActionBar/Token/index.tsx +18 -0
- package/src/features/ChatInput/ActionBar/Tools/Dropdown.tsx +145 -0
- package/src/features/ChatInput/ActionBar/Tools/ToolItem.tsx +45 -0
- package/src/features/ChatInput/ActionBar/Tools/index.tsx +33 -0
- package/src/features/ChatInput/ActionBar/config.ts +33 -0
- package/src/features/ChatInput/ActionBar/index.tsx +58 -0
- package/src/features/ChatInput/STT/browser.tsx +118 -0
- package/src/features/ChatInput/STT/common.tsx +120 -0
- package/src/features/ChatInput/STT/index.tsx +20 -0
- package/src/features/ChatInput/STT/openai.tsx +129 -0
- package/src/features/ChatInput/Topic/index.tsx +41 -0
- package/src/features/ChatInput/useChatInput.ts +45 -0
- package/src/features/ChatInput/useSend.ts +35 -0
- package/src/features/Conversation/Actions/Assistant.tsx +36 -0
- package/src/features/Conversation/Actions/Error.tsx +11 -0
- package/src/features/Conversation/Actions/Fallback.tsx +13 -0
- package/src/features/Conversation/Actions/Tool.tsx +28 -0
- package/src/features/Conversation/Actions/User.tsx +20 -0
- package/src/features/Conversation/Actions/customAction.ts +37 -0
- package/src/features/Conversation/Actions/index.ts +79 -0
- package/src/features/Conversation/Error/APIKeyForm/Bedrock.tsx +80 -0
- package/src/features/Conversation/Error/APIKeyForm/ProviderApiKeyForm.tsx +79 -0
- package/src/features/Conversation/Error/APIKeyForm/ProviderAvatar.tsx +89 -0
- package/src/features/Conversation/Error/APIKeyForm/index.tsx +96 -0
- package/src/features/Conversation/Error/AccessCodeForm.tsx +63 -0
- package/src/features/Conversation/Error/ClerkLogin/index.tsx +47 -0
- package/src/features/Conversation/Error/ErrorJsonViewer.tsx +26 -0
- package/src/features/Conversation/Error/InvalidAPIKey.tsx +16 -0
- package/src/features/Conversation/Error/InvalidAccessCode.tsx +79 -0
- package/src/features/Conversation/Error/OAuthForm.tsx +97 -0
- package/src/features/Conversation/Error/OllamaBizError/InvalidOllamaModel/index.tsx +153 -0
- package/src/features/Conversation/Error/OllamaBizError/InvalidOllamaModel/useDownloadMonitor.ts +46 -0
- package/src/features/Conversation/Error/OllamaBizError/SetupGuide.tsx +221 -0
- package/src/features/Conversation/Error/OllamaBizError/index.tsx +47 -0
- package/src/features/Conversation/Error/OpenAiBizError.tsx +29 -0
- package/src/features/Conversation/Error/PluginSettings.tsx +66 -0
- package/src/features/Conversation/Error/index.tsx +117 -0
- package/src/features/Conversation/Error/style.tsx +76 -0
- package/src/features/Conversation/Extras/Assistant.test.tsx +86 -0
- package/src/features/Conversation/Extras/Assistant.tsx +51 -0
- package/src/features/Conversation/Extras/ExtraContainer.tsx +13 -0
- package/src/features/Conversation/Extras/TTS/FilePlayer.tsx +25 -0
- package/src/features/Conversation/Extras/TTS/InitPlayer.tsx +93 -0
- package/src/features/Conversation/Extras/TTS/Player.tsx +61 -0
- package/src/features/Conversation/Extras/TTS/index.tsx +32 -0
- package/src/features/Conversation/Extras/Translate.tsx +72 -0
- package/src/features/Conversation/Extras/User.tsx +36 -0
- package/src/features/Conversation/Extras/index.ts +8 -0
- package/src/features/Conversation/Extras/type.ts +5 -0
- package/src/features/Conversation/Messages/Assistant/ToolCalls/index.tsx +73 -0
- package/src/features/Conversation/Messages/Assistant/ToolCalls/style.ts +25 -0
- package/src/features/Conversation/Messages/Assistant/index.tsx +51 -0
- package/src/features/Conversation/Messages/Default.tsx +19 -0
- package/src/features/Conversation/Messages/Tool/Inspector/PluginResultJSON.tsx +24 -0
- package/src/features/Conversation/Messages/Tool/Inspector/Settings.tsx +39 -0
- package/src/features/Conversation/Messages/Tool/Inspector/index.tsx +134 -0
- package/src/features/Conversation/Messages/Tool/Inspector/style.ts +26 -0
- package/src/features/Conversation/Messages/Tool/index.tsx +44 -0
- package/src/features/Conversation/Messages/User.tsx +23 -0
- package/src/features/Conversation/Messages/index.ts +38 -0
- package/src/features/Conversation/Plugins/Render/BuiltinType/index.test.tsx +53 -0
- package/src/features/Conversation/Plugins/Render/BuiltinType/index.tsx +29 -0
- package/src/features/Conversation/Plugins/Render/DefaultType/IFrameRender/index.tsx +61 -0
- package/src/features/Conversation/Plugins/Render/DefaultType/SystemJsRender/index.tsx +40 -0
- package/src/features/Conversation/Plugins/Render/DefaultType/SystemJsRender/utils.ts +26 -0
- package/src/features/Conversation/Plugins/Render/DefaultType/index.tsx +53 -0
- package/src/features/Conversation/Plugins/Render/Loading.tsx +60 -0
- package/src/features/Conversation/Plugins/Render/MarkdownType/index.tsx +25 -0
- package/src/features/Conversation/Plugins/Render/StandaloneType/Iframe.tsx +163 -0
- package/src/features/Conversation/Plugins/Render/StandaloneType/index.tsx +29 -0
- package/src/features/Conversation/Plugins/Render/index.tsx +51 -0
- package/src/features/Conversation/Plugins/Render/useParseContent.ts +15 -0
- package/src/features/Conversation/Plugins/Render/utils/iframeOnReady.test.ts +75 -0
- package/src/features/Conversation/Plugins/Render/utils/iframeOnReady.ts +25 -0
- package/src/features/Conversation/Plugins/Render/utils/listenToPlugin.test.ts +164 -0
- package/src/features/Conversation/Plugins/Render/utils/listenToPlugin.ts +98 -0
- package/src/features/Conversation/Plugins/Render/utils/pluginSettings.test.ts +53 -0
- package/src/features/Conversation/Plugins/Render/utils/pluginSettings.ts +17 -0
- package/src/features/Conversation/Plugins/Render/utils/pluginState.test.ts +43 -0
- package/src/features/Conversation/Plugins/Render/utils/pluginState.ts +20 -0
- package/src/features/Conversation/Plugins/Render/utils/postMessage.test.ts +64 -0
- package/src/features/Conversation/Plugins/Render/utils/postMessage.ts +28 -0
- package/src/features/Conversation/components/AutoScroll.tsx +26 -0
- package/src/features/Conversation/components/BackBottom/index.tsx +31 -0
- package/src/features/Conversation/components/BackBottom/style.ts +36 -0
- package/src/features/Conversation/components/BubblesLoading.tsx +61 -0
- package/src/features/Conversation/components/ChatItem/ActionsBar.tsx +58 -0
- package/src/features/Conversation/components/ChatItem/HistoryDivider.tsx +26 -0
- package/src/features/Conversation/components/ChatItem/index.tsx +156 -0
- package/src/features/Conversation/components/ChatList/index.tsx +21 -0
- package/src/features/Conversation/components/InboxWelcome/AgentsSuggest.tsx +113 -0
- package/src/features/Conversation/components/InboxWelcome/QuestionSuggest.tsx +104 -0
- package/src/features/Conversation/components/InboxWelcome/index.tsx +70 -0
- package/src/features/Conversation/components/OTPInput.tsx +136 -0
- package/src/features/Conversation/components/SkeletonList.tsx +51 -0
- package/src/features/Conversation/components/VirtualizedList/index.tsx +138 -0
- package/src/features/Conversation/hooks/useChatListActionsBar.tsx +55 -0
- package/src/features/Conversation/index.tsx +30 -0
- package/src/features/Conversation/types/index.tsx +32 -0
- package/src/features/DataImporter/Error.tsx +65 -0
- package/src/features/DataImporter/FileUploading.tsx +50 -0
- package/src/features/DataImporter/Loading.tsx +125 -0
- package/src/features/DataImporter/SuccessResult.tsx +61 -0
- package/src/features/DataImporter/index.tsx +185 -0
- package/src/features/DataImporter/style.ts +17 -0
- package/src/features/DebugUI/index.tsx +36 -0
- package/src/features/FileList/EditableFileList.tsx +31 -0
- package/src/features/FileList/FileListPreviewer.tsx +17 -0
- package/src/features/FileList/index.tsx +2 -0
- package/src/features/Follow/index.tsx +64 -0
- package/src/features/MobileSwitchLoading/index.tsx +13 -0
- package/src/features/MobileTabBar/index.tsx +61 -0
- package/src/features/ModelSelect/index.tsx +67 -0
- package/src/features/ModelSwitchPanel/index.tsx +113 -0
- package/src/features/PWAInstall/index.tsx +72 -0
- package/src/features/PluginDetailModal/APIs.tsx +43 -0
- package/src/features/PluginDetailModal/Meta.tsx +57 -0
- package/src/features/PluginDetailModal/index.tsx +75 -0
- package/src/features/PluginDevModal/LocalForm.tsx +124 -0
- package/src/features/PluginDevModal/PluginPreview.tsx +36 -0
- package/src/features/PluginDevModal/UrlManifestForm.tsx +134 -0
- package/src/features/PluginDevModal/index.tsx +172 -0
- package/src/features/PluginSettings/PluginSettingRender.tsx +86 -0
- package/src/features/PluginSettings/index.tsx +87 -0
- package/src/features/PluginStore/AddPluginButton.tsx +47 -0
- package/src/features/PluginStore/InstalledPluginList.tsx +61 -0
- package/src/features/PluginStore/Loading.tsx +13 -0
- package/src/features/PluginStore/OnlineList.tsx +89 -0
- package/src/features/PluginStore/PluginItem/Action.tsx +116 -0
- package/src/features/PluginStore/PluginItem/EditCustomPlugin.tsx +55 -0
- package/src/features/PluginStore/PluginItem/PluginTag.tsx +58 -0
- package/src/features/PluginStore/PluginItem/index.tsx +82 -0
- package/src/features/PluginStore/index.tsx +57 -0
- package/src/features/Setting/Footer.tsx +96 -0
- package/src/features/Setting/SettingContainer.tsx +35 -0
- package/src/features/SyncStatusInspector/DisableSync.tsx +79 -0
- package/src/features/SyncStatusInspector/EnableSync.tsx +136 -0
- package/src/features/SyncStatusInspector/EnableTag.tsx +66 -0
- package/src/features/SyncStatusInspector/index.tsx +27 -0
- package/src/features/User/DataStatistics.tsx +155 -0
- package/src/features/User/PlanTag.tsx +45 -0
- package/src/features/User/UserAvatar.tsx +75 -0
- package/src/features/User/UserInfo.tsx +59 -0
- package/src/features/User/UserLoginOrSignup.tsx +23 -0
- package/src/features/User/UserPanel/LangButton.tsx +57 -0
- package/src/features/User/UserPanel/PanelContent.tsx +85 -0
- package/src/features/User/UserPanel/ThemeButton.tsx +70 -0
- package/src/features/User/UserPanel/UpgradeBadge.tsx +19 -0
- package/src/features/User/UserPanel/index.tsx +43 -0
- package/src/features/User/UserPanel/useMenu.tsx +239 -0
- package/src/features/User/UserPanel/useNewVersion.tsx +14 -0
- package/src/features/User/__tests__/PanelContent.test.tsx +155 -0
- package/src/features/User/__tests__/UserAvatar.test.tsx +83 -0
- package/src/features/User/__tests__/useMenu.test.tsx +146 -0
- package/src/hooks/_header.ts +23 -0
- package/src/hooks/useActiveSettingsKey.ts +20 -0
- package/src/hooks/useActiveTabKey.ts +12 -0
- package/src/hooks/useDownloadSpeed.ts +50 -0
- package/src/hooks/useGreeting/greetingTime.ts +14 -0
- package/src/hooks/useGreeting/index.ts +16 -0
- package/src/hooks/useInterceptingRoutes.test.ts +70 -0
- package/src/hooks/useInterceptingRoutes.ts +46 -0
- package/src/hooks/useIsMobile.ts +8 -0
- package/src/hooks/useIsSubSlug.ts +12 -0
- package/src/hooks/usePWAInstall.test.ts +78 -0
- package/src/hooks/usePWAInstall.ts +39 -0
- package/src/hooks/usePlatform.test.ts +82 -0
- package/src/hooks/usePlatform.ts +32 -0
- package/src/hooks/useProviderName.ts +8 -0
- package/src/hooks/useQuery.test.ts +19 -0
- package/src/hooks/useQuery.ts +8 -0
- package/src/hooks/useQueryRoute.test.ts +86 -0
- package/src/hooks/useQueryRoute.ts +46 -0
- package/src/hooks/useSyncData.ts +50 -0
- package/src/hooks/useTTS.ts +84 -0
- package/src/hooks/useTokenCount.test.ts +41 -0
- package/src/hooks/useTokenCount.ts +20 -0
- package/src/layout/AuthProvider/Clerk/UserUpdater.tsx +40 -0
- package/src/layout/AuthProvider/Clerk/index.tsx +26 -0
- package/src/layout/AuthProvider/Clerk/useAppearance.ts +123 -0
- package/src/layout/AuthProvider/NextAuth/UserUpdater.tsx +35 -0
- package/src/layout/AuthProvider/NextAuth/index.tsx +17 -0
- package/src/layout/AuthProvider/NoAuth/index.tsx +16 -0
- package/src/layout/AuthProvider/index.tsx +17 -0
- package/src/layout/GlobalProvider/AppTheme.tsx +127 -0
- package/src/layout/GlobalProvider/Locale.tsx +62 -0
- package/src/layout/GlobalProvider/StoreInitialization.tsx +79 -0
- package/src/layout/GlobalProvider/StyleRegistry.tsx +24 -0
- package/src/layout/GlobalProvider/index.tsx +100 -0
- package/src/libs/agent-runtime/AgentRuntime.test.ts +416 -0
- package/src/libs/agent-runtime/AgentRuntime.ts +221 -0
- package/src/libs/agent-runtime/BaseAI.ts +24 -0
- package/src/libs/agent-runtime/anthropic/index.test.ts +507 -0
- package/src/libs/agent-runtime/anthropic/index.ts +160 -0
- package/src/libs/agent-runtime/azureOpenai/index.test.ts +356 -0
- package/src/libs/agent-runtime/azureOpenai/index.ts +106 -0
- package/src/libs/agent-runtime/bedrock/index.test.ts +394 -0
- package/src/libs/agent-runtime/bedrock/index.ts +154 -0
- package/src/libs/agent-runtime/deepseek/index.test.ts +255 -0
- package/src/libs/agent-runtime/deepseek/index.ts +10 -0
- package/src/libs/agent-runtime/error.ts +26 -0
- package/src/libs/agent-runtime/google/index.test.ts +602 -0
- package/src/libs/agent-runtime/google/index.ts +336 -0
- package/src/libs/agent-runtime/groq/index.test.ts +320 -0
- package/src/libs/agent-runtime/groq/index.ts +25 -0
- package/src/libs/agent-runtime/index.ts +22 -0
- package/src/libs/agent-runtime/minimax/index.test.ts +275 -0
- package/src/libs/agent-runtime/minimax/index.ts +176 -0
- package/src/libs/agent-runtime/mistral/index.test.ts +331 -0
- package/src/libs/agent-runtime/mistral/index.ts +21 -0
- package/src/libs/agent-runtime/moonshot/index.test.ts +251 -0
- package/src/libs/agent-runtime/moonshot/index.ts +10 -0
- package/src/libs/agent-runtime/ollama/index.test.ts +197 -0
- package/src/libs/agent-runtime/ollama/index.ts +111 -0
- package/src/libs/agent-runtime/ollama/type.ts +8 -0
- package/src/libs/agent-runtime/openai/__snapshots__/index.test.ts.snap +101 -0
- package/src/libs/agent-runtime/openai/fixtures/openai-models.json +170 -0
- package/src/libs/agent-runtime/openai/index.test.ts +245 -0
- package/src/libs/agent-runtime/openai/index.ts +16 -0
- package/src/libs/agent-runtime/openrouter/__snapshots__/index.test.ts.snap +82 -0
- package/src/libs/agent-runtime/openrouter/fixtures/models.json +62 -0
- package/src/libs/agent-runtime/openrouter/index.test.ts +312 -0
- package/src/libs/agent-runtime/openrouter/index.ts +41 -0
- package/src/libs/agent-runtime/openrouter/type.ts +28 -0
- package/src/libs/agent-runtime/perplexity/index.test.ts +249 -0
- package/src/libs/agent-runtime/perplexity/index.ts +31 -0
- package/src/libs/agent-runtime/qwen/index.test.ts +251 -0
- package/src/libs/agent-runtime/qwen/index.ts +28 -0
- package/src/libs/agent-runtime/togetherai/__snapshots__/index.test.ts.snap +886 -0
- package/src/libs/agent-runtime/togetherai/fixtures/models.json +8111 -0
- package/src/libs/agent-runtime/togetherai/index.test.ts +313 -0
- package/src/libs/agent-runtime/togetherai/index.ts +47 -0
- package/src/libs/agent-runtime/togetherai/type.ts +75 -0
- package/src/libs/agent-runtime/types/chat.ts +150 -0
- package/src/libs/agent-runtime/types/index.ts +3 -0
- package/src/libs/agent-runtime/types/textToImage.ts +34 -0
- package/src/libs/agent-runtime/types/type.ts +44 -0
- package/src/libs/agent-runtime/utils/anthropicHelpers.test.ts +233 -0
- package/src/libs/agent-runtime/utils/anthropicHelpers.ts +120 -0
- package/src/libs/agent-runtime/utils/createError.ts +11 -0
- package/src/libs/agent-runtime/utils/debugStream.test.ts +70 -0
- package/src/libs/agent-runtime/utils/debugStream.ts +48 -0
- package/src/libs/agent-runtime/utils/desensitizeUrl.test.ts +47 -0
- package/src/libs/agent-runtime/utils/desensitizeUrl.ts +34 -0
- package/src/libs/agent-runtime/utils/handleOpenAIError.ts +39 -0
- package/src/libs/agent-runtime/utils/openaiCompatibleFactory/index.test.ts +641 -0
- package/src/libs/agent-runtime/utils/openaiCompatibleFactory/index.ts +294 -0
- package/src/libs/agent-runtime/utils/response.ts +12 -0
- package/src/libs/agent-runtime/utils/streams/anthropic.test.ts +197 -0
- package/src/libs/agent-runtime/utils/streams/anthropic.ts +91 -0
- package/src/libs/agent-runtime/utils/streams/bedrock/claude.ts +21 -0
- package/src/libs/agent-runtime/utils/streams/bedrock/common.ts +32 -0
- package/src/libs/agent-runtime/utils/streams/bedrock/index.ts +3 -0
- package/src/libs/agent-runtime/utils/streams/bedrock/llama.test.ts +196 -0
- package/src/libs/agent-runtime/utils/streams/bedrock/llama.ts +51 -0
- package/src/libs/agent-runtime/utils/streams/google-ai.test.ts +97 -0
- package/src/libs/agent-runtime/utils/streams/google-ai.ts +68 -0
- package/src/libs/agent-runtime/utils/streams/index.ts +7 -0
- package/src/libs/agent-runtime/utils/streams/minimax.ts +39 -0
- package/src/libs/agent-runtime/utils/streams/ollama.test.ts +77 -0
- package/src/libs/agent-runtime/utils/streams/ollama.ts +38 -0
- package/src/libs/agent-runtime/utils/streams/openai.test.ts +263 -0
- package/src/libs/agent-runtime/utils/streams/openai.ts +83 -0
- package/src/libs/agent-runtime/utils/streams/protocol.ts +100 -0
- package/src/libs/agent-runtime/utils/uriParser.test.ts +29 -0
- package/src/libs/agent-runtime/utils/uriParser.ts +24 -0
- package/src/libs/agent-runtime/zeroone/index.test.ts +299 -0
- package/src/libs/agent-runtime/zeroone/index.ts +11 -0
- package/src/libs/agent-runtime/zhipu/authToken.test.ts +18 -0
- package/src/libs/agent-runtime/zhipu/authToken.ts +22 -0
- package/src/libs/agent-runtime/zhipu/index.test.ts +322 -0
- package/src/libs/agent-runtime/zhipu/index.ts +130 -0
- package/src/libs/logger/index.ts +5 -0
- package/src/libs/next-auth/index.ts +46 -0
- package/src/libs/next-auth/sso-providers/auth0.ts +17 -0
- package/src/libs/next-auth/sso-providers/authentik.ts +17 -0
- package/src/libs/next-auth/sso-providers/azure-ad.ts +17 -0
- package/src/libs/next-auth/sso-providers/github.ts +15 -0
- package/src/libs/next-auth/sso-providers/index.ts +7 -0
- package/src/libs/next-auth/sso-providers/zitadel.ts +16 -0
- package/src/libs/swr/index.ts +74 -0
- package/src/libs/traces/event.test.ts +158 -0
- package/src/libs/traces/event.ts +133 -0
- package/src/libs/traces/index.test.ts +61 -0
- package/src/libs/traces/index.ts +52 -0
- package/src/libs/trpc/client.ts +65 -0
- package/src/libs/trpc/index.ts +42 -0
- package/src/libs/trpc/init.ts +26 -0
- package/src/libs/trpc/middleware/password.test.ts +88 -0
- package/src/libs/trpc/middleware/password.ts +26 -0
- package/src/libs/trpc/middleware/userAuth.test.ts +44 -0
- package/src/libs/trpc/middleware/userAuth.ts +18 -0
- package/src/locales/create.ts +51 -38
- package/src/locales/default/auth.ts +8 -0
- package/src/locales/default/chat.ts +139 -0
- package/src/locales/default/clerk.ts +782 -0
- package/src/locales/default/common.ts +214 -39
- package/src/locales/default/components.ts +16 -0
- package/src/locales/default/error.ts +127 -0
- package/src/locales/default/index.ts +33 -0
- package/src/locales/default/market.ts +32 -0
- package/src/locales/default/metadata.ts +20 -0
- package/src/locales/default/migration.ts +47 -0
- package/src/locales/default/modelProvider.ts +111 -0
- package/src/locales/default/plugin.ts +166 -0
- package/src/locales/default/setting.ts +343 -32
- package/src/locales/default/tool.ts +10 -0
- package/src/locales/default/welcome.ts +50 -0
- package/src/locales/resources.test.ts +49 -0
- package/src/locales/resources.ts +114 -0
- package/src/middleware.ts +47 -0
- package/src/migrations/FromV0ToV1.ts +2 -4
- package/src/migrations/FromV1ToV2/fixtures/input-v1-session.json +191 -0
- package/src/migrations/FromV1ToV2/fixtures/output-v2.json +202 -0
- package/src/migrations/FromV1ToV2/index.ts +82 -0
- package/src/migrations/FromV1ToV2/migrations.test.ts +224 -0
- package/src/migrations/FromV1ToV2/types/v1.ts +78 -0
- package/src/migrations/FromV1ToV2/types/v2.ts +52 -0
- package/src/migrations/FromV2ToV3/fixtures/input-v2-session.json +72 -0
- package/src/migrations/FromV2ToV3/fixtures/output-v3-from-v1.json +203 -0
- package/src/migrations/FromV2ToV3/fixtures/output-v3.json +74 -0
- package/src/migrations/FromV2ToV3/index.ts +30 -0
- package/src/migrations/FromV2ToV3/migrations.test.ts +42 -0
- package/src/migrations/FromV2ToV3/types/v3.ts +27 -0
- package/src/migrations/FromV3ToV4/fixtures/azure-input-v3.json +79 -0
- package/src/migrations/FromV3ToV4/fixtures/azure-output-v4.json +75 -0
- package/src/migrations/FromV3ToV4/fixtures/ollama-input-v3.json +85 -0
- package/src/migrations/FromV3ToV4/fixtures/ollama-output-v4.json +85 -0
- package/src/migrations/FromV3ToV4/fixtures/openai-input-v3.json +77 -0
- package/src/migrations/FromV3ToV4/fixtures/openai-output-v4.json +77 -0
- package/src/migrations/FromV3ToV4/fixtures/openrouter-input-v3.json +82 -0
- package/src/migrations/FromV3ToV4/fixtures/openrouter-output-v4.json +85 -0
- package/src/migrations/FromV3ToV4/fixtures/output-v4-from-v1.json +203 -0
- package/src/migrations/FromV3ToV4/index.ts +102 -0
- package/src/migrations/FromV3ToV4/migrations.test.ts +195 -0
- package/src/migrations/FromV3ToV4/types/v3.ts +52 -0
- package/src/migrations/FromV3ToV4/types/v4.ts +37 -0
- package/src/migrations/FromV4ToV5/fixtures/from-v1-to-v5-output.json +245 -0
- package/src/migrations/FromV4ToV5/fixtures/function-input-v4.json +96 -0
- package/src/migrations/FromV4ToV5/fixtures/function-output-v5.json +120 -0
- package/src/migrations/FromV4ToV5/index.ts +58 -0
- package/src/migrations/FromV4ToV5/migrations.test.ts +49 -0
- package/src/migrations/FromV4ToV5/types/v4.ts +21 -0
- package/src/migrations/FromV4ToV5/types/v5.ts +27 -0
- package/src/migrations/FromV5ToV6/fixtures/from-v1-to-v6-output.json +247 -0
- package/src/migrations/FromV5ToV6/fixtures/session-input-v5.json +81 -0
- package/src/migrations/FromV5ToV6/fixtures/session-output-v6.json +85 -0
- package/src/migrations/FromV5ToV6/index.ts +61 -0
- package/src/migrations/FromV5ToV6/migrations.test.ts +50 -0
- package/src/migrations/FromV5ToV6/types/v5.ts +48 -0
- package/src/migrations/FromV5ToV6/types/v6.ts +60 -0
- package/src/migrations/FromV6ToV7/fixtures/output-v7-from-v1.json +203 -0
- package/src/migrations/FromV6ToV7/fixtures/provider-input-v6.json +103 -0
- package/src/migrations/FromV6ToV7/fixtures/provider-output-v7.json +118 -0
- package/src/migrations/FromV6ToV7/index.ts +101 -0
- package/src/migrations/FromV6ToV7/migrations.test.ts +64 -0
- package/src/migrations/FromV6ToV7/types/v6.ts +61 -0
- package/src/migrations/FromV6ToV7/types/v7.ts +71 -0
- package/src/{utils → migrations}/VersionController.test.ts +1 -3
- package/src/{utils → migrations}/VersionController.ts +6 -3
- package/src/migrations/index.ts +55 -7
- package/src/server/context.ts +51 -0
- package/src/server/files/s3.ts +78 -0
- package/src/server/globalConfig/index.ts +132 -0
- package/src/server/globalConfig/parseDefaultAgent.test.ts +195 -0
- package/src/server/globalConfig/parseDefaultAgent.ts +47 -0
- package/src/server/globalConfig/parseSystemAgent.test.ts +95 -0
- package/src/server/globalConfig/parseSystemAgent.ts +39 -0
- package/src/server/keyVaultsEncrypt/index.test.ts +62 -0
- package/src/server/keyVaultsEncrypt/index.ts +93 -0
- package/src/server/ld.ts +218 -0
- package/src/server/metadata.ts +96 -0
- package/src/server/mock.ts +8 -0
- package/src/server/routers/edge/config/__snapshots__/index.test.ts.snap +134 -0
- package/src/server/routers/edge/config/index.test.ts +195 -0
- package/src/server/routers/edge/config/index.ts +12 -0
- package/src/server/routers/edge/index.ts +15 -0
- package/src/server/routers/edge/upload.ts +16 -0
- package/src/server/routers/lambda/file.ts +49 -0
- package/src/server/routers/lambda/importer.ts +54 -0
- package/src/server/routers/lambda/index.ts +28 -0
- package/src/server/routers/lambda/message.ts +165 -0
- package/src/server/routers/lambda/plugin.ts +100 -0
- package/src/server/routers/lambda/session.ts +194 -0
- package/src/server/routers/lambda/sessionGroup.ts +77 -0
- package/src/server/routers/lambda/topic.ts +134 -0
- package/src/server/routers/lambda/user.ts +57 -0
- package/src/server/translation.ts +44 -0
- package/src/services/__tests__/__snapshots__/chat.test.ts.snap +116 -0
- package/src/services/__tests__/__snapshots__/tool.test.ts.snap +204 -0
- package/src/services/__tests__/chat.test.ts +959 -0
- package/src/services/__tests__/global.test.ts +100 -0
- package/src/services/__tests__/ollama.test.ts +28 -0
- package/src/services/__tests__/openai/OpenAPI_V3.json +245 -0
- package/src/services/__tests__/openai/plugin.json +22 -0
- package/src/services/__tests__/share.test.ts +131 -0
- package/src/services/__tests__/sync.test.ts +56 -0
- package/src/services/__tests__/tool.test.ts +268 -0
- package/src/services/__tests__/upload.test.ts +72 -0
- package/src/services/_auth.test.ts +175 -0
- package/src/services/_auth.ts +75 -0
- package/src/services/_header.ts +20 -0
- package/src/services/_url.ts +46 -0
- package/src/services/chat.ts +524 -0
- package/src/services/config.ts +159 -0
- package/src/services/debug.ts +40 -0
- package/src/services/file/client.test.ts +160 -0
- package/src/services/file/client.ts +65 -0
- package/src/services/file/index.ts +6 -0
- package/src/services/file/server.ts +45 -0
- package/src/services/file/type.ts +9 -0
- package/src/services/github.ts +42 -0
- package/src/services/global.ts +29 -0
- package/src/services/import/client.ts +74 -0
- package/src/services/import/index.ts +6 -0
- package/src/services/import/server.ts +115 -0
- package/src/services/market.ts +22 -0
- package/src/services/message/client.test.ts +349 -0
- package/src/services/message/client.ts +83 -0
- package/src/services/message/index.test.ts +48 -0
- package/src/services/message/index.ts +8 -0
- package/src/services/message/server.ts +93 -0
- package/src/services/message/type.ts +46 -0
- package/src/services/models.ts +37 -0
- package/src/services/ollama.ts +83 -0
- package/src/services/plugin/client.test.ts +162 -0
- package/src/services/plugin/client.ts +42 -0
- package/src/services/plugin/index.ts +6 -0
- package/src/services/plugin/server.ts +46 -0
- package/src/services/plugin/type.ts +21 -0
- package/src/services/session/client.test.ts +439 -0
- package/src/services/session/client.ts +180 -0
- package/src/services/session/index.ts +6 -0
- package/src/services/session/server.ts +148 -0
- package/src/services/session/type.ts +65 -0
- package/src/services/share.ts +61 -0
- package/src/services/sync.ts +19 -0
- package/src/services/textToImage.ts +36 -0
- package/src/services/tool.ts +144 -0
- package/src/services/topic/client.test.ts +245 -0
- package/src/services/topic/client.ts +70 -0
- package/src/services/topic/index.ts +6 -0
- package/src/services/topic/server.ts +68 -0
- package/src/services/topic/type.ts +34 -0
- package/src/services/trace.ts +28 -0
- package/src/services/upload.ts +99 -0
- package/src/services/user/client.test.ts +102 -0
- package/src/services/user/client.ts +52 -0
- package/src/services/user/index.ts +6 -0
- package/src/services/user/server.ts +28 -0
- package/src/services/user/type.ts +11 -0
- package/src/store/agent/index.ts +2 -0
- package/src/store/agent/initialState.ts +7 -0
- package/src/store/agent/selectors.ts +1 -0
- package/src/store/agent/slices/chat/__snapshots__/selectors.test.ts.snap +30 -0
- package/src/store/agent/slices/chat/action.test.ts +305 -0
- package/src/store/agent/slices/chat/action.ts +176 -0
- package/src/store/agent/slices/chat/index.ts +2 -0
- package/src/store/agent/slices/chat/initialState.ts +20 -0
- package/src/store/agent/slices/chat/selectors.test.ts +227 -0
- package/src/store/agent/slices/chat/selectors.ts +98 -0
- package/src/store/agent/store.ts +22 -0
- package/src/store/chat/helpers.test.ts +109 -0
- package/src/store/chat/helpers.ts +30 -0
- package/src/store/chat/index.ts +3 -0
- package/src/store/chat/initialState.ts +13 -0
- package/src/store/chat/selectors.ts +3 -0
- package/src/store/chat/slices/builtinTool/action.test.ts +104 -0
- package/src/store/chat/slices/builtinTool/action.ts +101 -0
- package/src/store/chat/slices/builtinTool/initialState.ts +7 -0
- package/src/store/chat/slices/builtinTool/selectors.ts +11 -0
- package/src/store/chat/slices/enchance/action.test.ts +126 -0
- package/src/store/chat/slices/enchance/action.ts +124 -0
- package/src/store/chat/slices/message/action.test.ts +1243 -0
- package/src/store/chat/slices/message/action.ts +765 -0
- package/src/store/chat/slices/message/initialState.ts +45 -0
- package/src/store/chat/slices/message/reducer.test.ts +83 -0
- package/src/store/chat/slices/message/reducer.ts +131 -0
- package/src/store/chat/slices/message/selectors.test.ts +293 -0
- package/src/store/chat/slices/message/selectors.ts +161 -0
- package/src/store/chat/slices/message/utils.ts +7 -0
- package/src/store/chat/slices/plugin/action.test.ts +660 -0
- package/src/store/chat/slices/plugin/action.ts +304 -0
- package/src/store/chat/slices/share/action.test.ts +213 -0
- package/src/store/chat/slices/share/action.ts +122 -0
- package/src/store/chat/slices/share/initialState.ts +7 -0
- package/src/store/chat/slices/topic/action.test.ts +540 -0
- package/src/store/chat/slices/topic/action.ts +330 -0
- package/src/store/chat/slices/topic/initialState.ts +28 -0
- package/src/store/chat/slices/topic/reducer.test.ts +139 -0
- package/src/store/chat/slices/topic/reducer.ts +67 -0
- package/src/store/chat/slices/topic/selectors.test.ts +95 -0
- package/src/store/chat/slices/topic/selectors.ts +35 -0
- package/src/store/chat/store.ts +44 -0
- package/src/store/file/index.ts +2 -0
- package/src/store/file/initialState.ts +7 -0
- package/src/store/file/selectors.ts +7 -0
- package/src/store/file/slices/images/action.test.ts +184 -0
- package/src/store/file/slices/images/action.ts +153 -0
- package/src/store/file/slices/images/initialState.ts +13 -0
- package/src/store/file/slices/images/selectors.test.ts +78 -0
- package/src/store/file/slices/images/selectors.ts +40 -0
- package/src/store/file/slices/tts/action.test.ts +141 -0
- package/src/store/file/slices/tts/action.ts +63 -0
- package/src/store/file/slices/tts/index.ts +2 -0
- package/src/store/file/slices/tts/selectors.ts +3 -0
- package/src/store/file/store.ts +23 -0
- package/src/store/global/action.test.ts +183 -0
- package/src/store/global/action.ts +107 -0
- package/src/store/global/index.ts +1 -0
- package/src/store/global/initialState.ts +72 -0
- package/src/store/global/selectors.ts +26 -0
- package/src/store/global/store.ts +26 -0
- package/src/store/market/action.ts +82 -0
- package/src/store/market/index.ts +3 -0
- package/src/store/market/initialState.ts +19 -0
- package/src/store/market/selectors.ts +38 -0
- package/src/store/market/store.ts +48 -0
- package/src/store/middleware/createDevtools.ts +23 -0
- package/src/store/middleware/createHyperStorage/index.test.ts +341 -0
- package/src/store/middleware/createHyperStorage/index.ts +126 -0
- package/src/store/middleware/createHyperStorage/indexedDB.test.ts +64 -0
- package/src/store/middleware/createHyperStorage/indexedDB.ts +26 -0
- package/src/store/middleware/createHyperStorage/keyMapper.ts +57 -0
- package/src/store/middleware/createHyperStorage/localStorage.ts +18 -0
- package/src/store/middleware/createHyperStorage/type.ts +25 -0
- package/src/store/middleware/createHyperStorage/urlStorage.test.ts +84 -0
- package/src/store/middleware/createHyperStorage/urlStorage.ts +81 -0
- package/src/store/serverConfig/Provider.tsx +23 -0
- package/src/store/serverConfig/index.ts +3 -0
- package/src/store/serverConfig/selectors.test.ts +74 -0
- package/src/store/serverConfig/selectors.ts +14 -0
- package/src/store/serverConfig/store.test.ts +53 -0
- package/src/store/serverConfig/store.ts +66 -0
- package/src/store/session/helpers.ts +1 -0
- package/src/store/session/index.ts +1 -32
- package/src/store/session/initialState.ts +4 -6
- package/src/store/session/selectors.ts +2 -3
- package/src/store/session/slices/session/action.test.ts +232 -0
- package/src/store/session/slices/session/action.ts +226 -70
- package/src/store/session/slices/session/helpers.ts +17 -0
- package/src/store/session/slices/session/initialState.ts +18 -19
- package/src/store/session/slices/session/reducers.test.ts +79 -0
- package/src/store/session/slices/session/reducers.ts +61 -0
- package/src/store/session/slices/session/selectors/index.ts +2 -20
- package/src/store/session/slices/session/selectors/list.test.ts +126 -0
- package/src/store/session/slices/session/selectors/list.ts +45 -51
- package/src/store/session/slices/session/selectors/meta.test.ts +108 -0
- package/src/store/session/slices/session/selectors/meta.ts +45 -0
- package/src/store/session/slices/sessionGroup/action.test.ts +133 -0
- package/src/store/session/slices/sessionGroup/action.ts +73 -0
- package/src/store/session/slices/sessionGroup/initialState.ts +12 -0
- package/src/store/session/slices/sessionGroup/reducer.test.ts +86 -0
- package/src/store/session/slices/sessionGroup/reducer.ts +56 -0
- package/src/store/session/slices/sessionGroup/selectors.ts +11 -0
- package/src/store/session/store.ts +25 -9
- package/src/store/tool/helpers.ts +28 -0
- package/src/store/tool/index.ts +2 -0
- package/src/store/tool/initialState.ts +13 -0
- package/src/store/tool/selectors/index.ts +5 -0
- package/src/store/tool/selectors/tool.test.ts +233 -0
- package/src/store/tool/selectors/tool.ts +110 -0
- package/src/store/tool/slices/builtin/action.test.ts +90 -0
- package/src/store/tool/slices/builtin/action.ts +54 -0
- package/src/store/{session/slices/session → tool/slices/builtin}/index.ts +0 -1
- package/src/store/tool/slices/builtin/initialState.ts +12 -0
- package/src/store/tool/slices/builtin/selectors.test.ts +53 -0
- package/src/store/tool/slices/builtin/selectors.ts +20 -0
- package/src/store/tool/slices/customPlugin/action.test.ts +141 -0
- package/src/store/tool/slices/customPlugin/action.ts +88 -0
- package/src/store/{session/slices/chat → tool/slices/customPlugin}/index.ts +1 -1
- package/src/store/tool/slices/customPlugin/initialState.ts +17 -0
- package/src/store/tool/slices/customPlugin/reducers/customPluginList.ts +56 -0
- package/src/store/tool/slices/customPlugin/selectors.test.ts +70 -0
- package/src/store/tool/slices/customPlugin/selectors.ts +9 -0
- package/src/store/tool/slices/plugin/__snapshots__/action.test.ts.snap +15 -0
- package/src/store/tool/slices/plugin/action.test.ts +196 -0
- package/src/store/tool/slices/plugin/action.ts +76 -0
- package/src/store/tool/slices/plugin/index.ts +3 -0
- package/src/store/tool/slices/plugin/initialState.ts +16 -0
- package/src/store/tool/slices/plugin/reducers/manifest.ts +36 -0
- package/src/store/tool/slices/plugin/selectors.test.ts +197 -0
- package/src/store/tool/slices/plugin/selectors.ts +80 -0
- package/src/store/tool/slices/store/action.test.ts +392 -0
- package/src/store/tool/slices/store/action.ts +112 -0
- package/src/store/tool/slices/store/index.ts +3 -0
- package/src/store/tool/slices/store/initialState.ts +17 -0
- package/src/store/tool/slices/store/selectors.test.ts +50 -0
- package/src/store/tool/slices/store/selectors.ts +32 -0
- package/src/store/tool/store.ts +32 -0
- package/src/store/user/helpers.ts +9 -0
- package/src/store/user/index.ts +1 -0
- package/src/store/user/initialState.ts +22 -0
- package/src/store/user/selectors.ts +13 -0
- package/src/store/user/slices/auth/action.test.ts +202 -0
- package/src/store/user/slices/auth/action.ts +63 -0
- package/src/store/user/slices/auth/initialState.ts +28 -0
- package/src/store/user/slices/auth/selectors.test.ts +143 -0
- package/src/store/user/slices/auth/selectors.ts +48 -0
- package/src/store/user/slices/common/action.test.ts +271 -0
- package/src/store/user/slices/common/action.ts +129 -0
- package/src/store/user/slices/common/initialState.ts +15 -0
- package/src/store/user/slices/modelList/action.test.ts +363 -0
- package/src/store/user/slices/modelList/action.ts +209 -0
- package/src/store/user/slices/modelList/initialState.ts +15 -0
- package/src/store/user/slices/modelList/reducers/customModelCard.test.ts +204 -0
- package/src/store/user/slices/modelList/reducers/customModelCard.ts +64 -0
- package/src/store/user/slices/modelList/selectors/index.ts +3 -0
- package/src/store/user/slices/modelList/selectors/keyVaults.test.ts +201 -0
- package/src/store/user/slices/modelList/selectors/keyVaults.ts +45 -0
- package/src/store/user/slices/modelList/selectors/modelConfig.test.ts +179 -0
- package/src/store/user/slices/modelList/selectors/modelConfig.ts +80 -0
- package/src/store/user/slices/modelList/selectors/modelProvider.test.ts +145 -0
- package/src/store/user/slices/modelList/selectors/modelProvider.ts +147 -0
- package/src/store/user/slices/preference/action.test.ts +43 -0
- package/src/store/user/slices/preference/action.ts +35 -0
- package/src/store/user/slices/preference/initialState.ts +13 -0
- package/src/store/user/slices/preference/selectors.test.ts +82 -0
- package/src/store/user/slices/preference/selectors.ts +19 -0
- package/src/store/user/slices/settings/action.test.ts +153 -0
- package/src/store/user/slices/settings/action.ts +109 -0
- package/src/store/user/slices/settings/initialState.ts +15 -0
- package/src/store/user/slices/settings/selectors/__snapshots__/settings.test.ts.snap +109 -0
- package/src/store/user/slices/settings/selectors/general.test.ts +45 -0
- package/src/store/user/slices/settings/selectors/general.ts +40 -0
- package/src/store/user/slices/settings/selectors/index.ts +3 -0
- package/src/store/user/slices/settings/selectors/settings.test.ts +156 -0
- package/src/store/user/slices/settings/selectors/settings.ts +52 -0
- package/src/store/user/slices/settings/selectors/systemAgent.ts +16 -0
- package/src/store/user/slices/sync/action.test.ts +164 -0
- package/src/store/user/slices/sync/action.ts +97 -0
- package/src/store/user/slices/sync/initialState.ts +13 -0
- package/src/store/user/slices/sync/selectors.ts +20 -0
- package/src/store/user/store.ts +42 -0
- package/src/styles/antdOverride.ts +9 -20
- package/src/styles/global.ts +39 -14
- package/src/styles/index.ts +6 -1
- package/src/styles/mobileHeader.ts +15 -0
- package/src/tools/dalle/Render/Item/EditMode.tsx +66 -0
- package/src/tools/dalle/Render/Item/Error.tsx +50 -0
- package/src/tools/dalle/Render/Item/Image.tsx +44 -0
- package/src/tools/dalle/Render/Item/ImageFileItem.tsx +77 -0
- package/src/tools/dalle/Render/Item/index.tsx +88 -0
- package/src/tools/dalle/Render/ToolBar.tsx +55 -0
- package/src/tools/dalle/Render/index.tsx +51 -0
- package/src/tools/dalle/index.ts +92 -0
- package/src/tools/index.ts +11 -0
- package/src/tools/renders.ts +14 -0
- package/src/types/agent/index.ts +83 -0
- package/src/types/exportConfig.ts +121 -14
- package/src/types/fetch.ts +36 -0
- package/src/types/files.ts +42 -0
- package/src/types/i18next.d.ts +1 -1
- package/src/types/importer.ts +128 -0
- package/src/types/llm.ts +70 -12
- package/src/types/locale.ts +4 -6
- package/src/types/market.ts +20 -0
- package/src/types/message/index.ts +82 -0
- package/src/types/message/tools.ts +65 -0
- package/src/types/message/translate.ts +4 -0
- package/src/types/meta.ts +24 -12
- package/src/types/next-auth.d.ts +23 -0
- package/src/types/openai/chat.ts +128 -0
- package/src/types/openai/functionCall.ts +10 -0
- package/src/types/openai/image.ts +34 -0
- package/src/types/openai/plugin.ts +57 -0
- package/src/types/serverConfig.ts +32 -0
- package/src/types/service.ts +7 -0
- package/src/types/session/agentSession.ts +35 -0
- package/src/types/session/index.ts +10 -0
- package/src/types/session/sessionGroup.ts +24 -0
- package/src/types/share.ts +7 -0
- package/src/types/sync.ts +41 -0
- package/src/types/tool/builtin.ts +36 -0
- package/src/types/tool/dalle.ts +12 -0
- package/src/types/tool/index.ts +16 -0
- package/src/types/tool/plugin.ts +35 -0
- package/src/types/tool/tool.ts +10 -0
- package/src/types/topic.ts +9 -0
- package/src/types/trace/action.ts +31 -0
- package/src/types/trace/index.ts +1 -0
- package/src/types/user/index.ts +44 -0
- package/src/types/user/settings/general.ts +12 -0
- package/src/types/user/settings/index.ts +32 -0
- package/src/types/user/settings/keyVaults.ts +37 -0
- package/src/types/user/settings/modelProvider.ts +34 -0
- package/src/types/user/settings/sync.ts +10 -0
- package/src/types/user/settings/systemAgent.ts +9 -0
- package/src/types/user/settings/tool.ts +5 -0
- package/src/types/user/settings/tts.ts +10 -0
- package/src/utils/__snapshots__/parseModels.test.ts.snap +63 -0
- package/src/utils/basePath.ts +3 -0
- package/src/utils/client/switchLang.test.ts +34 -0
- package/src/utils/client/switchLang.ts +10 -0
- package/src/utils/compass.ts +1 -5
- package/src/utils/compressImage.test.ts +59 -0
- package/src/utils/compressImage.ts +29 -0
- package/src/utils/config.ts +108 -0
- package/src/utils/cookie.ts +10 -0
- package/src/utils/difference.test.ts +46 -0
- package/src/utils/difference.ts +26 -0
- package/src/utils/env.ts +3 -0
- package/src/utils/fetch.test.ts +534 -0
- package/src/utils/fetch.ts +371 -105
- package/src/utils/filter.ts +1 -1
- package/src/utils/genOG.ts +20 -0
- package/src/utils/imageToBase64.ts +37 -0
- package/src/utils/jwt.test.ts +27 -0
- package/src/utils/jwt.ts +37 -0
- package/src/utils/keyboard.ts +13 -0
- package/src/utils/localStorage.ts +38 -0
- package/src/utils/locale.ts +16 -0
- package/src/utils/merge.ts +11 -0
- package/src/utils/parseMarkdown.ts +9 -0
- package/src/utils/parseModels.test.ts +290 -0
- package/src/utils/parseModels.ts +156 -0
- package/src/utils/platform.test.ts +83 -0
- package/src/utils/platform.ts +55 -0
- package/src/utils/responsive.ts +40 -0
- package/src/utils/speed.ts +32 -0
- package/src/utils/storeDebug.ts +11 -0
- package/src/utils/tokenizer.ts +5 -0
- package/src/utils/toolCall.ts +21 -0
- package/src/utils/trace.ts +21 -0
- package/src/utils/url.test.ts +51 -0
- package/src/utils/url.ts +23 -0
- package/src/utils/uuid.ts +4 -4
- package/src/utils/zustand.ts +8 -0
- package/tests/setup-db.ts +7 -0
- package/tests/setup.ts +35 -0
- package/tests/utils.tsx +11 -0
- package/tsconfig.json +24 -4
- package/vercel.json +3 -0
- package/vitest.config.ts +27 -3
- package/vitest.server.config.ts +23 -0
- package/.github/ISSUE_TEMPLATE/3_question.yml +0 -15
- package/.github/ISSUE_TEMPLATE/4_other.md +0 -7
- package/.github/dependabot.yml +0 -17
- package/.github/workflows/auto-merge.yml +0 -32
- package/.github/workflows/contributor-help.yml +0 -29
- package/.github/workflows/issue-check-inactive.yml +0 -22
- package/.github/workflows/issue-remove-inactive.yml +0 -25
- package/.gitpod.yml +0 -3
- package/.husky/commit-msg +0 -4
- package/locales/en_US/common.json +0 -40
- package/locales/en_US/setting.json +0 -97
- package/locales/zh_CN/common.json +0 -40
- package/locales/zh_CN/setting.json +0 -98
- package/public/next.svg +0 -1
- package/public/vercel.svg +0 -1
- package/scripts/genDefaultLocale.mjs +0 -12
- package/scripts/toc.mjs +0 -40
- package/src/const/modelTokens.ts +0 -8
- package/src/features/FolderPanel/index.tsx +0 -55
- package/src/helpers/prompt.test.ts +0 -36
- package/src/helpers/prompt.ts +0 -36
- package/src/layout/index.tsx +0 -42
- package/src/layout/style.ts +0 -18
- package/src/locales/index.ts +0 -5
- package/src/locales/resources/en_US.ts +0 -9
- package/src/locales/resources/index.ts +0 -7
- package/src/locales/resources/zh_CN.ts +0 -9
- package/src/pages/Sidebar.tsx +0 -36
- package/src/pages/_app.page.tsx +0 -13
- package/src/pages/_document.page.tsx +0 -70
- package/src/pages/api/LangChainStream.ts +0 -95
- package/src/pages/api/chain.api.ts +0 -17
- package/src/pages/api/openai.api.ts +0 -31
- package/src/pages/chat/SessionList/Header.tsx +0 -56
- package/src/pages/chat/SessionList/List/SessionItem.tsx +0 -90
- package/src/pages/chat/SessionList/List/index.tsx +0 -31
- package/src/pages/chat/SessionList/List/style.ts +0 -77
- package/src/pages/chat/SessionList/index.tsx +0 -18
- package/src/pages/chat/[id]/Config/ConfigCell.tsx +0 -68
- package/src/pages/chat/[id]/Config/ReadMode.tsx +0 -63
- package/src/pages/chat/[id]/Config/index.tsx +0 -79
- package/src/pages/chat/[id]/Conversation/ChatList.tsx +0 -36
- package/src/pages/chat/[id]/Conversation/Input.tsx +0 -61
- package/src/pages/chat/[id]/Conversation/index.tsx +0 -32
- package/src/pages/chat/[id]/Header.tsx +0 -86
- package/src/pages/chat/[id]/edit/AgentConfig.tsx +0 -95
- package/src/pages/chat/[id]/edit/AgentMeta.tsx +0 -117
- package/src/pages/chat/[id]/edit/FormItem.tsx +0 -26
- package/src/pages/chat/[id]/edit/Prompt.tsx +0 -68
- package/src/pages/chat/[id]/edit/index.page.tsx +0 -62
- package/src/pages/chat/[id]/edit/style.ts +0 -42
- package/src/pages/chat/[id]/index.page.tsx +0 -40
- package/src/pages/chat/index.page.tsx +0 -1
- package/src/pages/chat/layout.tsx +0 -51
- package/src/pages/index.page.tsx +0 -1
- package/src/pages/setting/Header.tsx +0 -27
- package/src/pages/setting/SettingForm.tsx +0 -42
- package/src/pages/setting/index.page.tsx +0 -41
- package/src/prompts/agent.ts +0 -65
- package/src/services/chatModel.ts +0 -34
- package/src/services/langChain.ts +0 -18
- package/src/services/url.ts +0 -8
- package/src/store/middleware/createHashStorage.ts +0 -49
- package/src/store/session/slices/agentConfig/action.ts +0 -226
- package/src/store/session/slices/agentConfig/initialState.ts +0 -34
- package/src/store/session/slices/agentConfig/selectors.ts +0 -54
- package/src/store/session/slices/chat/action.ts +0 -210
- package/src/store/session/slices/chat/initialState.ts +0 -12
- package/src/store/session/slices/chat/messageReducer.test.ts +0 -70
- package/src/store/session/slices/chat/messageReducer.ts +0 -84
- package/src/store/session/slices/chat/selectors.ts +0 -83
- package/src/store/session/slices/session/reducers/session.test.ts +0 -456
- package/src/store/session/slices/session/reducers/session.ts +0 -113
- package/src/store/session/slices/session/selectors/chat.ts +0 -4
- package/src/store/settings/action.ts +0 -31
- package/src/store/settings/index.ts +0 -23
- package/src/store/settings/initialState.ts +0 -25
- package/src/store/settings/selectors.ts +0 -9
- package/src/store/settings/store.ts +0 -13
- package/src/types/chatMessage.ts +0 -46
- package/src/types/langchain.ts +0 -34
- package/src/types/openai.ts +0 -62
- package/src/types/session.ts +0 -59
- /package/src/store/{session/slices/agentConfig → file/slices/images}/index.ts +0 -0
@@ -0,0 +1,1243 @@
|
|
1
|
+
import * as lobeUIModules from '@lobehub/ui';
|
2
|
+
import { act, renderHook, waitFor } from '@testing-library/react';
|
3
|
+
import useSWR, { mutate } from 'swr';
|
4
|
+
import { Mock, afterEach, beforeEach, describe, expect, it, vi } from 'vitest';
|
5
|
+
|
6
|
+
import { LOADING_FLAT } from '@/const/message';
|
7
|
+
import { DEFAULT_AGENT_CHAT_CONFIG, DEFAULT_AGENT_CONFIG } from '@/const/settings';
|
8
|
+
import { TraceEventType } from '@/const/trace';
|
9
|
+
import { chatService } from '@/services/chat';
|
10
|
+
import { messageService } from '@/services/message';
|
11
|
+
import { topicService } from '@/services/topic';
|
12
|
+
import { useAgentStore } from '@/store/agent';
|
13
|
+
import { agentSelectors } from '@/store/agent/selectors';
|
14
|
+
import { chatSelectors } from '@/store/chat/selectors';
|
15
|
+
import { messageMapKey } from '@/store/chat/slices/message/utils';
|
16
|
+
import { sessionMetaSelectors } from '@/store/session/selectors';
|
17
|
+
import { ChatMessage } from '@/types/message';
|
18
|
+
|
19
|
+
import { useChatStore } from '../../store';
|
20
|
+
|
21
|
+
vi.stubGlobal(
|
22
|
+
'fetch',
|
23
|
+
vi.fn(() => Promise.resolve(new Response('mock'))),
|
24
|
+
);
|
25
|
+
|
26
|
+
vi.mock('zustand/traditional');
|
27
|
+
// Mock service
|
28
|
+
vi.mock('@/services/message', () => ({
|
29
|
+
messageService: {
|
30
|
+
getMessages: vi.fn(),
|
31
|
+
updateMessageError: vi.fn(),
|
32
|
+
removeMessage: vi.fn(),
|
33
|
+
removeMessages: vi.fn(() => Promise.resolve()),
|
34
|
+
createMessage: vi.fn(() => Promise.resolve('new-message-id')),
|
35
|
+
updateMessage: vi.fn(),
|
36
|
+
removeAllMessages: vi.fn(() => Promise.resolve()),
|
37
|
+
},
|
38
|
+
}));
|
39
|
+
vi.mock('@/services/topic', () => ({
|
40
|
+
topicService: {
|
41
|
+
createTopic: vi.fn(() => Promise.resolve()),
|
42
|
+
removeTopic: vi.fn(() => Promise.resolve()),
|
43
|
+
},
|
44
|
+
}));
|
45
|
+
vi.mock('@/services/chat', async (importOriginal) => {
|
46
|
+
const module = await importOriginal();
|
47
|
+
|
48
|
+
return {
|
49
|
+
chatService: {
|
50
|
+
createAssistantMessage: vi.fn(() => Promise.resolve('assistant-message')),
|
51
|
+
createAssistantMessageStream: (module as any).chatService.createAssistantMessageStream,
|
52
|
+
},
|
53
|
+
};
|
54
|
+
});
|
55
|
+
|
56
|
+
const realCoreProcessMessage = useChatStore.getState().internal_coreProcessMessage;
|
57
|
+
const realRefreshMessages = useChatStore.getState().refreshMessages;
|
58
|
+
// Mock state
|
59
|
+
const mockState = {
|
60
|
+
activeId: 'session-id',
|
61
|
+
activeTopicId: 'topic-id',
|
62
|
+
messages: [],
|
63
|
+
refreshMessages: vi.fn(),
|
64
|
+
refreshTopic: vi.fn(),
|
65
|
+
internal_coreProcessMessage: vi.fn(),
|
66
|
+
saveToTopic: vi.fn(),
|
67
|
+
};
|
68
|
+
|
69
|
+
beforeEach(() => {
|
70
|
+
vi.clearAllMocks();
|
71
|
+
useChatStore.setState(mockState, false);
|
72
|
+
vi.spyOn(agentSelectors, 'currentAgentConfig').mockImplementation(() => DEFAULT_AGENT_CONFIG);
|
73
|
+
vi.spyOn(agentSelectors, 'currentAgentChatConfig').mockImplementation(
|
74
|
+
() => DEFAULT_AGENT_CHAT_CONFIG,
|
75
|
+
);
|
76
|
+
vi.spyOn(sessionMetaSelectors, 'currentAgentMeta').mockImplementation(() => ({ tags: [] }));
|
77
|
+
});
|
78
|
+
|
79
|
+
afterEach(() => {
|
80
|
+
process.env.NEXT_PUBLIC_BASE_PATH = undefined;
|
81
|
+
|
82
|
+
vi.restoreAllMocks();
|
83
|
+
});
|
84
|
+
|
85
|
+
describe('chatMessage actions', () => {
|
86
|
+
describe('addAIMessage', () => {
|
87
|
+
it('should return early if activeId is undefined', async () => {
|
88
|
+
useChatStore.setState({ activeId: undefined });
|
89
|
+
const { result } = renderHook(() => useChatStore());
|
90
|
+
const updateInputMessageSpy = vi.spyOn(result.current, 'updateInputMessage');
|
91
|
+
|
92
|
+
await act(async () => {
|
93
|
+
await result.current.addAIMessage();
|
94
|
+
});
|
95
|
+
|
96
|
+
expect(messageService.createMessage).not.toHaveBeenCalled();
|
97
|
+
expect(updateInputMessageSpy).not.toHaveBeenCalled();
|
98
|
+
});
|
99
|
+
|
100
|
+
it('should call internal_createMessage with correct parameters', async () => {
|
101
|
+
const inputMessage = 'Test input message';
|
102
|
+
useChatStore.setState({ inputMessage });
|
103
|
+
const { result } = renderHook(() => useChatStore());
|
104
|
+
|
105
|
+
await act(async () => {
|
106
|
+
await result.current.addAIMessage();
|
107
|
+
});
|
108
|
+
|
109
|
+
expect(messageService.createMessage).toHaveBeenCalledWith({
|
110
|
+
content: inputMessage,
|
111
|
+
role: 'assistant',
|
112
|
+
sessionId: mockState.activeId,
|
113
|
+
topicId: mockState.activeTopicId,
|
114
|
+
});
|
115
|
+
});
|
116
|
+
|
117
|
+
it('should call updateInputMessage with empty string', async () => {
|
118
|
+
const { result } = renderHook(() => useChatStore());
|
119
|
+
const updateInputMessageSpy = vi.spyOn(result.current, 'updateInputMessage');
|
120
|
+
await act(async () => {
|
121
|
+
await result.current.addAIMessage();
|
122
|
+
});
|
123
|
+
|
124
|
+
expect(updateInputMessageSpy).toHaveBeenCalledWith('');
|
125
|
+
});
|
126
|
+
});
|
127
|
+
|
128
|
+
describe('deleteMessage', () => {
|
129
|
+
it('deleteMessage should remove a message by id', async () => {
|
130
|
+
const { result } = renderHook(() => useChatStore());
|
131
|
+
const messageId = 'message-id';
|
132
|
+
const deleteSpy = vi.spyOn(result.current, 'deleteMessage');
|
133
|
+
|
134
|
+
act(() => {
|
135
|
+
useChatStore.setState({
|
136
|
+
activeId: 'session-id',
|
137
|
+
activeTopicId: undefined,
|
138
|
+
messagesMap: {
|
139
|
+
[messageMapKey('session-id')]: [{ id: messageId } as ChatMessage],
|
140
|
+
},
|
141
|
+
});
|
142
|
+
});
|
143
|
+
await act(async () => {
|
144
|
+
await result.current.deleteMessage(messageId);
|
145
|
+
});
|
146
|
+
|
147
|
+
expect(deleteSpy).toHaveBeenCalledWith(messageId);
|
148
|
+
expect(result.current.refreshMessages).toHaveBeenCalled();
|
149
|
+
});
|
150
|
+
});
|
151
|
+
|
152
|
+
describe('clearAllMessages', () => {
|
153
|
+
it('clearAllMessages should remove all messages', async () => {
|
154
|
+
const { result } = renderHook(() => useChatStore());
|
155
|
+
const clearAllSpy = vi.spyOn(result.current, 'clearAllMessages');
|
156
|
+
|
157
|
+
await act(async () => {
|
158
|
+
await result.current.clearAllMessages();
|
159
|
+
});
|
160
|
+
|
161
|
+
expect(clearAllSpy).toHaveBeenCalled();
|
162
|
+
expect(result.current.refreshMessages).toHaveBeenCalled();
|
163
|
+
});
|
164
|
+
});
|
165
|
+
|
166
|
+
describe('updateInputMessage', () => {
|
167
|
+
it('updateInputMessage should update the input message state', () => {
|
168
|
+
const { result } = renderHook(() => useChatStore());
|
169
|
+
const newInputMessage = 'Updated message';
|
170
|
+
act(() => {
|
171
|
+
result.current.updateInputMessage(newInputMessage);
|
172
|
+
});
|
173
|
+
|
174
|
+
expect(result.current.inputMessage).toEqual(newInputMessage);
|
175
|
+
});
|
176
|
+
});
|
177
|
+
|
178
|
+
describe('copyMessage', () => {
|
179
|
+
it('should call copyToClipboard with correct content', async () => {
|
180
|
+
const messageId = 'message-id';
|
181
|
+
const content = 'Test content';
|
182
|
+
const { result } = renderHook(() => useChatStore());
|
183
|
+
const copyToClipboardSpy = vi.spyOn(lobeUIModules, 'copyToClipboard');
|
184
|
+
|
185
|
+
await act(async () => {
|
186
|
+
await result.current.copyMessage(messageId, content);
|
187
|
+
});
|
188
|
+
|
189
|
+
expect(copyToClipboardSpy).toHaveBeenCalledWith(content);
|
190
|
+
});
|
191
|
+
|
192
|
+
it('should call internal_traceMessage with correct parameters', async () => {
|
193
|
+
const messageId = 'message-id';
|
194
|
+
const content = 'Test content';
|
195
|
+
const { result } = renderHook(() => useChatStore());
|
196
|
+
const internal_traceMessageSpy = vi.spyOn(result.current, 'internal_traceMessage');
|
197
|
+
|
198
|
+
await act(async () => {
|
199
|
+
await result.current.copyMessage(messageId, content);
|
200
|
+
});
|
201
|
+
|
202
|
+
expect(internal_traceMessageSpy).toHaveBeenCalledWith(messageId, {
|
203
|
+
eventType: TraceEventType.CopyMessage,
|
204
|
+
});
|
205
|
+
});
|
206
|
+
});
|
207
|
+
|
208
|
+
describe('clearMessage', () => {
|
209
|
+
beforeEach(() => {
|
210
|
+
vi.clearAllMocks(); // 清除 mocks
|
211
|
+
useChatStore.setState(mockState, false); // 重置 state
|
212
|
+
});
|
213
|
+
|
214
|
+
afterEach(() => {
|
215
|
+
vi.restoreAllMocks(); // 恢复所有模拟
|
216
|
+
});
|
217
|
+
it('clearMessage should remove messages from the active session and topic', async () => {
|
218
|
+
const { result } = renderHook(() => useChatStore());
|
219
|
+
const clearSpy = vi.spyOn(result.current, 'clearMessage');
|
220
|
+
const switchTopicSpy = vi.spyOn(result.current, 'switchTopic');
|
221
|
+
|
222
|
+
await act(async () => {
|
223
|
+
await result.current.clearMessage();
|
224
|
+
});
|
225
|
+
|
226
|
+
expect(clearSpy).toHaveBeenCalled();
|
227
|
+
expect(result.current.refreshMessages).toHaveBeenCalled();
|
228
|
+
expect(result.current.refreshTopic).toHaveBeenCalled();
|
229
|
+
expect(switchTopicSpy).toHaveBeenCalled();
|
230
|
+
});
|
231
|
+
|
232
|
+
it('should remove messages from the active session and topic, then refresh topics and messages', async () => {
|
233
|
+
const { result } = renderHook(() => useChatStore());
|
234
|
+
const switchTopicSpy = vi.spyOn(result.current, 'switchTopic');
|
235
|
+
const refreshTopicSpy = vi.spyOn(result.current, 'refreshTopic');
|
236
|
+
|
237
|
+
await act(async () => {
|
238
|
+
await result.current.clearMessage();
|
239
|
+
});
|
240
|
+
|
241
|
+
expect(mockState.refreshMessages).toHaveBeenCalled();
|
242
|
+
expect(refreshTopicSpy).toHaveBeenCalled();
|
243
|
+
expect(switchTopicSpy).toHaveBeenCalled();
|
244
|
+
|
245
|
+
// 检查 activeTopicId 是否被清除,需要在状态更新后进行检查
|
246
|
+
expect(useChatStore.getState().activeTopicId).toBeNull();
|
247
|
+
});
|
248
|
+
|
249
|
+
it('should call removeTopic if there is an activeTopicId', async () => {
|
250
|
+
const { result } = renderHook(() => useChatStore());
|
251
|
+
const switchTopicSpy = vi.spyOn(result.current, 'switchTopic');
|
252
|
+
const refreshTopicSpy = vi.spyOn(result.current, 'refreshTopic');
|
253
|
+
|
254
|
+
await act(async () => {
|
255
|
+
await result.current.clearMessage();
|
256
|
+
});
|
257
|
+
|
258
|
+
expect(mockState.activeTopicId).not.toBeUndefined(); // 确保在测试前 activeTopicId 存在
|
259
|
+
expect(refreshTopicSpy).toHaveBeenCalled();
|
260
|
+
expect(mockState.refreshMessages).toHaveBeenCalled();
|
261
|
+
expect(topicService.removeTopic).toHaveBeenCalledWith(mockState.activeTopicId);
|
262
|
+
expect(switchTopicSpy).toHaveBeenCalled();
|
263
|
+
});
|
264
|
+
});
|
265
|
+
|
266
|
+
describe('sendMessage', () => {
|
267
|
+
it('should not send message if there is no active session', async () => {
|
268
|
+
useChatStore.setState({ activeId: undefined });
|
269
|
+
const { result } = renderHook(() => useChatStore());
|
270
|
+
const message = 'Test message';
|
271
|
+
|
272
|
+
await act(async () => {
|
273
|
+
await result.current.sendMessage({ message });
|
274
|
+
});
|
275
|
+
|
276
|
+
expect(messageService.createMessage).not.toHaveBeenCalled();
|
277
|
+
expect(result.current.refreshMessages).not.toHaveBeenCalled();
|
278
|
+
expect(result.current.internal_coreProcessMessage).not.toHaveBeenCalled();
|
279
|
+
});
|
280
|
+
|
281
|
+
it('should not send message if message is empty and there are no files', async () => {
|
282
|
+
const { result } = renderHook(() => useChatStore());
|
283
|
+
const message = '';
|
284
|
+
|
285
|
+
await act(async () => {
|
286
|
+
await result.current.sendMessage({ message });
|
287
|
+
});
|
288
|
+
|
289
|
+
expect(messageService.createMessage).not.toHaveBeenCalled();
|
290
|
+
expect(result.current.refreshMessages).not.toHaveBeenCalled();
|
291
|
+
expect(result.current.internal_coreProcessMessage).not.toHaveBeenCalled();
|
292
|
+
});
|
293
|
+
|
294
|
+
it('should not send message if message is empty and there are empty files', async () => {
|
295
|
+
const { result } = renderHook(() => useChatStore());
|
296
|
+
const message = '';
|
297
|
+
|
298
|
+
await act(async () => {
|
299
|
+
await result.current.sendMessage({ message, files: [] });
|
300
|
+
});
|
301
|
+
|
302
|
+
expect(messageService.createMessage).not.toHaveBeenCalled();
|
303
|
+
expect(result.current.refreshMessages).not.toHaveBeenCalled();
|
304
|
+
expect(result.current.internal_coreProcessMessage).not.toHaveBeenCalled();
|
305
|
+
});
|
306
|
+
|
307
|
+
it('should create message and call internal_coreProcessMessage if message or files are provided', async () => {
|
308
|
+
const { result } = renderHook(() => useChatStore());
|
309
|
+
const message = 'Test message';
|
310
|
+
const files = [{ id: 'file-id', url: 'file-url' }];
|
311
|
+
|
312
|
+
// Mock messageService.create to resolve with a message id
|
313
|
+
(messageService.createMessage as Mock).mockResolvedValue('new-message-id');
|
314
|
+
|
315
|
+
await act(async () => {
|
316
|
+
await result.current.sendMessage({ message, files });
|
317
|
+
});
|
318
|
+
|
319
|
+
expect(messageService.createMessage).toHaveBeenCalledWith({
|
320
|
+
content: message,
|
321
|
+
files: files.map((f) => f.id),
|
322
|
+
role: 'user',
|
323
|
+
sessionId: mockState.activeId,
|
324
|
+
topicId: mockState.activeTopicId,
|
325
|
+
});
|
326
|
+
expect(result.current.internal_coreProcessMessage).toHaveBeenCalled();
|
327
|
+
});
|
328
|
+
|
329
|
+
describe('auto-create topic', () => {
|
330
|
+
it('should not auto-create topic if enableAutoCreateTopic is false', async () => {
|
331
|
+
const { result } = renderHook(() => useChatStore());
|
332
|
+
const message = 'Test message';
|
333
|
+
const autoCreateTopicThreshold = 5;
|
334
|
+
const enableAutoCreateTopic = false;
|
335
|
+
|
336
|
+
// Mock messageService.create to resolve with a message id
|
337
|
+
(messageService.createMessage as Mock).mockResolvedValue('new-message-id');
|
338
|
+
|
339
|
+
// Mock agent config to simulate auto-create topic behavior
|
340
|
+
(agentSelectors.currentAgentConfig as Mock).mockImplementation(() => ({
|
341
|
+
autoCreateTopicThreshold,
|
342
|
+
enableAutoCreateTopic,
|
343
|
+
}));
|
344
|
+
|
345
|
+
// Mock saveToTopic and switchTopic to simulate not being called
|
346
|
+
const saveToTopicMock = vi.fn();
|
347
|
+
const switchTopicMock = vi.fn();
|
348
|
+
|
349
|
+
await act(async () => {
|
350
|
+
useChatStore.setState({
|
351
|
+
...mockState,
|
352
|
+
// Mock the currentChats selector to return a list that does not reach the threshold
|
353
|
+
messagesMap: {
|
354
|
+
[messageMapKey('session-id')]: Array.from(
|
355
|
+
{ length: autoCreateTopicThreshold + 1 },
|
356
|
+
(_, i) => ({
|
357
|
+
id: `msg-${i}`,
|
358
|
+
}),
|
359
|
+
) as any,
|
360
|
+
},
|
361
|
+
activeTopicId: undefined,
|
362
|
+
saveToTopic: saveToTopicMock,
|
363
|
+
switchTopic: switchTopicMock,
|
364
|
+
});
|
365
|
+
|
366
|
+
await result.current.sendMessage({ message });
|
367
|
+
});
|
368
|
+
|
369
|
+
expect(saveToTopicMock).not.toHaveBeenCalled();
|
370
|
+
expect(switchTopicMock).not.toHaveBeenCalled();
|
371
|
+
});
|
372
|
+
|
373
|
+
it('should auto-create topic and switch to it if enabled and threshold is reached', async () => {
|
374
|
+
const { result } = renderHook(() => useChatStore());
|
375
|
+
const message = 'Test message';
|
376
|
+
const autoCreateTopicThreshold = 5;
|
377
|
+
const enableAutoCreateTopic = true;
|
378
|
+
|
379
|
+
// Mock agent config to simulate auto-create topic behavior
|
380
|
+
(agentSelectors.currentAgentConfig as Mock).mockImplementation(() => ({
|
381
|
+
autoCreateTopicThreshold,
|
382
|
+
enableAutoCreateTopic,
|
383
|
+
}));
|
384
|
+
|
385
|
+
// Mock messageService.create to resolve with a message id
|
386
|
+
(messageService.createMessage as Mock).mockResolvedValue('new-message-id');
|
387
|
+
|
388
|
+
// Mock saveToTopic to resolve with a topic id and switchTopic to switch to the new topic
|
389
|
+
const createTopicMock = vi.fn(() => Promise.resolve('new-topic-id'));
|
390
|
+
const switchTopicMock = vi.fn();
|
391
|
+
|
392
|
+
act(() => {
|
393
|
+
useChatStore.setState({
|
394
|
+
...mockState,
|
395
|
+
activeId: 'session_id',
|
396
|
+
messagesMap: {
|
397
|
+
[messageMapKey('session_id')]: Array.from(
|
398
|
+
{ length: autoCreateTopicThreshold },
|
399
|
+
(_, i) => ({
|
400
|
+
id: `msg-${i}`,
|
401
|
+
}),
|
402
|
+
) as any,
|
403
|
+
},
|
404
|
+
activeTopicId: undefined,
|
405
|
+
createTopic: createTopicMock,
|
406
|
+
switchTopic: switchTopicMock,
|
407
|
+
});
|
408
|
+
});
|
409
|
+
|
410
|
+
await act(async () => {
|
411
|
+
await result.current.sendMessage({ message });
|
412
|
+
});
|
413
|
+
|
414
|
+
expect(createTopicMock).toHaveBeenCalled();
|
415
|
+
expect(switchTopicMock).toHaveBeenCalledWith('new-topic-id', true);
|
416
|
+
});
|
417
|
+
|
418
|
+
it('should not auto-create topic, if autoCreateTopic = false and reached topic threshold', async () => {
|
419
|
+
const { result } = renderHook(() => useChatStore());
|
420
|
+
act(() => {
|
421
|
+
useAgentStore.setState({
|
422
|
+
activeId: 'abc',
|
423
|
+
agentMap: {
|
424
|
+
abc: {
|
425
|
+
chatConfig: {
|
426
|
+
enableAutoCreateTopic: false,
|
427
|
+
autoCreateTopicThreshold: 1,
|
428
|
+
},
|
429
|
+
},
|
430
|
+
},
|
431
|
+
});
|
432
|
+
|
433
|
+
useChatStore.setState({
|
434
|
+
// Mock the currentChats selector to return a list that does not reach the threshold
|
435
|
+
messagesMap: {
|
436
|
+
[messageMapKey('inbox')]: [{ id: '1' }, { id: '2' }] as ChatMessage[],
|
437
|
+
},
|
438
|
+
activeTopicId: 'inbox',
|
439
|
+
});
|
440
|
+
});
|
441
|
+
|
442
|
+
await act(async () => {
|
443
|
+
await result.current.sendMessage({ message: 'test' });
|
444
|
+
});
|
445
|
+
|
446
|
+
expect(topicService.createTopic).not.toHaveBeenCalled();
|
447
|
+
});
|
448
|
+
|
449
|
+
it('should not auto-create topic if autoCreateTopicThreshold is not reached', async () => {
|
450
|
+
const { result } = renderHook(() => useChatStore());
|
451
|
+
const message = 'Test message';
|
452
|
+
const autoCreateTopicThreshold = 5;
|
453
|
+
const enableAutoCreateTopic = true;
|
454
|
+
|
455
|
+
// Mock messageService.create to resolve with a message id
|
456
|
+
(messageService.createMessage as Mock).mockResolvedValue('new-message-id');
|
457
|
+
|
458
|
+
// Mock agent config to simulate auto-create topic behavior
|
459
|
+
(agentSelectors.currentAgentChatConfig as Mock).mockImplementation(() => ({
|
460
|
+
autoCreateTopicThreshold,
|
461
|
+
enableAutoCreateTopic,
|
462
|
+
}));
|
463
|
+
|
464
|
+
// Mock saveToTopic and switchTopic to simulate not being called
|
465
|
+
const createTopicMock = vi.fn();
|
466
|
+
const switchTopicMock = vi.fn();
|
467
|
+
|
468
|
+
await act(async () => {
|
469
|
+
useChatStore.setState({
|
470
|
+
...mockState,
|
471
|
+
activeId: 'session_id',
|
472
|
+
messagesMap: {
|
473
|
+
// Mock the currentChats selector to return a list that does not reach the threshold
|
474
|
+
[messageMapKey('session_id')]: Array.from(
|
475
|
+
{ length: autoCreateTopicThreshold - 3 },
|
476
|
+
(_, i) => ({
|
477
|
+
id: `msg-${i}`,
|
478
|
+
}),
|
479
|
+
) as any,
|
480
|
+
},
|
481
|
+
activeTopicId: undefined,
|
482
|
+
createTopic: createTopicMock,
|
483
|
+
switchTopic: switchTopicMock,
|
484
|
+
});
|
485
|
+
|
486
|
+
await result.current.sendMessage({ message });
|
487
|
+
});
|
488
|
+
|
489
|
+
expect(createTopicMock).not.toHaveBeenCalled();
|
490
|
+
expect(switchTopicMock).not.toHaveBeenCalled();
|
491
|
+
});
|
492
|
+
});
|
493
|
+
|
494
|
+
it('should add user message and not call internal_coreProcessMessage if onlyAddUserMessage = true', async () => {
|
495
|
+
const { result } = renderHook(() => useChatStore());
|
496
|
+
|
497
|
+
await act(async () => {
|
498
|
+
await result.current.sendMessage({ message: 'test', onlyAddUserMessage: true });
|
499
|
+
});
|
500
|
+
|
501
|
+
expect(messageService.createMessage).toHaveBeenCalled();
|
502
|
+
expect(result.current.internal_coreProcessMessage).not.toHaveBeenCalled();
|
503
|
+
});
|
504
|
+
|
505
|
+
it('当 isWelcomeQuestion 为 true 时,正确地传递给 internal_coreProcessMessage', async () => {
|
506
|
+
const { result } = renderHook(() => useChatStore());
|
507
|
+
|
508
|
+
await act(async () => {
|
509
|
+
await result.current.sendMessage({ message: 'test', isWelcomeQuestion: true });
|
510
|
+
});
|
511
|
+
|
512
|
+
expect(result.current.internal_coreProcessMessage).toHaveBeenCalledWith(
|
513
|
+
expect.anything(),
|
514
|
+
expect.anything(),
|
515
|
+
{ isWelcomeQuestion: true },
|
516
|
+
);
|
517
|
+
});
|
518
|
+
|
519
|
+
it('当只有文件而没有消息内容时,正确发送消息', async () => {
|
520
|
+
const { result } = renderHook(() => useChatStore());
|
521
|
+
|
522
|
+
await act(async () => {
|
523
|
+
await result.current.sendMessage({ message: '', files: [{ id: 'file-1' }] as any });
|
524
|
+
});
|
525
|
+
|
526
|
+
expect(messageService.createMessage).toHaveBeenCalledWith({
|
527
|
+
content: '',
|
528
|
+
files: ['file-1'],
|
529
|
+
role: 'user',
|
530
|
+
sessionId: 'session-id',
|
531
|
+
topicId: 'topic-id',
|
532
|
+
});
|
533
|
+
});
|
534
|
+
|
535
|
+
it('当同时有文件和消息内容时,正确发送消息并关联文件', async () => {
|
536
|
+
const { result } = renderHook(() => useChatStore());
|
537
|
+
|
538
|
+
await act(async () => {
|
539
|
+
await result.current.sendMessage({ message: 'test', files: [{ id: 'file-1' }] as any });
|
540
|
+
});
|
541
|
+
|
542
|
+
expect(messageService.createMessage).toHaveBeenCalledWith({
|
543
|
+
content: 'test',
|
544
|
+
files: ['file-1'],
|
545
|
+
role: 'user',
|
546
|
+
sessionId: 'session-id',
|
547
|
+
topicId: 'topic-id',
|
548
|
+
});
|
549
|
+
});
|
550
|
+
|
551
|
+
it('当 createMessage 抛出错误时,正确处理错误而不影响整个应用', async () => {
|
552
|
+
const { result } = renderHook(() => useChatStore());
|
553
|
+
vi.spyOn(messageService, 'createMessage').mockRejectedValue(
|
554
|
+
new Error('create message error'),
|
555
|
+
);
|
556
|
+
|
557
|
+
await expect(result.current.sendMessage({ message: 'test' })).rejects.toThrow(
|
558
|
+
'create message error',
|
559
|
+
);
|
560
|
+
|
561
|
+
expect(result.current.internal_coreProcessMessage).not.toHaveBeenCalled();
|
562
|
+
});
|
563
|
+
|
564
|
+
// it('自动创建主题成功后,正确地将消息复制到新主题,并删除之前的临时消息', async () => {
|
565
|
+
// const { result } = renderHook(() => useChatStore());
|
566
|
+
// act(() => {
|
567
|
+
// useAgentStore.setState({
|
568
|
+
// agentConfig: { enableAutoCreateTopic: true, autoCreateTopicThreshold: 1 },
|
569
|
+
// });
|
570
|
+
//
|
571
|
+
// useChatStore.setState({
|
572
|
+
// // Mock the currentChats selector to return a list that does not reach the threshold
|
573
|
+
// messagesMap: {
|
574
|
+
// [messageMapKey('inbox')]: [{ id: '1' }, { id: '2' }] as ChatMessage[],
|
575
|
+
// },
|
576
|
+
// activeId: 'inbox',
|
577
|
+
// });
|
578
|
+
// });
|
579
|
+
// vi.spyOn(topicService, 'createTopic').mockResolvedValue('new-topic');
|
580
|
+
//
|
581
|
+
// await act(async () => {
|
582
|
+
// await result.current.sendMessage({ message: 'test' });
|
583
|
+
// });
|
584
|
+
//
|
585
|
+
// expect(result.current.messagesMap[messageMapKey('inbox')]).toEqual([
|
586
|
+
// // { id: '1' },
|
587
|
+
// // { id: '2' },
|
588
|
+
// // { id: 'temp-id', content: 'test', role: 'user' },
|
589
|
+
// ]);
|
590
|
+
// // expect(result.current.getMessages('session-id')).toEqual([]);
|
591
|
+
// });
|
592
|
+
|
593
|
+
// it('自动创建主题失败时,正确地处理错误,不会影响后续的消息发送', async () => {
|
594
|
+
// const { result } = renderHook(() => useChatStore());
|
595
|
+
// result.current.setAgentConfig({ enableAutoCreateTopic: true, autoCreateTopicThreshold: 1 });
|
596
|
+
// result.current.setMessages([{ id: '1' }, { id: '2' }] as any);
|
597
|
+
// vi.spyOn(topicService, 'createTopic').mockRejectedValue(new Error('create topic error'));
|
598
|
+
//
|
599
|
+
// await act(async () => {
|
600
|
+
// await result.current.sendMessage({ message: 'test' });
|
601
|
+
// });
|
602
|
+
//
|
603
|
+
// expect(result.current.getMessages('session-id')).toEqual([
|
604
|
+
// { id: '1' },
|
605
|
+
// { id: '2' },
|
606
|
+
// { id: 'new-message-id', content: 'test', role: 'user' },
|
607
|
+
// ]);
|
608
|
+
// });
|
609
|
+
|
610
|
+
// it('当 activeTopicId 不存在且 autoCreateTopic 为 true,但消息数量未达到阈值时,正确地总结主题标题', async () => {
|
611
|
+
// const { result } = renderHook(() => useChatStore());
|
612
|
+
// result.current.setAgentConfig({ enableAutoCreateTopic: true, autoCreateTopicThreshold: 10 });
|
613
|
+
// result.current.setMessages([{ id: '1' }, { id: '2' }] as any);
|
614
|
+
// result.current.setActiveTopic({ id: 'topic-1', title: '' });
|
615
|
+
//
|
616
|
+
// await act(async () => {
|
617
|
+
// await result.current.sendMessage({ message: 'test' });
|
618
|
+
// });
|
619
|
+
//
|
620
|
+
// expect(result.current.summaryTopicTitle).toHaveBeenCalledWith('topic-1', [
|
621
|
+
// { id: '1' },
|
622
|
+
// { id: '2' },
|
623
|
+
// { id: 'new-message-id', content: 'test', role: 'user' },
|
624
|
+
// { id: 'assistant-message', role: 'assistant' },
|
625
|
+
// ]);
|
626
|
+
// });
|
627
|
+
//
|
628
|
+
// it('当 activeTopicId 存在且主题标题为空时,正确地总结主题标题', async () => {
|
629
|
+
// const { result } = renderHook(() => useChatStore());
|
630
|
+
// result.current.setActiveTopic({ id: 'topic-1', title: '' });
|
631
|
+
// result.current.setMessages([{ id: '1' }, { id: '2' }] as any, 'session-id', 'topic-1');
|
632
|
+
//
|
633
|
+
// await act(async () => {
|
634
|
+
// await result.current.sendMessage({ message: 'test' });
|
635
|
+
// });
|
636
|
+
//
|
637
|
+
// expect(result.current.summaryTopicTitle).toHaveBeenCalledWith('topic-1', [
|
638
|
+
// { id: '1' },
|
639
|
+
// { id: '2' },
|
640
|
+
// { id: 'new-message-id', content: 'test', role: 'user' },
|
641
|
+
// { id: 'assistant-message', role: 'assistant' },
|
642
|
+
// ]);
|
643
|
+
// });
|
644
|
+
});
|
645
|
+
|
646
|
+
describe('toggleMessageEditing action', () => {
|
647
|
+
it('should add message id to messageEditingIds when editing is true', () => {
|
648
|
+
const { result } = renderHook(() => useChatStore());
|
649
|
+
const messageId = 'message-id';
|
650
|
+
|
651
|
+
act(() => {
|
652
|
+
result.current.toggleMessageEditing(messageId, true);
|
653
|
+
});
|
654
|
+
|
655
|
+
expect(result.current.messageEditingIds).toContain(messageId);
|
656
|
+
});
|
657
|
+
|
658
|
+
it('should remove message id from messageEditingIds when editing is false', () => {
|
659
|
+
const { result } = renderHook(() => useChatStore());
|
660
|
+
const messageId = 'abc';
|
661
|
+
|
662
|
+
act(() => {
|
663
|
+
result.current.toggleMessageEditing(messageId, true);
|
664
|
+
result.current.toggleMessageEditing(messageId, false);
|
665
|
+
});
|
666
|
+
|
667
|
+
expect(result.current.messageEditingIds).not.toContain(messageId);
|
668
|
+
});
|
669
|
+
});
|
670
|
+
|
671
|
+
describe('internal_resendMessage action', () => {
|
672
|
+
it('should resend a message by id and refresh messages', async () => {
|
673
|
+
const { result } = renderHook(() => useChatStore());
|
674
|
+
const messageId = 'message-id';
|
675
|
+
|
676
|
+
act(() => {
|
677
|
+
useChatStore.setState({
|
678
|
+
activeId: 'session-id',
|
679
|
+
activeTopicId: undefined,
|
680
|
+
// Mock the currentChats selector to return a list that includes the message to be resent
|
681
|
+
messagesMap: {
|
682
|
+
[messageMapKey('session-id')]: [
|
683
|
+
{ id: messageId, role: 'user', content: 'Resend this message' } as ChatMessage,
|
684
|
+
],
|
685
|
+
},
|
686
|
+
});
|
687
|
+
});
|
688
|
+
|
689
|
+
// Mock the internal_coreProcessMessage function to resolve immediately
|
690
|
+
mockState.internal_coreProcessMessage.mockResolvedValue(undefined);
|
691
|
+
|
692
|
+
await act(async () => {
|
693
|
+
await result.current.internal_resendMessage(messageId);
|
694
|
+
});
|
695
|
+
|
696
|
+
expect(messageService.removeMessage).not.toHaveBeenCalledWith(messageId);
|
697
|
+
expect(mockState.internal_coreProcessMessage).toHaveBeenCalledWith(
|
698
|
+
expect.any(Array),
|
699
|
+
messageId,
|
700
|
+
{},
|
701
|
+
);
|
702
|
+
});
|
703
|
+
|
704
|
+
it('should not perform any action if the message id does not exist', async () => {
|
705
|
+
const { result } = renderHook(() => useChatStore());
|
706
|
+
const messageId = 'non-existing-message-id';
|
707
|
+
|
708
|
+
act(() => {
|
709
|
+
useChatStore.setState({
|
710
|
+
activeId: 'session-id',
|
711
|
+
activeTopicId: undefined,
|
712
|
+
// Mock the currentChats selector to return a list that does not include the message to be resent
|
713
|
+
messagesMap: {
|
714
|
+
[messageMapKey('session-id')]: [],
|
715
|
+
},
|
716
|
+
});
|
717
|
+
});
|
718
|
+
|
719
|
+
await act(async () => {
|
720
|
+
await result.current.internal_resendMessage(messageId);
|
721
|
+
});
|
722
|
+
|
723
|
+
expect(messageService.removeMessage).not.toHaveBeenCalledWith(messageId);
|
724
|
+
expect(mockState.internal_coreProcessMessage).not.toHaveBeenCalled();
|
725
|
+
expect(mockState.refreshMessages).not.toHaveBeenCalled();
|
726
|
+
});
|
727
|
+
});
|
728
|
+
|
729
|
+
describe('internal_updateMessageContent action', () => {
|
730
|
+
it('should call messageService.internal_updateMessageContent with correct parameters', async () => {
|
731
|
+
const { result } = renderHook(() => useChatStore());
|
732
|
+
const messageId = 'message-id';
|
733
|
+
const newContent = 'Updated content';
|
734
|
+
|
735
|
+
await act(async () => {
|
736
|
+
await result.current.internal_updateMessageContent(messageId, newContent);
|
737
|
+
});
|
738
|
+
|
739
|
+
expect(messageService.updateMessage).toHaveBeenCalledWith(messageId, { content: newContent });
|
740
|
+
});
|
741
|
+
|
742
|
+
it('should dispatch message update action', async () => {
|
743
|
+
const { result } = renderHook(() => useChatStore());
|
744
|
+
const messageId = 'message-id';
|
745
|
+
const newContent = 'Updated content';
|
746
|
+
const internal_dispatchMessageSpy = vi.spyOn(result.current, 'internal_dispatchMessage');
|
747
|
+
|
748
|
+
await act(async () => {
|
749
|
+
await result.current.internal_updateMessageContent(messageId, newContent);
|
750
|
+
});
|
751
|
+
|
752
|
+
expect(internal_dispatchMessageSpy).toHaveBeenCalledWith({
|
753
|
+
id: messageId,
|
754
|
+
type: 'updateMessages',
|
755
|
+
value: { content: newContent },
|
756
|
+
});
|
757
|
+
});
|
758
|
+
|
759
|
+
it('should refresh messages after updating content', async () => {
|
760
|
+
const { result } = renderHook(() => useChatStore());
|
761
|
+
const messageId = 'message-id';
|
762
|
+
const newContent = 'Updated content';
|
763
|
+
|
764
|
+
await act(async () => {
|
765
|
+
await result.current.internal_updateMessageContent(messageId, newContent);
|
766
|
+
});
|
767
|
+
|
768
|
+
expect(result.current.refreshMessages).toHaveBeenCalled();
|
769
|
+
});
|
770
|
+
});
|
771
|
+
|
772
|
+
describe('internal_coreProcessMessage action', () => {
|
773
|
+
it('should handle the core AI message processing', async () => {
|
774
|
+
useChatStore.setState({ internal_coreProcessMessage: realCoreProcessMessage });
|
775
|
+
|
776
|
+
const { result } = renderHook(() => useChatStore());
|
777
|
+
const userMessage = {
|
778
|
+
id: 'user-message-id',
|
779
|
+
role: 'user',
|
780
|
+
content: 'Hello, world!',
|
781
|
+
sessionId: mockState.activeId,
|
782
|
+
topicId: mockState.activeTopicId,
|
783
|
+
} as ChatMessage;
|
784
|
+
const messages = [userMessage];
|
785
|
+
|
786
|
+
// 模拟 AI 响应
|
787
|
+
const aiResponse = 'Hello, human!';
|
788
|
+
(chatService.createAssistantMessage as Mock).mockResolvedValue(aiResponse);
|
789
|
+
const spy = vi.spyOn(chatService, 'createAssistantMessageStream');
|
790
|
+
// 模拟消息创建
|
791
|
+
(messageService.createMessage as Mock).mockResolvedValue('assistant-message-id');
|
792
|
+
|
793
|
+
await act(async () => {
|
794
|
+
await result.current.internal_coreProcessMessage(messages, userMessage.id);
|
795
|
+
});
|
796
|
+
|
797
|
+
// 验证是否创建了代表 AI 响应的消息
|
798
|
+
expect(messageService.createMessage).toHaveBeenCalledWith(
|
799
|
+
expect.objectContaining({
|
800
|
+
role: 'assistant',
|
801
|
+
content: LOADING_FLAT,
|
802
|
+
fromModel: expect.anything(),
|
803
|
+
parentId: userMessage.id,
|
804
|
+
sessionId: mockState.activeId,
|
805
|
+
topicId: mockState.activeTopicId,
|
806
|
+
}),
|
807
|
+
);
|
808
|
+
|
809
|
+
// 验证 AI 服务是否被调用
|
810
|
+
expect(spy).toHaveBeenCalled();
|
811
|
+
|
812
|
+
// 验证消息列表是否刷新
|
813
|
+
expect(mockState.refreshMessages).toHaveBeenCalled();
|
814
|
+
});
|
815
|
+
});
|
816
|
+
|
817
|
+
describe('stopGenerateMessage action', () => {
|
818
|
+
it('should stop generating message and set loading states correctly', async () => {
|
819
|
+
const { result } = renderHook(() => useChatStore());
|
820
|
+
const internal_toggleChatLoadingSpy = vi.spyOn(result.current, 'internal_toggleChatLoading');
|
821
|
+
const abortController = new AbortController();
|
822
|
+
|
823
|
+
act(() => {
|
824
|
+
useChatStore.setState({ abortController });
|
825
|
+
});
|
826
|
+
|
827
|
+
await act(async () => {
|
828
|
+
result.current.stopGenerateMessage();
|
829
|
+
});
|
830
|
+
|
831
|
+
expect(abortController.signal.aborted).toBe(true);
|
832
|
+
expect(internal_toggleChatLoadingSpy).toHaveBeenCalledWith(
|
833
|
+
false,
|
834
|
+
undefined,
|
835
|
+
expect.any(String),
|
836
|
+
);
|
837
|
+
});
|
838
|
+
|
839
|
+
it('should not do anything if there is no abortController', async () => {
|
840
|
+
const { result } = renderHook(() => useChatStore());
|
841
|
+
|
842
|
+
// 确保没有设置 abortController
|
843
|
+
useChatStore.setState({ abortController: undefined });
|
844
|
+
|
845
|
+
await act(async () => {
|
846
|
+
result.current.stopGenerateMessage();
|
847
|
+
});
|
848
|
+
|
849
|
+
// 由于没有 abortController,不应调用任何方法
|
850
|
+
expect(result.current.abortController).toBeUndefined();
|
851
|
+
});
|
852
|
+
});
|
853
|
+
|
854
|
+
describe('toggleMessageEditing', () => {
|
855
|
+
it('should update messageEditingIds correctly when enabling editing', () => {
|
856
|
+
const messageId = 'message-id';
|
857
|
+
const { result } = renderHook(() => useChatStore());
|
858
|
+
|
859
|
+
act(() => {
|
860
|
+
result.current.toggleMessageEditing(messageId, true);
|
861
|
+
});
|
862
|
+
|
863
|
+
expect(result.current.messageEditingIds).toContain(messageId);
|
864
|
+
});
|
865
|
+
|
866
|
+
it('should update messageEditingIds correctly when disabling editing', () => {
|
867
|
+
const messageId = 'message-id';
|
868
|
+
useChatStore.setState({ messageEditingIds: [messageId] });
|
869
|
+
const { result } = renderHook(() => useChatStore());
|
870
|
+
|
871
|
+
act(() => {
|
872
|
+
result.current.toggleMessageEditing(messageId, false);
|
873
|
+
});
|
874
|
+
|
875
|
+
expect(result.current.messageEditingIds).not.toContain(messageId);
|
876
|
+
});
|
877
|
+
});
|
878
|
+
|
879
|
+
describe('refreshMessages action', () => {
|
880
|
+
beforeEach(() => {
|
881
|
+
vi.mock('swr', async () => {
|
882
|
+
const actual = await vi.importActual('swr');
|
883
|
+
return {
|
884
|
+
...(actual as any),
|
885
|
+
mutate: vi.fn(),
|
886
|
+
};
|
887
|
+
});
|
888
|
+
});
|
889
|
+
afterEach(() => {
|
890
|
+
// 在每个测试用例开始前恢复到实际的 SWR 实现
|
891
|
+
vi.resetAllMocks();
|
892
|
+
});
|
893
|
+
it('should refresh messages by calling mutate with current activeId and activeTopicId', async () => {
|
894
|
+
useChatStore.setState({ refreshMessages: realRefreshMessages });
|
895
|
+
|
896
|
+
const { result } = renderHook(() => useChatStore());
|
897
|
+
const activeId = useChatStore.getState().activeId;
|
898
|
+
const activeTopicId = useChatStore.getState().activeTopicId;
|
899
|
+
|
900
|
+
// 在这里,我们不需要再次模拟 mutate,因为它已经在顶部被模拟了
|
901
|
+
await act(async () => {
|
902
|
+
await result.current.refreshMessages();
|
903
|
+
});
|
904
|
+
|
905
|
+
// 确保 mutate 调用了正确的参数
|
906
|
+
expect(mutate).toHaveBeenCalledWith(['SWR_USE_FETCH_MESSAGES', activeId, activeTopicId]);
|
907
|
+
});
|
908
|
+
it('should handle errors during refreshing messages', async () => {
|
909
|
+
useChatStore.setState({ refreshMessages: realRefreshMessages });
|
910
|
+
const { result } = renderHook(() => useChatStore());
|
911
|
+
|
912
|
+
// 设置模拟错误
|
913
|
+
(mutate as Mock).mockImplementation(() => {
|
914
|
+
throw new Error('Mutate error');
|
915
|
+
});
|
916
|
+
|
917
|
+
await act(async () => {
|
918
|
+
await expect(result.current.refreshMessages()).rejects.toThrow('Mutate error');
|
919
|
+
});
|
920
|
+
|
921
|
+
// 确保恢复 mutate 的模拟,以免影响其他测试
|
922
|
+
(mutate as Mock).mockReset();
|
923
|
+
});
|
924
|
+
});
|
925
|
+
|
926
|
+
describe('useFetchMessages hook', () => {
|
927
|
+
// beforeEach(() => {
|
928
|
+
// vi.mocked(useSWR).mockRestore();
|
929
|
+
// });
|
930
|
+
|
931
|
+
it('should fetch messages for given session and topic ids', async () => {
|
932
|
+
const sessionId = 'session-id';
|
933
|
+
const topicId = 'topic-id';
|
934
|
+
const messages = [{ id: 'message-id', content: 'Hello' }];
|
935
|
+
|
936
|
+
// 设置模拟返回值
|
937
|
+
(messageService.getMessages as Mock).mockResolvedValue(messages);
|
938
|
+
|
939
|
+
const { result } = renderHook(() => useChatStore().useFetchMessages(sessionId, topicId));
|
940
|
+
|
941
|
+
// 等待异步操作完成
|
942
|
+
await waitFor(() => {
|
943
|
+
expect(result.current.data).toEqual(messages);
|
944
|
+
});
|
945
|
+
});
|
946
|
+
});
|
947
|
+
|
948
|
+
describe('internal_fetchAIChatMessage', () => {
|
949
|
+
it('should fetch AI chat message and return content', async () => {
|
950
|
+
const { result } = renderHook(() => useChatStore());
|
951
|
+
const messages = [{ id: 'message-id', content: 'Hello', role: 'user' }] as ChatMessage[];
|
952
|
+
const assistantMessageId = 'assistant-message-id';
|
953
|
+
const aiResponse = 'Hello, human!';
|
954
|
+
|
955
|
+
(fetch as Mock).mockResolvedValueOnce(new Response(aiResponse));
|
956
|
+
|
957
|
+
await act(async () => {
|
958
|
+
const response = await result.current.internal_fetchAIChatMessage(
|
959
|
+
messages,
|
960
|
+
assistantMessageId,
|
961
|
+
);
|
962
|
+
expect(response.isFunctionCall).toEqual(false);
|
963
|
+
});
|
964
|
+
});
|
965
|
+
|
966
|
+
it('should handle errors during AI response fetching', async () => {
|
967
|
+
const { result } = renderHook(() => useChatStore());
|
968
|
+
const messages = [{ id: 'message-id', content: 'Hello', role: 'user' }] as ChatMessage[];
|
969
|
+
const assistantMessageId = 'assistant-message-id';
|
970
|
+
|
971
|
+
// Mock fetch to reject with an error
|
972
|
+
const errorMessage = 'Error fetching AI response';
|
973
|
+
vi.mocked(fetch).mockRejectedValue(new Error(errorMessage));
|
974
|
+
|
975
|
+
await act(async () => {
|
976
|
+
expect(
|
977
|
+
await result.current.internal_fetchAIChatMessage(messages, assistantMessageId),
|
978
|
+
).toEqual({
|
979
|
+
isFunctionCall: false,
|
980
|
+
});
|
981
|
+
});
|
982
|
+
});
|
983
|
+
|
984
|
+
it('should generate correct contextMessages for "user" role', async () => {
|
985
|
+
const messageId = 'message-id';
|
986
|
+
const messages = [
|
987
|
+
{ id: 'msg-1', role: 'system' },
|
988
|
+
{ id: messageId, role: 'user', meta: { avatar: '😀' } },
|
989
|
+
{ id: 'msg-3', role: 'assistant' },
|
990
|
+
];
|
991
|
+
act(() => {
|
992
|
+
useChatStore.setState({
|
993
|
+
messagesMap: {
|
994
|
+
[chatSelectors.currentChatKey(mockState as any)]: messages as ChatMessage[],
|
995
|
+
},
|
996
|
+
});
|
997
|
+
});
|
998
|
+
const { result } = renderHook(() => useChatStore());
|
999
|
+
|
1000
|
+
await act(async () => {
|
1001
|
+
await result.current.internal_resendMessage(messageId);
|
1002
|
+
});
|
1003
|
+
|
1004
|
+
expect(result.current.internal_coreProcessMessage).toHaveBeenCalledWith(
|
1005
|
+
messages.slice(0, 2),
|
1006
|
+
messageId,
|
1007
|
+
{ traceId: undefined },
|
1008
|
+
);
|
1009
|
+
});
|
1010
|
+
|
1011
|
+
it('should generate correct contextMessages for "assistant" role', async () => {
|
1012
|
+
const messageId = 'message-id';
|
1013
|
+
const messages = [
|
1014
|
+
{ id: 'msg-1', role: 'system' },
|
1015
|
+
{ id: 'msg-2', role: 'user', meta: { avatar: '😀' } },
|
1016
|
+
{ id: messageId, role: 'assistant', parentId: 'msg-2' },
|
1017
|
+
];
|
1018
|
+
useChatStore.setState({
|
1019
|
+
messagesMap: {
|
1020
|
+
[chatSelectors.currentChatKey(mockState as any)]: messages as ChatMessage[],
|
1021
|
+
},
|
1022
|
+
});
|
1023
|
+
const { result } = renderHook(() => useChatStore());
|
1024
|
+
|
1025
|
+
await act(async () => {
|
1026
|
+
await result.current.internal_resendMessage(messageId);
|
1027
|
+
});
|
1028
|
+
|
1029
|
+
expect(result.current.internal_coreProcessMessage).toHaveBeenCalledWith(
|
1030
|
+
messages.slice(0, 2),
|
1031
|
+
'msg-2',
|
1032
|
+
{ traceId: undefined },
|
1033
|
+
);
|
1034
|
+
});
|
1035
|
+
|
1036
|
+
it('should return early if contextMessages is empty', async () => {
|
1037
|
+
const messageId = 'message-id';
|
1038
|
+
useChatStore.setState({
|
1039
|
+
messagesMap: { [chatSelectors.currentChatKey(mockState as any)]: [] },
|
1040
|
+
});
|
1041
|
+
const { result } = renderHook(() => useChatStore());
|
1042
|
+
|
1043
|
+
await act(async () => {
|
1044
|
+
await result.current.internal_resendMessage(messageId);
|
1045
|
+
});
|
1046
|
+
|
1047
|
+
expect(result.current.internal_coreProcessMessage).not.toHaveBeenCalled();
|
1048
|
+
});
|
1049
|
+
});
|
1050
|
+
|
1051
|
+
describe('internal_toggleChatLoading', () => {
|
1052
|
+
it('should set loading state and create an AbortController when loading is true', () => {
|
1053
|
+
const { result } = renderHook(() => useChatStore());
|
1054
|
+
const action = 'loading-action';
|
1055
|
+
|
1056
|
+
act(() => {
|
1057
|
+
result.current.internal_toggleChatLoading(true, 'message-id', action);
|
1058
|
+
});
|
1059
|
+
|
1060
|
+
const state = useChatStore.getState();
|
1061
|
+
expect(state.abortController).toBeInstanceOf(AbortController);
|
1062
|
+
expect(state.chatLoadingIds).toEqual(['message-id']);
|
1063
|
+
});
|
1064
|
+
|
1065
|
+
it('should clear loading state and abort controller when loading is false', () => {
|
1066
|
+
const { result } = renderHook(() => useChatStore());
|
1067
|
+
const action = 'stop-loading-action';
|
1068
|
+
|
1069
|
+
// Set initial loading state
|
1070
|
+
act(() => {
|
1071
|
+
result.current.internal_toggleChatLoading(true, 'message-id', 'start-loading-action');
|
1072
|
+
});
|
1073
|
+
|
1074
|
+
// Stop loading
|
1075
|
+
act(() => {
|
1076
|
+
result.current.internal_toggleChatLoading(false, undefined, action);
|
1077
|
+
});
|
1078
|
+
|
1079
|
+
const state = useChatStore.getState();
|
1080
|
+
expect(state.abortController).toBeUndefined();
|
1081
|
+
expect(state.chatLoadingIds).toEqual([]);
|
1082
|
+
});
|
1083
|
+
|
1084
|
+
it('should attach beforeunload event listener when loading starts', () => {
|
1085
|
+
const { result } = renderHook(() => useChatStore());
|
1086
|
+
const addEventListenerSpy = vi.spyOn(window, 'addEventListener');
|
1087
|
+
|
1088
|
+
act(() => {
|
1089
|
+
result.current.internal_toggleChatLoading(true, 'message-id', 'loading-action');
|
1090
|
+
});
|
1091
|
+
|
1092
|
+
expect(addEventListenerSpy).toHaveBeenCalledWith('beforeunload', expect.any(Function));
|
1093
|
+
});
|
1094
|
+
|
1095
|
+
it('should remove beforeunload event listener when loading stops', () => {
|
1096
|
+
const { result } = renderHook(() => useChatStore());
|
1097
|
+
const removeEventListenerSpy = vi.spyOn(window, 'removeEventListener');
|
1098
|
+
|
1099
|
+
// Start and then stop loading to trigger the removal of the event listener
|
1100
|
+
act(() => {
|
1101
|
+
result.current.internal_toggleChatLoading(true, 'message-id', 'start-loading-action');
|
1102
|
+
result.current.internal_toggleChatLoading(false, undefined, 'stop-loading-action');
|
1103
|
+
});
|
1104
|
+
|
1105
|
+
expect(removeEventListenerSpy).toHaveBeenCalledWith('beforeunload', expect.any(Function));
|
1106
|
+
});
|
1107
|
+
|
1108
|
+
it('should not create a new AbortController if one already exists', () => {
|
1109
|
+
const { result } = renderHook(() => useChatStore());
|
1110
|
+
const abortController = new AbortController();
|
1111
|
+
|
1112
|
+
act(() => {
|
1113
|
+
useChatStore.setState({ abortController });
|
1114
|
+
result.current.internal_toggleChatLoading(true, 'message-id', 'loading-action');
|
1115
|
+
});
|
1116
|
+
|
1117
|
+
const state = useChatStore.getState();
|
1118
|
+
expect(state.abortController).toEqual(abortController);
|
1119
|
+
});
|
1120
|
+
});
|
1121
|
+
|
1122
|
+
describe('internal_toggleMessageLoading action', () => {
|
1123
|
+
it('should add message id to messageLoadingIds when loading is true', () => {
|
1124
|
+
const { result } = renderHook(() => useChatStore());
|
1125
|
+
const messageId = 'message-id';
|
1126
|
+
|
1127
|
+
act(() => {
|
1128
|
+
result.current.internal_toggleMessageLoading(true, messageId);
|
1129
|
+
});
|
1130
|
+
|
1131
|
+
expect(result.current.messageLoadingIds).toContain(messageId);
|
1132
|
+
});
|
1133
|
+
|
1134
|
+
it('should remove message id from messageLoadingIds when loading is false', () => {
|
1135
|
+
const { result } = renderHook(() => useChatStore());
|
1136
|
+
const messageId = 'ddd-id';
|
1137
|
+
|
1138
|
+
act(() => {
|
1139
|
+
result.current.internal_toggleMessageLoading(true, messageId);
|
1140
|
+
result.current.internal_toggleMessageLoading(false, messageId);
|
1141
|
+
});
|
1142
|
+
|
1143
|
+
expect(result.current.messageLoadingIds).not.toContain(messageId);
|
1144
|
+
});
|
1145
|
+
});
|
1146
|
+
|
1147
|
+
describe('stopGenerateMessage', () => {
|
1148
|
+
it('should return early if abortController is undefined', () => {
|
1149
|
+
act(() => {
|
1150
|
+
useChatStore.setState({ abortController: undefined });
|
1151
|
+
});
|
1152
|
+
|
1153
|
+
const { result } = renderHook(() => useChatStore());
|
1154
|
+
|
1155
|
+
const spy = vi.spyOn(result.current, 'internal_toggleChatLoading');
|
1156
|
+
|
1157
|
+
act(() => {
|
1158
|
+
result.current.stopGenerateMessage();
|
1159
|
+
});
|
1160
|
+
|
1161
|
+
expect(spy).not.toHaveBeenCalled();
|
1162
|
+
});
|
1163
|
+
|
1164
|
+
it('should call abortController.abort()', () => {
|
1165
|
+
const abortMock = vi.fn();
|
1166
|
+
const abortController = { abort: abortMock } as unknown as AbortController;
|
1167
|
+
act(() => {
|
1168
|
+
useChatStore.setState({ abortController });
|
1169
|
+
});
|
1170
|
+
const { result } = renderHook(() => useChatStore());
|
1171
|
+
|
1172
|
+
act(() => {
|
1173
|
+
result.current.stopGenerateMessage();
|
1174
|
+
});
|
1175
|
+
|
1176
|
+
expect(abortMock).toHaveBeenCalled();
|
1177
|
+
});
|
1178
|
+
|
1179
|
+
it('should call internal_toggleChatLoading with correct parameters', () => {
|
1180
|
+
const abortController = new AbortController();
|
1181
|
+
act(() => {
|
1182
|
+
useChatStore.setState({ abortController });
|
1183
|
+
});
|
1184
|
+
const { result } = renderHook(() => useChatStore());
|
1185
|
+
const spy = vi.spyOn(result.current, 'internal_toggleChatLoading');
|
1186
|
+
|
1187
|
+
act(() => {
|
1188
|
+
result.current.stopGenerateMessage();
|
1189
|
+
});
|
1190
|
+
|
1191
|
+
expect(spy).toHaveBeenCalledWith(false, undefined, expect.any(String));
|
1192
|
+
});
|
1193
|
+
});
|
1194
|
+
|
1195
|
+
describe('updateInputMessage', () => {
|
1196
|
+
it('should not update state if message is the same as current inputMessage', () => {
|
1197
|
+
const inputMessage = 'Test input message';
|
1198
|
+
useChatStore.setState({ inputMessage });
|
1199
|
+
const { result } = renderHook(() => useChatStore());
|
1200
|
+
|
1201
|
+
act(() => {
|
1202
|
+
result.current.updateInputMessage(inputMessage);
|
1203
|
+
});
|
1204
|
+
|
1205
|
+
expect(result.current.inputMessage).toBe(inputMessage);
|
1206
|
+
});
|
1207
|
+
});
|
1208
|
+
|
1209
|
+
describe('modifyMessageContent', () => {
|
1210
|
+
it('should call internal_traceMessage with correct parameters before updating', async () => {
|
1211
|
+
const messageId = 'message-id';
|
1212
|
+
const content = 'Updated content';
|
1213
|
+
const { result } = renderHook(() => useChatStore());
|
1214
|
+
|
1215
|
+
const spy = vi.spyOn(result.current, 'internal_traceMessage');
|
1216
|
+
await act(async () => {
|
1217
|
+
await result.current.modifyMessageContent(messageId, content);
|
1218
|
+
});
|
1219
|
+
|
1220
|
+
expect(spy).toHaveBeenCalledWith(messageId, {
|
1221
|
+
eventType: TraceEventType.ModifyMessage,
|
1222
|
+
nextContent: content,
|
1223
|
+
});
|
1224
|
+
});
|
1225
|
+
|
1226
|
+
it('should call internal_updateMessageContent with correct parameters', async () => {
|
1227
|
+
const messageId = 'message-id';
|
1228
|
+
const content = 'Updated content';
|
1229
|
+
const { result } = renderHook(() => useChatStore());
|
1230
|
+
|
1231
|
+
const spy = vi.spyOn(result.current, 'internal_traceMessage');
|
1232
|
+
|
1233
|
+
await act(async () => {
|
1234
|
+
await result.current.modifyMessageContent(messageId, content);
|
1235
|
+
});
|
1236
|
+
|
1237
|
+
expect(spy).toHaveBeenCalledWith(messageId, {
|
1238
|
+
eventType: 'Modify Message',
|
1239
|
+
nextContent: 'Updated content',
|
1240
|
+
});
|
1241
|
+
});
|
1242
|
+
});
|
1243
|
+
});
|