@lobehub/chat 1.17.7 → 1.18.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of @lobehub/chat might be problematic. Click here for more details.

Files changed (337) hide show
  1. package/.dockerignore +0 -1
  2. package/CHANGELOG.md +42 -0
  3. package/locales/ar/common.json +1 -1
  4. package/locales/ar/discover.json +204 -0
  5. package/locales/ar/metadata.json +20 -3
  6. package/locales/ar/models.json +845 -0
  7. package/locales/ar/providers.json +80 -0
  8. package/locales/bg-BG/common.json +1 -1
  9. package/locales/bg-BG/discover.json +204 -0
  10. package/locales/bg-BG/metadata.json +20 -3
  11. package/locales/bg-BG/models.json +845 -0
  12. package/locales/bg-BG/providers.json +80 -0
  13. package/locales/de-DE/common.json +1 -1
  14. package/locales/de-DE/discover.json +204 -0
  15. package/locales/de-DE/metadata.json +20 -3
  16. package/locales/de-DE/models.json +845 -0
  17. package/locales/de-DE/providers.json +80 -0
  18. package/locales/en-US/common.json +1 -1
  19. package/locales/en-US/discover.json +204 -0
  20. package/locales/en-US/metadata.json +20 -3
  21. package/locales/en-US/models.json +845 -0
  22. package/locales/en-US/providers.json +80 -0
  23. package/locales/es-ES/common.json +1 -1
  24. package/locales/es-ES/discover.json +204 -0
  25. package/locales/es-ES/metadata.json +20 -3
  26. package/locales/es-ES/models.json +845 -0
  27. package/locales/es-ES/providers.json +80 -0
  28. package/locales/fr-FR/common.json +1 -1
  29. package/locales/fr-FR/discover.json +204 -0
  30. package/locales/fr-FR/metadata.json +20 -3
  31. package/locales/fr-FR/models.json +845 -0
  32. package/locales/fr-FR/providers.json +80 -0
  33. package/locales/it-IT/common.json +1 -1
  34. package/locales/it-IT/discover.json +204 -0
  35. package/locales/it-IT/metadata.json +20 -3
  36. package/locales/it-IT/models.json +845 -0
  37. package/locales/it-IT/providers.json +80 -0
  38. package/locales/ja-JP/common.json +1 -1
  39. package/locales/ja-JP/discover.json +204 -0
  40. package/locales/ja-JP/metadata.json +20 -3
  41. package/locales/ja-JP/models.json +845 -0
  42. package/locales/ja-JP/providers.json +80 -0
  43. package/locales/ko-KR/common.json +1 -1
  44. package/locales/ko-KR/discover.json +204 -0
  45. package/locales/ko-KR/metadata.json +20 -3
  46. package/locales/ko-KR/models.json +845 -0
  47. package/locales/ko-KR/providers.json +80 -0
  48. package/locales/nl-NL/common.json +1 -1
  49. package/locales/nl-NL/discover.json +204 -0
  50. package/locales/nl-NL/metadata.json +20 -3
  51. package/locales/nl-NL/models.json +845 -0
  52. package/locales/nl-NL/providers.json +80 -0
  53. package/locales/pl-PL/common.json +1 -1
  54. package/locales/pl-PL/discover.json +204 -0
  55. package/locales/pl-PL/metadata.json +20 -3
  56. package/locales/pl-PL/models.json +845 -0
  57. package/locales/pl-PL/providers.json +80 -0
  58. package/locales/pt-BR/common.json +1 -1
  59. package/locales/pt-BR/discover.json +204 -0
  60. package/locales/pt-BR/metadata.json +20 -3
  61. package/locales/pt-BR/models.json +845 -0
  62. package/locales/pt-BR/providers.json +80 -0
  63. package/locales/ru-RU/common.json +1 -1
  64. package/locales/ru-RU/discover.json +204 -0
  65. package/locales/ru-RU/metadata.json +20 -3
  66. package/locales/ru-RU/models.json +845 -0
  67. package/locales/ru-RU/providers.json +80 -0
  68. package/locales/tr-TR/common.json +1 -1
  69. package/locales/tr-TR/discover.json +204 -0
  70. package/locales/tr-TR/metadata.json +20 -3
  71. package/locales/tr-TR/models.json +845 -0
  72. package/locales/tr-TR/providers.json +80 -0
  73. package/locales/vi-VN/common.json +1 -1
  74. package/locales/vi-VN/discover.json +204 -0
  75. package/locales/vi-VN/metadata.json +20 -3
  76. package/locales/vi-VN/models.json +845 -0
  77. package/locales/vi-VN/providers.json +80 -0
  78. package/locales/zh-CN/common.json +1 -1
  79. package/locales/zh-CN/discover.json +204 -0
  80. package/locales/zh-CN/metadata.json +20 -3
  81. package/locales/zh-CN/models.json +845 -0
  82. package/locales/zh-CN/providers.json +80 -0
  83. package/locales/zh-CN/welcome.json +1 -1
  84. package/locales/zh-TW/common.json +1 -1
  85. package/locales/zh-TW/discover.json +204 -0
  86. package/locales/zh-TW/metadata.json +20 -3
  87. package/locales/zh-TW/models.json +845 -0
  88. package/locales/zh-TW/providers.json +80 -0
  89. package/package.json +3 -2
  90. package/src/app/(main)/@nav/_layout/Desktop/TopActions.test.tsx +3 -3
  91. package/src/app/(main)/@nav/_layout/Desktop/TopActions.tsx +3 -3
  92. package/src/app/(main)/@nav/_layout/Mobile.tsx +3 -3
  93. package/src/app/(main)/_layout/Mobile.tsx +9 -1
  94. package/src/app/(main)/discover/(detail)/_layout/Desktop.tsx +24 -0
  95. package/src/app/(main)/discover/(detail)/_layout/Mobile/Header.tsx +25 -0
  96. package/src/app/(main)/discover/(detail)/_layout/Mobile/index.tsx +17 -0
  97. package/src/app/(main)/discover/(detail)/assistant/[slug]/features/Actions.tsx +35 -0
  98. package/src/app/(main)/discover/(detail)/assistant/[slug]/features/AddAgent.tsx +86 -0
  99. package/src/app/(main)/discover/(detail)/assistant/[slug]/features/ConversationExample/TopicList.tsx +74 -0
  100. package/src/app/(main)/discover/(detail)/assistant/[slug]/features/ConversationExample/index.tsx +100 -0
  101. package/src/app/(main)/discover/(detail)/assistant/[slug]/features/Header.tsx +118 -0
  102. package/src/app/(main)/discover/(detail)/assistant/[slug]/features/InfoSidebar/SuggestionItem.tsx +62 -0
  103. package/src/app/(main)/discover/(detail)/assistant/[slug]/features/InfoSidebar/ToolItem.tsx +19 -0
  104. package/src/app/(main)/discover/(detail)/assistant/[slug]/features/InfoSidebar/index.tsx +64 -0
  105. package/src/app/(main)/discover/(detail)/assistant/[slug]/features/SystemRole.tsx +35 -0
  106. package/src/app/(main)/discover/(detail)/assistant/[slug]/features/Temp.tsx +44 -0
  107. package/src/app/(main)/discover/(detail)/assistant/[slug]/page.tsx +121 -0
  108. package/src/app/(main)/discover/(detail)/error.tsx +5 -0
  109. package/src/app/(main)/discover/(detail)/features/Back.tsx +42 -0
  110. package/src/app/(main)/discover/(detail)/features/Block.tsx +50 -0
  111. package/src/app/(main)/discover/(detail)/features/DetailLayout.tsx +91 -0
  112. package/src/app/(main)/discover/(detail)/features/HighlightBlock.tsx +82 -0
  113. package/src/app/(main)/discover/(detail)/features/ShareButton.tsx +160 -0
  114. package/src/app/(main)/discover/(detail)/features/SidebarContainer.tsx +19 -0
  115. package/src/app/(main)/discover/(detail)/layout.tsx +12 -0
  116. package/src/app/(main)/discover/(detail)/loading.tsx +38 -0
  117. package/src/app/(main)/discover/(detail)/model/[...slugs]/features/Actions.tsx +46 -0
  118. package/src/app/(main)/discover/(detail)/model/[...slugs]/features/ChatWithModel.tsx +93 -0
  119. package/src/app/(main)/discover/(detail)/model/[...slugs]/features/Header.tsx +85 -0
  120. package/src/app/(main)/discover/(detail)/model/[...slugs]/features/InfoSidebar/SuggestionItem.tsx +75 -0
  121. package/src/app/(main)/discover/(detail)/model/[...slugs]/features/InfoSidebar/index.tsx +49 -0
  122. package/src/app/(main)/discover/(detail)/model/[...slugs]/features/ParameterList/ParameterItem.tsx +71 -0
  123. package/src/app/(main)/discover/(detail)/model/[...slugs]/features/ParameterList/index.tsx +110 -0
  124. package/src/app/(main)/discover/(detail)/model/[...slugs]/features/ProviderList/ProviderItem.tsx +152 -0
  125. package/src/app/(main)/discover/(detail)/model/[...slugs]/features/ProviderList/index.tsx +45 -0
  126. package/src/app/(main)/discover/(detail)/model/[...slugs]/page.tsx +114 -0
  127. package/src/app/(main)/discover/(detail)/not-found.tsx +3 -0
  128. package/src/app/(main)/discover/(detail)/plugin/[slug]/features/Actions.tsx +35 -0
  129. package/src/app/(main)/discover/(detail)/plugin/[slug]/features/Header.tsx +114 -0
  130. package/src/app/(main)/discover/(detail)/plugin/[slug]/features/InfoSidebar/SuggestionItem.tsx +62 -0
  131. package/src/app/(main)/discover/(detail)/plugin/[slug]/features/InfoSidebar/index.tsx +49 -0
  132. package/src/app/(main)/discover/(detail)/plugin/[slug]/features/InstallPlugin.tsx +87 -0
  133. package/src/app/(main)/discover/(detail)/plugin/[slug]/features/ParameterList.tsx +95 -0
  134. package/src/app/(main)/discover/(detail)/plugin/[slug]/features/Schema.tsx +23 -0
  135. package/src/app/(main)/discover/(detail)/plugin/[slug]/page.tsx +103 -0
  136. package/src/app/(main)/discover/(detail)/provider/[slug]/features/Actions.tsx +49 -0
  137. package/src/app/(main)/discover/(detail)/provider/[slug]/features/Header.tsx +73 -0
  138. package/src/app/(main)/discover/(detail)/provider/[slug]/features/InfoSidebar/SuggestionItem.tsx +75 -0
  139. package/src/app/(main)/discover/(detail)/provider/[slug]/features/InfoSidebar/index.tsx +49 -0
  140. package/src/app/(main)/discover/(detail)/provider/[slug]/features/ModelList/ModelItem.tsx +148 -0
  141. package/src/app/(main)/discover/(detail)/provider/[slug]/features/ModelList/index.tsx +60 -0
  142. package/src/app/(main)/discover/(detail)/provider/[slug]/features/ProviderConfig.tsx +80 -0
  143. package/src/app/(main)/discover/(detail)/provider/[slug]/page.tsx +116 -0
  144. package/src/app/(main)/discover/(list)/(home)/Client.tsx +42 -0
  145. package/src/app/(main)/discover/(list)/(home)/features/AssistantList.tsx +33 -0
  146. package/src/app/(main)/discover/(list)/(home)/features/ModelList.tsx +22 -0
  147. package/src/app/(main)/discover/(list)/(home)/features/PluginList.tsx +25 -0
  148. package/src/app/(main)/discover/(list)/(home)/loading.tsx +1 -0
  149. package/src/app/(main)/discover/(list)/(home)/page.tsx +54 -0
  150. package/src/app/(main)/discover/(list)/_layout/Desktop/Nav.tsx +118 -0
  151. package/src/app/(main)/discover/(list)/_layout/Desktop/index.tsx +37 -0
  152. package/src/app/(main)/discover/(list)/_layout/Desktop/useScroll.ts +33 -0
  153. package/src/app/(main)/discover/(list)/_layout/Mobile/Header.tsx +62 -0
  154. package/src/app/(main)/discover/(list)/_layout/Mobile/Nav.tsx +94 -0
  155. package/src/app/(main)/discover/(list)/_layout/Mobile/index.tsx +27 -0
  156. package/src/app/(main)/discover/(list)/assistants/[slug]/page.tsx +64 -0
  157. package/src/app/(main)/discover/(list)/assistants/_layout/Desktop.tsx +22 -0
  158. package/src/app/(main)/discover/(list)/assistants/_layout/Mobile.tsx +9 -0
  159. package/src/app/(main)/discover/(list)/assistants/features/Card.tsx +176 -0
  160. package/src/app/(main)/discover/(list)/assistants/features/Category.tsx +48 -0
  161. package/src/app/(main)/discover/(list)/assistants/features/List.tsx +97 -0
  162. package/src/app/(main)/discover/(list)/assistants/features/useCategory.tsx +116 -0
  163. package/src/app/(main)/discover/(list)/assistants/layout.tsx +12 -0
  164. package/src/app/(main)/discover/(list)/assistants/loading.tsx +1 -0
  165. package/src/app/(main)/discover/(list)/assistants/page.tsx +51 -0
  166. package/src/app/(main)/discover/(list)/error.tsx +5 -0
  167. package/src/app/(main)/{market → discover/(list)}/layout.tsx +4 -3
  168. package/src/app/(main)/discover/(list)/loading.tsx +39 -0
  169. package/src/app/(main)/discover/(list)/models/[slug]/page.tsx +70 -0
  170. package/src/app/(main)/discover/(list)/models/_layout/Desktop.tsx +28 -0
  171. package/src/app/(main)/discover/(list)/models/_layout/Mobile.tsx +9 -0
  172. package/src/app/(main)/discover/(list)/models/features/Card.tsx +116 -0
  173. package/src/app/(main)/discover/(list)/models/features/Category.tsx +67 -0
  174. package/src/app/(main)/discover/(list)/models/features/List.tsx +72 -0
  175. package/src/app/(main)/discover/(list)/models/features/const.ts +9 -0
  176. package/src/app/(main)/discover/(list)/models/layout.tsx +12 -0
  177. package/src/app/(main)/discover/(list)/models/loading.tsx +1 -0
  178. package/src/app/(main)/discover/(list)/models/page.tsx +61 -0
  179. package/src/app/(main)/discover/(list)/not-found.tsx +3 -0
  180. package/src/app/(main)/discover/(list)/plugins/[slug]/page.tsx +64 -0
  181. package/src/app/(main)/discover/(list)/plugins/_layout/Desktop.tsx +22 -0
  182. package/src/app/(main)/discover/(list)/plugins/_layout/Mobile.tsx +9 -0
  183. package/src/app/(main)/discover/(list)/plugins/features/Card.tsx +154 -0
  184. package/src/app/(main)/discover/(list)/plugins/features/Category.tsx +45 -0
  185. package/src/app/(main)/discover/(list)/plugins/features/List.tsx +96 -0
  186. package/src/app/(main)/discover/(list)/plugins/features/useCategory.tsx +80 -0
  187. package/src/app/(main)/discover/(list)/plugins/layout.tsx +12 -0
  188. package/src/app/(main)/discover/(list)/plugins/loading.tsx +1 -0
  189. package/src/app/(main)/discover/(list)/plugins/page.tsx +52 -0
  190. package/src/app/(main)/discover/(list)/providers/features/Card.tsx +117 -0
  191. package/src/app/(main)/discover/(list)/providers/features/List.tsx +71 -0
  192. package/src/app/(main)/discover/(list)/providers/loading.tsx +1 -0
  193. package/src/app/(main)/discover/(list)/providers/page.tsx +52 -0
  194. package/src/app/(main)/discover/_layout/Desktop/Header.tsx +36 -0
  195. package/src/app/(main)/discover/_layout/Desktop/index.tsx +21 -0
  196. package/src/app/(main)/discover/_layout/Mobile/index.tsx +9 -0
  197. package/src/app/(main)/{market/features/AgentCard/AgentCardBanner.tsx → discover/components/CardBanner.tsx} +5 -5
  198. package/src/app/(main)/discover/components/CategoryContainer.tsx +18 -0
  199. package/src/app/(main)/discover/components/CategoryMenu.tsx +39 -0
  200. package/src/app/(main)/discover/components/GitHubAvatar.tsx +19 -0
  201. package/src/app/(main)/discover/components/GridLoadingCard.tsx +69 -0
  202. package/src/app/(main)/discover/components/ListLoading.tsx +66 -0
  203. package/src/app/(main)/discover/components/Loading.tsx +17 -0
  204. package/src/app/(main)/discover/components/SearchResultCount.tsx +37 -0
  205. package/src/app/(main)/discover/components/Statistic.tsx +92 -0
  206. package/src/app/(main)/discover/components/Title.tsx +76 -0
  207. package/src/app/(main)/discover/components/VirtuosoGridList/index.tsx +52 -0
  208. package/src/app/(main)/discover/components/VirtuosoGridList/useScrollParent.ts +19 -0
  209. package/src/app/(main)/discover/error.tsx +5 -0
  210. package/src/app/(main)/{market/features/ShareAgentButton → discover/features/CreateButton}/Inner.tsx +9 -10
  211. package/src/app/(main)/{market/features/ShareAgentButton → discover/features/CreateButton}/index.tsx +9 -9
  212. package/src/app/(main)/discover/features/LikeButton.tsx +73 -0
  213. package/src/app/(main)/discover/features/ModelFeatureTags.tsx +77 -0
  214. package/src/app/(main)/discover/features/StoreSearchBar.tsx +84 -0
  215. package/src/app/(main)/discover/features/const.ts +2 -0
  216. package/src/app/(main)/discover/features/useNav.tsx +71 -0
  217. package/src/app/(main)/discover/layout.tsx +12 -0
  218. package/src/app/(main)/discover/loading.tsx +9 -0
  219. package/src/app/(main)/discover/not-found.tsx +3 -0
  220. package/src/app/(main)/discover/search/_layout/Desktop.tsx +42 -0
  221. package/src/app/(main)/discover/search/_layout/Mobile/Header.tsx +31 -0
  222. package/src/app/(main)/discover/search/_layout/Mobile/Nav.tsx +56 -0
  223. package/src/app/(main)/discover/search/_layout/Mobile/index.tsx +32 -0
  224. package/src/app/(main)/discover/search/features/AssistantsResult.tsx +27 -0
  225. package/src/app/(main)/discover/search/features/Category.tsx +41 -0
  226. package/src/app/(main)/discover/search/features/ModelsResult.tsx +27 -0
  227. package/src/app/(main)/discover/search/features/PluginsResult.tsx +27 -0
  228. package/src/app/(main)/discover/search/features/ProvidersResult.tsx +26 -0
  229. package/src/app/(main)/discover/search/layout.tsx +12 -0
  230. package/src/app/(main)/discover/search/loading.tsx +1 -0
  231. package/src/app/(main)/discover/search/page.tsx +78 -0
  232. package/src/app/(main)/settings/llm/components/ProviderConfig/index.tsx +0 -6
  233. package/src/app/(main)/welcome/features/Actions.tsx +1 -1
  234. package/src/app/@modal/(.)discover/assistant/[slug]/page.tsx +1 -0
  235. package/src/app/@modal/(.)discover/layout.tsx +29 -0
  236. package/src/app/@modal/(.)discover/loading.tsx +3 -0
  237. package/src/app/@modal/(.)discover/model/[...slugs]/page.tsx +1 -0
  238. package/src/app/@modal/(.)discover/plugin/[slug]/page.tsx +1 -0
  239. package/src/app/@modal/(.)discover/provider/[slug]/page.tsx +1 -0
  240. package/src/app/@modal/features/InterceptingContext.tsx +9 -0
  241. package/src/app/@modal/layout.tsx +58 -21
  242. package/src/app/api/{market → assistant}/[id]/route.ts +2 -3
  243. package/src/app/api/{market → assistant/store}/route.ts +2 -5
  244. package/src/app/api/plugin/store/route.ts +1 -4
  245. package/src/app/metadata.ts +3 -0
  246. package/src/app/redirect/page.tsx +15 -0
  247. package/src/components/FetchErrorNotification/Description.tsx +2 -0
  248. package/src/components/InterceptingLink/index.tsx +27 -0
  249. package/src/components/mdx/CodeBlock.tsx +46 -0
  250. package/src/components/mdx/Link.tsx +21 -0
  251. package/src/components/mdx/index.tsx +51 -0
  252. package/src/const/discover.ts +63 -1
  253. package/src/features/Conversation/Error/PluginSettings.tsx +1 -1
  254. package/src/features/Conversation/Messages/Tool/Inspector/Settings.tsx +1 -1
  255. package/src/features/Conversation/components/InboxWelcome/AgentsSuggest.tsx +41 -24
  256. package/src/features/MobileTabBar/index.tsx +3 -3
  257. package/src/features/PluginDetailModal/APIs.tsx +1 -1
  258. package/src/features/PluginDevModal/UrlManifestForm.tsx +1 -1
  259. package/src/features/PluginStore/PluginItem/Action.tsx +1 -1
  260. package/src/features/PluginsUI/Render/DefaultType/index.tsx +1 -1
  261. package/src/features/PluginsUI/Render/StandaloneType/index.tsx +1 -1
  262. package/src/hooks/useInterceptingRoutes.ts +21 -1
  263. package/src/hooks/useShare.tsx +191 -0
  264. package/src/locales/create.ts +1 -1
  265. package/src/locales/default/common.ts +1 -1
  266. package/src/locales/default/discover.ts +205 -0
  267. package/src/locales/default/index.ts +6 -2
  268. package/src/locales/default/metadata.ts +23 -3
  269. package/src/locales/default/models.ts +15 -0
  270. package/src/locales/default/providers.ts +15 -0
  271. package/src/locales/default/welcome.ts +1 -1
  272. package/src/locales/resources.ts +2 -0
  273. package/src/server/ld.ts +85 -11
  274. package/src/server/metadata.ts +41 -3
  275. package/src/{app/api/market/AgentMarket.test.ts → server/modules/AssistantStore/index.test.ts} +15 -15
  276. package/src/{app/api/market/AgentMarket.ts → server/modules/AssistantStore/index.ts} +7 -3
  277. package/src/{app/api/plugin/store/Store.test.ts → server/modules/PluginStore/index.test.ts} +1 -1
  278. package/src/server/services/discover/index.ts +352 -0
  279. package/src/server/services/doc/index.tsx +40 -0
  280. package/src/server/translation.ts +11 -5
  281. package/src/services/__tests__/__snapshots__/tool.test.ts.snap +1 -1
  282. package/src/services/{_auth.test.ts → __tests__/_auth.test.ts} +1 -1
  283. package/src/services/__tests__/assistant.test.ts +82 -0
  284. package/src/services/__tests__/tool.test.ts +13 -13
  285. package/src/services/_url.ts +2 -2
  286. package/src/services/assistant.ts +30 -0
  287. package/src/services/chat.ts +1 -1
  288. package/src/services/tool.ts +7 -129
  289. package/src/store/chat/slices/plugin/action.test.ts +112 -0
  290. package/src/store/chat/slices/plugin/action.ts +1 -3
  291. package/src/store/global/initialState.ts +1 -1
  292. package/src/store/tool/selectors/tool.test.ts +1 -1
  293. package/src/store/tool/slices/customPlugin/action.test.ts +1 -1
  294. package/src/store/tool/slices/customPlugin/action.ts +1 -1
  295. package/src/store/tool/slices/plugin/action.ts +1 -1
  296. package/src/store/tool/slices/plugin/selectors.test.ts +3 -3
  297. package/src/store/tool/slices/plugin/selectors.ts +3 -3
  298. package/src/store/tool/slices/store/action.test.ts +16 -22
  299. package/src/store/tool/slices/store/action.ts +8 -8
  300. package/src/types/discover.ts +152 -0
  301. package/src/types/llm.ts +4 -2
  302. package/src/types/meta.ts +1 -0
  303. package/src/utils/format.test.ts +191 -112
  304. package/src/utils/format.ts +36 -0
  305. package/src/utils/toolManifest.ts +124 -0
  306. package/src/app/(main)/market/@detail/default.tsx +0 -12
  307. package/src/app/(main)/market/@detail/features/AgentDetailContent.tsx +0 -73
  308. package/src/app/(main)/market/@detail/features/Banner.tsx +0 -46
  309. package/src/app/(main)/market/@detail/features/Comment.tsx +0 -16
  310. package/src/app/(main)/market/@detail/features/Header.tsx +0 -81
  311. package/src/app/(main)/market/@detail/features/Loading.tsx +0 -63
  312. package/src/app/(main)/market/@detail/features/TokenTag.tsx +0 -27
  313. package/src/app/(main)/market/@detail/features/style.ts +0 -32
  314. package/src/app/(main)/market/_layout/Desktop/DetailSidebar.tsx +0 -84
  315. package/src/app/(main)/market/_layout/Desktop/Header.tsx +0 -29
  316. package/src/app/(main)/market/_layout/Desktop/Hero.tsx +0 -40
  317. package/src/app/(main)/market/_layout/Desktop/index.tsx +0 -46
  318. package/src/app/(main)/market/_layout/Mobile/DetailModal.tsx +0 -32
  319. package/src/app/(main)/market/_layout/Mobile/Header.tsx +0 -20
  320. package/src/app/(main)/market/_layout/Mobile/index.tsx +0 -25
  321. package/src/app/(main)/market/_layout/type.ts +0 -6
  322. package/src/app/(main)/market/features/AgentCard/index.tsx +0 -139
  323. package/src/app/(main)/market/features/AgentList.tsx +0 -103
  324. package/src/app/(main)/market/features/AgentSearchBar.tsx +0 -42
  325. package/src/app/(main)/market/features/TagList.tsx +0 -69
  326. package/src/app/(main)/market/loading.tsx +0 -15
  327. package/src/app/(main)/market/page.tsx +0 -44
  328. package/src/const/market.ts +0 -15
  329. package/src/locales/default/market.ts +0 -32
  330. package/src/services/market.ts +0 -22
  331. package/src/store/market/action.ts +0 -82
  332. package/src/store/market/index.ts +0 -3
  333. package/src/store/market/initialState.ts +0 -19
  334. package/src/store/market/selectors.ts +0 -38
  335. package/src/store/market/store.ts +0 -48
  336. package/src/types/market.ts +0 -20
  337. /package/src/{app/api/plugin/store/Store.ts → server/modules/PluginStore/index.ts} +0 -0
@@ -0,0 +1,52 @@
1
+ import StructuredData from '@/components/StructuredData';
2
+ import { Locales } from '@/locales/resources';
3
+ import { ldModule } from '@/server/ld';
4
+ import { metadataModule } from '@/server/metadata';
5
+ import { DiscoverService } from '@/server/services/discover';
6
+ import { translation } from '@/server/translation';
7
+ import { isMobileDevice } from '@/utils/responsive';
8
+
9
+ import List from './features/List';
10
+
11
+ type Props = { searchParams: { hl?: Locales } };
12
+
13
+ export const generateMetadata = async ({ searchParams }: Props) => {
14
+ const { t, locale } = await translation('metadata', searchParams?.hl);
15
+
16
+ return metadataModule.generate({
17
+ alternate: true,
18
+ description: t('discover.plugins.description'),
19
+ locale,
20
+ title: t('discover.plugins.title'),
21
+ url: '/discover/plugins',
22
+ });
23
+ };
24
+
25
+ const Page = async ({ searchParams }: Props) => {
26
+ const { t, locale } = await translation('metadata', searchParams?.hl);
27
+ const mobile = isMobileDevice();
28
+
29
+ const discoverService = new DiscoverService();
30
+ const items = await discoverService.getPluginList(locale);
31
+
32
+ const ld = ldModule.generate({
33
+ description: t('discover.plugins.description'),
34
+ title: t('discover.plugins.title'),
35
+ url: '/discover/plugins',
36
+ webpage: {
37
+ enable: true,
38
+ search: '/discover/search',
39
+ },
40
+ });
41
+
42
+ return (
43
+ <>
44
+ <StructuredData ld={ld} />
45
+ <List items={items} mobile={mobile} />
46
+ </>
47
+ );
48
+ };
49
+
50
+ Page.DisplayName = 'DiscoverTools';
51
+
52
+ export default Page;
@@ -0,0 +1,117 @@
1
+ import { ModelTag, ProviderCombine } from '@lobehub/icons';
2
+ import { Tag } from '@lobehub/ui';
3
+ import { Skeleton, Typography } from 'antd';
4
+ import { createStyles } from 'antd-style';
5
+ import dynamic from 'next/dynamic';
6
+ import { memo } from 'react';
7
+ import { useTranslation } from 'react-i18next';
8
+ import { Flexbox, FlexboxProps } from 'react-layout-kit';
9
+ import urlJoin from 'url-join';
10
+
11
+ import { DiscoverProviderItem } from '@/types/discover';
12
+
13
+ const Link = dynamic(() => import('next/link'), {
14
+ loading: () => <Skeleton.Button size={'small'} style={{ height: 22 }} />,
15
+ ssr: false,
16
+ });
17
+
18
+ const { Paragraph } = Typography;
19
+
20
+ const useStyles = createStyles(({ css, token, isDarkMode }) => ({
21
+ banner: css`
22
+ opacity: ${isDarkMode ? 0.9 : 0.4};
23
+ `,
24
+ container: css`
25
+ cursor: pointer;
26
+
27
+ position: relative;
28
+
29
+ overflow: hidden;
30
+
31
+ height: 100%;
32
+ min-height: 162px;
33
+
34
+ background: ${token.colorBgContainer};
35
+ border-radius: ${token.borderRadiusLG}px;
36
+ box-shadow: 0 0 1px 1px ${isDarkMode ? token.colorFillQuaternary : token.colorFillSecondary}
37
+ inset;
38
+
39
+ transition: box-shadow 0.2s ${token.motionEaseInOut};
40
+
41
+ &:hover {
42
+ box-shadow: 0 0 1px 1px ${isDarkMode ? token.colorFillSecondary : token.colorFill} inset;
43
+ }
44
+ `,
45
+ desc: css`
46
+ min-height: 44px;
47
+ margin-block-end: 0 !important;
48
+ color: ${token.colorTextDescription};
49
+ `,
50
+ tagBlue: css`
51
+ color: ${token.geekblue};
52
+ background: ${token.geekblue1};
53
+ `,
54
+ tagGreen: css`
55
+ color: ${token.green};
56
+ background: ${token.green1};
57
+ `,
58
+ time: css`
59
+ color: ${token.colorTextDescription};
60
+ `,
61
+ title: css`
62
+ zoom: 1.2;
63
+ margin-block-end: 0 !important;
64
+ font-size: 18px !important;
65
+ font-weight: bold;
66
+ `,
67
+ token: css`
68
+ font-family: ${token.fontFamilyCode};
69
+ `,
70
+ }));
71
+
72
+ export interface ProviderCardProps extends DiscoverProviderItem, FlexboxProps {
73
+ mobile?: boolean;
74
+ }
75
+
76
+ const ProviderCard = memo<ProviderCardProps>(({ models, className, meta, identifier, ...rest }) => {
77
+ const { description } = meta;
78
+ const { t } = useTranslation(['discover', 'providers']);
79
+ const { cx, styles, theme } = useStyles();
80
+
81
+ return (
82
+ <Flexbox className={cx(styles.container, className)} gap={24} {...rest}>
83
+ <Flexbox gap={12} padding={16} width={'100%'}>
84
+ <ProviderCombine
85
+ provider={identifier}
86
+ size={28}
87
+ style={{ color: theme.colorText }}
88
+ title={meta.title}
89
+ />
90
+ <Flexbox gap={8} horizontal style={{ fontSize: 12, marginTop: -8 }}>
91
+ <div style={{ color: theme.colorTextSecondary }}>@{meta.title}</div>
92
+ <div style={{ color: theme.colorTextDescription }}>
93
+ {t('providers.modelCount', { count: models.length })}
94
+ </div>
95
+ </Flexbox>
96
+ {description && (
97
+ <Paragraph className={styles.desc} ellipsis={{ rows: 2 }}>
98
+ {t(`${identifier}.description`, { ns: 'providers' })}
99
+ </Paragraph>
100
+ )}
101
+ <Flexbox gap={6} horizontal style={{ flexWrap: 'wrap' }}>
102
+ {models
103
+ .slice(0, 3)
104
+ .filter(Boolean)
105
+ .map((tag: string) => (
106
+ <Link href={urlJoin('/discover/model', tag)} key={tag}>
107
+ <ModelTag model={tag} style={{ margin: 0 }} />
108
+ </Link>
109
+ ))}
110
+ {models.length > 3 && <Tag>...</Tag>}
111
+ </Flexbox>
112
+ </Flexbox>
113
+ </Flexbox>
114
+ );
115
+ });
116
+
117
+ export default ProviderCard;
@@ -0,0 +1,71 @@
1
+ 'use client';
2
+
3
+ import { Empty } from 'antd';
4
+ import { memo } from 'react';
5
+ import { useTranslation } from 'react-i18next';
6
+ import urlJoin from 'url-join';
7
+
8
+ import InterceptingLink from '@/components/InterceptingLink';
9
+ import { DiscoverProviderItem } from '@/types/discover';
10
+
11
+ import SearchResultCount from '../../../components/SearchResultCount';
12
+ import Title from '../../../components/Title';
13
+ import { VirtuosoList } from '../../../components/VirtuosoGridList';
14
+ import Card from './Card';
15
+
16
+ export interface ListProps {
17
+ items?: DiscoverProviderItem[];
18
+ mobile?: boolean;
19
+ searchKeywords?: string;
20
+ }
21
+
22
+ const List = memo<ListProps>(({ searchKeywords, items = [], mobile }) => {
23
+ const { t } = useTranslation('discover');
24
+
25
+ if (searchKeywords) {
26
+ if (!items || items?.length === 0) return <Empty image={Empty.PRESENTED_IMAGE_SIMPLE} />;
27
+ return (
28
+ <>
29
+ <SearchResultCount count={items.length} keyword={searchKeywords} />
30
+ <VirtuosoList
31
+ data={items}
32
+ initialItemCount={6}
33
+ itemContent={(_, item) => (
34
+ <InterceptingLink
35
+ href={urlJoin('/discover/provider/', item.identifier)}
36
+ key={item.identifier}
37
+ >
38
+ <Card {...item} mobile={mobile} style={{ minHeight: 'unset' }} />
39
+ </InterceptingLink>
40
+ )}
41
+ style={{
42
+ minHeight: '75vh',
43
+ }}
44
+ />
45
+ </>
46
+ );
47
+ }
48
+
49
+ return (
50
+ <>
51
+ <Title tag={items.length}>{t('providers.list')}</Title>
52
+ <VirtuosoList
53
+ data={items}
54
+ initialItemCount={6}
55
+ itemContent={(_, item) => (
56
+ <InterceptingLink
57
+ href={urlJoin('/discover/provider/', item.identifier)}
58
+ key={item.identifier}
59
+ >
60
+ <Card {...item} mobile={mobile} style={{ minHeight: 'unset' }} />
61
+ </InterceptingLink>
62
+ )}
63
+ style={{
64
+ minHeight: '75vh',
65
+ }}
66
+ />
67
+ </>
68
+ );
69
+ });
70
+
71
+ export default List;
@@ -0,0 +1 @@
1
+ export { ProviderListLoading as default } from '../../components/ListLoading';
@@ -0,0 +1,52 @@
1
+ import StructuredData from '@/components/StructuredData';
2
+ import { Locales } from '@/locales/resources';
3
+ import { ldModule } from '@/server/ld';
4
+ import { metadataModule } from '@/server/metadata';
5
+ import { DiscoverService } from '@/server/services/discover';
6
+ import { translation } from '@/server/translation';
7
+ import { isMobileDevice } from '@/utils/responsive';
8
+
9
+ import List from './features/List';
10
+
11
+ type Props = { searchParams: { hl?: Locales } };
12
+
13
+ export const generateMetadata = async ({ searchParams }: Props) => {
14
+ const { t, locale } = await translation('metadata', searchParams?.hl);
15
+
16
+ return metadataModule.generate({
17
+ alternate: true,
18
+ description: t('discover.providers.description'),
19
+ locale,
20
+ title: t('discover.providers.title'),
21
+ url: '/discover/providers',
22
+ });
23
+ };
24
+
25
+ const Page = async ({ searchParams }: Props) => {
26
+ const { t, locale } = await translation('metadata', searchParams?.hl);
27
+ const mobile = isMobileDevice();
28
+
29
+ const discoverService = new DiscoverService();
30
+ const items = await discoverService.getProviderList(locale);
31
+
32
+ const ld = ldModule.generate({
33
+ description: t('discover.providers.description'),
34
+ title: t('discover.providers.title'),
35
+ url: '/discover/providers',
36
+ webpage: {
37
+ enable: true,
38
+ search: '/discover/search',
39
+ },
40
+ });
41
+
42
+ return (
43
+ <>
44
+ <StructuredData ld={ld} />
45
+ <List items={items} mobile={mobile} />
46
+ </>
47
+ );
48
+ };
49
+
50
+ Page.DisplayName = 'DiscoverProviders';
51
+
52
+ export default Page;
@@ -0,0 +1,36 @@
1
+ 'use client';
2
+
3
+ import { ChatHeader } from '@lobehub/ui';
4
+ import Link from 'next/link';
5
+ import { memo } from 'react';
6
+
7
+ import { ProductLogo } from '@/components/Branding';
8
+
9
+ import CreateButton from '../../features/CreateButton';
10
+ import StoreSearchBar from '../../features/StoreSearchBar';
11
+
12
+ const Header = memo(() => {
13
+ return (
14
+ <ChatHeader
15
+ left={
16
+ <Link href={'/discover'} style={{ color: 'inherit' }}>
17
+ <ProductLogo extra={'Discover'} size={36} type={'text'} />
18
+ </Link>
19
+ }
20
+ right={<CreateButton />}
21
+ style={{
22
+ position: 'relative',
23
+ zIndex: 10,
24
+ }}
25
+ styles={{
26
+ center: { flex: 1, maxWidth: 1440 },
27
+ left: { flex: 1, maxWidth: 240 },
28
+ right: { flex: 1, maxWidth: 240 },
29
+ }}
30
+ >
31
+ <StoreSearchBar />
32
+ </ChatHeader>
33
+ );
34
+ });
35
+
36
+ export default Header;
@@ -0,0 +1,21 @@
1
+ import { PropsWithChildren } from 'react';
2
+ import { Flexbox } from 'react-layout-kit';
3
+
4
+ import Header from './Header';
5
+
6
+ const Layout = ({ children }: PropsWithChildren) => {
7
+ return (
8
+ <>
9
+ <Flexbox height={'100%'} style={{ overflow: 'hidden', position: 'relative' }} width={'100%'}>
10
+ <Header />
11
+ {children}
12
+ </Flexbox>
13
+ {/* ↓ cloud slot ↓ */}
14
+ {/* ↑ cloud slot ↑ */}
15
+ </>
16
+ );
17
+ };
18
+
19
+ Layout.displayName = 'DesktopDiscoverStoreLayout';
20
+
21
+ export default Layout;
@@ -0,0 +1,9 @@
1
+ import { PropsWithChildren } from 'react';
2
+
3
+ const Layout = ({ children }: PropsWithChildren) => {
4
+ return children;
5
+ };
6
+
7
+ Layout.displayName = 'MobileDiscoverStoreLayout';
8
+
9
+ export default Layout;
@@ -1,6 +1,6 @@
1
1
  import { Avatar, DivProps } from '@lobehub/ui';
2
2
  import { createStyles } from 'antd-style';
3
- import { memo } from 'react';
3
+ import { ReactNode, memo } from 'react';
4
4
  import { Flexbox } from 'react-layout-kit';
5
5
 
6
6
  export const useStyles = createStyles(({ css, token }) => ({
@@ -20,15 +20,15 @@ export const useStyles = createStyles(({ css, token }) => ({
20
20
  `,
21
21
  }));
22
22
 
23
- interface AgentCardBannerProps extends DivProps {
24
- avatar?: string;
23
+ interface CardBannerProps extends DivProps {
24
+ avatar?: string | ReactNode;
25
25
  loading?: boolean;
26
26
  mask?: boolean;
27
27
  maskColor?: string;
28
28
  size?: number;
29
29
  }
30
30
 
31
- const AgentCardBanner = memo<AgentCardBannerProps>(
31
+ const CardBanner = memo<CardBannerProps>(
32
32
  ({ avatar, className, size = 600, children, ...props }) => {
33
33
  const { styles, theme, cx } = useStyles();
34
34
 
@@ -56,4 +56,4 @@ const AgentCardBanner = memo<AgentCardBannerProps>(
56
56
  },
57
57
  );
58
58
 
59
- export default AgentCardBanner;
59
+ export default CardBanner;
@@ -0,0 +1,18 @@
1
+ import { PropsWithChildren, memo } from 'react';
2
+ import { Flexbox } from 'react-layout-kit';
3
+
4
+ const CategoryContainer = memo<PropsWithChildren<{ top?: number }>>(({ children, top = 64 }) => {
5
+ return (
6
+ <Flexbox
7
+ as={'aside'}
8
+ flex={'none'}
9
+ height={`calc(100vh - ${top * 2 + 4}px)`}
10
+ style={{ overflowX: 'hidden', overflowY: 'hidden', position: 'sticky', top }}
11
+ width={220}
12
+ >
13
+ {children}
14
+ </Flexbox>
15
+ );
16
+ });
17
+
18
+ export default CategoryContainer;
@@ -0,0 +1,39 @@
1
+ 'use client';
2
+
3
+ import { ConfigProvider, Menu, MenuProps } from 'antd';
4
+ import { useTheme } from 'antd-style';
5
+ import { memo } from 'react';
6
+
7
+ export const ICON_SIZE = { fontSize: '1.25em' };
8
+
9
+ const CategoryMenu = memo<MenuProps>(({ style, ...rest }) => {
10
+ const theme = useTheme();
11
+
12
+ return (
13
+ <ConfigProvider
14
+ theme={{
15
+ components: {
16
+ Menu: {
17
+ itemSelectedBg: theme.colorFillTertiary,
18
+ },
19
+ },
20
+ }}
21
+ >
22
+ <Menu
23
+ mode="inline"
24
+ style={{
25
+ background: 'transparent',
26
+ border: 'none',
27
+ fontSize: 16,
28
+ overflowX: 'hidden',
29
+ overflowY: 'auto',
30
+ width: '100%',
31
+ ...style,
32
+ }}
33
+ {...rest}
34
+ />
35
+ </ConfigProvider>
36
+ );
37
+ });
38
+
39
+ export default CategoryMenu;
@@ -0,0 +1,19 @@
1
+ import { Avatar, type AvatarProps } from '@lobehub/ui';
2
+ import qs from 'query-string';
3
+ import { memo } from 'react';
4
+ import urlJoin from 'url-join';
5
+
6
+ interface GitHubAvatarProps extends Omit<AvatarProps, 'avatar'> {
7
+ username: string;
8
+ }
9
+
10
+ const GitHubAvatar = memo<GitHubAvatarProps>(({ username, size = 24 }) => {
11
+ const url = qs.stringifyUrl({
12
+ query: { size: size * 2 },
13
+ url: urlJoin('https://github.com', `${username}.png`),
14
+ });
15
+
16
+ return <Avatar alt={username} avatar={url} size={size} />;
17
+ });
18
+
19
+ export default GitHubAvatar;
@@ -0,0 +1,69 @@
1
+ 'use client';
2
+
3
+ import { Grid } from '@lobehub/ui';
4
+ import { Skeleton } from 'antd';
5
+ import { createStyles } from 'antd-style';
6
+ import { memo } from 'react';
7
+ import { Flexbox } from 'react-layout-kit';
8
+
9
+ const useStyles = createStyles(({ css, token, isDarkMode }) => ({
10
+ container: css`
11
+ cursor: pointer;
12
+
13
+ position: relative;
14
+
15
+ overflow: hidden;
16
+
17
+ background: ${token.colorBgContainer};
18
+ border-radius: ${token.borderRadiusLG}px;
19
+ box-shadow: 0 0 1px 1px ${isDarkMode ? token.colorFillQuaternary : token.colorFillSecondary}
20
+ inset;
21
+
22
+ transition: box-shadow 0.2s ${token.motionEaseInOut};
23
+ `,
24
+ desc: css`
25
+ min-height: 44px;
26
+ margin-block-end: 0 !important;
27
+ color: ${token.colorTextDescription};
28
+ `,
29
+
30
+ time: css`
31
+ color: ${token.colorTextDescription};
32
+ `,
33
+ title: css`
34
+ margin-block-end: 0 !important;
35
+ font-weight: bold;
36
+ `,
37
+ }));
38
+
39
+ const Card = memo<{ banner?: boolean }>(({ banner }) => {
40
+ const { styles } = useStyles();
41
+ return (
42
+ <Flexbox className={styles.container}>
43
+ {banner && (
44
+ <Flexbox width={'100%'}>
45
+ <Skeleton.Button style={{ height: 64, width: '100%' }} />
46
+ </Flexbox>
47
+ )}
48
+ <Flexbox padding={16}>
49
+ <Skeleton active />
50
+ </Flexbox>
51
+ </Flexbox>
52
+ );
53
+ });
54
+
55
+ interface GridLoadingCardProps {
56
+ banner?: boolean;
57
+ count?: number;
58
+ rows?: number;
59
+ }
60
+
61
+ const GridLoadingCard = memo<GridLoadingCardProps>(({ count = 8, rows = 4, banner }) => (
62
+ <Grid maxItemWidth={280} rows={rows}>
63
+ {Array.from({ length: count }).map((_, index) => (
64
+ <Card banner={banner} key={index} />
65
+ ))}
66
+ </Grid>
67
+ ));
68
+
69
+ export default GridLoadingCard;
@@ -0,0 +1,66 @@
1
+ 'use client';
2
+
3
+ import { Skeleton } from 'antd';
4
+ import { memo } from 'react';
5
+ import { Flexbox } from 'react-layout-kit';
6
+
7
+ import GridLoadingCard from './GridLoadingCard';
8
+
9
+ const ListLoading = memo(() => {
10
+ return (
11
+ <Flexbox gap={16}>
12
+ <Flexbox justify={'center'} style={{ minHeight: 62 }}>
13
+ <Skeleton.Button active style={{ minWidth: 150 }} />
14
+ </Flexbox>
15
+ <GridLoadingCard banner />
16
+ <Flexbox justify={'center'} style={{ minHeight: 62 }}>
17
+ <Skeleton.Button active style={{ minWidth: 150 }} />
18
+ </Flexbox>
19
+ <GridLoadingCard />
20
+ </Flexbox>
21
+ );
22
+ });
23
+
24
+ export const ListLoadingWithoutBanner = memo<{ banner?: boolean }>(() => {
25
+ return (
26
+ <Flexbox gap={16}>
27
+ <Flexbox justify={'center'} style={{ minHeight: 62 }}>
28
+ <Skeleton.Button active style={{ minWidth: 150 }} />
29
+ </Flexbox>
30
+ <GridLoadingCard count={16} />
31
+ </Flexbox>
32
+ );
33
+ });
34
+
35
+ export const ProviderListLoading = memo<{ banner?: boolean }>(() => {
36
+ return (
37
+ <Flexbox gap={16}>
38
+ <Flexbox justify={'center'} style={{ minHeight: 62 }}>
39
+ <Skeleton.Button active style={{ minWidth: 150 }} />
40
+ </Flexbox>
41
+ <GridLoadingCard count={6} rows={1} />
42
+ </Flexbox>
43
+ );
44
+ });
45
+
46
+ export const HomeLoading = memo<{ banner?: boolean }>(() => {
47
+ return (
48
+ <Flexbox gap={16}>
49
+ <Flexbox justify={'center'} style={{ minHeight: 62 }}>
50
+ <Skeleton.Button active style={{ minWidth: 150 }} />
51
+ </Flexbox>
52
+ <GridLoadingCard banner />
53
+ <GridLoadingCard />
54
+ <Flexbox justify={'center'} style={{ minHeight: 62 }}>
55
+ <Skeleton.Button active style={{ minWidth: 150 }} />
56
+ </Flexbox>
57
+ <GridLoadingCard />
58
+ <Flexbox justify={'center'} style={{ minHeight: 62 }}>
59
+ <Skeleton.Button active style={{ minWidth: 150 }} />
60
+ </Flexbox>
61
+ <GridLoadingCard />
62
+ </Flexbox>
63
+ );
64
+ });
65
+
66
+ export default ListLoading;
@@ -0,0 +1,17 @@
1
+ 'use client';
2
+
3
+ import { Skeleton } from 'antd';
4
+ import { memo } from 'react';
5
+
6
+ import Title from './Title';
7
+
8
+ const Loading = memo<{ title: string }>(({ title }) => {
9
+ return (
10
+ <>
11
+ <Title>{title}</Title>
12
+ <Skeleton active paragraph={{ rows: 8 }} title={false} />
13
+ </>
14
+ );
15
+ });
16
+
17
+ export default Loading;
@@ -0,0 +1,37 @@
1
+ 'use client';
2
+
3
+ import { createStyles } from 'antd-style';
4
+ import { memo } from 'react';
5
+ import { Trans } from 'react-i18next';
6
+
7
+ import Title from './Title';
8
+
9
+ const useStyles = createStyles(({ css, token }) => ({
10
+ highlight: css`
11
+ color: ${token.colorInfo};
12
+
13
+ &::before,
14
+ &::after {
15
+ content: '\`';
16
+ }
17
+ `,
18
+ }));
19
+
20
+ const SearchResultCount = memo<{ count: number; keyword: string }>(({ keyword, count }) => {
21
+ const { styles } = useStyles();
22
+ return (
23
+ <Title>
24
+ <Trans
25
+ components={{ highlight: <span className={styles.highlight} /> }}
26
+ i18nKey={'search.result'}
27
+ ns={'discover'}
28
+ values={{
29
+ count,
30
+ keyword,
31
+ }}
32
+ />
33
+ </Title>
34
+ );
35
+ });
36
+
37
+ export default SearchResultCount;