@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
|
@@ -0,0 +1,302 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "__esModule", {
|
|
8
|
+
value: true
|
|
9
|
+
});
|
|
10
|
+
exports["default"] = void 0;
|
|
11
|
+
|
|
12
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
13
|
+
|
|
14
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
15
|
+
|
|
16
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
17
|
+
|
|
18
|
+
var _isHotkey = _interopRequireDefault(require("is-hotkey"));
|
|
19
|
+
|
|
20
|
+
var _slateReact = require("slate-react");
|
|
21
|
+
|
|
22
|
+
var _slate = require("slate");
|
|
23
|
+
|
|
24
|
+
var _slateHistory = require("slate-history");
|
|
25
|
+
|
|
26
|
+
var _mathToolbar = require("@pie-lib/math-toolbar");
|
|
27
|
+
|
|
28
|
+
var _components = require("./components");
|
|
29
|
+
|
|
30
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
31
|
+
|
|
32
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
33
|
+
|
|
34
|
+
var HOTKEYS = {
|
|
35
|
+
'mod+b': 'bold',
|
|
36
|
+
'mod+i': 'italic',
|
|
37
|
+
'mod+u': 'underline',
|
|
38
|
+
'mod+`': 'code'
|
|
39
|
+
};
|
|
40
|
+
var LIST_TYPES = ['numbered-list', 'bulleted-list'];
|
|
41
|
+
var TEXT_ALIGN_TYPES = ['left', 'center', 'right', 'justify'];
|
|
42
|
+
|
|
43
|
+
var withMath = function withMath(editor) {
|
|
44
|
+
var isVoid = editor.isVoid,
|
|
45
|
+
isInline = editor.isInline;
|
|
46
|
+
|
|
47
|
+
editor.isVoid = function (element) {
|
|
48
|
+
return element.type === 'math' ? true : isVoid(element);
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
editor.isInline = function (element) {
|
|
52
|
+
return element.type === 'math' ? true : isInline(element);
|
|
53
|
+
};
|
|
54
|
+
|
|
55
|
+
return editor;
|
|
56
|
+
};
|
|
57
|
+
|
|
58
|
+
var plugins = [withMath, _slateHistory.withHistory, _slateReact.withReact];
|
|
59
|
+
|
|
60
|
+
var withPlugins = function withPlugins(editor) {
|
|
61
|
+
plugins.forEach(function (plugin) {
|
|
62
|
+
plugin(editor);
|
|
63
|
+
});
|
|
64
|
+
return editor;
|
|
65
|
+
};
|
|
66
|
+
|
|
67
|
+
var initialValue = [{
|
|
68
|
+
type: 'paragraph',
|
|
69
|
+
children: [{
|
|
70
|
+
type: 'math',
|
|
71
|
+
data: {
|
|
72
|
+
latex: '\\frac{1}{2}',
|
|
73
|
+
wrapper: 'round_brackets'
|
|
74
|
+
},
|
|
75
|
+
children: [{
|
|
76
|
+
text: '\\(\\frac{1}{2}\\)'
|
|
77
|
+
}]
|
|
78
|
+
}]
|
|
79
|
+
}];
|
|
80
|
+
|
|
81
|
+
var SlateEditor = function SlateEditor(_ref) {
|
|
82
|
+
var value = _ref.value;
|
|
83
|
+
var renderElement = (0, _react.useCallback)(function (props) {
|
|
84
|
+
return /*#__PURE__*/_react["default"].createElement(Element, props);
|
|
85
|
+
}, []);
|
|
86
|
+
var renderLeaf = (0, _react.useCallback)(function (props) {
|
|
87
|
+
return /*#__PURE__*/_react["default"].createElement(Leaf, props);
|
|
88
|
+
}, []);
|
|
89
|
+
var editor = (0, _react.useMemo)(function () {
|
|
90
|
+
return withPlugins((0, _slate.createEditor)());
|
|
91
|
+
}, []);
|
|
92
|
+
var slateValue = (0, _react.useMemo)(function () {
|
|
93
|
+
// Slate throws an error if the value on the initial render is invalid
|
|
94
|
+
// so we directly set the value on the editor in order
|
|
95
|
+
// to be able to trigger normalization on the initial value before rendering
|
|
96
|
+
editor.children = value;
|
|
97
|
+
|
|
98
|
+
_slate.Editor.normalize(editor, {
|
|
99
|
+
force: true
|
|
100
|
+
}); // We return the normalized internal value so that the rendering can take over from here
|
|
101
|
+
|
|
102
|
+
|
|
103
|
+
return editor.children;
|
|
104
|
+
}, [editor, value]);
|
|
105
|
+
return /*#__PURE__*/_react["default"].createElement(_slateReact.Slate, {
|
|
106
|
+
editor: editor,
|
|
107
|
+
value: slateValue
|
|
108
|
+
}, /*#__PURE__*/_react["default"].createElement(_slateReact.Editable, {
|
|
109
|
+
renderElement: renderElement,
|
|
110
|
+
renderLeaf: renderLeaf,
|
|
111
|
+
placeholder: "Enter some rich text\u2026",
|
|
112
|
+
spellCheck: true,
|
|
113
|
+
onKeyDown: function onKeyDown(event) {
|
|
114
|
+
for (var hotkey in HOTKEYS) {
|
|
115
|
+
if ((0, _isHotkey["default"])(hotkey, event)) {
|
|
116
|
+
event.preventDefault();
|
|
117
|
+
var mark = HOTKEYS[hotkey];
|
|
118
|
+
toggleMark(editor, mark);
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
}));
|
|
123
|
+
};
|
|
124
|
+
|
|
125
|
+
var toggleBlock = function toggleBlock(editor, format) {
|
|
126
|
+
var isActive = isBlockActive(editor, format, TEXT_ALIGN_TYPES.includes(format) ? 'align' : 'type');
|
|
127
|
+
var isList = LIST_TYPES.includes(format);
|
|
128
|
+
|
|
129
|
+
_slate.Transforms.unwrapNodes(editor, {
|
|
130
|
+
match: function match(n) {
|
|
131
|
+
return !_slate.Editor.isEditor(n) && _slate.Element.isElement(n) && LIST_TYPES.includes(n.type) && !TEXT_ALIGN_TYPES.includes(format);
|
|
132
|
+
},
|
|
133
|
+
split: true
|
|
134
|
+
});
|
|
135
|
+
|
|
136
|
+
var newProperties;
|
|
137
|
+
|
|
138
|
+
if (TEXT_ALIGN_TYPES.includes(format)) {
|
|
139
|
+
newProperties = {
|
|
140
|
+
align: isActive ? undefined : format
|
|
141
|
+
};
|
|
142
|
+
} else {
|
|
143
|
+
newProperties = {
|
|
144
|
+
type: isActive ? 'paragraph' : isList ? 'list-item' : format
|
|
145
|
+
};
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
_slate.Transforms.setNodes(editor, newProperties);
|
|
149
|
+
|
|
150
|
+
if (!isActive && isList) {
|
|
151
|
+
var block = {
|
|
152
|
+
type: format,
|
|
153
|
+
children: []
|
|
154
|
+
};
|
|
155
|
+
|
|
156
|
+
_slate.Transforms.wrapNodes(editor, block);
|
|
157
|
+
}
|
|
158
|
+
};
|
|
159
|
+
|
|
160
|
+
var toggleMark = function toggleMark(editor, format) {
|
|
161
|
+
var isActive = isMarkActive(editor, format);
|
|
162
|
+
|
|
163
|
+
if (isActive) {
|
|
164
|
+
_slate.Editor.removeMark(editor, format);
|
|
165
|
+
} else {
|
|
166
|
+
_slate.Editor.addMark(editor, format, true);
|
|
167
|
+
}
|
|
168
|
+
};
|
|
169
|
+
|
|
170
|
+
var isBlockActive = function isBlockActive(editor, format) {
|
|
171
|
+
var blockType = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'type';
|
|
172
|
+
var selection = editor.selection;
|
|
173
|
+
if (!selection) return false;
|
|
174
|
+
|
|
175
|
+
var _Array$from = Array.from(_slate.Editor.nodes(editor, {
|
|
176
|
+
at: _slate.Editor.unhangRange(editor, selection),
|
|
177
|
+
match: function match(n) {
|
|
178
|
+
return !_slate.Editor.isEditor(n) && _slate.Element.isElement(n) && n[blockType] === format;
|
|
179
|
+
}
|
|
180
|
+
})),
|
|
181
|
+
_Array$from2 = (0, _slicedToArray2["default"])(_Array$from, 1),
|
|
182
|
+
match = _Array$from2[0];
|
|
183
|
+
|
|
184
|
+
return !!match;
|
|
185
|
+
};
|
|
186
|
+
|
|
187
|
+
var isMarkActive = function isMarkActive(editor, format) {
|
|
188
|
+
var marks = _slate.Editor.marks(editor);
|
|
189
|
+
|
|
190
|
+
return marks ? marks[format] === true : false;
|
|
191
|
+
};
|
|
192
|
+
|
|
193
|
+
var Element = function Element(props) {
|
|
194
|
+
var attributes = props.attributes,
|
|
195
|
+
children = props.children,
|
|
196
|
+
element = props.element;
|
|
197
|
+
var style = {
|
|
198
|
+
textAlign: element.align
|
|
199
|
+
};
|
|
200
|
+
|
|
201
|
+
switch (element.type) {
|
|
202
|
+
case 'block-quote':
|
|
203
|
+
return /*#__PURE__*/_react["default"].createElement("blockquote", (0, _extends2["default"])({
|
|
204
|
+
style: style
|
|
205
|
+
}, attributes), children);
|
|
206
|
+
|
|
207
|
+
case 'bulleted-list':
|
|
208
|
+
return /*#__PURE__*/_react["default"].createElement("ul", (0, _extends2["default"])({
|
|
209
|
+
style: style
|
|
210
|
+
}, attributes), children);
|
|
211
|
+
|
|
212
|
+
case 'heading-one':
|
|
213
|
+
return /*#__PURE__*/_react["default"].createElement("h1", (0, _extends2["default"])({
|
|
214
|
+
style: style
|
|
215
|
+
}, attributes), children);
|
|
216
|
+
|
|
217
|
+
case 'heading-two':
|
|
218
|
+
return /*#__PURE__*/_react["default"].createElement("h2", (0, _extends2["default"])({
|
|
219
|
+
style: style
|
|
220
|
+
}, attributes), children);
|
|
221
|
+
|
|
222
|
+
case 'list-item':
|
|
223
|
+
return /*#__PURE__*/_react["default"].createElement("li", (0, _extends2["default"])({
|
|
224
|
+
style: style
|
|
225
|
+
}, attributes), children);
|
|
226
|
+
|
|
227
|
+
case 'numbered-list':
|
|
228
|
+
return /*#__PURE__*/_react["default"].createElement("ol", (0, _extends2["default"])({
|
|
229
|
+
style: style
|
|
230
|
+
}, attributes), children);
|
|
231
|
+
|
|
232
|
+
case 'math':
|
|
233
|
+
return /*#__PURE__*/_react["default"].createElement(_mathToolbar.MathPreview, (0, _extends2["default"])({}, attributes, props));
|
|
234
|
+
|
|
235
|
+
case 'mathml':
|
|
236
|
+
var html = props.node.data.get('html');
|
|
237
|
+
return /*#__PURE__*/_react["default"].createElement("span", (0, _extends2["default"])({}, props.attributes, {
|
|
238
|
+
dangerouslySetInnerHTML: {
|
|
239
|
+
__html: html
|
|
240
|
+
}
|
|
241
|
+
}));
|
|
242
|
+
|
|
243
|
+
default:
|
|
244
|
+
return /*#__PURE__*/_react["default"].createElement("p", (0, _extends2["default"])({
|
|
245
|
+
style: style
|
|
246
|
+
}, attributes), children);
|
|
247
|
+
}
|
|
248
|
+
};
|
|
249
|
+
|
|
250
|
+
var Leaf = function Leaf(_ref2) {
|
|
251
|
+
var attributes = _ref2.attributes,
|
|
252
|
+
children = _ref2.children,
|
|
253
|
+
leaf = _ref2.leaf;
|
|
254
|
+
|
|
255
|
+
if (leaf.bold) {
|
|
256
|
+
children = /*#__PURE__*/_react["default"].createElement("strong", null, children);
|
|
257
|
+
}
|
|
258
|
+
|
|
259
|
+
if (leaf.code) {
|
|
260
|
+
children = /*#__PURE__*/_react["default"].createElement("code", null, children);
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
if (leaf.italic) {
|
|
264
|
+
children = /*#__PURE__*/_react["default"].createElement("em", null, children);
|
|
265
|
+
}
|
|
266
|
+
|
|
267
|
+
if (leaf.underline) {
|
|
268
|
+
children = /*#__PURE__*/_react["default"].createElement("u", null, children);
|
|
269
|
+
}
|
|
270
|
+
|
|
271
|
+
return /*#__PURE__*/_react["default"].createElement("span", attributes, children);
|
|
272
|
+
};
|
|
273
|
+
|
|
274
|
+
var BlockButton = function BlockButton(_ref3) {
|
|
275
|
+
var format = _ref3.format,
|
|
276
|
+
icon = _ref3.icon;
|
|
277
|
+
var editor = (0, _slateReact.useSlate)();
|
|
278
|
+
return /*#__PURE__*/_react["default"].createElement(_components.Button, {
|
|
279
|
+
active: isBlockActive(editor, format, TEXT_ALIGN_TYPES.includes(format) ? 'align' : 'type'),
|
|
280
|
+
onMouseDown: function onMouseDown(event) {
|
|
281
|
+
event.preventDefault();
|
|
282
|
+
toggleBlock(editor, format);
|
|
283
|
+
}
|
|
284
|
+
}, /*#__PURE__*/_react["default"].createElement(_components.Icon, null, icon));
|
|
285
|
+
};
|
|
286
|
+
|
|
287
|
+
var MarkButton = function MarkButton(_ref4) {
|
|
288
|
+
var format = _ref4.format,
|
|
289
|
+
icon = _ref4.icon;
|
|
290
|
+
var editor = (0, _slateReact.useSlate)();
|
|
291
|
+
return /*#__PURE__*/_react["default"].createElement(_components.Button, {
|
|
292
|
+
active: isMarkActive(editor, format),
|
|
293
|
+
onMouseDown: function onMouseDown(event) {
|
|
294
|
+
event.preventDefault();
|
|
295
|
+
toggleMark(editor, format);
|
|
296
|
+
}
|
|
297
|
+
}, /*#__PURE__*/_react["default"].createElement(_components.Icon, null, icon));
|
|
298
|
+
};
|
|
299
|
+
|
|
300
|
+
var _default = SlateEditor;
|
|
301
|
+
exports["default"] = _default;
|
|
302
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["HOTKEYS","LIST_TYPES","TEXT_ALIGN_TYPES","withMath","editor","isVoid","isInline","element","type","plugins","withHistory","withReact","withPlugins","forEach","plugin","initialValue","children","data","latex","wrapper","text","SlateEditor","value","renderElement","useCallback","props","renderLeaf","useMemo","createEditor","slateValue","Editor","normalize","force","event","hotkey","isHotkey","preventDefault","mark","toggleMark","toggleBlock","format","isActive","isBlockActive","includes","isList","Transforms","unwrapNodes","match","n","isEditor","SlateElement","isElement","split","newProperties","align","undefined","setNodes","block","wrapNodes","isMarkActive","removeMark","addMark","blockType","selection","Array","from","nodes","at","unhangRange","marks","Element","attributes","style","textAlign","html","node","get","__html","Leaf","leaf","bold","code","italic","underline","BlockButton","icon","useSlate","MarkButton"],"sources":["../src/slate-editor.js"],"sourcesContent":["import React, { useCallback, useMemo } from 'react';\nimport isHotkey from 'is-hotkey';\nimport { Editable, withReact, useSlate, Slate } from 'slate-react';\nimport { Editor, Transforms, createEditor, Element as SlateElement } from 'slate';\nimport { withHistory } from 'slate-history';\nimport { MathPreview } from '@pie-lib/math-toolbar';\n\nimport { Button, Icon, Toolbar } from './components';\n\nconst HOTKEYS = {\n  'mod+b': 'bold',\n  'mod+i': 'italic',\n  'mod+u': 'underline',\n  'mod+`': 'code'\n};\n\nconst LIST_TYPES = ['numbered-list', 'bulleted-list'];\nconst TEXT_ALIGN_TYPES = ['left', 'center', 'right', 'justify'];\n\nconst withMath = editor => {\n  const { isVoid, isInline } = editor;\n\n  editor.isVoid = element => {\n    return element.type === 'math' ? true : isVoid(element);\n  };\n\n  editor.isInline = element => {\n    return element.type === 'math' ? true : isInline(element);\n  };\n\n  return editor;\n};\n\nconst plugins = [withMath, withHistory, withReact];\n\nconst withPlugins = editor => {\n  plugins.forEach(plugin => {\n    plugin(editor);\n  });\n\n  return editor;\n};\n\nconst initialValue = [\n  {\n    type: 'paragraph',\n    children: [\n      {\n        type: 'math',\n        data: {\n          latex: '\\\\frac{1}{2}',\n          wrapper: 'round_brackets'\n        },\n        children: [\n          {\n            text: '\\\\(\\\\frac{1}{2}\\\\)'\n          }\n        ]\n      }\n    ]\n  }\n];\n\nconst SlateEditor = ({ value }) => {\n  const renderElement = useCallback(props => <Element {...props} />, []);\n  const renderLeaf = useCallback(props => <Leaf {...props} />, []);\n  const editor = useMemo(() => withPlugins(createEditor()), []);\n\n  const slateValue = useMemo(() => {\n    // Slate throws an error if the value on the initial render is invalid\n    // so we directly set the value on the editor in order\n    // to be able to trigger normalization on the initial value before rendering\n    editor.children = value;\n    Editor.normalize(editor, { force: true });\n    // We return the normalized internal value so that the rendering can take over from here\n    return editor.children;\n  }, [editor, value]);\n\n  return (\n    <Slate editor={editor} value={slateValue}>\n      <Editable\n        renderElement={renderElement}\n        renderLeaf={renderLeaf}\n        placeholder=\"Enter some rich text…\"\n        spellCheck\n        onKeyDown={event => {\n          for (const hotkey in HOTKEYS) {\n            if (isHotkey(hotkey, event)) {\n              event.preventDefault();\n              const mark = HOTKEYS[hotkey];\n              toggleMark(editor, mark);\n            }\n          }\n        }}\n      />\n    </Slate>\n  );\n};\n\nconst toggleBlock = (editor, format) => {\n  const isActive = isBlockActive(\n    editor,\n    format,\n    TEXT_ALIGN_TYPES.includes(format) ? 'align' : 'type'\n  );\n  const isList = LIST_TYPES.includes(format);\n\n  Transforms.unwrapNodes(editor, {\n    match: n =>\n      !Editor.isEditor(n) &&\n      SlateElement.isElement(n) &&\n      LIST_TYPES.includes(n.type) &&\n      !TEXT_ALIGN_TYPES.includes(format),\n    split: true\n  });\n  let newProperties;\n  if (TEXT_ALIGN_TYPES.includes(format)) {\n    newProperties = {\n      align: isActive ? undefined : format\n    };\n  } else {\n    newProperties = {\n      type: isActive ? 'paragraph' : isList ? 'list-item' : format\n    };\n  }\n  Transforms.setNodes(editor, newProperties);\n\n  if (!isActive && isList) {\n    const block = { type: format, children: [] };\n    Transforms.wrapNodes(editor, block);\n  }\n};\n\nconst toggleMark = (editor, format) => {\n  const isActive = isMarkActive(editor, format);\n\n  if (isActive) {\n    Editor.removeMark(editor, format);\n  } else {\n    Editor.addMark(editor, format, true);\n  }\n};\n\nconst isBlockActive = (editor, format, blockType = 'type') => {\n  const { selection } = editor;\n  if (!selection) return false;\n\n  const [match] = Array.from(\n    Editor.nodes(editor, {\n      at: Editor.unhangRange(editor, selection),\n      match: n => !Editor.isEditor(n) && SlateElement.isElement(n) && n[blockType] === format\n    })\n  );\n\n  return !!match;\n};\n\nconst isMarkActive = (editor, format) => {\n  const marks = Editor.marks(editor);\n  return marks ? marks[format] === true : false;\n};\n\nconst Element = props => {\n  const { attributes, children, element } = props;\n  const style = { textAlign: element.align };\n  switch (element.type) {\n    case 'block-quote':\n      return (\n        <blockquote style={style} {...attributes}>\n          {children}\n        </blockquote>\n      );\n    case 'bulleted-list':\n      return (\n        <ul style={style} {...attributes}>\n          {children}\n        </ul>\n      );\n    case 'heading-one':\n      return (\n        <h1 style={style} {...attributes}>\n          {children}\n        </h1>\n      );\n    case 'heading-two':\n      return (\n        <h2 style={style} {...attributes}>\n          {children}\n        </h2>\n      );\n    case 'list-item':\n      return (\n        <li style={style} {...attributes}>\n          {children}\n        </li>\n      );\n    case 'numbered-list':\n      return (\n        <ol style={style} {...attributes}>\n          {children}\n        </ol>\n      );\n    case 'math':\n      return <MathPreview {...attributes} {...props} />;\n    case 'mathml':\n      const html = props.node.data.get('html');\n\n      return <span {...props.attributes} dangerouslySetInnerHTML={{ __html: html }} />;\n    default:\n      return (\n        <p style={style} {...attributes}>\n          {children}\n        </p>\n      );\n  }\n};\n\nconst Leaf = ({ attributes, children, leaf }) => {\n  if (leaf.bold) {\n    children = <strong>{children}</strong>;\n  }\n\n  if (leaf.code) {\n    children = <code>{children}</code>;\n  }\n\n  if (leaf.italic) {\n    children = <em>{children}</em>;\n  }\n\n  if (leaf.underline) {\n    children = <u>{children}</u>;\n  }\n\n  return <span {...attributes}>{children}</span>;\n};\n\nconst BlockButton = ({ format, icon }) => {\n  const editor = useSlate();\n  return (\n    <Button\n      active={isBlockActive(editor, format, TEXT_ALIGN_TYPES.includes(format) ? 'align' : 'type')}\n      onMouseDown={event => {\n        event.preventDefault();\n        toggleBlock(editor, format);\n      }}\n    >\n      <Icon>{icon}</Icon>\n    </Button>\n  );\n};\n\nconst MarkButton = ({ format, icon }) => {\n  const editor = useSlate();\n  return (\n    <Button\n      active={isMarkActive(editor, format)}\n      onMouseDown={event => {\n        event.preventDefault();\n        toggleMark(editor, format);\n      }}\n    >\n      <Icon>{icon}</Icon>\n    </Button>\n  );\n};\n\nexport default SlateEditor;\n"],"mappings":"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"}
|
|
@@ -0,0 +1,189 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports["default"] = void 0;
|
|
9
|
+
|
|
10
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
11
|
+
|
|
12
|
+
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
13
|
+
|
|
14
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
15
|
+
|
|
16
|
+
var _react = _interopRequireDefault(require("react"));
|
|
17
|
+
|
|
18
|
+
var _server = _interopRequireDefault(require("react-dom/server"));
|
|
19
|
+
|
|
20
|
+
var _escapeHtml = _interopRequireDefault(require("escape-html"));
|
|
21
|
+
|
|
22
|
+
var _slate = require("slate");
|
|
23
|
+
|
|
24
|
+
var _slateHyperscript = require("slate-hyperscript");
|
|
25
|
+
|
|
26
|
+
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; }
|
|
27
|
+
|
|
28
|
+
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; }
|
|
29
|
+
|
|
30
|
+
var Html = /*#__PURE__*/(0, _createClass2["default"])(function Html(props) {
|
|
31
|
+
var _this = this;
|
|
32
|
+
|
|
33
|
+
(0, _classCallCheck2["default"])(this, Html);
|
|
34
|
+
(0, _defineProperty2["default"])(this, "serializeEls", function (node) {
|
|
35
|
+
if (_slate.Text.isText(node)) {
|
|
36
|
+
var string = (0, _escapeHtml["default"])(node.text);
|
|
37
|
+
|
|
38
|
+
if (node.bold) {
|
|
39
|
+
string = /*#__PURE__*/_react["default"].createElement("strong", null, string);
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
return string;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
var children = (node.children || []).map(function (n) {
|
|
46
|
+
return _this.serializeEls(n);
|
|
47
|
+
});
|
|
48
|
+
|
|
49
|
+
var correctRule = _this.rules.reduce(function (res, rule) {
|
|
50
|
+
return res || rule.serialize(node, children);
|
|
51
|
+
}, null);
|
|
52
|
+
|
|
53
|
+
if (correctRule) {
|
|
54
|
+
return correctRule;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
switch (node.type) {
|
|
58
|
+
case 'quote':
|
|
59
|
+
return /*#__PURE__*/_react["default"].createElement("blockquote", null, /*#__PURE__*/_react["default"].createElement("p", null, children));
|
|
60
|
+
|
|
61
|
+
case 'paragraph':
|
|
62
|
+
return /*#__PURE__*/_react["default"].createElement("p", null, children);
|
|
63
|
+
|
|
64
|
+
case 'link':
|
|
65
|
+
return /*#__PURE__*/_react["default"].createElement("a", {
|
|
66
|
+
href: (0, _escapeHtml["default"])(node.url)
|
|
67
|
+
}, children);
|
|
68
|
+
|
|
69
|
+
default:
|
|
70
|
+
return children;
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
(0, _defineProperty2["default"])(this, "serialize", function (node) {
|
|
74
|
+
var deserialized = _this.serializeEls(node);
|
|
75
|
+
|
|
76
|
+
var html = _server["default"].renderToStaticMarkup( /*#__PURE__*/_react["default"].createElement('body', null, deserialized));
|
|
77
|
+
|
|
78
|
+
var inner = html.slice(6, -7);
|
|
79
|
+
return inner;
|
|
80
|
+
});
|
|
81
|
+
(0, _defineProperty2["default"])(this, "deserialize", function (html) {
|
|
82
|
+
var body = _this.parseHtml(html);
|
|
83
|
+
|
|
84
|
+
if (!body.firstChild || body.firstChild.nodeType === Node.TEXT_NODE) {
|
|
85
|
+
body = _this.parseHtml("<p>".concat(html, "</p>"));
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
return _this.deserializeEls(body);
|
|
89
|
+
});
|
|
90
|
+
(0, _defineProperty2["default"])(this, "deserializeEls", function (element) {
|
|
91
|
+
var markAttributes = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
92
|
+
|
|
93
|
+
if (element.nodeType === Node.TEXT_NODE) {
|
|
94
|
+
return (0, _slateHyperscript.jsx)('text', markAttributes, element.textContent);
|
|
95
|
+
} else if (element.nodeType !== Node.ELEMENT_NODE) {
|
|
96
|
+
return null;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
var nodeAttributes = _objectSpread({}, markAttributes); // define attributes for text nodes
|
|
100
|
+
|
|
101
|
+
|
|
102
|
+
if (element.nodeName === 'STRONG') {
|
|
103
|
+
nodeAttributes.bold = true;
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
var nextFn = function nextFn(nodes) {
|
|
107
|
+
var childNodes = Array.from(nodes);
|
|
108
|
+
var children = Array.from(childNodes).map(function (node) {
|
|
109
|
+
return _this.deserializeEls(node, nodeAttributes);
|
|
110
|
+
}).flat();
|
|
111
|
+
|
|
112
|
+
if (children.length === 0) {
|
|
113
|
+
children.push((0, _slateHyperscript.jsx)('text', nodeAttributes, ''));
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
return children;
|
|
117
|
+
};
|
|
118
|
+
|
|
119
|
+
var correctRule = _this.rules.reduce(function (res, rule) {
|
|
120
|
+
return res || rule.deserialize(element, nextFn);
|
|
121
|
+
}, null);
|
|
122
|
+
|
|
123
|
+
if (correctRule) {
|
|
124
|
+
return correctRule;
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
var childNodes = Array.from(element.childNodes);
|
|
128
|
+
var children = Array.from(childNodes).map(function (node) {
|
|
129
|
+
return _this.deserializeEls(node, nodeAttributes);
|
|
130
|
+
}).flat();
|
|
131
|
+
|
|
132
|
+
if (children.length === 0) {
|
|
133
|
+
children.push((0, _slateHyperscript.jsx)('text', nodeAttributes, ''));
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
switch (element.nodeName) {
|
|
137
|
+
case 'TABLE':
|
|
138
|
+
return (0, _slateHyperscript.jsx)('element', {
|
|
139
|
+
type: 'table'
|
|
140
|
+
}, children);
|
|
141
|
+
|
|
142
|
+
case 'TBODY':
|
|
143
|
+
return (0, _slateHyperscript.jsx)('element', {
|
|
144
|
+
type: 'tbody'
|
|
145
|
+
}, children);
|
|
146
|
+
|
|
147
|
+
case 'TR':
|
|
148
|
+
return (0, _slateHyperscript.jsx)('element', {
|
|
149
|
+
type: 'tr'
|
|
150
|
+
}, children);
|
|
151
|
+
|
|
152
|
+
case 'TD':
|
|
153
|
+
return (0, _slateHyperscript.jsx)('element', {
|
|
154
|
+
type: 'td'
|
|
155
|
+
}, children);
|
|
156
|
+
|
|
157
|
+
case 'BODY':
|
|
158
|
+
return (0, _slateHyperscript.jsx)('fragment', {}, children);
|
|
159
|
+
|
|
160
|
+
case 'BR':
|
|
161
|
+
return '\n';
|
|
162
|
+
|
|
163
|
+
case 'BLOCKQUOTE':
|
|
164
|
+
return (0, _slateHyperscript.jsx)('element', {
|
|
165
|
+
type: 'quote'
|
|
166
|
+
}, children);
|
|
167
|
+
|
|
168
|
+
case 'P':
|
|
169
|
+
return (0, _slateHyperscript.jsx)('element', {
|
|
170
|
+
type: 'paragraph'
|
|
171
|
+
}, children);
|
|
172
|
+
|
|
173
|
+
case 'A':
|
|
174
|
+
return (0, _slateHyperscript.jsx)('element', {
|
|
175
|
+
type: 'link',
|
|
176
|
+
url: element.getAttribute('href')
|
|
177
|
+
}, children);
|
|
178
|
+
|
|
179
|
+
default:
|
|
180
|
+
return children;
|
|
181
|
+
}
|
|
182
|
+
});
|
|
183
|
+
this.defaultBlock = props.defaultBlock;
|
|
184
|
+
this.parseHtml = props.parseHtml;
|
|
185
|
+
this.rules = props.rules;
|
|
186
|
+
});
|
|
187
|
+
var _default = Html;
|
|
188
|
+
exports["default"] = _default;
|
|
189
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Html","props","node","Text","isText","string","escapeHtml","text","bold","children","map","n","serializeEls","correctRule","rules","reduce","res","rule","serialize","type","url","deserialized","html","ReactServer","renderToStaticMarkup","React","createElement","inner","slice","body","parseHtml","firstChild","nodeType","Node","TEXT_NODE","deserializeEls","element","markAttributes","jsx","textContent","ELEMENT_NODE","nodeAttributes","nodeName","nextFn","nodes","childNodes","Array","from","flat","length","push","deserialize","getAttribute","defaultBlock"],"sources":["../src/test-serializer.js"],"sourcesContent":["import React from 'react';\nimport ReactServer from 'react-dom/server';\nimport escapeHtml from 'escape-html';\nimport { Text } from 'slate';\nimport { jsx } from 'slate-hyperscript';\n\nclass Html {\n  constructor(props) {\n    this.defaultBlock = props.defaultBlock;\n    this.parseHtml = props.parseHtml;\n    this.rules = props.rules;\n  }\n\n  serializeEls = node => {\n    if (Text.isText(node)) {\n      let string = escapeHtml(node.text);\n      if (node.bold) {\n        string = <strong>{string}</strong>;\n      }\n      return string;\n    }\n\n    let children = (node.children || []).map(n => this.serializeEls(n));\n\n    const correctRule = this.rules.reduce((res, rule) => {\n      return res || rule.serialize(node, children);\n    }, null);\n\n    if (correctRule) {\n      return correctRule;\n    }\n\n    switch (node.type) {\n      case 'quote':\n        return (\n          <blockquote>\n            <p>{children}</p>\n          </blockquote>\n        );\n      case 'paragraph':\n        return <p>{children}</p>;\n      case 'link':\n        return <a href={escapeHtml(node.url)}>{children}</a>;\n      default:\n        return children;\n    }\n  };\n\n  serialize = node => {\n    const deserialized = this.serializeEls(node);\n    const html = ReactServer.renderToStaticMarkup(React.createElement(\n      'body',\n      null,\n      deserialized\n    ));\n    const inner = html.slice(6, -7);\n    return inner;\n  };\n\n  deserialize = html => {\n    let body = this.parseHtml(html);\n\n    if (!body.firstChild || body.firstChild.nodeType === Node.TEXT_NODE) {\n      body = this.parseHtml(`<p>${html}</p>`);\n    }\n\n    return this.deserializeEls(body);\n  };\n\n  deserializeEls = (element, markAttributes = {}) => {\n    if (element.nodeType === Node.TEXT_NODE) {\n      return jsx('text', markAttributes, element.textContent);\n    } else if (element.nodeType !== Node.ELEMENT_NODE) {\n      return null;\n    }\n\n    const nodeAttributes = { ...markAttributes };\n\n    // define attributes for text nodes\n    if (element.nodeName === 'STRONG') {\n      nodeAttributes.bold = true;\n    }\n\n    const nextFn = nodes => {\n      const childNodes = Array.from(nodes);\n      const children = Array.from(childNodes)\n        .map(node => this.deserializeEls(node, nodeAttributes))\n        .flat();\n\n      if (children.length === 0) {\n        children.push(jsx('text', nodeAttributes, ''));\n      }\n\n      return children;\n    };\n\n    const correctRule = this.rules.reduce((res, rule) => {\n      return res || rule.deserialize(element, nextFn);\n    }, null);\n\n    if (correctRule) {\n      return correctRule;\n    }\n\n    const childNodes = Array.from(element.childNodes);\n    const children = Array.from(childNodes)\n      .map(node => this.deserializeEls(node, nodeAttributes))\n      .flat();\n\n    if (children.length === 0) {\n      children.push(jsx('text', nodeAttributes, ''));\n    }\n\n    switch (element.nodeName) {\n      case 'TABLE':\n        return jsx('element', { type: 'table' }, children);\n      case 'TBODY':\n        return jsx('element', { type: 'tbody' }, children);\n      case 'TR':\n        return jsx('element', { type: 'tr' }, children);\n      case 'TD':\n        return jsx('element', { type: 'td' }, children);\n      case 'BODY':\n        return jsx('fragment', {}, children);\n      case 'BR':\n        return '\\n';\n      case 'BLOCKQUOTE':\n        return jsx('element', { type: 'quote' }, children);\n      case 'P':\n        return jsx('element', { type: 'paragraph' }, children);\n      case 'A':\n        return jsx('element', { type: 'link', url: element.getAttribute('href') }, children);\n      default:\n        return children;\n    }\n  };\n}\n\nexport default Html;\n"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"test-serializer.js","names":["Html","props","node","Text","isText","string","escapeHtml","text","bold","children","map","n","serializeEls","correctRule","rules","reduce","res","rule","serialize","type","url","deserialized","html","ReactServer","renderToStaticMarkup","React","createElement","inner","slice","body","parseHtml","deserializeEls","element","markAttributes","nodeType","Node","TEXT_NODE","jsx","textContent","ELEMENT_NODE","nodeAttributes","nodeName","nextFn","nodes","childNodes","Array","from","flat","length","push","deserialize","getAttribute","defaultBlock"],"sources":["../src/test-serializer.js"],"sourcesContent":["import React from 'react';\nimport ReactServer from 'react-dom/server';\nimport escapeHtml from 'escape-html';\nimport { Text } from 'slate';\nimport { jsx } from 'slate-hyperscript';\n\nclass Html {\n constructor(props) {\n this.defaultBlock = props.defaultBlock;\n this.parseHtml = props.parseHtml;\n this.rules = props.rules;\n }\n\n serializeEls = node => {\n if (Text.isText(node)) {\n let string = escapeHtml(node.text);\n if (node.bold) {\n string = <strong>{string}</strong>;\n }\n return string;\n }\n\n let children = node.children.map(n => this.serializeEls(n));\n\n const correctRule = this.rules.reduce((res, rule) => {\n return res || rule.serialize(node, children);\n }, null);\n\n if (correctRule) {\n return correctRule;\n }\n\n switch (node.type) {\n case 'quote':\n return (\n <blockquote>\n <p>{children}</p>\n </blockquote>\n );\n case 'paragraph':\n return <p>{children}</p>;\n case 'link':\n return <a href={escapeHtml(node.url)}>{children}</a>;\n default:\n return children;\n }\n };\n\n serialize = node => {\n const deserialized = this.serializeEls(node);\n const html = ReactServer.renderToStaticMarkup(React.createElement(\n 'body',\n null,\n deserialized\n ));\n const inner = html.slice(6, -7);\n return inner;\n };\n\n deserialize = html => {\n const body = this.parseHtml(html);\n return this.deserializeEls(body);\n };\n\n deserializeEls = (element, markAttributes = {}) => {\n if (element.nodeType === Node.TEXT_NODE) {\n return jsx('text', markAttributes, element.textContent);\n } else if (element.nodeType !== Node.ELEMENT_NODE) {\n return null;\n }\n\n const nodeAttributes = { ...markAttributes };\n\n // define attributes for text nodes\n if (element.nodeName === 'STRONG') {\n nodeAttributes.bold = true;\n }\n\n const nextFn = nodes => {\n const childNodes = Array.from(nodes);\n const children = Array.from(childNodes)\n .map(node => this.deserializeEls(node, nodeAttributes))\n .flat();\n\n if (children.length === 0) {\n children.push(jsx('text', nodeAttributes, ''));\n }\n\n return children;\n };\n\n const correctRule = this.rules.reduce((res, rule) => {\n return res || rule.deserialize(element, nextFn);\n }, null);\n\n if (correctRule) {\n return correctRule;\n }\n\n const childNodes = Array.from(element.childNodes);\n const children = Array.from(childNodes)\n .map(node => this.deserializeEls(node, nodeAttributes))\n .flat();\n\n if (children.length === 0) {\n children.push(jsx('text', nodeAttributes, ''));\n }\n\n switch (element.nodeName) {\n case 'TABLE':\n return jsx('element', { type: 'table' }, children);\n case 'TBODY':\n return jsx('element', { type: 'tbody' }, children);\n case 'TR':\n return jsx('element', { type: 'tr' }, children);\n case 'TD':\n return jsx('element', { type: 'td' }, children);\n case 'BODY':\n return jsx('fragment', {}, children);\n case 'BR':\n return '\\n';\n case 'BLOCKQUOTE':\n return jsx('element', { type: 'quote' }, children);\n case 'P':\n return jsx('element', { type: 'paragraph' }, children);\n case 'A':\n return jsx('element', { type: 'link', url: element.getAttribute('href') }, children);\n default:\n return children;\n }\n };\n}\n\nexport default Html;\n"],"mappings":"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"}
|
package/lib/theme.js
CHANGED
|
@@ -6,4 +6,4 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
exports.primary = void 0;
|
|
7
7
|
var primary = '#304ffe';
|
|
8
8
|
exports.primary = primary;
|
|
9
|
-
//# sourceMappingURL=
|
|
9
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJwcmltYXJ5Il0sInNvdXJjZXMiOlsiLi4vc3JjL3RoZW1lLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBwcmltYXJ5ID0gJyMzMDRmZmUnO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBTyxJQUFNQSxPQUFPLEdBQUcsU0FBaEIifQ==
|
package/lib/theme.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"theme.js","names":["primary"],"sources":["../src/theme.js"],"sourcesContent":["export const primary = '#304ffe';\n"],"mappings":";;;;;;AAAO,IAAMA,OAAO,GAAG,SAAhB"}
|
package/package.json
CHANGED
|
@@ -1,39 +1,43 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@pie-lib/editable-html",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "10.0.0-beta.1",
|
|
4
4
|
"description": "",
|
|
5
5
|
"license": "ISC",
|
|
6
6
|
"main": "lib/index.js",
|
|
7
7
|
"module": "src/index.jsx",
|
|
8
8
|
"author": "pie-framework developers",
|
|
9
9
|
"dependencies": {
|
|
10
|
+
"@emotion/css": "^11.10.0",
|
|
10
11
|
"@material-ui/core": "^3.8.3",
|
|
11
12
|
"@material-ui/icons": "^3.0.2",
|
|
12
13
|
"@material-ui/styles": "^3.0.0-alpha.10",
|
|
13
|
-
"@pie-lib/drag": "^
|
|
14
|
-
"@pie-lib/math-rendering": "^2.5.
|
|
15
|
-
"@pie-lib/math-toolbar": "^1.11.
|
|
16
|
-
"@pie-lib/render-ui": "^4.
|
|
14
|
+
"@pie-lib/drag": "^1.1.52",
|
|
15
|
+
"@pie-lib/math-rendering": "^2.5.0",
|
|
16
|
+
"@pie-lib/math-toolbar": "^1.11.0",
|
|
17
|
+
"@pie-lib/render-ui": "^4.13.4",
|
|
17
18
|
"change-case": "^3.0.2",
|
|
18
19
|
"classnames": "^2.2.6",
|
|
19
20
|
"debug": "^4.1.1",
|
|
20
21
|
"immutable": "^4.0.0-rc.12",
|
|
22
|
+
"is-hotkey": "^0.2.0",
|
|
21
23
|
"keycode": "^2.2.0",
|
|
22
24
|
"lodash": "^4.17.11",
|
|
23
25
|
"prop-types": "^15.6.2",
|
|
24
26
|
"react-attr-converter": "^0.3.1",
|
|
25
27
|
"react-jss": "^8.6.1",
|
|
26
28
|
"react-portal": "^4.2.0",
|
|
27
|
-
"slate": "^0.
|
|
28
|
-
"slate-dev-environment": "^0.2.
|
|
29
|
-
"slate-edit-list": "^0.
|
|
30
|
-
"slate-edit-table": "^0.
|
|
31
|
-
"slate-
|
|
32
|
-
"slate-
|
|
33
|
-
"slate-
|
|
34
|
-
"slate-
|
|
29
|
+
"slate": "^0.82.1",
|
|
30
|
+
"slate-dev-environment": "^0.2.5",
|
|
31
|
+
"slate-edit-list": "^0.12.1",
|
|
32
|
+
"slate-edit-table": "^0.18.0",
|
|
33
|
+
"slate-history": "^0.66.0",
|
|
34
|
+
"slate-html-serializer": "^0.8.13",
|
|
35
|
+
"slate-hyperscript": "^0.77.0",
|
|
36
|
+
"slate-plain-serializer": "^0.7.13",
|
|
37
|
+
"slate-prop-types": "^0.5.44",
|
|
38
|
+
"slate-react": "^0.83.0",
|
|
35
39
|
"slate-schema-violations": "^0.1.39",
|
|
36
|
-
"slate-soft-break": "^0.
|
|
40
|
+
"slate-soft-break": "^0.9.0",
|
|
37
41
|
"to-style": "^1.3.3"
|
|
38
42
|
},
|
|
39
43
|
"devDependencies": {
|