@gientech/modual 2.0.3 → 2.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (419) hide show
  1. package/.editorconfig +38 -0
  2. package/.prettierignore +16 -0
  3. package/.prettierrc +17 -0
  4. package/README.md +643 -643
  5. package/USAGE.md +247 -0
  6. package/bash.exe.stackdump +40 -0
  7. package/components.json +21 -0
  8. package/dist/README.md +643 -0
  9. package/{assets/GientechStreamReader-CzB5AuYo.js → dist/assets/GientechStreamReader-DUCq-O5X.js} +1 -1
  10. package/{assets → dist/assets}/database.svg +11 -11
  11. package/{assets → dist/assets}/database_add.svg +53 -53
  12. package/{assets → dist/assets}/database_connect.svg +66 -66
  13. package/{assets → dist/assets}/database_upload.svg +29 -29
  14. package/{assets → dist/assets}/databse.svg +6 -6
  15. package/{assets → dist/assets}/defaultWeLogo.svg +14 -14
  16. package/{assets → dist/assets}/graph.svg +4 -4
  17. package/{assets/index-CN2AYX8Q.js → dist/assets/index-B2yNvzjy.js} +1 -1
  18. package/{assets/index-D9lYd8TZ.js → dist/assets/index-BKe5FgcC.js} +1 -1
  19. package/{assets/index-CBTA5S-5.js → dist/assets/index-D72cKELw.js} +1 -1
  20. package/{assets/index-s0cmC4Ks.js → dist/assets/index-DdVFXD_y.js} +1 -1
  21. package/{assets/index-B1ZDDbC1.js → dist/assets/index-DrkSoKz6.js} +1 -1
  22. package/{assets/index-B2rFliXg.js → dist/assets/index-KCfkkJKb.js} +1 -1
  23. package/{assets/index-DnBY0UXI.js → dist/assets/index-QI9biQrR.js} +2 -2
  24. package/{assets/index-DYhXjvk4.js → dist/assets/index-ZopkeZtI.js} +1 -1
  25. package/{assets/index-LDFwTu47.js → dist/assets/index-g-SUxfJH.js} +1 -1
  26. package/{assets/index-NFQIKNFn.js → dist/assets/index-j0kQJd0a.js} +1 -1
  27. package/{assets → dist/assets}/knowledge.svg +4 -4
  28. package/{assets/MySQL.svg → dist/assets/mysql.svg} +14 -14
  29. package/{assets/plus-G7zGXf6S.js → dist/assets/plus-V9zUoSq6.js} +1 -1
  30. package/{assets → dist/assets}/sensitive.svg +5 -5
  31. package/{assets/style-Bn7b5XHU.js → dist/assets/style-CGmZ5osp.js} +2 -2
  32. package/{assets/x-vfKYzKkK.js → dist/assets/x-CnaaLGJF.js} +1 -1
  33. package/dist/assistantConfig.js +1 -0
  34. package/dist/chat.js +824 -0
  35. package/dist/database.js +20 -0
  36. package/dist/databaseId.js +1 -0
  37. package/{databaseTable.js → dist/databaseTable.js} +1 -1
  38. package/dist/index.js +1 -0
  39. package/{modelManage.js → dist/modelManage.js} +1 -1
  40. package/dist/package.json +68 -0
  41. package/{sensitive.js → dist/sensitive.js} +1 -1
  42. package/dist/streamFilesReader.js +1 -0
  43. package/{worker → dist/worker}/pdf.worker.min.js +21 -21
  44. package/doc_assets/2.png +0 -0
  45. package/doc_assets/demo.md +27 -0
  46. package/doc_assets/demos/dist-app/assets/index.Dh-ZAS9Z.css +2 -0
  47. package/doc_assets/demos/dist-app/assets/index.Dv8KVW18.js +23699 -0
  48. package/doc_assets/demos/dist-app/assets/index.Dv8KVW18.js.map +1 -0
  49. package/doc_assets/demos/dist-app/index.html +14 -0
  50. package/doc_assets/demos/dist-app/vite.svg +1 -0
  51. package/doc_assets/images/1.png +0 -0
  52. package/doc_assets/images/3.png +0 -0
  53. package/doc_assets/images/component-screenshot.png +1 -0
  54. package/doc_assets/install.md +5 -0
  55. package/doc_assets//346/226/271/346/241/210//344/274/230/345/214/226/346/226/271/346/241/210-/345/244/232/344/274/232/350/257/235SSE/350/277/236/346/216/245/347/256/241/347/220/206.md +504 -0
  56. package/eslint.config.js +92 -0
  57. package/index.html +13 -0
  58. package/package.json +106 -44
  59. package/package.json.demo-backup +109 -0
  60. package/postcss.config.cjs +19 -0
  61. package/public/icons/answerAwartar.png +0 -0
  62. package/public/icons/docx-file.png +0 -0
  63. package/public/icons/folder.png +0 -0
  64. package/public/icons/html.png +0 -0
  65. package/public/icons/image.png +0 -0
  66. package/public/icons/jpg-file.png +0 -0
  67. package/public/icons/json.png +0 -0
  68. package/public/icons/md.png +0 -0
  69. package/public/icons/pdf.png +0 -0
  70. package/public/icons/pptx.png +0 -0
  71. package/public/icons/questionAwartar.png +0 -0
  72. package/public/icons/sheets.png +0 -0
  73. package/public/icons/txt.png +0 -0
  74. package/public/icons/xlsx.png +0 -0
  75. package/public/vite.svg +1 -0
  76. package/public/worker/pdf.worker.min.js +22 -0
  77. package/scripts/README.md +133 -0
  78. package/scripts/build-demo.js +88 -0
  79. package/scripts/decrypt-api-key.js +95 -0
  80. package/scripts/demo-selector.js +216 -0
  81. package/scripts/dev-demo.js +76 -0
  82. package/scripts/preview-demo.js +130 -0
  83. package/scripts/run-demo.bat +34 -0
  84. package/src/assets/img/close.png +0 -0
  85. package/src/assets/img/database.png +0 -0
  86. package/src/assets/img/downArrow.png +0 -0
  87. package/src/assets/img/downLoad.png +0 -0
  88. package/src/assets/img/excel.png +0 -0
  89. package/src/assets/img/graphIcon.png +0 -0
  90. package/src/assets/img/img.png +0 -0
  91. package/src/assets/img/pdf.png +0 -0
  92. package/src/assets/img/ppt.png +0 -0
  93. package/src/assets/img/singleQa.png +0 -0
  94. package/src/assets/img/txt.png +0 -0
  95. package/src/assets/img/webSearch.png +0 -0
  96. package/src/assets/img/word.png +0 -0
  97. package/src/assets/login/homeBg.png +0 -0
  98. package/src/assets/login/left.jpg +0 -0
  99. package/src/assets/login/logoImg.png +0 -0
  100. package/src/examples/ConversationAssistantPage/index.tsx +41 -0
  101. package/src/examples/Demo/index.tsx +12 -0
  102. package/src/examples/LoginPage/index.tsx +18 -0
  103. package/src/examples/chat/components/DrawerGraphPreview.tsx +78 -0
  104. package/src/examples/chat/index.tsx +154 -0
  105. package/src/examples/chat/logo03.png +0 -0
  106. package/src/examples/gientechStreamFilesReader/index.tsx +951 -0
  107. package/src/examples/headlessChat/index.tsx +234 -0
  108. package/src/examples/ragDatabaseDataPage/index.tsx +40 -0
  109. package/src/examples/ragDatabaseIdPage/index.tsx +47 -0
  110. package/src/examples/ragDatabasePage/index.tsx +36 -0
  111. package/src/examples/ragModelManagePage/index.tsx +38 -0
  112. package/src/examples/ragSearchPage/index.tsx +0 -0
  113. package/src/examples/ragSensitiveWordsPage/index.tsx +32 -0
  114. package/src/examples/streamFiles/index.tsx +417 -0
  115. package/src/lib_enter.ts +43 -0
  116. package/src/main.tsx +5 -0
  117. package/src/main.tsx.backup +5 -0
  118. package/src/modules/CHAT_UNIFICATION_PLAN.md +324 -0
  119. package/src/modules/assistantConfig/assets/databse.svg +6 -0
  120. package/src/modules/assistantConfig/assets/empty.png +0 -0
  121. package/src/modules/assistantConfig/assets/graph.svg +4 -0
  122. package/src/modules/assistantConfig/assets/knowledge.svg +4 -0
  123. package/src/modules/assistantConfig/assets/sensitive.svg +5 -0
  124. package/src/modules/assistantConfig/components/Database.tsx +171 -0
  125. package/src/modules/assistantConfig/components/Graph.tsx +177 -0
  126. package/src/modules/assistantConfig/components/Knowledge.tsx +276 -0
  127. package/src/modules/assistantConfig/components/NotFoundContent.tsx +21 -0
  128. package/src/modules/assistantConfig/components/Paragraph.tsx +51 -0
  129. package/src/modules/assistantConfig/components/ParamsItem.tsx +39 -0
  130. package/src/modules/assistantConfig/components/ResourceBinderItem.tsx +133 -0
  131. package/src/modules/assistantConfig/components/SearchableSelector.tsx +500 -0
  132. package/src/modules/assistantConfig/components/Sensitive.tsx +221 -0
  133. package/src/modules/assistantConfig/components/SliderInput.tsx +65 -0
  134. package/src/modules/assistantConfig/constants.tsx +75 -0
  135. package/src/modules/assistantConfig/index.tsx +710 -0
  136. package/src/modules/assistantConfig/server.ts +262 -0
  137. package/src/modules/chat/Conversations/Item.tsx +167 -0
  138. package/src/modules/chat/Conversations/List.tsx +210 -0
  139. package/src/modules/chat/Conversations/groupByTime.ts +39 -0
  140. package/src/modules/chat/Conversations/index.tsx +252 -0
  141. package/src/modules/chat/ReferenceBar.tsx +622 -0
  142. package/src/modules/chat/constants.tsx +52 -0
  143. package/src/modules/chat/data.txt +82 -0
  144. package/src/modules/chat/index.tsx +2054 -0
  145. package/src/modules/chat/referenceCom/DeleteModal.tsx +75 -0
  146. package/src/modules/chat/referenceCom/DrawerContent.tsx +136 -0
  147. package/src/modules/chat/referenceCom/DrawerDatabase.tsx +102 -0
  148. package/src/modules/chat/referenceCom/DrawerGraphPreview.tsx +86 -0
  149. package/src/modules/chat/referenceCom/DrawerPreview.tsx +73 -0
  150. package/src/modules/chat/referenceCom/DrawerTitle.tsx +26 -0
  151. package/src/modules/chat/referenceCom/RenameModal.tsx +86 -0
  152. package/src/modules/chat/referenceCom/TagCom.tsx +30 -0
  153. package/src/modules/chat/style.less +3 -0
  154. package/src/modules/chat/types.ts +17 -0
  155. package/src/modules/chat/utils/index.ts +348 -0
  156. package/src/modules/database/CreateModal.tsx +403 -0
  157. package/src/modules/database/assets/Doris.png +0 -0
  158. package/src/modules/database/assets/PostgreSQL.png +0 -0
  159. package/src/modules/database/assets/SQLServer.png +0 -0
  160. package/src/modules/database/assets/database.svg +11 -0
  161. package/src/modules/database/assets/database_add.svg +53 -0
  162. package/src/modules/database/assets/database_connect.svg +66 -0
  163. package/src/modules/database/assets/database_upload.svg +29 -0
  164. package/src/modules/database/assets/empty.png +0 -0
  165. package/src/modules/database/assets/mysql.svg +14 -0
  166. package/src/modules/database/index.tsx +477 -0
  167. package/src/modules/database/server.ts +196 -0
  168. package/src/modules/databaseId/CustomCom.tsx +156 -0
  169. package/src/modules/databaseId/EditConfig.tsx +280 -0
  170. package/src/modules/databaseId/UploadDrawer.tsx +535 -0
  171. package/src/modules/databaseId/assets/aiOptimize.svg +10 -0
  172. package/src/modules/databaseId/assets/empty.png +0 -0
  173. package/src/modules/databaseId/assets/template.svg +6 -0
  174. package/src/modules/databaseId/assets/upload.svg +9 -0
  175. package/src/modules/databaseId/assets/useTemp.svg +6 -0
  176. package/src/modules/databaseId/index.tsx +769 -0
  177. package/src/modules/databaseId/server.ts +286 -0
  178. package/src/modules/databaseId/style.css +5 -0
  179. package/src/modules/databaseTable/EditRowDrawer.tsx +124 -0
  180. package/src/modules/databaseTable/index.tsx +359 -0
  181. package/src/modules/databaseTable/server.ts +180 -0
  182. package/src/modules/headlessChat/ReferenceBar.tsx +783 -0
  183. package/src/modules/headlessChat/constants.tsx +54 -0
  184. package/src/modules/headlessChat/index.tsx +1706 -0
  185. package/src/modules/headlessChat/referenceCom/DeleteModal.tsx +75 -0
  186. package/src/modules/headlessChat/referenceCom/DrawerContent.tsx +136 -0
  187. package/src/modules/headlessChat/referenceCom/DrawerDatabase.tsx +102 -0
  188. package/src/modules/headlessChat/referenceCom/DrawerGraphPreview.tsx +86 -0
  189. package/src/modules/headlessChat/referenceCom/DrawerPreview.tsx +73 -0
  190. package/src/modules/headlessChat/referenceCom/DrawerTitle.tsx +26 -0
  191. package/src/modules/headlessChat/referenceCom/RenameModal.tsx +86 -0
  192. package/src/modules/headlessChat/referenceCom/TagCom.tsx +30 -0
  193. package/src/modules/headlessChat/style.less +3 -0
  194. package/src/modules/headlessChat/types.ts +23 -0
  195. package/src/modules/headlessChat/utils/index.ts +348 -0
  196. package/src/modules/login/components/Login/LoginBox/index.tsx +102 -0
  197. package/src/modules/login/components/Login/RegisterBox/index.tsx +180 -0
  198. package/src/modules/login/components/Login/index.tsx +100 -0
  199. package/src/modules/login/index.tsx +106 -0
  200. package/src/modules/login/style.css +3 -0
  201. package/src/modules/login/useServices.ts +53 -0
  202. package/src/modules/login/utils.ts +42 -0
  203. package/src/modules/modelManage/ConfigDrawer.tsx +249 -0
  204. package/src/modules/modelManage/ReplaceModal.tsx +124 -0
  205. package/src/modules/modelManage/assets/empty.png +0 -0
  206. package/src/modules/modelManage/const.ts +51 -0
  207. package/src/modules/modelManage/index.tsx +606 -0
  208. package/src/modules/modelManage/server.ts +223 -0
  209. package/src/modules/nodegraph/index.tsx +1 -0
  210. package/src/modules/search/assets/Icon-history.svg +8 -0
  211. package/src/modules/search/assets/answerAwartar.png +0 -0
  212. package/src/modules/search/assets/doc.png +0 -0
  213. package/src/modules/search/assets/genera.gif +0 -0
  214. package/src/modules/search/assets/icon-robot.svg +9 -0
  215. package/src/modules/search/assets/icon-search-bar.svg +14 -0
  216. package/src/modules/search/assets/icon-sub-title.svg +3 -0
  217. package/src/modules/search/assets/icon-title.svg +9 -0
  218. package/src/modules/search/assets/icon-zoomOut.svg +9 -0
  219. package/src/modules/search/assets/iconAi.svg +9 -0
  220. package/src/modules/search/assets/pdf.png +0 -0
  221. package/src/modules/search/assets/ppt.png +0 -0
  222. package/src/modules/search/assets/search.svg +3 -0
  223. package/src/modules/search/assets/selected.svg +4 -0
  224. package/src/modules/search/assets/txt.png +0 -0
  225. package/src/modules/search/assets/xls.png +0 -0
  226. package/src/modules/search/components/AssisSelect.tsx +137 -0
  227. package/src/modules/search/components/Editor/ChatViewEditor.tsx +261 -0
  228. package/src/modules/search/components/Editor/aichat.css +1 -0
  229. package/src/modules/search/components/Editor/constant.ts +13 -0
  230. package/src/modules/search/components/Editor/index.tsx +113 -0
  231. package/src/modules/search/components/Editor/plugins/autofomatRules.ts +332 -0
  232. package/src/modules/search/components/Editor/plugins/convertImgPlugins.tsx +20 -0
  233. package/src/modules/search/components/Editor/plugins/createIndexes.tsx +38 -0
  234. package/src/modules/search/components/Editor/plugins/displayer.ts +298 -0
  235. package/src/modules/search/components/Editor/plugins/imageClick.tsx +32 -0
  236. package/src/modules/search/components/Editor/plugins/myplugin.tsx +98 -0
  237. package/src/modules/search/components/Editor/ui/avatar.tsx +19 -0
  238. package/src/modules/search/components/Editor/ui/blockquote-element.tsx +21 -0
  239. package/src/modules/search/components/Editor/ui/button.tsx +58 -0
  240. package/src/modules/search/components/Editor/ui/calendar.tsx +68 -0
  241. package/src/modules/search/components/Editor/ui/caption.tsx +46 -0
  242. package/src/modules/search/components/Editor/ui/checkbox.tsx +27 -0
  243. package/src/modules/search/components/Editor/ui/code-block-combobox.tsx +188 -0
  244. package/src/modules/search/components/Editor/ui/code-block-element.css +434 -0
  245. package/src/modules/search/components/Editor/ui/code-block-element.tsx +39 -0
  246. package/src/modules/search/components/Editor/ui/code-leaf.tsx +24 -0
  247. package/src/modules/search/components/Editor/ui/code-line-element.tsx +10 -0
  248. package/src/modules/search/components/Editor/ui/code-syntax-leaf.tsx +21 -0
  249. package/src/modules/search/components/Editor/ui/column-element.tsx +30 -0
  250. package/src/modules/search/components/Editor/ui/column-group-element.tsx +94 -0
  251. package/src/modules/search/components/Editor/ui/command.tsx +75 -0
  252. package/src/modules/search/components/Editor/ui/comment-avatar.tsx +22 -0
  253. package/src/modules/search/components/Editor/ui/comment-create-form.tsx +37 -0
  254. package/src/modules/search/components/Editor/ui/comment-item.tsx +74 -0
  255. package/src/modules/search/components/Editor/ui/comment-leaf.tsx +49 -0
  256. package/src/modules/search/components/Editor/ui/comment-more-dropdown.tsx +42 -0
  257. package/src/modules/search/components/Editor/ui/comment-reply-items.tsx +22 -0
  258. package/src/modules/search/components/Editor/ui/comment-resolve-button.tsx +32 -0
  259. package/src/modules/search/components/Editor/ui/comment-value.tsx +34 -0
  260. package/src/modules/search/components/Editor/ui/comments-popover.tsx +63 -0
  261. package/src/modules/search/components/Editor/ui/date-element.tsx +83 -0
  262. package/src/modules/search/components/Editor/ui/dialog.tsx +63 -0
  263. package/src/modules/search/components/Editor/ui/draggable.tsx +177 -0
  264. package/src/modules/search/components/Editor/ui/dropdown-menu.tsx +180 -0
  265. package/src/modules/search/components/Editor/ui/emoji-input-element.tsx +85 -0
  266. package/src/modules/search/components/Editor/ui/excalidraw-element.tsx +28 -0
  267. package/src/modules/search/components/Editor/ui/fixed-toolbar-buttons.tsx +76 -0
  268. package/src/modules/search/components/Editor/ui/fixed-toolbar.tsx +8 -0
  269. package/src/modules/search/components/Editor/ui/floating-toolbar-buttons.tsx +51 -0
  270. package/src/modules/search/components/Editor/ui/floating-toolbar.tsx +77 -0
  271. package/src/modules/search/components/Editor/ui/heading-element.tsx +48 -0
  272. package/src/modules/search/components/Editor/ui/highlight-leaf.tsx +17 -0
  273. package/src/modules/search/components/Editor/ui/hr-element.tsx +30 -0
  274. package/src/modules/search/components/Editor/ui/icons.tsx +267 -0
  275. package/src/modules/search/components/Editor/ui/image-element.tsx +74 -0
  276. package/src/modules/search/components/Editor/ui/inline-combobox.tsx +368 -0
  277. package/src/modules/search/components/Editor/ui/input.tsx +25 -0
  278. package/src/modules/search/components/Editor/ui/insert-dropdown-menu.tsx +218 -0
  279. package/src/modules/search/components/Editor/ui/kbd-leaf.tsx +20 -0
  280. package/src/modules/search/components/Editor/ui/link-element.tsx +29 -0
  281. package/src/modules/search/components/Editor/ui/link-floating-toolbar.tsx +161 -0
  282. package/src/modules/search/components/Editor/ui/list-element.tsx +30 -0
  283. package/src/modules/search/components/Editor/ui/mark-toolbar-button.tsx +24 -0
  284. package/src/modules/search/components/Editor/ui/media-embed-element.tsx +133 -0
  285. package/src/modules/search/components/Editor/ui/media-popover.tsx +97 -0
  286. package/src/modules/search/components/Editor/ui/mention-element.tsx +43 -0
  287. package/src/modules/search/components/Editor/ui/mention-input-element.tsx +141 -0
  288. package/src/modules/search/components/Editor/ui/mode-dropdown-menu.tsx +93 -0
  289. package/src/modules/search/components/Editor/ui/more-dropdown-menu.tsx +67 -0
  290. package/src/modules/search/components/Editor/ui/paragraph-element.tsx +4 -0
  291. package/src/modules/search/components/Editor/ui/placeholder.tsx +52 -0
  292. package/src/modules/search/components/Editor/ui/popover.tsx +32 -0
  293. package/src/modules/search/components/Editor/ui/resizable.tsx +66 -0
  294. package/src/modules/search/components/Editor/ui/separator.tsx +25 -0
  295. package/src/modules/search/components/Editor/ui/style.less +12 -0
  296. package/src/modules/search/components/Editor/ui/table-cell-element.tsx +143 -0
  297. package/src/modules/search/components/Editor/ui/table-element.tsx +243 -0
  298. package/src/modules/search/components/Editor/ui/table-row-element.tsx +22 -0
  299. package/src/modules/search/components/Editor/ui/tableValue.tsx +135 -0
  300. package/src/modules/search/components/Editor/ui/todo-list-element.tsx +43 -0
  301. package/src/modules/search/components/Editor/ui/toggle-element.tsx +31 -0
  302. package/src/modules/search/components/Editor/ui/toolbar.tsx +157 -0
  303. package/src/modules/search/components/Editor/ui/tooltip.tsx +65 -0
  304. package/src/modules/search/components/Editor/ui/turn-into-dropdown-menu.tsx +160 -0
  305. package/src/modules/search/components/Editor/ui/with-draggables.tsx +175 -0
  306. package/src/modules/search/components/FileList.tsx +287 -0
  307. package/src/modules/search/components/ImageGroupView/index.tsx +85 -0
  308. package/src/modules/search/components/ResultContent.tsx +232 -0
  309. package/src/modules/search/components/SearchInput.tsx +232 -0
  310. package/src/modules/search/components/SearchLanding.tsx +74 -0
  311. package/src/modules/search/components/SearchView.tsx +563 -0
  312. package/src/modules/search/components/SimpleEditor.tsx +158 -0
  313. package/src/modules/search/components/SimpleFileList.tsx +215 -0
  314. package/src/modules/search/index.tsx +10 -0
  315. package/src/modules/search/reademe.md +1 -0
  316. package/src/modules/search/servers/apis.tsx +19 -0
  317. package/src/modules/search/servers/index.ts +184 -0
  318. package/src/modules/search/style.less +503 -0
  319. package/src/modules/search/type.ts +22 -0
  320. package/src/modules/search/utils.ts +34 -0
  321. package/src/modules/sensitive/index.tsx +313 -0
  322. package/src/modules/sensitive/server.ts +122 -0
  323. package/src/modules/streamFilesReader/GientechStreamReader.tsx +1625 -0
  324. package/src/modules/streamFilesReader/components/Header/Toolbar.tsx +0 -0
  325. package/src/modules/streamFilesReader/components/Header/index.tsx +297 -0
  326. package/src/modules/streamFilesReader/index.tsx +3 -0
  327. package/src/style.css +6 -0
  328. package/src/type.d.ts +0 -0
  329. package/src/utils/commonFn.tsx +111 -0
  330. package/src/utils/decryptApiKey.ts +40 -0
  331. package/src/utils/gientechCommon/components/AppError.tsx +32 -0
  332. package/src/utils/gientechCommon/components/AppLoading.tsx +75 -0
  333. package/src/utils/gientechCommon/components/DeleteModal.tsx +75 -0
  334. package/src/utils/gientechCommon/components/DisplayError.tsx +33 -0
  335. package/src/utils/gientechCommon/components/DisplayLoading.tsx +38 -0
  336. package/src/utils/gientechCommon/components/FeedBackModal.tsx +319 -0
  337. package/src/utils/gientechCommon/components/FileCardCommon.tsx +82 -0
  338. package/src/utils/gientechCommon/components/FileManager/index.tsx +400 -0
  339. package/src/utils/gientechCommon/components/FileManager/style.css +5 -0
  340. package/src/utils/gientechCommon/components/Messages/GientechNewChatWelcome.tsx +581 -0
  341. package/src/utils/gientechCommon/components/Messages/ReferenceCard.tsx +359 -0
  342. package/src/utils/gientechCommon/components/Messages/RetriveItem.tsx +245 -0
  343. package/src/utils/gientechCommon/components/Messages/WebRetriveItem.tsx +209 -0
  344. package/src/utils/gientechCommon/components/Messages/defaultBot.png +0 -0
  345. package/src/utils/gientechCommon/components/Messages/defaultStyleSet.tsx +148 -0
  346. package/src/utils/gientechCommon/components/Messages/defaultWeLogo.svg +14 -0
  347. package/src/utils/gientechCommon/components/RenameModal.tsx +86 -0
  348. package/src/utils/gientechCommon/components/style.less +11 -0
  349. package/src/utils/gientechCommon/configs/commonConfig.ts +2 -0
  350. package/src/utils/gientechCommon/configs/senderConfig.ts +0 -0
  351. package/src/utils/gientechCommon/configs/stylesConfig.ts +142 -0
  352. package/src/utils/gientechCommon/hooks/AichatUseController.tsx +417 -0
  353. package/src/utils/gientechCommon/hooks/useFileDisplayTools.tsx +204 -0
  354. package/src/utils/gientechCommon/hooks/useFileManager.ts +193 -0
  355. package/src/utils/gientechCommon/slate/converters/deserializers.ts +763 -0
  356. package/src/utils/gientechCommon/slate/converters/mockData.ts +232 -0
  357. package/src/utils/gientechCommon/slate/converters/slateConverters.ts +258 -0
  358. package/src/utils/gientechCommon/slate/richElements/index.tsx +499 -0
  359. package/src/utils/gientechCommon/utils/fileUtils.ts +86 -0
  360. package/src/utils/gientechCommon/utils/request.ts +37 -0
  361. package/src/utils/gientechCommon/utils/serverFn.ts +172 -0
  362. package/src/utils/index.tsx +142 -0
  363. package/src/utils/testconfigs/demologin/index.tsx +32 -0
  364. package/src/utils/testconfigs/index.ts +59 -0
  365. package/src/vite-env.d.ts +42 -0
  366. package/stats.html +4949 -0
  367. package/tailwind.config.js +170 -0
  368. package/tsconfig.app.json +30 -0
  369. package/tsconfig.app.tsbuildinfo +11 -0
  370. package/tsconfig.json +13 -0
  371. package/tsconfig.node.json +22 -0
  372. package/tsconfig.node.tsbuildinfo +1 -0
  373. package/vite.config.app.ts +93 -0
  374. package/vite.config.ts +232 -0
  375. package/workflows/release.yml +60 -0
  376. package//346/215/242/350/241/214/346/240/274/345/274/217/344/277/235/346/214/201/344/274/230/345/214/226/346/226/271/346/241/210.md +359 -0
  377. package/assistantConfig.js +0 -1
  378. package/chat.js +0 -786
  379. package/database.js +0 -20
  380. package/databaseId.js +0 -1
  381. package/index.js +0 -1
  382. package/streamFilesReader.js +0 -1
  383. /package/{assets → dist/assets}/Doris.png +0 -0
  384. /package/{assets → dist/assets}/PostgreSQL.png +0 -0
  385. /package/{assets → dist/assets}/SQLServer.png +0 -0
  386. /package/{assets → dist/assets}/empty.png +0 -0
  387. /package/{assets → dist/assets}/homeBg.png +0 -0
  388. /package/{assets → dist/assets}/index-CpW6Dhpp.js +0 -0
  389. /package/{assets → dist/assets}/left.jpg +0 -0
  390. /package/{assets → dist/assets}/logoImg.png +0 -0
  391. /package/{assets → dist/assets}/style.css +0 -0
  392. /package/{assets → dist/assets}/style2.css +0 -0
  393. /package/{assets → dist/assets}/style3.css +0 -0
  394. /package/{assets → dist/assets}/style4.css +0 -0
  395. /package/{assets → dist/assets}/worker-BbpylX7l.js +0 -0
  396. /package/{assistantConfig.d.ts → dist/assistantConfig.d.ts} +0 -0
  397. /package/{chat.d.ts → dist/chat.d.ts} +0 -0
  398. /package/{database.d.ts → dist/database.d.ts} +0 -0
  399. /package/{databaseId.d.ts → dist/databaseId.d.ts} +0 -0
  400. /package/{databaseTable.d.ts → dist/databaseTable.d.ts} +0 -0
  401. /package/{icons → dist/icons}/answerAwartar.png +0 -0
  402. /package/{icons → dist/icons}/docx-file.png +0 -0
  403. /package/{icons → dist/icons}/folder.png +0 -0
  404. /package/{icons → dist/icons}/html.png +0 -0
  405. /package/{icons → dist/icons}/image.png +0 -0
  406. /package/{icons → dist/icons}/jpg-file.png +0 -0
  407. /package/{icons → dist/icons}/json.png +0 -0
  408. /package/{icons → dist/icons}/md.png +0 -0
  409. /package/{icons → dist/icons}/pdf.png +0 -0
  410. /package/{icons → dist/icons}/pptx.png +0 -0
  411. /package/{icons → dist/icons}/questionAwartar.png +0 -0
  412. /package/{icons → dist/icons}/sheets.png +0 -0
  413. /package/{icons → dist/icons}/txt.png +0 -0
  414. /package/{icons → dist/icons}/xlsx.png +0 -0
  415. /package/{index.d.ts → dist/index.d.ts} +0 -0
  416. /package/{modelManage.d.ts → dist/modelManage.d.ts} +0 -0
  417. /package/{sensitive.d.ts → dist/sensitive.d.ts} +0 -0
  418. /package/{streamFilesReader.d.ts → dist/streamFilesReader.d.ts} +0 -0
  419. /package/{vite.svg → dist/vite.svg} +0 -0
@@ -0,0 +1,368 @@
1
+ import React, {
2
+ type HTMLAttributes,
3
+ type ReactNode,
4
+ type RefObject,
5
+ createContext,
6
+ forwardRef,
7
+ startTransition,
8
+ useCallback,
9
+ useContext,
10
+ useEffect,
11
+ useMemo,
12
+ useState,
13
+ } from 'react';
14
+
15
+ import type { PointRef } from 'slate';
16
+
17
+ import {
18
+ Combobox,
19
+ ComboboxItem,
20
+ type ComboboxItemProps,
21
+ ComboboxPopover,
22
+ ComboboxProvider,
23
+ Portal,
24
+ useComboboxContext,
25
+ useComboboxStore,
26
+ } from '@ariakit/react';
27
+ import { cn } from '@udecode/cn';
28
+ import { filterWords } from '@udecode/plate-combobox';
29
+ import {
30
+ type UseComboboxInputResult,
31
+ useComboboxInput,
32
+ useHTMLInputCursorState,
33
+ } from '@udecode/plate-combobox/react';
34
+ import {
35
+ type TElement,
36
+ createPointRef,
37
+ getPointBefore,
38
+ insertText,
39
+ moveSelection,
40
+ } from '@udecode/plate-common';
41
+ import {
42
+ findNodePath,
43
+ useComposedRef,
44
+ useEditorRef,
45
+ } from '@udecode/plate-common/react';
46
+ import { cva } from 'class-variance-authority';
47
+
48
+ type FilterFn = (
49
+ item: { keywords?: string[]; value: string },
50
+ search: string
51
+ ) => boolean;
52
+
53
+ interface InlineComboboxContextValue {
54
+ filter: FilterFn | false;
55
+ inputProps: UseComboboxInputResult['props'];
56
+ inputRef: RefObject<HTMLInputElement>;
57
+ removeInput: UseComboboxInputResult['removeInput'];
58
+ setHasEmpty: (hasEmpty: boolean) => void;
59
+ showTrigger: boolean;
60
+ trigger: string;
61
+ }
62
+
63
+ const InlineComboboxContext = createContext<InlineComboboxContextValue>(
64
+ null as any
65
+ );
66
+
67
+ export const defaultFilter: FilterFn = ({ keywords = [], value }, search) =>
68
+ [value, ...keywords].some((keyword) => filterWords(keyword, search));
69
+
70
+ interface InlineComboboxProps {
71
+ children: ReactNode;
72
+ element: TElement;
73
+ trigger: string;
74
+ filter?: FilterFn | false;
75
+ hideWhenNoValue?: boolean;
76
+ setValue?: (value: string) => void;
77
+ showTrigger?: boolean;
78
+ value?: string;
79
+ }
80
+
81
+ const InlineCombobox = ({
82
+ children,
83
+ element,
84
+ filter = defaultFilter,
85
+ hideWhenNoValue = false,
86
+ setValue: setValueProp,
87
+ showTrigger = true,
88
+ trigger,
89
+ value: valueProp,
90
+ }: InlineComboboxProps) => {
91
+ const editor = useEditorRef();
92
+ const inputRef = React.useRef<HTMLInputElement>(null);
93
+ const cursorState = useHTMLInputCursorState(inputRef);
94
+
95
+ const [valueState, setValueState] = useState('');
96
+ const hasValueProp = valueProp !== undefined;
97
+ const value = hasValueProp ? valueProp : valueState;
98
+
99
+ const setValue = useCallback(
100
+ (newValue: string) => {
101
+ setValueProp?.(newValue);
102
+
103
+ if (!hasValueProp) {
104
+ setValueState(newValue);
105
+ }
106
+ },
107
+ [setValueProp, hasValueProp]
108
+ );
109
+
110
+ /**
111
+ * Track the point just before the input element so we know where to
112
+ * insertText if the combobox closes due to a selection change.
113
+ */
114
+ const [insertPoint, setInsertPoint] = useState<PointRef | null>(null);
115
+
116
+ useEffect(() => {
117
+ const path = findNodePath(editor, element);
118
+
119
+ if (!path) return;
120
+
121
+ const point = getPointBefore(editor, path);
122
+
123
+ if (!point) return;
124
+
125
+ const pointRef = createPointRef(editor, point);
126
+ setInsertPoint(pointRef);
127
+
128
+ return () => {
129
+ pointRef.unref();
130
+ };
131
+ }, [editor, element]);
132
+
133
+ const { props: inputProps, removeInput } = useComboboxInput({
134
+ cancelInputOnBlur: false,
135
+ cursorState,
136
+ onCancelInput: (cause) => {
137
+ if (cause !== 'backspace') {
138
+ insertText(editor, trigger + value, {
139
+ at: insertPoint?.current ?? undefined,
140
+ });
141
+ }
142
+ if (cause === 'arrowLeft' || cause === 'arrowRight') {
143
+ moveSelection(editor, {
144
+ distance: 1,
145
+ reverse: cause === 'arrowLeft',
146
+ });
147
+ }
148
+ },
149
+ ref: inputRef,
150
+ });
151
+
152
+ const [hasEmpty, setHasEmpty] = useState(false);
153
+
154
+ const contextValue: InlineComboboxContextValue = useMemo(
155
+ () => ({
156
+ filter,
157
+ inputProps,
158
+ inputRef,
159
+ removeInput,
160
+ setHasEmpty,
161
+ showTrigger,
162
+ trigger,
163
+ }),
164
+ [
165
+ trigger,
166
+ showTrigger,
167
+ filter,
168
+ inputRef,
169
+ inputProps,
170
+ removeInput,
171
+ setHasEmpty,
172
+ ]
173
+ );
174
+
175
+ const store = useComboboxStore({
176
+ // open: ,
177
+ setValue: (newValue) => startTransition(() => setValue(newValue)),
178
+ });
179
+
180
+ const items = store.useState('items');
181
+
182
+ /**
183
+ * If there is no active ID and the list of items changes, select the first
184
+ * item.
185
+ */
186
+ useEffect(() => {
187
+ if (!store.getState().activeId) {
188
+ store.setActiveId(store.first());
189
+ }
190
+ // eslint-disable-next-line react-hooks/exhaustive-deps
191
+ }, [items, store]);
192
+
193
+ return (
194
+ <span contentEditable={false}>
195
+ <ComboboxProvider
196
+ open={
197
+ (items.length > 0 || hasEmpty) &&
198
+ (!hideWhenNoValue || value.length > 0)
199
+ }
200
+ store={store}
201
+ >
202
+ <InlineComboboxContext.Provider value={contextValue}>
203
+ {children}
204
+ </InlineComboboxContext.Provider>
205
+ </ComboboxProvider>
206
+ </span>
207
+ );
208
+ };
209
+
210
+ const InlineComboboxInput = forwardRef<
211
+ HTMLInputElement,
212
+ HTMLAttributes<HTMLInputElement>
213
+ >(({ className, ...props }, propRef) => {
214
+ const {
215
+ inputProps,
216
+ inputRef: contextRef,
217
+ showTrigger,
218
+ trigger,
219
+ } = useContext(InlineComboboxContext);
220
+
221
+ const store = useComboboxContext()!;
222
+ const value = store.useState('value');
223
+
224
+ const ref = useComposedRef(propRef, contextRef);
225
+
226
+ /**
227
+ * To create an auto-resizing input, we render a visually hidden span
228
+ * containing the input value and position the input element on top of it.
229
+ * This works well for all cases except when input exceeds the width of the
230
+ * container.
231
+ */
232
+
233
+ return (
234
+ <>
235
+ {showTrigger && trigger}
236
+
237
+ <span className="relative min-h-[1lh]">
238
+ <span
239
+ aria-hidden="true"
240
+ className="invisible overflow-hidden text-nowrap"
241
+ >
242
+ {value || '\u200B'}
243
+ </span>
244
+
245
+ <Combobox
246
+ autoSelect
247
+ className={cn(
248
+ 'absolute left-0 top-0 size-full bg-transparent outline-none',
249
+ className
250
+ )}
251
+ ref={ref}
252
+ value={value}
253
+ {...inputProps}
254
+ {...props}
255
+ />
256
+ </span>
257
+ </>
258
+ );
259
+ });
260
+
261
+ InlineComboboxInput.displayName = 'InlineComboboxInput';
262
+
263
+ const InlineComboboxContent: typeof ComboboxPopover = ({
264
+ className,
265
+ ...props
266
+ }) => {
267
+ // Portal prevents CSS from leaking into popover
268
+ return (
269
+ <Portal>
270
+ <ComboboxPopover
271
+ className={cn(
272
+ 'z-[500] max-h-[288px] w-[300px] overflow-y-auto rounded-md bg-popover shadow-md',
273
+ className
274
+ )}
275
+ {...props}
276
+ />
277
+ </Portal>
278
+ );
279
+ };
280
+
281
+ const comboboxItemVariants = cva(
282
+ 'relative flex h-9 select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none',
283
+ {
284
+ defaultVariants: {
285
+ interactive: true,
286
+ },
287
+ variants: {
288
+ interactive: {
289
+ false: '',
290
+ true: 'cursor-pointer transition-colors hover:bg-accent hover:text-accent-foreground data-[active-item=true]:bg-accent data-[active-item=true]:text-accent-foreground',
291
+ },
292
+ },
293
+ }
294
+ );
295
+
296
+ export type InlineComboboxItemProps = {
297
+ keywords?: string[];
298
+ } & ComboboxItemProps &
299
+ Required<Pick<ComboboxItemProps, 'value'>>;
300
+
301
+ const InlineComboboxItem = ({
302
+ className,
303
+ keywords,
304
+ onClick,
305
+ ...props
306
+ }: InlineComboboxItemProps) => {
307
+ const { value } = props;
308
+
309
+ const { filter, removeInput } = useContext(InlineComboboxContext);
310
+
311
+ const store = useComboboxContext()!;
312
+
313
+ // Optimization: Do not subscribe to value if filter is false
314
+ const search = filter && store.useState('value');
315
+
316
+ const visible = useMemo(
317
+ () => !filter || filter({ keywords, value }, search as string),
318
+ [filter, value, keywords, search]
319
+ );
320
+
321
+ if (!visible) return null;
322
+
323
+ return (
324
+ <ComboboxItem
325
+ className={cn(comboboxItemVariants(), className)}
326
+ onClick={(event) => {
327
+ removeInput(true);
328
+ onClick?.(event);
329
+ }}
330
+ {...props}
331
+ />
332
+ );
333
+ };
334
+
335
+ const InlineComboboxEmpty = ({
336
+ children,
337
+ className,
338
+ }: HTMLAttributes<HTMLDivElement>) => {
339
+ const { setHasEmpty } = useContext(InlineComboboxContext);
340
+ const store = useComboboxContext()!;
341
+ const items = store.useState('items');
342
+
343
+ useEffect(() => {
344
+ setHasEmpty(true);
345
+
346
+ return () => {
347
+ setHasEmpty(false);
348
+ };
349
+ }, [setHasEmpty]);
350
+
351
+ if (items.length > 0) return null;
352
+
353
+ return (
354
+ <div
355
+ className={cn(comboboxItemVariants({ interactive: false }), className)}
356
+ >
357
+ {children}
358
+ </div>
359
+ );
360
+ };
361
+
362
+ export {
363
+ InlineCombobox,
364
+ InlineComboboxContent,
365
+ InlineComboboxEmpty,
366
+ InlineComboboxInput,
367
+ InlineComboboxItem,
368
+ };
@@ -0,0 +1,25 @@
1
+ import { withVariants } from '@udecode/cn';
2
+ import { cva } from 'class-variance-authority';
3
+
4
+ export const inputVariants = cva(
5
+ 'flex w-full rounded-md bg-transparent text-sm file:border-0 file:bg-background file:text-sm file:font-medium placeholder:text-muted-foreground focus-visible:outline-none disabled:cursor-not-allowed disabled:opacity-50',
6
+ {
7
+ defaultVariants: {
8
+ h: 'md',
9
+ variant: 'default',
10
+ },
11
+ variants: {
12
+ h: {
13
+ md: 'h-10 px-3 py-2',
14
+ sm: 'h-9 px-3 py-2',
15
+ },
16
+ variant: {
17
+ default:
18
+ 'border border-input ring-offset-background focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2',
19
+ ghost: 'border-none focus-visible:ring-transparent',
20
+ },
21
+ },
22
+ }
23
+ );
24
+
25
+ export const Input = withVariants('input', inputVariants, ['variant', 'h']);
@@ -0,0 +1,218 @@
1
+ import React from 'react';
2
+
3
+ import type { DropdownMenuProps } from '@radix-ui/react-dropdown-menu';
4
+
5
+ import { BlockquotePlugin } from '@udecode/plate-block-quote/react';
6
+ import { ParagraphPlugin, insertEmptyElement } from '@udecode/plate-common';
7
+ import { focusEditor, useEditorRef } from '@udecode/plate-common/react';
8
+ import { HEADING_KEYS } from '@udecode/plate-heading';
9
+
10
+ import { Icons } from './icons';
11
+
12
+ import {
13
+ DropdownMenu,
14
+ DropdownMenuContent,
15
+ DropdownMenuItem,
16
+ DropdownMenuLabel,
17
+ DropdownMenuSeparator,
18
+ DropdownMenuTrigger,
19
+ useOpenState,
20
+ } from './dropdown-menu';
21
+ import { ToolbarButton } from './toolbar';
22
+
23
+ const items = [
24
+ {
25
+ items: [
26
+ {
27
+ description: 'Paragraph',
28
+ icon: Icons.paragraph,
29
+ label: 'Paragraph',
30
+ value: ParagraphPlugin.key,
31
+ },
32
+ {
33
+ description: 'Heading 1',
34
+ icon: Icons.h1,
35
+ label: 'Heading 1',
36
+ value: HEADING_KEYS.h1,
37
+ },
38
+ {
39
+ description: 'Heading 2',
40
+ icon: Icons.h2,
41
+ label: 'Heading 2',
42
+ value: HEADING_KEYS.h2,
43
+ },
44
+ {
45
+ description: 'Heading 3',
46
+ icon: Icons.h3,
47
+ label: 'Heading 3',
48
+ value: HEADING_KEYS.h3,
49
+ },
50
+ {
51
+ description: 'Quote (⌘+⇧+.)',
52
+ icon: Icons.blockquote,
53
+ label: 'Quote',
54
+ value: BlockquotePlugin.key,
55
+ },
56
+ // {
57
+ // value: TablePlugin.key,
58
+ // label: 'Table',
59
+ // description: 'Table',
60
+ // icon: Icons.table,
61
+ // },
62
+ // {
63
+ // value: 'ul',
64
+ // label: 'Bulleted list',
65
+ // description: 'Bulleted list',
66
+ // icon: Icons.ul,
67
+ // },
68
+ // {
69
+ // value: 'ol',
70
+ // label: 'Numbered list',
71
+ // description: 'Numbered list',
72
+ // icon: Icons.ol,
73
+ // },
74
+ // {
75
+ // value: HorizontalRulePlugin.key,
76
+ // label: 'Divider',
77
+ // description: 'Divider (---)',
78
+ // icon: Icons.hr,
79
+ // },
80
+ ],
81
+ label: 'Basic blocks',
82
+ },
83
+ // {
84
+ // label: 'Media',
85
+ // items: [
86
+ // {
87
+ // value: CodeBlockPlugin.key,
88
+ // label: 'Code',
89
+ // description: 'Code (```)',
90
+ // icon: Icons.codeblock,
91
+ // },
92
+ // {
93
+ // value: ImagePlugin.key,
94
+ // label: 'Image',
95
+ // description: 'Image',
96
+ // icon: Icons.image,
97
+ // },
98
+ // {
99
+ // value: MediaEmbedPlugin.key,
100
+ // label: 'Embed',
101
+ // description: 'Embed',
102
+ // icon: Icons.embed,
103
+ // },
104
+ // {
105
+ // value: ExcalidrawPlugin.key,
106
+ // label: 'Excalidraw',
107
+ // description: 'Excalidraw',
108
+ // icon: Icons.excalidraw,
109
+ // },
110
+ // ],
111
+ // },
112
+ // {
113
+ // label: 'Inline',
114
+ // items: [
115
+ // {
116
+ // value: LinkPlugin.key,
117
+ // label: 'Link',
118
+ // description: 'Link',
119
+ // icon: Icons.link,
120
+ // },
121
+ // ],
122
+ // },
123
+ ];
124
+
125
+ export function InsertDropdownMenu(props: DropdownMenuProps) {
126
+ const editor = useEditorRef();
127
+ const openState = useOpenState();
128
+
129
+ return (
130
+ <DropdownMenu modal={false} {...openState} {...props}>
131
+ <DropdownMenuTrigger asChild>
132
+ <ToolbarButton isDropdown pressed={openState.open} tooltip="Insert">
133
+ <Icons.add />
134
+ </ToolbarButton>
135
+ </DropdownMenuTrigger>
136
+
137
+ <DropdownMenuContent
138
+ align="start"
139
+ className="flex max-h-[500px] min-w-0 flex-col gap-0.5 overflow-y-auto"
140
+ >
141
+ {items.map(({ items: nestedItems, label }, index) => (
142
+ <React.Fragment key={label}>
143
+ {index !== 0 && <DropdownMenuSeparator />}
144
+
145
+ <DropdownMenuLabel>{label}</DropdownMenuLabel>
146
+ {nestedItems.map(
147
+ ({ icon: Icon, label: itemLabel, value: type }) => (
148
+ <DropdownMenuItem
149
+ className="min-w-[180px]"
150
+ key={type}
151
+ onSelect={() => {
152
+ switch (type) {
153
+ // case CodeBlockPlugin.key: {
154
+ // insertEmptyCodeBlock(editor);
155
+ //
156
+ // break;
157
+ // }
158
+ // case ImagePlugin.key: {
159
+ // await insertMedia(editor, { type: ImagePlugin.key });
160
+ //
161
+ // break;
162
+ // }
163
+ // case MediaEmbedPlugin.key: {
164
+ // await insertMedia(editor, {
165
+ // type: MediaEmbedPlugin.key,
166
+ // });
167
+ //
168
+ // break;
169
+ // }
170
+ // case 'ul':
171
+ // case 'ol': {
172
+ // insertEmptyElement(editor, ParagraphPlugin.key, {
173
+ // select: true,
174
+ // nextBlock: true,
175
+ // });
176
+ //
177
+ // if (settingsStore.get.checkedId(IndentListPlugin.key)) {
178
+ // toggleIndentList(editor, {
179
+ // listStyleType: type === 'ul' ? 'disc' : 'decimal',
180
+ // });
181
+ // } else if (settingsStore.get.checkedId('list')) {
182
+ // toggleList(editor, { type });
183
+ // }
184
+ //
185
+ // break;
186
+ // }
187
+ // case TablePlugin.key: {
188
+ // insertTable(editor);
189
+ //
190
+ // break;
191
+ // }
192
+ // case LinkPlugin.key: {
193
+ // triggerFloatingLink(editor, { focused: true });
194
+ //
195
+ // break;
196
+ // }
197
+ default: {
198
+ insertEmptyElement(editor, type, {
199
+ nextBlock: true,
200
+ select: true,
201
+ });
202
+ }
203
+ }
204
+
205
+ focusEditor(editor);
206
+ }}
207
+ >
208
+ <Icon className="mr-2 size-5" />
209
+ {itemLabel}
210
+ </DropdownMenuItem>
211
+ )
212
+ )}
213
+ </React.Fragment>
214
+ ))}
215
+ </DropdownMenuContent>
216
+ </DropdownMenu>
217
+ );
218
+ }
@@ -0,0 +1,20 @@
1
+ import React from 'react';
2
+
3
+ import { cn, withRef } from '@udecode/cn';
4
+ import { PlateLeaf } from '@udecode/plate-common/react';
5
+
6
+ export const KbdLeaf = withRef<typeof PlateLeaf>(
7
+ ({ children, className, ...props }, ref) => (
8
+ <PlateLeaf
9
+ asChild
10
+ className={cn(
11
+ 'rounded border border-border bg-muted px-1.5 py-0.5 font-mono text-sm shadow-[rgba(255,_255,_255,_0.1)_0px_0.5px_0px_0px_inset,_rgb(248,_249,_250)_0px_1px_5px_0px_inset,_rgb(193,_200,_205)_0px_0px_0px_0.5px,_rgb(193,_200,_205)_0px_2px_1px_-1px,_rgb(193,_200,_205)_0px_1px_0px_0px] dark:shadow-[rgba(255,_255,_255,_0.1)_0px_0.5px_0px_0px_inset,_rgb(26,_29,_30)_0px_1px_5px_0px_inset,_rgb(76,_81,_85)_0px_0px_0px_0.5px,_rgb(76,_81,_85)_0px_2px_1px_-1px,_rgb(76,_81,_85)_0px_1px_0px_0px]',
12
+ className
13
+ )}
14
+ ref={ref}
15
+ {...props}
16
+ >
17
+ <kbd>{children}</kbd>
18
+ </PlateLeaf>
19
+ )
20
+ );
@@ -0,0 +1,29 @@
1
+ import React from 'react';
2
+
3
+ import type { TLinkElement } from '@udecode/plate-link';
4
+
5
+ import { cn, withRef } from '@udecode/cn';
6
+ import { PlateElement, useElement } from '@udecode/plate-common/react';
7
+ import { useLink } from '@udecode/plate-link/react';
8
+
9
+ export const LinkElement = withRef<typeof PlateElement>(
10
+ ({ children, className, ...props }, ref) => {
11
+ const element = useElement<TLinkElement>();
12
+ const { props: linkProps } = useLink({ element });
13
+
14
+ return (
15
+ <PlateElement
16
+ asChild
17
+ className={cn(
18
+ 'font-medium text-primary underline decoration-primary underline-offset-4',
19
+ className
20
+ )}
21
+ ref={ref}
22
+ {...(linkProps as any)}
23
+ {...props}
24
+ >
25
+ <a>{children}</a>
26
+ </PlateElement>
27
+ );
28
+ }
29
+ );