@lobehub/chat 1.96.20 → 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.
- package/CHANGELOG.md +25 -0
- package/apps/desktop/package.json +1 -1
- package/apps/desktop/src/main/core/Browser.ts +2 -1
- package/apps/desktop/src/main/utils/next-electron-rsc.ts +15 -8
- package/changelog/v1.json +9 -0
- package/locales/ar/discover.json +452 -12
- package/locales/ar/metadata.json +4 -0
- package/locales/ar/plugin.json +89 -2
- package/locales/ar/setting.json +1 -0
- package/locales/bg-BG/discover.json +452 -12
- package/locales/bg-BG/metadata.json +4 -0
- package/locales/bg-BG/plugin.json +89 -2
- package/locales/bg-BG/setting.json +1 -0
- package/locales/de-DE/discover.json +452 -12
- package/locales/de-DE/metadata.json +4 -0
- package/locales/de-DE/plugin.json +89 -2
- package/locales/de-DE/setting.json +1 -0
- package/locales/en-US/discover.json +452 -12
- package/locales/en-US/metadata.json +4 -0
- package/locales/en-US/plugin.json +89 -2
- package/locales/en-US/setting.json +1 -0
- package/locales/es-ES/discover.json +452 -12
- package/locales/es-ES/metadata.json +4 -0
- package/locales/es-ES/plugin.json +89 -2
- package/locales/es-ES/setting.json +1 -0
- package/locales/fa-IR/discover.json +452 -12
- package/locales/fa-IR/metadata.json +4 -0
- package/locales/fa-IR/plugin.json +89 -2
- package/locales/fa-IR/setting.json +1 -0
- package/locales/fr-FR/discover.json +452 -12
- package/locales/fr-FR/metadata.json +4 -0
- package/locales/fr-FR/plugin.json +89 -2
- package/locales/fr-FR/setting.json +1 -0
- package/locales/it-IT/discover.json +452 -12
- package/locales/it-IT/metadata.json +4 -0
- package/locales/it-IT/plugin.json +89 -2
- package/locales/it-IT/setting.json +1 -0
- package/locales/ja-JP/discover.json +452 -12
- package/locales/ja-JP/metadata.json +4 -0
- package/locales/ja-JP/plugin.json +89 -2
- package/locales/ja-JP/setting.json +1 -0
- package/locales/ko-KR/discover.json +452 -12
- package/locales/ko-KR/metadata.json +4 -0
- package/locales/ko-KR/plugin.json +89 -2
- package/locales/ko-KR/setting.json +1 -0
- package/locales/nl-NL/discover.json +452 -12
- package/locales/nl-NL/metadata.json +4 -0
- package/locales/nl-NL/plugin.json +89 -2
- package/locales/nl-NL/setting.json +1 -0
- package/locales/pl-PL/discover.json +452 -12
- package/locales/pl-PL/metadata.json +4 -0
- package/locales/pl-PL/plugin.json +89 -2
- package/locales/pl-PL/setting.json +1 -0
- package/locales/pt-BR/discover.json +452 -12
- package/locales/pt-BR/metadata.json +4 -0
- package/locales/pt-BR/plugin.json +89 -2
- package/locales/pt-BR/setting.json +1 -0
- package/locales/ru-RU/discover.json +452 -12
- package/locales/ru-RU/metadata.json +4 -0
- package/locales/ru-RU/plugin.json +89 -2
- package/locales/ru-RU/setting.json +1 -0
- package/locales/tr-TR/discover.json +452 -12
- package/locales/tr-TR/metadata.json +4 -0
- package/locales/tr-TR/plugin.json +89 -2
- package/locales/tr-TR/setting.json +1 -0
- package/locales/vi-VN/discover.json +452 -12
- package/locales/vi-VN/metadata.json +4 -0
- package/locales/vi-VN/plugin.json +89 -2
- package/locales/vi-VN/setting.json +1 -0
- package/locales/zh-CN/discover.json +452 -12
- package/locales/zh-CN/metadata.json +8 -4
- package/locales/zh-CN/plugin.json +89 -2
- package/locales/zh-CN/setting.json +1 -0
- package/locales/zh-TW/discover.json +452 -12
- package/locales/zh-TW/metadata.json +4 -0
- package/locales/zh-TW/plugin.json +89 -2
- package/locales/zh-TW/setting.json +1 -0
- package/next.config.ts +70 -19
- package/package.json +6 -2
- package/scripts/buildSitemapIndex/index.ts +9 -4
- package/src/app/(backend)/trpc/lambda/[trpc]/route.ts +5 -0
- package/src/app/[variants]/(main)/_layout/Mobile/index.tsx +5 -4
- package/src/app/[variants]/(main)/chat/(workspace)/@conversation/features/ChatList/WelcomeChatItem/InboxWelcome/AgentsSuggest.tsx +31 -45
- package/src/app/[variants]/(main)/discover/(detail)/_layout/Desktop.tsx +8 -6
- package/src/app/[variants]/(main)/discover/(detail)/_layout/Mobile/Header.tsx +3 -2
- package/src/app/[variants]/(main)/discover/(detail)/_layout/Mobile/index.tsx +5 -1
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/Client.tsx +40 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/DetailProvider.tsx +19 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/Capabilities/Block.tsx +27 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/Capabilities/Knowledge.tsx +33 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/Capabilities/KnowledgeItem.tsx +58 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/Capabilities/PluginItem.tsx +68 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/Capabilities/Plugins.tsx +32 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/Capabilities/index.tsx +37 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/Nav.tsx +121 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/Overview/TagList.tsx +47 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/Overview/index.tsx +96 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/Related/index.tsx +31 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/SystemRole/TagList.tsx +47 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/SystemRole/index.tsx +54 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Details/index.tsx +49 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Header.tsx +176 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/{[slug]/features → [...slugs]/features/Sidebar/ActionButton}/AddAgent.tsx +22 -21
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Sidebar/ActionButton/index.tsx +31 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Sidebar/Related/Item.tsx +57 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Sidebar/Related/index.tsx +43 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Sidebar/Summary/index.tsx +38 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Sidebar/TocList/index.tsx +77 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/features/Sidebar/index.tsx +46 -0
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[...slugs]/loading.tsx +48 -0
- package/src/app/[variants]/(main)/discover/(detail)/{plugin/[slug] → assistant/[...slugs]}/page.tsx +39 -42
- package/src/app/[variants]/(main)/discover/(detail)/features/Breadcrumb.tsx +56 -0
- package/src/app/[variants]/(main)/discover/(detail)/features/DetailLayout.tsx +0 -1
- package/src/app/[variants]/(main)/discover/(detail)/features/MakedownRender.tsx +44 -0
- package/src/app/[variants]/(main)/discover/(detail)/features/ShareButton.tsx +4 -3
- package/src/app/[variants]/(main)/discover/(detail)/features/Toc/Heading.tsx +108 -0
- package/src/app/[variants]/(main)/discover/(detail)/features/Toc/index.tsx +92 -0
- package/src/app/[variants]/(main)/discover/(detail)/features/Toc/useToc.tsx +66 -0
- package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/Client.tsx +43 -0
- package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/features/Details/Related/index.tsx +32 -0
- package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/features/Details/Versions/index.tsx +76 -0
- package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/features/Details/index.tsx +59 -0
- package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/features/Sidebar/ActionButton/index.tsx +84 -0
- package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/features/Sidebar/ConnectionTypeAlert.tsx +35 -0
- package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/features/Sidebar/Related/Item.tsx +57 -0
- package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/features/Sidebar/Related/index.tsx +44 -0
- package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/features/Sidebar/ServerConfig.tsx +36 -0
- package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/features/Sidebar/TocList/index.tsx +98 -0
- package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/features/Sidebar/index.tsx +58 -0
- package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/loading.tsx +1 -0
- package/src/app/[variants]/(main)/discover/(detail)/mcp/[slug]/page.tsx +103 -0
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/Client.tsx +40 -0
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/DetailProvider.tsx +19 -0
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Details/Nav.tsx +90 -0
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Details/Overview/ProviderList/index.tsx +179 -0
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Details/Overview/index.tsx +22 -0
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/{ParameterList → Details/Parameter}/ParameterItem.tsx +1 -1
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/{ParameterList → Details/Parameter}/index.tsx +11 -11
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Details/Related/index.tsx +31 -0
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Details/index.tsx +47 -0
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Header.tsx +84 -59
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Sidebar/ActionButton/ChatWithModel.tsx +92 -0
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Sidebar/ActionButton/index.tsx +32 -0
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Sidebar/Related/Item.tsx +60 -0
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Sidebar/Related/index.tsx +43 -0
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Sidebar/RelatedProviders/Item.tsx +60 -0
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Sidebar/RelatedProviders/index.tsx +34 -0
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Sidebar/index.tsx +44 -0
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/loading.tsx +1 -0
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/page.tsx +22 -45
- package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/Client.tsx +40 -0
- package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/DetailProvider.tsx +19 -0
- package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Details/Guide/index.tsx +25 -0
- package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Details/Nav.tsx +99 -0
- package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Details/Overview/ModelList/index.tsx +142 -0
- package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Details/Overview/index.tsx +23 -0
- package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Details/Related/index.tsx +22 -0
- package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Details/index.tsx +47 -0
- package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Header.tsx +99 -0
- package/src/app/[variants]/(main)/discover/(detail)/provider/{[slug]/features → [...slugs]/features/Sidebar/ActionButton}/ProviderConfig.tsx +9 -14
- package/src/app/[variants]/(main)/discover/(detail)/provider/{[slug]/features/Actions.tsx → [...slugs]/features/Sidebar/ActionButton/index.tsx} +14 -18
- package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Sidebar/Related/Item.tsx +60 -0
- package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Sidebar/Related/index.tsx +34 -0
- package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Sidebar/RelatedModels/Item.tsx +60 -0
- package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Sidebar/RelatedModels/index.tsx +43 -0
- package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/features/Sidebar/index.tsx +44 -0
- package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/loading.tsx +1 -0
- package/src/app/[variants]/(main)/discover/(detail)/provider/[...slugs]/page.tsx +103 -0
- package/src/app/[variants]/(main)/discover/(list)/(home)/Client.tsx +24 -21
- package/src/app/[variants]/(main)/discover/(list)/(home)/loading.tsx +1 -1
- package/src/app/[variants]/(main)/discover/(list)/(home)/page.tsx +13 -38
- package/src/app/[variants]/(main)/discover/(list)/_layout/Desktop/Nav.tsx +15 -8
- package/src/app/[variants]/(main)/discover/(list)/_layout/Mobile/Header.tsx +1 -1
- package/src/app/[variants]/(main)/discover/(list)/_layout/Mobile/Nav.tsx +2 -1
- package/src/app/[variants]/(main)/discover/(list)/assistant/Client.tsx +44 -0
- package/src/app/[variants]/(main)/discover/(list)/assistant/features/Category/index.tsx +84 -0
- package/src/app/[variants]/(main)/discover/(list)/assistant/features/Category/useCategory.tsx +112 -0
- package/src/app/[variants]/(main)/discover/(list)/assistant/features/List/Item.tsx +189 -0
- package/src/app/[variants]/(main)/discover/(list)/assistant/features/List/TokenTag.tsx +70 -0
- package/src/app/[variants]/(main)/discover/(list)/assistant/features/List/index.tsx +33 -0
- package/src/app/[variants]/(main)/discover/(list)/assistant/page.tsx +46 -0
- package/src/app/[variants]/(main)/discover/(list)/features/Pagination.tsx +67 -0
- package/src/app/[variants]/(main)/discover/(list)/features/SortButton/index.tsx +184 -0
- package/src/app/[variants]/(main)/discover/(list)/mcp/Client.tsx +44 -0
- package/src/app/[variants]/(main)/discover/(list)/mcp/features/Category/index.tsx +83 -0
- package/src/app/[variants]/(main)/discover/(list)/mcp/features/List/ConnectionTypeTag.tsx +51 -0
- package/src/app/[variants]/(main)/discover/(list)/mcp/features/List/Item.tsx +225 -0
- package/src/app/[variants]/(main)/discover/(list)/mcp/features/List/MetaInfo.tsx +33 -0
- package/src/app/[variants]/(main)/discover/(list)/mcp/features/List/index.tsx +33 -0
- package/src/app/[variants]/(main)/discover/(list)/mcp/page.tsx +46 -0
- package/src/app/[variants]/(main)/discover/(list)/model/Client.tsx +44 -0
- package/src/app/[variants]/(main)/discover/(list)/{models → model}/_layout/Desktop.tsx +1 -7
- package/src/app/[variants]/(main)/discover/(list)/model/features/Category/index.tsx +82 -0
- package/src/app/[variants]/(main)/discover/(list)/model/features/Category/useCategory.tsx +41 -0
- package/src/app/[variants]/(main)/discover/(list)/model/features/List/Item.tsx +190 -0
- package/src/app/[variants]/(main)/discover/(list)/model/features/List/ModelTypeIcon.tsx +39 -0
- package/src/app/[variants]/(main)/discover/(list)/model/features/List/index.tsx +33 -0
- package/src/app/[variants]/(main)/discover/(list)/model/loading.tsx +1 -0
- package/src/app/[variants]/(main)/discover/(list)/model/page.tsx +44 -0
- package/src/app/[variants]/(main)/discover/(list)/provider/Client.tsx +43 -0
- package/src/app/[variants]/(main)/discover/(list)/provider/features/List/Item.tsx +136 -0
- package/src/app/[variants]/(main)/discover/(list)/provider/features/List/index.tsx +33 -0
- package/src/app/[variants]/(main)/discover/(list)/provider/loading.tsx +1 -0
- package/src/app/[variants]/(main)/discover/(list)/provider/page.tsx +44 -0
- package/src/app/[variants]/(main)/discover/_layout/Desktop/Header.tsx +1 -1
- package/src/app/[variants]/(main)/discover/components/CategoryContainer.tsx +7 -5
- package/src/app/[variants]/(main)/discover/components/CategoryMenu.tsx +28 -30
- package/src/app/[variants]/(main)/discover/components/ListLoading.tsx +56 -46
- package/src/app/[variants]/(main)/discover/components/Statistic.tsx +5 -6
- package/src/app/[variants]/(main)/discover/features/Search.tsx +62 -0
- package/src/app/[variants]/(main)/discover/features/Title.tsx +83 -0
- package/src/app/[variants]/(main)/discover/features/__tests__/calculateScore.test.ts +185 -0
- package/src/app/[variants]/(main)/discover/features/useNav.tsx +32 -12
- package/src/app/robots.tsx +7 -5
- package/src/app/sitemap.tsx +81 -13
- package/src/components/CopyableLabel/index.tsx +37 -0
- package/src/components/Descriptions/index.tsx +119 -0
- package/src/components/InlineTable/index.tsx +69 -0
- package/src/{features/PluginSettings/PluginSettingRender.tsx → components/JSONSchemaConfig/ItemRender.tsx} +3 -3
- package/src/components/MCPDepsIcon/Java.tsx +23 -0
- package/src/components/MCPDepsIcon/PowerShell.tsx +23 -0
- package/src/components/MCPDepsIcon/Terminal.tsx +23 -0
- package/src/components/MCPDepsIcon/UV.tsx +23 -0
- package/src/components/MCPDepsIcon/index.tsx +72 -0
- package/src/components/MCPStdioCommandInput/index.tsx +47 -0
- package/src/components/OfficialIcon.tsx +23 -0
- package/src/components/Plugins/MCPTag.tsx +18 -0
- package/src/components/Plugins/PluginTag.tsx +50 -0
- package/src/components/PublishedTime.tsx +71 -0
- package/src/config/__tests__/app.test.ts +6 -2
- package/src/const/discover.ts +8 -34
- package/src/database/models/message.ts +1 -0
- package/src/database/models/plugin.ts +13 -3
- package/src/envs/app.ts +1 -1
- package/src/features/AgentSetting/AgentPlugin/index.tsx +2 -2
- package/src/features/ChatInput/ActionBar/Tools/ToolItem.tsx +1 -1
- package/src/features/ChatInput/ActionBar/Tools/useControls.tsx +5 -5
- package/src/features/Conversation/Messages/Assistant/Tool/Inspector/index.tsx +25 -11
- package/src/features/MCP/MCPInstallProgress/InstallError/ErrorDetails.tsx +110 -0
- package/src/features/MCP/MCPInstallProgress/InstallError/index.tsx +51 -0
- package/src/features/MCP/MCPInstallProgress/MCPConfigForm.tsx +151 -0
- package/src/features/MCP/MCPInstallProgress/MCPDependenciesGuide.tsx +217 -0
- package/src/features/MCP/MCPInstallProgress/index.tsx +118 -0
- package/src/features/MCP/Scores.tsx +268 -0
- package/src/features/MCP/calculateScore.ts +324 -0
- package/src/features/MCP/useScoreList.ts +126 -0
- package/src/features/MCP/utils.ts +225 -0
- package/src/features/MCPPluginDetail/CollapseDesc.tsx +44 -0
- package/src/features/MCPPluginDetail/CollapseLayout.tsx +34 -0
- package/src/features/MCPPluginDetail/Deployment/Platform/index.tsx +47 -0
- package/src/features/MCPPluginDetail/Deployment/index.tsx +322 -0
- package/src/features/MCPPluginDetail/DetailProvider.tsx +19 -0
- package/src/features/MCPPluginDetail/Header.tsx +218 -0
- package/src/features/MCPPluginDetail/Nav.tsx +196 -0
- package/src/features/MCPPluginDetail/Overview/TagList.tsx +47 -0
- package/src/features/MCPPluginDetail/Overview/index.tsx +57 -0
- package/src/features/MCPPluginDetail/Schema/Block.tsx +50 -0
- package/src/features/MCPPluginDetail/Schema/Prompts.tsx +125 -0
- package/src/features/MCPPluginDetail/Schema/Resources.tsx +70 -0
- package/src/features/MCPPluginDetail/Schema/Tools.tsx +146 -0
- package/src/features/MCPPluginDetail/Schema/index.tsx +63 -0
- package/src/features/MCPPluginDetail/Schema/style.ts +9 -0
- package/src/features/MCPPluginDetail/Schema/types.ts +4 -0
- package/src/features/MCPPluginDetail/Score/GithubBadge/index.tsx +82 -0
- package/src/features/MCPPluginDetail/Score/ScoreItem.tsx +34 -0
- package/src/features/MCPPluginDetail/Score/ScoreList.tsx +24 -0
- package/src/features/MCPPluginDetail/Score/TotalScore.tsx +289 -0
- package/src/features/MCPPluginDetail/Score/index.tsx +88 -0
- package/src/features/PluginAvatar/index.tsx +1 -1
- package/src/features/PluginDetailModal/Meta.tsx +3 -4
- package/src/features/PluginDevModal/MCPManifestForm/MCPTypeSelect.tsx +3 -4
- package/src/features/PluginDevModal/MCPManifestForm/index.tsx +4 -41
- package/src/features/PluginDevModal/PluginPreview/EmptyState.tsx +5 -7
- package/src/features/PluginDevModal/PluginPreview/index.tsx +6 -6
- package/src/features/PluginSettings/index.tsx +2 -2
- package/src/features/PluginStore/AddPluginButton.tsx +1 -1
- package/src/features/PluginStore/Content.tsx +59 -0
- package/src/features/PluginStore/InstalledList/Detail/CustomPluginEmptyState.tsx +81 -0
- package/src/features/PluginStore/InstalledList/Detail/index.tsx +21 -0
- package/src/features/PluginStore/InstalledList/EditCustomPlugin.tsx +52 -0
- package/src/features/PluginStore/{PluginItem → InstalledList/List/Item}/Action.tsx +33 -13
- package/src/features/PluginStore/InstalledList/List/Item/index.tsx +62 -0
- package/src/features/PluginStore/InstalledList/List/index.tsx +77 -0
- package/src/features/PluginStore/InstalledList/index.tsx +85 -0
- package/src/features/PluginStore/Loading.tsx +2 -2
- package/src/features/PluginStore/McpList/Detail/Loading.tsx +44 -0
- package/src/features/PluginStore/McpList/Detail/Settings/index.tsx +381 -0
- package/src/features/PluginStore/McpList/Detail/index.tsx +71 -0
- package/src/features/PluginStore/McpList/List/Action.tsx +94 -0
- package/src/features/PluginStore/McpList/List/Item.tsx +84 -0
- package/src/features/PluginStore/McpList/List/index.tsx +97 -0
- package/src/features/PluginStore/McpList/index.tsx +54 -0
- package/src/features/PluginStore/PluginList/Detail/DetailProvider.tsx +19 -0
- package/src/features/PluginStore/PluginList/Detail/EmptyState.tsx +58 -0
- package/src/features/PluginStore/PluginList/Detail/Header.tsx +132 -0
- package/src/features/PluginStore/PluginList/Detail/InstallDetail/Nav.tsx +75 -0
- package/src/features/PluginStore/PluginList/Detail/InstallDetail/Settings.tsx +19 -0
- package/src/features/PluginStore/PluginList/Detail/InstallDetail/Tools.tsx +109 -0
- package/src/features/PluginStore/PluginList/Detail/InstallDetail/index.tsx +24 -0
- package/src/features/PluginStore/PluginList/Detail/Loading.tsx +44 -0
- package/src/features/PluginStore/PluginList/Detail/TagList.tsx +37 -0
- package/src/features/PluginStore/PluginList/Detail/index.tsx +39 -0
- package/src/features/PluginStore/PluginList/Detail/useCategory.tsx +76 -0
- package/src/features/PluginStore/PluginList/List/Action.tsx +72 -0
- package/src/features/PluginStore/PluginList/List/Item.tsx +94 -0
- package/src/features/PluginStore/PluginList/List/index.tsx +91 -0
- package/src/features/PluginStore/PluginList/index.tsx +47 -0
- package/src/features/PluginStore/Search/index.tsx +29 -0
- package/src/features/PluginStore/VirtuosoLoading.tsx +16 -0
- package/src/features/PluginStore/index.tsx +7 -31
- package/src/features/PluginTag/index.tsx +6 -4
- package/src/hooks/useInterceptingRoutes.test.ts +6 -0
- package/src/hooks/useMCPCategory.tsx +133 -0
- package/src/hooks/useQuery.ts +8 -0
- package/src/hooks/useQueryRoute.test.ts +7 -0
- package/src/hooks/useQueryRoute.ts +5 -3
- package/src/libs/mcp/client.ts +255 -11
- package/src/libs/mcp/types.ts +99 -0
- package/src/libs/trpc/client/desktop.ts +2 -3
- package/src/libs/trpc/lambda/context.ts +36 -5
- package/src/libs/trpc/lambda/index.ts +1 -1
- package/src/libs/trpc/lambda/init.ts +8 -1
- package/src/locales/default/discover.ts +457 -12
- package/src/locales/default/metadata.ts +9 -4
- package/src/locales/default/plugin.ts +89 -1
- package/src/locales/default/setting.ts +1 -0
- package/src/locales/resources.ts +1 -1
- package/src/middleware.ts +13 -3
- package/src/server/ld.ts +4 -3
- package/src/server/modules/AssistantStore/index.test.ts +10 -8
- package/src/server/modules/AssistantStore/index.ts +37 -17
- package/src/server/modules/PluginStore/index.test.ts +1 -1
- package/src/server/modules/PluginStore/index.ts +24 -1
- package/src/server/routers/desktop/mcp.ts +36 -2
- package/src/server/routers/edge/index.ts +0 -6
- package/src/server/routers/{edge → lambda}/config/index.ts +1 -1
- package/src/server/routers/lambda/index.ts +4 -0
- package/src/server/routers/lambda/market/index.ts +621 -0
- package/src/server/routers/lambda/plugin.ts +2 -0
- package/src/server/routers/tools/mcp.ts +22 -0
- package/src/server/services/discover/index.test.ts +573 -250
- package/src/server/services/discover/index.ts +1096 -241
- package/src/server/services/mcp/deps/MCPSystemDepsCheckService.ts +238 -0
- package/src/server/services/mcp/deps/checkers/ManualInstallationChecker.ts +20 -0
- package/src/server/services/mcp/deps/checkers/NpmInstallationChecker.ts +51 -0
- package/src/server/services/mcp/deps/checkers/PythonInstallationChecker.ts +69 -0
- package/src/server/services/mcp/deps/index.ts +14 -0
- package/src/server/services/mcp/deps/types.ts +49 -0
- package/src/server/services/mcp/index.ts +251 -33
- package/src/server/sitemap.test.ts +203 -46
- package/src/server/sitemap.ts +159 -52
- package/src/services/__tests__/global.test.ts +4 -7
- package/src/services/__tests__/tool.test.ts +1 -29
- package/src/services/discover.ts +365 -0
- package/src/services/global.ts +3 -3
- package/src/services/mcp.ts +131 -10
- package/src/services/plugin/_deprecated.ts +1 -1
- package/src/services/plugin/type.ts +3 -1
- package/src/services/tool.ts +9 -6
- package/src/store/chat/slices/plugin/action.test.ts +2 -3
- package/src/store/chat/slices/plugin/action.ts +22 -4
- package/src/store/discover/index.ts +1 -0
- package/src/store/discover/slices/assistant/action.ts +73 -0
- package/src/store/discover/slices/assistant/index.ts +1 -0
- package/src/store/discover/slices/mcp/action.ts +70 -0
- package/src/store/discover/slices/mcp/index.ts +1 -0
- package/src/store/discover/slices/model/action.ts +70 -0
- package/src/store/discover/slices/model/index.ts +1 -0
- package/src/store/discover/slices/plugin/action.ts +76 -0
- package/src/store/discover/slices/plugin/index.ts +1 -0
- package/src/store/discover/slices/provider/action.ts +61 -0
- package/src/store/discover/slices/provider/index.ts +1 -0
- package/src/store/discover/store.ts +39 -0
- package/src/store/tool/initialState.ts +8 -2
- package/src/store/tool/selectors/index.ts +2 -1
- package/src/store/tool/selectors/tool.test.ts +3 -1
- package/src/store/tool/selectors/tool.ts +14 -2
- package/src/store/tool/slices/mcpStore/action.ts +496 -0
- package/src/store/tool/slices/mcpStore/initialState.ts +40 -0
- package/src/store/tool/slices/mcpStore/selectors.ts +62 -0
- package/src/store/tool/slices/{store → oldStore}/action.test.ts +24 -19
- package/src/store/tool/slices/oldStore/action.ts +269 -0
- package/src/store/tool/slices/oldStore/index.ts +3 -0
- package/src/store/tool/slices/oldStore/initialState.ts +54 -0
- package/src/store/tool/slices/{store → oldStore}/selectors.test.ts +6 -3
- package/src/store/tool/slices/{store → oldStore}/selectors.ts +18 -5
- package/src/store/tool/slices/plugin/action.test.ts +2 -1
- package/src/store/tool/slices/plugin/action.ts +22 -4
- package/src/store/tool/slices/plugin/selectors.test.ts +12 -4
- package/src/store/tool/slices/plugin/selectors.ts +20 -9
- package/src/store/tool/store.ts +5 -2
- package/src/types/discover/assistants.ts +72 -0
- package/src/types/discover/index.ts +41 -0
- package/src/types/discover/mcp.ts +59 -0
- package/src/types/discover/models.ts +51 -0
- package/src/types/discover/plugins.ts +52 -0
- package/src/types/discover/providers.ts +47 -0
- package/src/types/message/tools.ts +3 -0
- package/src/types/plugins/index.ts +53 -0
- package/src/types/plugins/mcp.ts +188 -0
- package/src/types/plugins/mcpDeps.ts +30 -0
- package/src/types/tool/index.ts +10 -0
- package/src/types/tool/plugin.ts +3 -2
- package/src/types/tool/tool.ts +4 -1
- package/src/utils/client/cookie.ts +5 -2
- package/src/utils/locale.ts +2 -17
- package/src/utils/object.ts +10 -0
- package/src/utils/server/pageProps.ts +9 -0
- package/src/utils/toolCall.ts +5 -1
- package/src/utils/toolManifest.ts +1 -2
- package/vercel.json +1 -1
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[slug]/features/Actions.tsx +0 -35
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[slug]/features/ConversationExample/TopicList.tsx +0 -75
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[slug]/features/ConversationExample/index.tsx +0 -105
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[slug]/features/Header.tsx +0 -115
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[slug]/features/InfoSidebar/SuggestionItem.tsx +0 -62
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[slug]/features/InfoSidebar/ToolItem.tsx +0 -19
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[slug]/features/InfoSidebar/index.tsx +0 -60
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[slug]/features/SystemRole.tsx +0 -35
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[slug]/features/Temp.tsx +0 -44
- package/src/app/[variants]/(main)/discover/(detail)/assistant/[slug]/page.tsx +0 -124
- package/src/app/[variants]/(main)/discover/(detail)/loading.tsx +0 -38
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/Actions.tsx +0 -40
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/ChatWithModel.tsx +0 -93
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/InfoSidebar/SuggestionItem.tsx +0 -74
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/InfoSidebar/index.tsx +0 -45
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/ProviderList/ProviderItem.tsx +0 -139
- package/src/app/[variants]/(main)/discover/(detail)/model/[...slugs]/features/ProviderList/index.tsx +0 -45
- package/src/app/[variants]/(main)/discover/(detail)/plugin/[slug]/features/Actions.tsx +0 -35
- package/src/app/[variants]/(main)/discover/(detail)/plugin/[slug]/features/Header.tsx +0 -119
- package/src/app/[variants]/(main)/discover/(detail)/plugin/[slug]/features/InfoSidebar/SuggestionItem.tsx +0 -64
- package/src/app/[variants]/(main)/discover/(detail)/plugin/[slug]/features/InfoSidebar/index.tsx +0 -45
- package/src/app/[variants]/(main)/discover/(detail)/plugin/[slug]/features/InstallPlugin.tsx +0 -83
- package/src/app/[variants]/(main)/discover/(detail)/plugin/[slug]/features/ParameterList.tsx +0 -95
- package/src/app/[variants]/(main)/discover/(detail)/plugin/[slug]/features/Schema.tsx +0 -23
- package/src/app/[variants]/(main)/discover/(detail)/provider/[slug]/features/Header.tsx +0 -73
- package/src/app/[variants]/(main)/discover/(detail)/provider/[slug]/features/InfoSidebar/SuggestionItem.tsx +0 -77
- package/src/app/[variants]/(main)/discover/(detail)/provider/[slug]/features/InfoSidebar/index.tsx +0 -45
- package/src/app/[variants]/(main)/discover/(detail)/provider/[slug]/features/ModelList/ModelItem.tsx +0 -152
- package/src/app/[variants]/(main)/discover/(detail)/provider/[slug]/features/ModelList/index.tsx +0 -60
- package/src/app/[variants]/(main)/discover/(detail)/provider/[slug]/page.tsx +0 -126
- package/src/app/[variants]/(main)/discover/(list)/(home)/features/AssistantList.tsx +0 -33
- package/src/app/[variants]/(main)/discover/(list)/(home)/features/ModelList.tsx +0 -19
- package/src/app/[variants]/(main)/discover/(list)/(home)/features/PluginList.tsx +0 -25
- package/src/app/[variants]/(main)/discover/(list)/assistants/[slug]/page.tsx +0 -75
- package/src/app/[variants]/(main)/discover/(list)/assistants/features/Card.tsx +0 -195
- package/src/app/[variants]/(main)/discover/(list)/assistants/features/Category.tsx +0 -48
- package/src/app/[variants]/(main)/discover/(list)/assistants/features/List.tsx +0 -98
- package/src/app/[variants]/(main)/discover/(list)/assistants/features/useCategory.tsx +0 -116
- package/src/app/[variants]/(main)/discover/(list)/assistants/page.tsx +0 -64
- package/src/app/[variants]/(main)/discover/(list)/loading.tsx +0 -39
- package/src/app/[variants]/(main)/discover/(list)/models/[slug]/page.tsx +0 -78
- package/src/app/[variants]/(main)/discover/(list)/models/features/Card.tsx +0 -118
- package/src/app/[variants]/(main)/discover/(list)/models/features/Category.tsx +0 -67
- package/src/app/[variants]/(main)/discover/(list)/models/features/List.tsx +0 -71
- package/src/app/[variants]/(main)/discover/(list)/models/loading.tsx +0 -1
- package/src/app/[variants]/(main)/discover/(list)/models/page.tsx +0 -73
- package/src/app/[variants]/(main)/discover/(list)/plugins/[slug]/page.tsx +0 -75
- package/src/app/[variants]/(main)/discover/(list)/plugins/features/Card.tsx +0 -161
- package/src/app/[variants]/(main)/discover/(list)/plugins/features/Category.tsx +0 -45
- package/src/app/[variants]/(main)/discover/(list)/plugins/features/List.tsx +0 -97
- package/src/app/[variants]/(main)/discover/(list)/plugins/features/useCategory.tsx +0 -80
- package/src/app/[variants]/(main)/discover/(list)/plugins/page.tsx +0 -64
- package/src/app/[variants]/(main)/discover/(list)/providers/features/Card.tsx +0 -119
- package/src/app/[variants]/(main)/discover/(list)/providers/features/List.tsx +0 -67
- package/src/app/[variants]/(main)/discover/(list)/providers/loading.tsx +0 -1
- package/src/app/[variants]/(main)/discover/(list)/providers/page.tsx +0 -64
- package/src/app/[variants]/(main)/discover/features/StoreSearchBar.tsx +0 -87
- package/src/app/[variants]/(main)/discover/loading.tsx +0 -3
- package/src/app/[variants]/(main)/discover/search/_layout/Desktop.tsx +0 -42
- package/src/app/[variants]/(main)/discover/search/_layout/Mobile/Header.tsx +0 -31
- package/src/app/[variants]/(main)/discover/search/_layout/Mobile/Nav.tsx +0 -56
- package/src/app/[variants]/(main)/discover/search/_layout/Mobile/index.tsx +0 -32
- package/src/app/[variants]/(main)/discover/search/features/AssistantsResult.tsx +0 -27
- package/src/app/[variants]/(main)/discover/search/features/Category.tsx +0 -41
- package/src/app/[variants]/(main)/discover/search/features/ModelsResult.tsx +0 -27
- package/src/app/[variants]/(main)/discover/search/features/PluginsResult.tsx +0 -27
- package/src/app/[variants]/(main)/discover/search/features/ProvidersResult.tsx +0 -26
- package/src/app/[variants]/(main)/discover/search/layout.tsx +0 -12
- package/src/app/[variants]/(main)/discover/search/loading.tsx +0 -1
- package/src/app/[variants]/(main)/discover/search/page.tsx +0 -82
- package/src/features/PluginStore/InstalledPluginList.tsx +0 -59
- package/src/features/PluginStore/OnlineList.tsx +0 -87
- package/src/features/PluginStore/PluginItem/EditCustomPlugin.tsx +0 -55
- package/src/features/PluginStore/PluginItem/PluginTag.tsx +0 -29
- package/src/features/PluginStore/PluginItem/index.tsx +0 -83
- package/src/server/routers/edge/market/index.ts +0 -108
- package/src/services/__tests__/assistant.test.ts +0 -87
- package/src/services/assistant.ts +0 -25
- package/src/store/tool/slices/store/action.ts +0 -113
- package/src/store/tool/slices/store/initialState.ts +0 -17
- package/src/types/discover.ts +0 -179
- package/src/types/requestCache.ts +0 -3
- /package/src/app/[variants]/(main)/discover/(list)/{assistants → assistant}/_layout/Desktop.tsx +0 -0
- /package/src/app/[variants]/(main)/discover/(list)/{assistants → assistant}/_layout/Mobile.tsx +0 -0
- /package/src/app/[variants]/(main)/discover/(list)/{assistants → assistant}/layout.tsx +0 -0
- /package/src/app/[variants]/(main)/discover/(list)/{assistants → assistant}/loading.tsx +0 -0
- /package/src/app/[variants]/(main)/discover/(list)/{plugins → mcp}/_layout/Desktop.tsx +0 -0
- /package/src/app/[variants]/(main)/discover/(list)/{plugins → mcp}/_layout/Mobile.tsx +0 -0
- /package/src/app/[variants]/(main)/discover/(list)/{plugins → mcp}/layout.tsx +0 -0
- /package/src/app/[variants]/(main)/discover/(list)/{plugins → mcp}/loading.tsx +0 -0
- /package/src/app/[variants]/(main)/discover/(list)/{models → model}/_layout/Mobile.tsx +0 -0
- /package/src/app/[variants]/(main)/discover/(list)/{models → model}/features/const.ts +0 -0
- /package/src/app/[variants]/(main)/discover/(list)/{models → model}/layout.tsx +0 -0
- /package/src/{features/PluginStore/PluginItem → components/Plugins}/PluginAvatar.tsx +0 -0
- /package/src/server/routers/{edge → lambda}/config/__snapshots__/index.test.ts.snap +0 -0
- /package/src/server/routers/{edge → lambda}/config/index.test.ts +0 -0
- /package/src/store/tool/slices/{store → mcpStore}/index.ts +0 -0
@@ -0,0 +1,63 @@
|
|
1
|
+
import { memo, useState } from 'react';
|
2
|
+
import { useTranslation } from 'react-i18next';
|
3
|
+
import { Flexbox } from 'react-layout-kit';
|
4
|
+
|
5
|
+
import { useDetailContext } from '../DetailProvider';
|
6
|
+
import Block from './Block';
|
7
|
+
import Prompts from './Prompts';
|
8
|
+
import Resources from './Resources';
|
9
|
+
import Tools from './Tools';
|
10
|
+
import { ModeType } from './types';
|
11
|
+
|
12
|
+
const Schema = memo(() => {
|
13
|
+
const { t } = useTranslation('discover');
|
14
|
+
const { promptsCount, toolsCount, resourcesCount } = useDetailContext();
|
15
|
+
const [toolsActiveKey, setToolsActiveKey] = useState<string[]>([]);
|
16
|
+
const [toolsMode, setToolsMode] = useState<ModeType>(ModeType.Docs);
|
17
|
+
const [promptsActiveKey, setPromptsActiveKey] = useState<string[]>([]);
|
18
|
+
const [promptsMode, setPromptsMode] = useState<ModeType>(ModeType.Docs);
|
19
|
+
const [resourcesMode, setResourcesMode] = useState<ModeType>(ModeType.Docs);
|
20
|
+
|
21
|
+
return (
|
22
|
+
<Flexbox gap={64}>
|
23
|
+
<Block
|
24
|
+
count={toolsCount || 0}
|
25
|
+
desc={t('mcp.details.schema.tools.desc')}
|
26
|
+
id={'tools'}
|
27
|
+
mode={toolsMode}
|
28
|
+
setMode={setToolsMode}
|
29
|
+
title={t('mcp.details.schema.tools.title')}
|
30
|
+
>
|
31
|
+
<Tools activeKey={toolsActiveKey} mode={toolsMode} setActiveKey={setToolsActiveKey} />
|
32
|
+
</Block>
|
33
|
+
|
34
|
+
<Block
|
35
|
+
count={promptsCount || 0}
|
36
|
+
desc={t('mcp.details.schema.prompts.desc')}
|
37
|
+
id={'prompts'}
|
38
|
+
mode={promptsMode}
|
39
|
+
setMode={setPromptsMode}
|
40
|
+
title={t('mcp.details.schema.prompts.title')}
|
41
|
+
>
|
42
|
+
<Prompts
|
43
|
+
activeKey={promptsActiveKey}
|
44
|
+
mode={promptsMode}
|
45
|
+
setActiveKey={setPromptsActiveKey}
|
46
|
+
/>
|
47
|
+
</Block>
|
48
|
+
|
49
|
+
<Block
|
50
|
+
count={resourcesCount || 0}
|
51
|
+
desc={t('mcp.details.schema.resources.desc')}
|
52
|
+
id={'resources'}
|
53
|
+
mode={resourcesMode}
|
54
|
+
setMode={setResourcesMode}
|
55
|
+
title={t('mcp.details.schema.resources.title')}
|
56
|
+
>
|
57
|
+
<Resources mode={resourcesMode} />
|
58
|
+
</Block>
|
59
|
+
</Flexbox>
|
60
|
+
);
|
61
|
+
});
|
62
|
+
|
63
|
+
export default Schema;
|
@@ -0,0 +1,82 @@
|
|
1
|
+
import { Markdown, Select, Snippet, Tag } from '@lobehub/ui';
|
2
|
+
import { Divider } from 'antd';
|
3
|
+
import { useTheme } from 'antd-style';
|
4
|
+
import { memo, useState } from 'react';
|
5
|
+
import { useTranslation } from 'react-i18next';
|
6
|
+
import urlJoin from 'url-join';
|
7
|
+
|
8
|
+
import { OFFICIAL_SITE } from '@/const/url';
|
9
|
+
|
10
|
+
import { useDetailContext } from '../../DetailProvider';
|
11
|
+
|
12
|
+
type BadgeStyle = 'flat' | 'flat-square' | 'plastic' | 'for-the-badge';
|
13
|
+
type BadgeTheme = 'dark' | 'light';
|
14
|
+
|
15
|
+
const GithubBadge = memo(() => {
|
16
|
+
const { t } = useTranslation('discover');
|
17
|
+
const theme = useTheme();
|
18
|
+
const { identifier = '' } = useDetailContext();
|
19
|
+
const [selectedStyle, setSelectedStyle] = useState<BadgeStyle>('flat-square');
|
20
|
+
const [selectedTheme, setSelectedTheme] = useState<BadgeTheme>('dark');
|
21
|
+
|
22
|
+
const pageUrl = urlJoin(OFFICIAL_SITE, 'mcp', identifier);
|
23
|
+
const badgeUrl = urlJoin(OFFICIAL_SITE, 'badge/mcp', identifier);
|
24
|
+
const styledBadgeUrl =
|
25
|
+
selectedStyle === 'flat-square' ? badgeUrl : `${badgeUrl}?style=${selectedStyle}`;
|
26
|
+
|
27
|
+
const badgeFullUrl = urlJoin(OFFICIAL_SITE, 'badge/mcp-full', identifier);
|
28
|
+
|
29
|
+
// 构建带主题参数的完整 badge URL
|
30
|
+
const styledBadgeFullUrl =
|
31
|
+
selectedTheme === 'dark' ? badgeFullUrl : `${badgeFullUrl}?theme=${selectedTheme}`;
|
32
|
+
|
33
|
+
const badgeLite = `[](${pageUrl})`;
|
34
|
+
|
35
|
+
const badge = `[](${pageUrl})`;
|
36
|
+
|
37
|
+
const styleOptions = [
|
38
|
+
{ label: 'Flat Square', value: 'flat-square' },
|
39
|
+
{ label: 'Flat', value: 'flat' },
|
40
|
+
{ label: 'Plastic', value: 'plastic' },
|
41
|
+
{ label: 'For The Badge', value: 'for-the-badge' },
|
42
|
+
];
|
43
|
+
|
44
|
+
const themeOptions = [
|
45
|
+
{ label: 'Dark', value: 'dark' },
|
46
|
+
{ label: 'Light', value: 'light' },
|
47
|
+
];
|
48
|
+
|
49
|
+
return (
|
50
|
+
<>
|
51
|
+
<Markdown>{t('mcp.details.githubBadge.desc')}</Markdown>
|
52
|
+
|
53
|
+
<Select
|
54
|
+
onChange={setSelectedStyle}
|
55
|
+
options={styleOptions}
|
56
|
+
prefix={<Tag style={{ marginRight: 4 }}>style</Tag>}
|
57
|
+
value={selectedStyle}
|
58
|
+
/>
|
59
|
+
<Snippet language={'md'} style={{ fontSize: 12 }} variant={'outlined'}>
|
60
|
+
{badgeLite}
|
61
|
+
</Snippet>
|
62
|
+
<img
|
63
|
+
alt="MCP Badge"
|
64
|
+
height={selectedStyle === 'for-the-badge' ? 28 : 20}
|
65
|
+
src={styledBadgeUrl}
|
66
|
+
/>
|
67
|
+
<Divider style={{ color: theme.colorTextDescription, fontSize: 12 }}>OR</Divider>
|
68
|
+
<Select
|
69
|
+
onChange={setSelectedTheme}
|
70
|
+
options={themeOptions}
|
71
|
+
prefix={<Tag style={{ marginRight: 4 }}>theme</Tag>}
|
72
|
+
value={selectedTheme}
|
73
|
+
/>
|
74
|
+
<Snippet language={'md'} style={{ fontSize: 12 }} variant={'outlined'}>
|
75
|
+
{badge}
|
76
|
+
</Snippet>
|
77
|
+
<img alt="MCP Badge" src={styledBadgeFullUrl} />
|
78
|
+
</>
|
79
|
+
);
|
80
|
+
});
|
81
|
+
|
82
|
+
export default GithubBadge;
|
@@ -0,0 +1,34 @@
|
|
1
|
+
import { Icon } from '@lobehub/ui';
|
2
|
+
import { useTheme } from 'antd-style';
|
3
|
+
import { BanIcon, CircleCheckBigIcon, CircleDashedIcon } from 'lucide-react';
|
4
|
+
import { ReactNode, memo } from 'react';
|
5
|
+
import { Flexbox } from 'react-layout-kit';
|
6
|
+
|
7
|
+
import Title from '../../../app/[variants]/(main)/discover/features/Title';
|
8
|
+
|
9
|
+
export interface ScoreItemProps {
|
10
|
+
check: boolean;
|
11
|
+
desc: ReactNode;
|
12
|
+
key: string;
|
13
|
+
required?: boolean;
|
14
|
+
title: ReactNode;
|
15
|
+
}
|
16
|
+
|
17
|
+
const ScoreItem = memo<ScoreItemProps>(({ required, check, desc, title }) => {
|
18
|
+
const theme = useTheme();
|
19
|
+
return (
|
20
|
+
<Flexbox align={'center'} gap={16} horizontal paddingInline={16}>
|
21
|
+
<Icon
|
22
|
+
color={check ? theme.colorSuccess : required ? theme.colorError : theme.colorTextQuaternary}
|
23
|
+
icon={check ? CircleCheckBigIcon : required ? BanIcon : CircleDashedIcon}
|
24
|
+
size={24}
|
25
|
+
/>
|
26
|
+
<Flexbox gap={4}>
|
27
|
+
<Title level={3}>{title}</Title>
|
28
|
+
<p style={{ color: theme.colorTextSecondary, margin: 0 }}>{desc}</p>
|
29
|
+
</Flexbox>
|
30
|
+
</Flexbox>
|
31
|
+
);
|
32
|
+
});
|
33
|
+
|
34
|
+
export default ScoreItem;
|
@@ -0,0 +1,24 @@
|
|
1
|
+
import { Divider } from 'antd';
|
2
|
+
import { Fragment, memo } from 'react';
|
3
|
+
import { Flexbox } from 'react-layout-kit';
|
4
|
+
|
5
|
+
import ScoreItem, { ScoreItemProps } from './ScoreItem';
|
6
|
+
|
7
|
+
interface ScoreListProps {
|
8
|
+
items: ScoreItemProps[];
|
9
|
+
}
|
10
|
+
|
11
|
+
const ScoreList = memo<ScoreListProps>(({ items }) => {
|
12
|
+
return (
|
13
|
+
<Flexbox gap={16} paddingBlock={16}>
|
14
|
+
{items.map((item, index) => (
|
15
|
+
<Fragment key={item.key}>
|
16
|
+
<ScoreItem {...item} key={item.key} />
|
17
|
+
{index < items.length - 1 && <Divider style={{ margin: 0 }} />}
|
18
|
+
</Fragment>
|
19
|
+
))}
|
20
|
+
</Flexbox>
|
21
|
+
);
|
22
|
+
});
|
23
|
+
|
24
|
+
export default ScoreList;
|
@@ -0,0 +1,289 @@
|
|
1
|
+
import { Block } from '@lobehub/ui';
|
2
|
+
import { Popover, Progress } from 'antd';
|
3
|
+
import { createStyles } from 'antd-style';
|
4
|
+
import { memo } from 'react';
|
5
|
+
import { useTranslation } from 'react-i18next';
|
6
|
+
import { Center, Flexbox } from 'react-layout-kit';
|
7
|
+
|
8
|
+
import { ScoreResult, getGradeColor, sortItemsByPriority } from '../../MCP/calculateScore';
|
9
|
+
|
10
|
+
const useStyles = createStyles(({ css, token }) => ({
|
11
|
+
colorDot: css`
|
12
|
+
width: 8px;
|
13
|
+
height: 8px;
|
14
|
+
border-radius: 50%;
|
15
|
+
`,
|
16
|
+
container: css`
|
17
|
+
padding: 24px;
|
18
|
+
border: 1px solid ${token.colorBorderSecondary};
|
19
|
+
border-radius: 12px;
|
20
|
+
background: ${token.colorFillQuaternary};
|
21
|
+
`,
|
22
|
+
description: css`
|
23
|
+
margin-block-start: 8px;
|
24
|
+
font-size: 14px;
|
25
|
+
color: ${token.colorTextSecondary};
|
26
|
+
`,
|
27
|
+
gradeBadge: css`
|
28
|
+
flex: none;
|
29
|
+
|
30
|
+
width: 32px;
|
31
|
+
height: 32px;
|
32
|
+
border: 2px solid;
|
33
|
+
border-radius: 50%;
|
34
|
+
|
35
|
+
font-size: 16px;
|
36
|
+
font-weight: bold;
|
37
|
+
`,
|
38
|
+
gradeInfo: css`
|
39
|
+
display: flex;
|
40
|
+
gap: 12px;
|
41
|
+
align-items: center;
|
42
|
+
margin-block-start: 12px;
|
43
|
+
`,
|
44
|
+
itemList: css`
|
45
|
+
margin-block: 8px;
|
46
|
+
margin-inline: 0;
|
47
|
+
padding-inline-start: 16px;
|
48
|
+
|
49
|
+
li {
|
50
|
+
margin-block: 4px;
|
51
|
+
margin-inline: 0;
|
52
|
+
}
|
53
|
+
`,
|
54
|
+
legend: css`
|
55
|
+
display: flex;
|
56
|
+
gap: 16px;
|
57
|
+
margin-block-start: 8px;
|
58
|
+
font-size: 12px;
|
59
|
+
`,
|
60
|
+
legendItem: css`
|
61
|
+
display: flex;
|
62
|
+
gap: 4px;
|
63
|
+
align-items: center;
|
64
|
+
`,
|
65
|
+
progressContainer: css`
|
66
|
+
margin-block-start: 16px;
|
67
|
+
`,
|
68
|
+
scoreText: css`
|
69
|
+
font-size: 24px;
|
70
|
+
font-weight: 600;
|
71
|
+
color: ${token.colorText};
|
72
|
+
`,
|
73
|
+
sectionTitle: css`
|
74
|
+
margin-block: 12px 6px;
|
75
|
+
margin-inline: 0;
|
76
|
+
padding-block-start: 8px;
|
77
|
+
border-block-start: 1px solid ${token.colorBorderSecondary};
|
78
|
+
|
79
|
+
font-size: 14px;
|
80
|
+
font-weight: 600;
|
81
|
+
color: ${token.colorText};
|
82
|
+
|
83
|
+
&:first-of-type {
|
84
|
+
padding-block-start: 0;
|
85
|
+
border-block-start: none;
|
86
|
+
}
|
87
|
+
`,
|
88
|
+
tooltipContent: css`
|
89
|
+
max-width: 400px;
|
90
|
+
line-height: 1.5;
|
91
|
+
`,
|
92
|
+
}));
|
93
|
+
|
94
|
+
interface ScoreItem {
|
95
|
+
check: boolean;
|
96
|
+
required?: boolean;
|
97
|
+
title: string;
|
98
|
+
weight?: number;
|
99
|
+
}
|
100
|
+
|
101
|
+
interface TotalScoreProps {
|
102
|
+
isValidated?: boolean;
|
103
|
+
scoreItems?: ScoreItem[];
|
104
|
+
scoreResult: ScoreResult;
|
105
|
+
}
|
106
|
+
|
107
|
+
const TotalScore = memo<TotalScoreProps>(({ scoreResult, scoreItems = [], isValidated }) => {
|
108
|
+
const { styles, theme } = useStyles();
|
109
|
+
const { t } = useTranslation('discover');
|
110
|
+
|
111
|
+
const { totalScore, maxScore, percentage, grade } = scoreResult;
|
112
|
+
|
113
|
+
// 使用主题颜色的段级颜色配置
|
114
|
+
const SEGMENT_COLORS = {
|
115
|
+
// 绿色 (80-100%)
|
116
|
+
A_COLOR: theme.colorSuccess,
|
117
|
+
|
118
|
+
// 黄色 (60-85%)
|
119
|
+
B_COLOR: theme.colorWarning,
|
120
|
+
|
121
|
+
// 红色 (0-60%)
|
122
|
+
F_COLOR: theme.colorError,
|
123
|
+
};
|
124
|
+
|
125
|
+
const allItems = sortItemsByPriority([...scoreItems]);
|
126
|
+
const completedRequired = allItems.filter((item) => item.required && item.check);
|
127
|
+
const incompleteRequired = allItems.filter((item) => item.required && !item.check);
|
128
|
+
const completedOptional = allItems.filter((item) => !item.required && item.check);
|
129
|
+
const incompleteOptional = allItems.filter((item) => !item.required && !item.check);
|
130
|
+
|
131
|
+
// 计算必需项个数
|
132
|
+
const totalRequiredItems = completedRequired.length + incompleteRequired.length;
|
133
|
+
const completedRequiredItems = completedRequired.length;
|
134
|
+
|
135
|
+
// 生成 tooltip 内容
|
136
|
+
const renderTooltipContent = () => (
|
137
|
+
<div className={styles.tooltipContent}>
|
138
|
+
<div style={{ fontSize: '14px', marginBottom: '12px' }}>
|
139
|
+
<strong>
|
140
|
+
{totalScore}/{maxScore} {t('mcp.details.totalScore.scoreInfo.points')} (
|
141
|
+
{Math.round(percentage)}%)
|
142
|
+
</strong>
|
143
|
+
</div>
|
144
|
+
|
145
|
+
{completedRequired.length > 0 && (
|
146
|
+
<>
|
147
|
+
<div className={styles.sectionTitle} style={{ color: getGradeColor(grade, theme) }}>
|
148
|
+
{t('mcp.details.totalScore.popover.completedRequired', {
|
149
|
+
count: completedRequired.length,
|
150
|
+
})}
|
151
|
+
:
|
152
|
+
</div>
|
153
|
+
<ul className={styles.itemList}>
|
154
|
+
{completedRequired.map((item, index) => (
|
155
|
+
<li key={index}>{item.title}</li>
|
156
|
+
))}
|
157
|
+
</ul>
|
158
|
+
</>
|
159
|
+
)}
|
160
|
+
|
161
|
+
{incompleteRequired.length > 0 && (
|
162
|
+
<>
|
163
|
+
<div className={styles.sectionTitle} style={{ color: theme.colorError }}>
|
164
|
+
{t('mcp.details.totalScore.popover.incompleteRequired', {
|
165
|
+
count: incompleteRequired.length,
|
166
|
+
})}
|
167
|
+
:
|
168
|
+
</div>
|
169
|
+
<ul className={styles.itemList}>
|
170
|
+
{incompleteRequired.map((item, index) => (
|
171
|
+
<li key={index}>{item.title}</li>
|
172
|
+
))}
|
173
|
+
</ul>
|
174
|
+
</>
|
175
|
+
)}
|
176
|
+
|
177
|
+
{completedOptional.length > 0 && (
|
178
|
+
<>
|
179
|
+
<div className={styles.sectionTitle} style={{ color: getGradeColor(grade, theme) }}>
|
180
|
+
{t('mcp.details.totalScore.popover.completedOptional', {
|
181
|
+
count: completedOptional.length,
|
182
|
+
})}
|
183
|
+
:
|
184
|
+
</div>
|
185
|
+
<ul className={styles.itemList}>
|
186
|
+
{completedOptional.map((item, index) => (
|
187
|
+
<li key={index}>{item.title}</li>
|
188
|
+
))}
|
189
|
+
</ul>
|
190
|
+
</>
|
191
|
+
)}
|
192
|
+
|
193
|
+
{incompleteOptional.length > 0 && (
|
194
|
+
<>
|
195
|
+
<div className={styles.sectionTitle} style={{ color: theme.colorTextSecondary }}>
|
196
|
+
{t('mcp.details.totalScore.popover.incompleteOptional', {
|
197
|
+
count: incompleteOptional.length,
|
198
|
+
})}
|
199
|
+
:
|
200
|
+
</div>
|
201
|
+
<ul className={styles.itemList}>
|
202
|
+
{incompleteOptional.map((item, index) => (
|
203
|
+
<li key={index}>{item.title}</li>
|
204
|
+
))}
|
205
|
+
</ul>
|
206
|
+
</>
|
207
|
+
)}
|
208
|
+
</div>
|
209
|
+
);
|
210
|
+
|
211
|
+
return (
|
212
|
+
<Block gap={12} padding={16} variant={'outlined'}>
|
213
|
+
<Flexbox align="flex-start" horizontal justify="space-between">
|
214
|
+
<Flexbox>
|
215
|
+
<h2 style={{ fontWeight: 'bold', margin: 0 }}>
|
216
|
+
{t(`mcp.details.scoreLevel.${grade}.fullTitle`)}
|
217
|
+
</h2>
|
218
|
+
<div className={styles.description}>{t(`mcp.details.scoreLevel.${grade}.desc`)}</div>
|
219
|
+
</Flexbox>
|
220
|
+
{isValidated && (
|
221
|
+
<Center
|
222
|
+
className={styles.gradeBadge}
|
223
|
+
style={{
|
224
|
+
borderColor: getGradeColor(grade, theme),
|
225
|
+
color: getGradeColor(grade, theme),
|
226
|
+
}}
|
227
|
+
>
|
228
|
+
{grade.toUpperCase()}
|
229
|
+
</Center>
|
230
|
+
)}
|
231
|
+
</Flexbox>
|
232
|
+
|
233
|
+
<div className={styles.progressContainer}>
|
234
|
+
<Popover
|
235
|
+
arrow={false}
|
236
|
+
content={renderTooltipContent()}
|
237
|
+
placement="bottom"
|
238
|
+
title={t('mcp.details.totalScore.popover.title')}
|
239
|
+
trigger={['hover', 'click']}
|
240
|
+
>
|
241
|
+
<Progress
|
242
|
+
percent={Math.round(percentage)}
|
243
|
+
showInfo={false}
|
244
|
+
size={{
|
245
|
+
height: 8,
|
246
|
+
}}
|
247
|
+
strokeColor={{
|
248
|
+
'0%': SEGMENT_COLORS.F_COLOR,
|
249
|
+
'60%': SEGMENT_COLORS.B_COLOR,
|
250
|
+
'80%': SEGMENT_COLORS.A_COLOR,
|
251
|
+
}}
|
252
|
+
/>
|
253
|
+
</Popover>
|
254
|
+
|
255
|
+
<div className={styles.legend}>
|
256
|
+
<div className={styles.legendItem}>
|
257
|
+
<div className={styles.colorDot} style={{ backgroundColor: SEGMENT_COLORS.F_COLOR }} />
|
258
|
+
<span>{t('mcp.details.totalScore.legend.fGrade', { maxPercent: 60 })}</span>
|
259
|
+
</div>
|
260
|
+
<div className={styles.legendItem}>
|
261
|
+
<div className={styles.colorDot} style={{ backgroundColor: SEGMENT_COLORS.B_COLOR }} />
|
262
|
+
<span>
|
263
|
+
{t('mcp.details.totalScore.legend.bGrade', { maxPercent: 80, minPercent: 60 })}
|
264
|
+
</span>
|
265
|
+
</div>
|
266
|
+
<div className={styles.legendItem}>
|
267
|
+
<div className={styles.colorDot} style={{ backgroundColor: SEGMENT_COLORS.A_COLOR }} />
|
268
|
+
<span>{t('mcp.details.totalScore.legend.aGrade', { minPercent: 80 })}</span>
|
269
|
+
</div>
|
270
|
+
</div>
|
271
|
+
</div>
|
272
|
+
|
273
|
+
<div className={styles.gradeInfo}>
|
274
|
+
<span style={{ fontSize: '16px', fontWeight: 600 }}>
|
275
|
+
{totalScore}/{maxScore} {t('mcp.details.totalScore.scoreInfo.points')}
|
276
|
+
</span>
|
277
|
+
<span style={{ color: getGradeColor(grade, theme), fontWeight: 600 }}>
|
278
|
+
{Math.round(percentage)}%
|
279
|
+
</span>
|
280
|
+
<span style={{ color: getGradeColor(grade, theme), fontSize: '14px' }}>
|
281
|
+
{t('mcp.details.totalScore.scoreInfo.requiredItems')}: {completedRequiredItems}/
|
282
|
+
{totalRequiredItems} {t('mcp.details.totalScore.scoreInfo.items')}
|
283
|
+
</span>
|
284
|
+
</div>
|
285
|
+
</Block>
|
286
|
+
);
|
287
|
+
});
|
288
|
+
|
289
|
+
export default TotalScore;
|
@@ -0,0 +1,88 @@
|
|
1
|
+
import { Block, Grid } from '@lobehub/ui';
|
2
|
+
import { memo } from 'react';
|
3
|
+
import { useTranslation } from 'react-i18next';
|
4
|
+
import { Flexbox } from 'react-layout-kit';
|
5
|
+
|
6
|
+
import {
|
7
|
+
calculateScore,
|
8
|
+
calculateScoreFlags,
|
9
|
+
createScoreItems,
|
10
|
+
sortItemsByPriority,
|
11
|
+
} from '@/features/MCP/calculateScore';
|
12
|
+
import { useScoreList } from '@/features/MCP/useScoreList';
|
13
|
+
|
14
|
+
import Title from '../../../app/[variants]/(main)/discover/features/Title';
|
15
|
+
import { useDetailContext } from '../DetailProvider';
|
16
|
+
import GithubBadge from './GithubBadge';
|
17
|
+
import ScoreList from './ScoreList';
|
18
|
+
import TotalScore from './TotalScore';
|
19
|
+
|
20
|
+
const Score = memo(() => {
|
21
|
+
const { t } = useTranslation('discover');
|
22
|
+
const {
|
23
|
+
github,
|
24
|
+
overview,
|
25
|
+
isValidated,
|
26
|
+
toolsCount,
|
27
|
+
promptsCount,
|
28
|
+
resourcesCount,
|
29
|
+
deploymentOptions,
|
30
|
+
} = useDetailContext();
|
31
|
+
|
32
|
+
// 使用工具函数计算所有的 has* 值
|
33
|
+
const scoreFlags = calculateScoreFlags({
|
34
|
+
deploymentOptions,
|
35
|
+
github,
|
36
|
+
isClaimed: false, // 详情页暂时没有 claimed 状态
|
37
|
+
isValidated,
|
38
|
+
overview,
|
39
|
+
promptsCount,
|
40
|
+
resourcesCount,
|
41
|
+
toolsCount,
|
42
|
+
});
|
43
|
+
|
44
|
+
// 计算总分和评级
|
45
|
+
const scoreItems = createScoreItems(scoreFlags);
|
46
|
+
const scoreResult = calculateScore(scoreItems);
|
47
|
+
|
48
|
+
// 使用新的 hook 创建评分项目列表
|
49
|
+
const scoreListItems = useScoreList();
|
50
|
+
|
51
|
+
// 使用工具函数排序
|
52
|
+
const sortedScoreListItems = sortItemsByPriority(scoreListItems);
|
53
|
+
|
54
|
+
return (
|
55
|
+
<Flexbox gap={16}>
|
56
|
+
{/* 总分显示 */}
|
57
|
+
<TotalScore
|
58
|
+
isValidated={isValidated}
|
59
|
+
scoreItems={scoreListItems.map((item) => ({
|
60
|
+
check: item.check,
|
61
|
+
required: item.required,
|
62
|
+
title: item.title,
|
63
|
+
weight: item.weight,
|
64
|
+
}))}
|
65
|
+
scoreResult={scoreResult}
|
66
|
+
/>
|
67
|
+
|
68
|
+
{/* 评分明细 */}
|
69
|
+
|
70
|
+
<Grid rows={2}>
|
71
|
+
<Flexbox gap={16}>
|
72
|
+
<Title>{t('mcp.details.score.listTitle')}</Title>
|
73
|
+
<Block variant={'outlined'}>
|
74
|
+
<ScoreList items={sortedScoreListItems} />
|
75
|
+
</Block>
|
76
|
+
</Flexbox>
|
77
|
+
<Flexbox gap={16}>
|
78
|
+
<Title>GitHub Badge</Title>
|
79
|
+
<Block gap={16} padding={16} variant={'outlined'}>
|
80
|
+
<GithubBadge />
|
81
|
+
</Block>
|
82
|
+
</Flexbox>
|
83
|
+
</Grid>
|
84
|
+
</Flexbox>
|
85
|
+
);
|
86
|
+
});
|
87
|
+
|
88
|
+
export default Score;
|
@@ -4,7 +4,7 @@ import { LucideToyBrick } from 'lucide-react';
|
|
4
4
|
import { memo } from 'react';
|
5
5
|
import { useTranslation } from 'react-i18next';
|
6
6
|
|
7
|
-
import Avatar from '@/
|
7
|
+
import Avatar from '@/components/Plugins/PluginAvatar';
|
8
8
|
import { pluginHelpers, useToolStore } from '@/store/tool';
|
9
9
|
import { toolSelectors } from '@/store/tool/selectors';
|
10
10
|
|
@@ -1,5 +1,4 @@
|
|
1
|
-
import { Block } from '@lobehub/ui';
|
2
|
-
import { Typography } from 'antd';
|
1
|
+
import { Block, Text } from '@lobehub/ui';
|
3
2
|
import isEqual from 'fast-deep-equal';
|
4
3
|
import { memo } from 'react';
|
5
4
|
import { Flexbox } from 'react-layout-kit';
|
@@ -18,9 +17,9 @@ const Meta = memo<{
|
|
18
17
|
<PluginAvatar identifier={id} size={40} />
|
19
18
|
<Flexbox gap={2}>
|
20
19
|
<div>{pluginHelpers.getPluginTitle(pluginMeta)}</div>
|
21
|
-
<
|
20
|
+
<Text style={{ fontSize: 12 }} type={'secondary'}>
|
22
21
|
{pluginHelpers.getPluginDesc(pluginMeta)}
|
23
|
-
</
|
22
|
+
</Text>
|
24
23
|
</Flexbox>
|
25
24
|
</Block>
|
26
25
|
);
|
@@ -1,5 +1,4 @@
|
|
1
|
-
import { Icon } from '@lobehub/ui';
|
2
|
-
import { Typography } from 'antd';
|
1
|
+
import { Icon, Text } from '@lobehub/ui';
|
3
2
|
import { createStyles } from 'antd-style';
|
4
3
|
import { CheckIcon, RouterIcon, TerminalIcon } from 'lucide-react';
|
5
4
|
import React, { memo } from 'react';
|
@@ -161,9 +160,9 @@ const MCPTypeSelect = ({ value, onChange }: MCPTypeSelectProps) => {
|
|
161
160
|
))}
|
162
161
|
</Flexbox>
|
163
162
|
{disabled && (
|
164
|
-
<
|
163
|
+
<Text style={{ fontSize: 12, marginTop: 8 }} type="warning">
|
165
164
|
{t('dev.mcp.type.stdioNotAvailable')}
|
166
|
-
</
|
165
|
+
</Text>
|
167
166
|
)}
|
168
167
|
</Flexbox>
|
169
168
|
);
|