@lobehub/chat 1.96.19 → 1.97.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (509) hide show
  1. package/.env.example +7 -0
  2. package/CHANGELOG.md +50 -0
  3. package/apps/desktop/package.json +1 -1
  4. package/apps/desktop/src/main/core/Browser.ts +2 -1
  5. package/apps/desktop/src/main/utils/next-electron-rsc.ts +15 -8
  6. package/changelog/v1.json +18 -0
  7. package/locales/ar/discover.json +452 -12
  8. package/locales/ar/metadata.json +4 -0
  9. package/locales/ar/plugin.json +89 -2
  10. package/locales/ar/setting.json +1 -0
  11. package/locales/bg-BG/discover.json +452 -12
  12. package/locales/bg-BG/metadata.json +4 -0
  13. package/locales/bg-BG/plugin.json +89 -2
  14. package/locales/bg-BG/setting.json +1 -0
  15. package/locales/de-DE/discover.json +452 -12
  16. package/locales/de-DE/metadata.json +4 -0
  17. package/locales/de-DE/plugin.json +89 -2
  18. package/locales/de-DE/setting.json +1 -0
  19. package/locales/en-US/discover.json +452 -12
  20. package/locales/en-US/metadata.json +4 -0
  21. package/locales/en-US/plugin.json +89 -2
  22. package/locales/en-US/setting.json +1 -0
  23. package/locales/es-ES/discover.json +452 -12
  24. package/locales/es-ES/metadata.json +4 -0
  25. package/locales/es-ES/plugin.json +89 -2
  26. package/locales/es-ES/setting.json +1 -0
  27. package/locales/fa-IR/discover.json +452 -12
  28. package/locales/fa-IR/metadata.json +4 -0
  29. package/locales/fa-IR/plugin.json +89 -2
  30. package/locales/fa-IR/setting.json +1 -0
  31. package/locales/fr-FR/discover.json +452 -12
  32. package/locales/fr-FR/metadata.json +4 -0
  33. package/locales/fr-FR/plugin.json +89 -2
  34. package/locales/fr-FR/setting.json +1 -0
  35. package/locales/it-IT/discover.json +452 -12
  36. package/locales/it-IT/metadata.json +4 -0
  37. package/locales/it-IT/plugin.json +89 -2
  38. package/locales/it-IT/setting.json +1 -0
  39. package/locales/ja-JP/discover.json +452 -12
  40. package/locales/ja-JP/metadata.json +4 -0
  41. package/locales/ja-JP/plugin.json +89 -2
  42. package/locales/ja-JP/setting.json +1 -0
  43. package/locales/ko-KR/discover.json +452 -12
  44. package/locales/ko-KR/metadata.json +4 -0
  45. package/locales/ko-KR/plugin.json +89 -2
  46. package/locales/ko-KR/setting.json +1 -0
  47. package/locales/nl-NL/discover.json +452 -12
  48. package/locales/nl-NL/metadata.json +4 -0
  49. package/locales/nl-NL/plugin.json +89 -2
  50. package/locales/nl-NL/setting.json +1 -0
  51. package/locales/pl-PL/discover.json +452 -12
  52. package/locales/pl-PL/metadata.json +4 -0
  53. package/locales/pl-PL/plugin.json +89 -2
  54. package/locales/pl-PL/setting.json +1 -0
  55. package/locales/pt-BR/discover.json +452 -12
  56. package/locales/pt-BR/metadata.json +4 -0
  57. package/locales/pt-BR/plugin.json +89 -2
  58. package/locales/pt-BR/setting.json +1 -0
  59. package/locales/ru-RU/discover.json +452 -12
  60. package/locales/ru-RU/metadata.json +4 -0
  61. package/locales/ru-RU/plugin.json +89 -2
  62. package/locales/ru-RU/setting.json +1 -0
  63. package/locales/tr-TR/discover.json +452 -12
  64. package/locales/tr-TR/metadata.json +4 -0
  65. package/locales/tr-TR/plugin.json +89 -2
  66. package/locales/tr-TR/setting.json +1 -0
  67. package/locales/vi-VN/discover.json +452 -12
  68. package/locales/vi-VN/metadata.json +4 -0
  69. package/locales/vi-VN/plugin.json +89 -2
  70. package/locales/vi-VN/setting.json +1 -0
  71. package/locales/zh-CN/discover.json +452 -12
  72. package/locales/zh-CN/metadata.json +8 -4
  73. package/locales/zh-CN/plugin.json +89 -2
  74. package/locales/zh-CN/setting.json +1 -0
  75. package/locales/zh-TW/discover.json +452 -12
  76. package/locales/zh-TW/metadata.json +4 -0
  77. package/locales/zh-TW/plugin.json +89 -2
  78. package/locales/zh-TW/setting.json +1 -0
  79. package/next.config.ts +70 -19
  80. package/package.json +6 -2
  81. package/scripts/buildSitemapIndex/index.ts +9 -4
  82. package/src/app/(backend)/trpc/lambda/[trpc]/route.ts +5 -0
  83. package/src/app/[variants]/(main)/_layout/Mobile/index.tsx +5 -4
  84. package/src/app/[variants]/(main)/chat/(workspace)/@conversation/features/ChatList/WelcomeChatItem/InboxWelcome/AgentsSuggest.tsx +31 -45
  85. package/src/app/[variants]/(main)/discover/(detail)/_layout/Desktop.tsx +8 -6
  86. package/src/app/[variants]/(main)/discover/(detail)/_layout/Mobile/Header.tsx +3 -2
  87. package/src/app/[variants]/(main)/discover/(detail)/_layout/Mobile/index.tsx +5 -1
  88. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/Client.tsx +40 -0
  89. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/DetailProvider.tsx +19 -0
  90. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/Capabilities/Block.tsx +27 -0
  91. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/Capabilities/Knowledge.tsx +33 -0
  92. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/Capabilities/KnowledgeItem.tsx +58 -0
  93. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/Capabilities/PluginItem.tsx +68 -0
  94. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/Capabilities/Plugins.tsx +32 -0
  95. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/Capabilities/index.tsx +37 -0
  96. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/Nav.tsx +121 -0
  97. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/Overview/TagList.tsx +47 -0
  98. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/Overview/index.tsx +96 -0
  99. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/Related/index.tsx +31 -0
  100. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/SystemRole/TagList.tsx +47 -0
  101. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/SystemRole/index.tsx +54 -0
  102. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/index.tsx +49 -0
  103. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Header.tsx +176 -0
  104. package/src/app/[variants]/(main)/discover/(detail)/assistant/{[slug]/features → [...slugs]/features/Sidebar/ActionButton}/AddAgent.tsx +22 -21
  105. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Sidebar/ActionButton/index.tsx +31 -0
  106. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Sidebar/Related/Item.tsx +57 -0
  107. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Sidebar/Related/index.tsx +43 -0
  108. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Sidebar/Summary/index.tsx +38 -0
  109. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Sidebar/TocList/index.tsx +77 -0
  110. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Sidebar/index.tsx +46 -0
  111. package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/loading.tsx +48 -0
  112. package/src/app/[variants]/(main)/discover/(detail)/{plugin/[slug] → assistant/[...slugs]}/page.tsx +39 -42
  113. package/src/app/[variants]/(main)/discover/(detail)/features/Breadcrumb.tsx +56 -0
  114. package/src/app/[variants]/(main)/discover/(detail)/features/DetailLayout.tsx +0 -1
  115. package/src/app/[variants]/(main)/discover/(detail)/features/MakedownRender.tsx +44 -0
  116. package/src/app/[variants]/(main)/discover/(detail)/features/ShareButton.tsx +4 -3
  117. package/src/app/[variants]/(main)/discover/(detail)/features/Toc/Heading.tsx +108 -0
  118. package/src/app/[variants]/(main)/discover/(detail)/features/Toc/index.tsx +92 -0
  119. package/src/app/[variants]/(main)/discover/(detail)/features/Toc/useToc.tsx +66 -0
  120. package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/Client.tsx +43 -0
  121. package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/features/Details/Related/index.tsx +32 -0
  122. package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/features/Details/Versions/index.tsx +76 -0
  123. package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/features/Details/index.tsx +59 -0
  124. package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/features/Sidebar/ActionButton/index.tsx +84 -0
  125. package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/features/Sidebar/ConnectionTypeAlert.tsx +35 -0
  126. package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/features/Sidebar/Related/Item.tsx +57 -0
  127. package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/features/Sidebar/Related/index.tsx +44 -0
  128. package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/features/Sidebar/ServerConfig.tsx +36 -0
  129. package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/features/Sidebar/TocList/index.tsx +98 -0
  130. package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/features/Sidebar/index.tsx +58 -0
  131. package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/loading.tsx +1 -0
  132. package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/page.tsx +103 -0
  133. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/Client.tsx +40 -0
  134. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/DetailProvider.tsx +19 -0
  135. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Details/Nav.tsx +90 -0
  136. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Details/Overview/ProviderList/index.tsx +179 -0
  137. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Details/Overview/index.tsx +22 -0
  138. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/{ParameterList → Details/Parameter}/ParameterItem.tsx +1 -1
  139. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/{ParameterList → Details/Parameter}/index.tsx +11 -11
  140. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Details/Related/index.tsx +31 -0
  141. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Details/index.tsx +47 -0
  142. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Header.tsx +84 -59
  143. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Sidebar/ActionButton/ChatWithModel.tsx +92 -0
  144. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Sidebar/ActionButton/index.tsx +32 -0
  145. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Sidebar/Related/Item.tsx +60 -0
  146. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Sidebar/Related/index.tsx +43 -0
  147. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Sidebar/RelatedProviders/Item.tsx +60 -0
  148. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Sidebar/RelatedProviders/index.tsx +34 -0
  149. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Sidebar/index.tsx +44 -0
  150. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/loading.tsx +1 -0
  151. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/page.tsx +22 -45
  152. package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/Client.tsx +40 -0
  153. package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/DetailProvider.tsx +19 -0
  154. package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Details/Guide/index.tsx +25 -0
  155. package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Details/Nav.tsx +99 -0
  156. package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Details/Overview/ModelList/index.tsx +142 -0
  157. package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Details/Overview/index.tsx +23 -0
  158. package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Details/Related/index.tsx +22 -0
  159. package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Details/index.tsx +47 -0
  160. package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Header.tsx +99 -0
  161. package/src/app/[variants]/(main)/discover/(detail)/provider/{[slug]/features → [...slugs]/features/Sidebar/ActionButton}/ProviderConfig.tsx +9 -14
  162. package/src/app/[variants]/(main)/discover/(detail)/provider/{[slug]/features/Actions.tsx → [...slugs]/features/Sidebar/ActionButton/index.tsx} +14 -18
  163. package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Sidebar/Related/Item.tsx +60 -0
  164. package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Sidebar/Related/index.tsx +34 -0
  165. package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Sidebar/RelatedModels/Item.tsx +60 -0
  166. package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Sidebar/RelatedModels/index.tsx +43 -0
  167. package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Sidebar/index.tsx +44 -0
  168. package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/loading.tsx +1 -0
  169. package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/page.tsx +103 -0
  170. package/src/app/[variants]/(main)/discover/(list)/(home)/Client.tsx +24 -21
  171. package/src/app/[variants]/(main)/discover/(list)/(home)/loading.tsx +1 -1
  172. package/src/app/[variants]/(main)/discover/(list)/(home)/page.tsx +13 -38
  173. package/src/app/[variants]/(main)/discover/(list)/_layout/Desktop/Nav.tsx +15 -8
  174. package/src/app/[variants]/(main)/discover/(list)/_layout/Mobile/Header.tsx +1 -1
  175. package/src/app/[variants]/(main)/discover/(list)/_layout/Mobile/Nav.tsx +2 -1
  176. package/src/app/[variants]/(main)/discover/(list)/assistant/Client.tsx +44 -0
  177. package/src/app/[variants]/(main)/discover/(list)/assistant/features/Category/index.tsx +84 -0
  178. package/src/app/[variants]/(main)/discover/(list)/assistant/features/Category/useCategory.tsx +112 -0
  179. package/src/app/[variants]/(main)/discover/(list)/assistant/features/List/Item.tsx +189 -0
  180. package/src/app/[variants]/(main)/discover/(list)/assistant/features/List/TokenTag.tsx +70 -0
  181. package/src/app/[variants]/(main)/discover/(list)/assistant/features/List/index.tsx +33 -0
  182. package/src/app/[variants]/(main)/discover/(list)/assistant/page.tsx +46 -0
  183. package/src/app/[variants]/(main)/discover/(list)/features/Pagination.tsx +67 -0
  184. package/src/app/[variants]/(main)/discover/(list)/features/SortButton/index.tsx +184 -0
  185. package/src/app/[variants]/(main)/discover/(list)/mcp/Client.tsx +44 -0
  186. package/src/app/[variants]/(main)/discover/(list)/mcp/features/Category/index.tsx +83 -0
  187. package/src/app/[variants]/(main)/discover/(list)/mcp/features/List/ConnectionTypeTag.tsx +51 -0
  188. package/src/app/[variants]/(main)/discover/(list)/mcp/features/List/Item.tsx +225 -0
  189. package/src/app/[variants]/(main)/discover/(list)/mcp/features/List/MetaInfo.tsx +33 -0
  190. package/src/app/[variants]/(main)/discover/(list)/mcp/features/List/index.tsx +33 -0
  191. package/src/app/[variants]/(main)/discover/(list)/mcp/page.tsx +46 -0
  192. package/src/app/[variants]/(main)/discover/(list)/model/Client.tsx +44 -0
  193. package/src/app/[variants]/(main)/discover/(list)/{models → model}/_layout/Desktop.tsx +1 -7
  194. package/src/app/[variants]/(main)/discover/(list)/model/features/Category/index.tsx +82 -0
  195. package/src/app/[variants]/(main)/discover/(list)/model/features/Category/useCategory.tsx +41 -0
  196. package/src/app/[variants]/(main)/discover/(list)/model/features/List/Item.tsx +190 -0
  197. package/src/app/[variants]/(main)/discover/(list)/model/features/List/ModelTypeIcon.tsx +39 -0
  198. package/src/app/[variants]/(main)/discover/(list)/model/features/List/index.tsx +33 -0
  199. package/src/app/[variants]/(main)/discover/(list)/model/loading.tsx +1 -0
  200. package/src/app/[variants]/(main)/discover/(list)/model/page.tsx +44 -0
  201. package/src/app/[variants]/(main)/discover/(list)/provider/Client.tsx +43 -0
  202. package/src/app/[variants]/(main)/discover/(list)/provider/features/List/Item.tsx +136 -0
  203. package/src/app/[variants]/(main)/discover/(list)/provider/features/List/index.tsx +33 -0
  204. package/src/app/[variants]/(main)/discover/(list)/provider/loading.tsx +1 -0
  205. package/src/app/[variants]/(main)/discover/(list)/provider/page.tsx +44 -0
  206. package/src/app/[variants]/(main)/discover/_layout/Desktop/Header.tsx +1 -1
  207. package/src/app/[variants]/(main)/discover/components/CategoryContainer.tsx +7 -5
  208. package/src/app/[variants]/(main)/discover/components/CategoryMenu.tsx +28 -30
  209. package/src/app/[variants]/(main)/discover/components/ListLoading.tsx +56 -46
  210. package/src/app/[variants]/(main)/discover/components/Statistic.tsx +5 -6
  211. package/src/app/[variants]/(main)/discover/features/Search.tsx +62 -0
  212. package/src/app/[variants]/(main)/discover/features/Title.tsx +83 -0
  213. package/src/app/[variants]/(main)/discover/features/__tests__/calculateScore.test.ts +185 -0
  214. package/src/app/[variants]/(main)/discover/features/useNav.tsx +32 -12
  215. package/src/app/robots.tsx +7 -5
  216. package/src/app/sitemap.tsx +81 -13
  217. package/src/components/CopyableLabel/index.tsx +37 -0
  218. package/src/components/Descriptions/index.tsx +119 -0
  219. package/src/components/InlineTable/index.tsx +69 -0
  220. package/src/{features/PluginSettings/PluginSettingRender.tsx → components/JSONSchemaConfig/ItemRender.tsx} +3 -3
  221. package/src/components/MCPDepsIcon/Java.tsx +23 -0
  222. package/src/components/MCPDepsIcon/PowerShell.tsx +23 -0
  223. package/src/components/MCPDepsIcon/Terminal.tsx +23 -0
  224. package/src/components/MCPDepsIcon/UV.tsx +23 -0
  225. package/src/components/MCPDepsIcon/index.tsx +72 -0
  226. package/src/components/MCPStdioCommandInput/index.tsx +47 -0
  227. package/src/components/OfficialIcon.tsx +23 -0
  228. package/src/components/Plugins/MCPTag.tsx +18 -0
  229. package/src/components/Plugins/PluginTag.tsx +50 -0
  230. package/src/components/PublishedTime.tsx +71 -0
  231. package/src/config/__tests__/app.test.ts +6 -2
  232. package/src/const/discover.ts +8 -34
  233. package/src/database/models/message.ts +1 -0
  234. package/src/database/models/plugin.ts +13 -3
  235. package/src/envs/app.ts +1 -1
  236. package/src/features/AgentSetting/AgentPlugin/index.tsx +2 -2
  237. package/src/features/ChatInput/ActionBar/Tools/ToolItem.tsx +1 -1
  238. package/src/features/ChatInput/ActionBar/Tools/useControls.tsx +5 -5
  239. package/src/features/Conversation/Messages/Assistant/Tool/Inspector/index.tsx +25 -11
  240. package/src/features/MCP/MCPInstallProgress/InstallError/ErrorDetails.tsx +110 -0
  241. package/src/features/MCP/MCPInstallProgress/InstallError/index.tsx +51 -0
  242. package/src/features/MCP/MCPInstallProgress/MCPConfigForm.tsx +151 -0
  243. package/src/features/MCP/MCPInstallProgress/MCPDependenciesGuide.tsx +217 -0
  244. package/src/features/MCP/MCPInstallProgress/index.tsx +118 -0
  245. package/src/features/MCP/Scores.tsx +268 -0
  246. package/src/features/MCP/calculateScore.ts +324 -0
  247. package/src/features/MCP/useScoreList.ts +126 -0
  248. package/src/features/MCP/utils.ts +225 -0
  249. package/src/features/MCPPluginDetail/CollapseDesc.tsx +44 -0
  250. package/src/features/MCPPluginDetail/CollapseLayout.tsx +34 -0
  251. package/src/features/MCPPluginDetail/Deployment/Platform/index.tsx +47 -0
  252. package/src/features/MCPPluginDetail/Deployment/index.tsx +322 -0
  253. package/src/features/MCPPluginDetail/DetailProvider.tsx +19 -0
  254. package/src/features/MCPPluginDetail/Header.tsx +218 -0
  255. package/src/features/MCPPluginDetail/Nav.tsx +196 -0
  256. package/src/features/MCPPluginDetail/Overview/TagList.tsx +47 -0
  257. package/src/features/MCPPluginDetail/Overview/index.tsx +57 -0
  258. package/src/features/MCPPluginDetail/Schema/Block.tsx +50 -0
  259. package/src/features/MCPPluginDetail/Schema/Prompts.tsx +125 -0
  260. package/src/features/MCPPluginDetail/Schema/Resources.tsx +70 -0
  261. package/src/features/MCPPluginDetail/Schema/Tools.tsx +146 -0
  262. package/src/features/MCPPluginDetail/Schema/index.tsx +63 -0
  263. package/src/features/MCPPluginDetail/Schema/style.ts +9 -0
  264. package/src/features/MCPPluginDetail/Schema/types.ts +4 -0
  265. package/src/features/MCPPluginDetail/Score/GithubBadge/index.tsx +82 -0
  266. package/src/features/MCPPluginDetail/Score/ScoreItem.tsx +34 -0
  267. package/src/features/MCPPluginDetail/Score/ScoreList.tsx +24 -0
  268. package/src/features/MCPPluginDetail/Score/TotalScore.tsx +289 -0
  269. package/src/features/MCPPluginDetail/Score/index.tsx +88 -0
  270. package/src/features/PluginAvatar/index.tsx +1 -1
  271. package/src/features/PluginDetailModal/Meta.tsx +3 -4
  272. package/src/features/PluginDevModal/MCPManifestForm/MCPTypeSelect.tsx +3 -4
  273. package/src/features/PluginDevModal/MCPManifestForm/index.tsx +4 -41
  274. package/src/features/PluginDevModal/PluginPreview/EmptyState.tsx +5 -7
  275. package/src/features/PluginDevModal/PluginPreview/index.tsx +6 -6
  276. package/src/features/PluginSettings/index.tsx +2 -2
  277. package/src/features/PluginStore/AddPluginButton.tsx +1 -1
  278. package/src/features/PluginStore/Content.tsx +59 -0
  279. package/src/features/PluginStore/InstalledList/Detail/CustomPluginEmptyState.tsx +81 -0
  280. package/src/features/PluginStore/InstalledList/Detail/index.tsx +21 -0
  281. package/src/features/PluginStore/InstalledList/EditCustomPlugin.tsx +52 -0
  282. package/src/features/PluginStore/{PluginItem → InstalledList/List/Item}/Action.tsx +33 -13
  283. package/src/features/PluginStore/InstalledList/List/Item/index.tsx +62 -0
  284. package/src/features/PluginStore/InstalledList/List/index.tsx +77 -0
  285. package/src/features/PluginStore/InstalledList/index.tsx +85 -0
  286. package/src/features/PluginStore/Loading.tsx +2 -2
  287. package/src/features/PluginStore/McpList/Detail/Loading.tsx +44 -0
  288. package/src/features/PluginStore/McpList/Detail/Settings/index.tsx +381 -0
  289. package/src/features/PluginStore/McpList/Detail/index.tsx +71 -0
  290. package/src/features/PluginStore/McpList/List/Action.tsx +94 -0
  291. package/src/features/PluginStore/McpList/List/Item.tsx +84 -0
  292. package/src/features/PluginStore/McpList/List/index.tsx +97 -0
  293. package/src/features/PluginStore/McpList/index.tsx +54 -0
  294. package/src/features/PluginStore/PluginList/Detail/DetailProvider.tsx +19 -0
  295. package/src/features/PluginStore/PluginList/Detail/EmptyState.tsx +58 -0
  296. package/src/features/PluginStore/PluginList/Detail/Header.tsx +132 -0
  297. package/src/features/PluginStore/PluginList/Detail/InstallDetail/Nav.tsx +75 -0
  298. package/src/features/PluginStore/PluginList/Detail/InstallDetail/Settings.tsx +19 -0
  299. package/src/features/PluginStore/PluginList/Detail/InstallDetail/Tools.tsx +109 -0
  300. package/src/features/PluginStore/PluginList/Detail/InstallDetail/index.tsx +24 -0
  301. package/src/features/PluginStore/PluginList/Detail/Loading.tsx +44 -0
  302. package/src/features/PluginStore/PluginList/Detail/TagList.tsx +37 -0
  303. package/src/features/PluginStore/PluginList/Detail/index.tsx +39 -0
  304. package/src/features/PluginStore/PluginList/Detail/useCategory.tsx +76 -0
  305. package/src/features/PluginStore/PluginList/List/Action.tsx +72 -0
  306. package/src/features/PluginStore/PluginList/List/Item.tsx +94 -0
  307. package/src/features/PluginStore/PluginList/List/index.tsx +91 -0
  308. package/src/features/PluginStore/PluginList/index.tsx +47 -0
  309. package/src/features/PluginStore/Search/index.tsx +29 -0
  310. package/src/features/PluginStore/VirtuosoLoading.tsx +16 -0
  311. package/src/features/PluginStore/index.tsx +7 -31
  312. package/src/features/PluginTag/index.tsx +6 -4
  313. package/src/hooks/useInterceptingRoutes.test.ts +6 -0
  314. package/src/hooks/useMCPCategory.tsx +133 -0
  315. package/src/hooks/useQuery.ts +8 -0
  316. package/src/hooks/useQueryRoute.test.ts +7 -0
  317. package/src/hooks/useQueryRoute.ts +5 -3
  318. package/src/libs/mcp/client.ts +265 -13
  319. package/src/libs/mcp/types.ts +99 -0
  320. package/src/libs/trpc/client/desktop.ts +2 -3
  321. package/src/libs/trpc/lambda/context.ts +36 -5
  322. package/src/libs/trpc/lambda/index.ts +1 -1
  323. package/src/libs/trpc/lambda/init.ts +8 -1
  324. package/src/locales/default/discover.ts +457 -12
  325. package/src/locales/default/metadata.ts +9 -4
  326. package/src/locales/default/plugin.ts +89 -1
  327. package/src/locales/default/setting.ts +1 -0
  328. package/src/locales/resources.ts +1 -1
  329. package/src/middleware.ts +13 -3
  330. package/src/server/ld.ts +4 -3
  331. package/src/server/modules/AssistantStore/index.test.ts +10 -8
  332. package/src/server/modules/AssistantStore/index.ts +37 -17
  333. package/src/server/modules/PluginStore/index.test.ts +1 -1
  334. package/src/server/modules/PluginStore/index.ts +24 -1
  335. package/src/server/routers/desktop/mcp.ts +36 -2
  336. package/src/server/routers/edge/index.ts +0 -6
  337. package/src/server/routers/{edge → lambda}/config/index.ts +1 -1
  338. package/src/server/routers/lambda/index.ts +4 -0
  339. package/src/server/routers/lambda/market/index.ts +621 -0
  340. package/src/server/routers/lambda/plugin.ts +2 -0
  341. package/src/server/routers/tools/mcp.ts +22 -0
  342. package/src/server/services/discover/index.test.ts +573 -250
  343. package/src/server/services/discover/index.ts +1096 -241
  344. package/src/server/services/mcp/deps/MCPSystemDepsCheckService.ts +238 -0
  345. package/src/server/services/mcp/deps/checkers/ManualInstallationChecker.ts +20 -0
  346. package/src/server/services/mcp/deps/checkers/NpmInstallationChecker.ts +51 -0
  347. package/src/server/services/mcp/deps/checkers/PythonInstallationChecker.ts +69 -0
  348. package/src/server/services/mcp/deps/index.ts +14 -0
  349. package/src/server/services/mcp/deps/types.ts +49 -0
  350. package/src/server/services/mcp/index.ts +251 -33
  351. package/src/server/sitemap.test.ts +203 -46
  352. package/src/server/sitemap.ts +159 -52
  353. package/src/services/__tests__/global.test.ts +4 -7
  354. package/src/services/__tests__/tool.test.ts +1 -29
  355. package/src/services/discover.ts +365 -0
  356. package/src/services/global.ts +3 -3
  357. package/src/services/mcp.ts +131 -10
  358. package/src/services/plugin/_deprecated.ts +1 -1
  359. package/src/services/plugin/type.ts +3 -1
  360. package/src/services/tool.ts +9 -6
  361. package/src/store/chat/slices/plugin/action.test.ts +2 -3
  362. package/src/store/chat/slices/plugin/action.ts +22 -4
  363. package/src/store/discover/index.ts +1 -0
  364. package/src/store/discover/slices/assistant/action.ts +73 -0
  365. package/src/store/discover/slices/assistant/index.ts +1 -0
  366. package/src/store/discover/slices/mcp/action.ts +70 -0
  367. package/src/store/discover/slices/mcp/index.ts +1 -0
  368. package/src/store/discover/slices/model/action.ts +70 -0
  369. package/src/store/discover/slices/model/index.ts +1 -0
  370. package/src/store/discover/slices/plugin/action.ts +76 -0
  371. package/src/store/discover/slices/plugin/index.ts +1 -0
  372. package/src/store/discover/slices/provider/action.ts +61 -0
  373. package/src/store/discover/slices/provider/index.ts +1 -0
  374. package/src/store/discover/store.ts +39 -0
  375. package/src/store/tool/initialState.ts +8 -2
  376. package/src/store/tool/selectors/index.ts +2 -1
  377. package/src/store/tool/selectors/tool.test.ts +3 -1
  378. package/src/store/tool/selectors/tool.ts +14 -2
  379. package/src/store/tool/slices/mcpStore/action.ts +496 -0
  380. package/src/store/tool/slices/mcpStore/initialState.ts +40 -0
  381. package/src/store/tool/slices/mcpStore/selectors.ts +62 -0
  382. package/src/store/tool/slices/{store → oldStore}/action.test.ts +24 -19
  383. package/src/store/tool/slices/oldStore/action.ts +269 -0
  384. package/src/store/tool/slices/oldStore/index.ts +3 -0
  385. package/src/store/tool/slices/oldStore/initialState.ts +54 -0
  386. package/src/store/tool/slices/{store → oldStore}/selectors.test.ts +6 -3
  387. package/src/store/tool/slices/{store → oldStore}/selectors.ts +18 -5
  388. package/src/store/tool/slices/plugin/action.test.ts +2 -1
  389. package/src/store/tool/slices/plugin/action.ts +22 -4
  390. package/src/store/tool/slices/plugin/selectors.test.ts +12 -4
  391. package/src/store/tool/slices/plugin/selectors.ts +20 -9
  392. package/src/store/tool/store.ts +5 -2
  393. package/src/types/discover/assistants.ts +72 -0
  394. package/src/types/discover/index.ts +41 -0
  395. package/src/types/discover/mcp.ts +59 -0
  396. package/src/types/discover/models.ts +51 -0
  397. package/src/types/discover/plugins.ts +52 -0
  398. package/src/types/discover/providers.ts +47 -0
  399. package/src/types/message/tools.ts +3 -0
  400. package/src/types/plugins/index.ts +53 -0
  401. package/src/types/plugins/mcp.ts +188 -0
  402. package/src/types/plugins/mcpDeps.ts +30 -0
  403. package/src/types/tool/index.ts +10 -0
  404. package/src/types/tool/plugin.ts +3 -2
  405. package/src/types/tool/tool.ts +4 -1
  406. package/src/utils/client/cookie.ts +5 -2
  407. package/src/utils/locale.ts +2 -17
  408. package/src/utils/object.ts +10 -0
  409. package/src/utils/server/pageProps.ts +9 -0
  410. package/src/utils/toolCall.ts +5 -1
  411. package/src/utils/toolManifest.ts +1 -2
  412. package/vercel.json +1 -1
  413. package/src/app/[variants]/(main)/discover/(detail)/assistant/[slug]/features/Actions.tsx +0 -35
  414. package/src/app/[variants]/(main)/discover/(detail)/assistant/[slug]/features/ConversationExample/TopicList.tsx +0 -75
  415. package/src/app/[variants]/(main)/discover/(detail)/assistant/[slug]/features/ConversationExample/index.tsx +0 -105
  416. package/src/app/[variants]/(main)/discover/(detail)/assistant/[slug]/features/Header.tsx +0 -115
  417. package/src/app/[variants]/(main)/discover/(detail)/assistant/[slug]/features/InfoSidebar/SuggestionItem.tsx +0 -62
  418. package/src/app/[variants]/(main)/discover/(detail)/assistant/[slug]/features/InfoSidebar/ToolItem.tsx +0 -19
  419. package/src/app/[variants]/(main)/discover/(detail)/assistant/[slug]/features/InfoSidebar/index.tsx +0 -60
  420. package/src/app/[variants]/(main)/discover/(detail)/assistant/[slug]/features/SystemRole.tsx +0 -35
  421. package/src/app/[variants]/(main)/discover/(detail)/assistant/[slug]/features/Temp.tsx +0 -44
  422. package/src/app/[variants]/(main)/discover/(detail)/assistant/[slug]/page.tsx +0 -124
  423. package/src/app/[variants]/(main)/discover/(detail)/loading.tsx +0 -38
  424. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Actions.tsx +0 -40
  425. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/ChatWithModel.tsx +0 -93
  426. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/InfoSidebar/SuggestionItem.tsx +0 -74
  427. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/InfoSidebar/index.tsx +0 -45
  428. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/ProviderList/ProviderItem.tsx +0 -139
  429. package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/ProviderList/index.tsx +0 -45
  430. package/src/app/[variants]/(main)/discover/(detail)/plugin/[slug]/features/Actions.tsx +0 -35
  431. package/src/app/[variants]/(main)/discover/(detail)/plugin/[slug]/features/Header.tsx +0 -119
  432. package/src/app/[variants]/(main)/discover/(detail)/plugin/[slug]/features/InfoSidebar/SuggestionItem.tsx +0 -64
  433. package/src/app/[variants]/(main)/discover/(detail)/plugin/[slug]/features/InfoSidebar/index.tsx +0 -45
  434. package/src/app/[variants]/(main)/discover/(detail)/plugin/[slug]/features/InstallPlugin.tsx +0 -83
  435. package/src/app/[variants]/(main)/discover/(detail)/plugin/[slug]/features/ParameterList.tsx +0 -95
  436. package/src/app/[variants]/(main)/discover/(detail)/plugin/[slug]/features/Schema.tsx +0 -23
  437. package/src/app/[variants]/(main)/discover/(detail)/provider/[slug]/features/Header.tsx +0 -73
  438. package/src/app/[variants]/(main)/discover/(detail)/provider/[slug]/features/InfoSidebar/SuggestionItem.tsx +0 -77
  439. package/src/app/[variants]/(main)/discover/(detail)/provider/[slug]/features/InfoSidebar/index.tsx +0 -45
  440. package/src/app/[variants]/(main)/discover/(detail)/provider/[slug]/features/ModelList/ModelItem.tsx +0 -152
  441. package/src/app/[variants]/(main)/discover/(detail)/provider/[slug]/features/ModelList/index.tsx +0 -60
  442. package/src/app/[variants]/(main)/discover/(detail)/provider/[slug]/page.tsx +0 -126
  443. package/src/app/[variants]/(main)/discover/(list)/(home)/features/AssistantList.tsx +0 -33
  444. package/src/app/[variants]/(main)/discover/(list)/(home)/features/ModelList.tsx +0 -19
  445. package/src/app/[variants]/(main)/discover/(list)/(home)/features/PluginList.tsx +0 -25
  446. package/src/app/[variants]/(main)/discover/(list)/assistants/[slug]/page.tsx +0 -75
  447. package/src/app/[variants]/(main)/discover/(list)/assistants/features/Card.tsx +0 -195
  448. package/src/app/[variants]/(main)/discover/(list)/assistants/features/Category.tsx +0 -48
  449. package/src/app/[variants]/(main)/discover/(list)/assistants/features/List.tsx +0 -98
  450. package/src/app/[variants]/(main)/discover/(list)/assistants/features/useCategory.tsx +0 -116
  451. package/src/app/[variants]/(main)/discover/(list)/assistants/page.tsx +0 -64
  452. package/src/app/[variants]/(main)/discover/(list)/loading.tsx +0 -39
  453. package/src/app/[variants]/(main)/discover/(list)/models/[slug]/page.tsx +0 -78
  454. package/src/app/[variants]/(main)/discover/(list)/models/features/Card.tsx +0 -118
  455. package/src/app/[variants]/(main)/discover/(list)/models/features/Category.tsx +0 -67
  456. package/src/app/[variants]/(main)/discover/(list)/models/features/List.tsx +0 -71
  457. package/src/app/[variants]/(main)/discover/(list)/models/loading.tsx +0 -1
  458. package/src/app/[variants]/(main)/discover/(list)/models/page.tsx +0 -73
  459. package/src/app/[variants]/(main)/discover/(list)/plugins/[slug]/page.tsx +0 -75
  460. package/src/app/[variants]/(main)/discover/(list)/plugins/features/Card.tsx +0 -161
  461. package/src/app/[variants]/(main)/discover/(list)/plugins/features/Category.tsx +0 -45
  462. package/src/app/[variants]/(main)/discover/(list)/plugins/features/List.tsx +0 -97
  463. package/src/app/[variants]/(main)/discover/(list)/plugins/features/useCategory.tsx +0 -80
  464. package/src/app/[variants]/(main)/discover/(list)/plugins/page.tsx +0 -64
  465. package/src/app/[variants]/(main)/discover/(list)/providers/features/Card.tsx +0 -119
  466. package/src/app/[variants]/(main)/discover/(list)/providers/features/List.tsx +0 -67
  467. package/src/app/[variants]/(main)/discover/(list)/providers/loading.tsx +0 -1
  468. package/src/app/[variants]/(main)/discover/(list)/providers/page.tsx +0 -64
  469. package/src/app/[variants]/(main)/discover/features/StoreSearchBar.tsx +0 -87
  470. package/src/app/[variants]/(main)/discover/loading.tsx +0 -3
  471. package/src/app/[variants]/(main)/discover/search/_layout/Desktop.tsx +0 -42
  472. package/src/app/[variants]/(main)/discover/search/_layout/Mobile/Header.tsx +0 -31
  473. package/src/app/[variants]/(main)/discover/search/_layout/Mobile/Nav.tsx +0 -56
  474. package/src/app/[variants]/(main)/discover/search/_layout/Mobile/index.tsx +0 -32
  475. package/src/app/[variants]/(main)/discover/search/features/AssistantsResult.tsx +0 -27
  476. package/src/app/[variants]/(main)/discover/search/features/Category.tsx +0 -41
  477. package/src/app/[variants]/(main)/discover/search/features/ModelsResult.tsx +0 -27
  478. package/src/app/[variants]/(main)/discover/search/features/PluginsResult.tsx +0 -27
  479. package/src/app/[variants]/(main)/discover/search/features/ProvidersResult.tsx +0 -26
  480. package/src/app/[variants]/(main)/discover/search/layout.tsx +0 -12
  481. package/src/app/[variants]/(main)/discover/search/loading.tsx +0 -1
  482. package/src/app/[variants]/(main)/discover/search/page.tsx +0 -82
  483. package/src/features/PluginStore/InstalledPluginList.tsx +0 -59
  484. package/src/features/PluginStore/OnlineList.tsx +0 -87
  485. package/src/features/PluginStore/PluginItem/EditCustomPlugin.tsx +0 -55
  486. package/src/features/PluginStore/PluginItem/PluginTag.tsx +0 -29
  487. package/src/features/PluginStore/PluginItem/index.tsx +0 -83
  488. package/src/server/routers/edge/market/index.ts +0 -108
  489. package/src/services/__tests__/assistant.test.ts +0 -87
  490. package/src/services/assistant.ts +0 -25
  491. package/src/store/tool/slices/store/action.ts +0 -113
  492. package/src/store/tool/slices/store/initialState.ts +0 -17
  493. package/src/types/discover.ts +0 -179
  494. package/src/types/requestCache.ts +0 -3
  495. /package/src/app/[variants]/(main)/discover/(list)/{assistants → assistant}/_layout/Desktop.tsx +0 -0
  496. /package/src/app/[variants]/(main)/discover/(list)/{assistants → assistant}/_layout/Mobile.tsx +0 -0
  497. /package/src/app/[variants]/(main)/discover/(list)/{assistants → assistant}/layout.tsx +0 -0
  498. /package/src/app/[variants]/(main)/discover/(list)/{assistants → assistant}/loading.tsx +0 -0
  499. /package/src/app/[variants]/(main)/discover/(list)/{plugins → mcp}/_layout/Desktop.tsx +0 -0
  500. /package/src/app/[variants]/(main)/discover/(list)/{plugins → mcp}/_layout/Mobile.tsx +0 -0
  501. /package/src/app/[variants]/(main)/discover/(list)/{plugins → mcp}/layout.tsx +0 -0
  502. /package/src/app/[variants]/(main)/discover/(list)/{plugins → mcp}/loading.tsx +0 -0
  503. /package/src/app/[variants]/(main)/discover/(list)/{models → model}/_layout/Mobile.tsx +0 -0
  504. /package/src/app/[variants]/(main)/discover/(list)/{models → model}/features/const.ts +0 -0
  505. /package/src/app/[variants]/(main)/discover/(list)/{models → model}/layout.tsx +0 -0
  506. /package/src/{features/PluginStore/PluginItem → components/Plugins}/PluginAvatar.tsx +0 -0
  507. /package/src/server/routers/{edge → lambda}/config/__snapshots__/index.test.ts.snap +0 -0
  508. /package/src/server/routers/{edge → lambda}/config/index.test.ts +0 -0
  509. /package/src/store/tool/slices/{store → mcpStore}/index.ts +0 -0
@@ -1,18 +1,11 @@
1
- import {
2
- SiBun,
3
- SiDocker,
4
- SiNodedotjs,
5
- SiNpm,
6
- SiPnpm,
7
- SiPython,
8
- } from '@icons-pack/react-simple-icons';
9
1
  import { LobeChatPluginManifest } from '@lobehub/chat-plugin-sdk';
10
- import { Alert, AutoComplete, FormItem, Input, TextArea } from '@lobehub/ui';
2
+ import { Alert, FormItem, Input, TextArea } from '@lobehub/ui';
11
3
  import { Button, Divider, Form, FormInstance } from 'antd';
12
- import { FC, useState } from 'react';
4
+ import { useState } from 'react';
13
5
  import { useTranslation } from 'react-i18next';
14
6
  import { Flexbox } from 'react-layout-kit';
15
7
 
8
+ import MCPStdioCommandInput from '@/components/MCPStdioCommandInput';
16
9
  import { isDesktop } from '@/const/version';
17
10
  import { mcpService } from '@/services/mcp';
18
11
  import { useToolStore } from '@/store/tool';
@@ -29,25 +22,6 @@ interface MCPManifestFormProps {
29
22
  isEditMode?: boolean;
30
23
  }
31
24
 
32
- // 定义预设的命令选项
33
- const STDIO_COMMAND_OPTIONS: {
34
- // 假设图标是 React 函数组件
35
- color?: string;
36
- icon?: FC<{ color?: string; size?: number }>;
37
- value: string;
38
- }[] = [
39
- { color: '#CB3837', icon: SiNpm, value: 'npx' },
40
- { color: '#CB3837', icon: SiNpm, value: 'npm' },
41
- { color: '#F69220', icon: SiPnpm, value: 'pnpm' },
42
- { color: '#F69220', icon: SiPnpm, value: 'pnpx' },
43
- { color: '#339933', icon: SiNodedotjs, value: 'node' },
44
- { color: '#efe2d2', icon: SiBun, value: 'bun' },
45
- { color: '#efe2d2', icon: SiBun, value: 'bunx' },
46
- { color: '#DE5FE9', icon: SiPython, value: 'uv' },
47
- { color: '#3776AB', icon: SiPython, value: 'python' },
48
- { color: '#2496ED', icon: SiDocker, value: 'docker' },
49
- ];
50
-
51
25
  const HTTP_URL_KEY = ['customParams', 'mcp', 'url'];
52
26
  const STDIO_COMMAND = ['customParams', 'mcp', 'command'];
53
27
  const STDIO_ARGS = ['customParams', 'mcp', 'args'];
@@ -324,18 +298,7 @@ const MCPManifestForm = ({ form, isEditMode }: MCPManifestFormProps) => {
324
298
  rules={[{ message: t('dev.mcp.command.required'), required: true }]}
325
299
  tag={'command'}
326
300
  >
327
- <AutoComplete
328
- options={STDIO_COMMAND_OPTIONS.map(({ value, icon: Icon, color }) => ({
329
- label: (
330
- <Flexbox align={'center'} gap={8} horizontal>
331
- {Icon && <Icon color={color} size={16} />}
332
- {value}
333
- </Flexbox>
334
- ),
335
- value: value,
336
- }))}
337
- placeholder={t('dev.mcp.command.placeholder')}
338
- />
301
+ <MCPStdioCommandInput placeholder={t('dev.mcp.command.placeholder')} />
339
302
  </FormItem>
340
303
  <FormItem
341
304
  desc={t('dev.mcp.args.desc')}
@@ -1,11 +1,9 @@
1
- import { Icon } from '@lobehub/ui';
2
- import { Space, Typography } from 'antd';
1
+ import { Icon, Text } from '@lobehub/ui';
2
+ import { Space } from 'antd';
3
3
  import { createStyles } from 'antd-style';
4
4
  import { Puzzle } from 'lucide-react';
5
5
  import { useTranslation } from 'react-i18next';
6
6
 
7
- const { Title, Paragraph } = Typography;
8
-
9
7
  // Create styles using antd-style
10
8
  const useStyles = createStyles(({ token, css }) => ({
11
9
  container: css`
@@ -63,10 +61,10 @@ export default function PluginEmptyState() {
63
61
  <div className={styles.iconWrapper}>
64
62
  <Icon icon={Puzzle} size={32} />
65
63
  </div>
66
- <Title className={styles.title} level={4}>
64
+ <Text as={'h4'} className={styles.title}>
67
65
  {t('dev.preview.empty.title')}
68
- </Title>
69
- <Paragraph className={styles.description}>{t('dev.preview.empty.desc')}</Paragraph>
66
+ </Text>
67
+ <Text className={styles.description}>{t('dev.preview.empty.desc')}</Text>
70
68
  <Space align="center" direction="vertical">
71
69
  <div className={styles.line} style={{ width: 128 }} />
72
70
  <div className={styles.line} style={{ width: 96 }} />
@@ -1,6 +1,6 @@
1
1
  import { LobeChatPluginManifest } from '@lobehub/chat-plugin-sdk';
2
- import { Block, Icon } from '@lobehub/ui';
3
- import { Form as AForm, Button, FormInstance, Typography } from 'antd';
2
+ import { Block, Icon, Text } from '@lobehub/ui';
3
+ import { Form as AForm, Button, FormInstance } from 'antd';
4
4
  import { useTheme } from 'antd-style';
5
5
  import { FileCode } from 'lucide-react';
6
6
  import { memo } from 'react';
@@ -8,8 +8,8 @@ import { useTranslation } from 'react-i18next';
8
8
  import { Flexbox } from 'react-layout-kit';
9
9
 
10
10
  import ManifestPreviewer from '@/components/ManifestPreviewer';
11
- import PluginAvatar from '@/features/PluginStore/PluginItem/PluginAvatar';
12
- import PluginTag from '@/features/PluginStore/PluginItem/PluginTag';
11
+ import PluginAvatar from '@/components/Plugins/PluginAvatar';
12
+ import PluginTag from '@/components/Plugins/PluginTag';
13
13
  import { pluginHelpers } from '@/store/tool';
14
14
 
15
15
  import ApiVisualizer from './ApiVisualizer';
@@ -50,9 +50,9 @@ const PluginPreview = memo<{ form: FormInstance }>(({ form }) => {
50
50
  {pluginHelpers.getPluginTitle(meta) || 'Plugin Title'}
51
51
  <PluginTag type={'customPlugin'} />
52
52
  </Flexbox>
53
- <Typography.Text style={{ fontSize: 12 }} type={'secondary'}>
53
+ <Text style={{ fontSize: 12 }} type={'secondary'}>
54
54
  {pluginHelpers.getPluginDesc(meta) || 'Plugin Description'}
55
- </Typography.Text>
55
+ </Text>
56
56
  </Flexbox>
57
57
  </Flexbox>
58
58
 
@@ -9,7 +9,7 @@ import { useTranslation } from 'react-i18next';
9
9
  import { useToolStore } from '@/store/tool';
10
10
  import { pluginSelectors } from '@/store/tool/selectors';
11
11
 
12
- import PluginSettingRender from './PluginSettingRender';
12
+ import ItemRender from '../../components/JSONSchemaConfig/ItemRender';
13
13
 
14
14
  export const transformPluginSettings = (pluginSettings: PluginSchema) => {
15
15
  if (!pluginSettings?.properties) return [];
@@ -68,7 +68,7 @@ const PluginSettingsConfig = memo<PluginSettingsConfigProps>(({ schema, id }) =>
68
68
  initialValues={pluginSetting}
69
69
  items={items.map((item) => ({
70
70
  children: (
71
- <PluginSettingRender
71
+ <ItemRender
72
72
  enum={item.enum}
73
73
  format={item.format}
74
74
  maximum={item.maximum}
@@ -39,7 +39,7 @@ const AddPluginButton = forwardRef<HTMLButtonElement>((props, ref) => {
39
39
  }}
40
40
  ref={ref}
41
41
  >
42
- {t('plugin.addTooltip')}
42
+ {t('plugin.addMCPPlugin')}
43
43
  </Button>
44
44
  </div>
45
45
  );
@@ -0,0 +1,59 @@
1
+ import { Segmented } from '@lobehub/ui';
2
+ import { SegmentedOptions } from 'antd/es/segmented';
3
+ import { memo, useState } from 'react';
4
+ import { useTranslation } from 'react-i18next';
5
+ import { Flexbox } from 'react-layout-kit';
6
+
7
+ import { isDesktop } from '@/const/version';
8
+ import { useServerConfigStore } from '@/store/serverConfig';
9
+ import { useToolStore } from '@/store/tool';
10
+ import { PluginStoreTabs } from '@/store/tool/slices/oldStore';
11
+
12
+ import AddPluginButton from './AddPluginButton';
13
+ import InstalledList from './InstalledList';
14
+ import McpList from './McpList';
15
+ import PluginList from './PluginList';
16
+ import Search from './Search';
17
+
18
+ export const Content = memo(() => {
19
+ const { t } = useTranslation('plugin');
20
+ const mobile = useServerConfigStore((s) => s.isMobile);
21
+ const [listType] = useToolStore((s) => [s.listType]);
22
+ const [keywords] = useState<string>();
23
+
24
+ const options = [
25
+ isDesktop ? { label: t('store.tabs.mcp'), value: PluginStoreTabs.MCP } : undefined,
26
+ { label: t('store.tabs.old'), value: PluginStoreTabs.Plugin },
27
+ { label: t('store.tabs.installed'), value: PluginStoreTabs.Installed },
28
+ ].filter(Boolean) as SegmentedOptions;
29
+
30
+ return (
31
+ <Flexbox
32
+ gap={8}
33
+ style={{ maxHeight: mobile ? '-webkit-fill-available' : 'inherit' }}
34
+ width={'100%'}
35
+ >
36
+ <Flexbox gap={8} paddingInline={16}>
37
+ <Flexbox gap={8} horizontal>
38
+ <Segmented
39
+ block
40
+ onChange={(v) => {
41
+ useToolStore.setState({ listType: v as PluginStoreTabs });
42
+ }}
43
+ options={options}
44
+ style={{ flex: 1 }}
45
+ value={listType}
46
+ variant={'filled'}
47
+ />
48
+ <AddPluginButton />
49
+ </Flexbox>
50
+ <Search />
51
+ </Flexbox>
52
+ {listType === PluginStoreTabs.MCP && <McpList />}
53
+ {listType === PluginStoreTabs.Plugin && <PluginList />}
54
+ {listType === PluginStoreTabs.Installed && <InstalledList keywords={keywords} />}
55
+ </Flexbox>
56
+ );
57
+ });
58
+
59
+ export default Content;
@@ -0,0 +1,81 @@
1
+ import { Button, Icon, Text } from '@lobehub/ui';
2
+ import { createStyles } from 'antd-style';
3
+ import { Package } from 'lucide-react';
4
+ import { memo, useState } from 'react';
5
+ import { useTranslation } from 'react-i18next';
6
+ import { Center, Flexbox } from 'react-layout-kit';
7
+
8
+ import EditCustomPlugin from '../EditCustomPlugin';
9
+
10
+ const useStyles = createStyles(({ css, token }) => ({
11
+ button: css`
12
+ margin-block-start: ${token.marginLG}px;
13
+ `,
14
+ container: css`
15
+ height: 80%;
16
+ padding-block: ${token.paddingXL}px;
17
+ padding-inline: ${token.paddingLG}px;
18
+ `,
19
+ description: css`
20
+ max-width: 240px;
21
+ line-height: 1.5;
22
+ color: ${token.colorTextSecondary};
23
+ text-align: center;
24
+ `,
25
+ iconWrapper: css`
26
+ display: flex;
27
+ align-items: center;
28
+ justify-content: center;
29
+
30
+ width: 64px;
31
+ height: 64px;
32
+ margin-block-end: ${token.marginMD}px;
33
+ border-radius: 50%;
34
+
35
+ background-color: ${token.colorPrimaryBg};
36
+ `,
37
+ title: css`
38
+ margin-block-end: ${token.marginSM}px;
39
+
40
+ font-size: ${token.fontSizeLG}px;
41
+ font-weight: 500;
42
+ color: ${token.colorText};
43
+ text-align: center;
44
+ `,
45
+ }));
46
+
47
+ interface Props {
48
+ identifier: string;
49
+ }
50
+
51
+ const CustomPluginEmptyState = memo<Props>(({ identifier }) => {
52
+ const { styles } = useStyles();
53
+ const { t } = useTranslation('plugin');
54
+
55
+ const [showModal, setModal] = useState(false);
56
+
57
+ return (
58
+ <Center className={styles.container}>
59
+ <Flexbox align="center">
60
+ <div className={styles.iconWrapper}>
61
+ <Icon icon={Package} size={32} />
62
+ </div>
63
+ <Text className={styles.title}>{t('detailModal.customPlugin.title')}</Text>
64
+ <Text className={styles.description}>{t('detailModal.customPlugin.description')}</Text>
65
+ <EditCustomPlugin identifier={identifier} onOpenChange={setModal} open={showModal}>
66
+ <Button
67
+ className={styles.button}
68
+ onClick={() => {
69
+ setModal(true);
70
+ }}
71
+ type="primary"
72
+ >
73
+ {t('detailModal.customPlugin.editBtn')}
74
+ </Button>
75
+ </EditCustomPlugin>
76
+ </Flexbox>
77
+ </Center>
78
+ );
79
+ });
80
+
81
+ export default CustomPluginEmptyState;
@@ -0,0 +1,21 @@
1
+ import { memo } from 'react';
2
+
3
+ import McpDetail from '../../McpList/Detail';
4
+ import PluginDetail from '../../PluginList/Detail';
5
+ import CustomPluginEmptyState from './CustomPluginEmptyState';
6
+
7
+ interface DetailProps {
8
+ identifier: string;
9
+ runtimeType?: 'mcp' | 'default';
10
+ type?: 'plugin' | 'customPlugin' | 'builtin';
11
+ }
12
+
13
+ const Detail = memo<DetailProps>(({ identifier, type, runtimeType }) => {
14
+ if (type === 'customPlugin') return <CustomPluginEmptyState identifier={identifier} />;
15
+
16
+ if (runtimeType === 'mcp') return <McpDetail identifier={identifier} />;
17
+
18
+ if (type === 'plugin') return <PluginDetail identifier={identifier} />;
19
+ });
20
+
21
+ export default Detail;
@@ -0,0 +1,52 @@
1
+ import isEqual from 'fast-deep-equal';
2
+ import { ReactNode, memo } from 'react';
3
+
4
+ import DevModal from '@/features/PluginDevModal';
5
+ import { useToolStore } from '@/store/tool';
6
+ import { pluginSelectors } from '@/store/tool/slices/plugin/selectors';
7
+
8
+ interface EditCustomPluginProps {
9
+ children: ReactNode;
10
+ identifier: string;
11
+ onOpenChange: (open: boolean) => void;
12
+ open: boolean;
13
+ }
14
+
15
+ const EditCustomPlugin = memo<EditCustomPluginProps>(
16
+ ({ identifier, open, onOpenChange, children }) => {
17
+ const [installCustomPlugin, updateNewDevPlugin, uninstallCustomPlugin] = useToolStore((s) => [
18
+ s.installCustomPlugin,
19
+ s.updateNewCustomPlugin,
20
+ s.uninstallCustomPlugin,
21
+ ]);
22
+
23
+ const customPlugin = useToolStore(pluginSelectors.getCustomPluginById(identifier), isEqual);
24
+
25
+ return (
26
+ <div
27
+ onClick={(e) => {
28
+ e.stopPropagation();
29
+ }}
30
+ >
31
+ <DevModal
32
+ mode={'edit'}
33
+ onDelete={() => {
34
+ uninstallCustomPlugin(identifier);
35
+ onOpenChange(false);
36
+ }}
37
+ onOpenChange={onOpenChange}
38
+ onSave={async (devPlugin) => {
39
+ await installCustomPlugin(devPlugin);
40
+ onOpenChange(false);
41
+ }}
42
+ onValueChange={updateNewDevPlugin}
43
+ open={open}
44
+ value={customPlugin}
45
+ />
46
+ {children}
47
+ </div>
48
+ );
49
+ },
50
+ );
51
+
52
+ export default EditCustomPlugin;
@@ -1,6 +1,6 @@
1
1
  import { ActionIcon, Button, Dropdown, Icon } from '@lobehub/ui';
2
2
  import { App } from 'antd';
3
- import { InfoIcon, MoreVerticalIcon, Settings, Trash2 } from 'lucide-react';
3
+ import { InfoIcon, MoreVerticalIcon, PackageSearch, Settings, Trash2 } from 'lucide-react';
4
4
  import { memo, useState } from 'react';
5
5
  import { useTranslation } from 'react-i18next';
6
6
  import { Flexbox } from 'react-layout-kit';
@@ -12,21 +12,25 @@ import { pluginHelpers, useToolStore } from '@/store/tool';
12
12
  import { pluginSelectors, pluginStoreSelectors } from '@/store/tool/selectors';
13
13
  import { LobeToolType } from '@/types/tool/tool';
14
14
 
15
- import EditCustomPlugin from './EditCustomPlugin';
15
+ import EditCustomPlugin from '../../EditCustomPlugin';
16
16
 
17
17
  interface ActionsProps {
18
18
  identifier: string;
19
+ isMCP?: boolean;
19
20
  type: LobeToolType;
20
21
  }
21
22
 
22
- const Actions = memo<ActionsProps>(({ identifier, type }) => {
23
+ const Actions = memo<ActionsProps>(({ identifier, type, isMCP }) => {
23
24
  const mobile = useServerConfigStore((s) => s.isMobile);
24
- const [installed, installing, installPlugin, unInstallPlugin] = useToolStore((s) => [
25
- pluginSelectors.isPluginInstalled(identifier)(s),
26
- pluginStoreSelectors.isPluginInstallLoading(identifier)(s),
27
- s.installPlugin,
28
- s.uninstallPlugin,
29
- ]);
25
+ const [installed, installing, installPlugin, unInstallPlugin, installMCPPlugin] = useToolStore(
26
+ (s) => [
27
+ pluginSelectors.isPluginInstalled(identifier)(s),
28
+ pluginStoreSelectors.isPluginInstallLoading(identifier)(s),
29
+ s.installPlugin,
30
+ s.uninstallPlugin,
31
+ s.installMCPPlugin,
32
+ ],
33
+ );
30
34
 
31
35
  const isCustomPlugin = type === 'customPlugin';
32
36
  const { t } = useTranslation('plugin');
@@ -37,12 +41,24 @@ const Actions = memo<ActionsProps>(({ identifier, type }) => {
37
41
  const [tab, setTab] = useState('info');
38
42
  const hasSettings = pluginHelpers.isSettingSchemaNonEmpty(plugin?.settings);
39
43
 
44
+ const [showModal, setModal] = useState(false);
45
+
40
46
  return (
41
47
  <>
42
48
  <Flexbox align={'center'} horizontal>
43
49
  {installed ? (
44
50
  <>
45
- {isCustomPlugin && <EditCustomPlugin identifier={identifier} />}
51
+ {isCustomPlugin && (
52
+ <EditCustomPlugin identifier={identifier} onOpenChange={setModal} open={showModal}>
53
+ <ActionIcon
54
+ icon={PackageSearch}
55
+ onClick={() => {
56
+ setModal(true);
57
+ }}
58
+ title={t('store.actions.manifest')}
59
+ />
60
+ </EditCustomPlugin>
61
+ )}
46
62
  {hasSettings && (
47
63
  <ActionIcon
48
64
  icon={Settings}
@@ -92,11 +108,15 @@ const Actions = memo<ActionsProps>(({ identifier, type }) => {
92
108
  <Button
93
109
  loading={installing}
94
110
  onClick={async () => {
95
- await installPlugin(identifier);
96
- await togglePlugin(identifier);
111
+ if (isMCP) {
112
+ await installMCPPlugin(identifier);
113
+ await togglePlugin(identifier);
114
+ } else {
115
+ await installPlugin(identifier);
116
+ await togglePlugin(identifier);
117
+ }
97
118
  }}
98
119
  size={mobile ? 'small' : undefined}
99
- type={'primary'}
100
120
  >
101
121
  {t('store.actions.install')}
102
122
  </Button>
@@ -0,0 +1,62 @@
1
+ import { Block, Text } from '@lobehub/ui';
2
+ import { memo } from 'react';
3
+ import { Flexbox } from 'react-layout-kit';
4
+
5
+ import PluginAvatar from '@/components/Plugins/PluginAvatar';
6
+ import PluginTag from '@/components/Plugins/PluginTag';
7
+ import { DiscoverPluginItem } from '@/types/discover';
8
+ import { LobeToolType } from '@/types/tool/tool';
9
+
10
+ import Actions from './Action';
11
+
12
+ interface PluginItemProps extends DiscoverPluginItem {
13
+ active?: boolean;
14
+ onClick?: () => void;
15
+ runtimeType?: 'mcp' | 'default' | 'markdown' | 'standalone' | undefined;
16
+ type: LobeToolType;
17
+ }
18
+
19
+ const Item = memo<PluginItemProps>(
20
+ ({ title, description, avatar, onClick, active, identifier, author, runtimeType, type }) => {
21
+ const isMCP = runtimeType === 'mcp';
22
+
23
+ return (
24
+ <Block
25
+ align={'center'}
26
+ clickable
27
+ gap={8}
28
+ horizontal
29
+ justify={'space-between'}
30
+ onClick={onClick}
31
+ paddingBlock={8}
32
+ paddingInline={12}
33
+ style={{ position: 'relative' }}
34
+ variant={active ? 'filled' : 'borderless'}
35
+ >
36
+ <Flexbox
37
+ align={'center'}
38
+ flex={1}
39
+ gap={8}
40
+ horizontal
41
+ style={{ overflow: 'hidden', position: 'relative' }}
42
+ >
43
+ <PluginAvatar avatar={avatar} />
44
+ <Flexbox flex={1} gap={4} style={{ overflow: 'hidden', position: 'relative' }}>
45
+ <Flexbox align={'center'} gap={4} horizontal>
46
+ <Text ellipsis strong>
47
+ {title}
48
+ </Text>
49
+ <PluginTag author={author} isMCP={isMCP} type={type!} />
50
+ </Flexbox>
51
+ <Text ellipsis fontSize={12} type={'secondary'}>
52
+ {description}
53
+ </Text>
54
+ </Flexbox>
55
+ </Flexbox>
56
+ <Actions identifier={identifier} isMCP={isMCP} type={type!} />
57
+ </Block>
58
+ );
59
+ },
60
+ );
61
+
62
+ export default Item;
@@ -0,0 +1,77 @@
1
+ import { Empty } from 'antd';
2
+ import isEqual from 'fast-deep-equal';
3
+ import { memo, useMemo } from 'react';
4
+ import { useTranslation } from 'react-i18next';
5
+ import { Center, Flexbox } from 'react-layout-kit';
6
+ import { Virtuoso } from 'react-virtuoso';
7
+
8
+ import { useToolStore } from '@/store/tool';
9
+ import { pluginSelectors } from '@/store/tool/selectors';
10
+ import { LobeToolType } from '@/types/tool/tool';
11
+
12
+ import PluginItem from './Item';
13
+
14
+ interface ListProps {
15
+ identifier?: string;
16
+ keywords?: string;
17
+ setIdentifier?: (props: {
18
+ identifier?: string;
19
+ runtimeType: 'mcp' | 'default';
20
+ type?: LobeToolType;
21
+ }) => void;
22
+ }
23
+
24
+ export const List = memo<ListProps>(({ keywords, identifier, setIdentifier }) => {
25
+ const { t } = useTranslation('plugin');
26
+ const installedPlugins = useToolStore(pluginSelectors.installedPluginMetaList, isEqual);
27
+
28
+ const filteredPluginList = useMemo(
29
+ () =>
30
+ installedPlugins.filter((item) =>
31
+ [item?.title, item?.description, item.author, ...(item?.tags || [])]
32
+ .filter(Boolean)
33
+ .join('')
34
+ .toLowerCase()
35
+ .includes((keywords || '')?.toLowerCase()),
36
+ ),
37
+ [installedPlugins, keywords],
38
+ );
39
+
40
+ const isEmpty = installedPlugins.length === 0;
41
+
42
+ if (isEmpty)
43
+ return (
44
+ <Center paddingBlock={40}>
45
+ <Empty description={t('store.empty')} image={Empty.PRESENTED_IMAGE_SIMPLE} />
46
+ </Center>
47
+ );
48
+
49
+ return (
50
+ <Virtuoso
51
+ data={filteredPluginList}
52
+ itemContent={(_, item) => {
53
+ return (
54
+ <Flexbox
55
+ key={item.identifier}
56
+ onClick={() => {
57
+ setIdentifier?.({
58
+ identifier: item.identifier,
59
+ runtimeType: item.runtimeType as any,
60
+ type: item.type,
61
+ });
62
+ }}
63
+ paddingBlock={2}
64
+ paddingInline={4}
65
+ >
66
+ <PluginItem active={identifier === item.identifier} {...(item as any)} />
67
+ </Flexbox>
68
+ );
69
+ }}
70
+ overscan={400}
71
+ style={{ height: '100%', width: '100%' }}
72
+ totalCount={filteredPluginList.length}
73
+ />
74
+ );
75
+ });
76
+
77
+ export default List;