@seafile/sdoc-editor 0.3.6 → 0.3.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/api/sdoc-server-api.js +165 -170
- package/dist/api/seafile-api.js +180 -246
- package/dist/basic-sdk/comment/comment-decorate.js +23 -30
- package/dist/basic-sdk/comment/components/comment-all-participants/index.js +18 -18
- package/dist/basic-sdk/comment/components/comment-all-participants/participant-avatar.js +13 -13
- package/dist/basic-sdk/comment/components/comment-delete-shadow.js +11 -9
- package/dist/basic-sdk/comment/components/comment-editor.js +37 -34
- package/dist/basic-sdk/comment/components/comment-input/comment-participant-item.js +16 -14
- package/dist/basic-sdk/comment/components/comment-input/index.js +110 -106
- package/dist/basic-sdk/comment/components/comment-item-content.js +29 -37
- package/dist/basic-sdk/comment/components/comment-item-reply.js +24 -33
- package/dist/basic-sdk/comment/components/comment-item-resolved-reply.js +5 -3
- package/dist/basic-sdk/comment/components/comment-item-wrapper.js +190 -285
- package/dist/basic-sdk/comment/components/comment-list.js +52 -72
- package/dist/basic-sdk/comment/components/comment-participants-editor/index.js +23 -30
- package/dist/basic-sdk/comment/components/comment-participants-editor/searched-collaborators.js +21 -19
- package/dist/basic-sdk/comment/components/comment-participants-editor/selected-participants.js +16 -14
- package/dist/basic-sdk/comment/components/editor-comment.js +23 -32
- package/dist/basic-sdk/comment/components/elements-comment-count/element-comment-count.js +18 -20
- package/dist/basic-sdk/comment/components/elements-comment-count/index.js +8 -8
- package/dist/basic-sdk/comment/components/global-comment/global-comment-body-header.js +23 -25
- package/dist/basic-sdk/comment/components/global-comment/global-comment-editor.js +9 -7
- package/dist/basic-sdk/comment/components/global-comment/global-comment-header.js +9 -6
- package/dist/basic-sdk/comment/components/global-comment/index.js +63 -86
- package/dist/basic-sdk/comment/constants/index.js +9 -9
- package/dist/basic-sdk/comment/helper.js +27 -26
- package/dist/basic-sdk/comment/hooks/comment-hooks/use-comment-context.js +8 -7
- package/dist/basic-sdk/comment/hooks/comment-hooks/use-comment-list.js +19 -30
- package/dist/basic-sdk/comment/hooks/comment-hooks/use-comment-mount.js +41 -71
- package/dist/basic-sdk/comment/hooks/notification-hooks/use-notification-context.js +8 -7
- package/dist/basic-sdk/comment/hooks/notification-hooks/use-notification-mount.js +45 -64
- package/dist/basic-sdk/comment/hooks/use-participants.js +46 -53
- package/dist/basic-sdk/comment/index.js +22 -19
- package/dist/basic-sdk/comment/provider/comment-context-provider.js +9 -11
- package/dist/basic-sdk/comment/provider/index.js +4 -2
- package/dist/basic-sdk/comment/provider/notification-context-provider.js +9 -11
- package/dist/basic-sdk/comment/reducer/comment-reducer.js +151 -137
- package/dist/basic-sdk/comment/reducer/notification-reducer.js +20 -15
- package/dist/basic-sdk/comment/utils/index.js +180 -173
- package/dist/basic-sdk/comment/utils/notification-utils.js +15 -14
- package/dist/basic-sdk/constants/index.js +9 -9
- package/dist/basic-sdk/cursor/helper.js +13 -9
- package/dist/basic-sdk/cursor/use-cursors.js +9 -13
- package/dist/basic-sdk/decorates/index.js +8 -9
- package/dist/basic-sdk/editor/editable-article.js +63 -57
- package/dist/basic-sdk/editor/sdoc-editor.js +42 -47
- package/dist/basic-sdk/extension/commons/color-menu/color-item.js +6 -4
- package/dist/basic-sdk/extension/commons/color-menu/index.js +40 -50
- package/dist/basic-sdk/extension/commons/dropdown-menu-item/index.js +17 -16
- package/dist/basic-sdk/extension/commons/element-popover/index.js +27 -45
- package/dist/basic-sdk/extension/commons/insert-element-dialog/index.js +46 -59
- package/dist/basic-sdk/extension/commons/menu/menu-group.js +7 -21
- package/dist/basic-sdk/extension/commons/menu/menu-item.js +17 -14
- package/dist/basic-sdk/extension/commons/more-dropdown/index.js +9 -7
- package/dist/basic-sdk/extension/commons/select-file-dialog/helpers.js +3 -3
- package/dist/basic-sdk/extension/commons/select-file-dialog/index.js +26 -23
- package/dist/basic-sdk/extension/commons/select-file-dialog/local-files/index.js +49 -80
- package/dist/basic-sdk/extension/constants/color.js +10 -10
- package/dist/basic-sdk/extension/constants/diff-view.js +3 -3
- package/dist/basic-sdk/extension/constants/element-type.js +29 -29
- package/dist/basic-sdk/extension/constants/font.js +44 -37
- package/dist/basic-sdk/extension/constants/index.js +27 -16
- package/dist/basic-sdk/extension/constants/keyboard.js +4 -4
- package/dist/basic-sdk/extension/constants/menus-config.js +234 -203
- package/dist/basic-sdk/extension/core/queries/index.js +185 -285
- package/dist/basic-sdk/extension/core/transforms/focus-editor.js +2 -2
- package/dist/basic-sdk/extension/core/transforms/move-children.js +14 -14
- package/dist/basic-sdk/extension/core/transforms/remove-node-children.js +6 -18
- package/dist/basic-sdk/extension/core/transforms/replace-node.js +22 -19
- package/dist/basic-sdk/extension/core/transforms/update-parent-node.js +6 -8
- package/dist/basic-sdk/extension/core/utils/index.js +12 -12
- package/dist/basic-sdk/extension/index.js +6 -6
- package/dist/basic-sdk/extension/plugins/blockquote/helpers.js +39 -54
- package/dist/basic-sdk/extension/plugins/blockquote/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/blockquote/menu/index.js +34 -44
- package/dist/basic-sdk/extension/plugins/blockquote/model.js +8 -9
- package/dist/basic-sdk/extension/plugins/blockquote/plugin.js +36 -37
- package/dist/basic-sdk/extension/plugins/blockquote/render-elem.js +7 -5
- package/dist/basic-sdk/extension/plugins/check-list/helpers.js +15 -25
- package/dist/basic-sdk/extension/plugins/check-list/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/check-list/menu/index.js +35 -45
- package/dist/basic-sdk/extension/plugins/check-list/model.js +9 -10
- package/dist/basic-sdk/extension/plugins/check-list/plugin.js +16 -10
- package/dist/basic-sdk/extension/plugins/check-list/render-elem.js +42 -56
- package/dist/basic-sdk/extension/plugins/clear-format/helpers.js +21 -36
- package/dist/basic-sdk/extension/plugins/clear-format/menu/index.js +12 -10
- package/dist/basic-sdk/extension/plugins/code-block/helpers.js +40 -58
- package/dist/basic-sdk/extension/plugins/code-block/hover-menu/index.js +38 -46
- package/dist/basic-sdk/extension/plugins/code-block/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/code-block/menu/index.js +9 -7
- package/dist/basic-sdk/extension/plugins/code-block/model.js +8 -9
- package/dist/basic-sdk/extension/plugins/code-block/plugin.js +44 -51
- package/dist/basic-sdk/extension/plugins/code-block/prismjs.js +27 -27
- package/dist/basic-sdk/extension/plugins/code-block/render-elem.js +62 -58
- package/dist/basic-sdk/extension/plugins/file-link/constants/index.js +16 -14
- package/dist/basic-sdk/extension/plugins/file-link/helpers.js +34 -36
- package/dist/basic-sdk/extension/plugins/file-link/hover-menu/index.js +19 -23
- package/dist/basic-sdk/extension/plugins/file-link/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/file-link/menu/index.js +10 -8
- package/dist/basic-sdk/extension/plugins/file-link/plugin.js +17 -11
- package/dist/basic-sdk/extension/plugins/file-link/render-elem.js +34 -38
- package/dist/basic-sdk/extension/plugins/font/helpers.js +75 -78
- package/dist/basic-sdk/extension/plugins/font/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/font/menu/font-family/font-item.js +14 -13
- package/dist/basic-sdk/extension/plugins/font/menu/font-family/index.js +38 -55
- package/dist/basic-sdk/extension/plugins/font/menu/font-size/font-size-scale.js +12 -10
- package/dist/basic-sdk/extension/plugins/font/menu/font-size/index.js +29 -31
- package/dist/basic-sdk/extension/plugins/font/menu/index.js +5 -3
- package/dist/basic-sdk/extension/plugins/font/plugin.js +4 -4
- package/dist/basic-sdk/extension/plugins/header/helpers.js +32 -38
- package/dist/basic-sdk/extension/plugins/header/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/header/menu/index.js +101 -107
- package/dist/basic-sdk/extension/plugins/header/plugin.js +41 -44
- package/dist/basic-sdk/extension/plugins/header/render-elem.js +28 -20
- package/dist/basic-sdk/extension/plugins/html/helper.js +30 -28
- package/dist/basic-sdk/extension/plugins/html/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/html/plugin.js +12 -10
- package/dist/basic-sdk/extension/plugins/html/rules/blockquote.js +5 -3
- package/dist/basic-sdk/extension/plugins/html/rules/check-list.js +4 -2
- package/dist/basic-sdk/extension/plugins/html/rules/code-block.js +20 -24
- package/dist/basic-sdk/extension/plugins/html/rules/header.js +7 -5
- package/dist/basic-sdk/extension/plugins/html/rules/image.js +4 -2
- package/dist/basic-sdk/extension/plugins/html/rules/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/html/rules/link.js +5 -3
- package/dist/basic-sdk/extension/plugins/html/rules/list.js +6 -4
- package/dist/basic-sdk/extension/plugins/html/rules/paragraph.js +5 -3
- package/dist/basic-sdk/extension/plugins/html/rules/table.js +5 -3
- package/dist/basic-sdk/extension/plugins/html/rules/text.js +5 -3
- package/dist/basic-sdk/extension/plugins/image/constants/index.js +2 -2
- package/dist/basic-sdk/extension/plugins/image/dialogs/image-previewer.js +59 -75
- package/dist/basic-sdk/extension/plugins/image/helpers.js +74 -98
- package/dist/basic-sdk/extension/plugins/image/hover-menu/index.js +49 -62
- package/dist/basic-sdk/extension/plugins/image/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/image/menu/index.js +12 -9
- package/dist/basic-sdk/extension/plugins/image/model.js +11 -12
- package/dist/basic-sdk/extension/plugins/image/plugin.js +43 -35
- package/dist/basic-sdk/extension/plugins/image/render-elem.js +73 -91
- package/dist/basic-sdk/extension/plugins/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/link/dialog/add-link-dialog/index.js +30 -39
- package/dist/basic-sdk/extension/plugins/link/helpers.js +76 -100
- package/dist/basic-sdk/extension/plugins/link/hover/index.js +12 -9
- package/dist/basic-sdk/extension/plugins/link/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/link/menu/index.js +10 -8
- package/dist/basic-sdk/extension/plugins/link/model.js +10 -11
- package/dist/basic-sdk/extension/plugins/link/plugin.js +28 -31
- package/dist/basic-sdk/extension/plugins/link/render-elem.js +66 -74
- package/dist/basic-sdk/extension/plugins/list/helpers.js +45 -57
- package/dist/basic-sdk/extension/plugins/list/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/list/menu/index.js +37 -49
- package/dist/basic-sdk/extension/plugins/list/model.js +11 -12
- package/dist/basic-sdk/extension/plugins/list/plugin/index.js +16 -12
- package/dist/basic-sdk/extension/plugins/list/plugin/insert-break-list.js +4 -4
- package/dist/basic-sdk/extension/plugins/list/plugin/insert-fragment-list.js +54 -70
- package/dist/basic-sdk/extension/plugins/list/plugin/normalize-list.js +16 -20
- package/dist/basic-sdk/extension/plugins/list/plugin/on-tab-handle.js +19 -14
- package/dist/basic-sdk/extension/plugins/list/plugin/shortcut.js +20 -28
- package/dist/basic-sdk/extension/plugins/list/queries/index.js +16 -18
- package/dist/basic-sdk/extension/plugins/list/render-elem.js +23 -15
- package/dist/basic-sdk/extension/plugins/list/transforms/insert-list-item.js +20 -24
- package/dist/basic-sdk/extension/plugins/list/transforms/move-list-item-down.js +16 -19
- package/dist/basic-sdk/extension/plugins/list/transforms/move-list-item-up.js +31 -35
- package/dist/basic-sdk/extension/plugins/list/transforms/move-list-items-to-list.js +18 -18
- package/dist/basic-sdk/extension/plugins/list/transforms/move-list-items.js +23 -24
- package/dist/basic-sdk/extension/plugins/list/transforms/normalize-list-item.js +38 -55
- package/dist/basic-sdk/extension/plugins/list/transforms/normalize-nested-list.js +11 -13
- package/dist/basic-sdk/extension/plugins/list/transforms/remove-first-list-item.js +8 -8
- package/dist/basic-sdk/extension/plugins/list/transforms/toggle-list.js +42 -50
- package/dist/basic-sdk/extension/plugins/list/transforms/unwrap-list.js +11 -14
- package/dist/basic-sdk/extension/plugins/markdown/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/markdown/plugin.js +59 -52
- package/dist/basic-sdk/extension/plugins/paragraph/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/paragraph/render-elem.js +12 -10
- package/dist/basic-sdk/extension/plugins/sdoc-link/constants/index.js +16 -14
- package/dist/basic-sdk/extension/plugins/sdoc-link/helpers.js +66 -65
- package/dist/basic-sdk/extension/plugins/sdoc-link/hover-menu/index.js +19 -23
- package/dist/basic-sdk/extension/plugins/sdoc-link/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/sdoc-link/menu/index.js +10 -8
- package/dist/basic-sdk/extension/plugins/sdoc-link/plugin.js +23 -15
- package/dist/basic-sdk/extension/plugins/sdoc-link/render-elem.js +35 -39
- package/dist/basic-sdk/extension/plugins/table/constants/index.js +16 -14
- package/dist/basic-sdk/extension/plugins/table/dialog/custom-table-size-dialog/index.js +17 -24
- package/dist/basic-sdk/extension/plugins/table/dialog/custom-table-size-dialog/number-input.js +9 -7
- package/dist/basic-sdk/extension/plugins/table/helpers.js +466 -440
- package/dist/basic-sdk/extension/plugins/table/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/table/menu/active-table-menu/cell-bg-color-menu.js +16 -13
- package/dist/basic-sdk/extension/plugins/table/menu/active-table-menu/cell-text-align-menu.js +16 -18
- package/dist/basic-sdk/extension/plugins/table/menu/active-table-menu/common-menu.js +58 -65
- package/dist/basic-sdk/extension/plugins/table/menu/active-table-menu/index.js +7 -5
- package/dist/basic-sdk/extension/plugins/table/menu/active-table-menu/remove-table-menu.js +11 -9
- package/dist/basic-sdk/extension/plugins/table/menu/active-table-menu/table-column-menu.js +13 -14
- package/dist/basic-sdk/extension/plugins/table/menu/active-table-menu/table-row-menu.js +13 -14
- package/dist/basic-sdk/extension/plugins/table/menu/table-context-menu/index.js +92 -105
- package/dist/basic-sdk/extension/plugins/table/menu/table-context-menu/insert-table-element.js +62 -66
- package/dist/basic-sdk/extension/plugins/table/menu/table-menu/index.js +9 -7
- package/dist/basic-sdk/extension/plugins/table/model.js +14 -15
- package/dist/basic-sdk/extension/plugins/table/plugin.js +130 -112
- package/dist/basic-sdk/extension/plugins/table/popover/table-size-popover/index.js +31 -45
- package/dist/basic-sdk/extension/plugins/table/popover/table-template/index.js +12 -14
- package/dist/basic-sdk/extension/plugins/table/popover/table-template/sample-table.js +15 -19
- package/dist/basic-sdk/extension/plugins/table/render/hooks.js +25 -32
- package/dist/basic-sdk/extension/plugins/table/render/index.js +57 -67
- package/dist/basic-sdk/extension/plugins/table/render/render-cell.js +42 -36
- package/dist/basic-sdk/extension/plugins/table/render/render-row.js +44 -49
- package/dist/basic-sdk/extension/plugins/table/render/resize-handlers/first-column-left-resize-handler.js +36 -45
- package/dist/basic-sdk/extension/plugins/table/render/resize-handlers/index.js +10 -8
- package/dist/basic-sdk/extension/plugins/table/render/resize-handlers/resize-handler.js +41 -50
- package/dist/basic-sdk/extension/plugins/table/render/table-header/columns-header/column-header.js +30 -29
- package/dist/basic-sdk/extension/plugins/table/render/table-header/columns-header/index.js +21 -33
- package/dist/basic-sdk/extension/plugins/table/render/table-header/index.js +17 -15
- package/dist/basic-sdk/extension/plugins/table/render/table-header/rows-columns-header.js +7 -5
- package/dist/basic-sdk/extension/plugins/table/render/table-header/rows-header/index.js +22 -32
- package/dist/basic-sdk/extension/plugins/table/render/table-header/rows-header/row-header.js +41 -43
- package/dist/basic-sdk/extension/plugins/table/render/table-root.js +16 -20
- package/dist/basic-sdk/extension/plugins/text-align/helpers.js +19 -24
- package/dist/basic-sdk/extension/plugins/text-align/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/text-align/menu/index.js +20 -26
- package/dist/basic-sdk/extension/plugins/text-style/caret.js +9 -7
- package/dist/basic-sdk/extension/plugins/text-style/helpers.js +17 -24
- package/dist/basic-sdk/extension/plugins/text-style/index.js +1 -1
- package/dist/basic-sdk/extension/plugins/text-style/menu/index.js +38 -37
- package/dist/basic-sdk/extension/plugins/text-style/plugin.js +6 -6
- package/dist/basic-sdk/extension/plugins/text-style/render-elem.js +14 -10
- package/dist/basic-sdk/extension/render/custom-element.js +30 -49
- package/dist/basic-sdk/extension/render/element-decorate/rebase-decorate/index.js +6 -4
- package/dist/basic-sdk/extension/render/element-decorate/rebase-decorate/rebase-delete-modify-decorate.js +13 -10
- package/dist/basic-sdk/extension/render/element-decorate/rebase-decorate/rebase-modify-delete-decorate.js +13 -10
- package/dist/basic-sdk/extension/render/element-decorate/rebase-decorate/rebase-modify-modify-decorate.js +21 -19
- package/dist/basic-sdk/extension/render/render-element.js +5 -3
- package/dist/basic-sdk/extension/render/render-leaf.js +4 -6
- package/dist/basic-sdk/extension/toolbar/context-toolbar/index.js +18 -16
- package/dist/basic-sdk/extension/toolbar/header-toolbar/index.js +5 -3
- package/dist/basic-sdk/extension/toolbar/header-toolbar/insert-toolbar/index.js +29 -29
- package/dist/basic-sdk/extension/toolbar/header-toolbar/redo-undo.js +45 -53
- package/dist/basic-sdk/extension/toolbar/side-toolbar/event.js +8 -8
- package/dist/basic-sdk/extension/toolbar/side-toolbar/helpers.js +45 -49
- package/dist/basic-sdk/extension/toolbar/side-toolbar/index.js +50 -72
- package/dist/basic-sdk/extension/toolbar/side-toolbar/insert-below-menu.js +5 -3
- package/dist/basic-sdk/extension/toolbar/side-toolbar/insert-block-menu.js +25 -26
- package/dist/basic-sdk/extension/toolbar/side-toolbar/side-menu.js +24 -26
- package/dist/basic-sdk/extension/toolbar/side-toolbar/transform-menus.js +14 -16
- package/dist/basic-sdk/extension/utils/index.js +4 -4
- package/dist/basic-sdk/highlight/index.js +8 -13
- package/dist/basic-sdk/highlight/setNodeToDecorations.js +43 -73
- package/dist/basic-sdk/hooks/use-color-context.js +27 -35
- package/dist/basic-sdk/hooks/use-scroll-context.js +6 -4
- package/dist/basic-sdk/hooks/use-selection-element.js +5 -7
- package/dist/basic-sdk/hooks/use-selection-position.js +13 -15
- package/dist/basic-sdk/hooks/use-selection-update.js +6 -11
- package/dist/basic-sdk/layout/article-container.js +20 -23
- package/dist/basic-sdk/layout/editor-container.js +6 -4
- package/dist/basic-sdk/layout/editor-content.js +15 -15
- package/dist/basic-sdk/node-id/constants.js +9 -9
- package/dist/basic-sdk/node-id/helpers.js +44 -29
- package/dist/basic-sdk/node-id/index.js +13 -11
- package/dist/basic-sdk/outline/index.js +24 -27
- package/dist/basic-sdk/outline/outline-item.js +39 -44
- package/dist/basic-sdk/socket/helpers.js +99 -90
- package/dist/basic-sdk/socket/socket-client.js +175 -171
- package/dist/basic-sdk/socket/socket-manager.js +316 -297
- package/dist/basic-sdk/socket/with-socket-io.js +38 -30
- package/dist/basic-sdk/utils/debug.js +4 -4
- package/dist/basic-sdk/utils/diff-text.js +191 -193
- package/dist/basic-sdk/utils/diff.js +115 -106
- package/dist/basic-sdk/utils/document-utils.js +10 -13
- package/dist/basic-sdk/utils/dom-utils.js +18 -16
- package/dist/basic-sdk/utils/event-bus.js +26 -39
- package/dist/basic-sdk/utils/event-handler.js +81 -79
- package/dist/basic-sdk/utils/mouse-event.js +29 -27
- package/dist/basic-sdk/utils/object-utils.js +35 -53
- package/dist/basic-sdk/utils/rebase.js +101 -76
- package/dist/basic-sdk/views/published-revision-diff-viewer.js +19 -22
- package/dist/basic-sdk/views/readonly-article.js +7 -5
- package/dist/basic-sdk/views/revision-diff-viewer.js +15 -18
- package/dist/basic-sdk/views/sdoc-diff-viewer.js +8 -6
- package/dist/basic-sdk/views/sdoc-viewer.js +9 -7
- package/dist/components/common-loading/index.js +1 -1
- package/dist/components/doc-info/index.js +25 -23
- package/dist/components/doc-operations/collaborators-operation/collaborators-popover.js +36 -49
- package/dist/components/doc-operations/collaborators-operation/index.js +58 -76
- package/dist/components/doc-operations/comments-operation/index.js +7 -13
- package/dist/components/doc-operations/history-operation.js +5 -5
- package/dist/components/doc-operations/index.js +10 -9
- package/dist/components/doc-operations/more-operations.js +15 -21
- package/dist/components/doc-operations/revision-operations/changes-count/index.js +15 -16
- package/dist/components/doc-operations/revision-operations/index.js +65 -71
- package/dist/components/doc-operations/revision-operations/more-revision-operations/index.js +13 -17
- package/dist/components/doc-operations/revision-operations/publish-revision/index.js +8 -5
- package/dist/components/doc-operations/revision-operations/revisions/index.js +13 -19
- package/dist/components/doc-operations/revision-operations/revisions/revisions-dialog/index.js +56 -87
- package/dist/components/doc-operations/revision-operations/revisions/revisions-dialog/revision-operation/index.js +14 -16
- package/dist/components/doc-operations/revision-operations/view-changes/index.js +25 -32
- package/dist/components/doc-operations/share-operation/index.js +2 -2
- package/dist/components/doc-operations/tag-operation/constans.js +1 -1
- package/dist/components/doc-operations/tag-operation/file-tag-quick-view/index.js +26 -42
- package/dist/components/doc-operations/tag-operation/index.js +1 -1
- package/dist/components/doc-operations/tag-operation/tag-popover/index.js +95 -175
- package/dist/components/doc-operations/tag-operation/utils.js +2 -6
- package/dist/components/draft-dropdown/index.js +44 -53
- package/dist/components/loading/index.js +8 -22
- package/dist/components/modal-portal/index.js +15 -32
- package/dist/components/switch/index.js +8 -6
- package/dist/components/tip-dialog/index.js +21 -23
- package/dist/components/tip-message/index.js +93 -92
- package/dist/components/toast/alert.js +73 -88
- package/dist/components/toast/index.js +1 -1
- package/dist/components/toast/toast.js +76 -103
- package/dist/components/toast/toastManager.js +55 -89
- package/dist/components/toast/toaster.js +54 -56
- package/dist/components/tooltip/index.js +15 -16
- package/dist/constants/index.js +26 -6
- package/dist/constants/transfer-types.js +3 -3
- package/dist/context.js +242 -339
- package/dist/hooks/use-collaborators.js +18 -20
- package/dist/hooks/use-document.js +33 -45
- package/dist/layout/content.js +13 -26
- package/dist/layout/header.js +13 -26
- package/dist/layout/layout.js +11 -9
- package/dist/model/notification.js +10 -11
- package/dist/model/revision.js +27 -28
- package/dist/model/user.js +10 -11
- package/dist/pages/error-boundary.js +18 -36
- package/dist/pages/error-page.js +14 -26
- package/dist/pages/published-revision-viewer.js +23 -35
- package/dist/pages/simple-editor.js +39 -46
- package/dist/pages/simple-viewer.js +70 -104
- package/dist/utils/date-utils.js +67 -81
- package/dist/utils/get-event-transfer.js +13 -15
- package/dist/utils/hotkey.js +24 -24
- package/dist/utils/index.js +20 -20
- package/dist/utils/local-storage-utils.js +41 -58
- package/package.json +10 -10
- package/public/locales/cs/sdoc-editor.json +3 -1
- package/public/locales/de/sdoc-editor.json +3 -1
- package/public/locales/en/sdoc-editor.json +1 -0
- package/public/locales/es/sdoc-editor.json +3 -1
- package/public/locales/fr/sdoc-editor.json +3 -1
- package/public/locales/it/sdoc-editor.json +3 -1
- package/public/locales/ru/sdoc-editor.json +3 -1
- package/public/locales/zh_CN/sdoc-editor.json +1 -0
|
@@ -2,9 +2,11 @@ import React from 'react';
|
|
|
2
2
|
import { UncontrolledPopover } from 'reactstrap';
|
|
3
3
|
import InsertBlockMenu from './insert-block-menu';
|
|
4
4
|
import { INSERT_POSITION } from '../../constants';
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
5
|
+
const InsertBelowMenu = _ref => {
|
|
6
|
+
let {
|
|
7
|
+
target,
|
|
8
|
+
slateNode
|
|
9
|
+
} = _ref;
|
|
8
10
|
return /*#__PURE__*/React.createElement(UncontrolledPopover, {
|
|
9
11
|
boundariesElement: "viewport",
|
|
10
12
|
target: target,
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
|
|
2
1
|
import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
|
|
3
2
|
import React, { useCallback } from 'react';
|
|
4
3
|
import { useSlateStatic } from '@seafile/slate-react';
|
|
@@ -13,54 +12,56 @@ import { ELEMENT_TYPE, INSERT_POSITION, LOCAL_IMAGE, SIDE_INSERT_MENUS_CONFIG }
|
|
|
13
12
|
import EventBus from '../../../utils/event-bus';
|
|
14
13
|
import { INTERNAL_EVENT } from '../../../constants';
|
|
15
14
|
import DropdownMenuItem from '../../commons/dropdown-menu-item';
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
15
|
+
const InsertBlockMenu = _ref => {
|
|
16
|
+
let {
|
|
17
|
+
insertPosition,
|
|
18
|
+
slateNode
|
|
19
|
+
} = _ref;
|
|
20
|
+
const editor = useSlateStatic();
|
|
21
|
+
const onInsertImageToggle = useCallback(() => {
|
|
22
|
+
const eventBus = EventBus.getInstance();
|
|
22
23
|
if (insertPosition === INSERT_POSITION.CURRENT) {
|
|
23
24
|
Transforms.select(editor, editor.selection.focus);
|
|
24
25
|
}
|
|
25
26
|
eventBus.dispatch(INTERNAL_EVENT.INSERT_ELEMENT, {
|
|
26
27
|
type: LOCAL_IMAGE,
|
|
27
|
-
insertPosition
|
|
28
|
-
slateNode
|
|
28
|
+
insertPosition,
|
|
29
|
+
slateNode
|
|
29
30
|
});
|
|
30
31
|
|
|
31
32
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
32
33
|
}, [editor, insertPosition]);
|
|
33
|
-
|
|
34
|
-
|
|
34
|
+
const createTable = useCallback(size => {
|
|
35
|
+
const newInsertPosition = slateNode.type === ELEMENT_TYPE.LIST_ITEM ? INSERT_POSITION.AFTER : insertPosition;
|
|
35
36
|
insertTable(editor, size, editor.selection, newInsertPosition);
|
|
36
37
|
|
|
37
38
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
38
39
|
}, [editor, insertPosition, slateNode]);
|
|
39
|
-
|
|
40
|
-
|
|
40
|
+
const openLinkDialog = useCallback(() => {
|
|
41
|
+
const eventBus = EventBus.getInstance();
|
|
41
42
|
eventBus.dispatch(INTERNAL_EVENT.INSERT_ELEMENT, {
|
|
42
43
|
type: ELEMENT_TYPE.LINK,
|
|
43
|
-
insertPosition
|
|
44
|
-
slateNode
|
|
44
|
+
insertPosition,
|
|
45
|
+
slateNode
|
|
45
46
|
});
|
|
46
47
|
|
|
47
48
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
48
49
|
}, [insertPosition]);
|
|
49
|
-
|
|
50
|
-
|
|
50
|
+
const onInsertCodeBlock = useCallback(() => {
|
|
51
|
+
const newInsertPosition = slateNode.type === ELEMENT_TYPE.LIST_ITEM ? INSERT_POSITION.AFTER : insertPosition;
|
|
51
52
|
changeToCodeBlock(editor, 'plaintext', newInsertPosition);
|
|
52
53
|
|
|
53
54
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
54
55
|
}, [editor, insertPosition, slateNode]);
|
|
55
|
-
|
|
56
|
+
const onInsertList = useCallback(type => {
|
|
56
57
|
toggleList(editor, type, insertPosition);
|
|
57
58
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
58
59
|
}, [editor, insertPosition, slateNode]);
|
|
59
|
-
|
|
60
|
+
const onInsertCheckList = useCallback(() => {
|
|
60
61
|
setCheckListItemType(editor, ELEMENT_TYPE.CHECK_LIST_ITEM, insertPosition);
|
|
61
62
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
62
63
|
}, [editor, insertPosition, slateNode]);
|
|
63
|
-
|
|
64
|
+
const onInsert = useCallback(type => {
|
|
64
65
|
insertElement(editor, type, insertPosition);
|
|
65
66
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
66
67
|
}, [editor, insertPosition, slateNode]);
|
|
@@ -87,24 +88,22 @@ var InsertBlockMenu = function InsertBlockMenu(_ref) {
|
|
|
87
88
|
onClick: onInsertCodeBlock
|
|
88
89
|
}), /*#__PURE__*/React.createElement(DropdownMenuItem, {
|
|
89
90
|
menuConfig: _objectSpread({}, SIDE_INSERT_MENUS_CONFIG[ELEMENT_TYPE.UNORDERED_LIST]),
|
|
90
|
-
onClick:
|
|
91
|
+
onClick: () => {
|
|
91
92
|
onInsertList(ELEMENT_TYPE.UNORDERED_LIST);
|
|
92
93
|
}
|
|
93
94
|
}), /*#__PURE__*/React.createElement(DropdownMenuItem, {
|
|
94
95
|
menuConfig: _objectSpread({}, SIDE_INSERT_MENUS_CONFIG[ELEMENT_TYPE.ORDERED_LIST]),
|
|
95
|
-
onClick:
|
|
96
|
+
onClick: () => {
|
|
96
97
|
onInsertList(ELEMENT_TYPE.ORDERED_LIST);
|
|
97
98
|
}
|
|
98
99
|
}), /*#__PURE__*/React.createElement(DropdownMenuItem, {
|
|
99
100
|
menuConfig: _objectSpread({}, SIDE_INSERT_MENUS_CONFIG[ELEMENT_TYPE.CHECK_LIST_ITEM]),
|
|
100
101
|
onClick: onInsertCheckList
|
|
101
|
-
}), [SIDE_INSERT_MENUS_CONFIG[ELEMENT_TYPE.PARAGRAPH]
|
|
102
|
+
}), [SIDE_INSERT_MENUS_CONFIG[ELEMENT_TYPE.PARAGRAPH], ...SIDE_INSERT_MENUS_CONFIG[ELEMENT_TYPE.HEADER]].map(item => {
|
|
102
103
|
return /*#__PURE__*/React.createElement(DropdownMenuItem, {
|
|
103
104
|
key: item.id,
|
|
104
105
|
menuConfig: item,
|
|
105
|
-
onClick:
|
|
106
|
-
return onInsert(item.type);
|
|
107
|
-
}
|
|
106
|
+
onClick: () => onInsert(item.type)
|
|
108
107
|
});
|
|
109
108
|
}));
|
|
110
109
|
};
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
|
|
2
1
|
import React, { useCallback, useEffect, useRef, useState } from 'react';
|
|
3
2
|
import { withTranslation } from 'react-i18next';
|
|
4
3
|
import { useSlateStatic } from '@seafile/slate-react';
|
|
@@ -14,41 +13,40 @@ import DropdownMenuItem from '../../commons/dropdown-menu-item';
|
|
|
14
13
|
import toaster from '../../../../components/toast';
|
|
15
14
|
import { HEADER1, HEADER2, HEADER3 } from '../../constants';
|
|
16
15
|
import './side-menu.css';
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
var unsubscribeChange = eventBus.subscribe('change', onReset);
|
|
16
|
+
const SideMenu = _ref => {
|
|
17
|
+
let {
|
|
18
|
+
slateNode,
|
|
19
|
+
isNodeEmpty,
|
|
20
|
+
menuPosition,
|
|
21
|
+
onReset,
|
|
22
|
+
t
|
|
23
|
+
} = _ref;
|
|
24
|
+
const sideMenuRef = useRef(null);
|
|
25
|
+
const [menuStyle, setMenuStyle] = useState('');
|
|
26
|
+
const editor = useSlateStatic();
|
|
27
|
+
useEffect(() => {
|
|
28
|
+
const eventBus = EventBus.getInstance();
|
|
29
|
+
const unsubscribeChange = eventBus.subscribe('change', onReset);
|
|
32
30
|
return unsubscribeChange;
|
|
33
31
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
34
32
|
}, []);
|
|
35
|
-
|
|
33
|
+
const onCopy = useCallback(() => {
|
|
36
34
|
onCopyNode(editor, slateNode);
|
|
37
35
|
onReset();
|
|
38
36
|
}, [editor, onReset, slateNode]);
|
|
39
|
-
|
|
37
|
+
const onCut = useCallback(() => {
|
|
40
38
|
onCopyNode(editor, slateNode);
|
|
41
39
|
onDeleteNode(editor, slateNode);
|
|
42
40
|
onReset();
|
|
43
41
|
}, [editor, onReset, slateNode]);
|
|
44
|
-
|
|
42
|
+
const onDelete = useCallback(() => {
|
|
45
43
|
onDeleteNode(editor, slateNode);
|
|
46
44
|
onReset();
|
|
47
45
|
}, [editor, onReset, slateNode]);
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
46
|
+
const onCopyHeaderLink = useCallback(() => {
|
|
47
|
+
const serviceUrl = context.getSetting('serviceUrl');
|
|
48
|
+
const sdocUuid = context.getSetting('docUuid');
|
|
49
|
+
const href = serviceUrl + "/smart-link/".concat(sdocUuid, "/#").concat(slateNode.id);
|
|
52
50
|
copy(href);
|
|
53
51
|
toaster.success(t('Copied'), {
|
|
54
52
|
hasCloseButton: false,
|
|
@@ -56,10 +54,10 @@ var SideMenu = function SideMenu(_ref) {
|
|
|
56
54
|
});
|
|
57
55
|
onReset();
|
|
58
56
|
}, [onReset, slateNode.id, t]);
|
|
59
|
-
useEffect(
|
|
60
|
-
|
|
57
|
+
useEffect(() => {
|
|
58
|
+
let top = menuPosition.top;
|
|
61
59
|
if (sideMenuRef.current) {
|
|
62
|
-
|
|
60
|
+
const overflowY = menuPosition.top + sideMenuRef.current.offsetHeight - document.body.clientHeight;
|
|
63
61
|
if (overflowY > 0) {
|
|
64
62
|
top = menuPosition.top - overflowY - 10;
|
|
65
63
|
}
|
|
@@ -5,23 +5,23 @@ import { useSlateStatic } from '@seafile/slate-react';
|
|
|
5
5
|
import { onSetNodeType } from './helpers';
|
|
6
6
|
import { SIDE_TRANSFORM_MENUS_CONFIG, LIST_ITEM_SUPPORTED_TRANSFORMATION, LIST_ITEM_CORRELATION_TYPE } from '../../constants';
|
|
7
7
|
import DropdownMenuItem from '../../commons/dropdown-menu-item';
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
8
|
+
const TransformMenus = _ref => {
|
|
9
|
+
let {
|
|
10
|
+
target,
|
|
11
|
+
slateNode,
|
|
12
|
+
onReset,
|
|
13
|
+
t
|
|
14
|
+
} = _ref;
|
|
15
|
+
const editor = useSlateStatic();
|
|
16
|
+
const onSetType = useCallback(newType => {
|
|
15
17
|
onSetNodeType(editor, slateNode, newType);
|
|
16
18
|
onReset();
|
|
17
19
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
18
20
|
}, []);
|
|
19
|
-
|
|
20
|
-
|
|
21
|
+
const getSideMenusConfig = useCallback(SIDE_TRANSFORM_MENUS_CONFIG => {
|
|
22
|
+
let newSideMenusConfig = SIDE_TRANSFORM_MENUS_CONFIG;
|
|
21
23
|
if (LIST_ITEM_CORRELATION_TYPE.includes(slateNode.type)) {
|
|
22
|
-
newSideMenusConfig = SIDE_TRANSFORM_MENUS_CONFIG.filter(
|
|
23
|
-
return LIST_ITEM_SUPPORTED_TRANSFORMATION.includes(item.type);
|
|
24
|
-
});
|
|
24
|
+
newSideMenusConfig = SIDE_TRANSFORM_MENUS_CONFIG.filter(item => LIST_ITEM_SUPPORTED_TRANSFORMATION.includes(item.type));
|
|
25
25
|
}
|
|
26
26
|
return newSideMenusConfig;
|
|
27
27
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
@@ -36,13 +36,11 @@ var TransformMenus = function TransformMenus(_ref) {
|
|
|
36
36
|
fade: false
|
|
37
37
|
}, /*#__PURE__*/React.createElement("div", {
|
|
38
38
|
className: "sdoc-dropdown-menu-container"
|
|
39
|
-
}, getSideMenusConfig(SIDE_TRANSFORM_MENUS_CONFIG).map(
|
|
39
|
+
}, getSideMenusConfig(SIDE_TRANSFORM_MENUS_CONFIG).map(item => {
|
|
40
40
|
return /*#__PURE__*/React.createElement(DropdownMenuItem, {
|
|
41
41
|
key: item.id,
|
|
42
42
|
menuConfig: item,
|
|
43
|
-
onClick:
|
|
44
|
-
return onSetType(item.type);
|
|
45
|
-
}
|
|
43
|
+
onClick: () => onSetType(item.type)
|
|
46
44
|
});
|
|
47
45
|
})));
|
|
48
46
|
};
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import isUrl from 'is-url';
|
|
2
|
-
export
|
|
3
|
-
export
|
|
2
|
+
export const IMAGE_TYPES = ['png', 'jpg', 'gif'];
|
|
3
|
+
export const isImage = url => {
|
|
4
4
|
if (!url) return false;
|
|
5
5
|
if (!isUrl(url)) return false;
|
|
6
|
-
|
|
6
|
+
const suffix = url.split('.')[1]; // http://xx/mm/*.png
|
|
7
7
|
if (!suffix) return false;
|
|
8
8
|
return IMAGE_TYPES.includes(suffix.toLowerCase());
|
|
9
9
|
};
|
|
10
|
-
export
|
|
10
|
+
export const isSameDomain = (currentUrl, targetUrl) => {
|
|
11
11
|
return String(currentUrl).split('/')[2] === String(targetUrl).split('/')[2];
|
|
12
12
|
};
|
|
@@ -1,19 +1,14 @@
|
|
|
1
|
-
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
|
|
2
1
|
import { Element } from '@seafile/slate';
|
|
3
2
|
import { CODE_LINE } from '../extension/constants';
|
|
4
3
|
import { SetNodeToDecorations } from './setNodeToDecorations';
|
|
5
|
-
export
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
if (Element.isElement(node) && node.type === CODE_LINE) {
|
|
12
|
-
var _editor$nodeToDecorat;
|
|
13
|
-
ranges = (editor === null || editor === void 0 ? void 0 : (_editor$nodeToDecorat = editor.nodeToDecorations) === null || _editor$nodeToDecorat === void 0 ? void 0 : _editor$nodeToDecorat.get(node)) || [];
|
|
14
|
-
return ranges;
|
|
15
|
-
}
|
|
4
|
+
export const highlightDecorate = editor => _ref => {
|
|
5
|
+
let [node, path] = _ref;
|
|
6
|
+
let ranges = [];
|
|
7
|
+
if (Element.isElement(node) && node.type === CODE_LINE) {
|
|
8
|
+
var _editor$nodeToDecorat;
|
|
9
|
+
ranges = (editor === null || editor === void 0 ? void 0 : (_editor$nodeToDecorat = editor.nodeToDecorations) === null || _editor$nodeToDecorat === void 0 ? void 0 : _editor$nodeToDecorat.get(node)) || [];
|
|
16
10
|
return ranges;
|
|
17
|
-
}
|
|
11
|
+
}
|
|
12
|
+
return ranges;
|
|
18
13
|
};
|
|
19
14
|
export { SetNodeToDecorations };
|
|
@@ -1,105 +1,75 @@
|
|
|
1
1
|
import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
|
|
2
|
-
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
|
|
3
|
-
import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
|
|
4
|
-
import _createForOfIteratorHelper from "@babel/runtime/helpers/esm/createForOfIteratorHelper";
|
|
5
2
|
import { Node, Element, Editor } from '@seafile/slate';
|
|
6
3
|
import { useSlateStatic } from '@seafile/slate-react';
|
|
7
4
|
import Prism, { normalizeTokens, normalizeTokensByLanguageType } from '../extension/plugins/code-block/prismjs';
|
|
8
5
|
import { CODE_BLOCK } from '../extension/constants';
|
|
9
6
|
import { getValidLang } from '../extension/plugins/code-block/helpers';
|
|
10
|
-
|
|
11
|
-
|
|
7
|
+
const mergeMaps = function () {
|
|
8
|
+
const map = new Map();
|
|
12
9
|
for (var _len = arguments.length, maps = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
13
10
|
maps[_key] = arguments[_key];
|
|
14
11
|
}
|
|
15
|
-
for (
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
_step;
|
|
19
|
-
try {
|
|
20
|
-
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
21
|
-
var item = _step.value;
|
|
22
|
-
map.set.apply(map, _toConsumableArray(item));
|
|
23
|
-
}
|
|
24
|
-
} catch (err) {
|
|
25
|
-
_iterator.e(err);
|
|
26
|
-
} finally {
|
|
27
|
-
_iterator.f();
|
|
12
|
+
for (const m of maps) {
|
|
13
|
+
for (const item of m) {
|
|
14
|
+
map.set(...item);
|
|
28
15
|
}
|
|
29
16
|
}
|
|
30
17
|
return map;
|
|
31
18
|
};
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
return Node.string(line);
|
|
39
|
-
}).join('\n');
|
|
40
|
-
var language = getValidLang(block.language);
|
|
41
|
-
var tokens = Prism.tokenize(text, Prism.languages[language]);
|
|
19
|
+
const getChildNodeToDecorations = _ref => {
|
|
20
|
+
let [block, blockPath] = _ref;
|
|
21
|
+
const nodeToDecorations = new Map();
|
|
22
|
+
const text = block.children.map(line => Node.string(line)).join('\n');
|
|
23
|
+
const language = getValidLang(block.language);
|
|
24
|
+
let tokens = Prism.tokenize(text, Prism.languages[language]);
|
|
42
25
|
if (Object.keys(normalizeTokensByLanguageType).includes(language)) {
|
|
43
26
|
tokens = normalizeTokensByLanguageType[language](tokens);
|
|
44
27
|
}
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
for (
|
|
48
|
-
|
|
49
|
-
|
|
28
|
+
const normalizedTokens = normalizeTokens(tokens); // make tokens flat and grouped by line
|
|
29
|
+
const blockChildren = block.children;
|
|
30
|
+
for (let index = 0; index < normalizedTokens.length; index++) {
|
|
31
|
+
const tokens = normalizedTokens[index];
|
|
32
|
+
const element = blockChildren[index];
|
|
50
33
|
if (element) {
|
|
51
34
|
if (!nodeToDecorations.has(element)) {
|
|
52
35
|
nodeToDecorations.set(element, []);
|
|
53
36
|
}
|
|
54
37
|
}
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
token: true
|
|
77
|
-
}, Object.fromEntries(token.types.map(function (type) {
|
|
78
|
-
return [type, true];
|
|
79
|
-
})));
|
|
80
|
-
if (nodeToDecorations.get(element)) {
|
|
81
|
-
nodeToDecorations.get(element).push(range);
|
|
82
|
-
}
|
|
83
|
-
start = end;
|
|
38
|
+
let start = 0;
|
|
39
|
+
for (const token of tokens) {
|
|
40
|
+
const length = token.content.length;
|
|
41
|
+
if (!length) {
|
|
42
|
+
continue;
|
|
43
|
+
}
|
|
44
|
+
const end = start + length;
|
|
45
|
+
const path = [...blockPath, index, 0];
|
|
46
|
+
const range = _objectSpread({
|
|
47
|
+
anchor: {
|
|
48
|
+
path,
|
|
49
|
+
offset: start
|
|
50
|
+
},
|
|
51
|
+
focus: {
|
|
52
|
+
path,
|
|
53
|
+
offset: end
|
|
54
|
+
},
|
|
55
|
+
token: true
|
|
56
|
+
}, Object.fromEntries(token.types.map(type => [type, true])));
|
|
57
|
+
if (nodeToDecorations.get(element)) {
|
|
58
|
+
nodeToDecorations.get(element).push(range);
|
|
84
59
|
}
|
|
85
|
-
|
|
86
|
-
_iterator2.e(err);
|
|
87
|
-
} finally {
|
|
88
|
-
_iterator2.f();
|
|
60
|
+
start = end;
|
|
89
61
|
}
|
|
90
62
|
}
|
|
91
63
|
return nodeToDecorations;
|
|
92
64
|
};
|
|
93
|
-
export
|
|
94
|
-
|
|
95
|
-
|
|
65
|
+
export const SetNodeToDecorations = () => {
|
|
66
|
+
const editor = useSlateStatic();
|
|
67
|
+
const blockEntries = Array.from(Editor.nodes(editor, {
|
|
96
68
|
at: [],
|
|
97
69
|
mode: 'highest',
|
|
98
|
-
match:
|
|
99
|
-
return Element.isElement(n) && n.type === CODE_BLOCK;
|
|
100
|
-
}
|
|
70
|
+
match: n => Element.isElement(n) && n.type === CODE_BLOCK
|
|
101
71
|
}));
|
|
102
|
-
|
|
72
|
+
const nodeToDecorations = mergeMaps(...blockEntries.map(getChildNodeToDecorations));
|
|
103
73
|
editor.nodeToDecorations = nodeToDecorations;
|
|
104
74
|
return null;
|
|
105
75
|
};
|
|
@@ -1,48 +1,40 @@
|
|
|
1
|
-
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
|
|
2
1
|
import React, { useContext, useState } from 'react';
|
|
3
2
|
import { DEFAULT_LAST_USED_FONT_COLOR, DEFAULT_LAST_USED_HIGHLIGHT_COLOR, DEFAULT_LAST_USED_TABLE_CELL_BACKGROUND_COLOR } from '../extension/constants';
|
|
4
|
-
|
|
5
|
-
export
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
updateLastUsedFontColor = _useState2[1];
|
|
10
|
-
var _useState3 = useState(DEFAULT_LAST_USED_HIGHLIGHT_COLOR),
|
|
11
|
-
_useState4 = _slicedToArray(_useState3, 2),
|
|
12
|
-
lastUsedHighlightColor = _useState4[0],
|
|
13
|
-
updateLastUsedHighlightColor = _useState4[1];
|
|
14
|
-
var _useState5 = useState(DEFAULT_LAST_USED_TABLE_CELL_BACKGROUND_COLOR),
|
|
15
|
-
_useState6 = _slicedToArray(_useState5, 2),
|
|
16
|
-
lastUsedTableCellBackgroundColor = _useState6[0],
|
|
17
|
-
updateLastUsedTableCellBackgroundColor = _useState6[1];
|
|
3
|
+
const ColorContext = React.createContext(null);
|
|
4
|
+
export const ColorProvider = props => {
|
|
5
|
+
const [lastUsedFontColor, updateLastUsedFontColor] = useState(DEFAULT_LAST_USED_FONT_COLOR);
|
|
6
|
+
const [lastUsedHighlightColor, updateLastUsedHighlightColor] = useState(DEFAULT_LAST_USED_HIGHLIGHT_COLOR);
|
|
7
|
+
const [lastUsedTableCellBackgroundColor, updateLastUsedTableCellBackgroundColor] = useState(DEFAULT_LAST_USED_TABLE_CELL_BACKGROUND_COLOR);
|
|
18
8
|
return /*#__PURE__*/React.createElement(ColorContext.Provider, {
|
|
19
9
|
value: {
|
|
20
|
-
lastUsedFontColor
|
|
21
|
-
updateLastUsedFontColor
|
|
22
|
-
lastUsedHighlightColor
|
|
23
|
-
updateLastUsedHighlightColor
|
|
24
|
-
lastUsedTableCellBackgroundColor
|
|
25
|
-
updateLastUsedTableCellBackgroundColor
|
|
10
|
+
lastUsedFontColor,
|
|
11
|
+
updateLastUsedFontColor,
|
|
12
|
+
lastUsedHighlightColor,
|
|
13
|
+
updateLastUsedHighlightColor,
|
|
14
|
+
lastUsedTableCellBackgroundColor,
|
|
15
|
+
updateLastUsedTableCellBackgroundColor
|
|
26
16
|
}
|
|
27
17
|
}, props.children);
|
|
28
18
|
};
|
|
29
|
-
export
|
|
30
|
-
|
|
19
|
+
export const useColorContext = () => {
|
|
20
|
+
const context = useContext(ColorContext);
|
|
31
21
|
if (!context) {
|
|
32
22
|
throw new Error('\'ColorContext\' is null');
|
|
33
23
|
}
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
24
|
+
const {
|
|
25
|
+
lastUsedFontColor,
|
|
26
|
+
lastUsedHighlightColor,
|
|
27
|
+
lastUsedTableCellBackgroundColor,
|
|
28
|
+
updateLastUsedFontColor,
|
|
29
|
+
updateLastUsedHighlightColor,
|
|
30
|
+
updateLastUsedTableCellBackgroundColor
|
|
31
|
+
} = context;
|
|
40
32
|
return {
|
|
41
|
-
lastUsedFontColor
|
|
42
|
-
updateLastUsedFontColor
|
|
43
|
-
lastUsedHighlightColor
|
|
44
|
-
updateLastUsedHighlightColor
|
|
45
|
-
lastUsedTableCellBackgroundColor
|
|
46
|
-
updateLastUsedTableCellBackgroundColor
|
|
33
|
+
lastUsedFontColor,
|
|
34
|
+
updateLastUsedFontColor,
|
|
35
|
+
lastUsedHighlightColor,
|
|
36
|
+
updateLastUsedHighlightColor,
|
|
37
|
+
lastUsedTableCellBackgroundColor,
|
|
38
|
+
updateLastUsedTableCellBackgroundColor
|
|
47
39
|
};
|
|
48
40
|
};
|
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
import React, { useContext } from 'react';
|
|
2
|
-
export
|
|
3
|
-
export
|
|
4
|
-
|
|
2
|
+
export const ScrollContext = React.createContext(null);
|
|
3
|
+
export const useScrollContext = () => {
|
|
4
|
+
const context = useContext(ScrollContext);
|
|
5
5
|
if (!context) {
|
|
6
6
|
throw new Error('The \`useScrollContext\` hook must be used inside the <ScrollContext> component\'s context.');
|
|
7
7
|
}
|
|
8
|
-
|
|
8
|
+
const {
|
|
9
|
+
scrollRef
|
|
10
|
+
} = context;
|
|
9
11
|
return scrollRef;
|
|
10
12
|
};
|
|
@@ -1,14 +1,12 @@
|
|
|
1
1
|
import { Editor, Element } from '@seafile/slate';
|
|
2
2
|
import { useSlateStatic } from '@seafile/slate-react';
|
|
3
3
|
import { useMemo } from 'react';
|
|
4
|
-
export
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
4
|
+
export const useSelectionElement = () => {
|
|
5
|
+
const editor = useSlateStatic();
|
|
6
|
+
const nodeEntry = useMemo(() => {
|
|
7
|
+
const nodeEntry = Editor.above(editor, {
|
|
8
8
|
mode: 'lowest',
|
|
9
|
-
match:
|
|
10
|
-
return Element.isElement(n) && Editor.isBlock(editor, n);
|
|
11
|
-
}
|
|
9
|
+
match: n => Element.isElement(n) && Editor.isBlock(editor, n)
|
|
12
10
|
});
|
|
13
11
|
return nodeEntry;
|
|
14
12
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
@@ -1,25 +1,23 @@
|
|
|
1
1
|
import { ReactEditor, useSlateStatic } from '@seafile/slate-react';
|
|
2
2
|
import { Editor, Element } from '@seafile/slate';
|
|
3
3
|
import { useScrollContext } from './use-scroll-context';
|
|
4
|
-
export
|
|
5
|
-
|
|
4
|
+
export const useSelectionPosition = () => {
|
|
5
|
+
const editor = useSlateStatic();
|
|
6
6
|
if (!editor.selection) return {
|
|
7
7
|
x: 0,
|
|
8
8
|
y: 0
|
|
9
9
|
};
|
|
10
|
-
|
|
10
|
+
const node = Editor.above(editor, {
|
|
11
11
|
mode: 'lowest',
|
|
12
|
-
match:
|
|
13
|
-
return Element.isElement(n) && Editor.isBlock(editor, n);
|
|
14
|
-
}
|
|
12
|
+
match: n => Element.isElement(n) && Editor.isBlock(editor, n)
|
|
15
13
|
});
|
|
16
14
|
if (!node) return {
|
|
17
15
|
x: 0,
|
|
18
16
|
y: 0
|
|
19
17
|
};
|
|
20
18
|
try {
|
|
21
|
-
|
|
22
|
-
|
|
19
|
+
const domNode = ReactEditor.toDOMNode(editor, node[0]);
|
|
20
|
+
const rect = domNode.getBoundingClientRect();
|
|
23
21
|
return rect;
|
|
24
22
|
} catch (error) {
|
|
25
23
|
// A new node has not yet been indexed, it cannot be retrieved, and the new node has no comment information, just do not display it
|
|
@@ -29,13 +27,13 @@ export var useSelectionPosition = function useSelectionPosition() {
|
|
|
29
27
|
};
|
|
30
28
|
}
|
|
31
29
|
};
|
|
32
|
-
export
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
30
|
+
export const useCommentListPosition = () => {
|
|
31
|
+
const selectionPosition = useSelectionPosition();
|
|
32
|
+
const headerHeight = 100;
|
|
33
|
+
const scrollRef = useScrollContext();
|
|
34
|
+
const {
|
|
35
|
+
scrollTop = 0
|
|
36
|
+
} = scrollRef.current || {};
|
|
39
37
|
if (selectionPosition.y !== 0) {
|
|
40
38
|
selectionPosition.y = selectionPosition.y - headerHeight + scrollTop;
|
|
41
39
|
}
|