@pie-lib/editable-html 9.5.13 → 10.0.0-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +0 -302
- package/lib/components.js +116 -0
- package/lib/components.js.map +1 -0
- package/lib/editor.js +418 -103
- package/lib/editor.js.map +1 -1
- package/lib/index.js +101 -155
- package/lib/index.js.map +1 -1
- package/lib/new-serialization.js +320 -0
- package/lib/new-serialization.js.map +1 -0
- package/lib/old-serialization.js +330 -0
- package/lib/parse-html.js +1 -1
- package/lib/parse-html.js.map +1 -1
- package/lib/plugins/characters/custom-popper.js +1 -1
- package/lib/plugins/characters/custom-popper.js.map +1 -1
- package/lib/plugins/characters/index.js +21 -19
- package/lib/plugins/characters/index.js.map +1 -1
- package/lib/plugins/characters/utils.js +1 -1
- package/lib/plugins/characters/utils.js.map +1 -1
- package/lib/plugins/hotKeys/index.js +67 -0
- package/lib/plugins/hotKeys/index.js.map +1 -0
- package/lib/plugins/image/alt-dialog.js +1 -6
- package/lib/plugins/image/alt-dialog.js.map +1 -1
- package/lib/plugins/image/component.js +70 -53
- package/lib/plugins/image/component.js.map +1 -1
- package/lib/plugins/image/image-toolbar.js +7 -9
- package/lib/plugins/image/image-toolbar.js.map +1 -1
- package/lib/plugins/image/index.js +83 -27
- package/lib/plugins/image/index.js.map +1 -1
- package/lib/plugins/image/insert-image-handler.js +72 -33
- package/lib/plugins/image/insert-image-handler.js.map +1 -1
- package/lib/plugins/index.js +23 -41
- package/lib/plugins/index.js.map +1 -1
- package/lib/plugins/list/index.js +64 -100
- package/lib/plugins/list/index.js.map +1 -1
- package/lib/plugins/math/index.js +86 -60
- package/lib/plugins/math/index.js.map +1 -1
- package/lib/plugins/media/index.js +202 -132
- package/lib/plugins/media/index.js.map +1 -1
- package/lib/plugins/media/media-dialog.js +17 -16
- package/lib/plugins/media/media-dialog.js.map +1 -1
- package/lib/plugins/media/media-toolbar.js +3 -3
- package/lib/plugins/media/media-toolbar.js.map +1 -1
- package/lib/plugins/media/media-wrapper.js +21 -58
- package/lib/plugins/media/media-wrapper.js.map +1 -1
- package/lib/plugins/respArea/drag-in-the-blank/choice.js +3 -3
- package/lib/plugins/respArea/drag-in-the-blank/choice.js.map +1 -1
- package/lib/plugins/respArea/drag-in-the-blank/index.js +3 -2
- package/lib/plugins/respArea/drag-in-the-blank/index.js.map +1 -1
- package/lib/plugins/respArea/explicit-constructed-response/index.js +3 -2
- package/lib/plugins/respArea/explicit-constructed-response/index.js.map +1 -1
- package/lib/plugins/respArea/icons/index.js +13 -15
- package/lib/plugins/respArea/icons/index.js.map +1 -1
- package/lib/plugins/respArea/index.js +87 -53
- package/lib/plugins/respArea/index.js.map +1 -1
- package/lib/plugins/respArea/inline-dropdown/index.js +4 -3
- package/lib/plugins/respArea/inline-dropdown/index.js.map +1 -1
- package/lib/plugins/respArea/utils.js +17 -20
- package/lib/plugins/respArea/utils.js.map +1 -1
- package/lib/plugins/table/icons/index.js +1 -1
- package/lib/plugins/table/icons/index.js.map +1 -1
- package/lib/plugins/table/index.js +381 -212
- package/lib/plugins/table/index.js.map +1 -1
- package/lib/plugins/table/table-toolbar.js +5 -6
- package/lib/plugins/table/table-toolbar.js.map +1 -1
- package/lib/plugins/toolbar/default-toolbar.js +55 -11
- package/lib/plugins/toolbar/default-toolbar.js.map +1 -1
- package/lib/plugins/toolbar/done-button.js +1 -1
- package/lib/plugins/toolbar/done-button.js.map +1 -1
- package/lib/plugins/toolbar/editor-and-toolbar.js +186 -232
- package/lib/plugins/toolbar/editor-and-toolbar.js.map +1 -1
- package/lib/plugins/toolbar/index.js +1 -2
- package/lib/plugins/toolbar/index.js.map +1 -1
- package/lib/plugins/toolbar/toolbar-buttons.js +1 -1
- package/lib/plugins/toolbar/toolbar-buttons.js.map +1 -1
- package/lib/plugins/toolbar/toolbar.js +253 -239
- package/lib/plugins/toolbar/toolbar.js.map +1 -1
- package/lib/plugins/utils.js +27 -2
- package/lib/plugins/utils.js.map +1 -1
- package/lib/serialization.js +1 -1
- package/lib/serialization.js.map +1 -1
- package/lib/slate-editor.js +302 -0
- package/lib/test-serializer.js +189 -0
- package/lib/test-serializer.js.map +1 -0
- package/lib/theme.js +1 -1
- package/lib/theme.js.map +1 -1
- package/package.json +18 -14
- package/playground/image/data.js +20 -20
- package/playground/image/index.html +22 -20
- package/playground/image/index.jsx +12 -10
- package/playground/index.html +25 -23
- package/playground/mathquill/index.html +23 -20
- package/playground/mathquill/index.jsx +18 -22
- package/playground/prod-test/index.html +24 -20
- package/playground/prod-test/index.jsx +5 -3
- package/playground/schema-override/data.js +10 -10
- package/playground/schema-override/image-plugin.jsx +3 -4
- package/playground/schema-override/index.html +21 -19
- package/playground/schema-override/index.jsx +13 -14
- package/playground/serialization/data.js +10 -10
- package/playground/serialization/image-plugin.jsx +3 -4
- package/playground/serialization/index.html +22 -20
- package/playground/table-examples.html +5 -8
- package/playground/webpack.config.js +10 -10
- package/src/components.js +135 -0
- package/src/editor.jsx +478 -141
- package/src/index.jsx +71 -95
- package/src/new-serialization.jsx +291 -0
- package/src/parse-html.js +1 -1
- package/src/plugins/characters/custom-popper.js +7 -7
- package/src/plugins/characters/index.jsx +33 -34
- package/src/plugins/characters/utils.js +81 -81
- package/src/plugins/hotKeys/index.js +54 -0
- package/src/plugins/image/alt-dialog.jsx +4 -5
- package/src/plugins/image/component.jsx +106 -89
- package/src/plugins/image/image-toolbar.jsx +27 -19
- package/src/plugins/image/index.jsx +75 -43
- package/src/plugins/image/insert-image-handler.js +62 -27
- package/src/plugins/index.jsx +23 -41
- package/src/plugins/list/index.jsx +70 -95
- package/src/plugins/math/index.jsx +102 -82
- package/src/plugins/media/index.jsx +159 -124
- package/src/plugins/media/media-dialog.js +98 -71
- package/src/plugins/media/media-toolbar.jsx +8 -8
- package/src/plugins/media/media-wrapper.jsx +29 -30
- package/src/plugins/respArea/drag-in-the-blank/choice.jsx +21 -19
- package/src/plugins/respArea/drag-in-the-blank/index.jsx +14 -11
- package/src/plugins/respArea/explicit-constructed-response/index.jsx +7 -6
- package/src/plugins/respArea/icons/index.jsx +11 -14
- package/src/plugins/respArea/index.jsx +92 -52
- package/src/plugins/respArea/inline-dropdown/index.jsx +9 -8
- package/src/plugins/respArea/utils.jsx +26 -35
- package/src/plugins/table/icons/index.jsx +17 -11
- package/src/plugins/table/index.jsx +288 -231
- package/src/plugins/table/table-toolbar.jsx +15 -11
- package/src/plugins/toolbar/default-toolbar.jsx +65 -19
- package/src/plugins/toolbar/done-button.jsx +4 -4
- package/src/plugins/toolbar/editor-and-toolbar.jsx +150 -145
- package/src/plugins/toolbar/index.jsx +2 -3
- package/src/plugins/toolbar/toolbar-buttons.jsx +11 -11
- package/src/plugins/toolbar/toolbar.jsx +244 -221
- package/src/plugins/utils.js +21 -4
- package/src/serialization.jsx +32 -32
- package/src/test-serializer.js +139 -0
- package/src/test-serializer.js.rej +20 -0
|
@@ -0,0 +1,330 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.valueToHtml = exports.reactAttributes = exports.parseStyleString = exports.htmlToValue = exports.getBase64 = exports.TEXT_RULE = exports.BLOCK_TAGS = void 0;
|
|
9
|
+
|
|
10
|
+
var _testSerializer = _interopRequireDefault(require("./test-serializer"));
|
|
11
|
+
|
|
12
|
+
var _react = _interopRequireDefault(require("react"));
|
|
13
|
+
|
|
14
|
+
var _debug = _interopRequireDefault(require("debug"));
|
|
15
|
+
|
|
16
|
+
var _toStyle = require("to-style");
|
|
17
|
+
|
|
18
|
+
var _image = require("./plugins/image");
|
|
19
|
+
|
|
20
|
+
var _math = require("./plugins/math");
|
|
21
|
+
|
|
22
|
+
var _media = require("./plugins/media");
|
|
23
|
+
|
|
24
|
+
var _list = require("./plugins/list");
|
|
25
|
+
|
|
26
|
+
var _table = require("./plugins/table");
|
|
27
|
+
|
|
28
|
+
var _respArea = require("./plugins/respArea");
|
|
29
|
+
|
|
30
|
+
var _slate = require("slate");
|
|
31
|
+
|
|
32
|
+
var log = (0, _debug["default"])('@pie-lib:editable-html:serialization');
|
|
33
|
+
/**
|
|
34
|
+
* Tags to blocks.
|
|
35
|
+
*
|
|
36
|
+
* @type {Object}
|
|
37
|
+
*/
|
|
38
|
+
|
|
39
|
+
var BLOCK_TAGS = {
|
|
40
|
+
div: 'div',
|
|
41
|
+
span: 'span',
|
|
42
|
+
p: 'paragraph',
|
|
43
|
+
blockquote: 'quote',
|
|
44
|
+
pre: 'code',
|
|
45
|
+
h1: 'heading-one',
|
|
46
|
+
h2: 'heading-two',
|
|
47
|
+
h3: 'heading-three',
|
|
48
|
+
h4: 'heading-four',
|
|
49
|
+
h5: 'heading-five',
|
|
50
|
+
h6: 'heading-six'
|
|
51
|
+
};
|
|
52
|
+
/**
|
|
53
|
+
* Tags to marks.
|
|
54
|
+
*
|
|
55
|
+
* @type {Object}
|
|
56
|
+
*/
|
|
57
|
+
|
|
58
|
+
exports.BLOCK_TAGS = BLOCK_TAGS;
|
|
59
|
+
var MARK_TAGS = {
|
|
60
|
+
b: 'bold',
|
|
61
|
+
em: 'italic',
|
|
62
|
+
u: 'underline',
|
|
63
|
+
s: 'strikethrough',
|
|
64
|
+
code: 'code',
|
|
65
|
+
strong: 'bold'
|
|
66
|
+
};
|
|
67
|
+
|
|
68
|
+
var parseStyleString = function parseStyleString(s) {
|
|
69
|
+
var regex = /([\w-]*)\s*:\s*([^;]*)/g;
|
|
70
|
+
var match;
|
|
71
|
+
var result = {};
|
|
72
|
+
|
|
73
|
+
while (match = regex.exec(s)) {
|
|
74
|
+
result[match[1]] = match[2].trim();
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
return result;
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
exports.parseStyleString = parseStyleString;
|
|
81
|
+
|
|
82
|
+
var getBase64 = function getBase64(file) {
|
|
83
|
+
return new Promise(function (resolve, reject) {
|
|
84
|
+
var reader = new FileReader();
|
|
85
|
+
reader.readAsDataURL(file);
|
|
86
|
+
|
|
87
|
+
reader.onload = function () {
|
|
88
|
+
return resolve(reader.result);
|
|
89
|
+
};
|
|
90
|
+
|
|
91
|
+
reader.onerror = function (error) {
|
|
92
|
+
return reject(error);
|
|
93
|
+
};
|
|
94
|
+
});
|
|
95
|
+
};
|
|
96
|
+
|
|
97
|
+
exports.getBase64 = getBase64;
|
|
98
|
+
|
|
99
|
+
var reactAttributes = function reactAttributes(o) {
|
|
100
|
+
return (0, _toStyle.object)(o, {
|
|
101
|
+
camelize: true,
|
|
102
|
+
addUnits: false
|
|
103
|
+
});
|
|
104
|
+
};
|
|
105
|
+
|
|
106
|
+
exports.reactAttributes = reactAttributes;
|
|
107
|
+
|
|
108
|
+
var attributesToMap = function attributesToMap(el) {
|
|
109
|
+
return function (acc, attribute) {
|
|
110
|
+
var value = el.getAttribute(attribute);
|
|
111
|
+
|
|
112
|
+
if (value) {
|
|
113
|
+
if (attribute === 'style') {
|
|
114
|
+
var styleString = el.getAttribute(attribute);
|
|
115
|
+
var reactStyleObject = reactAttributes(parseStyleString(styleString));
|
|
116
|
+
acc['style'] = reactStyleObject;
|
|
117
|
+
} else {
|
|
118
|
+
acc[attribute] = el.getAttribute(attribute);
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
return acc;
|
|
123
|
+
};
|
|
124
|
+
};
|
|
125
|
+
|
|
126
|
+
var attributes = ['border', 'cellpadding', 'cellspacing', 'class', 'style'];
|
|
127
|
+
/**
|
|
128
|
+
* Serializer rules.
|
|
129
|
+
*
|
|
130
|
+
* @type {Array}
|
|
131
|
+
*/
|
|
132
|
+
|
|
133
|
+
var blocks = {
|
|
134
|
+
deserialize: function deserialize(el, next) {
|
|
135
|
+
log('[blocks:deserialize] block: ', el);
|
|
136
|
+
var block = BLOCK_TAGS[el.tagName.toLowerCase()];
|
|
137
|
+
if (!block) return;
|
|
138
|
+
log('[blocks:deserialize] block: ', block);
|
|
139
|
+
|
|
140
|
+
if (el.childNodes.length === 1) {
|
|
141
|
+
var cn = el.childNodes[0];
|
|
142
|
+
|
|
143
|
+
if (cn && cn.tagName && cn.tagName.toLowerCase() === block) {
|
|
144
|
+
log('[we have a child node of the same]...');
|
|
145
|
+
return;
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
return {
|
|
150
|
+
object: 'block',
|
|
151
|
+
type: block,
|
|
152
|
+
|
|
153
|
+
/**
|
|
154
|
+
* Here for rendering styles for all block elements
|
|
155
|
+
*/
|
|
156
|
+
data: {
|
|
157
|
+
attributes: attributes.reduce(attributesToMap(el), {})
|
|
158
|
+
},
|
|
159
|
+
nodes: next(el.childNodes)
|
|
160
|
+
};
|
|
161
|
+
},
|
|
162
|
+
serialize: function serialize(object, children) {
|
|
163
|
+
if (object.object !== 'block') return;
|
|
164
|
+
var jsonData = object.data.toJSON();
|
|
165
|
+
log('[blocks:serialize] object: ', object, children);
|
|
166
|
+
var key;
|
|
167
|
+
|
|
168
|
+
for (key in BLOCK_TAGS) {
|
|
169
|
+
if (BLOCK_TAGS[key] === object.type) {
|
|
170
|
+
var Tag = key;
|
|
171
|
+
return /*#__PURE__*/_react["default"].createElement(Tag, jsonData.attributes, children);
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
};
|
|
176
|
+
var marks = {
|
|
177
|
+
deserialize: function deserialize(el, next) {
|
|
178
|
+
var mark = MARK_TAGS[el.tagName.toLowerCase()];
|
|
179
|
+
if (!mark) return;
|
|
180
|
+
log('[deserialize] mark: ', mark);
|
|
181
|
+
return {
|
|
182
|
+
object: 'mark',
|
|
183
|
+
type: mark,
|
|
184
|
+
nodes: next(el.childNodes)
|
|
185
|
+
};
|
|
186
|
+
},
|
|
187
|
+
serialize: function serialize(object, children) {
|
|
188
|
+
if (_slate.Mark.isMark(object)) {
|
|
189
|
+
for (var key in MARK_TAGS) {
|
|
190
|
+
if (MARK_TAGS[key] === object.type) {
|
|
191
|
+
var Tag = key;
|
|
192
|
+
return /*#__PURE__*/_react["default"].createElement(Tag, null, children);
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
};
|
|
198
|
+
|
|
199
|
+
var findPreviousText = function findPreviousText(el) {
|
|
200
|
+
if (el.nodeName === '#text') {
|
|
201
|
+
return el;
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
if (el.previousSibling) {
|
|
205
|
+
return findPreviousText(el.previousSibling);
|
|
206
|
+
}
|
|
207
|
+
|
|
208
|
+
return null;
|
|
209
|
+
};
|
|
210
|
+
|
|
211
|
+
var TEXT_RULE = {
|
|
212
|
+
deserialize: function deserialize(el) {
|
|
213
|
+
/**
|
|
214
|
+
* This needs to be called on the dom element in order to merge the adjacent text nodes together
|
|
215
|
+
* */
|
|
216
|
+
el.normalize();
|
|
217
|
+
|
|
218
|
+
if (el.tagName && el.tagName.toLowerCase() === 'br') {
|
|
219
|
+
return {
|
|
220
|
+
object: 'text',
|
|
221
|
+
leaves: [{
|
|
222
|
+
object: 'leaf',
|
|
223
|
+
text: '\n'
|
|
224
|
+
}]
|
|
225
|
+
};
|
|
226
|
+
}
|
|
227
|
+
|
|
228
|
+
if (el.nodeName === '#text') {
|
|
229
|
+
if (el.nodeValue && el.nodeValue.match(/<!--.*?-->/)) return;
|
|
230
|
+
log('[text:deserialize] return text object..');
|
|
231
|
+
return {
|
|
232
|
+
object: 'text',
|
|
233
|
+
leaves: [{
|
|
234
|
+
object: 'leaf',
|
|
235
|
+
text: el.nodeValue
|
|
236
|
+
}]
|
|
237
|
+
};
|
|
238
|
+
}
|
|
239
|
+
},
|
|
240
|
+
serialize: function serialize(obj, children) {
|
|
241
|
+
if (obj.object === 'string') {
|
|
242
|
+
return children.split('\n').reduce(function (array, text, i) {
|
|
243
|
+
if (i !== 0) array.push( /*#__PURE__*/_react["default"].createElement("br", null));
|
|
244
|
+
array.push(text);
|
|
245
|
+
return array;
|
|
246
|
+
}, []);
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
};
|
|
250
|
+
exports.TEXT_RULE = TEXT_RULE;
|
|
251
|
+
var RULES = [_list.serialization, _math.serialization, _media.serialization, _image.serialization, _table.serialization, _respArea.serialization, TEXT_RULE, blocks, marks];
|
|
252
|
+
|
|
253
|
+
function allWhitespace(node) {
|
|
254
|
+
// Use ECMA-262 Edition 3 String and RegExp features
|
|
255
|
+
return !/[^\t\n\r ]/.test(node.textContent);
|
|
256
|
+
}
|
|
257
|
+
|
|
258
|
+
function defaultParseHtml(html) {
|
|
259
|
+
if (typeof DOMParser === 'undefined') {
|
|
260
|
+
throw new Error('The native `DOMParser` global which the `Html` serializer uses by default is not present in this environment. You must supply the `options.parseHtml` function instead.');
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
var parsed = new DOMParser().parseFromString(html, 'text/html');
|
|
264
|
+
var body = parsed.body;
|
|
265
|
+
var textNodes = document.createTreeWalker(body, NodeFilter.SHOW_TEXT, null, null);
|
|
266
|
+
var n = textNodes.nextNode();
|
|
267
|
+
|
|
268
|
+
while (n) {
|
|
269
|
+
if (allWhitespace(n) || n.nodeValue === "\u200B") {
|
|
270
|
+
n.parentNode.removeChild(n);
|
|
271
|
+
}
|
|
272
|
+
|
|
273
|
+
n = textNodes.nextNode();
|
|
274
|
+
}
|
|
275
|
+
|
|
276
|
+
return body;
|
|
277
|
+
}
|
|
278
|
+
/** If this lib is used on the server side, we need to bypass using the DOMParser - just put in a stub. */
|
|
279
|
+
|
|
280
|
+
|
|
281
|
+
var parseHtml = typeof window === 'undefined' ? function () {
|
|
282
|
+
return {
|
|
283
|
+
childNodes: []
|
|
284
|
+
};
|
|
285
|
+
} : defaultParseHtml;
|
|
286
|
+
var serializer = new _testSerializer["default"]({
|
|
287
|
+
defaultBlock: 'div',
|
|
288
|
+
rules: RULES,
|
|
289
|
+
parseHtml: parseHtml
|
|
290
|
+
});
|
|
291
|
+
|
|
292
|
+
var _extends = Object.assign || function (target) {
|
|
293
|
+
for (var i = 1; i < arguments.length; i++) {
|
|
294
|
+
var source = arguments[i];
|
|
295
|
+
|
|
296
|
+
for (var key in source) {
|
|
297
|
+
if (Object.prototype.hasOwnProperty.call(source, key)) {
|
|
298
|
+
target[key] = source[key];
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
}
|
|
302
|
+
|
|
303
|
+
return target;
|
|
304
|
+
};
|
|
305
|
+
|
|
306
|
+
var htmlToValue = function htmlToValue(html) {
|
|
307
|
+
try {
|
|
308
|
+
return serializer.deserialize(html);
|
|
309
|
+
} catch (e) {
|
|
310
|
+
console.log("Couldn't parse html: ", e);
|
|
311
|
+
return {};
|
|
312
|
+
}
|
|
313
|
+
};
|
|
314
|
+
|
|
315
|
+
exports.htmlToValue = htmlToValue;
|
|
316
|
+
|
|
317
|
+
var valueToHtml = function valueToHtml(value) {
|
|
318
|
+
return serializer.serialize(value);
|
|
319
|
+
};
|
|
320
|
+
/**
|
|
321
|
+
*
|
|
322
|
+
* <div><div>a</div></div> -> <div>a</div>
|
|
323
|
+
*
|
|
324
|
+
* <div><div>a</div><div>b</div></div> -> <div>a</div><div>b</div>
|
|
325
|
+
* <div><div>a</div>4444<div>b</div></div> -> <div>a</div>4444<div>b</div>
|
|
326
|
+
*/
|
|
327
|
+
|
|
328
|
+
|
|
329
|
+
exports.valueToHtml = valueToHtml;
|
|
330
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["log","debug","BLOCK_TAGS","div","span","p","blockquote","pre","h1","h2","h3","h4","h5","h6","MARK_TAGS","b","em","u","s","code","strong","parseStyleString","regex","match","result","exec","trim","getBase64","file","Promise","resolve","reject","reader","FileReader","readAsDataURL","onload","onerror","error","reactAttributes","o","toStyleObject","camelize","addUnits","attributesToMap","el","acc","attribute","value","getAttribute","styleString","reactStyleObject","attributes","blocks","deserialize","next","block","tagName","toLowerCase","childNodes","length","cn","object","type","data","reduce","nodes","serialize","children","jsonData","toJSON","key","Tag","marks","mark","Mark","isMark","findPreviousText","nodeName","previousSibling","TEXT_RULE","normalize","leaves","text","nodeValue","obj","split","array","i","push","RULES","listSerialization","mathSerialization","mediaSerialization","imgSerialization","tableSerialization","responseAreaSerialization","allWhitespace","node","test","textContent","defaultParseHtml","html","DOMParser","Error","parsed","parseFromString","body","textNodes","document","createTreeWalker","NodeFilter","SHOW_TEXT","n","nextNode","parentNode","removeChild","parseHtml","window","serializer","Html","defaultBlock","rules","_extends","Object","assign","target","arguments","source","prototype","hasOwnProperty","call","htmlToValue","e","console","valueToHtml"],"sources":["../src/old-serialization.jsx"],"sourcesContent":["import Html from './test-serializer';\nimport React from 'react';\nimport debug from 'debug';\nimport { object as toStyleObject } from 'to-style';\n\nimport { serialization as imgSerialization } from './plugins/image';\nimport { serialization as mathSerialization } from './plugins/math';\nimport { serialization as mediaSerialization } from './plugins/media';\nimport { serialization as listSerialization } from './plugins/list';\nimport { serialization as tableSerialization } from './plugins/table';\nimport { serialization as responseAreaSerialization } from './plugins/respArea';\nimport { Mark, Value } from 'slate';\n\nconst log = debug('@pie-lib:editable-html:serialization');\n\n/**\n * Tags to blocks.\n *\n * @type {Object}\n */\n\nexport const BLOCK_TAGS = {\n  div: 'div',\n  span: 'span',\n  p: 'paragraph',\n  blockquote: 'quote',\n  pre: 'code',\n  h1: 'heading-one',\n  h2: 'heading-two',\n  h3: 'heading-three',\n  h4: 'heading-four',\n  h5: 'heading-five',\n  h6: 'heading-six'\n};\n\n/**\n * Tags to marks.\n *\n * @type {Object}\n */\n\nconst MARK_TAGS = {\n  b: 'bold',\n  em: 'italic',\n  u: 'underline',\n  s: 'strikethrough',\n  code: 'code',\n  strong: 'bold'\n};\n\nexport const parseStyleString = s => {\n  const regex = /([\\w-]*)\\s*:\\s*([^;]*)/g;\n  let match;\n  const result = {};\n  while ((match = regex.exec(s))) {\n    result[match[1]] = match[2].trim();\n  }\n  return result;\n};\n\nexport const getBase64 = file => {\n  return new Promise((resolve, reject) => {\n    const reader = new FileReader();\n    reader.readAsDataURL(file);\n    reader.onload = () => resolve(reader.result);\n    reader.onerror = error => reject(error);\n  });\n};\n\nexport const reactAttributes = o => toStyleObject(o, { camelize: true, addUnits: false });\n\nconst attributesToMap = el => (acc, attribute) => {\n  const value = el.getAttribute(attribute);\n  if (value) {\n    if (attribute === 'style') {\n      const styleString = el.getAttribute(attribute);\n      const reactStyleObject = reactAttributes(parseStyleString(styleString));\n      acc['style'] = reactStyleObject;\n    } else {\n      acc[attribute] = el.getAttribute(attribute);\n    }\n  }\n  return acc;\n};\n\nconst attributes = ['border', 'cellpadding', 'cellspacing', 'class', 'style'];\n\n/**\n * Serializer rules.\n *\n * @type {Array}\n */\n\nconst blocks = {\n  deserialize(el, next) {\n    log('[blocks:deserialize] block: ', el);\n    const block = BLOCK_TAGS[el.tagName.toLowerCase()];\n    if (!block) return;\n    log('[blocks:deserialize] block: ', block);\n\n    if (el.childNodes.length === 1) {\n      const cn = el.childNodes[0];\n      if (cn && cn.tagName && cn.tagName.toLowerCase() === block) {\n        log('[we have a child node of the same]...');\n        return;\n      }\n    }\n\n    return {\n      object: 'block',\n      type: block,\n      /**\n       * Here for rendering styles for all block elements\n       */\n      data: { attributes: attributes.reduce(attributesToMap(el), {}) },\n      nodes: next(el.childNodes)\n    };\n  },\n  serialize: (object, children) => {\n    if (object.object !== 'block') return;\n\n    const jsonData = object.data.toJSON();\n\n    log('[blocks:serialize] object: ', object, children);\n    let key;\n\n    for (key in BLOCK_TAGS) {\n      if (BLOCK_TAGS[key] === object.type) {\n        const Tag = key;\n\n        return <Tag {...jsonData.attributes}>{children}</Tag>;\n      }\n    }\n  }\n};\n\nconst marks = {\n  deserialize(el, next) {\n    const mark = MARK_TAGS[el.tagName.toLowerCase()];\n    if (!mark) return;\n    log('[deserialize] mark: ', mark);\n    return {\n      object: 'mark',\n      type: mark,\n      nodes: next(el.childNodes)\n    };\n  },\n  serialize(object, children) {\n    if (Mark.isMark(object)) {\n      for (var key in MARK_TAGS) {\n        if (MARK_TAGS[key] === object.type) {\n          const Tag = key;\n          return <Tag>{children}</Tag>;\n        }\n      }\n    }\n  }\n};\n\nconst findPreviousText = el => {\n  if (el.nodeName === '#text') {\n    return el;\n  }\n\n  if (el.previousSibling) {\n    return findPreviousText(el.previousSibling);\n  }\n\n  return null;\n};\n\nexport const TEXT_RULE = {\n  deserialize(el) {\n    /**\n     * This needs to be called on the dom element in order to merge the adjacent text nodes together\n     * */\n    el.normalize();\n\n    if (el.tagName && el.tagName.toLowerCase() === 'br') {\n      return {\n        object: 'text',\n        leaves: [\n          {\n            object: 'leaf',\n            text: '\\n'\n          }\n        ]\n      };\n    }\n\n    if (el.nodeName === '#text') {\n      if (el.nodeValue && el.nodeValue.match(/<!--.*?-->/)) return;\n\n      log('[text:deserialize] return text object..');\n      return {\n        object: 'text',\n        leaves: [\n          {\n            object: 'leaf',\n            text: el.nodeValue\n          }\n        ]\n      };\n    }\n  },\n\n  serialize(obj, children) {\n    if (obj.object === 'string') {\n      return children.split('\\n').reduce((array, text, i) => {\n        if (i !== 0) array.push(<br />);\n        array.push(text);\n        return array;\n      }, []);\n    }\n  }\n};\n\nconst RULES = [\n  listSerialization,\n  mathSerialization,\n  mediaSerialization,\n  imgSerialization,\n  tableSerialization,\n  responseAreaSerialization,\n  TEXT_RULE,\n  blocks,\n  marks\n];\n\nfunction allWhitespace(node) {\n  // Use ECMA-262 Edition 3 String and RegExp features\n  return !/[^\\t\\n\\r ]/.test(node.textContent);\n}\n\nfunction defaultParseHtml(html) {\n  if (typeof DOMParser === 'undefined') {\n    throw new Error(\n      'The native `DOMParser` global which the `Html` serializer uses by default is not present in this environment. You must supply the `options.parseHtml` function instead.'\n    );\n  }\n\n  const parsed = new DOMParser().parseFromString(html, 'text/html');\n\n  const { body } = parsed;\n  const textNodes = document.createTreeWalker(body, NodeFilter.SHOW_TEXT, null, null);\n  let n = textNodes.nextNode();\n\n  while (n) {\n    if (allWhitespace(n) || n.nodeValue === '\\u200B') {\n      n.parentNode.removeChild(n);\n    }\n    n = textNodes.nextNode();\n  }\n\n  return body;\n}\n\n/** If this lib is used on the server side, we need to bypass using the DOMParser - just put in a stub. */\nconst parseHtml =\n  typeof window === 'undefined'\n    ? () => ({\n        childNodes: []\n      })\n    : defaultParseHtml;\n\nconst serializer = new Html({\n  defaultBlock: 'div',\n  rules: RULES,\n  parseHtml\n});\n\nconst _extends =\n  Object.assign ||\n  function(target) {\n    for (var i = 1; i < arguments.length; i++) {\n      var source = arguments[i];\n\n      for (var key in source) {\n        if (Object.prototype.hasOwnProperty.call(source, key)) {\n          target[key] = source[key];\n        }\n      }\n    }\n\n    return target;\n  };\n\nexport const htmlToValue = html => {\n  try {\n    return serializer.deserialize(html);\n  } catch (e) {\n    console.log(\"Couldn't parse html: \", e);\n    return {};\n  }\n};\n\nexport const valueToHtml = value => serializer.serialize(value);\n\n/**\n *\n * <div><div>a</div></div> -> <div>a</div>\n *\n * <div><div>a</div><div>b</div></div> -> <div>a</div><div>b</div>\n * <div><div>a</div>4444<div>b</div></div> -> <div>a</div>4444<div>b</div>\n */\n"],"mappings":"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"}
|
package/lib/parse-html.js
CHANGED
|
@@ -13,4 +13,4 @@ var parseDegrees = function parseDegrees(html) {
|
|
|
13
13
|
};
|
|
14
14
|
|
|
15
15
|
exports.parseDegrees = parseDegrees;
|
|
16
|
-
//# sourceMappingURL=
|
|
16
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJwYXJzZURlZ3JlZXMiLCJodG1sIiwicmVwbGFjZSJdLCJzb3VyY2VzIjpbIi4uL3NyYy9wYXJzZS1odG1sLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBwYXJzZURlZ3JlZXMgPSBodG1sID0+XG4gIGh0bWxcbiAgICAvLyByZW1vdmVzIFxcKCAgIHVzZSBjYXNlOiA1MMKwXG4gICAgLnJlcGxhY2UoL1xcXFxbKF0vZywgJycpXG4gICAgLy8gcmVtb3ZlcyBcXCkgICB1c2UgY2FzZTogNTDCsCttPDFcbiAgICAucmVwbGFjZSgvXFxcXFspXS9nLCAnJylcbiAgICAvLyByZW1vdmVzIFxcZGVncmVlICB1c2UgY2FzZTogNTDCsFxuICAgIC5yZXBsYWNlKC9cXFxcZGVncmVlL2csICcmZGVnOycpO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQU8sSUFBTUEsWUFBWSxHQUFHLFNBQWZBLFlBQWUsQ0FBQUMsSUFBSTtFQUFBLE9BQzlCQSxJQUFJLENBQ0Y7RUFERSxDQUVEQyxPQUZILENBRVcsUUFGWCxFQUVxQixFQUZyQixFQUdFO0VBSEYsQ0FJR0EsT0FKSCxDQUlXLFFBSlgsRUFJcUIsRUFKckIsRUFLRTtFQUxGLENBTUdBLE9BTkgsQ0FNVyxXQU5YLEVBTXdCLE9BTnhCLENBRDhCO0FBQUEsQ0FBekIifQ==
|
package/lib/parse-html.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"parse-html.js","names":["parseDegrees","html","replace"],"sources":["../src/parse-html.js"],"sourcesContent":["export const parseDegrees = html =>\n html\n // removes \\( use case: 50°\n .replace(/\\\\[(]/g, '')\n // removes \\) use case: 50°+m<1\n .replace(/\\\\[)]/g, '')\n // removes \\degree use case: 50°\n .replace(/\\\\degree/g, '°');\n"],"mappings":";;;;;;;AAAO,IAAMA,YAAY,GAAG,SAAfA,YAAe,CAAAC,IAAI;EAAA,OAC9BA,IAAI,CACF;EADE,CAEDC,OAFH,CAEW,QAFX,EAEqB,EAFrB,EAGE;EAHF,CAIGA,OAJH,CAIW,QAJX,EAIqB,EAJrB,EAKE;EALF,CAMGA,OANH,CAMW,WANX,EAMwB,OANxB,CAD8B;AAAA,CAAzB"}
|
|
@@ -70,4 +70,4 @@ var CustomPopper = (0, _styles.withStyles)(styles)(function (_ref) {
|
|
|
70
70
|
});
|
|
71
71
|
var _default = CustomPopper;
|
|
72
72
|
exports["default"] = _default;
|
|
73
|
-
//# sourceMappingURL=
|
|
73
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzdHlsZXMiLCJwb3BvdmVyIiwiYmFja2dyb3VuZCIsInBhZGRpbmciLCJwb2ludGVyRXZlbnRzIiwiekluZGV4IiwicGFwZXIiLCJoZWlnaHQiLCJ3aWR0aCIsInR5cG9ncmFwaHkiLCJmb250U2l6ZSIsInRleHRBbGlnbiIsIkN1c3RvbVBvcHBlciIsIndpdGhTdHlsZXMiLCJjbGFzc2VzIiwiY2hpbGRyZW4iLCJwcm9wcyIsInZlcnRpY2FsIiwiaG9yaXpvbnRhbCIsInJvb3QiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcGx1Z2lucy9jaGFyYWN0ZXJzL2N1c3RvbS1wb3BwZXIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHdpdGhTdHlsZXMgfSBmcm9tICdAbWF0ZXJpYWwtdWkvY29yZS9zdHlsZXMnO1xuaW1wb3J0IFBvcHBlciBmcm9tICdAbWF0ZXJpYWwtdWkvY29yZS9Qb3BwZXInO1xuaW1wb3J0IFR5cG9ncmFwaHkgZnJvbSAnQG1hdGVyaWFsLXVpL2NvcmUvVHlwb2dyYXBoeSc7XG5cbmNvbnN0IHN0eWxlcyA9ICgpID0+ICh7XG4gIHBvcG92ZXI6IHtcbiAgICBiYWNrZ3JvdW5kOiAnI2ZmZicsXG4gICAgcGFkZGluZzogJzEwcHgnLFxuICAgIHBvaW50ZXJFdmVudHM6ICdub25lJyxcbiAgICB6SW5kZXg6IDk5OTk5XG4gIH0sXG4gIHBhcGVyOiB7XG4gICAgcGFkZGluZzogMjAsXG4gICAgaGVpZ2h0OiAnYXV0bycsXG4gICAgd2lkdGg6ICdhdXRvJ1xuICB9LFxuICB0eXBvZ3JhcGh5OiB7XG4gICAgZm9udFNpemU6IDUwLFxuICAgIHRleHRBbGlnbjogJ2NlbnRlcidcbiAgfVxufSk7XG5cbmNvbnN0IEN1c3RvbVBvcHBlciA9IHdpdGhTdHlsZXMoc3R5bGVzKSgoeyBjbGFzc2VzLCBjaGlsZHJlbiwgLi4ucHJvcHMgfSkgPT4gKFxuICA8UG9wcGVyXG4gICAgaWQ9XCJtb3VzZS1vdmVyLXBvcG92ZXJcIlxuICAgIG9wZW5cbiAgICBjbGFzc05hbWU9e2NsYXNzZXMucG9wb3Zlcn1cbiAgICBjbGFzc2VzPXt7XG4gICAgICBwYXBlcjogY2xhc3Nlcy5wYXBlclxuICAgIH19XG4gICAgYW5jaG9yT3JpZ2luPXt7XG4gICAgICB2ZXJ0aWNhbDogJ2JvdHRvbScsXG4gICAgICBob3Jpem9udGFsOiAnbGVmdCdcbiAgICB9fVxuICAgIHRyYW5zZm9ybU9yaWdpbj17e1xuICAgICAgdmVydGljYWw6ICd0b3AnLFxuICAgICAgaG9yaXpvbnRhbDogJ2xlZnQnXG4gICAgfX1cbiAgICBkaXNhYmxlUmVzdG9yZUZvY3VzXG4gICAgZGlzYWJsZUF1dG9Gb2N1c1xuICAgIHsuLi5wcm9wc31cbiAgPlxuICAgIDxUeXBvZ3JhcGh5IGNsYXNzZXM9e3sgcm9vdDogY2xhc3Nlcy50eXBvZ3JhcGh5IH19PntjaGlsZHJlbn08L1R5cG9ncmFwaHk+XG4gIDwvUG9wcGVyPlxuKSk7XG5cbmV4cG9ydCBkZWZhdWx0IEN1c3RvbVBvcHBlcjtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOzs7O0FBRUEsSUFBTUEsTUFBTSxHQUFHLFNBQVRBLE1BQVM7RUFBQSxPQUFPO0lBQ3BCQyxPQUFPLEVBQUU7TUFDUEMsVUFBVSxFQUFFLE1BREw7TUFFUEMsT0FBTyxFQUFFLE1BRkY7TUFHUEMsYUFBYSxFQUFFLE1BSFI7TUFJUEMsTUFBTSxFQUFFO0lBSkQsQ0FEVztJQU9wQkMsS0FBSyxFQUFFO01BQ0xILE9BQU8sRUFBRSxFQURKO01BRUxJLE1BQU0sRUFBRSxNQUZIO01BR0xDLEtBQUssRUFBRTtJQUhGLENBUGE7SUFZcEJDLFVBQVUsRUFBRTtNQUNWQyxRQUFRLEVBQUUsRUFEQTtNQUVWQyxTQUFTLEVBQUU7SUFGRDtFQVpRLENBQVA7QUFBQSxDQUFmOztBQWtCQSxJQUFNQyxZQUFZLEdBQUcsSUFBQUMsa0JBQUEsRUFBV2IsTUFBWCxFQUFtQjtFQUFBLElBQUdjLE9BQUgsUUFBR0EsT0FBSDtFQUFBLElBQVlDLFFBQVosUUFBWUEsUUFBWjtFQUFBLElBQXlCQyxLQUF6QjtFQUFBLG9CQUN0QyxnQ0FBQyxrQkFBRDtJQUNFLEVBQUUsRUFBQyxvQkFETDtJQUVFLElBQUksTUFGTjtJQUdFLFNBQVMsRUFBRUYsT0FBTyxDQUFDYixPQUhyQjtJQUlFLE9BQU8sRUFBRTtNQUNQSyxLQUFLLEVBQUVRLE9BQU8sQ0FBQ1I7SUFEUixDQUpYO0lBT0UsWUFBWSxFQUFFO01BQ1pXLFFBQVEsRUFBRSxRQURFO01BRVpDLFVBQVUsRUFBRTtJQUZBLENBUGhCO0lBV0UsZUFBZSxFQUFFO01BQ2ZELFFBQVEsRUFBRSxLQURLO01BRWZDLFVBQVUsRUFBRTtJQUZHLENBWG5CO0lBZUUsbUJBQW1CLE1BZnJCO0lBZ0JFLGdCQUFnQjtFQWhCbEIsR0FpQk1GLEtBakJOLGdCQW1CRSxnQ0FBQyxzQkFBRDtJQUFZLE9BQU8sRUFBRTtNQUFFRyxJQUFJLEVBQUVMLE9BQU8sQ0FBQ0w7SUFBaEI7RUFBckIsR0FBb0RNLFFBQXBELENBbkJGLENBRHNDO0FBQUEsQ0FBbkIsQ0FBckI7ZUF3QmVILFkifQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"custom-popper.js","names":["styles","popover","background","padding","pointerEvents","zIndex","paper","height","width","typography","fontSize","textAlign","CustomPopper","withStyles","classes","children","props","vertical","horizontal","root"],"sources":["../../../src/plugins/characters/custom-popper.js"],"sourcesContent":["import React from 'react';\nimport { withStyles } from '@material-ui/core/styles';\nimport Popper from '@material-ui/core/Popper';\nimport Typography from '@material-ui/core/Typography';\n\nconst styles = () => ({\n popover: {\n background: '#fff',\n padding: '10px',\n pointerEvents: 'none',\n zIndex: 99999\n },\n paper: {\n padding: 20,\n height: 'auto',\n width: 'auto'\n },\n typography: {\n fontSize: 50,\n textAlign: 'center'\n }\n});\n\nconst CustomPopper = withStyles(styles)(({ classes, children, ...props }) => (\n <Popper\n id=\"mouse-over-popover\"\n open\n className={classes.popover}\n classes={{\n paper: classes.paper\n }}\n anchorOrigin={{\n vertical: 'bottom',\n horizontal: 'left'\n }}\n transformOrigin={{\n vertical: 'top',\n horizontal: 'left'\n }}\n disableRestoreFocus\n disableAutoFocus\n {...props}\n >\n <Typography classes={{ root: classes.typography }}>{children}</Typography>\n </Popper>\n));\n\nexport default CustomPopper;\n"],"mappings":";;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;;;AAEA,IAAMA,MAAM,GAAG,SAATA,MAAS;EAAA,OAAO;IACpBC,OAAO,EAAE;MACPC,UAAU,EAAE,MADL;MAEPC,OAAO,EAAE,MAFF;MAGPC,aAAa,EAAE,MAHR;MAIPC,MAAM,EAAE;IAJD,CADW;IAOpBC,KAAK,EAAE;MACLH,OAAO,EAAE,EADJ;MAELI,MAAM,EAAE,MAFH;MAGLC,KAAK,EAAE;IAHF,CAPa;IAYpBC,UAAU,EAAE;MACVC,QAAQ,EAAE,EADA;MAEVC,SAAS,EAAE;IAFD;EAZQ,CAAP;AAAA,CAAf;;AAkBA,IAAMC,YAAY,GAAG,IAAAC,kBAAA,EAAWb,MAAX,EAAmB;EAAA,IAAGc,OAAH,QAAGA,OAAH;EAAA,IAAYC,QAAZ,QAAYA,QAAZ;EAAA,IAAyBC,KAAzB;EAAA,oBACtC,gCAAC,kBAAD;IACE,EAAE,EAAC,oBADL;IAEE,IAAI,MAFN;IAGE,SAAS,EAAEF,OAAO,CAACb,OAHrB;IAIE,OAAO,EAAE;MACPK,KAAK,EAAEQ,OAAO,CAACR;IADR,CAJX;IAOE,YAAY,EAAE;MACZW,QAAQ,EAAE,QADE;MAEZC,UAAU,EAAE;IAFA,CAPhB;IAWE,eAAe,EAAE;MACfD,QAAQ,EAAE,KADK;MAEfC,UAAU,EAAE;IAFG,CAXnB;IAeE,mBAAmB,MAfrB;IAgBE,gBAAgB;EAhBlB,GAiBMF,KAjBN,gBAmBE,gCAAC,sBAAD;IAAY,OAAO,EAAE;MAAEG,IAAI,EAAEL,OAAO,CAACL;IAAhB;EAArB,GAAoDM,QAApD,CAnBF,CADsC;AAAA,CAAnB,CAArB;eAwBeH,Y"}
|
|
@@ -8,6 +8,8 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
8
8
|
exports["default"] = CharactersPlugin;
|
|
9
9
|
exports.removeDialogs = void 0;
|
|
10
10
|
|
|
11
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
12
|
+
|
|
11
13
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
12
14
|
|
|
13
15
|
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
@@ -28,6 +30,10 @@ var _utils = require("../respArea/utils");
|
|
|
28
30
|
|
|
29
31
|
var _utils2 = require("./utils");
|
|
30
32
|
|
|
33
|
+
var _slateReact = require("slate-react");
|
|
34
|
+
|
|
35
|
+
var _slate = require("slate");
|
|
36
|
+
|
|
31
37
|
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; }
|
|
32
38
|
|
|
33
39
|
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; }
|
|
@@ -54,8 +60,7 @@ var removeDialogs = function removeDialogs() {
|
|
|
54
60
|
exports.removeDialogs = removeDialogs;
|
|
55
61
|
|
|
56
62
|
var insertDialog = function insertDialog(_ref) {
|
|
57
|
-
var
|
|
58
|
-
value = _ref.value,
|
|
63
|
+
var editor = _ref.editor,
|
|
59
64
|
callback = _ref.callback,
|
|
60
65
|
opts = _ref.opts;
|
|
61
66
|
var newEl = document.createElement('div');
|
|
@@ -134,6 +139,9 @@ var insertDialog = function insertDialog(_ref) {
|
|
|
134
139
|
// so right after mouseup, the click will be triggered
|
|
135
140
|
if (firstCallMade) {
|
|
136
141
|
var focusIsInModals = newEl.contains(e.target) || popoverEl && popoverEl.contains(e.target);
|
|
142
|
+
|
|
143
|
+
var editorDOM = _slateReact.ReactEditor.toDOMNode(editor, editor);
|
|
144
|
+
|
|
137
145
|
var focusIsInEditor = editorDOM.contains(e.target);
|
|
138
146
|
|
|
139
147
|
if (!(focusIsInModals || focusIsInEditor)) {
|
|
@@ -193,7 +201,11 @@ var insertDialog = function insertDialog(_ref) {
|
|
|
193
201
|
});
|
|
194
202
|
|
|
195
203
|
_reactDom["default"].render(el, newEl, function () {
|
|
196
|
-
var
|
|
204
|
+
var _Editor$node = _slate.Editor.node(editor, editor.selection),
|
|
205
|
+
_Editor$node2 = (0, _slicedToArray2["default"])(_Editor$node, 1),
|
|
206
|
+
nodeAtSelection = _Editor$node2[0];
|
|
207
|
+
|
|
208
|
+
var cursorItem = _slateReact.ReactEditor.toDOMNode(editor, nodeAtSelection);
|
|
197
209
|
|
|
198
210
|
if (cursorItem) {
|
|
199
211
|
var bodyRect = document.body.getBoundingClientRect();
|
|
@@ -241,32 +253,22 @@ function CharactersPlugin(opts) {
|
|
|
241
253
|
icon: /*#__PURE__*/_react["default"].createElement(CharacterIcon, {
|
|
242
254
|
letter: opts.characterIcon || _utils2.characterIcons[opts.language] || 'ñ'
|
|
243
255
|
}),
|
|
244
|
-
onClick: function onClick(
|
|
245
|
-
var editorDOM = document.querySelector("[data-key=\"".concat(value.document.key, "\"]"));
|
|
246
|
-
var valueToUse = value;
|
|
247
|
-
|
|
256
|
+
onClick: function onClick(editor) {
|
|
248
257
|
var callback = function callback(_char, focus) {
|
|
249
|
-
valueToUse = getFocusedValue();
|
|
250
|
-
|
|
251
258
|
if (_char) {
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
log('[characters:insert]: ', value);
|
|
255
|
-
onChange(change);
|
|
259
|
+
log('[characters:insert]: ', _char);
|
|
260
|
+
editor.insertText(_char);
|
|
256
261
|
}
|
|
257
262
|
|
|
258
263
|
log('[characters:click]');
|
|
259
264
|
|
|
260
265
|
if (focus) {
|
|
261
|
-
|
|
262
|
-
editorDOM.focus();
|
|
263
|
-
}
|
|
266
|
+
_slateReact.ReactEditor.focus(editor);
|
|
264
267
|
}
|
|
265
268
|
};
|
|
266
269
|
|
|
267
270
|
insertDialog({
|
|
268
|
-
|
|
269
|
-
value: valueToUse,
|
|
271
|
+
editor: editor,
|
|
270
272
|
callback: callback,
|
|
271
273
|
opts: opts
|
|
272
274
|
});
|
|
@@ -282,4 +284,4 @@ function CharactersPlugin(opts) {
|
|
|
282
284
|
}
|
|
283
285
|
};
|
|
284
286
|
}
|
|
285
|
-
//# sourceMappingURL=index.js.map
|
|
287
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["log","debug","removePopOvers","prevPopOvers","document","querySelectorAll","forEach","s","remove","removeDialogs","prevDialogs","insertDialog","editor","callback","opts","newEl","createElement","className","configToUse","language","spanishConfig","specialConfig","characters","insertSnackBar","layoutForCharacters","reduce","obj","arr","length","columns","rows","popoverEl","closePopOver","renderPopOver","event","el","infoStyle","fontSize","lineHeight","ReactDOM","render","currentTarget","label","description","unicode","body","appendChild","firstCallMade","listener","e","focusIsInModals","contains","target","editorDOM","ReactEditor","toDOMNode","focusIsInEditor","handleClose","undefined","removeEventListener","handleChange","val","n","map","k","name","get","write","category","extraClass","extraProps","style","border","hasPreview","actions","onMouseEnter","ev","onMouseLeave","Editor","node","selection","nodeAtSelection","cursorItem","bodyRect","getBoundingClientRect","boundRect","position","top","Math","abs","offsetHeight","zIndex","leftValue","left","offsetWidth","rightValue","x","leftAlignedWidth","right","rightAlignedWidth","addEventListener","CharacterIcon","letter","CharactersPlugin","toolbar","icon","characterIcon","characterIcons","onClick","char","focus","insertText","pluginStyles","parentNode","p"],"sources":["../../../src/plugins/characters/index.jsx"],"sourcesContent":["import React from 'react';\nimport ReactDOM from 'react-dom';\nimport debug from 'debug';\nimport get from 'lodash/get';\n\nimport { PureToolbar } from '@pie-lib/math-toolbar';\n\nimport CustomPopper from './custom-popper';\nimport { insertSnackBar } from '../respArea/utils';\nimport { characterIcons, spanishConfig, specialConfig } from './utils';\nimport { ReactEditor } from 'slate-react';\nimport { Editor } from 'slate';\nconst log = debug('@pie-lib:editable-html:plugins:characters');\n\nconst removePopOvers = () => {\n  const prevPopOvers = document.querySelectorAll('#mouse-over-popover');\n\n  log('[characters:removePopOvers]');\n  prevPopOvers.forEach(s => s.remove());\n};\n\nexport const removeDialogs = () => {\n  const prevDialogs = document.querySelectorAll('.insert-character-dialog');\n\n  log('[characters:removeDialogs]');\n  prevDialogs.forEach(s => s.remove());\n  removePopOvers();\n};\n\nconst insertDialog = ({ editor, callback, opts }) => {\n  const newEl = document.createElement('div');\n\n  log('[characters:insertDialog]');\n\n  removeDialogs();\n\n  newEl.className = 'insert-character-dialog';\n\n  let configToUse;\n\n  switch (true) {\n    case opts.language === 'spanish':\n      configToUse = spanishConfig;\n      break;\n    case opts.language === 'special':\n      configToUse = specialConfig;\n      break;\n    default:\n      configToUse = opts;\n  }\n\n  if (!configToUse.characters) {\n    insertSnackBar('No characters provided or language not recognized');\n    return;\n  }\n\n  const layoutForCharacters = configToUse.characters.reduce(\n    (obj, arr) => {\n      if (arr.length >= obj.columns) {\n        obj.columns = arr.length;\n      }\n\n      return obj;\n    },\n    { rows: configToUse.characters.length, columns: 0 }\n  );\n\n  let popoverEl;\n\n  const closePopOver = () => {\n    if (popoverEl) {\n      popoverEl.remove();\n    }\n\n    removePopOvers();\n  };\n\n  const renderPopOver = (event, el) => {\n    if (!event) {\n      return;\n    }\n\n    const infoStyle = { fontSize: '20px', lineHeight: '20px' };\n\n    closePopOver();\n\n    popoverEl = document.createElement('div');\n    ReactDOM.render(\n      <CustomPopper onClose={closePopOver} anchorEl={event.currentTarget}>\n        <div>{el.label}</div>\n\n        <div style={infoStyle}>{el.description}</div>\n\n        <div style={infoStyle}>{el.unicode}</div>\n      </CustomPopper>,\n      popoverEl\n    );\n\n    document.body.appendChild(newEl);\n  };\n\n  let firstCallMade = false;\n\n  const listener = e => {\n    // this will be triggered right after setting it because\n    // this toolbar is added on the mousedown event\n    // so right after mouseup, the click will be triggered\n    if (firstCallMade) {\n      const focusIsInModals =\n        newEl.contains(e.target) || (popoverEl && popoverEl.contains(e.target));\n      const editorDOM = ReactEditor.toDOMNode(editor, editor);\n      const focusIsInEditor = editorDOM.contains(e.target);\n\n      if (!(focusIsInModals || focusIsInEditor)) {\n        handleClose();\n      }\n    } else {\n      firstCallMade = true;\n    }\n  };\n\n  const handleClose = () => {\n    callback(undefined, true);\n    newEl.remove();\n    closePopOver();\n    document.body.removeEventListener('click', listener);\n  };\n\n  const handleChange = val => {\n    if (typeof val === 'string') {\n      callback(val, true);\n    }\n  };\n\n  const el = (\n    <PureToolbar\n      autoFocus\n      noDecimal\n      hideInput\n      noLatexHandling\n      layoutForKeyPad={layoutForCharacters}\n      additionalKeys={configToUse.characters.reduce((arr, n) => {\n        arr = [\n          ...arr,\n          ...n.map(k => ({\n            name: get(k, 'name') || k,\n            write: get(k, 'write') || k,\n            label: get(k, 'label') || k,\n            category: 'character',\n            extraClass: 'character',\n            extraProps: {\n              ...(k.extraProps || {}),\n              style: {\n                ...(k.extraProps || {}).style,\n                border: '1px solid #000'\n              }\n            },\n            ...(configToUse.hasPreview\n              ? {\n                  actions: { onMouseEnter: ev => renderPopOver(ev, k), onMouseLeave: closePopOver }\n                }\n              : {})\n          }))\n        ];\n\n        return arr;\n      }, [])}\n      keypadMode=\"language\"\n      onChange={handleChange}\n      onDone={handleClose}\n    />\n  );\n\n  ReactDOM.render(el, newEl, () => {\n    const [nodeAtSelection] = Editor.node(editor, editor.selection);\n    const cursorItem = ReactEditor.toDOMNode(editor, nodeAtSelection);\n\n    if (cursorItem) {\n      const bodyRect = document.body.getBoundingClientRect();\n      const boundRect = cursorItem.getBoundingClientRect();\n\n      document.body.appendChild(newEl);\n      newEl.style.position = 'absolute';\n      newEl.style.top = `${boundRect.top + Math.abs(bodyRect.top) - newEl.offsetHeight - 10}px`;\n      newEl.style.zIndex = 99999;\n\n      const leftValue = `${boundRect.left +\n        Math.abs(bodyRect.left) +\n        cursorItem.offsetWidth +\n        10}px`;\n\n      const rightValue = `${boundRect.x}px`;\n\n      newEl.style.left = leftValue;\n\n      const leftAlignedWidth = newEl.offsetWidth;\n\n      newEl.style.left = 'unset';\n      newEl.style.right = rightValue;\n\n      const rightAlignedWidth = newEl.offsetWidth;\n\n      newEl.style.left = 'unset';\n      newEl.style.right = 'unset';\n\n      if (leftAlignedWidth >= rightAlignedWidth) {\n        newEl.style.left = leftValue;\n      } else {\n        newEl.style.right = rightValue;\n      }\n\n      document.body.addEventListener('click', listener);\n    }\n  });\n};\n\nconst CharacterIcon = ({ letter }) => (\n  <div\n    style={{\n      fontSize: '25px',\n      lineHeight: '15px'\n    }}\n  >\n    {letter}\n  </div>\n);\n\nexport default function CharactersPlugin(opts) {\n  removeDialogs();\n  return {\n    name: 'characters',\n    toolbar: {\n      icon: <CharacterIcon letter={opts.characterIcon || characterIcons[opts.language] || 'ñ'} />,\n      onClick: editor => {\n        const callback = (char, focus) => {\n          if (char) {\n            log('[characters:insert]: ', char);\n            editor.insertText(char);\n          }\n\n          log('[characters:click]');\n\n          if (focus) {\n            ReactEditor.focus(editor);\n          }\n        };\n\n        insertDialog({ editor, callback, opts });\n      }\n    },\n\n    pluginStyles: (node, parentNode, p) => {\n      if (p) {\n        return {\n          position: 'absolute',\n          top: 'initial'\n        };\n      }\n    }\n  };\n}\n"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/plugins/characters/index.jsx"],"names":["log","removePopOvers","prevPopOvers","document","querySelectorAll","forEach","s","remove","removeDialogs","prevDialogs","insertDialog","editorDOM","value","callback","opts","newEl","createElement","className","configToUse","language","spanishConfig","specialConfig","characters","layoutForCharacters","reduce","obj","arr","length","columns","rows","popoverEl","closePopOver","renderPopOver","event","el","infoStyle","fontSize","lineHeight","ReactDOM","render","currentTarget","label","description","unicode","body","appendChild","firstCallMade","listener","e","focusIsInModals","contains","target","focusIsInEditor","handleClose","undefined","removeEventListener","handleChange","val","n","map","k","name","write","category","extraClass","extraProps","style","border","hasPreview","actions","onMouseEnter","ev","onMouseLeave","cursorItem","querySelector","anchorKey","bodyRect","getBoundingClientRect","boundRect","position","top","Math","abs","offsetHeight","zIndex","leftValue","left","offsetWidth","rightValue","x","leftAlignedWidth","right","rightAlignedWidth","addEventListener","CharacterIcon","letter","CharactersPlugin","toolbar","icon","characterIcon","characterIcons","onClick","onChange","getFocusedValue","key","valueToUse","char","focus","change","insertTextByKey","anchorOffset","pluginStyles","node","parentNode","p"],"mappings":"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","sourcesContent":["import React from 'react';\nimport ReactDOM from 'react-dom';\nimport debug from 'debug';\nimport get from 'lodash/get';\n\nimport { PureToolbar } from '@pie-lib/math-toolbar';\n\nimport CustomPopper from './custom-popper';\nimport { insertSnackBar } from '../respArea/utils';\nimport { characterIcons, spanishConfig, specialConfig } from './utils';\nconst log = debug('@pie-lib:editable-html:plugins:characters');\n\nconst removePopOvers = () => {\n const prevPopOvers = document.querySelectorAll('#mouse-over-popover');\n\n log('[characters:removePopOvers]');\n prevPopOvers.forEach((s) => s.remove());\n};\n\nexport const removeDialogs = () => {\n const prevDialogs = document.querySelectorAll('.insert-character-dialog');\n\n log('[characters:removeDialogs]');\n prevDialogs.forEach((s) => s.remove());\n removePopOvers();\n};\n\nconst insertDialog = ({ editorDOM, value, callback, opts }) => {\n const newEl = document.createElement('div');\n\n log('[characters:insertDialog]');\n\n removeDialogs();\n\n newEl.className = 'insert-character-dialog';\n\n let configToUse;\n\n switch (true) {\n case opts.language === 'spanish':\n configToUse = spanishConfig;\n break;\n case opts.language === 'special':\n configToUse = specialConfig;\n break;\n default:\n configToUse = opts;\n }\n\n if (!configToUse.characters) {\n insertSnackBar('No characters provided or language not recognized');\n return;\n }\n\n const layoutForCharacters = configToUse.characters.reduce(\n (obj, arr) => {\n if (arr.length >= obj.columns) {\n obj.columns = arr.length;\n }\n\n return obj;\n },\n { rows: configToUse.characters.length, columns: 0 },\n );\n\n let popoverEl;\n\n const closePopOver = () => {\n if (popoverEl) {\n popoverEl.remove();\n }\n\n removePopOvers();\n };\n\n const renderPopOver = (event, el) => {\n if (!event) {\n return;\n }\n\n const infoStyle = { fontSize: '20px', lineHeight: '20px' };\n\n closePopOver();\n\n popoverEl = document.createElement('div');\n ReactDOM.render(\n <CustomPopper onClose={closePopOver} anchorEl={event.currentTarget}>\n <div>{el.label}</div>\n\n <div style={infoStyle}>{el.description}</div>\n\n <div style={infoStyle}>{el.unicode}</div>\n </CustomPopper>,\n popoverEl,\n );\n\n document.body.appendChild(newEl);\n };\n\n let firstCallMade = false;\n\n const listener = (e) => {\n // this will be triggered right after setting it because\n // this toolbar is added on the mousedown event\n // so right after mouseup, the click will be triggered\n if (firstCallMade) {\n const focusIsInModals = newEl.contains(e.target) || (popoverEl && popoverEl.contains(e.target));\n const focusIsInEditor = editorDOM.contains(e.target);\n\n if (!(focusIsInModals || focusIsInEditor)) {\n handleClose();\n }\n } else {\n firstCallMade = true;\n }\n };\n\n const handleClose = () => {\n callback(undefined, true);\n newEl.remove();\n closePopOver();\n document.body.removeEventListener('click', listener);\n };\n\n const handleChange = (val) => {\n if (typeof val === 'string') {\n callback(val, true);\n }\n };\n\n const el = (\n <PureToolbar\n autoFocus\n noDecimal\n hideInput\n noLatexHandling\n layoutForKeyPad={layoutForCharacters}\n additionalKeys={configToUse.characters.reduce((arr, n) => {\n arr = [\n ...arr,\n ...n.map((k) => ({\n name: get(k, 'name') || k,\n write: get(k, 'write') || k,\n label: get(k, 'label') || k,\n category: 'character',\n extraClass: 'character',\n extraProps: {\n ...(k.extraProps || {}),\n style: {\n ...(k.extraProps || {}).style,\n border: '1px solid #000',\n },\n },\n ...(configToUse.hasPreview\n ? {\n actions: { onMouseEnter: (ev) => renderPopOver(ev, k), onMouseLeave: closePopOver },\n }\n : {}),\n })),\n ];\n\n return arr;\n }, [])}\n keypadMode=\"language\"\n onChange={handleChange}\n onDone={handleClose}\n />\n );\n\n ReactDOM.render(el, newEl, () => {\n const cursorItem = document.querySelector(`[data-key=\"${value.anchorKey}\"]`);\n\n if (cursorItem) {\n const bodyRect = document.body.getBoundingClientRect();\n const boundRect = cursorItem.getBoundingClientRect();\n\n document.body.appendChild(newEl);\n newEl.style.position = 'absolute';\n newEl.style.top = `${boundRect.top + Math.abs(bodyRect.top) - newEl.offsetHeight - 10}px`;\n newEl.style.zIndex = 99999;\n\n const leftValue = `${boundRect.left + Math.abs(bodyRect.left) + cursorItem.offsetWidth + 10}px`;\n\n const rightValue = `${boundRect.x}px`;\n\n newEl.style.left = leftValue;\n\n const leftAlignedWidth = newEl.offsetWidth;\n\n newEl.style.left = 'unset';\n newEl.style.right = rightValue;\n\n const rightAlignedWidth = newEl.offsetWidth;\n\n newEl.style.left = 'unset';\n newEl.style.right = 'unset';\n\n if (leftAlignedWidth >= rightAlignedWidth) {\n newEl.style.left = leftValue;\n } else {\n newEl.style.right = rightValue;\n }\n\n document.body.addEventListener('click', listener);\n }\n });\n};\n\nconst CharacterIcon = ({ letter }) => (\n <div\n style={{\n fontSize: '25px',\n lineHeight: '15px',\n }}\n >\n {letter}\n </div>\n);\n\nexport default function CharactersPlugin(opts) {\n removeDialogs();\n return {\n name: 'characters',\n toolbar: {\n icon: <CharacterIcon letter={opts.characterIcon || characterIcons[opts.language] || 'ñ'} />,\n onClick: (value, onChange, getFocusedValue) => {\n const editorDOM = document.querySelector(`[data-key=\"${value.document.key}\"]`);\n let valueToUse = value;\n const callback = (char, focus) => {\n valueToUse = getFocusedValue();\n\n if (char) {\n const change = valueToUse.change().insertTextByKey(valueToUse.anchorKey, valueToUse.anchorOffset, char);\n\n valueToUse = change.value;\n log('[characters:insert]: ', value);\n onChange(change);\n }\n\n log('[characters:click]');\n\n if (focus) {\n if (editorDOM) {\n editorDOM.focus();\n }\n }\n };\n\n insertDialog({ editorDOM, value: valueToUse, callback, opts });\n },\n },\n\n pluginStyles: (node, parentNode, p) => {\n if (p) {\n return {\n position: 'absolute',\n top: 'initial',\n };\n }\n },\n };\n}\n"],"file":"index.js"}
|
|
1
|
+
{"version":3,"file":"index.js","names":["log","debug","removePopOvers","prevPopOvers","document","querySelectorAll","forEach","s","remove","removeDialogs","prevDialogs","insertDialog","editor","callback","opts","newEl","createElement","className","configToUse","language","spanishConfig","specialConfig","characters","insertSnackBar","layoutForCharacters","reduce","obj","arr","length","columns","rows","popoverEl","closePopOver","renderPopOver","event","el","infoStyle","fontSize","lineHeight","ReactDOM","render","currentTarget","label","description","unicode","body","appendChild","firstCallMade","listener","e","focusIsInModals","contains","target","editorDOM","ReactEditor","toDOMNode","focusIsInEditor","handleClose","undefined","removeEventListener","handleChange","val","n","map","k","name","get","write","category","extraClass","extraProps","style","border","hasPreview","actions","onMouseEnter","ev","onMouseLeave","Editor","node","selection","nodeAtSelection","cursorItem","bodyRect","getBoundingClientRect","boundRect","position","top","Math","abs","offsetHeight","zIndex","leftValue","left","offsetWidth","rightValue","x","leftAlignedWidth","right","rightAlignedWidth","addEventListener","CharacterIcon","letter","CharactersPlugin","toolbar","icon","characterIcon","characterIcons","onClick","char","focus","insertText","pluginStyles","parentNode","p"],"sources":["../../../src/plugins/characters/index.jsx"],"sourcesContent":["import React from 'react';\nimport ReactDOM from 'react-dom';\nimport debug from 'debug';\nimport get from 'lodash/get';\n\nimport { PureToolbar } from '@pie-lib/math-toolbar';\n\nimport CustomPopper from './custom-popper';\nimport { insertSnackBar } from '../respArea/utils';\nimport { characterIcons, spanishConfig, specialConfig } from './utils';\nimport { ReactEditor } from 'slate-react';\nimport { Editor } from 'slate';\nconst log = debug('@pie-lib:editable-html:plugins:characters');\n\nconst removePopOvers = () => {\n const prevPopOvers = document.querySelectorAll('#mouse-over-popover');\n\n log('[characters:removePopOvers]');\n prevPopOvers.forEach(s => s.remove());\n};\n\nexport const removeDialogs = () => {\n const prevDialogs = document.querySelectorAll('.insert-character-dialog');\n\n log('[characters:removeDialogs]');\n prevDialogs.forEach(s => s.remove());\n removePopOvers();\n};\n\nconst insertDialog = ({ editor, callback, opts }) => {\n const newEl = document.createElement('div');\n\n log('[characters:insertDialog]');\n\n removeDialogs();\n\n newEl.className = 'insert-character-dialog';\n\n let configToUse;\n\n switch (true) {\n case opts.language === 'spanish':\n configToUse = spanishConfig;\n break;\n case opts.language === 'special':\n configToUse = specialConfig;\n break;\n default:\n configToUse = opts;\n }\n\n if (!configToUse.characters) {\n insertSnackBar('No characters provided or language not recognized');\n return;\n }\n\n const layoutForCharacters = configToUse.characters.reduce(\n (obj, arr) => {\n if (arr.length >= obj.columns) {\n obj.columns = arr.length;\n }\n\n return obj;\n },\n { rows: configToUse.characters.length, columns: 0 }\n );\n\n let popoverEl;\n\n const closePopOver = () => {\n if (popoverEl) {\n popoverEl.remove();\n }\n\n removePopOvers();\n };\n\n const renderPopOver = (event, el) => {\n if (!event) {\n return;\n }\n\n const infoStyle = { fontSize: '20px', lineHeight: '20px' };\n\n closePopOver();\n\n popoverEl = document.createElement('div');\n ReactDOM.render(\n <CustomPopper onClose={closePopOver} anchorEl={event.currentTarget}>\n <div>{el.label}</div>\n\n <div style={infoStyle}>{el.description}</div>\n\n <div style={infoStyle}>{el.unicode}</div>\n </CustomPopper>,\n popoverEl\n );\n\n document.body.appendChild(newEl);\n };\n\n let firstCallMade = false;\n\n const listener = e => {\n // this will be triggered right after setting it because\n // this toolbar is added on the mousedown event\n // so right after mouseup, the click will be triggered\n if (firstCallMade) {\n const focusIsInModals =\n newEl.contains(e.target) || (popoverEl && popoverEl.contains(e.target));\n const editorDOM = ReactEditor.toDOMNode(editor, editor);\n const focusIsInEditor = editorDOM.contains(e.target);\n\n if (!(focusIsInModals || focusIsInEditor)) {\n handleClose();\n }\n } else {\n firstCallMade = true;\n }\n };\n\n const handleClose = () => {\n callback(undefined, true);\n newEl.remove();\n closePopOver();\n document.body.removeEventListener('click', listener);\n };\n\n const handleChange = val => {\n if (typeof val === 'string') {\n callback(val, true);\n }\n };\n\n const el = (\n <PureToolbar\n autoFocus\n noDecimal\n hideInput\n noLatexHandling\n layoutForKeyPad={layoutForCharacters}\n additionalKeys={configToUse.characters.reduce((arr, n) => {\n arr = [\n ...arr,\n ...n.map(k => ({\n name: get(k, 'name') || k,\n write: get(k, 'write') || k,\n label: get(k, 'label') || k,\n category: 'character',\n extraClass: 'character',\n extraProps: {\n ...(k.extraProps || {}),\n style: {\n ...(k.extraProps || {}).style,\n border: '1px solid #000'\n }\n },\n ...(configToUse.hasPreview\n ? {\n actions: { onMouseEnter: ev => renderPopOver(ev, k), onMouseLeave: closePopOver }\n }\n : {})\n }))\n ];\n\n return arr;\n }, [])}\n keypadMode=\"language\"\n onChange={handleChange}\n onDone={handleClose}\n />\n );\n\n ReactDOM.render(el, newEl, () => {\n const [nodeAtSelection] = Editor.node(editor, editor.selection);\n const cursorItem = ReactEditor.toDOMNode(editor, nodeAtSelection);\n\n if (cursorItem) {\n const bodyRect = document.body.getBoundingClientRect();\n const boundRect = cursorItem.getBoundingClientRect();\n\n document.body.appendChild(newEl);\n newEl.style.position = 'absolute';\n newEl.style.top = `${boundRect.top + Math.abs(bodyRect.top) - newEl.offsetHeight - 10}px`;\n newEl.style.zIndex = 99999;\n\n const leftValue = `${boundRect.left +\n Math.abs(bodyRect.left) +\n cursorItem.offsetWidth +\n 10}px`;\n\n const rightValue = `${boundRect.x}px`;\n\n newEl.style.left = leftValue;\n\n const leftAlignedWidth = newEl.offsetWidth;\n\n newEl.style.left = 'unset';\n newEl.style.right = rightValue;\n\n const rightAlignedWidth = newEl.offsetWidth;\n\n newEl.style.left = 'unset';\n newEl.style.right = 'unset';\n\n if (leftAlignedWidth >= rightAlignedWidth) {\n newEl.style.left = leftValue;\n } else {\n newEl.style.right = rightValue;\n }\n\n document.body.addEventListener('click', listener);\n }\n });\n};\n\nconst CharacterIcon = ({ letter }) => (\n <div\n style={{\n fontSize: '25px',\n lineHeight: '15px'\n }}\n >\n {letter}\n </div>\n);\n\nexport default function CharactersPlugin(opts) {\n removeDialogs();\n return {\n name: 'characters',\n toolbar: {\n icon: <CharacterIcon letter={opts.characterIcon || characterIcons[opts.language] || 'ñ'} />,\n onClick: editor => {\n const callback = (char, focus) => {\n if (char) {\n log('[characters:insert]: ', char);\n editor.insertText(char);\n }\n\n log('[characters:click]');\n\n if (focus) {\n ReactEditor.focus(editor);\n }\n };\n\n insertDialog({ editor, callback, opts });\n }\n },\n\n pluginStyles: (node, parentNode, p) => {\n if (p) {\n return {\n position: 'absolute',\n top: 'initial'\n };\n }\n }\n };\n}\n"],"mappings":"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"}
|