@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,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.tableStyles = exports.tableFullPageEditorStyles = exports.tableCommentEditorStyles = void 0;
|
|
9
|
+
|
|
10
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
11
|
+
|
|
12
|
+
var _react = require("@emotion/react");
|
|
13
|
+
|
|
14
|
+
var _styles = require("@atlaskit/editor-common/styles");
|
|
15
|
+
|
|
16
|
+
var _constants = require("@atlaskit/theme/constants");
|
|
17
|
+
|
|
18
|
+
var _colors = require("@atlaskit/theme/colors");
|
|
19
|
+
|
|
20
|
+
var _editorSharedStyles = require("@atlaskit/editor-shared-styles");
|
|
21
|
+
|
|
22
|
+
var _scrollbar = require("@atlaskit/editor-shared-styles/scrollbar");
|
|
23
|
+
|
|
24
|
+
var _types = require("../types");
|
|
25
|
+
|
|
26
|
+
var _consts = require("./consts");
|
|
27
|
+
|
|
28
|
+
var _uiStyles = require("./ui-styles");
|
|
29
|
+
|
|
30
|
+
var _tokens = require("@atlaskit/tokens");
|
|
31
|
+
|
|
32
|
+
var _templateObject, _templateObject2, _templateObject3;
|
|
33
|
+
|
|
34
|
+
var cornerControlHeight = _consts.tableToolbarSize + 1;
|
|
35
|
+
var rangeSelectionStyles = "\n.".concat(_types.TableCssClassName.NODEVIEW_WRAPPER, ".").concat(_editorSharedStyles.akEditorSelectedNodeClassName, " table tbody tr {\n th,td {\n ").concat((0, _editorSharedStyles.getSelectionStyles)([_editorSharedStyles.SelectionStyle.Blanket, _editorSharedStyles.SelectionStyle.Border]), "\n }\n}\n");
|
|
36
|
+
var sentinelStyles = ".".concat(_types.TableCssClassName.TABLE_CONTAINER, " {\n > .").concat(_types.TableCssClassName.TABLE_STICKY_SENTINEL_TOP, ", > .").concat(_types.TableCssClassName.TABLE_STICKY_SENTINEL_BOTTOM, " {\n position: absolute;\n width: 100%;\n height: 1px;\n margin-top: -1px;\n // need this to avoid sentinel being focused via keyboard\n // this still allows it to be detected by intersection observer\n visibility: hidden;\n }\n > .").concat(_types.TableCssClassName.TABLE_STICKY_SENTINEL_TOP, " {\n top: ").concat(_consts.columnControlsDecorationHeight, "px;\n }\n > .").concat(_types.TableCssClassName.TABLE_STICKY_SENTINEL_BOTTOM, " {\n bottom: ").concat(_consts.tableScrollbarOffset + _consts.stickyRowOffsetTop + _consts.tablePadding * 2 + 23, "px;\n }\n &.").concat(_types.TableCssClassName.WITH_CONTROLS, " {\n > .").concat(_types.TableCssClassName.TABLE_STICKY_SENTINEL_TOP, " {\n top: 0px;\n }\n > .").concat(_types.TableCssClassName.TABLE_STICKY_SENTINEL_BOTTOM, " {\n margin-bottom: ").concat(_consts.columnControlsDecorationHeight, "px;\n }\n }\n}"); // TODO: https://product-fabric.atlassian.net/browse/DSP-4139
|
|
37
|
+
|
|
38
|
+
var tableStyles = function tableStyles(props) {
|
|
39
|
+
var _props$featureFlags;
|
|
40
|
+
|
|
41
|
+
return (0, _react.css)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2.default)(["\n .", " button {\n background: ", ";\n color: ", ";\n cursor: none;\n }\n\n .", ":not(.", ") button:hover {\n background: ", ";\n color: ", " !important;\n cursor: pointer;\n }\n\n .ProseMirror {\n ", ";\n ", ";\n ", ";\n ", ";\n ", ";\n ", ";\n ", ";\n\n .", " {\n margin-bottom: 0;\n }\n\n .", " {\n td.", ", th.", " {\n position: relative;\n overflow: visible;\n }\n\n td.", " {\n background-color: ", ";\n\n // ED-15246: Trello card is visible through a border of a table border\n // This fixes a border issue caused by relative positioned table cells\n &::after {\n height: 100%;\n content: '';\n border-left: 1px solid ", ";\n border-bottom: 1px solid ", ";\n position: absolute;\n right: 0px;\n top: 0px;\n bottom: 0;\n width: 100%;\n display: inline-block;\n pointer-events: none;\n }\n }\n }\n\n .", " {\n ", "\n }\n\n .", " {\n ", "\n }\n\n /* Delete button */\n ", "\n /* Ends Delete button */\n\n /* sticky styles */\n .", " .", " .", ":first-of-type {\n margin-top: ", "px;\n width: ", "px;\n\n position: fixed !important;\n z-index: ", " !important;\n box-shadow: 0px -", "px ", ";\n border-right: 0 none;\n /* top set by NumberColumn component */\n }\n\n .", " .", ".sticky {\n position: fixed !important;\n /* needs to be above row controls */\n z-index: ", " !important;\n background: ", ";\n\n width: ", "px;\n height: ", "px;\n }\n\n .", ".sticky .", " {\n border-bottom: 0px none;\n border-right: 0px none;\n\n height: ", "px;\n width: ", "px;\n }\n\n .", " .", " {\n z-index: 0;\n }\n\n .", "\n .", "\n .", ".sticky {\n position: fixed !important;\n z-index: ", " !important;\n display: flex;\n border-left: ", "px solid\n ", ";\n margin-left: -", "px;\n }\n\n .", " col:first-of-type {\n /* moving rows out of a table layout does weird things in Chrome */\n border-right: 1px solid ", ";\n }\n\n tr.sticky {\n padding-top: ", "px;\n position: fixed;\n display: grid;\n\n /* to keep it above cell selection */\n z-index: ", ";\n\n overflow-y: visible;\n overflow-x: hidden;\n\n grid-auto-flow: column;\n\n /* background for where controls apply */\n background: ", ";\n box-sizing: content-box;\n\n margin-top: 2px;\n\n box-shadow: ", ";\n margin-left: -1px;\n\n &.no-pointer-events {\n pointer-events: none;\n }\n }\n\n .", " .", " {\n left: unset;\n position: fixed;\n z-index: ", ";\n }\n\n .", ".", "\n .", " {\n padding-bottom: ", "px;\n }\n\n tr.sticky th {\n border-bottom: ", "px solid\n ", ";\n margin-right: -1px;\n }\n\n .", " tr.sticky > th:last-child {\n border-right-width: 1px;\n }\n\n /* add left edge for first cell */\n .", " tr.sticky > th:first-of-type {\n margin-left: 0px;\n }\n\n /* add a little bit so the scroll lines up with the table */\n .", " tr.sticky::after {\n content: ' ';\n width: 1px;\n }\n\n /* To fix jumpiness caused in Chrome Browsers for sticky headers */\n .", " .sticky + tr {\n min-height: 0px;\n }\n\n /* move resize line a little in sticky bar */\n .", ".", " {\n tr.sticky\n td.", ",\n tr.sticky\n th.", " {\n .", "::after {\n right: ", "px;\n }\n }\n\n /* when selected put it back to normal -- :not selector would be nicer */\n tr.sticky\n td.", ".", ",\n tr.sticky\n th.", ".", " {\n .", "::after {\n right: ", "px;\n }\n }\n }\n\n tr.sticky\n .", ",\n tr.sticky\n .", " {\n z-index: 1;\n }\n\n .", " tr.sticky {\n padding-top: ", "px;\n }\n\n .", ".", "\n .", "\n .", ":first-of-type {\n margin-top: ", "px;\n }\n\n .", ".sticky {\n border-top: ", "px solid\n ", ";\n }\n\n ", "\n ", "\n\n .", " .", " {\n height: 0; // stop overflow flash & set correct height in update-overflow-shadows.ts\n }\n\n .less-padding {\n padding: 0 ", "px;\n\n .", " {\n padding: 0 ", "px;\n }\n\n &.", "[data-number-column='true'] {\n padding-left: ", "px;\n }\n\n .", " {\n left: 6px;\n }\n\n .", " {\n left: calc(100% - 6px);\n }\n }\n\n > .", " {\n /**\n * Prevent margins collapsing, aids with placing the gap-cursor correctly\n * @see https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Box_Model/Mastering_margin_collapsing\n *\n * TODO: Enable this, many tests will fail!\n * border-top: 1px solid transparent;\n */\n }\n\n /* Breakout only works on top level */\n > * .", " .", " {\n margin-left: unset !important;\n width: 100% !important;\n }\n\n ", ";\n\n /* Corner controls */\n .", " {\n width: ", "px;\n height: ", "px;\n display: none;\n\n .", " {\n position: relative;\n\n ", ";\n }\n\n .", " {\n position: relative;\n\n ", ";\n }\n }\n\n .", ".sticky {\n .", " {\n /* sticky row insert dot overlaps other row insert and messes things up */\n display: none !important;\n }\n }\n\n .", " {\n position: absolute;\n top: 0;\n width: ", "px;\n height: ", "px;\n border: 1px solid ", ";\n border-radius: 0;\n border-top-left-radius: ", "px;\n background: ", ";\n box-sizing: border-box;\n padding: 0;\n :focus {\n outline: none;\n }\n }\n .active .", " {\n border-color: ", ";\n background: ", ";\n }\n\n .", "[data-number-column='true'] {\n .", ", .", " {\n width: ", "px;\n }\n .", " .", " {\n border-right-width: 0;\n }\n }\n\n :not(.", ") .", ":hover {\n border-color: ", ";\n background: ", ";\n cursor: pointer;\n }\n\n :not(.", ")\n .", ".", " {\n border-color: ", ";\n background: ", ";\n }\n\n /* Row controls */\n .", " {\n width: ", "px;\n box-sizing: border-box;\n display: none;\n position: relative;\n\n ", ";\n\n .", " {\n display: flex;\n flex-direction: column;\n }\n .", ":last-child > button {\n border-bottom-left-radius: ", "px;\n }\n .", " {\n position: relative;\n margin-top: -1px;\n }\n .", ":hover,\n .", ".active,\n .", ":hover {\n z-index: ", ";\n }\n\n ", "\n }\n\n :not(.", ") .", " {\n ", "\n ", "\n }\n\n /* Numbered column */\n .", " {\n position: relative;\n float: right;\n margin-left: ", "px;\n top: ", "px;\n width: ", "px;\n box-sizing: border-box;\n }\n\n .", " {\n border: 1px solid ", ";\n box-sizing: border-box;\n margin-top: -1px;\n padding-bottom: 2px;\n padding: 10px 2px;\n text-align: center;\n font-size: ", ";\n background-color: ", ";\n color: ", ";\n border-color: ", ";\n\n :first-child:not(style),\n style:first-child + * {\n margin-top: 0;\n }\n :last-child {\n border-bottom: 1px solid ", ";\n }\n }\n\n .", " {\n .", ", .", " {\n display: block;\n }\n .", " {\n padding-left: 1px;\n .", " {\n border-left: 0 none;\n }\n\n .", ".active {\n border-bottom: 1px solid ", ";\n border-color: ", ";\n background-color: ", ";\n position: relative;\n z-index: ", ";\n color: ", ";\n }\n }\n }\n :not(.", ") .", " {\n .", " {\n cursor: pointer;\n }\n .", ":hover {\n border-bottom: 1px solid ", ";\n border-color: ", ";\n background-color: ", ";\n position: relative;\n z-index: ", ";\n color: ", ";\n }\n .", ".", " {\n background-color: ", ";\n border: 1px solid ", ";\n border-left: 0;\n color: ", ";\n position: relative;\n z-index: ", ";\n }\n }\n\n /* Table */\n .", " > table {\n table-layout: fixed;\n\n .", " + * {\n margin-top: 0;\n }\n\n /*\n * Headings have a top margin by default, but we don't want this on the\n * first heading within table header cells.\n *\n * This specifically sets margin-top for the first heading within a header\n * cell when center/right aligned.\n */\n th.", " > .fabric-editor-block-mark {\n > h1:first-of-type,\n > h2:first-of-type,\n > h3:first-of-type,\n > h4:first-of-type,\n > h5:first-of-type,\n > h6:first-of-type {\n margin-top: 0;\n }\n }\n\n .", ", .", " {\n position: relative;\n }\n /* Give selected cells a blue overlay */\n .", "::after,\n .", "::after {\n z-index: ", ";\n position: absolute;\n content: '';\n left: 0;\n right: 0;\n top: 0;\n bottom: 0;\n width: 100%;\n pointer-events: none;\n }\n .", " {\n border: 1px solid ", ";\n }\n .", "::after {\n background: ", ";\n z-index: ", ";\n }\n th.", "::after,\n td.", "::after {\n background: ", ";\n z-index: ", ";\n }\n // ED-15246: Trello card is visible through a border of a table border\n td.", ", td.", " {\n &::after {\n height: 100%;\n width: 100%;\n border: 1px solid ", ";\n content: '';\n position: absolute;\n left: -1px;\n top: -1px;\n bottom: 0;\n z-index: ", ";\n display: inline-block;\n pointer-events: none;\n }\n &.", "::after {\n border: 1px solid ", ";\n z-index: ", ";\n }\n }\n }\n .", " {\n position: absolute;\n /* top of corner control is table margin top - corner control height + 1 pixel of table border. */\n top: ", "px;\n }\n .", ".", " {\n z-index: ", ";\n }\n .", " {\n left: -", "px;\n }\n .", " {\n /*\n compensating for half of the insert column button\n that is aligned to the right edge initially on hover of the top right column control when table overflown,\n its center should be aligned with the edge\n */\n padding-right: ", "px;\n margin-right: -", "px;\n padding-bottom: ", "px;\n margin-bottom: -", "px;\n /* fixes gap cursor height */\n overflow: auto;\n position: relative;\n }\n }\n\n .ProseMirror.", " {\n .", " {\n overflow-x: auto;\n ", ";\n }\n }\n\n .ProseMirror.", " {\n cursor: col-resize;\n }\n\n .ProseMirror .pm-table-cell-content-wrap ol[data-child-count='100+'] {\n padding-left: revert;\n }\n"])), _types.TableCssClassName.LAYOUT_BUTTON, (0, _tokens.token)('color.background.neutral', _colors.N20A), (0, _tokens.token)('color.icon', _colors.N300), _types.TableCssClassName.LAYOUT_BUTTON, _types.TableCssClassName.IS_RESIZING, (0, _tokens.token)('color.background.neutral.hovered', _colors.B300), (0, _tokens.token)('color.icon', 'white'), (0, _styles.tableSharedStyle)(props), (0, _uiStyles.columnControlsLineMarker)(props), _uiStyles.hoveredDeleteButton, _uiStyles.hoveredCell, _uiStyles.hoveredWarningCell, _uiStyles.resizeHandle, rangeSelectionStyles, _types.TableCssClassName.LAST_ITEM_IN_CELL, _types.TableCssClassName.TABLE_NODE_WRAPPER, _types.TableCssClassName.TABLE_CELL, _types.TableCssClassName.TABLE_HEADER_CELL, _types.TableCssClassName.TABLE_CELL, (0, _consts.tableCellBackgroundColor)(props), (0, _consts.tableBorderColor)(props), (0, _consts.tableBorderColor)(props), _types.TableCssClassName.CONTROLS_FLOATING_BUTTON_COLUMN, _uiStyles.insertColumnButtonWrapper, _types.TableCssClassName.CONTROLS_FLOATING_BUTTON_ROW, _uiStyles.insertRowButtonWrapper, _uiStyles.DeleteButton, _types.TableCssClassName.TABLE_STICKY, _types.TableCssClassName.NUMBERED_COLUMN, _types.TableCssClassName.NUMBERED_COLUMN_BUTTON, _consts.stickyRowOffsetTop + 2, _editorSharedStyles.akEditorTableNumberColumnWidth, _editorSharedStyles.akEditorStickyHeaderZIndex, _consts.stickyRowOffsetTop, (0, _tokens.token)('elevation.surface', 'white'), _types.TableCssClassName.TABLE_STICKY, _types.TableCssClassName.CORNER_CONTROLS, _editorSharedStyles.akEditorSmallZIndex, (0, _tokens.token)('elevation.surface', 'white'), _consts.tableToolbarSize, _consts.tableToolbarSize, _types.TableCssClassName.CORNER_CONTROLS, _types.TableCssClassName.CONTROLS_CORNER_BUTTON, _consts.tableToolbarSize, _consts.tableToolbarSize, _types.TableCssClassName.TABLE_STICKY, _types.TableCssClassName.COLUMN_CONTROLS_DECORATIONS, _types.TableCssClassName.TABLE_STICKY, _types.TableCssClassName.ROW_CONTROLS, _types.TableCssClassName.ROW_CONTROLS_BUTTON_WRAP, _editorSharedStyles.akEditorStickyHeaderZIndex, _consts.tableToolbarSize, (0, _tokens.token)('elevation.surface', 'white'), _consts.tableToolbarSize, _types.TableCssClassName.TABLE_STICKY, (0, _tokens.token)('elevation.surface', 'green'), _consts.stickyRowOffsetTop, _consts.stickyRowZIndex, (0, _tokens.token)('elevation.surface', 'white'), (0, _tokens.token)('elevation.shadow.overflow', "0 6px 4px -4px ".concat(_colors.N40A)), _types.TableCssClassName.TABLE_STICKY, _types.TableCssClassName.TABLE_STICKY_SHADOW, _consts.stickyRowZIndex + 1, _types.TableCssClassName.WITH_CONTROLS, _types.TableCssClassName.TABLE_STICKY, _types.TableCssClassName.TABLE_STICKY_SHADOW, _consts.tableToolbarSize, _consts.stickyHeaderBorderBottomWidth, (0, _consts.tableBorderColor)(props), _types.TableCssClassName.TABLE_STICKY, _types.TableCssClassName.TABLE_STICKY, _types.TableCssClassName.TABLE_STICKY, _types.TableCssClassName.TABLE_STICKY, _types.TableCssClassName.TABLE_CONTAINER, _types.TableCssClassName.TABLE_STICKY, _types.TableCssClassName.WITH_RESIZE_LINE, _types.TableCssClassName.WITH_RESIZE_LINE, _types.TableCssClassName.RESIZE_HANDLE_DECORATION, (_consts.resizeHandlerAreaWidth - _consts.resizeLineWidth) / 2 + 1, _types.TableCssClassName.WITH_RESIZE_LINE, _types.TableCssClassName.SELECTED_CELL, _types.TableCssClassName.WITH_RESIZE_LINE, _types.TableCssClassName.SELECTED_CELL, _types.TableCssClassName.RESIZE_HANDLE_DECORATION, (_consts.resizeHandlerAreaWidth - _consts.resizeLineWidth) / 2, _types.TableCssClassName.HOVERED_CELL, _types.TableCssClassName.SELECTED_CELL, _types.TableCssClassName.WITH_CONTROLS, _consts.tableControlsSpacing, _types.TableCssClassName.WITH_CONTROLS, _types.TableCssClassName.TABLE_STICKY, _types.TableCssClassName.NUMBERED_COLUMN, _types.TableCssClassName.NUMBERED_COLUMN_BUTTON, _consts.tableControlsSpacing + 2, _types.TableCssClassName.CORNER_CONTROLS, _consts.tableControlsSpacing - _consts.tableToolbarSize + 2, (0, _tokens.token)('elevation.surface', 'white'), (_props$featureFlags = props.featureFlags) !== null && _props$featureFlags !== void 0 && _props$featureFlags.stickyHeadersOptimization ? sentinelStyles : '', (0, _uiStyles.OverflowShadow)(props), _types.TableCssClassName.TABLE_STICKY, _types.TableCssClassName.TABLE_STICKY_SHADOW, _consts.tablePadding, _types.TableCssClassName.ROW_CONTROLS_WRAPPER, _consts.tablePadding, _types.TableCssClassName.TABLE_CONTAINER, _editorSharedStyles.akEditorTableNumberColumnWidth + _consts.tablePadding - 1, _types.TableCssClassName.TABLE_LEFT_SHADOW, _types.TableCssClassName.TABLE_RIGHT_SHADOW, _types.TableCssClassName.NODEVIEW_WRAPPER, _types.TableCssClassName.NODEVIEW_WRAPPER, _types.TableCssClassName.TABLE_CONTAINER, (0, _uiStyles.columnControlsDecoration)(props), _types.TableCssClassName.CORNER_CONTROLS, _consts.tableToolbarSize + 1, cornerControlHeight, _types.TableCssClassName.CORNER_CONTROLS_INSERT_ROW_MARKER, (0, _uiStyles.InsertMarker)(props, "\n left: -11px;\n top: 9px;\n "), _types.TableCssClassName.CORNER_CONTROLS_INSERT_COLUMN_MARKER, (0, _uiStyles.InsertMarker)(props, "\n right: -1px;\n top: -12px;\n "), _types.TableCssClassName.CORNER_CONTROLS, _types.TableCssClassName.CORNER_CONTROLS_INSERT_ROW_MARKER, _types.TableCssClassName.CONTROLS_CORNER_BUTTON, _consts.tableToolbarSize + 1, _consts.tableToolbarSize + 1, (0, _consts.tableBorderColor)(props), _consts.tableBorderRadiusSize, (0, _consts.tableToolbarColor)(props), _types.TableCssClassName.CONTROLS_CORNER_BUTTON, _consts.tableBorderSelectedColor, _consts.tableToolbarSelectedColor, _types.TableCssClassName.TABLE_CONTAINER, _types.TableCssClassName.CORNER_CONTROLS, _types.TableCssClassName.CONTROLS_CORNER_BUTTON, _editorSharedStyles.akEditorTableToolbarSize + _editorSharedStyles.akEditorTableNumberColumnWidth, _types.TableCssClassName.ROW_CONTROLS, _types.TableCssClassName.CONTROLS_BUTTON, _types.TableCssClassName.IS_RESIZING, _types.TableCssClassName.CONTROLS_CORNER_BUTTON, _consts.tableBorderSelectedColor, _consts.tableToolbarSelectedColor, _types.TableCssClassName.IS_RESIZING, _types.TableCssClassName.CONTROLS_CORNER_BUTTON, _types.TableCssClassName.HOVERED_CELL_IN_DANGER, _consts.tableBorderDeleteColor, _consts.tableToolbarDeleteColor, _types.TableCssClassName.ROW_CONTROLS, _consts.tableToolbarSize, (0, _uiStyles.InsertMarker)(props, "\n bottom: -1px;\n left: -11px;\n "), _types.TableCssClassName.ROW_CONTROLS_INNER, _types.TableCssClassName.ROW_CONTROLS_BUTTON_WRAP, _consts.tableBorderRadiusSize, _types.TableCssClassName.ROW_CONTROLS_BUTTON_WRAP, _types.TableCssClassName.ROW_CONTROLS_BUTTON_WRAP, _types.TableCssClassName.ROW_CONTROLS_BUTTON_WRAP, _types.TableCssClassName.CONTROLS_BUTTON, _editorSharedStyles.akEditorUnitZIndex, (0, _uiStyles.HeaderButton)(props, "\n border-bottom: 1px solid ".concat((0, _consts.tableBorderColor)(props), ";\n border-right: 0px;\n border-radius: 0;\n height: 100%;\n width: ").concat(_consts.tableToolbarSize, "px;\n\n .").concat(_types.TableCssClassName.CONTROLS_BUTTON_OVERLAY, " {\n position: absolute;\n width: 30px;\n height: 50%;\n right: 0;\n bottom: 0;\n }\n .").concat(_types.TableCssClassName.CONTROLS_BUTTON_OVERLAY, ":first-of-type {\n top: 0;\n }\n ")), _types.TableCssClassName.IS_RESIZING, _types.TableCssClassName.ROW_CONTROLS, (0, _uiStyles.HeaderButtonHover)(), (0, _uiStyles.HeaderButtonDanger)(), _types.TableCssClassName.NUMBERED_COLUMN, _editorSharedStyles.akEditorTableToolbarSize - 1, _editorSharedStyles.akEditorTableToolbarSize, _editorSharedStyles.akEditorTableNumberColumnWidth + 1, _types.TableCssClassName.NUMBERED_COLUMN_BUTTON, (0, _consts.tableBorderColor)(props), (0, _editorSharedStyles.relativeFontSizeToBase16)((0, _constants.fontSize)()), (0, _consts.tableToolbarColor)(props), (0, _consts.tableTextColor)(props), (0, _consts.tableBorderColor)(props), (0, _consts.tableBorderColor)(props), _types.TableCssClassName.WITH_CONTROLS, _types.TableCssClassName.CORNER_CONTROLS, _types.TableCssClassName.ROW_CONTROLS, _types.TableCssClassName.NUMBERED_COLUMN, _types.TableCssClassName.NUMBERED_COLUMN_BUTTON, _types.TableCssClassName.NUMBERED_COLUMN_BUTTON, _consts.tableBorderSelectedColor, _consts.tableBorderSelectedColor, _consts.tableToolbarSelectedColor, _editorSharedStyles.akEditorUnitZIndex, (0, _tokens.token)('color.text.inverse', _colors.N0), _types.TableCssClassName.IS_RESIZING, _types.TableCssClassName.WITH_CONTROLS, _types.TableCssClassName.NUMBERED_COLUMN_BUTTON, _types.TableCssClassName.NUMBERED_COLUMN_BUTTON, _consts.tableBorderSelectedColor, _consts.tableBorderSelectedColor, _consts.tableToolbarSelectedColor, _editorSharedStyles.akEditorUnitZIndex, (0, _tokens.token)('color.text.inverse', _colors.N0), _types.TableCssClassName.NUMBERED_COLUMN_BUTTON, _types.TableCssClassName.HOVERED_CELL_IN_DANGER, _consts.tableToolbarDeleteColor, _consts.tableBorderDeleteColor, (0, _tokens.token)('color.text.inverse', _colors.R500), _editorSharedStyles.akEditorUnitZIndex, _types.TableCssClassName.TABLE_NODE_WRAPPER, _types.TableCssClassName.COLUMN_CONTROLS_DECORATIONS, _types.TableCssClassName.TABLE_HEADER_CELL, _types.TableCssClassName.SELECTED_CELL, _types.TableCssClassName.HOVERED_CELL_IN_DANGER, _types.TableCssClassName.SELECTED_CELL, _types.TableCssClassName.HOVERED_CELL_IN_DANGER, _editorSharedStyles.akEditorSmallZIndex, _types.TableCssClassName.SELECTED_CELL, _consts.tableBorderSelectedColor, _types.TableCssClassName.SELECTED_CELL, _consts.tableCellSelectedColor, _editorSharedStyles.akEditorSmallZIndex, _types.TableCssClassName.HOVERED_CELL_IN_DANGER, _types.TableCssClassName.HOVERED_CELL_IN_DANGER, _consts.tableCellDeleteColor, _editorSharedStyles.akEditorUnitZIndex * 100, _types.TableCssClassName.HOVERED_CELL, _types.TableCssClassName.SELECTED_CELL, _consts.tableBorderSelectedColor, _editorSharedStyles.akEditorSmallZIndex, _types.TableCssClassName.HOVERED_CELL_IN_DANGER, _consts.tableBorderDeleteColor, _editorSharedStyles.akEditorUnitZIndex * 100, _types.TableCssClassName.ROW_CONTROLS_WRAPPER, _styles.tableMarginTop - cornerControlHeight + 1, _types.TableCssClassName.ROW_CONTROLS_WRAPPER, _types.TableCssClassName.TABLE_LEFT_SHADOW, _editorSharedStyles.akEditorUnitZIndex, _types.TableCssClassName.ROW_CONTROLS_WRAPPER, _consts.tableToolbarSize, _types.TableCssClassName.TABLE_NODE_WRAPPER, _consts.tableInsertColumnButtonSize / 2, _consts.tableInsertColumnButtonSize / 2, _consts.tableScrollbarOffset, _consts.tableScrollbarOffset, _types.TableCssClassName.IS_RESIZING, _types.TableCssClassName.TABLE_NODE_WRAPPER, _scrollbar.scrollbarStyles, _types.TableCssClassName.RESIZE_CURSOR);
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
exports.tableStyles = tableStyles;
|
|
45
|
+
var tableFullPageEditorStyles = (0, _react.css)(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2.default)(["\n .ProseMirror .", " > table {\n margin-left: 0;\n margin-right: 0;\n width: 100%;\n }\n"])), _types.TableCssClassName.TABLE_NODE_WRAPPER);
|
|
46
|
+
exports.tableFullPageEditorStyles = tableFullPageEditorStyles;
|
|
47
|
+
var tableCommentEditorStyles = (0, _react.css)(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2.default)(["\n .ProseMirror .", " > table {\n margin-left: 0;\n margin-right: 0;\n ", ";\n }\n"])), _types.TableCssClassName.TABLE_NODE_WRAPPER, _scrollbar.scrollbarStyles);
|
|
48
|
+
exports.tableCommentEditorStyles = tableCommentEditorStyles;
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.tableToolbarSize = exports.tableToolbarSelectedColor = exports.tableToolbarDeleteColor = exports.tableToolbarColor = exports.tableTextColor = exports.tableScrollbarOffset = exports.tablePadding = exports.tableMarginFullWidthMode = exports.tableInsertColumnButtonSize = exports.tableInsertColumnButtonOffset = exports.tableFloatingControlsColor = exports.tableDeleteButtonSize = exports.tableDeleteButtonOffset = exports.tableControlsSpacing = exports.tableCellSelectedColor = exports.tableCellDeleteColor = exports.tableCellBackgroundColor = exports.tableBorderSelectedColor = exports.tableBorderRadiusSize = exports.tableBorderDeleteColor = exports.tableBorderColor = exports.stickyRowZIndex = exports.stickyRowOffsetTop = exports.stickyHeaderBorderBottomWidth = exports.resizeLineWidth = exports.resizeHandlerZIndex = exports.resizeHandlerAreaWidth = exports.lineMarkerSize = exports.lineMarkerOffsetFromColumnControls = exports.layoutButtonSize = exports.contextualMenuTriggerSize = exports.contextualMenuDropdownWidth = exports.columnResizeHandleZIndex = exports.columnControlsZIndex = exports.columnControlsSelectedZIndex = exports.columnControlsDecorationHeight = void 0;
|
|
7
|
+
|
|
8
|
+
var _colors = require("@atlaskit/theme/colors");
|
|
9
|
+
|
|
10
|
+
var _styles = require("@atlaskit/editor-common/styles");
|
|
11
|
+
|
|
12
|
+
var _editorSharedStyles = require("@atlaskit/editor-shared-styles");
|
|
13
|
+
|
|
14
|
+
var _tokens = require("@atlaskit/tokens");
|
|
15
|
+
|
|
16
|
+
var _types = require("../types");
|
|
17
|
+
|
|
18
|
+
var _components = require("@atlaskit/theme/components");
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* Basic colors added to prevent content overflow in table cells.
|
|
22
|
+
*/
|
|
23
|
+
// TODO: https://product-fabric.atlassian.net/browse/DSP-4135
|
|
24
|
+
// eslint-disable-next-line @atlaskit/design-system/ensure-design-token-usage
|
|
25
|
+
var tableCellBackgroundColor = (0, _components.themed)({
|
|
26
|
+
light: _colors.N0,
|
|
27
|
+
dark: _colors.DN30
|
|
28
|
+
});
|
|
29
|
+
exports.tableCellBackgroundColor = tableCellBackgroundColor;
|
|
30
|
+
var tableToolbarColor = (0, _components.themed)({
|
|
31
|
+
light: _editorSharedStyles.akEditorTableToolbar,
|
|
32
|
+
dark: _editorSharedStyles.akEditorTableToolbarDark
|
|
33
|
+
});
|
|
34
|
+
exports.tableToolbarColor = tableToolbarColor;
|
|
35
|
+
var tableTextColor = (0, _components.themed)({
|
|
36
|
+
light: (0, _tokens.token)('color.text.subtlest', _colors.N200),
|
|
37
|
+
dark: (0, _tokens.token)('color.text.subtlest', _colors.DN400)
|
|
38
|
+
});
|
|
39
|
+
exports.tableTextColor = tableTextColor;
|
|
40
|
+
var tableBorderColor = (0, _components.themed)({
|
|
41
|
+
light: (0, _tokens.token)('color.border', _editorSharedStyles.akEditorTableBorder),
|
|
42
|
+
dark: (0, _tokens.token)('color.border', _editorSharedStyles.akEditorTableBorderDark)
|
|
43
|
+
});
|
|
44
|
+
exports.tableBorderColor = tableBorderColor;
|
|
45
|
+
var tableFloatingControlsColor = (0, _tokens.token)('color.background.neutral', _colors.N20); // TODO: https://product-fabric.atlassian.net/browse/DSP-4461
|
|
46
|
+
|
|
47
|
+
exports.tableFloatingControlsColor = tableFloatingControlsColor;
|
|
48
|
+
var tableCellSelectedColor = (0, _tokens.token)('color.blanket.selected', 'rgba(179, 212, 255, 0.3)');
|
|
49
|
+
exports.tableCellSelectedColor = tableCellSelectedColor;
|
|
50
|
+
var tableToolbarSelectedColor = (0, _tokens.token)('color.background.selected.bold', _colors.B200);
|
|
51
|
+
exports.tableToolbarSelectedColor = tableToolbarSelectedColor;
|
|
52
|
+
var tableBorderSelectedColor = (0, _tokens.token)('color.border.selected', _colors.B300);
|
|
53
|
+
exports.tableBorderSelectedColor = tableBorderSelectedColor;
|
|
54
|
+
var tableCellDeleteColor = (0, _tokens.token)('color.blanket.danger', 'rgba(255, 235, 230, 0.3)');
|
|
55
|
+
exports.tableCellDeleteColor = tableCellDeleteColor;
|
|
56
|
+
var tableBorderDeleteColor = (0, _tokens.token)('color.border.danger', _colors.R400);
|
|
57
|
+
exports.tableBorderDeleteColor = tableBorderDeleteColor;
|
|
58
|
+
var tableToolbarDeleteColor = (0, _tokens.token)('color.background.danger.bold', _colors.R75);
|
|
59
|
+
exports.tableToolbarDeleteColor = tableToolbarDeleteColor;
|
|
60
|
+
var tableBorderRadiusSize = 3;
|
|
61
|
+
exports.tableBorderRadiusSize = tableBorderRadiusSize;
|
|
62
|
+
var tablePadding = 8;
|
|
63
|
+
exports.tablePadding = tablePadding;
|
|
64
|
+
var tableScrollbarOffset = 15;
|
|
65
|
+
exports.tableScrollbarOffset = tableScrollbarOffset;
|
|
66
|
+
var tableMarginFullWidthMode = 2;
|
|
67
|
+
exports.tableMarginFullWidthMode = tableMarginFullWidthMode;
|
|
68
|
+
var tableInsertColumnButtonSize = 20;
|
|
69
|
+
exports.tableInsertColumnButtonSize = tableInsertColumnButtonSize;
|
|
70
|
+
var tableDeleteButtonSize = 16;
|
|
71
|
+
exports.tableDeleteButtonSize = tableDeleteButtonSize;
|
|
72
|
+
var tableDeleteButtonOffset = 6;
|
|
73
|
+
exports.tableDeleteButtonOffset = tableDeleteButtonOffset;
|
|
74
|
+
var tableToolbarSize = _editorSharedStyles.akEditorTableToolbarSize;
|
|
75
|
+
exports.tableToolbarSize = tableToolbarSize;
|
|
76
|
+
var tableControlsSpacing = _styles.tableMarginTop + tablePadding - _styles.tableCellBorderWidth;
|
|
77
|
+
exports.tableControlsSpacing = tableControlsSpacing;
|
|
78
|
+
var tableInsertColumnButtonOffset = 3;
|
|
79
|
+
exports.tableInsertColumnButtonOffset = tableInsertColumnButtonOffset;
|
|
80
|
+
var layoutButtonSize = 32;
|
|
81
|
+
exports.layoutButtonSize = layoutButtonSize;
|
|
82
|
+
var lineMarkerOffsetFromColumnControls = 13;
|
|
83
|
+
exports.lineMarkerOffsetFromColumnControls = lineMarkerOffsetFromColumnControls;
|
|
84
|
+
var lineMarkerSize = 4;
|
|
85
|
+
exports.lineMarkerSize = lineMarkerSize;
|
|
86
|
+
var columnControlsDecorationHeight = 25;
|
|
87
|
+
exports.columnControlsDecorationHeight = columnControlsDecorationHeight;
|
|
88
|
+
var columnControlsZIndex = _editorSharedStyles.akEditorUnitZIndex * 10;
|
|
89
|
+
exports.columnControlsZIndex = columnControlsZIndex;
|
|
90
|
+
var columnControlsSelectedZIndex = columnControlsZIndex + 1;
|
|
91
|
+
exports.columnControlsSelectedZIndex = columnControlsSelectedZIndex;
|
|
92
|
+
var columnResizeHandleZIndex = columnControlsSelectedZIndex + 1;
|
|
93
|
+
exports.columnResizeHandleZIndex = columnResizeHandleZIndex;
|
|
94
|
+
var resizeHandlerAreaWidth = _types.RESIZE_HANDLE_AREA_DECORATION_GAP / 3;
|
|
95
|
+
exports.resizeHandlerAreaWidth = resizeHandlerAreaWidth;
|
|
96
|
+
var resizeLineWidth = 2;
|
|
97
|
+
exports.resizeLineWidth = resizeLineWidth;
|
|
98
|
+
var resizeHandlerZIndex = columnControlsZIndex + _editorSharedStyles.akRichMediaResizeZIndex;
|
|
99
|
+
exports.resizeHandlerZIndex = resizeHandlerZIndex;
|
|
100
|
+
var contextualMenuTriggerSize = 16;
|
|
101
|
+
exports.contextualMenuTriggerSize = contextualMenuTriggerSize;
|
|
102
|
+
var contextualMenuDropdownWidth = 180;
|
|
103
|
+
exports.contextualMenuDropdownWidth = contextualMenuDropdownWidth;
|
|
104
|
+
var stickyRowZIndex = resizeHandlerZIndex + 2;
|
|
105
|
+
exports.stickyRowZIndex = stickyRowZIndex;
|
|
106
|
+
var stickyRowOffsetTop = 8;
|
|
107
|
+
exports.stickyRowOffsetTop = stickyRowOffsetTop;
|
|
108
|
+
var stickyHeaderBorderBottomWidth = 1;
|
|
109
|
+
exports.stickyHeaderBorderBottomWidth = stickyHeaderBorderBottomWidth;
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
|
|
8
|
+
var _reactIntlNext = require("react-intl-next");
|
|
9
|
+
|
|
10
|
+
var _default = (0, _reactIntlNext.defineMessages)({
|
|
11
|
+
insertColumn: {
|
|
12
|
+
id: 'fabric.editor.insertColumn',
|
|
13
|
+
defaultMessage: 'Insert column right',
|
|
14
|
+
description: 'Inserts a new column to the right of selected column.'
|
|
15
|
+
},
|
|
16
|
+
removeColumns: {
|
|
17
|
+
id: 'fabric.editor.removeColumns',
|
|
18
|
+
defaultMessage: 'Delete {0, plural, one {column} other {columns}}',
|
|
19
|
+
description: 'Deletes a table column.'
|
|
20
|
+
},
|
|
21
|
+
insertRow: {
|
|
22
|
+
id: 'fabric.editor.insertRow',
|
|
23
|
+
defaultMessage: 'Insert row below',
|
|
24
|
+
description: 'Inserts a new row below the selected row.'
|
|
25
|
+
},
|
|
26
|
+
removeRows: {
|
|
27
|
+
id: 'fabric.editor.removeRows',
|
|
28
|
+
defaultMessage: 'Delete {0, plural, one {row} other {rows}}',
|
|
29
|
+
description: 'Deletes a table row.'
|
|
30
|
+
},
|
|
31
|
+
cellOptions: {
|
|
32
|
+
id: 'fabric.editor.cellOptions',
|
|
33
|
+
defaultMessage: 'Cell options',
|
|
34
|
+
description: 'Opens a menu with options for the current table cell.'
|
|
35
|
+
},
|
|
36
|
+
confirmDeleteLinkedModalOKButton: {
|
|
37
|
+
id: 'fabric.editor.tables.confirmDeleteLinkedModalOKButton',
|
|
38
|
+
defaultMessage: 'Remove table and data',
|
|
39
|
+
description: 'Action button label for confirm modal when deleting a table linked to an extension.'
|
|
40
|
+
},
|
|
41
|
+
confirmDeleteLinkedModalMessage: {
|
|
42
|
+
id: 'fabric.editor.tables.confirmDeleteLinkedModalMessage',
|
|
43
|
+
defaultMessage: 'Removing this table will break all the charts connected to it.',
|
|
44
|
+
description: 'Message for confirm modal when deleting a table linked to an extension.'
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
exports.default = _default;
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.resizeHandle = exports.insertRowButtonWrapper = exports.insertColumnButtonWrapper = exports.hoveredWarningCell = exports.hoveredDeleteButton = exports.hoveredCell = exports.columnControlsLineMarker = exports.columnControlsDecoration = exports.OverflowShadow = exports.InsertMarker = exports.HeaderButtonHover = exports.HeaderButtonDanger = exports.HeaderButton = exports.DeleteButton = void 0;
|
|
9
|
+
|
|
10
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
11
|
+
|
|
12
|
+
var _react = require("@emotion/react");
|
|
13
|
+
|
|
14
|
+
var _styles = require("@atlaskit/editor-common/styles");
|
|
15
|
+
|
|
16
|
+
var _editorSharedStyles = require("@atlaskit/editor-shared-styles");
|
|
17
|
+
|
|
18
|
+
var _colors = require("@atlaskit/theme/colors");
|
|
19
|
+
|
|
20
|
+
var _consts = require("./consts");
|
|
21
|
+
|
|
22
|
+
var _types = require("../types");
|
|
23
|
+
|
|
24
|
+
var _constants = require("@atlaskit/theme/constants");
|
|
25
|
+
|
|
26
|
+
var _tokens = require("@atlaskit/tokens");
|
|
27
|
+
|
|
28
|
+
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11, _templateObject12, _templateObject13, _templateObject14, _templateObject15, _templateObject16, _templateObject17, _templateObject18, _templateObject19, _templateObject20, _templateObject21;
|
|
29
|
+
|
|
30
|
+
var InsertLine = function InsertLine(cssString) {
|
|
31
|
+
return (0, _react.css)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2.default)(["\n .", " {\n background: ", ";\n display: none;\n position: absolute;\n z-index: ", ";\n ", "\n }\n"])), _types.TableCssClassName.CONTROLS_INSERT_LINE, _consts.tableBorderSelectedColor, _editorSharedStyles.akEditorUnitZIndex, cssString);
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
var Marker = function Marker(props) {
|
|
35
|
+
return (0, _react.css)(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2.default)(["\n background-color: ", ";\n position: absolute;\n height: ", "px;\n width: ", "px;\n border-radius: 50%;\n pointer-events: none;\n"])), (0, _consts.tableBorderColor)(props), _consts.lineMarkerSize, _consts.lineMarkerSize);
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
var InsertMarker = function InsertMarker(props, cssString) {
|
|
39
|
+
return (0, _react.css)(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2.default)(["\n .", " {\n ", ";\n ", "\n }\n"])), _types.TableCssClassName.CONTROLS_INSERT_MARKER, Marker(props), cssString);
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
exports.InsertMarker = InsertMarker;
|
|
43
|
+
|
|
44
|
+
var Button = function Button(cssString) {
|
|
45
|
+
return (0, _react.css)(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2.default)(["\n border-radius: ", "px;\n border-width: 0px;\n display: inline-flex;\n max-width: 100%;\n text-align: center;\n margin: 0px;\n padding: 0px;\n text-decoration: none;\n transition: background 0.1s ease-out 0s,\n box-shadow 0.15s cubic-bezier(0.47, 0.03, 0.49, 1.38) 0s;\n outline: none !important;\n cursor: none;\n\n > .", " {\n display: inline-flex;\n max-height: 100%;\n max-width: 100%;\n }\n ", "\n"])), (0, _constants.borderRadius)(), _types.TableCssClassName.CONTROLS_BUTTON_ICON, cssString);
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
var HeaderButton = function HeaderButton(props, cssString) {
|
|
49
|
+
return (0, _react.css)(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2.default)(["\n .", " {\n background: ", ";\n border: 1px solid ", ";\n display: block;\n box-sizing: border-box;\n padding: 0;\n\n :focus {\n outline: none;\n }\n ", "\n }\n\n .", "::after {\n content: ' ';\n background-color: transparent;\n left: -15px;\n top: 0;\n position: absolute;\n width: 15px;\n height: 100%;\n z-index: 1;\n }\n\n .active .", " {\n color: ", ";\n background-color: ", ";\n border-color: ", ";\n }\n"])), _types.TableCssClassName.CONTROLS_BUTTON, (0, _consts.tableToolbarColor)(props), (0, _consts.tableBorderColor)(props), cssString, _types.TableCssClassName.ROW_CONTROLS_BUTTON, _types.TableCssClassName.CONTROLS_BUTTON, (0, _tokens.token)('color.icon.inverse', _colors.N0), _consts.tableToolbarSelectedColor, _consts.tableBorderSelectedColor);
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
exports.HeaderButton = HeaderButton;
|
|
53
|
+
|
|
54
|
+
var HeaderButtonHover = function HeaderButtonHover() {
|
|
55
|
+
return (0, _react.css)(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2.default)(["\n .", ":hover {\n color: ", ";\n background-color: ", ";\n border-color: ", ";\n cursor: pointer;\n }\n"])), _types.TableCssClassName.CONTROLS_BUTTON, (0, _tokens.token)('color.icon.inverse', _colors.N0), _consts.tableToolbarSelectedColor, _consts.tableBorderSelectedColor);
|
|
56
|
+
};
|
|
57
|
+
|
|
58
|
+
exports.HeaderButtonHover = HeaderButtonHover;
|
|
59
|
+
|
|
60
|
+
var HeaderButtonDanger = function HeaderButtonDanger() {
|
|
61
|
+
return (0, _react.css)(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2.default)(["\n .", " .", " {\n background-color: ", ";\n border-color: ", ";\n position: relative;\n z-index: ", ";\n }\n"])), _types.TableCssClassName.HOVERED_CELL_IN_DANGER, _types.TableCssClassName.CONTROLS_BUTTON, _consts.tableToolbarDeleteColor, _consts.tableBorderDeleteColor, _editorSharedStyles.akEditorUnitZIndex);
|
|
62
|
+
};
|
|
63
|
+
|
|
64
|
+
exports.HeaderButtonDanger = HeaderButtonDanger;
|
|
65
|
+
|
|
66
|
+
var InsertButton = function InsertButton() {
|
|
67
|
+
return (0, _react.css)(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2.default)(["\n .", " {\n position: absolute;\n z-index: ", ";\n bottom: 0;\n }\n .", ",\n .", " {\n height: ", "px;\n width: ", "px;\n }\n .", " {\n ", "\n }\n .", " {\n display: none;\n }\n &:hover .", " {\n display: flex;\n }\n"])), _types.TableCssClassName.CONTROLS_INSERT_BUTTON_INNER, _editorSharedStyles.akEditorUnitZIndex + 10, _types.TableCssClassName.CONTROLS_INSERT_BUTTON_INNER, _types.TableCssClassName.CONTROLS_INSERT_BUTTON, _consts.tableInsertColumnButtonSize, _consts.tableInsertColumnButtonSize, _types.TableCssClassName.CONTROLS_INSERT_BUTTON, Button("\n background: ".concat((0, _tokens.token)('elevation.surface.overlay', 'white'), ";\n box-shadow: ").concat((0, _tokens.token)('elevation.shadow.overlay', "0 4px 8px -2px ".concat(_colors.N60A, ", 0 0 1px ").concat(_colors.N60A)), ";\n color: ").concat((0, _tokens.token)('color.icon', _colors.N300), ";\n ")), _types.TableCssClassName.CONTROLS_INSERT_LINE, _types.TableCssClassName.CONTROLS_INSERT_LINE);
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
var InsertButtonHover = function InsertButtonHover() {
|
|
71
|
+
return (0, _react.css)(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2.default)(["\n .", ":hover {\n background: ", ";\n color: ", ";\n cursor: pointer;\n }\n"])), _types.TableCssClassName.CONTROLS_INSERT_BUTTON, (0, _tokens.token)('color.background.brand.bold', _colors.B300), (0, _tokens.token)('color.icon.inverse', 'white'));
|
|
72
|
+
};
|
|
73
|
+
|
|
74
|
+
var insertColumnButtonWrapper = (0, _react.css)(_templateObject10 || (_templateObject10 = (0, _taggedTemplateLiteral2.default)(["\n ", "\n ", "\n ", "\n"])), InsertButton(), InsertButtonHover(), InsertLine("\n width: 2px;\n left: 9px;\n "));
|
|
75
|
+
exports.insertColumnButtonWrapper = insertColumnButtonWrapper;
|
|
76
|
+
var insertRowButtonWrapper = (0, _react.css)(_templateObject11 || (_templateObject11 = (0, _taggedTemplateLiteral2.default)(["\n ", "\n ", "\n ", "\n"])), InsertButton(), InsertButtonHover(), InsertLine("\n height: 2px;\n top: -11px;\n left: ".concat(_consts.tableInsertColumnButtonSize - 1, "px;\n ")));
|
|
77
|
+
exports.insertRowButtonWrapper = insertRowButtonWrapper;
|
|
78
|
+
|
|
79
|
+
var columnControlsLineMarker = function columnControlsLineMarker(props) {
|
|
80
|
+
return (0, _react.css)(_templateObject12 || (_templateObject12 = (0, _taggedTemplateLiteral2.default)(["\n .", ".", "\n table\n tr:first-of-type\n td,\n .", ".", "\n table\n tr:first-of-type\n th {\n position: relative;\n\n &::before {\n content: ' ';\n ", ";\n top: -", "px;\n right: -", "px;\n }\n }\n"])), _types.TableCssClassName.TABLE_CONTAINER, _types.TableCssClassName.WITH_CONTROLS, _types.TableCssClassName.TABLE_CONTAINER, _types.TableCssClassName.WITH_CONTROLS, Marker(props), _consts.tableToolbarSize + _consts.lineMarkerOffsetFromColumnControls, _consts.lineMarkerSize / 2);
|
|
81
|
+
};
|
|
82
|
+
|
|
83
|
+
exports.columnControlsLineMarker = columnControlsLineMarker;
|
|
84
|
+
var DeleteButton = (0, _react.css)(_templateObject13 || (_templateObject13 = (0, _taggedTemplateLiteral2.default)(["\n .", ",\n .", " {\n height: ", "px;\n width: ", "px;\n }\n .", " {\n .", " {\n ", "\n }\n }\n\n .", ":hover {\n background: ", ";\n color: ", ";\n cursor: pointer;\n }\n"])), _types.TableCssClassName.CONTROLS_DELETE_BUTTON_WRAP, _types.TableCssClassName.CONTROLS_DELETE_BUTTON, _consts.tableDeleteButtonSize, _consts.tableDeleteButtonSize, _types.TableCssClassName.CONTROLS_DELETE_BUTTON_WRAP, _types.TableCssClassName.CONTROLS_DELETE_BUTTON, Button("\n background: ".concat((0, _tokens.token)('color.background.neutral', _colors.N20A), ";\n color: ").concat((0, _tokens.token)('color.icon', _colors.N300), ";\n ")), _types.TableCssClassName.CONTROLS_DELETE_BUTTON, (0, _tokens.token)('color.background.danger.bold', _colors.R300), (0, _tokens.token)('color.icon.inverse', 'white')); // TODO: https://product-fabric.atlassian.net/browse/DSP-4451
|
|
85
|
+
|
|
86
|
+
/* eslint-disable @atlaskit/design-system/ensure-design-token-usage */
|
|
87
|
+
|
|
88
|
+
exports.DeleteButton = DeleteButton;
|
|
89
|
+
|
|
90
|
+
var OverflowShadow = function OverflowShadow(props) {
|
|
91
|
+
return (0, _react.css)(_templateObject14 || (_templateObject14 = (0, _taggedTemplateLiteral2.default)(["\n .", ", .", " {\n display: block;\n height: calc(\n 100% - ", "px\n );\n position: absolute;\n pointer-events: none;\n top: ", "px;\n z-index: ", ";\n width: 8px;\n }\n .", " {\n background: linear-gradient(to left, rgba(99, 114, 130, 0) 0, ", " 100%);\n left: 0px;\n }\n .", "[data-number-column='true'] > :not(.", ").", " {\n left: ", "px;\n }\n .", " {\n background: linear-gradient(\n to right,\n rgba(99, 114, 130, 0) 0,\n ", " 100%\n );\n left: calc(100% + 2px);\n }\n .", " {\n .", ", .", " {\n height: calc(100% - ", "px);\n top: ", "px;\n }\n .", " {\n border-left: 1px solid ", ";\n }\n }\n .", ".", " {\n .", ", .", " {\n top: ", "px;\n }\n }\n"])), _types.TableCssClassName.TABLE_RIGHT_SHADOW, _types.TableCssClassName.TABLE_LEFT_SHADOW, _styles.tableMarginTop + _styles.tableMarginBottom + _consts.tableToolbarSize - 2, _styles.tableMarginTop + _consts.tableToolbarSize - 1, _editorSharedStyles.akEditorShadowZIndex, _types.TableCssClassName.TABLE_LEFT_SHADOW, _colors.N40A, _types.TableCssClassName.TABLE_CONTAINER, _types.TableCssClassName.TABLE_STICKY_SHADOW, _types.TableCssClassName.TABLE_LEFT_SHADOW, _editorSharedStyles.akEditorTableNumberColumnWidth - 1, _types.TableCssClassName.TABLE_RIGHT_SHADOW, _colors.N40A, _types.TableCssClassName.WITH_CONTROLS, _types.TableCssClassName.TABLE_RIGHT_SHADOW, _types.TableCssClassName.TABLE_LEFT_SHADOW, _styles.tableMarginTop + _styles.tableMarginBottom - 2, _styles.tableMarginTop - 1, _types.TableCssClassName.TABLE_LEFT_SHADOW, (0, _consts.tableBorderColor)(props), _types.TableCssClassName.WITH_CONTROLS, _types.TableCssClassName.TABLE_STICKY, _types.TableCssClassName.TABLE_RIGHT_SHADOW, _types.TableCssClassName.TABLE_LEFT_SHADOW, _consts.tableControlsSpacing);
|
|
92
|
+
};
|
|
93
|
+
/* eslint-enable @atlaskit/design-system/ensure-design-token-usage */
|
|
94
|
+
|
|
95
|
+
|
|
96
|
+
exports.OverflowShadow = OverflowShadow;
|
|
97
|
+
|
|
98
|
+
var columnHeaderButton = function columnHeaderButton(props, cssString) {
|
|
99
|
+
return (0, _react.css)(_templateObject15 || (_templateObject15 = (0, _taggedTemplateLiteral2.default)(["\n background: ", ";\n border: 1px solid ", ";\n display: block;\n box-sizing: border-box;\n padding: 0;\n\n :focus {\n outline: none;\n }\n\n ", "\n"])), (0, _consts.tableToolbarColor)(props), (0, _consts.tableBorderColor)(props), cssString);
|
|
100
|
+
};
|
|
101
|
+
|
|
102
|
+
var columnHeaderButtonSelected = (0, _react.css)(_templateObject16 || (_templateObject16 = (0, _taggedTemplateLiteral2.default)(["\n color: ", ";\n background-color: ", ";\n border-color: ", ";\n z-index: ", ";\n"])), (0, _tokens.token)('color.text.inverse', _colors.N0), _consts.tableToolbarSelectedColor, _consts.tableBorderSelectedColor, _consts.columnControlsSelectedZIndex);
|
|
103
|
+
|
|
104
|
+
var columnControlsDecoration = function columnControlsDecoration(props) {
|
|
105
|
+
return (0, _react.css)(_templateObject17 || (_templateObject17 = (0, _taggedTemplateLiteral2.default)(["\n .", " {\n display: none;\n cursor: pointer;\n position: absolute;\n width: calc(100% + ", "px);\n left: -1px;\n top: -", "px;\n height: ", "px;\n\n &::after {\n content: ' ';\n\n ", "\n }\n }\n\n .", " .", " {\n display: block;\n }\n\n table\n tr:first-of-type\n td.", ",\n table\n tr:first-of-type\n th.", " {\n &.", ",\n &.", ",\n &.", " {\n .", "::after {\n ", ";\n }\n\n &.", "\n .", "::after {\n background-color: ", ";\n border: 1px solid ", ";\n border-bottom: none;\n z-index: ", ";\n }\n }\n }\n\n .", "\n table\n tr:first-of-type\n td.", ",\n .", "\n table\n tr:first-of-type\n th.", " {\n .", "::after {\n ", ";\n }\n }\n"])), _types.TableCssClassName.COLUMN_CONTROLS_DECORATIONS, _styles.tableCellBorderWidth * 2, _consts.columnControlsDecorationHeight + _styles.tableCellBorderWidth, _consts.columnControlsDecorationHeight, columnHeaderButton(props, "\n border-right: ".concat(_styles.tableCellBorderWidth, "px solid ").concat((0, _consts.tableBorderColor)(props), ";\n border-bottom: none;\n height: ").concat(_consts.tableToolbarSize, "px;\n width: 100%;\n position: absolute;\n top: ").concat(_consts.columnControlsDecorationHeight - _consts.tableToolbarSize, "px;\n left: 0px;\n z-index: ").concat(_consts.columnControlsZIndex, ";\n ")), _types.TableCssClassName.WITH_CONTROLS, _types.TableCssClassName.COLUMN_CONTROLS_DECORATIONS, _types.TableCssClassName.TABLE_CELL, _types.TableCssClassName.TABLE_HEADER_CELL, _types.TableCssClassName.COLUMN_SELECTED, _types.TableCssClassName.HOVERED_COLUMN, _types.TableCssClassName.HOVERED_TABLE, _types.TableCssClassName.COLUMN_CONTROLS_DECORATIONS, columnHeaderButtonSelected, _types.TableCssClassName.HOVERED_CELL_IN_DANGER, _types.TableCssClassName.COLUMN_CONTROLS_DECORATIONS, _consts.tableToolbarDeleteColor, _consts.tableBorderDeleteColor, _editorSharedStyles.akEditorUnitZIndex * 100, _types.TableCssClassName.TABLE_SELECTED, _types.TableCssClassName.TABLE_CELL, _types.TableCssClassName.TABLE_SELECTED, _types.TableCssClassName.TABLE_HEADER_CELL, _types.TableCssClassName.COLUMN_CONTROLS_DECORATIONS, columnHeaderButtonSelected);
|
|
106
|
+
};
|
|
107
|
+
|
|
108
|
+
exports.columnControlsDecoration = columnControlsDecoration;
|
|
109
|
+
var hoveredDeleteButton = (0, _react.css)(_templateObject18 || (_templateObject18 = (0, _taggedTemplateLiteral2.default)(["\n .", ".", " {\n .", ",\n .", ",\n .", " {\n border: 1px solid ", ";\n }\n .", "::after {\n background: ", ";\n }\n }\n"])), _types.TableCssClassName.TABLE_CONTAINER, _types.TableCssClassName.HOVERED_DELETE_BUTTON, _types.TableCssClassName.SELECTED_CELL, _types.TableCssClassName.COLUMN_SELECTED, _types.TableCssClassName.HOVERED_CELL, _consts.tableBorderDeleteColor, _types.TableCssClassName.SELECTED_CELL, _consts.tableCellDeleteColor);
|
|
110
|
+
exports.hoveredDeleteButton = hoveredDeleteButton;
|
|
111
|
+
var hoveredCell = (0, _react.css)(_templateObject19 || (_templateObject19 = (0, _taggedTemplateLiteral2.default)(["\n :not(.", ")\n .", ":not(.", ") {\n .", " {\n position: relative;\n border: 1px solid ", ";\n }\n }\n"])), _types.TableCssClassName.IS_RESIZING, _types.TableCssClassName.TABLE_CONTAINER, _types.TableCssClassName.HOVERED_DELETE_BUTTON, _types.TableCssClassName.HOVERED_CELL, _consts.tableBorderSelectedColor);
|
|
112
|
+
exports.hoveredCell = hoveredCell;
|
|
113
|
+
var hoveredWarningCell = (0, _react.css)(_templateObject20 || (_templateObject20 = (0, _taggedTemplateLiteral2.default)(["\n :not(.", ")\n .", ":not(.", ") {\n td.", " {\n background-color: ", " !important; // We need to override the background-color added to the cell\n border: 1px solid ", ";\n }\n }\n"])), _types.TableCssClassName.IS_RESIZING, _types.TableCssClassName.TABLE_CONTAINER, _types.TableCssClassName.HOVERED_DELETE_BUTTON, _types.TableCssClassName.HOVERED_CELL_WARNING, (0, _tokens.token)('color.background.warning', _colors.Y50), (0, _tokens.token)('color.border.warning', _colors.Y200));
|
|
114
|
+
exports.hoveredWarningCell = hoveredWarningCell;
|
|
115
|
+
var resizeHandle = (0, _react.css)(_templateObject21 || (_templateObject21 = (0, _taggedTemplateLiteral2.default)(["\n .", " {\n .", " {\n background-color: transparent;\n position: absolute;\n width: ", "px;\n height: 100%;\n top: 0;\n right: -", "px;\n cursor: col-resize;\n z-index: ", ";\n }\n\n td.", ", th.", " {\n .", "::after {\n content: ' ';\n right: ", "px;\n position: absolute;\n width: ", "px;\n height: calc(100% + 1px);\n background-color: ", ";\n z-index: ", ";\n top: 0;\n }\n }\n\n table\n tr:first-of-type\n th.", "\n .", "::after,\n table\n tr:first-of-type\n td.", "\n .", "::after {\n top: -", "px;\n height: calc(100% + ", "px);\n }\n }\n"])), _types.TableCssClassName.TABLE_CONTAINER, _types.TableCssClassName.RESIZE_HANDLE_DECORATION, _consts.resizeHandlerAreaWidth, _consts.resizeHandlerAreaWidth / 2, _consts.resizeHandlerZIndex, _types.TableCssClassName.WITH_RESIZE_LINE, _types.TableCssClassName.WITH_RESIZE_LINE, _types.TableCssClassName.RESIZE_HANDLE_DECORATION, (_consts.resizeHandlerAreaWidth - _consts.resizeLineWidth) / 2, _consts.resizeLineWidth, _consts.tableBorderSelectedColor, _consts.columnControlsZIndex * 2, _types.TableCssClassName.WITH_RESIZE_LINE, _types.TableCssClassName.RESIZE_HANDLE_DECORATION, _types.TableCssClassName.WITH_RESIZE_LINE, _types.TableCssClassName.RESIZE_HANDLE_DECORATION, _consts.tableToolbarSize + _styles.tableCellBorderWidth, _consts.tableToolbarSize + _styles.tableCellBorderWidth);
|
|
116
|
+
exports.resizeHandle = resizeHandle;
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.getSelectedCellInfo = getSelectedCellInfo;
|
|
7
|
+
exports.getSelectedTableInfo = getSelectedTableInfo;
|
|
8
|
+
exports.withEditorAnalyticsAPI = void 0;
|
|
9
|
+
|
|
10
|
+
var _tableMap = require("@atlaskit/editor-tables/table-map");
|
|
11
|
+
|
|
12
|
+
var _utils = require("@atlaskit/editor-tables/utils");
|
|
13
|
+
|
|
14
|
+
function getSelectedTableInfo(selection) {
|
|
15
|
+
var map;
|
|
16
|
+
var totalRowCount = 0;
|
|
17
|
+
var totalColumnCount = 0;
|
|
18
|
+
var table = (0, _utils.findTable)(selection);
|
|
19
|
+
|
|
20
|
+
if (table) {
|
|
21
|
+
map = _tableMap.TableMap.get(table.node);
|
|
22
|
+
totalRowCount = map.height;
|
|
23
|
+
totalColumnCount = map.width;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
return {
|
|
27
|
+
table: table,
|
|
28
|
+
map: map,
|
|
29
|
+
totalRowCount: totalRowCount,
|
|
30
|
+
totalColumnCount: totalColumnCount
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
function getSelectedCellInfo(selection) {
|
|
35
|
+
var horizontalCells = 1;
|
|
36
|
+
var verticalCells = 1;
|
|
37
|
+
var totalCells = 1;
|
|
38
|
+
|
|
39
|
+
var _getSelectedTableInfo = getSelectedTableInfo(selection),
|
|
40
|
+
table = _getSelectedTableInfo.table,
|
|
41
|
+
map = _getSelectedTableInfo.map,
|
|
42
|
+
totalRowCount = _getSelectedTableInfo.totalRowCount,
|
|
43
|
+
totalColumnCount = _getSelectedTableInfo.totalColumnCount;
|
|
44
|
+
|
|
45
|
+
if (table && map) {
|
|
46
|
+
var rect = (0, _utils.getSelectionRect)(selection);
|
|
47
|
+
|
|
48
|
+
if (rect) {
|
|
49
|
+
totalCells = map.cellsInRect(rect).length;
|
|
50
|
+
horizontalCells = rect.right - rect.left;
|
|
51
|
+
verticalCells = rect.bottom - rect.top;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
return {
|
|
56
|
+
totalRowCount: totalRowCount,
|
|
57
|
+
totalColumnCount: totalColumnCount,
|
|
58
|
+
horizontalCells: horizontalCells,
|
|
59
|
+
verticalCells: verticalCells,
|
|
60
|
+
totalCells: totalCells
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
var withEditorAnalyticsAPI = function withEditorAnalyticsAPI(payload) {
|
|
65
|
+
return function (editorAnalyticsAPI) {
|
|
66
|
+
return function (command) {
|
|
67
|
+
return function (state, dispatch, view) {
|
|
68
|
+
return command(state, function (tr) {
|
|
69
|
+
var dynamicPayload = payload instanceof Function ? payload(state) : payload;
|
|
70
|
+
|
|
71
|
+
if (dynamicPayload) {
|
|
72
|
+
editorAnalyticsAPI === null || editorAnalyticsAPI === void 0 ? void 0 : editorAnalyticsAPI.attachAnalyticsEvent(dynamicPayload)(tr);
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
if (dispatch) {
|
|
76
|
+
dispatch(tr);
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
return true;
|
|
80
|
+
}, view);
|
|
81
|
+
};
|
|
82
|
+
};
|
|
83
|
+
};
|
|
84
|
+
};
|
|
85
|
+
|
|
86
|
+
exports.withEditorAnalyticsAPI = withEditorAnalyticsAPI;
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.isTableCollapsible = exports.collapseSelectedTable = void 0;
|
|
7
|
+
|
|
8
|
+
var _prosemirrorModel = require("prosemirror-model");
|
|
9
|
+
|
|
10
|
+
var _prosemirrorTransform = require("prosemirror-transform");
|
|
11
|
+
|
|
12
|
+
var _utils = require("@atlaskit/editor-tables/utils");
|
|
13
|
+
|
|
14
|
+
var bail = function bail() {
|
|
15
|
+
return {
|
|
16
|
+
tableIsCollapsible: false
|
|
17
|
+
};
|
|
18
|
+
};
|
|
19
|
+
/**
|
|
20
|
+
* Checks whether we can wrap the selected table into an expand via
|
|
21
|
+
* prosemirror-transform's `findWrapping` helper
|
|
22
|
+
*/
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
var isTableCollapsible = function isTableCollapsible(tr) {
|
|
26
|
+
var selection = tr.selection;
|
|
27
|
+
var schema = tr.doc.type.schema;
|
|
28
|
+
var nodePos = (0, _utils.findTable)(selection);
|
|
29
|
+
|
|
30
|
+
if (!nodePos) {
|
|
31
|
+
return bail();
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
var expand = schema.nodes.expand;
|
|
35
|
+
var node = nodePos.node,
|
|
36
|
+
pos = nodePos.pos;
|
|
37
|
+
var $pos = tr.doc.resolve(pos);
|
|
38
|
+
var range = new _prosemirrorModel.NodeRange($pos, tr.doc.resolve(pos + node.nodeSize), $pos.depth);
|
|
39
|
+
|
|
40
|
+
if (!range) {
|
|
41
|
+
return bail();
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
var canWrap = (0, _prosemirrorTransform.findWrapping)(range, expand);
|
|
45
|
+
|
|
46
|
+
if (canWrap === null) {
|
|
47
|
+
return bail();
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
return {
|
|
51
|
+
tableIsCollapsible: true,
|
|
52
|
+
range: range,
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* Do we ever want to deal with the result of `findWrapping`? Probably not,
|
|
56
|
+
* but we have it anyway.
|
|
57
|
+
*/
|
|
58
|
+
findWrappingRes: canWrap
|
|
59
|
+
};
|
|
60
|
+
};
|
|
61
|
+
/**
|
|
62
|
+
* Collapses the selected table into an expand given a transaction via
|
|
63
|
+
* `Transform.wrap`.
|
|
64
|
+
*
|
|
65
|
+
* Will return undefined if it cannot determine the relevant table from a
|
|
66
|
+
* selection, or if the table itself isn't collapsible.
|
|
67
|
+
*
|
|
68
|
+
* @param tr
|
|
69
|
+
* @returns Transaction | undefined
|
|
70
|
+
*/
|
|
71
|
+
|
|
72
|
+
|
|
73
|
+
exports.isTableCollapsible = isTableCollapsible;
|
|
74
|
+
|
|
75
|
+
var collapseSelectedTable = function collapseSelectedTable(tr) {
|
|
76
|
+
var canCollapse = isTableCollapsible(tr);
|
|
77
|
+
var expand = tr.doc.type.schema.nodes.expand;
|
|
78
|
+
|
|
79
|
+
if (!canCollapse.range || !canCollapse.tableIsCollapsible) {
|
|
80
|
+
return undefined;
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* TODO: add attrs: { __expanded: false } when
|
|
84
|
+
* - it is working with new collab (CEMS-1204)
|
|
85
|
+
* - synchrony is no longer used
|
|
86
|
+
*
|
|
87
|
+
* (via confluence-frontend, "this feature" referencing allowInteractiveExpand)
|
|
88
|
+
* `we can NEVER allow this feature to be enabled for the synchrony-powered editor
|
|
89
|
+
*/
|
|
90
|
+
|
|
91
|
+
|
|
92
|
+
tr.wrap(canCollapse.range, [{
|
|
93
|
+
type: expand
|
|
94
|
+
}]).setMeta('scrollIntoView', true);
|
|
95
|
+
return tr;
|
|
96
|
+
};
|
|
97
|
+
|
|
98
|
+
exports.collapseSelectedTable = collapseSelectedTable;
|