@lobehub/lobehub 1.143.0-next.2 → 2.0.0-next.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (244) hide show
  1. package/.github/workflows/desktop-pr-build.yml +12 -10
  2. package/.github/workflows/docker.yml +25 -20
  3. package/.github/workflows/e2e.yml +3 -3
  4. package/.github/workflows/release-desktop-beta.yml +8 -8
  5. package/.github/workflows/release.yml +1 -1
  6. package/.github/workflows/test.yml +4 -4
  7. package/CHANGELOG.md +265 -0
  8. package/README.md +7 -0
  9. package/README.zh-CN.md +7 -0
  10. package/apps/desktop/src/main/utils/next-electron-rsc.ts +7 -5
  11. package/changelog/v1.json +85 -0
  12. package/docs/development/database-schema.dbml +11 -1
  13. package/docs/self-hosting/advanced/auth/next-auth/auth0.mdx +2 -2
  14. package/docs/self-hosting/advanced/auth/next-auth/auth0.zh-CN.mdx +2 -2
  15. package/docs/self-hosting/advanced/auth/next-auth/authelia.mdx +2 -2
  16. package/docs/self-hosting/advanced/auth/next-auth/authelia.zh-CN.mdx +2 -2
  17. package/docs/self-hosting/advanced/auth/next-auth/authentik.mdx +2 -2
  18. package/docs/self-hosting/advanced/auth/next-auth/authentik.zh-CN.mdx +2 -2
  19. package/docs/self-hosting/advanced/auth/next-auth/casdoor.mdx +2 -2
  20. package/docs/self-hosting/advanced/auth/next-auth/casdoor.zh-CN.mdx +2 -2
  21. package/docs/self-hosting/advanced/auth/next-auth/cloudflare-zero-trust.mdx +2 -2
  22. package/docs/self-hosting/advanced/auth/next-auth/cloudflare-zero-trust.zh-CN.mdx +2 -2
  23. package/docs/self-hosting/advanced/auth/next-auth/github.mdx +2 -2
  24. package/docs/self-hosting/advanced/auth/next-auth/github.zh-CN.mdx +2 -2
  25. package/docs/self-hosting/advanced/auth/next-auth/google.mdx +32 -29
  26. package/docs/self-hosting/advanced/auth/next-auth/keycloak.mdx +2 -2
  27. package/docs/self-hosting/advanced/auth/next-auth/keycloak.zh-CN.mdx +2 -2
  28. package/docs/self-hosting/advanced/auth/next-auth/logto.mdx +5 -3
  29. package/docs/self-hosting/advanced/auth/next-auth/logto.zh-CN.mdx +5 -3
  30. package/docs/self-hosting/advanced/auth/next-auth/microsoft-entra-id.mdx +2 -2
  31. package/docs/self-hosting/advanced/auth/next-auth/microsoft-entra-id.zh-CN.mdx +2 -2
  32. package/docs/self-hosting/advanced/auth/next-auth/okta.mdx +2 -2
  33. package/docs/self-hosting/advanced/auth/next-auth/okta.zh-CN.mdx +2 -2
  34. package/docs/self-hosting/advanced/auth/next-auth/wechat.mdx +2 -2
  35. package/docs/self-hosting/advanced/auth/next-auth/wechat.zh-CN.mdx +2 -2
  36. package/docs/self-hosting/advanced/auth/next-auth/zitadel.mdx +2 -2
  37. package/docs/self-hosting/advanced/auth/next-auth/zitadel.zh-CN.mdx +2 -2
  38. package/docs/self-hosting/advanced/auth.mdx +32 -21
  39. package/docs/self-hosting/advanced/auth.zh-CN.mdx +30 -19
  40. package/docs/self-hosting/advanced/online-search.mdx +30 -25
  41. package/docs/self-hosting/advanced/online-search.zh-CN.mdx +25 -23
  42. package/locales/ar/models.json +15 -6
  43. package/locales/bg-BG/models.json +15 -6
  44. package/locales/de-DE/models.json +15 -6
  45. package/locales/en-US/models.json +15 -6
  46. package/locales/es-ES/models.json +15 -6
  47. package/locales/fa-IR/models.json +15 -6
  48. package/locales/fr-FR/models.json +15 -6
  49. package/locales/it-IT/models.json +15 -6
  50. package/locales/ja-JP/models.json +15 -6
  51. package/locales/ko-KR/models.json +15 -6
  52. package/locales/nl-NL/models.json +15 -6
  53. package/locales/pl-PL/models.json +15 -6
  54. package/locales/pt-BR/models.json +15 -6
  55. package/locales/ru-RU/models.json +15 -6
  56. package/locales/tr-TR/models.json +15 -6
  57. package/locales/vi-VN/models.json +15 -6
  58. package/locales/zh-CN/models.json +15 -6
  59. package/locales/zh-TW/models.json +15 -6
  60. package/next.config.ts +2 -3
  61. package/package.json +13 -19
  62. package/packages/const/src/index.ts +0 -1
  63. package/packages/const/src/models.ts +13 -0
  64. package/packages/const/src/url.ts +1 -4
  65. package/packages/context-engine/src/index.ts +1 -6
  66. package/packages/context-engine/src/processors/GroupMessageFlatten.ts +12 -2
  67. package/packages/context-engine/src/processors/__tests__/GroupMessageFlatten.test.ts +73 -9
  68. package/packages/context-engine/src/providers/index.ts +0 -2
  69. package/packages/database/migrations/0041_improve_index.sql +10 -0
  70. package/packages/database/migrations/meta/0041_snapshot.json +7784 -0
  71. package/packages/database/migrations/meta/_journal.json +7 -0
  72. package/packages/database/package.json +1 -1
  73. package/packages/database/src/core/migrations.json +17 -0
  74. package/packages/database/src/models/__tests__/message.grouping.test.ts +812 -0
  75. package/packages/database/src/models/__tests__/message.test.ts +322 -170
  76. package/packages/database/src/models/message.ts +62 -24
  77. package/packages/database/src/models/session.ts +60 -19
  78. package/packages/database/src/schemas/agent.ts +10 -11
  79. package/packages/database/src/schemas/message.ts +5 -1
  80. package/packages/database/src/schemas/relations.ts +6 -4
  81. package/packages/database/src/schemas/session.ts +2 -0
  82. package/packages/database/src/schemas/topic.ts +6 -1
  83. package/packages/database/src/utils/__tests__/groupMessages.test.ts +145 -2
  84. package/packages/database/src/utils/groupMessages.ts +7 -5
  85. package/packages/electron-client-ipc/package.json +4 -1
  86. package/packages/file-loaders/package.json +1 -0
  87. package/packages/model-bank/src/aiModels/anthropic.ts +0 -63
  88. package/packages/model-bank/src/aiModels/azure.ts +155 -0
  89. package/packages/model-bank/src/aiModels/bedrock.ts +44 -0
  90. package/packages/model-bank/src/aiModels/higress.ts +0 -55
  91. package/packages/model-bank/src/aiModels/infiniai.ts +21 -0
  92. package/packages/model-bank/src/aiModels/ollamacloud.ts +13 -0
  93. package/packages/model-bank/src/aiModels/siliconcloud.ts +19 -0
  94. package/packages/model-runtime/src/core/openaiCompatibleFactory/createImage.ts +1 -1
  95. package/packages/model-runtime/src/core/openaiCompatibleFactory/index.test.ts +33 -3
  96. package/packages/model-runtime/src/core/parameterResolver.ts +3 -0
  97. package/packages/model-runtime/src/core/streams/openai/__snapshots__/responsesStream.test.ts.snap +0 -38
  98. package/packages/model-runtime/src/providers/azureOpenai/index.ts +2 -1
  99. package/packages/model-runtime/src/providers/minimax/index.ts +5 -5
  100. package/packages/model-runtime/src/providers/search1api/index.test.ts +2 -2
  101. package/packages/types/src/message/common/base.ts +13 -0
  102. package/packages/types/src/message/common/image.ts +8 -0
  103. package/packages/types/src/message/common/metadata.ts +39 -0
  104. package/packages/types/src/message/common/tools.ts +10 -0
  105. package/packages/types/src/message/db/params.ts +47 -1
  106. package/packages/types/src/message/ui/chat.ts +4 -1
  107. package/packages/types/src/search.ts +16 -0
  108. package/packages/web-crawler/src/crawImpl/firecrawl.ts +39 -12
  109. package/scripts/migrateServerDB/index.ts +2 -1
  110. package/src/app/(backend)/oidc/consent/route.ts +0 -1
  111. package/src/app/(backend)/webapi/revalidate/route.ts +1 -1
  112. package/src/app/[variants]/(main)/chat/(workspace)/@conversation/features/ChatInput/V1Mobile/index.tsx +2 -2
  113. package/src/app/[variants]/(main)/chat/(workspace)/@conversation/features/ChatInput/V1Mobile/useSend.ts +6 -4
  114. package/src/app/[variants]/(main)/chat/(workspace)/@conversation/features/ChatInput/useSend.ts +15 -10
  115. package/src/app/[variants]/(main)/chat/@session/features/SessionListContent/List/Item/index.tsx +4 -2
  116. package/src/app/[variants]/(main)/settings/_layout/SettingsContent.tsx +0 -3
  117. package/src/app/[variants]/layout.tsx +1 -0
  118. package/src/app/sitemap.tsx +7 -1
  119. package/src/components/Thinking/index.tsx +4 -3
  120. package/src/config/modelProviders/anthropic.ts +0 -23
  121. package/src/config/modelProviders/higress.ts +0 -23
  122. package/src/config/modelProviders/minimax.ts +1 -1
  123. package/src/config/modelProviders/qiniu.ts +1 -1
  124. package/src/envs/auth.ts +0 -179
  125. package/src/features/AgentSetting/AgentPlugin/index.tsx +21 -13
  126. package/src/features/ChatInput/ActionBar/STT/browser.tsx +2 -2
  127. package/src/features/ChatInput/ActionBar/STT/openai.tsx +2 -2
  128. package/src/features/ChatInput/ActionBar/Tools/useControls.tsx +1 -3
  129. package/src/features/Conversation/Error/ErrorJsonViewer.tsx +4 -3
  130. package/src/features/Conversation/Error/OllamaBizError/index.tsx +7 -2
  131. package/src/features/Conversation/Error/index.tsx +15 -5
  132. package/src/features/Conversation/MarkdownElements/LobeArtifact/Render/index.tsx +2 -2
  133. package/src/features/Conversation/Messages/Assistant/Extra/index.tsx +2 -2
  134. package/src/features/Conversation/Messages/Assistant/MessageContent.tsx +5 -3
  135. package/src/features/Conversation/Messages/Assistant/Tool/Inspector/BuiltinPluginTitle.tsx +2 -2
  136. package/src/features/Conversation/Messages/Assistant/Tool/Inspector/ToolTitle.tsx +4 -2
  137. package/src/features/Conversation/Messages/Assistant/Tool/Render/CustomRender.tsx +2 -2
  138. package/src/features/Conversation/Messages/Assistant/Tool/Render/index.tsx +2 -2
  139. package/src/features/Conversation/Messages/Assistant/Tool/index.tsx +2 -2
  140. package/src/features/Conversation/Messages/Assistant/index.tsx +4 -4
  141. package/src/features/Conversation/Messages/Default.tsx +2 -2
  142. package/src/features/Conversation/Messages/User/Extra.tsx +2 -2
  143. package/src/features/Conversation/Messages/User/index.tsx +4 -4
  144. package/src/features/Conversation/Messages/index.tsx +3 -3
  145. package/src/features/Conversation/components/AutoScroll.tsx +2 -2
  146. package/src/features/Conversation/components/Extras/Usage/UsageDetail/index.tsx +9 -6
  147. package/src/features/PluginTag/index.tsx +1 -3
  148. package/src/features/PluginsUI/Render/BuiltinType/index.test.tsx +37 -28
  149. package/src/features/Portal/Artifacts/Body/index.tsx +2 -2
  150. package/src/libs/next-auth/auth.config.ts +1 -1
  151. package/src/libs/next-auth/sso-providers/auth0.ts +0 -7
  152. package/src/libs/next-auth/sso-providers/authelia.ts +3 -5
  153. package/src/libs/next-auth/sso-providers/authentik.ts +0 -7
  154. package/src/libs/next-auth/sso-providers/cloudflare-zero-trust.ts +3 -6
  155. package/src/libs/next-auth/sso-providers/cognito.ts +1 -5
  156. package/src/libs/next-auth/sso-providers/generic-oidc.ts +3 -5
  157. package/src/libs/next-auth/sso-providers/github.ts +0 -6
  158. package/src/libs/next-auth/sso-providers/google.ts +0 -2
  159. package/src/libs/next-auth/sso-providers/index.ts +0 -2
  160. package/src/libs/next-auth/sso-providers/keycloak.ts +0 -3
  161. package/src/libs/next-auth/sso-providers/logto.ts +3 -5
  162. package/src/libs/next-auth/sso-providers/okta.ts +0 -4
  163. package/src/libs/next-auth/sso-providers/zitadel.ts +0 -7
  164. package/src/libs/oidc-provider/provider.ts +1 -1
  165. package/src/server/modules/AssistantStore/index.ts +1 -1
  166. package/src/server/modules/ModelRuntime/trace.ts +11 -4
  167. package/src/server/routers/lambda/message.ts +14 -3
  168. package/src/server/routers/lambda/session.ts +8 -5
  169. package/src/server/services/search/impls/firecrawl/index.ts +51 -11
  170. package/src/server/services/search/impls/firecrawl/type.ts +60 -9
  171. package/src/services/chat/chat.test.ts +1 -40
  172. package/src/services/chat/contextEngineering.test.ts +0 -30
  173. package/src/services/chat/contextEngineering.ts +1 -12
  174. package/src/services/chat/index.ts +2 -7
  175. package/src/services/chat/types.ts +1 -1
  176. package/src/services/message/_deprecated.ts +1 -1
  177. package/src/services/message/client.ts +8 -2
  178. package/src/services/message/server.ts +7 -2
  179. package/src/services/message/type.ts +6 -1
  180. package/src/services/user/client.test.ts +4 -1
  181. package/src/store/chat/helpers.test.ts +99 -0
  182. package/src/store/chat/helpers.ts +21 -2
  183. package/src/store/chat/selectors.ts +1 -1
  184. package/src/store/chat/slices/aiChat/actions/generateAIChat.ts +3 -3
  185. package/src/store/chat/slices/builtinTool/actions/index.ts +1 -4
  186. package/src/store/chat/slices/message/action.test.ts +5 -1
  187. package/src/store/chat/slices/message/action.ts +102 -14
  188. package/src/store/chat/slices/message/reducer.test.ts +363 -5
  189. package/src/store/chat/slices/message/reducer.ts +87 -3
  190. package/src/store/chat/slices/message/{selectors.test.ts → selectors/chat.test.ts} +266 -30
  191. package/src/store/chat/slices/message/{selectors.ts → selectors/chat.ts} +29 -79
  192. package/src/store/chat/slices/message/selectors/index.ts +2 -0
  193. package/src/store/chat/slices/message/selectors/messageState.test.ts +36 -0
  194. package/src/store/chat/slices/message/selectors/messageState.ts +80 -0
  195. package/src/store/chat/slices/plugin/action.test.ts +34 -132
  196. package/src/store/chat/slices/plugin/action.ts +1 -44
  197. package/src/store/tool/selectors/tool.test.ts +1 -1
  198. package/src/store/tool/selectors/tool.ts +6 -8
  199. package/src/store/tool/slices/builtin/action.test.ts +83 -35
  200. package/src/store/tool/slices/builtin/action.ts +0 -9
  201. package/src/store/tool/slices/builtin/selectors.test.ts +4 -30
  202. package/src/store/tool/slices/builtin/selectors.ts +15 -21
  203. package/src/tools/index.ts +0 -6
  204. package/src/tools/renders.ts +0 -3
  205. package/src/tools/web-browsing/Portal/Search/Footer.tsx +2 -2
  206. package/tsconfig.json +9 -2
  207. package/packages/const/src/guide.ts +0 -89
  208. package/packages/context-engine/src/providers/InboxGuide.ts +0 -102
  209. package/packages/context-engine/src/providers/__tests__/InboxGuideProvider.test.ts +0 -121
  210. package/src/app/[variants]/(main)/settings/llm/ProviderList/Azure/index.tsx +0 -93
  211. package/src/app/[variants]/(main)/settings/llm/ProviderList/Bedrock/index.tsx +0 -70
  212. package/src/app/[variants]/(main)/settings/llm/ProviderList/Cloudflare/index.tsx +0 -39
  213. package/src/app/[variants]/(main)/settings/llm/ProviderList/Github/index.tsx +0 -52
  214. package/src/app/[variants]/(main)/settings/llm/ProviderList/HuggingFace/index.tsx +0 -52
  215. package/src/app/[variants]/(main)/settings/llm/ProviderList/Ollama/index.tsx +0 -20
  216. package/src/app/[variants]/(main)/settings/llm/ProviderList/OpenAI/index.tsx +0 -17
  217. package/src/app/[variants]/(main)/settings/llm/ProviderList/providers.tsx +0 -132
  218. package/src/app/[variants]/(main)/settings/llm/components/Checker.tsx +0 -118
  219. package/src/app/[variants]/(main)/settings/llm/components/ProviderConfig/index.tsx +0 -303
  220. package/src/app/[variants]/(main)/settings/llm/components/ProviderModelList/CustomModelOption.tsx +0 -98
  221. package/src/app/[variants]/(main)/settings/llm/components/ProviderModelList/ModelConfigModal/Form.tsx +0 -104
  222. package/src/app/[variants]/(main)/settings/llm/components/ProviderModelList/ModelConfigModal/index.tsx +0 -77
  223. package/src/app/[variants]/(main)/settings/llm/components/ProviderModelList/ModelFetcher.tsx +0 -105
  224. package/src/app/[variants]/(main)/settings/llm/components/ProviderModelList/Option.tsx +0 -68
  225. package/src/app/[variants]/(main)/settings/llm/components/ProviderModelList/index.tsx +0 -146
  226. package/src/app/[variants]/(main)/settings/llm/const.ts +0 -20
  227. package/src/app/[variants]/(main)/settings/llm/features/Footer.tsx +0 -35
  228. package/src/app/[variants]/(main)/settings/llm/index.tsx +0 -30
  229. package/src/app/[variants]/(main)/settings/llm/type.ts +0 -5
  230. package/src/envs/__tests__/auth.test.ts +0 -200
  231. package/src/libs/next-auth/sso-providers/azure-ad.ts +0 -33
  232. package/src/services/chat/__snapshots__/chat.test.ts.snap +0 -110
  233. package/src/store/chat/slices/builtinTool/actions/__tests__/dalle.test.ts +0 -121
  234. package/src/store/chat/slices/builtinTool/actions/dalle.ts +0 -124
  235. package/src/tools/dalle/Render/GalleyGrid.tsx +0 -60
  236. package/src/tools/dalle/Render/Item/EditMode.tsx +0 -66
  237. package/src/tools/dalle/Render/Item/Error.tsx +0 -49
  238. package/src/tools/dalle/Render/Item/Image.tsx +0 -44
  239. package/src/tools/dalle/Render/Item/ImageFileItem.tsx +0 -57
  240. package/src/tools/dalle/Render/Item/index.tsx +0 -88
  241. package/src/tools/dalle/Render/ToolBar.tsx +0 -56
  242. package/src/tools/dalle/Render/index.tsx +0 -52
  243. package/src/tools/dalle/index.ts +0 -92
  244. /package/src/{middleware.ts → proxy.ts} +0 -0
@@ -1,104 +0,0 @@
1
- import { Input } from '@lobehub/ui';
2
- import { Checkbox, Form, FormInstance } from 'antd';
3
- import { memo, useEffect } from 'react';
4
- import { useTranslation } from 'react-i18next';
5
-
6
- import MaxTokenSlider from '@/components/MaxTokenSlider';
7
- import { useIsMobile } from '@/hooks/useIsMobile';
8
- import { ChatModelCard } from '@/types/llm';
9
-
10
- interface ModelConfigFormProps {
11
- initialValues?: ChatModelCard;
12
- onFormInstanceReady: (instance: FormInstance) => void;
13
- showAzureDeployName?: boolean;
14
- }
15
-
16
- const ModelConfigForm = memo<ModelConfigFormProps>(
17
- ({ showAzureDeployName, onFormInstanceReady, initialValues }) => {
18
- const { t } = useTranslation('setting');
19
-
20
- const [formInstance] = Form.useForm();
21
-
22
- const isMobile = useIsMobile();
23
-
24
- useEffect(() => {
25
- onFormInstanceReady(formInstance);
26
- }, []);
27
-
28
- return (
29
- <div
30
- onClick={(e) => {
31
- e.stopPropagation();
32
- }}
33
- onKeyDown={(e) => {
34
- e.stopPropagation();
35
- }}
36
- >
37
- <Form
38
- colon={false}
39
- form={formInstance}
40
- initialValues={initialValues}
41
- labelCol={{ span: 4 }}
42
- style={{ marginTop: 16 }}
43
- wrapperCol={isMobile ? { span: 18 } : { offset: 1, span: 18 }}
44
- >
45
- <Form.Item
46
- extra={t('llm.customModelCards.modelConfig.id.extra')}
47
- label={t('llm.customModelCards.modelConfig.id.title')}
48
- name={'id'}
49
- >
50
- <Input placeholder={t('llm.customModelCards.modelConfig.id.placeholder')} />
51
- </Form.Item>
52
- {showAzureDeployName && (
53
- <Form.Item
54
- extra={t('llm.customModelCards.modelConfig.azureDeployName.extra')}
55
- label={t('llm.customModelCards.modelConfig.azureDeployName.title')}
56
- name={'deploymentName'}
57
- >
58
- <Input
59
- placeholder={t('llm.customModelCards.modelConfig.azureDeployName.placeholder')}
60
- />
61
- </Form.Item>
62
- )}
63
- <Form.Item
64
- label={t('llm.customModelCards.modelConfig.displayName.title')}
65
- name={'displayName'}
66
- >
67
- <Input placeholder={t('llm.customModelCards.modelConfig.displayName.placeholder')} />
68
- </Form.Item>
69
- <Form.Item
70
- label={t('llm.customModelCards.modelConfig.tokens.title')}
71
- name={'contextWindowTokens'}
72
- >
73
- <MaxTokenSlider />
74
- </Form.Item>
75
- <Form.Item
76
- extra={t('llm.customModelCards.modelConfig.functionCall.extra')}
77
- label={t('llm.customModelCards.modelConfig.functionCall.title')}
78
- name={'functionCall'}
79
- valuePropName={'checked'}
80
- >
81
- <Checkbox />
82
- </Form.Item>
83
- <Form.Item
84
- extra={t('llm.customModelCards.modelConfig.vision.extra')}
85
- label={t('llm.customModelCards.modelConfig.vision.title')}
86
- name={'vision'}
87
- valuePropName={'checked'}
88
- >
89
- <Checkbox />
90
- </Form.Item>
91
- <Form.Item
92
- extra={t('llm.customModelCards.modelConfig.files.extra')}
93
- label={t('llm.customModelCards.modelConfig.files.title')}
94
- name={'files'}
95
- valuePropName={'checked'}
96
- >
97
- <Checkbox />
98
- </Form.Item>
99
- </Form>
100
- </div>
101
- );
102
- },
103
- );
104
- export default ModelConfigForm;
@@ -1,77 +0,0 @@
1
- import { Button, Modal } from '@lobehub/ui';
2
- import { FormInstance } from 'antd';
3
- import isEqual from 'fast-deep-equal';
4
- import { memo, useState } from 'react';
5
- import { useTranslation } from 'react-i18next';
6
-
7
- import { useUserStore } from '@/store/user';
8
- import { modelConfigSelectors } from '@/store/user/selectors';
9
-
10
- import ModelConfigForm from './Form';
11
-
12
- interface ModelConfigModalProps {
13
- provider?: string;
14
- showAzureDeployName?: boolean;
15
- }
16
-
17
- const ModelConfigModal = memo<ModelConfigModalProps>(({ showAzureDeployName, provider }) => {
18
- const { t } = useTranslation('setting');
19
- const { t: tc } = useTranslation('common');
20
- const [formInstance, setFormInstance] = useState<FormInstance>();
21
-
22
- const [open, id, editingProvider, dispatchCustomModelCards, toggleEditingCustomModelCard] =
23
- useUserStore((s) => [
24
- !!s.editingCustomCardModel && provider === s.editingCustomCardModel?.provider,
25
- s.editingCustomCardModel?.id,
26
- s.editingCustomCardModel?.provider,
27
- s.dispatchCustomModelCards,
28
- s.toggleEditingCustomModelCard,
29
- ]);
30
-
31
- const modelCard = useUserStore(
32
- modelConfigSelectors.getCustomModelCard({ id, provider: editingProvider }),
33
- isEqual,
34
- );
35
-
36
- const closeModal = () => {
37
- toggleEditingCustomModelCard(undefined);
38
- };
39
-
40
- return (
41
- <Modal
42
- destroyOnHidden
43
- footer={[
44
- <Button key="cancel" onClick={closeModal}>
45
- {tc('cancel')}
46
- </Button>,
47
- <Button
48
- key="ok"
49
- onClick={() => {
50
- if (!editingProvider || !id || !formInstance) return;
51
- const data = formInstance.getFieldsValue();
52
-
53
- dispatchCustomModelCards(editingProvider as any, { id, type: 'update', value: data });
54
-
55
- closeModal();
56
- }}
57
- style={{ marginInlineStart: '16px' }}
58
- type="primary"
59
- >
60
- {tc('ok')}
61
- </Button>,
62
- ]}
63
- maskClosable
64
- onCancel={closeModal}
65
- open={open}
66
- title={t('llm.customModelCards.modelConfig.modalTitle')}
67
- zIndex={1251} // Select is 1150
68
- >
69
- <ModelConfigForm
70
- initialValues={modelCard}
71
- onFormInstanceReady={setFormInstance}
72
- showAzureDeployName={showAzureDeployName}
73
- />
74
- </Modal>
75
- );
76
- });
77
- export default ModelConfigModal;
@@ -1,105 +0,0 @@
1
- import { ActionIcon, Icon, Text, Tooltip } from '@lobehub/ui';
2
- import { createStyles } from 'antd-style';
3
- import dayjs from 'dayjs';
4
- import isEqual from 'fast-deep-equal';
5
- import { CircleX, LucideLoaderCircle, LucideRefreshCcwDot } from 'lucide-react';
6
- import { memo } from 'react';
7
- import { useTranslation } from 'react-i18next';
8
- import { Flexbox } from 'react-layout-kit';
9
-
10
- import { useUserStore } from '@/store/user';
11
- import {
12
- modelConfigSelectors,
13
- modelProviderSelectors,
14
- settingsSelectors,
15
- } from '@/store/user/selectors';
16
- import { GlobalLLMProviderKey } from '@/types/user/settings';
17
-
18
- const useStyles = createStyles(({ css, token }) => ({
19
- hover: css`
20
- cursor: pointer;
21
-
22
- padding-block: 4px;
23
- padding-inline: 8px;
24
- border-radius: ${token.borderRadius}px;
25
-
26
- transition: all 0.2s ease-in-out;
27
-
28
- &:hover {
29
- color: ${token.colorText};
30
- background-color: ${token.colorFillSecondary};
31
- }
32
- `,
33
- }));
34
-
35
- interface ModelFetcherProps {
36
- provider: GlobalLLMProviderKey;
37
- }
38
-
39
- const ModelFetcher = memo<ModelFetcherProps>(({ provider }) => {
40
- const { styles } = useStyles();
41
- const { t } = useTranslation('setting');
42
- const [useFetchProviderModelList, clearObtainedModels] = useUserStore((s) => [
43
- s.useFetchProviderModelList,
44
- s.clearObtainedModels,
45
- s.setModelProviderConfig,
46
- ]);
47
- const enabledAutoFetch = useUserStore(modelConfigSelectors.isAutoFetchModelsEnabled(provider));
48
- const latestFetchTime = useUserStore(
49
- (s) => settingsSelectors.providerConfig(provider)(s)?.latestFetchTime,
50
- );
51
- const totalModels = useUserStore(
52
- (s) => modelProviderSelectors.getModelCardsById(provider)(s).length,
53
- );
54
-
55
- const remoteModels = useUserStore(
56
- modelProviderSelectors.remoteProviderModelCards(provider),
57
- isEqual,
58
- );
59
-
60
- const { mutate, isValidating } = useFetchProviderModelList(provider, enabledAutoFetch);
61
-
62
- return (
63
- <Text style={{ fontSize: 12 }} type={'secondary'}>
64
- <Flexbox align={'center'} gap={0} horizontal justify={'space-between'}>
65
- <div style={{ display: 'flex', lineHeight: '24px' }}>
66
- {t('llm.modelList.total', { count: totalModels })}
67
- {remoteModels && remoteModels.length > 0 && (
68
- <ActionIcon
69
- icon={CircleX}
70
- onClick={() => clearObtainedModels(provider)}
71
- size={'small'}
72
- title={t('llm.fetcher.clear')}
73
- />
74
- )}
75
- </div>
76
- <Tooltip
77
- styles={{ root: { pointerEvents: 'none' } }}
78
- title={
79
- latestFetchTime
80
- ? t('llm.fetcher.latestTime', {
81
- time: dayjs(latestFetchTime).format('YYYY-MM-DD HH:mm:ss'),
82
- })
83
- : t('llm.fetcher.noLatestTime')
84
- }
85
- >
86
- <Flexbox
87
- align={'center'}
88
- className={styles.hover}
89
- gap={4}
90
- horizontal
91
- onClick={() => mutate()}
92
- >
93
- <Icon
94
- icon={isValidating ? LucideLoaderCircle : LucideRefreshCcwDot}
95
- size={'small'}
96
- spin={isValidating}
97
- />
98
- <div>{isValidating ? t('llm.fetcher.fetching') : t('llm.fetcher.fetch')}</div>
99
- </Flexbox>
100
- </Tooltip>
101
- </Flexbox>
102
- </Text>
103
- );
104
- });
105
- export default ModelFetcher;
@@ -1,68 +0,0 @@
1
- import { ModelIcon } from '@lobehub/icons';
2
- import { ActionIcon, Text, Tooltip } from '@lobehub/ui';
3
- import { useTheme } from 'antd-style';
4
- import isEqual from 'fast-deep-equal';
5
- import { Recycle } from 'lucide-react';
6
- import { memo } from 'react';
7
- import { useTranslation } from 'react-i18next';
8
- import { Flexbox } from 'react-layout-kit';
9
-
10
- import { ModelInfoTags } from '@/components/ModelSelect';
11
- import { useUserStore } from '@/store/user';
12
- import { modelProviderSelectors } from '@/store/user/selectors';
13
- import { GlobalLLMProviderKey } from '@/types/user/settings';
14
-
15
- import CustomModelOption from './CustomModelOption';
16
-
17
- interface OptionRenderProps {
18
- displayName: string;
19
- id: string;
20
- isAzure?: boolean;
21
- provider: GlobalLLMProviderKey;
22
- removed?: boolean;
23
- }
24
- const OptionRender = memo<OptionRenderProps>(({ displayName, id, provider, isAzure, removed }) => {
25
- const model = useUserStore(
26
- (s) => modelProviderSelectors.getModelCardById(id, provider)(s),
27
- isEqual,
28
- );
29
- const { t } = useTranslation('components');
30
- const theme = useTheme();
31
- // if there is isCustom, it means it is a user defined custom model
32
- if (model?.isCustom || isAzure) return <CustomModelOption id={id} provider={provider} />;
33
-
34
- return (
35
- <Flexbox
36
- align={'center'}
37
- gap={8}
38
- horizontal
39
- justify={'space-between'}
40
- style={{ paddingInlineEnd: 8 }}
41
- >
42
- <Flexbox align={'center'} gap={8} horizontal>
43
- <ModelIcon model={id} size={32} />
44
- <Flexbox>
45
- <Flexbox align={'center'} gap={8} horizontal>
46
- {displayName}
47
- <ModelInfoTags directionReverse placement={'top'} {...model!} />
48
- </Flexbox>
49
- <Text style={{ fontSize: 12 }} type={'secondary'}>
50
- {id}
51
- </Text>
52
- </Flexbox>
53
- </Flexbox>
54
- {removed && (
55
- <Tooltip
56
- placement={'top'}
57
- style={{ pointerEvents: 'none' }}
58
- styles={{ root: { maxWidth: 300 } }}
59
- title={t('ModelSelect.removed')}
60
- >
61
- <ActionIcon icon={Recycle} style={{ color: theme.colorWarning }} />
62
- </Tooltip>
63
- )}
64
- </Flexbox>
65
- );
66
- });
67
-
68
- export default OptionRender;
@@ -1,146 +0,0 @@
1
- import { ActionIcon, Select } from '@lobehub/ui';
2
- import { css, cx } from 'antd-style';
3
- import isEqual from 'fast-deep-equal';
4
- import { RotateCwIcon } from 'lucide-react';
5
- import { ReactNode, memo } from 'react';
6
- import { useTranslation } from 'react-i18next';
7
- import { Flexbox } from 'react-layout-kit';
8
-
9
- import { useUserStore } from '@/store/user';
10
- import { modelProviderSelectors } from '@/store/user/selectors';
11
- import { GlobalLLMProviderKey } from '@/types/user/settings';
12
-
13
- import ModelConfigModal from './ModelConfigModal';
14
- import ModelFetcher from './ModelFetcher';
15
- import OptionRender from './Option';
16
-
17
- const styles = {
18
- divStyle: css`
19
- position: relative;
20
-
21
- .ant-select-selector {
22
- padding-inline-end: 50px !important;
23
- }
24
- `,
25
- popup: css`
26
- &.ant-select-dropdown {
27
- .ant-select-item-option-selected {
28
- font-weight: normal;
29
- }
30
- }
31
- `,
32
- reset: css`
33
- position: absolute;
34
- z-index: 20;
35
- inset-block-start: 50%;
36
- inset-inline-end: 28px;
37
- transform: translateY(-50%);
38
- `,
39
- };
40
-
41
- interface CustomModelSelectProps {
42
- notFoundContent?: ReactNode;
43
- placeholder?: string;
44
- provider: GlobalLLMProviderKey;
45
- showAzureDeployName?: boolean;
46
- showModelFetcher?: boolean;
47
- }
48
-
49
- const ProviderModelListSelect = memo<CustomModelSelectProps>(
50
- ({ showModelFetcher = false, provider, showAzureDeployName, notFoundContent, placeholder }) => {
51
- const { t } = useTranslation('common');
52
- const { t: transSetting } = useTranslation('setting');
53
- const [setModelProviderConfig, updateEnabledModels] = useUserStore((s) => [
54
- s.setModelProviderConfig,
55
- s.updateEnabledModels,
56
- ]);
57
-
58
- const chatModelCards = useUserStore(
59
- modelProviderSelectors.getModelCardsById(provider),
60
- isEqual,
61
- );
62
-
63
- const defaultEnableModel = useUserStore(
64
- modelProviderSelectors.getDefaultEnabledModelsById(provider),
65
- isEqual,
66
- );
67
- const enabledModels = useUserStore(
68
- modelProviderSelectors.getEnableModelsById(provider),
69
- isEqual,
70
- );
71
-
72
- const showReset = !!enabledModels && !isEqual(defaultEnableModel, enabledModels);
73
-
74
- return (
75
- <>
76
- <Flexbox gap={8}>
77
- <div className={cx(styles.divStyle)}>
78
- <div className={cx(styles.reset)}>
79
- {showReset && (
80
- <ActionIcon
81
- icon={RotateCwIcon}
82
- onClick={() => {
83
- setModelProviderConfig(provider, { enabledModels: null });
84
- }}
85
- size={'small'}
86
- title={t('reset')}
87
- />
88
- )}
89
- </div>
90
- <Select
91
- allowClear
92
- mode="tags"
93
- notFoundContent={notFoundContent}
94
- onChange={(value, options) => {
95
- updateEnabledModels(provider, value, options as any[]);
96
- }}
97
- optionFilterProp="label"
98
- optionRender={({ label, value }) => {
99
- // model is in the chatModels
100
- if (chatModelCards.some((c) => c.id === value))
101
- return (
102
- <OptionRender
103
- displayName={label as string}
104
- id={value as string}
105
- isAzure={showAzureDeployName}
106
- provider={provider}
107
- />
108
- );
109
-
110
- if (enabledModels?.some((m) => value === m)) {
111
- return (
112
- <OptionRender
113
- displayName={label as string}
114
- id={value as string}
115
- isAzure={showAzureDeployName}
116
- provider={provider}
117
- removed
118
- />
119
- );
120
- }
121
-
122
- // model is defined by user in client
123
- return (
124
- <Flexbox align={'center'} gap={8} horizontal>
125
- {transSetting('llm.customModelCards.addNew', { id: value })}
126
- </Flexbox>
127
- );
128
- }}
129
- options={chatModelCards.map((model) => ({
130
- label: model.displayName || model.id,
131
- value: model.id,
132
- }))}
133
- placeholder={placeholder}
134
- popupClassName={cx(styles.popup)}
135
- value={enabledModels ?? defaultEnableModel}
136
- />
137
- </div>
138
- {showModelFetcher && <ModelFetcher provider={provider} />}
139
- </Flexbox>
140
- <ModelConfigModal provider={provider} showAzureDeployName={showAzureDeployName} />
141
- </>
142
- );
143
- },
144
- );
145
-
146
- export default ProviderModelListSelect;
@@ -1,20 +0,0 @@
1
- export const LLMProviderConfigKey = 'languageModel';
2
- export const KeyVaultsConfigKey = 'keyVaults';
3
-
4
- /**
5
- * we use this key to define default api key
6
- * equal GOOGLE_API_KEY or ZHIPU_API_KEY
7
- */
8
- export const LLMProviderApiTokenKey = 'apiKey';
9
-
10
- /**
11
- * we use this key to define the baseURL
12
- * equal OPENAI_PROXY_URL
13
- */
14
- export const LLMProviderBaseUrlKey = 'baseURL';
15
-
16
- /**
17
- * we use this key to define the custom model name
18
- * equal CUSTOM_MODELS
19
- */
20
- export const LLMProviderModelListKey = 'enabledModels';
@@ -1,35 +0,0 @@
1
- 'use client';
2
-
3
- import { useTheme } from 'antd-style';
4
- import Link from 'next/link';
5
- import { memo } from 'react';
6
- import { Trans } from 'react-i18next';
7
- import { Center } from 'react-layout-kit';
8
-
9
- import { MORE_MODEL_PROVIDER_REQUEST_URL } from '@/const/url';
10
-
11
- const Footer = memo(() => {
12
- const theme = useTheme();
13
- return (
14
- <Center
15
- style={{
16
- background: theme.colorFillQuaternary,
17
- border: `1px dashed ${theme.colorFillSecondary}`,
18
- borderRadius: theme.borderRadiusLG,
19
- padding: 12,
20
- }}
21
- >
22
- <div style={{ color: theme.colorTextSecondary, fontSize: 12, textAlign: 'center' }}>
23
- <Trans i18nKey="llm.waitingForMore" ns={'setting'}>
24
- 更多模型正在
25
- <Link aria-label={'todo'} href={MORE_MODEL_PROVIDER_REQUEST_URL} target="_blank">
26
- 计划接入
27
- </Link>
28
- 中 ,敬请期待
29
- </Trans>
30
- </div>
31
- </Center>
32
- );
33
- });
34
-
35
- export default Footer;
@@ -1,30 +0,0 @@
1
- 'use client';
2
-
3
- import { isCustomBranding } from '@/const/version';
4
-
5
- import { useProviderList } from './ProviderList/providers';
6
- import ProviderConfig from './components/ProviderConfig';
7
- import Footer from './features/Footer';
8
-
9
- const Page = () => {
10
- const list = useProviderList();
11
-
12
- return (
13
- <div
14
- style={{
15
- display: 'flex',
16
- flexDirection: 'column',
17
- gap: 24,
18
- }}
19
- >
20
- {list.map(({ id, ...res }) => (
21
- <ProviderConfig id={id as any} key={id} {...res} />
22
- ))}
23
- {!isCustomBranding && <Footer />}
24
- </div>
25
- );
26
- };
27
-
28
- Page.displayName = 'LlmSetting';
29
-
30
- export default Page;
@@ -1,5 +0,0 @@
1
- import { ProviderConfigProps } from './components/ProviderConfig';
2
-
3
- export interface ProviderItem extends Omit<ProviderConfigProps, 'id'> {
4
- id: string;
5
- }