@pie-lib/editable-html 9.5.13 → 10.0.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (144) hide show
  1. package/CHANGELOG.md +0 -302
  2. package/lib/components.js +116 -0
  3. package/lib/components.js.map +1 -0
  4. package/lib/editor.js +418 -103
  5. package/lib/editor.js.map +1 -1
  6. package/lib/index.js +101 -155
  7. package/lib/index.js.map +1 -1
  8. package/lib/new-serialization.js +320 -0
  9. package/lib/new-serialization.js.map +1 -0
  10. package/lib/old-serialization.js +330 -0
  11. package/lib/parse-html.js +1 -1
  12. package/lib/parse-html.js.map +1 -1
  13. package/lib/plugins/characters/custom-popper.js +1 -1
  14. package/lib/plugins/characters/custom-popper.js.map +1 -1
  15. package/lib/plugins/characters/index.js +21 -19
  16. package/lib/plugins/characters/index.js.map +1 -1
  17. package/lib/plugins/characters/utils.js +1 -1
  18. package/lib/plugins/characters/utils.js.map +1 -1
  19. package/lib/plugins/hotKeys/index.js +67 -0
  20. package/lib/plugins/hotKeys/index.js.map +1 -0
  21. package/lib/plugins/image/alt-dialog.js +1 -6
  22. package/lib/plugins/image/alt-dialog.js.map +1 -1
  23. package/lib/plugins/image/component.js +70 -53
  24. package/lib/plugins/image/component.js.map +1 -1
  25. package/lib/plugins/image/image-toolbar.js +7 -9
  26. package/lib/plugins/image/image-toolbar.js.map +1 -1
  27. package/lib/plugins/image/index.js +83 -27
  28. package/lib/plugins/image/index.js.map +1 -1
  29. package/lib/plugins/image/insert-image-handler.js +72 -33
  30. package/lib/plugins/image/insert-image-handler.js.map +1 -1
  31. package/lib/plugins/index.js +23 -41
  32. package/lib/plugins/index.js.map +1 -1
  33. package/lib/plugins/list/index.js +64 -100
  34. package/lib/plugins/list/index.js.map +1 -1
  35. package/lib/plugins/math/index.js +86 -60
  36. package/lib/plugins/math/index.js.map +1 -1
  37. package/lib/plugins/media/index.js +202 -132
  38. package/lib/plugins/media/index.js.map +1 -1
  39. package/lib/plugins/media/media-dialog.js +17 -16
  40. package/lib/plugins/media/media-dialog.js.map +1 -1
  41. package/lib/plugins/media/media-toolbar.js +3 -3
  42. package/lib/plugins/media/media-toolbar.js.map +1 -1
  43. package/lib/plugins/media/media-wrapper.js +21 -58
  44. package/lib/plugins/media/media-wrapper.js.map +1 -1
  45. package/lib/plugins/respArea/drag-in-the-blank/choice.js +3 -3
  46. package/lib/plugins/respArea/drag-in-the-blank/choice.js.map +1 -1
  47. package/lib/plugins/respArea/drag-in-the-blank/index.js +3 -2
  48. package/lib/plugins/respArea/drag-in-the-blank/index.js.map +1 -1
  49. package/lib/plugins/respArea/explicit-constructed-response/index.js +3 -2
  50. package/lib/plugins/respArea/explicit-constructed-response/index.js.map +1 -1
  51. package/lib/plugins/respArea/icons/index.js +13 -15
  52. package/lib/plugins/respArea/icons/index.js.map +1 -1
  53. package/lib/plugins/respArea/index.js +87 -53
  54. package/lib/plugins/respArea/index.js.map +1 -1
  55. package/lib/plugins/respArea/inline-dropdown/index.js +4 -3
  56. package/lib/plugins/respArea/inline-dropdown/index.js.map +1 -1
  57. package/lib/plugins/respArea/utils.js +17 -20
  58. package/lib/plugins/respArea/utils.js.map +1 -1
  59. package/lib/plugins/table/icons/index.js +1 -1
  60. package/lib/plugins/table/icons/index.js.map +1 -1
  61. package/lib/plugins/table/index.js +381 -212
  62. package/lib/plugins/table/index.js.map +1 -1
  63. package/lib/plugins/table/table-toolbar.js +5 -6
  64. package/lib/plugins/table/table-toolbar.js.map +1 -1
  65. package/lib/plugins/toolbar/default-toolbar.js +55 -11
  66. package/lib/plugins/toolbar/default-toolbar.js.map +1 -1
  67. package/lib/plugins/toolbar/done-button.js +1 -1
  68. package/lib/plugins/toolbar/done-button.js.map +1 -1
  69. package/lib/plugins/toolbar/editor-and-toolbar.js +186 -232
  70. package/lib/plugins/toolbar/editor-and-toolbar.js.map +1 -1
  71. package/lib/plugins/toolbar/index.js +1 -2
  72. package/lib/plugins/toolbar/index.js.map +1 -1
  73. package/lib/plugins/toolbar/toolbar-buttons.js +1 -1
  74. package/lib/plugins/toolbar/toolbar-buttons.js.map +1 -1
  75. package/lib/plugins/toolbar/toolbar.js +253 -239
  76. package/lib/plugins/toolbar/toolbar.js.map +1 -1
  77. package/lib/plugins/utils.js +27 -2
  78. package/lib/plugins/utils.js.map +1 -1
  79. package/lib/serialization.js +1 -1
  80. package/lib/serialization.js.map +1 -1
  81. package/lib/slate-editor.js +302 -0
  82. package/lib/test-serializer.js +189 -0
  83. package/lib/test-serializer.js.map +1 -0
  84. package/lib/theme.js +1 -1
  85. package/lib/theme.js.map +1 -1
  86. package/package.json +18 -14
  87. package/playground/image/data.js +20 -20
  88. package/playground/image/index.html +22 -20
  89. package/playground/image/index.jsx +12 -10
  90. package/playground/index.html +25 -23
  91. package/playground/mathquill/index.html +23 -20
  92. package/playground/mathquill/index.jsx +18 -22
  93. package/playground/prod-test/index.html +24 -20
  94. package/playground/prod-test/index.jsx +5 -3
  95. package/playground/schema-override/data.js +10 -10
  96. package/playground/schema-override/image-plugin.jsx +3 -4
  97. package/playground/schema-override/index.html +21 -19
  98. package/playground/schema-override/index.jsx +13 -14
  99. package/playground/serialization/data.js +10 -10
  100. package/playground/serialization/image-plugin.jsx +3 -4
  101. package/playground/serialization/index.html +22 -20
  102. package/playground/table-examples.html +5 -8
  103. package/playground/webpack.config.js +10 -10
  104. package/src/components.js +135 -0
  105. package/src/editor.jsx +478 -141
  106. package/src/index.jsx +71 -95
  107. package/src/new-serialization.jsx +291 -0
  108. package/src/parse-html.js +1 -1
  109. package/src/plugins/characters/custom-popper.js +7 -7
  110. package/src/plugins/characters/index.jsx +33 -34
  111. package/src/plugins/characters/utils.js +81 -81
  112. package/src/plugins/hotKeys/index.js +54 -0
  113. package/src/plugins/image/alt-dialog.jsx +4 -5
  114. package/src/plugins/image/component.jsx +106 -89
  115. package/src/plugins/image/image-toolbar.jsx +27 -19
  116. package/src/plugins/image/index.jsx +75 -43
  117. package/src/plugins/image/insert-image-handler.js +62 -27
  118. package/src/plugins/index.jsx +23 -41
  119. package/src/plugins/list/index.jsx +70 -95
  120. package/src/plugins/math/index.jsx +102 -82
  121. package/src/plugins/media/index.jsx +159 -124
  122. package/src/plugins/media/media-dialog.js +98 -71
  123. package/src/plugins/media/media-toolbar.jsx +8 -8
  124. package/src/plugins/media/media-wrapper.jsx +29 -30
  125. package/src/plugins/respArea/drag-in-the-blank/choice.jsx +21 -19
  126. package/src/plugins/respArea/drag-in-the-blank/index.jsx +14 -11
  127. package/src/plugins/respArea/explicit-constructed-response/index.jsx +7 -6
  128. package/src/plugins/respArea/icons/index.jsx +11 -14
  129. package/src/plugins/respArea/index.jsx +92 -52
  130. package/src/plugins/respArea/inline-dropdown/index.jsx +9 -8
  131. package/src/plugins/respArea/utils.jsx +26 -35
  132. package/src/plugins/table/icons/index.jsx +17 -11
  133. package/src/plugins/table/index.jsx +288 -231
  134. package/src/plugins/table/table-toolbar.jsx +15 -11
  135. package/src/plugins/toolbar/default-toolbar.jsx +65 -19
  136. package/src/plugins/toolbar/done-button.jsx +4 -4
  137. package/src/plugins/toolbar/editor-and-toolbar.jsx +150 -145
  138. package/src/plugins/toolbar/index.jsx +2 -3
  139. package/src/plugins/toolbar/toolbar-buttons.jsx +11 -11
  140. package/src/plugins/toolbar/toolbar.jsx +244 -221
  141. package/src/plugins/utils.js +21 -4
  142. package/src/serialization.jsx +32 -32
  143. package/src/test-serializer.js +139 -0
  144. package/src/test-serializer.js.rej +20 -0
@@ -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=theme.js.map
9
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJwcmltYXJ5Il0sInNvdXJjZXMiOlsiLi4vc3JjL3RoZW1lLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBwcmltYXJ5ID0gJyMzMDRmZmUnO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBTyxJQUFNQSxPQUFPLEdBQUcsU0FBaEIifQ==
package/lib/theme.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/theme.js"],"names":["primary"],"mappings":";;;;;;AAAO,IAAMA,OAAO,GAAG,SAAhB","sourcesContent":["export const primary = '#304ffe';\n"],"file":"theme.js"}
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": "9.5.13",
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": "^2.1.12",
14
- "@pie-lib/math-rendering": "^2.5.12",
15
- "@pie-lib/math-toolbar": "^1.11.22",
16
- "@pie-lib/render-ui": "^4.14.12",
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.36.2",
28
- "slate-dev-environment": "^0.2.0",
29
- "slate-edit-list": "^0.11.3",
30
- "slate-edit-table": "^0.17.0",
31
- "slate-html-serializer": "^0.6.12",
32
- "slate-plain-serializer": "^0.5.26",
33
- "slate-prop-types": "^0.4.38",
34
- "slate-react": "^0.14.3",
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.8.1",
40
+ "slate-soft-break": "^0.9.0",
37
41
  "to-style": "^1.3.3"
38
42
  },
39
43
  "devDependencies": {