@atlaskit/editor-plugin-table 0.0.0 → 0.0.1
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/CHANGELOG.md +17 -0
- package/dist/cjs/plugins/table/commands/clear.js +64 -0
- package/dist/cjs/plugins/table/commands/collapse.js +24 -0
- package/dist/cjs/plugins/table/commands/go-to-next-cell.js +66 -0
- package/dist/cjs/plugins/table/commands/hover.js +183 -0
- package/dist/cjs/plugins/table/commands/index.js +235 -0
- package/dist/cjs/plugins/table/commands/insert.js +186 -0
- package/dist/cjs/plugins/table/commands/misc.js +509 -0
- package/dist/cjs/plugins/table/commands/selection.js +419 -0
- package/dist/cjs/plugins/table/commands/sort.js +94 -0
- package/dist/cjs/plugins/table/commands/split-cell.js +38 -0
- package/dist/cjs/plugins/table/commands/toggle.js +124 -0
- package/dist/cjs/plugins/table/commands-with-analytics.js +543 -0
- package/dist/cjs/plugins/table/create-plugin-config.js +31 -0
- package/dist/cjs/plugins/table/event-handlers.js +441 -0
- package/dist/cjs/plugins/table/handlers.js +155 -0
- package/dist/cjs/plugins/table/index.js +347 -0
- package/dist/cjs/plugins/table/nodeviews/OverflowShadowsObserver.js +182 -0
- package/dist/cjs/plugins/table/nodeviews/TableComponent.js +610 -0
- package/dist/cjs/plugins/table/nodeviews/table.js +261 -0
- package/dist/cjs/plugins/table/nodeviews/tableCell.js +123 -0
- package/dist/cjs/plugins/table/nodeviews/types.js +5 -0
- package/dist/cjs/plugins/table/nodeviews/update-overflow-shadows.js +67 -0
- package/dist/cjs/plugins/table/pm-plugins/decorations/plugin.js +81 -0
- package/dist/cjs/plugins/table/pm-plugins/decorations/utils/column-controls.js +88 -0
- package/dist/cjs/plugins/table/pm-plugins/decorations/utils/column-resizing.js +55 -0
- package/dist/cjs/plugins/table/pm-plugins/decorations/utils/compose-decorations.js +21 -0
- package/dist/cjs/plugins/table/pm-plugins/decorations/utils/index.js +35 -0
- package/dist/cjs/plugins/table/pm-plugins/decorations/utils/types.js +5 -0
- package/dist/cjs/plugins/table/pm-plugins/default-table-selection.js +12 -0
- package/dist/cjs/plugins/table/pm-plugins/keymap.js +59 -0
- package/dist/cjs/plugins/table/pm-plugins/main.js +308 -0
- package/dist/cjs/plugins/table/pm-plugins/plugin-factory.js +65 -0
- package/dist/cjs/plugins/table/pm-plugins/plugin-key.js +11 -0
- package/dist/cjs/plugins/table/pm-plugins/safari-delayed-dom-selection-syncing-workaround.js +79 -0
- package/dist/cjs/plugins/table/pm-plugins/safari-delete-composition-text-issue-workaround.js +118 -0
- package/dist/cjs/plugins/table/pm-plugins/sticky-headers/commands.js +30 -0
- package/dist/cjs/plugins/table/pm-plugins/sticky-headers/index.js +51 -0
- package/dist/cjs/plugins/table/pm-plugins/sticky-headers/nodeviews/dom.js +46 -0
- package/dist/cjs/plugins/table/pm-plugins/sticky-headers/nodeviews/tableRow.js +590 -0
- package/dist/cjs/plugins/table/pm-plugins/sticky-headers/plugin-key.js +11 -0
- package/dist/cjs/plugins/table/pm-plugins/sticky-headers/plugin-state.js +68 -0
- package/dist/cjs/plugins/table/pm-plugins/sticky-headers/plugin.js +34 -0
- package/dist/cjs/plugins/table/pm-plugins/sticky-headers/types.js +5 -0
- package/dist/cjs/plugins/table/pm-plugins/sticky-headers/util.js +25 -0
- package/dist/cjs/plugins/table/pm-plugins/table-local-id.js +205 -0
- package/dist/cjs/plugins/table/pm-plugins/table-resizing/commands.js +158 -0
- package/dist/cjs/plugins/table/pm-plugins/table-resizing/event-handlers.js +182 -0
- package/dist/cjs/plugins/table/pm-plugins/table-resizing/index.js +29 -0
- package/dist/cjs/plugins/table/pm-plugins/table-resizing/plugin-factory.js +40 -0
- package/dist/cjs/plugins/table/pm-plugins/table-resizing/plugin-key.js +11 -0
- package/dist/cjs/plugins/table/pm-plugins/table-resizing/plugin.js +70 -0
- package/dist/cjs/plugins/table/pm-plugins/table-resizing/reducer.js +46 -0
- package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/colgroup.js +71 -0
- package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/column-state.js +107 -0
- package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/content-width.js +112 -0
- package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/dom.js +158 -0
- package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/index.js +209 -0
- package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/misc.js +115 -0
- package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/resize-column.js +19 -0
- package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/resize-logic.js +279 -0
- package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/resize-state.js +364 -0
- package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/scale-table.js +132 -0
- package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/types.js +5 -0
- package/dist/cjs/plugins/table/pm-plugins/table-resizing/utils/unit-to-number.js +12 -0
- package/dist/cjs/plugins/table/pm-plugins/table-selection-keymap.js +23 -0
- package/dist/cjs/plugins/table/reducer.js +107 -0
- package/dist/cjs/plugins/table/todo-stubs.js +10 -0
- package/dist/cjs/plugins/table/toolbar.js +325 -0
- package/dist/cjs/plugins/table/transforms/column-width.js +196 -0
- package/dist/cjs/plugins/table/transforms/delete-columns.js +293 -0
- package/dist/cjs/plugins/table/transforms/delete-rows.js +176 -0
- package/dist/cjs/plugins/table/transforms/fix-tables.js +250 -0
- package/dist/cjs/plugins/table/transforms/index.js +85 -0
- package/dist/cjs/plugins/table/transforms/merge.js +349 -0
- package/dist/cjs/plugins/table/transforms/metadata.js +23 -0
- package/dist/cjs/plugins/table/transforms/replace-table.js +48 -0
- package/dist/cjs/plugins/table/transforms/split.js +92 -0
- package/dist/cjs/plugins/table/types.js +106 -0
- package/dist/cjs/plugins/table/ui/FloatingContextualButton/index.js +194 -0
- package/dist/cjs/plugins/table/ui/FloatingContextualButton/styles.js +26 -0
- package/dist/cjs/plugins/table/ui/FloatingContextualMenu/ContextualMenu.js +529 -0
- package/dist/cjs/plugins/table/ui/FloatingContextualMenu/index.js +116 -0
- package/dist/cjs/plugins/table/ui/FloatingContextualMenu/styles.js +34 -0
- package/dist/cjs/plugins/table/ui/FloatingDeleteButton/DeleteButton.js +49 -0
- package/dist/cjs/plugins/table/ui/FloatingDeleteButton/getPopUpOptions.js +71 -0
- package/dist/cjs/plugins/table/ui/FloatingDeleteButton/index.js +365 -0
- package/dist/cjs/plugins/table/ui/FloatingDeleteButton/types.js +5 -0
- package/dist/cjs/plugins/table/ui/FloatingInsertButton/InsertButton.js +118 -0
- package/dist/cjs/plugins/table/ui/FloatingInsertButton/getPopupOptions.js +108 -0
- package/dist/cjs/plugins/table/ui/FloatingInsertButton/index.js +244 -0
- package/dist/cjs/plugins/table/ui/LayoutButton/index.js +255 -0
- package/dist/cjs/plugins/table/ui/TableFloatingControls/CornerControls/index.js +140 -0
- package/dist/cjs/plugins/table/ui/TableFloatingControls/NumberColumn/index.js +146 -0
- package/dist/cjs/plugins/table/ui/TableFloatingControls/RowControls/index.js +135 -0
- package/dist/cjs/plugins/table/ui/TableFloatingControls/index.js +229 -0
- package/dist/cjs/plugins/table/ui/common-styles.js +48 -0
- package/dist/cjs/plugins/table/ui/consts.js +109 -0
- package/dist/cjs/plugins/table/ui/messages.js +48 -0
- package/dist/cjs/plugins/table/ui/ui-styles.js +116 -0
- package/dist/cjs/plugins/table/utils/analytics.js +86 -0
- package/dist/cjs/plugins/table/utils/collapse.js +98 -0
- package/dist/cjs/plugins/table/utils/column-controls.js +234 -0
- package/dist/cjs/plugins/table/utils/decoration.js +405 -0
- package/dist/cjs/plugins/table/utils/dom.js +224 -0
- package/dist/cjs/plugins/table/utils/get-allow-add-column-custom-step.js +13 -0
- package/dist/cjs/plugins/table/utils/index.js +355 -0
- package/dist/cjs/plugins/table/utils/nodes.js +159 -0
- package/dist/cjs/plugins/table/utils/paste.js +148 -0
- package/dist/cjs/plugins/table/utils/referentiality.js +29 -0
- package/dist/cjs/plugins/table/utils/row-controls.js +254 -0
- package/dist/cjs/plugins/table/utils/selection.js +116 -0
- package/dist/cjs/plugins/table/utils/table.js +48 -0
- package/dist/cjs/plugins/table/utils/update-plugin-state-decorations.js +16 -0
- package/dist/cjs/plugins/table-plugin.js +4 -45
- package/dist/cjs/version.json +1 -1
- package/dist/es2019/plugins/table/commands/clear.js +48 -0
- package/dist/es2019/plugins/table/commands/collapse.js +14 -0
- package/dist/es2019/plugins/table/commands/go-to-next-cell.js +47 -0
- package/dist/es2019/plugins/table/commands/hover.js +117 -0
- package/dist/es2019/plugins/table/commands/index.js +7 -0
- package/dist/es2019/plugins/table/commands/insert.js +141 -0
- package/dist/es2019/plugins/table/commands/misc.js +405 -0
- package/dist/es2019/plugins/table/commands/selection.js +369 -0
- package/dist/es2019/plugins/table/commands/sort.js +74 -0
- package/dist/es2019/plugins/table/commands/split-cell.js +29 -0
- package/dist/es2019/plugins/table/commands/toggle.js +76 -0
- package/dist/es2019/plugins/table/commands-with-analytics.js +409 -0
- package/dist/es2019/plugins/table/create-plugin-config.js +14 -0
- package/dist/es2019/plugins/table/event-handlers.js +387 -0
- package/dist/es2019/plugins/table/handlers.js +123 -0
- package/dist/es2019/plugins/table/index.js +308 -0
- package/dist/es2019/plugins/table/nodeviews/OverflowShadowsObserver.js +159 -0
- package/dist/es2019/plugins/table/nodeviews/TableComponent.js +578 -0
- package/dist/es2019/plugins/table/nodeviews/table.js +200 -0
- package/dist/es2019/plugins/table/nodeviews/tableCell.js +77 -0
- package/dist/es2019/plugins/table/nodeviews/types.js +1 -0
- package/dist/es2019/plugins/table/nodeviews/update-overflow-shadows.js +52 -0
- package/dist/es2019/plugins/table/pm-plugins/decorations/plugin.js +52 -0
- package/dist/es2019/plugins/table/pm-plugins/decorations/utils/column-controls.js +67 -0
- package/dist/es2019/plugins/table/pm-plugins/decorations/utils/column-resizing.js +27 -0
- package/dist/es2019/plugins/table/pm-plugins/decorations/utils/compose-decorations.js +7 -0
- package/dist/es2019/plugins/table/pm-plugins/decorations/utils/index.js +3 -0
- package/dist/es2019/plugins/table/pm-plugins/decorations/utils/types.js +1 -0
- package/dist/es2019/plugins/table/pm-plugins/default-table-selection.js +5 -0
- package/dist/es2019/plugins/table/pm-plugins/keymap.js +34 -0
- package/dist/es2019/plugins/table/pm-plugins/main.js +274 -0
- package/dist/es2019/plugins/table/pm-plugins/plugin-factory.js +46 -0
- package/dist/es2019/plugins/table/pm-plugins/plugin-key.js +2 -0
- package/dist/es2019/plugins/table/pm-plugins/safari-delayed-dom-selection-syncing-workaround.js +66 -0
- package/dist/es2019/plugins/table/pm-plugins/safari-delete-composition-text-issue-workaround.js +106 -0
- package/dist/es2019/plugins/table/pm-plugins/sticky-headers/commands.js +9 -0
- package/dist/es2019/plugins/table/pm-plugins/sticky-headers/index.js +5 -0
- package/dist/es2019/plugins/table/pm-plugins/sticky-headers/nodeviews/dom.js +34 -0
- package/dist/es2019/plugins/table/pm-plugins/sticky-headers/nodeviews/tableRow.js +546 -0
- package/dist/es2019/plugins/table/pm-plugins/sticky-headers/plugin-key.js +2 -0
- package/dist/es2019/plugins/table/pm-plugins/sticky-headers/plugin-state.js +47 -0
- package/dist/es2019/plugins/table/pm-plugins/sticky-headers/plugin.js +17 -0
- package/dist/es2019/plugins/table/pm-plugins/sticky-headers/types.js +1 -0
- package/dist/es2019/plugins/table/pm-plugins/sticky-headers/util.js +14 -0
- package/dist/es2019/plugins/table/pm-plugins/table-local-id.js +203 -0
- package/dist/es2019/plugins/table/pm-plugins/table-resizing/commands.js +109 -0
- package/dist/es2019/plugins/table/pm-plugins/table-resizing/event-handlers.js +173 -0
- package/dist/es2019/plugins/table/pm-plugins/table-resizing/index.js +3 -0
- package/dist/es2019/plugins/table/pm-plugins/table-resizing/plugin-factory.js +20 -0
- package/dist/es2019/plugins/table/pm-plugins/table-resizing/plugin-key.js +2 -0
- package/dist/es2019/plugins/table/pm-plugins/table-resizing/plugin.js +58 -0
- package/dist/es2019/plugins/table/pm-plugins/table-resizing/reducer.js +31 -0
- package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/colgroup.js +45 -0
- package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/column-state.js +78 -0
- package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/content-width.js +97 -0
- package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/dom.js +124 -0
- package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/index.js +9 -0
- package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/misc.js +90 -0
- package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/resize-column.js +8 -0
- package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/resize-logic.js +221 -0
- package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/resize-state.js +276 -0
- package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/scale-table.js +105 -0
- package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/types.js +1 -0
- package/dist/es2019/plugins/table/pm-plugins/table-resizing/utils/unit-to-number.js +1 -0
- package/dist/es2019/plugins/table/pm-plugins/table-selection-keymap.js +10 -0
- package/dist/es2019/plugins/table/reducer.js +103 -0
- package/dist/es2019/plugins/table/todo-stubs.js +1 -0
- package/dist/es2019/plugins/table/toolbar.js +287 -0
- package/dist/es2019/plugins/table/transforms/column-width.js +163 -0
- package/dist/es2019/plugins/table/transforms/delete-columns.js +247 -0
- package/dist/es2019/plugins/table/transforms/delete-rows.js +135 -0
- package/dist/es2019/plugins/table/transforms/fix-tables.js +218 -0
- package/dist/es2019/plugins/table/transforms/index.js +7 -0
- package/dist/es2019/plugins/table/transforms/merge.js +312 -0
- package/dist/es2019/plugins/table/transforms/metadata.js +11 -0
- package/dist/es2019/plugins/table/transforms/replace-table.js +33 -0
- package/dist/es2019/plugins/table/transforms/split.js +72 -0
- package/dist/es2019/plugins/table/types.js +84 -0
- package/dist/es2019/plugins/table/ui/FloatingContextualButton/index.js +142 -0
- package/dist/es2019/plugins/table/ui/FloatingContextualButton/styles.js +28 -0
- package/dist/es2019/plugins/table/ui/FloatingContextualMenu/ContextualMenu.js +482 -0
- package/dist/es2019/plugins/table/ui/FloatingContextualMenu/index.js +99 -0
- package/dist/es2019/plugins/table/ui/FloatingContextualMenu/styles.js +48 -0
- package/dist/es2019/plugins/table/ui/FloatingDeleteButton/DeleteButton.js +36 -0
- package/dist/es2019/plugins/table/ui/FloatingDeleteButton/getPopUpOptions.js +59 -0
- package/dist/es2019/plugins/table/ui/FloatingDeleteButton/index.js +302 -0
- package/dist/es2019/plugins/table/ui/FloatingDeleteButton/types.js +1 -0
- package/dist/es2019/plugins/table/ui/FloatingInsertButton/InsertButton.js +96 -0
- package/dist/es2019/plugins/table/ui/FloatingInsertButton/getPopupOptions.js +96 -0
- package/dist/es2019/plugins/table/ui/FloatingInsertButton/index.js +199 -0
- package/dist/es2019/plugins/table/ui/LayoutButton/index.js +195 -0
- package/dist/es2019/plugins/table/ui/TableFloatingControls/CornerControls/index.js +95 -0
- package/dist/es2019/plugins/table/ui/TableFloatingControls/NumberColumn/index.js +91 -0
- package/dist/es2019/plugins/table/ui/TableFloatingControls/RowControls/index.js +82 -0
- package/dist/es2019/plugins/table/ui/TableFloatingControls/index.js +158 -0
- package/dist/es2019/plugins/table/ui/common-styles.js +647 -0
- package/dist/es2019/plugins/table/ui/consts.js +61 -0
- package/dist/es2019/plugins/table/ui/messages.js +38 -0
- package/dist/es2019/plugins/table/ui/ui-styles.js +398 -0
- package/dist/es2019/plugins/table/utils/analytics.js +65 -0
- package/dist/es2019/plugins/table/utils/collapse.js +84 -0
- package/dist/es2019/plugins/table/utils/column-controls.js +178 -0
- package/dist/es2019/plugins/table/utils/decoration.js +346 -0
- package/dist/es2019/plugins/table/utils/dom.js +160 -0
- package/dist/es2019/plugins/table/utils/get-allow-add-column-custom-step.js +5 -0
- package/dist/es2019/plugins/table/utils/index.js +10 -0
- package/dist/es2019/plugins/table/utils/nodes.js +104 -0
- package/dist/es2019/plugins/table/utils/paste.js +117 -0
- package/dist/es2019/plugins/table/utils/referentiality.js +18 -0
- package/dist/es2019/plugins/table/utils/row-controls.js +210 -0
- package/dist/es2019/plugins/table/utils/selection.js +95 -0
- package/dist/es2019/plugins/table/utils/table.js +27 -0
- package/dist/es2019/plugins/table/utils/update-plugin-state-decorations.js +3 -0
- package/dist/es2019/plugins/table-plugin.js +1 -44
- package/dist/es2019/version.json +1 -1
- package/dist/esm/plugins/table/commands/clear.js +48 -0
- package/dist/esm/plugins/table/commands/collapse.js +14 -0
- package/dist/esm/plugins/table/commands/go-to-next-cell.js +50 -0
- package/dist/esm/plugins/table/commands/hover.js +149 -0
- package/dist/esm/plugins/table/commands/index.js +7 -0
- package/dist/esm/plugins/table/commands/insert.js +153 -0
- package/dist/esm/plugins/table/commands/misc.js +427 -0
- package/dist/esm/plugins/table/commands/selection.js +401 -0
- package/dist/esm/plugins/table/commands/sort.js +79 -0
- package/dist/esm/plugins/table/commands/split-cell.js +28 -0
- package/dist/esm/plugins/table/commands/toggle.js +97 -0
- package/dist/esm/plugins/table/commands-with-analytics.js +464 -0
- package/dist/esm/plugins/table/create-plugin-config.js +20 -0
- package/dist/esm/plugins/table/event-handlers.js +387 -0
- package/dist/esm/plugins/table/handlers.js +140 -0
- package/dist/esm/plugins/table/index.js +312 -0
- package/dist/esm/plugins/table/nodeviews/OverflowShadowsObserver.js +177 -0
- package/dist/esm/plugins/table/nodeviews/TableComponent.js +596 -0
- package/dist/esm/plugins/table/nodeviews/table.js +235 -0
- package/dist/esm/plugins/table/nodeviews/tableCell.js +111 -0
- package/dist/esm/plugins/table/nodeviews/types.js +1 -0
- package/dist/esm/plugins/table/nodeviews/update-overflow-shadows.js +54 -0
- package/dist/esm/plugins/table/pm-plugins/decorations/plugin.js +58 -0
- package/dist/esm/plugins/table/pm-plugins/decorations/utils/column-controls.js +71 -0
- package/dist/esm/plugins/table/pm-plugins/decorations/utils/column-resizing.js +40 -0
- package/dist/esm/plugins/table/pm-plugins/decorations/utils/compose-decorations.js +12 -0
- package/dist/esm/plugins/table/pm-plugins/decorations/utils/index.js +3 -0
- package/dist/esm/plugins/table/pm-plugins/decorations/utils/types.js +1 -0
- package/dist/esm/plugins/table/pm-plugins/default-table-selection.js +5 -0
- package/dist/esm/plugins/table/pm-plugins/keymap.js +36 -0
- package/dist/esm/plugins/table/pm-plugins/main.js +278 -0
- package/dist/esm/plugins/table/pm-plugins/plugin-factory.js +51 -0
- package/dist/esm/plugins/table/pm-plugins/plugin-key.js +2 -0
- package/dist/esm/plugins/table/pm-plugins/safari-delayed-dom-selection-syncing-workaround.js +66 -0
- package/dist/esm/plugins/table/pm-plugins/safari-delete-composition-text-issue-workaround.js +102 -0
- package/dist/esm/plugins/table/pm-plugins/sticky-headers/commands.js +17 -0
- package/dist/esm/plugins/table/pm-plugins/sticky-headers/index.js +5 -0
- package/dist/esm/plugins/table/pm-plugins/sticky-headers/nodeviews/dom.js +34 -0
- package/dist/esm/plugins/table/pm-plugins/sticky-headers/nodeviews/tableRow.js +588 -0
- package/dist/esm/plugins/table/pm-plugins/sticky-headers/plugin-key.js +2 -0
- package/dist/esm/plugins/table/pm-plugins/sticky-headers/plugin-state.js +57 -0
- package/dist/esm/plugins/table/pm-plugins/sticky-headers/plugin.js +21 -0
- package/dist/esm/plugins/table/pm-plugins/sticky-headers/types.js +1 -0
- package/dist/esm/plugins/table/pm-plugins/sticky-headers/util.js +16 -0
- package/dist/esm/plugins/table/pm-plugins/table-local-id.js +205 -0
- package/dist/esm/plugins/table/pm-plugins/table-resizing/commands.js +127 -0
- package/dist/esm/plugins/table/pm-plugins/table-resizing/event-handlers.js +159 -0
- package/dist/esm/plugins/table/pm-plugins/table-resizing/index.js +3 -0
- package/dist/esm/plugins/table/pm-plugins/table-resizing/plugin-factory.js +26 -0
- package/dist/esm/plugins/table/pm-plugins/table-resizing/plugin-key.js +2 -0
- package/dist/esm/plugins/table/pm-plugins/table-resizing/plugin.js +52 -0
- package/dist/esm/plugins/table/pm-plugins/table-resizing/reducer.js +35 -0
- package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/colgroup.js +50 -0
- package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/column-state.js +80 -0
- package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/content-width.js +104 -0
- package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/dom.js +125 -0
- package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/index.js +9 -0
- package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/misc.js +88 -0
- package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/resize-column.js +8 -0
- package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/resize-logic.js +257 -0
- package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/resize-state.js +320 -0
- package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/scale-table.js +109 -0
- package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/types.js +1 -0
- package/dist/esm/plugins/table/pm-plugins/table-resizing/utils/unit-to-number.js +3 -0
- package/dist/esm/plugins/table/pm-plugins/table-selection-keymap.js +10 -0
- package/dist/esm/plugins/table/reducer.js +95 -0
- package/dist/esm/plugins/table/todo-stubs.js +1 -0
- package/dist/esm/plugins/table/toolbar.js +290 -0
- package/dist/esm/plugins/table/transforms/column-width.js +175 -0
- package/dist/esm/plugins/table/transforms/delete-columns.js +271 -0
- package/dist/esm/plugins/table/transforms/delete-rows.js +156 -0
- package/dist/esm/plugins/table/transforms/fix-tables.js +229 -0
- package/dist/esm/plugins/table/transforms/index.js +7 -0
- package/dist/esm/plugins/table/transforms/merge.js +324 -0
- package/dist/esm/plugins/table/transforms/metadata.js +13 -0
- package/dist/esm/plugins/table/transforms/replace-table.js +34 -0
- package/dist/esm/plugins/table/transforms/split.js +82 -0
- package/dist/esm/plugins/table/types.js +90 -0
- package/dist/esm/plugins/table/ui/FloatingContextualButton/index.js +167 -0
- package/dist/esm/plugins/table/ui/FloatingContextualButton/styles.js +11 -0
- package/dist/esm/plugins/table/ui/FloatingContextualMenu/ContextualMenu.js +501 -0
- package/dist/esm/plugins/table/ui/FloatingContextualMenu/index.js +96 -0
- package/dist/esm/plugins/table/ui/FloatingContextualMenu/styles.js +15 -0
- package/dist/esm/plugins/table/ui/FloatingDeleteButton/DeleteButton.js +37 -0
- package/dist/esm/plugins/table/ui/FloatingDeleteButton/getPopUpOptions.js +61 -0
- package/dist/esm/plugins/table/ui/FloatingDeleteButton/index.js +333 -0
- package/dist/esm/plugins/table/ui/FloatingDeleteButton/types.js +1 -0
- package/dist/esm/plugins/table/ui/FloatingInsertButton/InsertButton.js +90 -0
- package/dist/esm/plugins/table/ui/FloatingInsertButton/getPopupOptions.js +96 -0
- package/dist/esm/plugins/table/ui/FloatingInsertButton/index.js +214 -0
- package/dist/esm/plugins/table/ui/LayoutButton/index.js +227 -0
- package/dist/esm/plugins/table/ui/TableFloatingControls/CornerControls/index.js +120 -0
- package/dist/esm/plugins/table/ui/TableFloatingControls/NumberColumn/index.js +126 -0
- package/dist/esm/plugins/table/ui/TableFloatingControls/RowControls/index.js +113 -0
- package/dist/esm/plugins/table/ui/TableFloatingControls/index.js +207 -0
- package/dist/esm/plugins/table/ui/common-styles.js +25 -0
- package/dist/esm/plugins/table/ui/consts.js +61 -0
- package/dist/esm/plugins/table/ui/messages.js +38 -0
- package/dist/esm/plugins/table/ui/ui-styles.js +73 -0
- package/dist/esm/plugins/table/utils/analytics.js +71 -0
- package/dist/esm/plugins/table/utils/collapse.js +84 -0
- package/dist/esm/plugins/table/utils/column-controls.js +202 -0
- package/dist/esm/plugins/table/utils/decoration.js +366 -0
- package/dist/esm/plugins/table/utils/dom.js +175 -0
- package/dist/esm/plugins/table/utils/get-allow-add-column-custom-step.js +5 -0
- package/dist/esm/plugins/table/utils/index.js +10 -0
- package/dist/esm/plugins/table/utils/nodes.js +112 -0
- package/dist/esm/plugins/table/utils/paste.js +115 -0
- package/dist/esm/plugins/table/utils/referentiality.js +20 -0
- package/dist/esm/plugins/table/utils/row-controls.js +221 -0
- package/dist/esm/plugins/table/utils/selection.js +96 -0
- package/dist/esm/plugins/table/utils/table.js +30 -0
- package/dist/esm/plugins/table/utils/update-plugin-state-decorations.js +5 -0
- package/dist/esm/plugins/table-plugin.js +1 -42
- package/dist/esm/version.json +1 -1
- package/dist/types/plugins/table/commands/clear.d.ts +3 -0
- package/dist/types/plugins/table/commands/collapse.d.ts +2 -0
- package/dist/types/plugins/table/commands/go-to-next-cell.d.ts +4 -0
- package/dist/types/plugins/table/commands/hover.d.ts +8 -0
- package/dist/types/plugins/table/commands/index.d.ts +7 -0
- package/dist/types/plugins/table/commands/insert.d.ts +10 -0
- package/dist/types/plugins/table/commands/misc.d.ts +27 -0
- package/dist/types/plugins/table/commands/selection.d.ts +8 -0
- package/dist/types/plugins/table/commands/sort.d.ts +3 -0
- package/dist/types/plugins/table/commands/split-cell.d.ts +6 -0
- package/dist/types/plugins/table/commands/toggle.d.ts +12 -0
- package/dist/types/plugins/table/commands-with-analytics.d.ts +26 -0
- package/dist/types/plugins/table/create-plugin-config.d.ts +2 -0
- package/dist/types/plugins/table/event-handlers.d.ts +16 -0
- package/dist/types/plugins/table/handlers.d.ts +3 -0
- package/dist/types/plugins/table/index.d.ts +18 -0
- package/dist/types/plugins/table/nodeviews/OverflowShadowsObserver.d.ts +26 -0
- package/dist/types/plugins/table/nodeviews/TableComponent.d.ts +72 -0
- package/dist/types/plugins/table/nodeviews/__mocks__/OverflowShadowsObserver.d.ts +9 -0
- package/dist/types/plugins/table/nodeviews/__mocks__/OverridableMock.d.ts +9 -0
- package/dist/types/plugins/table/nodeviews/table.d.ts +31 -0
- package/dist/types/plugins/table/nodeviews/tableCell.d.ts +19 -0
- package/dist/types/plugins/table/nodeviews/types.d.ts +23 -0
- package/dist/types/plugins/table/nodeviews/update-overflow-shadows.d.ts +8 -0
- package/dist/types/plugins/table/pm-plugins/decorations/plugin.d.ts +7 -0
- package/dist/types/plugins/table/pm-plugins/decorations/utils/column-controls.d.ts +3 -0
- package/dist/types/plugins/table/pm-plugins/decorations/utils/column-resizing.d.ts +2 -0
- package/dist/types/plugins/table/pm-plugins/decorations/utils/compose-decorations.d.ts +2 -0
- package/dist/types/plugins/table/pm-plugins/decorations/utils/index.d.ts +3 -0
- package/dist/types/plugins/table/pm-plugins/decorations/utils/types.d.ts +6 -0
- package/dist/types/plugins/table/pm-plugins/default-table-selection.d.ts +5 -0
- package/dist/types/plugins/table/pm-plugins/keymap.d.ts +5 -0
- package/dist/types/plugins/table/pm-plugins/main.d.ts +8 -0
- package/dist/types/plugins/table/pm-plugins/plugin-factory.d.ts +1 -0
- package/dist/types/plugins/table/pm-plugins/plugin-key.d.ts +3 -0
- package/dist/types/plugins/table/pm-plugins/safari-delayed-dom-selection-syncing-workaround.d.ts +4 -0
- package/dist/types/plugins/table/pm-plugins/safari-delete-composition-text-issue-workaround.d.ts +15 -0
- package/dist/types/plugins/table/pm-plugins/sticky-headers/commands.d.ts +3 -0
- package/dist/types/plugins/table/pm-plugins/sticky-headers/index.d.ts +6 -0
- package/dist/types/plugins/table/pm-plugins/sticky-headers/nodeviews/dom.d.ts +6 -0
- package/dist/types/plugins/table/pm-plugins/sticky-headers/nodeviews/tableRow.d.ts +65 -0
- package/dist/types/plugins/table/pm-plugins/sticky-headers/plugin-key.d.ts +3 -0
- package/dist/types/plugins/table/pm-plugins/sticky-headers/plugin-state.d.ts +3 -0
- package/dist/types/plugins/table/pm-plugins/sticky-headers/plugin.d.ts +4 -0
- package/dist/types/plugins/table/pm-plugins/sticky-headers/types.d.ts +16 -0
- package/dist/types/plugins/table/pm-plugins/sticky-headers/util.d.ts +2 -0
- package/dist/types/plugins/table/pm-plugins/table-local-id.d.ts +22 -0
- package/dist/types/plugins/table/pm-plugins/table-resizing/commands.d.ts +25 -0
- package/dist/types/plugins/table/pm-plugins/table-resizing/event-handlers.d.ts +4 -0
- package/dist/types/plugins/table/pm-plugins/table-resizing/index.d.ts +3 -0
- package/dist/types/plugins/table/pm-plugins/table-resizing/plugin-factory.d.ts +4 -0
- package/dist/types/plugins/table/pm-plugins/table-resizing/plugin-key.d.ts +3 -0
- package/dist/types/plugins/table/pm-plugins/table-resizing/plugin.d.ts +6 -0
- package/dist/types/plugins/table/pm-plugins/table-resizing/reducer.d.ts +3 -0
- package/dist/types/plugins/table/pm-plugins/table-resizing/utils/colgroup.d.ts +8 -0
- package/dist/types/plugins/table/pm-plugins/table-resizing/utils/column-state.d.ts +14 -0
- package/dist/types/plugins/table/pm-plugins/table-resizing/utils/content-width.d.ts +4 -0
- package/dist/types/plugins/table/pm-plugins/table-resizing/utils/dom.d.ts +13 -0
- package/dist/types/plugins/table/pm-plugins/table-resizing/utils/index.d.ts +12 -0
- package/dist/types/plugins/table/pm-plugins/table-resizing/utils/misc.d.ts +22 -0
- package/dist/types/plugins/table/pm-plugins/table-resizing/utils/resize-column.d.ts +2 -0
- package/dist/types/plugins/table/pm-plugins/table-resizing/utils/resize-logic.d.ts +4 -0
- package/dist/types/plugins/table/pm-plugins/table-resizing/utils/resize-state.d.ts +29 -0
- package/dist/types/plugins/table/pm-plugins/table-resizing/utils/scale-table.d.ts +17 -0
- package/dist/types/plugins/table/pm-plugins/table-resizing/utils/types.d.ts +22 -0
- package/dist/types/plugins/table/pm-plugins/table-resizing/utils/unit-to-number.d.ts +1 -0
- package/dist/types/plugins/table/pm-plugins/table-selection-keymap.d.ts +4 -0
- package/dist/types/plugins/table/reducer.d.ts +3 -0
- package/dist/types/plugins/table/todo-stubs.d.ts +1 -0
- package/dist/types/plugins/table/toolbar.d.ts +36 -0
- package/dist/types/plugins/table/transforms/column-width.d.ts +18 -0
- package/dist/types/plugins/table/transforms/delete-columns.d.ts +3 -0
- package/dist/types/plugins/table/transforms/delete-rows.d.ts +3 -0
- package/dist/types/plugins/table/transforms/fix-tables.d.ts +10 -0
- package/dist/types/plugins/table/transforms/index.d.ts +7 -0
- package/dist/types/plugins/table/transforms/merge.d.ts +5 -0
- package/dist/types/plugins/table/transforms/metadata.d.ts +21 -0
- package/dist/types/plugins/table/transforms/replace-table.d.ts +5 -0
- package/dist/types/plugins/table/transforms/split.d.ts +9 -0
- package/dist/types/plugins/table/types.d.ts +328 -0
- package/dist/types/plugins/table/ui/FloatingContextualButton/index.d.ts +29 -0
- package/dist/types/plugins/table/ui/FloatingContextualButton/styles.d.ts +1 -0
- package/dist/types/plugins/table/ui/FloatingContextualMenu/ContextualMenu.d.ts +87 -0
- package/dist/types/plugins/table/ui/FloatingContextualMenu/index.d.ts +22 -0
- package/dist/types/plugins/table/ui/FloatingContextualMenu/styles.d.ts +2 -0
- package/dist/types/plugins/table/ui/FloatingDeleteButton/DeleteButton.d.ts +14 -0
- package/dist/types/plugins/table/ui/FloatingDeleteButton/getPopUpOptions.d.ts +10 -0
- package/dist/types/plugins/table/ui/FloatingDeleteButton/index.d.ts +54 -0
- package/dist/types/plugins/table/ui/FloatingDeleteButton/types.d.ts +1 -0
- package/dist/types/plugins/table/ui/FloatingInsertButton/InsertButton.d.ts +12 -0
- package/dist/types/plugins/table/ui/FloatingInsertButton/getPopupOptions.d.ts +3 -0
- package/dist/types/plugins/table/ui/FloatingInsertButton/index.d.ts +35 -0
- package/dist/types/plugins/table/ui/LayoutButton/index.d.ts +21 -0
- package/dist/types/plugins/table/ui/TableFloatingControls/CornerControls/index.d.ts +19 -0
- package/dist/types/plugins/table/ui/TableFloatingControls/NumberColumn/index.d.ts +21 -0
- package/dist/types/plugins/table/ui/TableFloatingControls/RowControls/index.d.ts +17 -0
- package/dist/types/plugins/table/ui/TableFloatingControls/index.d.ts +40 -0
- package/dist/types/plugins/table/ui/common-styles.d.ts +4 -0
- package/dist/types/plugins/table/ui/consts.d.ts +39 -0
- package/dist/types/plugins/table/ui/messages.d.ts +38 -0
- package/dist/types/plugins/table/ui/ui-styles.d.ts +15 -0
- package/dist/types/plugins/table/utils/analytics.d.ts +18 -0
- package/dist/types/plugins/table/utils/collapse.d.ts +29 -0
- package/dist/types/plugins/table/utils/column-controls.d.ts +10 -0
- package/dist/types/plugins/table/utils/decoration.d.ts +13 -0
- package/dist/types/plugins/table/utils/dom.d.ts +17 -0
- package/dist/types/plugins/table/utils/get-allow-add-column-custom-step.d.ts +2 -0
- package/dist/types/plugins/table/utils/index.d.ts +11 -0
- package/dist/types/plugins/table/utils/nodes.d.ts +12 -0
- package/dist/types/plugins/table/utils/paste.d.ts +14 -0
- package/dist/types/plugins/table/utils/referentiality.d.ts +2 -0
- package/dist/types/plugins/table/utils/row-controls.d.ts +16 -0
- package/dist/types/plugins/table/utils/selection.d.ts +6 -0
- package/dist/types/plugins/table/utils/table.d.ts +4 -0
- package/dist/types/plugins/table/utils/update-plugin-state-decorations.d.ts +4 -0
- package/dist/types/plugins/table-plugin.d.ts +1 -1
- package/package.json +27 -5
- package/report.api.md +50 -1
- package/src/plugins/table/__tests__/integration/block-node-selection.ts +164 -0
- package/src/plugins/table/__tests__/unit/commands/go-to-next-cell.ts +155 -0
- package/src/plugins/table/__tests__/unit/commands/insert.ts +116 -0
- package/src/plugins/table/__tests__/unit/commands/misc.ts +165 -0
- package/src/plugins/table/__tests__/unit/commands.ts +982 -0
- package/src/plugins/table/__tests__/unit/event-handlers.ts +130 -0
- package/src/plugins/table/__tests__/unit/get-toolbar-config.ts +140 -0
- package/src/plugins/table/__tests__/unit/nodeviews/OverflowShadowsObserver.ts +153 -0
- package/src/plugins/table/__tests__/unit/nodeviews/TableComponent.tsx +388 -0
- package/src/plugins/table/__tests__/unit/nodeviews/table.ts +121 -0
- package/src/plugins/table/__tests__/unit/pm-plugins/decorations/column-controls.ts +34 -0
- package/src/plugins/table/__tests__/unit/pm-plugins/decorations/column-resizing.ts +152 -0
- package/src/plugins/table/__tests__/unit/pm-plugins/decorations/plugin.ts +140 -0
- package/src/plugins/table/__tests__/unit/pm-plugins/main-with-allow-collapse.ts +100 -0
- package/src/plugins/table/__tests__/unit/pm-plugins/main.ts +187 -0
- package/src/plugins/table/__tests__/unit/pm-plugins/safari-delete-composition-text-issue-workaround.ts +83 -0
- package/src/plugins/table/__tests__/unit/pm-plugins/sticky-headers/tableRow.tsx +603 -0
- package/src/plugins/table/__tests__/unit/pm-plugins/table-local-id.ts +515 -0
- package/src/plugins/table/__tests__/unit/pm-plugins/table-resizing/colgroup.ts +86 -0
- package/src/plugins/table/__tests__/unit/pm-plugins/table-resizing/event-handlers.ts +132 -0
- package/src/plugins/table/__tests__/unit/pm-plugins/table-selection-keymap.ts +564 -0
- package/src/plugins/table/__tests__/unit/toolbar.ts +240 -0
- package/src/plugins/table/__tests__/unit/utils/collapse.ts +74 -0
- package/src/plugins/table/__tests__/unit/utils/column-controls.ts +61 -0
- package/src/plugins/table/__tests__/visual-regression/__fixtures__/table-with-100-numbered-list-items.json +20272 -0
- package/src/plugins/table/__tests__/visual-regression/__image_snapshots__/cell-options-menu-ts-table-cell-options-menu-delete-column-menu-item-should-remove-the-table-column-on-click-1-snap.png +3 -0
- package/src/plugins/table/__tests__/visual-regression/__image_snapshots__/cell-options-menu-ts-table-cell-options-menu-delete-column-menu-item-visual-hints-should-be-added-to-the-table-column-on-hover-1-snap.png +3 -0
- package/src/plugins/table/__tests__/visual-regression/__image_snapshots__/cell-options-menu-ts-table-cell-options-menu-delete-row-menu-item-should-remove-the-table-row-on-click-1-snap.png +3 -0
- package/src/plugins/table/__tests__/visual-regression/__image_snapshots__/cell-options-menu-ts-table-cell-options-menu-delete-row-menu-item-visual-hints-should-be-added-to-the-table-row-on-hover-1-snap.png +3 -0
- package/src/plugins/table/__tests__/visual-regression/__image_snapshots__/copy-button-ts-floating-toolbar-copy-button-table-target-node-displays-blue-border-when-copy-button-is-hovered-1-snap.png +3 -0
- package/src/plugins/table/__tests__/visual-regression/__image_snapshots__/index-ts-snapshot-test-table-numbered-list-should-not-overflow-table-cell-when-there-are-more-than-100-ordered-list-items-1-snap.png +3 -0
- package/src/plugins/table/__tests__/visual-regression/__image_snapshots__/index-ts-snapshot-test-table-numbered-list-should-not-overflow-table-cell-when-there-are-more-than-100-ordered-list-items-2-snap.png +3 -0
- package/src/plugins/table/__tests__/visual-regression/__image_snapshots__/index-ts-snapshot-test-table-numbered-list-should-not-overflow-table-cell-when-there-are-more-than-100-ordered-list-items-3-snap.png +3 -0
- package/src/plugins/table/__tests__/visual-regression/cell-options-menu.ts +97 -0
- package/src/plugins/table/__tests__/visual-regression/index.ts +42 -0
- package/src/plugins/table/commands/clear.ts +58 -0
- package/src/plugins/table/commands/collapse.ts +16 -0
- package/src/plugins/table/commands/go-to-next-cell.ts +56 -0
- package/src/plugins/table/commands/hover.ts +192 -0
- package/src/plugins/table/commands/index.ts +40 -0
- package/src/plugins/table/commands/insert.ts +174 -0
- package/src/plugins/table/commands/misc.ts +506 -0
- package/src/plugins/table/commands/selection.ts +406 -0
- package/src/plugins/table/commands/sort.ts +109 -0
- package/src/plugins/table/commands/split-cell.ts +28 -0
- package/src/plugins/table/commands/toggle.ts +93 -0
- package/src/plugins/table/commands-with-analytics.ts +523 -0
- package/src/plugins/table/create-plugin-config.ts +18 -0
- package/src/plugins/table/event-handlers.ts +514 -0
- package/src/plugins/table/handlers.ts +169 -0
- package/src/plugins/table/index.tsx +413 -0
- package/src/plugins/table/nodeviews/OverflowShadowsObserver.ts +189 -0
- package/src/plugins/table/nodeviews/TableComponent.tsx +693 -0
- package/src/plugins/table/nodeviews/__mocks__/OverflowShadowsObserver.ts +13 -0
- package/src/plugins/table/nodeviews/__mocks__/OverridableMock.ts +21 -0
- package/src/plugins/table/nodeviews/table.tsx +241 -0
- package/src/plugins/table/nodeviews/tableCell.tsx +110 -0
- package/src/plugins/table/nodeviews/types.ts +29 -0
- package/src/plugins/table/nodeviews/update-overflow-shadows.ts +72 -0
- package/src/plugins/table/pm-plugins/decorations/plugin.ts +74 -0
- package/src/plugins/table/pm-plugins/decorations/utils/column-controls.ts +89 -0
- package/src/plugins/table/pm-plugins/decorations/utils/column-resizing.ts +46 -0
- package/src/plugins/table/pm-plugins/decorations/utils/compose-decorations.ts +11 -0
- package/src/plugins/table/pm-plugins/decorations/utils/index.ts +6 -0
- package/src/plugins/table/pm-plugins/decorations/utils/types.ts +10 -0
- package/src/plugins/table/pm-plugins/default-table-selection.ts +5 -0
- package/src/plugins/table/pm-plugins/keymap.ts +108 -0
- package/src/plugins/table/pm-plugins/main.ts +399 -0
- package/src/plugins/table/pm-plugins/plugin-factory.ts +43 -0
- package/src/plugins/table/pm-plugins/plugin-key.ts +4 -0
- package/src/plugins/table/pm-plugins/safari-delayed-dom-selection-syncing-workaround.ts +78 -0
- package/src/plugins/table/pm-plugins/safari-delete-composition-text-issue-workaround.ts +118 -0
- package/src/plugins/table/pm-plugins/sticky-headers/commands.ts +12 -0
- package/src/plugins/table/pm-plugins/sticky-headers/index.ts +7 -0
- package/src/plugins/table/pm-plugins/sticky-headers/nodeviews/dom.ts +37 -0
- package/src/plugins/table/pm-plugins/sticky-headers/nodeviews/tableRow.ts +658 -0
- package/src/plugins/table/pm-plugins/sticky-headers/plugin-key.ts +6 -0
- package/src/plugins/table/pm-plugins/sticky-headers/plugin-state.ts +55 -0
- package/src/plugins/table/pm-plugins/sticky-headers/plugin.ts +36 -0
- package/src/plugins/table/pm-plugins/sticky-headers/types.ts +20 -0
- package/src/plugins/table/pm-plugins/sticky-headers/util.ts +18 -0
- package/src/plugins/table/pm-plugins/table-local-id.ts +203 -0
- package/src/plugins/table/pm-plugins/table-resizing/commands.ts +168 -0
- package/src/plugins/table/pm-plugins/table-resizing/event-handlers.ts +218 -0
- package/src/plugins/table/pm-plugins/table-resizing/index.ts +3 -0
- package/src/plugins/table/pm-plugins/table-resizing/plugin-factory.ts +28 -0
- package/src/plugins/table/pm-plugins/table-resizing/plugin-key.ts +6 -0
- package/src/plugins/table/pm-plugins/table-resizing/plugin.ts +79 -0
- package/src/plugins/table/pm-plugins/table-resizing/reducer.ts +40 -0
- package/src/plugins/table/pm-plugins/table-resizing/utils/colgroup.ts +58 -0
- package/src/plugins/table/pm-plugins/table-resizing/utils/column-state.ts +122 -0
- package/src/plugins/table/pm-plugins/table-resizing/utils/content-width.ts +130 -0
- package/src/plugins/table/pm-plugins/table-resizing/utils/dom.ts +176 -0
- package/src/plugins/table/pm-plugins/table-resizing/utils/index.ts +37 -0
- package/src/plugins/table/pm-plugins/table-resizing/utils/misc.ts +136 -0
- package/src/plugins/table/pm-plugins/table-resizing/utils/resize-column.ts +23 -0
- package/src/plugins/table/pm-plugins/table-resizing/utils/resize-logic.ts +275 -0
- package/src/plugins/table/pm-plugins/table-resizing/utils/resize-state.ts +348 -0
- package/src/plugins/table/pm-plugins/table-resizing/utils/scale-table.ts +142 -0
- package/src/plugins/table/pm-plugins/table-resizing/utils/types.ts +23 -0
- package/src/plugins/table/pm-plugins/table-resizing/utils/unit-to-number.ts +2 -0
- package/src/plugins/table/pm-plugins/table-selection-keymap.ts +32 -0
- package/src/plugins/table/reducer.ts +106 -0
- package/src/plugins/table/todo-stubs.ts +1 -0
- package/src/plugins/table/toolbar.ts +401 -0
- package/src/plugins/table/transforms/column-width.ts +187 -0
- package/src/plugins/table/transforms/delete-columns.ts +251 -0
- package/src/plugins/table/transforms/delete-rows.ts +150 -0
- package/src/plugins/table/transforms/fix-tables.ts +296 -0
- package/src/plugins/table/transforms/index.ts +7 -0
- package/src/plugins/table/transforms/merge.ts +312 -0
- package/src/plugins/table/transforms/metadata.ts +35 -0
- package/src/plugins/table/transforms/replace-table.ts +48 -0
- package/src/plugins/table/transforms/split.ts +99 -0
- package/src/plugins/table/types.ts +345 -0
- package/src/plugins/table/ui/FloatingContextualButton/index.tsx +196 -0
- package/src/plugins/table/ui/FloatingContextualButton/styles.ts +29 -0
- package/src/plugins/table/ui/FloatingContextualMenu/ContextualMenu.tsx +524 -0
- package/src/plugins/table/ui/FloatingContextualMenu/__tests__/ContextualMenu.tsx +55 -0
- package/src/plugins/table/ui/FloatingContextualMenu/__tests__/FloatingContextualMenu.tsx +49 -0
- package/src/plugins/table/ui/FloatingContextualMenu/index.tsx +131 -0
- package/src/plugins/table/ui/FloatingContextualMenu/styles.ts +53 -0
- package/src/plugins/table/ui/FloatingDeleteButton/DeleteButton.tsx +49 -0
- package/src/plugins/table/ui/FloatingDeleteButton/getPopUpOptions.ts +75 -0
- package/src/plugins/table/ui/FloatingDeleteButton/index.tsx +384 -0
- package/src/plugins/table/ui/FloatingDeleteButton/types.ts +1 -0
- package/src/plugins/table/ui/FloatingInsertButton/InsertButton.tsx +132 -0
- package/src/plugins/table/ui/FloatingInsertButton/getPopupOptions.ts +122 -0
- package/src/plugins/table/ui/FloatingInsertButton/index.tsx +268 -0
- package/src/plugins/table/ui/LayoutButton/index.tsx +220 -0
- package/src/plugins/table/ui/TableFloatingControls/CornerControls/index.tsx +105 -0
- package/src/plugins/table/ui/TableFloatingControls/NumberColumn/index.tsx +108 -0
- package/src/plugins/table/ui/TableFloatingControls/RowControls/index.tsx +119 -0
- package/src/plugins/table/ui/TableFloatingControls/index.tsx +202 -0
- package/src/plugins/table/ui/common-styles.ts +726 -0
- package/src/plugins/table/ui/consts.ts +100 -0
- package/src/plugins/table/ui/messages.ts +43 -0
- package/src/plugins/table/ui/ui-styles.ts +459 -0
- package/src/plugins/table/utils/analytics.ts +81 -0
- package/src/plugins/table/utils/collapse.ts +99 -0
- package/src/plugins/table/utils/column-controls.ts +225 -0
- package/src/plugins/table/utils/decoration.ts +456 -0
- package/src/plugins/table/utils/dom.ts +211 -0
- package/src/plugins/table/utils/get-allow-add-column-custom-step.ts +11 -0
- package/src/plugins/table/utils/index.ts +69 -0
- package/src/plugins/table/utils/nodes.ts +140 -0
- package/src/plugins/table/utils/paste.ts +164 -0
- package/src/plugins/table/utils/referentiality.ts +24 -0
- package/src/plugins/table/utils/row-controls.ts +238 -0
- package/src/plugins/table/utils/selection.ts +107 -0
- package/src/plugins/table/utils/table.ts +31 -0
- package/src/plugins/table/utils/update-plugin-state-decorations.ts +14 -0
- package/src/plugins/table-plugin.ts +1 -38
|
@@ -0,0 +1,220 @@
|
|
|
1
|
+
import React, { createRef } from 'react';
|
|
2
|
+
|
|
3
|
+
import classnames from 'classnames';
|
|
4
|
+
import { EditorView } from 'prosemirror-view';
|
|
5
|
+
import { WrappedComponentProps, injectIntl } from 'react-intl-next';
|
|
6
|
+
|
|
7
|
+
import { TableLayout } from '@atlaskit/adf-schema';
|
|
8
|
+
import { Popup } from '@atlaskit/editor-common/ui';
|
|
9
|
+
import type { PopupPosition } from '@atlaskit/editor-common/ui';
|
|
10
|
+
import CollapseIcon from '@atlaskit/icon/glyph/editor/collapse';
|
|
11
|
+
import ExpandIcon from '@atlaskit/icon/glyph/editor/expand';
|
|
12
|
+
|
|
13
|
+
import commonMessages from '@atlaskit/editor-common/messages';
|
|
14
|
+
import { ToolbarButton } from '@atlaskit/editor-common/ui-menu';
|
|
15
|
+
import { toggleTableLayoutWithAnalytics } from '../../commands-with-analytics';
|
|
16
|
+
import { TableCssClassName as ClassName } from '../../types';
|
|
17
|
+
import { RowStickyState } from '../../pm-plugins/sticky-headers';
|
|
18
|
+
import { findDomRefAtPos } from 'prosemirror-utils';
|
|
19
|
+
import type { EditorAnalyticsAPI } from '@atlaskit/editor-common/analytics';
|
|
20
|
+
|
|
21
|
+
export interface Props {
|
|
22
|
+
editorView: EditorView;
|
|
23
|
+
targetRef?: HTMLElement;
|
|
24
|
+
mountPoint?: HTMLElement;
|
|
25
|
+
boundariesElement?: HTMLElement;
|
|
26
|
+
scrollableElement?: HTMLElement;
|
|
27
|
+
isResizing?: boolean;
|
|
28
|
+
layout?: TableLayout;
|
|
29
|
+
stickyHeader?: RowStickyState;
|
|
30
|
+
editorAnalyticsAPI?: EditorAnalyticsAPI;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
const addPopupOffset = (pos: PopupPosition) => ({
|
|
34
|
+
...pos,
|
|
35
|
+
|
|
36
|
+
// add 12 pixels to align y position with
|
|
37
|
+
//the columns controls
|
|
38
|
+
top: pos.top ? pos.top + 12 : undefined,
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
const getMessage = (layout: TableLayout) => {
|
|
42
|
+
switch (layout) {
|
|
43
|
+
case 'default':
|
|
44
|
+
return commonMessages.layoutWide;
|
|
45
|
+
case 'wide':
|
|
46
|
+
return commonMessages.layoutFullWidth;
|
|
47
|
+
default:
|
|
48
|
+
return commonMessages.layoutFixedWidth;
|
|
49
|
+
}
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
class LayoutButton extends React.Component<Props & WrappedComponentProps, any> {
|
|
53
|
+
static displayName = 'LayoutButton';
|
|
54
|
+
private stickyButtonRef = createRef<HTMLDivElement>();
|
|
55
|
+
|
|
56
|
+
private resizeObserver: ResizeObserver = new ResizeObserver((entries) => {
|
|
57
|
+
entries.forEach((entry) => {
|
|
58
|
+
const resizeButton = this.stickyButtonRef.current;
|
|
59
|
+
const tableWrapper = this.props.targetRef;
|
|
60
|
+
if (resizeButton && tableWrapper) {
|
|
61
|
+
const clientRect = tableWrapper.getBoundingClientRect();
|
|
62
|
+
resizeButton.style.left = `${clientRect.right}px`;
|
|
63
|
+
}
|
|
64
|
+
});
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
getTitle() {
|
|
68
|
+
const {
|
|
69
|
+
intl: { formatMessage },
|
|
70
|
+
layout = 'default',
|
|
71
|
+
} = this.props;
|
|
72
|
+
return formatMessage(getMessage(layout));
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
toolbarButton() {
|
|
76
|
+
const { isResizing, layout = 'default' } = this.props;
|
|
77
|
+
const title = this.getTitle();
|
|
78
|
+
|
|
79
|
+
return (
|
|
80
|
+
<div
|
|
81
|
+
className={classnames(ClassName.LAYOUT_BUTTON, {
|
|
82
|
+
[ClassName.IS_RESIZING]: isResizing,
|
|
83
|
+
})}
|
|
84
|
+
>
|
|
85
|
+
<ToolbarButton
|
|
86
|
+
title={title}
|
|
87
|
+
onClick={this.handleClick}
|
|
88
|
+
iconBefore={
|
|
89
|
+
layout === 'full-width' ? (
|
|
90
|
+
<CollapseIcon label={title} />
|
|
91
|
+
) : (
|
|
92
|
+
<ExpandIcon label={title} />
|
|
93
|
+
)
|
|
94
|
+
}
|
|
95
|
+
/>
|
|
96
|
+
</div>
|
|
97
|
+
);
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
getStickyTargetRef(pos: number): Node | null {
|
|
101
|
+
const { editorView } = this.props;
|
|
102
|
+
const domAtPos = editorView.domAtPos.bind(editorView);
|
|
103
|
+
const node = findDomRefAtPos(pos, domAtPos) as HTMLElement;
|
|
104
|
+
return node.dataset['headerRow'] && node.classList.contains('sticky')
|
|
105
|
+
? node
|
|
106
|
+
: null;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
renderSticky(button: JSX.Element, targetRef: Node, tableRef: Node) {
|
|
110
|
+
// const title = this.getTitle();
|
|
111
|
+
const title = 'TODO MISSING TITLE';
|
|
112
|
+
|
|
113
|
+
if (
|
|
114
|
+
!(targetRef instanceof HTMLElement) ||
|
|
115
|
+
!(tableRef instanceof HTMLElement)
|
|
116
|
+
) {
|
|
117
|
+
return null;
|
|
118
|
+
}
|
|
119
|
+
const pos = targetRef.getBoundingClientRect();
|
|
120
|
+
const tablePos = tableRef.getBoundingClientRect();
|
|
121
|
+
|
|
122
|
+
return (
|
|
123
|
+
<div
|
|
124
|
+
ref={this.stickyButtonRef}
|
|
125
|
+
aria-label={title}
|
|
126
|
+
style={{
|
|
127
|
+
position: 'fixed',
|
|
128
|
+
top: pos.top + 22,
|
|
129
|
+
left: tablePos.right,
|
|
130
|
+
}}
|
|
131
|
+
>
|
|
132
|
+
{button}
|
|
133
|
+
</div>
|
|
134
|
+
);
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
renderPopup(button: JSX.Element) {
|
|
138
|
+
const {
|
|
139
|
+
mountPoint,
|
|
140
|
+
boundariesElement,
|
|
141
|
+
scrollableElement,
|
|
142
|
+
targetRef,
|
|
143
|
+
} = this.props;
|
|
144
|
+
|
|
145
|
+
if (!targetRef) {
|
|
146
|
+
return null;
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
// const title = this.getTitle();
|
|
150
|
+
const title = 'TODO MISSING TITLE';
|
|
151
|
+
|
|
152
|
+
return (
|
|
153
|
+
<Popup
|
|
154
|
+
ariaLabel={title}
|
|
155
|
+
target={targetRef}
|
|
156
|
+
alignY="start"
|
|
157
|
+
alignX="end"
|
|
158
|
+
onPositionCalculated={addPopupOffset}
|
|
159
|
+
stick={true}
|
|
160
|
+
mountTo={mountPoint}
|
|
161
|
+
boundariesElement={boundariesElement}
|
|
162
|
+
scrollableElement={scrollableElement}
|
|
163
|
+
forcePlacement={true}
|
|
164
|
+
>
|
|
165
|
+
{button}
|
|
166
|
+
</Popup>
|
|
167
|
+
);
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
render() {
|
|
171
|
+
const { stickyHeader } = this.props;
|
|
172
|
+
const button = this.toolbarButton();
|
|
173
|
+
|
|
174
|
+
const stickyTargetRef =
|
|
175
|
+
stickyHeader && stickyHeader.sticky && stickyHeader.pos
|
|
176
|
+
? this.getStickyTargetRef(stickyHeader.pos)
|
|
177
|
+
: null;
|
|
178
|
+
if (stickyTargetRef && this.props.targetRef) {
|
|
179
|
+
return this.renderSticky(button, stickyTargetRef, this.props.targetRef);
|
|
180
|
+
} else {
|
|
181
|
+
return this.renderPopup(button);
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
componentDidMount() {
|
|
186
|
+
const dom = this.props.editorView.dom;
|
|
187
|
+
const scrollPanel = dom.closest('.fabric-editor-popup-scroll-parent');
|
|
188
|
+
if (scrollPanel instanceof HTMLElement) {
|
|
189
|
+
this.resizeObserver.observe(scrollPanel);
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
componentWillUnmount() {
|
|
194
|
+
const dom = this.props.editorView.dom;
|
|
195
|
+
const scrollPanel = dom.closest('.fabric-editor-popup-scroll-parent');
|
|
196
|
+
if (scrollPanel instanceof HTMLElement) {
|
|
197
|
+
this.resizeObserver.unobserve(scrollPanel);
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
shouldComponentUpdate(nextProps: Props) {
|
|
202
|
+
const { targetRef, layout, isResizing, stickyHeader } = this.props;
|
|
203
|
+
return (
|
|
204
|
+
stickyHeader !== nextProps.stickyHeader ||
|
|
205
|
+
targetRef !== nextProps.targetRef ||
|
|
206
|
+
layout !== nextProps.layout ||
|
|
207
|
+
isResizing !== nextProps.isResizing
|
|
208
|
+
);
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
private handleClick = () => {
|
|
212
|
+
const { state, dispatch } = this.props.editorView;
|
|
213
|
+
toggleTableLayoutWithAnalytics(this.props.editorAnalyticsAPI)(
|
|
214
|
+
state,
|
|
215
|
+
dispatch,
|
|
216
|
+
);
|
|
217
|
+
};
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
export default injectIntl(LayoutButton);
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import React, { Component } from 'react';
|
|
2
|
+
|
|
3
|
+
import classnames from 'classnames';
|
|
4
|
+
import { TableMap } from '@atlaskit/editor-tables/table-map';
|
|
5
|
+
import {
|
|
6
|
+
findTable,
|
|
7
|
+
isTableSelected,
|
|
8
|
+
selectTable,
|
|
9
|
+
} from '@atlaskit/editor-tables/utils';
|
|
10
|
+
import { EditorView } from 'prosemirror-view';
|
|
11
|
+
|
|
12
|
+
import { clearHoverSelection, hoverTable } from '../../../commands';
|
|
13
|
+
import { TableCssClassName as ClassName } from '../../../types';
|
|
14
|
+
|
|
15
|
+
export interface Props {
|
|
16
|
+
editorView: EditorView;
|
|
17
|
+
tableRef?: HTMLTableElement;
|
|
18
|
+
isInDanger?: boolean;
|
|
19
|
+
isResizing?: boolean;
|
|
20
|
+
hoveredRows?: number[];
|
|
21
|
+
isHeaderColumnEnabled?: boolean;
|
|
22
|
+
isHeaderRowEnabled?: boolean;
|
|
23
|
+
stickyTop?: number;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
export default class CornerControls extends Component<Props, any> {
|
|
27
|
+
render() {
|
|
28
|
+
const {
|
|
29
|
+
isInDanger,
|
|
30
|
+
tableRef,
|
|
31
|
+
isHeaderColumnEnabled,
|
|
32
|
+
isHeaderRowEnabled,
|
|
33
|
+
} = this.props;
|
|
34
|
+
if (!tableRef) {
|
|
35
|
+
return null;
|
|
36
|
+
}
|
|
37
|
+
const isActive = this.isActive();
|
|
38
|
+
|
|
39
|
+
return (
|
|
40
|
+
<div
|
|
41
|
+
className={classnames(ClassName.CORNER_CONTROLS, {
|
|
42
|
+
active: isActive,
|
|
43
|
+
sticky: this.props.stickyTop !== undefined,
|
|
44
|
+
})}
|
|
45
|
+
style={{
|
|
46
|
+
top:
|
|
47
|
+
this.props.stickyTop !== undefined
|
|
48
|
+
? `${this.props.stickyTop}px`
|
|
49
|
+
: undefined,
|
|
50
|
+
}}
|
|
51
|
+
>
|
|
52
|
+
<button
|
|
53
|
+
type="button"
|
|
54
|
+
className={classnames(ClassName.CONTROLS_CORNER_BUTTON, {
|
|
55
|
+
danger: isActive && isInDanger,
|
|
56
|
+
})}
|
|
57
|
+
onClick={this.selectTable}
|
|
58
|
+
onMouseOver={this.hoverTable}
|
|
59
|
+
onMouseOut={this.clearHoverSelection}
|
|
60
|
+
/>
|
|
61
|
+
|
|
62
|
+
{!isHeaderRowEnabled && (
|
|
63
|
+
<div className={ClassName.CORNER_CONTROLS_INSERT_ROW_MARKER}>
|
|
64
|
+
<div className={ClassName.CONTROLS_INSERT_MARKER} />
|
|
65
|
+
</div>
|
|
66
|
+
)}
|
|
67
|
+
{!isHeaderColumnEnabled && (
|
|
68
|
+
<div className={ClassName.CORNER_CONTROLS_INSERT_COLUMN_MARKER}>
|
|
69
|
+
<div className={ClassName.CONTROLS_INSERT_MARKER} />
|
|
70
|
+
</div>
|
|
71
|
+
)}
|
|
72
|
+
</div>
|
|
73
|
+
);
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
private isActive = () => {
|
|
77
|
+
const { editorView, hoveredRows, isResizing } = this.props;
|
|
78
|
+
const { selection } = editorView.state;
|
|
79
|
+
const table = findTable(selection);
|
|
80
|
+
if (!table) {
|
|
81
|
+
return false;
|
|
82
|
+
}
|
|
83
|
+
return (
|
|
84
|
+
isTableSelected(selection) ||
|
|
85
|
+
(hoveredRows &&
|
|
86
|
+
hoveredRows.length === TableMap.get(table.node).height &&
|
|
87
|
+
!isResizing)
|
|
88
|
+
);
|
|
89
|
+
};
|
|
90
|
+
|
|
91
|
+
private clearHoverSelection = () => {
|
|
92
|
+
const { state, dispatch } = this.props.editorView;
|
|
93
|
+
clearHoverSelection()(state, dispatch);
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
private selectTable = () => {
|
|
97
|
+
const { state, dispatch } = this.props.editorView;
|
|
98
|
+
dispatch(selectTable(state.tr).setMeta('addToHistory', false));
|
|
99
|
+
};
|
|
100
|
+
|
|
101
|
+
private hoverTable = () => {
|
|
102
|
+
const { state, dispatch } = this.props.editorView;
|
|
103
|
+
hoverTable()(state, dispatch);
|
|
104
|
+
};
|
|
105
|
+
}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
import React, { Component } from 'react';
|
|
2
|
+
|
|
3
|
+
import { Selection } from 'prosemirror-state';
|
|
4
|
+
import { isRowSelected } from '@atlaskit/editor-tables/utils';
|
|
5
|
+
import { EditorView } from 'prosemirror-view';
|
|
6
|
+
|
|
7
|
+
import { clearHoverSelection } from '../../../commands';
|
|
8
|
+
import { TableCssClassName as ClassName } from '../../../types';
|
|
9
|
+
import { getRowHeights } from '../../../utils';
|
|
10
|
+
|
|
11
|
+
export interface Props {
|
|
12
|
+
editorView: EditorView;
|
|
13
|
+
tableRef: HTMLTableElement;
|
|
14
|
+
tableActive?: boolean;
|
|
15
|
+
hoverRows: (rows: number[], danger?: boolean) => void;
|
|
16
|
+
hoveredRows?: number[];
|
|
17
|
+
selectRow: (row: number, expand: boolean) => void;
|
|
18
|
+
hasHeaderRow?: boolean;
|
|
19
|
+
isInDanger?: boolean;
|
|
20
|
+
isResizing?: boolean;
|
|
21
|
+
stickyTop?: number;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export default class NumberColumn extends Component<Props, any> {
|
|
25
|
+
render() {
|
|
26
|
+
const { tableRef, hasHeaderRow } = this.props;
|
|
27
|
+
const rowHeights = getRowHeights(tableRef);
|
|
28
|
+
|
|
29
|
+
return (
|
|
30
|
+
<div
|
|
31
|
+
className={ClassName.NUMBERED_COLUMN}
|
|
32
|
+
style={{
|
|
33
|
+
marginTop:
|
|
34
|
+
hasHeaderRow && this.props.stickyTop !== undefined
|
|
35
|
+
? rowHeights[0]
|
|
36
|
+
: undefined,
|
|
37
|
+
}}
|
|
38
|
+
>
|
|
39
|
+
{rowHeights.map((rowHeight, index) => (
|
|
40
|
+
<div
|
|
41
|
+
key={`wrapper-${index}`}
|
|
42
|
+
className={this.getClassNames(index)}
|
|
43
|
+
data-index={index}
|
|
44
|
+
style={{
|
|
45
|
+
height: rowHeight,
|
|
46
|
+
top:
|
|
47
|
+
this.props.stickyTop !== undefined &&
|
|
48
|
+
hasHeaderRow &&
|
|
49
|
+
index === 0
|
|
50
|
+
? `${this.props.stickyTop}px`
|
|
51
|
+
: undefined,
|
|
52
|
+
}}
|
|
53
|
+
onClick={(event) => this.selectRow(index, event)}
|
|
54
|
+
onMouseOver={() => this.hoverRows(index)}
|
|
55
|
+
onMouseOut={this.clearHoverSelection}
|
|
56
|
+
>
|
|
57
|
+
{hasHeaderRow ? (index > 0 ? index : null) : index + 1}
|
|
58
|
+
</div>
|
|
59
|
+
))}
|
|
60
|
+
</div>
|
|
61
|
+
);
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
private hoverRows = (index: number) =>
|
|
65
|
+
this.props.tableActive ? this.props.hoverRows([index]) : null;
|
|
66
|
+
|
|
67
|
+
private selectRow = (
|
|
68
|
+
index: number,
|
|
69
|
+
event: React.MouseEvent<HTMLDivElement, MouseEvent>,
|
|
70
|
+
) => {
|
|
71
|
+
const { tableActive, editorView, selectRow } = this.props;
|
|
72
|
+
// If selection is outside the table then first reset the selection inside table
|
|
73
|
+
if (!tableActive && event.target && event.target instanceof Node) {
|
|
74
|
+
const { doc, selection, tr } = editorView.state;
|
|
75
|
+
const pos = editorView.posAtDOM(event.target, 1);
|
|
76
|
+
const $pos = doc.resolve(pos);
|
|
77
|
+
const newPos =
|
|
78
|
+
selection.head > pos
|
|
79
|
+
? // Selection is after table
|
|
80
|
+
// nodeSize - 3 will move the position inside last table cell
|
|
81
|
+
Selection.near(doc.resolve(pos + ($pos.parent.nodeSize - 3)), -1)
|
|
82
|
+
: // Selection is before table
|
|
83
|
+
Selection.near($pos);
|
|
84
|
+
editorView.dispatch(tr.setSelection(newPos));
|
|
85
|
+
}
|
|
86
|
+
selectRow(index, event.shiftKey);
|
|
87
|
+
};
|
|
88
|
+
|
|
89
|
+
private clearHoverSelection = () => {
|
|
90
|
+
const { tableActive, editorView } = this.props;
|
|
91
|
+
if (tableActive) {
|
|
92
|
+
const { state, dispatch } = editorView;
|
|
93
|
+
clearHoverSelection()(state, dispatch);
|
|
94
|
+
}
|
|
95
|
+
};
|
|
96
|
+
|
|
97
|
+
private getClassNames = (index: number) => {
|
|
98
|
+
const { hoveredRows, editorView, isInDanger, isResizing } = this.props;
|
|
99
|
+
const isActive =
|
|
100
|
+
isRowSelected(index)(editorView.state.selection) ||
|
|
101
|
+
((hoveredRows || []).indexOf(index) !== -1 && !isResizing);
|
|
102
|
+
return [
|
|
103
|
+
ClassName.NUMBERED_COLUMN_BUTTON,
|
|
104
|
+
isActive ? ClassName.HOVERED_CELL_ACTIVE : '',
|
|
105
|
+
isActive && isInDanger ? ClassName.HOVERED_CELL_IN_DANGER : '',
|
|
106
|
+
].join(' ');
|
|
107
|
+
};
|
|
108
|
+
}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
import React, { Component } from 'react';
|
|
2
|
+
|
|
3
|
+
import { EditorView } from 'prosemirror-view';
|
|
4
|
+
|
|
5
|
+
import { clearHoverSelection } from '../../../commands';
|
|
6
|
+
import { TableCssClassName as ClassName } from '../../../types';
|
|
7
|
+
import {
|
|
8
|
+
getRowClassNames,
|
|
9
|
+
getRowHeights,
|
|
10
|
+
getRowsParams,
|
|
11
|
+
RowParams,
|
|
12
|
+
} from '../../../utils';
|
|
13
|
+
import { tableControlsSpacing, tableToolbarSize } from '../../consts';
|
|
14
|
+
|
|
15
|
+
export interface Props {
|
|
16
|
+
editorView: EditorView;
|
|
17
|
+
tableRef: HTMLTableElement;
|
|
18
|
+
selectRow: (row: number, expand: boolean) => void;
|
|
19
|
+
hoverRows: (rows: number[], danger?: boolean) => void;
|
|
20
|
+
hoveredRows?: number[];
|
|
21
|
+
isInDanger?: boolean;
|
|
22
|
+
isResizing?: boolean;
|
|
23
|
+
insertRowButtonIndex?: number;
|
|
24
|
+
stickyTop?: number;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
export default class RowControls extends Component<Props> {
|
|
28
|
+
render() {
|
|
29
|
+
const {
|
|
30
|
+
editorView,
|
|
31
|
+
tableRef,
|
|
32
|
+
hoveredRows,
|
|
33
|
+
isInDanger,
|
|
34
|
+
isResizing,
|
|
35
|
+
} = this.props;
|
|
36
|
+
if (!tableRef) {
|
|
37
|
+
return null;
|
|
38
|
+
}
|
|
39
|
+
const { selection } = editorView.state;
|
|
40
|
+
const rowHeights = getRowHeights(tableRef);
|
|
41
|
+
const rowsParams = getRowsParams(rowHeights);
|
|
42
|
+
|
|
43
|
+
const firstRow = tableRef.querySelector('tr');
|
|
44
|
+
const hasHeaderRow = firstRow
|
|
45
|
+
? firstRow.getAttribute('data-header-row')
|
|
46
|
+
: false;
|
|
47
|
+
|
|
48
|
+
return (
|
|
49
|
+
<div className={ClassName.ROW_CONTROLS}>
|
|
50
|
+
<div className={ClassName.ROW_CONTROLS_INNER}>
|
|
51
|
+
{rowsParams.map(
|
|
52
|
+
({ startIndex, endIndex, height }: RowParams, index) => {
|
|
53
|
+
// if previous row was header row, add its height to our margin
|
|
54
|
+
let marginTop = -1;
|
|
55
|
+
if (
|
|
56
|
+
index === 1 &&
|
|
57
|
+
hasHeaderRow &&
|
|
58
|
+
this.props.stickyTop !== undefined
|
|
59
|
+
) {
|
|
60
|
+
marginTop += rowHeights[index - 1] + tableToolbarSize;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
const thisRowSticky =
|
|
64
|
+
this.props.stickyTop !== undefined &&
|
|
65
|
+
index === 0 &&
|
|
66
|
+
hasHeaderRow;
|
|
67
|
+
|
|
68
|
+
return (
|
|
69
|
+
<div
|
|
70
|
+
className={`${
|
|
71
|
+
ClassName.ROW_CONTROLS_BUTTON_WRAP
|
|
72
|
+
} ${getRowClassNames(
|
|
73
|
+
startIndex,
|
|
74
|
+
selection,
|
|
75
|
+
hoveredRows,
|
|
76
|
+
isInDanger,
|
|
77
|
+
isResizing,
|
|
78
|
+
)} ${thisRowSticky ? 'sticky' : ''}`}
|
|
79
|
+
key={startIndex}
|
|
80
|
+
style={{
|
|
81
|
+
height: height,
|
|
82
|
+
marginTop: `${marginTop}px`,
|
|
83
|
+
top: thisRowSticky
|
|
84
|
+
? `${this.props.stickyTop! + 3}px`
|
|
85
|
+
: undefined,
|
|
86
|
+
paddingTop: thisRowSticky
|
|
87
|
+
? `${tableControlsSpacing}px`
|
|
88
|
+
: undefined,
|
|
89
|
+
}}
|
|
90
|
+
>
|
|
91
|
+
<button
|
|
92
|
+
type="button"
|
|
93
|
+
className={`${ClassName.ROW_CONTROLS_BUTTON}
|
|
94
|
+
${ClassName.CONTROLS_BUTTON}
|
|
95
|
+
`}
|
|
96
|
+
onClick={(event) =>
|
|
97
|
+
this.props.selectRow(startIndex, event.shiftKey)
|
|
98
|
+
}
|
|
99
|
+
onMouseOver={() => this.props.hoverRows([startIndex])}
|
|
100
|
+
onMouseOut={this.clearHoverSelection}
|
|
101
|
+
data-start-index={startIndex}
|
|
102
|
+
data-end-index={endIndex}
|
|
103
|
+
/>
|
|
104
|
+
|
|
105
|
+
<div className={ClassName.CONTROLS_INSERT_MARKER} />
|
|
106
|
+
</div>
|
|
107
|
+
);
|
|
108
|
+
},
|
|
109
|
+
)}
|
|
110
|
+
</div>
|
|
111
|
+
</div>
|
|
112
|
+
);
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
private clearHoverSelection = () => {
|
|
116
|
+
const { state, dispatch } = this.props.editorView;
|
|
117
|
+
clearHoverSelection()(state, dispatch);
|
|
118
|
+
};
|
|
119
|
+
}
|