@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,211 @@
|
|
|
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 _socket = _interopRequireDefault(require("socket.io-client"));
|
|
10
|
+
var _debug = require("../utils/debug");
|
|
11
|
+
var _socketManager = _interopRequireDefault(require("./socket-manager"));
|
|
12
|
+
class SocketClient {
|
|
13
|
+
constructor(config) {
|
|
14
|
+
var _this = this;
|
|
15
|
+
(0, _defineProperty2.default)(this, "getParams", function () {
|
|
16
|
+
let params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
17
|
+
const {
|
|
18
|
+
docUuid,
|
|
19
|
+
user
|
|
20
|
+
} = _this.config;
|
|
21
|
+
return {
|
|
22
|
+
doc_uuid: docUuid,
|
|
23
|
+
user,
|
|
24
|
+
...params
|
|
25
|
+
};
|
|
26
|
+
});
|
|
27
|
+
(0, _defineProperty2.default)(this, "onConnected", () => {
|
|
28
|
+
// join room
|
|
29
|
+
this.socket.emit('join-room', result => {
|
|
30
|
+
const socketManager = _socketManager.default.getInstance();
|
|
31
|
+
if (result.success) {
|
|
32
|
+
// sync operations or document
|
|
33
|
+
if (this.isReconnect) {
|
|
34
|
+
this.isReconnect = false;
|
|
35
|
+
// The reconnect of socketManager needs to be triggered after entering the room again
|
|
36
|
+
socketManager.onReconnect(result);
|
|
37
|
+
}
|
|
38
|
+
socketManager.dispatchConnectState('onConnected', result);
|
|
39
|
+
return;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
// Disconnect the server in the client side. There will be no reconnection.
|
|
43
|
+
this.socket.disconnect();
|
|
44
|
+
socketManager.dispatchConnectState('connect-error', result);
|
|
45
|
+
});
|
|
46
|
+
});
|
|
47
|
+
(0, _defineProperty2.default)(this, "onReconnect", data => {
|
|
48
|
+
(0, _debug.clientDebug)('reconnect.');
|
|
49
|
+
this.isReconnect = true;
|
|
50
|
+
const socketManager = _socketManager.default.getInstance();
|
|
51
|
+
socketManager.dispatchConnectState('reconnect');
|
|
52
|
+
});
|
|
53
|
+
(0, _defineProperty2.default)(this, "onReconnectAttempt", attemptNumber => {
|
|
54
|
+
(0, _debug.clientDebug)('reconnect_attempt. %s', attemptNumber);
|
|
55
|
+
const socketManager = _socketManager.default.getInstance();
|
|
56
|
+
socketManager.dispatchConnectState('reconnect_attempt', attemptNumber);
|
|
57
|
+
});
|
|
58
|
+
(0, _defineProperty2.default)(this, "onReconnectError", () => {
|
|
59
|
+
(0, _debug.clientDebug)('reconnect_error.');
|
|
60
|
+
const socketManager = _socketManager.default.getInstance();
|
|
61
|
+
socketManager.dispatchConnectState('reconnect_error');
|
|
62
|
+
});
|
|
63
|
+
(0, _defineProperty2.default)(this, "onDisconnected", data => {
|
|
64
|
+
(0, _debug.clientDebug)('disconnect message: %s', data);
|
|
65
|
+
const socketManager = _socketManager.default.getInstance();
|
|
66
|
+
socketManager.dispatchConnectState('disconnect');
|
|
67
|
+
});
|
|
68
|
+
(0, _defineProperty2.default)(this, "onConnectError", e => {
|
|
69
|
+
(0, _debug.clientDebug)('connect_error.');
|
|
70
|
+
const socketManager = _socketManager.default.getInstance();
|
|
71
|
+
socketManager.dispatchConnectState('connect_error');
|
|
72
|
+
});
|
|
73
|
+
(0, _defineProperty2.default)(this, "sendOperations", (operations, version, selection, callback) => {
|
|
74
|
+
(0, _debug.clientDebug)('send operations: %O', operations);
|
|
75
|
+
this.socket.emit('update-document', this.getParams({
|
|
76
|
+
operations,
|
|
77
|
+
version,
|
|
78
|
+
selection
|
|
79
|
+
}), result => {
|
|
80
|
+
callback && callback(result);
|
|
81
|
+
});
|
|
82
|
+
});
|
|
83
|
+
(0, _defineProperty2.default)(this, "onJoinRoom", userInfo => {
|
|
84
|
+
(0, _debug.serverDebug)('%s joined room success.', userInfo.username);
|
|
85
|
+
const socketManager = _socketManager.default.getInstance();
|
|
86
|
+
socketManager.dispatchConnectState('join-room', userInfo);
|
|
87
|
+
});
|
|
88
|
+
(0, _defineProperty2.default)(this, "onLeaveRoom", username => {
|
|
89
|
+
(0, _debug.serverDebug)('%s leaved room success.', username);
|
|
90
|
+
const socketManager = _socketManager.default.getInstance();
|
|
91
|
+
socketManager.dispatchConnectState('leave-room', username);
|
|
92
|
+
});
|
|
93
|
+
/**
|
|
94
|
+
* receive remote broadcast operations
|
|
95
|
+
* @param {*} params {operations, version}
|
|
96
|
+
*/
|
|
97
|
+
(0, _defineProperty2.default)(this, "onReceiveRemoteOperations", params => {
|
|
98
|
+
(0, _debug.serverDebug)('receive operations: %O', params);
|
|
99
|
+
const socketManager = _socketManager.default.getInstance();
|
|
100
|
+
socketManager.onReceiveRemoteOperations(params);
|
|
101
|
+
});
|
|
102
|
+
(0, _defineProperty2.default)(this, "getRecentOperations", () => {
|
|
103
|
+
const {
|
|
104
|
+
docUuid
|
|
105
|
+
} = this.config;
|
|
106
|
+
const socketManager = _socketManager.default.getInstance();
|
|
107
|
+
const clientVersion = socketManager.getDocumentVersion();
|
|
108
|
+
this.socket.emit('sync-document', {
|
|
109
|
+
doc_uuid: docUuid,
|
|
110
|
+
version: clientVersion
|
|
111
|
+
}, result => {
|
|
112
|
+
if (result.success) {
|
|
113
|
+
socketManager.onGetRecentOperations(result);
|
|
114
|
+
}
|
|
115
|
+
});
|
|
116
|
+
});
|
|
117
|
+
(0, _defineProperty2.default)(this, "sendCursorLocation", location => {
|
|
118
|
+
const {
|
|
119
|
+
cursorData: cursor_data
|
|
120
|
+
} = this.config;
|
|
121
|
+
this.socket.emit('update-cursor', this.getParams({
|
|
122
|
+
location,
|
|
123
|
+
cursor_data
|
|
124
|
+
}));
|
|
125
|
+
});
|
|
126
|
+
(0, _defineProperty2.default)(this, "receiveCursorLocation", params => {
|
|
127
|
+
const socketManager = _socketManager.default.getInstance();
|
|
128
|
+
socketManager.receiveCursorLocation(params);
|
|
129
|
+
});
|
|
130
|
+
(0, _defineProperty2.default)(this, "disconnectWithServer", () => {
|
|
131
|
+
this.socket.disconnect();
|
|
132
|
+
});
|
|
133
|
+
(0, _defineProperty2.default)(this, "receivePublishDocument", () => {
|
|
134
|
+
const socketManager = _socketManager.default.getInstance();
|
|
135
|
+
socketManager.receivePublishDocument();
|
|
136
|
+
});
|
|
137
|
+
(0, _defineProperty2.default)(this, "receivePublishDocumentError", () => {
|
|
138
|
+
const socketManager = _socketManager.default.getInstance();
|
|
139
|
+
socketManager.receivePublishDocumentError();
|
|
140
|
+
});
|
|
141
|
+
(0, _defineProperty2.default)(this, "receiveDocumentReplaced", () => {
|
|
142
|
+
const socketManager = _socketManager.default.getInstance();
|
|
143
|
+
socketManager.receiveDocumentReplaced();
|
|
144
|
+
});
|
|
145
|
+
(0, _defineProperty2.default)(this, "receiveDocumentReplacedError", () => {
|
|
146
|
+
const socketManager = _socketManager.default.getInstance();
|
|
147
|
+
socketManager.receiveDocumentReplacedError();
|
|
148
|
+
});
|
|
149
|
+
(0, _defineProperty2.default)(this, "receiveRemoveDocument", () => {
|
|
150
|
+
const socketManager = _socketManager.default.getInstance();
|
|
151
|
+
socketManager.receiveRemoveDocument();
|
|
152
|
+
});
|
|
153
|
+
(0, _defineProperty2.default)(this, "receiveRemoveDocumentError", () => {
|
|
154
|
+
const socketManager = _socketManager.default.getInstance();
|
|
155
|
+
socketManager.receiveRemoveDocumentError();
|
|
156
|
+
});
|
|
157
|
+
(0, _defineProperty2.default)(this, "receiveNewNotification", notification => {
|
|
158
|
+
const socketManager = _socketManager.default.getInstance();
|
|
159
|
+
socketManager.receiveNewNotification(notification);
|
|
160
|
+
});
|
|
161
|
+
(0, _defineProperty2.default)(this, "receiveParticipantAdded", uses => {
|
|
162
|
+
const socketManager = _socketManager.default.getInstance();
|
|
163
|
+
socketManager.receiveParticipantAdded(uses);
|
|
164
|
+
});
|
|
165
|
+
(0, _defineProperty2.default)(this, "receiveParticipantRemoved", email => {
|
|
166
|
+
const socketManager = _socketManager.default.getInstance();
|
|
167
|
+
socketManager.receiveParticipantRemoved(email);
|
|
168
|
+
});
|
|
169
|
+
this.config = config;
|
|
170
|
+
this.isReconnect = false;
|
|
171
|
+
this.socket = (0, _socket.default)(config.sdocServer, {
|
|
172
|
+
reconnection: true,
|
|
173
|
+
auth: {
|
|
174
|
+
token: config.accessToken
|
|
175
|
+
},
|
|
176
|
+
query: {
|
|
177
|
+
'sdoc_uuid': config.docUuid
|
|
178
|
+
}
|
|
179
|
+
});
|
|
180
|
+
this.socket.on('connect', this.onConnected);
|
|
181
|
+
this.socket.on('disconnect', this.onDisconnected);
|
|
182
|
+
this.socket.on('connect_error', this.onConnectError);
|
|
183
|
+
this.socket.on('join-room', this.onJoinRoom);
|
|
184
|
+
this.socket.on('leave-room', this.onLeaveRoom);
|
|
185
|
+
this.socket.on('update-document', this.onReceiveRemoteOperations);
|
|
186
|
+
|
|
187
|
+
// doc replaced
|
|
188
|
+
this.socket.on('doc-replaced', this.receiveDocumentReplaced);
|
|
189
|
+
this.socket.on('doc-replaced-error', this.receiveDocumentReplacedError);
|
|
190
|
+
|
|
191
|
+
// doc published
|
|
192
|
+
this.socket.on('doc-published', this.receivePublishDocument);
|
|
193
|
+
this.socket.on('doc-published-error', this.receivePublishDocumentError);
|
|
194
|
+
|
|
195
|
+
// doc removed
|
|
196
|
+
this.socket.on('doc-removed', this.receiveRemoveDocument);
|
|
197
|
+
this.socket.on('doc-removed-error', this.receiveRemoveDocumentError);
|
|
198
|
+
this.socket.on('update-cursor', this.receiveCursorLocation);
|
|
199
|
+
|
|
200
|
+
// notification
|
|
201
|
+
this.socket.on('new-notification', this.receiveNewNotification);
|
|
202
|
+
|
|
203
|
+
// participant
|
|
204
|
+
this.socket.on('participant-added', this.receiveParticipantAdded);
|
|
205
|
+
this.socket.on('participant-removed', this.receiveParticipantRemoved);
|
|
206
|
+
this.socket.io.on('reconnect', this.onReconnect);
|
|
207
|
+
this.socket.io.on('reconnect_attempt', this.onReconnectAttempt);
|
|
208
|
+
this.socket.io.on('reconnect_error', this.onReconnectError);
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
var _default = exports.default = SocketClient;
|
|
@@ -0,0 +1,386 @@
|
|
|
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 _constants = require("../constants");
|
|
10
|
+
var _helper = require("../cursor/helper");
|
|
11
|
+
var _debug = require("../utils/debug");
|
|
12
|
+
var _eventBus = _interopRequireDefault(require("../utils/event-bus"));
|
|
13
|
+
var _helpers = require("./helpers");
|
|
14
|
+
var _socketClient = _interopRequireDefault(require("./socket-client"));
|
|
15
|
+
var _SocketManager;
|
|
16
|
+
// idle --> sending --> conflict --> idle
|
|
17
|
+
// --> conflict --> idle
|
|
18
|
+
// --> disconnect --> conflict --> idle
|
|
19
|
+
// --> idle
|
|
20
|
+
const STATE = {
|
|
21
|
+
IDLE: 'idle',
|
|
22
|
+
SENDING: 'sending',
|
|
23
|
+
CONFLICT: 'conflict',
|
|
24
|
+
DISCONNECT: 'disconnect',
|
|
25
|
+
NEED_RELOAD: 'need_reload'
|
|
26
|
+
};
|
|
27
|
+
class SocketManager {
|
|
28
|
+
constructor(editor, _document, config) {
|
|
29
|
+
(0, _defineProperty2.default)(this, "getDocumentVersion", () => {
|
|
30
|
+
const {
|
|
31
|
+
version
|
|
32
|
+
} = this.document;
|
|
33
|
+
return version;
|
|
34
|
+
});
|
|
35
|
+
(0, _defineProperty2.default)(this, "updateDocumentVersion", document => {
|
|
36
|
+
this.document['version'] = document.version;
|
|
37
|
+
});
|
|
38
|
+
(0, _defineProperty2.default)(this, "receivePublishDocument", () => {
|
|
39
|
+
this.eventBus.dispatch(_constants.INTERNAL_EVENT.PUBLISH_DOCUMENT);
|
|
40
|
+
});
|
|
41
|
+
(0, _defineProperty2.default)(this, "receivePublishDocumentError", () => {
|
|
42
|
+
this.eventBus.dispatch(_constants.INTERNAL_EVENT.PUBLISH_DOCUMENT_ERROR);
|
|
43
|
+
});
|
|
44
|
+
(0, _defineProperty2.default)(this, "receiveRemoveDocument", () => {
|
|
45
|
+
this.eventBus.dispatch(_constants.INTERNAL_EVENT.REMOVE_DOCUMENT);
|
|
46
|
+
});
|
|
47
|
+
(0, _defineProperty2.default)(this, "receiveRemoveDocumentError", () => {
|
|
48
|
+
this.eventBus.dispatch(_constants.INTERNAL_EVENT.REMOVE_DOCUMENT_ERROR);
|
|
49
|
+
});
|
|
50
|
+
(0, _defineProperty2.default)(this, "receiveDocumentReplaced", () => {
|
|
51
|
+
this.eventBus.dispatch(_constants.INTERNAL_EVENT.DOCUMENT_REPLACED);
|
|
52
|
+
});
|
|
53
|
+
(0, _defineProperty2.default)(this, "receiveDocumentReplacedError", () => {
|
|
54
|
+
this.eventBus.dispatch(_constants.INTERNAL_EVENT.DOCUMENT_REPLACED_ERROR);
|
|
55
|
+
});
|
|
56
|
+
(0, _defineProperty2.default)(this, "receiveNewNotification", notification => {
|
|
57
|
+
this.eventBus.dispatch(_constants.INTERNAL_EVENT.NEW_NOTIFICATION, notification);
|
|
58
|
+
});
|
|
59
|
+
(0, _defineProperty2.default)(this, "onReceiveLocalOperations", operations => {
|
|
60
|
+
if (this.editor.readonly) return;
|
|
61
|
+
this.pendingOperationList.push(operations);
|
|
62
|
+
const lastOpBeginTime = new Date().getTime();
|
|
63
|
+
this.pendingOperationBeginTimeList.push(lastOpBeginTime);
|
|
64
|
+
const firstOpBeginTime = this.pendingOperationBeginTimeList[0];
|
|
65
|
+
const isExceedExecuteTime = (lastOpBeginTime - firstOpBeginTime) / 1000 > 30 ? true : false;
|
|
66
|
+
if (isExceedExecuteTime || this.pendingOperationList.length > 50) {
|
|
67
|
+
this.dispatchConnectState('pending_operations_exceed_limit');
|
|
68
|
+
}
|
|
69
|
+
this.sendOperations();
|
|
70
|
+
});
|
|
71
|
+
(0, _defineProperty2.default)(this, "sendOperations", () => {
|
|
72
|
+
if (this.editor.readonly) return;
|
|
73
|
+
if (this.state !== STATE.IDLE) return;
|
|
74
|
+
(0, _debug.stateDebug)(`State changed: ${this.state} -> ${STATE.SENDING}`);
|
|
75
|
+
this.state = STATE.SENDING;
|
|
76
|
+
this.sendNextOperations();
|
|
77
|
+
});
|
|
78
|
+
(0, _defineProperty2.default)(this, "sendNextOperations", () => {
|
|
79
|
+
if (this.state !== STATE.SENDING) return;
|
|
80
|
+
if (this.pendingOperationList.length === 0) {
|
|
81
|
+
(0, _debug.stateDebug)(`State Changed: ${this.state} -> ${STATE.IDLE}`);
|
|
82
|
+
this.state = STATE.IDLE;
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
this.dispatchConnectState('is-saving');
|
|
86
|
+
const version = this.document.version;
|
|
87
|
+
const operations = this.pendingOperationList.shift();
|
|
88
|
+
const selection = this.editor.selection;
|
|
89
|
+
this._sendingOperations = operations;
|
|
90
|
+
this.socketClient.sendOperations(operations, version, selection, this.sendOperationsCallback);
|
|
91
|
+
});
|
|
92
|
+
(0, _defineProperty2.default)(this, "sendOperationsCallback", result => {
|
|
93
|
+
if (result && result.success) {
|
|
94
|
+
const {
|
|
95
|
+
version: serverVersion
|
|
96
|
+
} = result;
|
|
97
|
+
this.document['version'] = serverVersion;
|
|
98
|
+
const lastSavedAt = new Date().getTime();
|
|
99
|
+
this.dispatchConnectState('saved', lastSavedAt);
|
|
100
|
+
|
|
101
|
+
// send next operations
|
|
102
|
+
this.pendingOperationBeginTimeList.shift(); // remove current operation's begin time
|
|
103
|
+
this._sendingOperations = null;
|
|
104
|
+
this.sendNextOperations();
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
// Operations are execute failure
|
|
109
|
+
const {
|
|
110
|
+
error_type
|
|
111
|
+
} = result;
|
|
112
|
+
if (error_type === 'load_document_content_error' || error_type === 'save_operations_to_database_error' || error_type === 'token_expired') {
|
|
113
|
+
// load_document_content_error: After a short-term reconnection, the content of the document fails to load
|
|
114
|
+
// save_operation_to_database_error: Save operation to database error
|
|
115
|
+
this.dispatchConnectState(error_type);
|
|
116
|
+
|
|
117
|
+
// reset sending control
|
|
118
|
+
(0, _debug.stateDebug)(`State Changed: ${this.state} -> ${STATE.NEED_RELOAD}`);
|
|
119
|
+
this.state = STATE.NEED_RELOAD;
|
|
120
|
+
this._sendingOperations = null;
|
|
121
|
+
} else if (error_type === 'version_behind_server') {
|
|
122
|
+
// Put the failed operation into the pending list and re-execute it
|
|
123
|
+
this.pendingOperationList.unshift([...this._sendingOperations]);
|
|
124
|
+
(0, _debug.stateDebug)(`State Changed: ${this.state} -> ${STATE.CONFLICT}`);
|
|
125
|
+
this.state = STATE.CONFLICT;
|
|
126
|
+
const {
|
|
127
|
+
lose_operations
|
|
128
|
+
} = result;
|
|
129
|
+
this.resolveConflicting(lose_operations);
|
|
130
|
+
} else if (error_type === 'execute_client_operations_error') {
|
|
131
|
+
this.editor.isRemote = true;
|
|
132
|
+
const dupSendingOperations = [...this._sendingOperations];
|
|
133
|
+
(0, _helpers.revertOperationList)(this.editor, [dupSendingOperations]);
|
|
134
|
+
|
|
135
|
+
// Update the save time after revert
|
|
136
|
+
const lastSavedAt = new Date().getTime();
|
|
137
|
+
this.dispatchConnectState('saved', lastSavedAt);
|
|
138
|
+
|
|
139
|
+
// Set isRemote to false must be in Promise.resolve function, make sure the modification of isRemote is later than the onChange event
|
|
140
|
+
Promise.resolve().then(_ => {
|
|
141
|
+
this.editor.isRemote = false;
|
|
142
|
+
this.dispatchConnectState(error_type);
|
|
143
|
+
|
|
144
|
+
// send next operations
|
|
145
|
+
this._sendingOperations = null;
|
|
146
|
+
this.sendNextOperations();
|
|
147
|
+
});
|
|
148
|
+
}
|
|
149
|
+
});
|
|
150
|
+
(0, _defineProperty2.default)(this, "onReceiveRemoteOperations", params => {
|
|
151
|
+
// if this.disconnect is true, Then the message sent by the remote end cannot be received
|
|
152
|
+
if (this.state !== STATE.IDLE) return;
|
|
153
|
+
if (this.editor.readonly) return;
|
|
154
|
+
const {
|
|
155
|
+
version: serverVersion
|
|
156
|
+
} = params;
|
|
157
|
+
const {
|
|
158
|
+
version: clientVersion
|
|
159
|
+
} = this.document;
|
|
160
|
+
if (serverVersion === clientVersion + 1) {
|
|
161
|
+
// update execute remote operations flag
|
|
162
|
+
this.editor.isRemote = true;
|
|
163
|
+
const {
|
|
164
|
+
operations
|
|
165
|
+
} = params;
|
|
166
|
+
// Update content & version
|
|
167
|
+
(0, _debug.serverDebug)('execute remote operations: %O', operations);
|
|
168
|
+
try {
|
|
169
|
+
(0, _helpers.syncRemoteOperations)(this.editor, operations);
|
|
170
|
+
} catch (error) {
|
|
171
|
+
(0, _debug.stateDebug)(`State Changed: ${this.state} -> ${STATE.CONFLICT}`);
|
|
172
|
+
this.state = STATE.CONFLICT;
|
|
173
|
+
this.dispatchConnectState('sync_server_operations_error');
|
|
174
|
+
return;
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
// Update document
|
|
178
|
+
this.document.version = serverVersion;
|
|
179
|
+
this.document.children = this.editor.children;
|
|
180
|
+
Promise.resolve().then(() => {
|
|
181
|
+
this.editor.isRemote = false;
|
|
182
|
+
this.revertOperationList = [];
|
|
183
|
+
});
|
|
184
|
+
} else {
|
|
185
|
+
// isConflict
|
|
186
|
+
this.onConflictHappen();
|
|
187
|
+
}
|
|
188
|
+
});
|
|
189
|
+
(0, _defineProperty2.default)(this, "onReconnect", result => {
|
|
190
|
+
const {
|
|
191
|
+
version: serverVersion
|
|
192
|
+
} = result;
|
|
193
|
+
const clientVersion = this.getDocumentVersion();
|
|
194
|
+
// The client version is inconsistent with the server version, and the latest operations performed by the server need to be loaded
|
|
195
|
+
if (serverVersion !== clientVersion) {
|
|
196
|
+
this.onConflictHappen();
|
|
197
|
+
return;
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
// The version consistency indicates that there is no conflict and no processing is required
|
|
201
|
+
(0, _debug.stateDebug)(`State Changed: ${this.state} -> ${STATE.IDLE}`);
|
|
202
|
+
this.state = STATE.IDLE;
|
|
203
|
+
if (this.pendingOperationList.length > 0) {
|
|
204
|
+
(0, _debug.clientDebug)('After reconnection, manually trigger the execution of ops.');
|
|
205
|
+
(0, _debug.stateDebug)(`State Changed: ${this.state} -> ${STATE.SENDING}`);
|
|
206
|
+
this.state = STATE.SENDING;
|
|
207
|
+
this.sendNextOperations();
|
|
208
|
+
}
|
|
209
|
+
});
|
|
210
|
+
(0, _defineProperty2.default)(this, "onConflictHappen", () => {
|
|
211
|
+
(0, _debug.stateDebug)(`State Changed: ${this.state} -> ${STATE.CONFLICT}`);
|
|
212
|
+
this.state = STATE.CONFLICT;
|
|
213
|
+
this.socketClient.getRecentOperations();
|
|
214
|
+
});
|
|
215
|
+
(0, _defineProperty2.default)(this, "onGetRecentOperations", result => {
|
|
216
|
+
if (this.editor.readonly) return;
|
|
217
|
+
const {
|
|
218
|
+
mode,
|
|
219
|
+
content
|
|
220
|
+
} = result;
|
|
221
|
+
(0, _debug.conflictDebug)('Start conflict resolution');
|
|
222
|
+
// sync document
|
|
223
|
+
if (mode === 'document') {
|
|
224
|
+
const {
|
|
225
|
+
version,
|
|
226
|
+
children
|
|
227
|
+
} = content;
|
|
228
|
+
// 1. update document
|
|
229
|
+
(0, _debug.conflictDebug)('Update local document to remote document');
|
|
230
|
+
this.document.children = children;
|
|
231
|
+
this.document.version = version;
|
|
232
|
+
this.editor.children = children;
|
|
233
|
+
this.editor.isRemote = true;
|
|
234
|
+
this.editor.onChange();
|
|
235
|
+
(0, _debug.stateDebug)(`State Changed: ${this.state} -> ${STATE.IDLE}`);
|
|
236
|
+
this.editor.isRemote = false;
|
|
237
|
+
this.state = STATE.IDLE;
|
|
238
|
+
this._sendingOperations = null;
|
|
239
|
+
|
|
240
|
+
// 2. exec client operationList
|
|
241
|
+
const pendingOperationList = this.pendingOperationList.slice();
|
|
242
|
+
this.pendingOperationList = [];
|
|
243
|
+
|
|
244
|
+
// need resend this operations to server
|
|
245
|
+
(0, _debug.conflictDebug)('Re-execute local unsynchronized operations: %o', pendingOperationList);
|
|
246
|
+
(0, _helpers.reExecRevertOperationList)(this.editor, pendingOperationList);
|
|
247
|
+
return;
|
|
248
|
+
}
|
|
249
|
+
|
|
250
|
+
// mode os operations: sync operations
|
|
251
|
+
// content is [{version, operations}, {version, operations}, ...]
|
|
252
|
+
const loseOperations = content;
|
|
253
|
+
this.resolveConflicting(loseOperations);
|
|
254
|
+
});
|
|
255
|
+
(0, _defineProperty2.default)(this, "resolveConflicting", loseOperations => {
|
|
256
|
+
if (this.editor.readonly) return;
|
|
257
|
+
(0, _debug.conflictDebug)('resolve conflicts');
|
|
258
|
+
this.editor.isRemote = true;
|
|
259
|
+
if (this.pendingOperationList.length !== 0) {
|
|
260
|
+
// 1. Revert operations
|
|
261
|
+
// 1.1 record reverted operationList & clear pendingOperationList
|
|
262
|
+
this.revertOperationList = this.pendingOperationList.slice();
|
|
263
|
+
this.pendingOperationList = [];
|
|
264
|
+
|
|
265
|
+
// 1.2 Revert operationList
|
|
266
|
+
(0, _debug.conflictDebug)('revert locale operations: %O', this.revertOperationList);
|
|
267
|
+
(0, _helpers.revertOperationList)(this.editor, this.revertOperationList);
|
|
268
|
+
}
|
|
269
|
+
loseOperations = loseOperations.sort((prev, next) => prev.version - next.version);
|
|
270
|
+
(0, _debug.conflictDebug)('lose operations length: %s', loseOperations.length);
|
|
271
|
+
while (loseOperations.length > 0) {
|
|
272
|
+
const operationParams = loseOperations.shift();
|
|
273
|
+
// 2. execute operations
|
|
274
|
+
const {
|
|
275
|
+
operations,
|
|
276
|
+
version: serverVersion
|
|
277
|
+
} = operationParams;
|
|
278
|
+
// 2.1 Update content & version
|
|
279
|
+
(0, _debug.conflictDebug)('execute lose operations: %O', operations);
|
|
280
|
+
try {
|
|
281
|
+
(0, _helpers.syncRemoteOperations)(this.editor, operations);
|
|
282
|
+
} catch (error) {
|
|
283
|
+
(0, _debug.stateDebug)(`State Changed: ${this.state} -> ${STATE.CONFLICT}`);
|
|
284
|
+
this.state = STATE.CONFLICT;
|
|
285
|
+
this.dispatchConnectState('sync_server_operations_error');
|
|
286
|
+
return;
|
|
287
|
+
}
|
|
288
|
+
|
|
289
|
+
// 2.2 Update document
|
|
290
|
+
this.document.version = serverVersion;
|
|
291
|
+
this.document.children = this.editor.children;
|
|
292
|
+
}
|
|
293
|
+
if (this.revertOperationList.length === 0) {
|
|
294
|
+
Promise.resolve().then(() => {
|
|
295
|
+
this.editor.isRemote = false;
|
|
296
|
+
(0, _debug.stateDebug)(`State Changed: ${this.state} -> ${STATE.IDLE}`);
|
|
297
|
+
this.state = STATE.IDLE;
|
|
298
|
+
this._sendingOperations = null;
|
|
299
|
+
this.revertOperationList = [];
|
|
300
|
+
});
|
|
301
|
+
return;
|
|
302
|
+
}
|
|
303
|
+
|
|
304
|
+
// Set isRemote to false must be in Promise.resolve function, make sure the modification of isRemote is later than the onChange event
|
|
305
|
+
Promise.resolve().then(() => {
|
|
306
|
+
// reset execute remote operations flag
|
|
307
|
+
this.editor.isRemote = false;
|
|
308
|
+
(0, _debug.stateDebug)(`State Changed: ${this.state} -> ${STATE.IDLE}`);
|
|
309
|
+
this.state = STATE.IDLE;
|
|
310
|
+
this._sendingOperations = null;
|
|
311
|
+
|
|
312
|
+
// 3. Execute pending operations
|
|
313
|
+
// 3.1 Re-execute operations
|
|
314
|
+
(0, _debug.conflictDebug)('Editor isRemote is false: %s', this.editor.isRemote);
|
|
315
|
+
(0, _debug.conflictDebug)('Re-execute pending operations, %O', this.revertOperationList);
|
|
316
|
+
(0, _helpers.reExecRevertOperationList)(this.editor, this.revertOperationList);
|
|
317
|
+
|
|
318
|
+
// 3.2 Clear revert operationList
|
|
319
|
+
this.revertOperationList = [];
|
|
320
|
+
(0, _debug.conflictDebug)('Complete conflict resolution');
|
|
321
|
+
});
|
|
322
|
+
});
|
|
323
|
+
(0, _defineProperty2.default)(this, "sendCursorLocation", location => {
|
|
324
|
+
this.socketClient.sendCursorLocation(location);
|
|
325
|
+
});
|
|
326
|
+
(0, _defineProperty2.default)(this, "receiveCursorLocation", params => {
|
|
327
|
+
if (this.editor.readonly) return;
|
|
328
|
+
const {
|
|
329
|
+
user,
|
|
330
|
+
location,
|
|
331
|
+
cursor_data: cursorData
|
|
332
|
+
} = params;
|
|
333
|
+
(0, _helpers.syncRemoteCursorLocation)(this.editor, user, location, cursorData);
|
|
334
|
+
return;
|
|
335
|
+
});
|
|
336
|
+
(0, _defineProperty2.default)(this, "dispatchConnectState", (type, message) => {
|
|
337
|
+
if (type === 'leave-room') {
|
|
338
|
+
(0, _helper.deleteCursor)(this.editor, message);
|
|
339
|
+
this.editor.onCursor && this.editor.onCursor(this.editor.cursors);
|
|
340
|
+
}
|
|
341
|
+
if (type === 'disconnect') {
|
|
342
|
+
// current state is sending
|
|
343
|
+
if (this._sendingOperations) {
|
|
344
|
+
this.pendingOperationList.unshift(this._sendingOperations.slice());
|
|
345
|
+
this._sendingOperations = null;
|
|
346
|
+
}
|
|
347
|
+
(0, _debug.stateDebug)(`State Changed: ${this.state} -> ${STATE.DISCONNECT}`);
|
|
348
|
+
this.state = STATE.DISCONNECT;
|
|
349
|
+
}
|
|
350
|
+
this.eventBus.dispatch(type, message);
|
|
351
|
+
});
|
|
352
|
+
(0, _defineProperty2.default)(this, "closeSocketConnect", () => {
|
|
353
|
+
this.socketClient.disconnectWithServer();
|
|
354
|
+
});
|
|
355
|
+
(0, _defineProperty2.default)(this, "receiveParticipantAdded", uses => {
|
|
356
|
+
this.eventBus.dispatch(_constants.INTERNAL_EVENT.PARTICIPANT_ADDED, uses);
|
|
357
|
+
});
|
|
358
|
+
(0, _defineProperty2.default)(this, "receiveParticipantRemoved", email => {
|
|
359
|
+
this.eventBus.dispatch(_constants.INTERNAL_EVENT.PARTICIPANT_REMOVED, email);
|
|
360
|
+
});
|
|
361
|
+
this.editor = editor;
|
|
362
|
+
this.document = _document;
|
|
363
|
+
this.socketClient = new _socketClient.default(config);
|
|
364
|
+
this.pendingOperationList = []; // Two-dimensional arrays: [operations, operations, ...]
|
|
365
|
+
this.pendingOperationBeginTimeList = [];
|
|
366
|
+
this.remoteOperationsList = []; // Same with pending operations
|
|
367
|
+
this.revertOperationList = [];
|
|
368
|
+
this.eventBus = _eventBus.default.getInstance();
|
|
369
|
+
this.state = STATE.IDLE;
|
|
370
|
+
}
|
|
371
|
+
}
|
|
372
|
+
_SocketManager = SocketManager;
|
|
373
|
+
(0, _defineProperty2.default)(SocketManager, "getInstance", (editor, document, socketConfig) => {
|
|
374
|
+
if (_SocketManager.instance) {
|
|
375
|
+
return _SocketManager.instance;
|
|
376
|
+
}
|
|
377
|
+
if (!document || !socketConfig) {
|
|
378
|
+
throw new Error('SocketManager init params is invalid. Place check your code to fix it.');
|
|
379
|
+
}
|
|
380
|
+
_SocketManager.instance = new _SocketManager(editor, document, socketConfig);
|
|
381
|
+
return _SocketManager.instance;
|
|
382
|
+
});
|
|
383
|
+
(0, _defineProperty2.default)(SocketManager, "destroy", () => {
|
|
384
|
+
_SocketManager.instance = null;
|
|
385
|
+
});
|
|
386
|
+
var _default = exports.default = SocketManager;
|
|
@@ -0,0 +1,73 @@
|
|
|
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 _helper = require("../cursor/helper");
|
|
9
|
+
var _eventBus = _interopRequireDefault(require("../utils/event-bus"));
|
|
10
|
+
var _socketManager = _interopRequireDefault(require("./socket-manager"));
|
|
11
|
+
const withSocketIO = (editor, options) => {
|
|
12
|
+
const {
|
|
13
|
+
onChange
|
|
14
|
+
} = editor;
|
|
15
|
+
const newEditor = editor;
|
|
16
|
+
let socketManager = null;
|
|
17
|
+
const {
|
|
18
|
+
user
|
|
19
|
+
} = options.config;
|
|
20
|
+
newEditor.user = user;
|
|
21
|
+
newEditor.openConnection = () => {
|
|
22
|
+
const {
|
|
23
|
+
document,
|
|
24
|
+
config
|
|
25
|
+
} = options;
|
|
26
|
+
const cursorData = (0, _helper.generateCursorData)(options.config);
|
|
27
|
+
config['cursorData'] = cursorData;
|
|
28
|
+
socketManager = _socketManager.default.getInstance(newEditor, document, config);
|
|
29
|
+
};
|
|
30
|
+
newEditor.closeConnection = () => {
|
|
31
|
+
socketManager && socketManager.closeSocketConnect();
|
|
32
|
+
_socketManager.default.destroy();
|
|
33
|
+
};
|
|
34
|
+
newEditor.onChange = () => {
|
|
35
|
+
if (newEditor.readonly) return;
|
|
36
|
+
const {
|
|
37
|
+
document,
|
|
38
|
+
config
|
|
39
|
+
} = options;
|
|
40
|
+
let operations = newEditor.operations;
|
|
41
|
+
if (!newEditor.isRemote && operations.length > 0) {
|
|
42
|
+
const isAllSetSelection = operations.every(operation => operation.type === 'set_selection');
|
|
43
|
+
const socketManager = _socketManager.default.getInstance(newEditor, document, config);
|
|
44
|
+
if (!isAllSetSelection) {
|
|
45
|
+
// get update content value operations
|
|
46
|
+
const updateOperations = operations.filter(operation => operation.type !== 'set_selection');
|
|
47
|
+
socketManager.onReceiveLocalOperations(updateOperations);
|
|
48
|
+
}
|
|
49
|
+
socketManager.sendCursorLocation(editor.selection);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
// dispatch editor change event
|
|
53
|
+
const eventBus = _eventBus.default.getInstance(newEditor, document, config);
|
|
54
|
+
eventBus.dispatch('change');
|
|
55
|
+
onChange();
|
|
56
|
+
};
|
|
57
|
+
newEditor.rebaseContent = (document, originFileVersion) => {
|
|
58
|
+
const {
|
|
59
|
+
config
|
|
60
|
+
} = options;
|
|
61
|
+
const socketManager = _socketManager.default.getInstance(newEditor, document, config);
|
|
62
|
+
socketManager.sendRebaseContent(document, originFileVersion);
|
|
63
|
+
};
|
|
64
|
+
newEditor.updateDocumentVersion = document => {
|
|
65
|
+
const {
|
|
66
|
+
config
|
|
67
|
+
} = options;
|
|
68
|
+
const socketManager = _socketManager.default.getInstance(newEditor, document, config);
|
|
69
|
+
socketManager.updateDocumentVersion(document);
|
|
70
|
+
};
|
|
71
|
+
return newEditor;
|
|
72
|
+
};
|
|
73
|
+
var _default = exports.default = withSocketIO;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
const KebabToCamel = str => {
|
|
8
|
+
return str.replace(/(_[a-z])/g, match => `${match.slice(1).toUpperCase()}`);
|
|
9
|
+
};
|
|
10
|
+
var _default = exports.default = KebabToCamel;
|