@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.
- package/CHANGELOG.md +0 -302
- package/lib/components.js +116 -0
- package/lib/components.js.map +1 -0
- package/lib/editor.js +418 -103
- package/lib/editor.js.map +1 -1
- package/lib/index.js +101 -155
- package/lib/index.js.map +1 -1
- package/lib/new-serialization.js +320 -0
- package/lib/new-serialization.js.map +1 -0
- package/lib/old-serialization.js +330 -0
- package/lib/parse-html.js +1 -1
- package/lib/parse-html.js.map +1 -1
- package/lib/plugins/characters/custom-popper.js +1 -1
- package/lib/plugins/characters/custom-popper.js.map +1 -1
- package/lib/plugins/characters/index.js +21 -19
- package/lib/plugins/characters/index.js.map +1 -1
- package/lib/plugins/characters/utils.js +1 -1
- package/lib/plugins/characters/utils.js.map +1 -1
- package/lib/plugins/hotKeys/index.js +67 -0
- package/lib/plugins/hotKeys/index.js.map +1 -0
- package/lib/plugins/image/alt-dialog.js +1 -6
- package/lib/plugins/image/alt-dialog.js.map +1 -1
- package/lib/plugins/image/component.js +70 -53
- package/lib/plugins/image/component.js.map +1 -1
- package/lib/plugins/image/image-toolbar.js +7 -9
- package/lib/plugins/image/image-toolbar.js.map +1 -1
- package/lib/plugins/image/index.js +83 -27
- package/lib/plugins/image/index.js.map +1 -1
- package/lib/plugins/image/insert-image-handler.js +72 -33
- package/lib/plugins/image/insert-image-handler.js.map +1 -1
- package/lib/plugins/index.js +23 -41
- package/lib/plugins/index.js.map +1 -1
- package/lib/plugins/list/index.js +64 -100
- package/lib/plugins/list/index.js.map +1 -1
- package/lib/plugins/math/index.js +86 -60
- package/lib/plugins/math/index.js.map +1 -1
- package/lib/plugins/media/index.js +202 -132
- package/lib/plugins/media/index.js.map +1 -1
- package/lib/plugins/media/media-dialog.js +17 -16
- package/lib/plugins/media/media-dialog.js.map +1 -1
- package/lib/plugins/media/media-toolbar.js +3 -3
- package/lib/plugins/media/media-toolbar.js.map +1 -1
- package/lib/plugins/media/media-wrapper.js +21 -58
- package/lib/plugins/media/media-wrapper.js.map +1 -1
- package/lib/plugins/respArea/drag-in-the-blank/choice.js +3 -3
- package/lib/plugins/respArea/drag-in-the-blank/choice.js.map +1 -1
- package/lib/plugins/respArea/drag-in-the-blank/index.js +3 -2
- package/lib/plugins/respArea/drag-in-the-blank/index.js.map +1 -1
- package/lib/plugins/respArea/explicit-constructed-response/index.js +3 -2
- package/lib/plugins/respArea/explicit-constructed-response/index.js.map +1 -1
- package/lib/plugins/respArea/icons/index.js +13 -15
- package/lib/plugins/respArea/icons/index.js.map +1 -1
- package/lib/plugins/respArea/index.js +87 -53
- package/lib/plugins/respArea/index.js.map +1 -1
- package/lib/plugins/respArea/inline-dropdown/index.js +4 -3
- package/lib/plugins/respArea/inline-dropdown/index.js.map +1 -1
- package/lib/plugins/respArea/utils.js +17 -20
- package/lib/plugins/respArea/utils.js.map +1 -1
- package/lib/plugins/table/icons/index.js +1 -1
- package/lib/plugins/table/icons/index.js.map +1 -1
- package/lib/plugins/table/index.js +381 -212
- package/lib/plugins/table/index.js.map +1 -1
- package/lib/plugins/table/table-toolbar.js +5 -6
- package/lib/plugins/table/table-toolbar.js.map +1 -1
- package/lib/plugins/toolbar/default-toolbar.js +55 -11
- package/lib/plugins/toolbar/default-toolbar.js.map +1 -1
- package/lib/plugins/toolbar/done-button.js +1 -1
- package/lib/plugins/toolbar/done-button.js.map +1 -1
- package/lib/plugins/toolbar/editor-and-toolbar.js +186 -232
- package/lib/plugins/toolbar/editor-and-toolbar.js.map +1 -1
- package/lib/plugins/toolbar/index.js +1 -2
- package/lib/plugins/toolbar/index.js.map +1 -1
- package/lib/plugins/toolbar/toolbar-buttons.js +1 -1
- package/lib/plugins/toolbar/toolbar-buttons.js.map +1 -1
- package/lib/plugins/toolbar/toolbar.js +253 -239
- package/lib/plugins/toolbar/toolbar.js.map +1 -1
- package/lib/plugins/utils.js +27 -2
- package/lib/plugins/utils.js.map +1 -1
- package/lib/serialization.js +1 -1
- package/lib/serialization.js.map +1 -1
- package/lib/slate-editor.js +302 -0
- package/lib/test-serializer.js +189 -0
- package/lib/test-serializer.js.map +1 -0
- package/lib/theme.js +1 -1
- package/lib/theme.js.map +1 -1
- package/package.json +18 -14
- package/playground/image/data.js +20 -20
- package/playground/image/index.html +22 -20
- package/playground/image/index.jsx +12 -10
- package/playground/index.html +25 -23
- package/playground/mathquill/index.html +23 -20
- package/playground/mathquill/index.jsx +18 -22
- package/playground/prod-test/index.html +24 -20
- package/playground/prod-test/index.jsx +5 -3
- package/playground/schema-override/data.js +10 -10
- package/playground/schema-override/image-plugin.jsx +3 -4
- package/playground/schema-override/index.html +21 -19
- package/playground/schema-override/index.jsx +13 -14
- package/playground/serialization/data.js +10 -10
- package/playground/serialization/image-plugin.jsx +3 -4
- package/playground/serialization/index.html +22 -20
- package/playground/table-examples.html +5 -8
- package/playground/webpack.config.js +10 -10
- package/src/components.js +135 -0
- package/src/editor.jsx +478 -141
- package/src/index.jsx +71 -95
- package/src/new-serialization.jsx +291 -0
- package/src/parse-html.js +1 -1
- package/src/plugins/characters/custom-popper.js +7 -7
- package/src/plugins/characters/index.jsx +33 -34
- package/src/plugins/characters/utils.js +81 -81
- package/src/plugins/hotKeys/index.js +54 -0
- package/src/plugins/image/alt-dialog.jsx +4 -5
- package/src/plugins/image/component.jsx +106 -89
- package/src/plugins/image/image-toolbar.jsx +27 -19
- package/src/plugins/image/index.jsx +75 -43
- package/src/plugins/image/insert-image-handler.js +62 -27
- package/src/plugins/index.jsx +23 -41
- package/src/plugins/list/index.jsx +70 -95
- package/src/plugins/math/index.jsx +102 -82
- package/src/plugins/media/index.jsx +159 -124
- package/src/plugins/media/media-dialog.js +98 -71
- package/src/plugins/media/media-toolbar.jsx +8 -8
- package/src/plugins/media/media-wrapper.jsx +29 -30
- package/src/plugins/respArea/drag-in-the-blank/choice.jsx +21 -19
- package/src/plugins/respArea/drag-in-the-blank/index.jsx +14 -11
- package/src/plugins/respArea/explicit-constructed-response/index.jsx +7 -6
- package/src/plugins/respArea/icons/index.jsx +11 -14
- package/src/plugins/respArea/index.jsx +92 -52
- package/src/plugins/respArea/inline-dropdown/index.jsx +9 -8
- package/src/plugins/respArea/utils.jsx +26 -35
- package/src/plugins/table/icons/index.jsx +17 -11
- package/src/plugins/table/index.jsx +288 -231
- package/src/plugins/table/table-toolbar.jsx +15 -11
- package/src/plugins/toolbar/default-toolbar.jsx +65 -19
- package/src/plugins/toolbar/done-button.jsx +4 -4
- package/src/plugins/toolbar/editor-and-toolbar.jsx +150 -145
- package/src/plugins/toolbar/index.jsx +2 -3
- package/src/plugins/toolbar/toolbar-buttons.jsx +11 -11
- package/src/plugins/toolbar/toolbar.jsx +244 -221
- package/src/plugins/utils.js +21 -4
- package/src/serialization.jsx +32 -32
- package/src/test-serializer.js +139 -0
- 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
|
|
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
|
|
30
|
+
var _slateHyperscript = require("slate-hyperscript");
|
|
29
31
|
|
|
30
|
-
var _styles = require("@material-ui/
|
|
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
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
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
|
-
}),
|
|
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:
|
|
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
|
|
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
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
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:
|
|
84
|
-
className:
|
|
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
|
|
97
|
-
|
|
98
|
-
return
|
|
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
|
-
|
|
102
|
-
|
|
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
|
-
|
|
106
|
-
var update = addedTable.data.remove('newTable');
|
|
107
|
-
change.setNodeByKey(addedTable.key, {
|
|
108
|
-
data: update
|
|
109
|
-
});
|
|
156
|
+
return null;
|
|
110
157
|
};
|
|
111
158
|
|
|
112
|
-
|
|
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 =
|
|
118
|
-
|
|
119
|
-
}
|
|
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
|
-
|
|
133
|
-
|
|
134
|
-
|
|
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
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
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
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
return
|
|
153
|
-
|
|
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 =
|
|
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(
|
|
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
|
-
|
|
177
|
-
|
|
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
|
-
|
|
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
|
|
277
|
+
return (0, _get["default"])(tableBlock, 'data.border') !== '0';
|
|
194
278
|
};
|
|
195
279
|
|
|
196
280
|
var addRow = function addRow() {
|
|
197
|
-
var
|
|
198
|
-
|
|
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
|
-
|
|
202
|
-
|
|
203
|
-
|
|
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
|
|
208
|
-
|
|
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
|
|
213
|
-
|
|
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
|
|
218
|
-
|
|
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
|
-
|
|
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
|
-
|
|
226
|
-
|
|
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 '
|
|
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 '
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
447
|
-
|
|
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
|
-
|
|
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:
|
|
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,
|
|
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 '
|
|
646
|
+
case 'tr':
|
|
479
647
|
{
|
|
480
648
|
return /*#__PURE__*/_react["default"].createElement("tr", null, children);
|
|
481
649
|
}
|
|
482
650
|
|
|
483
|
-
case '
|
|
651
|
+
case 'td':
|
|
484
652
|
{
|
|
485
653
|
var _attributes2 = dataToAttributes(object.data);
|
|
486
654
|
|
|
487
|
-
|
|
655
|
+
return /*#__PURE__*/_react["default"].createElement("td", _attributes2, children);
|
|
656
|
+
}
|
|
488
657
|
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
|
|
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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"}
|