@worktile/theia 3.0.8 → 3.0.9
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/bundles/worktile-theia.umd.js +14357 -14343
- package/bundles/worktile-theia.umd.js.map +1 -1
- 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 +65 -65
- package/components/toolbar-dropdown/toolbar-dropdown.component.d.ts +33 -33
- package/components/toolbar-dropdown/toolbar-dropdown.component.scss +0 -1
- 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 +18 -18
- 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 +98 -98
- package/esm2015/components/color-select/color-select.component.js +112 -112
- package/esm2015/components/column-resize/column-resize-notifier.js +31 -31
- package/esm2015/components/column-resize/column-resize.directive.js +98 -98
- package/esm2015/components/column-resize/column-resize.module.js +34 -34
- package/esm2015/components/column-resize/event-dispatcher.js +55 -55
- package/esm2015/components/column-resize/overlay-handle.component.js +139 -139
- package/esm2015/components/column-resize/resize-ref.js +25 -25
- package/esm2015/components/column-resize/resizing.store.js +154 -154
- package/esm2015/components/column-resize/selectors.js +4 -4
- package/esm2015/components/contextmenu/contextmenu.component.js +64 -64
- package/esm2015/components/conversion-hint/conversion-hint.component.js +59 -59
- package/esm2015/components/element/element.component.js +23 -23
- package/esm2015/components/inline-toolbar/inline-toolbar.component.js +126 -126
- package/esm2015/components/nav-split-line/nav-split-line.component.js +36 -36
- package/esm2015/components/table-select/table-select.component.js +53 -53
- package/esm2015/components/template/template.component.js +66 -66
- package/esm2015/components/text/text.component.js +57 -57
- package/esm2015/components/toolbar/toolbar.component.js +250 -250
- package/esm2015/components/toolbar-dropdown/toolbar-dropdown.component.js +132 -132
- package/esm2015/components/toolbar-group/toolbar-group.component.js +116 -116
- package/esm2015/components/toolbar-item/toolbar-item.component.js +64 -64
- package/esm2015/constants/auto-format-rules.js +166 -166
- package/esm2015/constants/code.js +88 -88
- package/esm2015/constants/color-select.js +61 -61
- package/esm2015/constants/default.js +9 -9
- package/esm2015/constants/error.js +7 -7
- package/esm2015/constants/index.js +5 -5
- package/esm2015/constants/node-types.js +132 -132
- package/esm2015/constants/selector.js +3 -3
- package/esm2015/constants/toolbar.js +69 -69
- package/esm2015/core/create-plugin.js +4 -4
- package/esm2015/core/create-toolbar.js +56 -56
- package/esm2015/core/index.js +4 -4
- package/esm2015/core/toolbar-item/base-toolbar-item.js +91 -91
- package/esm2015/core/utils/combine-plugins.js +9 -9
- package/esm2015/core/utils/flatten-deep-plugins.js +18 -18
- package/esm2015/core/utils/get-plugin-options.js +2 -2
- package/esm2015/core/utils/get-plugin.js +1 -1
- package/esm2015/core/utils/get-plugins.js +4 -4
- package/esm2015/core/utils/index.js +10 -10
- package/esm2015/core/utils/merge-array.js +17 -17
- package/esm2015/core/utils/merge-deep-plugins.js +13 -13
- package/esm2015/core/utils/merge-options.js +19 -19
- package/esm2015/core/utils/nested-structure-by-key.js +10 -10
- package/esm2015/core/utils/plugins-by-key.js +9 -9
- package/esm2015/core/with-theia.js +22 -22
- package/esm2015/custom-types.js +1 -1
- package/esm2015/editor.component.js +439 -439
- package/esm2015/editor.module.js +201 -201
- package/esm2015/interfaces/auto-format.js +1 -1
- package/esm2015/interfaces/editor.js +22 -22
- package/esm2015/interfaces/element.js +1 -1
- package/esm2015/interfaces/image.js +2 -2
- package/esm2015/interfaces/index.js +8 -8
- package/esm2015/interfaces/plugins/index.js +4 -4
- package/esm2015/interfaces/plugins/no-infer.js +1 -1
- package/esm2015/interfaces/plugins/plugin-key.js +39 -39
- package/esm2015/interfaces/plugins/plugins.js +1 -1
- package/esm2015/interfaces/plugins/with-override.js +1 -1
- package/esm2015/interfaces/reset-block-type-plugin-options.js +2 -2
- package/esm2015/interfaces/toolbar.js +11 -11
- package/esm2015/interfaces/upload.js +2 -2
- package/esm2015/interfaces/utility/index.js +3 -3
- package/esm2015/interfaces/utility/nested-structure-by-key.js +1 -1
- package/esm2015/interfaces/utility/override-by-key.js +1 -1
- package/esm2015/interfaces/utility/types.js +1 -1
- package/esm2015/interfaces/valid-children-types.js +35 -35
- package/esm2015/interfaces/view-base.js +21 -21
- package/esm2015/pipes.js +42 -42
- package/esm2015/plugins/align/align.editor.js +47 -47
- package/esm2015/plugins/align/align.plugin.js +63 -63
- package/esm2015/plugins/autoformat/autoformat.plugin.js +109 -109
- package/esm2015/plugins/autoformat/transforms/auto-format-block.js +14 -14
- package/esm2015/plugins/autoformat/transforms/auto-format-inline.js +77 -77
- package/esm2015/plugins/blockquote/blockquote.component.js +21 -21
- package/esm2015/plugins/blockquote/blockquote.editor.js +20 -20
- package/esm2015/plugins/blockquote/blockquote.plugin.js +70 -70
- package/esm2015/plugins/code/code.component.js +244 -244
- package/esm2015/plugins/code/code.editor.js +47 -47
- package/esm2015/plugins/code/code.plugin.js +41 -41
- package/esm2015/plugins/color/color.editor.js +44 -44
- package/esm2015/plugins/color/color.plugin.js +27 -27
- package/esm2015/plugins/color/toolbar-item.component.js +79 -79
- package/esm2015/plugins/common/auto-insert-data..js +77 -77
- package/esm2015/plugins/common/block-card.plugin.js +286 -286
- package/esm2015/plugins/common/get-fragment.plugin.js +24 -24
- package/esm2015/plugins/common/history.plugin.js +30 -30
- package/esm2015/plugins/common/move-selection.plugin.js +89 -89
- package/esm2015/plugins/common/remove-empty.plugin.js +59 -59
- package/esm2015/plugins/common/remove-void.plugin.js +56 -56
- package/esm2015/plugins/common/reset-type.plugin.js +34 -34
- package/esm2015/plugins/common/transforms.plugin.js +17 -17
- package/esm2015/plugins/deserializers/deserialize-html.plugin.js +38 -38
- package/esm2015/plugins/deserializers/deserialize-md.plugin.js +121 -121
- package/esm2015/plugins/font-size/font-size.editor.js +97 -97
- package/esm2015/plugins/heading/heading.editor.js +53 -53
- package/esm2015/plugins/heading/heading.plugin.js +84 -84
- package/esm2015/plugins/hr/hr.component.js +40 -40
- package/esm2015/plugins/hr/hr.editor.js +7 -7
- package/esm2015/plugins/hr/hr.plugin.js +41 -41
- package/esm2015/plugins/image/image.component.js +369 -369
- package/esm2015/plugins/image/image.editor.js +57 -57
- package/esm2015/plugins/image/image.plugin.js +57 -57
- package/esm2015/plugins/indent/indent.editor.js +72 -72
- package/esm2015/plugins/indent/indent.plugin.js +59 -59
- package/esm2015/plugins/indent/on-keydown-indent.js +53 -53
- package/esm2015/plugins/index.js +70 -70
- package/esm2015/plugins/inline-code/inline-code.component.js +21 -21
- package/esm2015/plugins/inline-code/inline-code.editor.js +48 -48
- package/esm2015/plugins/inline-code/inline-code.plugin.js +65 -65
- package/esm2015/plugins/link/edit/link-edit.component.js +108 -108
- package/esm2015/plugins/link/hover/link-hover.component.js +39 -39
- package/esm2015/plugins/link/link.component.js +162 -162
- package/esm2015/plugins/link/link.editor.js +66 -66
- package/esm2015/plugins/link/link.plugin.js +58 -58
- package/esm2015/plugins/link/link.types.js +12 -12
- package/esm2015/plugins/list/components/bulleted-list.component.js +33 -33
- package/esm2015/plugins/list/components/list-item.component.js +94 -94
- package/esm2015/plugins/list/components/numbered-list.component.js +39 -39
- package/esm2015/plugins/list/list.editor.js +125 -125
- package/esm2015/plugins/list/list.plugin.js +280 -280
- package/esm2015/plugins/list/normalizers/get-list-normalizer.js +39 -39
- package/esm2015/plugins/list/normalizers/normalize-list-item.js +19 -19
- package/esm2015/plugins/list/normalizers/normalize-no.js +42 -42
- package/esm2015/plugins/list/on-key-down-list.js +32 -32
- package/esm2015/plugins/list/queries/get-list-item-entry.js +27 -27
- package/esm2015/plugins/list/queries/get-list-item-sublist.js +12 -12
- package/esm2015/plugins/list/queries/get-list-types.js +5 -5
- package/esm2015/plugins/list/queries/get-start-list-item.js +26 -26
- package/esm2015/plugins/list/queries/has-list-in-list-item.js +27 -27
- package/esm2015/plugins/list/queries/is-in-list.js +5 -5
- package/esm2015/plugins/list/queries/is-list-nested.js +10 -10
- package/esm2015/plugins/list/queries/is-list.js +5 -5
- package/esm2015/plugins/list/queries/is-node-type-list.js +4 -4
- package/esm2015/plugins/list/queries/is-selection-at-list-item-start.js +12 -12
- package/esm2015/plugins/list/queries/is-selection-in-same-list-item.js +16 -16
- package/esm2015/plugins/list/queries/is-single-list-item.js +9 -9
- package/esm2015/plugins/list/transforms/insert-list-data.js +71 -71
- package/esm2015/plugins/list/transforms/insert-list-item.js +72 -72
- package/esm2015/plugins/list/transforms/move-list-item-down.js +41 -41
- package/esm2015/plugins/list/transforms/move-list-item-sublist-items-to-list-item-sublist.js +42 -42
- package/esm2015/plugins/list/transforms/move-list-item-sublist-items-to-list.js +29 -29
- package/esm2015/plugins/list/transforms/move-list-item-up.js +77 -77
- package/esm2015/plugins/list/transforms/unwrap-list.js +9 -9
- package/esm2015/plugins/list/types.js +2 -2
- package/esm2015/plugins/mark/mark.editor.js +28 -28
- package/esm2015/plugins/mark/mark.plugin.js +101 -101
- package/esm2015/plugins/node-id/node-id.plugin.js +68 -68
- package/esm2015/plugins/normalizers/insert-paragraph-nodes.js +28 -28
- package/esm2015/plugins/normalizers/remove-empty-nodes.js +17 -17
- package/esm2015/plugins/normalizers/trailing-node.plugin.js +33 -33
- package/esm2015/plugins/paint-format/paint-format.editor.js +122 -122
- package/esm2015/plugins/public-api.js +15 -15
- package/esm2015/plugins/quick-insert/components/quick-insert.component.js +101 -101
- package/esm2015/plugins/quick-insert/components/quick-toolbar/quick-toolbar.component.js +83 -83
- package/esm2015/plugins/quick-insert/quick-insert.editor.js +52 -52
- package/esm2015/plugins/quick-insert/quick-insert.plugin.js +74 -74
- package/esm2015/plugins/soft-break/soft-break.plugin.js +36 -36
- package/esm2015/plugins/soft-break/soft-break.types.js +1 -1
- package/esm2015/plugins/table/components/insert-mark/insert-mark.component.js +102 -102
- package/esm2015/plugins/table/components/row/row.component.js +46 -46
- package/esm2015/plugins/table/components/table.component.js +469 -469
- package/esm2015/plugins/table/components/td/td.component.js +698 -698
- package/esm2015/plugins/table/components/toolbar/table-options.component.js +67 -67
- package/esm2015/plugins/table/components/toolbar/table-toolbar.component.js +161 -161
- package/esm2015/plugins/table/table.editor.js +182 -182
- package/esm2015/plugins/table/table.plugin.js +423 -423
- package/esm2015/plugins/table/table.service.js +102 -102
- package/esm2015/plugins/table/table.store.js +479 -479
- package/esm2015/plugins/table/table.types.js +33 -33
- package/esm2015/plugins/table/toolbar-item.component.js +61 -61
- package/esm2015/plugins/table/transforms/clear-cell.js +11 -11
- package/esm2015/plugins/table/transforms/clear-table-node.js +27 -27
- package/esm2015/plugins/table/transforms/insert-column.js +57 -57
- package/esm2015/plugins/table/transforms/insert-row.js +42 -42
- package/esm2015/plugins/table/transforms/insert-table.js +14 -14
- package/esm2015/plugins/table/transforms/remove-column.js +51 -51
- package/esm2015/plugins/table/transforms/remove-row.js +50 -50
- package/esm2015/plugins/table/transforms/remove-table.js +49 -49
- package/esm2015/plugins/table/utils/add-columns.js +28 -28
- package/esm2015/plugins/table/utils/calc-anchor-position.js +24 -24
- package/esm2015/plugins/table/utils/calc-span.js +72 -72
- package/esm2015/plugins/table/utils/create-cell.js +19 -19
- package/esm2015/plugins/table/utils/create-row.js +12 -12
- package/esm2015/plugins/table/utils/create-table.js +13 -13
- package/esm2015/plugins/table/utils/get-base-height.js +22 -22
- package/esm2015/plugins/table/utils/get-select-cell-node.js +16 -16
- package/esm2015/plugins/table/utils/index.js +8 -8
- package/esm2015/plugins/table/utils/is-range-in-table.js +16 -16
- package/esm2015/plugins/table/utils/is-selection-in-table.js +11 -11
- package/esm2015/plugins/table/utils/is-virtual-key.js +13 -13
- package/esm2015/plugins/table/utils/merge-cell.js +90 -90
- package/esm2015/plugins/table/utils/next-path.js +5 -5
- package/esm2015/plugins/table/utils/normalize-table.js +30 -30
- package/esm2015/plugins/table/utils/remove-columns.js +23 -23
- package/esm2015/plugins/table/utils/set-menu-cell-invisibility.js +15 -15
- package/esm2015/plugins/table/utils/split-cell.js +31 -31
- package/esm2015/plugins/table/utils/table-position.js +242 -242
- package/esm2015/plugins/todo-item/todo-item.component.js +55 -55
- package/esm2015/plugins/todo-item/todo-item.editor.js +31 -31
- package/esm2015/plugins/todo-item/todo-item.plugin.js +78 -78
- package/esm2015/plugins/vertical-align/toolbar-item.component.js +89 -89
- package/esm2015/plugins/vertical-align/vertical-align.editor.js +54 -54
- package/esm2015/public-api.js +23 -23
- package/esm2015/queries/anchor-block-entry.js +13 -13
- package/esm2015/queries/anchor-block.js +6 -6
- package/esm2015/queries/anchor-inline-entry.js +10 -10
- package/esm2015/queries/find-descendant.js +47 -47
- package/esm2015/queries/find-node.js +45 -45
- package/esm2015/queries/find-path.js +28 -28
- package/esm2015/queries/get-above-by-type.js +10 -10
- package/esm2015/queries/get-above.js +9 -9
- package/esm2015/queries/get-anchor-block-entry.js +8 -8
- package/esm2015/queries/get-block-above.js +7 -7
- package/esm2015/queries/get-block-card-above.js +7 -7
- package/esm2015/queries/get-block-card-cursor.js +5 -5
- package/esm2015/queries/get-container-blocks.js +11 -11
- package/esm2015/queries/get-directly-parent.js +11 -11
- package/esm2015/queries/get-insert-elements-path.js +43 -43
- package/esm2015/queries/get-last-child-path.js +9 -9
- package/esm2015/queries/get-last-node.js +17 -17
- package/esm2015/queries/get-next-sibling-nodes.js +17 -17
- package/esm2015/queries/get-node.js +10 -10
- package/esm2015/queries/get-nodes-by-type.js +12 -12
- package/esm2015/queries/get-nodes.js +7 -7
- package/esm2015/queries/get-parent.js +12 -12
- package/esm2015/queries/get-plain-text.js +16 -16
- package/esm2015/queries/get-plugin-by-toolbar.js +12 -12
- package/esm2015/queries/get-point-before.js +62 -62
- package/esm2015/queries/get-point-from-location.js +15 -15
- package/esm2015/queries/get-previous-path.js +9 -9
- package/esm2015/queries/get-rang-from-block-start.js +16 -16
- package/esm2015/queries/get-range-before.js +17 -17
- package/esm2015/queries/get-selection-marks.js +19 -19
- package/esm2015/queries/get-selection-nodes-by-type.js +29 -29
- package/esm2015/queries/get-text.js +9 -9
- package/esm2015/queries/get-toolbar-disabled.js +13 -13
- package/esm2015/queries/index.js +59 -58
- package/esm2015/queries/is-across-blocks.js +7 -7
- package/esm2015/queries/is-ancestor-empty.js +6 -6
- package/esm2015/queries/is-ancestor.js +3 -3
- package/esm2015/queries/is-block-above-empty.js +11 -11
- package/esm2015/queries/is-block-active.js +7 -7
- package/esm2015/queries/is-block-card-cursor.js +4 -4
- package/esm2015/queries/is-block-text-empty-after-selection.js +31 -31
- package/esm2015/queries/is-collapsed.js +7 -7
- package/esm2015/queries/is-contain-nested-type.js +28 -28
- package/esm2015/queries/is-container-type.js +2 -2
- package/esm2015/queries/is-descendant.js +3 -3
- package/esm2015/queries/is-empty-content.js +15 -0
- package/esm2015/queries/is-empty-paragraph-by-path.js +7 -7
- package/esm2015/queries/is-empty-paragraph.js +11 -11
- package/esm2015/queries/is-first-child.js +5 -5
- package/esm2015/queries/is-include-types.js +11 -11
- package/esm2015/queries/is-node-type-in.js +9 -9
- package/esm2015/queries/is-node-type.js +15 -15
- package/esm2015/queries/is-paragraph.js +9 -9
- package/esm2015/queries/is-point-at-root.js +2 -2
- package/esm2015/queries/is-range-across-blocks.js +18 -18
- package/esm2015/queries/is-range-at-root.js +3 -3
- package/esm2015/queries/is-start.js +6 -6
- package/esm2015/queries/some-node.js +9 -9
- package/esm2015/services/color-select.service.js +49 -49
- package/esm2015/services/context.service.js +59 -59
- package/esm2015/services/table-contextmenu.service.js +189 -189
- package/esm2015/services/toolbar.service.js +47 -47
- package/esm2015/shortcuts/index.js +5 -5
- package/esm2015/shortcuts/mark.js +24 -24
- package/esm2015/transforms/apply-deep-to-nodes.js +21 -21
- package/esm2015/transforms/clear-marks.js +23 -23
- package/esm2015/transforms/close-conversion-hint.js +8 -8
- package/esm2015/transforms/delete-element.js +11 -11
- package/esm2015/transforms/handle-continual-delete-backward.js +17 -17
- package/esm2015/transforms/handle-continual-insert-break.js +19 -19
- package/esm2015/transforms/index.js +18 -18
- package/esm2015/transforms/insert-elements.js +34 -34
- package/esm2015/transforms/insert-paragraph.js +6 -6
- package/esm2015/transforms/merge-deep-to-nodes.js +8 -8
- package/esm2015/transforms/move-children.js +21 -21
- package/esm2015/transforms/on-keydown-reset-block-type.js +22 -22
- package/esm2015/transforms/set-end-selection.js +10 -10
- package/esm2015/transforms/set-marks.js +9 -9
- package/esm2015/transforms/set-node.js +5 -5
- package/esm2015/transforms/split-node.js +31 -31
- package/esm2015/transforms/un-hang-range.js +11 -11
- package/esm2015/transforms/un-wrap.js +11 -11
- package/esm2015/transforms/unwrap-nodes-by-type.js +11 -11
- package/esm2015/utils/auto-focus.js +13 -13
- package/esm2015/utils/auto-scroll-view.js +24 -24
- package/esm2015/utils/cast-array.js +7 -7
- package/esm2015/utils/common.js +2 -2
- package/esm2015/utils/create-empty-paragraph.js +14 -14
- package/esm2015/utils/data-transform.js +48 -48
- package/esm2015/utils/dom.js +46 -46
- package/esm2015/utils/editor-uuid.js +8 -8
- package/esm2015/utils/fragment.js +65 -65
- package/esm2015/utils/get-editable-element-height.js +6 -6
- package/esm2015/utils/get-toolbar-class.js +6 -6
- package/esm2015/utils/id-creator.js +11 -11
- package/esm2015/utils/index.js +13 -13
- package/esm2015/utils/is-clean-empty-paragraph.js +36 -36
- package/esm2015/utils/is-inline.js +9 -9
- package/esm2015/utils/lodash.js +3 -3
- package/esm2015/utils/match.js +29 -29
- package/esm2015/utils/merge-element-options.js +19 -19
- package/esm2015/utils/weak-maps.js +3 -3
- package/esm2015/worktile-theia.js +4 -4
- package/fesm2015/worktile-theia.js +13156 -13142
- package/fesm2015/worktile-theia.js.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 +1 -1
- 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 +74 -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 -57
- 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 -0
- 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-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 +1 -1
- 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,470 +1,470 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { Component, ElementRef, ViewChild, HostListener } from '@angular/core';
|
|
3
|
-
import { fromEvent, Subject } from 'rxjs';
|
|
4
|
-
import { take, takeUntil, debounceTime } from 'rxjs/operators';
|
|
5
|
-
import { Transforms } from 'slate';
|
|
6
|
-
import { AngularEditor } from 'slate-angular';
|
|
7
|
-
import { TablePosition } from '../utils';
|
|
8
|
-
import { ColumnResizeNotifierSource } from '../../../components/column-resize/column-resize-notifier';
|
|
9
|
-
import { TableCellEventDispatcher } from '../../../components/column-resize/event-dispatcher';
|
|
10
|
-
import { TableStore } from '../table.store';
|
|
11
|
-
import { getElementHeight, getElementWidth } from '../../../utils/dom';
|
|
12
|
-
import { TableService } from '../table.service';
|
|
13
|
-
import { TheTableContextMenuService } from '../../../services/table-contextmenu.service';
|
|
14
|
-
import { TheBaseElementComponent } from '../../../interfaces/view-base';
|
|
15
|
-
import { TableOptions, TheTableToken } from '../table.types';
|
|
16
|
-
import { TheEditor } from '../../../interfaces/editor';
|
|
17
|
-
import { SLA_TABLE_CELL_SELECTOR } from '../../../constants/selector';
|
|
18
|
-
import * as TheTransforms from '../../../transforms';
|
|
19
|
-
import * as i0 from "@angular/core";
|
|
20
|
-
import * as i1 from "../../../components/column-resize/event-dispatcher";
|
|
21
|
-
import * as i2 from "../../../components/column-resize/column-resize-notifier";
|
|
22
|
-
import * as i3 from "../table.store";
|
|
23
|
-
import * as i4 from "../table.service";
|
|
24
|
-
import * as i5 from "../../../services/context.service";
|
|
25
|
-
import * as i6 from "../../../services/table-contextmenu.service";
|
|
26
|
-
import * as i7 from "./insert-mark/insert-mark.component";
|
|
27
|
-
import * as i8 from "slate-angular";
|
|
28
|
-
import * as i9 from "../../../components/column-resize/column-resize.directive";
|
|
29
|
-
import * as i10 from "@angular/common";
|
|
30
|
-
export class TheTableComponent extends TheBaseElementComponent {
|
|
31
|
-
constructor(elementRef, eventDispatcher, resizeNotifier, tableStore, cdr, ngZone, tableService, theContextService, theTableContextMenuService) {
|
|
32
|
-
super(elementRef, cdr);
|
|
33
|
-
this.eventDispatcher = eventDispatcher;
|
|
34
|
-
this.resizeNotifier = resizeNotifier;
|
|
35
|
-
this.tableStore = tableStore;
|
|
36
|
-
this.cdr = cdr;
|
|
37
|
-
this.ngZone = ngZone;
|
|
38
|
-
this.tableService = tableService;
|
|
39
|
-
this.theContextService = theContextService;
|
|
40
|
-
this.theTableContextMenuService = theTableContextMenuService;
|
|
41
|
-
this.destroy$ = new Subject();
|
|
42
|
-
this.rowControls = [];
|
|
43
|
-
this.colControls = [];
|
|
44
|
-
}
|
|
45
|
-
get columns() {
|
|
46
|
-
return this.normalizedColumns || (this.element && this.element.columns);
|
|
47
|
-
}
|
|
48
|
-
get nativeElement() {
|
|
49
|
-
return this.elementRef.nativeElement;
|
|
50
|
-
}
|
|
51
|
-
get tbodyNativeElement() {
|
|
52
|
-
var _a;
|
|
53
|
-
return (_a = this.tbodyElement) === null || _a === void 0 ? void 0 : _a.nativeElement;
|
|
54
|
-
}
|
|
55
|
-
get isSelectedAllCell() {
|
|
56
|
-
return (this.tableStore.selectedRowsIndex.length === this.rowControls.length &&
|
|
57
|
-
this.tableStore.selectedColumnsIndex.length === this.colControls.length);
|
|
58
|
-
}
|
|
59
|
-
handleMousedown(event) {
|
|
60
|
-
if (event.target instanceof Element && this.tbodyNativeElement.contains(event.target)) {
|
|
61
|
-
return;
|
|
62
|
-
}
|
|
63
|
-
if (!TheEditor.isFocused(this.editor)) {
|
|
64
|
-
TheEditor.focus(this.editor);
|
|
65
|
-
}
|
|
66
|
-
AngularEditor.moveBlockCard(this.editor, this.element, { direction: 'left' });
|
|
67
|
-
event.preventDefault();
|
|
68
|
-
}
|
|
69
|
-
onContextChange() {
|
|
70
|
-
super.onContextChange();
|
|
71
|
-
if (this.initialized) {
|
|
72
|
-
Promise.resolve().then(() => {
|
|
73
|
-
this.tableStore.emitTableChange();
|
|
74
|
-
this.useRowControls();
|
|
75
|
-
this.cdr.markForCheck();
|
|
76
|
-
});
|
|
77
|
-
this.getIsInTable();
|
|
78
|
-
this.getColControls();
|
|
79
|
-
if (this.normalizedColumns) {
|
|
80
|
-
this.normalizeShowColumns();
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
ngOnInit() {
|
|
85
|
-
super.ngOnInit();
|
|
86
|
-
this.getColControls();
|
|
87
|
-
this.getIsInTable();
|
|
88
|
-
}
|
|
89
|
-
ngAfterViewInit() {
|
|
90
|
-
this.ngZone.onStable.pipe(take(1)).subscribe(() => __awaiter(this, void 0, void 0, function* () {
|
|
91
|
-
var _a;
|
|
92
|
-
const blockCardElement = this.nativeElement.closest('slate-block-card');
|
|
93
|
-
if (blockCardElement) {
|
|
94
|
-
blockCardElement.classList.add(`slate-block-card-${this.element.type}`);
|
|
95
|
-
}
|
|
96
|
-
this.tableStore.initEditor(this.editor);
|
|
97
|
-
this.subscribeCellsChange();
|
|
98
|
-
this.subscribeCellPositionChange();
|
|
99
|
-
this.listenTableContextMenuEvent();
|
|
100
|
-
this.useTableWrapperWidth();
|
|
101
|
-
if ((_a = this.element.options) === null || _a === void 0 ? void 0 : _a.numberedColumn) {
|
|
102
|
-
const loadImageDone = yield this.resolveImage();
|
|
103
|
-
// 等待序号列表格内图片加载完成后再去渲染表格行高度
|
|
104
|
-
if (loadImageDone) {
|
|
105
|
-
this.useRowControls();
|
|
106
|
-
this.cdr.detectChanges();
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
else {
|
|
110
|
-
this.useRowControls();
|
|
111
|
-
this.cdr.markForCheck();
|
|
112
|
-
}
|
|
113
|
-
}));
|
|
114
|
-
}
|
|
115
|
-
subscribeCellPositionChange() {
|
|
116
|
-
this.tableStore
|
|
117
|
-
.cellsPositionChange()
|
|
118
|
-
.pipe(debounceTime(100), takeUntil(this.destroy$))
|
|
119
|
-
.subscribe(x => {
|
|
120
|
-
this.cdr.detectChanges();
|
|
121
|
-
});
|
|
122
|
-
}
|
|
123
|
-
useTableWrapperWidth() {
|
|
124
|
-
const rootWidth = this.theContextService.getOptions().width;
|
|
125
|
-
const tablePath = TheEditor.findPath(this.editor, this.element);
|
|
126
|
-
if (tablePath.length > 1) {
|
|
127
|
-
// 解决table不在顶层时,拖动单元格宽度计算问题
|
|
128
|
-
this.theTableWrapperWidth = this.tableWrapper.nativeElement.offsetWidth;
|
|
129
|
-
}
|
|
130
|
-
else {
|
|
131
|
-
this.theTableWrapperWidth = rootWidth;
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
subscribeCellsChange() {
|
|
135
|
-
this.tableStore
|
|
136
|
-
.dangerousOrSelectedCellsChange()
|
|
137
|
-
.pipe(takeUntil(this.destroy$))
|
|
138
|
-
.subscribe(() => {
|
|
139
|
-
this.cdr.detectChanges();
|
|
140
|
-
});
|
|
141
|
-
}
|
|
142
|
-
useRowControls() {
|
|
143
|
-
var _a;
|
|
144
|
-
if (this.selection || ((_a = this.element.options) === null || _a === void 0 ? void 0 : _a.numberedColumn)) {
|
|
145
|
-
this.rowControls = this.calculateRowControls();
|
|
146
|
-
}
|
|
147
|
-
}
|
|
148
|
-
detectChanges() {
|
|
149
|
-
this.cdr.detectChanges();
|
|
150
|
-
}
|
|
151
|
-
calculateMinRowSpanCellForRows() {
|
|
152
|
-
const table = this.element;
|
|
153
|
-
const cells = table.children.map((row, index) => {
|
|
154
|
-
const noHiddenCells = row.children.filter(cell => !cell.hidden);
|
|
155
|
-
if (noHiddenCells.length > 0) {
|
|
156
|
-
const minRowspan = Math.min.apply(Math, noHiddenCells.map(cell => {
|
|
157
|
-
return cell.rowspan || 1;
|
|
158
|
-
}));
|
|
159
|
-
const cell = row.children.find(item => !item.hidden && (item.rowspan || 1) === minRowspan);
|
|
160
|
-
return {
|
|
161
|
-
cell,
|
|
162
|
-
rowIndex: index
|
|
163
|
-
};
|
|
164
|
-
}
|
|
165
|
-
else {
|
|
166
|
-
return {
|
|
167
|
-
rowIndex: index
|
|
168
|
-
};
|
|
169
|
-
}
|
|
170
|
-
});
|
|
171
|
-
return cells;
|
|
172
|
-
}
|
|
173
|
-
calculateRowControls() {
|
|
174
|
-
const minRowSpanCellForRows = this.calculateMinRowSpanCellForRows();
|
|
175
|
-
const rowControls = [];
|
|
176
|
-
let previousRowIndex = 0;
|
|
177
|
-
let previousCombineRowIndex = 0;
|
|
178
|
-
minRowSpanCellForRows.forEach((cellInfo, index) => {
|
|
179
|
-
if (!cellInfo.cell) {
|
|
180
|
-
rowControls.push({
|
|
181
|
-
height: 0,
|
|
182
|
-
rowIndex: index
|
|
183
|
-
});
|
|
184
|
-
previousCombineRowIndex = index;
|
|
185
|
-
if (index === minRowSpanCellForRows.length - 1) {
|
|
186
|
-
this.calculateRowControlsAvgHeight(previousCombineRowIndex, previousRowIndex, rowControls);
|
|
187
|
-
}
|
|
188
|
-
return;
|
|
189
|
-
}
|
|
190
|
-
// calculate combine row height
|
|
191
|
-
if (previousCombineRowIndex > previousRowIndex) {
|
|
192
|
-
this.calculateRowControlsAvgHeight(previousCombineRowIndex, previousRowIndex, rowControls);
|
|
193
|
-
previousCombineRowIndex = 0;
|
|
194
|
-
}
|
|
195
|
-
const cellDom = AngularEditor.toDOMNode(this.editor, cellInfo.cell);
|
|
196
|
-
let height = getElementHeight(cellDom);
|
|
197
|
-
// 当cell为合并的单元格(rowspan > 1),计算其实际高度(当前单元格的高度 - 下方合并单元格的高度)
|
|
198
|
-
if (cellInfo.cell.rowspan > 1) {
|
|
199
|
-
const calcHeight = height - this.getBelowRowHeight(minRowSpanCellForRows, index, cellInfo.rowIndex, cellInfo.cell.rowspan);
|
|
200
|
-
rowControls.push({
|
|
201
|
-
height: calcHeight,
|
|
202
|
-
rowIndex: cellInfo.rowIndex
|
|
203
|
-
});
|
|
204
|
-
}
|
|
205
|
-
else {
|
|
206
|
-
rowControls.push({
|
|
207
|
-
height,
|
|
208
|
-
rowIndex: cellInfo.rowIndex
|
|
209
|
-
});
|
|
210
|
-
}
|
|
211
|
-
previousRowIndex = index;
|
|
212
|
-
});
|
|
213
|
-
return rowControls;
|
|
214
|
-
}
|
|
215
|
-
calculateRowControlsAvgHeight(previousCombineRowIndex, previousRowIndex, rowControls) {
|
|
216
|
-
const rowControl = rowControls[previousRowIndex];
|
|
217
|
-
const count = previousCombineRowIndex - previousRowIndex;
|
|
218
|
-
const avgHeight = Math.floor(rowControl.height / (count + 1));
|
|
219
|
-
const firstHeight = rowControl.height - avgHeight * count;
|
|
220
|
-
rowControl.height = firstHeight;
|
|
221
|
-
rowControls
|
|
222
|
-
.filter((item, _index) => _index > previousRowIndex && _index <= previousCombineRowIndex)
|
|
223
|
-
.forEach(rowControl => {
|
|
224
|
-
rowControl.height = avgHeight;
|
|
225
|
-
});
|
|
226
|
-
}
|
|
227
|
-
getBelowRowHeight(cells, index, rowIndex, rowspan) {
|
|
228
|
-
let belowRowlHeight = 0;
|
|
229
|
-
cells.slice(index + 1, cells.length).map(item => {
|
|
230
|
-
if (!item.cell) {
|
|
231
|
-
return;
|
|
232
|
-
}
|
|
233
|
-
if (rowIndex + rowspan > item.rowIndex) {
|
|
234
|
-
const cellDom = AngularEditor.toDOMNode(this.editor, item.cell);
|
|
235
|
-
if (item.cell.rowspan > 1) {
|
|
236
|
-
// 如果下方单元格的rowspan > 1,递归计算
|
|
237
|
-
const height = this.getBelowRowHeight(cells, cells.findIndex(cell => cell.rowIndex === item.rowIndex), item.rowIndex, item.cell.rowspan);
|
|
238
|
-
belowRowlHeight += getElementHeight(cellDom) - height;
|
|
239
|
-
}
|
|
240
|
-
else {
|
|
241
|
-
belowRowlHeight += getElementHeight(cellDom);
|
|
242
|
-
}
|
|
243
|
-
}
|
|
244
|
-
});
|
|
245
|
-
return belowRowlHeight;
|
|
246
|
-
}
|
|
247
|
-
resolveImage() {
|
|
248
|
-
const imageElements = this.nativeElement.querySelectorAll('img');
|
|
249
|
-
if (imageElements.length) {
|
|
250
|
-
const imageResolves = [];
|
|
251
|
-
imageElements.forEach(item => {
|
|
252
|
-
const image = new Image();
|
|
253
|
-
const imageLoad = new Promise(resolve => {
|
|
254
|
-
image.onload = () => {
|
|
255
|
-
resolve(true);
|
|
256
|
-
};
|
|
257
|
-
image.onerror = () => {
|
|
258
|
-
resolve(true);
|
|
259
|
-
};
|
|
260
|
-
image.src = item.getAttribute('src');
|
|
261
|
-
});
|
|
262
|
-
imageResolves.push(imageLoad);
|
|
263
|
-
});
|
|
264
|
-
return Promise.all(imageResolves);
|
|
265
|
-
}
|
|
266
|
-
return Promise.resolve(true);
|
|
267
|
-
}
|
|
268
|
-
getColControls() {
|
|
269
|
-
var _a, _b;
|
|
270
|
-
this.colControls = ((_b = (_a = this.element) === null || _a === void 0 ? void 0 : _a.children[0]) === null || _b === void 0 ? void 0 : _b.children) || [];
|
|
271
|
-
}
|
|
272
|
-
onColMouseDown(event, index) {
|
|
273
|
-
event.stopPropagation();
|
|
274
|
-
event.preventDefault();
|
|
275
|
-
if (!!this.selection && this.isInTable) {
|
|
276
|
-
this.tableStore.clearDangerousCells();
|
|
277
|
-
this.tableStore.selectColumn(this.editor, index);
|
|
278
|
-
this.tableService.openToolbar(event.target, true);
|
|
279
|
-
}
|
|
280
|
-
}
|
|
281
|
-
getIsInTable() {
|
|
282
|
-
if (this.selection) {
|
|
283
|
-
const opts = new TableOptions();
|
|
284
|
-
const selection = this.editor.selection;
|
|
285
|
-
const startPosition = TablePosition.create(opts, this.editor, selection.anchor.path);
|
|
286
|
-
const endPosition = TablePosition.create(opts, this.editor, selection.focus.path);
|
|
287
|
-
this.isInTable = startPosition.isInTable() && endPosition.isInTable();
|
|
288
|
-
}
|
|
289
|
-
else {
|
|
290
|
-
this.isInTable = false;
|
|
291
|
-
}
|
|
292
|
-
}
|
|
293
|
-
normalizeShowColumns() {
|
|
294
|
-
const table = this.element;
|
|
295
|
-
const tr = table.children[0];
|
|
296
|
-
if (this.element.columns) {
|
|
297
|
-
let isGood = true;
|
|
298
|
-
this.normalizedColumns = table.columns.map(item => {
|
|
299
|
-
return Object.assign({}, item);
|
|
300
|
-
});
|
|
301
|
-
if (this.element.columns.length !== tr.children.length) {
|
|
302
|
-
this.normalizedColumns = tr.children.map((item, i) => this.columns[i] || { width: 200 });
|
|
303
|
-
isGood = false;
|
|
304
|
-
}
|
|
305
|
-
const totalWidth = this.normalizedColumns.reduce((pre, cur) => {
|
|
306
|
-
return pre + cur.width;
|
|
307
|
-
}, 0);
|
|
308
|
-
if (totalWidth < this.theTableWrapperWidth) {
|
|
309
|
-
const lastColumnWidth = this.theTableWrapperWidth - totalWidth + this.normalizedColumns[this.normalizedColumns.length - 1].width;
|
|
310
|
-
this.normalizedColumns[this.normalizedColumns.length - 1] = { width: lastColumnWidth };
|
|
311
|
-
isGood = false;
|
|
312
|
-
}
|
|
313
|
-
if (isGood) {
|
|
314
|
-
this.normalizedColumns = null;
|
|
315
|
-
}
|
|
316
|
-
}
|
|
317
|
-
}
|
|
318
|
-
initializeColumns() {
|
|
319
|
-
if (!this.element.columns) {
|
|
320
|
-
const tr = this.element.children[0];
|
|
321
|
-
const tableWidth = AngularEditor.toDOMNode(this.editor, tr).offsetWidth;
|
|
322
|
-
const columns = tr.children.map(cell => {
|
|
323
|
-
return { width: Math.round(tableWidth / tr.children.length) - tr.children.length };
|
|
324
|
-
});
|
|
325
|
-
TheTransforms.setNode(this.editor, { columns }, this.element);
|
|
326
|
-
}
|
|
327
|
-
}
|
|
328
|
-
initializeRows() {
|
|
329
|
-
this.element.children.map(row => {
|
|
330
|
-
if (!row.height) {
|
|
331
|
-
const element = TheEditor.toDOMNode(this.editor, row);
|
|
332
|
-
TheTransforms.setNode(this.editor, { height: getElementHeight(element) }, row);
|
|
333
|
-
}
|
|
334
|
-
});
|
|
335
|
-
}
|
|
336
|
-
transformRowHeight() {
|
|
337
|
-
const rowElements = this.nativeElement.querySelector('tbody').children;
|
|
338
|
-
if (rowElements) {
|
|
339
|
-
[...rowElements].map((row, index) => {
|
|
340
|
-
const height = getElementHeight(row);
|
|
341
|
-
TheTransforms.setNode(this.editor, { height }, this.element.children[index]);
|
|
342
|
-
});
|
|
343
|
-
}
|
|
344
|
-
}
|
|
345
|
-
transformColumnsWidth() {
|
|
346
|
-
const cols = [...this.nativeElement.querySelector('colgroup').children];
|
|
347
|
-
const columns = cols.map(col => {
|
|
348
|
-
return { width: getElementWidth(col) };
|
|
349
|
-
});
|
|
350
|
-
TheTransforms.setNode(this.editor, { columns }, this.element);
|
|
351
|
-
}
|
|
352
|
-
onRowMouseDown(event, index) {
|
|
353
|
-
if (this.readonly)
|
|
354
|
-
return;
|
|
355
|
-
event.stopPropagation();
|
|
356
|
-
event.preventDefault();
|
|
357
|
-
if (!this.isInTable) {
|
|
358
|
-
const path = TheEditor.findPath(this.editor, this.element);
|
|
359
|
-
Transforms.select(this.editor, path);
|
|
360
|
-
}
|
|
361
|
-
this.tableStore.selectRow(this.editor, index);
|
|
362
|
-
this.tableService.openToolbar(event.target, true);
|
|
363
|
-
}
|
|
364
|
-
onSelectTable(event) {
|
|
365
|
-
event.stopPropagation();
|
|
366
|
-
event.preventDefault();
|
|
367
|
-
this.tableStore.selectTable(this.editor);
|
|
368
|
-
this.tableService.openToolbar(event.target);
|
|
369
|
-
}
|
|
370
|
-
listenTableContextMenuEvent() {
|
|
371
|
-
this.ngZone.runOutsideAngular(() => {
|
|
372
|
-
fromEvent(this.theTableElement.nativeElement, 'contextmenu')
|
|
373
|
-
.pipe(takeUntil(this.destroy$))
|
|
374
|
-
.subscribe(event => {
|
|
375
|
-
if (this.readonly) {
|
|
376
|
-
return;
|
|
377
|
-
}
|
|
378
|
-
event.preventDefault();
|
|
379
|
-
this.tableStore.isRightClicking = true;
|
|
380
|
-
const cell = event.target.closest(SLA_TABLE_CELL_SELECTOR);
|
|
381
|
-
if (!cell) {
|
|
382
|
-
return;
|
|
383
|
-
}
|
|
384
|
-
else {
|
|
385
|
-
if (!cell.classList.contains('selected-cell')) {
|
|
386
|
-
this.tableStore.selectCell(cell, this.editor);
|
|
387
|
-
}
|
|
388
|
-
}
|
|
389
|
-
if (this.theTableContextMenuService.isOpened) {
|
|
390
|
-
this.theTableContextMenuService
|
|
391
|
-
.closeContextMenu()
|
|
392
|
-
.pipe(take(1))
|
|
393
|
-
.subscribe(() => {
|
|
394
|
-
this.theTableContextMenuService.openMenuList(event);
|
|
395
|
-
});
|
|
396
|
-
}
|
|
397
|
-
else if (this.tableService.isOpened) {
|
|
398
|
-
this.tableService
|
|
399
|
-
.closeToolbar()
|
|
400
|
-
.pipe(take(1))
|
|
401
|
-
.subscribe(() => {
|
|
402
|
-
this.theTableContextMenuService.openMenuList(event);
|
|
403
|
-
});
|
|
404
|
-
}
|
|
405
|
-
else {
|
|
406
|
-
this.cdr.markForCheck();
|
|
407
|
-
this.theTableContextMenuService.openMenuList(event);
|
|
408
|
-
}
|
|
409
|
-
// patch for right click select next cell
|
|
410
|
-
setTimeout(() => {
|
|
411
|
-
Transforms.select(this.editor, this.editor.selection.anchor.path);
|
|
412
|
-
});
|
|
413
|
-
});
|
|
414
|
-
});
|
|
415
|
-
}
|
|
416
|
-
trackByFnRowControls(index) {
|
|
417
|
-
return index;
|
|
418
|
-
}
|
|
419
|
-
trackByFnColControls(index) {
|
|
420
|
-
return index;
|
|
421
|
-
}
|
|
422
|
-
ngOnDestroy() {
|
|
423
|
-
super.ngOnDestroy();
|
|
424
|
-
this.destroy$.next();
|
|
425
|
-
this.destroy$.complete();
|
|
426
|
-
}
|
|
427
|
-
}
|
|
428
|
-
TheTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheTableComponent, deps: [{ token: i0.ElementRef }, { token: i1.TableCellEventDispatcher }, { token: i2.ColumnResizeNotifierSource }, { token: i3.TableStore }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: i4.TableService }, { token: i5.TheContextService }, { token: i6.TheTableContextMenuService }], target: i0.ɵɵFactoryTarget.Component });
|
|
429
|
-
TheTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheTableComponent, selector: "the-table, [theTable]", host: { listeners: { "mousedown": "handleMousedown($event)" } }, providers: [
|
|
430
|
-
TableStore,
|
|
431
|
-
TableService,
|
|
432
|
-
TheTableContextMenuService,
|
|
433
|
-
TableCellEventDispatcher,
|
|
434
|
-
ColumnResizeNotifierSource,
|
|
435
|
-
{
|
|
436
|
-
provide: TheTableToken,
|
|
437
|
-
useExisting: TheTableComponent
|
|
438
|
-
}
|
|
439
|
-
], viewQueries: [{ propertyName: "tableWrapper", first: true, predicate: ["tableWrapper"], descendants: true, read: ElementRef, static: true }, { propertyName: "theTableElement", first: true, predicate: ["theTable"], descendants: true, read: ElementRef, static: true }, { propertyName: "tbodyElement", first: true, predicate: ["tbody"], descendants: true, read: ElementRef, static: true }], usesInheritance: true, ngImport: i0, template: "<!-- \u7C7B\u540D the-temp-*: \u4E34\u65F6\u89E3\u51B3\u56E0\u53D7portal\u5F71\u54CD\u8868\u683C\u6837\u5F0F\u95EE\u9898\uFF0C\u540E\u671F\u6539\u56DEthe-* -->\n<div\n class=\"the-temp-table-container\"\n theColumnResize\n [ngClass]=\"{\n 'the-temp-table-with-controls': isInTable,\n 'the-temp-numbered-column-container': element?.options?.numberedColumn,\n 'the-temp-table-selection-hide': tableStore.isCellSelecting || tableStore.isRightClicking\n }\"\n>\n <div\n class=\"the-temp-table-row-controls-wrapper\"\n [ngClass]=\"{\n 'the-temp-table-focus': isInTable\n }\"\n >\n <div\n class=\"the-temp-table-corner-controls\"\n [ngClass]=\"{\n visible: !readonly && isInTable,\n active: isSelectedAllCell,\n dangerous: tableStore.isSelectedTable && tableStore.dangerousCells.length > 0\n }\"\n >\n <div class=\"the-temp-table-corner-button\" (mousedown)=\"onSelectTable($event)\"></div>\n <div class=\"the-temp-table-corner-controls-insert-row-marker\">\n <the-table-insert-mark type=\"row\" [at]=\"0\" [tableStore]=\"tableStore\"></the-table-insert-mark>\n </div>\n <div class=\"the-temp-table-corner-controls-insert-column-marker\">\n <the-table-insert-mark type=\"column\" [at]=\"0\" [tableStore]=\"tableStore\"></the-table-insert-mark>\n </div>\n </div>\n <div class=\"the-temp-table-row-controls\">\n <div class=\"the-temp-table-row-controls-inner\">\n <div\n class=\"the-temp-table-row-controls-button-wrap\"\n *ngFor=\"let control of rowControls; let i = index; trackBy: trackByFnRowControls\"\n [ngClass]=\"{\n active: tableStore.selectedRowsIndex.includes(control.rowIndex),\n dangerous: tableStore.dangerousRowsIndex.includes(control.rowIndex) && tableStore.dangerousCells.length > 0\n }\"\n >\n <ng-container *ngIf=\"!readonly && isInTable && !element?.options?.numberedColumn\">\n <button\n (mousedown)=\"onRowMouseDown($event, control.rowIndex)\"\n type=\"button\"\n [ngStyle]=\"{ height: control.height + 1 + 'px' }\"\n class=\"the-temp-table-row-controls-button the-temp-table-controls-button\"\n ></button>\n </ng-container>\n <ng-container *ngIf=\"element?.options?.numberedColumn\">\n <div\n [contentEditable]=\"false\"\n contenteditable=\"false\"\n (mousedown)=\"onRowMouseDown($event, control.rowIndex)\"\n class=\"the-temp-table-numbered-controls-button\"\n [ngStyle]=\"{ height: control.height + 1 + 'px' }\"\n >\n <p class=\"row-number d-flex align-items-center\">{{ i + 1 }}</p>\n </div>\n </ng-container>\n <the-table-insert-mark type=\"row\" [at]=\"control.rowIndex + 1\" [tableStore]=\"tableStore\"> </the-table-insert-mark>\n </div>\n </div>\n </div>\n </div>\n <div class=\"the-temp-table-wrapper\" #tableWrapper [ngClass]=\"{ 'the-temp-table-numbered': element?.options?.numberedColumn }\">\n <table class=\"the-temp-table\" #theTable [ngClass]=\"{ 'the-temp-table-with-controls': isInTable }\">\n <colgroup *ngIf=\"columns\">\n <col *ngFor=\"let col of columns\" [ngStyle]=\"{ width: col.width + 'px' }\" />\n </colgroup>\n <thead>\n <tr class=\"the-temp-table-col-controls-wrapper\">\n <th\n class=\"the-temp-table-col-controls\"\n [ngClass]=\"{\n active: tableStore.selectedColumnsIndex.includes(i),\n dangerous: tableStore.dangerousColumnsIndex.includes(i) && tableStore.dangerousCells.length > 0\n }\"\n (mousedown)=\"onColMouseDown($event, i)\"\n *ngFor=\"let control of colControls; let i = index; trackBy: trackByFnColControls\"\n >\n <the-table-insert-mark *ngIf=\"isInTable\" type=\"column\" [at]=\"i + 1\" [tableStore]=\"tableStore\">\n </the-table-insert-mark>\n </th>\n </tr>\n </thead>\n <tbody #tbody>\n <slate-children [children]=\"children\" [context]=\"childrenContext\" [viewContext]=\"viewContext\"> </slate-children>\n </tbody>\n </table>\n </div>\n</div>\n", components: [{ type: i7.TheInsertMarkComponent, selector: "the-table-insert-mark", inputs: ["type", "at", "tableStore"] }, { type: i8.SlateChildrenComponent, selector: "slate-children", inputs: ["children", "context", "viewContext"] }], directives: [{ type: i9.TheColumnResizeDirective, selector: "div[theColumnResize]" }, { type: i10.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i10.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
|
|
440
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheTableComponent, decorators: [{
|
|
441
|
-
type: Component,
|
|
442
|
-
args: [{
|
|
443
|
-
selector: 'the-table, [theTable]',
|
|
444
|
-
templateUrl: './table.component.html',
|
|
445
|
-
providers: [
|
|
446
|
-
TableStore,
|
|
447
|
-
TableService,
|
|
448
|
-
TheTableContextMenuService,
|
|
449
|
-
TableCellEventDispatcher,
|
|
450
|
-
ColumnResizeNotifierSource,
|
|
451
|
-
{
|
|
452
|
-
provide: TheTableToken,
|
|
453
|
-
useExisting: TheTableComponent
|
|
454
|
-
}
|
|
455
|
-
]
|
|
456
|
-
}]
|
|
457
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.TableCellEventDispatcher }, { type: i2.ColumnResizeNotifierSource }, { type: i3.TableStore }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type: i4.TableService }, { type: i5.TheContextService }, { type: i6.TheTableContextMenuService }]; }, propDecorators: { tableWrapper: [{
|
|
458
|
-
type: ViewChild,
|
|
459
|
-
args: ['tableWrapper', { read: ElementRef, static: true }]
|
|
460
|
-
}], theTableElement: [{
|
|
461
|
-
type: ViewChild,
|
|
462
|
-
args: ['theTable', { read: ElementRef, static: true }]
|
|
463
|
-
}], tbodyElement: [{
|
|
464
|
-
type: ViewChild,
|
|
465
|
-
args: ['tbody', { read: ElementRef, static: true }]
|
|
466
|
-
}], handleMousedown: [{
|
|
467
|
-
type: HostListener,
|
|
468
|
-
args: ['mousedown', ['$event']]
|
|
469
|
-
}] } });
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { Component, ElementRef, ViewChild, HostListener } from '@angular/core';
|
|
3
|
+
import { fromEvent, Subject } from 'rxjs';
|
|
4
|
+
import { take, takeUntil, debounceTime } from 'rxjs/operators';
|
|
5
|
+
import { Transforms } from 'slate';
|
|
6
|
+
import { AngularEditor } from 'slate-angular';
|
|
7
|
+
import { TablePosition } from '../utils';
|
|
8
|
+
import { ColumnResizeNotifierSource } from '../../../components/column-resize/column-resize-notifier';
|
|
9
|
+
import { TableCellEventDispatcher } from '../../../components/column-resize/event-dispatcher';
|
|
10
|
+
import { TableStore } from '../table.store';
|
|
11
|
+
import { getElementHeight, getElementWidth } from '../../../utils/dom';
|
|
12
|
+
import { TableService } from '../table.service';
|
|
13
|
+
import { TheTableContextMenuService } from '../../../services/table-contextmenu.service';
|
|
14
|
+
import { TheBaseElementComponent } from '../../../interfaces/view-base';
|
|
15
|
+
import { TableOptions, TheTableToken } from '../table.types';
|
|
16
|
+
import { TheEditor } from '../../../interfaces/editor';
|
|
17
|
+
import { SLA_TABLE_CELL_SELECTOR } from '../../../constants/selector';
|
|
18
|
+
import * as TheTransforms from '../../../transforms';
|
|
19
|
+
import * as i0 from "@angular/core";
|
|
20
|
+
import * as i1 from "../../../components/column-resize/event-dispatcher";
|
|
21
|
+
import * as i2 from "../../../components/column-resize/column-resize-notifier";
|
|
22
|
+
import * as i3 from "../table.store";
|
|
23
|
+
import * as i4 from "../table.service";
|
|
24
|
+
import * as i5 from "../../../services/context.service";
|
|
25
|
+
import * as i6 from "../../../services/table-contextmenu.service";
|
|
26
|
+
import * as i7 from "./insert-mark/insert-mark.component";
|
|
27
|
+
import * as i8 from "slate-angular";
|
|
28
|
+
import * as i9 from "../../../components/column-resize/column-resize.directive";
|
|
29
|
+
import * as i10 from "@angular/common";
|
|
30
|
+
export class TheTableComponent extends TheBaseElementComponent {
|
|
31
|
+
constructor(elementRef, eventDispatcher, resizeNotifier, tableStore, cdr, ngZone, tableService, theContextService, theTableContextMenuService) {
|
|
32
|
+
super(elementRef, cdr);
|
|
33
|
+
this.eventDispatcher = eventDispatcher;
|
|
34
|
+
this.resizeNotifier = resizeNotifier;
|
|
35
|
+
this.tableStore = tableStore;
|
|
36
|
+
this.cdr = cdr;
|
|
37
|
+
this.ngZone = ngZone;
|
|
38
|
+
this.tableService = tableService;
|
|
39
|
+
this.theContextService = theContextService;
|
|
40
|
+
this.theTableContextMenuService = theTableContextMenuService;
|
|
41
|
+
this.destroy$ = new Subject();
|
|
42
|
+
this.rowControls = [];
|
|
43
|
+
this.colControls = [];
|
|
44
|
+
}
|
|
45
|
+
get columns() {
|
|
46
|
+
return this.normalizedColumns || (this.element && this.element.columns);
|
|
47
|
+
}
|
|
48
|
+
get nativeElement() {
|
|
49
|
+
return this.elementRef.nativeElement;
|
|
50
|
+
}
|
|
51
|
+
get tbodyNativeElement() {
|
|
52
|
+
var _a;
|
|
53
|
+
return (_a = this.tbodyElement) === null || _a === void 0 ? void 0 : _a.nativeElement;
|
|
54
|
+
}
|
|
55
|
+
get isSelectedAllCell() {
|
|
56
|
+
return (this.tableStore.selectedRowsIndex.length === this.rowControls.length &&
|
|
57
|
+
this.tableStore.selectedColumnsIndex.length === this.colControls.length);
|
|
58
|
+
}
|
|
59
|
+
handleMousedown(event) {
|
|
60
|
+
if (event.target instanceof Element && this.tbodyNativeElement.contains(event.target)) {
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
if (!TheEditor.isFocused(this.editor)) {
|
|
64
|
+
TheEditor.focus(this.editor);
|
|
65
|
+
}
|
|
66
|
+
AngularEditor.moveBlockCard(this.editor, this.element, { direction: 'left' });
|
|
67
|
+
event.preventDefault();
|
|
68
|
+
}
|
|
69
|
+
onContextChange() {
|
|
70
|
+
super.onContextChange();
|
|
71
|
+
if (this.initialized) {
|
|
72
|
+
Promise.resolve().then(() => {
|
|
73
|
+
this.tableStore.emitTableChange();
|
|
74
|
+
this.useRowControls();
|
|
75
|
+
this.cdr.markForCheck();
|
|
76
|
+
});
|
|
77
|
+
this.getIsInTable();
|
|
78
|
+
this.getColControls();
|
|
79
|
+
if (this.normalizedColumns) {
|
|
80
|
+
this.normalizeShowColumns();
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
ngOnInit() {
|
|
85
|
+
super.ngOnInit();
|
|
86
|
+
this.getColControls();
|
|
87
|
+
this.getIsInTable();
|
|
88
|
+
}
|
|
89
|
+
ngAfterViewInit() {
|
|
90
|
+
this.ngZone.onStable.pipe(take(1)).subscribe(() => __awaiter(this, void 0, void 0, function* () {
|
|
91
|
+
var _a;
|
|
92
|
+
const blockCardElement = this.nativeElement.closest('slate-block-card');
|
|
93
|
+
if (blockCardElement) {
|
|
94
|
+
blockCardElement.classList.add(`slate-block-card-${this.element.type}`);
|
|
95
|
+
}
|
|
96
|
+
this.tableStore.initEditor(this.editor);
|
|
97
|
+
this.subscribeCellsChange();
|
|
98
|
+
this.subscribeCellPositionChange();
|
|
99
|
+
this.listenTableContextMenuEvent();
|
|
100
|
+
this.useTableWrapperWidth();
|
|
101
|
+
if ((_a = this.element.options) === null || _a === void 0 ? void 0 : _a.numberedColumn) {
|
|
102
|
+
const loadImageDone = yield this.resolveImage();
|
|
103
|
+
// 等待序号列表格内图片加载完成后再去渲染表格行高度
|
|
104
|
+
if (loadImageDone) {
|
|
105
|
+
this.useRowControls();
|
|
106
|
+
this.cdr.detectChanges();
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
else {
|
|
110
|
+
this.useRowControls();
|
|
111
|
+
this.cdr.markForCheck();
|
|
112
|
+
}
|
|
113
|
+
}));
|
|
114
|
+
}
|
|
115
|
+
subscribeCellPositionChange() {
|
|
116
|
+
this.tableStore
|
|
117
|
+
.cellsPositionChange()
|
|
118
|
+
.pipe(debounceTime(100), takeUntil(this.destroy$))
|
|
119
|
+
.subscribe(x => {
|
|
120
|
+
this.cdr.detectChanges();
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
useTableWrapperWidth() {
|
|
124
|
+
const rootWidth = this.theContextService.getOptions().width;
|
|
125
|
+
const tablePath = TheEditor.findPath(this.editor, this.element);
|
|
126
|
+
if (tablePath.length > 1) {
|
|
127
|
+
// 解决table不在顶层时,拖动单元格宽度计算问题
|
|
128
|
+
this.theTableWrapperWidth = this.tableWrapper.nativeElement.offsetWidth;
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
this.theTableWrapperWidth = rootWidth;
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
subscribeCellsChange() {
|
|
135
|
+
this.tableStore
|
|
136
|
+
.dangerousOrSelectedCellsChange()
|
|
137
|
+
.pipe(takeUntil(this.destroy$))
|
|
138
|
+
.subscribe(() => {
|
|
139
|
+
this.cdr.detectChanges();
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
useRowControls() {
|
|
143
|
+
var _a;
|
|
144
|
+
if (this.selection || ((_a = this.element.options) === null || _a === void 0 ? void 0 : _a.numberedColumn)) {
|
|
145
|
+
this.rowControls = this.calculateRowControls();
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
detectChanges() {
|
|
149
|
+
this.cdr.detectChanges();
|
|
150
|
+
}
|
|
151
|
+
calculateMinRowSpanCellForRows() {
|
|
152
|
+
const table = this.element;
|
|
153
|
+
const cells = table.children.map((row, index) => {
|
|
154
|
+
const noHiddenCells = row.children.filter(cell => !cell.hidden);
|
|
155
|
+
if (noHiddenCells.length > 0) {
|
|
156
|
+
const minRowspan = Math.min.apply(Math, noHiddenCells.map(cell => {
|
|
157
|
+
return cell.rowspan || 1;
|
|
158
|
+
}));
|
|
159
|
+
const cell = row.children.find(item => !item.hidden && (item.rowspan || 1) === minRowspan);
|
|
160
|
+
return {
|
|
161
|
+
cell,
|
|
162
|
+
rowIndex: index
|
|
163
|
+
};
|
|
164
|
+
}
|
|
165
|
+
else {
|
|
166
|
+
return {
|
|
167
|
+
rowIndex: index
|
|
168
|
+
};
|
|
169
|
+
}
|
|
170
|
+
});
|
|
171
|
+
return cells;
|
|
172
|
+
}
|
|
173
|
+
calculateRowControls() {
|
|
174
|
+
const minRowSpanCellForRows = this.calculateMinRowSpanCellForRows();
|
|
175
|
+
const rowControls = [];
|
|
176
|
+
let previousRowIndex = 0;
|
|
177
|
+
let previousCombineRowIndex = 0;
|
|
178
|
+
minRowSpanCellForRows.forEach((cellInfo, index) => {
|
|
179
|
+
if (!cellInfo.cell) {
|
|
180
|
+
rowControls.push({
|
|
181
|
+
height: 0,
|
|
182
|
+
rowIndex: index
|
|
183
|
+
});
|
|
184
|
+
previousCombineRowIndex = index;
|
|
185
|
+
if (index === minRowSpanCellForRows.length - 1) {
|
|
186
|
+
this.calculateRowControlsAvgHeight(previousCombineRowIndex, previousRowIndex, rowControls);
|
|
187
|
+
}
|
|
188
|
+
return;
|
|
189
|
+
}
|
|
190
|
+
// calculate combine row height
|
|
191
|
+
if (previousCombineRowIndex > previousRowIndex) {
|
|
192
|
+
this.calculateRowControlsAvgHeight(previousCombineRowIndex, previousRowIndex, rowControls);
|
|
193
|
+
previousCombineRowIndex = 0;
|
|
194
|
+
}
|
|
195
|
+
const cellDom = AngularEditor.toDOMNode(this.editor, cellInfo.cell);
|
|
196
|
+
let height = getElementHeight(cellDom);
|
|
197
|
+
// 当cell为合并的单元格(rowspan > 1),计算其实际高度(当前单元格的高度 - 下方合并单元格的高度)
|
|
198
|
+
if (cellInfo.cell.rowspan > 1) {
|
|
199
|
+
const calcHeight = height - this.getBelowRowHeight(minRowSpanCellForRows, index, cellInfo.rowIndex, cellInfo.cell.rowspan);
|
|
200
|
+
rowControls.push({
|
|
201
|
+
height: calcHeight,
|
|
202
|
+
rowIndex: cellInfo.rowIndex
|
|
203
|
+
});
|
|
204
|
+
}
|
|
205
|
+
else {
|
|
206
|
+
rowControls.push({
|
|
207
|
+
height,
|
|
208
|
+
rowIndex: cellInfo.rowIndex
|
|
209
|
+
});
|
|
210
|
+
}
|
|
211
|
+
previousRowIndex = index;
|
|
212
|
+
});
|
|
213
|
+
return rowControls;
|
|
214
|
+
}
|
|
215
|
+
calculateRowControlsAvgHeight(previousCombineRowIndex, previousRowIndex, rowControls) {
|
|
216
|
+
const rowControl = rowControls[previousRowIndex];
|
|
217
|
+
const count = previousCombineRowIndex - previousRowIndex;
|
|
218
|
+
const avgHeight = Math.floor(rowControl.height / (count + 1));
|
|
219
|
+
const firstHeight = rowControl.height - avgHeight * count;
|
|
220
|
+
rowControl.height = firstHeight;
|
|
221
|
+
rowControls
|
|
222
|
+
.filter((item, _index) => _index > previousRowIndex && _index <= previousCombineRowIndex)
|
|
223
|
+
.forEach(rowControl => {
|
|
224
|
+
rowControl.height = avgHeight;
|
|
225
|
+
});
|
|
226
|
+
}
|
|
227
|
+
getBelowRowHeight(cells, index, rowIndex, rowspan) {
|
|
228
|
+
let belowRowlHeight = 0;
|
|
229
|
+
cells.slice(index + 1, cells.length).map(item => {
|
|
230
|
+
if (!item.cell) {
|
|
231
|
+
return;
|
|
232
|
+
}
|
|
233
|
+
if (rowIndex + rowspan > item.rowIndex) {
|
|
234
|
+
const cellDom = AngularEditor.toDOMNode(this.editor, item.cell);
|
|
235
|
+
if (item.cell.rowspan > 1) {
|
|
236
|
+
// 如果下方单元格的rowspan > 1,递归计算
|
|
237
|
+
const height = this.getBelowRowHeight(cells, cells.findIndex(cell => cell.rowIndex === item.rowIndex), item.rowIndex, item.cell.rowspan);
|
|
238
|
+
belowRowlHeight += getElementHeight(cellDom) - height;
|
|
239
|
+
}
|
|
240
|
+
else {
|
|
241
|
+
belowRowlHeight += getElementHeight(cellDom);
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
});
|
|
245
|
+
return belowRowlHeight;
|
|
246
|
+
}
|
|
247
|
+
resolveImage() {
|
|
248
|
+
const imageElements = this.nativeElement.querySelectorAll('img');
|
|
249
|
+
if (imageElements.length) {
|
|
250
|
+
const imageResolves = [];
|
|
251
|
+
imageElements.forEach(item => {
|
|
252
|
+
const image = new Image();
|
|
253
|
+
const imageLoad = new Promise(resolve => {
|
|
254
|
+
image.onload = () => {
|
|
255
|
+
resolve(true);
|
|
256
|
+
};
|
|
257
|
+
image.onerror = () => {
|
|
258
|
+
resolve(true);
|
|
259
|
+
};
|
|
260
|
+
image.src = item.getAttribute('src');
|
|
261
|
+
});
|
|
262
|
+
imageResolves.push(imageLoad);
|
|
263
|
+
});
|
|
264
|
+
return Promise.all(imageResolves);
|
|
265
|
+
}
|
|
266
|
+
return Promise.resolve(true);
|
|
267
|
+
}
|
|
268
|
+
getColControls() {
|
|
269
|
+
var _a, _b;
|
|
270
|
+
this.colControls = ((_b = (_a = this.element) === null || _a === void 0 ? void 0 : _a.children[0]) === null || _b === void 0 ? void 0 : _b.children) || [];
|
|
271
|
+
}
|
|
272
|
+
onColMouseDown(event, index) {
|
|
273
|
+
event.stopPropagation();
|
|
274
|
+
event.preventDefault();
|
|
275
|
+
if (!!this.selection && this.isInTable) {
|
|
276
|
+
this.tableStore.clearDangerousCells();
|
|
277
|
+
this.tableStore.selectColumn(this.editor, index);
|
|
278
|
+
this.tableService.openToolbar(event.target, true);
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
getIsInTable() {
|
|
282
|
+
if (this.selection) {
|
|
283
|
+
const opts = new TableOptions();
|
|
284
|
+
const selection = this.editor.selection;
|
|
285
|
+
const startPosition = TablePosition.create(opts, this.editor, selection.anchor.path);
|
|
286
|
+
const endPosition = TablePosition.create(opts, this.editor, selection.focus.path);
|
|
287
|
+
this.isInTable = startPosition.isInTable() && endPosition.isInTable();
|
|
288
|
+
}
|
|
289
|
+
else {
|
|
290
|
+
this.isInTable = false;
|
|
291
|
+
}
|
|
292
|
+
}
|
|
293
|
+
normalizeShowColumns() {
|
|
294
|
+
const table = this.element;
|
|
295
|
+
const tr = table.children[0];
|
|
296
|
+
if (this.element.columns) {
|
|
297
|
+
let isGood = true;
|
|
298
|
+
this.normalizedColumns = table.columns.map(item => {
|
|
299
|
+
return Object.assign({}, item);
|
|
300
|
+
});
|
|
301
|
+
if (this.element.columns.length !== tr.children.length) {
|
|
302
|
+
this.normalizedColumns = tr.children.map((item, i) => this.columns[i] || { width: 200 });
|
|
303
|
+
isGood = false;
|
|
304
|
+
}
|
|
305
|
+
const totalWidth = this.normalizedColumns.reduce((pre, cur) => {
|
|
306
|
+
return pre + cur.width;
|
|
307
|
+
}, 0);
|
|
308
|
+
if (totalWidth < this.theTableWrapperWidth) {
|
|
309
|
+
const lastColumnWidth = this.theTableWrapperWidth - totalWidth + this.normalizedColumns[this.normalizedColumns.length - 1].width;
|
|
310
|
+
this.normalizedColumns[this.normalizedColumns.length - 1] = { width: lastColumnWidth };
|
|
311
|
+
isGood = false;
|
|
312
|
+
}
|
|
313
|
+
if (isGood) {
|
|
314
|
+
this.normalizedColumns = null;
|
|
315
|
+
}
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
initializeColumns() {
|
|
319
|
+
if (!this.element.columns) {
|
|
320
|
+
const tr = this.element.children[0];
|
|
321
|
+
const tableWidth = AngularEditor.toDOMNode(this.editor, tr).offsetWidth;
|
|
322
|
+
const columns = tr.children.map(cell => {
|
|
323
|
+
return { width: Math.round(tableWidth / tr.children.length) - tr.children.length };
|
|
324
|
+
});
|
|
325
|
+
TheTransforms.setNode(this.editor, { columns }, this.element);
|
|
326
|
+
}
|
|
327
|
+
}
|
|
328
|
+
initializeRows() {
|
|
329
|
+
this.element.children.map(row => {
|
|
330
|
+
if (!row.height) {
|
|
331
|
+
const element = TheEditor.toDOMNode(this.editor, row);
|
|
332
|
+
TheTransforms.setNode(this.editor, { height: getElementHeight(element) }, row);
|
|
333
|
+
}
|
|
334
|
+
});
|
|
335
|
+
}
|
|
336
|
+
transformRowHeight() {
|
|
337
|
+
const rowElements = this.nativeElement.querySelector('tbody').children;
|
|
338
|
+
if (rowElements) {
|
|
339
|
+
[...rowElements].map((row, index) => {
|
|
340
|
+
const height = getElementHeight(row);
|
|
341
|
+
TheTransforms.setNode(this.editor, { height }, this.element.children[index]);
|
|
342
|
+
});
|
|
343
|
+
}
|
|
344
|
+
}
|
|
345
|
+
transformColumnsWidth() {
|
|
346
|
+
const cols = [...this.nativeElement.querySelector('colgroup').children];
|
|
347
|
+
const columns = cols.map(col => {
|
|
348
|
+
return { width: getElementWidth(col) };
|
|
349
|
+
});
|
|
350
|
+
TheTransforms.setNode(this.editor, { columns }, this.element);
|
|
351
|
+
}
|
|
352
|
+
onRowMouseDown(event, index) {
|
|
353
|
+
if (this.readonly)
|
|
354
|
+
return;
|
|
355
|
+
event.stopPropagation();
|
|
356
|
+
event.preventDefault();
|
|
357
|
+
if (!this.isInTable) {
|
|
358
|
+
const path = TheEditor.findPath(this.editor, this.element);
|
|
359
|
+
Transforms.select(this.editor, path);
|
|
360
|
+
}
|
|
361
|
+
this.tableStore.selectRow(this.editor, index);
|
|
362
|
+
this.tableService.openToolbar(event.target, true);
|
|
363
|
+
}
|
|
364
|
+
onSelectTable(event) {
|
|
365
|
+
event.stopPropagation();
|
|
366
|
+
event.preventDefault();
|
|
367
|
+
this.tableStore.selectTable(this.editor);
|
|
368
|
+
this.tableService.openToolbar(event.target);
|
|
369
|
+
}
|
|
370
|
+
listenTableContextMenuEvent() {
|
|
371
|
+
this.ngZone.runOutsideAngular(() => {
|
|
372
|
+
fromEvent(this.theTableElement.nativeElement, 'contextmenu')
|
|
373
|
+
.pipe(takeUntil(this.destroy$))
|
|
374
|
+
.subscribe(event => {
|
|
375
|
+
if (this.readonly) {
|
|
376
|
+
return;
|
|
377
|
+
}
|
|
378
|
+
event.preventDefault();
|
|
379
|
+
this.tableStore.isRightClicking = true;
|
|
380
|
+
const cell = event.target.closest(SLA_TABLE_CELL_SELECTOR);
|
|
381
|
+
if (!cell) {
|
|
382
|
+
return;
|
|
383
|
+
}
|
|
384
|
+
else {
|
|
385
|
+
if (!cell.classList.contains('selected-cell')) {
|
|
386
|
+
this.tableStore.selectCell(cell, this.editor);
|
|
387
|
+
}
|
|
388
|
+
}
|
|
389
|
+
if (this.theTableContextMenuService.isOpened) {
|
|
390
|
+
this.theTableContextMenuService
|
|
391
|
+
.closeContextMenu()
|
|
392
|
+
.pipe(take(1))
|
|
393
|
+
.subscribe(() => {
|
|
394
|
+
this.theTableContextMenuService.openMenuList(event);
|
|
395
|
+
});
|
|
396
|
+
}
|
|
397
|
+
else if (this.tableService.isOpened) {
|
|
398
|
+
this.tableService
|
|
399
|
+
.closeToolbar()
|
|
400
|
+
.pipe(take(1))
|
|
401
|
+
.subscribe(() => {
|
|
402
|
+
this.theTableContextMenuService.openMenuList(event);
|
|
403
|
+
});
|
|
404
|
+
}
|
|
405
|
+
else {
|
|
406
|
+
this.cdr.markForCheck();
|
|
407
|
+
this.theTableContextMenuService.openMenuList(event);
|
|
408
|
+
}
|
|
409
|
+
// patch for right click select next cell
|
|
410
|
+
setTimeout(() => {
|
|
411
|
+
Transforms.select(this.editor, this.editor.selection.anchor.path);
|
|
412
|
+
});
|
|
413
|
+
});
|
|
414
|
+
});
|
|
415
|
+
}
|
|
416
|
+
trackByFnRowControls(index) {
|
|
417
|
+
return index;
|
|
418
|
+
}
|
|
419
|
+
trackByFnColControls(index) {
|
|
420
|
+
return index;
|
|
421
|
+
}
|
|
422
|
+
ngOnDestroy() {
|
|
423
|
+
super.ngOnDestroy();
|
|
424
|
+
this.destroy$.next();
|
|
425
|
+
this.destroy$.complete();
|
|
426
|
+
}
|
|
427
|
+
}
|
|
428
|
+
TheTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheTableComponent, deps: [{ token: i0.ElementRef }, { token: i1.TableCellEventDispatcher }, { token: i2.ColumnResizeNotifierSource }, { token: i3.TableStore }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: i4.TableService }, { token: i5.TheContextService }, { token: i6.TheTableContextMenuService }], target: i0.ɵɵFactoryTarget.Component });
|
|
429
|
+
TheTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheTableComponent, selector: "the-table, [theTable]", host: { listeners: { "mousedown": "handleMousedown($event)" } }, providers: [
|
|
430
|
+
TableStore,
|
|
431
|
+
TableService,
|
|
432
|
+
TheTableContextMenuService,
|
|
433
|
+
TableCellEventDispatcher,
|
|
434
|
+
ColumnResizeNotifierSource,
|
|
435
|
+
{
|
|
436
|
+
provide: TheTableToken,
|
|
437
|
+
useExisting: TheTableComponent
|
|
438
|
+
}
|
|
439
|
+
], viewQueries: [{ propertyName: "tableWrapper", first: true, predicate: ["tableWrapper"], descendants: true, read: ElementRef, static: true }, { propertyName: "theTableElement", first: true, predicate: ["theTable"], descendants: true, read: ElementRef, static: true }, { propertyName: "tbodyElement", first: true, predicate: ["tbody"], descendants: true, read: ElementRef, static: true }], usesInheritance: true, ngImport: i0, template: "<!-- \u7C7B\u540D the-temp-*: \u4E34\u65F6\u89E3\u51B3\u56E0\u53D7portal\u5F71\u54CD\u8868\u683C\u6837\u5F0F\u95EE\u9898\uFF0C\u540E\u671F\u6539\u56DEthe-* -->\n<div\n class=\"the-temp-table-container\"\n theColumnResize\n [ngClass]=\"{\n 'the-temp-table-with-controls': isInTable,\n 'the-temp-numbered-column-container': element?.options?.numberedColumn,\n 'the-temp-table-selection-hide': tableStore.isCellSelecting || tableStore.isRightClicking\n }\"\n>\n <div\n class=\"the-temp-table-row-controls-wrapper\"\n [ngClass]=\"{\n 'the-temp-table-focus': isInTable\n }\"\n >\n <div\n class=\"the-temp-table-corner-controls\"\n [ngClass]=\"{\n visible: !readonly && isInTable,\n active: isSelectedAllCell,\n dangerous: tableStore.isSelectedTable && tableStore.dangerousCells.length > 0\n }\"\n >\n <div class=\"the-temp-table-corner-button\" (mousedown)=\"onSelectTable($event)\"></div>\n <div class=\"the-temp-table-corner-controls-insert-row-marker\">\n <the-table-insert-mark type=\"row\" [at]=\"0\" [tableStore]=\"tableStore\"></the-table-insert-mark>\n </div>\n <div class=\"the-temp-table-corner-controls-insert-column-marker\">\n <the-table-insert-mark type=\"column\" [at]=\"0\" [tableStore]=\"tableStore\"></the-table-insert-mark>\n </div>\n </div>\n <div class=\"the-temp-table-row-controls\">\n <div class=\"the-temp-table-row-controls-inner\">\n <div\n class=\"the-temp-table-row-controls-button-wrap\"\n *ngFor=\"let control of rowControls; let i = index; trackBy: trackByFnRowControls\"\n [ngClass]=\"{\n active: tableStore.selectedRowsIndex.includes(control.rowIndex),\n dangerous: tableStore.dangerousRowsIndex.includes(control.rowIndex) && tableStore.dangerousCells.length > 0\n }\"\n >\n <ng-container *ngIf=\"!readonly && isInTable && !element?.options?.numberedColumn\">\n <button\n (mousedown)=\"onRowMouseDown($event, control.rowIndex)\"\n type=\"button\"\n [ngStyle]=\"{ height: control.height + 1 + 'px' }\"\n class=\"the-temp-table-row-controls-button the-temp-table-controls-button\"\n ></button>\n </ng-container>\n <ng-container *ngIf=\"element?.options?.numberedColumn\">\n <div\n [contentEditable]=\"false\"\n contenteditable=\"false\"\n (mousedown)=\"onRowMouseDown($event, control.rowIndex)\"\n class=\"the-temp-table-numbered-controls-button\"\n [ngStyle]=\"{ height: control.height + 1 + 'px' }\"\n >\n <p class=\"row-number d-flex align-items-center\">{{ i + 1 }}</p>\n </div>\n </ng-container>\n <the-table-insert-mark type=\"row\" [at]=\"control.rowIndex + 1\" [tableStore]=\"tableStore\"> </the-table-insert-mark>\n </div>\n </div>\n </div>\n </div>\n <div class=\"the-temp-table-wrapper\" #tableWrapper [ngClass]=\"{ 'the-temp-table-numbered': element?.options?.numberedColumn }\">\n <table class=\"the-temp-table\" #theTable [ngClass]=\"{ 'the-temp-table-with-controls': isInTable }\">\n <colgroup *ngIf=\"columns\">\n <col *ngFor=\"let col of columns\" [ngStyle]=\"{ width: col.width + 'px' }\" />\n </colgroup>\n <thead>\n <tr class=\"the-temp-table-col-controls-wrapper\">\n <th\n class=\"the-temp-table-col-controls\"\n [ngClass]=\"{\n active: tableStore.selectedColumnsIndex.includes(i),\n dangerous: tableStore.dangerousColumnsIndex.includes(i) && tableStore.dangerousCells.length > 0\n }\"\n (mousedown)=\"onColMouseDown($event, i)\"\n *ngFor=\"let control of colControls; let i = index; trackBy: trackByFnColControls\"\n >\n <the-table-insert-mark *ngIf=\"isInTable\" type=\"column\" [at]=\"i + 1\" [tableStore]=\"tableStore\">\n </the-table-insert-mark>\n </th>\n </tr>\n </thead>\n <tbody #tbody>\n <slate-children [children]=\"children\" [context]=\"childrenContext\" [viewContext]=\"viewContext\"> </slate-children>\n </tbody>\n </table>\n </div>\n</div>\n", components: [{ type: i7.TheInsertMarkComponent, selector: "the-table-insert-mark", inputs: ["type", "at", "tableStore"] }, { type: i8.SlateChildrenComponent, selector: "slate-children", inputs: ["children", "context", "viewContext"] }], directives: [{ type: i9.TheColumnResizeDirective, selector: "div[theColumnResize]" }, { type: i10.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i10.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
|
|
440
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheTableComponent, decorators: [{
|
|
441
|
+
type: Component,
|
|
442
|
+
args: [{
|
|
443
|
+
selector: 'the-table, [theTable]',
|
|
444
|
+
templateUrl: './table.component.html',
|
|
445
|
+
providers: [
|
|
446
|
+
TableStore,
|
|
447
|
+
TableService,
|
|
448
|
+
TheTableContextMenuService,
|
|
449
|
+
TableCellEventDispatcher,
|
|
450
|
+
ColumnResizeNotifierSource,
|
|
451
|
+
{
|
|
452
|
+
provide: TheTableToken,
|
|
453
|
+
useExisting: TheTableComponent
|
|
454
|
+
}
|
|
455
|
+
]
|
|
456
|
+
}]
|
|
457
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.TableCellEventDispatcher }, { type: i2.ColumnResizeNotifierSource }, { type: i3.TableStore }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type: i4.TableService }, { type: i5.TheContextService }, { type: i6.TheTableContextMenuService }]; }, propDecorators: { tableWrapper: [{
|
|
458
|
+
type: ViewChild,
|
|
459
|
+
args: ['tableWrapper', { read: ElementRef, static: true }]
|
|
460
|
+
}], theTableElement: [{
|
|
461
|
+
type: ViewChild,
|
|
462
|
+
args: ['theTable', { read: ElementRef, static: true }]
|
|
463
|
+
}], tbodyElement: [{
|
|
464
|
+
type: ViewChild,
|
|
465
|
+
args: ['tbody', { read: ElementRef, static: true }]
|
|
466
|
+
}], handleMousedown: [{
|
|
467
|
+
type: HostListener,
|
|
468
|
+
args: ['mousedown', ['$event']]
|
|
469
|
+
}] } });
|
|
470
470
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../packages/src/plugins/table/components/table.component.ts","../../../../../../packages/src/plugins/table/components/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, OnDestroy, ChangeDetectorRef, NgZone, AfterViewInit, ViewChild, HostListener } from '@angular/core';\nimport { fromEvent, Subject } from 'rxjs';\nimport { take, takeUntil, debounceTime } from 'rxjs/operators';\nimport { Editor, Transforms } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { TablePosition } from '../utils';\nimport { ColumnResizeNotifierSource } from '../../../components/column-resize/column-resize-notifier';\nimport { TableCellEventDispatcher } from '../../../components/column-resize/event-dispatcher';\nimport { TableStore } from '../table.store';\nimport { getElementHeight, getElementWidth } from '../../../utils/dom';\nimport { TableService } from '../table.service';\nimport { TheTableContextMenuService } from '../../../services/table-contextmenu.service';\nimport { TheContextService } from '../../../services/context.service';\nimport { TheBaseElementComponent } from '../../../interfaces/view-base';\nimport { TableCellElement, TableElement, TableRowElement } from '../../../custom-types';\nimport { TableOptions, TheTableColumn, TheTableToken } from '../table.types';\nimport { TheEditor } from '../../../interfaces/editor';\nimport { SLA_TABLE_CELL_SELECTOR } from '../../../constants/selector';\nimport * as TheTransforms from '../../../transforms';\n\n@Component({\n    selector: 'the-table, [theTable]',\n    templateUrl: './table.component.html',\n    providers: [\n        TableStore,\n        TableService,\n        TheTableContextMenuService,\n        TableCellEventDispatcher,\n        ColumnResizeNotifierSource,\n        {\n            provide: TheTableToken,\n            useExisting: TheTableComponent\n        }\n    ]\n})\nexport class TheTableComponent extends TheBaseElementComponent<TableElement, Editor> implements OnInit, AfterViewInit, OnDestroy {\n    destroy$: Subject<any> = new Subject();\n    theTableWrapperWidth: number;\n\n    rowControls: { height: number; rowIndex: number }[] = [];\n\n    colControls = [];\n\n    normalizedColumns: TheTableColumn[];\n\n    isInTable: boolean;\n\n    get columns(): TheTableColumn[] {\n        return this.normalizedColumns || (this.element && this.element.columns);\n    }\n\n    get nativeElement(): HTMLElement {\n        return this.elementRef.nativeElement;\n    }\n\n    get tbodyNativeElement(): HTMLElement {\n        return this.tbodyElement?.nativeElement;\n    }\n\n    get isSelectedAllCell() {\n        return (\n            this.tableStore.selectedRowsIndex.length === this.rowControls.length &&\n            this.tableStore.selectedColumnsIndex.length === this.colControls.length\n        );\n    }\n\n    @ViewChild('tableWrapper', { read: ElementRef, static: true })\n    tableWrapper: ElementRef;\n\n    @ViewChild('theTable', { read: ElementRef, static: true })\n    theTableElement: ElementRef;\n\n    @ViewChild('tbody', { read: ElementRef, static: true })\n    tbodyElement: ElementRef;\n\n    @HostListener('mousedown', ['$event'])\n    handleMousedown(event: MouseEvent) {\n        if (event.target instanceof Element && this.tbodyNativeElement.contains(event.target)) {\n            return;\n        }\n        if (!TheEditor.isFocused(this.editor)) {\n            TheEditor.focus(this.editor);\n        }\n        AngularEditor.moveBlockCard(this.editor, this.element, { direction: 'left' });\n        event.preventDefault();\n    }\n\n    onContextChange() {\n        super.onContextChange();\n        if (this.initialized) {\n            Promise.resolve().then(() => {\n                this.tableStore.emitTableChange();\n                this.useRowControls();\n                this.cdr.markForCheck();\n            });\n            this.getIsInTable();\n            this.getColControls();\n            if (this.normalizedColumns) {\n                this.normalizeShowColumns();\n            }\n        }\n    }\n\n    constructor(\n        elementRef: ElementRef,\n        public eventDispatcher: TableCellEventDispatcher,\n        public resizeNotifier: ColumnResizeNotifierSource,\n        public tableStore: TableStore,\n        public cdr: ChangeDetectorRef,\n        public ngZone: NgZone,\n        public tableService: TableService,\n        private theContextService: TheContextService,\n        private theTableContextMenuService: TheTableContextMenuService\n    ) {\n        super(elementRef, cdr);\n    }\n\n    ngOnInit() {\n        super.ngOnInit();\n        this.getColControls();\n        this.getIsInTable();\n    }\n\n    ngAfterViewInit() {\n        this.ngZone.onStable.pipe(take(1)).subscribe(async () => {\n            const blockCardElement = this.nativeElement.closest('slate-block-card');\n            if (blockCardElement) {\n                blockCardElement.classList.add(`slate-block-card-${this.element.type}`);\n            }\n            this.tableStore.initEditor(this.editor);\n            this.subscribeCellsChange();\n            this.subscribeCellPositionChange();\n            this.listenTableContextMenuEvent();\n            this.useTableWrapperWidth();\n            if (this.element.options?.numberedColumn) {\n                const loadImageDone = await this.resolveImage();\n                // 等待序号列表格内图片加载完成后再去渲染表格行高度\n                if (loadImageDone) {\n                    this.useRowControls();\n                    this.cdr.detectChanges();\n                }\n            } else {\n                this.useRowControls();\n                this.cdr.markForCheck();\n            }\n        });\n    }\n\n    subscribeCellPositionChange() {\n        this.tableStore\n            .cellsPositionChange()\n            .pipe(debounceTime(100), takeUntil(this.destroy$))\n            .subscribe(x => {\n                this.cdr.detectChanges();\n            });\n    }\n\n    useTableWrapperWidth() {\n        const rootWidth = this.theContextService.getOptions().width;\n        const tablePath = TheEditor.findPath(this.editor, this.element);\n        if (tablePath.length > 1) {\n            // 解决table不在顶层时，拖动单元格宽度计算问题\n            this.theTableWrapperWidth = this.tableWrapper.nativeElement.offsetWidth;\n        } else {\n            this.theTableWrapperWidth = rootWidth;\n        }\n    }\n\n    subscribeCellsChange() {\n        this.tableStore\n            .dangerousOrSelectedCellsChange()\n            .pipe(takeUntil(this.destroy$))\n            .subscribe(() => {\n                this.cdr.detectChanges();\n            });\n    }\n\n    useRowControls() {\n        if (this.selection || this.element.options?.numberedColumn) {\n            this.rowControls = this.calculateRowControls();\n        }\n    }\n\n    detectChanges() {\n        this.cdr.detectChanges();\n    }\n\n    calculateMinRowSpanCellForRows(): { cell?: TableCellElement; rowIndex: number }[] {\n        const table = this.element;\n        const cells = table.children.map((row, index) => {\n            const noHiddenCells = row.children.filter(cell => !cell.hidden);\n            if (noHiddenCells.length > 0) {\n                const minRowspan = Math.min.apply(\n                    Math,\n                    noHiddenCells.map(cell => {\n                        return cell.rowspan || 1;\n                    })\n                );\n\n                const cell = row.children.find(item => !item.hidden && (item.rowspan || 1) === minRowspan);\n                return {\n                    cell,\n                    rowIndex: index\n                };\n            } else {\n                return {\n                    rowIndex: index\n                };\n            }\n        });\n        return cells;\n    }\n\n    calculateRowControls() {\n        const minRowSpanCellForRows = this.calculateMinRowSpanCellForRows();\n\n        const rowControls = [];\n        let previousRowIndex = 0;\n        let previousCombineRowIndex = 0;\n        minRowSpanCellForRows.forEach((cellInfo, index) => {\n            if (!cellInfo.cell) {\n                rowControls.push({\n                    height: 0,\n                    rowIndex: index\n                });\n                previousCombineRowIndex = index;\n                if (index === minRowSpanCellForRows.length - 1) {\n                    this.calculateRowControlsAvgHeight(previousCombineRowIndex, previousRowIndex, rowControls);\n                }\n                return;\n            }\n\n            // calculate combine row height\n            if (previousCombineRowIndex > previousRowIndex) {\n                this.calculateRowControlsAvgHeight(previousCombineRowIndex, previousRowIndex, rowControls);\n                previousCombineRowIndex = 0;\n            }\n\n            const cellDom = AngularEditor.toDOMNode(this.editor, cellInfo.cell);\n            let height = getElementHeight(cellDom);\n            // 当cell为合并的单元格(rowspan > 1)，计算其实际高度（当前单元格的高度 - 下方合并单元格的高度）\n            if (cellInfo.cell.rowspan > 1) {\n                const calcHeight = height - this.getBelowRowHeight(minRowSpanCellForRows, index, cellInfo.rowIndex, cellInfo.cell.rowspan);\n                rowControls.push({\n                    height: calcHeight,\n                    rowIndex: cellInfo.rowIndex\n                });\n            } else {\n                rowControls.push({\n                    height,\n                    rowIndex: cellInfo.rowIndex\n                });\n            }\n            previousRowIndex = index;\n        });\n        return rowControls;\n    }\n\n    calculateRowControlsAvgHeight(\n        previousCombineRowIndex: number,\n        previousRowIndex: number,\n        rowControls: { height: number; rowIndex: number }[]\n    ) {\n        const rowControl = rowControls[previousRowIndex];\n        const count = previousCombineRowIndex - previousRowIndex;\n        const avgHeight = Math.floor(rowControl.height / (count + 1));\n        const firstHeight = rowControl.height - avgHeight * count;\n        rowControl.height = firstHeight;\n        rowControls\n            .filter((item, _index) => _index > previousRowIndex && _index <= previousCombineRowIndex)\n            .forEach(rowControl => {\n                rowControl.height = avgHeight;\n            });\n    }\n\n    getBelowRowHeight(\n        cells: {\n            cell?: TableCellElement;\n            rowIndex: number;\n        }[],\n        index: number,\n        rowIndex: number,\n        rowspan: number\n    ) {\n        let belowRowlHeight = 0;\n        cells.slice(index + 1, cells.length).map(item => {\n            if (!item.cell) {\n                return;\n            }\n            if (rowIndex + rowspan > item.rowIndex) {\n                const cellDom = AngularEditor.toDOMNode(this.editor, item.cell);\n                if (item.cell.rowspan > 1) {\n                    // 如果下方单元格的rowspan > 1，递归计算\n                    const height = this.getBelowRowHeight(\n                        cells,\n                        cells.findIndex(cell => cell.rowIndex === item.rowIndex),\n                        item.rowIndex,\n                        item.cell.rowspan\n                    );\n                    belowRowlHeight += getElementHeight(cellDom) - height;\n                } else {\n                    belowRowlHeight += getElementHeight(cellDom);\n                }\n            }\n        });\n        return belowRowlHeight;\n    }\n\n    resolveImage() {\n        const imageElements = this.nativeElement.querySelectorAll('img');\n        if (imageElements.length) {\n            const imageResolves: Promise<any>[] = [];\n            imageElements.forEach(item => {\n                const image = new Image();\n                const imageLoad = new Promise(resolve => {\n                    image.onload = () => {\n                        resolve(true);\n                    };\n                    image.onerror = () => {\n                        resolve(true);\n                    };\n                    image.src = item.getAttribute('src');\n                });\n                imageResolves.push(imageLoad);\n            });\n            return Promise.all(imageResolves);\n        }\n        return Promise.resolve(true);\n    }\n\n    getColControls() {\n        this.colControls = this.element?.children[0]?.children || [];\n    }\n\n    onColMouseDown(event: MouseEvent, index: number) {\n        event.stopPropagation();\n        event.preventDefault();\n        if (!!this.selection && this.isInTable) {\n            this.tableStore.clearDangerousCells();\n            this.tableStore.selectColumn(this.editor, index);\n            this.tableService.openToolbar(event.target as HTMLElement, true);\n        }\n    }\n\n    getIsInTable() {\n        if (this.selection) {\n            const opts = new TableOptions();\n            const selection = this.editor.selection;\n            const startPosition = TablePosition.create(opts, this.editor, selection.anchor.path);\n            const endPosition = TablePosition.create(opts, this.editor, selection.focus.path);\n            this.isInTable = startPosition.isInTable() && endPosition.isInTable();\n        } else {\n            this.isInTable = false;\n        }\n    }\n\n    normalizeShowColumns() {\n        const table = this.element;\n        const tr = table.children[0];\n        if (this.element.columns) {\n            let isGood = true;\n            this.normalizedColumns = table.columns.map(item => {\n                return { ...item };\n            });\n            if (this.element.columns.length !== tr.children.length) {\n                this.normalizedColumns = tr.children.map((item, i) => this.columns[i] || { width: 200 });\n                isGood = false;\n            }\n            const totalWidth = this.normalizedColumns.reduce((pre, cur) => {\n                return pre + cur.width;\n            }, 0);\n            if (totalWidth < this.theTableWrapperWidth) {\n                const lastColumnWidth =\n                    this.theTableWrapperWidth - totalWidth + this.normalizedColumns[this.normalizedColumns.length - 1].width;\n                this.normalizedColumns[this.normalizedColumns.length - 1] = { width: lastColumnWidth };\n                isGood = false;\n            }\n            if (isGood) {\n                this.normalizedColumns = null;\n            }\n        }\n    }\n\n    initializeColumns() {\n        if (!this.element.columns) {\n            const tr = this.element.children[0] as TableRowElement;\n            const tableWidth = AngularEditor.toDOMNode(this.editor, tr).offsetWidth;\n            const columns = tr.children.map(cell => {\n                return { width: Math.round(tableWidth / tr.children.length) - tr.children.length };\n            });\n            TheTransforms.setNode(this.editor, { columns }, this.element);\n        }\n    }\n\n    initializeRows() {\n        this.element.children.map(row => {\n            if (!row.height) {\n                const element = TheEditor.toDOMNode(this.editor, row);\n                TheTransforms.setNode(this.editor, { height: getElementHeight(element) }, row);\n            }\n        });\n    }\n\n    transformRowHeight() {\n        const rowElements = this.nativeElement.querySelector('tbody').children;\n        if (rowElements) {\n            ([...rowElements] as HTMLTableRowElement[]).map((row, index) => {\n                const height = getElementHeight(row);\n                TheTransforms.setNode(this.editor, { height }, this.element.children[index]);\n            });\n        }\n    }\n\n    transformColumnsWidth() {\n        const cols = [...this.nativeElement.querySelector('colgroup').children] as HTMLTableColElement[];\n        const columns: TheTableColumn[] = cols.map(col => {\n            return { width: getElementWidth(col) };\n        });\n        TheTransforms.setNode(this.editor, { columns }, this.element);\n    }\n\n    onRowMouseDown(event: MouseEvent, index: number) {\n        if (this.readonly) return;\n        event.stopPropagation();\n        event.preventDefault();\n        if (!this.isInTable) {\n            const path = TheEditor.findPath(this.editor, this.element);\n            Transforms.select(this.editor, path);\n        }\n        this.tableStore.selectRow(this.editor, index);\n        this.tableService.openToolbar(event.target as HTMLElement, true);\n    }\n\n    onSelectTable(event: MouseEvent) {\n        event.stopPropagation();\n        event.preventDefault();\n        this.tableStore.selectTable(this.editor);\n        this.tableService.openToolbar(event.target as HTMLElement);\n    }\n\n    listenTableContextMenuEvent() {\n        this.ngZone.runOutsideAngular(() => {\n            fromEvent<MouseEvent>(this.theTableElement.nativeElement, 'contextmenu')\n                .pipe(takeUntil(this.destroy$))\n                .subscribe(event => {\n                    if (this.readonly) {\n                        return;\n                    }\n                    event.preventDefault();\n                    this.tableStore.isRightClicking = true;\n                    const cell = (event.target as HTMLElement).closest(SLA_TABLE_CELL_SELECTOR) as HTMLTableCellElement;\n                    if (!cell) {\n                        return;\n                    } else {\n                        if (!cell.classList.contains('selected-cell')) {\n                            this.tableStore.selectCell(cell, this.editor);\n                        }\n                    }\n                    if (this.theTableContextMenuService.isOpened) {\n                        this.theTableContextMenuService\n                            .closeContextMenu()\n                            .pipe(take(1))\n                            .subscribe(() => {\n                                this.theTableContextMenuService.openMenuList(event);\n                            });\n                    } else if (this.tableService.isOpened) {\n                        this.tableService\n                            .closeToolbar()\n                            .pipe(take(1))\n                            .subscribe(() => {\n                                this.theTableContextMenuService.openMenuList(event);\n                            });\n                    } else {\n                        this.cdr.markForCheck();\n                        this.theTableContextMenuService.openMenuList(event);\n                    }\n\n                    // patch for right click select next cell\n                    setTimeout(() => {\n                        Transforms.select(this.editor, this.editor.selection.anchor.path);\n                    });\n                });\n        });\n    }\n\n    trackByFnRowControls(index: number) {\n        return index;\n    }\n\n    trackByFnColControls(index: number) {\n        return index;\n    }\n\n    ngOnDestroy() {\n        super.ngOnDestroy();\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}\n","<!-- 类名 the-temp-*: 临时解决因受portal影响表格样式问题，后期改回the-* -->\n<div\n    class=\"the-temp-table-container\"\n    theColumnResize\n    [ngClass]=\"{\n        'the-temp-table-with-controls': isInTable,\n        'the-temp-numbered-column-container': element?.options?.numberedColumn,\n        'the-temp-table-selection-hide': tableStore.isCellSelecting || tableStore.isRightClicking\n    }\"\n>\n    <div\n        class=\"the-temp-table-row-controls-wrapper\"\n        [ngClass]=\"{\n            'the-temp-table-focus': isInTable\n        }\"\n    >\n        <div\n            class=\"the-temp-table-corner-controls\"\n            [ngClass]=\"{\n                visible: !readonly && isInTable,\n                active: isSelectedAllCell,\n                dangerous: tableStore.isSelectedTable && tableStore.dangerousCells.length > 0\n            }\"\n        >\n            <div class=\"the-temp-table-corner-button\" (mousedown)=\"onSelectTable($event)\"></div>\n            <div class=\"the-temp-table-corner-controls-insert-row-marker\">\n                <the-table-insert-mark type=\"row\" [at]=\"0\" [tableStore]=\"tableStore\"></the-table-insert-mark>\n            </div>\n            <div class=\"the-temp-table-corner-controls-insert-column-marker\">\n                <the-table-insert-mark type=\"column\" [at]=\"0\" [tableStore]=\"tableStore\"></the-table-insert-mark>\n            </div>\n        </div>\n        <div class=\"the-temp-table-row-controls\">\n            <div class=\"the-temp-table-row-controls-inner\">\n                <div\n                    class=\"the-temp-table-row-controls-button-wrap\"\n                    *ngFor=\"let control of rowControls; let i = index; trackBy: trackByFnRowControls\"\n                    [ngClass]=\"{\n                        active: tableStore.selectedRowsIndex.includes(control.rowIndex),\n                        dangerous: tableStore.dangerousRowsIndex.includes(control.rowIndex) && tableStore.dangerousCells.length > 0\n                    }\"\n                >\n                    <ng-container *ngIf=\"!readonly && isInTable && !element?.options?.numberedColumn\">\n                        <button\n                            (mousedown)=\"onRowMouseDown($event, control.rowIndex)\"\n                            type=\"button\"\n                            [ngStyle]=\"{ height: control.height + 1 + 'px' }\"\n                            class=\"the-temp-table-row-controls-button the-temp-table-controls-button\"\n                        ></button>\n                    </ng-container>\n                    <ng-container *ngIf=\"element?.options?.numberedColumn\">\n                        <div\n                            [contentEditable]=\"false\"\n                            contenteditable=\"false\"\n                            (mousedown)=\"onRowMouseDown($event, control.rowIndex)\"\n                            class=\"the-temp-table-numbered-controls-button\"\n                            [ngStyle]=\"{ height: control.height + 1 + 'px' }\"\n                        >\n                            <p class=\"row-number d-flex align-items-center\">{{ i + 1 }}</p>\n                        </div>\n                    </ng-container>\n                    <the-table-insert-mark type=\"row\" [at]=\"control.rowIndex + 1\" [tableStore]=\"tableStore\"> </the-table-insert-mark>\n                </div>\n            </div>\n        </div>\n    </div>\n    <div class=\"the-temp-table-wrapper\" #tableWrapper [ngClass]=\"{ 'the-temp-table-numbered': element?.options?.numberedColumn }\">\n        <table class=\"the-temp-table\" #theTable [ngClass]=\"{ 'the-temp-table-with-controls': isInTable }\">\n            <colgroup *ngIf=\"columns\">\n                <col *ngFor=\"let col of columns\" [ngStyle]=\"{ width: col.width + 'px' }\" />\n            </colgroup>\n            <thead>\n                <tr class=\"the-temp-table-col-controls-wrapper\">\n                    <th\n                        class=\"the-temp-table-col-controls\"\n                        [ngClass]=\"{\n                            active: tableStore.selectedColumnsIndex.includes(i),\n                            dangerous: tableStore.dangerousColumnsIndex.includes(i) && tableStore.dangerousCells.length > 0\n                        }\"\n                        (mousedown)=\"onColMouseDown($event, i)\"\n                        *ngFor=\"let control of colControls; let i = index; trackBy: trackByFnColControls\"\n                    >\n                        <the-table-insert-mark *ngIf=\"isInTable\" type=\"column\" [at]=\"i + 1\" [tableStore]=\"tableStore\">\n                        </the-table-insert-mark>\n                    </th>\n                </tr>\n            </thead>\n            <tbody #tbody>\n                <slate-children [children]=\"children\" [context]=\"childrenContext\" [viewContext]=\"viewContext\"> </slate-children>\n            </tbody>\n        </table>\n    </div>\n</div>\n"]}
|