@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,212 @@
|
|
|
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 _reactI18next = require("react-i18next");
|
|
11
|
+
var _reactstrap = require("reactstrap");
|
|
12
|
+
var _classnames = _interopRequireDefault(require("classnames"));
|
|
13
|
+
var _dayjs = _interopRequireDefault(require("dayjs"));
|
|
14
|
+
var _context = _interopRequireDefault(require("../../../context"));
|
|
15
|
+
var _core = require("../../../extension/core");
|
|
16
|
+
var _constants = require("../../constants");
|
|
17
|
+
var _useCommentList = _interopRequireDefault(require("../../hooks/comment-hooks/use-comment-list"));
|
|
18
|
+
var _commentItemCollapseWrapper = _interopRequireDefault(require("../comment-item-collapse-wrapper"));
|
|
19
|
+
var _commentItemWrapper = _interopRequireDefault(require("../comment-item-wrapper"));
|
|
20
|
+
var _globalCommentBodyHeader = _interopRequireDefault(require("./global-comment-body-header"));
|
|
21
|
+
var _globalCommentEditor = _interopRequireDefault(require("./global-comment-editor"));
|
|
22
|
+
var _globalCommentHeader = _interopRequireDefault(require("./global-comment-header"));
|
|
23
|
+
require("./index.css");
|
|
24
|
+
const GlobalComment = _ref => {
|
|
25
|
+
let {
|
|
26
|
+
editor,
|
|
27
|
+
deleteUnseenNotifications,
|
|
28
|
+
t
|
|
29
|
+
} = _ref;
|
|
30
|
+
const contentRef = (0, _react.useRef)(null);
|
|
31
|
+
const commentDetailRef = (0, _react.useRef)(null);
|
|
32
|
+
const [activeCommentGroup, setActiveCommentGroup] = (0, _react.useState)(null);
|
|
33
|
+
const [showEditor, setShowEditor] = (0, _react.useState)(false);
|
|
34
|
+
const [isScrollDisplayed, setIsScrollDisplayed] = (0, _react.useState)(false);
|
|
35
|
+
const [globalCommentContent, setGlobalCommentContent] = (0, _react.useState)(null);
|
|
36
|
+
const {
|
|
37
|
+
commentList,
|
|
38
|
+
commentType,
|
|
39
|
+
setCommentType,
|
|
40
|
+
dispatch
|
|
41
|
+
} = (0, _useCommentList.default)();
|
|
42
|
+
const detectScroll = (0, _react.useCallback)(() => {
|
|
43
|
+
if (!contentRef.current) return;
|
|
44
|
+
const contentContainer = contentRef.current;
|
|
45
|
+
const isShowScroll = contentContainer.scrollHeight > contentContainer.clientHeight;
|
|
46
|
+
setIsScrollDisplayed(isShowScroll);
|
|
47
|
+
}, []);
|
|
48
|
+
const onCommentsPanelBodyScroll = (0, _react.useCallback)(position => {
|
|
49
|
+
var _contentRef$current, _contentRef$current2;
|
|
50
|
+
(_contentRef$current = contentRef.current) === null || _contentRef$current === void 0 ? void 0 : _contentRef$current.scrollTo({
|
|
51
|
+
top: position === 'top' ? 0 : (_contentRef$current2 = contentRef.current) === null || _contentRef$current2 === void 0 ? void 0 : _contentRef$current2.scrollHeight,
|
|
52
|
+
behavior: 'smooth'
|
|
53
|
+
});
|
|
54
|
+
}, [contentRef]);
|
|
55
|
+
(0, _react.useEffect)(() => {
|
|
56
|
+
detectScroll();
|
|
57
|
+
// When a comment is updated, update the comment details page
|
|
58
|
+
if (activeCommentGroup) {
|
|
59
|
+
const newActiveCommentGroup = commentList.find(item => item.id === activeCommentGroup.id);
|
|
60
|
+
setActiveCommentGroup(newActiveCommentGroup);
|
|
61
|
+
deleteUnseenNotifications && deleteUnseenNotifications(newActiveCommentGroup);
|
|
62
|
+
}
|
|
63
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
64
|
+
}, [commentList, detectScroll]);
|
|
65
|
+
const updateScrollPosition = (0, _react.useCallback)(() => {
|
|
66
|
+
var _contentRef$current3;
|
|
67
|
+
const resolvedDom = document.querySelector('.sdoc-resolved');
|
|
68
|
+
(_contentRef$current3 = contentRef.current) === null || _contentRef$current3 === void 0 ? void 0 : _contentRef$current3.scrollTo({
|
|
69
|
+
top: resolvedDom.offsetTop,
|
|
70
|
+
behavior: 'smooth'
|
|
71
|
+
});
|
|
72
|
+
}, []);
|
|
73
|
+
const insertComment = (0, _react.useCallback)(async (elementId, comment) => {
|
|
74
|
+
const res = await _context.default.insertComment(comment);
|
|
75
|
+
const {
|
|
76
|
+
comment: returnComment
|
|
77
|
+
} = res.data;
|
|
78
|
+
const newComment = {
|
|
79
|
+
...comment,
|
|
80
|
+
id: returnComment.id,
|
|
81
|
+
user_name: returnComment.user_name,
|
|
82
|
+
avatar_url: returnComment.avatar_url,
|
|
83
|
+
replies: []
|
|
84
|
+
};
|
|
85
|
+
dispatch({
|
|
86
|
+
type: 'INSERT_COMMENT',
|
|
87
|
+
payload: {
|
|
88
|
+
element_id: elementId,
|
|
89
|
+
comment: newComment
|
|
90
|
+
}
|
|
91
|
+
});
|
|
92
|
+
}, [dispatch]);
|
|
93
|
+
const insertDocComment = (0, _react.useCallback)(commentDetail => {
|
|
94
|
+
var _commentDetailRef$cur;
|
|
95
|
+
// Reply to a comment
|
|
96
|
+
if (activeCommentGroup && (_commentDetailRef$cur = commentDetailRef.current) !== null && _commentDetailRef$cur !== void 0 && _commentDetailRef$cur.insertContent) {
|
|
97
|
+
commentDetailRef.current.insertContent(commentDetail);
|
|
98
|
+
} else {
|
|
99
|
+
// Insert global comment
|
|
100
|
+
const user = _context.default.getUserInfo();
|
|
101
|
+
const elementId = _constants.DOC_COMMENT_ELEMENT_ID;
|
|
102
|
+
const time = (0, _dayjs.default)().format('YYYY-MM-DD HH:mm:ss');
|
|
103
|
+
const comment = {
|
|
104
|
+
comment: commentDetail,
|
|
105
|
+
detail: {
|
|
106
|
+
element_id: elementId,
|
|
107
|
+
comment: commentDetail
|
|
108
|
+
},
|
|
109
|
+
author: user.username,
|
|
110
|
+
updated_at: time
|
|
111
|
+
};
|
|
112
|
+
insertComment(elementId, comment);
|
|
113
|
+
detectScroll();
|
|
114
|
+
}
|
|
115
|
+
// After the comment is inserted, scroll to the bottom
|
|
116
|
+
setTimeout(() => {
|
|
117
|
+
onCommentsPanelBodyScroll('bottom');
|
|
118
|
+
}, 500);
|
|
119
|
+
}, [activeCommentGroup, detectScroll, insertComment, onCommentsPanelBodyScroll]);
|
|
120
|
+
const hiddenCommentEditor = (0, _react.useCallback)(() => {
|
|
121
|
+
setShowEditor(false);
|
|
122
|
+
}, []);
|
|
123
|
+
const isClickCommentPanelBody = (0, _react.useCallback)(event => {
|
|
124
|
+
if (contentRef.current && contentRef.current.contains(event.target)) return true;
|
|
125
|
+
return false;
|
|
126
|
+
}, []);
|
|
127
|
+
const getNodeByElementId = (0, _react.useCallback)(elementId => {
|
|
128
|
+
if (elementId !== _constants.DOC_COMMENT_ELEMENT_ID) {
|
|
129
|
+
return (0, _core.getNodeById)(editor.children, elementId);
|
|
130
|
+
}
|
|
131
|
+
return null;
|
|
132
|
+
}, [editor.children]);
|
|
133
|
+
const setCurrentCommentGroup = (0, _react.useCallback)(commentGroupId => {
|
|
134
|
+
const activeCommentGroup = commentList.find(item => item.id === commentGroupId);
|
|
135
|
+
if (activeCommentGroup) {
|
|
136
|
+
setActiveCommentGroup(activeCommentGroup);
|
|
137
|
+
deleteUnseenNotifications && deleteUnseenNotifications(activeCommentGroup);
|
|
138
|
+
} else {
|
|
139
|
+
setActiveCommentGroup(null);
|
|
140
|
+
}
|
|
141
|
+
}, [commentList, deleteUnseenNotifications]);
|
|
142
|
+
const commentEditorPlaceholder = !activeCommentGroup ? t('Enter_comment_shift_enter_for_new_line_Enter_to_send') : t('Enter_reply_shift_Enter_for_new_line_Enter_to_send');
|
|
143
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
144
|
+
className: "sdoc-comment-drawer"
|
|
145
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
146
|
+
className: "comments-panel-wrapper"
|
|
147
|
+
}, /*#__PURE__*/_react.default.createElement(_globalCommentHeader.default, {
|
|
148
|
+
toggle: () => {},
|
|
149
|
+
activeCommentGroup: activeCommentGroup,
|
|
150
|
+
setCurrentCommentGroup: setCurrentCommentGroup
|
|
151
|
+
}), /*#__PURE__*/_react.default.createElement("div", {
|
|
152
|
+
className: "comments-panel-body"
|
|
153
|
+
}, !activeCommentGroup && /*#__PURE__*/_react.default.createElement(_globalCommentBodyHeader.default, {
|
|
154
|
+
commentList: commentList,
|
|
155
|
+
commentType: commentType,
|
|
156
|
+
setCommentType: setCommentType
|
|
157
|
+
}), /*#__PURE__*/_react.default.createElement("div", {
|
|
158
|
+
ref: contentRef,
|
|
159
|
+
className: "comments-panel-body__content"
|
|
160
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
161
|
+
id: "global-comment-list-container",
|
|
162
|
+
className: "sdoc-comment-list-container"
|
|
163
|
+
}, !activeCommentGroup && Array.isArray(commentList) && commentList.map(comment => {
|
|
164
|
+
var _comment$replies, _comment$replies2;
|
|
165
|
+
const replyCount = (_comment$replies = comment.replies) === null || _comment$replies === void 0 ? void 0 : _comment$replies.length;
|
|
166
|
+
const latestReply = ((_comment$replies2 = comment.replies) === null || _comment$replies2 === void 0 ? void 0 : _comment$replies2.length) > 0 ? comment.replies[comment.replies.length - 1] : null;
|
|
167
|
+
const elementId = comment.detail.element_id;
|
|
168
|
+
const element = getNodeByElementId(elementId);
|
|
169
|
+
return /*#__PURE__*/_react.default.createElement(_commentItemCollapseWrapper.default, {
|
|
170
|
+
key: comment.id,
|
|
171
|
+
editor: editor,
|
|
172
|
+
element: element,
|
|
173
|
+
topLevelComment: comment,
|
|
174
|
+
replyCount: replyCount,
|
|
175
|
+
latestReply: latestReply,
|
|
176
|
+
setCurrentCommentGroup: setCurrentCommentGroup
|
|
177
|
+
});
|
|
178
|
+
}), activeCommentGroup && /*#__PURE__*/_react.default.createElement(_commentItemWrapper.default, {
|
|
179
|
+
key: activeCommentGroup.id,
|
|
180
|
+
editor: editor,
|
|
181
|
+
element: getNodeByElementId(activeCommentGroup.detail.element_id),
|
|
182
|
+
container: "global-comment-list-container",
|
|
183
|
+
commentDetailRef: commentDetailRef,
|
|
184
|
+
comment: activeCommentGroup,
|
|
185
|
+
isGlobalComment: true,
|
|
186
|
+
isActive: true,
|
|
187
|
+
updateScrollPosition: updateScrollPosition,
|
|
188
|
+
isClickCommentPanelBody: isClickCommentPanelBody,
|
|
189
|
+
setCurrentCommentGroup: setCurrentCommentGroup
|
|
190
|
+
}))), /*#__PURE__*/_react.default.createElement("div", {
|
|
191
|
+
className: (0, _classnames.default)('global-comment-input-wrapper', {
|
|
192
|
+
'active': globalCommentContent === null || globalCommentContent === void 0 ? void 0 : globalCommentContent.trim()
|
|
193
|
+
})
|
|
194
|
+
}, !showEditor && /*#__PURE__*/_react.default.createElement(_reactstrap.Input, {
|
|
195
|
+
value: globalCommentContent !== null && globalCommentContent !== void 0 && globalCommentContent.trim() ? '.....' : '',
|
|
196
|
+
readOnly: true,
|
|
197
|
+
placeholder: commentEditorPlaceholder,
|
|
198
|
+
onFocus: () => {
|
|
199
|
+
setShowEditor(true);
|
|
200
|
+
}
|
|
201
|
+
}), showEditor && /*#__PURE__*/_react.default.createElement(_globalCommentEditor.default, {
|
|
202
|
+
globalCommentContent: globalCommentContent,
|
|
203
|
+
isScrollDisplayed: isScrollDisplayed,
|
|
204
|
+
type: activeCommentGroup ? 'replay' : 'comment',
|
|
205
|
+
hiddenCommentEditor: hiddenCommentEditor,
|
|
206
|
+
insertDocComment: insertDocComment,
|
|
207
|
+
onContentChange: content => {
|
|
208
|
+
setGlobalCommentContent(content);
|
|
209
|
+
}
|
|
210
|
+
})))));
|
|
211
|
+
};
|
|
212
|
+
var _default = exports.default = (0, _reactI18next.withTranslation)('sdoc-editor')(GlobalComment);
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
Object.defineProperty(exports, "EditorComment", {
|
|
8
|
+
enumerable: true,
|
|
9
|
+
get: function () {
|
|
10
|
+
return _editorComment.default;
|
|
11
|
+
}
|
|
12
|
+
});
|
|
13
|
+
Object.defineProperty(exports, "GlobalComment", {
|
|
14
|
+
enumerable: true,
|
|
15
|
+
get: function () {
|
|
16
|
+
return _globalComment.default;
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
var _editorComment = _interopRequireDefault(require("./editor-comment"));
|
|
20
|
+
var _globalComment = _interopRequireDefault(require("./global-comment"));
|
|
21
|
+
require("./style.css");
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
/* editor-comment css */
|
|
2
|
+
.sdoc-comment-container {
|
|
3
|
+
position: absolute;
|
|
4
|
+
left: 0;
|
|
5
|
+
top: 0;
|
|
6
|
+
width: 100%;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
.sdoc-comment-container .comment-container-main {
|
|
10
|
+
position: absolute;
|
|
11
|
+
width: 100%;
|
|
12
|
+
top: 0;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
.sdoc-comment-container .comment-container-right {
|
|
16
|
+
position: absolute;
|
|
17
|
+
left: 100%;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
.sdoc-comment-container .comment-container-right .comment-add-wrapper {
|
|
21
|
+
position: absolute;
|
|
22
|
+
left: -22px;
|
|
23
|
+
width: 20px;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
.sdoc-comment-container .comment-container-right .comment-add-wrapper .sdocfont {
|
|
27
|
+
color: #999;
|
|
28
|
+
background-color: #FFF;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
.sdoc-comment-container .comment-container-right .comment-add-wrapper .sdocfont:hover {
|
|
32
|
+
color: #333;
|
|
33
|
+
cursor: pointer;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
.sdoc-comment-container .comment-container-right .comment-list-wrapper {
|
|
37
|
+
position: absolute;
|
|
38
|
+
left: 14px;
|
|
39
|
+
width: 280px;
|
|
40
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.UP = exports.POPOVER_ADDING_HEIGHT = exports.LINE_HEIGHT = exports.FONT_SIZE_WIDTH = exports.DOWN = exports.DOC_NOTIFICATION_REDUCER_TYPE = exports.DOC_COMMENT_ELEMENT_ID = exports.COMMENT_URL_CLASSNAME = exports.COMMENT_TYPES = void 0;
|
|
7
|
+
const COMMENT_TYPES = exports.COMMENT_TYPES = {
|
|
8
|
+
DOC: 'Doc_comments',
|
|
9
|
+
ALL: 'All_comments',
|
|
10
|
+
RESOLVED: 'Resolved_comments',
|
|
11
|
+
UNRESOLVED: 'Unresolved_comments'
|
|
12
|
+
};
|
|
13
|
+
const DOWN = exports.DOWN = 'down';
|
|
14
|
+
const UP = exports.UP = 'up';
|
|
15
|
+
const FONT_SIZE_WIDTH = exports.FONT_SIZE_WIDTH = 15;
|
|
16
|
+
const LINE_HEIGHT = exports.LINE_HEIGHT = 22;
|
|
17
|
+
const POPOVER_ADDING_HEIGHT = exports.POPOVER_ADDING_HEIGHT = 10;
|
|
18
|
+
const COMMENT_URL_CLASSNAME = exports.COMMENT_URL_CLASSNAME = 'sdoc-comment-url';
|
|
19
|
+
const DOC_COMMENT_ELEMENT_ID = exports.DOC_COMMENT_ELEMENT_ID = '0';
|
|
20
|
+
const DOC_NOTIFICATION_REDUCER_TYPE = exports.DOC_NOTIFICATION_REDUCER_TYPE = {
|
|
21
|
+
FETCHING: 'fetching',
|
|
22
|
+
FETCHED: 'fetched',
|
|
23
|
+
FETCH_ERROR: 'error',
|
|
24
|
+
ADD: 'add',
|
|
25
|
+
DEL: 'del'
|
|
26
|
+
};
|
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.useCursorPosition = exports.updateElementsAttrs = exports.updateCommentedElementsAttrs = exports.getSelectionRange = exports.getSelectedElemIds = exports.getPrimaryElementId = exports.getElementCommentCountTop = exports.getDomById = exports.getCursorPosition = exports.getCommentedTextsByElementId = exports.getAvatarUrl = void 0;
|
|
8
|
+
var _slate = require("@seafile/slate");
|
|
9
|
+
var _slateReact = require("@seafile/slate-react");
|
|
10
|
+
var _context = _interopRequireDefault(require("../context"));
|
|
11
|
+
var _core = require("../extension/core");
|
|
12
|
+
var _useScrollContext = require("../hooks/use-scroll-context");
|
|
13
|
+
const getSelectionRange = () => {
|
|
14
|
+
if (window.getSelection) {
|
|
15
|
+
const sel = window.getSelection();
|
|
16
|
+
if (sel.getRangeAt && sel.rangeCount) {
|
|
17
|
+
return sel.getRangeAt(0);
|
|
18
|
+
}
|
|
19
|
+
} else if (document.selection && document.selection.createRange) {
|
|
20
|
+
return document.selection.createRange();
|
|
21
|
+
}
|
|
22
|
+
return null;
|
|
23
|
+
};
|
|
24
|
+
exports.getSelectionRange = getSelectionRange;
|
|
25
|
+
const getCursorPosition = () => {
|
|
26
|
+
let x = 0;
|
|
27
|
+
let y = 0;
|
|
28
|
+
let range = getSelectionRange();
|
|
29
|
+
if (range) {
|
|
30
|
+
const rect = range.getBoundingClientRect();
|
|
31
|
+
const headerHeight = 93;
|
|
32
|
+
x = rect.x || 0;
|
|
33
|
+
y = rect.y - headerHeight + (rect.height - 24) / 2 || 0;
|
|
34
|
+
}
|
|
35
|
+
return {
|
|
36
|
+
x: x,
|
|
37
|
+
y: y
|
|
38
|
+
};
|
|
39
|
+
};
|
|
40
|
+
exports.getCursorPosition = getCursorPosition;
|
|
41
|
+
const useCursorPosition = () => {
|
|
42
|
+
const scrollRef = (0, _useScrollContext.useScrollContext)();
|
|
43
|
+
const {
|
|
44
|
+
scrollTop = 0
|
|
45
|
+
} = scrollRef.current || {};
|
|
46
|
+
let position = getCursorPosition();
|
|
47
|
+
if (position.y !== 0) {
|
|
48
|
+
position.y = position.y + scrollTop;
|
|
49
|
+
}
|
|
50
|
+
return position;
|
|
51
|
+
};
|
|
52
|
+
exports.useCursorPosition = useCursorPosition;
|
|
53
|
+
const getAvatarUrl = () => {
|
|
54
|
+
const server = _context.default.getSetting('serviceUrl');
|
|
55
|
+
const avatarUrl = `${server}/media/avatars/default.png`;
|
|
56
|
+
return avatarUrl;
|
|
57
|
+
};
|
|
58
|
+
exports.getAvatarUrl = getAvatarUrl;
|
|
59
|
+
const getElementCommentCountTop = (editor, element, scrollTop) => {
|
|
60
|
+
let minY;
|
|
61
|
+
const children = element.children || [];
|
|
62
|
+
children.forEach(child => {
|
|
63
|
+
const childDom = _slateReact.ReactEditor.toDOMNode(editor, child);
|
|
64
|
+
|
|
65
|
+
// use child real dom
|
|
66
|
+
const childRealDom = childDom.childNodes[0];
|
|
67
|
+
const {
|
|
68
|
+
y
|
|
69
|
+
} = childRealDom ? childRealDom.getBoundingClientRect() : {
|
|
70
|
+
y: 0
|
|
71
|
+
};
|
|
72
|
+
if (!minY) minY = y;
|
|
73
|
+
minY = Math.min(minY, y);
|
|
74
|
+
});
|
|
75
|
+
return minY - 93 + scrollTop; // 100: header height(56) + toolbar height(37)
|
|
76
|
+
};
|
|
77
|
+
exports.getElementCommentCountTop = getElementCommentCountTop;
|
|
78
|
+
const getSelectedElemIds = editor => {
|
|
79
|
+
const {
|
|
80
|
+
selection
|
|
81
|
+
} = editor;
|
|
82
|
+
if (!selection) return;
|
|
83
|
+
const selectedElemId = [];
|
|
84
|
+
const nodeEntries = Array.from(_slate.Editor.nodes(editor, {
|
|
85
|
+
match: n => _slate.Element.isElement(n) && _slate.Editor.isBlock(editor, n),
|
|
86
|
+
mode: 'lowest'
|
|
87
|
+
}));
|
|
88
|
+
for (const [node] of nodeEntries) {
|
|
89
|
+
selectedElemId.push(node.id);
|
|
90
|
+
}
|
|
91
|
+
return selectedElemId;
|
|
92
|
+
};
|
|
93
|
+
exports.getSelectedElemIds = getSelectedElemIds;
|
|
94
|
+
const getCommentedTextsByElementId = (elementId, textCommentId) => {
|
|
95
|
+
const container = document.querySelector(`[data-id='${elementId}']`);
|
|
96
|
+
if (!container) return [];
|
|
97
|
+
let targetDoms = container.querySelectorAll(`.sdoc_comment_${textCommentId}`);
|
|
98
|
+
if (targetDoms.length === 0) {
|
|
99
|
+
targetDoms = container.querySelectorAll(`.removed_sdoc_comment_${textCommentId}`);
|
|
100
|
+
}
|
|
101
|
+
const texts = [];
|
|
102
|
+
targetDoms.forEach(dom => {
|
|
103
|
+
var _dom$textContent;
|
|
104
|
+
texts.push(((_dom$textContent = dom.textContent) === null || _dom$textContent === void 0 ? void 0 : _dom$textContent.trim()) || '');
|
|
105
|
+
});
|
|
106
|
+
return texts;
|
|
107
|
+
};
|
|
108
|
+
exports.getCommentedTextsByElementId = getCommentedTextsByElementId;
|
|
109
|
+
const getDomById = elementId => {
|
|
110
|
+
const container = document.querySelector(`[data-id='${elementId}']`);
|
|
111
|
+
if (!container) return [];
|
|
112
|
+
const lastCommentedDomWithMarks = container.querySelector('.comment');
|
|
113
|
+
return lastCommentedDomWithMarks;
|
|
114
|
+
};
|
|
115
|
+
exports.getDomById = getDomById;
|
|
116
|
+
const updateElementsAttrs = (activeElementIds, editor, text_comment_id) => {
|
|
117
|
+
if (Array.isArray(activeElementIds)) {
|
|
118
|
+
for (const elemId of activeElementIds) {
|
|
119
|
+
const dom = document.querySelectorAll(`[data-id="${elemId}"]`)[0];
|
|
120
|
+
if (!dom) continue;
|
|
121
|
+
const domNode = _slateReact.ReactEditor.toSlateNode(editor, dom);
|
|
122
|
+
const nodePath = (0, _core.findPath)(editor, domNode);
|
|
123
|
+
domNode.children.forEach((textNode, index) => {
|
|
124
|
+
if (textNode.comment) {
|
|
125
|
+
const textNodePath = [...nodePath, index];
|
|
126
|
+
_slate.Transforms.setNodes(editor, {
|
|
127
|
+
[`sdoc_comment_${text_comment_id}`]: true
|
|
128
|
+
}, {
|
|
129
|
+
at: textNodePath,
|
|
130
|
+
match: _slate.Text.isText,
|
|
131
|
+
split: true
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
};
|
|
138
|
+
exports.updateElementsAttrs = updateElementsAttrs;
|
|
139
|
+
const updateCommentedElementsAttrs = function (activeElementIds, editor, text_comment_id) {
|
|
140
|
+
let resolved = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
|
|
141
|
+
let isDeleteComment = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false;
|
|
142
|
+
if (Array.isArray(activeElementIds)) {
|
|
143
|
+
_slate.Editor.withoutNormalizing(editor, () => {
|
|
144
|
+
for (const elemId of activeElementIds) {
|
|
145
|
+
// const { element } = elem;
|
|
146
|
+
const dom = document.querySelector(`[data-id="${elemId}"]`);
|
|
147
|
+
if (!dom) continue;
|
|
148
|
+
const domNode = _slateReact.ReactEditor.toSlateNode(editor, dom);
|
|
149
|
+
const domNodePath = (0, _core.findPath)(editor, domNode);
|
|
150
|
+
domNode.children.forEach((child, index) => {
|
|
151
|
+
const childPath = [...domNodePath, index];
|
|
152
|
+
if (_slate.Text.isText(child) && `sdoc_comment_${text_comment_id}` in child) {
|
|
153
|
+
_slate.Transforms.unsetNodes(editor, [`sdoc_comment_${text_comment_id}`], {
|
|
154
|
+
at: childPath,
|
|
155
|
+
match: _slate.Text.isText
|
|
156
|
+
});
|
|
157
|
+
!isDeleteComment && _slate.Transforms.setNodes(editor, {
|
|
158
|
+
[`sdoc_comment_${text_comment_id}`]: resolved
|
|
159
|
+
}, {
|
|
160
|
+
at: childPath,
|
|
161
|
+
match: _slate.Text.isText
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
};
|
|
169
|
+
exports.updateCommentedElementsAttrs = updateCommentedElementsAttrs;
|
|
170
|
+
const getPrimaryElementId = detail => {
|
|
171
|
+
if (!detail) return null;
|
|
172
|
+
let elementId;
|
|
173
|
+
const {
|
|
174
|
+
element_id,
|
|
175
|
+
element_id_list = []
|
|
176
|
+
} = detail;
|
|
177
|
+
if (element_id_list.length > 0) {
|
|
178
|
+
elementId = element_id_list[0];
|
|
179
|
+
} else {
|
|
180
|
+
elementId = element_id;
|
|
181
|
+
}
|
|
182
|
+
return elementId;
|
|
183
|
+
};
|
|
184
|
+
exports.getPrimaryElementId = getPrimaryElementId;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.useCommentContext = exports.CommentContext = void 0;
|
|
8
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
9
|
+
const CommentContext = exports.CommentContext = /*#__PURE__*/_react.default.createContext();
|
|
10
|
+
const useCommentContext = () => {
|
|
11
|
+
const {
|
|
12
|
+
commentsInfo,
|
|
13
|
+
dispatch
|
|
14
|
+
} = (0, _react.useContext)(CommentContext);
|
|
15
|
+
return {
|
|
16
|
+
commentsInfo,
|
|
17
|
+
dispatch
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
exports.useCommentContext = useCommentContext;
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
var _react = require("react");
|
|
8
|
+
var _constants = require("../../constants");
|
|
9
|
+
var _useCommentContext = require("./use-comment-context");
|
|
10
|
+
const useCommentList = () => {
|
|
11
|
+
const {
|
|
12
|
+
commentsInfo,
|
|
13
|
+
dispatch
|
|
14
|
+
} = (0, _useCommentContext.useCommentContext)();
|
|
15
|
+
const {
|
|
16
|
+
comment_list
|
|
17
|
+
} = commentsInfo || {};
|
|
18
|
+
const [commentType, setCommentType] = (0, _react.useState)(_constants.COMMENT_TYPES.ALL);
|
|
19
|
+
const [commentList, setCommentList] = (0, _react.useState)([]);
|
|
20
|
+
(0, _react.useEffect)(() => {
|
|
21
|
+
if (commentType === _constants.COMMENT_TYPES.ALL) {
|
|
22
|
+
const commentList = comment_list.map(item => {
|
|
23
|
+
item.replies = item.replies.filter(reply => !['True', 'False'].includes(reply.reply));
|
|
24
|
+
return item;
|
|
25
|
+
});
|
|
26
|
+
setCommentList(commentList);
|
|
27
|
+
} else if (commentType === _constants.COMMENT_TYPES.RESOLVED) {
|
|
28
|
+
const commentList = comment_list.filter(item => item.resolved);
|
|
29
|
+
setCommentList(commentList);
|
|
30
|
+
} else if (commentType === _constants.COMMENT_TYPES.UNRESOLVED) {
|
|
31
|
+
const commentList = comment_list.filter(item => !item.resolved);
|
|
32
|
+
setCommentList(commentList);
|
|
33
|
+
} else if (commentType === _constants.COMMENT_TYPES.DOC) {
|
|
34
|
+
const commentList = comment_list.filter(comment => comment.detail.element_id === _constants.DOC_COMMENT_ELEMENT_ID);
|
|
35
|
+
setCommentList(commentList);
|
|
36
|
+
}
|
|
37
|
+
}, [commentType, comment_list]);
|
|
38
|
+
return {
|
|
39
|
+
dispatch,
|
|
40
|
+
commentList,
|
|
41
|
+
commentType,
|
|
42
|
+
setCommentType
|
|
43
|
+
};
|
|
44
|
+
};
|
|
45
|
+
var _default = exports.default = useCommentList;
|
|
@@ -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.useCommentsMount = void 0;
|
|
8
|
+
var _react = require("react");
|
|
9
|
+
var _constants = require("../../../constants");
|
|
10
|
+
var _context = _interopRequireDefault(require("../../../context"));
|
|
11
|
+
var _eventBus = _interopRequireDefault(require("../../../utils/event-bus"));
|
|
12
|
+
const useCommentsMount = dispatch => {
|
|
13
|
+
const request = (0, _react.useCallback)(async () => {
|
|
14
|
+
dispatch({
|
|
15
|
+
type: 'FETCHING_STATE'
|
|
16
|
+
});
|
|
17
|
+
try {
|
|
18
|
+
const res = await _context.default.listComments();
|
|
19
|
+
const comments = res.data.comments;
|
|
20
|
+
dispatch({
|
|
21
|
+
type: 'RECEIVE_STATE',
|
|
22
|
+
payload: comments
|
|
23
|
+
});
|
|
24
|
+
} catch (error) {
|
|
25
|
+
console.log(error);
|
|
26
|
+
dispatch({
|
|
27
|
+
type: 'FETCHING_ERROR'
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
31
|
+
}, []);
|
|
32
|
+
const reRequest = (0, _react.useCallback)(async () => {
|
|
33
|
+
dispatch({
|
|
34
|
+
type: 'REFETCHING_STATE'
|
|
35
|
+
});
|
|
36
|
+
try {
|
|
37
|
+
const res = await _context.default.listComments();
|
|
38
|
+
const comments = res.data.comments;
|
|
39
|
+
dispatch({
|
|
40
|
+
type: 'RECEIVE_STATE',
|
|
41
|
+
payload: comments
|
|
42
|
+
});
|
|
43
|
+
} catch (error) {
|
|
44
|
+
console.log(error);
|
|
45
|
+
// dispatch({type: 'FETCHING_ERROR'});
|
|
46
|
+
}
|
|
47
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
48
|
+
}, []);
|
|
49
|
+
(0, _react.useEffect)(() => {
|
|
50
|
+
request();
|
|
51
|
+
const eventBus = _eventBus.default.getInstance();
|
|
52
|
+
const unsubscribeNewNotification = eventBus.subscribe(_constants.INTERNAL_EVENT.NEW_NOTIFICATION, reRequest);
|
|
53
|
+
return () => {
|
|
54
|
+
unsubscribeNewNotification();
|
|
55
|
+
};
|
|
56
|
+
}, [request, reRequest]);
|
|
57
|
+
};
|
|
58
|
+
exports.useCommentsMount = useCommentsMount;
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
Object.defineProperty(exports, "NotificationContext", {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: function () {
|
|
9
|
+
return _useNotificationContext.NotificationContext;
|
|
10
|
+
}
|
|
11
|
+
});
|
|
12
|
+
Object.defineProperty(exports, "useNotificationContext", {
|
|
13
|
+
enumerable: true,
|
|
14
|
+
get: function () {
|
|
15
|
+
return _useNotificationContext.useNotificationContext;
|
|
16
|
+
}
|
|
17
|
+
});
|
|
18
|
+
Object.defineProperty(exports, "useNotificationsMount", {
|
|
19
|
+
enumerable: true,
|
|
20
|
+
get: function () {
|
|
21
|
+
return _useNotificationMount.useNotificationsMount;
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
var _useNotificationContext = require("./use-notification-context");
|
|
25
|
+
var _useNotificationMount = require("./use-notification-mount");
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.useNotificationContext = exports.NotificationContext = void 0;
|
|
8
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
9
|
+
const NotificationContext = exports.NotificationContext = /*#__PURE__*/_react.default.createContext();
|
|
10
|
+
const useNotificationContext = () => {
|
|
11
|
+
const {
|
|
12
|
+
notificationsInfo,
|
|
13
|
+
dispatch
|
|
14
|
+
} = (0, _react.useContext)(NotificationContext);
|
|
15
|
+
return {
|
|
16
|
+
notificationsInfo,
|
|
17
|
+
dispatch
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
exports.useNotificationContext = useNotificationContext;
|