@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.
- package/dist/bin.d.mts +1 -0
- package/dist/bin.mjs +90 -0
- package/dist/index.d.mts +13 -0
- package/dist/index.mjs +66 -0
- package/dist/mdx/actions.mjs +34 -0
- package/dist/mdx/client.mjs +167 -0
- package/dist/package.mjs +6 -0
- package/dist/src/components/code-editor/mdx.lazy.mjs +19 -0
- package/dist/src/components/code-editor/mdx.mjs +44 -0
- package/dist/src/components/code-editor/yaml.lazy.mjs +22 -0
- package/dist/src/components/code-editor/yaml.mjs +63 -0
- package/dist/src/components/editor/editor-base-kit.mjs +41 -0
- package/dist/src/components/editor/editor-kit.mjs +73 -0
- package/dist/src/components/editor/md.mjs +42 -0
- package/dist/src/components/editor/plugins/ai-kit.mjs +68 -0
- package/dist/src/components/editor/plugins/align-base-kit.mjs +28 -0
- package/dist/src/components/editor/plugins/align-kit.mjs +30 -0
- package/dist/src/components/editor/plugins/autoformat-kit.mjs +214 -0
- package/dist/src/components/editor/plugins/basic-blocks-base-kit.mjs +22 -0
- package/dist/src/components/editor/plugins/basic-blocks-kit.mjs +51 -0
- package/dist/src/components/editor/plugins/basic-marks-base-kit.mjs +20 -0
- package/dist/src/components/editor/plugins/basic-marks-kit.mjs +28 -0
- package/dist/src/components/editor/plugins/block-menu-kit.mjs +11 -0
- package/dist/src/components/editor/plugins/block-placeholder-kit.mjs +14 -0
- package/dist/src/components/editor/plugins/block-selection-kit.mjs +48 -0
- package/dist/src/components/editor/plugins/callout-base-kit.mjs +8 -0
- package/dist/src/components/editor/plugins/callout-kit.mjs +10 -0
- package/dist/src/components/editor/plugins/code-block-base-kit.mjs +16 -0
- package/dist/src/components/editor/plugins/code-block-kit.mjs +19 -0
- package/dist/src/components/editor/plugins/column-base-kit.mjs +8 -0
- package/dist/src/components/editor/plugins/column-kit.mjs +10 -0
- package/dist/src/components/editor/plugins/comment-base-kit.mjs +8 -0
- package/dist/src/components/editor/plugins/comment-kit.mjs +53 -0
- package/dist/src/components/editor/plugins/copilot-kit.mjs +49 -0
- package/dist/src/components/editor/plugins/cursor-overlay-kit.mjs +11 -0
- package/dist/src/components/editor/plugins/date-base-kit.mjs +8 -0
- package/dist/src/components/editor/plugins/date-kit.mjs +10 -0
- package/dist/src/components/editor/plugins/discussion-kit.mjs +94 -0
- package/dist/src/components/editor/plugins/dnd-kit.mjs +31 -0
- package/dist/src/components/editor/plugins/emoji-kit.mjs +11 -0
- package/dist/src/components/editor/plugins/exit-break-kit.mjs +12 -0
- package/dist/src/components/editor/plugins/fixed-toolbar-kit.mjs +15 -0
- package/dist/src/components/editor/plugins/floating-toolbar-kit.mjs +15 -0
- package/dist/src/components/editor/plugins/font-base-kit.mjs +14 -0
- package/dist/src/components/editor/plugins/font-kit.mjs +19 -0
- package/dist/src/components/editor/plugins/indent-base-kit.mjs +17 -0
- package/dist/src/components/editor/plugins/indent-kit.mjs +20 -0
- package/dist/src/components/editor/plugins/line-height-base-kit.mjs +20 -0
- package/dist/src/components/editor/plugins/line-height-kit.mjs +22 -0
- package/dist/src/components/editor/plugins/link-base-kit.mjs +8 -0
- package/dist/src/components/editor/plugins/link-kit.mjs +15 -0
- package/dist/src/components/editor/plugins/list-base-kit.mjs +19 -0
- package/dist/src/components/editor/plugins/list-kit.mjs +22 -0
- package/dist/src/components/editor/plugins/markdown-kit.mjs +17 -0
- package/dist/src/components/editor/plugins/math-base-kit.mjs +8 -0
- package/dist/src/components/editor/plugins/math-kit.mjs +10 -0
- package/dist/src/components/editor/plugins/media-base-kit.mjs +23 -0
- package/dist/src/components/editor/plugins/media-kit.mjs +37 -0
- package/dist/src/components/editor/plugins/slash-kit.mjs +11 -0
- package/dist/src/components/editor/plugins/suggestion-base-kit.mjs +8 -0
- package/dist/src/components/editor/plugins/suggestion-kit.mjs +50 -0
- package/dist/src/components/editor/plugins/table-base-kit.mjs +13 -0
- package/dist/src/components/editor/plugins/table-kit.mjs +15 -0
- package/dist/src/components/editor/transforms.mjs +125 -0
- package/dist/src/components/editor/ui/ai-chat-editor.mjs +21 -0
- package/dist/src/components/editor/ui/ai-menu.mjs +488 -0
- package/dist/src/components/editor/ui/ai-node.mjs +24 -0
- package/dist/src/components/editor/ui/ai-toolbar-button.mjs +23 -0
- package/dist/src/components/editor/ui/align-toolbar-button.mjs +71 -0
- package/dist/src/components/editor/ui/block-context-menu.mjs +130 -0
- package/dist/src/components/editor/ui/block-discussion.mjs +200 -0
- package/dist/src/components/editor/ui/block-draggable.mjs +265 -0
- package/dist/src/components/editor/ui/block-list-static.mjs +48 -0
- package/dist/src/components/editor/ui/block-list.mjs +47 -0
- package/dist/src/components/editor/ui/block-selection.mjs +28 -0
- package/dist/src/components/editor/ui/block-suggestion.mjs +319 -0
- package/dist/src/components/editor/ui/blockquote-node-static.mjs +14 -0
- package/dist/src/components/editor/ui/blockquote-node.mjs +16 -0
- package/dist/src/components/editor/ui/callout-node-static.mjs +29 -0
- package/dist/src/components/editor/ui/callout-node.mjs +50 -0
- package/dist/src/components/editor/ui/caption.mjs +39 -0
- package/dist/src/components/editor/ui/code-block-node-static.mjs +30 -0
- package/dist/src/components/editor/ui/code-block-node.mjs +121 -0
- package/dist/src/components/editor/ui/code-node-static.mjs +15 -0
- package/dist/src/components/editor/ui/code-node.mjs +17 -0
- package/dist/src/components/editor/ui/column-node-static.mjs +32 -0
- package/dist/src/components/editor/ui/column-node.mjs +229 -0
- package/dist/src/components/editor/ui/comment-node-static.mjs +14 -0
- package/dist/src/components/editor/ui/comment-node.mjs +33 -0
- package/dist/src/components/editor/ui/comment-toolbar-button.mjs +23 -0
- package/dist/src/components/editor/ui/comment.mjs +422 -0
- package/dist/src/components/editor/ui/cursor-overlay.mjs +36 -0
- package/dist/src/components/editor/ui/date-node-static.mjs +32 -0
- package/dist/src/components/editor/ui/date-node.mjs +60 -0
- package/dist/src/components/editor/ui/editor-static.mjs +31 -0
- package/dist/src/components/editor/ui/editor.mjs +60 -0
- package/dist/src/components/editor/ui/emoji-node.mjs +46 -0
- package/dist/src/components/editor/ui/emoji-toolbar-button.mjs +415 -0
- package/dist/src/components/editor/ui/equation-node-static.mjs +65 -0
- package/dist/src/components/editor/ui/equation-node.mjs +159 -0
- package/dist/src/components/editor/ui/equation-toolbar-button.mjs +23 -0
- package/dist/src/components/editor/ui/fixed-toolbar-buttons.mjs +109 -0
- package/dist/src/components/editor/ui/fixed-toolbar.mjs +16 -0
- package/dist/src/components/editor/ui/floating-toolbar-buttons.mjs +54 -0
- package/dist/src/components/editor/ui/floating-toolbar.mjs +51 -0
- package/dist/src/components/editor/ui/font-color-toolbar-button.mjs +637 -0
- package/dist/src/components/editor/ui/font-size-toolbar-button.mjs +83 -0
- package/dist/src/components/editor/ui/ghost-text.mjs +22 -0
- package/dist/src/components/editor/ui/heading-node-static.mjs +60 -0
- package/dist/src/components/editor/ui/heading-node.mjs +62 -0
- package/dist/src/components/editor/ui/highlight-node-static.mjs +15 -0
- package/dist/src/components/editor/ui/highlight-node.mjs +17 -0
- package/dist/src/components/editor/ui/history-toolbar-button.mjs +35 -0
- package/dist/src/components/editor/ui/hr-node-static.mjs +18 -0
- package/dist/src/components/editor/ui/hr-node.mjs +23 -0
- package/dist/src/components/editor/ui/indent-toolbar-button.mjs +29 -0
- package/dist/src/components/editor/ui/inline-combobox.mjs +148 -0
- package/dist/src/components/editor/ui/insert-toolbar-button.mjs +199 -0
- package/dist/src/components/editor/ui/kbd-node-static.mjs +15 -0
- package/dist/src/components/editor/ui/kbd-node.mjs +17 -0
- package/dist/src/components/editor/ui/line-height-toolbar-button.mjs +56 -0
- package/dist/src/components/editor/ui/link-node-static.mjs +20 -0
- package/dist/src/components/editor/ui/link-node.mjs +28 -0
- package/dist/src/components/editor/ui/link-toolbar-button.mjs +21 -0
- package/dist/src/components/editor/ui/link-toolbar.mjs +141 -0
- package/dist/src/components/editor/ui/list-toolbar-button.mjs +131 -0
- package/dist/src/components/editor/ui/mark-toolbar-button.mjs +20 -0
- package/dist/src/components/editor/ui/media-image-node-static.mjs +32 -0
- package/dist/src/components/editor/ui/media-image-node.mjs +64 -0
- package/dist/src/components/editor/ui/media-placeholder-node.mjs +184 -0
- package/dist/src/components/editor/ui/media-preview-dialog.mjs +113 -0
- package/dist/src/components/editor/ui/media-toolbar-button.mjs +156 -0
- package/dist/src/components/editor/ui/media-toolbar.mjs +80 -0
- package/dist/src/components/editor/ui/media-upload-toast.mjs +39 -0
- package/dist/src/components/editor/ui/media-video-node-static.mjs +27 -0
- package/dist/src/components/editor/ui/mode-toolbar-button.mjs +112 -0
- package/dist/src/components/editor/ui/paragraph-node-static.mjs +15 -0
- package/dist/src/components/editor/ui/paragraph-node.mjs +17 -0
- package/dist/src/components/editor/ui/resize-handle.mjs +43 -0
- package/dist/src/components/editor/ui/slash-node.mjs +228 -0
- package/dist/src/components/editor/ui/suggestion-node-static.mjs +24 -0
- package/dist/src/components/editor/ui/suggestion-node.mjs +111 -0
- package/dist/src/components/editor/ui/suggestion-toolbar-button.mjs +24 -0
- package/dist/src/components/editor/ui/table-icons.mjs +1310 -0
- package/dist/src/components/editor/ui/table-node-static.mjs +68 -0
- package/dist/src/components/editor/ui/table-node.mjs +375 -0
- package/dist/src/components/editor/ui/table-toolbar-button.mjs +190 -0
- package/dist/src/components/editor/ui/turn-into-toolbar-button.mjs +168 -0
- package/dist/src/components/editor/use-chat.mjs +80 -0
- package/dist/src/components/json-schema-editor/client.mjs +46 -0
- package/dist/src/components/json-schema-editor/components/inputs.mjs +438 -0
- package/dist/src/components/json-schema-editor/get-default-values.mjs +23 -0
- package/dist/src/components/json-schema-editor/schema.mjs +131 -0
- package/dist/src/components/json-schema-editor/utils/merge-schema.mjs +134 -0
- package/dist/src/components/json-schema-editor/utils/schema-to-string.mjs +53 -0
- package/dist/src/components/ui/alert-dialog.mjs +90 -0
- package/dist/src/components/ui/avatar.mjs +32 -0
- package/dist/src/components/ui/button.mjs +48 -0
- package/dist/src/components/ui/calendar.mjs +108 -0
- package/dist/src/components/ui/checkbox.mjs +23 -0
- package/dist/src/components/ui/combobox.mjs +53 -0
- package/dist/src/components/ui/command.mjs +42 -0
- package/dist/src/components/ui/context-menu.mjs +67 -0
- package/dist/src/components/ui/dialog.mjs +9 -0
- package/dist/src/components/ui/dropdown-menu.mjs +122 -0
- package/dist/src/components/ui/input-group.mjs +31 -0
- package/dist/src/components/ui/input.mjs +15 -0
- package/dist/src/components/ui/label.mjs +19 -0
- package/dist/src/components/ui/popover.mjs +37 -0
- package/dist/src/components/ui/select.mjs +80 -0
- package/dist/src/components/ui/separator.mjs +19 -0
- package/dist/src/components/ui/spinner.mjs +16 -0
- package/dist/src/components/ui/tabs.mjs +39 -0
- package/dist/src/components/ui/textarea.mjs +14 -0
- package/dist/src/components/ui/toolbar.mjs +183 -0
- package/dist/src/components/ui/tooltip.mjs +38 -0
- package/dist/src/hooks/editor/use-is-creator.mjs +19 -0
- package/dist/src/hooks/use-upload-file.mjs +73 -0
- package/dist/src/lib/config.mjs +38 -0
- package/dist/src/lib/data/store.d.mts +15 -0
- package/dist/src/lib/lowlight.mjs +7 -0
- package/dist/src/lib/utils/deep-equal.mjs +18 -0
- package/dist/src/lib/utils/remove-undefined.mjs +18 -0
- package/dist/src/lib/utils.mjs +10 -0
- package/dist/types.d.mts +50 -0
- package/next.config.ts +23 -0
- package/package.json +131 -0
- package/postcss.config.mjs +7 -0
- package/src/app/(dashboard)/collection/[name]/[...slug]/page.client.tsx +26 -0
- package/src/app/(dashboard)/collection/[name]/[...slug]/page.tsx +17 -0
- package/src/app/(dashboard)/collection/[name]/page.client.tsx +82 -0
- package/src/app/(dashboard)/collection/[name]/page.tsx +11 -0
- package/src/app/(dashboard)/layout.tsx +34 -0
- package/src/app/(dashboard)/page.tsx +38 -0
- package/src/app/api/ai/command/prompts.ts +313 -0
- package/src/app/api/ai/command/route.ts +203 -0
- package/src/app/api/ai/command/utils.ts +242 -0
- package/src/app/api/ai/copilot/route.ts +33 -0
- package/src/app/api/uploadthing/route.ts +5 -0
- package/src/app/codeblock/LICENSE +21 -0
- package/src/app/codeblock/styles.css +289 -0
- package/src/app/favicon.ico +0 -0
- package/src/app/globals.css +223 -0
- package/src/app/layout.client.tsx +15 -0
- package/src/app/layout.tsx +30 -0
- package/src/components/app-sidebar.tsx +162 -0
- package/src/components/code-editor/mdx.lazy.tsx +18 -0
- package/src/components/code-editor/mdx.tsx +48 -0
- package/src/components/code-editor/yaml.lazy.tsx +20 -0
- package/src/components/code-editor/yaml.tsx +71 -0
- package/src/components/collection/actions.tsx +41 -0
- package/src/components/collection/client.tsx +63 -0
- package/src/components/collection/context.tsx +24 -0
- package/src/components/collection/document/actions.tsx +83 -0
- package/src/components/editor/editor-base-kit.tsx +37 -0
- package/src/components/editor/editor-kit.tsx +87 -0
- package/src/components/editor/md.tsx +60 -0
- package/src/components/editor/plugins/ai-kit.tsx +102 -0
- package/src/components/editor/plugins/align-base-kit.tsx +16 -0
- package/src/components/editor/plugins/align-kit.tsx +18 -0
- package/src/components/editor/plugins/autoformat-kit.tsx +236 -0
- package/src/components/editor/plugins/basic-blocks-base-kit.tsx +34 -0
- package/src/components/editor/plugins/basic-blocks-kit.tsx +87 -0
- package/src/components/editor/plugins/basic-marks-base-kit.tsx +26 -0
- package/src/components/editor/plugins/basic-marks-kit.tsx +40 -0
- package/src/components/editor/plugins/basic-nodes-kit.tsx +6 -0
- package/src/components/editor/plugins/block-menu-kit.tsx +14 -0
- package/src/components/editor/plugins/block-placeholder-kit.tsx +17 -0
- package/src/components/editor/plugins/block-selection-kit.tsx +54 -0
- package/src/components/editor/plugins/callout-base-kit.tsx +5 -0
- package/src/components/editor/plugins/callout-kit.tsx +7 -0
- package/src/components/editor/plugins/code-block-base-kit.tsx +16 -0
- package/src/components/editor/plugins/code-block-kit.tsx +19 -0
- package/src/components/editor/plugins/column-base-kit.tsx +11 -0
- package/src/components/editor/plugins/column-kit.tsx +10 -0
- package/src/components/editor/plugins/comment-base-kit.tsx +5 -0
- package/src/components/editor/plugins/comment-kit.tsx +92 -0
- package/src/components/editor/plugins/copilot-kit.tsx +70 -0
- package/src/components/editor/plugins/cursor-overlay-kit.tsx +13 -0
- package/src/components/editor/plugins/date-base-kit.tsx +5 -0
- package/src/components/editor/plugins/date-kit.tsx +7 -0
- package/src/components/editor/plugins/discussion-kit.tsx +142 -0
- package/src/components/editor/plugins/dnd-kit.tsx +25 -0
- package/src/components/editor/plugins/emoji-kit.tsx +13 -0
- package/src/components/editor/plugins/exit-break-kit.tsx +12 -0
- package/src/components/editor/plugins/fixed-toolbar-kit.tsx +19 -0
- package/src/components/editor/plugins/floating-toolbar-kit.tsx +19 -0
- package/src/components/editor/plugins/font-base-kit.tsx +20 -0
- package/src/components/editor/plugins/font-kit.tsx +29 -0
- package/src/components/editor/plugins/indent-base-kit.tsx +13 -0
- package/src/components/editor/plugins/indent-kit.tsx +22 -0
- package/src/components/editor/plugins/line-height-base-kit.tsx +14 -0
- package/src/components/editor/plugins/line-height-kit.tsx +16 -0
- package/src/components/editor/plugins/link-base-kit.tsx +5 -0
- package/src/components/editor/plugins/link-kit.tsx +15 -0
- package/src/components/editor/plugins/list-base-kit.tsx +17 -0
- package/src/components/editor/plugins/list-kit.tsx +26 -0
- package/src/components/editor/plugins/markdown-kit.tsx +13 -0
- package/src/components/editor/plugins/math-base-kit.tsx +11 -0
- package/src/components/editor/plugins/math-kit.tsx +10 -0
- package/src/components/editor/plugins/media-base-kit.tsx +25 -0
- package/src/components/editor/plugins/media-kit.tsx +28 -0
- package/src/components/editor/plugins/slash-kit.tsx +18 -0
- package/src/components/editor/plugins/suggestion-base-kit.tsx +5 -0
- package/src/components/editor/plugins/suggestion-kit.tsx +83 -0
- package/src/components/editor/plugins/table-base-kit.tsx +20 -0
- package/src/components/editor/plugins/table-kit.tsx +22 -0
- package/src/components/editor/settings-dialog.tsx +418 -0
- package/src/components/editor/transforms.ts +193 -0
- package/src/components/editor/types.ts +149 -0
- package/src/components/editor/ui/ai-chat-editor.tsx +20 -0
- package/src/components/editor/ui/ai-menu.tsx +663 -0
- package/src/components/editor/ui/ai-node.tsx +40 -0
- package/src/components/editor/ui/ai-toolbar-button.tsx +23 -0
- package/src/components/editor/ui/align-toolbar-button.tsx +78 -0
- package/src/components/editor/ui/block-context-menu.tsx +154 -0
- package/src/components/editor/ui/block-discussion.tsx +318 -0
- package/src/components/editor/ui/block-draggable.tsx +464 -0
- package/src/components/editor/ui/block-list-static.tsx +75 -0
- package/src/components/editor/ui/block-list.tsx +72 -0
- package/src/components/editor/ui/block-selection.tsx +37 -0
- package/src/components/editor/ui/block-suggestion.tsx +438 -0
- package/src/components/editor/ui/blockquote-node-static.tsx +5 -0
- package/src/components/editor/ui/blockquote-node.tsx +7 -0
- package/src/components/editor/ui/callout-node-static.tsx +30 -0
- package/src/components/editor/ui/callout-node.tsx +64 -0
- package/src/components/editor/ui/caption.tsx +55 -0
- package/src/components/editor/ui/code-block-node-static.tsx +33 -0
- package/src/components/editor/ui/code-block-node.tsx +161 -0
- package/src/components/editor/ui/code-node-static.tsx +15 -0
- package/src/components/editor/ui/code-node.tsx +17 -0
- package/src/components/editor/ui/column-node-static.tsx +27 -0
- package/src/components/editor/ui/column-node.tsx +285 -0
- package/src/components/editor/ui/comment-node-static.tsx +12 -0
- package/src/components/editor/ui/comment-node.tsx +43 -0
- package/src/components/editor/ui/comment-toolbar-button.tsx +24 -0
- package/src/components/editor/ui/comment.tsx +577 -0
- package/src/components/editor/ui/cursor-overlay.tsx +66 -0
- package/src/components/editor/ui/date-node-static.tsx +45 -0
- package/src/components/editor/ui/date-node.tsx +86 -0
- package/src/components/editor/ui/editor-static.tsx +47 -0
- package/src/components/editor/ui/editor.tsx +120 -0
- package/src/components/editor/ui/emoji-node.tsx +65 -0
- package/src/components/editor/ui/emoji-toolbar-button.tsx +582 -0
- package/src/components/editor/ui/equation-node-static.tsx +94 -0
- package/src/components/editor/ui/equation-node.tsx +218 -0
- package/src/components/editor/ui/equation-toolbar-button.tsx +24 -0
- package/src/components/editor/ui/fixed-toolbar-buttons.tsx +135 -0
- package/src/components/editor/ui/fixed-toolbar.tsx +17 -0
- package/src/components/editor/ui/floating-toolbar-buttons.tsx +72 -0
- package/src/components/editor/ui/floating-toolbar.tsx +76 -0
- package/src/components/editor/ui/font-color-toolbar-button.tsx +804 -0
- package/src/components/editor/ui/font-size-toolbar-button.tsx +102 -0
- package/src/components/editor/ui/ghost-text.tsx +27 -0
- package/src/components/editor/ui/heading-node-static.tsx +54 -0
- package/src/components/editor/ui/heading-node.tsx +54 -0
- package/src/components/editor/ui/highlight-node-static.tsx +11 -0
- package/src/components/editor/ui/highlight-node.tsx +13 -0
- package/src/components/editor/ui/history-toolbar-button.tsx +41 -0
- package/src/components/editor/ui/hr-node-static.tsx +16 -0
- package/src/components/editor/ui/hr-node.tsx +28 -0
- package/src/components/editor/ui/indent-toolbar-button.tsx +27 -0
- package/src/components/editor/ui/inline-combobox.tsx +251 -0
- package/src/components/editor/ui/insert-toolbar-button.tsx +242 -0
- package/src/components/editor/ui/kbd-node-static.tsx +15 -0
- package/src/components/editor/ui/kbd-node.tsx +17 -0
- package/src/components/editor/ui/line-height-toolbar-button.tsx +66 -0
- package/src/components/editor/ui/link-node-static.tsx +21 -0
- package/src/components/editor/ui/link-node.tsx +37 -0
- package/src/components/editor/ui/link-toolbar-button.tsx +18 -0
- package/src/components/editor/ui/link-toolbar.tsx +196 -0
- package/src/components/editor/ui/list-toolbar-button.tsx +195 -0
- package/src/components/editor/ui/mark-toolbar-button.tsx +20 -0
- package/src/components/editor/ui/media-image-node-static.tsx +33 -0
- package/src/components/editor/ui/media-image-node.tsx +75 -0
- package/src/components/editor/ui/media-placeholder-node.tsx +235 -0
- package/src/components/editor/ui/media-preview-dialog.tsx +145 -0
- package/src/components/editor/ui/media-toolbar-button.tsx +202 -0
- package/src/components/editor/ui/media-toolbar.tsx +100 -0
- package/src/components/editor/ui/media-upload-toast.tsx +59 -0
- package/src/components/editor/ui/media-video-node-static.tsx +23 -0
- package/src/components/editor/ui/mode-toolbar-button.tsx +121 -0
- package/src/components/editor/ui/paragraph-node-static.tsx +13 -0
- package/src/components/editor/ui/paragraph-node.tsx +15 -0
- package/src/components/editor/ui/resize-handle.tsx +79 -0
- package/src/components/editor/ui/slash-node.tsx +274 -0
- package/src/components/editor/ui/suggestion-node-static.tsx +30 -0
- package/src/components/editor/ui/suggestion-node.tsx +157 -0
- package/src/components/editor/ui/suggestion-toolbar-button.tsx +25 -0
- package/src/components/editor/ui/table-icons.tsx +685 -0
- package/src/components/editor/ui/table-node-static.tsx +86 -0
- package/src/components/editor/ui/table-node.tsx +569 -0
- package/src/components/editor/ui/table-toolbar-button.tsx +260 -0
- package/src/components/editor/ui/turn-into-toolbar-button.tsx +176 -0
- package/src/components/editor/use-chat.ts +120 -0
- package/src/components/icons/logo.tsx +37 -0
- package/src/components/json-schema-editor/client.tsx +55 -0
- package/src/components/json-schema-editor/components/inputs.tsx +612 -0
- package/src/components/json-schema-editor/get-default-values.ts +29 -0
- package/src/components/json-schema-editor/schema.tsx +206 -0
- package/src/components/json-schema-editor/utils/merge-schema.ts +167 -0
- package/src/components/json-schema-editor/utils/schema-to-string.ts +87 -0
- package/src/components/nav-user.tsx +102 -0
- package/src/components/site-header.tsx +13 -0
- package/src/components/ui/alert-dialog.tsx +182 -0
- package/src/components/ui/avatar.tsx +96 -0
- package/src/components/ui/badge.tsx +46 -0
- package/src/components/ui/button.tsx +65 -0
- package/src/components/ui/calendar.tsx +186 -0
- package/src/components/ui/checkbox.tsx +29 -0
- package/src/components/ui/combobox.tsx +267 -0
- package/src/components/ui/command.tsx +180 -0
- package/src/components/ui/context-menu.tsx +161 -0
- package/src/components/ui/dialog.tsx +142 -0
- package/src/components/ui/drawer.tsx +120 -0
- package/src/components/ui/dropdown-menu.tsx +239 -0
- package/src/components/ui/field.tsx +224 -0
- package/src/components/ui/input-group.tsx +144 -0
- package/src/components/ui/input.tsx +19 -0
- package/src/components/ui/label.tsx +18 -0
- package/src/components/ui/popover.tsx +76 -0
- package/src/components/ui/select.tsx +182 -0
- package/src/components/ui/separator.tsx +28 -0
- package/src/components/ui/sheet.tsx +130 -0
- package/src/components/ui/sidebar.tsx +608 -0
- package/src/components/ui/sonner.tsx +45 -0
- package/src/components/ui/spinner.tsx +15 -0
- package/src/components/ui/table.tsx +89 -0
- package/src/components/ui/tabs.tsx +60 -0
- package/src/components/ui/textarea.tsx +18 -0
- package/src/components/ui/toggle-group.tsx +86 -0
- package/src/components/ui/toggle.tsx +45 -0
- package/src/components/ui/toolbar.tsx +365 -0
- package/src/components/ui/tooltip.tsx +57 -0
- package/src/hooks/editor/use-is-creator.ts +21 -0
- package/src/hooks/use-mobile.ts +19 -0
- package/src/hooks/use-mounted.ts +11 -0
- package/src/hooks/use-upload-file.ts +121 -0
- package/src/lib/ai/markdown-joiner-transform.ts +235 -0
- package/src/lib/config.ts +60 -0
- package/src/lib/data/actions.ts +51 -0
- package/src/lib/data/boundary.client.tsx +22 -0
- package/src/lib/data/boundary.tsx +22 -0
- package/src/lib/data/query.ts +9 -0
- package/src/lib/data/store.ts +52 -0
- package/src/lib/lowlight.ts +3 -0
- package/src/lib/uploadthing.ts +19 -0
- package/src/lib/utils/deep-equal.ts +37 -0
- package/src/lib/utils/remove-undefined.ts +21 -0
- package/src/lib/utils/urls.ts +6 -0
- package/src/lib/utils.ts +6 -0
- package/tsconfig.build.json +24 -0
- 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,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,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,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,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];
|