@worktile/theia 13.0.0-next.1 → 13.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +11 -11
- package/components/color-select/color-select.component.d.ts +32 -32
- package/components/color-select/color-select.component.scss +107 -107
- package/components/column-resize/column-resize-notifier.d.ts +35 -35
- package/components/column-resize/column-resize.directive.d.ts +26 -26
- package/components/column-resize/column-resize.module.d.ts +14 -14
- package/components/column-resize/event-dispatcher.d.ts +31 -31
- package/components/column-resize/overlay-handle.component.d.ts +33 -33
- package/components/column-resize/resize-ref.d.ts +25 -25
- package/components/column-resize/resizing.store.d.ts +28 -28
- package/components/column-resize/selectors.d.ts +3 -3
- package/components/contextmenu/contextmenu.component.d.ts +22 -22
- package/components/conversion-hint/conversion-hint.component.d.ts +18 -18
- package/components/conversion-hint/conversion-hint.component.scss +11 -11
- package/components/element/element.component.d.ts +7 -7
- package/components/inline-toolbar/inline-toolbar.component.d.ts +26 -26
- package/components/nav-split-line/nav-split-line.component.d.ts +13 -13
- package/components/table-select/table-select.component.d.ts +20 -20
- package/components/table-select/table-select.component.scss +35 -35
- package/components/template/template.component.d.ts +15 -15
- package/components/text/text.component.d.ts +14 -14
- package/components/toolbar/toolbar.component.d.ts +64 -64
- package/components/toolbar-dropdown/toolbar-dropdown.component.d.ts +33 -33
- package/components/toolbar-group/toolbar-group.component.d.ts +33 -33
- package/components/toolbar-group/toolbar-group.component.scss +17 -17
- package/components/toolbar-item/toolbar-item.component.d.ts +17 -17
- package/constants/auto-format-rules.d.ts +2 -2
- package/constants/code.d.ts +9 -9
- package/constants/color-select.d.ts +14 -14
- package/constants/default.d.ts +9 -9
- package/constants/error.d.ts +5 -5
- package/constants/index.d.ts +5 -5
- package/constants/node-types.d.ts +99 -99
- package/constants/selector.d.ts +2 -2
- package/constants/toolbar.d.ts +17 -17
- package/core/create-plugin.d.ts +2 -2
- package/core/create-toolbar.d.ts +5 -5
- package/core/index.d.ts +4 -4
- package/core/toolbar-item/base-toolbar-item.d.ts +29 -29
- package/core/utils/combine-plugins.d.ts +2 -2
- package/core/utils/flatten-deep-plugins.d.ts +6 -6
- package/core/utils/get-plugin-options.d.ts +2 -2
- package/core/utils/get-plugin.d.ts +2 -2
- package/core/utils/get-plugins.d.ts +2 -2
- package/core/utils/index.d.ts +10 -10
- package/core/utils/merge-array.d.ts +1 -1
- package/core/utils/merge-deep-plugins.d.ts +2 -2
- package/core/utils/merge-options.d.ts +2 -2
- package/core/utils/nested-structure-by-key.d.ts +2 -2
- package/core/utils/plugins-by-key.d.ts +2 -2
- package/core/with-theia.d.ts +4 -4
- package/custom-types.d.ts +131 -131
- package/editor.component.d.ts +92 -92
- package/editor.module.d.ts +100 -98
- package/esm2020/components/color-select/color-select.component.mjs +108 -108
- package/esm2020/components/column-resize/column-resize-notifier.mjs +31 -31
- package/esm2020/components/column-resize/column-resize.directive.mjs +98 -98
- package/esm2020/components/column-resize/column-resize.module.mjs +32 -32
- package/esm2020/components/column-resize/event-dispatcher.mjs +55 -55
- package/esm2020/components/column-resize/overlay-handle.component.mjs +139 -139
- package/esm2020/components/column-resize/resize-ref.mjs +25 -25
- package/esm2020/components/column-resize/resizing.store.mjs +154 -154
- package/esm2020/components/column-resize/selectors.mjs +4 -4
- package/esm2020/components/contextmenu/contextmenu.component.mjs +61 -61
- package/esm2020/components/conversion-hint/conversion-hint.component.mjs +54 -54
- package/esm2020/components/element/element.component.mjs +22 -22
- package/esm2020/components/inline-toolbar/inline-toolbar.component.mjs +125 -125
- package/esm2020/components/nav-split-line/nav-split-line.component.mjs +36 -36
- package/esm2020/components/table-select/table-select.component.mjs +49 -49
- package/esm2020/components/template/template.component.mjs +62 -62
- package/esm2020/components/text/text.component.mjs +57 -57
- package/esm2020/components/toolbar/toolbar.component.mjs +241 -241
- package/esm2020/components/toolbar-dropdown/toolbar-dropdown.component.mjs +128 -128
- package/esm2020/components/toolbar-group/toolbar-group.component.mjs +110 -110
- package/esm2020/components/toolbar-item/toolbar-item.component.mjs +60 -60
- package/esm2020/constants/auto-format-rules.mjs +166 -166
- package/esm2020/constants/code.mjs +88 -88
- package/esm2020/constants/color-select.mjs +61 -61
- package/esm2020/constants/default.mjs +9 -9
- package/esm2020/constants/error.mjs +7 -7
- package/esm2020/constants/index.mjs +5 -5
- package/esm2020/constants/node-types.mjs +132 -132
- package/esm2020/constants/selector.mjs +3 -3
- package/esm2020/constants/toolbar.mjs +69 -69
- package/esm2020/core/create-plugin.mjs +4 -4
- package/esm2020/core/create-toolbar.mjs +55 -55
- package/esm2020/core/index.mjs +4 -4
- package/esm2020/core/toolbar-item/base-toolbar-item.mjs +89 -89
- package/esm2020/core/utils/combine-plugins.mjs +9 -9
- package/esm2020/core/utils/flatten-deep-plugins.mjs +18 -18
- package/esm2020/core/utils/get-plugin-options.mjs +2 -2
- package/esm2020/core/utils/get-plugin.mjs +1 -1
- package/esm2020/core/utils/get-plugins.mjs +3 -3
- package/esm2020/core/utils/index.mjs +10 -10
- package/esm2020/core/utils/merge-array.mjs +17 -17
- package/esm2020/core/utils/merge-deep-plugins.mjs +13 -13
- package/esm2020/core/utils/merge-options.mjs +19 -19
- package/esm2020/core/utils/nested-structure-by-key.mjs +10 -10
- package/esm2020/core/utils/plugins-by-key.mjs +9 -9
- package/esm2020/core/with-theia.mjs +22 -22
- package/esm2020/custom-types.mjs +1 -1
- package/esm2020/editor.component.mjs +430 -430
- package/esm2020/editor.module.mjs +207 -201
- package/esm2020/interfaces/auto-format.mjs +1 -1
- package/esm2020/interfaces/editor.mjs +24 -24
- package/esm2020/interfaces/element.mjs +1 -1
- package/esm2020/interfaces/image.mjs +2 -2
- package/esm2020/interfaces/index.mjs +8 -8
- package/esm2020/interfaces/plugins/index.mjs +4 -4
- package/esm2020/interfaces/plugins/no-infer.mjs +1 -1
- package/esm2020/interfaces/plugins/plugin-key.mjs +39 -39
- package/esm2020/interfaces/plugins/plugins.mjs +1 -1
- package/esm2020/interfaces/plugins/with-override.mjs +1 -1
- package/esm2020/interfaces/reset-block-type-plugin-options.mjs +2 -2
- package/esm2020/interfaces/toolbar.mjs +11 -11
- package/esm2020/interfaces/upload.mjs +1 -1
- package/esm2020/interfaces/utility/index.mjs +3 -3
- package/esm2020/interfaces/utility/nested-structure-by-key.mjs +1 -1
- package/esm2020/interfaces/utility/override-by-key.mjs +1 -1
- package/esm2020/interfaces/utility/types.mjs +1 -1
- package/esm2020/interfaces/valid-children-types.mjs +35 -35
- package/esm2020/interfaces/view-base.mjs +21 -21
- package/esm2020/pipes.mjs +42 -42
- package/esm2020/plugins/align/align.editor.mjs +46 -46
- package/esm2020/plugins/align/align.plugin.mjs +63 -63
- package/esm2020/plugins/autoformat/autoformat.plugin.mjs +108 -108
- package/esm2020/plugins/autoformat/transforms/auto-format-block.mjs +14 -14
- package/esm2020/plugins/autoformat/transforms/auto-format-inline.mjs +77 -77
- package/esm2020/plugins/blockquote/blockquote.component.mjs +21 -21
- package/esm2020/plugins/blockquote/blockquote.editor.mjs +19 -19
- package/esm2020/plugins/blockquote/blockquote.plugin.mjs +70 -70
- package/esm2020/plugins/code/code.component.mjs +240 -240
- package/esm2020/plugins/code/code.editor.mjs +47 -47
- package/esm2020/plugins/code/code.plugin.mjs +41 -41
- package/esm2020/plugins/color/color.editor.mjs +43 -43
- package/esm2020/plugins/color/color.plugin.mjs +27 -27
- package/esm2020/plugins/color/toolbar-item.component.mjs +78 -78
- package/esm2020/plugins/common/auto-insert-data..mjs +76 -76
- package/esm2020/plugins/common/block-card.plugin.mjs +286 -286
- package/esm2020/plugins/common/get-fragment.plugin.mjs +23 -23
- package/esm2020/plugins/common/history.plugin.mjs +30 -30
- package/esm2020/plugins/common/move-selection.plugin.mjs +89 -89
- package/esm2020/plugins/common/remove-empty.plugin.mjs +59 -59
- package/esm2020/plugins/common/remove-void.plugin.mjs +56 -56
- package/esm2020/plugins/common/reset-type.plugin.mjs +34 -34
- package/esm2020/plugins/common/transforms.plugin.mjs +17 -17
- package/esm2020/plugins/deserializers/deserialize-html.plugin.mjs +38 -38
- package/esm2020/plugins/deserializers/deserialize-md.plugin.mjs +121 -121
- package/esm2020/plugins/font-size/font-size.editor.mjs +97 -97
- package/esm2020/plugins/heading/heading.editor.mjs +53 -53
- package/esm2020/plugins/heading/heading.plugin.mjs +84 -84
- package/esm2020/plugins/hr/hr.component.mjs +40 -40
- package/esm2020/plugins/hr/hr.editor.mjs +7 -7
- package/esm2020/plugins/hr/hr.plugin.mjs +41 -41
- package/esm2020/plugins/image/image.component.mjs +385 -365
- package/esm2020/plugins/image/image.editor.mjs +57 -57
- package/esm2020/plugins/image/image.plugin.mjs +56 -56
- package/esm2020/plugins/indent/indent.editor.mjs +70 -70
- package/esm2020/plugins/indent/indent.plugin.mjs +57 -57
- package/esm2020/plugins/indent/on-keydown-indent.mjs +53 -53
- package/esm2020/plugins/index.mjs +70 -70
- package/esm2020/plugins/inline-code/inline-code.component.mjs +21 -21
- package/esm2020/plugins/inline-code/inline-code.editor.mjs +47 -47
- package/esm2020/plugins/inline-code/inline-code.plugin.mjs +65 -65
- package/esm2020/plugins/link/edit/link-edit.component.mjs +105 -105
- package/esm2020/plugins/link/hover/link-hover.component.mjs +36 -36
- package/esm2020/plugins/link/link.component.mjs +162 -162
- package/esm2020/plugins/link/link.editor.mjs +66 -66
- package/esm2020/plugins/link/link.plugin.mjs +58 -58
- package/esm2020/plugins/link/link.types.mjs +12 -12
- package/esm2020/plugins/list/components/bulleted-list.component.mjs +32 -32
- package/esm2020/plugins/list/components/list-item.component.mjs +92 -92
- package/esm2020/plugins/list/components/numbered-list.component.mjs +38 -38
- package/esm2020/plugins/list/list.editor.mjs +125 -125
- package/esm2020/plugins/list/list.plugin.mjs +285 -285
- package/esm2020/plugins/list/normalizers/get-list-normalizer.mjs +39 -39
- package/esm2020/plugins/list/normalizers/normalize-list-item.mjs +18 -18
- package/esm2020/plugins/list/normalizers/normalize-no.mjs +42 -42
- package/esm2020/plugins/list/on-key-down-list.mjs +32 -32
- package/esm2020/plugins/list/queries/get-list-item-entry.mjs +27 -27
- package/esm2020/plugins/list/queries/get-list-item-sublist.mjs +12 -12
- package/esm2020/plugins/list/queries/get-list-types.mjs +5 -5
- package/esm2020/plugins/list/queries/get-start-list-item.mjs +26 -26
- package/esm2020/plugins/list/queries/has-list-in-list-item.mjs +27 -27
- package/esm2020/plugins/list/queries/is-in-list.mjs +5 -5
- package/esm2020/plugins/list/queries/is-list-nested.mjs +10 -10
- package/esm2020/plugins/list/queries/is-list.mjs +5 -5
- package/esm2020/plugins/list/queries/is-node-type-list.mjs +4 -4
- package/esm2020/plugins/list/queries/is-selection-at-list-item-start.mjs +12 -12
- package/esm2020/plugins/list/queries/is-selection-in-same-list-item.mjs +16 -16
- package/esm2020/plugins/list/queries/is-single-list-item.mjs +9 -9
- package/esm2020/plugins/list/transforms/insert-list-data.mjs +71 -71
- package/esm2020/plugins/list/transforms/insert-list-item.mjs +72 -72
- package/esm2020/plugins/list/transforms/move-list-item-down.mjs +41 -41
- package/esm2020/plugins/list/transforms/move-list-item-sublist-items-to-list-item-sublist.mjs +42 -42
- package/esm2020/plugins/list/transforms/move-list-item-sublist-items-to-list.mjs +29 -29
- package/esm2020/plugins/list/transforms/move-list-item-up.mjs +77 -77
- package/esm2020/plugins/list/transforms/unwrap-list.mjs +9 -9
- package/esm2020/plugins/list/types.mjs +2 -2
- package/esm2020/plugins/mark/mark.editor.mjs +27 -27
- package/esm2020/plugins/mark/mark.plugin.mjs +104 -104
- package/esm2020/plugins/node-id/node-id.plugin.mjs +77 -77
- package/esm2020/plugins/normalizers/insert-paragraph-nodes.mjs +27 -27
- package/esm2020/plugins/normalizers/remove-empty-nodes.mjs +17 -17
- package/esm2020/plugins/normalizers/trailing-node.plugin.mjs +32 -32
- package/esm2020/plugins/paint-format/paint-format.editor.mjs +122 -122
- package/esm2020/plugins/public-api.mjs +15 -15
- package/esm2020/plugins/quick-insert/components/quick-insert.component.mjs +95 -95
- package/esm2020/plugins/quick-insert/components/quick-toolbar/quick-toolbar.component.mjs +79 -79
- package/esm2020/plugins/quick-insert/quick-insert.editor.mjs +52 -52
- package/esm2020/plugins/quick-insert/quick-insert.plugin.mjs +73 -73
- package/esm2020/plugins/soft-break/soft-break.plugin.mjs +35 -35
- package/esm2020/plugins/soft-break/soft-break.types.mjs +1 -1
- package/esm2020/plugins/table/components/insert-mark/insert-mark.component.mjs +99 -99
- package/esm2020/plugins/table/components/row/row.component.mjs +46 -46
- package/esm2020/plugins/table/components/table.component.mjs +460 -460
- package/esm2020/plugins/table/components/td/td.component.mjs +696 -696
- package/esm2020/plugins/table/components/toolbar/table-options.component.mjs +70 -70
- package/esm2020/plugins/table/components/toolbar/table-toolbar.component.mjs +158 -158
- package/esm2020/plugins/table/table.editor.mjs +182 -182
- package/esm2020/plugins/table/table.plugin.mjs +426 -426
- package/esm2020/plugins/table/table.service.mjs +102 -102
- package/esm2020/plugins/table/table.store.mjs +483 -483
- package/esm2020/plugins/table/table.types.mjs +33 -33
- package/esm2020/plugins/table/toolbar-item.component.mjs +60 -60
- package/esm2020/plugins/table/transforms/clear-cell.mjs +14 -14
- package/esm2020/plugins/table/transforms/clear-table-node.mjs +27 -27
- package/esm2020/plugins/table/transforms/insert-column.mjs +57 -57
- package/esm2020/plugins/table/transforms/insert-row.mjs +42 -42
- package/esm2020/plugins/table/transforms/insert-table.mjs +14 -14
- package/esm2020/plugins/table/transforms/remove-column.mjs +51 -51
- package/esm2020/plugins/table/transforms/remove-row.mjs +50 -50
- package/esm2020/plugins/table/transforms/remove-table.mjs +49 -49
- package/esm2020/plugins/table/utils/add-columns.mjs +28 -28
- package/esm2020/plugins/table/utils/calc-anchor-position.mjs +24 -24
- package/esm2020/plugins/table/utils/calc-span.mjs +72 -72
- package/esm2020/plugins/table/utils/create-cell.mjs +19 -19
- package/esm2020/plugins/table/utils/create-row.mjs +12 -12
- package/esm2020/plugins/table/utils/create-table.mjs +13 -13
- package/esm2020/plugins/table/utils/get-base-height.mjs +22 -22
- package/esm2020/plugins/table/utils/get-select-cell-node.mjs +19 -19
- package/esm2020/plugins/table/utils/index.mjs +8 -8
- package/esm2020/plugins/table/utils/is-range-in-table.mjs +16 -16
- package/esm2020/plugins/table/utils/is-selection-in-table.mjs +11 -11
- package/esm2020/plugins/table/utils/is-virtual-key.mjs +12 -12
- package/esm2020/plugins/table/utils/merge-cell.mjs +90 -90
- package/esm2020/plugins/table/utils/next-path.mjs +5 -5
- package/esm2020/plugins/table/utils/normalize-table.mjs +30 -30
- package/esm2020/plugins/table/utils/remove-columns.mjs +23 -23
- package/esm2020/plugins/table/utils/set-menu-cell-invisibility.mjs +15 -15
- package/esm2020/plugins/table/utils/split-cell.mjs +31 -31
- package/esm2020/plugins/table/utils/table-position.mjs +242 -242
- package/esm2020/plugins/todo-item/todo-item.component.mjs +53 -53
- package/esm2020/plugins/todo-item/todo-item.editor.mjs +31 -31
- package/esm2020/plugins/todo-item/todo-item.plugin.mjs +78 -78
- package/esm2020/plugins/vertical-align/toolbar-item.component.mjs +82 -82
- package/esm2020/plugins/vertical-align/vertical-align.editor.mjs +54 -54
- package/esm2020/public-api.mjs +23 -23
- package/esm2020/queries/anchor-block-entry.mjs +13 -13
- package/esm2020/queries/anchor-block.mjs +6 -6
- package/esm2020/queries/anchor-inline-entry.mjs +10 -10
- package/esm2020/queries/find-descendant.mjs +47 -47
- package/esm2020/queries/find-node.mjs +45 -45
- package/esm2020/queries/find-path.mjs +28 -28
- package/esm2020/queries/get-above-by-type.mjs +13 -13
- package/esm2020/queries/get-above.mjs +9 -9
- package/esm2020/queries/get-anchor-block-entry.mjs +8 -8
- package/esm2020/queries/get-block-above.mjs +10 -10
- package/esm2020/queries/get-block-card-above.mjs +10 -10
- package/esm2020/queries/get-block-card-cursor.mjs +5 -5
- package/esm2020/queries/get-container-blocks.mjs +11 -11
- package/esm2020/queries/get-directly-parent.mjs +11 -11
- package/esm2020/queries/get-insert-elements-path.mjs +43 -43
- package/esm2020/queries/get-last-child-path.mjs +9 -9
- package/esm2020/queries/get-last-node.mjs +17 -17
- package/esm2020/queries/get-next-sibling-nodes.mjs +17 -17
- package/esm2020/queries/get-node.mjs +10 -10
- package/esm2020/queries/get-nodes-by-type.mjs +15 -15
- package/esm2020/queries/get-nodes.mjs +7 -7
- package/esm2020/queries/get-parent.mjs +12 -12
- package/esm2020/queries/get-plain-text.mjs +16 -16
- package/esm2020/queries/get-plugin-by-toolbar.mjs +12 -12
- package/esm2020/queries/get-point-before.mjs +61 -61
- package/esm2020/queries/get-point-from-location.mjs +15 -15
- package/esm2020/queries/get-previous-path.mjs +9 -9
- package/esm2020/queries/get-rang-from-block-start.mjs +16 -16
- package/esm2020/queries/get-range-before.mjs +17 -17
- package/esm2020/queries/get-selection-marks.mjs +18 -18
- package/esm2020/queries/get-selection-nodes-by-type.mjs +29 -29
- package/esm2020/queries/get-text.mjs +9 -9
- package/esm2020/queries/get-toolbar-disabled.mjs +12 -12
- package/esm2020/queries/index.mjs +58 -58
- package/esm2020/queries/is-across-blocks.mjs +7 -7
- package/esm2020/queries/is-ancestor-empty.mjs +6 -6
- package/esm2020/queries/is-ancestor.mjs +3 -3
- package/esm2020/queries/is-block-above-empty.mjs +11 -11
- package/esm2020/queries/is-block-active.mjs +7 -7
- package/esm2020/queries/is-block-card-cursor.mjs +4 -4
- package/esm2020/queries/is-block-text-empty-after-selection.mjs +31 -31
- package/esm2020/queries/is-collapsed.mjs +7 -7
- package/esm2020/queries/is-contain-nested-type.mjs +28 -28
- package/esm2020/queries/is-container-type.mjs +2 -2
- package/esm2020/queries/is-descendant.mjs +3 -3
- package/esm2020/queries/is-empty-content.mjs +14 -14
- package/esm2020/queries/is-empty-paragraph-by-path.mjs +7 -7
- package/esm2020/queries/is-empty-paragraph.mjs +11 -11
- package/esm2020/queries/is-first-child.mjs +5 -5
- package/esm2020/queries/is-include-types.mjs +11 -11
- package/esm2020/queries/is-node-type-in.mjs +9 -9
- package/esm2020/queries/is-node-type.mjs +15 -15
- package/esm2020/queries/is-paragraph.mjs +9 -9
- package/esm2020/queries/is-point-at-root.mjs +2 -2
- package/esm2020/queries/is-range-across-blocks.mjs +22 -22
- package/esm2020/queries/is-range-at-root.mjs +3 -3
- package/esm2020/queries/is-start.mjs +6 -6
- package/esm2020/queries/some-node.mjs +9 -9
- package/esm2020/services/color-select.service.mjs +49 -49
- package/esm2020/services/context.service.mjs +58 -58
- package/esm2020/services/table-contextmenu.service.mjs +189 -189
- package/esm2020/services/toolbar.service.mjs +47 -47
- package/esm2020/shortcuts/index.mjs +5 -5
- package/esm2020/shortcuts/mark.mjs +24 -24
- package/esm2020/transforms/apply-deep-to-nodes.mjs +21 -21
- package/esm2020/transforms/clear-marks.mjs +23 -23
- package/esm2020/transforms/close-conversion-hint.mjs +8 -8
- package/esm2020/transforms/delete-element.mjs +11 -11
- package/esm2020/transforms/handle-continual-delete-backward.mjs +17 -17
- package/esm2020/transforms/handle-continual-insert-break.mjs +19 -19
- package/esm2020/transforms/index.mjs +18 -18
- package/esm2020/transforms/insert-elements.mjs +33 -33
- package/esm2020/transforms/insert-paragraph.mjs +6 -6
- package/esm2020/transforms/merge-deep-to-nodes.mjs +8 -8
- package/esm2020/transforms/move-children.mjs +21 -21
- package/esm2020/transforms/on-keydown-reset-block-type.mjs +22 -22
- package/esm2020/transforms/set-end-selection.mjs +10 -10
- package/esm2020/transforms/set-marks.mjs +9 -9
- package/esm2020/transforms/set-node.mjs +5 -5
- package/esm2020/transforms/split-node.mjs +31 -31
- package/esm2020/transforms/un-hang-range.mjs +11 -11
- package/esm2020/transforms/un-wrap.mjs +11 -11
- package/esm2020/transforms/unwrap-nodes-by-type.mjs +14 -14
- package/esm2020/utils/auto-focus.mjs +13 -13
- package/esm2020/utils/auto-scroll-view.mjs +24 -24
- package/esm2020/utils/cast-array.mjs +7 -7
- package/esm2020/utils/common.mjs +2 -2
- package/esm2020/utils/create-empty-paragraph.mjs +14 -14
- package/esm2020/utils/data-transform.mjs +48 -48
- package/esm2020/utils/dom.mjs +46 -46
- package/esm2020/utils/editor-uuid.mjs +8 -8
- package/esm2020/utils/fragment.mjs +65 -65
- package/esm2020/utils/get-all-nodes-by-type.mjs +5 -0
- package/esm2020/utils/get-editable-element-height.mjs +6 -6
- package/esm2020/utils/get-toolbar-class.mjs +6 -6
- package/esm2020/utils/id-creator.mjs +11 -11
- package/esm2020/utils/index.mjs +13 -13
- package/esm2020/utils/is-clean-empty-paragraph.mjs +36 -36
- package/esm2020/utils/is-inline.mjs +8 -8
- package/esm2020/utils/lodash.mjs +2 -2
- package/esm2020/utils/match.mjs +32 -32
- package/esm2020/utils/merge-element-options.mjs +19 -19
- package/esm2020/utils/weak-maps.mjs +3 -3
- package/esm2020/worktile-theia.mjs +4 -4
- package/fesm2015/worktile-theia.mjs +13131 -13097
- package/fesm2015/worktile-theia.mjs.map +1 -1
- package/fesm2020/worktile-theia.mjs +13150 -13120
- package/fesm2020/worktile-theia.mjs.map +1 -1
- package/interfaces/auto-format.d.ts +64 -64
- package/interfaces/editor.d.ts +146 -146
- package/interfaces/element.d.ts +9 -9
- package/interfaces/image.d.ts +25 -25
- package/interfaces/index.d.ts +8 -8
- package/interfaces/plugins/index.d.ts +4 -4
- package/interfaces/plugins/no-infer.d.ts +1 -1
- package/interfaces/plugins/plugin-key.d.ts +48 -48
- package/interfaces/plugins/plugins.d.ts +45 -45
- package/interfaces/plugins/with-override.d.ts +7 -7
- package/interfaces/reset-block-type-plugin-options.d.ts +23 -23
- package/interfaces/toolbar.d.ts +64 -64
- package/interfaces/upload.d.ts +11 -11
- package/interfaces/utility/index.d.ts +3 -3
- package/interfaces/utility/nested-structure-by-key.d.ts +3 -3
- package/interfaces/utility/override-by-key.d.ts +3 -3
- package/interfaces/utility/types.d.ts +1 -1
- package/interfaces/valid-children-types.d.ts +9 -9
- package/interfaces/view-base.d.ts +9 -9
- package/package.json +5 -4
- package/pipes.d.ts +16 -16
- package/plugins/align/align.editor.d.ts +7 -7
- package/plugins/align/align.plugin.d.ts +2 -2
- package/plugins/autoformat/autoformat.plugin.d.ts +6 -6
- package/plugins/autoformat/transforms/auto-format-block.d.ts +5 -5
- package/plugins/autoformat/transforms/auto-format-inline.d.ts +9 -9
- package/plugins/blockquote/blockquote.component.d.ts +11 -11
- package/plugins/blockquote/blockquote.editor.d.ts +4 -4
- package/plugins/blockquote/blockquote.plugin.d.ts +2 -2
- package/plugins/code/code.component.d.ts +65 -65
- package/plugins/code/code.editor.d.ts +8 -8
- package/plugins/code/code.plugin.d.ts +2 -2
- package/plugins/color/color.editor.d.ts +8 -8
- package/plugins/color/color.plugin.d.ts +1 -1
- package/plugins/color/toolbar-item.component.d.ts +16 -16
- package/plugins/common/auto-insert-data..d.ts +2 -2
- package/plugins/common/block-card.plugin.d.ts +2 -2
- package/plugins/common/get-fragment.plugin.d.ts +6 -6
- package/plugins/common/history.plugin.d.ts +9 -9
- package/plugins/common/move-selection.plugin.d.ts +2 -2
- package/plugins/common/remove-empty.plugin.d.ts +2 -2
- package/plugins/common/remove-void.plugin.d.ts +2 -2
- package/plugins/common/reset-type.plugin.d.ts +2 -2
- package/plugins/common/transforms.plugin.d.ts +8 -8
- package/plugins/deserializers/deserialize-html.plugin.d.ts +2 -2
- package/plugins/deserializers/deserialize-md.plugin.d.ts +2 -2
- package/plugins/font-size/font-size.editor.d.ts +10 -10
- package/plugins/heading/heading.editor.d.ts +9 -9
- package/plugins/heading/heading.plugin.d.ts +7 -7
- package/plugins/hr/hr.component.d.ts +12 -12
- package/plugins/hr/hr.editor.d.ts +4 -4
- package/plugins/hr/hr.plugin.d.ts +2 -2
- package/plugins/image/image.component.d.ts +77 -74
- package/plugins/image/image.editor.d.ts +12 -12
- package/plugins/image/image.plugin.d.ts +7 -7
- package/plugins/indent/indent.editor.d.ts +10 -10
- package/plugins/indent/indent.plugin.d.ts +8 -8
- package/plugins/indent/on-keydown-indent.d.ts +3 -3
- package/plugins/index.d.ts +1 -1
- package/plugins/inline-code/inline-code.component.d.ts +9 -9
- package/plugins/inline-code/inline-code.editor.d.ts +7 -7
- package/plugins/inline-code/inline-code.plugin.d.ts +2 -2
- package/plugins/link/edit/link-edit.component.d.ts +36 -36
- package/plugins/link/hover/link-hover.component.d.ts +15 -15
- package/plugins/link/link.component.d.ts +39 -39
- package/plugins/link/link.editor.d.ts +7 -7
- package/plugins/link/link.plugin.d.ts +2 -2
- package/plugins/link/link.types.d.ts +9 -9
- package/plugins/list/components/bulleted-list.component.d.ts +15 -15
- package/plugins/list/components/list-item.component.d.ts +20 -20
- package/plugins/list/components/numbered-list.component.d.ts +16 -16
- package/plugins/list/list.editor.d.ts +12 -12
- package/plugins/list/list.plugin.d.ts +3 -3
- package/plugins/list/normalizers/get-list-normalizer.d.ts +6 -6
- package/plugins/list/normalizers/normalize-list-item.d.ts +5 -5
- package/plugins/list/normalizers/normalize-no.d.ts +2 -2
- package/plugins/list/on-key-down-list.d.ts +2 -2
- package/plugins/list/queries/get-list-item-entry.d.ts +10 -10
- package/plugins/list/queries/get-list-item-sublist.d.ts +6 -6
- package/plugins/list/queries/get-list-types.d.ts +2 -2
- package/plugins/list/queries/get-start-list-item.d.ts +8 -8
- package/plugins/list/queries/has-list-in-list-item.d.ts +15 -15
- package/plugins/list/queries/is-in-list.d.ts +2 -2
- package/plugins/list/queries/is-list-nested.d.ts +5 -5
- package/plugins/list/queries/is-list.d.ts +2 -2
- package/plugins/list/queries/is-node-type-list.d.ts +2 -2
- package/plugins/list/queries/is-selection-at-list-item-start.d.ts +5 -5
- package/plugins/list/queries/is-selection-in-same-list-item.d.ts +5 -5
- package/plugins/list/queries/is-single-list-item.d.ts +5 -5
- package/plugins/list/transforms/insert-list-data.d.ts +12 -12
- package/plugins/list/transforms/insert-list-item.d.ts +5 -5
- package/plugins/list/transforms/move-list-item-down.d.ts +6 -6
- package/plugins/list/transforms/move-list-item-sublist-items-to-list-item-sublist.d.ts +20 -20
- package/plugins/list/transforms/move-list-item-sublist-items-to-list.d.ts +19 -19
- package/plugins/list/transforms/move-list-item-up.d.ts +10 -10
- package/plugins/list/transforms/unwrap-list.d.ts +2 -2
- package/plugins/list/types.d.ts +7 -7
- package/plugins/mark/mark.editor.d.ts +8 -8
- package/plugins/mark/mark.plugin.d.ts +3 -3
- package/plugins/node-id/node-id.plugin.d.ts +8 -8
- package/plugins/normalizers/insert-paragraph-nodes.d.ts +7 -7
- package/plugins/normalizers/remove-empty-nodes.d.ts +7 -7
- package/plugins/normalizers/trailing-node.plugin.d.ts +9 -9
- package/plugins/paint-format/paint-format.editor.d.ts +8 -8
- package/plugins/public-api.d.ts +15 -15
- package/plugins/quick-insert/components/quick-insert.component.d.ts +28 -28
- package/plugins/quick-insert/components/quick-toolbar/quick-toolbar.component.d.ts +28 -28
- package/plugins/quick-insert/quick-insert.editor.d.ts +7 -7
- package/plugins/quick-insert/quick-insert.plugin.d.ts +10 -10
- package/plugins/soft-break/soft-break.plugin.d.ts +5 -5
- package/plugins/soft-break/soft-break.types.d.ts +8 -8
- package/plugins/table/components/insert-mark/insert-mark.component.d.ts +24 -24
- package/plugins/table/components/row/row.component.d.ts +14 -14
- package/plugins/table/components/table.component.d.ts +79 -79
- package/plugins/table/components/td/td.component.d.ts +95 -95
- package/plugins/table/components/toolbar/table-options.component.d.ts +20 -20
- package/plugins/table/components/toolbar/table-toolbar.component.d.ts +38 -38
- package/plugins/table/table.editor.d.ts +25 -25
- package/plugins/table/table.plugin.d.ts +3 -3
- package/plugins/table/table.service.d.ts +30 -30
- package/plugins/table/table.store.d.ts +71 -71
- package/plugins/table/table.types.d.ts +67 -67
- package/plugins/table/toolbar-item.component.d.ts +17 -17
- package/plugins/table/transforms/clear-cell.d.ts +6 -6
- package/plugins/table/transforms/clear-table-node.d.ts +6 -6
- package/plugins/table/transforms/insert-column.d.ts +12 -12
- package/plugins/table/transforms/insert-row.d.ts +6 -6
- package/plugins/table/transforms/insert-table.d.ts +6 -6
- package/plugins/table/transforms/remove-column.d.ts +3 -3
- package/plugins/table/transforms/remove-row.d.ts +3 -3
- package/plugins/table/transforms/remove-table.d.ts +3 -3
- package/plugins/table/utils/add-columns.d.ts +2 -2
- package/plugins/table/utils/calc-anchor-position.d.ts +6 -6
- package/plugins/table/utils/calc-span.d.ts +11 -11
- package/plugins/table/utils/create-cell.d.ts +16 -16
- package/plugins/table/utils/create-row.d.ts +7 -7
- package/plugins/table/utils/create-table.d.ts +7 -7
- package/plugins/table/utils/get-base-height.d.ts +9 -9
- package/plugins/table/utils/get-select-cell-node.d.ts +7 -7
- package/plugins/table/utils/index.d.ts +7 -7
- package/plugins/table/utils/is-range-in-table.d.ts +6 -6
- package/plugins/table/utils/is-selection-in-table.d.ts +6 -6
- package/plugins/table/utils/is-virtual-key.d.ts +1 -1
- package/plugins/table/utils/merge-cell.d.ts +21 -21
- package/plugins/table/utils/next-path.d.ts +2 -2
- package/plugins/table/utils/normalize-table.d.ts +2 -2
- package/plugins/table/utils/remove-columns.d.ts +2 -2
- package/plugins/table/utils/set-menu-cell-invisibility.d.ts +3 -3
- package/plugins/table/utils/split-cell.d.ts +4 -4
- package/plugins/table/utils/table-position.d.ts +97 -97
- package/plugins/todo-item/todo-item.component.d.ts +21 -21
- package/plugins/todo-item/todo-item.editor.d.ts +5 -5
- package/plugins/todo-item/todo-item.plugin.d.ts +5 -5
- package/plugins/vertical-align/toolbar-item.component.d.ts +25 -25
- package/plugins/vertical-align/vertical-align.editor.d.ts +7 -7
- package/public-api.d.ts +20 -20
- package/queries/anchor-block-entry.d.ts +2 -2
- package/queries/anchor-block.d.ts +2 -2
- package/queries/anchor-inline-entry.d.ts +2 -2
- package/queries/find-descendant.d.ts +10 -10
- package/queries/find-node.d.ts +15 -15
- package/queries/find-path.d.ts +6 -6
- package/queries/get-above-by-type.d.ts +6 -6
- package/queries/get-above.d.ts +6 -6
- package/queries/get-anchor-block-entry.d.ts +2 -2
- package/queries/get-block-above.d.ts +7 -7
- package/queries/get-block-card-above.d.ts +7 -7
- package/queries/get-block-card-cursor.d.ts +2 -2
- package/queries/get-container-blocks.d.ts +2 -2
- package/queries/get-directly-parent.d.ts +2 -2
- package/queries/get-insert-elements-path.d.ts +7 -7
- package/queries/get-last-child-path.d.ts +6 -6
- package/queries/get-last-node.d.ts +2 -2
- package/queries/get-next-sibling-nodes.d.ts +7 -7
- package/queries/get-node.d.ts +2 -2
- package/queries/get-nodes-by-type.d.ts +6 -6
- package/queries/get-nodes.d.ts +4 -4
- package/queries/get-parent.d.ts +7 -7
- package/queries/get-plain-text.d.ts +6 -6
- package/queries/get-plugin-by-toolbar.d.ts +3 -3
- package/queries/get-point-before.d.ts +38 -38
- package/queries/get-point-from-location.d.ts +5 -5
- package/queries/get-previous-path.d.ts +2 -2
- package/queries/get-rang-from-block-start.d.ts +9 -9
- package/queries/get-range-before.d.ts +7 -7
- package/queries/get-selection-marks.d.ts +12 -12
- package/queries/get-selection-nodes-by-type.d.ts +3 -3
- package/queries/get-text.d.ts +6 -6
- package/queries/get-toolbar-disabled.d.ts +4 -4
- package/queries/index.d.ts +58 -58
- package/queries/is-across-blocks.d.ts +2 -2
- package/queries/is-ancestor-empty.d.ts +5 -5
- package/queries/is-ancestor.d.ts +2 -2
- package/queries/is-block-above-empty.d.ts +5 -5
- package/queries/is-block-active.d.ts +3 -3
- package/queries/is-block-card-cursor.d.ts +2 -2
- package/queries/is-block-text-empty-after-selection.d.ts +7 -7
- package/queries/is-collapsed.d.ts +6 -6
- package/queries/is-contain-nested-type.d.ts +2 -2
- package/queries/is-container-type.d.ts +2 -2
- package/queries/is-descendant.d.ts +2 -2
- package/queries/is-empty-content.d.ts +2 -2
- package/queries/is-empty-paragraph-by-path.d.ts +2 -2
- package/queries/is-empty-paragraph.d.ts +2 -2
- package/queries/is-first-child.d.ts +5 -5
- package/queries/is-include-types.d.ts +3 -3
- package/queries/is-node-type-in.d.ts +6 -6
- package/queries/is-node-type.d.ts +6 -6
- package/queries/is-paragraph.d.ts +2 -2
- package/queries/is-point-at-root.d.ts +2 -2
- package/queries/is-range-across-blocks.d.ts +8 -8
- package/queries/is-range-at-root.d.ts +2 -2
- package/queries/is-start.d.ts +5 -5
- package/queries/some-node.d.ts +7 -7
- package/services/color-select.service.d.ts +20 -20
- package/services/context.service.d.ts +49 -49
- package/services/table-contextmenu.service.d.ts +25 -25
- package/services/toolbar.service.d.ts +9 -9
- package/shortcuts/index.d.ts +2 -2
- package/shortcuts/mark.d.ts +2 -2
- package/transforms/apply-deep-to-nodes.d.ts +12 -12
- package/transforms/clear-marks.d.ts +2 -2
- package/transforms/close-conversion-hint.d.ts +2 -2
- package/transforms/delete-element.d.ts +2 -2
- package/transforms/handle-continual-delete-backward.d.ts +3 -3
- package/transforms/handle-continual-insert-break.d.ts +3 -3
- package/transforms/index.d.ts +18 -18
- package/transforms/insert-elements.d.ts +2 -2
- package/transforms/insert-paragraph.d.ts +2 -2
- package/transforms/merge-deep-to-nodes.d.ts +5 -5
- package/transforms/move-children.d.ts +24 -24
- package/transforms/on-keydown-reset-block-type.d.ts +3 -3
- package/transforms/set-end-selection.d.ts +2 -2
- package/transforms/set-marks.d.ts +12 -12
- package/transforms/set-node.d.ts +2 -2
- package/transforms/split-node.d.ts +3 -3
- package/transforms/un-hang-range.d.ts +10 -10
- package/transforms/un-wrap.d.ts +3 -3
- package/transforms/unwrap-nodes-by-type.d.ts +6 -6
- package/utils/auto-focus.d.ts +2 -2
- package/utils/auto-scroll-view.d.ts +6 -6
- package/utils/cast-array.d.ts +1 -1
- package/utils/common.d.ts +2 -2
- package/utils/create-empty-paragraph.d.ts +2 -2
- package/utils/data-transform.d.ts +6 -6
- package/utils/dom.d.ts +10 -10
- package/utils/editor-uuid.d.ts +3 -3
- package/utils/fragment.d.ts +10 -10
- package/utils/get-all-nodes-by-type.d.ts +3 -0
- package/utils/get-editable-element-height.d.ts +2 -2
- package/utils/get-toolbar-class.d.ts +2 -2
- package/utils/id-creator.d.ts +1 -1
- package/utils/index.d.ts +13 -13
- package/utils/is-clean-empty-paragraph.d.ts +9 -9
- package/utils/is-inline.d.ts +2 -2
- package/utils/lodash.d.ts +2 -2
- package/utils/match.d.ts +18 -18
- package/utils/merge-element-options.d.ts +2 -2
- package/utils/weak-maps.d.ts +5 -5
- package/worktile-theia.d.ts +5 -5
|
@@ -1,427 +1,427 @@
|
|
|
1
|
-
import { Transforms, Node, Range, Editor, Element, Path, Operation } from 'slate';
|
|
2
|
-
import { AngularEditor, ELEMENT_TO_COMPONENT, hotkeys } from 'slate-angular';
|
|
3
|
-
import { TableOptions } from './table.types';
|
|
4
|
-
import { isRangeInTable, isSelectionInTable, TablePosition } from './utils';
|
|
5
|
-
import { PluginKeys, TheEditor } from '../../interfaces';
|
|
6
|
-
import { ElementKinds } from '../../constants/node-types';
|
|
7
|
-
import { TheTableComponent } from './components/table.component';
|
|
8
|
-
import { TableEditor } from './table.editor';
|
|
9
|
-
import { clearTableNode } from './transforms/clear-table-node';
|
|
10
|
-
import { isVirtualKey } from './utils/is-virtual-key';
|
|
11
|
-
import { insertColumnAtRow } from './transforms/insert-column';
|
|
12
|
-
import { calculateAnchorPositionInCell } from './utils/calc-anchor-position';
|
|
13
|
-
import { CLIPBOARD_FORMAT_KEY } from '../../constants/default';
|
|
14
|
-
import { getOriginCell } from './utils/calc-span';
|
|
15
|
-
import { resetTableCell } from './utils/split-cell';
|
|
16
|
-
import { removeColumns } from './utils/remove-columns';
|
|
17
|
-
import { addColumns } from './utils/add-columns';
|
|
18
|
-
import { TheTableRowComponent } from './components/row/row.component';
|
|
19
|
-
import { TheTdComponent } from './components/td/td.component';
|
|
20
|
-
import { extractFragment } from '../../utils/fragment';
|
|
21
|
-
import * as TheQueries from '../../queries';
|
|
22
|
-
import { normalizeTable } from './utils/normalize-table';
|
|
23
|
-
import { cloneDeep } from '../../utils/lodash';
|
|
24
|
-
import { createPluginFactory } from '../../core';
|
|
25
|
-
import { TheTableToolbarItemComponent } from './toolbar-item.component';
|
|
26
|
-
export const withTable = (editor) => {
|
|
27
|
-
const { deleteBackward, deleteForward, onKeydown, setFragmentData, insertData, normalizeNode, isBlockCard, renderElement, deleteCutData, isContainer, onChange } = editor;
|
|
28
|
-
editor.deleteBackward = unit => {
|
|
29
|
-
const opts = new TableOptions();
|
|
30
|
-
if (!isSelectionInTable(opts, editor)) {
|
|
31
|
-
deleteBackward(unit);
|
|
32
|
-
return;
|
|
33
|
-
}
|
|
34
|
-
const { selection } = editor;
|
|
35
|
-
const [, startBlockPath] = Editor.above(editor, {
|
|
36
|
-
match: n => Editor.isBlock(editor, n)
|
|
37
|
-
});
|
|
38
|
-
const startPosition = TablePosition.create(opts, editor, selection.anchor.path);
|
|
39
|
-
if (startBlockPath.length <= startPosition.cellEntry[1].length + 1 &&
|
|
40
|
-
startBlockPath.pop() === 0 &&
|
|
41
|
-
selection.anchor.offset === 0 &&
|
|
42
|
-
TheQueries.isStart(editor, selection.anchor, startBlockPath) &&
|
|
43
|
-
!Editor.isVoid(editor, TheQueries.anchorBlock(editor))) {
|
|
44
|
-
return;
|
|
45
|
-
}
|
|
46
|
-
deleteBackward(unit);
|
|
47
|
-
};
|
|
48
|
-
editor.deleteForward = unit => {
|
|
49
|
-
const opts = new TableOptions();
|
|
50
|
-
const afterPoint = Editor.after(editor, editor.selection);
|
|
51
|
-
if (afterPoint && isRangeInTable(opts, editor, { anchor: afterPoint, focus: afterPoint })) {
|
|
52
|
-
const beforePosition = TablePosition.create(opts, editor, editor.selection.anchor.path);
|
|
53
|
-
const afterPosition = TablePosition.create(opts, editor, afterPoint.path);
|
|
54
|
-
if (beforePosition.cell && beforePosition.cell !== afterPosition.cell) {
|
|
55
|
-
return;
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
deleteForward(unit);
|
|
59
|
-
};
|
|
60
|
-
editor.onKeydown = (event) => {
|
|
61
|
-
const opts = new TableOptions();
|
|
62
|
-
const isMoveUp = hotkeys.isMoveUp(event);
|
|
63
|
-
const isMoveDown = hotkeys.isMoveDown(event);
|
|
64
|
-
const isMoveBackward = hotkeys.isMoveBackward(event);
|
|
65
|
-
const isMoveForward = hotkeys.isMoveForward(event);
|
|
66
|
-
const { selection } = editor;
|
|
67
|
-
if (!selection || !selection.anchor || !selection.focus) {
|
|
68
|
-
onKeydown(event);
|
|
69
|
-
return;
|
|
70
|
-
}
|
|
71
|
-
const startPosition = TablePosition.create(opts, editor, selection.anchor.path);
|
|
72
|
-
const endPosition = TablePosition.create(opts, editor, selection.focus.path);
|
|
73
|
-
const isCollapsed = Range.isCollapsed(selection);
|
|
74
|
-
if (startPosition && endPosition && endPosition.isInTable()) {
|
|
75
|
-
// for keyboard up and down key in the table
|
|
76
|
-
if (isMoveUp || isMoveDown) {
|
|
77
|
-
const cellPath = endPosition.cellEntry[1];
|
|
78
|
-
const startPath = Editor.start(editor, cellPath).path;
|
|
79
|
-
const endPath = Editor.end(editor, cellPath).path;
|
|
80
|
-
const { isFirstLine, isLastLine } = calculateAnchorPositionInCell(editor);
|
|
81
|
-
startPath.pop();
|
|
82
|
-
endPath.pop();
|
|
83
|
-
if ((TheQueries.anchorBlockEntry(editor)[1].toString() !== startPath.toString() || !isFirstLine) && isMoveUp) {
|
|
84
|
-
onKeydown(event);
|
|
85
|
-
return;
|
|
86
|
-
}
|
|
87
|
-
if ((TheQueries.anchorBlockEntry(editor)[1].toString() !== endPath.toString() || !isLastLine) && isMoveDown) {
|
|
88
|
-
onKeydown(event);
|
|
89
|
-
return;
|
|
90
|
-
}
|
|
91
|
-
event.preventDefault();
|
|
92
|
-
let at;
|
|
93
|
-
if (isMoveUp) {
|
|
94
|
-
const aboveRow = startPosition.table.children[startPosition.getRowIndex() - 1];
|
|
95
|
-
const aboveCell = aboveRow && aboveRow.children[startPosition.getColumnIndex()];
|
|
96
|
-
if (aboveCell) {
|
|
97
|
-
if (aboveCell.hidden) {
|
|
98
|
-
TableEditor.selectOriginCell(editor, startPosition.table, startPosition.getRowIndex() - 1, startPosition.getColumnIndex(), false);
|
|
99
|
-
return;
|
|
100
|
-
}
|
|
101
|
-
else {
|
|
102
|
-
at = Editor.end(editor, TheEditor.findPath(editor, aboveCell));
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
else {
|
|
106
|
-
const previousNodeEntry = Editor.previous(editor, { at: startPosition.tableEntry[1] });
|
|
107
|
-
const beforePoint = Editor.before(editor, startPosition.tableEntry[1]);
|
|
108
|
-
Editor.next(editor, { at: startPosition.tableEntry[1] });
|
|
109
|
-
if (previousNodeEntry) {
|
|
110
|
-
at = Editor.end(editor, previousNodeEntry[1]);
|
|
111
|
-
}
|
|
112
|
-
if (!previousNodeEntry && beforePoint) {
|
|
113
|
-
at = Editor.end(editor, beforePoint.path);
|
|
114
|
-
}
|
|
115
|
-
if (!previousNodeEntry && !beforePoint) {
|
|
116
|
-
AngularEditor.moveBlockCard(editor, startPosition.tableEntry[0], { direction: 'left' });
|
|
117
|
-
return;
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
Transforms.select(editor, at);
|
|
121
|
-
}
|
|
122
|
-
else {
|
|
123
|
-
let belowRowIndex = startPosition.getRowIndex() + 1;
|
|
124
|
-
if (startPosition.cell.rowspan > 1) {
|
|
125
|
-
belowRowIndex = startPosition.getRowIndex() + startPosition.cell.rowspan;
|
|
126
|
-
}
|
|
127
|
-
const belowRow = startPosition.table.children[belowRowIndex];
|
|
128
|
-
const belowCell = belowRow && belowRow.children[startPosition.getColumnIndex()];
|
|
129
|
-
if (belowCell) {
|
|
130
|
-
if (belowCell.hidden) {
|
|
131
|
-
TableEditor.selectOriginCell(editor, startPosition.table, startPosition.getRowIndex() + 1, startPosition.getColumnIndex(), true);
|
|
132
|
-
return;
|
|
133
|
-
}
|
|
134
|
-
else {
|
|
135
|
-
at = Editor.start(editor, TheEditor.findPath(editor, belowCell));
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
else {
|
|
139
|
-
const nextNodeEntry = Editor.next(editor, { at: startPosition.tableEntry[1] });
|
|
140
|
-
const movePath = nextNodeEntry ? nextNodeEntry[1] : Editor.after(editor, startPosition.tableEntry[1]).path;
|
|
141
|
-
at = Editor.start(editor, movePath);
|
|
142
|
-
}
|
|
143
|
-
Transforms.select(editor, at);
|
|
144
|
-
}
|
|
145
|
-
return;
|
|
146
|
-
}
|
|
147
|
-
if (isMoveBackward) {
|
|
148
|
-
const beforePoint = Editor.before(editor, editor.selection);
|
|
149
|
-
const beforePosition = beforePoint && TablePosition.create(opts, editor, beforePoint.path);
|
|
150
|
-
if (beforePosition && beforePosition.cell && beforePosition.cell.hidden) {
|
|
151
|
-
event.preventDefault();
|
|
152
|
-
const at = Editor.end(editor, TheEditor.findPath(editor, beforePosition.findPrevious()));
|
|
153
|
-
Transforms.select(editor, at);
|
|
154
|
-
}
|
|
155
|
-
}
|
|
156
|
-
if (isMoveForward) {
|
|
157
|
-
const afterPoint = Editor.after(editor, editor.selection);
|
|
158
|
-
const afterPosition = afterPoint && TablePosition.create(opts, editor, afterPoint.path);
|
|
159
|
-
if (afterPosition.cell && afterPosition.cell.hidden) {
|
|
160
|
-
event.preventDefault();
|
|
161
|
-
const nextCell = afterPosition.findNext();
|
|
162
|
-
if (nextCell) {
|
|
163
|
-
const at = Editor.start(editor, TheEditor.findPath(editor, afterPosition.findNext()));
|
|
164
|
-
Transforms.select(editor, at);
|
|
165
|
-
event.preventDefault();
|
|
166
|
-
}
|
|
167
|
-
else {
|
|
168
|
-
AngularEditor.moveBlockCard(editor, startPosition.tableEntry[0], { direction: 'right' });
|
|
169
|
-
event.preventDefault();
|
|
170
|
-
}
|
|
171
|
-
return;
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
// Prevent deleting cells in the table
|
|
175
|
-
if (!isCollapsed && !startPosition.isInTable() && !isVirtualKey(event)) {
|
|
176
|
-
event.preventDefault();
|
|
177
|
-
let tableOutPath;
|
|
178
|
-
Editor.withoutNormalizing(editor, () => {
|
|
179
|
-
if (Range.isForward(selection)) {
|
|
180
|
-
tableOutPath = Editor.end(editor, [selection.focus.path[0] - 1]);
|
|
181
|
-
clearTableNode(opts, editor, true);
|
|
182
|
-
}
|
|
183
|
-
else {
|
|
184
|
-
tableOutPath = Editor.start(editor, [selection.focus.path[0] + 1]);
|
|
185
|
-
clearTableNode(opts, editor);
|
|
186
|
-
}
|
|
187
|
-
const tableOutRange = Editor.range(editor, selection.anchor, tableOutPath);
|
|
188
|
-
Transforms.delete(editor, { at: tableOutRange });
|
|
189
|
-
});
|
|
190
|
-
// new range
|
|
191
|
-
const cellRange = Editor.range(editor, editor.selection.focus.path.slice(0, 3));
|
|
192
|
-
const focusRange = Range.intersection(editor.selection, cellRange);
|
|
193
|
-
Transforms.select(editor, focusRange);
|
|
194
|
-
Editor.deleteFragment(editor);
|
|
195
|
-
return;
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
|
-
onKeydown(event);
|
|
199
|
-
return;
|
|
200
|
-
};
|
|
201
|
-
editor.setFragmentData = unit => {
|
|
202
|
-
const opts = new TableOptions();
|
|
203
|
-
if (!isSelectionInTable(opts, editor)) {
|
|
204
|
-
setFragmentData(unit);
|
|
205
|
-
return;
|
|
206
|
-
}
|
|
207
|
-
const { selection } = editor;
|
|
208
|
-
const tablePosition = TablePosition.create(opts, editor, selection.anchor.path);
|
|
209
|
-
const tableComponent = ELEMENT_TO_COMPONENT.get(tablePosition.table);
|
|
210
|
-
const cells = tableComponent.tableStore.selectedCells;
|
|
211
|
-
let tableFragment = null;
|
|
212
|
-
if (tableComponent.tableStore.selectedRowsIndex.length > 0) {
|
|
213
|
-
const rows = tablePosition.table.children.slice(tableComponent.tableStore.selectedRowsIndex[0], tableComponent.tableStore.selectedRowsIndex[tableComponent.tableStore.selectedRowsIndex.length - 1] + 1);
|
|
214
|
-
tableFragment = {
|
|
215
|
-
...tablePosition.table,
|
|
216
|
-
children: rows
|
|
217
|
-
};
|
|
218
|
-
}
|
|
219
|
-
else if (cells.length > 0) {
|
|
220
|
-
const tempRows = {};
|
|
221
|
-
for (const cell of cells) {
|
|
222
|
-
const { row, col } = cell;
|
|
223
|
-
const cellPath = [...tablePosition.tableEntry[1], row, col];
|
|
224
|
-
const cellNode = Node.get(editor, cellPath);
|
|
225
|
-
if (!tempRows[row]) {
|
|
226
|
-
tempRows[row] = [];
|
|
227
|
-
}
|
|
228
|
-
tempRows[row].push(cellNode);
|
|
229
|
-
}
|
|
230
|
-
const rows = Object.values(tempRows).map((item) => {
|
|
231
|
-
return {
|
|
232
|
-
type: ElementKinds.tableRow,
|
|
233
|
-
children: item
|
|
234
|
-
};
|
|
235
|
-
});
|
|
236
|
-
tableFragment = {
|
|
237
|
-
type: ElementKinds.table,
|
|
238
|
-
children: rows
|
|
239
|
-
};
|
|
240
|
-
}
|
|
241
|
-
if (tableFragment) {
|
|
242
|
-
tableFragment = normalizeTable(cloneDeep(tableFragment));
|
|
243
|
-
const plainText = Node.string(tableFragment);
|
|
244
|
-
tableFragment = [tableFragment];
|
|
245
|
-
const stringObj = JSON.stringify(tableFragment);
|
|
246
|
-
const encoded = window.btoa(encodeURIComponent(stringObj));
|
|
247
|
-
unit.setData(`application/${CLIPBOARD_FORMAT_KEY}`, encoded);
|
|
248
|
-
unit.setData('text/plain', plainText);
|
|
249
|
-
return;
|
|
250
|
-
}
|
|
251
|
-
setFragmentData(unit);
|
|
252
|
-
};
|
|
253
|
-
editor.insertData = data => {
|
|
254
|
-
const fragment = extractFragment(data);
|
|
255
|
-
if (fragment) {
|
|
256
|
-
const opts = new TableOptions();
|
|
257
|
-
const { selection } = editor;
|
|
258
|
-
if (isSelectionInTable(opts, editor) &&
|
|
259
|
-
fragment.length === 1 &&
|
|
260
|
-
Element.isElement(fragment[0]) &&
|
|
261
|
-
fragment[0].type === ElementKinds.table) {
|
|
262
|
-
const tablePosition = TablePosition.create(opts, editor, selection.anchor.path);
|
|
263
|
-
const clipboardTable = fragment[0].children;
|
|
264
|
-
const clipboardRow = clipboardTable[0].children;
|
|
265
|
-
const selectRowIndex = tablePosition.getRowIndex();
|
|
266
|
-
const selectColIndex = tablePosition.getColumnIndex();
|
|
267
|
-
const lastRowIndex = selectRowIndex + clipboardTable.length - 1;
|
|
268
|
-
const lastColIndex = selectColIndex + clipboardRow.length - 1;
|
|
269
|
-
for (let i = selectRowIndex; i <= lastRowIndex; i++) {
|
|
270
|
-
for (let j = selectColIndex; j <= lastColIndex; j++) {
|
|
271
|
-
const row = tablePosition.table.children[i];
|
|
272
|
-
if (row && row.children[j]) {
|
|
273
|
-
const originCell = getOriginCell(tablePosition.table, i, j);
|
|
274
|
-
if (originCell && (originCell.colspan || originCell.rowspan)) {
|
|
275
|
-
const path = TheEditor.findPath(editor, originCell).slice(-2);
|
|
276
|
-
resetTableCell(editor, tablePosition.table, originCell, path[0], path[1]);
|
|
277
|
-
}
|
|
278
|
-
}
|
|
279
|
-
}
|
|
280
|
-
}
|
|
281
|
-
Editor.withoutNormalizing(editor, () => {
|
|
282
|
-
if (lastColIndex > tablePosition.getWidth() - 1) {
|
|
283
|
-
const addColCount = lastColIndex - (tablePosition.getWidth() - 1);
|
|
284
|
-
TableEditor.insertColumn(editor, addColCount, tablePosition.getWidth());
|
|
285
|
-
}
|
|
286
|
-
if (lastRowIndex > tablePosition.getHeight() - 1) {
|
|
287
|
-
const addRowCount = lastRowIndex - (tablePosition.getHeight() - 1);
|
|
288
|
-
TableEditor.insertRow(editor, addRowCount, tablePosition.getHeight());
|
|
289
|
-
}
|
|
290
|
-
clipboardTable.forEach((row, i) => {
|
|
291
|
-
row.children.forEach((col, j) => {
|
|
292
|
-
const at = [...tablePosition.tableEntry[1], selectRowIndex + i, selectColIndex + j];
|
|
293
|
-
Transforms.removeNodes(editor, { at });
|
|
294
|
-
Transforms.insertNodes(editor, col, { at });
|
|
295
|
-
});
|
|
296
|
-
});
|
|
297
|
-
});
|
|
298
|
-
const target = Editor.start(editor, [...tablePosition.tableEntry[1], selectRowIndex, selectColIndex]);
|
|
299
|
-
Transforms.select(editor, target);
|
|
300
|
-
return;
|
|
301
|
-
}
|
|
302
|
-
}
|
|
303
|
-
insertData(data);
|
|
304
|
-
};
|
|
305
|
-
editor.normalizeNode = (entry) => {
|
|
306
|
-
if (Element.isElement(entry[0]) && entry[0].type === ElementKinds.table) {
|
|
307
|
-
const table = entry[0];
|
|
308
|
-
const maxWidth = Math.max(...table.children.map(row => row.children.length));
|
|
309
|
-
const invalidRows = table.children.filter(row => row.children.length < maxWidth);
|
|
310
|
-
if (invalidRows.length > 0) {
|
|
311
|
-
const opts = new TableOptions();
|
|
312
|
-
Editor.withoutNormalizing(editor, () => {
|
|
313
|
-
table.children.map((row, rowIndex) => {
|
|
314
|
-
row.children.map((cell, cellIndex) => {
|
|
315
|
-
if (cell.hidden || cell.colspan || cell.rowspan) {
|
|
316
|
-
Transforms.setNodes(editor, { hidden: null, colspan: null, rowspan: null }, { at: [...entry[1], rowIndex, cellIndex] });
|
|
317
|
-
}
|
|
318
|
-
});
|
|
319
|
-
});
|
|
320
|
-
invalidRows.forEach(row => {
|
|
321
|
-
const count = maxWidth - row.children.length;
|
|
322
|
-
insertColumnAtRow(opts, editor, count, entry, table.children.indexOf(row), row.children.length);
|
|
323
|
-
});
|
|
324
|
-
});
|
|
325
|
-
}
|
|
326
|
-
if (table.columns && table.columns.length !== maxWidth) {
|
|
327
|
-
const columns = table.columns.length > maxWidth ? removeColumns(table, maxWidth) : addColumns(table, maxWidth);
|
|
328
|
-
Transforms.setNodes(editor, { columns }, { at: entry[1] });
|
|
329
|
-
}
|
|
330
|
-
}
|
|
331
|
-
// adjust selection when selection is in hidden cell
|
|
332
|
-
if (Element.isElement(entry[0]) && entry[0].type === ElementKinds.tableCell && entry[0].hidden) {
|
|
333
|
-
if (editor.selection && Range.isCollapsed(editor.selection) && Path.isAncestor(entry[1], editor.selection.anchor.path)) {
|
|
334
|
-
setTimeout(() => {
|
|
335
|
-
const opts = new TableOptions();
|
|
336
|
-
const tablePosition = TablePosition.create(opts, editor, editor.selection.anchor.path);
|
|
337
|
-
const origin = getOriginCell(tablePosition.table, tablePosition.getRowIndex(), tablePosition.getColumnIndex());
|
|
338
|
-
if (origin) {
|
|
339
|
-
const path = AngularEditor.findPath(editor, origin);
|
|
340
|
-
Transforms.select(editor, Editor.end(editor, path));
|
|
341
|
-
}
|
|
342
|
-
}, 0);
|
|
343
|
-
return;
|
|
344
|
-
}
|
|
345
|
-
}
|
|
346
|
-
normalizeNode(entry);
|
|
347
|
-
};
|
|
348
|
-
editor.isBlockCard = (element) => {
|
|
349
|
-
if (element && element.type === ElementKinds.table) {
|
|
350
|
-
return true;
|
|
351
|
-
}
|
|
352
|
-
return isBlockCard(element);
|
|
353
|
-
};
|
|
354
|
-
editor.renderElement = (element) => {
|
|
355
|
-
if (element.type === ElementKinds.table) {
|
|
356
|
-
return TheTableComponent;
|
|
357
|
-
}
|
|
358
|
-
if (element.type === ElementKinds.tableRow) {
|
|
359
|
-
return TheTableRowComponent;
|
|
360
|
-
}
|
|
361
|
-
if (element.type === ElementKinds.tableCell) {
|
|
362
|
-
return TheTdComponent;
|
|
363
|
-
}
|
|
364
|
-
return renderElement(element);
|
|
365
|
-
};
|
|
366
|
-
editor.deleteCutData = () => {
|
|
367
|
-
const opts = new TableOptions();
|
|
368
|
-
if (!isSelectionInTable(opts, editor)) {
|
|
369
|
-
deleteCutData();
|
|
370
|
-
return;
|
|
371
|
-
}
|
|
372
|
-
const { selection } = editor;
|
|
373
|
-
const element = TablePosition.create(opts, editor, selection.anchor.path);
|
|
374
|
-
const tableComponent = ELEMENT_TO_COMPONENT.get(element.table);
|
|
375
|
-
const cells = tableComponent.tableStore.selectedCells;
|
|
376
|
-
if (cells.length > 0) {
|
|
377
|
-
Editor.withoutNormalizing(editor, () => {
|
|
378
|
-
if (tableComponent.tableStore.isSelectedTable) {
|
|
379
|
-
TableEditor.removeTable(editor);
|
|
380
|
-
}
|
|
381
|
-
else {
|
|
382
|
-
tableComponent.tableStore.clearSelectedCellsContent();
|
|
383
|
-
}
|
|
384
|
-
tableComponent.tableService.closeToolbar();
|
|
385
|
-
});
|
|
386
|
-
return;
|
|
387
|
-
}
|
|
388
|
-
deleteCutData();
|
|
389
|
-
};
|
|
390
|
-
editor.isContainer = (element) => {
|
|
391
|
-
return element.type === ElementKinds.tableCell ? true : isContainer(element);
|
|
392
|
-
};
|
|
393
|
-
editor.onChange = () => {
|
|
394
|
-
onChange();
|
|
395
|
-
// adujst selection when selection is in hidden cell
|
|
396
|
-
// just hook set_selection
|
|
397
|
-
const isCollapsed = editor.selection && Range.isCollapsed(editor.selection);
|
|
398
|
-
const isSelectionOperation = editor.operations.every(op => Operation.isSelectionOperation(op));
|
|
399
|
-
if (isCollapsed && isSelectionOperation) {
|
|
400
|
-
const opts = new TableOptions();
|
|
401
|
-
const tablePosition = TablePosition.create(opts, editor, editor.selection.anchor.path);
|
|
402
|
-
if (tablePosition.isInTable() && tablePosition.cell.hidden) {
|
|
403
|
-
TableEditor.selectOriginCell(editor, tablePosition.table, tablePosition.getRowIndex(), tablePosition.getColumnIndex(), false);
|
|
404
|
-
}
|
|
405
|
-
}
|
|
406
|
-
};
|
|
407
|
-
return editor;
|
|
408
|
-
};
|
|
409
|
-
export const createTablePlugin = createPluginFactory({
|
|
410
|
-
key: PluginKeys.table,
|
|
411
|
-
withOverrides: withTable,
|
|
412
|
-
nestedStructureByKey: {
|
|
413
|
-
[ElementKinds.table]: ElementKinds.tableRow,
|
|
414
|
-
[ElementKinds.tableRow]: ElementKinds.tableCell
|
|
415
|
-
},
|
|
416
|
-
toolbarItems: [
|
|
417
|
-
{
|
|
418
|
-
key: ElementKinds.table,
|
|
419
|
-
icon: 'table-border-all',
|
|
420
|
-
name: '表格',
|
|
421
|
-
iconComponent: TheTableToolbarItemComponent,
|
|
422
|
-
execute: editor => TableEditor.insertTable(editor),
|
|
423
|
-
active: editor => TableEditor.isActive(editor)
|
|
424
|
-
}
|
|
425
|
-
]
|
|
426
|
-
});
|
|
1
|
+
import { Transforms, Node, Range, Editor, Element, Path, Operation } from 'slate';
|
|
2
|
+
import { AngularEditor, ELEMENT_TO_COMPONENT, hotkeys } from 'slate-angular';
|
|
3
|
+
import { TableOptions } from './table.types';
|
|
4
|
+
import { isRangeInTable, isSelectionInTable, TablePosition } from './utils';
|
|
5
|
+
import { PluginKeys, TheEditor } from '../../interfaces';
|
|
6
|
+
import { ElementKinds } from '../../constants/node-types';
|
|
7
|
+
import { TheTableComponent } from './components/table.component';
|
|
8
|
+
import { TableEditor } from './table.editor';
|
|
9
|
+
import { clearTableNode } from './transforms/clear-table-node';
|
|
10
|
+
import { isVirtualKey } from './utils/is-virtual-key';
|
|
11
|
+
import { insertColumnAtRow } from './transforms/insert-column';
|
|
12
|
+
import { calculateAnchorPositionInCell } from './utils/calc-anchor-position';
|
|
13
|
+
import { CLIPBOARD_FORMAT_KEY } from '../../constants/default';
|
|
14
|
+
import { getOriginCell } from './utils/calc-span';
|
|
15
|
+
import { resetTableCell } from './utils/split-cell';
|
|
16
|
+
import { removeColumns } from './utils/remove-columns';
|
|
17
|
+
import { addColumns } from './utils/add-columns';
|
|
18
|
+
import { TheTableRowComponent } from './components/row/row.component';
|
|
19
|
+
import { TheTdComponent } from './components/td/td.component';
|
|
20
|
+
import { extractFragment } from '../../utils/fragment';
|
|
21
|
+
import * as TheQueries from '../../queries';
|
|
22
|
+
import { normalizeTable } from './utils/normalize-table';
|
|
23
|
+
import { cloneDeep } from '../../utils/lodash';
|
|
24
|
+
import { createPluginFactory } from '../../core';
|
|
25
|
+
import { TheTableToolbarItemComponent } from './toolbar-item.component';
|
|
26
|
+
export const withTable = (editor) => {
|
|
27
|
+
const { deleteBackward, deleteForward, onKeydown, setFragmentData, insertData, normalizeNode, isBlockCard, renderElement, deleteCutData, isContainer, onChange } = editor;
|
|
28
|
+
editor.deleteBackward = unit => {
|
|
29
|
+
const opts = new TableOptions();
|
|
30
|
+
if (!isSelectionInTable(opts, editor)) {
|
|
31
|
+
deleteBackward(unit);
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
const { selection } = editor;
|
|
35
|
+
const [, startBlockPath] = Editor.above(editor, {
|
|
36
|
+
match: n => Editor.isBlock(editor, n)
|
|
37
|
+
});
|
|
38
|
+
const startPosition = TablePosition.create(opts, editor, selection.anchor.path);
|
|
39
|
+
if (startBlockPath.length <= startPosition.cellEntry[1].length + 1 &&
|
|
40
|
+
startBlockPath.pop() === 0 &&
|
|
41
|
+
selection.anchor.offset === 0 &&
|
|
42
|
+
TheQueries.isStart(editor, selection.anchor, startBlockPath) &&
|
|
43
|
+
!Editor.isVoid(editor, TheQueries.anchorBlock(editor))) {
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
deleteBackward(unit);
|
|
47
|
+
};
|
|
48
|
+
editor.deleteForward = unit => {
|
|
49
|
+
const opts = new TableOptions();
|
|
50
|
+
const afterPoint = Editor.after(editor, editor.selection);
|
|
51
|
+
if (afterPoint && isRangeInTable(opts, editor, { anchor: afterPoint, focus: afterPoint })) {
|
|
52
|
+
const beforePosition = TablePosition.create(opts, editor, editor.selection.anchor.path);
|
|
53
|
+
const afterPosition = TablePosition.create(opts, editor, afterPoint.path);
|
|
54
|
+
if (beforePosition.cell && beforePosition.cell !== afterPosition.cell) {
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
deleteForward(unit);
|
|
59
|
+
};
|
|
60
|
+
editor.onKeydown = (event) => {
|
|
61
|
+
const opts = new TableOptions();
|
|
62
|
+
const isMoveUp = hotkeys.isMoveUp(event);
|
|
63
|
+
const isMoveDown = hotkeys.isMoveDown(event);
|
|
64
|
+
const isMoveBackward = hotkeys.isMoveBackward(event);
|
|
65
|
+
const isMoveForward = hotkeys.isMoveForward(event);
|
|
66
|
+
const { selection } = editor;
|
|
67
|
+
if (!selection || !selection.anchor || !selection.focus) {
|
|
68
|
+
onKeydown(event);
|
|
69
|
+
return;
|
|
70
|
+
}
|
|
71
|
+
const startPosition = TablePosition.create(opts, editor, selection.anchor.path);
|
|
72
|
+
const endPosition = TablePosition.create(opts, editor, selection.focus.path);
|
|
73
|
+
const isCollapsed = Range.isCollapsed(selection);
|
|
74
|
+
if (startPosition && endPosition && endPosition.isInTable()) {
|
|
75
|
+
// for keyboard up and down key in the table
|
|
76
|
+
if (isMoveUp || isMoveDown) {
|
|
77
|
+
const cellPath = endPosition.cellEntry[1];
|
|
78
|
+
const startPath = Editor.start(editor, cellPath).path;
|
|
79
|
+
const endPath = Editor.end(editor, cellPath).path;
|
|
80
|
+
const { isFirstLine, isLastLine } = calculateAnchorPositionInCell(editor);
|
|
81
|
+
startPath.pop();
|
|
82
|
+
endPath.pop();
|
|
83
|
+
if ((TheQueries.anchorBlockEntry(editor)[1].toString() !== startPath.toString() || !isFirstLine) && isMoveUp) {
|
|
84
|
+
onKeydown(event);
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
if ((TheQueries.anchorBlockEntry(editor)[1].toString() !== endPath.toString() || !isLastLine) && isMoveDown) {
|
|
88
|
+
onKeydown(event);
|
|
89
|
+
return;
|
|
90
|
+
}
|
|
91
|
+
event.preventDefault();
|
|
92
|
+
let at;
|
|
93
|
+
if (isMoveUp) {
|
|
94
|
+
const aboveRow = startPosition.table.children[startPosition.getRowIndex() - 1];
|
|
95
|
+
const aboveCell = aboveRow && aboveRow.children[startPosition.getColumnIndex()];
|
|
96
|
+
if (aboveCell) {
|
|
97
|
+
if (aboveCell.hidden) {
|
|
98
|
+
TableEditor.selectOriginCell(editor, startPosition.table, startPosition.getRowIndex() - 1, startPosition.getColumnIndex(), false);
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
else {
|
|
102
|
+
at = Editor.end(editor, TheEditor.findPath(editor, aboveCell));
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
const previousNodeEntry = Editor.previous(editor, { at: startPosition.tableEntry[1] });
|
|
107
|
+
const beforePoint = Editor.before(editor, startPosition.tableEntry[1]);
|
|
108
|
+
Editor.next(editor, { at: startPosition.tableEntry[1] });
|
|
109
|
+
if (previousNodeEntry) {
|
|
110
|
+
at = Editor.end(editor, previousNodeEntry[1]);
|
|
111
|
+
}
|
|
112
|
+
if (!previousNodeEntry && beforePoint) {
|
|
113
|
+
at = Editor.end(editor, beforePoint.path);
|
|
114
|
+
}
|
|
115
|
+
if (!previousNodeEntry && !beforePoint) {
|
|
116
|
+
AngularEditor.moveBlockCard(editor, startPosition.tableEntry[0], { direction: 'left' });
|
|
117
|
+
return;
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
Transforms.select(editor, at);
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
let belowRowIndex = startPosition.getRowIndex() + 1;
|
|
124
|
+
if (startPosition.cell.rowspan > 1) {
|
|
125
|
+
belowRowIndex = startPosition.getRowIndex() + startPosition.cell.rowspan;
|
|
126
|
+
}
|
|
127
|
+
const belowRow = startPosition.table.children[belowRowIndex];
|
|
128
|
+
const belowCell = belowRow && belowRow.children[startPosition.getColumnIndex()];
|
|
129
|
+
if (belowCell) {
|
|
130
|
+
if (belowCell.hidden) {
|
|
131
|
+
TableEditor.selectOriginCell(editor, startPosition.table, startPosition.getRowIndex() + 1, startPosition.getColumnIndex(), true);
|
|
132
|
+
return;
|
|
133
|
+
}
|
|
134
|
+
else {
|
|
135
|
+
at = Editor.start(editor, TheEditor.findPath(editor, belowCell));
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
else {
|
|
139
|
+
const nextNodeEntry = Editor.next(editor, { at: startPosition.tableEntry[1] });
|
|
140
|
+
const movePath = nextNodeEntry ? nextNodeEntry[1] : Editor.after(editor, startPosition.tableEntry[1]).path;
|
|
141
|
+
at = Editor.start(editor, movePath);
|
|
142
|
+
}
|
|
143
|
+
Transforms.select(editor, at);
|
|
144
|
+
}
|
|
145
|
+
return;
|
|
146
|
+
}
|
|
147
|
+
if (isMoveBackward) {
|
|
148
|
+
const beforePoint = Editor.before(editor, editor.selection);
|
|
149
|
+
const beforePosition = beforePoint && TablePosition.create(opts, editor, beforePoint.path);
|
|
150
|
+
if (beforePosition && beforePosition.cell && beforePosition.cell.hidden) {
|
|
151
|
+
event.preventDefault();
|
|
152
|
+
const at = Editor.end(editor, TheEditor.findPath(editor, beforePosition.findPrevious()));
|
|
153
|
+
Transforms.select(editor, at);
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
if (isMoveForward) {
|
|
157
|
+
const afterPoint = Editor.after(editor, editor.selection);
|
|
158
|
+
const afterPosition = afterPoint && TablePosition.create(opts, editor, afterPoint.path);
|
|
159
|
+
if (afterPosition.cell && afterPosition.cell.hidden) {
|
|
160
|
+
event.preventDefault();
|
|
161
|
+
const nextCell = afterPosition.findNext();
|
|
162
|
+
if (nextCell) {
|
|
163
|
+
const at = Editor.start(editor, TheEditor.findPath(editor, afterPosition.findNext()));
|
|
164
|
+
Transforms.select(editor, at);
|
|
165
|
+
event.preventDefault();
|
|
166
|
+
}
|
|
167
|
+
else {
|
|
168
|
+
AngularEditor.moveBlockCard(editor, startPosition.tableEntry[0], { direction: 'right' });
|
|
169
|
+
event.preventDefault();
|
|
170
|
+
}
|
|
171
|
+
return;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
// Prevent deleting cells in the table
|
|
175
|
+
if (!isCollapsed && !startPosition.isInTable() && !isVirtualKey(event)) {
|
|
176
|
+
event.preventDefault();
|
|
177
|
+
let tableOutPath;
|
|
178
|
+
Editor.withoutNormalizing(editor, () => {
|
|
179
|
+
if (Range.isForward(selection)) {
|
|
180
|
+
tableOutPath = Editor.end(editor, [selection.focus.path[0] - 1]);
|
|
181
|
+
clearTableNode(opts, editor, true);
|
|
182
|
+
}
|
|
183
|
+
else {
|
|
184
|
+
tableOutPath = Editor.start(editor, [selection.focus.path[0] + 1]);
|
|
185
|
+
clearTableNode(opts, editor);
|
|
186
|
+
}
|
|
187
|
+
const tableOutRange = Editor.range(editor, selection.anchor, tableOutPath);
|
|
188
|
+
Transforms.delete(editor, { at: tableOutRange });
|
|
189
|
+
});
|
|
190
|
+
// new range
|
|
191
|
+
const cellRange = Editor.range(editor, editor.selection.focus.path.slice(0, 3));
|
|
192
|
+
const focusRange = Range.intersection(editor.selection, cellRange);
|
|
193
|
+
Transforms.select(editor, focusRange);
|
|
194
|
+
Editor.deleteFragment(editor);
|
|
195
|
+
return;
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
onKeydown(event);
|
|
199
|
+
return;
|
|
200
|
+
};
|
|
201
|
+
editor.setFragmentData = unit => {
|
|
202
|
+
const opts = new TableOptions();
|
|
203
|
+
if (!isSelectionInTable(opts, editor)) {
|
|
204
|
+
setFragmentData(unit);
|
|
205
|
+
return;
|
|
206
|
+
}
|
|
207
|
+
const { selection } = editor;
|
|
208
|
+
const tablePosition = TablePosition.create(opts, editor, selection.anchor.path);
|
|
209
|
+
const tableComponent = ELEMENT_TO_COMPONENT.get(tablePosition.table);
|
|
210
|
+
const cells = tableComponent.tableStore.selectedCells;
|
|
211
|
+
let tableFragment = null;
|
|
212
|
+
if (tableComponent.tableStore.selectedRowsIndex.length > 0) {
|
|
213
|
+
const rows = tablePosition.table.children.slice(tableComponent.tableStore.selectedRowsIndex[0], tableComponent.tableStore.selectedRowsIndex[tableComponent.tableStore.selectedRowsIndex.length - 1] + 1);
|
|
214
|
+
tableFragment = {
|
|
215
|
+
...tablePosition.table,
|
|
216
|
+
children: rows
|
|
217
|
+
};
|
|
218
|
+
}
|
|
219
|
+
else if (cells.length > 0) {
|
|
220
|
+
const tempRows = {};
|
|
221
|
+
for (const cell of cells) {
|
|
222
|
+
const { row, col } = cell;
|
|
223
|
+
const cellPath = [...tablePosition.tableEntry[1], row, col];
|
|
224
|
+
const cellNode = Node.get(editor, cellPath);
|
|
225
|
+
if (!tempRows[row]) {
|
|
226
|
+
tempRows[row] = [];
|
|
227
|
+
}
|
|
228
|
+
tempRows[row].push(cellNode);
|
|
229
|
+
}
|
|
230
|
+
const rows = Object.values(tempRows).map((item) => {
|
|
231
|
+
return {
|
|
232
|
+
type: ElementKinds.tableRow,
|
|
233
|
+
children: item
|
|
234
|
+
};
|
|
235
|
+
});
|
|
236
|
+
tableFragment = {
|
|
237
|
+
type: ElementKinds.table,
|
|
238
|
+
children: rows
|
|
239
|
+
};
|
|
240
|
+
}
|
|
241
|
+
if (tableFragment) {
|
|
242
|
+
tableFragment = normalizeTable(cloneDeep(tableFragment));
|
|
243
|
+
const plainText = Node.string(tableFragment);
|
|
244
|
+
tableFragment = [tableFragment];
|
|
245
|
+
const stringObj = JSON.stringify(tableFragment);
|
|
246
|
+
const encoded = window.btoa(encodeURIComponent(stringObj));
|
|
247
|
+
unit.setData(`application/${CLIPBOARD_FORMAT_KEY}`, encoded);
|
|
248
|
+
unit.setData('text/plain', plainText);
|
|
249
|
+
return;
|
|
250
|
+
}
|
|
251
|
+
setFragmentData(unit);
|
|
252
|
+
};
|
|
253
|
+
editor.insertData = data => {
|
|
254
|
+
const fragment = extractFragment(data);
|
|
255
|
+
if (fragment) {
|
|
256
|
+
const opts = new TableOptions();
|
|
257
|
+
const { selection } = editor;
|
|
258
|
+
if (isSelectionInTable(opts, editor) &&
|
|
259
|
+
fragment.length === 1 &&
|
|
260
|
+
Element.isElement(fragment[0]) &&
|
|
261
|
+
fragment[0].type === ElementKinds.table) {
|
|
262
|
+
const tablePosition = TablePosition.create(opts, editor, selection.anchor.path);
|
|
263
|
+
const clipboardTable = fragment[0].children;
|
|
264
|
+
const clipboardRow = clipboardTable[0].children;
|
|
265
|
+
const selectRowIndex = tablePosition.getRowIndex();
|
|
266
|
+
const selectColIndex = tablePosition.getColumnIndex();
|
|
267
|
+
const lastRowIndex = selectRowIndex + clipboardTable.length - 1;
|
|
268
|
+
const lastColIndex = selectColIndex + clipboardRow.length - 1;
|
|
269
|
+
for (let i = selectRowIndex; i <= lastRowIndex; i++) {
|
|
270
|
+
for (let j = selectColIndex; j <= lastColIndex; j++) {
|
|
271
|
+
const row = tablePosition.table.children[i];
|
|
272
|
+
if (row && row.children[j]) {
|
|
273
|
+
const originCell = getOriginCell(tablePosition.table, i, j);
|
|
274
|
+
if (originCell && (originCell.colspan || originCell.rowspan)) {
|
|
275
|
+
const path = TheEditor.findPath(editor, originCell).slice(-2);
|
|
276
|
+
resetTableCell(editor, tablePosition.table, originCell, path[0], path[1]);
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
Editor.withoutNormalizing(editor, () => {
|
|
282
|
+
if (lastColIndex > tablePosition.getWidth() - 1) {
|
|
283
|
+
const addColCount = lastColIndex - (tablePosition.getWidth() - 1);
|
|
284
|
+
TableEditor.insertColumn(editor, addColCount, tablePosition.getWidth());
|
|
285
|
+
}
|
|
286
|
+
if (lastRowIndex > tablePosition.getHeight() - 1) {
|
|
287
|
+
const addRowCount = lastRowIndex - (tablePosition.getHeight() - 1);
|
|
288
|
+
TableEditor.insertRow(editor, addRowCount, tablePosition.getHeight());
|
|
289
|
+
}
|
|
290
|
+
clipboardTable.forEach((row, i) => {
|
|
291
|
+
row.children.forEach((col, j) => {
|
|
292
|
+
const at = [...tablePosition.tableEntry[1], selectRowIndex + i, selectColIndex + j];
|
|
293
|
+
Transforms.removeNodes(editor, { at });
|
|
294
|
+
Transforms.insertNodes(editor, col, { at });
|
|
295
|
+
});
|
|
296
|
+
});
|
|
297
|
+
});
|
|
298
|
+
const target = Editor.start(editor, [...tablePosition.tableEntry[1], selectRowIndex, selectColIndex]);
|
|
299
|
+
Transforms.select(editor, target);
|
|
300
|
+
return;
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
insertData(data);
|
|
304
|
+
};
|
|
305
|
+
editor.normalizeNode = (entry) => {
|
|
306
|
+
if (Element.isElement(entry[0]) && entry[0].type === ElementKinds.table) {
|
|
307
|
+
const table = entry[0];
|
|
308
|
+
const maxWidth = Math.max(...table.children.map(row => row.children.length));
|
|
309
|
+
const invalidRows = table.children.filter(row => row.children.length < maxWidth);
|
|
310
|
+
if (invalidRows.length > 0) {
|
|
311
|
+
const opts = new TableOptions();
|
|
312
|
+
Editor.withoutNormalizing(editor, () => {
|
|
313
|
+
table.children.map((row, rowIndex) => {
|
|
314
|
+
row.children.map((cell, cellIndex) => {
|
|
315
|
+
if (cell.hidden || cell.colspan || cell.rowspan) {
|
|
316
|
+
Transforms.setNodes(editor, { hidden: null, colspan: null, rowspan: null }, { at: [...entry[1], rowIndex, cellIndex] });
|
|
317
|
+
}
|
|
318
|
+
});
|
|
319
|
+
});
|
|
320
|
+
invalidRows.forEach(row => {
|
|
321
|
+
const count = maxWidth - row.children.length;
|
|
322
|
+
insertColumnAtRow(opts, editor, count, entry, table.children.indexOf(row), row.children.length);
|
|
323
|
+
});
|
|
324
|
+
});
|
|
325
|
+
}
|
|
326
|
+
if (table.columns && table.columns.length !== maxWidth) {
|
|
327
|
+
const columns = table.columns.length > maxWidth ? removeColumns(table, maxWidth) : addColumns(table, maxWidth);
|
|
328
|
+
Transforms.setNodes(editor, { columns }, { at: entry[1] });
|
|
329
|
+
}
|
|
330
|
+
}
|
|
331
|
+
// adjust selection when selection is in hidden cell
|
|
332
|
+
if (Element.isElement(entry[0]) && entry[0].type === ElementKinds.tableCell && entry[0].hidden) {
|
|
333
|
+
if (editor.selection && Range.isCollapsed(editor.selection) && Path.isAncestor(entry[1], editor.selection.anchor.path)) {
|
|
334
|
+
setTimeout(() => {
|
|
335
|
+
const opts = new TableOptions();
|
|
336
|
+
const tablePosition = TablePosition.create(opts, editor, editor.selection.anchor.path);
|
|
337
|
+
const origin = getOriginCell(tablePosition.table, tablePosition.getRowIndex(), tablePosition.getColumnIndex());
|
|
338
|
+
if (origin) {
|
|
339
|
+
const path = AngularEditor.findPath(editor, origin);
|
|
340
|
+
Transforms.select(editor, Editor.end(editor, path));
|
|
341
|
+
}
|
|
342
|
+
}, 0);
|
|
343
|
+
return;
|
|
344
|
+
}
|
|
345
|
+
}
|
|
346
|
+
normalizeNode(entry);
|
|
347
|
+
};
|
|
348
|
+
editor.isBlockCard = (element) => {
|
|
349
|
+
if (element && element.type === ElementKinds.table) {
|
|
350
|
+
return true;
|
|
351
|
+
}
|
|
352
|
+
return isBlockCard(element);
|
|
353
|
+
};
|
|
354
|
+
editor.renderElement = (element) => {
|
|
355
|
+
if (element.type === ElementKinds.table) {
|
|
356
|
+
return TheTableComponent;
|
|
357
|
+
}
|
|
358
|
+
if (element.type === ElementKinds.tableRow) {
|
|
359
|
+
return TheTableRowComponent;
|
|
360
|
+
}
|
|
361
|
+
if (element.type === ElementKinds.tableCell) {
|
|
362
|
+
return TheTdComponent;
|
|
363
|
+
}
|
|
364
|
+
return renderElement(element);
|
|
365
|
+
};
|
|
366
|
+
editor.deleteCutData = () => {
|
|
367
|
+
const opts = new TableOptions();
|
|
368
|
+
if (!isSelectionInTable(opts, editor)) {
|
|
369
|
+
deleteCutData();
|
|
370
|
+
return;
|
|
371
|
+
}
|
|
372
|
+
const { selection } = editor;
|
|
373
|
+
const element = TablePosition.create(opts, editor, selection.anchor.path);
|
|
374
|
+
const tableComponent = ELEMENT_TO_COMPONENT.get(element.table);
|
|
375
|
+
const cells = tableComponent.tableStore.selectedCells;
|
|
376
|
+
if (cells.length > 0) {
|
|
377
|
+
Editor.withoutNormalizing(editor, () => {
|
|
378
|
+
if (tableComponent.tableStore.isSelectedTable) {
|
|
379
|
+
TableEditor.removeTable(editor);
|
|
380
|
+
}
|
|
381
|
+
else {
|
|
382
|
+
tableComponent.tableStore.clearSelectedCellsContent();
|
|
383
|
+
}
|
|
384
|
+
tableComponent.tableService.closeToolbar();
|
|
385
|
+
});
|
|
386
|
+
return;
|
|
387
|
+
}
|
|
388
|
+
deleteCutData();
|
|
389
|
+
};
|
|
390
|
+
editor.isContainer = (element) => {
|
|
391
|
+
return element.type === ElementKinds.tableCell ? true : isContainer(element);
|
|
392
|
+
};
|
|
393
|
+
editor.onChange = () => {
|
|
394
|
+
onChange();
|
|
395
|
+
// adujst selection when selection is in hidden cell
|
|
396
|
+
// just hook set_selection
|
|
397
|
+
const isCollapsed = editor.selection && Range.isCollapsed(editor.selection);
|
|
398
|
+
const isSelectionOperation = editor.operations.every(op => Operation.isSelectionOperation(op));
|
|
399
|
+
if (isCollapsed && isSelectionOperation) {
|
|
400
|
+
const opts = new TableOptions();
|
|
401
|
+
const tablePosition = TablePosition.create(opts, editor, editor.selection.anchor.path);
|
|
402
|
+
if (tablePosition.isInTable() && tablePosition.cell.hidden) {
|
|
403
|
+
TableEditor.selectOriginCell(editor, tablePosition.table, tablePosition.getRowIndex(), tablePosition.getColumnIndex(), false);
|
|
404
|
+
}
|
|
405
|
+
}
|
|
406
|
+
};
|
|
407
|
+
return editor;
|
|
408
|
+
};
|
|
409
|
+
export const createTablePlugin = createPluginFactory({
|
|
410
|
+
key: PluginKeys.table,
|
|
411
|
+
withOverrides: withTable,
|
|
412
|
+
nestedStructureByKey: {
|
|
413
|
+
[ElementKinds.table]: ElementKinds.tableRow,
|
|
414
|
+
[ElementKinds.tableRow]: ElementKinds.tableCell
|
|
415
|
+
},
|
|
416
|
+
toolbarItems: [
|
|
417
|
+
{
|
|
418
|
+
key: ElementKinds.table,
|
|
419
|
+
icon: 'table-border-all',
|
|
420
|
+
name: '表格',
|
|
421
|
+
iconComponent: TheTableToolbarItemComponent,
|
|
422
|
+
execute: editor => TableEditor.insertTable(editor),
|
|
423
|
+
active: editor => TableEditor.isActive(editor)
|
|
424
|
+
}
|
|
425
|
+
]
|
|
426
|
+
});
|
|
427
427
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.plugin.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/table/table.plugin.ts"],"names":[],"mappings":"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","sourcesContent":["import { Transforms, Point, Node, Range, Editor, NodeEntry, Element, Path, Operation } from 'slate';\nimport { AngularEditor, ELEMENT_TO_COMPONENT, hotkeys } from 'slate-angular';\nimport { TableOptions } from './table.types';\nimport { isRangeInTable, isSelectionInTable, TablePosition } from './utils';\nimport { PluginKeys, TheEditor } from '../../interfaces';\nimport { ElementKinds } from '../../constants/node-types';\nimport { TableCellElement, TableElement, TableRowElement } from '../../custom-types';\nimport { TheTableComponent } from './components/table.component';\nimport { TableEditor } from './table.editor';\nimport { clearTableNode } from './transforms/clear-table-node';\nimport { isVirtualKey } from './utils/is-virtual-key';\nimport { insertColumnAtRow } from './transforms/insert-column';\nimport { calculateAnchorPositionInCell } from './utils/calc-anchor-position';\nimport { CLIPBOARD_FORMAT_KEY } from '../../constants/default';\nimport { getOriginCell } from './utils/calc-span';\nimport { resetTableCell } from './utils/split-cell';\nimport { removeColumns } from './utils/remove-columns';\nimport { addColumns } from './utils/add-columns';\nimport { TheTableRowComponent } from './components/row/row.component';\nimport { TheTdComponent } from './components/td/td.component';\nimport { extractFragment } from '../../utils/fragment';\nimport * as TheQueries from '../../queries';\nimport { normalizeTable } from './utils/normalize-table';\nimport { cloneDeep } from '../../utils/lodash';\nimport { createPluginFactory } from '../../core';\nimport { TheTableToolbarItemComponent } from './toolbar-item.component';\n\nexport const withTable = <T extends Editor>(editor: T): T => {\n    const {\n        deleteBackward,\n        deleteForward,\n        onKeydown,\n        setFragmentData,\n        insertData,\n        normalizeNode,\n        isBlockCard,\n        renderElement,\n        deleteCutData,\n        isContainer,\n        onChange\n    } = editor;\n\n    editor.deleteBackward = unit => {\n        const opts = new TableOptions();\n        if (!isSelectionInTable(opts, editor)) {\n            deleteBackward(unit);\n            return;\n        }\n        const { selection } = editor;\n\n        const [, startBlockPath] = Editor.above<Element>(editor, {\n            match: n => Editor.isBlock(editor, n)\n        });\n        const startPosition = TablePosition.create(opts, editor, selection.anchor.path);\n        if (\n            startBlockPath.length <= startPosition.cellEntry[1].length + 1 &&\n            startBlockPath.pop() === 0 &&\n            selection.anchor.offset === 0 &&\n            TheQueries.isStart(editor, selection.anchor, startBlockPath) &&\n            !Editor.isVoid(editor, TheQueries.anchorBlock(editor))\n        ) {\n            return;\n        }\n        deleteBackward(unit);\n    };\n\n    editor.deleteForward = unit => {\n        const opts = new TableOptions();\n        const afterPoint = Editor.after(editor, editor.selection);\n        if (afterPoint && isRangeInTable(opts, editor, { anchor: afterPoint, focus: afterPoint })) {\n            const beforePosition = TablePosition.create(opts, editor, editor.selection.anchor.path);\n            const afterPosition = TablePosition.create(opts, editor, afterPoint.path);\n            if (beforePosition.cell && beforePosition.cell !== afterPosition.cell) {\n                return;\n            }\n        }\n        deleteForward(unit);\n    };\n\n    editor.onKeydown = (event: KeyboardEvent) => {\n        const opts = new TableOptions();\n        const isMoveUp = hotkeys.isMoveUp(event);\n        const isMoveDown = hotkeys.isMoveDown(event);\n        const isMoveBackward = hotkeys.isMoveBackward(event);\n        const isMoveForward = hotkeys.isMoveForward(event);\n        const { selection } = editor;\n        if (!selection || !selection.anchor || !selection.focus) {\n            onKeydown(event);\n            return;\n        }\n        const startPosition = TablePosition.create(opts, editor, selection.anchor.path);\n        const endPosition = TablePosition.create(opts, editor, selection.focus.path);\n        const isCollapsed = Range.isCollapsed(selection);\n        if (startPosition && endPosition && endPosition.isInTable()) {\n            // for keyboard up and down key in the table\n            if (isMoveUp || isMoveDown) {\n                const cellPath = endPosition.cellEntry[1];\n                const startPath = Editor.start(editor, cellPath).path;\n                const endPath = Editor.end(editor, cellPath).path;\n                const { isFirstLine, isLastLine } = calculateAnchorPositionInCell(editor);\n                startPath.pop();\n                endPath.pop();\n\n                if ((TheQueries.anchorBlockEntry(editor)[1].toString() !== startPath.toString() || !isFirstLine) && isMoveUp) {\n                    onKeydown(event);\n                    return;\n                }\n\n                if ((TheQueries.anchorBlockEntry(editor)[1].toString() !== endPath.toString() || !isLastLine) && isMoveDown) {\n                    onKeydown(event);\n                    return;\n                }\n\n                event.preventDefault();\n                let at: Point;\n                if (isMoveUp) {\n                    const aboveRow = startPosition.table.children[startPosition.getRowIndex() - 1];\n                    const aboveCell = aboveRow && aboveRow.children[startPosition.getColumnIndex()];\n                    if (aboveCell) {\n                        if (aboveCell.hidden) {\n                            TableEditor.selectOriginCell(\n                                editor,\n                                startPosition.table,\n                                startPosition.getRowIndex() - 1,\n                                startPosition.getColumnIndex(),\n                                false\n                            );\n                            return;\n                        } else {\n                            at = Editor.end(editor, TheEditor.findPath(editor, aboveCell));\n                        }\n                    } else {\n                        const previousNodeEntry = Editor.previous(editor, { at: startPosition.tableEntry[1] });\n                        const beforePoint = Editor.before(editor, startPosition.tableEntry[1]);\n                        Editor.next(editor, { at: startPosition.tableEntry[1] });\n\n                        if (previousNodeEntry) {\n                            at = Editor.end(editor, previousNodeEntry[1]);\n                        }\n\n                        if (!previousNodeEntry && beforePoint) {\n                            at = Editor.end(editor, beforePoint.path);\n                        }\n\n                        if (!previousNodeEntry && !beforePoint) {\n                            AngularEditor.moveBlockCard(editor, startPosition.tableEntry[0], { direction: 'left' });\n                            return;\n                        }\n                    }\n                    Transforms.select(editor, at);\n                } else {\n                    let belowRowIndex = startPosition.getRowIndex() + 1;\n                    if (startPosition.cell.rowspan > 1) {\n                        belowRowIndex = startPosition.getRowIndex() + startPosition.cell.rowspan;\n                    }\n                    const belowRow = startPosition.table.children[belowRowIndex];\n                    const belowCell = belowRow && belowRow.children[startPosition.getColumnIndex()];\n                    if (belowCell) {\n                        if (belowCell.hidden) {\n                            TableEditor.selectOriginCell(\n                                editor,\n                                startPosition.table,\n                                startPosition.getRowIndex() + 1,\n                                startPosition.getColumnIndex(),\n                                true\n                            );\n                            return;\n                        } else {\n                            at = Editor.start(editor, TheEditor.findPath(editor, belowCell));\n                        }\n                    } else {\n                        const nextNodeEntry = Editor.next(editor, { at: startPosition.tableEntry[1] });\n                        const movePath = nextNodeEntry ? nextNodeEntry[1] : Editor.after(editor, startPosition.tableEntry[1]).path;\n                        at = Editor.start(editor, movePath);\n                    }\n                    Transforms.select(editor, at);\n                }\n                return;\n            }\n\n            if (isMoveBackward) {\n                const beforePoint = Editor.before(editor, editor.selection);\n                const beforePosition = beforePoint && TablePosition.create(opts, editor, beforePoint.path);\n                if (beforePosition && beforePosition.cell && beforePosition.cell.hidden) {\n                    event.preventDefault();\n                    const at = Editor.end(editor, TheEditor.findPath(editor, beforePosition.findPrevious()));\n                    Transforms.select(editor, at);\n                }\n            }\n\n            if (isMoveForward) {\n                const afterPoint = Editor.after(editor, editor.selection);\n                const afterPosition = afterPoint && TablePosition.create(opts, editor, afterPoint.path);\n                if (afterPosition.cell && afterPosition.cell.hidden) {\n                    event.preventDefault();\n                    const nextCell = afterPosition.findNext();\n                    if (nextCell) {\n                        const at = Editor.start(editor, TheEditor.findPath(editor, afterPosition.findNext()));\n                        Transforms.select(editor, at);\n                        event.preventDefault();\n                    } else {\n                        AngularEditor.moveBlockCard(editor, startPosition.tableEntry[0], { direction: 'right' });\n                        event.preventDefault();\n                    }\n                    return;\n                }\n            }\n\n            // Prevent deleting cells in the table\n            if (!isCollapsed && !startPosition.isInTable() && !isVirtualKey(event)) {\n                event.preventDefault();\n                let tableOutPath: Point;\n                Editor.withoutNormalizing(editor, () => {\n                    if (Range.isForward(selection)) {\n                        tableOutPath = Editor.end(editor, [selection.focus.path[0] - 1]);\n                        clearTableNode(opts, editor, true);\n                    } else {\n                        tableOutPath = Editor.start(editor, [selection.focus.path[0] + 1]);\n                        clearTableNode(opts, editor);\n                    }\n                    const tableOutRange = Editor.range(editor, selection.anchor, tableOutPath);\n                    Transforms.delete(editor, { at: tableOutRange });\n                });\n                // new range\n                const cellRange = Editor.range(editor, editor.selection.focus.path.slice(0, 3));\n                const focusRange = Range.intersection(editor.selection, cellRange);\n                Transforms.select(editor, focusRange);\n                Editor.deleteFragment(editor);\n                return;\n            }\n        }\n        onKeydown(event);\n        return;\n    };\n\n    editor.setFragmentData = unit => {\n        const opts = new TableOptions();\n        if (!isSelectionInTable(opts, editor)) {\n            setFragmentData(unit);\n            return;\n        }\n        const { selection } = editor;\n        const tablePosition = TablePosition.create(opts, editor, selection.anchor.path);\n        const tableComponent = ELEMENT_TO_COMPONENT.get(tablePosition.table) as TheTableComponent;\n        const cells = tableComponent.tableStore.selectedCells;\n        let tableFragment = null;\n        if (tableComponent.tableStore.selectedRowsIndex.length > 0) {\n            const rows = tablePosition.table.children.slice(\n                tableComponent.tableStore.selectedRowsIndex[0],\n                tableComponent.tableStore.selectedRowsIndex[tableComponent.tableStore.selectedRowsIndex.length - 1] + 1\n            );\n            tableFragment = {\n                ...tablePosition.table,\n                children: rows\n            };\n        } else if (cells.length > 0) {\n            const tempRows = {};\n            for (const cell of cells) {\n                const { row, col } = cell;\n                const cellPath = [...tablePosition.tableEntry[1], row, col];\n                const cellNode = Node.get(editor, cellPath) as TableCellElement;\n                if (!tempRows[row]) {\n                    tempRows[row] = [];\n                }\n                tempRows[row].push(cellNode);\n            }\n            const rows: TableRowElement[] = Object.values(tempRows).map((item: TableCellElement[]) => {\n                return {\n                    type: ElementKinds.tableRow,\n                    children: item\n                };\n            });\n            tableFragment = {\n                type: ElementKinds.table,\n                children: rows\n            };\n        }\n        if (tableFragment) {\n            tableFragment = normalizeTable(cloneDeep(tableFragment));\n            const plainText = Node.string(tableFragment);\n            tableFragment = [tableFragment];\n            const stringObj = JSON.stringify(tableFragment);\n            const encoded = window.btoa(encodeURIComponent(stringObj));\n            unit.setData(`application/${CLIPBOARD_FORMAT_KEY}`, encoded);\n            unit.setData('text/plain', plainText);\n            return;\n        }\n        setFragmentData(unit);\n    };\n\n    editor.insertData = data => {\n        const fragment = extractFragment(data);\n        if (fragment) {\n            const opts = new TableOptions();\n            const { selection } = editor;\n            if (\n                isSelectionInTable(opts, editor) &&\n                fragment.length === 1 &&\n                Element.isElement(fragment[0]) &&\n                fragment[0].type === ElementKinds.table\n            ) {\n                const tablePosition = TablePosition.create(opts, editor, selection.anchor.path);\n                const clipboardTable = fragment[0].children as Node[];\n                const clipboardRow = (clipboardTable[0] as Element).children;\n                const selectRowIndex = tablePosition.getRowIndex();\n                const selectColIndex = tablePosition.getColumnIndex();\n                const lastRowIndex = selectRowIndex + clipboardTable.length - 1;\n                const lastColIndex = selectColIndex + clipboardRow.length - 1;\n\n                for (let i = selectRowIndex; i <= lastRowIndex; i++) {\n                    for (let j = selectColIndex; j <= lastColIndex; j++) {\n                        const row = tablePosition.table.children[i];\n                        if (row && row.children[j]) {\n                            const originCell = getOriginCell(tablePosition.table, i, j);\n                            if (originCell && (originCell.colspan || originCell.rowspan)) {\n                                const path = TheEditor.findPath(editor, originCell).slice(-2);\n                                resetTableCell(editor, tablePosition.table, originCell, path[0], path[1]);\n                            }\n                        }\n                    }\n                }\n\n                Editor.withoutNormalizing(editor, () => {\n                    if (lastColIndex > tablePosition.getWidth() - 1) {\n                        const addColCount = lastColIndex - (tablePosition.getWidth() - 1);\n                        TableEditor.insertColumn(editor, addColCount, tablePosition.getWidth());\n                    }\n                    if (lastRowIndex > tablePosition.getHeight() - 1) {\n                        const addRowCount = lastRowIndex - (tablePosition.getHeight() - 1);\n                        TableEditor.insertRow(editor, addRowCount, tablePosition.getHeight());\n                    }\n                    clipboardTable.forEach((row: TableElement, i: number) => {\n                        row.children.forEach((col: Node, j: number) => {\n                            const at = [...tablePosition.tableEntry[1], selectRowIndex + i, selectColIndex + j];\n                            Transforms.removeNodes(editor, { at });\n                            Transforms.insertNodes(editor, col, { at });\n                        });\n                    });\n                });\n                const target = Editor.start(editor, [...tablePosition.tableEntry[1], selectRowIndex, selectColIndex]);\n                Transforms.select(editor, target);\n                return;\n            }\n        }\n        insertData(data);\n    };\n\n    editor.normalizeNode = (entry: NodeEntry<Node>) => {\n        if (Element.isElement(entry[0]) && entry[0].type === ElementKinds.table) {\n            const table = entry[0] as TableElement;\n            const maxWidth = Math.max(...table.children.map(row => row.children.length));\n            const invalidRows = table.children.filter(row => row.children.length < maxWidth);\n            if (invalidRows.length > 0) {\n                const opts = new TableOptions();\n                Editor.withoutNormalizing(editor, () => {\n                    table.children.map((row, rowIndex) => {\n                        row.children.map((cell, cellIndex) => {\n                            if (cell.hidden || cell.colspan || cell.rowspan) {\n                                Transforms.setNodes(\n                                    editor,\n                                    { hidden: null, colspan: null, rowspan: null },\n                                    { at: [...entry[1], rowIndex, cellIndex] }\n                                );\n                            }\n                        });\n                    });\n                    invalidRows.forEach(row => {\n                        const count = maxWidth - row.children.length;\n                        insertColumnAtRow(\n                            opts,\n                            editor,\n                            count,\n                            entry as NodeEntry<TableElement>,\n                            table.children.indexOf(row),\n                            row.children.length\n                        );\n                    });\n                });\n            }\n            if (table.columns && table.columns.length !== maxWidth) {\n                const columns = table.columns.length > maxWidth ? removeColumns(table, maxWidth) : addColumns(table, maxWidth);\n                Transforms.setNodes(editor, { columns }, { at: entry[1] });\n            }\n        }\n        // adjust selection when selection is in hidden cell\n        if (Element.isElement(entry[0]) && entry[0].type === ElementKinds.tableCell && entry[0].hidden) {\n            if (editor.selection && Range.isCollapsed(editor.selection) && Path.isAncestor(entry[1], editor.selection.anchor.path)) {\n                setTimeout(() => {\n                    const opts = new TableOptions();\n                    const tablePosition = TablePosition.create(opts, editor, editor.selection.anchor.path);\n                    const origin = getOriginCell(tablePosition.table, tablePosition.getRowIndex(), tablePosition.getColumnIndex());\n                    if (origin) {\n                        const path = AngularEditor.findPath(editor, origin);\n                        Transforms.select(editor, Editor.end(editor, path));\n                    }\n                }, 0);\n                return;\n            }\n        }\n        normalizeNode(entry);\n    };\n\n    editor.isBlockCard = (element: Element) => {\n        if (element && element.type === ElementKinds.table) {\n            return true;\n        }\n        return isBlockCard(element);\n    };\n\n    editor.renderElement = (element: Element) => {\n        if (element.type === ElementKinds.table) {\n            return TheTableComponent;\n        }\n        if (element.type === ElementKinds.tableRow) {\n            return TheTableRowComponent;\n        }\n        if (element.type === ElementKinds.tableCell) {\n            return TheTdComponent;\n        }\n        return renderElement(element);\n    };\n\n    editor.deleteCutData = () => {\n        const opts = new TableOptions();\n        if (!isSelectionInTable(opts, editor)) {\n            deleteCutData();\n            return;\n        }\n        const { selection } = editor;\n        const element = TablePosition.create(opts, editor, selection.anchor.path);\n        const tableComponent = ELEMENT_TO_COMPONENT.get(element.table) as TheTableComponent;\n        const cells = tableComponent.tableStore.selectedCells;\n        if (cells.length > 0) {\n            Editor.withoutNormalizing(editor, () => {\n                if (tableComponent.tableStore.isSelectedTable) {\n                    TableEditor.removeTable(editor);\n                } else {\n                    tableComponent.tableStore.clearSelectedCellsContent();\n                }\n                tableComponent.tableService.closeToolbar();\n            });\n            return;\n        }\n        deleteCutData();\n    };\n\n    editor.isContainer = (element: Element) => {\n        return element.type === ElementKinds.tableCell ? true : isContainer(element);\n    };\n\n    editor.onChange = () => {\n        onChange();\n        // adujst selection when selection is in hidden cell\n        // just hook set_selection\n        const isCollapsed = editor.selection && Range.isCollapsed(editor.selection);\n        const isSelectionOperation = editor.operations.every(op => Operation.isSelectionOperation(op));\n        if (isCollapsed && isSelectionOperation) {\n            const opts = new TableOptions();\n            const tablePosition = TablePosition.create(opts, editor, editor.selection.anchor.path);\n            if (tablePosition.isInTable() && tablePosition.cell.hidden) {\n                TableEditor.selectOriginCell(\n                    editor,\n                    tablePosition.table,\n                    tablePosition.getRowIndex(),\n                    tablePosition.getColumnIndex(),\n                    false\n                );\n            }\n        }\n    };\n\n    return editor;\n};\n\nexport const createTablePlugin = createPluginFactory({\n    key: PluginKeys.table,\n    withOverrides: withTable,\n    nestedStructureByKey: {\n        [ElementKinds.table]: ElementKinds.tableRow,\n        [ElementKinds.tableRow]: ElementKinds.tableCell\n    },\n    toolbarItems: [\n        {\n            key: ElementKinds.table,\n            icon: 'table-border-all',\n            name: '表格',\n            iconComponent: TheTableToolbarItemComponent,\n            execute: editor => TableEditor.insertTable(editor),\n            active: editor => TableEditor.isActive(editor)\n        }\n    ]\n});\n"]}
|