@fuma-content/studio 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (413) hide show
  1. package/dist/bin.d.mts +1 -0
  2. package/dist/bin.mjs +90 -0
  3. package/dist/index.d.mts +13 -0
  4. package/dist/index.mjs +66 -0
  5. package/dist/mdx/actions.mjs +34 -0
  6. package/dist/mdx/client.mjs +167 -0
  7. package/dist/package.mjs +6 -0
  8. package/dist/src/components/code-editor/mdx.lazy.mjs +19 -0
  9. package/dist/src/components/code-editor/mdx.mjs +44 -0
  10. package/dist/src/components/code-editor/yaml.lazy.mjs +22 -0
  11. package/dist/src/components/code-editor/yaml.mjs +63 -0
  12. package/dist/src/components/editor/editor-base-kit.mjs +41 -0
  13. package/dist/src/components/editor/editor-kit.mjs +73 -0
  14. package/dist/src/components/editor/md.mjs +42 -0
  15. package/dist/src/components/editor/plugins/ai-kit.mjs +68 -0
  16. package/dist/src/components/editor/plugins/align-base-kit.mjs +28 -0
  17. package/dist/src/components/editor/plugins/align-kit.mjs +30 -0
  18. package/dist/src/components/editor/plugins/autoformat-kit.mjs +214 -0
  19. package/dist/src/components/editor/plugins/basic-blocks-base-kit.mjs +22 -0
  20. package/dist/src/components/editor/plugins/basic-blocks-kit.mjs +51 -0
  21. package/dist/src/components/editor/plugins/basic-marks-base-kit.mjs +20 -0
  22. package/dist/src/components/editor/plugins/basic-marks-kit.mjs +28 -0
  23. package/dist/src/components/editor/plugins/block-menu-kit.mjs +11 -0
  24. package/dist/src/components/editor/plugins/block-placeholder-kit.mjs +14 -0
  25. package/dist/src/components/editor/plugins/block-selection-kit.mjs +48 -0
  26. package/dist/src/components/editor/plugins/callout-base-kit.mjs +8 -0
  27. package/dist/src/components/editor/plugins/callout-kit.mjs +10 -0
  28. package/dist/src/components/editor/plugins/code-block-base-kit.mjs +16 -0
  29. package/dist/src/components/editor/plugins/code-block-kit.mjs +19 -0
  30. package/dist/src/components/editor/plugins/column-base-kit.mjs +8 -0
  31. package/dist/src/components/editor/plugins/column-kit.mjs +10 -0
  32. package/dist/src/components/editor/plugins/comment-base-kit.mjs +8 -0
  33. package/dist/src/components/editor/plugins/comment-kit.mjs +53 -0
  34. package/dist/src/components/editor/plugins/copilot-kit.mjs +49 -0
  35. package/dist/src/components/editor/plugins/cursor-overlay-kit.mjs +11 -0
  36. package/dist/src/components/editor/plugins/date-base-kit.mjs +8 -0
  37. package/dist/src/components/editor/plugins/date-kit.mjs +10 -0
  38. package/dist/src/components/editor/plugins/discussion-kit.mjs +94 -0
  39. package/dist/src/components/editor/plugins/dnd-kit.mjs +31 -0
  40. package/dist/src/components/editor/plugins/emoji-kit.mjs +11 -0
  41. package/dist/src/components/editor/plugins/exit-break-kit.mjs +12 -0
  42. package/dist/src/components/editor/plugins/fixed-toolbar-kit.mjs +15 -0
  43. package/dist/src/components/editor/plugins/floating-toolbar-kit.mjs +15 -0
  44. package/dist/src/components/editor/plugins/font-base-kit.mjs +14 -0
  45. package/dist/src/components/editor/plugins/font-kit.mjs +19 -0
  46. package/dist/src/components/editor/plugins/indent-base-kit.mjs +17 -0
  47. package/dist/src/components/editor/plugins/indent-kit.mjs +20 -0
  48. package/dist/src/components/editor/plugins/line-height-base-kit.mjs +20 -0
  49. package/dist/src/components/editor/plugins/line-height-kit.mjs +22 -0
  50. package/dist/src/components/editor/plugins/link-base-kit.mjs +8 -0
  51. package/dist/src/components/editor/plugins/link-kit.mjs +15 -0
  52. package/dist/src/components/editor/plugins/list-base-kit.mjs +19 -0
  53. package/dist/src/components/editor/plugins/list-kit.mjs +22 -0
  54. package/dist/src/components/editor/plugins/markdown-kit.mjs +17 -0
  55. package/dist/src/components/editor/plugins/math-base-kit.mjs +8 -0
  56. package/dist/src/components/editor/plugins/math-kit.mjs +10 -0
  57. package/dist/src/components/editor/plugins/media-base-kit.mjs +23 -0
  58. package/dist/src/components/editor/plugins/media-kit.mjs +37 -0
  59. package/dist/src/components/editor/plugins/slash-kit.mjs +11 -0
  60. package/dist/src/components/editor/plugins/suggestion-base-kit.mjs +8 -0
  61. package/dist/src/components/editor/plugins/suggestion-kit.mjs +50 -0
  62. package/dist/src/components/editor/plugins/table-base-kit.mjs +13 -0
  63. package/dist/src/components/editor/plugins/table-kit.mjs +15 -0
  64. package/dist/src/components/editor/transforms.mjs +125 -0
  65. package/dist/src/components/editor/ui/ai-chat-editor.mjs +21 -0
  66. package/dist/src/components/editor/ui/ai-menu.mjs +488 -0
  67. package/dist/src/components/editor/ui/ai-node.mjs +24 -0
  68. package/dist/src/components/editor/ui/ai-toolbar-button.mjs +23 -0
  69. package/dist/src/components/editor/ui/align-toolbar-button.mjs +71 -0
  70. package/dist/src/components/editor/ui/block-context-menu.mjs +130 -0
  71. package/dist/src/components/editor/ui/block-discussion.mjs +200 -0
  72. package/dist/src/components/editor/ui/block-draggable.mjs +265 -0
  73. package/dist/src/components/editor/ui/block-list-static.mjs +48 -0
  74. package/dist/src/components/editor/ui/block-list.mjs +47 -0
  75. package/dist/src/components/editor/ui/block-selection.mjs +28 -0
  76. package/dist/src/components/editor/ui/block-suggestion.mjs +319 -0
  77. package/dist/src/components/editor/ui/blockquote-node-static.mjs +14 -0
  78. package/dist/src/components/editor/ui/blockquote-node.mjs +16 -0
  79. package/dist/src/components/editor/ui/callout-node-static.mjs +29 -0
  80. package/dist/src/components/editor/ui/callout-node.mjs +50 -0
  81. package/dist/src/components/editor/ui/caption.mjs +39 -0
  82. package/dist/src/components/editor/ui/code-block-node-static.mjs +30 -0
  83. package/dist/src/components/editor/ui/code-block-node.mjs +121 -0
  84. package/dist/src/components/editor/ui/code-node-static.mjs +15 -0
  85. package/dist/src/components/editor/ui/code-node.mjs +17 -0
  86. package/dist/src/components/editor/ui/column-node-static.mjs +32 -0
  87. package/dist/src/components/editor/ui/column-node.mjs +229 -0
  88. package/dist/src/components/editor/ui/comment-node-static.mjs +14 -0
  89. package/dist/src/components/editor/ui/comment-node.mjs +33 -0
  90. package/dist/src/components/editor/ui/comment-toolbar-button.mjs +23 -0
  91. package/dist/src/components/editor/ui/comment.mjs +422 -0
  92. package/dist/src/components/editor/ui/cursor-overlay.mjs +36 -0
  93. package/dist/src/components/editor/ui/date-node-static.mjs +32 -0
  94. package/dist/src/components/editor/ui/date-node.mjs +60 -0
  95. package/dist/src/components/editor/ui/editor-static.mjs +31 -0
  96. package/dist/src/components/editor/ui/editor.mjs +60 -0
  97. package/dist/src/components/editor/ui/emoji-node.mjs +46 -0
  98. package/dist/src/components/editor/ui/emoji-toolbar-button.mjs +415 -0
  99. package/dist/src/components/editor/ui/equation-node-static.mjs +65 -0
  100. package/dist/src/components/editor/ui/equation-node.mjs +159 -0
  101. package/dist/src/components/editor/ui/equation-toolbar-button.mjs +23 -0
  102. package/dist/src/components/editor/ui/fixed-toolbar-buttons.mjs +109 -0
  103. package/dist/src/components/editor/ui/fixed-toolbar.mjs +16 -0
  104. package/dist/src/components/editor/ui/floating-toolbar-buttons.mjs +54 -0
  105. package/dist/src/components/editor/ui/floating-toolbar.mjs +51 -0
  106. package/dist/src/components/editor/ui/font-color-toolbar-button.mjs +637 -0
  107. package/dist/src/components/editor/ui/font-size-toolbar-button.mjs +83 -0
  108. package/dist/src/components/editor/ui/ghost-text.mjs +22 -0
  109. package/dist/src/components/editor/ui/heading-node-static.mjs +60 -0
  110. package/dist/src/components/editor/ui/heading-node.mjs +62 -0
  111. package/dist/src/components/editor/ui/highlight-node-static.mjs +15 -0
  112. package/dist/src/components/editor/ui/highlight-node.mjs +17 -0
  113. package/dist/src/components/editor/ui/history-toolbar-button.mjs +35 -0
  114. package/dist/src/components/editor/ui/hr-node-static.mjs +18 -0
  115. package/dist/src/components/editor/ui/hr-node.mjs +23 -0
  116. package/dist/src/components/editor/ui/indent-toolbar-button.mjs +29 -0
  117. package/dist/src/components/editor/ui/inline-combobox.mjs +148 -0
  118. package/dist/src/components/editor/ui/insert-toolbar-button.mjs +199 -0
  119. package/dist/src/components/editor/ui/kbd-node-static.mjs +15 -0
  120. package/dist/src/components/editor/ui/kbd-node.mjs +17 -0
  121. package/dist/src/components/editor/ui/line-height-toolbar-button.mjs +56 -0
  122. package/dist/src/components/editor/ui/link-node-static.mjs +20 -0
  123. package/dist/src/components/editor/ui/link-node.mjs +28 -0
  124. package/dist/src/components/editor/ui/link-toolbar-button.mjs +21 -0
  125. package/dist/src/components/editor/ui/link-toolbar.mjs +141 -0
  126. package/dist/src/components/editor/ui/list-toolbar-button.mjs +131 -0
  127. package/dist/src/components/editor/ui/mark-toolbar-button.mjs +20 -0
  128. package/dist/src/components/editor/ui/media-image-node-static.mjs +32 -0
  129. package/dist/src/components/editor/ui/media-image-node.mjs +64 -0
  130. package/dist/src/components/editor/ui/media-placeholder-node.mjs +184 -0
  131. package/dist/src/components/editor/ui/media-preview-dialog.mjs +113 -0
  132. package/dist/src/components/editor/ui/media-toolbar-button.mjs +156 -0
  133. package/dist/src/components/editor/ui/media-toolbar.mjs +80 -0
  134. package/dist/src/components/editor/ui/media-upload-toast.mjs +39 -0
  135. package/dist/src/components/editor/ui/media-video-node-static.mjs +27 -0
  136. package/dist/src/components/editor/ui/mode-toolbar-button.mjs +112 -0
  137. package/dist/src/components/editor/ui/paragraph-node-static.mjs +15 -0
  138. package/dist/src/components/editor/ui/paragraph-node.mjs +17 -0
  139. package/dist/src/components/editor/ui/resize-handle.mjs +43 -0
  140. package/dist/src/components/editor/ui/slash-node.mjs +228 -0
  141. package/dist/src/components/editor/ui/suggestion-node-static.mjs +24 -0
  142. package/dist/src/components/editor/ui/suggestion-node.mjs +111 -0
  143. package/dist/src/components/editor/ui/suggestion-toolbar-button.mjs +24 -0
  144. package/dist/src/components/editor/ui/table-icons.mjs +1310 -0
  145. package/dist/src/components/editor/ui/table-node-static.mjs +68 -0
  146. package/dist/src/components/editor/ui/table-node.mjs +375 -0
  147. package/dist/src/components/editor/ui/table-toolbar-button.mjs +190 -0
  148. package/dist/src/components/editor/ui/turn-into-toolbar-button.mjs +168 -0
  149. package/dist/src/components/editor/use-chat.mjs +80 -0
  150. package/dist/src/components/json-schema-editor/client.mjs +46 -0
  151. package/dist/src/components/json-schema-editor/components/inputs.mjs +438 -0
  152. package/dist/src/components/json-schema-editor/get-default-values.mjs +23 -0
  153. package/dist/src/components/json-schema-editor/schema.mjs +131 -0
  154. package/dist/src/components/json-schema-editor/utils/merge-schema.mjs +134 -0
  155. package/dist/src/components/json-schema-editor/utils/schema-to-string.mjs +53 -0
  156. package/dist/src/components/ui/alert-dialog.mjs +90 -0
  157. package/dist/src/components/ui/avatar.mjs +32 -0
  158. package/dist/src/components/ui/button.mjs +48 -0
  159. package/dist/src/components/ui/calendar.mjs +108 -0
  160. package/dist/src/components/ui/checkbox.mjs +23 -0
  161. package/dist/src/components/ui/combobox.mjs +53 -0
  162. package/dist/src/components/ui/command.mjs +42 -0
  163. package/dist/src/components/ui/context-menu.mjs +67 -0
  164. package/dist/src/components/ui/dialog.mjs +9 -0
  165. package/dist/src/components/ui/dropdown-menu.mjs +122 -0
  166. package/dist/src/components/ui/input-group.mjs +31 -0
  167. package/dist/src/components/ui/input.mjs +15 -0
  168. package/dist/src/components/ui/label.mjs +19 -0
  169. package/dist/src/components/ui/popover.mjs +37 -0
  170. package/dist/src/components/ui/select.mjs +80 -0
  171. package/dist/src/components/ui/separator.mjs +19 -0
  172. package/dist/src/components/ui/spinner.mjs +16 -0
  173. package/dist/src/components/ui/tabs.mjs +39 -0
  174. package/dist/src/components/ui/textarea.mjs +14 -0
  175. package/dist/src/components/ui/toolbar.mjs +183 -0
  176. package/dist/src/components/ui/tooltip.mjs +38 -0
  177. package/dist/src/hooks/editor/use-is-creator.mjs +19 -0
  178. package/dist/src/hooks/use-upload-file.mjs +73 -0
  179. package/dist/src/lib/config.mjs +38 -0
  180. package/dist/src/lib/data/store.d.mts +15 -0
  181. package/dist/src/lib/lowlight.mjs +7 -0
  182. package/dist/src/lib/utils/deep-equal.mjs +18 -0
  183. package/dist/src/lib/utils/remove-undefined.mjs +18 -0
  184. package/dist/src/lib/utils.mjs +10 -0
  185. package/dist/types.d.mts +50 -0
  186. package/next.config.ts +23 -0
  187. package/package.json +131 -0
  188. package/postcss.config.mjs +7 -0
  189. package/src/app/(dashboard)/collection/[name]/[...slug]/page.client.tsx +26 -0
  190. package/src/app/(dashboard)/collection/[name]/[...slug]/page.tsx +17 -0
  191. package/src/app/(dashboard)/collection/[name]/page.client.tsx +82 -0
  192. package/src/app/(dashboard)/collection/[name]/page.tsx +11 -0
  193. package/src/app/(dashboard)/layout.tsx +34 -0
  194. package/src/app/(dashboard)/page.tsx +38 -0
  195. package/src/app/api/ai/command/prompts.ts +313 -0
  196. package/src/app/api/ai/command/route.ts +203 -0
  197. package/src/app/api/ai/command/utils.ts +242 -0
  198. package/src/app/api/ai/copilot/route.ts +33 -0
  199. package/src/app/api/uploadthing/route.ts +5 -0
  200. package/src/app/codeblock/LICENSE +21 -0
  201. package/src/app/codeblock/styles.css +289 -0
  202. package/src/app/favicon.ico +0 -0
  203. package/src/app/globals.css +223 -0
  204. package/src/app/layout.client.tsx +15 -0
  205. package/src/app/layout.tsx +30 -0
  206. package/src/components/app-sidebar.tsx +162 -0
  207. package/src/components/code-editor/mdx.lazy.tsx +18 -0
  208. package/src/components/code-editor/mdx.tsx +48 -0
  209. package/src/components/code-editor/yaml.lazy.tsx +20 -0
  210. package/src/components/code-editor/yaml.tsx +71 -0
  211. package/src/components/collection/actions.tsx +41 -0
  212. package/src/components/collection/client.tsx +63 -0
  213. package/src/components/collection/context.tsx +24 -0
  214. package/src/components/collection/document/actions.tsx +83 -0
  215. package/src/components/editor/editor-base-kit.tsx +37 -0
  216. package/src/components/editor/editor-kit.tsx +87 -0
  217. package/src/components/editor/md.tsx +60 -0
  218. package/src/components/editor/plugins/ai-kit.tsx +102 -0
  219. package/src/components/editor/plugins/align-base-kit.tsx +16 -0
  220. package/src/components/editor/plugins/align-kit.tsx +18 -0
  221. package/src/components/editor/plugins/autoformat-kit.tsx +236 -0
  222. package/src/components/editor/plugins/basic-blocks-base-kit.tsx +34 -0
  223. package/src/components/editor/plugins/basic-blocks-kit.tsx +87 -0
  224. package/src/components/editor/plugins/basic-marks-base-kit.tsx +26 -0
  225. package/src/components/editor/plugins/basic-marks-kit.tsx +40 -0
  226. package/src/components/editor/plugins/basic-nodes-kit.tsx +6 -0
  227. package/src/components/editor/plugins/block-menu-kit.tsx +14 -0
  228. package/src/components/editor/plugins/block-placeholder-kit.tsx +17 -0
  229. package/src/components/editor/plugins/block-selection-kit.tsx +54 -0
  230. package/src/components/editor/plugins/callout-base-kit.tsx +5 -0
  231. package/src/components/editor/plugins/callout-kit.tsx +7 -0
  232. package/src/components/editor/plugins/code-block-base-kit.tsx +16 -0
  233. package/src/components/editor/plugins/code-block-kit.tsx +19 -0
  234. package/src/components/editor/plugins/column-base-kit.tsx +11 -0
  235. package/src/components/editor/plugins/column-kit.tsx +10 -0
  236. package/src/components/editor/plugins/comment-base-kit.tsx +5 -0
  237. package/src/components/editor/plugins/comment-kit.tsx +92 -0
  238. package/src/components/editor/plugins/copilot-kit.tsx +70 -0
  239. package/src/components/editor/plugins/cursor-overlay-kit.tsx +13 -0
  240. package/src/components/editor/plugins/date-base-kit.tsx +5 -0
  241. package/src/components/editor/plugins/date-kit.tsx +7 -0
  242. package/src/components/editor/plugins/discussion-kit.tsx +142 -0
  243. package/src/components/editor/plugins/dnd-kit.tsx +25 -0
  244. package/src/components/editor/plugins/emoji-kit.tsx +13 -0
  245. package/src/components/editor/plugins/exit-break-kit.tsx +12 -0
  246. package/src/components/editor/plugins/fixed-toolbar-kit.tsx +19 -0
  247. package/src/components/editor/plugins/floating-toolbar-kit.tsx +19 -0
  248. package/src/components/editor/plugins/font-base-kit.tsx +20 -0
  249. package/src/components/editor/plugins/font-kit.tsx +29 -0
  250. package/src/components/editor/plugins/indent-base-kit.tsx +13 -0
  251. package/src/components/editor/plugins/indent-kit.tsx +22 -0
  252. package/src/components/editor/plugins/line-height-base-kit.tsx +14 -0
  253. package/src/components/editor/plugins/line-height-kit.tsx +16 -0
  254. package/src/components/editor/plugins/link-base-kit.tsx +5 -0
  255. package/src/components/editor/plugins/link-kit.tsx +15 -0
  256. package/src/components/editor/plugins/list-base-kit.tsx +17 -0
  257. package/src/components/editor/plugins/list-kit.tsx +26 -0
  258. package/src/components/editor/plugins/markdown-kit.tsx +13 -0
  259. package/src/components/editor/plugins/math-base-kit.tsx +11 -0
  260. package/src/components/editor/plugins/math-kit.tsx +10 -0
  261. package/src/components/editor/plugins/media-base-kit.tsx +25 -0
  262. package/src/components/editor/plugins/media-kit.tsx +28 -0
  263. package/src/components/editor/plugins/slash-kit.tsx +18 -0
  264. package/src/components/editor/plugins/suggestion-base-kit.tsx +5 -0
  265. package/src/components/editor/plugins/suggestion-kit.tsx +83 -0
  266. package/src/components/editor/plugins/table-base-kit.tsx +20 -0
  267. package/src/components/editor/plugins/table-kit.tsx +22 -0
  268. package/src/components/editor/settings-dialog.tsx +418 -0
  269. package/src/components/editor/transforms.ts +193 -0
  270. package/src/components/editor/types.ts +149 -0
  271. package/src/components/editor/ui/ai-chat-editor.tsx +20 -0
  272. package/src/components/editor/ui/ai-menu.tsx +663 -0
  273. package/src/components/editor/ui/ai-node.tsx +40 -0
  274. package/src/components/editor/ui/ai-toolbar-button.tsx +23 -0
  275. package/src/components/editor/ui/align-toolbar-button.tsx +78 -0
  276. package/src/components/editor/ui/block-context-menu.tsx +154 -0
  277. package/src/components/editor/ui/block-discussion.tsx +318 -0
  278. package/src/components/editor/ui/block-draggable.tsx +464 -0
  279. package/src/components/editor/ui/block-list-static.tsx +75 -0
  280. package/src/components/editor/ui/block-list.tsx +72 -0
  281. package/src/components/editor/ui/block-selection.tsx +37 -0
  282. package/src/components/editor/ui/block-suggestion.tsx +438 -0
  283. package/src/components/editor/ui/blockquote-node-static.tsx +5 -0
  284. package/src/components/editor/ui/blockquote-node.tsx +7 -0
  285. package/src/components/editor/ui/callout-node-static.tsx +30 -0
  286. package/src/components/editor/ui/callout-node.tsx +64 -0
  287. package/src/components/editor/ui/caption.tsx +55 -0
  288. package/src/components/editor/ui/code-block-node-static.tsx +33 -0
  289. package/src/components/editor/ui/code-block-node.tsx +161 -0
  290. package/src/components/editor/ui/code-node-static.tsx +15 -0
  291. package/src/components/editor/ui/code-node.tsx +17 -0
  292. package/src/components/editor/ui/column-node-static.tsx +27 -0
  293. package/src/components/editor/ui/column-node.tsx +285 -0
  294. package/src/components/editor/ui/comment-node-static.tsx +12 -0
  295. package/src/components/editor/ui/comment-node.tsx +43 -0
  296. package/src/components/editor/ui/comment-toolbar-button.tsx +24 -0
  297. package/src/components/editor/ui/comment.tsx +577 -0
  298. package/src/components/editor/ui/cursor-overlay.tsx +66 -0
  299. package/src/components/editor/ui/date-node-static.tsx +45 -0
  300. package/src/components/editor/ui/date-node.tsx +86 -0
  301. package/src/components/editor/ui/editor-static.tsx +47 -0
  302. package/src/components/editor/ui/editor.tsx +120 -0
  303. package/src/components/editor/ui/emoji-node.tsx +65 -0
  304. package/src/components/editor/ui/emoji-toolbar-button.tsx +582 -0
  305. package/src/components/editor/ui/equation-node-static.tsx +94 -0
  306. package/src/components/editor/ui/equation-node.tsx +218 -0
  307. package/src/components/editor/ui/equation-toolbar-button.tsx +24 -0
  308. package/src/components/editor/ui/fixed-toolbar-buttons.tsx +135 -0
  309. package/src/components/editor/ui/fixed-toolbar.tsx +17 -0
  310. package/src/components/editor/ui/floating-toolbar-buttons.tsx +72 -0
  311. package/src/components/editor/ui/floating-toolbar.tsx +76 -0
  312. package/src/components/editor/ui/font-color-toolbar-button.tsx +804 -0
  313. package/src/components/editor/ui/font-size-toolbar-button.tsx +102 -0
  314. package/src/components/editor/ui/ghost-text.tsx +27 -0
  315. package/src/components/editor/ui/heading-node-static.tsx +54 -0
  316. package/src/components/editor/ui/heading-node.tsx +54 -0
  317. package/src/components/editor/ui/highlight-node-static.tsx +11 -0
  318. package/src/components/editor/ui/highlight-node.tsx +13 -0
  319. package/src/components/editor/ui/history-toolbar-button.tsx +41 -0
  320. package/src/components/editor/ui/hr-node-static.tsx +16 -0
  321. package/src/components/editor/ui/hr-node.tsx +28 -0
  322. package/src/components/editor/ui/indent-toolbar-button.tsx +27 -0
  323. package/src/components/editor/ui/inline-combobox.tsx +251 -0
  324. package/src/components/editor/ui/insert-toolbar-button.tsx +242 -0
  325. package/src/components/editor/ui/kbd-node-static.tsx +15 -0
  326. package/src/components/editor/ui/kbd-node.tsx +17 -0
  327. package/src/components/editor/ui/line-height-toolbar-button.tsx +66 -0
  328. package/src/components/editor/ui/link-node-static.tsx +21 -0
  329. package/src/components/editor/ui/link-node.tsx +37 -0
  330. package/src/components/editor/ui/link-toolbar-button.tsx +18 -0
  331. package/src/components/editor/ui/link-toolbar.tsx +196 -0
  332. package/src/components/editor/ui/list-toolbar-button.tsx +195 -0
  333. package/src/components/editor/ui/mark-toolbar-button.tsx +20 -0
  334. package/src/components/editor/ui/media-image-node-static.tsx +33 -0
  335. package/src/components/editor/ui/media-image-node.tsx +75 -0
  336. package/src/components/editor/ui/media-placeholder-node.tsx +235 -0
  337. package/src/components/editor/ui/media-preview-dialog.tsx +145 -0
  338. package/src/components/editor/ui/media-toolbar-button.tsx +202 -0
  339. package/src/components/editor/ui/media-toolbar.tsx +100 -0
  340. package/src/components/editor/ui/media-upload-toast.tsx +59 -0
  341. package/src/components/editor/ui/media-video-node-static.tsx +23 -0
  342. package/src/components/editor/ui/mode-toolbar-button.tsx +121 -0
  343. package/src/components/editor/ui/paragraph-node-static.tsx +13 -0
  344. package/src/components/editor/ui/paragraph-node.tsx +15 -0
  345. package/src/components/editor/ui/resize-handle.tsx +79 -0
  346. package/src/components/editor/ui/slash-node.tsx +274 -0
  347. package/src/components/editor/ui/suggestion-node-static.tsx +30 -0
  348. package/src/components/editor/ui/suggestion-node.tsx +157 -0
  349. package/src/components/editor/ui/suggestion-toolbar-button.tsx +25 -0
  350. package/src/components/editor/ui/table-icons.tsx +685 -0
  351. package/src/components/editor/ui/table-node-static.tsx +86 -0
  352. package/src/components/editor/ui/table-node.tsx +569 -0
  353. package/src/components/editor/ui/table-toolbar-button.tsx +260 -0
  354. package/src/components/editor/ui/turn-into-toolbar-button.tsx +176 -0
  355. package/src/components/editor/use-chat.ts +120 -0
  356. package/src/components/icons/logo.tsx +37 -0
  357. package/src/components/json-schema-editor/client.tsx +55 -0
  358. package/src/components/json-schema-editor/components/inputs.tsx +612 -0
  359. package/src/components/json-schema-editor/get-default-values.ts +29 -0
  360. package/src/components/json-schema-editor/schema.tsx +206 -0
  361. package/src/components/json-schema-editor/utils/merge-schema.ts +167 -0
  362. package/src/components/json-schema-editor/utils/schema-to-string.ts +87 -0
  363. package/src/components/nav-user.tsx +102 -0
  364. package/src/components/site-header.tsx +13 -0
  365. package/src/components/ui/alert-dialog.tsx +182 -0
  366. package/src/components/ui/avatar.tsx +96 -0
  367. package/src/components/ui/badge.tsx +46 -0
  368. package/src/components/ui/button.tsx +65 -0
  369. package/src/components/ui/calendar.tsx +186 -0
  370. package/src/components/ui/checkbox.tsx +29 -0
  371. package/src/components/ui/combobox.tsx +267 -0
  372. package/src/components/ui/command.tsx +180 -0
  373. package/src/components/ui/context-menu.tsx +161 -0
  374. package/src/components/ui/dialog.tsx +142 -0
  375. package/src/components/ui/drawer.tsx +120 -0
  376. package/src/components/ui/dropdown-menu.tsx +239 -0
  377. package/src/components/ui/field.tsx +224 -0
  378. package/src/components/ui/input-group.tsx +144 -0
  379. package/src/components/ui/input.tsx +19 -0
  380. package/src/components/ui/label.tsx +18 -0
  381. package/src/components/ui/popover.tsx +76 -0
  382. package/src/components/ui/select.tsx +182 -0
  383. package/src/components/ui/separator.tsx +28 -0
  384. package/src/components/ui/sheet.tsx +130 -0
  385. package/src/components/ui/sidebar.tsx +608 -0
  386. package/src/components/ui/sonner.tsx +45 -0
  387. package/src/components/ui/spinner.tsx +15 -0
  388. package/src/components/ui/table.tsx +89 -0
  389. package/src/components/ui/tabs.tsx +60 -0
  390. package/src/components/ui/textarea.tsx +18 -0
  391. package/src/components/ui/toggle-group.tsx +86 -0
  392. package/src/components/ui/toggle.tsx +45 -0
  393. package/src/components/ui/toolbar.tsx +365 -0
  394. package/src/components/ui/tooltip.tsx +57 -0
  395. package/src/hooks/editor/use-is-creator.ts +21 -0
  396. package/src/hooks/use-mobile.ts +19 -0
  397. package/src/hooks/use-mounted.ts +11 -0
  398. package/src/hooks/use-upload-file.ts +121 -0
  399. package/src/lib/ai/markdown-joiner-transform.ts +235 -0
  400. package/src/lib/config.ts +60 -0
  401. package/src/lib/data/actions.ts +51 -0
  402. package/src/lib/data/boundary.client.tsx +22 -0
  403. package/src/lib/data/boundary.tsx +22 -0
  404. package/src/lib/data/query.ts +9 -0
  405. package/src/lib/data/store.ts +52 -0
  406. package/src/lib/lowlight.ts +3 -0
  407. package/src/lib/uploadthing.ts +19 -0
  408. package/src/lib/utils/deep-equal.ts +37 -0
  409. package/src/lib/utils/remove-undefined.ts +21 -0
  410. package/src/lib/utils/urls.ts +6 -0
  411. package/src/lib/utils.ts +6 -0
  412. package/tsconfig.build.json +24 -0
  413. package/tsconfig.json +37 -0
@@ -0,0 +1,87 @@
1
+ "use client";
2
+
3
+ import {
4
+ BlockquotePlugin,
5
+ H1Plugin,
6
+ H2Plugin,
7
+ H3Plugin,
8
+ H4Plugin,
9
+ H5Plugin,
10
+ H6Plugin,
11
+ HorizontalRulePlugin,
12
+ } from "@platejs/basic-nodes/react";
13
+ import { ParagraphPlugin } from "platejs/react";
14
+ import { BlockquoteElement } from "@/components/editor/ui/blockquote-node";
15
+ import {
16
+ H1Element,
17
+ H2Element,
18
+ H3Element,
19
+ H4Element,
20
+ H5Element,
21
+ H6Element,
22
+ } from "@/components/editor/ui/heading-node";
23
+ import { HrElement } from "@/components/editor/ui/hr-node";
24
+ import { ParagraphElement } from "@/components/editor/ui/paragraph-node";
25
+
26
+ export const BasicBlocksKit = [
27
+ ParagraphPlugin.withComponent(ParagraphElement),
28
+ H1Plugin.configure({
29
+ node: {
30
+ component: H1Element,
31
+ },
32
+ rules: {
33
+ break: { empty: "reset" },
34
+ },
35
+ shortcuts: { toggle: { keys: "mod+alt+1" } },
36
+ }),
37
+ H2Plugin.configure({
38
+ node: {
39
+ component: H2Element,
40
+ },
41
+ rules: {
42
+ break: { empty: "reset" },
43
+ },
44
+ shortcuts: { toggle: { keys: "mod+alt+2" } },
45
+ }),
46
+ H3Plugin.configure({
47
+ node: {
48
+ component: H3Element,
49
+ },
50
+ rules: {
51
+ break: { empty: "reset" },
52
+ },
53
+ shortcuts: { toggle: { keys: "mod+alt+3" } },
54
+ }),
55
+ H4Plugin.configure({
56
+ node: {
57
+ component: H4Element,
58
+ },
59
+ rules: {
60
+ break: { empty: "reset" },
61
+ },
62
+ shortcuts: { toggle: { keys: "mod+alt+4" } },
63
+ }),
64
+ H5Plugin.configure({
65
+ node: {
66
+ component: H5Element,
67
+ },
68
+ rules: {
69
+ break: { empty: "reset" },
70
+ },
71
+ shortcuts: { toggle: { keys: "mod+alt+5" } },
72
+ }),
73
+ H6Plugin.configure({
74
+ node: {
75
+ component: H6Element,
76
+ },
77
+ rules: {
78
+ break: { empty: "reset" },
79
+ },
80
+ shortcuts: { toggle: { keys: "mod+alt+6" } },
81
+ }),
82
+ BlockquotePlugin.configure({
83
+ node: { component: BlockquoteElement },
84
+ shortcuts: { toggle: { keys: "mod+shift+period" } },
85
+ }),
86
+ HorizontalRulePlugin.withComponent(HrElement),
87
+ ];
@@ -0,0 +1,26 @@
1
+ import {
2
+ BaseBoldPlugin,
3
+ BaseCodePlugin,
4
+ BaseHighlightPlugin,
5
+ BaseItalicPlugin,
6
+ BaseKbdPlugin,
7
+ BaseStrikethroughPlugin,
8
+ BaseSubscriptPlugin,
9
+ BaseSuperscriptPlugin,
10
+ BaseUnderlinePlugin,
11
+ } from "@platejs/basic-nodes";
12
+ import { CodeLeafStatic } from "@/components/editor/ui/code-node-static";
13
+ import { HighlightLeafStatic } from "@/components/editor/ui/highlight-node-static";
14
+ import { KbdLeafStatic } from "@/components/editor/ui/kbd-node-static";
15
+
16
+ export const BaseBasicMarksKit = [
17
+ BaseBoldPlugin,
18
+ BaseItalicPlugin,
19
+ BaseUnderlinePlugin,
20
+ BaseCodePlugin.withComponent(CodeLeafStatic),
21
+ BaseStrikethroughPlugin,
22
+ BaseSubscriptPlugin,
23
+ BaseSuperscriptPlugin,
24
+ BaseHighlightPlugin.withComponent(HighlightLeafStatic),
25
+ BaseKbdPlugin.withComponent(KbdLeafStatic),
26
+ ];
@@ -0,0 +1,40 @@
1
+ "use client";
2
+
3
+ import {
4
+ BoldPlugin,
5
+ CodePlugin,
6
+ HighlightPlugin,
7
+ ItalicPlugin,
8
+ KbdPlugin,
9
+ StrikethroughPlugin,
10
+ SubscriptPlugin,
11
+ SuperscriptPlugin,
12
+ UnderlinePlugin,
13
+ } from "@platejs/basic-nodes/react";
14
+ import { CodeLeaf } from "@/components/editor/ui/code-node";
15
+ import { HighlightLeaf } from "@/components/editor/ui/highlight-node";
16
+ import { KbdLeaf } from "@/components/editor/ui/kbd-node";
17
+
18
+ export const BasicMarksKit = [
19
+ BoldPlugin,
20
+ ItalicPlugin,
21
+ UnderlinePlugin,
22
+ CodePlugin.configure({
23
+ node: { component: CodeLeaf },
24
+ shortcuts: { toggle: { keys: "mod+e" } },
25
+ }),
26
+ StrikethroughPlugin.configure({
27
+ shortcuts: { toggle: { keys: "mod+shift+x" } },
28
+ }),
29
+ SubscriptPlugin.configure({
30
+ shortcuts: { toggle: { keys: "mod+comma" } },
31
+ }),
32
+ SuperscriptPlugin.configure({
33
+ shortcuts: { toggle: { keys: "mod+period" } },
34
+ }),
35
+ HighlightPlugin.configure({
36
+ node: { component: HighlightLeaf },
37
+ shortcuts: { toggle: { keys: "mod+shift+h" } },
38
+ }),
39
+ KbdPlugin.withComponent(KbdLeaf),
40
+ ];
@@ -0,0 +1,6 @@
1
+ "use client";
2
+
3
+ import { BasicBlocksKit } from "./basic-blocks-kit";
4
+ import { BasicMarksKit } from "./basic-marks-kit";
5
+
6
+ export const BasicNodesKit = [...BasicBlocksKit, ...BasicMarksKit];
@@ -0,0 +1,14 @@
1
+ "use client";
2
+
3
+ import { BlockMenuPlugin } from "@platejs/selection/react";
4
+
5
+ import { BlockContextMenu } from "@/components/editor/ui/block-context-menu";
6
+
7
+ import { BlockSelectionKit } from "./block-selection-kit";
8
+
9
+ export const BlockMenuKit = [
10
+ ...BlockSelectionKit,
11
+ BlockMenuPlugin.configure({
12
+ render: { aboveEditable: BlockContextMenu },
13
+ }),
14
+ ];
@@ -0,0 +1,17 @@
1
+ "use client";
2
+
3
+ import { KEYS } from "platejs";
4
+ import { BlockPlaceholderPlugin } from "platejs/react";
5
+
6
+ export const BlockPlaceholderKit = [
7
+ BlockPlaceholderPlugin.configure({
8
+ options: {
9
+ className:
10
+ "before:absolute before:cursor-text before:text-muted-foreground/80 before:content-[attr(placeholder)]",
11
+ placeholders: {
12
+ [KEYS.p]: "Type something...",
13
+ },
14
+ query: ({ path }) => path.length === 1,
15
+ },
16
+ }),
17
+ ];
@@ -0,0 +1,54 @@
1
+ "use client";
2
+
3
+ import { AIChatPlugin } from "@platejs/ai/react";
4
+ import { BlockSelectionPlugin } from "@platejs/selection/react";
5
+ import { getPluginTypes, isHotkey, KEYS } from "platejs";
6
+
7
+ import { BlockSelection } from "@/components/editor/ui/block-selection";
8
+ import { createPlatePlugin } from "platejs/react";
9
+
10
+ const InlineSelectionPlugin = createPlatePlugin((editor) => ({
11
+ key: "inline-selection",
12
+ priority: 200,
13
+ handlers: {
14
+ onKeyDown({ event: e }) {
15
+ const marks = editor.api.marks();
16
+ if (!marks) return;
17
+
18
+ if (isHotkey("escape")(e) && KEYS.sub in marks) {
19
+ editor.tf.removeMark(KEYS.sub);
20
+ e.preventDefault();
21
+ return true;
22
+ }
23
+
24
+ if (isHotkey("escape")(e) && KEYS.sup in marks) {
25
+ editor.tf.removeMark(KEYS.sup);
26
+ e.preventDefault();
27
+ return true;
28
+ }
29
+ },
30
+ },
31
+ }));
32
+
33
+ export const BlockSelectionKit = [
34
+ InlineSelectionPlugin,
35
+ BlockSelectionPlugin.configure(({ editor }) => ({
36
+ options: {
37
+ enableContextMenu: true,
38
+ isSelectable: (element) =>
39
+ !getPluginTypes(editor, [KEYS.column, KEYS.codeLine, KEYS.td]).includes(element.type),
40
+ onKeyDownSelecting: (editor, e) => {
41
+ if (isHotkey("mod+j")(e)) {
42
+ editor.getApi(AIChatPlugin).aiChat.show();
43
+ }
44
+ },
45
+ },
46
+ render: {
47
+ belowRootNodes: (props) => {
48
+ if (!props.attributes.className?.includes("slate-selectable")) return null;
49
+
50
+ return <BlockSelection {...(props as any)} />;
51
+ },
52
+ },
53
+ })),
54
+ ];
@@ -0,0 +1,5 @@
1
+ import { BaseCalloutPlugin } from "@platejs/callout";
2
+
3
+ import { CalloutElementStatic } from "@/components/editor/ui/callout-node-static";
4
+
5
+ export const BaseCalloutKit = [BaseCalloutPlugin.withComponent(CalloutElementStatic)];
@@ -0,0 +1,7 @@
1
+ "use client";
2
+
3
+ import { CalloutPlugin } from "@platejs/callout/react";
4
+
5
+ import { CalloutElement } from "@/components/editor/ui/callout-node";
6
+
7
+ export const CalloutKit = [CalloutPlugin.withComponent(CalloutElement)];
@@ -0,0 +1,16 @@
1
+ import { BaseCodeBlockPlugin, BaseCodeLinePlugin, BaseCodeSyntaxPlugin } from "@platejs/code-block";
2
+ import {
3
+ CodeBlockElementStatic,
4
+ CodeLineElementStatic,
5
+ CodeSyntaxLeafStatic,
6
+ } from "@/components/editor/ui/code-block-node-static";
7
+ import { lowlight } from "@/lib/lowlight";
8
+
9
+ export const BaseCodeBlockKit = [
10
+ BaseCodeBlockPlugin.configure({
11
+ node: { component: CodeBlockElementStatic },
12
+ options: { lowlight },
13
+ }),
14
+ BaseCodeLinePlugin.withComponent(CodeLineElementStatic),
15
+ BaseCodeSyntaxPlugin.withComponent(CodeSyntaxLeafStatic),
16
+ ];
@@ -0,0 +1,19 @@
1
+ "use client";
2
+
3
+ import { CodeBlockPlugin, CodeLinePlugin, CodeSyntaxPlugin } from "@platejs/code-block/react";
4
+ import {
5
+ CodeBlockElement,
6
+ CodeLineElement,
7
+ CodeSyntaxLeaf,
8
+ } from "@/components/editor/ui/code-block-node";
9
+ import { lowlight } from "@/lib/lowlight";
10
+
11
+ export const CodeBlockKit = [
12
+ CodeBlockPlugin.configure({
13
+ node: { component: CodeBlockElement },
14
+ options: { lowlight },
15
+ shortcuts: { toggle: { keys: "mod+alt+8" } },
16
+ }),
17
+ CodeLinePlugin.withComponent(CodeLineElement),
18
+ CodeSyntaxPlugin.withComponent(CodeSyntaxLeaf),
19
+ ];
@@ -0,0 +1,11 @@
1
+ import { BaseColumnItemPlugin, BaseColumnPlugin } from "@platejs/layout";
2
+
3
+ import {
4
+ ColumnElementStatic,
5
+ ColumnGroupElementStatic,
6
+ } from "@/components/editor/ui/column-node-static";
7
+
8
+ export const BaseColumnKit = [
9
+ BaseColumnPlugin.withComponent(ColumnGroupElementStatic),
10
+ BaseColumnItemPlugin.withComponent(ColumnElementStatic),
11
+ ];
@@ -0,0 +1,10 @@
1
+ "use client";
2
+
3
+ import { ColumnItemPlugin, ColumnPlugin } from "@platejs/layout/react";
4
+
5
+ import { ColumnElement, ColumnGroupElement } from "@/components/editor/ui/column-node";
6
+
7
+ export const ColumnKit = [
8
+ ColumnPlugin.withComponent(ColumnGroupElement),
9
+ ColumnItemPlugin.withComponent(ColumnElement),
10
+ ];
@@ -0,0 +1,5 @@
1
+ import { BaseCommentPlugin } from "@platejs/comment";
2
+
3
+ import { CommentLeafStatic } from "@/components/editor/ui/comment-node-static";
4
+
5
+ export const BaseCommentKit = [BaseCommentPlugin.withComponent(CommentLeafStatic)];
@@ -0,0 +1,92 @@
1
+ "use client";
2
+
3
+ import { type BaseCommentConfig, BaseCommentPlugin, getDraftCommentKey } from "@platejs/comment";
4
+ import type { ExtendConfig, Path } from "platejs";
5
+ import { isSlateString } from "platejs";
6
+ import { toTPlatePlugin } from "platejs/react";
7
+
8
+ import { CommentLeaf } from "@/components/editor/ui/comment-node";
9
+
10
+ type CommentConfig = ExtendConfig<
11
+ BaseCommentConfig,
12
+ {
13
+ activeId: string | null;
14
+ commentingBlock: Path | null;
15
+ hoverId: string | null;
16
+ uniquePathMap: Map<string, Path>;
17
+ }
18
+ >;
19
+
20
+ export const commentPlugin = toTPlatePlugin<CommentConfig>(BaseCommentPlugin, {
21
+ handlers: {
22
+ onClick: ({ api, event, setOption, type }) => {
23
+ let leaf = event.target as HTMLElement;
24
+ let isSet = false;
25
+
26
+ const unsetActiveSuggestion = () => {
27
+ setOption("activeId", null);
28
+ isSet = true;
29
+ };
30
+
31
+ if (!isSlateString(leaf)) unsetActiveSuggestion();
32
+
33
+ while (leaf.parentElement) {
34
+ if (leaf.classList.contains(`slate-${type}`)) {
35
+ const commentsEntry = api.comment?.node();
36
+
37
+ if (!commentsEntry) {
38
+ unsetActiveSuggestion();
39
+
40
+ break;
41
+ }
42
+
43
+ const id = api.comment?.nodeId(commentsEntry[0]);
44
+
45
+ setOption("activeId", id ?? null);
46
+ isSet = true;
47
+
48
+ break;
49
+ }
50
+
51
+ leaf = leaf.parentElement;
52
+ }
53
+
54
+ if (!isSet) unsetActiveSuggestion();
55
+ },
56
+ },
57
+ options: {
58
+ activeId: null,
59
+ commentingBlock: null,
60
+ hoverId: null,
61
+ uniquePathMap: new Map(),
62
+ },
63
+ })
64
+ .extendTransforms(
65
+ ({
66
+ editor,
67
+ setOption,
68
+ tf: {
69
+ comment: { setDraft },
70
+ },
71
+ }) => ({
72
+ setDraft: () => {
73
+ if (editor.api.isCollapsed()) {
74
+ editor.tf.select(editor.api.block()?.[1]);
75
+ }
76
+
77
+ setDraft();
78
+
79
+ editor.tf.collapse();
80
+ setOption("activeId", getDraftCommentKey());
81
+ if (editor.selection) setOption("commentingBlock", editor.selection.focus.path.slice(0, 1));
82
+ },
83
+ }),
84
+ )
85
+ .configure({
86
+ node: { component: CommentLeaf },
87
+ shortcuts: {
88
+ setDraft: { keys: "mod+shift+m" },
89
+ },
90
+ });
91
+
92
+ export const CommentKit = [commentPlugin];
@@ -0,0 +1,70 @@
1
+ "use client";
2
+
3
+ import { CopilotPlugin } from "@platejs/ai/react";
4
+ import { serializeMd, stripMarkdown } from "@platejs/markdown";
5
+ import type { TElement } from "platejs";
6
+
7
+ import { GhostText } from "@/components/editor/ui/ghost-text";
8
+
9
+ import { MarkdownKit } from "./markdown-kit";
10
+
11
+ export const CopilotKit = [
12
+ ...MarkdownKit,
13
+ CopilotPlugin.configure(({ api }) => ({
14
+ options: {
15
+ completeOptions: {
16
+ api: "/api/ai/copilot",
17
+ body: {
18
+ system: `You are an advanced AI writing assistant, similar to VSCode Copilot but for general text. Your task is to predict and generate the next part of the text based on the given context.
19
+
20
+ Rules:
21
+ - Continue the text naturally up to the next punctuation mark (., ,, ;, :, ?, or !).
22
+ - Maintain style and tone. Don't repeat given text.
23
+ - For unclear context, provide the most likely continuation.
24
+ - Handle code snippets, lists, or structured text if needed.
25
+ - Don't include """ in your response.
26
+ - CRITICAL: Always end with a punctuation mark.
27
+ - CRITICAL: Avoid starting a new block. Do not use block formatting like >, #, 1., 2., -, etc. The suggestion should continue in the same block as the context.
28
+ - If no context is provided or you can't generate a continuation, return "0" without explanation.`,
29
+ },
30
+ onFinish: (_, completion) => {
31
+ if (completion === "0") return;
32
+
33
+ api.copilot.setBlockSuggestion({
34
+ text: stripMarkdown(completion),
35
+ });
36
+ },
37
+ },
38
+ debounceDelay: 500,
39
+ renderGhostText: GhostText,
40
+ getPrompt: ({ editor }) => {
41
+ const contextEntry = editor.api.block({ highest: true });
42
+
43
+ if (!contextEntry) return "";
44
+
45
+ const prompt = serializeMd(editor, {
46
+ value: [contextEntry[0] as TElement],
47
+ });
48
+
49
+ return `Continue the text up to the next punctuation mark:
50
+ """
51
+ ${prompt}
52
+ """`;
53
+ },
54
+ },
55
+ shortcuts: {
56
+ accept: {
57
+ keys: "tab",
58
+ },
59
+ acceptNextWord: {
60
+ keys: "mod+right",
61
+ },
62
+ reject: {
63
+ keys: "escape",
64
+ },
65
+ triggerSuggestion: {
66
+ keys: "ctrl+space",
67
+ },
68
+ },
69
+ })),
70
+ ];
@@ -0,0 +1,13 @@
1
+ "use client";
2
+
3
+ import { CursorOverlayPlugin } from "@platejs/selection/react";
4
+
5
+ import { CursorOverlay } from "@/components/editor/ui/cursor-overlay";
6
+
7
+ export const CursorOverlayKit = [
8
+ CursorOverlayPlugin.configure({
9
+ render: {
10
+ afterEditable: () => <CursorOverlay />,
11
+ },
12
+ }),
13
+ ];
@@ -0,0 +1,5 @@
1
+ import { BaseDatePlugin } from "@platejs/date";
2
+
3
+ import { DateElementStatic } from "@/components/editor/ui/date-node-static";
4
+
5
+ export const BaseDateKit = [BaseDatePlugin.withComponent(DateElementStatic)];
@@ -0,0 +1,7 @@
1
+ "use client";
2
+
3
+ import { DatePlugin } from "@platejs/date/react";
4
+
5
+ import { DateElement } from "@/components/editor/ui/date-node";
6
+
7
+ export const DateKit = [DatePlugin.withComponent(DateElement)];
@@ -0,0 +1,142 @@
1
+ "use client";
2
+
3
+ import { createPlatePlugin } from "platejs/react";
4
+ import { BlockDiscussion } from "@/components/editor/ui/block-discussion";
5
+ import type { TComment } from "@/components/editor/ui/comment";
6
+
7
+ export type TDiscussion = {
8
+ id: string;
9
+ comments: TComment[];
10
+ createdAt: Date;
11
+ isResolved: boolean;
12
+ userId: string;
13
+ documentContent?: string;
14
+ };
15
+
16
+ const discussionsData: TDiscussion[] = [
17
+ {
18
+ id: "discussion1",
19
+ comments: [
20
+ {
21
+ id: "comment1",
22
+ contentRich: [
23
+ {
24
+ children: [
25
+ {
26
+ text: "Comments are a great way to provide feedback and discuss changes.",
27
+ },
28
+ ],
29
+ type: "p",
30
+ },
31
+ ],
32
+ createdAt: new Date(Date.now() - 600_000),
33
+ discussionId: "discussion1",
34
+ isEdited: false,
35
+ userId: "charlie",
36
+ },
37
+ {
38
+ id: "comment2",
39
+ contentRich: [
40
+ {
41
+ children: [
42
+ {
43
+ text: "Agreed! The link to the docs makes it easy to learn more.",
44
+ },
45
+ ],
46
+ type: "p",
47
+ },
48
+ ],
49
+ createdAt: new Date(Date.now() - 500_000),
50
+ discussionId: "discussion1",
51
+ isEdited: false,
52
+ userId: "bob",
53
+ },
54
+ ],
55
+ createdAt: new Date(),
56
+ documentContent: "comments",
57
+ isResolved: false,
58
+ userId: "charlie",
59
+ },
60
+ {
61
+ id: "discussion2",
62
+ comments: [
63
+ {
64
+ id: "comment1",
65
+ contentRich: [
66
+ {
67
+ children: [
68
+ {
69
+ text: "Nice demonstration of overlapping annotations with both comments and suggestions!",
70
+ },
71
+ ],
72
+ type: "p",
73
+ },
74
+ ],
75
+ createdAt: new Date(Date.now() - 300_000),
76
+ discussionId: "discussion2",
77
+ isEdited: false,
78
+ userId: "bob",
79
+ },
80
+ {
81
+ id: "comment2",
82
+ contentRich: [
83
+ {
84
+ children: [
85
+ {
86
+ text: "This helps users understand how powerful the editor can be.",
87
+ },
88
+ ],
89
+ type: "p",
90
+ },
91
+ ],
92
+ createdAt: new Date(Date.now() - 200_000),
93
+ discussionId: "discussion2",
94
+ isEdited: false,
95
+ userId: "charlie",
96
+ },
97
+ ],
98
+ createdAt: new Date(),
99
+ documentContent: "overlapping",
100
+ isResolved: false,
101
+ userId: "bob",
102
+ },
103
+ ];
104
+
105
+ const avatarUrl = (seed: string) => `https://api.dicebear.com/9.x/glass/svg?seed=${seed}`;
106
+
107
+ const usersData: Record<string, { id: string; avatarUrl: string; name: string; hue?: number }> = {
108
+ alice: {
109
+ id: "alice",
110
+ avatarUrl: avatarUrl("alice6"),
111
+ name: "Alice",
112
+ },
113
+ bob: {
114
+ id: "bob",
115
+ avatarUrl: avatarUrl("bob4"),
116
+ name: "Bob",
117
+ },
118
+ charlie: {
119
+ id: "charlie",
120
+ avatarUrl: avatarUrl("charlie2"),
121
+ name: "Charlie",
122
+ },
123
+ };
124
+
125
+ // This plugin is purely UI. It's only used to store the discussions and users data
126
+ export const discussionPlugin = createPlatePlugin({
127
+ key: "discussion",
128
+ options: {
129
+ currentUserId: "alice",
130
+ discussions: discussionsData,
131
+ users: usersData,
132
+ },
133
+ })
134
+ .configure({
135
+ render: { aboveNodes: BlockDiscussion },
136
+ })
137
+ .extendSelectors(({ getOption }) => ({
138
+ currentUser: () => getOption("users")[getOption("currentUserId")],
139
+ user: (id: string) => getOption("users")[id],
140
+ }));
141
+
142
+ export const DiscussionKit = [discussionPlugin];