@seafile/comment-editor 0.0.1-alpha.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/README.md +51 -0
- package/dist/assets/css/plugin-editor.css +7 -0
- package/dist/assets/css/simple-editor.css +9 -0
- package/dist/assets/css/simple-viewer.css +6 -0
- package/dist/assets/images/content-replaced.png +0 -0
- package/dist/assets/images/revision-avatar.png +0 -0
- package/dist/assets/images/sdoc-freezed.png +0 -0
- package/dist/basic-sdk/android/constants.js +10 -0
- package/dist/basic-sdk/android/js-bridge.js +74 -0
- package/dist/basic-sdk/android/outline-module.js +29 -0
- package/dist/basic-sdk/api/sdoc-server-api.js +189 -0
- package/dist/basic-sdk/api/seafile-api.js +220 -0
- package/dist/basic-sdk/assets/css/default.css +27 -0
- package/dist/basic-sdk/assets/css/diff-viewer.css +5 -0
- package/dist/basic-sdk/assets/css/dropdown-menu.css +138 -0
- package/dist/basic-sdk/assets/css/layout.css +160 -0
- package/dist/basic-sdk/assets/css/sdoc-comment-editor-plugin.css +19 -0
- package/dist/basic-sdk/assets/css/sdoc-editor-article.css +29 -0
- package/dist/basic-sdk/assets/css/sdoc-editor-plugins.css +320 -0
- package/dist/basic-sdk/assets/css/sdoc-viewer.css +14 -0
- package/dist/basic-sdk/assets/css/sdoc-wiki-viewer.css +28 -0
- package/dist/basic-sdk/assets/images/black-border.png +0 -0
- package/dist/basic-sdk/assets/images/grey-border.png +0 -0
- package/dist/basic-sdk/assets/images/image-placeholder.png +0 -0
- package/dist/basic-sdk/assets/images/no-border.png +0 -0
- package/dist/basic-sdk/assets/images/sdoc-ask-ai.png +0 -0
- package/dist/basic-sdk/comment/comment-decorate.js +33 -0
- package/dist/basic-sdk/comment/components/comment-all-participants/index.css +83 -0
- package/dist/basic-sdk/comment/components/comment-all-participants/index.js +67 -0
- package/dist/basic-sdk/comment/components/comment-all-participants/participant-avatar.js +43 -0
- package/dist/basic-sdk/comment/components/comment-context-menu/index.css +16 -0
- package/dist/basic-sdk/comment/components/comment-context-menu/index.js +43 -0
- package/dist/basic-sdk/comment/components/comment-context-menu/menu-item.js +57 -0
- package/dist/basic-sdk/comment/components/comment-delete-popover.js +80 -0
- package/dist/basic-sdk/comment/components/comment-editor.js +165 -0
- package/dist/basic-sdk/comment/components/comment-item-collapse-wrapper.js +160 -0
- package/dist/basic-sdk/comment/components/comment-item-content.js +156 -0
- package/dist/basic-sdk/comment/components/comment-item-reply.js +124 -0
- package/dist/basic-sdk/comment/components/comment-item-resolved-reply.js +38 -0
- package/dist/basic-sdk/comment/components/comment-item-wrapper.js +368 -0
- package/dist/basic-sdk/comment/components/comment-list.css +422 -0
- package/dist/basic-sdk/comment/components/comment-list.js +216 -0
- package/dist/basic-sdk/comment/components/comment-operation/index.css +26 -0
- package/dist/basic-sdk/comment/components/comment-operation/index.js +31 -0
- package/dist/basic-sdk/comment/components/comment-participants-editor/index.css +132 -0
- package/dist/basic-sdk/comment/components/comment-participants-editor/index.js +69 -0
- package/dist/basic-sdk/comment/components/comment-participants-editor/searched-collaborators.js +62 -0
- package/dist/basic-sdk/comment/components/comment-participants-editor/selected-participants.js +48 -0
- package/dist/basic-sdk/comment/components/editor-comment.js +183 -0
- package/dist/basic-sdk/comment/components/elements-comment-count/element-comment-count.js +64 -0
- package/dist/basic-sdk/comment/components/elements-comment-count/index.css +29 -0
- package/dist/basic-sdk/comment/components/elements-comment-count/index.js +49 -0
- package/dist/basic-sdk/comment/components/global-comment/global-comment-body-header.js +87 -0
- package/dist/basic-sdk/comment/components/global-comment/global-comment-editor.js +36 -0
- package/dist/basic-sdk/comment/components/global-comment/global-comment-header.js +82 -0
- package/dist/basic-sdk/comment/components/global-comment/index.css +326 -0
- package/dist/basic-sdk/comment/components/global-comment/index.js +212 -0
- package/dist/basic-sdk/comment/components/index.js +21 -0
- package/dist/basic-sdk/comment/components/style.css +40 -0
- package/dist/basic-sdk/comment/constants/index.js +26 -0
- package/dist/basic-sdk/comment/helper.js +184 -0
- package/dist/basic-sdk/comment/hooks/comment-hooks/use-comment-context.js +20 -0
- package/dist/basic-sdk/comment/hooks/comment-hooks/use-comment-list.js +45 -0
- package/dist/basic-sdk/comment/hooks/comment-hooks/use-comment-mount.js +58 -0
- package/dist/basic-sdk/comment/hooks/notification-hooks/index.js +25 -0
- package/dist/basic-sdk/comment/hooks/notification-hooks/use-notification-context.js +20 -0
- package/dist/basic-sdk/comment/hooks/notification-hooks/use-notification-mount.js +74 -0
- package/dist/basic-sdk/comment/hooks/use-participants.js +26 -0
- package/dist/basic-sdk/comment/index.js +67 -0
- package/dist/basic-sdk/comment/provider/comment-context-provider.js +37 -0
- package/dist/basic-sdk/comment/provider/index.js +23 -0
- package/dist/basic-sdk/comment/provider/notification-context-provider.js +31 -0
- package/dist/basic-sdk/comment/provider/participants-content-provider.js +96 -0
- package/dist/basic-sdk/comment/reducer/comment-reducer.js +353 -0
- package/dist/basic-sdk/comment/reducer/notification-reducer.js +89 -0
- package/dist/basic-sdk/comment/utils/get-event-transfer.js +77 -0
- package/dist/basic-sdk/comment/utils/index.js +281 -0
- package/dist/basic-sdk/comment/utils/notification-utils.js +62 -0
- package/dist/basic-sdk/components/file-loading/index.css +57 -0
- package/dist/basic-sdk/components/file-loading/index.js +15 -0
- package/dist/basic-sdk/components/loading/index.js +19 -0
- package/dist/basic-sdk/components/loading/style.css +49 -0
- package/dist/basic-sdk/components/toast/alert.js +51 -0
- package/dist/basic-sdk/components/toast/index.css +118 -0
- package/dist/basic-sdk/components/toast/index.js +10 -0
- package/dist/basic-sdk/components/toast/toast.js +104 -0
- package/dist/basic-sdk/components/toast/toastManager.js +110 -0
- package/dist/basic-sdk/components/toast/toaster.js +77 -0
- package/dist/basic-sdk/components/tooltip/index.css +29 -0
- package/dist/basic-sdk/components/tooltip/index.js +39 -0
- package/dist/basic-sdk/constants/index.js +119 -0
- package/dist/basic-sdk/constants/key-codes.js +109 -0
- package/dist/basic-sdk/constants/plugin.js +10 -0
- package/dist/basic-sdk/constants/z-index.js +8 -0
- package/dist/basic-sdk/context.js +275 -0
- package/dist/basic-sdk/cursor/helper.js +57 -0
- package/dist/basic-sdk/cursor/use-cursors.js +27 -0
- package/dist/basic-sdk/decorates/index.js +28 -0
- package/dist/basic-sdk/editor/comment-article.js +104 -0
- package/dist/basic-sdk/editor/sdoc-comment-editor.js +128 -0
- package/dist/basic-sdk/editor/sdoc-editor.js +50 -0
- package/dist/basic-sdk/extension/commons/Inline-bug-fix-wrapper/index.js +17 -0
- package/dist/basic-sdk/extension/commons/color-menu/color-item.js +31 -0
- package/dist/basic-sdk/extension/commons/color-menu/index.css +161 -0
- package/dist/basic-sdk/extension/commons/color-menu/index.js +208 -0
- package/dist/basic-sdk/extension/commons/dropdown-menu-item/index.css +12 -0
- package/dist/basic-sdk/extension/commons/dropdown-menu-item/index.js +57 -0
- package/dist/basic-sdk/extension/commons/element-popover/index.js +47 -0
- package/dist/basic-sdk/extension/commons/file-insert-dialog/index.js +282 -0
- package/dist/basic-sdk/extension/commons/file-insert-dialog/style.css +91 -0
- package/dist/basic-sdk/extension/commons/index.js +47 -0
- package/dist/basic-sdk/extension/commons/insert-element-dialog/index.js +251 -0
- package/dist/basic-sdk/extension/commons/menu/index.js +21 -0
- package/dist/basic-sdk/extension/commons/menu/menu-group.js +17 -0
- package/dist/basic-sdk/extension/commons/menu/menu-item.js +60 -0
- package/dist/basic-sdk/extension/commons/menu/menu.css +82 -0
- package/dist/basic-sdk/extension/commons/menu-shortcut-indicator/index.js +22 -0
- package/dist/basic-sdk/extension/commons/menu-shortcut-indicator/style.css +18 -0
- package/dist/basic-sdk/extension/commons/more-dropdown/index.js +44 -0
- package/dist/basic-sdk/extension/commons/search-list/index.css +28 -0
- package/dist/basic-sdk/extension/commons/search-list/index.js +149 -0
- package/dist/basic-sdk/extension/commons/select/_option.js +39 -0
- package/dist/basic-sdk/extension/commons/select/field-setting.js +109 -0
- package/dist/basic-sdk/extension/commons/select/index.js +142 -0
- package/dist/basic-sdk/extension/commons/select/menu/index.js +11 -0
- package/dist/basic-sdk/extension/commons/select/menu/item.js +39 -0
- package/dist/basic-sdk/extension/commons/select/menu/menu.js +34 -0
- package/dist/basic-sdk/extension/commons/select/menu/style.css +43 -0
- package/dist/basic-sdk/extension/commons/select/style.css +149 -0
- package/dist/basic-sdk/extension/commons/select-file-dialog/helpers.js +54 -0
- package/dist/basic-sdk/extension/commons/select-file-dialog/index.css +135 -0
- package/dist/basic-sdk/extension/commons/select-file-dialog/index.js +207 -0
- package/dist/basic-sdk/extension/commons/select-file-dialog/local-files/index.css +114 -0
- package/dist/basic-sdk/extension/commons/select-file-dialog/local-files/index.js +191 -0
- package/dist/basic-sdk/extension/commons/wiki-file-insert-dialog/index.js +274 -0
- package/dist/basic-sdk/extension/commons/wiki-file-insert-dialog/style.css +116 -0
- package/dist/basic-sdk/extension/constants/color.js +282 -0
- package/dist/basic-sdk/extension/constants/diff-view.js +20 -0
- package/dist/basic-sdk/extension/constants/element-type.js +56 -0
- package/dist/basic-sdk/extension/constants/font.js +537 -0
- package/dist/basic-sdk/extension/constants/index.js +562 -0
- package/dist/basic-sdk/extension/constants/keyboard.js +45 -0
- package/dist/basic-sdk/extension/constants/menus-config.js +472 -0
- package/dist/basic-sdk/extension/core/index.js +38 -0
- package/dist/basic-sdk/extension/core/queries/index.js +613 -0
- package/dist/basic-sdk/extension/core/transforms/delete-merge.js +174 -0
- package/dist/basic-sdk/extension/core/transforms/focus-editor.js +18 -0
- package/dist/basic-sdk/extension/core/transforms/index.js +71 -0
- package/dist/basic-sdk/extension/core/transforms/move-children.js +35 -0
- package/dist/basic-sdk/extension/core/transforms/rebase.js +75 -0
- package/dist/basic-sdk/extension/core/transforms/remove-node-children.js +19 -0
- package/dist/basic-sdk/extension/core/transforms/replace-node.js +43 -0
- package/dist/basic-sdk/extension/core/transforms/update-parent-node.js +34 -0
- package/dist/basic-sdk/extension/core/utils/index.js +50 -0
- package/dist/basic-sdk/extension/index.js +50 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-icon/index.js +26 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-icon/style.css +22 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-menu/ai-context-menu.js +41 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-menu/ai-dropdown-menu.js +35 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-menu/index.js +20 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-menu/menu-item.js +58 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-menu/style.css +12 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-module/adjust-sub-menu.js +44 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-module/helpers.js +72 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-module/index.js +600 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-module/lang-sub-menu.js +55 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-module/style.css +148 -0
- package/dist/basic-sdk/extension/plugins/ai/ai-module/tip-dialog.js +41 -0
- package/dist/basic-sdk/extension/plugins/ai/constants/index.js +137 -0
- package/dist/basic-sdk/extension/plugins/ai/index.js +1 -0
- package/dist/basic-sdk/extension/plugins/blockquote/helpers.js +153 -0
- package/dist/basic-sdk/extension/plugins/blockquote/index.js +21 -0
- package/dist/basic-sdk/extension/plugins/blockquote/menu/index.js +55 -0
- package/dist/basic-sdk/extension/plugins/blockquote/model.js +16 -0
- package/dist/basic-sdk/extension/plugins/blockquote/plugin.js +144 -0
- package/dist/basic-sdk/extension/plugins/blockquote/render-elem.js +24 -0
- package/dist/basic-sdk/extension/plugins/callout/constant.js +58 -0
- package/dist/basic-sdk/extension/plugins/callout/helper.js +281 -0
- package/dist/basic-sdk/extension/plugins/callout/index.js +19 -0
- package/dist/basic-sdk/extension/plugins/callout/menu/index.css +16 -0
- package/dist/basic-sdk/extension/plugins/callout/menu/index.js +52 -0
- package/dist/basic-sdk/extension/plugins/callout/plugin.js +109 -0
- package/dist/basic-sdk/extension/plugins/callout/render-elem/callout-color-selector/index.js +65 -0
- package/dist/basic-sdk/extension/plugins/callout/render-elem/callout-color-selector/style.css +39 -0
- package/dist/basic-sdk/extension/plugins/callout/render-elem/callout-hover-menu/index.js +90 -0
- package/dist/basic-sdk/extension/plugins/callout/render-elem/callout-hover-menu/style.css +45 -0
- package/dist/basic-sdk/extension/plugins/callout/render-elem/callout-icon/index.js +45 -0
- package/dist/basic-sdk/extension/plugins/callout/render-elem/callout-icon/style.css +33 -0
- package/dist/basic-sdk/extension/plugins/callout/render-elem/index.css +52 -0
- package/dist/basic-sdk/extension/plugins/callout/render-elem/index.js +134 -0
- package/dist/basic-sdk/extension/plugins/check-list/helpers.js +121 -0
- package/dist/basic-sdk/extension/plugins/check-list/index.js +16 -0
- package/dist/basic-sdk/extension/plugins/check-list/menu/index.js +58 -0
- package/dist/basic-sdk/extension/plugins/check-list/model.js +17 -0
- package/dist/basic-sdk/extension/plugins/check-list/plugin.js +110 -0
- package/dist/basic-sdk/extension/plugins/check-list/render-elem.js +71 -0
- package/dist/basic-sdk/extension/plugins/clear-format/helpers.js +54 -0
- package/dist/basic-sdk/extension/plugins/clear-format/menu/index.js +35 -0
- package/dist/basic-sdk/extension/plugins/code-block/helpers.js +206 -0
- package/dist/basic-sdk/extension/plugins/code-block/hover-menu/index.css +148 -0
- package/dist/basic-sdk/extension/plugins/code-block/hover-menu/index.js +257 -0
- package/dist/basic-sdk/extension/plugins/code-block/index.js +19 -0
- package/dist/basic-sdk/extension/plugins/code-block/menu/index.js +35 -0
- package/dist/basic-sdk/extension/plugins/code-block/model.js +16 -0
- package/dist/basic-sdk/extension/plugins/code-block/plugin.js +229 -0
- package/dist/basic-sdk/extension/plugins/code-block/prismjs.js +189 -0
- package/dist/basic-sdk/extension/plugins/code-block/render-elem.js +182 -0
- package/dist/basic-sdk/extension/plugins/file-link/constants/index.js +26 -0
- package/dist/basic-sdk/extension/plugins/file-link/helpers.js +125 -0
- package/dist/basic-sdk/extension/plugins/file-link/hover-menu/index.css +89 -0
- package/dist/basic-sdk/extension/plugins/file-link/hover-menu/index.js +120 -0
- package/dist/basic-sdk/extension/plugins/file-link/index.js +18 -0
- package/dist/basic-sdk/extension/plugins/file-link/menu/index.js +38 -0
- package/dist/basic-sdk/extension/plugins/file-link/plugin.js +72 -0
- package/dist/basic-sdk/extension/plugins/file-link/render-elem.css +56 -0
- package/dist/basic-sdk/extension/plugins/file-link/render-elem.js +164 -0
- package/dist/basic-sdk/extension/plugins/font/helpers.js +173 -0
- package/dist/basic-sdk/extension/plugins/font/index.js +13 -0
- package/dist/basic-sdk/extension/plugins/font/menu/font-family/font-item.js +39 -0
- package/dist/basic-sdk/extension/plugins/font/menu/font-family/index.css +40 -0
- package/dist/basic-sdk/extension/plugins/font/menu/font-family/index.js +145 -0
- package/dist/basic-sdk/extension/plugins/font/menu/font-size/font-size-scale.js +38 -0
- package/dist/basic-sdk/extension/plugins/font/menu/font-size/index.css +40 -0
- package/dist/basic-sdk/extension/plugins/font/menu/font-size/index.js +103 -0
- package/dist/basic-sdk/extension/plugins/font/menu/index.js +24 -0
- package/dist/basic-sdk/extension/plugins/font/plugin.js +18 -0
- package/dist/basic-sdk/extension/plugins/group/index.js +13 -0
- package/dist/basic-sdk/extension/plugins/group/render-elem.js +25 -0
- package/dist/basic-sdk/extension/plugins/header/helpers.js +69 -0
- package/dist/basic-sdk/extension/plugins/header/index.js +17 -0
- package/dist/basic-sdk/extension/plugins/header/menu/index.js +153 -0
- package/dist/basic-sdk/extension/plugins/header/menu/style.css +79 -0
- package/dist/basic-sdk/extension/plugins/header/placeholder.js +35 -0
- package/dist/basic-sdk/extension/plugins/header/plugin.js +140 -0
- package/dist/basic-sdk/extension/plugins/header/render-elem.js +90 -0
- package/dist/basic-sdk/extension/plugins/history/history-menu.js +70 -0
- package/dist/basic-sdk/extension/plugins/html/helper.js +144 -0
- package/dist/basic-sdk/extension/plugins/html/index.js +13 -0
- package/dist/basic-sdk/extension/plugins/html/plugin.js +50 -0
- package/dist/basic-sdk/extension/plugins/html/rules/blockquote.js +24 -0
- package/dist/basic-sdk/extension/plugins/html/rules/check-list.js +27 -0
- package/dist/basic-sdk/extension/plugins/html/rules/code-block.js +89 -0
- package/dist/basic-sdk/extension/plugins/html/rules/header.js +32 -0
- package/dist/basic-sdk/extension/plugins/html/rules/image.js +29 -0
- package/dist/basic-sdk/extension/plugins/html/rules/index.js +18 -0
- package/dist/basic-sdk/extension/plugins/html/rules/link.js +29 -0
- package/dist/basic-sdk/extension/plugins/html/rules/list.js +59 -0
- package/dist/basic-sdk/extension/plugins/html/rules/paragraph.js +24 -0
- package/dist/basic-sdk/extension/plugins/html/rules/table.js +41 -0
- package/dist/basic-sdk/extension/plugins/html/rules/text.js +66 -0
- package/dist/basic-sdk/extension/plugins/image/base64-to-unit8array.js +21 -0
- package/dist/basic-sdk/extension/plugins/image/constants/index.js +30 -0
- package/dist/basic-sdk/extension/plugins/image/copy-image-error-svg/index.js +64 -0
- package/dist/basic-sdk/extension/plugins/image/dialogs/image-previewer.js +86 -0
- package/dist/basic-sdk/extension/plugins/image/helpers.js +346 -0
- package/dist/basic-sdk/extension/plugins/image/hover-menu/index.css +89 -0
- package/dist/basic-sdk/extension/plugins/image/hover-menu/index.js +302 -0
- package/dist/basic-sdk/extension/plugins/image/image-cache.js +30 -0
- package/dist/basic-sdk/extension/plugins/image/image-loader/index.css +49 -0
- package/dist/basic-sdk/extension/plugins/image/image-loader/index.js +24 -0
- package/dist/basic-sdk/extension/plugins/image/index.js +21 -0
- package/dist/basic-sdk/extension/plugins/image/menu/index.js +73 -0
- package/dist/basic-sdk/extension/plugins/image/model.js +19 -0
- package/dist/basic-sdk/extension/plugins/image/plugin.js +230 -0
- package/dist/basic-sdk/extension/plugins/image/render-elem.js +405 -0
- package/dist/basic-sdk/extension/plugins/image/use-copy-image.js +80 -0
- package/dist/basic-sdk/extension/plugins/image/use-upload-image.js +67 -0
- package/dist/basic-sdk/extension/plugins/index.js +172 -0
- package/dist/basic-sdk/extension/plugins/link/dialog/add-link-dialog/index.js +140 -0
- package/dist/basic-sdk/extension/plugins/link/helpers.js +232 -0
- package/dist/basic-sdk/extension/plugins/link/hover/index.css +66 -0
- package/dist/basic-sdk/extension/plugins/link/hover/index.js +60 -0
- package/dist/basic-sdk/extension/plugins/link/index.js +21 -0
- package/dist/basic-sdk/extension/plugins/link/menu/index.js +63 -0
- package/dist/basic-sdk/extension/plugins/link/model.js +18 -0
- package/dist/basic-sdk/extension/plugins/link/plugin.js +148 -0
- package/dist/basic-sdk/extension/plugins/link/render-elem.js +142 -0
- package/dist/basic-sdk/extension/plugins/list/helpers.js +115 -0
- package/dist/basic-sdk/extension/plugins/list/index.js +18 -0
- package/dist/basic-sdk/extension/plugins/list/menu/index.js +65 -0
- package/dist/basic-sdk/extension/plugins/list/model.js +47 -0
- package/dist/basic-sdk/extension/plugins/list/plugin/index.js +140 -0
- package/dist/basic-sdk/extension/plugins/list/plugin/insert-break-list.js +30 -0
- package/dist/basic-sdk/extension/plugins/list/plugin/insert-fragment-list.js +176 -0
- package/dist/basic-sdk/extension/plugins/list/plugin/normalize-list.js +80 -0
- package/dist/basic-sdk/extension/plugins/list/plugin/on-tab-handle.js +61 -0
- package/dist/basic-sdk/extension/plugins/list/plugin/shortcut.js +89 -0
- package/dist/basic-sdk/extension/plugins/list/queries/index.js +55 -0
- package/dist/basic-sdk/extension/plugins/list/render-elem.js +64 -0
- package/dist/basic-sdk/extension/plugins/list/transforms/index.js +76 -0
- package/dist/basic-sdk/extension/plugins/list/transforms/insert-list-item.js +94 -0
- package/dist/basic-sdk/extension/plugins/list/transforms/is-across-list-items.js +25 -0
- package/dist/basic-sdk/extension/plugins/list/transforms/move-list-item-down.js +48 -0
- package/dist/basic-sdk/extension/plugins/list/transforms/move-list-item-sublist-to-list-item-sublist.js +63 -0
- package/dist/basic-sdk/extension/plugins/list/transforms/move-list-item-up.js +125 -0
- package/dist/basic-sdk/extension/plugins/list/transforms/move-list-items-to-list.js +63 -0
- package/dist/basic-sdk/extension/plugins/list/transforms/move-list-items.js +73 -0
- package/dist/basic-sdk/extension/plugins/list/transforms/normalize-list-item.js +109 -0
- package/dist/basic-sdk/extension/plugins/list/transforms/normalize-nested-list.js +38 -0
- package/dist/basic-sdk/extension/plugins/list/transforms/remove-first-list-item.js +24 -0
- package/dist/basic-sdk/extension/plugins/list/transforms/remove-list-item.js +64 -0
- package/dist/basic-sdk/extension/plugins/list/transforms/toggle-list.js +164 -0
- package/dist/basic-sdk/extension/plugins/list/transforms/unwrap-list.js +51 -0
- package/dist/basic-sdk/extension/plugins/markdown/index.js +12 -0
- package/dist/basic-sdk/extension/plugins/markdown/plugin.js +202 -0
- package/dist/basic-sdk/extension/plugins/mention/helper.js +239 -0
- package/dist/basic-sdk/extension/plugins/mention/index.js +17 -0
- package/dist/basic-sdk/extension/plugins/mention/plugin.js +269 -0
- package/dist/basic-sdk/extension/plugins/mention/render-elem/comment-participant-item.js +56 -0
- package/dist/basic-sdk/extension/plugins/mention/render-elem/index.css +60 -0
- package/dist/basic-sdk/extension/plugins/mention/render-elem/index.js +61 -0
- package/dist/basic-sdk/extension/plugins/mention/render-elem/participant-popover.js +242 -0
- package/dist/basic-sdk/extension/plugins/multi-column/constants/index.js +7 -0
- package/dist/basic-sdk/extension/plugins/multi-column/helper.js +192 -0
- package/dist/basic-sdk/extension/plugins/multi-column/index.js +17 -0
- package/dist/basic-sdk/extension/plugins/multi-column/plugin.js +153 -0
- package/dist/basic-sdk/extension/plugins/multi-column/render/index.css +51 -0
- package/dist/basic-sdk/extension/plugins/multi-column/render/index.js +91 -0
- package/dist/basic-sdk/extension/plugins/multi-column/render/multi-column-root.js +23 -0
- package/dist/basic-sdk/extension/plugins/multi-column/render/render-column.js +46 -0
- package/dist/basic-sdk/extension/plugins/multi-column/render-elem.js +20 -0
- package/dist/basic-sdk/extension/plugins/multi-column/resize-handlers/column-resize-handler.js +28 -0
- package/dist/basic-sdk/extension/plugins/multi-column/resize-handlers/index.js +148 -0
- package/dist/basic-sdk/extension/plugins/paragraph/helper.js +17 -0
- package/dist/basic-sdk/extension/plugins/paragraph/index.js +16 -0
- package/dist/basic-sdk/extension/plugins/paragraph/plugin.js +166 -0
- package/dist/basic-sdk/extension/plugins/paragraph/render-elem.js +78 -0
- package/dist/basic-sdk/extension/plugins/sdoc-link/constants/index.js +26 -0
- package/dist/basic-sdk/extension/plugins/sdoc-link/helpers.js +291 -0
- package/dist/basic-sdk/extension/plugins/sdoc-link/hover-menu/index.css +89 -0
- package/dist/basic-sdk/extension/plugins/sdoc-link/hover-menu/index.js +119 -0
- package/dist/basic-sdk/extension/plugins/sdoc-link/index.js +19 -0
- package/dist/basic-sdk/extension/plugins/sdoc-link/menu/index.js +38 -0
- package/dist/basic-sdk/extension/plugins/sdoc-link/plugin.js +102 -0
- package/dist/basic-sdk/extension/plugins/sdoc-link/render/render-elem.css +68 -0
- package/dist/basic-sdk/extension/plugins/sdoc-link/render/render-elem.js +180 -0
- package/dist/basic-sdk/extension/plugins/sdoc-link/render/render-file-link-temp-input.js +34 -0
- package/dist/basic-sdk/extension/plugins/search-replace/constant.js +8 -0
- package/dist/basic-sdk/extension/plugins/search-replace/helper.js +355 -0
- package/dist/basic-sdk/extension/plugins/search-replace/index.js +17 -0
- package/dist/basic-sdk/extension/plugins/search-replace/menu/index.css +14 -0
- package/dist/basic-sdk/extension/plugins/search-replace/menu/index.js +89 -0
- package/dist/basic-sdk/extension/plugins/search-replace/plugin.js +28 -0
- package/dist/basic-sdk/extension/plugins/search-replace/popover/index.css +98 -0
- package/dist/basic-sdk/extension/plugins/search-replace/popover/index.js +238 -0
- package/dist/basic-sdk/extension/plugins/search-replace/popover/replace-all-confirm-modal.js +50 -0
- package/dist/basic-sdk/extension/plugins/table/constants/index.js +64 -0
- package/dist/basic-sdk/extension/plugins/table/dialogs/custom-table-size-dialog/index.css +7 -0
- package/dist/basic-sdk/extension/plugins/table/dialogs/custom-table-size-dialog/index.js +102 -0
- package/dist/basic-sdk/extension/plugins/table/dialogs/custom-table-size-dialog/number-input.js +31 -0
- package/dist/basic-sdk/extension/plugins/table/dialogs/index.js +20 -0
- package/dist/basic-sdk/extension/plugins/table/dialogs/split-cell-setting-dialog.js +115 -0
- package/dist/basic-sdk/extension/plugins/table/helpers.js +2124 -0
- package/dist/basic-sdk/extension/plugins/table/index.js +21 -0
- package/dist/basic-sdk/extension/plugins/table/menu/active-table-menu/common-menu.js +83 -0
- package/dist/basic-sdk/extension/plugins/table/menu/color-selector-popover/color-item.js +31 -0
- package/dist/basic-sdk/extension/plugins/table/menu/color-selector-popover/index.js +173 -0
- package/dist/basic-sdk/extension/plugins/table/menu/color-selector-popover/style.css +7 -0
- package/dist/basic-sdk/extension/plugins/table/menu/horizontal-align-popover/index.js +79 -0
- package/dist/basic-sdk/extension/plugins/table/menu/index.js +20 -0
- package/dist/basic-sdk/extension/plugins/table/menu/table-context-menu/index.css +40 -0
- package/dist/basic-sdk/extension/plugins/table/menu/table-context-menu/index.js +232 -0
- package/dist/basic-sdk/extension/plugins/table/menu/table-context-menu/insert-table-element.js +97 -0
- package/dist/basic-sdk/extension/plugins/table/menu/table-menu/index.js +41 -0
- package/dist/basic-sdk/extension/plugins/table/menu/vertical-align-popover/index.js +81 -0
- package/dist/basic-sdk/extension/plugins/table/menu/vertical-align-popover/style.css +24 -0
- package/dist/basic-sdk/extension/plugins/table/model.js +54 -0
- package/dist/basic-sdk/extension/plugins/table/plugin.js +621 -0
- package/dist/basic-sdk/extension/plugins/table/popover/table-size-popover/index.css +69 -0
- package/dist/basic-sdk/extension/plugins/table/popover/table-size-popover/index.js +265 -0
- package/dist/basic-sdk/extension/plugins/table/popover/table-template/index.css +43 -0
- package/dist/basic-sdk/extension/plugins/table/popover/table-template/index.js +129 -0
- package/dist/basic-sdk/extension/plugins/table/popover/table-template/sample-table.js +44 -0
- package/dist/basic-sdk/extension/plugins/table/render/alternate-color.css +37 -0
- package/dist/basic-sdk/extension/plugins/table/render/drag-handlers/column-drag-handler.js +24 -0
- package/dist/basic-sdk/extension/plugins/table/render/drag-handlers/index.js +53 -0
- package/dist/basic-sdk/extension/plugins/table/render/drag-handlers/row-drag-handler.js +24 -0
- package/dist/basic-sdk/extension/plugins/table/render/hooks.js +76 -0
- package/dist/basic-sdk/extension/plugins/table/render/index.css +169 -0
- package/dist/basic-sdk/extension/plugins/table/render/index.js +271 -0
- package/dist/basic-sdk/extension/plugins/table/render/render-cell.js +253 -0
- package/dist/basic-sdk/extension/plugins/table/render/render-row.js +15 -0
- package/dist/basic-sdk/extension/plugins/table/render/resize-handlers/column-resize-handler.js +114 -0
- package/dist/basic-sdk/extension/plugins/table/render/resize-handlers/first-column-left-resize-handler.js +100 -0
- package/dist/basic-sdk/extension/plugins/table/render/resize-handlers/index.js +74 -0
- package/dist/basic-sdk/extension/plugins/table/render/resize-handlers/row-resize-handler.js +90 -0
- package/dist/basic-sdk/extension/plugins/table/render/resize-mask/index.js +136 -0
- package/dist/basic-sdk/extension/plugins/table/render/table-header/columns-header/column-header.js +104 -0
- package/dist/basic-sdk/extension/plugins/table/render/table-header/columns-header/index.js +92 -0
- package/dist/basic-sdk/extension/plugins/table/render/table-header/index.css +84 -0
- package/dist/basic-sdk/extension/plugins/table/render/table-header/index.js +114 -0
- package/dist/basic-sdk/extension/plugins/table/render/table-header/rows-columns-header.js +32 -0
- package/dist/basic-sdk/extension/plugins/table/render/table-header/rows-header/index.js +90 -0
- package/dist/basic-sdk/extension/plugins/table/render/table-header/rows-header/row-header.js +126 -0
- package/dist/basic-sdk/extension/plugins/table/render/table-root.js +60 -0
- package/dist/basic-sdk/extension/plugins/table/render-elem.js +27 -0
- package/dist/basic-sdk/extension/plugins/text-align/helpers.js +51 -0
- package/dist/basic-sdk/extension/plugins/text-align/index.js +8 -0
- package/dist/basic-sdk/extension/plugins/text-align/menu/index.css +5 -0
- package/dist/basic-sdk/extension/plugins/text-align/menu/index.js +98 -0
- package/dist/basic-sdk/extension/plugins/text-style/caret.js +60 -0
- package/dist/basic-sdk/extension/plugins/text-style/helpers.js +63 -0
- package/dist/basic-sdk/extension/plugins/text-style/index.js +15 -0
- package/dist/basic-sdk/extension/plugins/text-style/menu/comemnt-editor-menu.js +72 -0
- package/dist/basic-sdk/extension/plugins/text-style/menu/index.js +163 -0
- package/dist/basic-sdk/extension/plugins/text-style/plugin.js +30 -0
- package/dist/basic-sdk/extension/plugins/text-style/render-elem.js +137 -0
- package/dist/basic-sdk/extension/plugins/video/constants/index.js +10 -0
- package/dist/basic-sdk/extension/plugins/video/dialog/add-video-link-dialog/index.js +108 -0
- package/dist/basic-sdk/extension/plugins/video/helpers.js +241 -0
- package/dist/basic-sdk/extension/plugins/video/index.css +73 -0
- package/dist/basic-sdk/extension/plugins/video/index.js +20 -0
- package/dist/basic-sdk/extension/plugins/video/menu/index.js +76 -0
- package/dist/basic-sdk/extension/plugins/video/plugin.js +52 -0
- package/dist/basic-sdk/extension/plugins/video/render-elem.js +155 -0
- package/dist/basic-sdk/extension/plugins/wiki-link/helpers.js +77 -0
- package/dist/basic-sdk/extension/plugins/wiki-link/index.js +16 -0
- package/dist/basic-sdk/extension/render/helper.js +64 -0
- package/dist/basic-sdk/extension/render/render-comment-editor-element.js +105 -0
- package/dist/basic-sdk/extension/render/render-leaf.js +19 -0
- package/dist/basic-sdk/extension/toolbar/comment-editor-toolbar/index.js +64 -0
- package/dist/basic-sdk/extension/toolbar/comment-editor-toolbar/post-comment/index.js +36 -0
- package/dist/basic-sdk/extension/toolbar/comment-editor-toolbar/post-comment/style.css +7 -0
- package/dist/basic-sdk/extension/utils/index.js +88 -0
- package/dist/basic-sdk/highlight/index.js +26 -0
- package/dist/basic-sdk/highlight/setNodeToDecorations.js +83 -0
- package/dist/basic-sdk/hooks/use-collaborators.js +62 -0
- package/dist/basic-sdk/hooks/use-color-context.js +49 -0
- package/dist/basic-sdk/hooks/use-force-update.js +15 -0
- package/dist/basic-sdk/hooks/use-plugins.js +9 -0
- package/dist/basic-sdk/hooks/use-scroll-context.js +20 -0
- package/dist/basic-sdk/hooks/use-selection-element.js +26 -0
- package/dist/basic-sdk/hooks/use-selection-position.js +68 -0
- package/dist/basic-sdk/hooks/use-selection-update.js +20 -0
- package/dist/basic-sdk/index.js +194 -0
- package/dist/basic-sdk/layout/article-container.js +89 -0
- package/dist/basic-sdk/layout/editor-container.js +32 -0
- package/dist/basic-sdk/layout/index.js +20 -0
- package/dist/basic-sdk/model/index.js +20 -0
- package/dist/basic-sdk/model/notification.js +18 -0
- package/dist/basic-sdk/model/user.js +17 -0
- package/dist/basic-sdk/node-id/constants.js +24 -0
- package/dist/basic-sdk/node-id/helpers.js +160 -0
- package/dist/basic-sdk/node-id/index.js +69 -0
- package/dist/basic-sdk/right-panel/index.css +15 -0
- package/dist/basic-sdk/right-panel/index.js +86 -0
- package/dist/basic-sdk/right-panel/resize-width/index.css +38 -0
- package/dist/basic-sdk/right-panel/resize-width/index.js +132 -0
- package/dist/basic-sdk/slate-convert/html-to-slate/constants.js +39 -0
- package/dist/basic-sdk/slate-convert/html-to-slate/helper.js +64 -0
- package/dist/basic-sdk/slate-convert/html-to-slate/index.js +137 -0
- package/dist/basic-sdk/slate-convert/html-to-slate/rules/blockquote.js +24 -0
- package/dist/basic-sdk/slate-convert/html-to-slate/rules/check-list.js +27 -0
- package/dist/basic-sdk/slate-convert/html-to-slate/rules/code-block.js +90 -0
- package/dist/basic-sdk/slate-convert/html-to-slate/rules/header.js +24 -0
- package/dist/basic-sdk/slate-convert/html-to-slate/rules/image.js +29 -0
- package/dist/basic-sdk/slate-convert/html-to-slate/rules/index.js +18 -0
- package/dist/basic-sdk/slate-convert/html-to-slate/rules/link.js +29 -0
- package/dist/basic-sdk/slate-convert/html-to-slate/rules/list.js +57 -0
- package/dist/basic-sdk/slate-convert/html-to-slate/rules/paragraph.js +34 -0
- package/dist/basic-sdk/slate-convert/html-to-slate/rules/table.js +45 -0
- package/dist/basic-sdk/slate-convert/html-to-slate/rules/text.js +63 -0
- package/dist/basic-sdk/slate-convert/index.js +34 -0
- package/dist/basic-sdk/slate-convert/md-to-html/index.js +53 -0
- package/dist/basic-sdk/slate-convert/md-to-html/sanitize-schema.js +24 -0
- package/dist/basic-sdk/slate-convert/md-to-slate/index.js +44 -0
- package/dist/basic-sdk/slate-convert/md-to-slate/transform.js +414 -0
- package/dist/basic-sdk/slate-convert/slate-to-md/index.js +43 -0
- package/dist/basic-sdk/slate-convert/slate-to-md/transform.js +344 -0
- package/dist/basic-sdk/socket/helpers.js +299 -0
- package/dist/basic-sdk/socket/index.js +20 -0
- package/dist/basic-sdk/socket/socket-client.js +211 -0
- package/dist/basic-sdk/socket/socket-manager.js +386 -0
- package/dist/basic-sdk/socket/with-socket-io.js +73 -0
- package/dist/basic-sdk/utils/Kebab-to-camel.js +10 -0
- package/dist/basic-sdk/utils/common-utils.js +65 -0
- package/dist/basic-sdk/utils/debounce.js +20 -0
- package/dist/basic-sdk/utils/debug.js +20 -0
- package/dist/basic-sdk/utils/default-mode.js +28 -0
- package/dist/basic-sdk/utils/diff-text.js +297 -0
- package/dist/basic-sdk/utils/diff.js +328 -0
- package/dist/basic-sdk/utils/document-utils.js +81 -0
- package/dist/basic-sdk/utils/dom-utils.js +57 -0
- package/dist/basic-sdk/utils/event-bus.js +40 -0
- package/dist/basic-sdk/utils/event-handler.js +131 -0
- package/dist/basic-sdk/utils/full-width-mode.js +36 -0
- package/dist/basic-sdk/utils/is-punctuation-mark.js +50 -0
- package/dist/basic-sdk/utils/local-storage-utils.js +52 -0
- package/dist/basic-sdk/utils/mouse-event.js +81 -0
- package/dist/basic-sdk/utils/object-utils.js +58 -0
- package/dist/basic-sdk/utils/rebase.js +309 -0
- package/dist/components/error-boundary/error-page.css +16 -0
- package/dist/components/error-boundary/error-page.js +36 -0
- package/dist/components/error-boundary/index.js +33 -0
- package/dist/components/modal-header/index.css +18 -0
- package/dist/components/modal-header/index.js +29 -0
- package/dist/components/modal-portal/index.js +26 -0
- package/dist/components/tip-dialog/index.css +48 -0
- package/dist/components/tip-dialog/index.js +115 -0
- package/dist/components/tip-message/index.js +194 -0
- package/dist/components/tip-message/style.css +15 -0
- package/dist/constants/index.js +67 -0
- package/dist/hooks/index.js +12 -0
- package/dist/hooks/use-document.js +75 -0
- package/dist/index.js +27 -0
- package/dist/pages/seafile-comment-editor.js +69 -0
- package/dist/utils/date-utils.js +78 -0
- package/dist/utils/index.js +45 -0
- package/package.json +189 -0
- package/public/favicon.ico +0 -0
- package/public/index.html +44 -0
- package/public/locales/cs/sdoc-editor.json +626 -0
- package/public/locales/de/sdoc-editor.json +626 -0
- package/public/locales/en/sdoc-editor.json +638 -0
- package/public/locales/es/sdoc-editor.json +626 -0
- package/public/locales/es_AR/sdoc-editor.json +626 -0
- package/public/locales/es_MX/sdoc-editor.json +626 -0
- package/public/locales/fr/sdoc-editor.json +626 -0
- package/public/locales/it/sdoc-editor.json +627 -0
- package/public/locales/ru/sdoc-editor.json +626 -0
- package/public/locales/zh_CN/sdoc-editor.json +639 -0
- package/public/manifest.json +15 -0
- package/public/media/dtable-font.css +1568 -0
- package/public/media/dtable-fonts/dtable-font.eot +0 -0
- package/public/media/dtable-fonts/dtable-font.svg +793 -0
- package/public/media/dtable-fonts/dtable-font.ttf +0 -0
- package/public/media/dtable-fonts/dtable-font.woff +0 -0
- package/public/media/dtable-fonts/dtable-font.woff2 +0 -0
- package/public/media/scripts/mathjax/tex-svg.js +1 -0
- package/public/media/sdoc-editor-font/iconfont.css +558 -0
- package/public/media/sdoc-editor-font/iconfont.eot +0 -0
- package/public/media/sdoc-editor-font/iconfont.svg +289 -0
- package/public/media/sdoc-editor-font/iconfont.ttf +0 -0
- package/public/media/sdoc-editor-font/iconfont.woff +0 -0
- package/public/media/sdoc-editor-font/iconfont.woff2 +0 -0
- package/public/media/sdoc-editor-font.css +558 -0
- package/public/media/seafile-logo.png +0 -0
- package/public/media/seafile-ui.css +8 -0
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.setCheckListItemType = exports.isMenuDisabled = exports.getCheckListItemType = exports.convertToCheck = void 0;
|
|
7
|
+
var _slate = require("@seafile/slate");
|
|
8
|
+
var _constants = require("../../constants");
|
|
9
|
+
var _core = require("../../core");
|
|
10
|
+
const isMenuDisabled = (editor, readonly) => {
|
|
11
|
+
if (readonly) return true;
|
|
12
|
+
if (editor.selection == null) return true;
|
|
13
|
+
let selectedElements = [];
|
|
14
|
+
const nodeEntries = _slate.Editor.nodes(editor, {
|
|
15
|
+
universal: true
|
|
16
|
+
});
|
|
17
|
+
for (let nodeEntry of nodeEntries) {
|
|
18
|
+
const [node] = nodeEntry;
|
|
19
|
+
if (_slate.Element.isElement(node)) selectedElements.push(node);
|
|
20
|
+
}
|
|
21
|
+
const notMatch = selectedElements.some(element => {
|
|
22
|
+
if (_slate.Editor.isVoid(editor, element) && _slate.Editor.isBlock(editor, element)) return true;
|
|
23
|
+
const {
|
|
24
|
+
type
|
|
25
|
+
} = element;
|
|
26
|
+
if (type === _constants.ELEMENT_TYPE.CODE_LINE) return true;
|
|
27
|
+
if (type === _constants.ELEMENT_TYPE.CODE_BLOCK) return true;
|
|
28
|
+
if ([_constants.ORDERED_LIST, _constants.UNORDERED_LIST].includes(type) && (0, _core.isMultiLevelList)(element)) return true;
|
|
29
|
+
if (type === _constants.ELEMENT_TYPE.TABLE) return true;
|
|
30
|
+
if (type === _constants.ELEMENT_TYPE.TABLE_ROW) return true;
|
|
31
|
+
if (type === _constants.ELEMENT_TYPE.TABLE_CELL) return true;
|
|
32
|
+
return false;
|
|
33
|
+
});
|
|
34
|
+
if (notMatch) return true;
|
|
35
|
+
return false;
|
|
36
|
+
};
|
|
37
|
+
exports.isMenuDisabled = isMenuDisabled;
|
|
38
|
+
const getCheckListItemType = editor => {
|
|
39
|
+
const node = (0, _core.getSelectedNodeByType)(editor, _constants.CHECK_LIST_ITEM);
|
|
40
|
+
if (!node) return _constants.PARAGRAPH;
|
|
41
|
+
return node.type;
|
|
42
|
+
};
|
|
43
|
+
exports.getCheckListItemType = getCheckListItemType;
|
|
44
|
+
const convertToCheck = (editor, listNode, listPath) => {
|
|
45
|
+
const checkList = [];
|
|
46
|
+
const {
|
|
47
|
+
children
|
|
48
|
+
} = listNode || {};
|
|
49
|
+
children.forEach(item => {
|
|
50
|
+
const text = _slate.Node.string(item);
|
|
51
|
+
const checkNode = (0, _core.generateEmptyElement)(_constants.CHECK_LIST_ITEM, {}, text);
|
|
52
|
+
checkList.push(checkNode);
|
|
53
|
+
});
|
|
54
|
+
_slate.Transforms.removeNodes(editor, {
|
|
55
|
+
at: [listPath[0]]
|
|
56
|
+
});
|
|
57
|
+
_slate.Transforms.insertNodes(editor, checkList, {
|
|
58
|
+
at: [listPath[0]]
|
|
59
|
+
});
|
|
60
|
+
_slate.Transforms.select(editor, {
|
|
61
|
+
path: [listPath[0], 0],
|
|
62
|
+
offset: 0
|
|
63
|
+
});
|
|
64
|
+
};
|
|
65
|
+
exports.convertToCheck = convertToCheck;
|
|
66
|
+
const setCheckListItemType = (editor, newType, insertPosition) => {
|
|
67
|
+
if (insertPosition === _constants.INSERT_POSITION.AFTER) {
|
|
68
|
+
const p = (0, _core.generateEmptyElement)(_constants.PARAGRAPH);
|
|
69
|
+
const path = _slate.Editor.path(editor, editor.selection);
|
|
70
|
+
_slate.Transforms.insertNodes(editor, p, {
|
|
71
|
+
at: [path[0] + 1]
|
|
72
|
+
});
|
|
73
|
+
_slate.Transforms.select(editor, [path[0] + 1]);
|
|
74
|
+
}
|
|
75
|
+
if (!(0, _core.isRangeAcrossBlocks)(editor)) {
|
|
76
|
+
const path = _slate.Editor.path(editor, editor.selection);
|
|
77
|
+
const [currentNode] = (0, _core.getCurrentNode)(editor);
|
|
78
|
+
if (path) {
|
|
79
|
+
const [targetNode, targetPath] = _slate.Editor.node(editor, [path[0]]);
|
|
80
|
+
if (targetNode && [_constants.ORDERED_LIST, _constants.UNORDERED_LIST].includes(targetNode === null || targetNode === void 0 ? void 0 : targetNode.type)) {
|
|
81
|
+
convertToCheck(editor, targetNode, targetPath);
|
|
82
|
+
if (newType === _constants.CHECK_LIST_ITEM && !_slate.Node.string(currentNode)) {
|
|
83
|
+
(0, _core.focusEditor)(editor);
|
|
84
|
+
}
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
_slate.Transforms.setNodes(editor, {
|
|
89
|
+
type: newType
|
|
90
|
+
});
|
|
91
|
+
// When currentNode is empty
|
|
92
|
+
if (newType === _constants.CHECK_LIST_ITEM && !_slate.Node.string(currentNode)) {
|
|
93
|
+
(0, _core.focusEditor)(editor, path);
|
|
94
|
+
}
|
|
95
|
+
} else {
|
|
96
|
+
const nodes = _slate.Editor.nodes(editor, {
|
|
97
|
+
match: n => {
|
|
98
|
+
const type = (0, _core.getNodeType)(n);
|
|
99
|
+
if (!type) return;
|
|
100
|
+
if (type === _constants.PARAGRAPH) return true;
|
|
101
|
+
if (type === _constants.CHECK_LIST_ITEM) return true;
|
|
102
|
+
if (type.startsWith(_constants.HEADER)) return true;
|
|
103
|
+
if (type === _constants.TITLE) return true;
|
|
104
|
+
if (type === _constants.SUBTITLE) return true;
|
|
105
|
+
return false;
|
|
106
|
+
},
|
|
107
|
+
universal: false,
|
|
108
|
+
mode: 'highest' // Match top level
|
|
109
|
+
});
|
|
110
|
+
const nodesEntry = Array.from(nodes);
|
|
111
|
+
if (nodesEntry.length === 0) return;
|
|
112
|
+
nodesEntry.forEach(nodeEntry => {
|
|
113
|
+
_slate.Transforms.setNodes(editor, {
|
|
114
|
+
type: newType
|
|
115
|
+
}, {
|
|
116
|
+
at: nodeEntry[1]
|
|
117
|
+
});
|
|
118
|
+
});
|
|
119
|
+
}
|
|
120
|
+
};
|
|
121
|
+
exports.setCheckListItemType = setCheckListItemType;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.default = void 0;
|
|
8
|
+
var _constants = require("../../constants");
|
|
9
|
+
var _plugin = _interopRequireDefault(require("./plugin"));
|
|
10
|
+
var _renderElem = require("./render-elem");
|
|
11
|
+
const CheckListPlugin = {
|
|
12
|
+
type: _constants.CHECK_LIST_ITEM,
|
|
13
|
+
editorPlugin: _plugin.default,
|
|
14
|
+
renderElements: [_renderElem.renderCheckListItem]
|
|
15
|
+
};
|
|
16
|
+
var _default = exports.default = CheckListPlugin;
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.default = void 0;
|
|
8
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/defineProperty"));
|
|
9
|
+
var _react = _interopRequireDefault(require("react"));
|
|
10
|
+
var _commons = require("../../../commons");
|
|
11
|
+
var _constants = require("../../../constants");
|
|
12
|
+
var _core = require("../../../core");
|
|
13
|
+
var _helpers = require("../helpers");
|
|
14
|
+
class CheckListMenu extends _react.default.Component {
|
|
15
|
+
constructor() {
|
|
16
|
+
super(...arguments);
|
|
17
|
+
(0, _defineProperty2.default)(this, "isActive", () => {
|
|
18
|
+
const {
|
|
19
|
+
editor
|
|
20
|
+
} = this.props;
|
|
21
|
+
return (0, _helpers.getCheckListItemType)(editor) === _constants.CHECK_LIST_ITEM;
|
|
22
|
+
});
|
|
23
|
+
(0, _defineProperty2.default)(this, "isDisabled", () => {
|
|
24
|
+
const {
|
|
25
|
+
editor,
|
|
26
|
+
readonly
|
|
27
|
+
} = this.props;
|
|
28
|
+
return (0, _helpers.isMenuDisabled)(editor, readonly);
|
|
29
|
+
});
|
|
30
|
+
(0, _defineProperty2.default)(this, "onMouseDown", () => {
|
|
31
|
+
const {
|
|
32
|
+
editor
|
|
33
|
+
} = this.props;
|
|
34
|
+
const active = this.isActive(editor);
|
|
35
|
+
const newType = active ? _constants.PARAGRAPH : _constants.CHECK_LIST_ITEM;
|
|
36
|
+
(0, _helpers.setCheckListItemType)(editor, newType);
|
|
37
|
+
(0, _core.focusEditor)(editor, editor.selection);
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
render() {
|
|
41
|
+
const {
|
|
42
|
+
isRichEditor,
|
|
43
|
+
className
|
|
44
|
+
} = this.props;
|
|
45
|
+
const menuConfig = _constants.MENUS_CONFIG_MAP[_constants.CHECK_LIST_ITEM];
|
|
46
|
+
const props = {
|
|
47
|
+
isRichEditor,
|
|
48
|
+
className,
|
|
49
|
+
ariaLabel: 'check list',
|
|
50
|
+
...menuConfig,
|
|
51
|
+
disabled: this.isDisabled(),
|
|
52
|
+
isActive: this.isActive(),
|
|
53
|
+
onMouseDown: this.onMouseDown
|
|
54
|
+
};
|
|
55
|
+
return /*#__PURE__*/_react.default.createElement(_commons.MenuItem, props);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
var _default = exports.default = CheckListMenu;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
var _constants = require("../../constants");
|
|
8
|
+
class CheckListItem {
|
|
9
|
+
constructor(options) {
|
|
10
|
+
this.type = options.type || _constants.CHECK_LIST_ITEM;
|
|
11
|
+
this.checked = options.checked || false;
|
|
12
|
+
this.children = options.children || [{
|
|
13
|
+
text: ''
|
|
14
|
+
}];
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
var _default = exports.default = CheckListItem;
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.default = void 0;
|
|
8
|
+
var _slate = require("@seafile/slate");
|
|
9
|
+
var _isHotkey = _interopRequireDefault(require("is-hotkey"));
|
|
10
|
+
var _constants = require("../../constants");
|
|
11
|
+
var _core = require("../../core");
|
|
12
|
+
const withCheckList = editor => {
|
|
13
|
+
const {
|
|
14
|
+
insertBreak,
|
|
15
|
+
deleteBackward,
|
|
16
|
+
onHotKeyDown
|
|
17
|
+
} = editor;
|
|
18
|
+
const newEditor = editor;
|
|
19
|
+
newEditor.insertBreak = () => {
|
|
20
|
+
const {
|
|
21
|
+
selection
|
|
22
|
+
} = newEditor;
|
|
23
|
+
if (!selection) {
|
|
24
|
+
insertBreak();
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
const node = (0, _core.getSelectedNodeByType)(editor, _constants.CHECK_LIST_ITEM);
|
|
28
|
+
if (!node) {
|
|
29
|
+
insertBreak();
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
if (_slate.Node.string(node).length === 0) {
|
|
33
|
+
_slate.Transforms.setNodes(editor, {
|
|
34
|
+
type: _constants.PARAGRAPH,
|
|
35
|
+
children: [(0, _core.generateDefaultText)()]
|
|
36
|
+
}, {
|
|
37
|
+
at: node[1]
|
|
38
|
+
});
|
|
39
|
+
return;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
// If it is check-list-item, handle your own business logic
|
|
43
|
+
if ((0, _core.isCursorAtBlockStart)(editor)) {
|
|
44
|
+
const path = (0, _core.findPath)(editor, node);
|
|
45
|
+
const newNode = (0, _core.generateEmptyElement)(_constants.CHECK_LIST_ITEM);
|
|
46
|
+
_slate.Transforms.insertNodes(editor, newNode, {
|
|
47
|
+
at: path
|
|
48
|
+
});
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
_slate.Transforms.splitNodes(editor, {
|
|
52
|
+
always: true
|
|
53
|
+
});
|
|
54
|
+
_slate.Transforms.setNodes(editor, {
|
|
55
|
+
checked: false
|
|
56
|
+
}, {
|
|
57
|
+
at: node[1]
|
|
58
|
+
});
|
|
59
|
+
};
|
|
60
|
+
newEditor.deleteBackward = unit => {
|
|
61
|
+
const {
|
|
62
|
+
selection
|
|
63
|
+
} = newEditor;
|
|
64
|
+
if (selection && _slate.Range.isCollapsed(selection)) {
|
|
65
|
+
const selectedTodo = (0, _core.getSelectedNodeByType)(editor, _constants.CHECK_LIST_ITEM);
|
|
66
|
+
if (selectedTodo) {
|
|
67
|
+
// If the current todo has no text, it will be converted to a paragraph
|
|
68
|
+
if (_slate.Node.string(selectedTodo).length === 0) {
|
|
69
|
+
_slate.Transforms.setNodes(editor, {
|
|
70
|
+
type: _constants.PARAGRAPH,
|
|
71
|
+
children: [(0, _core.generateDefaultText)()]
|
|
72
|
+
}, {
|
|
73
|
+
at: selectedTodo[1]
|
|
74
|
+
});
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
deleteBackward(unit);
|
|
80
|
+
};
|
|
81
|
+
newEditor.onHotKeyDown = event => {
|
|
82
|
+
const selectedTodo = (0, _core.getSelectedNodeByType)(editor, _constants.CHECK_LIST_ITEM);
|
|
83
|
+
if (selectedTodo) {
|
|
84
|
+
if ((0, _isHotkey.default)('shift+enter', event)) {
|
|
85
|
+
event.preventDefault();
|
|
86
|
+
const {
|
|
87
|
+
selection
|
|
88
|
+
} = newEditor;
|
|
89
|
+
const insertPoint = _slate.Editor.start(editor, selection);
|
|
90
|
+
_slate.Transforms.insertText(editor, '\n', {
|
|
91
|
+
at: insertPoint
|
|
92
|
+
});
|
|
93
|
+
(0, _core.focusEditor)(editor, {
|
|
94
|
+
anchor: {
|
|
95
|
+
path: insertPoint.path,
|
|
96
|
+
offset: insertPoint.offset + 1
|
|
97
|
+
},
|
|
98
|
+
focus: {
|
|
99
|
+
path: insertPoint.path,
|
|
100
|
+
offset: insertPoint.offset + 1
|
|
101
|
+
}
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
return true;
|
|
105
|
+
}
|
|
106
|
+
return onHotKeyDown && onHotKeyDown(event);
|
|
107
|
+
};
|
|
108
|
+
return newEditor;
|
|
109
|
+
};
|
|
110
|
+
var _default = exports.default = withCheckList;
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.renderCheckListItem = void 0;
|
|
8
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/defineProperty"));
|
|
9
|
+
var _react = _interopRequireDefault(require("react"));
|
|
10
|
+
var _slate = require("@seafile/slate");
|
|
11
|
+
var _slateReact = require("@seafile/slate-react");
|
|
12
|
+
class CheckListItem extends _react.default.PureComponent {
|
|
13
|
+
constructor() {
|
|
14
|
+
super(...arguments);
|
|
15
|
+
(0, _defineProperty2.default)(this, "onChange", event => {
|
|
16
|
+
const {
|
|
17
|
+
editor,
|
|
18
|
+
element,
|
|
19
|
+
readOnly
|
|
20
|
+
} = this.props;
|
|
21
|
+
if (readOnly) return;
|
|
22
|
+
const checked = event.target.checked;
|
|
23
|
+
const path = _slateReact.ReactEditor.findPath(editor, element);
|
|
24
|
+
_slate.Transforms.setNodes(editor, {
|
|
25
|
+
checked
|
|
26
|
+
}, {
|
|
27
|
+
at: path
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
render() {
|
|
32
|
+
const {
|
|
33
|
+
attributes,
|
|
34
|
+
children,
|
|
35
|
+
element
|
|
36
|
+
} = this.props;
|
|
37
|
+
const {
|
|
38
|
+
id,
|
|
39
|
+
align,
|
|
40
|
+
checked = false
|
|
41
|
+
} = element || {};
|
|
42
|
+
const style = {
|
|
43
|
+
textAlign: align
|
|
44
|
+
};
|
|
45
|
+
return /*#__PURE__*/_react.default.createElement("div", Object.assign({
|
|
46
|
+
"data-id": id
|
|
47
|
+
}, attributes, {
|
|
48
|
+
className: `sdoc-checkbox-container ${attributes.className}`,
|
|
49
|
+
style: style
|
|
50
|
+
}), /*#__PURE__*/_react.default.createElement("div", {
|
|
51
|
+
className: "sdoc-checkbox-input-wrapper"
|
|
52
|
+
}, /*#__PURE__*/_react.default.createElement("input", {
|
|
53
|
+
contentEditable: false,
|
|
54
|
+
className: "sdoc-checkbox-input",
|
|
55
|
+
type: "checkbox",
|
|
56
|
+
onChange: this.onChange,
|
|
57
|
+
checked: checked
|
|
58
|
+
}), /*#__PURE__*/_react.default.createElement("p", {
|
|
59
|
+
className: "sdoc-checkbox-content-container"
|
|
60
|
+
}, children)));
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
const renderCheckListItem = (props, editor) => {
|
|
64
|
+
// eslint-disable-next-line react-hooks/rules-of-hooks
|
|
65
|
+
const readOnly = (0, _slateReact.useReadOnly)();
|
|
66
|
+
return /*#__PURE__*/_react.default.createElement(CheckListItem, Object.assign({}, props, {
|
|
67
|
+
editor: editor,
|
|
68
|
+
readOnly: readOnly
|
|
69
|
+
}));
|
|
70
|
+
};
|
|
71
|
+
exports.renderCheckListItem = renderCheckListItem;
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.isMenuDisabled = exports.clearStyles = void 0;
|
|
7
|
+
var _slate = require("@seafile/slate");
|
|
8
|
+
var _constants = require("../../constants");
|
|
9
|
+
var _core = require("../../core");
|
|
10
|
+
const isMenuDisabled = function (editor) {
|
|
11
|
+
let readonly = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
|
|
12
|
+
if (readonly) return true;
|
|
13
|
+
if (editor.selection == null) return true;
|
|
14
|
+
const [match] = _slate.Editor.nodes(editor, {
|
|
15
|
+
match: n => {
|
|
16
|
+
const type = (0, _core.getNodeType)(n);
|
|
17
|
+
if ([_constants.CODE_BLOCK, _constants.CODE_LINE].includes(type)) return true; // code-block
|
|
18
|
+
if (_slate.Editor.isVoid(editor, n)) return true; // void node
|
|
19
|
+
|
|
20
|
+
return false;
|
|
21
|
+
},
|
|
22
|
+
universal: true
|
|
23
|
+
});
|
|
24
|
+
if (match) return true;
|
|
25
|
+
return false;
|
|
26
|
+
};
|
|
27
|
+
exports.isMenuDisabled = isMenuDisabled;
|
|
28
|
+
const removeMarks = (editor, textNode) => {
|
|
29
|
+
// Iterate text node properties, clearing styles
|
|
30
|
+
const keys = Object.keys(textNode);
|
|
31
|
+
keys.forEach(key => {
|
|
32
|
+
if (key === 'text') {
|
|
33
|
+
// Keep only the text attribute (Text attributes are necessary)
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
// All other attributes are deleted
|
|
37
|
+
_slate.Editor.removeMark(editor, key);
|
|
38
|
+
});
|
|
39
|
+
};
|
|
40
|
+
const clearStyles = editor => {
|
|
41
|
+
_slate.Transforms.unwrapNodes(editor, {
|
|
42
|
+
match: n => (0, _core.getNodeType)(n) === 'link'
|
|
43
|
+
});
|
|
44
|
+
const nodeEntries = _slate.Editor.nodes(editor, {
|
|
45
|
+
match: n => _slate.Text.isText(n),
|
|
46
|
+
universal: true
|
|
47
|
+
});
|
|
48
|
+
for (const nodeEntry of nodeEntries) {
|
|
49
|
+
// single text node
|
|
50
|
+
const n = nodeEntry[0];
|
|
51
|
+
removeMarks(editor, n);
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
exports.clearStyles = clearStyles;
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.default = void 0;
|
|
8
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
9
|
+
var _commons = require("../../../commons");
|
|
10
|
+
var _constants = require("../../../constants");
|
|
11
|
+
var _helpers = require("../helpers");
|
|
12
|
+
const menuConfig = _constants.MENUS_CONFIG_MAP[_constants.CLEAR_FORMAT];
|
|
13
|
+
const ClearFormatMenu = _ref => {
|
|
14
|
+
let {
|
|
15
|
+
isRichEditor,
|
|
16
|
+
className,
|
|
17
|
+
editor,
|
|
18
|
+
readonly
|
|
19
|
+
} = _ref;
|
|
20
|
+
const onMouseDown = (0, _react.useCallback)(() => {
|
|
21
|
+
(0, _helpers.clearStyles)(editor);
|
|
22
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
23
|
+
}, []);
|
|
24
|
+
const props = {
|
|
25
|
+
isRichEditor,
|
|
26
|
+
className,
|
|
27
|
+
ariaLabel: 'clear',
|
|
28
|
+
...menuConfig,
|
|
29
|
+
disabled: (0, _helpers.isMenuDisabled)(editor, readonly),
|
|
30
|
+
isActive: false,
|
|
31
|
+
'onMouseDown': onMouseDown
|
|
32
|
+
};
|
|
33
|
+
return /*#__PURE__*/_react.default.createElement(_commons.MenuItem, props);
|
|
34
|
+
};
|
|
35
|
+
var _default = exports.default = ClearFormatMenu;
|
|
@@ -0,0 +1,206 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.setClipboardCodeBlockData = exports.isMenuDisabled = exports.getValidLang = exports.getSelectedLangOption = exports.getSelectCodeElem = exports.getCodeBlockNode = exports.deleteBackwardByLength = exports.changeToPlainText = exports.changeToCodeBlock = void 0;
|
|
8
|
+
var _slate = require("@seafile/slate");
|
|
9
|
+
var _copyToClipboard = _interopRequireDefault(require("copy-to-clipboard"));
|
|
10
|
+
var _slugid = _interopRequireDefault(require("slugid"));
|
|
11
|
+
var _constants = require("../../constants");
|
|
12
|
+
var _core = require("../../core");
|
|
13
|
+
var _helper = require("../callout/helper");
|
|
14
|
+
var _prismjs = require("./prismjs");
|
|
15
|
+
const isMenuDisabled = (editor, readonly) => {
|
|
16
|
+
if (readonly) return true;
|
|
17
|
+
const {
|
|
18
|
+
selection
|
|
19
|
+
} = editor;
|
|
20
|
+
if (selection === null) return true;
|
|
21
|
+
if ((0, _helper.getCalloutEntry)(editor)) return true;
|
|
22
|
+
const selectedElems = (0, _core.getSelectedElems)(editor);
|
|
23
|
+
const hasVoid = selectedElems.some(elem => editor.isVoid(elem));
|
|
24
|
+
if (hasVoid) return true;
|
|
25
|
+
const isMatch = selectedElems.every(elem => {
|
|
26
|
+
const type = (0, _core.getNodeType)(elem);
|
|
27
|
+
if (type === _constants.PARAGRAPH) return true;
|
|
28
|
+
return false;
|
|
29
|
+
});
|
|
30
|
+
if (isMatch) return false; // enable
|
|
31
|
+
return true; // disable
|
|
32
|
+
};
|
|
33
|
+
exports.isMenuDisabled = isMenuDisabled;
|
|
34
|
+
const getSelectCodeElem = editor => {
|
|
35
|
+
const codeNode = (0, _core.getSelectedNodeByType)(editor, _constants.CODE_BLOCK);
|
|
36
|
+
if (codeNode == null) return null;
|
|
37
|
+
return codeNode;
|
|
38
|
+
};
|
|
39
|
+
exports.getSelectCodeElem = getSelectCodeElem;
|
|
40
|
+
const getCodeBlockNode = language => {
|
|
41
|
+
const node = {
|
|
42
|
+
id: _slugid.default.nice(),
|
|
43
|
+
type: _constants.CODE_BLOCK,
|
|
44
|
+
language,
|
|
45
|
+
style: {
|
|
46
|
+
white_space: 'nowrap'
|
|
47
|
+
},
|
|
48
|
+
// default nowrap
|
|
49
|
+
children: [{
|
|
50
|
+
id: _slugid.default.nice(),
|
|
51
|
+
type: _constants.CODE_LINE,
|
|
52
|
+
children: [{
|
|
53
|
+
text: '',
|
|
54
|
+
id: _slugid.default.nice()
|
|
55
|
+
}]
|
|
56
|
+
}]
|
|
57
|
+
};
|
|
58
|
+
return node;
|
|
59
|
+
};
|
|
60
|
+
exports.getCodeBlockNode = getCodeBlockNode;
|
|
61
|
+
const changeToCodeBlock = function (editor) {
|
|
62
|
+
let language = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
|
|
63
|
+
let position = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : _constants.INSERT_POSITION.CURRENT;
|
|
64
|
+
let isQuickMenu = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
|
|
65
|
+
if (!editor.selection) return;
|
|
66
|
+
let strArr = []; // Summarizes the strings for the selected highest-level node
|
|
67
|
+
const path = _slate.Editor.path(editor, editor.selection, {
|
|
68
|
+
edge: 'start'
|
|
69
|
+
});
|
|
70
|
+
const newCodeBlockNode = getCodeBlockNode(language); // New code-block node
|
|
71
|
+
|
|
72
|
+
// Insert after
|
|
73
|
+
if (position === _constants.INSERT_POSITION.AFTER) {
|
|
74
|
+
strArr = [''];
|
|
75
|
+
newCodeBlockNode.children[0].children[0].text = strArr.join('\n');
|
|
76
|
+
_slate.Transforms.insertNodes(editor, newCodeBlockNode, {
|
|
77
|
+
mode: 'highest',
|
|
78
|
+
at: [path[0] + 1]
|
|
79
|
+
});
|
|
80
|
+
_slate.Transforms.select(editor, [path[0] + 1, 0, 0]);
|
|
81
|
+
return;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
// Insert current
|
|
85
|
+
if (position === _constants.INSERT_POSITION.CURRENT) {
|
|
86
|
+
// Insert codeblock in multi_column
|
|
87
|
+
const currentMultiColumnEntry = (0, _core.getSelectedNodeEntryByType)(editor, _constants.MULTI_COLUMN);
|
|
88
|
+
if (currentMultiColumnEntry) {
|
|
89
|
+
const currentParagraphPath = editor.selection.anchor.path.slice(0, 3);
|
|
90
|
+
const nodeEntry = _slate.Editor.node(editor, currentParagraphPath);
|
|
91
|
+
if (nodeEntry) {
|
|
92
|
+
strArr.push(_slate.Node.string(nodeEntry[0]));
|
|
93
|
+
}
|
|
94
|
+
_slate.Transforms.removeNodes(editor, {
|
|
95
|
+
at: currentParagraphPath
|
|
96
|
+
});
|
|
97
|
+
newCodeBlockNode.children[0].children[0].text = strArr.join('\n');
|
|
98
|
+
_slate.Transforms.insertNodes(editor, newCodeBlockNode, {
|
|
99
|
+
at: currentParagraphPath
|
|
100
|
+
});
|
|
101
|
+
_slate.Transforms.select(editor, _slate.Editor.start(editor, currentParagraphPath));
|
|
102
|
+
return;
|
|
103
|
+
}
|
|
104
|
+
// Select the plain text of the node
|
|
105
|
+
const nodeEntries = _slate.Editor.nodes(editor, {
|
|
106
|
+
match: n => editor.children.includes(n),
|
|
107
|
+
// Matches the selected node at the highest level
|
|
108
|
+
universal: true
|
|
109
|
+
});
|
|
110
|
+
for (let nodeEntry of nodeEntries) {
|
|
111
|
+
const [n] = nodeEntry;
|
|
112
|
+
if (n) strArr.push(_slate.Node.string(n));
|
|
113
|
+
}
|
|
114
|
+
// Deletes the selected node at the highest level
|
|
115
|
+
_slate.Transforms.removeNodes(editor, {
|
|
116
|
+
mode: 'highest'
|
|
117
|
+
});
|
|
118
|
+
|
|
119
|
+
// Modify location
|
|
120
|
+
const atPath = [path[0]];
|
|
121
|
+
const atPoint = {
|
|
122
|
+
anchor: {
|
|
123
|
+
offset: 0,
|
|
124
|
+
path: [path[0], 0, 0]
|
|
125
|
+
},
|
|
126
|
+
focus: {
|
|
127
|
+
offset: 0,
|
|
128
|
+
path: [path[0], 0, 0]
|
|
129
|
+
}
|
|
130
|
+
};
|
|
131
|
+
// Insert new node
|
|
132
|
+
newCodeBlockNode.children[0].children[0].text = strArr.join('\n');
|
|
133
|
+
_slate.Transforms.insertNodes(editor, newCodeBlockNode, {
|
|
134
|
+
mode: 'highest',
|
|
135
|
+
at: atPath
|
|
136
|
+
});
|
|
137
|
+
queueMicrotask(() => {
|
|
138
|
+
if (!isQuickMenu) {
|
|
139
|
+
_slate.Transforms.select(editor, atPoint);
|
|
140
|
+
} else {
|
|
141
|
+
(0, _core.focusEditor)(editor, atPoint);
|
|
142
|
+
}
|
|
143
|
+
});
|
|
144
|
+
}
|
|
145
|
+
};
|
|
146
|
+
exports.changeToCodeBlock = changeToCodeBlock;
|
|
147
|
+
const changeToPlainText = editor => {
|
|
148
|
+
const elem = getSelectCodeElem(editor);
|
|
149
|
+
if (elem == null) return;
|
|
150
|
+
|
|
151
|
+
// Get code text
|
|
152
|
+
const str = _slate.Node.string(elem);
|
|
153
|
+
|
|
154
|
+
// Delete the highest level node, -> "the code-block node"
|
|
155
|
+
_slate.Transforms.removeNodes(editor, {
|
|
156
|
+
mode: 'highest'
|
|
157
|
+
});
|
|
158
|
+
|
|
159
|
+
// Insert p node
|
|
160
|
+
const pList = str.split('\n').map(s => {
|
|
161
|
+
return {
|
|
162
|
+
id: elem.id,
|
|
163
|
+
type: _constants.PARAGRAPH,
|
|
164
|
+
children: [{
|
|
165
|
+
text: s,
|
|
166
|
+
id: _slugid.default.nice()
|
|
167
|
+
}]
|
|
168
|
+
};
|
|
169
|
+
});
|
|
170
|
+
_slate.Transforms.insertNodes(editor, pList, {
|
|
171
|
+
mode: 'highest'
|
|
172
|
+
});
|
|
173
|
+
};
|
|
174
|
+
exports.changeToPlainText = changeToPlainText;
|
|
175
|
+
const setClipboardCodeBlockData = value => {
|
|
176
|
+
// Insert text into the clipboard for use on other pages
|
|
177
|
+
// Empty string cannot apply in `copy`
|
|
178
|
+
const text = value.children.map(line => _slate.Node.string(line)).join('\n') || ' ';
|
|
179
|
+
(0, _copyToClipboard.default)(text, {
|
|
180
|
+
format: 'text/plain',
|
|
181
|
+
onCopy: data => {
|
|
182
|
+
// Set the sdoc editor to format the data
|
|
183
|
+
data.setData('text/code-block', JSON.stringify(value));
|
|
184
|
+
}
|
|
185
|
+
});
|
|
186
|
+
};
|
|
187
|
+
exports.setClipboardCodeBlockData = setClipboardCodeBlockData;
|
|
188
|
+
const deleteBackwardByLength = (editor, len) => {
|
|
189
|
+
let i = len >= 4 ? 4 : len;
|
|
190
|
+
while (i > 0) {
|
|
191
|
+
_slate.Editor.deleteBackward(editor, 'word');
|
|
192
|
+
i--;
|
|
193
|
+
}
|
|
194
|
+
};
|
|
195
|
+
exports.deleteBackwardByLength = deleteBackwardByLength;
|
|
196
|
+
const getSelectedLangOption = lang => {
|
|
197
|
+
const langs = (0, _prismjs.genCodeLangs)();
|
|
198
|
+
const selectedLangOption = langs.find(item => item.value === lang);
|
|
199
|
+
return selectedLangOption || langs[0];
|
|
200
|
+
};
|
|
201
|
+
exports.getSelectedLangOption = getSelectedLangOption;
|
|
202
|
+
const getValidLang = lang => {
|
|
203
|
+
const langOption = getSelectedLangOption(lang);
|
|
204
|
+
return langOption.value;
|
|
205
|
+
};
|
|
206
|
+
exports.getValidLang = getValidLang;
|