@atlaskit/editor-plugin-table 22.3.0 → 22.3.2

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 (51) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/dist/cjs/tablePlugin.js +5 -0
  3. package/dist/cjs/ui/FloatingDragMenu/index.js +9 -4
  4. package/dist/cjs/ui/TableMenu/row/RowMenu.compiled.css +6 -0
  5. package/dist/cjs/ui/TableMenu/row/RowMenu.js +35 -0
  6. package/dist/cjs/ui/TableMenu/row/RowMenuItems.js +130 -0
  7. package/dist/cjs/ui/TableMenu/row/getRowMenuComponents.js +189 -0
  8. package/dist/cjs/ui/TableMenu/row/keys.js +77 -0
  9. package/dist/cjs/ui/TableMenu/shared/consts.js +7 -0
  10. package/dist/cjs/ui/TableMenu/shared/items/BackgroundColorItem.compiled.css +11 -0
  11. package/dist/cjs/ui/TableMenu/shared/items/BackgroundColorItem.js +68 -0
  12. package/dist/cjs/ui/TableMenu/shared/items/ClearCellsItem.js +31 -0
  13. package/dist/es2019/tablePlugin.js +5 -0
  14. package/dist/es2019/ui/FloatingDragMenu/index.js +10 -5
  15. package/dist/es2019/ui/TableMenu/row/RowMenu.compiled.css +6 -0
  16. package/dist/es2019/ui/TableMenu/row/RowMenu.js +27 -0
  17. package/dist/es2019/ui/TableMenu/row/RowMenuItems.js +126 -0
  18. package/dist/es2019/ui/TableMenu/row/getRowMenuComponents.js +155 -0
  19. package/dist/es2019/ui/TableMenu/row/keys.js +87 -0
  20. package/dist/es2019/ui/TableMenu/shared/consts.js +1 -0
  21. package/dist/es2019/ui/TableMenu/shared/items/BackgroundColorItem.compiled.css +11 -0
  22. package/dist/es2019/ui/TableMenu/shared/items/BackgroundColorItem.js +60 -0
  23. package/dist/es2019/ui/TableMenu/shared/items/ClearCellsItem.js +26 -0
  24. package/dist/esm/tablePlugin.js +5 -0
  25. package/dist/esm/ui/FloatingDragMenu/index.js +10 -5
  26. package/dist/esm/ui/TableMenu/row/RowMenu.compiled.css +6 -0
  27. package/dist/esm/ui/TableMenu/row/RowMenu.js +28 -0
  28. package/dist/esm/ui/TableMenu/row/RowMenuItems.js +123 -0
  29. package/dist/esm/ui/TableMenu/row/getRowMenuComponents.js +183 -0
  30. package/dist/esm/ui/TableMenu/row/keys.js +70 -0
  31. package/dist/esm/ui/TableMenu/shared/consts.js +1 -0
  32. package/dist/esm/ui/TableMenu/shared/items/BackgroundColorItem.compiled.css +11 -0
  33. package/dist/esm/ui/TableMenu/shared/items/BackgroundColorItem.js +60 -0
  34. package/dist/esm/ui/TableMenu/shared/items/ClearCellsItem.js +24 -0
  35. package/dist/types/tablePluginType.d.ts +3 -1
  36. package/dist/types/ui/TableMenu/row/RowMenu.d.ts +7 -0
  37. package/dist/types/ui/TableMenu/row/RowMenuItems.d.ts +8 -0
  38. package/dist/types/ui/TableMenu/row/getRowMenuComponents.d.ts +9 -0
  39. package/dist/types/ui/TableMenu/row/keys.d.ts +20 -0
  40. package/dist/types/ui/TableMenu/shared/consts.d.ts +1 -0
  41. package/dist/types/ui/TableMenu/shared/items/BackgroundColorItem.d.ts +10 -0
  42. package/dist/types/ui/TableMenu/shared/items/ClearCellsItem.d.ts +6 -0
  43. package/dist/types-ts4.5/tablePluginType.d.ts +3 -1
  44. package/dist/types-ts4.5/ui/TableMenu/row/RowMenu.d.ts +7 -0
  45. package/dist/types-ts4.5/ui/TableMenu/row/RowMenuItems.d.ts +8 -0
  46. package/dist/types-ts4.5/ui/TableMenu/row/getRowMenuComponents.d.ts +9 -0
  47. package/dist/types-ts4.5/ui/TableMenu/row/keys.d.ts +20 -0
  48. package/dist/types-ts4.5/ui/TableMenu/shared/consts.d.ts +1 -0
  49. package/dist/types-ts4.5/ui/TableMenu/shared/items/BackgroundColorItem.d.ts +10 -0
  50. package/dist/types-ts4.5/ui/TableMenu/shared/items/ClearCellsItem.d.ts +6 -0
  51. package/package.json +11 -7
package/CHANGELOG.md CHANGED
@@ -1,5 +1,21 @@
1
1
  # @atlaskit/editor-plugin-table
2
2
 
3
+ ## 22.3.2
4
+
5
+ ### Patch Changes
6
+
7
+ - Updated dependencies
8
+
9
+ ## 22.3.1
10
+
11
+ ### Patch Changes
12
+
13
+ - [`6403e27aa3327`](https://bitbucket.org/atlassian/atlassian-frontend-monorepo/commits/6403e27aa3327) -
14
+ Add the experimental table row menu structure, keyboard shortcut hints, and shared table menu
15
+ items. Expose table row menu icons through editor-toolbar. Ensure the UI control registry is
16
+ available before table row menu items are registered.
17
+ - Updated dependencies
18
+
3
19
  ## 22.3.0
4
20
 
5
21
  ### Minor Changes
@@ -52,6 +52,7 @@ var _analytics2 = require("./pm-plugins/utils/analytics");
52
52
  var _create = require("./pm-plugins/utils/create");
53
53
  var _viewModeSort = require("./pm-plugins/view-mode-sort");
54
54
  var _ContentComponent = require("./ui/ContentComponent");
55
+ var _getRowMenuComponents = require("./ui/TableMenu/row/getRowMenuComponents");
55
56
  var _toolbar = require("./ui/toolbar");
56
57
  function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
57
58
  function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
@@ -91,6 +92,10 @@ var tablePlugin = function tablePlugin(_ref) {
91
92
  var isTableSelectorEnabled =
92
93
  // eslint-disable-next-line @atlaskit/platform/no-preconditioning
93
94
  !(options !== null && options !== void 0 && options.isChromelessEditor) && !(options !== null && options !== void 0 && options.isCommentEditor) && (options === null || options === void 0 || (_options$getEditorFea2 = options.getEditorFeatureFlags) === null || _options$getEditorFea2 === void 0 ? void 0 : _options$getEditorFea2.call(options).tableSelector) && (0, _experiments.editorExperiment)('platform_editor_controls', 'variant1');
95
+ if ((0, _expValEquals.expValEquals)('platform_editor_table_menu_updates', 'isEnabled', true)) {
96
+ var _api$uiControlRegistr;
97
+ api === null || api === void 0 || (_api$uiControlRegistr = api.uiControlRegistry) === null || _api$uiControlRegistr === void 0 || _api$uiControlRegistr.actions.register((0, _getRowMenuComponents.getRowMenuComponents)());
98
+ }
94
99
  return {
95
100
  name: 'table',
96
101
  // Use getSharedState to store fullWidthEnabled and wasFullWidthModeEnabled to guarantee access
@@ -10,9 +10,13 @@ var _ui = require("@atlaskit/editor-common/ui");
10
10
  var _editorSharedStyles = require("@atlaskit/editor-shared-styles");
11
11
  var _cellSelection = require("@atlaskit/editor-tables/cell-selection");
12
12
  var _platformFeatureFlags = require("@atlaskit/platform-feature-flags");
13
+ var _expValEquals = require("@atlaskit/tmp-editor-statsig/exp-val-equals");
13
14
  var _types = require("../../types");
14
15
  var _consts = require("../consts");
16
+ var _RowMenu = require("../TableMenu/row/RowMenu");
17
+ var _consts2 = require("../TableMenu/shared/consts");
15
18
  var _DragMenu = _interopRequireDefault(require("./DragMenu"));
19
+ var rowMenuOffset = _consts.dragTableInsertColumnButtonSize + 4;
16
20
  var FloatingDragMenu = function FloatingDragMenu(_ref) {
17
21
  var _getEditorFeatureFlag;
18
22
  var mountPoint = _ref.mountPoint,
@@ -39,7 +43,6 @@ var FloatingDragMenu = function FloatingDragMenu(_ref) {
39
43
  }
40
44
  var inStickyMode = (stickyHeaders === null || stickyHeaders === void 0 ? void 0 : stickyHeaders.sticky) || (tableWrapper === null || tableWrapper === void 0 ? void 0 : tableWrapper.classList.contains(_types.TableCssClassName.TABLE_NODE_WRAPPER_NO_OVERFLOW)) && (0, _platformFeatureFlags.fg)('platform_editor_table_sticky_header_patch_7');
41
45
  var targetHandleRef = direction === 'row' ? document.querySelector('#drag-handle-button-row') : document.querySelector('#drag-handle-button-column');
42
- var offset = direction === 'row' ? [-9, 0] : [0, -7];
43
46
  if (!targetHandleRef || !(editorView.state.selection instanceof _cellSelection.CellSelection)) {
44
47
  return null;
45
48
  }
@@ -57,7 +60,7 @@ var FloatingDragMenu = function FloatingDragMenu(_ref) {
57
60
  mountTo: mountPoint,
58
61
  boundariesElement: boundariesElement,
59
62
  scrollableElement: scrollableElement,
60
- fitWidth: _consts.dragMenuDropdownWidth,
63
+ fitWidth: (0, _expValEquals.expValEquals)('platform_editor_table_menu_updates', 'isEnabled', true) ? _consts2.newMenuWidth : _consts.dragMenuDropdownWidth,
61
64
  fitHeight: _consts.tablePopupMenuFitHeight
62
65
  // z-index value below is to ensure that this menu is above other floating menu
63
66
  // in table, but below floating dialogs like typeaheads, pickers, etc.
@@ -65,9 +68,11 @@ var FloatingDragMenu = function FloatingDragMenu(_ref) {
65
68
  ,
66
69
  zIndex: inStickyMode ? _editorSharedStyles.akEditorFloatingDialogZIndex : _editorSharedStyles.akEditorFloatingOverlapPanelZIndex,
67
70
  forcePlacement: true,
68
- offset: offset,
71
+ offset: (0, _expValEquals.expValEquals)('platform_editor_table_menu_updates', 'isEnabled', true) ? [rowMenuOffset, 0] : direction === 'row' ? [-9, 0] : [0, -7],
69
72
  stick: true
70
- }, /*#__PURE__*/_react.default.createElement(_DragMenu.default, {
73
+ }, (0, _expValEquals.expValEquals)('platform_editor_table_menu_updates', 'isEnabled', true) ? /*#__PURE__*/_react.default.createElement(_RowMenu.RowMenu, {
74
+ api: api
75
+ }) : /*#__PURE__*/_react.default.createElement(_DragMenu.default, {
71
76
  editorView: editorView,
72
77
  isOpen: isOpen,
73
78
  tableNode: tableNode,
@@ -0,0 +1,6 @@
1
+
2
+ ._2rko1qi0{border-radius:var(--ds-radius-medium,6px)}._16qs130s{box-shadow:var(--ds-shadow-overlay,0 8px 9pt #1e1f2126,0 0 1px #1e1f214f)}
3
+ ._18m915vq{overflow-y:hidden}
4
+ ._1bsb1178{width:280px}
5
+ ._1reo15vq{overflow-x:hidden}
6
+ ._bfhk1bhr{background-color:var(--ds-surface-overlay,#fff)}
@@ -0,0 +1,35 @@
1
+ /* RowMenu.tsx generated by @compiled/babel-plugin v0.39.1 */
2
+ "use strict";
3
+
4
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.RowMenu = void 0;
9
+ require("./RowMenu.compiled.css");
10
+ var _runtime = require("@compiled/react/runtime");
11
+ var _react = _interopRequireDefault(require("react"));
12
+ var _editorUiControlModel = require("@atlaskit/editor-ui-control-model");
13
+ var _compiled = require("@atlaskit/primitives/compiled");
14
+ var _keys = require("./keys");
15
+ var rowMenuContainerStyles = {
16
+ container: "_2rko1qi0 _1reo15vq _18m915vq _1bsb1178 _16qs130s _bfhk1bhr"
17
+ };
18
+ var RowMenu = exports.RowMenu = function RowMenu(_ref) {
19
+ var _api$uiControlRegistr, _api$uiControlRegistr2;
20
+ var api = _ref.api;
21
+ var rowMenuComponents = (_api$uiControlRegistr = api === null || api === void 0 || (_api$uiControlRegistr2 = api.uiControlRegistry) === null || _api$uiControlRegistr2 === void 0 ? void 0 : _api$uiControlRegistr2.actions.getComponents(_keys.ROW_MENU.key)) !== null && _api$uiControlRegistr !== void 0 ? _api$uiControlRegistr : [];
22
+ var surface = rowMenuComponents.find(function (c) {
23
+ return c.type === _keys.ROW_MENU.type;
24
+ });
25
+ if (!surface) {
26
+ return null;
27
+ }
28
+ return /*#__PURE__*/_react.default.createElement(_compiled.Box, {
29
+ xcss: rowMenuContainerStyles.container,
30
+ testId: "row-handle-menu"
31
+ }, /*#__PURE__*/_react.default.createElement(_editorUiControlModel.SurfaceRenderer, {
32
+ surface: surface,
33
+ components: rowMenuComponents
34
+ }));
35
+ };
@@ -0,0 +1,130 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.NumberedRowsToggleItem = exports.MoveRowUpItem = exports.MoveRowDownItem = exports.HeaderRowToggleItem = exports.DeleteRowItem = exports.AddRowBelowItem = exports.AddRowAboveItem = void 0;
8
+ var _react = _interopRequireDefault(require("react"));
9
+ var _reactIntl = require("react-intl");
10
+ var _keymaps = require("@atlaskit/editor-common/keymaps");
11
+ var _messages = require("@atlaskit/editor-common/messages");
12
+ var _editorToolbar = require("@atlaskit/editor-toolbar");
13
+ var _expValEquals = require("@atlaskit/tmp-editor-statsig/exp-val-equals");
14
+ var _toggle = _interopRequireDefault(require("@atlaskit/toggle"));
15
+ var HeaderRowToggleItem = exports.HeaderRowToggleItem = function HeaderRowToggleItem() {
16
+ var _useIntl = (0, _reactIntl.useIntl)(),
17
+ formatMessage = _useIntl.formatMessage;
18
+ return /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarDropdownItem, {
19
+ testId: "row-menu-header-row-toggle",
20
+ elemAfter: /*#__PURE__*/_react.default.createElement(_toggle.default, {
21
+ id: "row-menu-toggle-header-row",
22
+ label: formatMessage(_messages.tableMessages.headerRow),
23
+ isChecked: false
24
+ })
25
+ }, formatMessage(_messages.tableMessages.headerRow));
26
+ };
27
+ var NumberedRowsToggleItem = exports.NumberedRowsToggleItem = function NumberedRowsToggleItem() {
28
+ var _useIntl2 = (0, _reactIntl.useIntl)(),
29
+ formatMessage = _useIntl2.formatMessage;
30
+ return /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarDropdownItem, {
31
+ testId: "row-menu-numbered-rows-toggle",
32
+ elemAfter: /*#__PURE__*/_react.default.createElement(_toggle.default, {
33
+ id: "row-menu-toggle-numbered-rows",
34
+ label: formatMessage(_messages.tableMessages.numberedRows),
35
+ isChecked: false
36
+ })
37
+ }, formatMessage(_messages.tableMessages.numberedRows));
38
+ };
39
+ var getMoveRowUpShortcut = function getMoveRowUpShortcut() {
40
+ return (0, _keymaps.tooltip)((0, _expValEquals.expValEquals)('editor-a11y-fy26-keyboard-move-row-column', 'isEnabled', true) ? _keymaps.moveRowUp : _keymaps.moveRowUpOld);
41
+ };
42
+ var getMoveRowDownShortcut = function getMoveRowDownShortcut() {
43
+ return (0, _keymaps.tooltip)((0, _expValEquals.expValEquals)('editor-a11y-fy26-keyboard-move-row-column', 'isEnabled', true) ? _keymaps.moveRowDown : _keymaps.moveRowDownOld);
44
+ };
45
+ var AddRowAboveItem = exports.AddRowAboveItem = function AddRowAboveItem() {
46
+ var _tooltip;
47
+ var _useIntl3 = (0, _reactIntl.useIntl)(),
48
+ formatMessage = _useIntl3.formatMessage;
49
+ return /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarDropdownItem, {
50
+ testId: "row-menu-add-row-above",
51
+ elemBefore: /*#__PURE__*/_react.default.createElement(_editorToolbar.TableRowAddAboveIcon, {
52
+ color: "currentColor",
53
+ label: "",
54
+ size: "small"
55
+ }),
56
+ elemAfter: /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarKeyboardShortcutHint, {
57
+ shortcut: (_tooltip = (0, _keymaps.tooltip)(_keymaps.addRowBefore)) !== null && _tooltip !== void 0 ? _tooltip : ''
58
+ })
59
+ }, formatMessage(_messages.tableMessages.addRowAbove));
60
+ };
61
+ var AddRowBelowItem = exports.AddRowBelowItem = function AddRowBelowItem() {
62
+ var _tooltip2;
63
+ var _useIntl4 = (0, _reactIntl.useIntl)(),
64
+ formatMessage = _useIntl4.formatMessage;
65
+ return /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarDropdownItem, {
66
+ testId: "row-menu-add-row-below",
67
+ elemBefore: /*#__PURE__*/_react.default.createElement(_editorToolbar.TableRowAddBelowIcon, {
68
+ color: "currentColor",
69
+ label: "",
70
+ size: "small"
71
+ }),
72
+ elemAfter: /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarKeyboardShortcutHint, {
73
+ shortcut: (_tooltip2 = (0, _keymaps.tooltip)(_keymaps.addRowAfter)) !== null && _tooltip2 !== void 0 ? _tooltip2 : ''
74
+ })
75
+ }, formatMessage(_messages.tableMessages.addRowBelow));
76
+ };
77
+ var MoveRowUpItem = exports.MoveRowUpItem = function MoveRowUpItem() {
78
+ var _getMoveRowUpShortcut;
79
+ var _useIntl5 = (0, _reactIntl.useIntl)(),
80
+ formatMessage = _useIntl5.formatMessage;
81
+ return /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarDropdownItem, {
82
+ testId: "row-menu-move-row-up",
83
+ elemBefore: /*#__PURE__*/_react.default.createElement(_editorToolbar.TableRowMoveUpIcon, {
84
+ color: "currentColor",
85
+ label: "",
86
+ size: "small"
87
+ }),
88
+ elemAfter: /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarKeyboardShortcutHint, {
89
+ shortcut: (_getMoveRowUpShortcut = getMoveRowUpShortcut()) !== null && _getMoveRowUpShortcut !== void 0 ? _getMoveRowUpShortcut : ''
90
+ })
91
+ }, formatMessage(_messages.tableMessages.moveRowUp, {
92
+ 0: 1
93
+ }));
94
+ };
95
+ var MoveRowDownItem = exports.MoveRowDownItem = function MoveRowDownItem() {
96
+ var _getMoveRowDownShortc;
97
+ var _useIntl6 = (0, _reactIntl.useIntl)(),
98
+ formatMessage = _useIntl6.formatMessage;
99
+ return /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarDropdownItem, {
100
+ testId: "row-menu-move-row-down",
101
+ elemBefore: /*#__PURE__*/_react.default.createElement(_editorToolbar.TableRowMoveDownIcon, {
102
+ color: "currentColor",
103
+ label: "",
104
+ size: "small"
105
+ }),
106
+ elemAfter: /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarKeyboardShortcutHint, {
107
+ shortcut: (_getMoveRowDownShortc = getMoveRowDownShortcut()) !== null && _getMoveRowDownShortc !== void 0 ? _getMoveRowDownShortc : ''
108
+ })
109
+ }, formatMessage(_messages.tableMessages.moveRowDown, {
110
+ 0: 1
111
+ }));
112
+ };
113
+ var DeleteRowItem = exports.DeleteRowItem = function DeleteRowItem() {
114
+ var _tooltip3;
115
+ var _useIntl7 = (0, _reactIntl.useIntl)(),
116
+ formatMessage = _useIntl7.formatMessage;
117
+ return /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarDropdownItem, {
118
+ testId: "row-menu-delete-row",
119
+ elemBefore: /*#__PURE__*/_react.default.createElement(_editorToolbar.DeleteIcon, {
120
+ color: "currentColor",
121
+ label: "",
122
+ size: "small"
123
+ }),
124
+ elemAfter: /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarKeyboardShortcutHint, {
125
+ shortcut: (_tooltip3 = (0, _keymaps.tooltip)(_keymaps.deleteRow)) !== null && _tooltip3 !== void 0 ? _tooltip3 : ''
126
+ })
127
+ }, formatMessage(_messages.tableMessages.removeRows, {
128
+ 0: 1
129
+ }));
130
+ };
@@ -0,0 +1,189 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.getRowMenuComponents = void 0;
8
+ var _react = _interopRequireDefault(require("react"));
9
+ var _editorToolbar = require("@atlaskit/editor-toolbar");
10
+ var _BackgroundColorItem = require("../shared/items/BackgroundColorItem");
11
+ var _ClearCellsItem = require("../shared/items/ClearCellsItem");
12
+ var _keys = require("./keys");
13
+ var _RowMenuItems = require("./RowMenuItems");
14
+ /**
15
+ * Returns the RegisterComponent[] array defining the row menu surface.
16
+ *
17
+ * This is a **UI-only stub** — all items are always visible with no conditional
18
+ * logic and no wired actions. Functional behaviour (actions, conditional visibility)
19
+ * will be connected in follow-up tickets.
20
+ */
21
+ var getRowMenuComponents = exports.getRowMenuComponents = function getRowMenuComponents() {
22
+ return [
23
+ // --- Menu surface ---
24
+ {
25
+ type: _keys.ROW_MENU.type,
26
+ key: _keys.ROW_MENU.key
27
+ },
28
+ // --- Toggle section (Header row, Numbered rows) ---
29
+ {
30
+ type: _keys.ROW_TOGGLE_SECTION.type,
31
+ key: _keys.ROW_TOGGLE_SECTION.key,
32
+ parents: [{
33
+ type: _keys.ROW_MENU.type,
34
+ key: _keys.ROW_MENU.key,
35
+ rank: _keys.ROW_SECTION_RANK[_keys.ROW_TOGGLE_SECTION.key]
36
+ }],
37
+ component: function component(props) {
38
+ return /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarDropdownItemSection, null, props.children);
39
+ }
40
+ }, {
41
+ type: _keys.HEADER_ROW_TOGGLE_ITEM.type,
42
+ key: _keys.HEADER_ROW_TOGGLE_ITEM.key,
43
+ parents: [{
44
+ type: _keys.ROW_TOGGLE_SECTION.type,
45
+ key: _keys.ROW_TOGGLE_SECTION.key,
46
+ rank: _keys.TOGGLE_SECTION_ITEM_RANK[_keys.HEADER_ROW_TOGGLE_ITEM.key]
47
+ }],
48
+ component: function component() {
49
+ return /*#__PURE__*/_react.default.createElement(_RowMenuItems.HeaderRowToggleItem, null);
50
+ }
51
+ }, {
52
+ type: _keys.NUMBERED_ROWS_TOGGLE_ITEM.type,
53
+ key: _keys.NUMBERED_ROWS_TOGGLE_ITEM.key,
54
+ parents: [{
55
+ type: _keys.ROW_TOGGLE_SECTION.type,
56
+ key: _keys.ROW_TOGGLE_SECTION.key,
57
+ rank: _keys.TOGGLE_SECTION_ITEM_RANK[_keys.NUMBERED_ROWS_TOGGLE_ITEM.key]
58
+ }],
59
+ component: function component() {
60
+ return /*#__PURE__*/_react.default.createElement(_RowMenuItems.NumberedRowsToggleItem, null);
61
+ }
62
+ },
63
+ // --- Background color section ---
64
+ {
65
+ type: _keys.ROW_BACKGROUND_SECTION.type,
66
+ key: _keys.ROW_BACKGROUND_SECTION.key,
67
+ parents: [{
68
+ type: _keys.ROW_MENU.type,
69
+ key: _keys.ROW_MENU.key,
70
+ rank: _keys.ROW_SECTION_RANK[_keys.ROW_BACKGROUND_SECTION.key]
71
+ }],
72
+ component: function component(props) {
73
+ return /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarDropdownItemSection, {
74
+ hasSeparator: true
75
+ }, props.children);
76
+ }
77
+ }, {
78
+ type: _keys.BACKGROUND_COLOR_ITEM.type,
79
+ key: _keys.BACKGROUND_COLOR_ITEM.key,
80
+ parents: [{
81
+ type: _keys.ROW_BACKGROUND_SECTION.type,
82
+ key: _keys.ROW_BACKGROUND_SECTION.key,
83
+ rank: _keys.BACKGROUND_SECTION_ITEM_RANK[_keys.BACKGROUND_COLOR_ITEM.key]
84
+ }],
85
+ component: function component() {
86
+ return /*#__PURE__*/_react.default.createElement(_BackgroundColorItem.BackgroundColorItem, {
87
+ testId: "row-menu-background-color"
88
+ });
89
+ }
90
+ },
91
+ // --- Add / Move section ---
92
+ {
93
+ type: _keys.ROW_ADD_SECTION.type,
94
+ key: _keys.ROW_ADD_SECTION.key,
95
+ parents: [{
96
+ type: _keys.ROW_MENU.type,
97
+ key: _keys.ROW_MENU.key,
98
+ rank: _keys.ROW_SECTION_RANK[_keys.ROW_ADD_SECTION.key]
99
+ }],
100
+ component: function component(props) {
101
+ return /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarDropdownItemSection, {
102
+ hasSeparator: true
103
+ }, props.children);
104
+ }
105
+ }, {
106
+ type: _keys.ADD_ROW_ABOVE_ITEM.type,
107
+ key: _keys.ADD_ROW_ABOVE_ITEM.key,
108
+ parents: [{
109
+ type: _keys.ROW_ADD_SECTION.type,
110
+ key: _keys.ROW_ADD_SECTION.key,
111
+ rank: _keys.ADD_SECTION_ITEM_RANK[_keys.ADD_ROW_ABOVE_ITEM.key]
112
+ }],
113
+ component: function component() {
114
+ return /*#__PURE__*/_react.default.createElement(_RowMenuItems.AddRowAboveItem, null);
115
+ }
116
+ }, {
117
+ type: _keys.ADD_ROW_BELOW_ITEM.type,
118
+ key: _keys.ADD_ROW_BELOW_ITEM.key,
119
+ parents: [{
120
+ type: _keys.ROW_ADD_SECTION.type,
121
+ key: _keys.ROW_ADD_SECTION.key,
122
+ rank: _keys.ADD_SECTION_ITEM_RANK[_keys.ADD_ROW_BELOW_ITEM.key]
123
+ }],
124
+ component: function component() {
125
+ return /*#__PURE__*/_react.default.createElement(_RowMenuItems.AddRowBelowItem, null);
126
+ }
127
+ }, {
128
+ type: _keys.MOVE_ROW_UP_ITEM.type,
129
+ key: _keys.MOVE_ROW_UP_ITEM.key,
130
+ parents: [{
131
+ type: _keys.ROW_ADD_SECTION.type,
132
+ key: _keys.ROW_ADD_SECTION.key,
133
+ rank: _keys.ADD_SECTION_ITEM_RANK[_keys.MOVE_ROW_UP_ITEM.key]
134
+ }],
135
+ component: function component() {
136
+ return /*#__PURE__*/_react.default.createElement(_RowMenuItems.MoveRowUpItem, null);
137
+ }
138
+ }, {
139
+ type: _keys.MOVE_ROW_DOWN_ITEM.type,
140
+ key: _keys.MOVE_ROW_DOWN_ITEM.key,
141
+ parents: [{
142
+ type: _keys.ROW_ADD_SECTION.type,
143
+ key: _keys.ROW_ADD_SECTION.key,
144
+ rank: _keys.ADD_SECTION_ITEM_RANK[_keys.MOVE_ROW_DOWN_ITEM.key]
145
+ }],
146
+ component: function component() {
147
+ return /*#__PURE__*/_react.default.createElement(_RowMenuItems.MoveRowDownItem, null);
148
+ }
149
+ },
150
+ // --- Danger section (Clear cells, Delete row) ---
151
+ {
152
+ type: _keys.ROW_DANGER_SECTION.type,
153
+ key: _keys.ROW_DANGER_SECTION.key,
154
+ parents: [{
155
+ type: _keys.ROW_MENU.type,
156
+ key: _keys.ROW_MENU.key,
157
+ rank: _keys.ROW_SECTION_RANK[_keys.ROW_DANGER_SECTION.key]
158
+ }],
159
+ component: function component(props) {
160
+ return /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarDropdownItemSection, {
161
+ hasSeparator: true
162
+ }, props.children);
163
+ }
164
+ }, {
165
+ type: _keys.CLEAR_CELLS_ITEM.type,
166
+ key: _keys.CLEAR_CELLS_ITEM.key,
167
+ parents: [{
168
+ type: _keys.ROW_DANGER_SECTION.type,
169
+ key: _keys.ROW_DANGER_SECTION.key,
170
+ rank: _keys.DANGER_SECTION_ITEM_RANK[_keys.CLEAR_CELLS_ITEM.key]
171
+ }],
172
+ component: function component() {
173
+ return /*#__PURE__*/_react.default.createElement(_ClearCellsItem.ClearCellsItem, {
174
+ testId: "row-menu-clear-cells"
175
+ });
176
+ }
177
+ }, {
178
+ type: _keys.DELETE_ROW_ITEM.type,
179
+ key: _keys.DELETE_ROW_ITEM.key,
180
+ parents: [{
181
+ type: _keys.ROW_DANGER_SECTION.type,
182
+ key: _keys.ROW_DANGER_SECTION.key,
183
+ rank: _keys.DANGER_SECTION_ITEM_RANK[_keys.DELETE_ROW_ITEM.key]
184
+ }],
185
+ component: function component() {
186
+ return /*#__PURE__*/_react.default.createElement(_RowMenuItems.DeleteRowItem, null);
187
+ }
188
+ }];
189
+ };
@@ -0,0 +1,77 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.TOGGLE_SECTION_ITEM_RANK = exports.ROW_TOGGLE_SECTION = exports.ROW_SECTION_RANK = exports.ROW_MENU = exports.ROW_DANGER_SECTION = exports.ROW_BACKGROUND_SECTION = exports.ROW_ADD_SECTION = exports.NUMBERED_ROWS_TOGGLE_ITEM = exports.MOVE_ROW_UP_ITEM = exports.MOVE_ROW_DOWN_ITEM = exports.HEADER_ROW_TOGGLE_ITEM = exports.DELETE_ROW_ITEM = exports.DANGER_SECTION_ITEM_RANK = exports.CLEAR_CELLS_ITEM = exports.BACKGROUND_SECTION_ITEM_RANK = exports.BACKGROUND_COLOR_ITEM = exports.ADD_SECTION_ITEM_RANK = exports.ADD_ROW_BELOW_ITEM = exports.ADD_ROW_ABOVE_ITEM = void 0;
8
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
9
+ // --- Menu surface ---
10
+
11
+ var ROW_MENU = exports.ROW_MENU = {
12
+ type: 'menu',
13
+ key: 'row-handle-menu'
14
+ };
15
+
16
+ // --- Sections ---
17
+
18
+ var ROW_TOGGLE_SECTION = exports.ROW_TOGGLE_SECTION = {
19
+ type: 'menu-section',
20
+ key: 'row-toggle-section'
21
+ };
22
+ var ROW_BACKGROUND_SECTION = exports.ROW_BACKGROUND_SECTION = {
23
+ type: 'menu-section',
24
+ key: 'row-background-section'
25
+ };
26
+ var ROW_ADD_SECTION = exports.ROW_ADD_SECTION = {
27
+ type: 'menu-section',
28
+ key: 'row-add-section'
29
+ };
30
+ var ROW_DANGER_SECTION = exports.ROW_DANGER_SECTION = {
31
+ type: 'menu-section',
32
+ key: 'row-danger-section'
33
+ };
34
+ var ROW_SECTION_RANK = exports.ROW_SECTION_RANK = (0, _defineProperty2.default)((0, _defineProperty2.default)((0, _defineProperty2.default)((0, _defineProperty2.default)({}, ROW_TOGGLE_SECTION.key, 100), ROW_BACKGROUND_SECTION.key, 200), ROW_ADD_SECTION.key, 300), ROW_DANGER_SECTION.key, 400);
35
+ var HEADER_ROW_TOGGLE_ITEM = exports.HEADER_ROW_TOGGLE_ITEM = {
36
+ type: 'menu-item',
37
+ key: 'header-row-toggle'
38
+ };
39
+ var NUMBERED_ROWS_TOGGLE_ITEM = exports.NUMBERED_ROWS_TOGGLE_ITEM = {
40
+ type: 'menu-item',
41
+ key: 'numbered-rows-toggle'
42
+ };
43
+ var BACKGROUND_COLOR_ITEM = exports.BACKGROUND_COLOR_ITEM = {
44
+ type: 'menu-item',
45
+ key: 'background-color'
46
+ };
47
+ var ADD_ROW_ABOVE_ITEM = exports.ADD_ROW_ABOVE_ITEM = {
48
+ type: 'menu-item',
49
+ key: 'add-row-above'
50
+ };
51
+ var ADD_ROW_BELOW_ITEM = exports.ADD_ROW_BELOW_ITEM = {
52
+ type: 'menu-item',
53
+ key: 'add-row-below'
54
+ };
55
+ var MOVE_ROW_UP_ITEM = exports.MOVE_ROW_UP_ITEM = {
56
+ type: 'menu-item',
57
+ key: 'move-row-up'
58
+ };
59
+ var MOVE_ROW_DOWN_ITEM = exports.MOVE_ROW_DOWN_ITEM = {
60
+ type: 'menu-item',
61
+ key: 'move-row-down'
62
+ };
63
+ var CLEAR_CELLS_ITEM = exports.CLEAR_CELLS_ITEM = {
64
+ type: 'menu-item',
65
+ key: 'clear-cells'
66
+ };
67
+ var DELETE_ROW_ITEM = exports.DELETE_ROW_ITEM = {
68
+ type: 'menu-item',
69
+ key: 'delete-row'
70
+ };
71
+
72
+ // --- Item ranks within their sections ---
73
+
74
+ var TOGGLE_SECTION_ITEM_RANK = exports.TOGGLE_SECTION_ITEM_RANK = (0, _defineProperty2.default)((0, _defineProperty2.default)({}, HEADER_ROW_TOGGLE_ITEM.key, 100), NUMBERED_ROWS_TOGGLE_ITEM.key, 200);
75
+ var BACKGROUND_SECTION_ITEM_RANK = exports.BACKGROUND_SECTION_ITEM_RANK = (0, _defineProperty2.default)({}, BACKGROUND_COLOR_ITEM.key, 100);
76
+ var ADD_SECTION_ITEM_RANK = exports.ADD_SECTION_ITEM_RANK = (0, _defineProperty2.default)((0, _defineProperty2.default)((0, _defineProperty2.default)((0, _defineProperty2.default)({}, ADD_ROW_ABOVE_ITEM.key, 100), ADD_ROW_BELOW_ITEM.key, 200), MOVE_ROW_UP_ITEM.key, 300), MOVE_ROW_DOWN_ITEM.key, 400);
77
+ var DANGER_SECTION_ITEM_RANK = exports.DANGER_SECTION_ITEM_RANK = (0, _defineProperty2.default)((0, _defineProperty2.default)({}, CLEAR_CELLS_ITEM.key, 100), DELETE_ROW_ITEM.key, 200);
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.newMenuWidth = void 0;
7
+ var newMenuWidth = exports.newMenuWidth = 280;
@@ -0,0 +1,11 @@
1
+
2
+ ._2rko12b0{border-radius:var(--ds-radius-small,4px)}
3
+ ._zulp1b66{gap:var(--ds-space-050,4px)}._189ee4h9{border-width:var(--ds-border-width,1px)}
4
+ ._1dqonqa1{border-style:solid}
5
+ ._1h6d1l7x{border-color:var(--ds-border,#0b120e24)}
6
+ ._1rjcu2gc{padding-block:var(--ds-space-100,8px)}
7
+ ._1bsbdlk8{width:14px}
8
+ ._1e0c1txw{display:flex}
9
+ ._1o9zidpf{flex-shrink:0}
10
+ ._4cvr1h6o{align-items:center}
11
+ ._4t3idlk8{height:14px}
@@ -0,0 +1,68 @@
1
+ /* BackgroundColorItem.tsx generated by @compiled/babel-plugin v0.39.1 */
2
+ "use strict";
3
+
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.BackgroundColorItem = void 0;
9
+ require("./BackgroundColorItem.compiled.css");
10
+ var _runtime = require("@compiled/react/runtime");
11
+ var _react = _interopRequireWildcard(require("react"));
12
+ var _reactIntl = require("react-intl");
13
+ var _messages = require("@atlaskit/editor-common/messages");
14
+ var _uiColor = require("@atlaskit/editor-common/ui-color");
15
+ var _editorPalette = require("@atlaskit/editor-palette");
16
+ var _editorToolbar = require("@atlaskit/editor-toolbar");
17
+ var _compiled = require("@atlaskit/primitives/compiled");
18
+ function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
19
+ var colorPaletteColumns = 7;
20
+ var colorPaletteStyles = {
21
+ container: "_1rjcu2gc",
22
+ elemAfter: "_zulp1b66 _1e0c1txw _4cvr1h6o",
23
+ colorPreview: "_2rko12b0 _1h6d1l7x _1dqonqa1 _189ee4h9 _1bsbdlk8 _4t3idlk8 _1o9zidpf"
24
+ };
25
+ var BackgroundColorItem = exports.BackgroundColorItem = function BackgroundColorItem(_ref) {
26
+ var testId = _ref.testId;
27
+ var _useIntl = (0, _reactIntl.useIntl)(),
28
+ formatMessage = _useIntl.formatMessage;
29
+ var selectedColor = '#ffffff';
30
+ var onClick = (0, _react.useCallback)(function () {}, []);
31
+ var colorPreviewStyle = (0, _react.useMemo)(function () {
32
+ return {
33
+ backgroundColor: selectedColor
34
+ };
35
+ }, [selectedColor]);
36
+ var paletteOptions = (0, _react.useMemo)(function () {
37
+ return {
38
+ palette: _uiColor.cellBackgroundColorPalette,
39
+ paletteColorTooltipMessages: _uiColor.backgroundPaletteTooltipMessages,
40
+ hexToPaletteColor: _editorPalette.hexToEditorBackgroundPaletteColor
41
+ };
42
+ }, []);
43
+ return /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarNestedDropdownMenu, {
44
+ testId: testId,
45
+ elemBefore: /*#__PURE__*/_react.default.createElement(_editorToolbar.PaintBucketIcon, {
46
+ color: "currentColor",
47
+ label: "",
48
+ size: "small"
49
+ }),
50
+ elemAfter: /*#__PURE__*/_react.default.createElement(_compiled.Box, {
51
+ xcss: colorPaletteStyles.elemAfter
52
+ }, /*#__PURE__*/_react.default.createElement("div", {
53
+ style: colorPreviewStyle,
54
+ className: (0, _runtime.ax)([colorPaletteStyles.colorPreview])
55
+ }), /*#__PURE__*/_react.default.createElement(_editorToolbar.NestedDropdownRightIcon, {
56
+ label: "",
57
+ size: "small"
58
+ })),
59
+ text: formatMessage(_messages.tableMessages.backgroundColor)
60
+ }, /*#__PURE__*/_react.default.createElement(_compiled.Box, {
61
+ xcss: colorPaletteStyles.container
62
+ }, /*#__PURE__*/_react.default.createElement(_uiColor.ColorPalette, {
63
+ cols: colorPaletteColumns,
64
+ onClick: onClick,
65
+ selectedColor: selectedColor,
66
+ paletteOptions: paletteOptions
67
+ })));
68
+ };
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.ClearCellsItem = void 0;
8
+ var _react = _interopRequireDefault(require("react"));
9
+ var _reactIntl = require("react-intl");
10
+ var _keymaps = require("@atlaskit/editor-common/keymaps");
11
+ var _messages = require("@atlaskit/editor-common/messages");
12
+ var _editorToolbar = require("@atlaskit/editor-toolbar");
13
+ var ClearCellsItem = exports.ClearCellsItem = function ClearCellsItem(_ref) {
14
+ var _tooltip;
15
+ var testId = _ref.testId;
16
+ var _useIntl = (0, _reactIntl.useIntl)(),
17
+ formatMessage = _useIntl.formatMessage;
18
+ return /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarDropdownItem, {
19
+ testId: testId,
20
+ elemBefore: /*#__PURE__*/_react.default.createElement(_editorToolbar.CrossIcon, {
21
+ color: "currentColor",
22
+ label: "",
23
+ size: "small"
24
+ }),
25
+ elemAfter: /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarKeyboardShortcutHint, {
26
+ shortcut: (_tooltip = (0, _keymaps.tooltip)(_keymaps.backspace)) !== null && _tooltip !== void 0 ? _tooltip : ''
27
+ })
28
+ }, formatMessage(_messages.tableMessages.clearCells, {
29
+ 0: 1
30
+ }));
31
+ };