@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
|
@@ -10,36 +10,39 @@ import FontSizeScale from '../../font/menu/font-size/font-size-scale';
|
|
|
10
10
|
import { getValue, isMenuDisabled, addMark, removeMark } from '../helpers';
|
|
11
11
|
import { useColorContext } from '../../../../hooks/use-color-context';
|
|
12
12
|
import { eventStopPropagation } from '../../../../utils/mouse-event';
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
13
|
+
const TextStyleMenuList = _ref => {
|
|
14
|
+
let {
|
|
15
|
+
editor,
|
|
16
|
+
t,
|
|
17
|
+
isRichEditor,
|
|
18
|
+
className,
|
|
19
|
+
idPrefix,
|
|
20
|
+
readonly
|
|
21
|
+
} = _ref;
|
|
22
|
+
let selectedFontSize = getFontSize(editor);
|
|
23
|
+
let selectedFontSizeValue = selectedFontSize;
|
|
24
|
+
const {
|
|
25
|
+
lastUsedFontColor,
|
|
26
|
+
updateLastUsedFontColor,
|
|
27
|
+
lastUsedHighlightColor,
|
|
28
|
+
updateLastUsedHighlightColor
|
|
29
|
+
} = useColorContext();
|
|
30
|
+
const isActive = useCallback(type => {
|
|
31
|
+
const isMark = getValue(editor, type);
|
|
29
32
|
return !!isMark;
|
|
30
33
|
|
|
31
34
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
32
35
|
}, [editor]);
|
|
33
|
-
|
|
36
|
+
const isDisabled = useCallback(() => {
|
|
34
37
|
return isMenuDisabled(editor, readonly);
|
|
35
38
|
|
|
36
39
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
37
40
|
}, [editor, readonly]);
|
|
38
|
-
|
|
41
|
+
const onMouseDown = useCallback((event, type) => {
|
|
39
42
|
event.preventDefault();
|
|
40
43
|
event.stopPropagation();
|
|
41
44
|
if (isDisabled()) return;
|
|
42
|
-
|
|
45
|
+
const active = isActive(type);
|
|
43
46
|
if (active) {
|
|
44
47
|
removeMark(editor, type);
|
|
45
48
|
} else {
|
|
@@ -49,39 +52,37 @@ var TextStyleMenuList = function TextStyleMenuList(_ref) {
|
|
|
49
52
|
|
|
50
53
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
51
54
|
}, [editor]);
|
|
52
|
-
|
|
55
|
+
const setColor = useCallback((type, color) => {
|
|
53
56
|
Editor.addMark(editor, type, color);
|
|
54
57
|
focusEditor(editor);
|
|
55
58
|
|
|
56
59
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
57
60
|
}, [editor]);
|
|
58
|
-
|
|
61
|
+
const increaseFontSize = useCallback(event => {
|
|
59
62
|
eventStopPropagation(event);
|
|
60
63
|
setFontSize(editor, selectedFontSizeValue + 1);
|
|
61
64
|
|
|
62
65
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
63
66
|
}, [editor, selectedFontSize, selectedFontSizeValue]);
|
|
64
|
-
|
|
67
|
+
const reduceFontSize = useCallback(event => {
|
|
65
68
|
eventStopPropagation(event);
|
|
66
|
-
|
|
69
|
+
const nextFontSize = selectedFontSizeValue - 1;
|
|
67
70
|
if (nextFontSize < 1) return;
|
|
68
71
|
setFontSize(editor, nextFontSize);
|
|
69
72
|
|
|
70
73
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
71
74
|
}, [editor, selectedFontSize, selectedFontSizeValue]);
|
|
72
|
-
|
|
73
|
-
return MENUS_CONFIG_MAP[key].map(
|
|
74
|
-
|
|
75
|
-
isRichEditor
|
|
76
|
-
className
|
|
75
|
+
const getTextStyleList = useCallback(key => {
|
|
76
|
+
return MENUS_CONFIG_MAP[key].map(item => {
|
|
77
|
+
let itemProps = {
|
|
78
|
+
isRichEditor,
|
|
79
|
+
className,
|
|
77
80
|
disabled: isDisabled(),
|
|
78
81
|
isActive: isActive(item.type),
|
|
79
|
-
onMouseDown: item.isColor ?
|
|
82
|
+
onMouseDown: item.isColor ? () => {} : onMouseDown
|
|
80
83
|
};
|
|
81
84
|
if (item.isColor) {
|
|
82
|
-
itemProps['setColor'] =
|
|
83
|
-
return setColor(item.type, color);
|
|
84
|
-
};
|
|
85
|
+
itemProps['setColor'] = color => setColor(item.type, color);
|
|
85
86
|
itemProps['defaultColorTip'] = item.type === TEXT_STYLE_MAP.COLOR ? t('Default') : '';
|
|
86
87
|
itemProps['lastUsedColor'] = item.type === TEXT_STYLE_MAP.COLOR ? lastUsedFontColor : lastUsedHighlightColor;
|
|
87
88
|
itemProps['updateLastUsedColor'] = item.type === TEXT_STYLE_MAP.COLOR ? updateLastUsedFontColor : updateLastUsedHighlightColor;
|
|
@@ -93,14 +94,14 @@ var TextStyleMenuList = function TextStyleMenuList(_ref) {
|
|
|
93
94
|
|
|
94
95
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
95
96
|
}, [editor, lastUsedFontColor, lastUsedHighlightColor, readonly]);
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
return /*#__PURE__*/React.createElement(React.Fragment, null, list.map(
|
|
99
|
-
|
|
97
|
+
const list = getTextStyleList(TEXT_STYLE);
|
|
98
|
+
const dropdownList = getTextStyleList(TEXT_STYLE_MORE);
|
|
99
|
+
return /*#__PURE__*/React.createElement(React.Fragment, null, list.map((itemProps, index) => {
|
|
100
|
+
const Component = itemProps.isColor ? ColorMenu : MenuItem;
|
|
100
101
|
return /*#__PURE__*/React.createElement(Component, Object.assign({
|
|
101
102
|
key: index
|
|
102
103
|
}, itemProps));
|
|
103
|
-
}), /*#__PURE__*/React.createElement(MoreDropdown, null, dropdownList.map(
|
|
104
|
+
}), /*#__PURE__*/React.createElement(MoreDropdown, null, dropdownList.map((itemProps, index) => {
|
|
104
105
|
return /*#__PURE__*/React.createElement(MenuItem, Object.assign({
|
|
105
106
|
key: index
|
|
106
107
|
}, itemProps));
|
|
@@ -1,22 +1,22 @@
|
|
|
1
1
|
import { TEXT_STYLE_MAP } from '../../constants';
|
|
2
2
|
import { getValue, isMenuDisabled, addMark, removeMark } from './helpers';
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
3
|
+
const withTextStyle = editor => {
|
|
4
|
+
const toggleTextStyle = type => {
|
|
5
|
+
const isDisabled = isMenuDisabled(editor);
|
|
6
6
|
if (isDisabled) {
|
|
7
7
|
return false;
|
|
8
8
|
}
|
|
9
|
-
|
|
9
|
+
const isActive = !!getValue(editor, type);
|
|
10
10
|
if (isActive) {
|
|
11
11
|
removeMark(editor, type);
|
|
12
12
|
} else {
|
|
13
13
|
addMark(editor, type);
|
|
14
14
|
}
|
|
15
15
|
};
|
|
16
|
-
editor.toggleTextBold =
|
|
16
|
+
editor.toggleTextBold = () => {
|
|
17
17
|
toggleTextStyle(TEXT_STYLE_MAP.BOLD);
|
|
18
18
|
};
|
|
19
|
-
editor.toggleTextItalic =
|
|
19
|
+
editor.toggleTextItalic = () => {
|
|
20
20
|
toggleTextStyle(TEXT_STYLE_MAP.ITALIC);
|
|
21
21
|
};
|
|
22
22
|
return editor;
|
|
@@ -1,17 +1,21 @@
|
|
|
1
1
|
import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
|
|
2
|
-
|
|
2
|
+
const _excluded = ["text"];
|
|
3
3
|
import React from 'react';
|
|
4
4
|
import Caret from './caret';
|
|
5
5
|
import { TEXT_STYLE_MAP } from '../../constants';
|
|
6
6
|
import { generatorFontFamily } from '../font/helpers';
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
7
|
+
const renderText = (props, editor) => {
|
|
8
|
+
const {
|
|
9
|
+
attributes,
|
|
10
|
+
children,
|
|
11
|
+
leaf
|
|
12
|
+
} = props;
|
|
13
|
+
const {
|
|
14
|
+
text
|
|
15
|
+
} = leaf,
|
|
12
16
|
rest = _objectWithoutProperties(leaf, _excluded);
|
|
13
|
-
|
|
14
|
-
|
|
17
|
+
let markedChildren = React.cloneElement(children);
|
|
18
|
+
let style = {};
|
|
15
19
|
if (leaf.isCaret) {
|
|
16
20
|
style['position'] = 'relative';
|
|
17
21
|
style['display'] = 'inline-block';
|
|
@@ -27,13 +31,13 @@ var renderText = function renderText(props, editor) {
|
|
|
27
31
|
style['backgroundColor'] = leaf[TEXT_STYLE_MAP.HIGHLIGHT_COLOR];
|
|
28
32
|
}
|
|
29
33
|
if (leaf[TEXT_STYLE_MAP.FONT_SIZE]) {
|
|
30
|
-
|
|
34
|
+
const fontSize = leaf[TEXT_STYLE_MAP.FONT_SIZE];
|
|
31
35
|
if (typeof fontSize === 'number') {
|
|
32
36
|
style['fontSize'] = "".concat(fontSize, "pt");
|
|
33
37
|
}
|
|
34
38
|
}
|
|
35
39
|
if (leaf[TEXT_STYLE_MAP.FONT]) {
|
|
36
|
-
|
|
40
|
+
const fontWeight = leaf[TEXT_STYLE_MAP.BOLD] ? 600 : 400;
|
|
37
41
|
style['fontFamily'] = generatorFontFamily(leaf[TEXT_STYLE_MAP.FONT], fontWeight);
|
|
38
42
|
}
|
|
39
43
|
if (leaf[TEXT_STYLE_MAP.BOLD]) {
|
|
@@ -1,14 +1,15 @@
|
|
|
1
1
|
import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
|
|
2
|
-
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
|
|
3
2
|
import { useSlateStatic } from '@seafile/slate-react';
|
|
4
3
|
import { BLOCKQUOTE, LINK, CHECK_LIST_ITEM, HEADER1, HEADER2, HEADER3, HEADER4, HEADER5, HEADER6, LIST_ITEM, ORDERED_LIST, PARAGRAPH, UNORDERED_LIST, CODE_BLOCK, CODE_LINE, IMAGE, ELEMENT_TYPE, SDOC_LINK, FILE_LINK, TITLE, SUBTITLE, SUPPORTED_SIDE_OPERATION_TYPE } from '../constants';
|
|
5
4
|
import { BlockquotePlugin, LinkPlugin, CheckListPlugin, HeaderPlugin, ListPlugin, CodeBlockPlugin, ImagePlugin, TablePlugin, SdocLinkPlugin, ParagraphPlugin, FileLinkPlugin } from '../plugins';
|
|
6
5
|
import { onMouseEnter, onDragOver, onDragLeave, onDrop } from '../toolbar/side-toolbar/event';
|
|
7
6
|
import { getParentNode } from '../core';
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
7
|
+
const CustomRenderElement = props => {
|
|
8
|
+
const editor = useSlateStatic();
|
|
9
|
+
const {
|
|
10
|
+
element,
|
|
11
|
+
attributes
|
|
12
|
+
} = props;
|
|
12
13
|
if (SUPPORTED_SIDE_OPERATION_TYPE.includes(element.type)) {
|
|
13
14
|
attributes['onMouseEnter'] = onMouseEnter;
|
|
14
15
|
attributes['onDragOver'] = onDragOver;
|
|
@@ -19,20 +20,17 @@ var CustomRenderElement = function CustomRenderElement(props) {
|
|
|
19
20
|
switch (element.type) {
|
|
20
21
|
case PARAGRAPH:
|
|
21
22
|
{
|
|
22
|
-
|
|
23
|
-
renderParagraph = _ParagraphPlugin$rend[0];
|
|
23
|
+
const [renderParagraph] = ParagraphPlugin.renderElements;
|
|
24
24
|
return renderParagraph(props);
|
|
25
25
|
}
|
|
26
26
|
case TITLE:
|
|
27
27
|
{
|
|
28
|
-
|
|
29
|
-
renderTitle = _HeaderPlugin$renderE[0];
|
|
28
|
+
const [renderTitle] = HeaderPlugin.renderElements;
|
|
30
29
|
return renderTitle(props, editor);
|
|
31
30
|
}
|
|
32
31
|
case SUBTITLE:
|
|
33
32
|
{
|
|
34
|
-
|
|
35
|
-
renderSubtitle = _HeaderPlugin$renderE2[1];
|
|
33
|
+
const [, renderSubtitle] = HeaderPlugin.renderElements;
|
|
36
34
|
return renderSubtitle(props, editor);
|
|
37
35
|
}
|
|
38
36
|
case HEADER1:
|
|
@@ -42,106 +40,89 @@ var CustomRenderElement = function CustomRenderElement(props) {
|
|
|
42
40
|
case HEADER5:
|
|
43
41
|
case HEADER6:
|
|
44
42
|
{
|
|
45
|
-
|
|
46
|
-
renderHeader = _HeaderPlugin$renderE3[2];
|
|
43
|
+
const [,, renderHeader] = HeaderPlugin.renderElements;
|
|
47
44
|
return renderHeader(props, editor);
|
|
48
45
|
}
|
|
49
46
|
case LINK:
|
|
50
47
|
{
|
|
51
|
-
|
|
52
|
-
renderLink = _LinkPlugin$renderEle[0];
|
|
48
|
+
const [renderLink] = LinkPlugin.renderElements;
|
|
53
49
|
return renderLink(props, editor);
|
|
54
50
|
}
|
|
55
51
|
case BLOCKQUOTE:
|
|
56
52
|
{
|
|
57
|
-
|
|
58
|
-
renderBlockquote = _BlockquotePlugin$ren[0];
|
|
53
|
+
const [renderBlockquote] = BlockquotePlugin.renderElements;
|
|
59
54
|
return renderBlockquote(props, editor);
|
|
60
55
|
}
|
|
61
56
|
case ORDERED_LIST:
|
|
62
57
|
case UNORDERED_LIST:
|
|
63
58
|
{
|
|
64
|
-
|
|
65
|
-
renderList = _ListPlugin$renderEle[0];
|
|
59
|
+
const [renderList] = ListPlugin.renderElements;
|
|
66
60
|
return renderList(props, editor);
|
|
67
61
|
}
|
|
68
62
|
case LIST_ITEM:
|
|
69
63
|
{
|
|
70
|
-
|
|
71
|
-
renderListItem = _ListPlugin$renderEle2[1];
|
|
64
|
+
const [, renderListItem] = ListPlugin.renderElements;
|
|
72
65
|
return renderListItem(props, editor);
|
|
73
66
|
}
|
|
74
67
|
case CHECK_LIST_ITEM:
|
|
75
68
|
{
|
|
76
|
-
|
|
77
|
-
renderCheckListItem = _CheckListPlugin$rend[0];
|
|
69
|
+
const [renderCheckListItem] = CheckListPlugin.renderElements;
|
|
78
70
|
return renderCheckListItem(props, editor);
|
|
79
71
|
}
|
|
80
72
|
case CODE_BLOCK:
|
|
81
73
|
{
|
|
82
|
-
|
|
83
|
-
renderCodeBlock = _CodeBlockPlugin$rend[0];
|
|
74
|
+
const [renderCodeBlock] = CodeBlockPlugin.renderElements;
|
|
84
75
|
return renderCodeBlock(props, editor);
|
|
85
76
|
}
|
|
86
77
|
case CODE_LINE:
|
|
87
78
|
{
|
|
88
|
-
|
|
89
|
-
renderCodeLine = _CodeBlockPlugin$rend2[1];
|
|
79
|
+
const [, renderCodeLine] = CodeBlockPlugin.renderElements;
|
|
90
80
|
return renderCodeLine(props, editor);
|
|
91
81
|
}
|
|
92
82
|
case IMAGE:
|
|
93
83
|
{
|
|
94
84
|
var _editor$element_comme;
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
});
|
|
100
|
-
var leaf = {};
|
|
85
|
+
const parentNode = getParentNode(editor.children, element.id);
|
|
86
|
+
const comments = ((_editor$element_comme = editor.element_comments_map) === null || _editor$element_comme === void 0 ? void 0 : _editor$element_comme[parentNode.id]) || [];
|
|
87
|
+
const unresolvedComments = comments && comments.filter(item => !item.resolved);
|
|
88
|
+
let leaf = {};
|
|
101
89
|
if (unresolvedComments && unresolvedComments.length > 0) {
|
|
102
90
|
leaf['computed_background_color'] = 'rgba(129, 237, 247, 0.5)';
|
|
103
91
|
}
|
|
104
|
-
|
|
105
|
-
renderImage = _ImagePlugin$renderEl[0];
|
|
92
|
+
const [renderImage] = ImagePlugin.renderElements;
|
|
106
93
|
return renderImage(_objectSpread(_objectSpread({}, props), {}, {
|
|
107
|
-
leaf
|
|
94
|
+
leaf
|
|
108
95
|
}), editor);
|
|
109
96
|
}
|
|
110
97
|
case ELEMENT_TYPE.TABLE:
|
|
111
98
|
{
|
|
112
|
-
|
|
113
|
-
renderTable = _TablePlugin$renderEl[0];
|
|
99
|
+
const [renderTable] = TablePlugin.renderElements;
|
|
114
100
|
return renderTable(props, editor);
|
|
115
101
|
}
|
|
116
102
|
case ELEMENT_TYPE.TABLE_ROW:
|
|
117
103
|
{
|
|
118
|
-
|
|
119
|
-
renderTableRow = _TablePlugin$renderEl2[1];
|
|
104
|
+
const [, renderTableRow] = TablePlugin.renderElements;
|
|
120
105
|
return renderTableRow(props, editor);
|
|
121
106
|
}
|
|
122
107
|
case ELEMENT_TYPE.TABLE_CELL:
|
|
123
108
|
{
|
|
124
|
-
|
|
125
|
-
renderTableCell = _TablePlugin$renderEl3[2];
|
|
109
|
+
const [,, renderTableCell] = TablePlugin.renderElements;
|
|
126
110
|
return renderTableCell(props, editor);
|
|
127
111
|
}
|
|
128
112
|
case SDOC_LINK:
|
|
129
113
|
{
|
|
130
|
-
|
|
131
|
-
renderSdocLink = _SdocLinkPlugin$rende[0];
|
|
114
|
+
const [renderSdocLink] = SdocLinkPlugin.renderElements;
|
|
132
115
|
return renderSdocLink(props, editor);
|
|
133
116
|
}
|
|
134
117
|
case FILE_LINK:
|
|
135
118
|
{
|
|
136
|
-
|
|
137
|
-
renderFileLink = _FileLinkPlugin$rende[0];
|
|
119
|
+
const [renderFileLink] = FileLinkPlugin.renderElements;
|
|
138
120
|
return renderFileLink(props, editor);
|
|
139
121
|
}
|
|
140
122
|
default:
|
|
141
123
|
{
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
return _renderParagraph(props);
|
|
124
|
+
const [renderParagraph] = ParagraphPlugin.renderElements;
|
|
125
|
+
return renderParagraph(props);
|
|
145
126
|
}
|
|
146
127
|
}
|
|
147
128
|
};
|
|
@@ -4,10 +4,12 @@ import RebaseModifyModifyDecorate from './rebase-modify-modify-decorate';
|
|
|
4
4
|
import RebaseDeleteModifyDecorate from './rebase-delete-modify-decorate';
|
|
5
5
|
import { REBASE_MARK_KEY, REBASE_TYPE } from '../../../../constants';
|
|
6
6
|
import './index.css';
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
7
|
+
const RebaseDecorate = _ref => {
|
|
8
|
+
let {
|
|
9
|
+
element,
|
|
10
|
+
children
|
|
11
|
+
} = _ref;
|
|
12
|
+
const rebaseType = element[REBASE_MARK_KEY.REBASE_TYPE];
|
|
11
13
|
if (!rebaseType) return /*#__PURE__*/React.createElement(React.Fragment, null, children);
|
|
12
14
|
if (rebaseType === REBASE_TYPE.MODIFY_DELETE) {
|
|
13
15
|
return /*#__PURE__*/React.createElement(RebaseModifyDeleteDecorate, {
|
|
@@ -5,14 +5,17 @@ import { useSlateStatic } from '@seafile/slate-react';
|
|
|
5
5
|
import { ELEMENT_TYPE } from '../../../constants';
|
|
6
6
|
import { REBASE_MARKS } from '../../../../constants';
|
|
7
7
|
import { findPath, deleteNodeMark, updateRebaseParentNodeByPath } from '../../../core';
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
8
|
+
const RebaseDeleteModifyDecorate = _ref => {
|
|
9
|
+
let {
|
|
10
|
+
element,
|
|
11
|
+
children
|
|
12
|
+
} = _ref;
|
|
13
|
+
const {
|
|
14
|
+
t
|
|
15
|
+
} = useTranslation();
|
|
16
|
+
const editor = useSlateStatic();
|
|
17
|
+
const deleteElement = useCallback(() => {
|
|
18
|
+
const path = findPath(editor, element);
|
|
16
19
|
Transforms.removeNodes(editor, {
|
|
17
20
|
at: path
|
|
18
21
|
});
|
|
@@ -22,8 +25,8 @@ var RebaseDeleteModifyDecorate = function RebaseDeleteModifyDecorate(_ref) {
|
|
|
22
25
|
|
|
23
26
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
24
27
|
}, [editor, element]);
|
|
25
|
-
|
|
26
|
-
|
|
28
|
+
const deleteMark = useCallback(() => {
|
|
29
|
+
const path = findPath(editor, element);
|
|
27
30
|
deleteNodeMark(editor, path, element, REBASE_MARKS);
|
|
28
31
|
if (element.type === ELEMENT_TYPE.LIST_ITEM) {
|
|
29
32
|
updateRebaseParentNodeByPath(editor, path);
|
|
@@ -5,14 +5,17 @@ import { useSlateStatic } from '@seafile/slate-react';
|
|
|
5
5
|
import { ELEMENT_TYPE } from '../../../constants';
|
|
6
6
|
import { REBASE_MARKS } from '../../../../constants';
|
|
7
7
|
import { findPath, deleteNodeMark, updateRebaseParentNodeByPath } from '../../../core';
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
8
|
+
const RebaseModifyDeleteDecorate = _ref => {
|
|
9
|
+
let {
|
|
10
|
+
element,
|
|
11
|
+
children
|
|
12
|
+
} = _ref;
|
|
13
|
+
const {
|
|
14
|
+
t
|
|
15
|
+
} = useTranslation();
|
|
16
|
+
const editor = useSlateStatic();
|
|
17
|
+
const deleteElement = useCallback(() => {
|
|
18
|
+
const path = findPath(editor, element);
|
|
16
19
|
Transforms.removeNodes(editor, {
|
|
17
20
|
at: path
|
|
18
21
|
});
|
|
@@ -22,8 +25,8 @@ var RebaseModifyDeleteDecorate = function RebaseModifyDeleteDecorate(_ref) {
|
|
|
22
25
|
|
|
23
26
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
24
27
|
}, [editor, element]);
|
|
25
|
-
|
|
26
|
-
|
|
28
|
+
const deleteMark = useCallback(() => {
|
|
29
|
+
const path = findPath(editor, element);
|
|
27
30
|
deleteNodeMark(editor, path, element, REBASE_MARKS);
|
|
28
31
|
if (element.type === ELEMENT_TYPE.LIST_ITEM) {
|
|
29
32
|
updateRebaseParentNodeByPath(editor, path);
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
|
|
2
1
|
import React, { useCallback } from 'react';
|
|
3
2
|
import { useTranslation } from 'react-i18next';
|
|
4
3
|
import deepCopy from 'deep-copy';
|
|
@@ -7,16 +6,19 @@ import { useSlateStatic } from '@seafile/slate-react';
|
|
|
7
6
|
import { ELEMENT_TYPE } from '../../../constants';
|
|
8
7
|
import { REBASE_MARKS, REBASE_MARK_KEY, REBASE_ORIGIN } from '../../../../constants';
|
|
9
8
|
import { findPath, getNode, deleteNodeMark, updateRebaseParentNodeByPath } from '../../../core';
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
9
|
+
const RebaseModifyModifyDecorate = _ref => {
|
|
10
|
+
let {
|
|
11
|
+
element,
|
|
12
|
+
children
|
|
13
|
+
} = _ref;
|
|
14
|
+
const {
|
|
15
|
+
t
|
|
16
|
+
} = useTranslation();
|
|
17
|
+
const editor = useSlateStatic();
|
|
18
|
+
const useMasterChanges = useCallback(() => {
|
|
19
|
+
const path = findPath(editor, element);
|
|
18
20
|
deleteNodeMark(editor, path, element[REBASE_MARK_KEY.OLD_ELEMENT], REBASE_MARKS);
|
|
19
|
-
|
|
21
|
+
const nextElementPath = [...path];
|
|
20
22
|
nextElementPath[path.length - 1] = path[path.length - 1] + 1;
|
|
21
23
|
Transforms.removeNodes(editor, {
|
|
22
24
|
at: nextElementPath
|
|
@@ -27,12 +29,12 @@ var RebaseModifyModifyDecorate = function RebaseModifyModifyDecorate(_ref) {
|
|
|
27
29
|
|
|
28
30
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
29
31
|
}, [editor, element]);
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
32
|
+
const useCurrentChanges = useCallback(() => {
|
|
33
|
+
const path = findPath(editor, element);
|
|
34
|
+
const currentElementPath = [...path];
|
|
33
35
|
currentElementPath[path.length - 1] = path[path.length - 1] + 1;
|
|
34
|
-
|
|
35
|
-
|
|
36
|
+
const currentElement = getNode(editor, currentElementPath);
|
|
37
|
+
const newCurrentElement = deepCopy(currentElement);
|
|
36
38
|
deleteNodeMark(editor, currentElementPath, newCurrentElement, REBASE_MARKS);
|
|
37
39
|
Transforms.removeNodes(editor, {
|
|
38
40
|
at: path
|
|
@@ -43,14 +45,14 @@ var RebaseModifyModifyDecorate = function RebaseModifyModifyDecorate(_ref) {
|
|
|
43
45
|
|
|
44
46
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
45
47
|
}, [editor, element]);
|
|
46
|
-
|
|
48
|
+
const useBothChanges = useCallback(() => {
|
|
47
49
|
// delete element marks
|
|
48
|
-
|
|
50
|
+
const path = findPath(editor, element);
|
|
49
51
|
deleteNodeMark(editor, path, element, REBASE_MARKS);
|
|
50
52
|
|
|
51
53
|
// delete next element marks
|
|
52
|
-
|
|
53
|
-
|
|
54
|
+
const nextElementPath = [...path.slice(0, -1), path[path.length - 1] + 1];
|
|
55
|
+
const nextElement = getNode(editor, nextElementPath);
|
|
54
56
|
deleteNodeMark(editor, nextElementPath, nextElement, REBASE_MARKS);
|
|
55
57
|
if (element.type === ELEMENT_TYPE.LIST_ITEM) {
|
|
56
58
|
updateRebaseParentNodeByPath(editor, path);
|
|
@@ -2,9 +2,11 @@ import React from 'react';
|
|
|
2
2
|
import { REBASE_MARK_KEY } from '../../constants';
|
|
3
3
|
import { RebaseDecorate } from './element-decorate';
|
|
4
4
|
import CustomElement from './custom-element';
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
5
|
+
const RenderElement = props => {
|
|
6
|
+
const {
|
|
7
|
+
element
|
|
8
|
+
} = props;
|
|
9
|
+
const rebaseType = element[REBASE_MARK_KEY.REBASE_TYPE];
|
|
8
10
|
if (rebaseType) {
|
|
9
11
|
return /*#__PURE__*/React.createElement(RebaseDecorate, {
|
|
10
12
|
element: element
|
|
@@ -1,14 +1,12 @@
|
|
|
1
|
-
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
|
|
2
1
|
import React from 'react';
|
|
3
2
|
import { useSlateStatic } from '@seafile/slate-react';
|
|
4
3
|
import { TextPlugin } from '../plugins';
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
renderText = _TextPlugin$renderEle[0];
|
|
4
|
+
const CustomLeaf = props => {
|
|
5
|
+
const editor = useSlateStatic();
|
|
6
|
+
const [renderText] = TextPlugin.renderElements;
|
|
9
7
|
return renderText(props, editor);
|
|
10
8
|
};
|
|
11
|
-
|
|
9
|
+
const renderLeaf = props => {
|
|
12
10
|
return /*#__PURE__*/React.createElement(CustomLeaf, props);
|
|
13
11
|
};
|
|
14
12
|
export default renderLeaf;
|
|
@@ -8,29 +8,31 @@ import { useScrollContext } from '../../../hooks/use-scroll-context';
|
|
|
8
8
|
import { getSelectedNodeByType } from '../../core';
|
|
9
9
|
import { CODE_BLOCK } from '../../constants';
|
|
10
10
|
import './index.css';
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
11
|
+
const ContextToolbar = () => {
|
|
12
|
+
const ref = useRef(null);
|
|
13
|
+
const editor = useSlateStatic();
|
|
14
|
+
const scrollRef = useScrollContext();
|
|
15
|
+
const inFocus = useFocused();
|
|
16
|
+
const readOnly = useReadOnly();
|
|
17
|
+
const setContextToolbarPosition = useCallback(() => {
|
|
18
|
+
const el = ref.current;
|
|
19
|
+
const domSelection = window.getSelection();
|
|
20
|
+
const domRange = domSelection.getRangeAt(0);
|
|
21
|
+
const rect = domRange.getBoundingClientRect();
|
|
22
22
|
el.style.top = "".concat(rect.top - 42 - 12, "px"); // top = Current top - Element height - Shaded part
|
|
23
23
|
el.style.left = "".concat(rect.left, "px");
|
|
24
24
|
el.style.display = 'block';
|
|
25
25
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
26
26
|
}, []);
|
|
27
|
-
|
|
27
|
+
const onScroll = useCallback(e => {
|
|
28
28
|
setContextToolbarPosition();
|
|
29
29
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
30
30
|
}, []);
|
|
31
|
-
useEffect(
|
|
32
|
-
|
|
33
|
-
|
|
31
|
+
useEffect(() => {
|
|
32
|
+
const el = ref.current;
|
|
33
|
+
const {
|
|
34
|
+
selection
|
|
35
|
+
} = editor;
|
|
34
36
|
if (!el) {
|
|
35
37
|
return;
|
|
36
38
|
}
|
|
@@ -42,7 +44,7 @@ var ContextToolbar = function ContextToolbar() {
|
|
|
42
44
|
scrollRef.current && scrollRef.current.addEventListener('scroll', onScroll);
|
|
43
45
|
setContextToolbarPosition();
|
|
44
46
|
});
|
|
45
|
-
|
|
47
|
+
const onMouseDown = useCallback(event => {
|
|
46
48
|
event.preventDefault(); // prevent toolbar from taking focus away from editor
|
|
47
49
|
}, []);
|
|
48
50
|
return createPortal( /*#__PURE__*/React.createElement("div", {
|