@comet/cms-admin 9.0.0-beta.0 → 9.0.0-beta.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.
Files changed (89) hide show
  1. package/lib/blocks/createTableBlock.d.ts +23 -0
  2. package/lib/blocks/createTableBlock.d.ts.map +1 -0
  3. package/lib/blocks/createTableBlock.js +243 -0
  4. package/lib/blocks/table/CellValue.d.ts +9 -0
  5. package/lib/blocks/table/CellValue.d.ts.map +1 -0
  6. package/lib/blocks/table/CellValue.js +86 -0
  7. package/lib/blocks/table/ColumnHeader.d.ts +16 -0
  8. package/lib/blocks/table/ColumnHeader.d.ts.map +1 -0
  9. package/lib/blocks/table/ColumnHeader.js +296 -0
  10. package/lib/blocks/table/EditCell.d.ts +3 -0
  11. package/lib/blocks/table/EditCell.d.ts.map +1 -0
  12. package/lib/blocks/table/EditCell.js +119 -0
  13. package/lib/blocks/table/FailedToPasteSnackbar.d.ts +3 -0
  14. package/lib/blocks/table/FailedToPasteSnackbar.d.ts.map +1 -0
  15. package/lib/blocks/table/FailedToPasteSnackbar.js +23 -0
  16. package/lib/blocks/table/RowActionsCell.d.ts +13 -0
  17. package/lib/blocks/table/RowActionsCell.d.ts.map +1 -0
  18. package/lib/blocks/table/RowActionsCell.js +240 -0
  19. package/lib/blocks/table/TableBlockContext.d.ts +11 -0
  20. package/lib/blocks/table/TableBlockContext.d.ts.map +1 -0
  21. package/lib/blocks/table/TableBlockContext.js +18 -0
  22. package/lib/blocks/table/TableBlockGrid.d.ts +9 -0
  23. package/lib/blocks/table/TableBlockGrid.d.ts.map +1 -0
  24. package/lib/blocks/table/TableBlockGrid.js +231 -0
  25. package/lib/blocks/table/__mocks__/TableBlockData.mocks.js +203 -0
  26. package/lib/blocks/table/dataGridStyles.d.ts +3 -0
  27. package/lib/blocks/table/dataGridStyles.d.ts.map +1 -0
  28. package/lib/blocks/table/dataGridStyles.js +59 -0
  29. package/lib/blocks/table/utils/column.d.ts +48 -0
  30. package/lib/blocks/table/utils/column.d.ts.map +1 -0
  31. package/lib/blocks/table/utils/column.js +149 -0
  32. package/lib/blocks/table/utils/ensureMinimumTableState.d.ts +4 -0
  33. package/lib/blocks/table/utils/ensureMinimumTableState.d.ts.map +1 -0
  34. package/lib/blocks/table/utils/ensureMinimumTableState.js +49 -0
  35. package/lib/blocks/table/utils/getClipboardValueForSchema.d.ts +3 -0
  36. package/lib/blocks/table/utils/getClipboardValueForSchema.d.ts.map +1 -0
  37. package/lib/blocks/table/utils/getClipboardValueForSchema.js +45 -0
  38. package/lib/blocks/table/utils/row.d.ts +33 -0
  39. package/lib/blocks/table/utils/row.d.ts.map +1 -0
  40. package/lib/blocks/table/utils/row.js +124 -0
  41. package/lib/blocks/table/utils/rteSchema.d.ts +9 -0
  42. package/lib/blocks/table/utils/rteSchema.d.ts.map +1 -0
  43. package/lib/blocks/table/utils/rteSchema.js +4 -0
  44. package/lib/blocks/table/utils/useRecentlyPastedIds.d.ts +5 -0
  45. package/lib/blocks/table/utils/useRecentlyPastedIds.d.ts.map +1 -0
  46. package/lib/blocks/table/utils/useRecentlyPastedIds.js +45 -0
  47. package/lib/blocks.generated.d.ts +31 -1
  48. package/lib/blocks.generated.d.ts.map +1 -1
  49. package/lib/dam/DataGrid/DamContextMenu.d.ts.map +1 -1
  50. package/lib/dam/DataGrid/DamContextMenu.js +2 -3
  51. package/lib/dam/DataGrid/FolderDataGrid.d.ts.map +1 -1
  52. package/lib/dam/DataGrid/FolderDataGrid.gql.d.ts.map +1 -1
  53. package/lib/dam/DataGrid/FolderDataGrid.gql.generated.d.ts +8 -0
  54. package/lib/dam/DataGrid/FolderDataGrid.gql.generated.d.ts.map +1 -1
  55. package/lib/dam/DataGrid/FolderDataGrid.gql.js +1 -1
  56. package/lib/dam/DataGrid/FolderDataGrid.js +47 -7
  57. package/lib/dam/DataGrid/selection/DamSelectionContext.js +2 -2
  58. package/lib/dam/FileForm/EditFile.gql.d.ts.map +1 -1
  59. package/lib/dam/FileForm/EditFile.gql.generated.d.ts +3 -0
  60. package/lib/dam/FileForm/EditFile.gql.generated.d.ts.map +1 -1
  61. package/lib/dam/FileForm/EditFile.gql.js +1 -1
  62. package/lib/dam/FileForm/EditFile.js +4 -4
  63. package/lib/dam/FileForm/FilePreview.d.ts.map +1 -1
  64. package/lib/dam/FileForm/FilePreview.js +6 -7
  65. package/lib/dependencies/DependenciesList.d.ts +30 -0
  66. package/lib/dependencies/DependenciesList.d.ts.map +1 -0
  67. package/lib/dependencies/DependenciesList.js +282 -0
  68. package/lib/dependencies/DependentsList.d.ts +30 -0
  69. package/lib/dependencies/DependentsList.d.ts.map +1 -0
  70. package/lib/dependencies/{DependencyList.js → DependentsList.js} +165 -135
  71. package/lib/dependencies/getDisplayNameString.d.ts +4 -0
  72. package/lib/dependencies/getDisplayNameString.d.ts.map +1 -0
  73. package/lib/dependencies/getDisplayNameString.js +12 -0
  74. package/lib/graphql.generated.d.ts +27 -3
  75. package/lib/graphql.generated.d.ts.map +1 -1
  76. package/lib/index.d.ts +4 -2
  77. package/lib/index.d.ts.map +1 -1
  78. package/lib/index.js +4 -2
  79. package/lib/redirects/RedirectForm.d.ts.map +1 -1
  80. package/lib/redirects/RedirectForm.js +23 -6
  81. package/lib/testing/test-utils.d.ts +6 -0
  82. package/lib/testing/test-utils.d.ts.map +1 -0
  83. package/lib/testing/test-utils.js +34 -0
  84. package/package.json +23 -15
  85. package/lib/dependencies/DependencyList.d.ts +0 -29
  86. package/lib/dependencies/DependencyList.d.ts.map +0 -1
  87. package/lib/dependencies/DependencyList.sc.d.ts +0 -7
  88. package/lib/dependencies/DependencyList.sc.d.ts.map +0 -1
  89. package/lib/dependencies/DependencyList.sc.js +0 -73
@@ -0,0 +1,296 @@
1
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
2
+ function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
3
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
4
+ function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
5
+ function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
6
+ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
7
+ function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
8
+ function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i["return"]) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); }
9
+ function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); }
10
+ 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; }
11
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
12
+ function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
13
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
14
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
15
+ function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); }
16
+ function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; }
17
+ import { Alert, RowActionsItem, RowActionsMenu, useSnackbarApi, writeClipboardText } from "@comet/admin";
18
+ import { Add, Copy, Delete, DensityStandard, DragIndicator, Duplicate, Paste, PinLeft, PinRight, Remove } from "@comet/admin-icons";
19
+ import { ButtonBase, Divider, Snackbar } from "@mui/material";
20
+ import { styled } from "@mui/material/styles";
21
+ import { FormattedMessage, useIntl } from "react-intl";
22
+ import { v4 as uuid } from "uuid";
23
+ import { useBlockContext } from "../context/useBlockContext";
24
+ import { FailedToPasteSnackbar } from "./FailedToPasteSnackbar";
25
+ import { useTableBlockContext } from "./TableBlockContext";
26
+ import { columnInsertSchema, getDuplicatedColumnInsertData, getInsertDataFromColumnById, insertColumnDataAtIndex, removeColumnFromState, setColumnSize, toggleColumnHighlight } from "./utils/column";
27
+ import { getClipboardValueForSchema } from "./utils/getClipboardValueForSchema";
28
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
29
+ var columnSizes = {
30
+ extraSmall: /*#__PURE__*/_jsx(FormattedMessage, {
31
+ id: "comet.tableBlock.columnSize.extraSmall",
32
+ defaultMessage: "Extra small"
33
+ }),
34
+ small: /*#__PURE__*/_jsx(FormattedMessage, {
35
+ id: "comet.tableBlock.columnSize.small",
36
+ defaultMessage: "Small"
37
+ }),
38
+ standard: /*#__PURE__*/_jsx(FormattedMessage, {
39
+ id: "comet.tableBlock.columnSize.standard",
40
+ defaultMessage: "Standard"
41
+ }),
42
+ large: /*#__PURE__*/_jsx(FormattedMessage, {
43
+ id: "comet.tableBlock.columnSize.large",
44
+ defaultMessage: "Large"
45
+ }),
46
+ extraLarge: /*#__PURE__*/_jsx(FormattedMessage, {
47
+ id: "comet.tableBlock.columnSize.extraLarge",
48
+ defaultMessage: "Extra large"
49
+ })
50
+ };
51
+ export var ColumnHeader = function ColumnHeader(_ref) {
52
+ var columnSize = _ref.columnSize,
53
+ highlighted = _ref.highlighted,
54
+ state = _ref.state,
55
+ updateState = _ref.updateState,
56
+ columnIndex = _ref.columnIndex,
57
+ columnId = _ref.field,
58
+ addToRecentlyPastedIds = _ref.addToRecentlyPastedIds;
59
+ var snackbarApi = useSnackbarApi();
60
+ var blockContext = useBlockContext();
61
+ var intl = useIntl();
62
+ var _useTableBlockContext = useTableBlockContext(),
63
+ RichTextBlock = _useTableBlockContext.RichTextBlock;
64
+ var handleInsertColumnAtIndex = function handleInsertColumnAtIndex(newColumnIndex) {
65
+ updateState(function (state) {
66
+ var newColumnInsertData = {
67
+ size: "standard",
68
+ highlighted: false,
69
+ cellValues: state.rows.map(function () {
70
+ return RichTextBlock.defaultValues();
71
+ })
72
+ };
73
+ return insertColumnDataAtIndex(state, newColumnInsertData, newColumnIndex, RichTextBlock);
74
+ });
75
+ };
76
+ var handleDeleteColumn = function handleDeleteColumn() {
77
+ updateState(function (state) {
78
+ return removeColumnFromState(state, columnId);
79
+ });
80
+ };
81
+ var handleToggleColumnHighlight = function handleToggleColumnHighlight() {
82
+ updateState(function (state) {
83
+ return toggleColumnHighlight(state, columnId);
84
+ });
85
+ };
86
+ var handleSetColumnSize = function handleSetColumnSize(size) {
87
+ updateState(function (state) {
88
+ return setColumnSize(state, columnId, size);
89
+ });
90
+ };
91
+ var handleDuplicateColumn = function handleDuplicateColumn() {
92
+ updateState(function (state) {
93
+ var duplicatedColumnInsertData = getDuplicatedColumnInsertData(state, columnIndex, RichTextBlock);
94
+ if (!duplicatedColumnInsertData) {
95
+ snackbarApi.showSnackbar(/*#__PURE__*/_jsx(Snackbar, {
96
+ autoHideDuration: 5000,
97
+ children: /*#__PURE__*/_jsx(Alert, {
98
+ severity: "error",
99
+ children: /*#__PURE__*/_jsx(FormattedMessage, {
100
+ id: "comet.tableBlock.failedToDuplicateColumn",
101
+ defaultMessage: "Failed to duplicate column"
102
+ })
103
+ })
104
+ }));
105
+ return state;
106
+ }
107
+ var newColumnId = uuid();
108
+ addToRecentlyPastedIds(newColumnId);
109
+ return insertColumnDataAtIndex(state, duplicatedColumnInsertData, columnIndex + 1, RichTextBlock, newColumnId);
110
+ });
111
+ };
112
+ var handleCopyColumnToClipboard = function handleCopyColumnToClipboard() {
113
+ var columnInsertData = getInsertDataFromColumnById(state, columnId, RichTextBlock);
114
+ if (!columnInsertData) {
115
+ snackbarApi.showSnackbar(/*#__PURE__*/_jsx(Snackbar, {
116
+ autoHideDuration: 5000,
117
+ children: /*#__PURE__*/_jsx(Alert, {
118
+ severity: "error",
119
+ children: /*#__PURE__*/_jsx(FormattedMessage, {
120
+ id: "comet.tableBlock.failedToCopyColumn",
121
+ defaultMessage: "Failed to copy column"
122
+ })
123
+ })
124
+ }));
125
+ return;
126
+ }
127
+ writeClipboardText(JSON.stringify(columnInsertData));
128
+ };
129
+ var pasteColumnFromClipboard = /*#__PURE__*/function () {
130
+ var _ref2 = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee() {
131
+ var clipboardData, cellValuesToInsert, _t;
132
+ return _regenerator().w(function (_context) {
133
+ while (1) switch (_context.p = _context.n) {
134
+ case 0:
135
+ _context.n = 1;
136
+ return getClipboardValueForSchema(columnInsertSchema);
137
+ case 1:
138
+ clipboardData = _context.v;
139
+ if (clipboardData) {
140
+ _context.n = 2;
141
+ break;
142
+ }
143
+ snackbarApi.showSnackbar(/*#__PURE__*/_jsx(FailedToPasteSnackbar, {}));
144
+ return _context.a(2);
145
+ case 2:
146
+ cellValuesToInsert = [];
147
+ _context.p = 3;
148
+ _context.n = 4;
149
+ return Promise.all(clipboardData.cellValues.map(function (cellValue) {
150
+ return RichTextBlock.output2State(cellValue, blockContext);
151
+ }));
152
+ case 4:
153
+ cellValuesToInsert = _context.v;
154
+ _context.n = 6;
155
+ break;
156
+ case 5:
157
+ _context.p = 5;
158
+ _t = _context.v;
159
+ console.error(_t);
160
+ snackbarApi.showSnackbar(/*#__PURE__*/_jsx(FailedToPasteSnackbar, {}));
161
+ case 6:
162
+ updateState(function (state) {
163
+ var newColumnId = uuid();
164
+ addToRecentlyPastedIds(newColumnId);
165
+ return insertColumnDataAtIndex(state, _objectSpread(_objectSpread({}, clipboardData), {}, {
166
+ cellValues: cellValuesToInsert
167
+ }), columnIndex + 1, RichTextBlock, newColumnId);
168
+ });
169
+ case 7:
170
+ return _context.a(2);
171
+ }
172
+ }, _callee, null, [[3, 5]]);
173
+ }));
174
+ return function pasteColumnFromClipboard() {
175
+ return _ref2.apply(this, arguments);
176
+ };
177
+ }();
178
+ return /*#__PURE__*/_jsxs(_Fragment, {
179
+ children: [/*#__PURE__*/_jsx(DraggableColumnReorderingButton, {
180
+ component: "div",
181
+ disableRipple: true,
182
+ children: /*#__PURE__*/_jsx(DragIndicator, {})
183
+ }), /*#__PURE__*/_jsx(RowActionsMenu, {
184
+ children: /*#__PURE__*/_jsxs(RowActionsMenu, {
185
+ componentsProps: {
186
+ rowActionsIconItem: {
187
+ componentsProps: {
188
+ iconButton: {
189
+ "aria-label": intl.formatMessage({
190
+ id: "comet.tableBlock.openColumnOptions",
191
+ defaultMessage: "Open column options"
192
+ })
193
+ }
194
+ }
195
+ }
196
+ },
197
+ children: [/*#__PURE__*/_jsx(RowActionsMenu, {
198
+ text: /*#__PURE__*/_jsx(FormattedMessage, {
199
+ id: "comet.tableBlock.columnWidth",
200
+ defaultMessage: "Column width"
201
+ }),
202
+ icon: /*#__PURE__*/_jsx(DensityStandard, {}),
203
+ children: Object.entries(columnSizes).map(function (_ref3) {
204
+ var _ref4 = _slicedToArray(_ref3, 2),
205
+ size = _ref4[0],
206
+ label = _ref4[1];
207
+ return /*#__PURE__*/_jsx(RowActionsItem, {
208
+ onClick: function onClick() {
209
+ handleSetColumnSize(size);
210
+ },
211
+ componentsProps: {
212
+ menuItem: {
213
+ selected: columnSize === size
214
+ }
215
+ },
216
+ children: label
217
+ }, size);
218
+ })
219
+ }), /*#__PURE__*/_jsx(RowActionsItem, {
220
+ icon: highlighted ? /*#__PURE__*/_jsx(Remove, {}) : /*#__PURE__*/_jsx(Add, {}),
221
+ onClick: handleToggleColumnHighlight,
222
+ children: highlighted ? /*#__PURE__*/_jsx(FormattedMessage, {
223
+ id: "comet.tableBlock.removeHighlighting",
224
+ defaultMessage: "Remove highlighting"
225
+ }) : /*#__PURE__*/_jsx(FormattedMessage, {
226
+ id: "comet.tableBlock.highlightColumn",
227
+ defaultMessage: "Highlight column"
228
+ })
229
+ }), /*#__PURE__*/_jsx(Divider, {}), /*#__PURE__*/_jsx(RowActionsItem, {
230
+ icon: /*#__PURE__*/_jsx(PinLeft, {}),
231
+ onClick: function onClick() {
232
+ handleInsertColumnAtIndex(columnIndex);
233
+ },
234
+ children: /*#__PURE__*/_jsx(FormattedMessage, {
235
+ id: "comet.tableBlock.insertColumnLeft",
236
+ defaultMessage: "Insert column left"
237
+ })
238
+ }), /*#__PURE__*/_jsx(RowActionsItem, {
239
+ icon: /*#__PURE__*/_jsx(PinRight, {}),
240
+ onClick: function onClick() {
241
+ handleInsertColumnAtIndex(columnIndex + 1);
242
+ },
243
+ children: /*#__PURE__*/_jsx(FormattedMessage, {
244
+ id: "comet.tableBlock.insertColumnRight",
245
+ defaultMessage: "Insert column right"
246
+ })
247
+ }), /*#__PURE__*/_jsx(Divider, {}), /*#__PURE__*/_jsx(RowActionsItem, {
248
+ icon: /*#__PURE__*/_jsx(Copy, {}),
249
+ onClick: handleCopyColumnToClipboard,
250
+ children: /*#__PURE__*/_jsx(FormattedMessage, {
251
+ id: "comet.tableBlock.copyColumn",
252
+ defaultMessage: "Copy"
253
+ })
254
+ }), /*#__PURE__*/_jsx(RowActionsItem, {
255
+ icon: /*#__PURE__*/_jsx(Paste, {}),
256
+ onClick: pasteColumnFromClipboard,
257
+ children: /*#__PURE__*/_jsx(FormattedMessage, {
258
+ id: "comet.tableBlock.pasteColumn",
259
+ defaultMessage: "Paste"
260
+ })
261
+ }), /*#__PURE__*/_jsx(RowActionsItem, {
262
+ icon: /*#__PURE__*/_jsx(Duplicate, {}),
263
+ onClick: handleDuplicateColumn,
264
+ children: /*#__PURE__*/_jsx(FormattedMessage, {
265
+ id: "comet.tableBlock.duplicateColumn",
266
+ defaultMessage: "Duplicate"
267
+ })
268
+ }), /*#__PURE__*/_jsx(Divider, {}), /*#__PURE__*/_jsx(RowActionsItem, {
269
+ icon: /*#__PURE__*/_jsx(Delete, {}),
270
+ onClick: handleDeleteColumn,
271
+ children: /*#__PURE__*/_jsx(FormattedMessage, {
272
+ id: "comet.tableBlock.deleteColumn",
273
+ defaultMessage: "Delete"
274
+ })
275
+ })]
276
+ })
277
+ })]
278
+ });
279
+ };
280
+
281
+ // The first element of type "button" inside the ColumnHeader will automatically be used for column reordering
282
+ var DraggableColumnReorderingButton = /*#__PURE__*/styled(ButtonBase, process.env.NODE_ENV === "production" ? {
283
+ target: "e1blqe4j0"
284
+ } : {
285
+ target: "e1blqe4j0",
286
+ label: "DraggableColumnReorderingButton"
287
+ })(function (_ref5) {
288
+ var theme = _ref5.theme;
289
+ return {
290
+ position: "absolute",
291
+ inset: 0,
292
+ cursor: "move",
293
+ justifyContent: "flex-start",
294
+ paddingLeft: theme.spacing(2)
295
+ };
296
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/blocks/table/ColumnHeader.tsx"],"names":[],"mappings":"AA4NwC","file":"../../../src/blocks/table/ColumnHeader.tsx","sourcesContent":["import { Alert, RowActionsItem, RowActionsMenu, useSnackbarApi, writeClipboardText } from \"@comet/admin\";\nimport { Add, Copy, Delete, DensityStandard, DragIndicator, Duplicate, Paste, PinLeft, PinRight, Remove } from \"@comet/admin-icons\";\nimport { ButtonBase, Divider, Snackbar } from \"@mui/material\";\nimport { styled } from \"@mui/material/styles\";\nimport { type GridColumnHeaderParams } from \"@mui/x-data-grid\";\nimport { type Dispatch, type ReactNode, type SetStateAction } from \"react\";\nimport { FormattedMessage, useIntl } from \"react-intl\";\nimport { v4 as uuid } from \"uuid\";\n\nimport { type TableBlockData } from \"../../blocks.generated\";\nimport { useBlockContext } from \"../context/useBlockContext\";\nimport { type RichTextBlockState } from \"../createRichTextBlock\";\nimport { type TableBlockState } from \"../createTableBlock\";\nimport { FailedToPasteSnackbar } from \"./FailedToPasteSnackbar\";\nimport { useTableBlockContext } from \"./TableBlockContext\";\nimport {\n    columnInsertSchema,\n    getDuplicatedColumnInsertData,\n    getInsertDataFromColumnById,\n    insertColumnDataAtIndex,\n    removeColumnFromState,\n    setColumnSize,\n    toggleColumnHighlight,\n} from \"./utils/column\";\nimport { getClipboardValueForSchema } from \"./utils/getClipboardValueForSchema\";\n\ntype ColumnSize = TableBlockData[\"columns\"][number][\"size\"];\n\ntype Props = GridColumnHeaderParams & {\n    columnSize: ColumnSize;\n    highlighted: boolean;\n    state: TableBlockState;\n    updateState: Dispatch<SetStateAction<TableBlockState>>;\n    columnIndex: number;\n    addToRecentlyPastedIds: (id: string) => void;\n};\n\nconst columnSizes: Record<ColumnSize, ReactNode> = {\n    extraSmall: <FormattedMessage id=\"comet.tableBlock.columnSize.extraSmall\" defaultMessage=\"Extra small\" />,\n    small: <FormattedMessage id=\"comet.tableBlock.columnSize.small\" defaultMessage=\"Small\" />,\n    standard: <FormattedMessage id=\"comet.tableBlock.columnSize.standard\" defaultMessage=\"Standard\" />,\n    large: <FormattedMessage id=\"comet.tableBlock.columnSize.large\" defaultMessage=\"Large\" />,\n    extraLarge: <FormattedMessage id=\"comet.tableBlock.columnSize.extraLarge\" defaultMessage=\"Extra large\" />,\n};\n\nexport const ColumnHeader = ({ columnSize, highlighted, state, updateState, columnIndex, field: columnId, addToRecentlyPastedIds }: Props) => {\n    const snackbarApi = useSnackbarApi();\n    const blockContext = useBlockContext();\n    const intl = useIntl();\n    const { RichTextBlock } = useTableBlockContext();\n\n    const handleInsertColumnAtIndex = (newColumnIndex: number) => {\n        updateState((state) => {\n            const newColumnInsertData = {\n                size: \"standard\" as const,\n                highlighted: false,\n                cellValues: state.rows.map(() => RichTextBlock.defaultValues()),\n            };\n            return insertColumnDataAtIndex(state, newColumnInsertData, newColumnIndex, RichTextBlock);\n        });\n    };\n\n    const handleDeleteColumn = () => {\n        updateState((state) => {\n            return removeColumnFromState(state, columnId);\n        });\n    };\n\n    const handleToggleColumnHighlight = () => {\n        updateState((state) => {\n            return toggleColumnHighlight(state, columnId);\n        });\n    };\n\n    const handleSetColumnSize = (size: ColumnSize) => {\n        updateState((state) => {\n            return setColumnSize(state, columnId, size);\n        });\n    };\n\n    const handleDuplicateColumn = () => {\n        updateState((state) => {\n            const duplicatedColumnInsertData = getDuplicatedColumnInsertData(state, columnIndex, RichTextBlock);\n            if (!duplicatedColumnInsertData) {\n                snackbarApi.showSnackbar(\n                    <Snackbar autoHideDuration={5000}>\n                        <Alert severity=\"error\">\n                            <FormattedMessage id=\"comet.tableBlock.failedToDuplicateColumn\" defaultMessage=\"Failed to duplicate column\" />\n                        </Alert>\n                    </Snackbar>,\n                );\n                return state;\n            }\n\n            const newColumnId = uuid();\n            addToRecentlyPastedIds(newColumnId);\n            return insertColumnDataAtIndex(state, duplicatedColumnInsertData, columnIndex + 1, RichTextBlock, newColumnId);\n        });\n    };\n\n    const handleCopyColumnToClipboard = () => {\n        const columnInsertData = getInsertDataFromColumnById(state, columnId, RichTextBlock);\n        if (!columnInsertData) {\n            snackbarApi.showSnackbar(\n                <Snackbar autoHideDuration={5000}>\n                    <Alert severity=\"error\">\n                        <FormattedMessage id=\"comet.tableBlock.failedToCopyColumn\" defaultMessage=\"Failed to copy column\" />\n                    </Alert>\n                </Snackbar>,\n            );\n            return;\n        }\n\n        writeClipboardText(JSON.stringify(columnInsertData));\n    };\n\n    const pasteColumnFromClipboard = async () => {\n        const clipboardData = await getClipboardValueForSchema(columnInsertSchema);\n        if (!clipboardData) {\n            snackbarApi.showSnackbar(<FailedToPasteSnackbar />);\n            return;\n        }\n\n        let cellValuesToInsert: RichTextBlockState[] = [];\n\n        try {\n            cellValuesToInsert = await Promise.all(clipboardData.cellValues.map((cellValue) => RichTextBlock.output2State(cellValue, blockContext)));\n        } catch (error) {\n            console.error(error);\n            snackbarApi.showSnackbar(<FailedToPasteSnackbar />);\n        }\n\n        updateState((state) => {\n            const newColumnId = uuid();\n            addToRecentlyPastedIds(newColumnId);\n            return insertColumnDataAtIndex(state, { ...clipboardData, cellValues: cellValuesToInsert }, columnIndex + 1, RichTextBlock, newColumnId);\n        });\n    };\n\n    return (\n        <>\n            <DraggableColumnReorderingButton component=\"div\" disableRipple>\n                <DragIndicator />\n            </DraggableColumnReorderingButton>\n            <RowActionsMenu>\n                <RowActionsMenu\n                    componentsProps={{\n                        rowActionsIconItem: {\n                            componentsProps: {\n                                iconButton: {\n                                    \"aria-label\": intl.formatMessage({\n                                        id: \"comet.tableBlock.openColumnOptions\",\n                                        defaultMessage: \"Open column options\",\n                                    }),\n                                },\n                            },\n                        },\n                    }}\n                >\n                    <RowActionsMenu\n                        text={<FormattedMessage id=\"comet.tableBlock.columnWidth\" defaultMessage=\"Column width\" />}\n                        icon={<DensityStandard />}\n                    >\n                        {Object.entries(columnSizes).map(([size, label]) => (\n                            <RowActionsItem\n                                key={size}\n                                onClick={() => {\n                                    handleSetColumnSize(size as ColumnSize);\n                                }}\n                                componentsProps={{ menuItem: { selected: columnSize === size } }}\n                            >\n                                {label}\n                            </RowActionsItem>\n                        ))}\n                    </RowActionsMenu>\n                    <RowActionsItem icon={highlighted ? <Remove /> : <Add />} onClick={handleToggleColumnHighlight}>\n                        {highlighted ? (\n                            <FormattedMessage id=\"comet.tableBlock.removeHighlighting\" defaultMessage=\"Remove highlighting\" />\n                        ) : (\n                            <FormattedMessage id=\"comet.tableBlock.highlightColumn\" defaultMessage=\"Highlight column\" />\n                        )}\n                    </RowActionsItem>\n                    <Divider />\n                    <RowActionsItem\n                        icon={<PinLeft />}\n                        onClick={() => {\n                            handleInsertColumnAtIndex(columnIndex);\n                        }}\n                    >\n                        <FormattedMessage id=\"comet.tableBlock.insertColumnLeft\" defaultMessage=\"Insert column left\" />\n                    </RowActionsItem>\n                    <RowActionsItem\n                        icon={<PinRight />}\n                        onClick={() => {\n                            handleInsertColumnAtIndex(columnIndex + 1);\n                        }}\n                    >\n                        <FormattedMessage id=\"comet.tableBlock.insertColumnRight\" defaultMessage=\"Insert column right\" />\n                    </RowActionsItem>\n                    <Divider />\n                    <RowActionsItem icon={<Copy />} onClick={handleCopyColumnToClipboard}>\n                        <FormattedMessage id=\"comet.tableBlock.copyColumn\" defaultMessage=\"Copy\" />\n                    </RowActionsItem>\n                    <RowActionsItem icon={<Paste />} onClick={pasteColumnFromClipboard}>\n                        <FormattedMessage id=\"comet.tableBlock.pasteColumn\" defaultMessage=\"Paste\" />\n                    </RowActionsItem>\n                    <RowActionsItem icon={<Duplicate />} onClick={handleDuplicateColumn}>\n                        <FormattedMessage id=\"comet.tableBlock.duplicateColumn\" defaultMessage=\"Duplicate\" />\n                    </RowActionsItem>\n                    <Divider />\n                    <RowActionsItem icon={<Delete />} onClick={handleDeleteColumn}>\n                        <FormattedMessage id=\"comet.tableBlock.deleteColumn\" defaultMessage=\"Delete\" />\n                    </RowActionsItem>\n                </RowActionsMenu>\n            </RowActionsMenu>\n        </>\n    );\n};\n\n// The first element of type \"button\" inside the ColumnHeader will automatically be used for column reordering\nconst DraggableColumnReorderingButton = styled(ButtonBase)(({ theme }) => ({\n    position: \"absolute\",\n    inset: 0,\n    cursor: \"move\",\n    justifyContent: \"flex-start\",\n    paddingLeft: theme.spacing(2),\n})) as typeof ButtonBase;\n"]} */");
@@ -0,0 +1,3 @@
1
+ import { type GridRenderEditCellParams } from "@mui/x-data-grid-pro";
2
+ export declare const EditCell: ({ id, field, value }: GridRenderEditCellParams) => import("react/jsx-runtime").JSX.Element;
3
+ //# sourceMappingURL=EditCell.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"EditCell.d.ts","sourceRoot":"","sources":["../../../src/blocks/table/EditCell.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,wBAAwB,EAAqB,MAAM,sBAAsB,CAAC;AAOxF,eAAO,MAAM,QAAQ,GAAI,sBAAsB,wBAAwB,4CAmCtE,CAAC"}
@@ -0,0 +1,119 @@
1
+ function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
2
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
3
+ function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
4
+ function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
5
+ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
6
+ function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
7
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
8
+ import { Box, Popper } from "@mui/material";
9
+ import { styled } from "@mui/material/styles";
10
+ import { useGridApiContext } from "@mui/x-data-grid-pro";
11
+ import { useCallback, useState } from "react";
12
+ import { resolveNewState } from "../utils";
13
+ import { useTableBlockContext } from "./TableBlockContext";
14
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
15
+ export var EditCell = function EditCell(_ref) {
16
+ var id = _ref.id,
17
+ field = _ref.field,
18
+ value = _ref.value;
19
+ var _useTableBlockContext = useTableBlockContext(),
20
+ RichTextBlock = _useTableBlockContext.RichTextBlock;
21
+ var _useState = useState(value),
22
+ _useState2 = _slicedToArray(_useState, 2),
23
+ valueState = _useState2[0],
24
+ setValueState = _useState2[1];
25
+ var _useState3 = useState(),
26
+ _useState4 = _slicedToArray(_useState3, 2),
27
+ anchorEl = _useState4[0],
28
+ setAnchorEl = _useState4[1];
29
+ var apiRef = useGridApiContext();
30
+ var handleRef = useCallback(function (el) {
31
+ setAnchorEl(el);
32
+ }, []);
33
+ return /*#__PURE__*/_jsxs(Root, {
34
+ children: [/*#__PURE__*/_jsx(EditCellHandle, {
35
+ ref: handleRef
36
+ }), /*#__PURE__*/_jsx(EditPopper, {
37
+ open: !!anchorEl,
38
+ anchorEl: anchorEl,
39
+ placement: "bottom-start",
40
+ children: /*#__PURE__*/_jsx(EditorWrapper, {
41
+ onKeyDown: function onKeyDown(event) {
42
+ if (event.key === "Escape") {
43
+ apiRef.current.stopCellEditMode({
44
+ id: id,
45
+ field: field
46
+ });
47
+ }
48
+ event.stopPropagation();
49
+ },
50
+ children: /*#__PURE__*/_jsx(RichTextBlock.AdminComponent, {
51
+ state: valueState,
52
+ updateState: function updateState(setStateAction) {
53
+ var newContent = resolveNewState({
54
+ prevState: valueState,
55
+ setStateAction: setStateAction
56
+ });
57
+ setValueState(newContent);
58
+ apiRef.current.setEditCellValue({
59
+ id: id,
60
+ field: field,
61
+ value: newContent,
62
+ debounceMs: 200
63
+ });
64
+ }
65
+ })
66
+ })
67
+ })]
68
+ });
69
+ };
70
+ var Root = /*#__PURE__*/styled("div", process.env.NODE_ENV === "production" ? {
71
+ target: "e1eevhe83"
72
+ } : {
73
+ target: "e1eevhe83",
74
+ label: "Root"
75
+ })(process.env.NODE_ENV === "production" ? {
76
+ name: "bjn8wh",
77
+ styles: "position:relative"
78
+ } : {
79
+ name: "bjn8wh",
80
+ styles: "position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9ibG9ja3MvdGFibGUvRWRpdENlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThDYSIsImZpbGUiOiIuLi8uLi8uLi9zcmMvYmxvY2tzL3RhYmxlL0VkaXRDZWxsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJveCwgUG9wcGVyIH0gZnJvbSBcIkBtdWkvbWF0ZXJpYWxcIjtcbmltcG9ydCB7IHN0eWxlZCB9IGZyb20gXCJAbXVpL21hdGVyaWFsL3N0eWxlc1wiO1xuaW1wb3J0IHsgdHlwZSBHcmlkUmVuZGVyRWRpdENlbGxQYXJhbXMsIHVzZUdyaWRBcGlDb250ZXh0IH0gZnJvbSBcIkBtdWkveC1kYXRhLWdyaWQtcHJvXCI7XG5pbXBvcnQgeyB1c2VDYWxsYmFjaywgdXNlU3RhdGUgfSBmcm9tIFwicmVhY3RcIjtcblxuaW1wb3J0IHsgdHlwZSBSaWNoVGV4dEJsb2NrU3RhdGUgfSBmcm9tIFwiLi4vY3JlYXRlUmljaFRleHRCbG9ja1wiO1xuaW1wb3J0IHsgcmVzb2x2ZU5ld1N0YXRlIH0gZnJvbSBcIi4uL3V0aWxzXCI7XG5pbXBvcnQgeyB1c2VUYWJsZUJsb2NrQ29udGV4dCB9IGZyb20gXCIuL1RhYmxlQmxvY2tDb250ZXh0XCI7XG5cbmV4cG9ydCBjb25zdCBFZGl0Q2VsbCA9ICh7IGlkLCBmaWVsZCwgdmFsdWUgfTogR3JpZFJlbmRlckVkaXRDZWxsUGFyYW1zKSA9PiB7XG4gICAgY29uc3QgeyBSaWNoVGV4dEJsb2NrIH0gPSB1c2VUYWJsZUJsb2NrQ29udGV4dCgpO1xuICAgIGNvbnN0IFt2YWx1ZVN0YXRlLCBzZXRWYWx1ZVN0YXRlXSA9IHVzZVN0YXRlPFJpY2hUZXh0QmxvY2tTdGF0ZT4odmFsdWUpO1xuICAgIGNvbnN0IFthbmNob3JFbCwgc2V0QW5jaG9yRWxdID0gdXNlU3RhdGU8SFRNTEVsZW1lbnQgfCBudWxsPigpO1xuICAgIGNvbnN0IGFwaVJlZiA9IHVzZUdyaWRBcGlDb250ZXh0KCk7XG5cbiAgICBjb25zdCBoYW5kbGVSZWYgPSB1c2VDYWxsYmFjaygoZWw6IEhUTUxFbGVtZW50IHwgbnVsbCkgPT4ge1xuICAgICAgICBzZXRBbmNob3JFbChlbCk7XG4gICAgfSwgW10pO1xuXG4gICAgcmV0dXJuIChcbiAgICAgICAgPFJvb3Q+XG4gICAgICAgICAgICA8RWRpdENlbGxIYW5kbGUgcmVmPXtoYW5kbGVSZWZ9IC8+XG4gICAgICAgICAgICA8RWRpdFBvcHBlciBvcGVuPXshIWFuY2hvckVsfSBhbmNob3JFbD17YW5jaG9yRWx9IHBsYWNlbWVudD1cImJvdHRvbS1zdGFydFwiPlxuICAgICAgICAgICAgICAgIDxFZGl0b3JXcmFwcGVyXG4gICAgICAgICAgICAgICAgICAgIG9uS2V5RG93bj17KGV2ZW50KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAoZXZlbnQua2V5ID09PSBcIkVzY2FwZVwiKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgYXBpUmVmLmN1cnJlbnQuc3RvcENlbGxFZGl0TW9kZSh7IGlkLCBmaWVsZCB9KTtcbiAgICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuICAgICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgPFJpY2hUZXh0QmxvY2suQWRtaW5Db21wb25lbnRcbiAgICAgICAgICAgICAgICAgICAgICAgIHN0YXRlPXt2YWx1ZVN0YXRlfVxuICAgICAgICAgICAgICAgICAgICAgICAgdXBkYXRlU3RhdGU9eyhzZXRTdGF0ZUFjdGlvbikgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNvbnN0IG5ld0NvbnRlbnQgPSByZXNvbHZlTmV3U3RhdGUoeyBwcmV2U3RhdGU6IHZhbHVlU3RhdGUsIHNldFN0YXRlQWN0aW9uIH0pO1xuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgc2V0VmFsdWVTdGF0ZShuZXdDb250ZW50KTtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBhcGlSZWYuY3VycmVudC5zZXRFZGl0Q2VsbFZhbHVlKHsgaWQsIGZpZWxkLCB2YWx1ZTogbmV3Q29udGVudCwgZGVib3VuY2VNczogMjAwIH0pO1xuICAgICAgICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICA8L0VkaXRvcldyYXBwZXI+XG4gICAgICAgICAgICA8L0VkaXRQb3BwZXI+XG4gICAgICAgIDwvUm9vdD5cbiAgICApO1xufTtcblxuY29uc3QgUm9vdCA9IHN0eWxlZChcImRpdlwiKSh7XG4gICAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbn0pO1xuXG5jb25zdCBFZGl0Q2VsbEhhbmRsZSA9IHN0eWxlZChcImRpdlwiKSh7XG4gICAgcG9zaXRpb246IFwiYWJzb2x1dGVcIixcbiAgICB0b3A6IDAsXG59KTtcblxuY29uc3QgRWRpdFBvcHBlciA9IHN0eWxlZChQb3BwZXIpKCh7IHRoZW1lIH0pID0+ICh7XG4gICAgekluZGV4OiB0aGVtZS56SW5kZXgubW9kYWwgLSAxLFxuICAgIG1heFdpZHRoOiA0NjAsXG59KSk7XG5cbmNvbnN0IEVkaXRvcldyYXBwZXIgPSBzdHlsZWQoQm94KSgoeyB0aGVtZSB9KSA9PiAoe1xuICAgIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG4gICAgYm94U2hhZG93OiB0aGVtZS5zaGFkb3dzWzFdLFxufSkpO1xuIl19 */",
81
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
82
+ });
83
+ var EditCellHandle = /*#__PURE__*/styled("div", process.env.NODE_ENV === "production" ? {
84
+ target: "e1eevhe82"
85
+ } : {
86
+ target: "e1eevhe82",
87
+ label: "EditCellHandle"
88
+ })(process.env.NODE_ENV === "production" ? {
89
+ name: "1dbtoua",
90
+ styles: "position:absolute;top:0"
91
+ } : {
92
+ name: "1dbtoua",
93
+ styles: "position:absolute;top:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9ibG9ja3MvdGFibGUvRWRpdENlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtEdUIiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2Jsb2Nrcy90YWJsZS9FZGl0Q2VsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCb3gsIFBvcHBlciB9IGZyb20gXCJAbXVpL21hdGVyaWFsXCI7XG5pbXBvcnQgeyBzdHlsZWQgfSBmcm9tIFwiQG11aS9tYXRlcmlhbC9zdHlsZXNcIjtcbmltcG9ydCB7IHR5cGUgR3JpZFJlbmRlckVkaXRDZWxsUGFyYW1zLCB1c2VHcmlkQXBpQ29udGV4dCB9IGZyb20gXCJAbXVpL3gtZGF0YS1ncmlkLXByb1wiO1xuaW1wb3J0IHsgdXNlQ2FsbGJhY2ssIHVzZVN0YXRlIH0gZnJvbSBcInJlYWN0XCI7XG5cbmltcG9ydCB7IHR5cGUgUmljaFRleHRCbG9ja1N0YXRlIH0gZnJvbSBcIi4uL2NyZWF0ZVJpY2hUZXh0QmxvY2tcIjtcbmltcG9ydCB7IHJlc29sdmVOZXdTdGF0ZSB9IGZyb20gXCIuLi91dGlsc1wiO1xuaW1wb3J0IHsgdXNlVGFibGVCbG9ja0NvbnRleHQgfSBmcm9tIFwiLi9UYWJsZUJsb2NrQ29udGV4dFwiO1xuXG5leHBvcnQgY29uc3QgRWRpdENlbGwgPSAoeyBpZCwgZmllbGQsIHZhbHVlIH06IEdyaWRSZW5kZXJFZGl0Q2VsbFBhcmFtcykgPT4ge1xuICAgIGNvbnN0IHsgUmljaFRleHRCbG9jayB9ID0gdXNlVGFibGVCbG9ja0NvbnRleHQoKTtcbiAgICBjb25zdCBbdmFsdWVTdGF0ZSwgc2V0VmFsdWVTdGF0ZV0gPSB1c2VTdGF0ZTxSaWNoVGV4dEJsb2NrU3RhdGU+KHZhbHVlKTtcbiAgICBjb25zdCBbYW5jaG9yRWwsIHNldEFuY2hvckVsXSA9IHVzZVN0YXRlPEhUTUxFbGVtZW50IHwgbnVsbD4oKTtcbiAgICBjb25zdCBhcGlSZWYgPSB1c2VHcmlkQXBpQ29udGV4dCgpO1xuXG4gICAgY29uc3QgaGFuZGxlUmVmID0gdXNlQ2FsbGJhY2soKGVsOiBIVE1MRWxlbWVudCB8IG51bGwpID0+IHtcbiAgICAgICAgc2V0QW5jaG9yRWwoZWwpO1xuICAgIH0sIFtdKTtcblxuICAgIHJldHVybiAoXG4gICAgICAgIDxSb290PlxuICAgICAgICAgICAgPEVkaXRDZWxsSGFuZGxlIHJlZj17aGFuZGxlUmVmfSAvPlxuICAgICAgICAgICAgPEVkaXRQb3BwZXIgb3Blbj17ISFhbmNob3JFbH0gYW5jaG9yRWw9e2FuY2hvckVsfSBwbGFjZW1lbnQ9XCJib3R0b20tc3RhcnRcIj5cbiAgICAgICAgICAgICAgICA8RWRpdG9yV3JhcHBlclxuICAgICAgICAgICAgICAgICAgICBvbktleURvd249eyhldmVudCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgaWYgKGV2ZW50LmtleSA9PT0gXCJFc2NhcGVcIikge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFwaVJlZi5jdXJyZW50LnN0b3BDZWxsRWRpdE1vZGUoeyBpZCwgZmllbGQgfSk7XG4gICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgIDxSaWNoVGV4dEJsb2NrLkFkbWluQ29tcG9uZW50XG4gICAgICAgICAgICAgICAgICAgICAgICBzdGF0ZT17dmFsdWVTdGF0ZX1cbiAgICAgICAgICAgICAgICAgICAgICAgIHVwZGF0ZVN0YXRlPXsoc2V0U3RhdGVBY3Rpb24pID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25zdCBuZXdDb250ZW50ID0gcmVzb2x2ZU5ld1N0YXRlKHsgcHJldlN0YXRlOiB2YWx1ZVN0YXRlLCBzZXRTdGF0ZUFjdGlvbiB9KTtcblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIHNldFZhbHVlU3RhdGUobmV3Q29udGVudCk7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgYXBpUmVmLmN1cnJlbnQuc2V0RWRpdENlbGxWYWx1ZSh7IGlkLCBmaWVsZCwgdmFsdWU6IG5ld0NvbnRlbnQsIGRlYm91bmNlTXM6IDIwMCB9KTtcbiAgICAgICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgPC9FZGl0b3JXcmFwcGVyPlxuICAgICAgICAgICAgPC9FZGl0UG9wcGVyPlxuICAgICAgICA8L1Jvb3Q+XG4gICAgKTtcbn07XG5cbmNvbnN0IFJvb3QgPSBzdHlsZWQoXCJkaXZcIikoe1xuICAgIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG59KTtcblxuY29uc3QgRWRpdENlbGxIYW5kbGUgPSBzdHlsZWQoXCJkaXZcIikoe1xuICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgdG9wOiAwLFxufSk7XG5cbmNvbnN0IEVkaXRQb3BwZXIgPSBzdHlsZWQoUG9wcGVyKSgoeyB0aGVtZSB9KSA9PiAoe1xuICAgIHpJbmRleDogdGhlbWUuekluZGV4Lm1vZGFsIC0gMSxcbiAgICBtYXhXaWR0aDogNDYwLFxufSkpO1xuXG5jb25zdCBFZGl0b3JXcmFwcGVyID0gc3R5bGVkKEJveCkoKHsgdGhlbWUgfSkgPT4gKHtcbiAgICBwb3NpdGlvbjogXCJyZWxhdGl2ZVwiLFxuICAgIGJveFNoYWRvdzogdGhlbWUuc2hhZG93c1sxXSxcbn0pKTtcbiJdfQ== */",
94
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
95
+ });
96
+ var EditPopper = /*#__PURE__*/styled(Popper, process.env.NODE_ENV === "production" ? {
97
+ target: "e1eevhe81"
98
+ } : {
99
+ target: "e1eevhe81",
100
+ label: "EditPopper"
101
+ })(function (_ref2) {
102
+ var theme = _ref2.theme;
103
+ return {
104
+ zIndex: theme.zIndex.modal - 1,
105
+ maxWidth: 460
106
+ };
107
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9ibG9ja3MvdGFibGUvRWRpdENlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXVEbUIiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2Jsb2Nrcy90YWJsZS9FZGl0Q2VsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCb3gsIFBvcHBlciB9IGZyb20gXCJAbXVpL21hdGVyaWFsXCI7XG5pbXBvcnQgeyBzdHlsZWQgfSBmcm9tIFwiQG11aS9tYXRlcmlhbC9zdHlsZXNcIjtcbmltcG9ydCB7IHR5cGUgR3JpZFJlbmRlckVkaXRDZWxsUGFyYW1zLCB1c2VHcmlkQXBpQ29udGV4dCB9IGZyb20gXCJAbXVpL3gtZGF0YS1ncmlkLXByb1wiO1xuaW1wb3J0IHsgdXNlQ2FsbGJhY2ssIHVzZVN0YXRlIH0gZnJvbSBcInJlYWN0XCI7XG5cbmltcG9ydCB7IHR5cGUgUmljaFRleHRCbG9ja1N0YXRlIH0gZnJvbSBcIi4uL2NyZWF0ZVJpY2hUZXh0QmxvY2tcIjtcbmltcG9ydCB7IHJlc29sdmVOZXdTdGF0ZSB9IGZyb20gXCIuLi91dGlsc1wiO1xuaW1wb3J0IHsgdXNlVGFibGVCbG9ja0NvbnRleHQgfSBmcm9tIFwiLi9UYWJsZUJsb2NrQ29udGV4dFwiO1xuXG5leHBvcnQgY29uc3QgRWRpdENlbGwgPSAoeyBpZCwgZmllbGQsIHZhbHVlIH06IEdyaWRSZW5kZXJFZGl0Q2VsbFBhcmFtcykgPT4ge1xuICAgIGNvbnN0IHsgUmljaFRleHRCbG9jayB9ID0gdXNlVGFibGVCbG9ja0NvbnRleHQoKTtcbiAgICBjb25zdCBbdmFsdWVTdGF0ZSwgc2V0VmFsdWVTdGF0ZV0gPSB1c2VTdGF0ZTxSaWNoVGV4dEJsb2NrU3RhdGU+KHZhbHVlKTtcbiAgICBjb25zdCBbYW5jaG9yRWwsIHNldEFuY2hvckVsXSA9IHVzZVN0YXRlPEhUTUxFbGVtZW50IHwgbnVsbD4oKTtcbiAgICBjb25zdCBhcGlSZWYgPSB1c2VHcmlkQXBpQ29udGV4dCgpO1xuXG4gICAgY29uc3QgaGFuZGxlUmVmID0gdXNlQ2FsbGJhY2soKGVsOiBIVE1MRWxlbWVudCB8IG51bGwpID0+IHtcbiAgICAgICAgc2V0QW5jaG9yRWwoZWwpO1xuICAgIH0sIFtdKTtcblxuICAgIHJldHVybiAoXG4gICAgICAgIDxSb290PlxuICAgICAgICAgICAgPEVkaXRDZWxsSGFuZGxlIHJlZj17aGFuZGxlUmVmfSAvPlxuICAgICAgICAgICAgPEVkaXRQb3BwZXIgb3Blbj17ISFhbmNob3JFbH0gYW5jaG9yRWw9e2FuY2hvckVsfSBwbGFjZW1lbnQ9XCJib3R0b20tc3RhcnRcIj5cbiAgICAgICAgICAgICAgICA8RWRpdG9yV3JhcHBlclxuICAgICAgICAgICAgICAgICAgICBvbktleURvd249eyhldmVudCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgaWYgKGV2ZW50LmtleSA9PT0gXCJFc2NhcGVcIikge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFwaVJlZi5jdXJyZW50LnN0b3BDZWxsRWRpdE1vZGUoeyBpZCwgZmllbGQgfSk7XG4gICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgIDxSaWNoVGV4dEJsb2NrLkFkbWluQ29tcG9uZW50XG4gICAgICAgICAgICAgICAgICAgICAgICBzdGF0ZT17dmFsdWVTdGF0ZX1cbiAgICAgICAgICAgICAgICAgICAgICAgIHVwZGF0ZVN0YXRlPXsoc2V0U3RhdGVBY3Rpb24pID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25zdCBuZXdDb250ZW50ID0gcmVzb2x2ZU5ld1N0YXRlKHsgcHJldlN0YXRlOiB2YWx1ZVN0YXRlLCBzZXRTdGF0ZUFjdGlvbiB9KTtcblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIHNldFZhbHVlU3RhdGUobmV3Q29udGVudCk7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgYXBpUmVmLmN1cnJlbnQuc2V0RWRpdENlbGxWYWx1ZSh7IGlkLCBmaWVsZCwgdmFsdWU6IG5ld0NvbnRlbnQsIGRlYm91bmNlTXM6IDIwMCB9KTtcbiAgICAgICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgPC9FZGl0b3JXcmFwcGVyPlxuICAgICAgICAgICAgPC9FZGl0UG9wcGVyPlxuICAgICAgICA8L1Jvb3Q+XG4gICAgKTtcbn07XG5cbmNvbnN0IFJvb3QgPSBzdHlsZWQoXCJkaXZcIikoe1xuICAgIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG59KTtcblxuY29uc3QgRWRpdENlbGxIYW5kbGUgPSBzdHlsZWQoXCJkaXZcIikoe1xuICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgdG9wOiAwLFxufSk7XG5cbmNvbnN0IEVkaXRQb3BwZXIgPSBzdHlsZWQoUG9wcGVyKSgoeyB0aGVtZSB9KSA9PiAoe1xuICAgIHpJbmRleDogdGhlbWUuekluZGV4Lm1vZGFsIC0gMSxcbiAgICBtYXhXaWR0aDogNDYwLFxufSkpO1xuXG5jb25zdCBFZGl0b3JXcmFwcGVyID0gc3R5bGVkKEJveCkoKHsgdGhlbWUgfSkgPT4gKHtcbiAgICBwb3NpdGlvbjogXCJyZWxhdGl2ZVwiLFxuICAgIGJveFNoYWRvdzogdGhlbWUuc2hhZG93c1sxXSxcbn0pKTtcbiJdfQ== */");
108
+ var EditorWrapper = /*#__PURE__*/styled(Box, process.env.NODE_ENV === "production" ? {
109
+ target: "e1eevhe80"
110
+ } : {
111
+ target: "e1eevhe80",
112
+ label: "EditorWrapper"
113
+ })(function (_ref3) {
114
+ var theme = _ref3.theme;
115
+ return {
116
+ position: "relative",
117
+ boxShadow: theme.shadows[1]
118
+ };
119
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9ibG9ja3MvdGFibGUvRWRpdENlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTREc0IiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2Jsb2Nrcy90YWJsZS9FZGl0Q2VsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCb3gsIFBvcHBlciB9IGZyb20gXCJAbXVpL21hdGVyaWFsXCI7XG5pbXBvcnQgeyBzdHlsZWQgfSBmcm9tIFwiQG11aS9tYXRlcmlhbC9zdHlsZXNcIjtcbmltcG9ydCB7IHR5cGUgR3JpZFJlbmRlckVkaXRDZWxsUGFyYW1zLCB1c2VHcmlkQXBpQ29udGV4dCB9IGZyb20gXCJAbXVpL3gtZGF0YS1ncmlkLXByb1wiO1xuaW1wb3J0IHsgdXNlQ2FsbGJhY2ssIHVzZVN0YXRlIH0gZnJvbSBcInJlYWN0XCI7XG5cbmltcG9ydCB7IHR5cGUgUmljaFRleHRCbG9ja1N0YXRlIH0gZnJvbSBcIi4uL2NyZWF0ZVJpY2hUZXh0QmxvY2tcIjtcbmltcG9ydCB7IHJlc29sdmVOZXdTdGF0ZSB9IGZyb20gXCIuLi91dGlsc1wiO1xuaW1wb3J0IHsgdXNlVGFibGVCbG9ja0NvbnRleHQgfSBmcm9tIFwiLi9UYWJsZUJsb2NrQ29udGV4dFwiO1xuXG5leHBvcnQgY29uc3QgRWRpdENlbGwgPSAoeyBpZCwgZmllbGQsIHZhbHVlIH06IEdyaWRSZW5kZXJFZGl0Q2VsbFBhcmFtcykgPT4ge1xuICAgIGNvbnN0IHsgUmljaFRleHRCbG9jayB9ID0gdXNlVGFibGVCbG9ja0NvbnRleHQoKTtcbiAgICBjb25zdCBbdmFsdWVTdGF0ZSwgc2V0VmFsdWVTdGF0ZV0gPSB1c2VTdGF0ZTxSaWNoVGV4dEJsb2NrU3RhdGU+KHZhbHVlKTtcbiAgICBjb25zdCBbYW5jaG9yRWwsIHNldEFuY2hvckVsXSA9IHVzZVN0YXRlPEhUTUxFbGVtZW50IHwgbnVsbD4oKTtcbiAgICBjb25zdCBhcGlSZWYgPSB1c2VHcmlkQXBpQ29udGV4dCgpO1xuXG4gICAgY29uc3QgaGFuZGxlUmVmID0gdXNlQ2FsbGJhY2soKGVsOiBIVE1MRWxlbWVudCB8IG51bGwpID0+IHtcbiAgICAgICAgc2V0QW5jaG9yRWwoZWwpO1xuICAgIH0sIFtdKTtcblxuICAgIHJldHVybiAoXG4gICAgICAgIDxSb290PlxuICAgICAgICAgICAgPEVkaXRDZWxsSGFuZGxlIHJlZj17aGFuZGxlUmVmfSAvPlxuICAgICAgICAgICAgPEVkaXRQb3BwZXIgb3Blbj17ISFhbmNob3JFbH0gYW5jaG9yRWw9e2FuY2hvckVsfSBwbGFjZW1lbnQ9XCJib3R0b20tc3RhcnRcIj5cbiAgICAgICAgICAgICAgICA8RWRpdG9yV3JhcHBlclxuICAgICAgICAgICAgICAgICAgICBvbktleURvd249eyhldmVudCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgaWYgKGV2ZW50LmtleSA9PT0gXCJFc2NhcGVcIikge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFwaVJlZi5jdXJyZW50LnN0b3BDZWxsRWRpdE1vZGUoeyBpZCwgZmllbGQgfSk7XG4gICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgIDxSaWNoVGV4dEJsb2NrLkFkbWluQ29tcG9uZW50XG4gICAgICAgICAgICAgICAgICAgICAgICBzdGF0ZT17dmFsdWVTdGF0ZX1cbiAgICAgICAgICAgICAgICAgICAgICAgIHVwZGF0ZVN0YXRlPXsoc2V0U3RhdGVBY3Rpb24pID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25zdCBuZXdDb250ZW50ID0gcmVzb2x2ZU5ld1N0YXRlKHsgcHJldlN0YXRlOiB2YWx1ZVN0YXRlLCBzZXRTdGF0ZUFjdGlvbiB9KTtcblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIHNldFZhbHVlU3RhdGUobmV3Q29udGVudCk7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgYXBpUmVmLmN1cnJlbnQuc2V0RWRpdENlbGxWYWx1ZSh7IGlkLCBmaWVsZCwgdmFsdWU6IG5ld0NvbnRlbnQsIGRlYm91bmNlTXM6IDIwMCB9KTtcbiAgICAgICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgPC9FZGl0b3JXcmFwcGVyPlxuICAgICAgICAgICAgPC9FZGl0UG9wcGVyPlxuICAgICAgICA8L1Jvb3Q+XG4gICAgKTtcbn07XG5cbmNvbnN0IFJvb3QgPSBzdHlsZWQoXCJkaXZcIikoe1xuICAgIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG59KTtcblxuY29uc3QgRWRpdENlbGxIYW5kbGUgPSBzdHlsZWQoXCJkaXZcIikoe1xuICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgdG9wOiAwLFxufSk7XG5cbmNvbnN0IEVkaXRQb3BwZXIgPSBzdHlsZWQoUG9wcGVyKSgoeyB0aGVtZSB9KSA9PiAoe1xuICAgIHpJbmRleDogdGhlbWUuekluZGV4Lm1vZGFsIC0gMSxcbiAgICBtYXhXaWR0aDogNDYwLFxufSkpO1xuXG5jb25zdCBFZGl0b3JXcmFwcGVyID0gc3R5bGVkKEJveCkoKHsgdGhlbWUgfSkgPT4gKHtcbiAgICBwb3NpdGlvbjogXCJyZWxhdGl2ZVwiLFxuICAgIGJveFNoYWRvdzogdGhlbWUuc2hhZG93c1sxXSxcbn0pKTtcbiJdfQ== */");
@@ -0,0 +1,3 @@
1
+ import { type SnackbarProps } from "@mui/material";
2
+ export declare const FailedToPasteSnackbar: (props: Partial<SnackbarProps>) => import("react/jsx-runtime").JSX.Element;
3
+ //# sourceMappingURL=FailedToPasteSnackbar.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FailedToPasteSnackbar.d.ts","sourceRoot":"","sources":["../../../src/blocks/table/FailedToPasteSnackbar.tsx"],"names":[],"mappings":"AACA,OAAO,EAAY,KAAK,aAAa,EAAE,MAAM,eAAe,CAAC;AAG7D,eAAO,MAAM,qBAAqB,GAAI,OAAO,OAAO,CAAC,aAAa,CAAC,4CAQlE,CAAC"}
@@ -0,0 +1,23 @@
1
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
2
+ 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; }
3
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
4
+ function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
5
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
6
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
7
+ import { Alert } from "@comet/admin";
8
+ import { Snackbar } from "@mui/material";
9
+ import { FormattedMessage } from "react-intl";
10
+ import { jsx as _jsx } from "react/jsx-runtime";
11
+ export var FailedToPasteSnackbar = function FailedToPasteSnackbar(props) {
12
+ return /*#__PURE__*/_jsx(Snackbar, _objectSpread(_objectSpread({
13
+ autoHideDuration: 5000
14
+ }, props), {}, {
15
+ children: /*#__PURE__*/_jsx(Alert, {
16
+ severity: "error",
17
+ children: /*#__PURE__*/_jsx(FormattedMessage, {
18
+ id: "comet.tableBlock.couldNotPasteClipboardData",
19
+ defaultMessage: "Could not paste the clipboard data"
20
+ })
21
+ })
22
+ }));
23
+ };
@@ -0,0 +1,13 @@
1
+ import { type Dispatch, type SetStateAction } from "react";
2
+ import { type TableBlockState } from "../createTableBlock";
3
+ type Props = {
4
+ row: Record<string, unknown> & {
5
+ id: string;
6
+ };
7
+ updateState: Dispatch<SetStateAction<TableBlockState>>;
8
+ state: TableBlockState;
9
+ addToRecentlyPastedIds: (id: string) => void;
10
+ };
11
+ export declare const RowActionsCell: ({ row, updateState, state, addToRecentlyPastedIds }: Props) => import("react/jsx-runtime").JSX.Element;
12
+ export {};
13
+ //# sourceMappingURL=RowActionsCell.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RowActionsCell.d.ts","sourceRoot":"","sources":["../../../src/blocks/table/RowActionsCell.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAE,KAAK,QAAQ,EAAE,KAAK,cAAc,EAAE,MAAM,OAAO,CAAC;AAM3D,OAAO,EAAE,KAAK,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAa3D,KAAK,KAAK,GAAG;IACT,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG;QAAE,EAAE,EAAE,MAAM,CAAA;KAAE,CAAC;IAC9C,WAAW,EAAE,QAAQ,CAAC,cAAc,CAAC,eAAe,CAAC,CAAC,CAAC;IACvD,KAAK,EAAE,eAAe,CAAC;IACvB,sBAAsB,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;CAChD,CAAC;AAEF,eAAO,MAAM,cAAc,GAAI,qDAAqD,KAAK,4CAkKxF,CAAC"}