@pie-lib/editable-html 9.5.13 → 10.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 (144) hide show
  1. package/CHANGELOG.md +0 -302
  2. package/lib/components.js +116 -0
  3. package/lib/components.js.map +1 -0
  4. package/lib/editor.js +418 -103
  5. package/lib/editor.js.map +1 -1
  6. package/lib/index.js +101 -155
  7. package/lib/index.js.map +1 -1
  8. package/lib/new-serialization.js +320 -0
  9. package/lib/new-serialization.js.map +1 -0
  10. package/lib/old-serialization.js +330 -0
  11. package/lib/parse-html.js +1 -1
  12. package/lib/parse-html.js.map +1 -1
  13. package/lib/plugins/characters/custom-popper.js +1 -1
  14. package/lib/plugins/characters/custom-popper.js.map +1 -1
  15. package/lib/plugins/characters/index.js +21 -19
  16. package/lib/plugins/characters/index.js.map +1 -1
  17. package/lib/plugins/characters/utils.js +1 -1
  18. package/lib/plugins/characters/utils.js.map +1 -1
  19. package/lib/plugins/hotKeys/index.js +67 -0
  20. package/lib/plugins/hotKeys/index.js.map +1 -0
  21. package/lib/plugins/image/alt-dialog.js +1 -6
  22. package/lib/plugins/image/alt-dialog.js.map +1 -1
  23. package/lib/plugins/image/component.js +70 -53
  24. package/lib/plugins/image/component.js.map +1 -1
  25. package/lib/plugins/image/image-toolbar.js +7 -9
  26. package/lib/plugins/image/image-toolbar.js.map +1 -1
  27. package/lib/plugins/image/index.js +83 -27
  28. package/lib/plugins/image/index.js.map +1 -1
  29. package/lib/plugins/image/insert-image-handler.js +72 -33
  30. package/lib/plugins/image/insert-image-handler.js.map +1 -1
  31. package/lib/plugins/index.js +23 -41
  32. package/lib/plugins/index.js.map +1 -1
  33. package/lib/plugins/list/index.js +64 -100
  34. package/lib/plugins/list/index.js.map +1 -1
  35. package/lib/plugins/math/index.js +86 -60
  36. package/lib/plugins/math/index.js.map +1 -1
  37. package/lib/plugins/media/index.js +202 -132
  38. package/lib/plugins/media/index.js.map +1 -1
  39. package/lib/plugins/media/media-dialog.js +17 -16
  40. package/lib/plugins/media/media-dialog.js.map +1 -1
  41. package/lib/plugins/media/media-toolbar.js +3 -3
  42. package/lib/plugins/media/media-toolbar.js.map +1 -1
  43. package/lib/plugins/media/media-wrapper.js +21 -58
  44. package/lib/plugins/media/media-wrapper.js.map +1 -1
  45. package/lib/plugins/respArea/drag-in-the-blank/choice.js +3 -3
  46. package/lib/plugins/respArea/drag-in-the-blank/choice.js.map +1 -1
  47. package/lib/plugins/respArea/drag-in-the-blank/index.js +3 -2
  48. package/lib/plugins/respArea/drag-in-the-blank/index.js.map +1 -1
  49. package/lib/plugins/respArea/explicit-constructed-response/index.js +3 -2
  50. package/lib/plugins/respArea/explicit-constructed-response/index.js.map +1 -1
  51. package/lib/plugins/respArea/icons/index.js +13 -15
  52. package/lib/plugins/respArea/icons/index.js.map +1 -1
  53. package/lib/plugins/respArea/index.js +87 -53
  54. package/lib/plugins/respArea/index.js.map +1 -1
  55. package/lib/plugins/respArea/inline-dropdown/index.js +4 -3
  56. package/lib/plugins/respArea/inline-dropdown/index.js.map +1 -1
  57. package/lib/plugins/respArea/utils.js +17 -20
  58. package/lib/plugins/respArea/utils.js.map +1 -1
  59. package/lib/plugins/table/icons/index.js +1 -1
  60. package/lib/plugins/table/icons/index.js.map +1 -1
  61. package/lib/plugins/table/index.js +381 -212
  62. package/lib/plugins/table/index.js.map +1 -1
  63. package/lib/plugins/table/table-toolbar.js +5 -6
  64. package/lib/plugins/table/table-toolbar.js.map +1 -1
  65. package/lib/plugins/toolbar/default-toolbar.js +55 -11
  66. package/lib/plugins/toolbar/default-toolbar.js.map +1 -1
  67. package/lib/plugins/toolbar/done-button.js +1 -1
  68. package/lib/plugins/toolbar/done-button.js.map +1 -1
  69. package/lib/plugins/toolbar/editor-and-toolbar.js +186 -232
  70. package/lib/plugins/toolbar/editor-and-toolbar.js.map +1 -1
  71. package/lib/plugins/toolbar/index.js +1 -2
  72. package/lib/plugins/toolbar/index.js.map +1 -1
  73. package/lib/plugins/toolbar/toolbar-buttons.js +1 -1
  74. package/lib/plugins/toolbar/toolbar-buttons.js.map +1 -1
  75. package/lib/plugins/toolbar/toolbar.js +253 -239
  76. package/lib/plugins/toolbar/toolbar.js.map +1 -1
  77. package/lib/plugins/utils.js +27 -2
  78. package/lib/plugins/utils.js.map +1 -1
  79. package/lib/serialization.js +1 -1
  80. package/lib/serialization.js.map +1 -1
  81. package/lib/slate-editor.js +302 -0
  82. package/lib/test-serializer.js +189 -0
  83. package/lib/test-serializer.js.map +1 -0
  84. package/lib/theme.js +1 -1
  85. package/lib/theme.js.map +1 -1
  86. package/package.json +18 -14
  87. package/playground/image/data.js +20 -20
  88. package/playground/image/index.html +22 -20
  89. package/playground/image/index.jsx +12 -10
  90. package/playground/index.html +25 -23
  91. package/playground/mathquill/index.html +23 -20
  92. package/playground/mathquill/index.jsx +18 -22
  93. package/playground/prod-test/index.html +24 -20
  94. package/playground/prod-test/index.jsx +5 -3
  95. package/playground/schema-override/data.js +10 -10
  96. package/playground/schema-override/image-plugin.jsx +3 -4
  97. package/playground/schema-override/index.html +21 -19
  98. package/playground/schema-override/index.jsx +13 -14
  99. package/playground/serialization/data.js +10 -10
  100. package/playground/serialization/image-plugin.jsx +3 -4
  101. package/playground/serialization/index.html +22 -20
  102. package/playground/table-examples.html +5 -8
  103. package/playground/webpack.config.js +10 -10
  104. package/src/components.js +135 -0
  105. package/src/editor.jsx +478 -141
  106. package/src/index.jsx +71 -95
  107. package/src/new-serialization.jsx +291 -0
  108. package/src/parse-html.js +1 -1
  109. package/src/plugins/characters/custom-popper.js +7 -7
  110. package/src/plugins/characters/index.jsx +33 -34
  111. package/src/plugins/characters/utils.js +81 -81
  112. package/src/plugins/hotKeys/index.js +54 -0
  113. package/src/plugins/image/alt-dialog.jsx +4 -5
  114. package/src/plugins/image/component.jsx +106 -89
  115. package/src/plugins/image/image-toolbar.jsx +27 -19
  116. package/src/plugins/image/index.jsx +75 -43
  117. package/src/plugins/image/insert-image-handler.js +62 -27
  118. package/src/plugins/index.jsx +23 -41
  119. package/src/plugins/list/index.jsx +70 -95
  120. package/src/plugins/math/index.jsx +102 -82
  121. package/src/plugins/media/index.jsx +159 -124
  122. package/src/plugins/media/media-dialog.js +98 -71
  123. package/src/plugins/media/media-toolbar.jsx +8 -8
  124. package/src/plugins/media/media-wrapper.jsx +29 -30
  125. package/src/plugins/respArea/drag-in-the-blank/choice.jsx +21 -19
  126. package/src/plugins/respArea/drag-in-the-blank/index.jsx +14 -11
  127. package/src/plugins/respArea/explicit-constructed-response/index.jsx +7 -6
  128. package/src/plugins/respArea/icons/index.jsx +11 -14
  129. package/src/plugins/respArea/index.jsx +92 -52
  130. package/src/plugins/respArea/inline-dropdown/index.jsx +9 -8
  131. package/src/plugins/respArea/utils.jsx +26 -35
  132. package/src/plugins/table/icons/index.jsx +17 -11
  133. package/src/plugins/table/index.jsx +288 -231
  134. package/src/plugins/table/table-toolbar.jsx +15 -11
  135. package/src/plugins/toolbar/default-toolbar.jsx +65 -19
  136. package/src/plugins/toolbar/done-button.jsx +4 -4
  137. package/src/plugins/toolbar/editor-and-toolbar.jsx +150 -145
  138. package/src/plugins/toolbar/index.jsx +2 -3
  139. package/src/plugins/toolbar/toolbar-buttons.jsx +11 -11
  140. package/src/plugins/toolbar/toolbar.jsx +244 -221
  141. package/src/plugins/utils.js +21 -4
  142. package/src/serialization.jsx +32 -32
  143. package/src/test-serializer.js +139 -0
  144. package/src/test-serializer.js.rej +20 -0
@@ -5,16 +5,18 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.serialization = exports.reactAttributes = exports.parseStyleString = exports.moveFocusToBeginningOfTable = exports["default"] = void 0;
8
+ exports.serialization = exports.reactAttributes = exports.parseStyleString = exports["default"] = void 0;
9
9
 
10
10
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
11
 
12
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
13
+
14
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
15
+
12
16
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
13
17
 
14
18
  var _react = _interopRequireDefault(require("react"));
15
19
 
16
- var _slateEditTable = _interopRequireDefault(require("slate-edit-table"));
17
-
18
20
  var _slate = require("slate");
19
21
 
20
22
  var _debug = _interopRequireDefault(require("debug"));
@@ -25,43 +27,57 @@ var _tableToolbar = _interopRequireDefault(require("./table-toolbar"));
25
27
 
26
28
  var _propTypes = _interopRequireDefault(require("prop-types"));
27
29
 
28
- var _slatePropTypes = _interopRequireDefault(require("slate-prop-types"));
30
+ var _slateHyperscript = require("slate-hyperscript");
29
31
 
30
- var _styles = require("@material-ui/core/styles");
32
+ var _styles = require("@material-ui/styles");
31
33
 
32
34
  var _reactAttrConverter = _interopRequireDefault(require("react-attr-converter"));
33
35
 
34
36
  var _toStyle = require("to-style");
35
37
 
38
+ var _get = _interopRequireDefault(require("lodash/get"));
39
+
40
+ var _omit = _interopRequireDefault(require("lodash/omit"));
41
+
42
+ var _reduce = _interopRequireDefault(require("lodash/reduce"));
43
+
36
44
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
37
45
 
38
46
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
39
47
 
48
+ function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
49
+
50
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
51
+
52
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
53
+
40
54
  var log = (0, _debug["default"])('@pie-lib:editable-html:plugins:table');
41
- var Table = (0, _styles.withStyles)(function () {
42
- return {
43
- table: {}
44
- };
45
- })(function (props) {
46
- var nodeAttributes = dataToAttributes(props.node.data);
47
- return /*#__PURE__*/_react["default"].createElement("table", (0, _extends2["default"])({
48
- className: props.classes.table
49
- }, props.attributes, nodeAttributes, {
55
+
56
+ var Table = /*#__PURE__*/_react["default"].forwardRef(function (props) {
57
+ var nodeAttributes = (0, _omit["default"])(dataToAttributes(props.element.data), 'newTable');
58
+ var attrs = (0, _omit["default"])(props.attributes, 'newTable');
59
+ return /*#__PURE__*/_react["default"].createElement("table", (0, _extends2["default"])({}, attrs, nodeAttributes, {
50
60
  onFocus: props.onFocus,
51
61
  onBlur: props.onBlur
52
- }), /*#__PURE__*/_react["default"].createElement("tbody", null, props.children));
62
+ }), props.children);
53
63
  });
64
+
54
65
  Table.propTypes = {
55
66
  attributes: _propTypes["default"].object,
67
+ element: _propTypes["default"].object,
56
68
  onFocus: _propTypes["default"].func,
57
69
  onBlur: _propTypes["default"].func,
58
- node: _slatePropTypes["default"].node,
70
+ node: _propTypes["default"].shape({
71
+ type: _propTypes["default"].string,
72
+ children: _propTypes["default"].array,
73
+ data: _propTypes["default"].object
74
+ }),
59
75
  children: _propTypes["default"].oneOfType([_propTypes["default"].arrayOf(_propTypes["default"].node), _propTypes["default"].node]).isRequired
60
76
  };
61
77
 
62
- var TableRow = function TableRow(props) {
78
+ var TableRow = /*#__PURE__*/_react["default"].forwardRef(function (props) {
63
79
  return /*#__PURE__*/_react["default"].createElement("tr", props.attributes, props.children);
64
- };
80
+ });
65
81
 
66
82
  TableRow.propTypes = {
67
83
  attributes: _propTypes["default"].object,
@@ -69,163 +85,377 @@ TableRow.propTypes = {
69
85
  onBlur: _propTypes["default"].func,
70
86
  children: _propTypes["default"].oneOfType([_propTypes["default"].arrayOf(_propTypes["default"].node), _propTypes["default"].node]).isRequired
71
87
  };
72
- var TableCell = (0, _styles.withStyles)(function () {
73
- return {
74
- td: {
75
- minWidth: '25px'
76
- }
77
- };
78
- })(function (props) {
79
- var Tag = props.node.data.get('header') ? 'th' : 'td';
80
- var nodeAttributes = dataToAttributes(props.node.data);
88
+
89
+ var TableBody = /*#__PURE__*/_react["default"].forwardRef(function (props) {
90
+ return /*#__PURE__*/_react["default"].createElement("tbody", props.attributes, props.children);
91
+ });
92
+
93
+ TableBody.propTypes = {
94
+ attributes: _propTypes["default"].object,
95
+ onFocus: _propTypes["default"].func,
96
+ onBlur: _propTypes["default"].func,
97
+ children: _propTypes["default"].oneOfType([_propTypes["default"].arrayOf(_propTypes["default"].node), _propTypes["default"].node]).isRequired
98
+ };
99
+ var useCellStyles = (0, _styles.makeStyles)({
100
+ td: {
101
+ minWidth: '25px'
102
+ }
103
+ });
104
+
105
+ var TableCell = /*#__PURE__*/_react["default"].forwardRef(function (props) {
106
+ var classes = useCellStyles();
107
+ var node = props.node;
108
+ var Tag = (0, _get["default"])(node, 'data.header') ? 'th' : 'td';
109
+ var nodeAttributes = dataToAttributes(props.element.data);
81
110
  delete nodeAttributes.header;
82
111
  return /*#__PURE__*/_react["default"].createElement(Tag, (0, _extends2["default"])({}, props.attributes, nodeAttributes, {
83
- colSpan: props.node.data.get('colspan'),
84
- className: props.classes[Tag],
112
+ colSpan: (0, _get["default"])(node, 'data.colspan'),
113
+ className: classes[Tag],
85
114
  onFocus: props.onFocus,
86
115
  onBlur: props.onBlur
87
116
  }), props.children);
88
117
  });
118
+
89
119
  TableCell.propTypes = {
120
+ node: _propTypes["default"].object,
121
+ element: _propTypes["default"].object,
90
122
  attributes: _propTypes["default"].object,
91
123
  onFocus: _propTypes["default"].func,
92
124
  onBlur: _propTypes["default"].func,
93
125
  children: _propTypes["default"].oneOfType([_propTypes["default"].arrayOf(_propTypes["default"].node), _propTypes["default"].node]).isRequired
94
126
  };
95
127
 
96
- var moveFocusToBeginningOfTable = function moveFocusToBeginningOfTable(change) {
97
- var addedTable = change.value.document.findDescendant(function (d) {
98
- return !!d.data && !!d.data.get('newTable');
128
+ var getAncestorByType = function getAncestorByType(editor, type) {
129
+ if (!editor || !type) {
130
+ return null;
131
+ }
132
+
133
+ var ancestors = _slate.Node.ancestors(editor, _slate.Editor.path(editor, editor.selection), {
134
+ reverse: true
99
135
  });
100
136
 
101
- if (!addedTable) {
102
- return;
137
+ var _iterator = _createForOfIteratorHelper(ancestors),
138
+ _step;
139
+
140
+ try {
141
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
142
+ var _step$value = (0, _slicedToArray2["default"])(_step.value, 2),
143
+ ancestor = _step$value[0],
144
+ ancestorPath = _step$value[1];
145
+
146
+ if (ancestor.type === type) {
147
+ return [ancestor, ancestorPath];
148
+ }
149
+ }
150
+ } catch (err) {
151
+ _iterator.e(err);
152
+ } finally {
153
+ _iterator.f();
103
154
  }
104
155
 
105
- change.collapseToStartOf(addedTable);
106
- var update = addedTable.data.remove('newTable');
107
- change.setNodeByKey(addedTable.key, {
108
- data: update
109
- });
156
+ return null;
110
157
  };
111
158
 
112
- exports.moveFocusToBeginningOfTable = moveFocusToBeginningOfTable;
159
+ var moveToBeginningOfTable = function moveToBeginningOfTable(editor) {
160
+ var _getAncestorByType = getAncestorByType(editor, 'table'),
161
+ _getAncestorByType2 = (0, _slicedToArray2["default"])(_getAncestorByType, 2),
162
+ tableBlock = _getAncestorByType2[0],
163
+ tablePath = _getAncestorByType2[1];
164
+
165
+ var firstTdPath;
166
+
167
+ var _iterator2 = _createForOfIteratorHelper(_slate.Node.descendants(tableBlock, {
168
+ reverse: true
169
+ })),
170
+ _step2;
171
+
172
+ try {
173
+ for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
174
+ var _step2$value = (0, _slicedToArray2["default"])(_step2.value, 2),
175
+ descendant = _step2$value[0],
176
+ descendantPath = _step2$value[1];
177
+
178
+ if (descendant.type === 'td') {
179
+ firstTdPath = descendantPath;
180
+ }
181
+ }
182
+ } catch (err) {
183
+ _iterator2.e(err);
184
+ } finally {
185
+ _iterator2.f();
186
+ }
187
+
188
+ _slate.Transforms.select(editor, [].concat((0, _toConsumableArray2["default"])(tablePath), (0, _toConsumableArray2["default"])(firstTdPath)));
189
+ };
190
+
191
+ var TABLE_TYPES = ['tbody', 'tr', 'td', 'table'];
113
192
 
114
193
  var _default = function _default(opts, toolbarPlugins
115
194
  /* : {toolbar: {}}[] */
116
195
  ) {
117
- var core = (0, _slateEditTable["default"])({
118
- typeContent: 'div'
119
- }); // fix outdated schema
120
-
121
- if (core.schema && core.schema.blocks) {
122
- Object.keys(core.schema.blocks).forEach(function (key) {
123
- var block = core.schema.blocks[key];
124
-
125
- if (block.parent) {
126
- if (block.nodes[0].types) {
127
- block.nodes[0] = {
128
- type: block.nodes[0].types[0]
129
- };
130
- }
196
+ var core = {
197
+ utils: {}
198
+ };
131
199
 
132
- if (block.nodes[0].objects) {
133
- block.nodes[0] = {
134
- object: block.nodes[0].objects[0]
135
- };
136
- }
200
+ core.utils.createTable = function () {
201
+ var row = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 2;
202
+ var columns = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 2;
203
+ var tableRows = [];
204
+ var rowLength = new Array(row).fill(0).length;
205
+ var columnsLength = new Array(columns).fill(0).length;
206
+
207
+ for (var i = 0; i < rowLength; i++) {
208
+ var tableRow = {
209
+ type: 'tr',
210
+ children: []
211
+ };
137
212
 
138
- block.parent = {
139
- type: block.parent.types[0]
140
- };
141
- } else {
142
- block.nodes[0] = {
143
- type: block.nodes[0].types[0]
144
- };
213
+ for (var j = 0; j < columnsLength; j++) {
214
+ tableRow.children.push({
215
+ type: 'td',
216
+ children: [{
217
+ text: ''
218
+ }]
219
+ });
145
220
  }
146
- });
147
- }
148
221
 
149
- core.utils.getTableBlock = function (containerNode, key) {
150
- var node = containerNode.getDescendant(key);
151
- var ancestors = containerNode.getAncestors(key).push(node);
152
- return ancestors.findLast(function (p) {
153
- return p.type === 'table';
154
- });
222
+ tableRows.push(tableRow);
223
+ }
224
+
225
+ return {
226
+ type: 'table',
227
+ children: [{
228
+ type: 'tbody',
229
+ children: tableRows
230
+ }]
231
+ };
232
+ };
233
+
234
+ core.utils.getTableBlock = function (editor) {
235
+ return getAncestorByType(editor, 'table');
236
+ };
237
+
238
+ core.utils.isSelectionInTable = function (editor) {
239
+ return !!core.utils.getTableBlock(editor);
155
240
  };
156
241
 
157
242
  core.utils.createTableWithOptions = function (row, columns, extra) {
158
243
  var createdTable = core.utils.createTable(row, columns);
159
244
 
160
- var newTable = _slate.Block.create(_objectSpread(_objectSpread({}, createdTable.toJSON()), extra));
245
+ var newTable = _objectSpread(_objectSpread({}, createdTable), extra);
161
246
 
162
247
  return newTable;
163
248
  };
164
249
 
165
250
  core.toolbar = {
166
251
  icon: /*#__PURE__*/_react["default"].createElement(_GridOn["default"], null),
167
- onClick: function onClick(value, onChange) {
252
+ onClick: function onClick(editor) {
168
253
  log('insert table');
169
- var change = value.change();
170
254
  var newTable = core.utils.createTableWithOptions(2, 2, {
171
255
  data: {
172
256
  border: '1',
173
257
  newTable: true
174
258
  }
175
259
  });
176
- change.insertBlock(newTable);
177
- moveFocusToBeginningOfTable(change);
178
- onChange(change);
179
- },
180
- supports: function supports(node, value) {
181
- return node && node.object === 'block' && core.utils.isSelectionInTable(value);
260
+ editor.insertNode(newTable);
261
+ moveToBeginningOfTable(editor, newTable);
182
262
  },
183
263
 
184
264
  /**
185
265
  * Note - the node may not be a table node - it may be a node inside a table.
186
266
  */
187
- customToolbar: function customToolbar(node, value, onToolbarDone) {
267
+ customToolbar: function customToolbar(node, value, editor, onToolbarDone) {
188
268
  log('[customToolbar] node.data: ', node.data);
189
- var tableBlock = core.utils.getTableBlock(value.document, node === null || node === void 0 ? void 0 : node.key);
269
+
270
+ var _core$utils$getTableB = core.utils.getTableBlock(editor),
271
+ _core$utils$getTableB2 = (0, _slicedToArray2["default"])(_core$utils$getTableB, 1),
272
+ tableBlock = _core$utils$getTableB2[0];
273
+
190
274
  log('[customToolbar] tableBlock: ', tableBlock);
191
275
 
192
276
  var hasBorder = function hasBorder() {
193
- return tableBlock.data.get('border') && tableBlock.data.get('border') !== '0';
277
+ return (0, _get["default"])(tableBlock, 'data.border') !== '0';
194
278
  };
195
279
 
196
280
  var addRow = function addRow() {
197
- var change = core.changes.insertRow(value.change());
198
- onToolbarDone(change, false);
199
- };
281
+ var _getAncestorByType3 = getAncestorByType(editor, 'tr'),
282
+ _getAncestorByType4 = (0, _slicedToArray2["default"])(_getAncestorByType3, 2),
283
+ trNode = _getAncestorByType4[0],
284
+ trPath = _getAncestorByType4[1];
200
285
 
201
- var addColumn = function addColumn() {
202
- var change = core.changes.insertColumn(value.change());
203
- onToolbarDone(change, false);
286
+ log('[addRow]');
287
+
288
+ if (trNode) {
289
+ var newTr = {
290
+ type: 'tr',
291
+ children: []
292
+ };
293
+ var columnsLength = trNode.children.length;
294
+
295
+ for (var i = 0; i < columnsLength; i++) {
296
+ newTr.children.push({
297
+ type: 'td',
298
+ children: [{
299
+ text: ''
300
+ }]
301
+ });
302
+ }
303
+
304
+ _slate.Transforms.insertNodes(editor, [newTr], {
305
+ at: trPath
306
+ });
307
+ }
204
308
  };
205
309
 
206
310
  var removeRow = function removeRow() {
207
- var change = core.changes.removeRow(value.change());
208
- onToolbarDone(change, false);
311
+ var _getAncestorByType5 = getAncestorByType(editor, 'tbody'),
312
+ _getAncestorByType6 = (0, _slicedToArray2["default"])(_getAncestorByType5, 2),
313
+ tBodyNode = _getAncestorByType6[0],
314
+ tBodyPath = _getAncestorByType6[1];
315
+
316
+ log('[removeRow]');
317
+
318
+ if (tBodyPath) {
319
+ if (tBodyNode.children.length > 1) {
320
+ var _getAncestorByType7 = getAncestorByType(editor, 'tr'),
321
+ _getAncestorByType8 = (0, _slicedToArray2["default"])(_getAncestorByType7, 2),
322
+ trPath = _getAncestorByType8[1];
323
+
324
+ log('[removeRow]');
325
+
326
+ if (trPath) {
327
+ _slate.Transforms.removeNodes(editor, {
328
+ at: trPath
329
+ });
330
+ }
331
+ }
332
+ }
333
+ };
334
+
335
+ var addColumn = function addColumn() {
336
+ var _getAncestorByType9 = getAncestorByType(editor, 'tbody'),
337
+ _getAncestorByType10 = (0, _slicedToArray2["default"])(_getAncestorByType9, 2),
338
+ tBodyNode = _getAncestorByType10[0],
339
+ tBodyPath = _getAncestorByType10[1];
340
+
341
+ log('[addColumn]');
342
+
343
+ if (tBodyNode) {
344
+ var emptyTd = {
345
+ type: 'td',
346
+ children: [{
347
+ text: ''
348
+ }]
349
+ };
350
+
351
+ var trElements = _slate.Editor.nodes(editor, {
352
+ at: tBodyPath,
353
+ // Path of Editor
354
+ match: function match(node) {
355
+ return 'tr' === node.type;
356
+ }
357
+ });
358
+
359
+ var _iterator3 = _createForOfIteratorHelper(trElements),
360
+ _step3;
361
+
362
+ try {
363
+ for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
364
+ var _step3$value = (0, _slicedToArray2["default"])(_step3.value, 2),
365
+ trNode = _step3$value[0],
366
+ nodePath = _step3$value[1];
367
+
368
+ _slate.Transforms.insertNodes(editor, [emptyTd], {
369
+ at: [].concat((0, _toConsumableArray2["default"])(nodePath), [trNode.children.length])
370
+ });
371
+ }
372
+ } catch (err) {
373
+ _iterator3.e(err);
374
+ } finally {
375
+ _iterator3.f();
376
+ }
377
+ }
209
378
  };
210
379
 
211
380
  var removeColumn = function removeColumn() {
212
- var change = core.changes.removeColumn(value.change());
213
- onToolbarDone(change, false);
381
+ var _getAncestorByType11 = getAncestorByType(editor, 'tbody'),
382
+ _getAncestorByType12 = (0, _slicedToArray2["default"])(_getAncestorByType11, 2),
383
+ tBodyNode = _getAncestorByType12[0],
384
+ tBodyPath = _getAncestorByType12[1];
385
+
386
+ log('[addColumn]');
387
+
388
+ if (tBodyNode) {
389
+ var currentPath = _slate.Editor.path(editor, editor.selection);
390
+
391
+ var columnIndex = currentPath[currentPath.length - 2];
392
+
393
+ var trElements = _slate.Editor.nodes(editor, {
394
+ at: tBodyPath,
395
+ // Path of Editor
396
+ match: function match(node) {
397
+ return 'tr' === node.type;
398
+ }
399
+ });
400
+
401
+ var _iterator4 = _createForOfIteratorHelper(trElements),
402
+ _step4;
403
+
404
+ try {
405
+ for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
406
+ var _step4$value = (0, _slicedToArray2["default"])(_step4.value, 2),
407
+ trNode = _step4$value[0],
408
+ nodePath = _step4$value[1];
409
+
410
+ if (trNode.children.length > 1) {
411
+ _slate.Transforms.removeNodes(editor, {
412
+ at: [].concat((0, _toConsumableArray2["default"])(nodePath), [columnIndex])
413
+ });
414
+ }
415
+ }
416
+ } catch (err) {
417
+ _iterator4.e(err);
418
+ } finally {
419
+ _iterator4.f();
420
+ }
421
+ }
214
422
  };
215
423
 
216
424
  var removeTable = function removeTable() {
217
- var change = core.changes.removeTable(value.change());
218
- onToolbarDone(change, false);
425
+ var _getAncestorByType13 = getAncestorByType(editor, 'table'),
426
+ _getAncestorByType14 = (0, _slicedToArray2["default"])(_getAncestorByType13, 2),
427
+ tableNode = _getAncestorByType14[0],
428
+ tablePath = _getAncestorByType14[1];
429
+
430
+ editor.apply({
431
+ type: 'remove_node',
432
+ path: tablePath,
433
+ node: tableNode
434
+ });
219
435
  };
220
436
 
221
437
  var toggleBorder = function toggleBorder() {
222
438
  var data = tableBlock.data;
223
- var update = data.set('border', hasBorder() ? '0' : '1');
439
+
440
+ var update = _objectSpread(_objectSpread({}, data), {}, {
441
+ border: hasBorder() ? '0' : '1'
442
+ });
443
+
444
+ var _getAncestorByType15 = getAncestorByType(editor, 'table'),
445
+ _getAncestorByType16 = (0, _slicedToArray2["default"])(_getAncestorByType15, 2),
446
+ tablePath = _getAncestorByType16[1];
447
+
224
448
  log('[toggleBorder] update: ', update);
225
- var change = value.change().setNodeByKey(tableBlock.key, {
226
- data: update
449
+ editor.apply({
450
+ type: 'set_node',
451
+ path: tablePath,
452
+ properties: {
453
+ data: node.data
454
+ },
455
+ newProperties: {
456
+ data: update
457
+ }
227
458
  });
228
- onToolbarDone(change, false);
229
459
  };
230
460
 
231
461
  var onDone = function onDone() {
@@ -235,11 +465,11 @@ var _default = function _default(opts, toolbarPlugins
235
465
 
236
466
  var Tb = function Tb() {
237
467
  return /*#__PURE__*/_react["default"].createElement(_tableToolbar["default"], {
468
+ editor: editor,
238
469
  plugins: toolbarPlugins,
239
470
  onChange: function onChange(c) {
240
471
  return onToolbarDone(c, false);
241
472
  },
242
- value: value,
243
473
  onAddRow: addRow,
244
474
  onRemoveRow: removeRow,
245
475
  onAddColumn: addColumn,
@@ -255,6 +485,10 @@ var _default = function _default(opts, toolbarPlugins
255
485
  }
256
486
  };
257
487
 
488
+ core.supports = function (node, editor) {
489
+ return TABLE_TYPES.includes(node.type);
490
+ };
491
+
258
492
  var Node = function Node(props) {
259
493
  switch (props.node.type) {
260
494
  case 'table':
@@ -263,10 +497,16 @@ var _default = function _default(opts, toolbarPlugins
263
497
  onBlur: opts.onBlur
264
498
  }));
265
499
 
266
- case 'table_row':
500
+ case 'tbody':
501
+ return /*#__PURE__*/_react["default"].createElement(TableBody, (0, _extends2["default"])({}, props, {
502
+ onFocus: opts.onFocus,
503
+ onBlur: opts.onBlur
504
+ }));
505
+
506
+ case 'tr':
267
507
  return /*#__PURE__*/_react["default"].createElement(TableRow, props);
268
508
 
269
- case 'table_cell':
509
+ case 'td':
270
510
  return /*#__PURE__*/_react["default"].createElement(TableCell, (0, _extends2["default"])({}, props, {
271
511
  onFocus: opts.onFocus,
272
512
  onBlur: opts.onBlur
@@ -280,74 +520,6 @@ var _default = function _default(opts, toolbarPlugins
280
520
  Node.propTypes = {
281
521
  node: _propTypes["default"].object
282
522
  };
283
-
284
- core.normalizeNode = function (node) {
285
- if (node.object !== 'document') {
286
- return;
287
- }
288
-
289
- var tableAdded = node.findDescendant(function (d) {
290
- return d.data && d.data.get('newTable');
291
- });
292
-
293
- if (!tableAdded) {
294
- return;
295
- }
296
-
297
- var nodeToSearch = node.getParent(tableAdded.key) || node;
298
- var shouldAddTextAfterNode = false;
299
- var indexToNotHaveTableOn = nodeToSearch.nodes.size - 1;
300
- var indexOfLastTable = nodeToSearch.nodes.findLastIndex(function (d) {
301
- return d.type === 'table';
302
- }); // if the last table in the document is of type table, we need to do the change
303
-
304
- if (indexOfLastTable === indexToNotHaveTableOn) {
305
- shouldAddTextAfterNode = true;
306
- }
307
-
308
- if (!shouldAddTextAfterNode) {
309
- return;
310
- }
311
-
312
- return function (change) {
313
- if (shouldAddTextAfterNode) {
314
- var tableJSON = tableAdded.toJSON(); // we remove the table node because otherwise we can't add the empty block after it
315
- // we need a block that contains text in order to do it
316
-
317
- change.removeNodeByKey(tableAdded.key);
318
-
319
- var newBlock = _slate.Block.create({
320
- object: 'block',
321
- type: 'div'
322
- }); // we add an empty block but that it's going to be normalized
323
- // because it will add the empty text to it like it should
324
-
325
-
326
- change.insertBlock(newBlock);
327
- change.withoutNormalization(function () {
328
- // we do these changes without normalization
329
- // we get the text previous to the new block added
330
- var prevText = change.value.document.getPreviousText(newBlock.key);
331
-
332
- if (prevText) {
333
- var _prevText$text, _prevText$text2;
334
-
335
- // we move focus to the previous text
336
- change.moveFocusTo(prevText.key, (_prevText$text = prevText.text) === null || _prevText$text === void 0 ? void 0 : _prevText$text.length).moveAnchorTo(prevText.key, (_prevText$text2 = prevText.text) === null || _prevText$text2 === void 0 ? void 0 : _prevText$text2.length);
337
- } // we insert the table block between the first block with text and the last block with text
338
-
339
-
340
- change.insertBlock(_objectSpread(_objectSpread({}, tableJSON), {}, {
341
- data: _objectSpread(_objectSpread({}, tableJSON.data), {}, {
342
- newTable: true
343
- })
344
- }));
345
- moveFocusToBeginningOfTable(change);
346
- });
347
- }
348
- };
349
- };
350
-
351
523
  core.renderNode = Node;
352
524
  return core;
353
525
  };
@@ -396,11 +568,7 @@ var attributesToMap = function attributesToMap(el) {
396
568
  };
397
569
 
398
570
  var dataToAttributes = function dataToAttributes(data) {
399
- if (!data || !data.get) {
400
- return {};
401
- }
402
-
403
- return data.reduce(function (acc, v, name) {
571
+ return (0, _reduce["default"])(data, function (acc, v, name) {
404
572
  if (v) {
405
573
  acc[(0, _reactAttrConverter["default"])(name)] = v;
406
574
  }
@@ -420,80 +588,81 @@ var serialization = {
420
588
  {
421
589
  var children = el.children.length === 1 && el.children[0].tagName.toLowerCase() === 'tbody' ? el.children[0].children : el.children;
422
590
  var c = Array.from(children);
423
- return {
424
- object: 'block',
591
+ return (0, _slateHyperscript.jsx)('element', {
425
592
  type: 'table',
426
- nodes: next(c),
427
593
  data: attributes.reduce(attributesToMap(el), {})
428
- };
594
+ }, next(c));
595
+ }
596
+
597
+ case 'tbody':
598
+ {
599
+ return (0, _slateHyperscript.jsx)('element', {
600
+ type: 'tbody'
601
+ }, next(el.childNodes));
429
602
  }
430
603
 
431
604
  case 'th':
432
605
  {
433
- return {
434
- object: 'block',
435
- type: 'table_cell',
436
- nodes: next(el.childNodes),
606
+ return (0, _slateHyperscript.jsx)('element', {
607
+ type: 'th',
437
608
  data: cellAttributes.reduce(attributesToMap(el), {
438
609
  header: true
439
610
  })
440
- };
611
+ }, next(el.childNodes));
441
612
  }
442
613
 
443
614
  case 'tr':
444
615
  {
445
- return {
446
- object: 'block',
447
- type: 'table_row',
448
- nodes: next(Array.from(el.children))
449
- };
616
+ return (0, _slateHyperscript.jsx)('element', {
617
+ type: 'tr'
618
+ }, next(Array.from(el.children)));
450
619
  }
451
620
 
452
621
  case 'td':
453
622
  {
454
- return {
455
- object: 'block',
456
- type: 'table_cell',
457
- nodes: next(Array.from(el.childNodes)),
623
+ return (0, _slateHyperscript.jsx)('element', {
624
+ type: 'td',
458
625
  data: cellAttributes.reduce(attributesToMap(el), {
459
- header: false
626
+ header: true
460
627
  })
461
- };
628
+ }, next(el.childNodes));
462
629
  }
463
630
  }
464
631
  },
465
632
  serialize: function serialize(object, children) {
466
- if (object.object !== 'block') {
467
- return;
468
- }
469
-
470
633
  switch (object.type) {
471
634
  case 'table':
472
635
  {
473
636
  var _attributes = dataToAttributes(object.data);
474
637
 
475
- return /*#__PURE__*/_react["default"].createElement("table", _attributes, /*#__PURE__*/_react["default"].createElement("tbody", null, children));
638
+ return /*#__PURE__*/_react["default"].createElement("table", _attributes, children);
639
+ }
640
+
641
+ case 'tbody':
642
+ {
643
+ return /*#__PURE__*/_react["default"].createElement("tbody", null, children);
476
644
  }
477
645
 
478
- case 'table_row':
646
+ case 'tr':
479
647
  {
480
648
  return /*#__PURE__*/_react["default"].createElement("tr", null, children);
481
649
  }
482
650
 
483
- case 'table_cell':
651
+ case 'td':
484
652
  {
485
653
  var _attributes2 = dataToAttributes(object.data);
486
654
 
487
- delete _attributes2.header;
655
+ return /*#__PURE__*/_react["default"].createElement("td", _attributes2, children);
656
+ }
488
657
 
489
- if (object.data.get('header')) {
490
- return /*#__PURE__*/_react["default"].createElement("th", _attributes2, children);
491
- } else {
492
- return /*#__PURE__*/_react["default"].createElement("td", _attributes2, children);
493
- }
658
+ case 'th':
659
+ {
660
+ var _attributes3 = dataToAttributes(object.data);
661
+
662
+ return /*#__PURE__*/_react["default"].createElement("th", _attributes3, children);
494
663
  }
495
664
  }
496
665
  }
497
666
  };
498
667
  exports.serialization = serialization;
499
- //# sourceMappingURL=index.js.map
668
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["log","debug","Table","React","forwardRef","props","nodeAttributes","omit","dataToAttributes","element","data","attrs","attributes","onFocus","onBlur","children","propTypes","PropTypes","object","func","node","shape","type","string","array","oneOfType","arrayOf","isRequired","TableRow","TableBody","useCellStyles","makeStyles","td","minWidth","TableCell","classes","Tag","get","header","getAncestorByType","editor","ancestors","SlateNode","Editor","path","selection","reverse","ancestor","ancestorPath","moveToBeginningOfTable","tableBlock","tablePath","firstTdPath","descendants","descendant","descendantPath","Transforms","select","TABLE_TYPES","opts","toolbarPlugins","core","utils","createTable","row","columns","tableRows","rowLength","Array","fill","length","columnsLength","i","tableRow","j","push","text","getTableBlock","isSelectionInTable","createTableWithOptions","extra","createdTable","newTable","toolbar","icon","onClick","border","insertNode","customToolbar","value","onToolbarDone","hasBorder","addRow","trNode","trPath","newTr","insertNodes","at","removeRow","tBodyNode","tBodyPath","removeNodes","addColumn","emptyTd","trElements","nodes","match","nodePath","removeColumn","currentPath","columnIndex","removeTable","tableNode","apply","toggleBorder","update","properties","newProperties","onDone","Tb","c","supports","includes","Node","renderNode","parseStyleString","s","regex","result","exec","trim","reactAttributes","o","toStyleObject","camelize","addUnits","attributesToMap","el","acc","attribute","getAttribute","styleString","reactStyleObject","reduce","v","name","convert","cellAttributes","serialization","deserialize","next","tag","tagName","toLowerCase","from","jsx","childNodes","serialize"],"sources":["../../../src/plugins/table/index.jsx"],"sourcesContent":["import React from 'react';\nimport { Node as SlateNode, Editor, Transforms } from 'slate';\nimport debug from 'debug';\nimport GridOn from '@material-ui/icons/GridOn';\nimport TableToolbar from './table-toolbar';\nimport PropTypes from 'prop-types';\nimport { jsx } from 'slate-hyperscript';\nimport { makeStyles } from '@material-ui/styles';\nimport convert from 'react-attr-converter';\nimport { object as toStyleObject } from 'to-style';\nimport get from 'lodash/get';\nimport omit from 'lodash/omit';\nimport reduce from 'lodash/reduce';\n\nconst log = debug('@pie-lib:editable-html:plugins:table');\n\nconst Table = React.forwardRef(props => {\n  const nodeAttributes = omit(dataToAttributes(props.element.data), 'newTable');\n  const attrs = omit(props.attributes, 'newTable');\n\n  return (\n    <table {...attrs} {...nodeAttributes} onFocus={props.onFocus} onBlur={props.onBlur}>\n      {props.children}\n    </table>\n  );\n});\n\nTable.propTypes = {\n  attributes: PropTypes.object,\n  element: PropTypes.object,\n  onFocus: PropTypes.func,\n  onBlur: PropTypes.func,\n  node: PropTypes.shape({\n    type: PropTypes.string,\n    children: PropTypes.array,\n    data: PropTypes.object\n  }),\n  children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]).isRequired\n};\n\nconst TableRow = React.forwardRef(props => <tr {...props.attributes}>{props.children}</tr>);\n\nTableRow.propTypes = {\n  attributes: PropTypes.object,\n  onFocus: PropTypes.func,\n  onBlur: PropTypes.func,\n  children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]).isRequired\n};\n\nconst TableBody = React.forwardRef(props => <tbody {...props.attributes}>{props.children}</tbody>);\n\nTableBody.propTypes = {\n  attributes: PropTypes.object,\n  onFocus: PropTypes.func,\n  onBlur: PropTypes.func,\n  children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]).isRequired\n};\n\nconst useCellStyles = makeStyles({\n  td: {\n    minWidth: '25px'\n  }\n});\n\nconst TableCell = React.forwardRef(props => {\n  const classes = useCellStyles();\n  const { node } = props;\n  const Tag = get(node, 'data.header') ? 'th' : 'td';\n\n  const nodeAttributes = dataToAttributes(props.element.data);\n  delete nodeAttributes.header;\n\n  return (\n    <Tag\n      {...props.attributes}\n      {...nodeAttributes}\n      colSpan={get(node, 'data.colspan')}\n      className={classes[Tag]}\n      onFocus={props.onFocus}\n      onBlur={props.onBlur}\n    >\n      {props.children}\n    </Tag>\n  );\n});\n\nTableCell.propTypes = {\n  node: PropTypes.object,\n  element: PropTypes.object,\n  attributes: PropTypes.object,\n  onFocus: PropTypes.func,\n  onBlur: PropTypes.func,\n  children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]).isRequired\n};\n\nconst getAncestorByType = (editor, type) => {\n  if (!editor || !type) {\n    return null;\n  }\n\n  const ancestors = SlateNode.ancestors(editor, Editor.path(editor, editor.selection), {\n    reverse: true\n  });\n\n  for (const [ancestor, ancestorPath] of ancestors) {\n    if (ancestor.type === type) {\n      return [ancestor, ancestorPath];\n    }\n  }\n\n  return null;\n};\n\nconst moveToBeginningOfTable = editor => {\n  const [tableBlock, tablePath] = getAncestorByType(editor, 'table');\n  let firstTdPath;\n\n  for (const [descendant, descendantPath] of SlateNode.descendants(tableBlock, { reverse: true })) {\n    if (descendant.type === 'td') {\n      firstTdPath = descendantPath;\n    }\n  }\n\n  Transforms.select(editor, [...tablePath, ...firstTdPath]);\n};\n\nconst TABLE_TYPES = ['tbody', 'tr', 'td', 'table'];\n\nexport default (opts, toolbarPlugins /* :  {toolbar: {}}[] */) => {\n  const core = {\n    utils: {}\n  };\n\n  core.utils.createTable = (row = 2, columns = 2) => {\n    const tableRows = [];\n    const rowLength = new Array(row).fill(0).length;\n    const columnsLength = new Array(columns).fill(0).length;\n\n    for (let i = 0; i < rowLength; i++) {\n      const tableRow = { type: 'tr', children: [] };\n\n      for (let j = 0; j < columnsLength; j++) {\n        tableRow.children.push({\n          type: 'td',\n          children: [\n            {\n              text: ''\n            }\n          ]\n        });\n      }\n\n      tableRows.push(tableRow);\n    }\n\n    return {\n      type: 'table',\n      children: [\n        {\n          type: 'tbody',\n          children: tableRows\n        }\n      ]\n    };\n  };\n\n  core.utils.getTableBlock = editor => getAncestorByType(editor, 'table');\n\n  core.utils.isSelectionInTable = editor => !!core.utils.getTableBlock(editor);\n\n  core.utils.createTableWithOptions = (row, columns, extra) => {\n    const createdTable = core.utils.createTable(row, columns);\n    const newTable = { ...createdTable, ...extra };\n\n    return newTable;\n  };\n\n  core.toolbar = {\n    icon: <GridOn />,\n    onClick: editor => {\n      log('insert table');\n      const newTable = core.utils.createTableWithOptions(2, 2, {\n        data: {\n          border: '1',\n          newTable: true\n        }\n      });\n\n      editor.insertNode(newTable);\n      moveToBeginningOfTable(editor, newTable);\n    },\n    /**\n     * Note - the node may not be a table node - it may be a node inside a table.\n     */\n    customToolbar: (node, value, editor, onToolbarDone) => {\n      log('[customToolbar] node.data: ', node.data);\n\n      const [tableBlock] = core.utils.getTableBlock(editor);\n      log('[customToolbar] tableBlock: ', tableBlock);\n\n      const hasBorder = () => get(tableBlock, 'data.border') !== '0';\n      const addRow = () => {\n        const [trNode, trPath] = getAncestorByType(editor, 'tr');\n\n        log('[addRow]');\n\n        if (trNode) {\n          const newTr = { type: 'tr', children: [] };\n          const columnsLength = trNode.children.length;\n\n          for (let i = 0; i < columnsLength; i++) {\n            newTr.children.push({\n              type: 'td',\n              children: [\n                {\n                  text: ''\n                }\n              ]\n            });\n          }\n\n          Transforms.insertNodes(editor, [newTr], { at: trPath });\n        }\n      };\n\n      const removeRow = () => {\n        const [tBodyNode, tBodyPath] = getAncestorByType(editor, 'tbody');\n\n        log('[removeRow]');\n\n        if (tBodyPath) {\n          if (tBodyNode.children.length > 1) {\n            const [, trPath] = getAncestorByType(editor, 'tr');\n\n            log('[removeRow]');\n\n            if (trPath) {\n              Transforms.removeNodes(editor, { at: trPath });\n            }\n          }\n        }\n      };\n\n      const addColumn = () => {\n        const [tBodyNode, tBodyPath] = getAncestorByType(editor, 'tbody');\n\n        log('[addColumn]');\n\n        if (tBodyNode) {\n          const emptyTd = {\n            type: 'td',\n            children: [{ text: '' }]\n          };\n          const trElements = Editor.nodes(editor, {\n            at: tBodyPath, // Path of Editor\n            match: node => 'tr' === node.type\n          });\n\n          for (const [trNode, nodePath] of trElements) {\n            Transforms.insertNodes(editor, [emptyTd], {\n              at: [...nodePath, trNode.children.length]\n            });\n          }\n        }\n      };\n\n      const removeColumn = () => {\n        const [tBodyNode, tBodyPath] = getAncestorByType(editor, 'tbody');\n\n        log('[addColumn]');\n\n        if (tBodyNode) {\n          const currentPath = Editor.path(editor, editor.selection);\n          const columnIndex = currentPath[currentPath.length - 2];\n          const trElements = Editor.nodes(editor, {\n            at: tBodyPath, // Path of Editor\n            match: node => 'tr' === node.type\n          });\n\n          for (const [trNode, nodePath] of trElements) {\n            if (trNode.children.length > 1) {\n              Transforms.removeNodes(editor, { at: [...nodePath, columnIndex] });\n            }\n          }\n        }\n      };\n\n      const removeTable = () => {\n        const [tableNode, tablePath] = getAncestorByType(editor, 'table');\n\n        editor.apply({\n          type: 'remove_node',\n          path: tablePath,\n          node: tableNode\n        });\n      };\n\n      const toggleBorder = () => {\n        const { data } = tableBlock;\n        const update = {\n          ...data,\n          border: hasBorder() ? '0' : '1'\n        };\n        const [, tablePath] = getAncestorByType(editor, 'table');\n\n        log('[toggleBorder] update: ', update);\n\n        editor.apply({\n          type: 'set_node',\n          path: tablePath,\n          properties: {\n            data: node.data\n          },\n          newProperties: { data: update }\n        });\n      };\n\n      const onDone = () => {\n        log('[onDone] call onToolbarDone...');\n        onToolbarDone(null, true);\n      };\n\n      const Tb = () => (\n        <TableToolbar\n          editor={editor}\n          plugins={toolbarPlugins}\n          onChange={c => onToolbarDone(c, false)}\n          onAddRow={addRow}\n          onRemoveRow={removeRow}\n          onAddColumn={addColumn}\n          onRemoveColumn={removeColumn}\n          onRemoveTable={removeTable}\n          hasBorder={hasBorder()}\n          onToggleBorder={toggleBorder}\n          onDone={onDone}\n        />\n      );\n      return Tb;\n    }\n  };\n\n  core.supports = (node, editor) => TABLE_TYPES.includes(node.type);\n\n  const Node = props => {\n    switch (props.node.type) {\n      case 'table':\n        return <Table {...props} onFocus={opts.onFocus} onBlur={opts.onBlur} />;\n      case 'tbody':\n        return <TableBody {...props} onFocus={opts.onFocus} onBlur={opts.onBlur} />;\n      case 'tr':\n        return <TableRow {...props} />;\n      case 'td':\n        return <TableCell {...props} onFocus={opts.onFocus} onBlur={opts.onBlur} />;\n      default:\n        return null;\n    }\n  };\n  Node.propTypes = {\n    node: PropTypes.object\n  };\n\n  core.renderNode = Node;\n\n  return core;\n};\n\nexport const parseStyleString = s => {\n  const regex = /([\\w-]*)\\s*:\\s*([^;]*)/g;\n  let match;\n  const result = {};\n  while ((match = regex.exec(s))) {\n    result[match[1]] = match[2].trim();\n  }\n  return result;\n};\n\nexport const reactAttributes = o => toStyleObject(o, { camelize: true, addUnits: false });\n\nconst attributesToMap = el => (acc, attribute) => {\n  const value = el.getAttribute(attribute);\n  if (value) {\n    if (attribute === 'style') {\n      const styleString = el.getAttribute(attribute);\n      const reactStyleObject = reactAttributes(parseStyleString(styleString));\n      acc['style'] = reactStyleObject;\n    } else {\n      acc[attribute] = el.getAttribute(attribute);\n    }\n  }\n  return acc;\n};\n\nconst dataToAttributes = data => {\n  return reduce(\n    data,\n    (acc, v, name) => {\n      if (v) {\n        acc[convert(name)] = v;\n      }\n      return acc;\n    },\n    {}\n  );\n};\n\nconst attributes = ['border', 'cellpadding', 'cellspacing', 'class', 'style'];\n\nconst cellAttributes = ['colspan', 'rowspan', 'class', 'style'];\n\nexport const serialization = {\n  deserialize(el, next) {\n    const tag = el.tagName.toLowerCase();\n\n    switch (tag) {\n      case 'table': {\n        const children =\n          el.children.length === 1 && el.children[0].tagName.toLowerCase() === 'tbody'\n            ? el.children[0].children\n            : el.children;\n        const c = Array.from(children);\n\n        return jsx(\n          'element',\n          {\n            type: 'table',\n            data: attributes.reduce(attributesToMap(el), {})\n          },\n          next(c)\n        );\n      }\n      case 'tbody': {\n        return jsx(\n          'element',\n          {\n            type: 'tbody'\n          },\n          next(el.childNodes)\n        );\n      }\n      case 'th': {\n        return jsx(\n          'element',\n          {\n            type: 'th',\n            data: cellAttributes.reduce(attributesToMap(el), { header: true })\n          },\n          next(el.childNodes)\n        );\n      }\n      case 'tr': {\n        return jsx(\n          'element',\n          {\n            type: 'tr'\n          },\n          next(Array.from(el.children))\n        );\n      }\n      case 'td': {\n        return jsx(\n          'element',\n          {\n            type: 'td',\n            data: cellAttributes.reduce(attributesToMap(el), { header: true })\n          },\n          next(el.childNodes)\n        );\n      }\n    }\n  },\n  serialize(object, children) {\n    switch (object.type) {\n      case 'table': {\n        const attributes = dataToAttributes(object.data);\n        return (\n          <table {...attributes}>\n            {children}\n          </table>\n        );\n      }\n      case 'tbody': {\n        return <tbody>{children}</tbody>;\n      }\n      case 'tr': {\n        return <tr>{children}</tr>;\n      }\n      case 'td': {\n        const attributes = dataToAttributes(object.data);\n        return <td {...attributes}>{children}</td>;\n      }\n      case 'th': {\n        const attributes = dataToAttributes(object.data);\n        return <th {...attributes}>{children}</th>;\n      }\n    }\n  }\n};\n"],"mappings":"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"}