@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
|
@@ -7,18 +7,18 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
7
7
|
});
|
|
8
8
|
exports.serialization = exports["default"] = void 0;
|
|
9
9
|
|
|
10
|
-
var
|
|
11
|
-
|
|
12
|
-
var _slate = require("slate");
|
|
10
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
13
11
|
|
|
14
|
-
var
|
|
12
|
+
var _react = _interopRequireDefault(require("react"));
|
|
15
13
|
|
|
16
14
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
17
15
|
|
|
18
|
-
var _slateEditList = _interopRequireDefault(require("slate-edit-list"));
|
|
19
|
-
|
|
20
16
|
var _debug = _interopRequireDefault(require("debug"));
|
|
21
17
|
|
|
18
|
+
var _slate = require("slate");
|
|
19
|
+
|
|
20
|
+
var _slateHyperscript = require("slate-hyperscript");
|
|
21
|
+
|
|
22
22
|
var log = (0, _debug["default"])('@pie-lib:editable-html:plugins:list');
|
|
23
23
|
|
|
24
24
|
var b = function b(type, next, childNodes) {
|
|
@@ -32,22 +32,27 @@ var b = function b(type, next, childNodes) {
|
|
|
32
32
|
var serialization = {
|
|
33
33
|
deserialize: function deserialize(el, next) {
|
|
34
34
|
var name = el.tagName.toLowerCase();
|
|
35
|
+
var children = el.children.length ? Array.from(el.children) : el.childNodes;
|
|
35
36
|
|
|
36
37
|
if (name === 'li') {
|
|
37
|
-
return
|
|
38
|
+
return (0, _slateHyperscript.jsx)('element', {
|
|
39
|
+
type: 'li'
|
|
40
|
+
}, next(children));
|
|
38
41
|
}
|
|
39
42
|
|
|
40
43
|
if (name === 'ul') {
|
|
41
|
-
return
|
|
44
|
+
return (0, _slateHyperscript.jsx)('element', {
|
|
45
|
+
type: 'ul'
|
|
46
|
+
}, next(children));
|
|
42
47
|
}
|
|
43
48
|
|
|
44
49
|
if (name === 'ol') {
|
|
45
|
-
return
|
|
50
|
+
return (0, _slateHyperscript.jsx)('element', {
|
|
51
|
+
type: 'ol'
|
|
52
|
+
}, next(children));
|
|
46
53
|
}
|
|
47
54
|
},
|
|
48
55
|
serialize: function serialize(object, children) {
|
|
49
|
-
if (object.object !== 'block') return;
|
|
50
|
-
|
|
51
56
|
if (object.type === 'list_item') {
|
|
52
57
|
return /*#__PURE__*/_react["default"].createElement("li", null, children);
|
|
53
58
|
}
|
|
@@ -63,91 +68,67 @@ var serialization = {
|
|
|
63
68
|
};
|
|
64
69
|
exports.serialization = serialization;
|
|
65
70
|
|
|
66
|
-
var
|
|
67
|
-
var
|
|
68
|
-
|
|
69
|
-
}); // fix outdated schema
|
|
71
|
+
var isBlockActive = function isBlockActive(editor, format) {
|
|
72
|
+
var selection = editor.selection;
|
|
73
|
+
if (!selection) return false;
|
|
70
74
|
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
75
|
+
var _Array$from = Array.from(_slate.Editor.nodes(editor, {
|
|
76
|
+
at: _slate.Editor.unhangRange(editor, selection),
|
|
77
|
+
match: function match(node) {
|
|
78
|
+
return !_slate.Editor.isEditor(node) && _slate.Element.isElement(node) && node.type === format;
|
|
79
|
+
}
|
|
80
|
+
})),
|
|
81
|
+
_Array$from2 = (0, _slicedToArray2["default"])(_Array$from, 1),
|
|
82
|
+
match = _Array$from2[0];
|
|
74
83
|
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
}
|
|
84
|
+
return !!match;
|
|
85
|
+
};
|
|
78
86
|
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
87
|
+
var createEditList = function createEditList() {
|
|
88
|
+
var core = {
|
|
89
|
+
changes: {}
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
core.changes.wrapInList = function (editor, format) {
|
|
93
|
+
var isActive = isBlockActive(editor, format);
|
|
94
|
+
var isList = LIST_TYPES.includes(format);
|
|
95
|
+
|
|
96
|
+
_slate.Transforms.unwrapNodes(editor, {
|
|
97
|
+
match: function match(n) {
|
|
98
|
+
return !_slate.Editor.isEditor(n) && _slate.Element.isElement(n) && LIST_TYPES.includes(n.type);
|
|
99
|
+
},
|
|
100
|
+
split: true
|
|
82
101
|
});
|
|
83
|
-
}
|
|
84
|
-
/**
|
|
85
|
-
* This override of the core.changes.wrapInList is needed because the version
|
|
86
|
-
* of immutable that we have does not support getting the element at a specific
|
|
87
|
-
* index with a square bracket (list[0]). We have to use the list.get function instead
|
|
88
|
-
*/
|
|
89
102
|
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
103
|
+
var newProperties = {
|
|
104
|
+
type: isActive ? 'paragraph' : isList ? 'list_item' : format
|
|
105
|
+
};
|
|
93
106
|
|
|
107
|
+
_slate.Transforms.setNodes(editor, newProperties);
|
|
94
108
|
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
109
|
+
if (!isActive && isList) {
|
|
110
|
+
var block = {
|
|
111
|
+
type: format,
|
|
112
|
+
children: []
|
|
113
|
+
};
|
|
100
114
|
|
|
101
|
-
|
|
102
|
-
return _immutable["default"].List([startBlock]);
|
|
115
|
+
_slate.Transforms.wrapNodes(editor, block);
|
|
103
116
|
}
|
|
104
|
-
|
|
105
|
-
var ancestor = document.getCommonAncestor(startBlock.key, endBlock.key);
|
|
106
|
-
var startPath = ancestor.getPath(startBlock.key);
|
|
107
|
-
var endPath = ancestor.getPath(endBlock.key);
|
|
108
|
-
return ancestor.nodes.slice(startPath.get(0), endPath.get(0) + 1);
|
|
109
|
-
};
|
|
110
|
-
/**
|
|
111
|
-
* Wrap the blocks in the current selection in a new list. Selected
|
|
112
|
-
* lists are merged together.
|
|
113
|
-
*/
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
core.changes.wrapInList = function (change, type, data) {
|
|
117
|
-
var selectedBlocks = getHighestSelectedBlocks(change.value); // Wrap in container
|
|
118
|
-
|
|
119
|
-
change.wrapBlock({
|
|
120
|
-
type: type,
|
|
121
|
-
data: _slate.Data.create(data)
|
|
122
|
-
}, {
|
|
123
|
-
normalize: false
|
|
124
|
-
}); // Wrap in list items
|
|
125
|
-
|
|
126
|
-
selectedBlocks.forEach(function (node) {
|
|
127
|
-
if (core.utils.isList(node)) {
|
|
128
|
-
// Merge its items with the created list
|
|
129
|
-
node.nodes.forEach(function (_ref) {
|
|
130
|
-
var key = _ref.key;
|
|
131
|
-
return change.unwrapNodeByKey(key, {
|
|
132
|
-
normalize: false
|
|
133
|
-
});
|
|
134
|
-
});
|
|
135
|
-
} else if (node.type !== 'list_item') {
|
|
136
|
-
change.wrapBlockByKey(node.key, 'list_item', {
|
|
137
|
-
normalize: false
|
|
138
|
-
});
|
|
139
|
-
}
|
|
140
|
-
});
|
|
141
|
-
return change.normalize();
|
|
142
117
|
};
|
|
143
118
|
|
|
144
119
|
return core;
|
|
145
120
|
};
|
|
146
121
|
|
|
122
|
+
var LIST_TYPES = ['ol_list', 'ul_list', 'list_item'];
|
|
123
|
+
|
|
147
124
|
var _default = function _default(options) {
|
|
148
125
|
var type = options.type,
|
|
149
126
|
icon = options.icon;
|
|
150
|
-
var core = createEditList();
|
|
127
|
+
var core = createEditList();
|
|
128
|
+
|
|
129
|
+
core.supports = function (node) {
|
|
130
|
+
return LIST_TYPES.includes(node.type);
|
|
131
|
+
};
|
|
151
132
|
|
|
152
133
|
core.renderNode = function (props) {
|
|
153
134
|
var node = props.node,
|
|
@@ -170,26 +151,9 @@ var _default = function _default(options) {
|
|
|
170
151
|
isMark: false,
|
|
171
152
|
type: type,
|
|
172
153
|
icon: icon,
|
|
173
|
-
isActive:
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
var current = core.utils.getCurrentList(value);
|
|
179
|
-
return current ? current.type === type : false;
|
|
180
|
-
},
|
|
181
|
-
onClick: function onClick(value, onChange) {
|
|
182
|
-
log('[onClick]', value);
|
|
183
|
-
var inList = core.utils.isSelectionInList(value);
|
|
184
|
-
|
|
185
|
-
if (inList) {
|
|
186
|
-
var change = value.change().call(core.changes.unwrapList);
|
|
187
|
-
onChange(change);
|
|
188
|
-
} else {
|
|
189
|
-
var _change = value.change().call(core.changes.wrapInList, type);
|
|
190
|
-
|
|
191
|
-
onChange(_change);
|
|
192
|
-
}
|
|
154
|
+
isActive: isBlockActive,
|
|
155
|
+
onClick: function onClick(editor) {
|
|
156
|
+
core.changes.wrapInList(editor, type);
|
|
193
157
|
}
|
|
194
158
|
};
|
|
195
159
|
core.renderNode.propTypes = {
|
|
@@ -201,4 +165,4 @@ var _default = function _default(options) {
|
|
|
201
165
|
};
|
|
202
166
|
|
|
203
167
|
exports["default"] = _default;
|
|
204
|
-
//# sourceMappingURL=index.js.map
|
|
168
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["log","debug","b","type","next","childNodes","object","nodes","serialization","deserialize","el","name","tagName","toLowerCase","children","length","Array","from","jsx","serialize","isBlockActive","editor","format","selection","Editor","at","unhangRange","match","node","isEditor","SlateElement","isElement","createEditList","core","changes","wrapInList","isActive","isList","LIST_TYPES","includes","Transforms","unwrapNodes","n","split","newProperties","setNodes","block","wrapNodes","options","icon","supports","renderNode","props","attributes","toolbar","isMark","onClick","propTypes","PropTypes","func"],"sources":["../../../src/plugins/list/index.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport debug from 'debug';\nimport { Editor, Element as SlateElement, Transforms } from 'slate';\nimport { jsx } from \"slate-hyperscript\";\n\nconst log = debug('@pie-lib:editable-html:plugins:list');\n\nconst b = (type, next, childNodes) => ({\n  object: 'block',\n  type,\n  nodes: next(childNodes)\n});\n\nexport const serialization = {\n  deserialize(el, next) {\n    const name = el.tagName.toLowerCase();\n    const children = el.children.length ? Array.from(el.children) : el.childNodes;\n\n    if (name === 'li') {\n      return jsx(\n        'element',\n        {\n          type: 'li'\n        },\n        next(children)\n      );\n    }\n\n    if (name === 'ul') {\n      return jsx(\n        'element',\n        {\n          type: 'ul'\n        },\n        next(children)\n      );\n    }\n\n    if (name === 'ol') {\n      return jsx(\n        'element',\n        {\n          type: 'ol'\n        },\n        next(children)\n      );\n    }\n  },\n  serialize(object, children) {\n    if (object.type === 'list_item') {\n      return <li>{children}</li>;\n    }\n\n    if (object.type === 'ul_list') {\n      return <ul>{children}</ul>;\n    }\n\n    if (object.type === 'ol_list') {\n      return <ol>{children}</ol>;\n    }\n  }\n};\n\nconst isBlockActive = (editor, format) => {\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: node => !Editor.isEditor(node) && SlateElement.isElement(node) && node.type === format\n    })\n  );\n\n  return !!match;\n};\n\nconst createEditList = () => {\n  const core = {\n    changes: {}\n  };\n\n  core.changes.wrapInList = (editor, format) => {\n    const isActive = isBlockActive(editor, format);\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      split: true\n    });\n\n    const 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\n  return core;\n};\n\nconst LIST_TYPES = ['ol_list', 'ul_list', 'list_item'];\n\nexport default options => {\n  const { type, icon } = options;\n\n  const core = createEditList();\n\n  core.supports = node => LIST_TYPES.includes(node.type);\n\n  core.renderNode = props => {\n    const { node, attributes, children } = props;\n\n    switch (node.type) {\n      case 'ul_list':\n        return <ul {...attributes}>{children}</ul>;\n      case 'ol_list':\n        return <ol {...attributes}>{children}</ol>;\n      case 'list_item':\n        return <li {...attributes}>{children}</li>;\n    }\n  };\n\n  core.toolbar = {\n    isMark: false,\n    type,\n    icon,\n    isActive: isBlockActive,\n    onClick: editor => {\n      core.changes.wrapInList(editor, type);\n    }\n  };\n\n  core.renderNode.propTypes = {\n    node: PropTypes.object,\n    attributes: PropTypes.object,\n    children: PropTypes.func\n  };\n\n  return core;\n};\n"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/plugins/list/index.jsx"],"names":["log","b","type","next","childNodes","object","nodes","serialization","deserialize","el","name","tagName","toLowerCase","children","length","Array","from","serialize","createEditList","core","typeDefault","schema","blocks","Object","keys","forEach","key","block","parent","types","getHighestSelectedBlocks","value","range","selection","document","startBlock","getClosestBlock","startKey","endBlock","endKey","Immutable","List","ancestor","getCommonAncestor","startPath","getPath","endPath","slice","get","changes","wrapInList","change","data","selectedBlocks","wrapBlock","Data","create","normalize","node","utils","isList","_ref","unwrapNodeByKey","wrapBlockByKey","options","icon","renderNode","props","attributes","toolbar","isMark","isActive","isSelectionInList","current","getCurrentList","onClick","onChange","inList","call","unwrapList","propTypes","PropTypes","func"],"mappings":"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","sourcesContent":["import React from 'react';\nimport { Data } from 'slate';\nimport Immutable from 'immutable';\nimport PropTypes from 'prop-types';\nimport EditList from 'slate-edit-list';\nimport debug from 'debug';\n\nconst log = debug('@pie-lib:editable-html:plugins:list');\n\nconst b = (type, next, childNodes) => ({\n object: 'block',\n type,\n nodes: next(childNodes),\n});\n\nexport const serialization = {\n deserialize(el, next) {\n const name = el.tagName.toLowerCase();\n\n if (name === 'li') {\n return b('list_item', next, el.childNodes);\n }\n\n if (name === 'ul') {\n return b('ul_list', next, el.children.length ? Array.from(el.children) : el.childNodes);\n }\n\n if (name === 'ol') {\n return b('ol_list', next, el.children.length ? Array.from(el.children) : el.childNodes);\n }\n },\n serialize(object, children) {\n if (object.object !== 'block') return;\n\n if (object.type === 'list_item') {\n return <li>{children}</li>;\n }\n\n if (object.type === 'ul_list') {\n return <ul>{children}</ul>;\n }\n\n if (object.type === 'ol_list') {\n return <ol>{children}</ol>;\n }\n },\n};\n\nconst createEditList = () => {\n const core = EditList({\n typeDefault: 'span',\n });\n\n // fix outdated schema\n if (core.schema && core.schema.blocks) {\n Object.keys(core.schema.blocks).forEach((key) => {\n const block = core.schema.blocks[key];\n\n if (block.parent) {\n return;\n }\n\n block.nodes[0] = { type: block.nodes[0].types[0] };\n });\n }\n\n /**\n * This override of the core.changes.wrapInList is needed because the version\n * of immutable that we have does not support getting the element at a specific\n * index with a square bracket (list[0]). We have to use the list.get function instead\n */\n\n /**\n * Returns the highest list of blocks that cover the current selection\n */\n const getHighestSelectedBlocks = (value) => {\n const range = value.selection;\n const document = value.document;\n\n const startBlock = document.getClosestBlock(range.startKey);\n const endBlock = document.getClosestBlock(range.endKey);\n\n if (startBlock === endBlock) {\n return Immutable.List([startBlock]);\n }\n\n const ancestor = document.getCommonAncestor(startBlock.key, endBlock.key);\n const startPath = ancestor.getPath(startBlock.key);\n const endPath = ancestor.getPath(endBlock.key);\n\n return ancestor.nodes.slice(startPath.get(0), endPath.get(0) + 1);\n };\n\n /**\n * Wrap the blocks in the current selection in a new list. Selected\n * lists are merged together.\n */\n core.changes.wrapInList = function(change, type, data) {\n const selectedBlocks = getHighestSelectedBlocks(change.value);\n\n // Wrap in container\n change.wrapBlock({ type: type, data: Data.create(data) }, { normalize: false });\n\n // Wrap in list items\n selectedBlocks.forEach(function(node) {\n if (core.utils.isList(node)) {\n // Merge its items with the created list\n node.nodes.forEach(function(_ref) {\n const key = _ref.key;\n return change.unwrapNodeByKey(key, { normalize: false });\n });\n } else if (node.type !== 'list_item') {\n change.wrapBlockByKey(node.key, 'list_item', {\n normalize: false,\n });\n }\n });\n\n return change.normalize();\n };\n\n return core;\n};\n\nexport default (options) => {\n const { type, icon } = options;\n\n const core = createEditList();\n\n // eslint-disable-next-line react/display-name\n core.renderNode = (props) => {\n const { node, attributes, children } = props;\n\n switch (node.type) {\n case 'ul_list':\n return <ul {...attributes}>{children}</ul>;\n case 'ol_list':\n return <ol {...attributes}>{children}</ol>;\n case 'list_item':\n return <li {...attributes}>{children}</li>;\n }\n };\n\n core.toolbar = {\n isMark: false,\n type,\n icon,\n isActive: (value, type) => {\n if (!core.utils.isSelectionInList(value)) {\n return false;\n }\n const current = core.utils.getCurrentList(value);\n return current ? current.type === type : false;\n },\n onClick: (value, onChange) => {\n log('[onClick]', value);\n const inList = core.utils.isSelectionInList(value);\n if (inList) {\n const change = value.change().call(core.changes.unwrapList);\n onChange(change);\n } else {\n const change = value.change().call(core.changes.wrapInList, type);\n onChange(change);\n }\n },\n };\n\n core.renderNode.propTypes = {\n node: PropTypes.object,\n attributes: PropTypes.object,\n children: PropTypes.func,\n };\n\n return core;\n};\n"],"file":"index.js"}
|
|
1
|
+
{"version":3,"file":"index.js","names":["log","debug","b","type","next","childNodes","object","nodes","serialization","deserialize","el","name","tagName","toLowerCase","children","length","Array","from","jsx","serialize","isBlockActive","editor","format","selection","Editor","at","unhangRange","match","node","isEditor","SlateElement","isElement","createEditList","core","changes","wrapInList","isActive","isList","LIST_TYPES","includes","Transforms","unwrapNodes","n","split","newProperties","setNodes","block","wrapNodes","options","icon","supports","renderNode","props","attributes","toolbar","isMark","onClick","propTypes","PropTypes","func"],"sources":["../../../src/plugins/list/index.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport debug from 'debug';\nimport { Editor, Element as SlateElement, Transforms } from 'slate';\nimport { jsx } from \"slate-hyperscript\";\n\nconst log = debug('@pie-lib:editable-html:plugins:list');\n\nconst b = (type, next, childNodes) => ({\n object: 'block',\n type,\n nodes: next(childNodes)\n});\n\nexport const serialization = {\n deserialize(el, next) {\n const name = el.tagName.toLowerCase();\n const children = el.children.length ? Array.from(el.children) : el.childNodes;\n\n if (name === 'li') {\n return jsx(\n 'element',\n {\n type: 'li'\n },\n next(children)\n );\n }\n\n if (name === 'ul') {\n return jsx(\n 'element',\n {\n type: 'ul'\n },\n next(children)\n );\n }\n\n if (name === 'ol') {\n return jsx(\n 'element',\n {\n type: 'ol'\n },\n next(children)\n );\n }\n },\n serialize(object, children) {\n if (object.type === 'list_item') {\n return <li>{children}</li>;\n }\n\n if (object.type === 'ul_list') {\n return <ul>{children}</ul>;\n }\n\n if (object.type === 'ol_list') {\n return <ol>{children}</ol>;\n }\n }\n};\n\nconst isBlockActive = (editor, format) => {\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: node => !Editor.isEditor(node) && SlateElement.isElement(node) && node.type === format\n })\n );\n\n return !!match;\n};\n\nconst createEditList = () => {\n const core = {\n changes: {}\n };\n\n core.changes.wrapInList = (editor, format) => {\n const isActive = isBlockActive(editor, format);\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 split: true\n });\n\n const 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\n return core;\n};\n\nconst LIST_TYPES = ['ol_list', 'ul_list', 'list_item'];\n\nexport default options => {\n const { type, icon } = options;\n\n const core = createEditList();\n\n core.supports = node => LIST_TYPES.includes(node.type);\n\n core.renderNode = props => {\n const { node, attributes, children } = props;\n\n switch (node.type) {\n case 'ul_list':\n return <ul {...attributes}>{children}</ul>;\n case 'ol_list':\n return <ol {...attributes}>{children}</ol>;\n case 'list_item':\n return <li {...attributes}>{children}</li>;\n }\n };\n\n core.toolbar = {\n isMark: false,\n type,\n icon,\n isActive: isBlockActive,\n onClick: editor => {\n core.changes.wrapInList(editor, type);\n }\n };\n\n core.renderNode.propTypes = {\n node: PropTypes.object,\n attributes: PropTypes.object,\n children: PropTypes.func\n };\n\n return core;\n};\n"],"mappings":"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"}
|
|
@@ -13,23 +13,27 @@ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")
|
|
|
13
13
|
|
|
14
14
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
15
15
|
|
|
16
|
-
var
|
|
16
|
+
var _react = _interopRequireDefault(require("react"));
|
|
17
17
|
|
|
18
18
|
var _slate = require("slate");
|
|
19
19
|
|
|
20
|
+
var _slateReact = require("slate-react");
|
|
21
|
+
|
|
22
|
+
var _slateHyperscript = require("slate-hyperscript");
|
|
23
|
+
|
|
24
|
+
var _Functions = _interopRequireDefault(require("@material-ui/icons/Functions"));
|
|
25
|
+
|
|
20
26
|
var _mathToolbar = require("@pie-lib/math-toolbar");
|
|
21
27
|
|
|
22
28
|
var _mathRendering = require("@pie-lib/math-rendering");
|
|
23
29
|
|
|
24
|
-
var _react = _interopRequireDefault(require("react"));
|
|
25
|
-
|
|
26
30
|
var _debug = _interopRequireDefault(require("debug"));
|
|
27
31
|
|
|
28
|
-
var _slatePropTypes = _interopRequireDefault(require("slate-prop-types"));
|
|
29
|
-
|
|
30
32
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
31
33
|
|
|
32
|
-
var
|
|
34
|
+
var _isEqual = _interopRequireDefault(require("lodash/isEqual"));
|
|
35
|
+
|
|
36
|
+
var _newSerialization = require("../../new-serialization");
|
|
33
37
|
|
|
34
38
|
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; }
|
|
35
39
|
|
|
@@ -52,10 +56,11 @@ function generateAdditionalKeys() {
|
|
|
52
56
|
|
|
53
57
|
var CustomToolbarComp = /*#__PURE__*/_react["default"].memo(function (props) {
|
|
54
58
|
var node = props.node,
|
|
55
|
-
value = props.value,
|
|
56
59
|
onFocus = props.onFocus,
|
|
57
60
|
onBlur = props.onBlur,
|
|
58
|
-
onClick = props.onClick
|
|
61
|
+
onClick = props.onClick,
|
|
62
|
+
editor = props.editor,
|
|
63
|
+
nodePath = props.nodePath;
|
|
59
64
|
|
|
60
65
|
var _ref = props || {},
|
|
61
66
|
pluginProps = _ref.pluginProps;
|
|
@@ -70,36 +75,34 @@ var CustomToolbarComp = /*#__PURE__*/_react["default"].memo(function (props) {
|
|
|
70
75
|
controlledKeypadMode = _ref3$controlledKeypa === void 0 ? true : _ref3$controlledKeypa;
|
|
71
76
|
|
|
72
77
|
var onDone = function onDone(latex) {
|
|
73
|
-
var update = _objectSpread(_objectSpread({}, node.data
|
|
78
|
+
var update = _objectSpread(_objectSpread({}, node.data), {}, {
|
|
74
79
|
latex: latex
|
|
75
80
|
});
|
|
76
81
|
|
|
77
|
-
|
|
78
|
-
|
|
82
|
+
editor.apply({
|
|
83
|
+
type: 'set_node',
|
|
84
|
+
path: nodePath,
|
|
85
|
+
properties: {
|
|
86
|
+
data: node.data
|
|
87
|
+
},
|
|
88
|
+
newProperties: {
|
|
89
|
+
data: update
|
|
90
|
+
}
|
|
79
91
|
});
|
|
80
|
-
var nextText = value.document.getNextText(node.key);
|
|
81
|
-
change.moveFocusTo(nextText.key, 0).moveAnchorTo(nextText.key, 0);
|
|
82
|
-
props.onToolbarDone(change, false);
|
|
83
|
-
};
|
|
84
92
|
|
|
85
|
-
|
|
86
|
-
var update = _objectSpread(_objectSpread({}, node.data.toObject()), {}, {
|
|
87
|
-
latex: latex
|
|
88
|
-
});
|
|
93
|
+
_slateReact.ReactEditor.focus(editor);
|
|
89
94
|
|
|
90
|
-
|
|
91
|
-
|
|
95
|
+
_slate.Transforms.move(editor, {
|
|
96
|
+
distance: 1,
|
|
97
|
+
unit: 'offset'
|
|
92
98
|
});
|
|
93
|
-
log('call onToolbarChange:', change);
|
|
94
|
-
props.onDataChange(node.key, update);
|
|
95
99
|
};
|
|
96
100
|
|
|
97
|
-
var latex = node.data.
|
|
101
|
+
var latex = node.data.latex;
|
|
98
102
|
return /*#__PURE__*/_react["default"].createElement(_mathToolbar.MathToolbar, {
|
|
99
103
|
autoFocus: true,
|
|
100
104
|
additionalKeys: generateAdditionalKeys(customKeys),
|
|
101
105
|
latex: latex,
|
|
102
|
-
onChange: onChange,
|
|
103
106
|
onDone: onDone,
|
|
104
107
|
onBlur: onBlur,
|
|
105
108
|
onFocus: onFocus,
|
|
@@ -124,34 +127,39 @@ var CustomToolbarComp = /*#__PURE__*/_react["default"].memo(function (props) {
|
|
|
124
127
|
controlledKeypadModeNext = _next$pluginProps$mat.controlledKeypadMode;
|
|
125
128
|
var keypadModeChanged = keypadMode !== keypadModeNext;
|
|
126
129
|
var controlledKeypadModeChanged = controlledKeypadMode !== controlledKeypadModeNext;
|
|
127
|
-
var equal = node
|
|
130
|
+
var equal = (0, _isEqual["default"])(node, nodeNext);
|
|
128
131
|
return equal && !keypadModeChanged && !controlledKeypadModeChanged;
|
|
129
132
|
});
|
|
130
133
|
|
|
131
134
|
exports.CustomToolbarComp = CustomToolbarComp;
|
|
132
135
|
CustomToolbarComp.propTypes = {
|
|
133
|
-
|
|
134
|
-
|
|
136
|
+
editor: _propTypes["default"].object,
|
|
137
|
+
node: _propTypes["default"].shape({
|
|
138
|
+
type: _propTypes["default"].string,
|
|
139
|
+
children: _propTypes["default"].array,
|
|
140
|
+
data: _propTypes["default"].object
|
|
141
|
+
}).isRequired,
|
|
142
|
+
value: _propTypes["default"].arrayOf(_propTypes["default"].shape({
|
|
143
|
+
type: _propTypes["default"].string,
|
|
144
|
+
children: _propTypes["default"].array,
|
|
145
|
+
data: _propTypes["default"].object
|
|
146
|
+
})).isRequired,
|
|
135
147
|
onToolbarDone: _propTypes["default"].func,
|
|
136
|
-
onDataChange: _propTypes["default"].func,
|
|
137
148
|
onFocus: _propTypes["default"].func,
|
|
138
149
|
onClick: _propTypes["default"].func,
|
|
139
150
|
onBlur: _propTypes["default"].func
|
|
140
151
|
};
|
|
152
|
+
var mathTypes = ['math', 'mathml'];
|
|
141
153
|
|
|
142
154
|
function MathPlugin() {
|
|
143
155
|
return {
|
|
144
156
|
name: 'math',
|
|
145
157
|
toolbar: {
|
|
146
158
|
icon: /*#__PURE__*/_react["default"].createElement(_Functions["default"], null),
|
|
147
|
-
onClick: function onClick(
|
|
159
|
+
onClick: function onClick(editor) {
|
|
148
160
|
log('[insertMath]');
|
|
149
161
|
var math = inlineMath();
|
|
150
|
-
|
|
151
|
-
onChange(change);
|
|
152
|
-
},
|
|
153
|
-
supports: function supports(node) {
|
|
154
|
-
return node && node.object === 'inline' && node.type === 'math';
|
|
162
|
+
editor.insertNode(math);
|
|
155
163
|
},
|
|
156
164
|
|
|
157
165
|
/**
|
|
@@ -163,6 +171,23 @@ function MathPlugin() {
|
|
|
163
171
|
*/
|
|
164
172
|
CustomToolbarComp: CustomToolbarComp
|
|
165
173
|
},
|
|
174
|
+
rules: function rules(editor) {
|
|
175
|
+
var isVoid = editor.isVoid,
|
|
176
|
+
isInline = editor.isInline;
|
|
177
|
+
|
|
178
|
+
editor.isVoid = function (element) {
|
|
179
|
+
return mathTypes.includes(element.type) ? true : isVoid(element);
|
|
180
|
+
};
|
|
181
|
+
|
|
182
|
+
editor.isInline = function (element) {
|
|
183
|
+
return mathTypes.includes(element.type) ? true : isInline(element);
|
|
184
|
+
};
|
|
185
|
+
|
|
186
|
+
return editor;
|
|
187
|
+
},
|
|
188
|
+
supports: function supports(node) {
|
|
189
|
+
return mathTypes.includes(node.type);
|
|
190
|
+
},
|
|
166
191
|
schema: {
|
|
167
192
|
document: {
|
|
168
193
|
match: [{
|
|
@@ -189,12 +214,13 @@ function MathPlugin() {
|
|
|
189
214
|
|
|
190
215
|
|
|
191
216
|
if (props.node.type === 'mathml') {
|
|
192
|
-
var html = props.node.data.
|
|
193
|
-
return /*#__PURE__*/_react["default"].createElement("span", (0, _extends2["default"])({}, props.attributes, {
|
|
217
|
+
var html = props.node.data.html;
|
|
218
|
+
return /*#__PURE__*/_react["default"].createElement("span", null, /*#__PURE__*/_react["default"].createElement("span", (0, _extends2["default"])({}, props.attributes, {
|
|
219
|
+
contentEditable: false,
|
|
194
220
|
dangerouslySetInnerHTML: {
|
|
195
221
|
__html: html
|
|
196
222
|
}
|
|
197
|
-
}));
|
|
223
|
+
})), props.children);
|
|
198
224
|
}
|
|
199
225
|
}
|
|
200
226
|
};
|
|
@@ -206,14 +232,15 @@ MathPlugin.DOLLAR = 'dollar';
|
|
|
206
232
|
MathPlugin.DOUBLE_DOLLAR = 'double_dollar';
|
|
207
233
|
|
|
208
234
|
var inlineMath = function inlineMath() {
|
|
209
|
-
return
|
|
210
|
-
object: 'inline',
|
|
235
|
+
return {
|
|
211
236
|
type: 'math',
|
|
212
|
-
isVoid: true,
|
|
213
237
|
data: {
|
|
214
238
|
latex: ''
|
|
215
|
-
}
|
|
216
|
-
|
|
239
|
+
},
|
|
240
|
+
children: [{
|
|
241
|
+
text: ''
|
|
242
|
+
}]
|
|
243
|
+
};
|
|
217
244
|
};
|
|
218
245
|
|
|
219
246
|
exports.inlineMath = inlineMath;
|
|
@@ -258,7 +285,7 @@ var lessThanHandling = function lessThanHandling(input) {
|
|
|
258
285
|
};
|
|
259
286
|
|
|
260
287
|
var serialization = {
|
|
261
|
-
deserialize: function deserialize(el) {
|
|
288
|
+
deserialize: function deserialize(el, children) {
|
|
262
289
|
var tagName = getTagName(el);
|
|
263
290
|
/**
|
|
264
291
|
* This is used for when there's a wrapper over the mathml element.
|
|
@@ -268,7 +295,7 @@ var serialization = {
|
|
|
268
295
|
* This is for legacy content only since our math rendering is valid for the core slate rules
|
|
269
296
|
*/
|
|
270
297
|
|
|
271
|
-
var hasMathChild =
|
|
298
|
+
var hasMathChild = _newSerialization.BLOCK_TAGS[tagName] && el.childNodes.length === 1 && getTagName(el.firstChild) === 'math';
|
|
272
299
|
log('[deserialize] name: ', tagName);
|
|
273
300
|
/**
|
|
274
301
|
* This is here in order to be able to render mathml content
|
|
@@ -276,14 +303,12 @@ var serialization = {
|
|
|
276
303
|
|
|
277
304
|
if (tagName === 'math' || el.dataset && el.dataset.type === 'mathml' || hasMathChild) {
|
|
278
305
|
var newHtml = hasMathChild ? el.innerHTML : el.outerHTML;
|
|
279
|
-
return {
|
|
280
|
-
object: 'inline',
|
|
281
|
-
isVoid: true,
|
|
306
|
+
return (0, _slateHyperscript.jsx)('element', {
|
|
282
307
|
type: 'mathml',
|
|
283
308
|
data: {
|
|
284
309
|
html: newHtml
|
|
285
310
|
}
|
|
286
|
-
};
|
|
311
|
+
});
|
|
287
312
|
}
|
|
288
313
|
|
|
289
314
|
if (el.nodeType === TEXT_NODE) {
|
|
@@ -304,24 +329,23 @@ var serialization = {
|
|
|
304
329
|
wrapType = _unWrapMath.wrapType;
|
|
305
330
|
|
|
306
331
|
log('[deserialize]: noBrackets: ', unwrapped, wrapType);
|
|
307
|
-
return {
|
|
308
|
-
object: 'inline',
|
|
332
|
+
return (0, _slateHyperscript.jsx)('element', {
|
|
309
333
|
type: 'math',
|
|
310
|
-
isVoid: true,
|
|
311
|
-
nodes: [],
|
|
312
334
|
data: {
|
|
313
335
|
latex: unwrapped,
|
|
314
336
|
wrapper: wrapType
|
|
315
337
|
}
|
|
316
|
-
};
|
|
338
|
+
});
|
|
317
339
|
}
|
|
318
340
|
},
|
|
319
341
|
serialize: function serialize(object) {
|
|
320
342
|
if (object.type === 'math') {
|
|
321
|
-
var
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
343
|
+
var _ref4 = object.data || {},
|
|
344
|
+
latex = _ref4.latex,
|
|
345
|
+
wrapper = _ref4.wrapper;
|
|
346
|
+
|
|
347
|
+
log('[serialize] latex: ', latex);
|
|
348
|
+
var decoded = htmlDecode(lessThanHandling(latex));
|
|
325
349
|
return /*#__PURE__*/_react["default"].createElement("span", {
|
|
326
350
|
"data-latex": "",
|
|
327
351
|
"data-raw": decoded
|
|
@@ -333,7 +357,9 @@ var serialization = {
|
|
|
333
357
|
|
|
334
358
|
|
|
335
359
|
if (object.type === 'mathml') {
|
|
336
|
-
var
|
|
360
|
+
var _ref5 = object.data || {},
|
|
361
|
+
html = _ref5.html;
|
|
362
|
+
|
|
337
363
|
return /*#__PURE__*/_react["default"].createElement("span", {
|
|
338
364
|
"data-type": "mathml",
|
|
339
365
|
dangerouslySetInnerHTML: {
|
|
@@ -344,4 +370,4 @@ var serialization = {
|
|
|
344
370
|
}
|
|
345
371
|
};
|
|
346
372
|
exports.serialization = serialization;
|
|
347
|
-
//# sourceMappingURL=index.js.map
|
|
373
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["log","debug","TEXT_NODE","generateAdditionalKeys","keyData","map","key","name","latex","write","label","CustomToolbarComp","React","memo","props","node","onFocus","onBlur","onClick","editor","nodePath","pluginProps","math","keypadMode","customKeys","controlledKeypadMode","onDone","update","data","apply","type","path","properties","newProperties","ReactEditor","focus","Transforms","move","distance","unit","prev","next","nodeNext","keypadModeNext","controlledKeypadModeNext","keypadModeChanged","controlledKeypadModeChanged","equal","isEqual","propTypes","PropTypes","object","shape","string","children","array","isRequired","value","arrayOf","onToolbarDone","func","mathTypes","MathPlugin","toolbar","icon","inlineMath","insertNode","rules","isVoid","isInline","element","includes","supports","schema","document","match","pluginStyles","parentNode","p","position","top","renderNode","html","attributes","__html","ROUND_BRACKETS","SQUARE_BRACKETS","DOLLAR","DOUBLE_DOLLAR","text","htmlDecode","input","doc","DOMParser","parseFromString","documentElement","textContent","getTagName","el","tagName","toLowerCase","lessThanHandling","arrowSplit","split","length","reduce","st","part","serialization","deserialize","hasMathChild","BLOCK_TAGS","childNodes","firstChild","dataset","newHtml","innerHTML","outerHTML","jsx","nodeType","hasLatex","hasAttribute","unWrapMath","unwrapped","wrapType","wrapper","serialize","decoded","wrapMath"],"sources":["../../../src/plugins/math/index.jsx"],"sourcesContent":["import React from 'react';\nimport { Editor, Inline, Transforms } from 'slate';\nimport { ReactEditor } from 'slate-react';\nimport { jsx } from 'slate-hyperscript';\nimport Functions from '@material-ui/icons/Functions';\nimport { MathPreview, MathToolbar } from '@pie-lib/math-toolbar';\nimport { wrapMath, unWrapMath } from '@pie-lib/math-rendering';\nimport debug from 'debug';\nimport PropTypes from 'prop-types';\nimport isEqual from 'lodash/isEqual';\n\nimport { BLOCK_TAGS } from '../../new-serialization';\nconst log = debug('@pie-lib:editable-html:plugins:math');\n\nconst TEXT_NODE = 3;\n\nfunction generateAdditionalKeys(keyData = []) {\n  return keyData.map(key => ({\n    name: key,\n    latex: key,\n    write: key,\n    label: key\n  }));\n}\n\nexport const CustomToolbarComp = React.memo(\n  props => {\n    const { node, onFocus, onBlur, onClick, editor, nodePath } = props;\n    const { pluginProps } = props || {};\n    const { math } = pluginProps || {};\n    const { keypadMode, customKeys, controlledKeypadMode = true } = math || {};\n\n    const onDone = latex => {\n      const update = {\n        ...node.data,\n        latex\n      };\n      editor.apply({\n        type: 'set_node',\n        path: nodePath,\n        properties: {\n          data: node.data\n        },\n        newProperties: { data: update }\n      });\n      ReactEditor.focus(editor);\n      Transforms.move(editor, { distance: 1, unit: 'offset' });\n    };\n\n    const latex = node.data.latex;\n\n    return (\n      <MathToolbar\n        autoFocus\n        additionalKeys={generateAdditionalKeys(customKeys)}\n        latex={latex}\n        onDone={onDone}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={onClick}\n        keypadMode={keypadMode}\n        controlledKeypadMode={controlledKeypadMode}\n      />\n    );\n  },\n  (prev, next) => {\n    const { node, pluginProps: { math: { keypadMode, controlledKeypadMode } = {} } = {} } = prev;\n    const {\n      node: nodeNext,\n      pluginProps: {\n        math: { keypadMode: keypadModeNext, controlledKeypadMode: controlledKeypadModeNext } = {}\n      } = {}\n    } = next;\n    const keypadModeChanged = keypadMode !== keypadModeNext;\n    const controlledKeypadModeChanged = controlledKeypadMode !== controlledKeypadModeNext;\n\n    const equal = isEqual(node, nodeNext);\n    return equal && !keypadModeChanged && !controlledKeypadModeChanged;\n  }\n);\n\nCustomToolbarComp.propTypes = {\n  editor: PropTypes.object,\n  node: PropTypes.shape({\n    type: PropTypes.string,\n    children: PropTypes.array,\n    data: PropTypes.object\n  }).isRequired,\n  value: PropTypes.arrayOf(\n    PropTypes.shape({\n      type: PropTypes.string,\n      children: PropTypes.array,\n      data: PropTypes.object\n    })\n  ).isRequired,\n  onToolbarDone: PropTypes.func,\n  onFocus: PropTypes.func,\n  onClick: PropTypes.func,\n  onBlur: PropTypes.func\n};\n\nconst mathTypes = ['math', 'mathml'];\n\nexport default function MathPlugin() {\n  return {\n    name: 'math',\n    toolbar: {\n      icon: <Functions />,\n      onClick: editor => {\n        log('[insertMath]');\n        const math = inlineMath();\n\n        editor.insertNode(math);\n      },\n      /**\n       * Return a react component function\n       * @param node {Slate.Node}\n       * @param value {Slate.Value}\n       * @param onDone {(change?: Slate.Change, finishEditing :boolea) => void} - a function to call once the toolbar\n       *   has made any changes, call with the node.key and a data object.\n       */\n      CustomToolbarComp\n    },\n    rules: editor => {\n      const { isVoid, isInline } = editor;\n\n      editor.isVoid = element => {\n        return mathTypes.includes(element.type) ? true : isVoid(element);\n      };\n\n      editor.isInline = element => {\n        return mathTypes.includes(element.type) ? true : isInline(element);\n      };\n\n      return editor;\n    },\n    supports: node => mathTypes.includes(node.type),\n    schema: {\n      document: { match: [{ type: 'math' }] }\n    },\n\n    pluginStyles: (node, parentNode, p) => {\n      if (p) {\n        return {\n          position: 'absolute',\n          top: 'initial'\n        };\n      }\n    },\n\n    renderNode: props => {\n      if (props.node.type === 'math') {\n        log('[renderNode]: data:', props.node.data);\n        return <MathPreview {...props} />;\n      }\n\n      /**\n       * Here for rendering mathml content\n       */\n      if (props.node.type === 'mathml') {\n        const { data: { html } } = props.node;\n\n        return (\n          <span>\n            <span {...props.attributes} contentEditable={false} dangerouslySetInnerHTML={{ __html: html }} />\n            {props.children}\n          </span>\n        );\n      }\n    }\n  };\n}\n\nMathPlugin.ROUND_BRACKETS = 'round_brackets';\nMathPlugin.SQUARE_BRACKETS = 'square_brackets';\nMathPlugin.DOLLAR = 'dollar';\nMathPlugin.DOUBLE_DOLLAR = 'double_dollar';\n\nexport const inlineMath = () => ({\n  type: 'math',\n  data: {\n    latex: ''\n  },\n  children: [{ text: '' }]\n});\n\nconst htmlDecode = input => {\n  const doc = new DOMParser().parseFromString(input, 'text/html');\n\n  return doc.documentElement.textContent;\n};\n\nconst getTagName = el => {\n  return ((el && el.tagName) || '').toLowerCase();\n};\n\n/**\n * Makes sure that strings that contain stuff like:\n * x<y are not transformed into x by the DOMParser because it thinks\n * that <y is the start of a dom element tag\n * @param input\n * @returns {*}\n */\nconst lessThanHandling = input => {\n  const arrowSplit = input.split('<');\n\n  // if we don't have at least 2 characters there's no point in checking\n  if (input.length > 2) {\n    return arrowSplit.reduce((st, part) => {\n      /*\n       We check if this element resulted is:\n       div - continuation of a beginning of a HTML element\n       /div - closing of a HTML tag\n       br/> - beginning and closing of a html TAG\n       */\n      if (part.match(/<[a-zA-Z/][\\s\\S]*>/gi)) {\n        return `${st}${st ? '<' : ''}${part}`;\n      }\n\n      return `${st}${st ? '&lt;' : ''}${part}`;\n    }, '');\n  }\n\n  return input;\n};\n\nexport const serialization = {\n  deserialize(el, children) {\n    const tagName = getTagName(el);\n    /**\n     * This is used for when there's a wrapper over the mathml element.\n     * Because of this slate rule: \"Only allow block nodes or inline and text nodes in blocks.\"\n     * The element that contains only the mathml is removed (along with the math) because it has\n     * an inline child and the block is of type block\n     * This is for legacy content only since our math rendering is valid for the core slate rules\n     */\n    const hasMathChild =\n      BLOCK_TAGS[tagName] && el.childNodes.length === 1 && getTagName(el.firstChild) === 'math';\n    log('[deserialize] name: ', tagName);\n\n    /**\n     * This is here in order to be able to render mathml content\n     */\n    if (tagName === 'math' || (el.dataset && el.dataset.type === 'mathml') || hasMathChild) {\n      const newHtml = hasMathChild ? el.innerHTML : el.outerHTML;\n\n      return jsx('element', {\n        type: 'mathml',\n        data: {\n          html: newHtml\n        }\n      });\n    }\n\n    if (el.nodeType === TEXT_NODE) {\n      return;\n    }\n\n    if (tagName !== 'span') {\n      return;\n    }\n\n    const hasLatex = el.hasAttribute('data-latex') || el.hasAttribute('latex');\n\n    if (hasLatex) {\n      const latex = htmlDecode(el.innerHTML);\n      const { unwrapped, wrapType } = unWrapMath(latex);\n      log('[deserialize]: noBrackets: ', unwrapped, wrapType);\n\n      return jsx('element', {\n        type: 'math',\n        data: {\n          latex: unwrapped,\n          wrapper: wrapType\n        }\n      });\n    }\n  },\n  serialize(object) {\n    if (object.type === 'math') {\n      const { latex, wrapper } = object.data || {};\n      log('[serialize] latex: ', latex);\n      const decoded = htmlDecode(lessThanHandling(latex));\n      return (\n        <span data-latex=\"\" data-raw={decoded}>\n          {wrapMath(decoded, wrapper)}\n        </span>\n      );\n    }\n\n    /**\n     * Here for rendering mathml content\n     */\n    if (object.type === 'mathml') {\n      const { html } = object.data || {};\n\n      return <span data-type=\"mathml\" dangerouslySetInnerHTML={{ __html: html }} />;\n    }\n  }\n};\n"],"mappings":"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"}
|