@atlaskit/editor-plugin-table 7.5.4 → 7.5.6

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.
Files changed (236) hide show
  1. package/CHANGELOG.md +13 -0
  2. package/dist/cjs/commands/column-resize.js +3 -3
  3. package/dist/cjs/commands/delete.js +2 -2
  4. package/dist/cjs/commands/insert.js +15 -15
  5. package/dist/cjs/commands-with-analytics.js +7 -7
  6. package/dist/cjs/event-handlers.js +27 -11
  7. package/dist/cjs/nodeviews/OverflowShadowsObserver.js +24 -15
  8. package/dist/cjs/nodeviews/TableCell.js +5 -30
  9. package/dist/cjs/nodeviews/TableComponent.js +120 -83
  10. package/dist/cjs/nodeviews/TableContainer.js +23 -21
  11. package/dist/cjs/nodeviews/TableResizer.js +13 -13
  12. package/dist/cjs/nodeviews/table.js +9 -9
  13. package/dist/cjs/plugin.js +60 -59
  14. package/dist/cjs/pm-plugins/drag-and-drop/plugin.js +13 -13
  15. package/dist/cjs/pm-plugins/keymap.js +6 -8
  16. package/dist/cjs/pm-plugins/main.js +7 -24
  17. package/dist/cjs/pm-plugins/sticky-headers/plugin.js +2 -3
  18. package/dist/cjs/pm-plugins/table-resizing/event-handlers.js +12 -12
  19. package/dist/cjs/pm-plugins/table-resizing/utils/colgroup.js +2 -2
  20. package/dist/cjs/pm-plugins/table-resizing/utils/consts.js +4 -2
  21. package/dist/cjs/pm-plugins/table-resizing/utils/index.js +2 -2
  22. package/dist/cjs/pm-plugins/table-resizing/utils/misc.js +3 -3
  23. package/dist/cjs/pm-plugins/table-resizing/utils/resize-column.js +3 -3
  24. package/dist/cjs/pm-plugins/table-resizing/utils/resize-state.js +11 -12
  25. package/dist/cjs/pm-plugins/table-resizing/utils/scale-table.js +13 -13
  26. package/dist/cjs/pm-plugins/table-width.js +6 -2
  27. package/dist/cjs/toolbar.js +21 -21
  28. package/dist/cjs/transforms/column-width.js +4 -4
  29. package/dist/cjs/transforms/delete-columns.js +2 -2
  30. package/dist/cjs/ui/FloatingContextualMenu/ContextualMenu.js +53 -55
  31. package/dist/cjs/ui/FloatingContextualMenu/index.js +2 -4
  32. package/dist/cjs/ui/FloatingDragMenu/DragMenu.js +2 -2
  33. package/dist/cjs/ui/FloatingDragMenu/index.js +6 -6
  34. package/dist/cjs/ui/FloatingInsertButton/index.js +6 -7
  35. package/dist/cjs/ui/TableFloatingColumnControls/index.js +8 -48
  36. package/dist/cjs/ui/TableFloatingControls/index.js +113 -223
  37. package/dist/cjs/utils/column-controls.js +5 -5
  38. package/dist/cjs/utils/create.js +2 -5
  39. package/dist/cjs/utils/dom.js +13 -15
  40. package/dist/cjs/utils/drag-menu.js +4 -4
  41. package/dist/es2019/commands/column-resize.js +3 -3
  42. package/dist/es2019/commands/delete.js +2 -2
  43. package/dist/es2019/commands/insert.js +12 -12
  44. package/dist/es2019/commands-with-analytics.js +6 -6
  45. package/dist/es2019/event-handlers.js +27 -11
  46. package/dist/es2019/nodeviews/OverflowShadowsObserver.js +24 -15
  47. package/dist/es2019/nodeviews/TableCell.js +1 -24
  48. package/dist/es2019/nodeviews/TableComponent.js +88 -63
  49. package/dist/es2019/nodeviews/TableContainer.js +20 -22
  50. package/dist/es2019/nodeviews/TableResizer.js +13 -13
  51. package/dist/es2019/nodeviews/table.js +9 -9
  52. package/dist/es2019/plugin.js +19 -20
  53. package/dist/es2019/pm-plugins/drag-and-drop/plugin.js +6 -6
  54. package/dist/es2019/pm-plugins/keymap.js +5 -8
  55. package/dist/es2019/pm-plugins/main.js +6 -23
  56. package/dist/es2019/pm-plugins/sticky-headers/plugin.js +1 -1
  57. package/dist/es2019/pm-plugins/table-resizing/event-handlers.js +5 -5
  58. package/dist/es2019/pm-plugins/table-resizing/utils/colgroup.js +2 -2
  59. package/dist/es2019/pm-plugins/table-resizing/utils/consts.js +3 -1
  60. package/dist/es2019/pm-plugins/table-resizing/utils/index.js +1 -1
  61. package/dist/es2019/pm-plugins/table-resizing/utils/misc.js +2 -2
  62. package/dist/es2019/pm-plugins/table-resizing/utils/resize-column.js +3 -2
  63. package/dist/es2019/pm-plugins/table-resizing/utils/resize-state.js +12 -13
  64. package/dist/es2019/pm-plugins/table-resizing/utils/scale-table.js +13 -13
  65. package/dist/es2019/pm-plugins/table-width.js +6 -2
  66. package/dist/es2019/toolbar.js +15 -15
  67. package/dist/es2019/transforms/column-width.js +5 -5
  68. package/dist/es2019/transforms/delete-columns.js +2 -2
  69. package/dist/es2019/ui/FloatingContextualMenu/ContextualMenu.js +9 -12
  70. package/dist/es2019/ui/FloatingContextualMenu/index.js +2 -4
  71. package/dist/es2019/ui/FloatingDragMenu/DragMenu.js +2 -2
  72. package/dist/es2019/ui/FloatingDragMenu/index.js +5 -5
  73. package/dist/es2019/ui/FloatingInsertButton/index.js +5 -6
  74. package/dist/es2019/ui/TableFloatingColumnControls/index.js +5 -27
  75. package/dist/es2019/ui/TableFloatingControls/index.js +119 -193
  76. package/dist/es2019/utils/column-controls.js +6 -6
  77. package/dist/es2019/utils/create.js +2 -5
  78. package/dist/es2019/utils/dom.js +13 -15
  79. package/dist/es2019/utils/drag-menu.js +4 -4
  80. package/dist/esm/commands/column-resize.js +3 -3
  81. package/dist/esm/commands/delete.js +2 -2
  82. package/dist/esm/commands/insert.js +15 -15
  83. package/dist/esm/commands-with-analytics.js +7 -7
  84. package/dist/esm/event-handlers.js +27 -11
  85. package/dist/esm/nodeviews/OverflowShadowsObserver.js +24 -15
  86. package/dist/esm/nodeviews/TableCell.js +5 -30
  87. package/dist/esm/nodeviews/TableComponent.js +119 -82
  88. package/dist/esm/nodeviews/TableContainer.js +24 -22
  89. package/dist/esm/nodeviews/TableResizer.js +13 -13
  90. package/dist/esm/nodeviews/table.js +9 -9
  91. package/dist/esm/plugin.js +60 -59
  92. package/dist/esm/pm-plugins/drag-and-drop/plugin.js +13 -13
  93. package/dist/esm/pm-plugins/keymap.js +6 -8
  94. package/dist/esm/pm-plugins/main.js +7 -24
  95. package/dist/esm/pm-plugins/sticky-headers/plugin.js +2 -3
  96. package/dist/esm/pm-plugins/table-resizing/event-handlers.js +12 -12
  97. package/dist/esm/pm-plugins/table-resizing/utils/colgroup.js +2 -2
  98. package/dist/esm/pm-plugins/table-resizing/utils/consts.js +3 -1
  99. package/dist/esm/pm-plugins/table-resizing/utils/index.js +1 -1
  100. package/dist/esm/pm-plugins/table-resizing/utils/misc.js +2 -2
  101. package/dist/esm/pm-plugins/table-resizing/utils/resize-column.js +4 -3
  102. package/dist/esm/pm-plugins/table-resizing/utils/resize-state.js +13 -14
  103. package/dist/esm/pm-plugins/table-resizing/utils/scale-table.js +13 -13
  104. package/dist/esm/pm-plugins/table-width.js +6 -2
  105. package/dist/esm/toolbar.js +21 -21
  106. package/dist/esm/transforms/column-width.js +5 -5
  107. package/dist/esm/transforms/delete-columns.js +2 -2
  108. package/dist/esm/ui/FloatingContextualMenu/ContextualMenu.js +53 -55
  109. package/dist/esm/ui/FloatingContextualMenu/index.js +2 -4
  110. package/dist/esm/ui/FloatingDragMenu/DragMenu.js +2 -2
  111. package/dist/esm/ui/FloatingDragMenu/index.js +6 -6
  112. package/dist/esm/ui/FloatingInsertButton/index.js +6 -7
  113. package/dist/esm/ui/TableFloatingColumnControls/index.js +8 -48
  114. package/dist/esm/ui/TableFloatingControls/index.js +113 -224
  115. package/dist/esm/utils/column-controls.js +6 -6
  116. package/dist/esm/utils/create.js +2 -5
  117. package/dist/esm/utils/dom.js +13 -15
  118. package/dist/esm/utils/drag-menu.js +4 -4
  119. package/dist/types/commands/column-resize.d.ts +1 -1
  120. package/dist/types/commands/delete.d.ts +1 -1
  121. package/dist/types/commands/insert.d.ts +7 -7
  122. package/dist/types/commands-with-analytics.d.ts +3 -3
  123. package/dist/types/event-handlers.d.ts +4 -5
  124. package/dist/types/nodeviews/OverflowShadowsObserver.d.ts +3 -1
  125. package/dist/types/nodeviews/TableCell.d.ts +1 -5
  126. package/dist/types/nodeviews/TableComponent.d.ts +6 -3
  127. package/dist/types/nodeviews/TableContainer.d.ts +6 -4
  128. package/dist/types/nodeviews/TableResizer.d.ts +2 -2
  129. package/dist/types/nodeviews/table.d.ts +1 -1
  130. package/dist/types/nodeviews/types.d.ts +1 -0
  131. package/dist/types/plugin.d.ts +1 -0
  132. package/dist/types/pm-plugins/drag-and-drop/plugin.d.ts +1 -2
  133. package/dist/types/pm-plugins/keymap.d.ts +2 -2
  134. package/dist/types/pm-plugins/main.d.ts +1 -1
  135. package/dist/types/pm-plugins/sticky-headers/plugin.d.ts +2 -3
  136. package/dist/types/pm-plugins/table-resizing/utils/colgroup.d.ts +1 -1
  137. package/dist/types/pm-plugins/table-resizing/utils/consts.d.ts +1 -0
  138. package/dist/types/pm-plugins/table-resizing/utils/index.d.ts +1 -1
  139. package/dist/types/pm-plugins/table-resizing/utils/misc.d.ts +1 -1
  140. package/dist/types/pm-plugins/table-resizing/utils/resize-column.d.ts +2 -1
  141. package/dist/types/pm-plugins/table-resizing/utils/resize-state.d.ts +4 -4
  142. package/dist/types/pm-plugins/table-resizing/utils/scale-table.d.ts +4 -4
  143. package/dist/types/pm-plugins/table-width.d.ts +1 -2
  144. package/dist/types/toolbar.d.ts +2 -2
  145. package/dist/types/transforms/column-width.d.ts +1 -1
  146. package/dist/types/transforms/delete-columns.d.ts +1 -1
  147. package/dist/types/types.d.ts +1 -3
  148. package/dist/types/ui/FloatingContextualMenu/index.d.ts +1 -1
  149. package/dist/types/ui/FloatingDragMenu/DragMenu.d.ts +2 -2
  150. package/dist/types/ui/FloatingDragMenu/index.d.ts +2 -3
  151. package/dist/types/ui/FloatingInsertButton/index.d.ts +1 -2
  152. package/dist/types/ui/TableFloatingColumnControls/index.d.ts +2 -1
  153. package/dist/types/ui/TableFloatingControls/index.d.ts +5 -22
  154. package/dist/types/utils/create.d.ts +1 -2
  155. package/dist/types/utils/dom.d.ts +10 -2
  156. package/dist/types/utils/drag-menu.d.ts +1 -1
  157. package/dist/types-ts4.5/commands/column-resize.d.ts +1 -1
  158. package/dist/types-ts4.5/commands/delete.d.ts +1 -1
  159. package/dist/types-ts4.5/commands/insert.d.ts +7 -7
  160. package/dist/types-ts4.5/commands-with-analytics.d.ts +3 -3
  161. package/dist/types-ts4.5/event-handlers.d.ts +4 -5
  162. package/dist/types-ts4.5/nodeviews/OverflowShadowsObserver.d.ts +3 -1
  163. package/dist/types-ts4.5/nodeviews/TableCell.d.ts +1 -5
  164. package/dist/types-ts4.5/nodeviews/TableComponent.d.ts +6 -3
  165. package/dist/types-ts4.5/nodeviews/TableContainer.d.ts +6 -4
  166. package/dist/types-ts4.5/nodeviews/TableResizer.d.ts +2 -2
  167. package/dist/types-ts4.5/nodeviews/table.d.ts +1 -1
  168. package/dist/types-ts4.5/nodeviews/types.d.ts +1 -0
  169. package/dist/types-ts4.5/plugin.d.ts +1 -0
  170. package/dist/types-ts4.5/pm-plugins/drag-and-drop/plugin.d.ts +1 -2
  171. package/dist/types-ts4.5/pm-plugins/keymap.d.ts +2 -2
  172. package/dist/types-ts4.5/pm-plugins/main.d.ts +1 -1
  173. package/dist/types-ts4.5/pm-plugins/sticky-headers/plugin.d.ts +2 -3
  174. package/dist/types-ts4.5/pm-plugins/table-resizing/utils/colgroup.d.ts +1 -1
  175. package/dist/types-ts4.5/pm-plugins/table-resizing/utils/consts.d.ts +1 -0
  176. package/dist/types-ts4.5/pm-plugins/table-resizing/utils/index.d.ts +1 -1
  177. package/dist/types-ts4.5/pm-plugins/table-resizing/utils/misc.d.ts +1 -1
  178. package/dist/types-ts4.5/pm-plugins/table-resizing/utils/resize-column.d.ts +2 -1
  179. package/dist/types-ts4.5/pm-plugins/table-resizing/utils/resize-state.d.ts +4 -4
  180. package/dist/types-ts4.5/pm-plugins/table-resizing/utils/scale-table.d.ts +4 -4
  181. package/dist/types-ts4.5/pm-plugins/table-width.d.ts +1 -2
  182. package/dist/types-ts4.5/toolbar.d.ts +2 -2
  183. package/dist/types-ts4.5/transforms/column-width.d.ts +1 -1
  184. package/dist/types-ts4.5/transforms/delete-columns.d.ts +1 -1
  185. package/dist/types-ts4.5/types.d.ts +1 -3
  186. package/dist/types-ts4.5/ui/FloatingContextualMenu/index.d.ts +1 -1
  187. package/dist/types-ts4.5/ui/FloatingDragMenu/DragMenu.d.ts +2 -2
  188. package/dist/types-ts4.5/ui/FloatingDragMenu/index.d.ts +2 -3
  189. package/dist/types-ts4.5/ui/FloatingInsertButton/index.d.ts +1 -2
  190. package/dist/types-ts4.5/ui/TableFloatingColumnControls/index.d.ts +2 -1
  191. package/dist/types-ts4.5/ui/TableFloatingControls/index.d.ts +5 -22
  192. package/dist/types-ts4.5/utils/create.d.ts +1 -2
  193. package/dist/types-ts4.5/utils/dom.d.ts +10 -2
  194. package/dist/types-ts4.5/utils/drag-menu.d.ts +1 -1
  195. package/package.json +3 -4
  196. package/src/commands/column-resize.ts +4 -3
  197. package/src/commands/delete.ts +2 -2
  198. package/src/commands/insert.ts +15 -27
  199. package/src/commands-with-analytics.ts +6 -9
  200. package/src/event-handlers.ts +107 -105
  201. package/src/nodeviews/OverflowShadowsObserver.ts +32 -21
  202. package/src/nodeviews/TableCell.ts +0 -26
  203. package/src/nodeviews/TableComponent.tsx +107 -78
  204. package/src/nodeviews/TableContainer.tsx +26 -32
  205. package/src/nodeviews/TableResizer.tsx +15 -18
  206. package/src/nodeviews/table.tsx +6 -5
  207. package/src/nodeviews/types.ts +1 -0
  208. package/src/plugin.tsx +17 -32
  209. package/src/pm-plugins/drag-and-drop/plugin.ts +10 -15
  210. package/src/pm-plugins/keymap.ts +6 -13
  211. package/src/pm-plugins/main.ts +6 -25
  212. package/src/pm-plugins/sticky-headers/plugin.ts +2 -11
  213. package/src/pm-plugins/table-resizing/event-handlers.ts +6 -4
  214. package/src/pm-plugins/table-resizing/utils/colgroup.ts +2 -2
  215. package/src/pm-plugins/table-resizing/utils/consts.ts +2 -0
  216. package/src/pm-plugins/table-resizing/utils/index.ts +1 -1
  217. package/src/pm-plugins/table-resizing/utils/misc.ts +2 -2
  218. package/src/pm-plugins/table-resizing/utils/resize-column.ts +5 -2
  219. package/src/pm-plugins/table-resizing/utils/resize-state.ts +18 -13
  220. package/src/pm-plugins/table-resizing/utils/scale-table.ts +14 -14
  221. package/src/pm-plugins/table-width.ts +4 -6
  222. package/src/toolbar.tsx +16 -19
  223. package/src/transforms/column-width.ts +7 -6
  224. package/src/transforms/delete-columns.ts +2 -2
  225. package/src/types.ts +1 -4
  226. package/src/ui/FloatingContextualMenu/ContextualMenu.tsx +11 -16
  227. package/src/ui/FloatingContextualMenu/index.tsx +0 -2
  228. package/src/ui/FloatingDragMenu/DragMenu.tsx +3 -3
  229. package/src/ui/FloatingDragMenu/index.tsx +4 -8
  230. package/src/ui/FloatingInsertButton/index.tsx +11 -22
  231. package/src/ui/TableFloatingColumnControls/index.tsx +5 -29
  232. package/src/ui/TableFloatingControls/index.tsx +155 -241
  233. package/src/utils/column-controls.ts +5 -6
  234. package/src/utils/create.ts +2 -5
  235. package/src/utils/dom.ts +12 -19
  236. package/src/utils/drag-menu.ts +7 -12
@@ -1,9 +1,10 @@
1
1
  // Resize a given column by an amount from the current state
2
+
2
3
  import { growColumn, shrinkColumn } from './resize-logic';
3
4
  import { updateColgroup } from './resize-state';
4
- export var resizeColumn = function resizeColumn(resizeState, colIndex, amount, tableRef, selectedColumns) {
5
- var tablePreserveWidth = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : false;
5
+ export var resizeColumn = function resizeColumn(resizeState, colIndex, amount, tableRef, tableNode, selectedColumns) {
6
+ var isTableScalingEnabled = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : false;
6
7
  var newState = amount > 0 ? growColumn(resizeState, colIndex, amount, selectedColumns) : amount < 0 ? shrinkColumn(resizeState, colIndex, amount, selectedColumns) : resizeState;
7
- updateColgroup(newState, tableRef, tablePreserveWidth);
8
+ updateColgroup(newState, tableRef, tableNode, isTableScalingEnabled);
8
9
  return newState;
9
10
  };
@@ -8,8 +8,8 @@ import { getSelectedTableInfo } from '../../../utils';
8
8
  import { getColWidthFix, hasTableBeenResized, insertColgroupFromNode } from './colgroup';
9
9
  import { getCellsRefsInColumn, getColumnStateFromDOM } from './column-state';
10
10
  import { syncStickyRowToTable } from './dom';
11
- import { getTableMaxWidth } from './misc';
12
- import { MAX_SCALING_PERCENT, TABLE_DEFAULT_WIDTH } from './index';
11
+ import { getTableContainerElementWidth, getTableMaxWidth } from './misc';
12
+ import { COLUMN_MIN_WIDTH, MAX_SCALING_PERCENT, TABLE_DEFAULT_WIDTH } from './index';
13
13
  export var getResizeState = function getResizeState(_ref) {
14
14
  var minWidth = _ref.minWidth,
15
15
  maxSize = _ref.maxSize,
@@ -17,8 +17,8 @@ export var getResizeState = function getResizeState(_ref) {
17
17
  tableRef = _ref.tableRef,
18
18
  start = _ref.start,
19
19
  domAtPos = _ref.domAtPos,
20
- _ref$tablePreserveWid = _ref.tablePreserveWidth,
21
- tablePreserveWidth = _ref$tablePreserveWid === void 0 ? false : _ref$tablePreserveWid;
20
+ _ref$isTableScalingEn = _ref.isTableScalingEnabled,
21
+ isTableScalingEnabled = _ref$isTableScalingEn === void 0 ? false : _ref$isTableScalingEn;
22
22
  // If the table has been resized, we can use the column widths from the table node
23
23
  if (hasTableBeenResized(table)) {
24
24
  var _cols = calcTableColumnWidths(table).map(function (width, index) {
@@ -43,19 +43,19 @@ export var getResizeState = function getResizeState(_ref) {
43
43
  overflow: _overflow
44
44
  };
45
45
  }
46
- var shouldReinsertColgroup = !tablePreserveWidth;
46
+ var shouldReinsertColgroup = !isTableScalingEnabled;
47
47
 
48
48
  // Getting the resize state from DOM
49
- var colgroupChildren = insertColgroupFromNode(tableRef, table, tablePreserveWidth, shouldReinsertColgroup // don't reinsert colgroup when preserving table width - this causes widths to jump
49
+ var colgroupChildren = insertColgroupFromNode(tableRef, table, isTableScalingEnabled, shouldReinsertColgroup // don't reinsert colgroup when preserving table width - this causes widths to jump
50
50
  );
51
51
  var cols = Array.from(colgroupChildren).map(function (_, index) {
52
52
  // If the table hasn't been resized and we have a table width attribute, we can use it
53
53
  // to calculate the widths of the columns
54
- if (tablePreserveWidth && table.attrs.width) {
54
+ if (isTableScalingEnabled && table.attrs.width) {
55
55
  return {
56
56
  index: index,
57
57
  width: table.attrs.width / colgroupChildren.length,
58
- minWidth: 48
58
+ minWidth: COLUMN_MIN_WIDTH
59
59
  };
60
60
  }
61
61
  var cellsRefs = getCellsRefsInColumn(index, table, start, domAtPos);
@@ -78,13 +78,12 @@ export var getResizeState = function getResizeState(_ref) {
78
78
  };
79
79
 
80
80
  // updates Colgroup DOM node with new widths
81
- export var updateColgroup = function updateColgroup(state, tableRef, tablePreserveWidth) {
81
+ export var updateColgroup = function updateColgroup(state, tableRef, tableNode, isTableScalingEnabled) {
82
82
  var cols = tableRef.querySelectorAll('col');
83
83
  if (getBooleanFF('platform.editor.custom-table-width')) {
84
84
  var columnsCount = cols.length;
85
- if (tablePreserveWidth) {
86
- var _tableRef$dataset;
87
- var tableWidth = parseInt(((_tableRef$dataset = tableRef.dataset) === null || _tableRef$dataset === void 0 ? void 0 : _tableRef$dataset.tableWidth) || ''); // TODO - get this value from the table node, not the dom
85
+ if (isTableScalingEnabled && tableNode) {
86
+ var tableWidth = getTableContainerElementWidth(tableNode);
88
87
  if (tableWidth) {
89
88
  var _tableRef$parentEleme;
90
89
  var renderWidth = ((_tableRef$parentEleme = tableRef.parentElement) === null || _tableRef$parentEleme === void 0 ? void 0 : _tableRef$parentEleme.clientWidth) || TABLE_DEFAULT_WIDTH;
@@ -300,7 +299,7 @@ export var normaliseTableLayout = function normaliseTableLayout(input) {
300
299
  }
301
300
  };
302
301
  export var getNewResizeStateFromSelectedColumns = function getNewResizeStateFromSelectedColumns(rect, state, domAtPos, getEditorContainerWidth) {
303
- var tablePreserveWidth = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false;
302
+ var isTableScalingEnabled = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false;
304
303
  // Fail early so that we don't do complex calculations for no reason
305
304
  var numColumnsSelected = rect.right - rect.left;
306
305
  if (numColumnsSelected <= 1) {
@@ -338,7 +337,7 @@ export var getNewResizeStateFromSelectedColumns = function getNewResizeStateFrom
338
337
  tableRef: tableRef,
339
338
  start: table.start,
340
339
  domAtPos: domAtPos,
341
- tablePreserveWidth: tablePreserveWidth
340
+ isTableScalingEnabled: isTableScalingEnabled
342
341
  });
343
342
  var newResizeState = evenSelectedColumnsWidths(resizeState, rect);
344
343
  var widthsBefore = resizeState.widths;
@@ -14,7 +14,7 @@ import { syncStickyRowToTable } from './dom';
14
14
  // Base function to trigger the actual scale on a table node.
15
15
  // Will only resize/scale if a table has been previously resized.
16
16
  export var scale = function scale(tableRef, options, domAtPos) {
17
- var tablePreserveWidth = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
17
+ var isTableScalingEnabled = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
18
18
  /**
19
19
  * isBreakoutEnabled === true -> default center aligned
20
20
  * isBreakoutEnabled === false -> full width mode
@@ -60,12 +60,12 @@ export var scale = function scale(tableRef, options, domAtPos) {
60
60
  tableRef: tableRef,
61
61
  start: start,
62
62
  domAtPos: domAtPos,
63
- tablePreserveWidth: tablePreserveWidth
63
+ isTableScalingEnabled: isTableScalingEnabled
64
64
  });
65
65
  return scaleTableTo(resizeState, newWidth);
66
66
  };
67
67
  export var scaleWithParent = function scaleWithParent(tableRef, parentWidth, table, start, domAtPos) {
68
- var tablePreserveWidth = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : false;
68
+ var isTableScalingEnabled = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : false;
69
69
  var resizeState = getResizeState({
70
70
  minWidth: tableCellMinWidth,
71
71
  maxSize: parentWidth,
@@ -73,7 +73,7 @@ export var scaleWithParent = function scaleWithParent(tableRef, parentWidth, tab
73
73
  tableRef: tableRef,
74
74
  start: start,
75
75
  domAtPos: domAtPos,
76
- tablePreserveWidth: tablePreserveWidth
76
+ isTableScalingEnabled: isTableScalingEnabled
77
77
  });
78
78
  if (table.attrs.isNumberColumnEnabled) {
79
79
  parentWidth -= akEditorTableNumberColumnWidth;
@@ -105,7 +105,7 @@ export function scaleTableTo(state, maxSize) {
105
105
  return adjustColumnsWidths(newState, maxSize);
106
106
  }
107
107
  export var previewScaleTable = function previewScaleTable(tableRef, options, domAtPos) {
108
- var tablePreserveWidth = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
108
+ var isTableScalingEnabled = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
109
109
  var node = options.node,
110
110
  start = options.start,
111
111
  parentWidth = options.parentWidth;
@@ -119,20 +119,20 @@ export var previewScaleTable = function previewScaleTable(tableRef, options, dom
119
119
  }
120
120
 
121
121
  // If the table hasn't been resize, the colgroup 48px width values will gracefully scale down.
122
- // If we are scaling the table down with tablePreserveWidth, the colgroup widths may be scaled to a value that is not 48px.
123
- if (!hasTableBeenResized(node) && !tablePreserveWidth) {
122
+ // If we are scaling the table down with isTableScalingEnabled, the colgroup widths may be scaled to a value that is not 48px.
123
+ if (!hasTableBeenResized(node) && !isTableScalingEnabled) {
124
124
  syncStickyRowToTable(tableRef);
125
125
  return;
126
126
  }
127
- var resizeState = parentWidth ? scaleWithParent(tableRef, parentWidth, node, start, domAtPos, tablePreserveWidth) : scale(tableRef, options, domAtPos, tablePreserveWidth);
127
+ var resizeState = parentWidth ? scaleWithParent(tableRef, parentWidth, node, start, domAtPos, isTableScalingEnabled) : scale(tableRef, options, domAtPos, isTableScalingEnabled);
128
128
  if (resizeState) {
129
- updateColgroup(resizeState, tableRef, tablePreserveWidth);
129
+ updateColgroup(resizeState, tableRef, node, isTableScalingEnabled);
130
130
  }
131
131
  };
132
132
 
133
133
  // Scale the table to meet new requirements (col, layout change etc)
134
134
  export var scaleTable = function scaleTable(tableRef, options, domAtPos) {
135
- var tablePreserveWidth = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
135
+ var isTableScalingEnabled = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
136
136
  return function (tr) {
137
137
  if (!tableRef) {
138
138
  return tr;
@@ -145,7 +145,7 @@ export var scaleTable = function scaleTable(tableRef, options, domAtPos) {
145
145
  if (hasTableBeenResized(node) === false) {
146
146
  // If its not a re-sized table, we still want to re-create cols
147
147
  // To force reflow of columns upon delete.
148
- if (!tablePreserveWidth) {
148
+ if (!isTableScalingEnabled) {
149
149
  insertColgroupFromNode(tableRef, node);
150
150
  }
151
151
  tr.setMeta('scrollIntoView', false);
@@ -153,9 +153,9 @@ export var scaleTable = function scaleTable(tableRef, options, domAtPos) {
153
153
  }
154
154
  var resizeState;
155
155
  if (parentWidth) {
156
- resizeState = scaleWithParent(tableRef, parentWidth, node, start, domAtPos, tablePreserveWidth);
156
+ resizeState = scaleWithParent(tableRef, parentWidth, node, start, domAtPos, isTableScalingEnabled);
157
157
  } else {
158
- resizeState = scale(tableRef, options, domAtPos, tablePreserveWidth);
158
+ resizeState = scale(tableRef, options, domAtPos, isTableScalingEnabled);
159
159
  }
160
160
  if (resizeState) {
161
161
  tr = updateColumnWidths(resizeState, node, start)(tr);
@@ -16,9 +16,10 @@ import { PluginKey } from '@atlaskit/editor-prosemirror/state';
16
16
  import { ReplaceStep } from '@atlaskit/editor-prosemirror/transform';
17
17
  import { akEditorDefaultLayoutWidth, akEditorFullWidthLayoutWidth, akEditorWideLayoutWidth } from '@atlaskit/editor-shared-styles';
18
18
  import { findTable } from '@atlaskit/editor-tables/utils';
19
+ import { getPluginState } from './plugin-factory';
19
20
  import { TABLE_MAX_WIDTH } from './table-resizing/utils';
20
21
  export var pluginKey = new PluginKey('tableWidthPlugin');
21
- var createPlugin = function createPlugin(dispatch, dispatchAnalyticsEvent, fullWidthEnabled, getEditorFeatureFlags) {
22
+ var createPlugin = function createPlugin(dispatch, dispatchAnalyticsEvent, fullWidthEnabled) {
22
23
  return new SafePlugin({
23
24
  key: pluginKey,
24
25
  state: {
@@ -85,7 +86,10 @@ var createPlugin = function createPlugin(dispatch, dispatchAnalyticsEvent, fullW
85
86
  var referentialityTr = transactions.find(function (tr) {
86
87
  return tr.getMeta('referentialityTableInserted');
87
88
  });
88
- var shouldPatchTable = fullWidthEnabled && getEditorFeatureFlags && getEditorFeatureFlags()['tablePreserveWidth'];
89
+ var _getPluginState = getPluginState(newState),
90
+ _getPluginState$isTab = _getPluginState.isTableScalingEnabled,
91
+ isTableScalingEnabled = _getPluginState$isTab === void 0 ? false : _getPluginState$isTab;
92
+ var shouldPatchTable = fullWidthEnabled && isTableScalingEnabled;
89
93
  if (!isReplaceDocumentOperation && (!shouldPatchTable || !referentialityTr)) {
90
94
  return null;
91
95
  }
@@ -85,7 +85,7 @@ export var getToolbarMenuConfig = function getToolbarMenuConfig(config, state, _
85
85
  export var getToolbarCellOptionsConfig = function getToolbarCellOptionsConfig(editorState, editorView, initialSelectionRect, _ref2, getEditorContainerWidth, editorAnalyticsAPI) {
86
86
  var _pluginState$pluginCo, _pluginState$pluginCo2;
87
87
  var formatMessage = _ref2.formatMessage;
88
- var tablePreserveWidth = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : false;
88
+ var isTableScalingEnabled = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : false;
89
89
  var top = initialSelectionRect.top,
90
90
  bottom = initialSelectionRect.bottom,
91
91
  right = initialSelectionRect.right,
@@ -100,7 +100,7 @@ export var getToolbarCellOptionsConfig = function getToolbarCellOptionsConfig(ed
100
100
  var selectionRect = getClosestSelectionRect(state);
101
101
  var index = selectionRect === null || selectionRect === void 0 ? void 0 : selectionRect.right;
102
102
  if (index) {
103
- insertColumnWithAnalytics(getEditorContainerWidth, editorAnalyticsAPI, tablePreserveWidth)(INPUT_METHOD.FLOATING_TB, index)(state, dispatch, view);
103
+ insertColumnWithAnalytics(editorAnalyticsAPI, isTableScalingEnabled)(INPUT_METHOD.FLOATING_TB, index)(state, dispatch, view);
104
104
  }
105
105
  return true;
106
106
  },
@@ -179,7 +179,7 @@ export var getToolbarCellOptionsConfig = function getToolbarCellOptionsConfig(ed
179
179
  }];
180
180
  if (pluginState !== null && pluginState !== void 0 && (_pluginState$pluginCo = pluginState.pluginConfig) !== null && _pluginState$pluginCo !== void 0 && _pluginState$pluginCo.allowDistributeColumns) {
181
181
  var _newResizeStateWithAn;
182
- var newResizeStateWithAnalytics = editorView ? getNewResizeStateFromSelectedColumns(initialSelectionRect, editorState, editorView.domAtPos.bind(editorView), getEditorContainerWidth, tablePreserveWidth) : undefined;
182
+ var newResizeStateWithAnalytics = editorView ? getNewResizeStateFromSelectedColumns(initialSelectionRect, editorState, editorView.domAtPos.bind(editorView), getEditorContainerWidth, isTableScalingEnabled) : undefined;
183
183
  var wouldChange = (_newResizeStateWithAn = newResizeStateWithAnalytics === null || newResizeStateWithAnalytics === void 0 ? void 0 : newResizeStateWithAnalytics.changed) !== null && _newResizeStateWithAn !== void 0 ? _newResizeStateWithAn : false;
184
184
  var distributeColumnWidths = function distributeColumnWidths(state, dispatch) {
185
185
  if (newResizeStateWithAnalytics) {
@@ -299,13 +299,13 @@ export var getToolbarConfig = function getToolbarConfig(getEditorContainerWidth,
299
299
  if (tableObject && pluginState.editorHasFocus && !isWidthResizing) {
300
300
  var nodeType = state.schema.nodes.table;
301
301
  var menu = getToolbarMenuConfig(config, pluginState, intl, editorAnalyticsAPI);
302
- var _getEditorFeatureFlag = getEditorFeatureFlags(),
303
- _getEditorFeatureFlag2 = _getEditorFeatureFlag.tablePreserveWidth,
304
- tablePreserveWidth = _getEditorFeatureFlag2 === void 0 ? false : _getEditorFeatureFlag2;
302
+ var _getPluginState2 = getPluginState(state),
303
+ _getPluginState2$isTa = _getPluginState2.isTableScalingEnabled,
304
+ isTableScalingEnabled = _getPluginState2$isTa === void 0 ? false : _getPluginState2$isTa;
305
305
  var cellItems;
306
- cellItems = pluginState.isDragAndDropEnabled ? [] : getCellItems(config, state, getEditorView(), intl, getEditorContainerWidth, editorAnalyticsAPI, tablePreserveWidth);
306
+ cellItems = pluginState.isDragAndDropEnabled ? [] : getCellItems(state, getEditorView(), intl, getEditorContainerWidth, editorAnalyticsAPI, isTableScalingEnabled);
307
307
  var columnSettingsItems;
308
- columnSettingsItems = pluginState.isDragAndDropEnabled && getBooleanFF('platform.editor.table.new-cell-context-menu-styling') ? getColumnSettingItems(state, getEditorView(), intl, getEditorContainerWidth, editorAnalyticsAPI, tablePreserveWidth) : [];
308
+ columnSettingsItems = pluginState.isDragAndDropEnabled && getBooleanFF('platform.editor.table.new-cell-context-menu-styling') ? getColumnSettingItems(state, getEditorView(), intl, getEditorContainerWidth, editorAnalyticsAPI, isTableScalingEnabled) : [];
309
309
  var colorPicker = getColorPicker(state, menu, intl, editorAnalyticsAPI);
310
310
 
311
311
  // Check if we need to show confirm dialog for delete button
@@ -344,8 +344,8 @@ export var getToolbarConfig = function getToolbarConfig(getEditorContainerWidth,
344
344
  }
345
345
  return element;
346
346
  };
347
- var _getEditorFeatureFlag3 = getEditorFeatureFlags(),
348
- stickyScrollbar = _getEditorFeatureFlag3.stickyScrollbar;
347
+ var _getEditorFeatureFlag = getEditorFeatureFlags(),
348
+ stickyScrollbar = _getEditorFeatureFlag.stickyScrollbar;
349
349
  return {
350
350
  title: 'Table floating controls',
351
351
  getDomRef: getDomRef,
@@ -402,26 +402,26 @@ var separator = function separator(hidden) {
402
402
  hidden: hidden
403
403
  };
404
404
  };
405
- var getCellItems = function getCellItems(pluginConfig, state, view, _ref3, getEditorContainerWidth, editorAnalyticsAPI) {
405
+ var getCellItems = function getCellItems(state, view, _ref3, getEditorContainerWidth, editorAnalyticsAPI) {
406
406
  var formatMessage = _ref3.formatMessage;
407
- var tablePreserveWidth = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : false;
407
+ var isTableScalingEnabled = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : false;
408
408
  var initialSelectionRect = getClosestSelectionRect(state);
409
409
  if (initialSelectionRect) {
410
410
  var cellOptions = getToolbarCellOptionsConfig(state, view, initialSelectionRect, {
411
411
  formatMessage: formatMessage
412
- }, getEditorContainerWidth, editorAnalyticsAPI, tablePreserveWidth);
412
+ }, getEditorContainerWidth, editorAnalyticsAPI, isTableScalingEnabled);
413
413
  return [cellOptions, separator(cellOptions.hidden)];
414
414
  }
415
415
  return [];
416
416
  };
417
417
  export var getDistributeConfig = function getDistributeConfig(getEditorContainerWidth, editorAnalyticsAPI) {
418
- var tablePreserveWidth = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
418
+ var isTableScalingEnabled = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
419
419
  return function (state, dispatch, editorView) {
420
420
  var selectionOrTableRect = getClosestSelectionOrTableRect(state);
421
421
  if (!editorView || !selectionOrTableRect) {
422
422
  return false;
423
423
  }
424
- var newResizeStateWithAnalytics = getNewResizeStateFromSelectedColumns(selectionOrTableRect, state, editorView.domAtPos.bind(editorView), getEditorContainerWidth, tablePreserveWidth);
424
+ var newResizeStateWithAnalytics = getNewResizeStateFromSelectedColumns(selectionOrTableRect, state, editorView.domAtPos.bind(editorView), getEditorContainerWidth, isTableScalingEnabled);
425
425
  if (newResizeStateWithAnalytics) {
426
426
  distributeColumnsWidthsWithAnalytics(editorAnalyticsAPI)(INPUT_METHOD.FLOATING_TB, newResizeStateWithAnalytics)(state, dispatch);
427
427
  return true;
@@ -435,13 +435,13 @@ export var getDistributeConfig = function getDistributeConfig(getEditorContainer
435
435
  var getColumnSettingItems = function getColumnSettingItems(editorState, editorView, _ref4, getEditorContainerWidth, editorAnalyticsAPI) {
436
436
  var _newResizeStateWithAn2, _pluginState$pluginCo3;
437
437
  var formatMessage = _ref4.formatMessage;
438
- var tablePreserveWidth = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : false;
438
+ var isTableScalingEnabled = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : false;
439
439
  var pluginState = getPluginState(editorState);
440
440
  var selectionOrTableRect = getClosestSelectionOrTableRect(editorState);
441
441
  if (!selectionOrTableRect || !editorView) {
442
442
  return [];
443
443
  }
444
- var newResizeStateWithAnalytics = getNewResizeStateFromSelectedColumns(selectionOrTableRect, editorState, editorView.domAtPos.bind(editorView), getEditorContainerWidth, tablePreserveWidth);
444
+ var newResizeStateWithAnalytics = getNewResizeStateFromSelectedColumns(selectionOrTableRect, editorState, editorView.domAtPos.bind(editorView), getEditorContainerWidth, isTableScalingEnabled);
445
445
  var wouldChange = (_newResizeStateWithAn2 = newResizeStateWithAnalytics === null || newResizeStateWithAnalytics === void 0 ? void 0 : newResizeStateWithAnalytics.changed) !== null && _newResizeStateWithAn2 !== void 0 ? _newResizeStateWithAn2 : false;
446
446
  if (pluginState !== null && pluginState !== void 0 && (_pluginState$pluginCo3 = pluginState.pluginConfig) !== null && _pluginState$pluginCo3 !== void 0 && _pluginState$pluginCo3.allowDistributeColumns && pluginState.isDragAndDropEnabled) {
447
447
  return [{
@@ -450,7 +450,7 @@ var getColumnSettingItems = function getColumnSettingItems(editorState, editorVi
450
450
  title: formatMessage(messages.distributeColumns),
451
451
  icon: DistributeColumnIcon,
452
452
  onClick: function onClick(state, dispatch, view) {
453
- return getDistributeConfig(getEditorContainerWidth, editorAnalyticsAPI, tablePreserveWidth)(state, dispatch, view);
453
+ return getDistributeConfig(getEditorContainerWidth, editorAnalyticsAPI, isTableScalingEnabled)(state, dispatch, view);
454
454
  },
455
455
  disabled: !wouldChange
456
456
  }, {
@@ -462,9 +462,9 @@ var getColumnSettingItems = function getColumnSettingItems(editorState, editorVi
462
462
  var getColorPicker = function getColorPicker(state, menu, _ref5, editorAnalyticsAPI) {
463
463
  var _node$attrs;
464
464
  var formatMessage = _ref5.formatMessage;
465
- var _getPluginState2 = getPluginState(state),
466
- targetCellPosition = _getPluginState2.targetCellPosition,
467
- pluginConfig = _getPluginState2.pluginConfig;
465
+ var _getPluginState3 = getPluginState(state),
466
+ targetCellPosition = _getPluginState3.targetCellPosition,
467
+ pluginConfig = _getPluginState3.pluginConfig;
468
468
  if (!pluginConfig.allowBackgroundColor) {
469
469
  return [];
470
470
  }
@@ -5,7 +5,7 @@ import { tableCellMinWidth } from '@atlaskit/editor-common/styles';
5
5
  import { AttrStep } from '@atlaskit/editor-prosemirror/transform';
6
6
  import { TableMap } from '@atlaskit/editor-tables/table-map';
7
7
  import { getBooleanFF } from '@atlaskit/platform-feature-flags';
8
- import { getTableContainerElement, getTableElementWidth, hasTableBeenResized } from '../pm-plugins/table-resizing/utils';
8
+ import { getTableContainerElementWidth, getTableElementWidth, hasTableBeenResized } from '../pm-plugins/table-resizing/utils';
9
9
  import { isMinCellWidthTable } from '../pm-plugins/table-resizing/utils/colgroup';
10
10
  import { getResizeState } from '../pm-plugins/table-resizing/utils/resize-state';
11
11
  import { scaleTableTo } from '../pm-plugins/table-resizing/utils/scale-table';
@@ -88,7 +88,7 @@ export var updateColumnWidths = function updateColumnWidths(resizeState, table,
88
88
  * @returns Updated transaction with rescaled columns for a given table
89
89
  */
90
90
  export var rescaleColumns = function rescaleColumns() {
91
- var tablePreserveWidth = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
91
+ var isTableScalingEnabled = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
92
92
  return function (table, view) {
93
93
  return function (tr) {
94
94
  if (!view) {
@@ -107,11 +107,11 @@ export var rescaleColumns = function rescaleColumns() {
107
107
  possibleMaxWidth: 0,
108
108
  isResized: isResized
109
109
  };
110
- if (tablePreserveWidth) {
110
+ if (isTableScalingEnabled) {
111
111
  previousTableInfo = {
112
112
  // TODO - ensure correct width is returned when table doesn't have a width value
113
113
  width: getTableElementWidth(table.node),
114
- possibleMaxWidth: getBooleanFF('platform.editor.custom-table-width') ? getTableContainerElement(table.node) : getTableContainerElement(table.node) - insertColumnButtonOffset,
114
+ possibleMaxWidth: getBooleanFF('platform.editor.custom-table-width') ? getTableContainerElementWidth(table.node) : getTableContainerElementWidth(table.node) - insertColumnButtonOffset,
115
115
  isResized: isResized
116
116
  };
117
117
  } else {
@@ -169,7 +169,7 @@ export var rescaleColumns = function rescaleColumns() {
169
169
  tableRef: tableRef,
170
170
  domAtPos: domAtPos,
171
171
  maxSize: previousTableInfo.possibleMaxWidth,
172
- tablePreserveWidth: tablePreserveWidth
172
+ isTableScalingEnabled: isTableScalingEnabled
173
173
  });
174
174
 
175
175
  // Two scenarios that require scaling:
@@ -205,7 +205,7 @@ function fixRowSpans(table) {
205
205
  return table.type.createChecked(table.attrs, rows, table.marks);
206
206
  }
207
207
  export var deleteColumns = function deleteColumns(rect, allowCustomStep, view) {
208
- var tablePreserveWidth = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
208
+ var isTableScalingEnabled = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
209
209
  return function (tr) {
210
210
  var updatedTr = tr;
211
211
  updatedTr.setMeta(META_KEYS.OVERFLOW_TRIGGER, {
@@ -218,7 +218,7 @@ export var deleteColumns = function deleteColumns(rect, allowCustomStep, view) {
218
218
  }
219
219
  var table = findTable(updatedTr.selection);
220
220
  if (table) {
221
- updatedTr = rescaleColumns(tablePreserveWidth)(table, view)(updatedTr);
221
+ updatedTr = rescaleColumns(isTableScalingEnabled)(table, view)(updatedTr);
222
222
  }
223
223
  return updatedTr;
224
224
  };
@@ -274,11 +274,11 @@ export var ContextualMenu = /*#__PURE__*/function (_Component) {
274
274
  isDragAndDropEnabled = _getPluginState8.isDragAndDropEnabled,
275
275
  allowDistributeColumns = _getPluginState8.pluginConfig.allowDistributeColumns;
276
276
  if (allowDistributeColumns && (!isDragAndDropEnabled || !getBooleanFF('platform.editor.table.new-cell-context-menu-styling'))) {
277
- var _this$props$getEditor, _this$props9, _newResizeState$chang;
278
- var _ref = ((_this$props$getEditor = (_this$props9 = _this.props).getEditorFeatureFlags) === null || _this$props$getEditor === void 0 ? void 0 : _this$props$getEditor.call(_this$props9)) || {},
279
- _ref$tablePreserveWid = _ref.tablePreserveWidth,
280
- tablePreserveWidth = _ref$tablePreserveWid === void 0 ? false : _ref$tablePreserveWid;
281
- var newResizeState = getNewResizeStateFromSelectedColumns(selectionRect, editorView.state, editorView.domAtPos.bind(editorView), getEditorContainerWidth, tablePreserveWidth);
277
+ var _newResizeState$chang;
278
+ var _getPluginState9 = getPluginState(editorView.state),
279
+ _getPluginState9$isTa = _getPluginState9.isTableScalingEnabled,
280
+ isTableScalingEnabled = _getPluginState9$isTa === void 0 ? false : _getPluginState9$isTa;
281
+ var newResizeState = getNewResizeStateFromSelectedColumns(selectionRect, editorView.state, editorView.domAtPos.bind(editorView), getEditorContainerWidth, isTableScalingEnabled);
282
282
  var wouldChange = (_newResizeState$chang = newResizeState === null || newResizeState === void 0 ? void 0 : newResizeState.changed) !== null && _newResizeState$chang !== void 0 ? _newResizeState$chang : false;
283
283
  return {
284
284
  content: formatMessage(messages.distributeColumns),
@@ -291,12 +291,12 @@ export var ContextualMenu = /*#__PURE__*/function (_Component) {
291
291
  return null;
292
292
  });
293
293
  _defineProperty(_assertThisInitialized(_this), "createSortColumnItems", function () {
294
- var _this$props10 = _this.props,
295
- formatMessage = _this$props10.intl.formatMessage,
296
- editorView = _this$props10.editorView,
297
- allowColumnSorting = _this$props10.allowColumnSorting;
298
- var _getPluginState9 = getPluginState(editorView.state),
299
- isDragAndDropEnabled = _getPluginState9.isDragAndDropEnabled;
294
+ var _this$props9 = _this.props,
295
+ formatMessage = _this$props9.intl.formatMessage,
296
+ editorView = _this$props9.editorView,
297
+ allowColumnSorting = _this$props9.allowColumnSorting;
298
+ var _getPluginState10 = getPluginState(editorView.state),
299
+ isDragAndDropEnabled = _getPluginState10.isDragAndDropEnabled;
300
300
  if (allowColumnSorting && (!isDragAndDropEnabled || !getBooleanFF('platform.editor.table.new-cell-context-menu-styling'))) {
301
301
  var hasMergedCellsInTable = getMergedCellsPositions(editorView.state.tr).length > 0;
302
302
  var warning = hasMergedCellsInTable ? {
@@ -360,22 +360,20 @@ export var ContextualMenu = /*#__PURE__*/function (_Component) {
360
360
  items[1].items.push(deleteRowItem);
361
361
  return items;
362
362
  });
363
- _defineProperty(_assertThisInitialized(_this), "onMenuItemActivated", function (_ref2) {
364
- var item = _ref2.item;
365
- var _this$props11 = _this.props,
366
- editorView = _this$props11.editorView,
367
- selectionRect = _this$props11.selectionRect,
368
- editorAnalyticsAPI = _this$props11.editorAnalyticsAPI,
369
- getEditorContainerWidth = _this$props11.getEditorContainerWidth,
370
- getEditorFeatureFlags = _this$props11.getEditorFeatureFlags;
363
+ _defineProperty(_assertThisInitialized(_this), "onMenuItemActivated", function (_ref) {
364
+ var item = _ref.item;
365
+ var _this$props10 = _this.props,
366
+ editorView = _this$props10.editorView,
367
+ selectionRect = _this$props10.selectionRect,
368
+ editorAnalyticsAPI = _this$props10.editorAnalyticsAPI,
369
+ getEditorContainerWidth = _this$props10.getEditorContainerWidth;
371
370
  // TargetCellPosition could be outdated: https://product-fabric.atlassian.net/browse/ED-8129
372
371
  var state = editorView.state,
373
372
  dispatch = editorView.dispatch;
374
- var _getPluginState10 = getPluginState(state),
375
- targetCellPosition = _getPluginState10.targetCellPosition;
376
- var _ref3 = (getEditorFeatureFlags === null || getEditorFeatureFlags === void 0 ? void 0 : getEditorFeatureFlags()) || {},
377
- _ref3$tablePreserveWi = _ref3.tablePreserveWidth,
378
- tablePreserveWidth = _ref3$tablePreserveWi === void 0 ? false : _ref3$tablePreserveWi;
373
+ var _getPluginState11 = getPluginState(state),
374
+ targetCellPosition = _getPluginState11.targetCellPosition,
375
+ _getPluginState11$isT = _getPluginState11.isTableScalingEnabled,
376
+ isTableScalingEnabled = _getPluginState11$isT === void 0 ? false : _getPluginState11$isT;
379
377
  switch (item.value.name) {
380
378
  case 'sort_column_desc':
381
379
  sortColumnWithAnalytics(editorAnalyticsAPI)(INPUT_METHOD.CONTEXT_MENU, selectionRect.left, SortOrder.DESC)(state, dispatch);
@@ -394,7 +392,7 @@ export var ContextualMenu = /*#__PURE__*/function (_Component) {
394
392
  _this.toggleOpen();
395
393
  break;
396
394
  case 'distribute_columns':
397
- var newResizeStateWithAnalytics = getNewResizeStateFromSelectedColumns(selectionRect, state, editorView.domAtPos.bind(editorView), getEditorContainerWidth, tablePreserveWidth);
395
+ var newResizeStateWithAnalytics = getNewResizeStateFromSelectedColumns(selectionRect, state, editorView.domAtPos.bind(editorView), getEditorContainerWidth, isTableScalingEnabled);
398
396
  if (newResizeStateWithAnalytics) {
399
397
  distributeColumnsWidthsWithAnalytics(editorAnalyticsAPI)(INPUT_METHOD.CONTEXT_MENU, newResizeStateWithAnalytics)(state, dispatch);
400
398
  _this.toggleOpen();
@@ -405,7 +403,7 @@ export var ContextualMenu = /*#__PURE__*/function (_Component) {
405
403
  _this.toggleOpen();
406
404
  break;
407
405
  case 'insert_column':
408
- insertColumnWithAnalytics(getEditorContainerWidth, editorAnalyticsAPI, tablePreserveWidth)(INPUT_METHOD.CONTEXT_MENU, selectionRect.right)(state, dispatch, editorView);
406
+ insertColumnWithAnalytics(editorAnalyticsAPI, isTableScalingEnabled)(INPUT_METHOD.CONTEXT_MENU, selectionRect.right)(state, dispatch, editorView);
409
407
  _this.toggleOpen();
410
408
  break;
411
409
  case 'insert_row':
@@ -420,19 +418,19 @@ export var ContextualMenu = /*#__PURE__*/function (_Component) {
420
418
  _this.toggleOpen();
421
419
  break;
422
420
  case 'delete_row':
423
- var _getPluginState11 = getPluginState(state),
424
- isHeaderRowRequired = _getPluginState11.pluginConfig.isHeaderRowRequired;
421
+ var _getPluginState12 = getPluginState(state),
422
+ isHeaderRowRequired = _getPluginState12.pluginConfig.isHeaderRowRequired;
425
423
  deleteRowsWithAnalytics(editorAnalyticsAPI)(INPUT_METHOD.CONTEXT_MENU, selectionRect, !!isHeaderRowRequired)(state, dispatch);
426
424
  _this.toggleOpen();
427
425
  break;
428
426
  }
429
427
  });
430
428
  _defineProperty(_assertThisInitialized(_this), "toggleOpen", function () {
431
- var _this$props12 = _this.props,
432
- isOpen = _this$props12.isOpen,
433
- _this$props12$editorV = _this$props12.editorView,
434
- state = _this$props12$editorV.state,
435
- dispatch = _this$props12$editorV.dispatch;
429
+ var _this$props11 = _this.props,
430
+ isOpen = _this$props11.isOpen,
431
+ _this$props11$editorV = _this$props11.editorView,
432
+ state = _this$props11$editorV.state,
433
+ dispatch = _this$props11$editorV.dispatch;
436
434
  toggleContextualMenu()(state, dispatch);
437
435
  if (!isOpen) {
438
436
  _this.setState({
@@ -449,13 +447,13 @@ export var ContextualMenu = /*#__PURE__*/function (_Component) {
449
447
  isSubmenuOpen: false
450
448
  });
451
449
  });
452
- _defineProperty(_assertThisInitialized(_this), "handleItemMouseEnter", function (_ref4) {
453
- var item = _ref4.item;
454
- var _this$props13 = _this.props,
455
- _this$props13$editorV = _this$props13.editorView,
456
- state = _this$props13$editorV.state,
457
- dispatch = _this$props13$editorV.dispatch,
458
- selectionRect = _this$props13.selectionRect;
450
+ _defineProperty(_assertThisInitialized(_this), "handleItemMouseEnter", function (_ref2) {
451
+ var item = _ref2.item;
452
+ var _this$props12 = _this.props,
453
+ _this$props12$editorV = _this$props12.editorView,
454
+ state = _this$props12$editorV.state,
455
+ dispatch = _this$props12$editorV.dispatch,
456
+ selectionRect = _this$props12.selectionRect;
459
457
  if (item.value.name === 'background') {
460
458
  if (!_this.state.isSubmenuOpen) {
461
459
  _this.setState({
@@ -473,8 +471,8 @@ export var ContextualMenu = /*#__PURE__*/function (_Component) {
473
471
  hoverMergedCells()(state, dispatch);
474
472
  }
475
473
  });
476
- _defineProperty(_assertThisInitialized(_this), "handleItemMouseLeave", function (_ref5) {
477
- var item = _ref5.item;
474
+ _defineProperty(_assertThisInitialized(_this), "handleItemMouseLeave", function (_ref3) {
475
+ var item = _ref3.item;
478
476
  var _this$props$editorVie2 = _this.props.editorView,
479
477
  state = _this$props$editorVie2.state,
480
478
  dispatch = _this$props$editorVie2.dispatch;
@@ -493,12 +491,12 @@ export var ContextualMenu = /*#__PURE__*/function (_Component) {
493
491
  }
494
492
  });
495
493
  _defineProperty(_assertThisInitialized(_this), "setColor", function (color) {
496
- var _this$props14 = _this.props,
497
- editorView = _this$props14.editorView,
498
- editorAnalyticsAPI = _this$props14.editorAnalyticsAPI;
494
+ var _this$props13 = _this.props,
495
+ editorView = _this$props13.editorView,
496
+ editorAnalyticsAPI = _this$props13.editorAnalyticsAPI;
499
497
  // TargetCellPosition could be outdated: https://product-fabric.atlassian.net/browse/ED-8129
500
- var _getPluginState12 = getPluginState(editorView.state),
501
- targetCellPosition = _getPluginState12.targetCellPosition;
498
+ var _getPluginState13 = getPluginState(editorView.state),
499
+ targetCellPosition = _getPluginState13.targetCellPosition;
502
500
  var state = editorView.state,
503
501
  dispatch = editorView.dispatch;
504
502
  setColorWithAnalytics(editorAnalyticsAPI)(INPUT_METHOD.CONTEXT_MENU, color, targetCellPosition)(state, dispatch);
@@ -509,14 +507,14 @@ export var ContextualMenu = /*#__PURE__*/function (_Component) {
509
507
  _createClass(ContextualMenu, [{
510
508
  key: "render",
511
509
  value: function render() {
512
- var _this$props15 = this.props,
513
- isOpen = _this$props15.isOpen,
514
- mountPoint = _this$props15.mountPoint,
515
- offset = _this$props15.offset,
516
- boundariesElement = _this$props15.boundariesElement,
517
- editorView = _this$props15.editorView;
518
- var _getPluginState13 = getPluginState(editorView.state),
519
- isDragAndDropEnabled = _getPluginState13.isDragAndDropEnabled;
510
+ var _this$props14 = this.props,
511
+ isOpen = _this$props14.isOpen,
512
+ mountPoint = _this$props14.mountPoint,
513
+ offset = _this$props14.offset,
514
+ boundariesElement = _this$props14.boundariesElement,
515
+ editorView = _this$props14.editorView;
516
+ var _getPluginState14 = getPluginState(editorView.state),
517
+ isDragAndDropEnabled = _getPluginState14.isDragAndDropEnabled;
520
518
  var items = isDragAndDropEnabled && getBooleanFF('platform.editor.table.new-cell-context-menu-styling') ? this.createNewContextMenuItems() : this.createOriginalContextMenuItems();
521
519
  return jsx("div", {
522
520
  "data-testid": "table-cell-contextual-menu",
@@ -16,8 +16,7 @@ var FloatingContextualMenu = function FloatingContextualMenu(_ref) {
16
16
  isOpen = _ref.isOpen,
17
17
  pluginConfig = _ref.pluginConfig,
18
18
  editorAnalyticsAPI = _ref.editorAnalyticsAPI,
19
- getEditorContainerWidth = _ref.getEditorContainerWidth,
20
- getEditorFeatureFlags = _ref.getEditorFeatureFlags;
19
+ getEditorContainerWidth = _ref.getEditorContainerWidth;
21
20
  // TargetCellPosition could be outdated: https://product-fabric.atlassian.net/browse/ED-8129
22
21
  var _getPluginState = getPluginState(editorView.state),
23
22
  targetCellPosition = _getPluginState.targetCellPosition,
@@ -65,8 +64,7 @@ var FloatingContextualMenu = function FloatingContextualMenu(_ref) {
65
64
  selectionRect: selectionRect,
66
65
  boundariesElement: boundariesElement,
67
66
  editorAnalyticsAPI: editorAnalyticsAPI,
68
- getEditorContainerWidth: getEditorContainerWidth,
69
- getEditorFeatureFlags: getEditorFeatureFlags
67
+ getEditorContainerWidth: getEditorContainerWidth
70
68
  })));
71
69
  };
72
70
  FloatingContextualMenu.displayName = 'FloatingContextualMenu';
@@ -180,7 +180,7 @@ export var DragMenu = /*#__PURE__*/React.memo(function (_ref) {
180
180
  mountPoint = _ref.mountPoint,
181
181
  scrollableElement = _ref.scrollableElement,
182
182
  boundariesElement = _ref.boundariesElement,
183
- tablePreserveWidth = _ref.tablePreserveWidth;
183
+ isTableScalingEnabled = _ref.isTableScalingEnabled;
184
184
  var state = editorView.state,
185
185
  dispatch = editorView.dispatch;
186
186
  var selection = state.selection;
@@ -196,7 +196,7 @@ export var DragMenu = /*#__PURE__*/React.memo(function (_ref) {
196
196
  var shouldMoveDisabled = index !== undefined && hasMergedCells(index)(selection);
197
197
  var hasMergedCellsInTable = getMergedCellsPositions(state.tr).length > 0;
198
198
  var allowBackgroundColor = (_pluginConfig$allowBa = pluginConfig === null || pluginConfig === void 0 ? void 0 : pluginConfig.allowBackgroundColor) !== null && _pluginConfig$allowBa !== void 0 ? _pluginConfig$allowBa : false;
199
- var dragMenuConfig = getDragMenuConfig(direction, getEditorContainerWidth, !shouldMoveDisabled, hasMergedCellsInTable, editorView, tableMap, index, targetCellPosition, selectionRect, editorAnalyticsAPI, pluginConfig === null || pluginConfig === void 0 ? void 0 : pluginConfig.isHeaderRowRequired, tablePreserveWidth);
199
+ var dragMenuConfig = getDragMenuConfig(direction, getEditorContainerWidth, !shouldMoveDisabled, hasMergedCellsInTable, editorView, tableMap, index, targetCellPosition, selectionRect, editorAnalyticsAPI, pluginConfig === null || pluginConfig === void 0 ? void 0 : pluginConfig.isHeaderRowRequired, isTableScalingEnabled);
200
200
  var _convertToDropdownIte = convertToDropdownItems(dragMenuConfig, formatMessage, selectionRect),
201
201
  menuItems = _convertToDropdownIte.menuItems,
202
202
  menuCallback = _convertToDropdownIte.menuCallback;