@docyrus/ui-pro-ai-assistant 0.0.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.
Files changed (308) hide show
  1. package/dist/index.js +26161 -0
  2. package/dist/index.js.map +1 -0
  3. package/package.json +155 -0
  4. package/src/components/assistant-animations.tsx +29 -0
  5. package/src/components/assistant-dialogs.tsx +235 -0
  6. package/src/components/code-view.tsx +278 -0
  7. package/src/components/create-agent-task.tsx +104 -0
  8. package/src/components/create-new-work-version.tsx +30 -0
  9. package/src/components/extract-web.tsx +160 -0
  10. package/src/components/forward-to-agent.tsx +90 -0
  11. package/src/components/generate-chart.tsx +101 -0
  12. package/src/components/generative-action-button.tsx +122 -0
  13. package/src/components/generative-tool.tsx +685 -0
  14. package/src/components/generative-ui-object.tsx +210 -0
  15. package/src/components/input-area.tsx +1209 -0
  16. package/src/components/json-schema-layout.tsx +326 -0
  17. package/src/components/list-item-card.tsx +92 -0
  18. package/src/components/mermaid-diagram.tsx +192 -0
  19. package/src/components/preview-image.tsx +47 -0
  20. package/src/components/request-approval.tsx +48 -0
  21. package/src/components/request-user-input.tsx +270 -0
  22. package/src/components/search-web.tsx +319 -0
  23. package/src/components/sheet-command.tsx +88 -0
  24. package/src/components/shell-canvas.tsx +122 -0
  25. package/src/components/show-advanced-data-table.tsx +352 -0
  26. package/src/components/show-generated-content-options.tsx +93 -0
  27. package/src/components/show-people-cards.tsx +180 -0
  28. package/src/components/subagent-tool.tsx +180 -0
  29. package/src/components/text-editor-tool.tsx +328 -0
  30. package/src/components/work-canvas.tsx +88 -0
  31. package/src/components/work-card.tsx +42 -0
  32. package/src/declarations.d.ts +1 -0
  33. package/src/docy-assistant.tsx +1962 -0
  34. package/src/hooks/index.ts +7 -0
  35. package/src/hooks/use-assistant-api.ts +507 -0
  36. package/src/hooks/use-deployment-data.ts +162 -0
  37. package/src/hooks/use-project-state.ts +347 -0
  38. package/src/hooks/use-session-state.ts +207 -0
  39. package/src/hooks/use-speech-recognition.ts +137 -0
  40. package/src/hooks/use-ui-state.ts +185 -0
  41. package/src/hooks/use-works-state.ts +146 -0
  42. package/src/i18n/context.tsx +253 -0
  43. package/src/i18n/index.ts +19 -0
  44. package/src/i18n/locales/de.json +198 -0
  45. package/src/i18n/locales/el.json +198 -0
  46. package/src/i18n/locales/en.json +226 -0
  47. package/src/i18n/locales/es.json +198 -0
  48. package/src/i18n/locales/fr.json +198 -0
  49. package/src/i18n/locales/it.json +198 -0
  50. package/src/i18n/locales/pt.json +198 -0
  51. package/src/i18n/locales/sl.json +198 -0
  52. package/src/i18n/locales/tr.json +211 -0
  53. package/src/i18n/types.ts +23 -0
  54. package/src/i18n/use-translation.ts +17 -0
  55. package/src/index.ts +18 -0
  56. package/src/internal/plate-editor/editor/auth-context.ts +11 -0
  57. package/src/internal/plate-editor/editor/editor-base-kit.tsx +39 -0
  58. package/src/internal/plate-editor/editor/editor-kit.tsx +89 -0
  59. package/src/internal/plate-editor/editor/plate-editor.tsx +75 -0
  60. package/src/internal/plate-editor/editor/plate-types.ts +126 -0
  61. package/src/internal/plate-editor/editor/plugins/ai-kit.tsx +172 -0
  62. package/src/internal/plate-editor/editor/plugins/autoformat-kit.tsx +211 -0
  63. package/src/internal/plate-editor/editor/plugins/basic-blocks-base-kit.tsx +26 -0
  64. package/src/internal/plate-editor/editor/plugins/basic-blocks-kit.tsx +51 -0
  65. package/src/internal/plate-editor/editor/plugins/basic-marks-base-kit.tsx +24 -0
  66. package/src/internal/plate-editor/editor/plugins/basic-marks-kit.tsx +38 -0
  67. package/src/internal/plate-editor/editor/plugins/basic-nodes-kit.tsx +6 -0
  68. package/src/internal/plate-editor/editor/plugins/block-menu-kit.tsx +14 -0
  69. package/src/internal/plate-editor/editor/plugins/block-placeholder-kit.tsx +17 -0
  70. package/src/internal/plate-editor/editor/plugins/block-selection-kit.tsx +31 -0
  71. package/src/internal/plate-editor/editor/plugins/callout-base-kit.tsx +5 -0
  72. package/src/internal/plate-editor/editor/plugins/callout-kit.tsx +7 -0
  73. package/src/internal/plate-editor/editor/plugins/code-block-base-kit.tsx +23 -0
  74. package/src/internal/plate-editor/editor/plugins/code-block-kit.tsx +26 -0
  75. package/src/internal/plate-editor/editor/plugins/column-base-kit.tsx +8 -0
  76. package/src/internal/plate-editor/editor/plugins/column-kit.tsx +7 -0
  77. package/src/internal/plate-editor/editor/plugins/comment-base-kit.tsx +5 -0
  78. package/src/internal/plate-editor/editor/plugins/comment-kit.tsx +174 -0
  79. package/src/internal/plate-editor/editor/plugins/copilot-kit.tsx +68 -0
  80. package/src/internal/plate-editor/editor/plugins/cursor-overlay-kit.tsx +13 -0
  81. package/src/internal/plate-editor/editor/plugins/date-base-kit.tsx +5 -0
  82. package/src/internal/plate-editor/editor/plugins/date-kit.tsx +7 -0
  83. package/src/internal/plate-editor/editor/plugins/discussion-kit.tsx +36 -0
  84. package/src/internal/plate-editor/editor/plugins/dnd-kit.tsx +27 -0
  85. package/src/internal/plate-editor/editor/plugins/docx-export-kit.tsx +43 -0
  86. package/src/internal/plate-editor/editor/plugins/docx-kit.tsx +6 -0
  87. package/src/internal/plate-editor/editor/plugins/emoji-kit.tsx +15 -0
  88. package/src/internal/plate-editor/editor/plugins/exit-break-kit.tsx +12 -0
  89. package/src/internal/plate-editor/editor/plugins/floating-toolbar-kit.tsx +19 -0
  90. package/src/internal/plate-editor/editor/plugins/font-base-kit.tsx +36 -0
  91. package/src/internal/plate-editor/editor/plugins/font-kit.tsx +47 -0
  92. package/src/internal/plate-editor/editor/plugins/indent-base-kit.tsx +19 -0
  93. package/src/internal/plate-editor/editor/plugins/indent-kit.tsx +22 -0
  94. package/src/internal/plate-editor/editor/plugins/link-base-kit.tsx +5 -0
  95. package/src/internal/plate-editor/editor/plugins/link-kit.tsx +35 -0
  96. package/src/internal/plate-editor/editor/plugins/list-base-kit.tsx +24 -0
  97. package/src/internal/plate-editor/editor/plugins/list-kit.tsx +27 -0
  98. package/src/internal/plate-editor/editor/plugins/markdown-kit.tsx +18 -0
  99. package/src/internal/plate-editor/editor/plugins/math-base-kit.tsx +8 -0
  100. package/src/internal/plate-editor/editor/plugins/math-kit.tsx +10 -0
  101. package/src/internal/plate-editor/editor/plugins/media-base-kit.tsx +37 -0
  102. package/src/internal/plate-editor/editor/plugins/media-kit.tsx +53 -0
  103. package/src/internal/plate-editor/editor/plugins/mention-base-kit.tsx +5 -0
  104. package/src/internal/plate-editor/editor/plugins/mention-kit.tsx +36 -0
  105. package/src/internal/plate-editor/editor/plugins/slash-kit.tsx +17 -0
  106. package/src/internal/plate-editor/editor/plugins/suggestion-base-kit.tsx +5 -0
  107. package/src/internal/plate-editor/editor/plugins/suggestion-kit.tsx +95 -0
  108. package/src/internal/plate-editor/editor/plugins/table-base-kit.tsx +20 -0
  109. package/src/internal/plate-editor/editor/plugins/table-kit.tsx +22 -0
  110. package/src/internal/plate-editor/editor/plugins/toc-base-kit.tsx +5 -0
  111. package/src/internal/plate-editor/editor/plugins/toc-kit.tsx +14 -0
  112. package/src/internal/plate-editor/editor/plugins/toggle-base-kit.tsx +5 -0
  113. package/src/internal/plate-editor/editor/plugins/toggle-kit.tsx +9 -0
  114. package/src/internal/plate-editor/editor/transforms.ts +165 -0
  115. package/src/internal/plate-editor/editor/use-chat.ts +152 -0
  116. package/src/internal/plate-editor/hooks/index.ts +3 -0
  117. package/src/internal/plate-editor/hooks/use-copy-to-clipboard.ts +31 -0
  118. package/src/internal/plate-editor/hooks/use-is-touch-device.ts +26 -0
  119. package/src/internal/plate-editor/hooks/use-lock-scroll.ts +21 -0
  120. package/src/internal/plate-editor/hooks/use-media-query.ts +44 -0
  121. package/src/internal/plate-editor/hooks/use-mounted.ts +18 -0
  122. package/src/internal/plate-editor/hooks/use-on-click-outside.ts +114 -0
  123. package/src/internal/plate-editor/hooks/use-upload-file.ts +81 -0
  124. package/src/internal/plate-editor/i18n/context.tsx +58 -0
  125. package/src/internal/plate-editor/i18n/index.ts +3 -0
  126. package/src/internal/plate-editor/i18n/locales/de.json +57 -0
  127. package/src/internal/plate-editor/i18n/locales/el.json +57 -0
  128. package/src/internal/plate-editor/i18n/locales/en.json +57 -0
  129. package/src/internal/plate-editor/i18n/locales/es.json +57 -0
  130. package/src/internal/plate-editor/i18n/locales/fr.json +57 -0
  131. package/src/internal/plate-editor/i18n/locales/it.json +57 -0
  132. package/src/internal/plate-editor/i18n/locales/pt.json +57 -0
  133. package/src/internal/plate-editor/i18n/locales/sl.json +57 -0
  134. package/src/internal/plate-editor/i18n/locales/tr.json +57 -0
  135. package/src/internal/plate-editor/i18n/types.ts +59 -0
  136. package/src/internal/plate-editor/i18n/use-translation.ts +22 -0
  137. package/src/internal/plate-editor/index.ts +39 -0
  138. package/src/internal/plate-editor/lib/ai-output-converter.ts +153 -0
  139. package/src/internal/plate-editor/lib/download-file.ts +17 -0
  140. package/src/internal/plate-editor/plate-ui/ai-chat-editor.tsx +26 -0
  141. package/src/internal/plate-editor/plate-ui/ai-menu.tsx +828 -0
  142. package/src/internal/plate-editor/plate-ui/ai-node.tsx +41 -0
  143. package/src/internal/plate-editor/plate-ui/ai-toolbar-button.tsx +27 -0
  144. package/src/internal/plate-editor/plate-ui/alert-dialog.tsx +147 -0
  145. package/src/internal/plate-editor/plate-ui/align-toolbar-button.tsx +90 -0
  146. package/src/internal/plate-editor/plate-ui/avatar.tsx +3 -0
  147. package/src/internal/plate-editor/plate-ui/block-context-menu.tsx +106 -0
  148. package/src/internal/plate-editor/plate-ui/block-discussion.tsx +364 -0
  149. package/src/internal/plate-editor/plate-ui/block-draggable.tsx +556 -0
  150. package/src/internal/plate-editor/plate-ui/block-list-static.tsx +78 -0
  151. package/src/internal/plate-editor/plate-ui/block-list.tsx +85 -0
  152. package/src/internal/plate-editor/plate-ui/block-menu.tsx +557 -0
  153. package/src/internal/plate-editor/plate-ui/block-selection.tsx +47 -0
  154. package/src/internal/plate-editor/plate-ui/block-suggestion.tsx +469 -0
  155. package/src/internal/plate-editor/plate-ui/blockquote-node-static.tsx +10 -0
  156. package/src/internal/plate-editor/plate-ui/blockquote-node.tsx +11 -0
  157. package/src/internal/plate-editor/plate-ui/button.tsx +190 -0
  158. package/src/internal/plate-editor/plate-ui/calendar.tsx +3 -0
  159. package/src/internal/plate-editor/plate-ui/callout-node-static.tsx +76 -0
  160. package/src/internal/plate-editor/plate-ui/callout-node.tsx +54 -0
  161. package/src/internal/plate-editor/plate-ui/caption.tsx +48 -0
  162. package/src/internal/plate-editor/plate-ui/checkbox.tsx +3 -0
  163. package/src/internal/plate-editor/plate-ui/code-block-node-static.tsx +172 -0
  164. package/src/internal/plate-editor/plate-ui/code-block-node.tsx +228 -0
  165. package/src/internal/plate-editor/plate-ui/code-node-static.tsx +11 -0
  166. package/src/internal/plate-editor/plate-ui/code-node.tsx +12 -0
  167. package/src/internal/plate-editor/plate-ui/column-node-static.tsx +65 -0
  168. package/src/internal/plate-editor/plate-ui/column-node.tsx +24 -0
  169. package/src/internal/plate-editor/plate-ui/command.tsx +204 -0
  170. package/src/internal/plate-editor/plate-ui/comment-node-static.tsx +12 -0
  171. package/src/internal/plate-editor/plate-ui/comment-node.tsx +45 -0
  172. package/src/internal/plate-editor/plate-ui/comment-toolbar-button.tsx +24 -0
  173. package/src/internal/plate-editor/plate-ui/comment.tsx +619 -0
  174. package/src/internal/plate-editor/plate-ui/cursor-overlay.tsx +85 -0
  175. package/src/internal/plate-editor/plate-ui/date-node-static.tsx +43 -0
  176. package/src/internal/plate-editor/plate-ui/date-node.tsx +56 -0
  177. package/src/internal/plate-editor/plate-ui/dialog.tsx +426 -0
  178. package/src/internal/plate-editor/plate-ui/dropdown-menu.tsx +266 -0
  179. package/src/internal/plate-editor/plate-ui/editor-static.tsx +40 -0
  180. package/src/internal/plate-editor/plate-ui/editor.tsx +148 -0
  181. package/src/internal/plate-editor/plate-ui/emoji-node.tsx +48 -0
  182. package/src/internal/plate-editor/plate-ui/emoji-toolbar-button.tsx +626 -0
  183. package/src/internal/plate-editor/plate-ui/equation-node-static.tsx +155 -0
  184. package/src/internal/plate-editor/plate-ui/equation-node.tsx +226 -0
  185. package/src/internal/plate-editor/plate-ui/equation-toolbar-button.tsx +26 -0
  186. package/src/internal/plate-editor/plate-ui/export-toolbar-button.tsx +208 -0
  187. package/src/internal/plate-editor/plate-ui/fixed-toolbar-buttons.tsx +157 -0
  188. package/src/internal/plate-editor/plate-ui/fixed-toolbar.tsx +27 -0
  189. package/src/internal/plate-editor/plate-ui/floating-discussion.tsx +1129 -0
  190. package/src/internal/plate-editor/plate-ui/floating-toolbar-buttons.tsx +129 -0
  191. package/src/internal/plate-editor/plate-ui/floating-toolbar.tsx +99 -0
  192. package/src/internal/plate-editor/plate-ui/font-color-toolbar-button.tsx +211 -0
  193. package/src/internal/plate-editor/plate-ui/font-size-toolbar-button.tsx +154 -0
  194. package/src/internal/plate-editor/plate-ui/ghost-text.tsx +20 -0
  195. package/src/internal/plate-editor/plate-ui/heading-node-static.tsx +52 -0
  196. package/src/internal/plate-editor/plate-ui/heading-node.tsx +56 -0
  197. package/src/internal/plate-editor/plate-ui/highlight-node-static.tsx +9 -0
  198. package/src/internal/plate-editor/plate-ui/highlight-node.tsx +11 -0
  199. package/src/internal/plate-editor/plate-ui/history-toolbar-button.tsx +52 -0
  200. package/src/internal/plate-editor/plate-ui/hover-card.tsx +7 -0
  201. package/src/internal/plate-editor/plate-ui/hr-node-static.tsx +18 -0
  202. package/src/internal/plate-editor/plate-ui/hr-node.tsx +28 -0
  203. package/src/internal/plate-editor/plate-ui/import-toolbar-button.tsx +124 -0
  204. package/src/internal/plate-editor/plate-ui/indent-toolbar-button.tsx +34 -0
  205. package/src/internal/plate-editor/plate-ui/inline-combobox.tsx +409 -0
  206. package/src/internal/plate-editor/plate-ui/input.tsx +39 -0
  207. package/src/internal/plate-editor/plate-ui/insert-toolbar-button.tsx +260 -0
  208. package/src/internal/plate-editor/plate-ui/label.tsx +1 -0
  209. package/src/internal/plate-editor/plate-ui/line-height-toolbar-button.tsx +71 -0
  210. package/src/internal/plate-editor/plate-ui/link-node-static.tsx +15 -0
  211. package/src/internal/plate-editor/plate-ui/link-node.tsx +33 -0
  212. package/src/internal/plate-editor/plate-ui/link-toolbar-button.tsx +30 -0
  213. package/src/internal/plate-editor/plate-ui/link-toolbar.tsx +149 -0
  214. package/src/internal/plate-editor/plate-ui/list-toolbar-button.tsx +179 -0
  215. package/src/internal/plate-editor/plate-ui/mark-toolbar-button.tsx +36 -0
  216. package/src/internal/plate-editor/plate-ui/media-audio-node-static.tsx +21 -0
  217. package/src/internal/plate-editor/plate-ui/media-audio-node.tsx +32 -0
  218. package/src/internal/plate-editor/plate-ui/media-embed-node.tsx +103 -0
  219. package/src/internal/plate-editor/plate-ui/media-file-node-static.tsx +30 -0
  220. package/src/internal/plate-editor/plate-ui/media-file-node.tsx +52 -0
  221. package/src/internal/plate-editor/plate-ui/media-image-node-static.tsx +37 -0
  222. package/src/internal/plate-editor/plate-ui/media-image-node.tsx +183 -0
  223. package/src/internal/plate-editor/plate-ui/media-placeholder-node.tsx +441 -0
  224. package/src/internal/plate-editor/plate-ui/media-preview-dialog.tsx +127 -0
  225. package/src/internal/plate-editor/plate-ui/media-toolbar-button.tsx +229 -0
  226. package/src/internal/plate-editor/plate-ui/media-toolbar.tsx +216 -0
  227. package/src/internal/plate-editor/plate-ui/media-upload-toast.tsx +73 -0
  228. package/src/internal/plate-editor/plate-ui/media-video-node-static.tsx +35 -0
  229. package/src/internal/plate-editor/plate-ui/media-video-node.tsx +119 -0
  230. package/src/internal/plate-editor/plate-ui/mention-node-static.tsx +46 -0
  231. package/src/internal/plate-editor/plate-ui/mention-node.tsx +79 -0
  232. package/src/internal/plate-editor/plate-ui/menu.tsx +532 -0
  233. package/src/internal/plate-editor/plate-ui/mode-toolbar-button.tsx +126 -0
  234. package/src/internal/plate-editor/plate-ui/more-toolbar-button.tsx +34 -0
  235. package/src/internal/plate-editor/plate-ui/paragraph-node-static.tsx +15 -0
  236. package/src/internal/plate-editor/plate-ui/paragraph-node.tsx +16 -0
  237. package/src/internal/plate-editor/plate-ui/popover.tsx +77 -0
  238. package/src/internal/plate-editor/plate-ui/progress.tsx +1 -0
  239. package/src/internal/plate-editor/plate-ui/remote-cursor-overlay.tsx +81 -0
  240. package/src/internal/plate-editor/plate-ui/resize-handle.tsx +88 -0
  241. package/src/internal/plate-editor/plate-ui/separator.tsx +43 -0
  242. package/src/internal/plate-editor/plate-ui/slash-node.tsx +435 -0
  243. package/src/internal/plate-editor/plate-ui/spinner.tsx +1 -0
  244. package/src/internal/plate-editor/plate-ui/suggestion-node-static.tsx +35 -0
  245. package/src/internal/plate-editor/plate-ui/suggestion-node.tsx +168 -0
  246. package/src/internal/plate-editor/plate-ui/suggestion-toolbar-button.tsx +24 -0
  247. package/src/internal/plate-editor/plate-ui/table-node-static.tsx +85 -0
  248. package/src/internal/plate-editor/plate-ui/table-node.tsx +285 -0
  249. package/src/internal/plate-editor/plate-ui/table-toolbar-button.tsx +254 -0
  250. package/src/internal/plate-editor/plate-ui/tabs.tsx +3 -0
  251. package/src/internal/plate-editor/plate-ui/textarea.tsx +58 -0
  252. package/src/internal/plate-editor/plate-ui/toc-node-static.tsx +142 -0
  253. package/src/internal/plate-editor/plate-ui/toc-node.tsx +57 -0
  254. package/src/internal/plate-editor/plate-ui/toc-sidebar.tsx +50 -0
  255. package/src/internal/plate-editor/plate-ui/toggle-node-static.tsx +18 -0
  256. package/src/internal/plate-editor/plate-ui/toggle-node.tsx +33 -0
  257. package/src/internal/plate-editor/plate-ui/toggle-toolbar-button.tsx +26 -0
  258. package/src/internal/plate-editor/plate-ui/toggle.tsx +3 -0
  259. package/src/internal/plate-editor/plate-ui/toolbar.tsx +380 -0
  260. package/src/internal/plate-editor/plate-ui/tooltip.tsx +149 -0
  261. package/src/internal/plate-editor/plate-ui/turn-into-toolbar-button.tsx +177 -0
  262. package/src/internal/plate-editor/types/index.ts +22 -0
  263. package/src/internal/plate-editor/vite.ts +284 -0
  264. package/src/internal/sheets/components/univer-sheets.tsx +1104 -0
  265. package/src/internal/sheets/i18n/context.tsx +183 -0
  266. package/src/internal/sheets/i18n/index.ts +19 -0
  267. package/src/internal/sheets/i18n/locales/de.json +21 -0
  268. package/src/internal/sheets/i18n/locales/el.json +21 -0
  269. package/src/internal/sheets/i18n/locales/en.json +21 -0
  270. package/src/internal/sheets/i18n/locales/es.json +21 -0
  271. package/src/internal/sheets/i18n/locales/fr.json +21 -0
  272. package/src/internal/sheets/i18n/locales/it.json +21 -0
  273. package/src/internal/sheets/i18n/locales/pt.json +21 -0
  274. package/src/internal/sheets/i18n/locales/sl.json +21 -0
  275. package/src/internal/sheets/i18n/locales/tr.json +21 -0
  276. package/src/internal/sheets/i18n/types.ts +23 -0
  277. package/src/internal/sheets/i18n/use-translation.ts +17 -0
  278. package/src/internal/sheets/index.ts +14 -0
  279. package/src/internal/sheets/types/css.d.ts +11 -0
  280. package/src/internal/sheets/types/index.ts +260 -0
  281. package/src/internal/sheets/xlsx.ts +1169 -0
  282. package/src/lib/api-client.ts +77 -0
  283. package/src/lib/assistant-api-actions.ts +549 -0
  284. package/src/lib/assistant-config.tsx +71 -0
  285. package/src/lib/class-utils.ts +40 -0
  286. package/src/lib/index.ts +7 -0
  287. package/src/lib/message-utils.ts +131 -0
  288. package/src/tools/tools-schema.json +512 -0
  289. package/src/types/index.ts +235 -0
  290. package/src/views/assistant-view.tsx +1137 -0
  291. package/src/views/canvas-app.tsx +839 -0
  292. package/src/views/canvas-code.tsx +93 -0
  293. package/src/views/canvas-deep-research.tsx +44 -0
  294. package/src/views/canvas-image.tsx +25 -0
  295. package/src/views/canvas-record-view.tsx +285 -0
  296. package/src/views/canvas-spreadsheet.tsx +125 -0
  297. package/src/views/canvas-text.tsx +52 -0
  298. package/src/views/canvas.tsx +274 -0
  299. package/src/views/chat-panel.tsx +149 -0
  300. package/src/views/index.ts +20 -0
  301. package/src/views/memories-panel.tsx +365 -0
  302. package/src/views/message-list.tsx +370 -0
  303. package/src/views/project-detail.tsx +257 -0
  304. package/src/views/projects-panel.tsx +131 -0
  305. package/src/views/sessions-list.tsx +98 -0
  306. package/src/views/sidebar-content.tsx +256 -0
  307. package/src/views/work-detail.tsx +98 -0
  308. package/src/vite.ts +284 -0
@@ -0,0 +1,76 @@
1
+
2
+ import { SlateElement, type SlateElementProps } from 'platejs/static';
3
+
4
+ export function CalloutElementStatic(props: SlateElementProps) {
5
+ return (
6
+ <SlateElement
7
+ className="my-1 flex rounded-sm bg-muted p-4 pl-3"
8
+ style={{
9
+ backgroundColor: props.element.backgroundColor as any
10
+ }}
11
+ {...props}>
12
+ <div className="flex w-full gap-2 rounded-md">
13
+ <div
14
+ className="size-6 select-none text-[18px]"
15
+ style={{
16
+ fontFamily:
17
+ '"Apple Color Emoji", "Segoe UI Emoji", NotoColorEmoji, "Noto Color Emoji", "Segoe UI Symbol", "Android Emoji", EmojiSymbols'
18
+ }}>
19
+ <span data-plate-prevent-deserialization>
20
+ {(props.element.icon as any) || '💡'}
21
+ </span>
22
+ </div>
23
+ <div className="w-full">{props.children}</div>
24
+ </div>
25
+ </SlateElement>
26
+ );
27
+ }
28
+
29
+ /**
30
+ * DOCX-compatible callout component using table layout for side-by-side icon and content.
31
+ */
32
+ export function CalloutElementDocx({ children, ...props }: SlateElementProps) {
33
+ const backgroundColor
34
+ = (props.element.backgroundColor as string) || '#f4f4f5';
35
+ const icon = (props.element.icon as string) || '💡';
36
+
37
+ return (
38
+ <SlateElement {...props}>
39
+ <table
40
+ style={{
41
+ width: '100%',
42
+ borderCollapse: 'collapse',
43
+ border: 'none',
44
+ backgroundColor,
45
+ borderRadius: '4px',
46
+ marginTop: '4pt',
47
+ marginBottom: '4pt'
48
+ }}>
49
+ <tbody>
50
+ <tr>
51
+ <td
52
+ style={{
53
+ width: '30px',
54
+ verticalAlign: 'top',
55
+ padding: '8px 4px 8px 8px',
56
+ border: 'none',
57
+ fontSize: '18px',
58
+ fontFamily:
59
+ '"Apple Color Emoji", "Segoe UI Emoji", NotoColorEmoji, "Noto Color Emoji", "Segoe UI Symbol", "Android Emoji", EmojiSymbols'
60
+ }}>
61
+ <span data-plate-prevent-deserialization>{icon}</span>
62
+ </td>
63
+ <td
64
+ style={{
65
+ verticalAlign: 'top',
66
+ padding: '8px 8px 8px 4px',
67
+ border: 'none'
68
+ }}>
69
+ {children}
70
+ </td>
71
+ </tr>
72
+ </tbody>
73
+ </table>
74
+ </SlateElement>
75
+ );
76
+ }
@@ -0,0 +1,54 @@
1
+ 'use client';
2
+
3
+ import { useCalloutEmojiPicker } from '@platejs/callout/react';
4
+ import { useEmojiDropdownMenuState } from '@platejs/emoji/react';
5
+ import { PlateElement, type PlateElementProps } from 'platejs/react';
6
+
7
+ import { Button } from './button';
8
+
9
+ import { EmojiPicker, EmojiPopover } from './emoji-toolbar-button';
10
+
11
+ export function CalloutElement(props: PlateElementProps) {
12
+ const { emojiPickerState, isOpen, setIsOpen } = useEmojiDropdownMenuState({
13
+ closeOnSelect: true
14
+ });
15
+
16
+ const { emojiToolbarDropdownProps, props: calloutProps }
17
+ = useCalloutEmojiPicker({
18
+ isOpen,
19
+ setIsOpen
20
+ });
21
+
22
+ return (
23
+ <PlateElement
24
+ className="my-1 flex rounded-sm bg-muted p-4 pl-3"
25
+ style={{
26
+ backgroundColor: props.element.backgroundColor as any
27
+ }}
28
+ {...props}
29
+ attributes={{
30
+ ...props.attributes,
31
+ 'data-plate-open-context-menu': 'true'
32
+ }}>
33
+ <div className="flex w-full gap-2 rounded-md">
34
+ <EmojiPopover
35
+ {...emojiToolbarDropdownProps}
36
+ control={
37
+ <Button
38
+ className="size-6 select-none p-1 text-[18px] hover:bg-muted-foreground/15"
39
+ contentEditable={false}
40
+ style={{
41
+ fontFamily:
42
+ '"Apple Color Emoji", "Segoe UI Emoji", NotoColorEmoji, "Noto Color Emoji", "Segoe UI Symbol", "Android Emoji", EmojiSymbols'
43
+ }}
44
+ variant="ghost">
45
+ {(props.element.icon as any) || '💡'}
46
+ </Button>
47
+ }>
48
+ <EmojiPicker {...emojiPickerState} {...calloutProps} />
49
+ </EmojiPopover>
50
+ <div className="w-full">{props.children}</div>
51
+ </div>
52
+ </PlateElement>
53
+ );
54
+ }
@@ -0,0 +1,48 @@
1
+ import { type ComponentPropsWithoutRef } from 'react';
2
+ import * as React from 'react';
3
+
4
+ import {
5
+ Caption as CaptionPrimitive,
6
+ CaptionTextarea as CaptionTextareaPrimitive
7
+ } from '@platejs/caption/react';
8
+ import { cva, type VariantProps } from 'class-variance-authority';
9
+
10
+ import { cn } from '@docyrus/ui-pro-shared/lib/utils';
11
+
12
+ const captionVariants = cva('max-w-full', {
13
+ defaultVariants: {
14
+ align: 'center'
15
+ },
16
+ variants: {
17
+ align: {
18
+ center: 'mx-auto',
19
+ left: 'mr-auto',
20
+ right: 'ml-auto'
21
+ }
22
+ }
23
+ });
24
+
25
+ type CaptionProps = ComponentPropsWithoutRef<typeof CaptionPrimitive>
26
+ & VariantProps<typeof captionVariants>;
27
+
28
+ export function Caption({ align, className, ...props }: CaptionProps) {
29
+ return (
30
+ <CaptionPrimitive
31
+ {...props}
32
+ className={cn(captionVariants({ align }), className)} />
33
+ );
34
+ }
35
+
36
+ export function CaptionTextarea(
37
+ props: ComponentPropsWithoutRef<typeof CaptionTextareaPrimitive>
38
+ ) {
39
+ return (
40
+ <CaptionTextareaPrimitive
41
+ {...props}
42
+ className={cn(
43
+ 'mt-2 w-full resize-none border-none bg-inherit p-0 font-[inherit] text-inherit',
44
+ 'focus:outline-hidden focus:[&::placeholder]:opacity-0',
45
+ 'text-center print:placeholder:text-transparent'
46
+ )} />
47
+ );
48
+ }
@@ -0,0 +1,3 @@
1
+ 'use client';
2
+
3
+ export { Checkbox } from '@docyrus/ui-pro-shared/checkbox';
@@ -0,0 +1,172 @@
1
+
2
+ import { type TCodeBlockElement } from 'platejs';
3
+
4
+ import {
5
+ SlateElement,
6
+ type SlateElementProps,
7
+ SlateLeaf,
8
+ type SlateLeafProps
9
+ } from 'platejs/static';
10
+
11
+ import { cn } from '@docyrus/ui-pro-shared/lib/utils';
12
+
13
+ export function CodeBlockElementStatic(
14
+ props: SlateElementProps<TCodeBlockElement>
15
+ ) {
16
+ return (
17
+ <SlateElement
18
+ className={cn(
19
+ 'py-1',
20
+ '**:[.hljs-comment,.hljs-code,.hljs-formula]:text-[#6a737d]',
21
+ '**:[.hljs-keyword,.hljs-doctag,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_]:text-[#d73a49]',
22
+ '**:[.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_]:text-[#6f42c1]',
23
+ '**:[.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id,.hljs-variable]:text-[#005cc5]',
24
+ '**:[.hljs-regexp,.hljs-string,.hljs-meta_.hljs-string]:text-[#032f62]',
25
+ '**:[.hljs-built_in,.hljs-symbol]:text-[#e36209]',
26
+ '**:[.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo]:text-[#22863a]',
27
+ '**:[.hljs-emphasis]:italic',
28
+ '**:[.hljs-strong]:font-bold',
29
+ '**:[.hljs-section]:font-bold **:[.hljs-section]:text-[#005cc5]',
30
+ '**:[.hljs-bullet]:text-[#735c0f]',
31
+ '**:[.hljs-addition]:bg-[#f0fff4] **:[.hljs-addition]:text-[#22863a]',
32
+ '**:[.hljs-deletion]:bg-[#ffeef0] **:[.hljs-deletion]:text-[#b31d28]'
33
+ )}
34
+ {...props}>
35
+ <pre className="overflow-x-auto rounded-md bg-muted pt-[34px] pr-4 pb-8 pl-8 font-mono text-sm leading-[normal] [tab-size:2] print:break-inside-avoid">
36
+ <code>{props.children}</code>
37
+ </pre>
38
+ </SlateElement>
39
+ );
40
+ }
41
+
42
+ export function CodeLineElementStatic(props: SlateElementProps) {
43
+ return <SlateElement {...props} />;
44
+ }
45
+
46
+ export function CodeSyntaxLeafStatic(props: SlateLeafProps) {
47
+ const tokenClassName = props.leaf.className as string;
48
+
49
+ return <SlateLeaf {...props} className={tokenClassName} />;
50
+ }
51
+
52
+ /**
53
+ * DOCX-compatible code block components.
54
+ * Uses inline styles for proper rendering in Word documents.
55
+ */
56
+
57
+ export function CodeBlockElementDocx(
58
+ props: SlateElementProps<TCodeBlockElement>
59
+ ) {
60
+ return (
61
+ <SlateElement {...props}>
62
+ <div
63
+ style={{
64
+ backgroundColor: '#f5f5f5',
65
+ border: '1px solid #e0e0e0',
66
+ margin: '8pt 0',
67
+ padding: '12pt'
68
+ }}>
69
+ {props.children}
70
+ </div>
71
+ </SlateElement>
72
+ );
73
+ }
74
+
75
+ export function CodeLineElementDocx(props: SlateElementProps) {
76
+ return (
77
+ <SlateElement
78
+ {...props}
79
+ as="p"
80
+ style={{
81
+ fontFamily: "'Courier New', Consolas, monospace",
82
+ fontSize: '10pt',
83
+ margin: 0,
84
+ padding: 0
85
+ }} />
86
+ );
87
+ }
88
+
89
+ // Syntax highlighting color map for common token types
90
+ const syntaxColors: Record<string, string> = {
91
+ 'hljs-addition': '#22863a',
92
+ 'hljs-attr': '#005cc5',
93
+ 'hljs-attribute': '#005cc5',
94
+ 'hljs-built_in': '#e36209',
95
+ 'hljs-bullet': '#735c0f',
96
+ 'hljs-comment': '#6a737d',
97
+ 'hljs-deletion': '#b31d28',
98
+ 'hljs-doctag': '#d73a49',
99
+ 'hljs-emphasis': '#24292e',
100
+ 'hljs-formula': '#6a737d',
101
+ 'hljs-keyword': '#d73a49',
102
+ 'hljs-literal': '#005cc5',
103
+ 'hljs-meta': '#005cc5',
104
+ 'hljs-name': '#22863a',
105
+ 'hljs-number': '#005cc5',
106
+ 'hljs-operator': '#005cc5',
107
+ 'hljs-quote': '#22863a',
108
+ 'hljs-regexp': '#032f62',
109
+ 'hljs-section': '#005cc5',
110
+ 'hljs-selector-attr': '#005cc5',
111
+ 'hljs-selector-class': '#005cc5',
112
+ 'hljs-selector-id': '#005cc5',
113
+ 'hljs-selector-pseudo': '#22863a',
114
+ 'hljs-selector-tag': '#22863a',
115
+ 'hljs-string': '#032f62',
116
+ 'hljs-strong': '#24292e',
117
+ 'hljs-symbol': '#e36209',
118
+ 'hljs-template-tag': '#d73a49',
119
+ 'hljs-template-variable': '#d73a49',
120
+ 'hljs-title': '#6f42c1',
121
+ 'hljs-type': '#d73a49',
122
+ 'hljs-variable': '#005cc5'
123
+ };
124
+
125
+ // Convert regular spaces to non-breaking spaces to preserve indentation in Word
126
+ const preserveSpaces = (text: string): string => {
127
+ // Replace regular spaces with non-breaking spaces
128
+ return text.replace(/ /g, '\u00A0');
129
+ };
130
+
131
+ export function CodeSyntaxLeafDocx(props: SlateLeafProps) {
132
+ const tokenClassName = props.leaf.className as string;
133
+
134
+ // Extract color from className
135
+ let color: string | undefined;
136
+ let fontWeight: string | undefined;
137
+ let fontStyle: string | undefined;
138
+
139
+ if (tokenClassName) {
140
+ const classes = tokenClassName.split(' ');
141
+
142
+ for (const cls of classes) {
143
+ if (syntaxColors[cls]) {
144
+ color = syntaxColors[cls];
145
+ }
146
+ if (cls === 'hljs-strong' || cls === 'hljs-section') {
147
+ fontWeight = 'bold';
148
+ }
149
+ if (cls === 'hljs-emphasis') {
150
+ fontStyle = 'italic';
151
+ }
152
+ }
153
+ }
154
+
155
+ // Get the text content and preserve spaces
156
+ const text = props.leaf.text as string;
157
+ const preservedText = preserveSpaces(text);
158
+
159
+ return (
160
+ <span
161
+ data-slate-leaf="true"
162
+ style={{
163
+ color,
164
+ fontFamily: "'Courier New', Consolas, monospace",
165
+ fontSize: '10pt',
166
+ fontStyle,
167
+ fontWeight
168
+ }}>
169
+ {preservedText}
170
+ </span>
171
+ );
172
+ }
@@ -0,0 +1,228 @@
1
+ 'use client';
2
+
3
+ import { useMemo, useState } from 'react';
4
+
5
+ import * as React from 'react';
6
+
7
+ import { type TCodeBlockElement, NodeApi } from 'platejs';
8
+
9
+ import { CheckIcon, ChevronDownIcon, FilesIcon } from 'lucide-react';
10
+
11
+ import {
12
+ PlateElement,
13
+ type PlateElementProps,
14
+ PlateLeaf,
15
+ type PlateLeafProps,
16
+ useEditorRef,
17
+ useElement,
18
+ useReadOnly
19
+ } from 'platejs/react';
20
+
21
+ import { cn } from '@docyrus/ui-pro-shared/lib/utils';
22
+
23
+ import { BlockActionButton } from './block-context-menu';
24
+ import { Button } from './button';
25
+ import {
26
+ Command,
27
+ CommandEmpty,
28
+ CommandInput,
29
+ CommandItem,
30
+ CommandList
31
+ } from './command';
32
+ import { Input } from './input';
33
+ import { Popover, PopoverContent, PopoverTrigger } from './popover';
34
+
35
+ export function CodeBlockElement(props: PlateElementProps) {
36
+ const { element } = props;
37
+
38
+ return (
39
+ <PlateElement
40
+ className={cn(
41
+ 'group my-1',
42
+ '**:[.hljs-comment,.hljs-code,.hljs-formula]:text-[#6a737d]',
43
+ '**:[.hljs-keyword,.hljs-doctag,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_]:text-[#d73a49]',
44
+ '**:[.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_]:text-[#6f42c1]',
45
+ '**:[.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id,.hljs-variable]:text-[#005cc5]',
46
+ '**:[.hljs-regexp,.hljs-string,.hljs-meta_.hljs-string]:text-[#032f62]',
47
+ '**:[.hljs-built_in,.hljs-symbol]:text-[#e36209]',
48
+ '**:[.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo]:text-[#22863a]',
49
+ '**:[.hljs-emphasis]:italic',
50
+ '**:[.hljs-strong]:font-bold',
51
+ '**:[.hljs-section]:font-bold **:[.hljs-section]:text-[#005cc5]',
52
+ '**:[.hljs-bullet]:text-[#735c0f]',
53
+ '**:[.hljs-addition]:bg-[#f0fff4] **:[.hljs-addition]:text-[#22863a]',
54
+ '**:[.hljs-deletion]:bg-[#ffeef0] **:[.hljs-deletion]:text-[#b31d28]'
55
+ )}
56
+ {...props}>
57
+ <pre
58
+ className="overflow-x-auto rounded-md bg-muted pt-[34px] pr-4 pb-8 pl-8 font-mono text-sm leading-[normal] [tab-size:2] print:break-inside-avoid"
59
+ data-plate-open-context-menu>
60
+ <code>{props.children}</code>
61
+ </pre>
62
+
63
+ <div className="absolute top-2 left-2 z-10 h-5 opacity-0 transition-opacity duration-300 group-hover:opacity-100">
64
+ <CodeBlockCombobox />
65
+ </div>
66
+
67
+ <div
68
+ className="absolute top-1 right-1 z-10 flex select-none gap-px opacity-0 transition-opacity duration-300 group-hover:opacity-100"
69
+ contentEditable={false}>
70
+ <Button
71
+ className="relative top-0 right-0 w-auto"
72
+ onClick={() => {
73
+ const lines = element.children.map((child: any) => NodeApi.string(child));
74
+
75
+ void navigator.clipboard.writeText(lines.join('\n\n'));
76
+ }}
77
+ size="blockAction"
78
+ variant="blockActionSecondary">
79
+ <FilesIcon className="!size-3.5" />
80
+ Copy
81
+ </Button>
82
+
83
+ <BlockActionButton
84
+ defaultStyles={false}
85
+ variant="blockActionSecondary" />
86
+ </div>
87
+ </PlateElement>
88
+ );
89
+ }
90
+
91
+ function CodeBlockCombobox({ className }: { className?: string }) {
92
+ const [open, setOpen] = useState(false);
93
+ const readOnly = useReadOnly();
94
+ const editor = useEditorRef();
95
+ const element = useElement<TCodeBlockElement>();
96
+ const value = element?.lang || 'plaintext';
97
+ const [searchValue, setSearchValue] = useState('');
98
+
99
+ const items = useMemo(
100
+ () => languages.filter(
101
+ language => !searchValue
102
+ || language.label.toLowerCase().includes(searchValue.toLowerCase())
103
+ ),
104
+ [searchValue]
105
+ );
106
+
107
+ if (readOnly) return null;
108
+
109
+ return (
110
+ <Popover onOpenChange={setOpen} open={open}>
111
+ <PopoverTrigger asChild>
112
+ <Button
113
+ aria-expanded={open}
114
+ className={cn(
115
+ 'h-5 w-auto select-none justify-between gap-1 rounded-sm px-[5px] align-top text-muted-foreground text-xs',
116
+ className
117
+ )}
118
+ contentEditable={false}
119
+ role="combobox"
120
+ size="none"
121
+ variant="menuAction">
122
+ {languages.find(language => language.value === value)?.label
123
+ ?? 'Plain Text'}
124
+ <ChevronDownIcon className="!size-3 shrink-0" />
125
+ </Button>
126
+ </PopoverTrigger>
127
+ <PopoverContent
128
+ className="w-[200px] p-0"
129
+ onCloseAutoFocus={() => setSearchValue('')}>
130
+ <Command shouldFilter={false}>
131
+ <CommandInput
132
+ asChild
133
+ onValueChange={v => setSearchValue(v)}
134
+ value={searchValue}>
135
+ <Input placeholder="Search language..." />
136
+ </CommandInput>
137
+
138
+ <CommandEmpty>No language found.</CommandEmpty>
139
+
140
+ <CommandList className="h-[344px] overflow-y-auto">
141
+ {items.map(language => (
142
+ <CommandItem
143
+ className="cursor-pointer"
144
+ key={language.label}
145
+ onSelect={(v) => {
146
+ editor.tf.setNodes<TCodeBlockElement>(
147
+ { lang: v },
148
+ { at: element }
149
+ );
150
+ setSearchValue(v);
151
+ setOpen(false);
152
+ }}
153
+ value={language.value}>
154
+ <CheckIcon
155
+ className={cn(
156
+ 'mr-2 size-4',
157
+ value === language.value ? 'opacity-100' : 'opacity-0'
158
+ )} />
159
+ {language.label}
160
+ </CommandItem>
161
+ ))}
162
+ </CommandList>
163
+ </Command>
164
+ </PopoverContent>
165
+ </Popover>
166
+ );
167
+ }
168
+
169
+ export function CodeLineElement(props: PlateElementProps) {
170
+ return <PlateElement {...props} />;
171
+ }
172
+
173
+ export function CodeSyntaxLeaf(props: PlateLeafProps) {
174
+ const tokenClassName = props.leaf.className as string;
175
+
176
+ return <PlateLeaf {...props} className={tokenClassName} />;
177
+ }
178
+
179
+ const languages: { label: string; value: string }[] = [
180
+ { label: 'Auto', value: 'auto' },
181
+ { label: 'Plain Text', value: 'plaintext' },
182
+ { label: 'ABAP', value: 'abap' },
183
+ { label: 'Arduino', value: 'arduino' },
184
+ { label: 'Bash', value: 'bash' },
185
+ { label: 'C', value: 'c' },
186
+ { label: 'C#', value: 'csharp' },
187
+ { label: 'C++', value: 'cpp' },
188
+ { label: 'Clojure', value: 'clojure' },
189
+ { label: 'CSS', value: 'css' },
190
+ { label: 'Dart', value: 'dart' },
191
+ { label: 'Diff', value: 'diff' },
192
+ { label: 'Docker', value: 'dockerfile' },
193
+ { label: 'Elixir', value: 'elixir' },
194
+ { label: 'Erlang', value: 'erlang' },
195
+ { label: 'Go', value: 'go' },
196
+ { label: 'GraphQL', value: 'graphql' },
197
+ { label: 'Groovy', value: 'groovy' },
198
+ { label: 'Haskell', value: 'haskell' },
199
+ { label: 'HTML', value: 'html' },
200
+ { label: 'Java', value: 'java' },
201
+ { label: 'JavaScript', value: 'javascript' },
202
+ { label: 'JSON', value: 'json' },
203
+ { label: 'Kotlin', value: 'kotlin' },
204
+ { label: 'LaTeX', value: 'latex' },
205
+ { label: 'Less', value: 'less' },
206
+ { label: 'Lua', value: 'lua' },
207
+ { label: 'Makefile', value: 'makefile' },
208
+ { label: 'Markdown', value: 'markdown' },
209
+ { label: 'MATLAB', value: 'matlab' },
210
+ { label: 'Objective-C', value: 'objectivec' },
211
+ { label: 'OCaml', value: 'ocaml' },
212
+ { label: 'Perl', value: 'perl' },
213
+ { label: 'PHP', value: 'php' },
214
+ { label: 'PowerShell', value: 'powershell' },
215
+ { label: 'Python', value: 'python' },
216
+ { label: 'R', value: 'r' },
217
+ { label: 'Ruby', value: 'ruby' },
218
+ { label: 'Rust', value: 'rust' },
219
+ { label: 'Sass', value: 'scss' },
220
+ { label: 'Scala', value: 'scala' },
221
+ { label: 'Shell', value: 'shell' },
222
+ { label: 'SQL', value: 'sql' },
223
+ { label: 'Swift', value: 'swift' },
224
+ { label: 'TOML', value: 'toml' },
225
+ { label: 'TypeScript', value: 'typescript' },
226
+ { label: 'XML', value: 'xml' },
227
+ { label: 'YAML', value: 'yaml' }
228
+ ];
@@ -0,0 +1,11 @@
1
+
2
+ import { type SlateLeafProps, SlateLeaf } from 'platejs/static';
3
+
4
+ export function CodeLeafStatic(props: SlateLeafProps) {
5
+ return (
6
+ <SlateLeaf
7
+ {...props}
8
+ as="code"
9
+ className="whitespace-pre-wrap rounded-md bg-muted px-[0.3em] py-[0.2em] font-mono text-sm" />
10
+ );
11
+ }
@@ -0,0 +1,12 @@
1
+ 'use client';
2
+
3
+ import { PlateLeaf, type PlateLeafProps } from 'platejs/react';
4
+
5
+ export function CodeLeaf(props: PlateLeafProps) {
6
+ return (
7
+ <PlateLeaf
8
+ {...props}
9
+ as="code"
10
+ className="whitespace-pre-wrap rounded-md bg-muted px-[0.3em] py-[0.2em] font-mono text-sm" />
11
+ );
12
+ }
@@ -0,0 +1,65 @@
1
+
2
+ import { type TColumnElement } from 'platejs';
3
+
4
+ import { SlateElement, type SlateElementProps } from 'platejs/static';
5
+
6
+ export function ColumnElementStatic(props: SlateElementProps<TColumnElement>) {
7
+ const { width } = props.element;
8
+
9
+ return (
10
+ <SlateElement
11
+ className="border border-transparent p-1.5"
12
+ style={{ width: width ?? '100%' }}
13
+ {...props} />
14
+ );
15
+ }
16
+
17
+ export function ColumnGroupElementStatic(props: SlateElementProps) {
18
+ return (
19
+ <SlateElement className="my-2" {...props}>
20
+ <div className="flex size-full gap-4 rounded">{props.children}</div>
21
+ </SlateElement>
22
+ );
23
+ }
24
+
25
+ /**
26
+ * DOCX-compatible column component using table cell.
27
+ */
28
+ export function ColumnElementDocx(props: SlateElementProps<TColumnElement>) {
29
+ const { width } = props.element;
30
+
31
+ return (
32
+ <SlateElement
33
+ {...props}
34
+ as="td"
35
+ style={{
36
+ width: width ?? 'auto',
37
+ verticalAlign: 'top',
38
+ padding: '4px 8px',
39
+ border: 'none'
40
+ }}>
41
+ {props.children}
42
+ </SlateElement>
43
+ );
44
+ }
45
+
46
+ /**
47
+ * DOCX-compatible column group component using table layout.
48
+ */
49
+ export function ColumnGroupElementDocx(props: SlateElementProps) {
50
+ return (
51
+ <SlateElement {...props}>
52
+ <table
53
+ style={{
54
+ width: '100%',
55
+ borderCollapse: 'collapse',
56
+ border: 'none',
57
+ tableLayout: 'fixed'
58
+ }}>
59
+ <tbody>
60
+ <tr>{props.children}</tr>
61
+ </tbody>
62
+ </table>
63
+ </SlateElement>
64
+ );
65
+ }