@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,275 @@
|
|
|
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 _urlParse = _interopRequireDefault(require("url-parse"));
|
|
10
|
+
var _sdocServerApi = _interopRequireDefault(require("./api/sdoc-server-api"));
|
|
11
|
+
var _seafileApi = _interopRequireDefault(require("./api/seafile-api"));
|
|
12
|
+
class Context {
|
|
13
|
+
constructor() {
|
|
14
|
+
(0, _defineProperty2.default)(this, "initSettings", () => {
|
|
15
|
+
this.settings = window.seafile ? window.seafile : window.seafileConfig;
|
|
16
|
+
const {
|
|
17
|
+
name,
|
|
18
|
+
username,
|
|
19
|
+
avatarURL
|
|
20
|
+
} = this.settings;
|
|
21
|
+
const userInfo = {
|
|
22
|
+
name,
|
|
23
|
+
username,
|
|
24
|
+
avatar_url: avatarURL
|
|
25
|
+
};
|
|
26
|
+
this.user = userInfo;
|
|
27
|
+
if (this.settings['isSdocRevision']) {
|
|
28
|
+
const repoID = this.getSetting('repoID');
|
|
29
|
+
const siteRoot = this.getSetting('siteRoot');
|
|
30
|
+
const originFilePath = this.getSetting('originFilePath');
|
|
31
|
+
const originFileURL = `${siteRoot}lib/${repoID}/file${originFilePath}`;
|
|
32
|
+
this.settings['originFileURL'] = originFileURL;
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
(0, _defineProperty2.default)(this, "uploadLocalImage", imageFiles => {
|
|
36
|
+
const docUuid = this.getSetting('docUuid');
|
|
37
|
+
return this.api.uploadSdocImage(docUuid, imageFiles).then(res => {
|
|
38
|
+
const {
|
|
39
|
+
relative_path
|
|
40
|
+
} = res.data;
|
|
41
|
+
return relative_path;
|
|
42
|
+
});
|
|
43
|
+
});
|
|
44
|
+
(0, _defineProperty2.default)(this, "uploadLocalVideo", videoFiles => {
|
|
45
|
+
const docUuid = this.getSetting('docUuid');
|
|
46
|
+
return this.api.uploadSdocVideo(docUuid, videoFiles).then(res => {
|
|
47
|
+
const {
|
|
48
|
+
relative_path
|
|
49
|
+
} = res.data;
|
|
50
|
+
return relative_path;
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
this.settings = null;
|
|
54
|
+
this.sdocServerApi = null;
|
|
55
|
+
this.api = null;
|
|
56
|
+
this.config = null;
|
|
57
|
+
}
|
|
58
|
+
initApi() {
|
|
59
|
+
this.initSettings(); // lazy init context class
|
|
60
|
+
const server = this.getSetting('serviceUrl');
|
|
61
|
+
const token = this.getSetting('accessToken');
|
|
62
|
+
this.api = new _seafileApi.default(server, token);
|
|
63
|
+
const isOpenSocket = this.getSetting('isOpenSocket');
|
|
64
|
+
if (isOpenSocket) {
|
|
65
|
+
this.sdocServerApi = new _sdocServerApi.default(this.settings);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
getSettings() {
|
|
69
|
+
return this.settings;
|
|
70
|
+
}
|
|
71
|
+
getSetting(key) {
|
|
72
|
+
if (this.settings[key] === false) return this.settings[key];
|
|
73
|
+
return this.settings[key] || '';
|
|
74
|
+
}
|
|
75
|
+
getPrintCss() {
|
|
76
|
+
const server = this.getSetting('serviceUrl');
|
|
77
|
+
const mediaUrl = this.getSetting('mediaUrl');
|
|
78
|
+
// const commonCss = `${server}${mediaUrl}css/seafile-ui.css`;
|
|
79
|
+
const fontCss = `${server}${mediaUrl}/sdoc-editor/sdoc-editor-font.css`;
|
|
80
|
+
return [fontCss];
|
|
81
|
+
}
|
|
82
|
+
updateSettings(update) {
|
|
83
|
+
for (let key in update) {
|
|
84
|
+
this.settings[key] = update[key];
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
getEditorConfig() {
|
|
88
|
+
// When you need to execute this function, make sure to get the latest configuration items
|
|
89
|
+
const {
|
|
90
|
+
docUuid,
|
|
91
|
+
accessToken,
|
|
92
|
+
sdocServer
|
|
93
|
+
} = this.getSettings();
|
|
94
|
+
this.config = {
|
|
95
|
+
docUuid,
|
|
96
|
+
accessToken,
|
|
97
|
+
sdocServer: new _urlParse.default(sdocServer).origin,
|
|
98
|
+
user: this.getUserInfo()
|
|
99
|
+
};
|
|
100
|
+
return this.config;
|
|
101
|
+
}
|
|
102
|
+
getFileContent() {
|
|
103
|
+
return this.sdocServerApi.getDocContent().then(res => {
|
|
104
|
+
this.settings['last_modify_user'] = res.data.last_modify_user;
|
|
105
|
+
return res;
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
normalizeSdocContent() {
|
|
109
|
+
return this.sdocServerApi.normalizeSdocContent();
|
|
110
|
+
}
|
|
111
|
+
saveContent(content) {
|
|
112
|
+
return this.sdocServerApi.saveDocContent(content);
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
/**
|
|
116
|
+
* @private Get DocUuid
|
|
117
|
+
*/
|
|
118
|
+
getDocUuid() {
|
|
119
|
+
return this.getSetting('docUuid');
|
|
120
|
+
}
|
|
121
|
+
getCollaborators() {
|
|
122
|
+
return this.sdocServerApi.getCollaborators();
|
|
123
|
+
}
|
|
124
|
+
getUserInfo() {
|
|
125
|
+
return this.user;
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
// comments
|
|
129
|
+
listComments() {
|
|
130
|
+
return this.sdocServerApi.listComments();
|
|
131
|
+
}
|
|
132
|
+
insertComment(comment) {
|
|
133
|
+
return this.sdocServerApi.insertComment(comment);
|
|
134
|
+
}
|
|
135
|
+
deleteComment(commentId) {
|
|
136
|
+
return this.sdocServerApi.deleteComment(commentId);
|
|
137
|
+
}
|
|
138
|
+
updateComment(commentId, newComment) {
|
|
139
|
+
return this.sdocServerApi.updateComment(commentId, newComment);
|
|
140
|
+
}
|
|
141
|
+
insertReply(commentId, reply) {
|
|
142
|
+
return this.sdocServerApi.insertReply(commentId, reply);
|
|
143
|
+
}
|
|
144
|
+
deleteReply(commentId, replyId) {
|
|
145
|
+
return this.sdocServerApi.deleteReply(commentId, replyId);
|
|
146
|
+
}
|
|
147
|
+
updateReply(commentId, replyId, newReply) {
|
|
148
|
+
return this.sdocServerApi.updateReply(commentId, replyId, newReply);
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
// revision
|
|
152
|
+
startRevise() {
|
|
153
|
+
const repoID = this.getSetting('repoID');
|
|
154
|
+
const filePath = this.getSetting('docPath');
|
|
155
|
+
const fileUuid = this.getSetting('docUuid');
|
|
156
|
+
return this.api.startRevise(repoID, fileUuid, filePath);
|
|
157
|
+
}
|
|
158
|
+
getSeadocOriginFileContent() {
|
|
159
|
+
const docUuid = this.getSetting('docUuid');
|
|
160
|
+
return this.api.getSeadocOriginFileContent(docUuid);
|
|
161
|
+
}
|
|
162
|
+
getSdocRevisionsCount() {
|
|
163
|
+
const docUuid = this.getSetting('docUuid');
|
|
164
|
+
return this.api.getSdocRevisionsCount(docUuid);
|
|
165
|
+
}
|
|
166
|
+
getSdocRevisions(page, perPage) {
|
|
167
|
+
const docUuid = this.getSetting('docUuid');
|
|
168
|
+
return this.api.getSdocRevisions(docUuid, page, perPage);
|
|
169
|
+
}
|
|
170
|
+
publishRevision() {
|
|
171
|
+
const docUuid = this.getSetting('docUuid');
|
|
172
|
+
return this.api.publishRevision(docUuid);
|
|
173
|
+
}
|
|
174
|
+
updateSdocRevision(sdocContent) {
|
|
175
|
+
const docUuid = this.getSetting('docUuid');
|
|
176
|
+
const docName = this.getSetting('docName');
|
|
177
|
+
return this.api.updateSdocRevision(docUuid, docName, sdocContent);
|
|
178
|
+
}
|
|
179
|
+
deleteSdocRevision() {
|
|
180
|
+
const docUuid = this.getSetting('docUuid');
|
|
181
|
+
return this.api.deleteSdocRevision(docUuid);
|
|
182
|
+
}
|
|
183
|
+
deleteSdocOtherRevision(revisionId) {
|
|
184
|
+
const docUuid = this.getSetting('docUuid');
|
|
185
|
+
return this.api.deleteSdocOtherRevision(docUuid, revisionId);
|
|
186
|
+
}
|
|
187
|
+
getRevisionBaseVersionContent() {
|
|
188
|
+
const docUuid = this.getSetting('docUuid');
|
|
189
|
+
return this.api.getRevisionBaseVersionContent(docUuid);
|
|
190
|
+
}
|
|
191
|
+
getPublishedRevisionContent() {
|
|
192
|
+
const docUuid = this.getSetting('docUuid');
|
|
193
|
+
return this.api.getPublishedRevisionContent(docUuid);
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
// local files
|
|
197
|
+
getSdocLocalFiles(p, type) {
|
|
198
|
+
const docUuid = this.getSetting('docUuid');
|
|
199
|
+
return this.api.getSdocFiles(docUuid, p, type);
|
|
200
|
+
}
|
|
201
|
+
getSdocLocalFileId(p) {
|
|
202
|
+
const docUuid = this.getSetting('docUuid');
|
|
203
|
+
return this.api.getSdocFileId(docUuid, p);
|
|
204
|
+
}
|
|
205
|
+
getSdocLocalFileUrl(docUuid) {
|
|
206
|
+
const sdocServer = this.getSetting('serviceUrl');
|
|
207
|
+
return sdocServer + '/api/v2.1/seadoc/file/' + docUuid + '/?doc_uuid=' + docUuid;
|
|
208
|
+
}
|
|
209
|
+
copyImage(originDocUuid, imageList) {
|
|
210
|
+
const docUuid = this.getSetting('docUuid');
|
|
211
|
+
return this.api.asyncCopyImages(docUuid, originDocUuid, imageList);
|
|
212
|
+
}
|
|
213
|
+
getLinkFilesInfo(filesUrl) {
|
|
214
|
+
const docUuid = this.getSetting('docUuid');
|
|
215
|
+
return this.api.getLinkFilesInfo(docUuid, filesUrl);
|
|
216
|
+
}
|
|
217
|
+
getCopyMoveProgressView(taskId) {
|
|
218
|
+
const docUuid = this.getSetting('docUuid');
|
|
219
|
+
return this.api.getCopyMoveProgressView(docUuid, taskId);
|
|
220
|
+
}
|
|
221
|
+
searchSdocFiles(query, page, per_page) {
|
|
222
|
+
const docUuid = this.getSetting('docUuid');
|
|
223
|
+
return this.api.searchSdocFiles(docUuid, query, page, per_page);
|
|
224
|
+
}
|
|
225
|
+
getSearchFilesByFilename(query, page, per_page, search_type) {
|
|
226
|
+
const docUuid = this.getSetting('docUuid');
|
|
227
|
+
return this.api.searchFilesByFilename(docUuid, query, page, per_page, search_type);
|
|
228
|
+
}
|
|
229
|
+
|
|
230
|
+
// participants
|
|
231
|
+
listParticipants() {
|
|
232
|
+
const docUuid = this.getSetting('docUuid');
|
|
233
|
+
return this.api.listParticipants(docUuid);
|
|
234
|
+
}
|
|
235
|
+
addParticipants(emails) {
|
|
236
|
+
const docUuid = this.getSetting('docUuid');
|
|
237
|
+
return this.api.addParticipants(docUuid, emails);
|
|
238
|
+
}
|
|
239
|
+
deleteParticipants(emails) {
|
|
240
|
+
const docUuid = this.getSetting('docUuid');
|
|
241
|
+
return this.api.deleteParticipants(docUuid, emails);
|
|
242
|
+
}
|
|
243
|
+
listRelatedUsers() {
|
|
244
|
+
const docUuid = this.getSetting('docUuid');
|
|
245
|
+
return this.api.listRelatedUsers(docUuid);
|
|
246
|
+
}
|
|
247
|
+
|
|
248
|
+
// notification
|
|
249
|
+
listUnseenNotifications() {
|
|
250
|
+
const docUuid = this.getDocUuid();
|
|
251
|
+
return this.api.listUnseenNotifications(docUuid);
|
|
252
|
+
}
|
|
253
|
+
deleteUnseenNotifications(notificationIds) {
|
|
254
|
+
const docUuid = this.getDocUuid();
|
|
255
|
+
return this.api.deleteUnseenNotifications(docUuid, notificationIds);
|
|
256
|
+
}
|
|
257
|
+
readAllNotifications() {
|
|
258
|
+
const docUuid = this.getDocUuid();
|
|
259
|
+
return this.api.readAllNotifications(docUuid);
|
|
260
|
+
}
|
|
261
|
+
aiTranslate(text, lang) {
|
|
262
|
+
const docUuid = this.getDocUuid();
|
|
263
|
+
return this.api.aiTranslate(docUuid, text, lang);
|
|
264
|
+
}
|
|
265
|
+
writingAssistant(text, type, custom_prompt) {
|
|
266
|
+
const docUuid = this.getDocUuid();
|
|
267
|
+
return this.api.writingAssistant(docUuid, text, type, custom_prompt);
|
|
268
|
+
}
|
|
269
|
+
updateConfigUuid(docUuid) {
|
|
270
|
+
if (!this.config) return;
|
|
271
|
+
this.config['docUuid'] = docUuid;
|
|
272
|
+
}
|
|
273
|
+
}
|
|
274
|
+
const context = new Context();
|
|
275
|
+
var _default = exports.default = context;
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.setCursor = exports.generateCursorData = exports.deleteCursor = void 0;
|
|
8
|
+
var _randomcolor = _interopRequireDefault(require("randomcolor"));
|
|
9
|
+
// selection: { anchor, focus }
|
|
10
|
+
// cursor: { anchor, focus }
|
|
11
|
+
|
|
12
|
+
const setCursor = (editor, user, location, cursorData) => {
|
|
13
|
+
const {
|
|
14
|
+
username: clientId
|
|
15
|
+
} = user;
|
|
16
|
+
if (!editor.cursors) editor.cursors = {};
|
|
17
|
+
if (location) {
|
|
18
|
+
const oldCursor = editor.cursors[clientId] ? editor.cursors[clientId] : {};
|
|
19
|
+
const newCursorData = {
|
|
20
|
+
...oldCursor,
|
|
21
|
+
...location,
|
|
22
|
+
...cursorData
|
|
23
|
+
};
|
|
24
|
+
editor.cursors[clientId] = newCursorData;
|
|
25
|
+
} else {
|
|
26
|
+
delete editor.cursors[clientId];
|
|
27
|
+
}
|
|
28
|
+
editor.cursors = {
|
|
29
|
+
...editor.cursors
|
|
30
|
+
};
|
|
31
|
+
return editor;
|
|
32
|
+
};
|
|
33
|
+
exports.setCursor = setCursor;
|
|
34
|
+
const deleteCursor = (editor, username) => {
|
|
35
|
+
delete editor.cursors[username];
|
|
36
|
+
editor.cursors = {
|
|
37
|
+
...editor.cursors
|
|
38
|
+
};
|
|
39
|
+
return editor;
|
|
40
|
+
};
|
|
41
|
+
exports.deleteCursor = deleteCursor;
|
|
42
|
+
const generateCursorData = config => {
|
|
43
|
+
const {
|
|
44
|
+
user
|
|
45
|
+
} = config;
|
|
46
|
+
const options = {
|
|
47
|
+
luminosity: 'dark',
|
|
48
|
+
format: 'rgba',
|
|
49
|
+
alpha: 1
|
|
50
|
+
};
|
|
51
|
+
const color = (0, _randomcolor.default)(options);
|
|
52
|
+
return {
|
|
53
|
+
name: user.name,
|
|
54
|
+
cursor_color: color
|
|
55
|
+
};
|
|
56
|
+
};
|
|
57
|
+
exports.generateCursorData = generateCursorData;
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.useCursors = void 0;
|
|
7
|
+
var _react = require("react");
|
|
8
|
+
const useCursors = editor => {
|
|
9
|
+
const [cursors, setCursors] = (0, _react.useState)([]);
|
|
10
|
+
(0, _react.useEffect)(() => {
|
|
11
|
+
const cursors = Object.values(editor.cursors) || [];
|
|
12
|
+
setCursors(cursors);
|
|
13
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
14
|
+
}, []);
|
|
15
|
+
(0, _react.useEffect)(() => {
|
|
16
|
+
editor.onCursor = editorCursors => {
|
|
17
|
+
const cursors = Object.values(editorCursors) || [];
|
|
18
|
+
setCursors(cursors);
|
|
19
|
+
};
|
|
20
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
21
|
+
}, []);
|
|
22
|
+
return {
|
|
23
|
+
cursors,
|
|
24
|
+
setCursors
|
|
25
|
+
};
|
|
26
|
+
};
|
|
27
|
+
exports.useCursors = useCursors;
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.usePipDecorate = void 0;
|
|
8
|
+
var _commentDecorate = require("../comment/comment-decorate");
|
|
9
|
+
var _highlight = require("../highlight");
|
|
10
|
+
var _useSelectionUpdate = _interopRequireDefault(require("../hooks/use-selection-update"));
|
|
11
|
+
const pluginDecorates = [_highlight.highlightDecorate, _commentDecorate.commentDecorate];
|
|
12
|
+
const usePipDecorate = editor => {
|
|
13
|
+
(0, _useSelectionUpdate.default)();
|
|
14
|
+
const decorates = pluginDecorates.map(decorate => {
|
|
15
|
+
return decorate(editor);
|
|
16
|
+
});
|
|
17
|
+
return entry => {
|
|
18
|
+
let ranges = [];
|
|
19
|
+
const addRanges = newRanges => {
|
|
20
|
+
if (newRanges !== null && newRanges !== void 0 && newRanges.length) ranges = [...ranges, ...newRanges];
|
|
21
|
+
};
|
|
22
|
+
decorates.forEach(decorate => {
|
|
23
|
+
addRanges(decorate(entry));
|
|
24
|
+
});
|
|
25
|
+
return ranges;
|
|
26
|
+
};
|
|
27
|
+
};
|
|
28
|
+
exports.usePipDecorate = usePipDecorate;
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.default = void 0;
|
|
9
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
10
|
+
var _slate = require("@seafile/slate");
|
|
11
|
+
var _slateReact = require("@seafile/slate-react");
|
|
12
|
+
var _isHotkey = _interopRequireDefault(require("is-hotkey"));
|
|
13
|
+
var _scrollIntoViewIfNeeded = _interopRequireDefault(require("scroll-into-view-if-needed"));
|
|
14
|
+
var _constants = require("../constants");
|
|
15
|
+
var _useCursors = require("../cursor/use-cursors");
|
|
16
|
+
var _decorates = require("../decorates");
|
|
17
|
+
var _extension = require("../extension");
|
|
18
|
+
var _constants2 = require("../extension/constants");
|
|
19
|
+
var _renderCommentEditorElement = _interopRequireDefault(require("../extension/render/render-comment-editor-element"));
|
|
20
|
+
var _eventBus = _interopRequireDefault(require("../utils/event-bus"));
|
|
21
|
+
var _eventHandler = _interopRequireDefault(require("../utils/event-handler"));
|
|
22
|
+
const CommentArticle = _ref => {
|
|
23
|
+
let {
|
|
24
|
+
editor,
|
|
25
|
+
slateValue,
|
|
26
|
+
updateSlateValue,
|
|
27
|
+
type
|
|
28
|
+
} = _ref;
|
|
29
|
+
const {
|
|
30
|
+
cursors
|
|
31
|
+
} = (0, _useCursors.useCursors)(editor);
|
|
32
|
+
const decorate = (0, _decorates.usePipDecorate)(editor);
|
|
33
|
+
// init eventHandler
|
|
34
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
35
|
+
const eventProxy = (0, _react.useMemo)(() => new _eventHandler.default(editor), []);
|
|
36
|
+
const onMouseDown = (0, _react.useCallback)(event => {
|
|
37
|
+
if (event.button === 0) {
|
|
38
|
+
// Compatible with the editor which unload table plugin
|
|
39
|
+
editor.reSetTableSelectedRange && editor.reSetTableSelectedRange();
|
|
40
|
+
const eventBus = _eventBus.default.getInstance();
|
|
41
|
+
eventBus.dispatch(_constants.INTERNAL_EVENT.CANCEL_TABLE_SELECT_RANGE);
|
|
42
|
+
}
|
|
43
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
44
|
+
}, []);
|
|
45
|
+
const handleScrollIntoView = (0, _react.useCallback)((editor, domRange) => {
|
|
46
|
+
try {
|
|
47
|
+
const {
|
|
48
|
+
selection
|
|
49
|
+
} = editor;
|
|
50
|
+
// Do not scroll into view, when focus on image
|
|
51
|
+
const [imageNodeEntry] = _slate.Editor.nodes(editor, {
|
|
52
|
+
match: n => [_constants2.IMAGE, _constants2.IMAGE_BLOCK].includes(n.type),
|
|
53
|
+
at: selection
|
|
54
|
+
});
|
|
55
|
+
if (imageNodeEntry) return;
|
|
56
|
+
const focusedNode = _slate.Node.get(editor, selection.focus.path);
|
|
57
|
+
const domNode = _slateReact.ReactEditor.toDOMNode(editor, focusedNode);
|
|
58
|
+
if (!domNode) return;
|
|
59
|
+
(0, _scrollIntoViewIfNeeded.default)(domNode, {
|
|
60
|
+
'scrollMode': 'if-needed'
|
|
61
|
+
});
|
|
62
|
+
} catch (error) {
|
|
63
|
+
//
|
|
64
|
+
}
|
|
65
|
+
}, []);
|
|
66
|
+
const onKeyDown = (0, _react.useCallback)(event => {
|
|
67
|
+
if ((0, _isHotkey.default)('enter', event)) {
|
|
68
|
+
event.preventDefault();
|
|
69
|
+
const eventBus = _eventBus.default.getInstance();
|
|
70
|
+
eventBus.dispatch(_constants.INTERNAL_EVENT.COMMENT_EDITOR_POST_COMMENT, event);
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
73
|
+
if ((0, _isHotkey.default)('shift+enter', event)) {
|
|
74
|
+
event.preventDefault();
|
|
75
|
+
_slate.Editor.insertBreak(editor);
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
eventProxy.onKeyDown(event);
|
|
79
|
+
}, [eventProxy, editor]);
|
|
80
|
+
return /*#__PURE__*/_react.default.createElement(_slateReact.Slate, {
|
|
81
|
+
editor: editor,
|
|
82
|
+
value: slateValue,
|
|
83
|
+
onChange: updateSlateValue
|
|
84
|
+
}, /*#__PURE__*/_react.default.createElement(_slateReact.Editable, {
|
|
85
|
+
id: "sdoc-editor",
|
|
86
|
+
scrollSelectionIntoView: handleScrollIntoView,
|
|
87
|
+
cursors: cursors,
|
|
88
|
+
renderElement: props => (0, _renderCommentEditorElement.default)({
|
|
89
|
+
...props,
|
|
90
|
+
commentType: type
|
|
91
|
+
}),
|
|
92
|
+
renderLeaf: _extension.renderLeaf,
|
|
93
|
+
onMouseDown: onMouseDown,
|
|
94
|
+
decorate: decorate,
|
|
95
|
+
onCut: eventProxy.onCut,
|
|
96
|
+
onCopy: eventProxy.onCopy,
|
|
97
|
+
onCompositionStart: eventProxy.onCompositionStart,
|
|
98
|
+
onCompositionUpdate: eventProxy.onCompositionUpdate,
|
|
99
|
+
onCompositionEnd: eventProxy.onCompositionEnd,
|
|
100
|
+
onKeyDown: onKeyDown,
|
|
101
|
+
onBeforeInput: eventProxy.onBeforeInput
|
|
102
|
+
}));
|
|
103
|
+
};
|
|
104
|
+
var _default = exports.default = CommentArticle;
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.default = void 0;
|
|
9
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
10
|
+
var _slate = require("@seafile/slate");
|
|
11
|
+
var _deepCopy = _interopRequireDefault(require("deep-copy"));
|
|
12
|
+
var _fileLoading = _interopRequireDefault(require("../components/file-loading"));
|
|
13
|
+
var _constants = require("../constants");
|
|
14
|
+
var _context = _interopRequireDefault(require("../context"));
|
|
15
|
+
var _extension = require("../extension");
|
|
16
|
+
var _core = require("../extension/core");
|
|
17
|
+
var _commentEditorToolbar = _interopRequireDefault(require("../extension/toolbar/comment-editor-toolbar"));
|
|
18
|
+
var _useCollaborators = require("../hooks/use-collaborators");
|
|
19
|
+
var _useScrollContext = require("../hooks/use-scroll-context");
|
|
20
|
+
var _layout = require("../layout");
|
|
21
|
+
var _nodeId = _interopRequireDefault(require("../node-id"));
|
|
22
|
+
var _socket = require("../socket");
|
|
23
|
+
var _commentArticle = _interopRequireDefault(require("./comment-article"));
|
|
24
|
+
const SdocCommentEditor = /*#__PURE__*/(0, _react.forwardRef)((_ref, ref) => {
|
|
25
|
+
let {
|
|
26
|
+
editor: propsEditor,
|
|
27
|
+
document,
|
|
28
|
+
isReloading,
|
|
29
|
+
type,
|
|
30
|
+
onSubmit,
|
|
31
|
+
submitBtnText,
|
|
32
|
+
onCancel
|
|
33
|
+
} = _ref;
|
|
34
|
+
const [slateValue, setSlateValue] = (0, _react.useState)(document.elements);
|
|
35
|
+
const commentEditorContainerRef = (0, _react.useRef)(null);
|
|
36
|
+
const validEditor = (0, _react.useMemo)(() => {
|
|
37
|
+
if (propsEditor) return propsEditor;
|
|
38
|
+
const defaultEditor = (0, _extension.createCommentEditor)();
|
|
39
|
+
const editorConfig = _context.default.getEditorConfig();
|
|
40
|
+
const newEditor = (0, _nodeId.default)((0, _socket.withSocketIO)(defaultEditor, {
|
|
41
|
+
document,
|
|
42
|
+
config: editorConfig
|
|
43
|
+
}));
|
|
44
|
+
const {
|
|
45
|
+
cursors
|
|
46
|
+
} = document;
|
|
47
|
+
newEditor.cursors = cursors || {};
|
|
48
|
+
newEditor.width = _constants.COMMENT_EDITOR_EDIT_AREA_WIDTH; // default width
|
|
49
|
+
|
|
50
|
+
return newEditor;
|
|
51
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
52
|
+
}, []);
|
|
53
|
+
|
|
54
|
+
// useMount: focus editor
|
|
55
|
+
(0, _react.useEffect)(() => {
|
|
56
|
+
const [firstNode] = validEditor.children;
|
|
57
|
+
if (firstNode) {
|
|
58
|
+
const [firstNodeFirstChild] = firstNode.children;
|
|
59
|
+
if (firstNodeFirstChild) {
|
|
60
|
+
const endOfFirstNode = _slate.Editor.end(validEditor, [0, 0]);
|
|
61
|
+
const range = {
|
|
62
|
+
anchor: endOfFirstNode,
|
|
63
|
+
focus: endOfFirstNode
|
|
64
|
+
};
|
|
65
|
+
(0, _core.focusEditor)(validEditor, range);
|
|
66
|
+
}
|
|
67
|
+
// Force refresh to fix comment list
|
|
68
|
+
setSlateValue([...validEditor.children]);
|
|
69
|
+
}
|
|
70
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
71
|
+
}, []);
|
|
72
|
+
|
|
73
|
+
// The parent component can call the method of this component through ref
|
|
74
|
+
(0, _react.useImperativeHandle)(ref, () => ({
|
|
75
|
+
setSlateValue: document => {
|
|
76
|
+
// Force update of editor's child elements
|
|
77
|
+
validEditor.children = document.elements;
|
|
78
|
+
setSlateValue([...document.elements]);
|
|
79
|
+
},
|
|
80
|
+
updateDocumentVersion: document => {
|
|
81
|
+
validEditor.updateDocumentVersion(document);
|
|
82
|
+
},
|
|
83
|
+
// get value
|
|
84
|
+
getSlateValue: () => {
|
|
85
|
+
return (0, _deepCopy.default)({
|
|
86
|
+
...document,
|
|
87
|
+
elements: slateValue
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
92
|
+
}), [document, validEditor, slateValue]);
|
|
93
|
+
if (isReloading) {
|
|
94
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
95
|
+
className: "h-100 w-100 d-flex align-items-center justify-content-center"
|
|
96
|
+
}, /*#__PURE__*/_react.default.createElement(_fileLoading.default, null));
|
|
97
|
+
}
|
|
98
|
+
const handleFocusEditor = e => {
|
|
99
|
+
if (e.target === commentEditorContainerRef.current) {
|
|
100
|
+
const focusPoint = _slate.Editor.end(validEditor, []);
|
|
101
|
+
(0, _core.focusEditor)(validEditor, focusPoint);
|
|
102
|
+
}
|
|
103
|
+
};
|
|
104
|
+
return /*#__PURE__*/_react.default.createElement(_layout.EditorContainer, {
|
|
105
|
+
editor: validEditor
|
|
106
|
+
}, /*#__PURE__*/_react.default.createElement(_useCollaborators.CollaboratorsProvider, null, /*#__PURE__*/_react.default.createElement("div", {
|
|
107
|
+
className: "sdoc-comment-editor-wrapper"
|
|
108
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
109
|
+
ref: commentEditorContainerRef,
|
|
110
|
+
className: "article sdoc-comment-editor",
|
|
111
|
+
onClick: handleFocusEditor
|
|
112
|
+
}, /*#__PURE__*/_react.default.createElement(_useScrollContext.ScrollContext.Provider, {
|
|
113
|
+
value: {
|
|
114
|
+
scrollRef: commentEditorContainerRef
|
|
115
|
+
}
|
|
116
|
+
}, /*#__PURE__*/_react.default.createElement(_commentArticle.default, {
|
|
117
|
+
type: type,
|
|
118
|
+
editor: validEditor,
|
|
119
|
+
slateValue: slateValue,
|
|
120
|
+
updateSlateValue: setSlateValue
|
|
121
|
+
}))), /*#__PURE__*/_react.default.createElement(_commentEditorToolbar.default, {
|
|
122
|
+
editor: validEditor,
|
|
123
|
+
onSubmit: onSubmit,
|
|
124
|
+
submitBtnText: submitBtnText,
|
|
125
|
+
onCancel: onCancel
|
|
126
|
+
}))));
|
|
127
|
+
});
|
|
128
|
+
var _default = exports.default = SdocCommentEditor;
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.default = void 0;
|
|
9
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
10
|
+
var _provider = _interopRequireDefault(require("../comment/provider"));
|
|
11
|
+
var _constants = require("../constants");
|
|
12
|
+
var _context = _interopRequireDefault(require("../context"));
|
|
13
|
+
var _extension = require("../extension");
|
|
14
|
+
var _nodeId = _interopRequireDefault(require("../node-id"));
|
|
15
|
+
var _rightPanel = _interopRequireDefault(require("../right-panel"));
|
|
16
|
+
var _socket = require("../socket");
|
|
17
|
+
const SdocEditor = /*#__PURE__*/(0, _react.forwardRef)((_ref, ref) => {
|
|
18
|
+
let {
|
|
19
|
+
editor: propsEditor,
|
|
20
|
+
document,
|
|
21
|
+
isReloading,
|
|
22
|
+
showComment,
|
|
23
|
+
isShowHeaderToolbar = true,
|
|
24
|
+
showOutline = true
|
|
25
|
+
} = _ref;
|
|
26
|
+
const validEditor = (0, _react.useMemo)(() => {
|
|
27
|
+
if (propsEditor) return propsEditor;
|
|
28
|
+
const defaultEditor = (0, _extension.createDefaultEditor)();
|
|
29
|
+
const editorConfig = _context.default.getEditorConfig();
|
|
30
|
+
const newEditor = (0, _nodeId.default)((0, _socket.withSocketIO)(defaultEditor, {
|
|
31
|
+
document,
|
|
32
|
+
config: editorConfig
|
|
33
|
+
}));
|
|
34
|
+
const {
|
|
35
|
+
cursors
|
|
36
|
+
} = document;
|
|
37
|
+
newEditor.cursors = cursors || {};
|
|
38
|
+
newEditor.width = _constants.PAGE_EDIT_AREA_WIDTH; // default width
|
|
39
|
+
return newEditor;
|
|
40
|
+
|
|
41
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
42
|
+
}, []);
|
|
43
|
+
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_provider.default, {
|
|
44
|
+
children: _rightPanel.default,
|
|
45
|
+
editor: validEditor
|
|
46
|
+
}, /*#__PURE__*/_react.default.createElement(_rightPanel.default, {
|
|
47
|
+
editor: validEditor
|
|
48
|
+
})));
|
|
49
|
+
});
|
|
50
|
+
var _default = exports.default = SdocEditor;
|
|
@@ -0,0 +1,17 @@
|
|
|
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 _react = _interopRequireDefault(require("react"));
|
|
9
|
+
const InlineBugFixer = () => {
|
|
10
|
+
return /*#__PURE__*/_react.default.createElement("span", {
|
|
11
|
+
contentEditable: false,
|
|
12
|
+
style: {
|
|
13
|
+
fontSize: 0
|
|
14
|
+
}
|
|
15
|
+
}, String.fromCodePoint(160) /* Non-breaking space */);
|
|
16
|
+
};
|
|
17
|
+
var _default = exports.default = InlineBugFixer;
|