@pie-lib/editable-html 11.3.0-beta.0 → 11.3.0
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.json +12 -3322
- package/CHANGELOG.md +120 -96
- package/package.json +7 -6
- package/src/editor.jsx +3 -3
- package/src/plugins/media/media-dialog.js +1 -1
- package/src/plugins/respArea/drag-in-the-blank/choice.jsx +1 -1
- package/src/plugins/toolbar/default-toolbar.jsx +6 -4
- package/src/plugins/toolbar/editor-and-toolbar.jsx +1 -1
- package/src/plugins/toolbar/toolbar.jsx +4 -4
- package/lib/__tests__/editor.test.js +0 -470
- package/lib/__tests__/serialization.test.js +0 -246
- package/lib/__tests__/utils.js +0 -106
- package/lib/block-tags.js +0 -25
- package/lib/constants.js +0 -16
- package/lib/editor.js +0 -1355
- package/lib/index.js +0 -269
- package/lib/parse-html.js +0 -16
- package/lib/plugins/characters/custom-popper.js +0 -73
- package/lib/plugins/characters/index.js +0 -305
- package/lib/plugins/characters/utils.js +0 -381
- package/lib/plugins/css/icons/index.js +0 -37
- package/lib/plugins/css/index.js +0 -397
- package/lib/plugins/customPlugin/index.js +0 -114
- package/lib/plugins/html/icons/index.js +0 -38
- package/lib/plugins/html/index.js +0 -80
- package/lib/plugins/image/__tests__/component.test.js +0 -51
- package/lib/plugins/image/__tests__/image-toolbar-logic.test.js +0 -56
- package/lib/plugins/image/__tests__/image-toolbar.test.js +0 -26
- package/lib/plugins/image/__tests__/index.test.js +0 -98
- package/lib/plugins/image/__tests__/insert-image-handler.test.js +0 -125
- package/lib/plugins/image/__tests__/mock-change.js +0 -25
- package/lib/plugins/image/alt-dialog.js +0 -129
- package/lib/plugins/image/component.js +0 -419
- package/lib/plugins/image/image-toolbar.js +0 -177
- package/lib/plugins/image/index.js +0 -263
- package/lib/plugins/image/insert-image-handler.js +0 -161
- package/lib/plugins/index.js +0 -402
- package/lib/plugins/list/__tests__/index.test.js +0 -79
- package/lib/plugins/list/index.js +0 -334
- package/lib/plugins/math/__tests__/index.test.js +0 -300
- package/lib/plugins/math/index.js +0 -454
- package/lib/plugins/media/__tests__/index.test.js +0 -71
- package/lib/plugins/media/index.js +0 -387
- package/lib/plugins/media/media-dialog.js +0 -709
- package/lib/plugins/media/media-toolbar.js +0 -101
- package/lib/plugins/media/media-wrapper.js +0 -93
- package/lib/plugins/rendering/index.js +0 -46
- package/lib/plugins/respArea/drag-in-the-blank/choice.js +0 -254
- package/lib/plugins/respArea/drag-in-the-blank/index.js +0 -97
- package/lib/plugins/respArea/explicit-constructed-response/index.js +0 -57
- package/lib/plugins/respArea/icons/index.js +0 -95
- package/lib/plugins/respArea/index.js +0 -341
- package/lib/plugins/respArea/inline-dropdown/index.js +0 -75
- package/lib/plugins/respArea/math-templated/index.js +0 -130
- package/lib/plugins/respArea/utils.js +0 -125
- package/lib/plugins/table/CustomTablePlugin.js +0 -133
- package/lib/plugins/table/__tests__/index.test.js +0 -442
- package/lib/plugins/table/__tests__/table-toolbar.test.js +0 -54
- package/lib/plugins/table/icons/index.js +0 -69
- package/lib/plugins/table/index.js +0 -483
- package/lib/plugins/table/table-toolbar.js +0 -187
- package/lib/plugins/textAlign/icons/index.js +0 -226
- package/lib/plugins/textAlign/index.js +0 -34
- package/lib/plugins/toolbar/__tests__/default-toolbar.test.js +0 -128
- package/lib/plugins/toolbar/__tests__/editor-and-toolbar.test.js +0 -51
- package/lib/plugins/toolbar/__tests__/toolbar-buttons.test.js +0 -54
- package/lib/plugins/toolbar/__tests__/toolbar.test.js +0 -120
- package/lib/plugins/toolbar/default-toolbar.js +0 -229
- package/lib/plugins/toolbar/done-button.js +0 -53
- package/lib/plugins/toolbar/editor-and-toolbar.js +0 -286
- package/lib/plugins/toolbar/index.js +0 -34
- package/lib/plugins/toolbar/toolbar-buttons.js +0 -194
- package/lib/plugins/toolbar/toolbar.js +0 -376
- package/lib/plugins/utils.js +0 -62
- package/lib/serialization.js +0 -677
- package/lib/theme.js +0 -9
package/lib/plugins/css/index.js
DELETED
|
@@ -1,397 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
|
-
Object.defineProperty(exports, "__esModule", {
|
|
6
|
-
value: true
|
|
7
|
-
});
|
|
8
|
-
exports["default"] = CSSPlugin;
|
|
9
|
-
exports.removeDialogs = void 0;
|
|
10
|
-
|
|
11
|
-
var _react = _interopRequireDefault(require("react"));
|
|
12
|
-
|
|
13
|
-
var _reactDom = _interopRequireDefault(require("react-dom"));
|
|
14
|
-
|
|
15
|
-
var _List = _interopRequireDefault(require("@material-ui/core/List"));
|
|
16
|
-
|
|
17
|
-
var _slate = require("slate");
|
|
18
|
-
|
|
19
|
-
var _immutable = _interopRequireDefault(require("immutable"));
|
|
20
|
-
|
|
21
|
-
var _ListItem = _interopRequireDefault(require("@material-ui/core/ListItem"));
|
|
22
|
-
|
|
23
|
-
var _isEmpty = _interopRequireDefault(require("lodash/isEmpty"));
|
|
24
|
-
|
|
25
|
-
var _debug = _interopRequireDefault(require("debug"));
|
|
26
|
-
|
|
27
|
-
var _icons = _interopRequireDefault(require("./icons"));
|
|
28
|
-
|
|
29
|
-
var log = (0, _debug["default"])('@pie-lib:editable-html:plugins:characters');
|
|
30
|
-
|
|
31
|
-
var removeDialogs = function removeDialogs() {
|
|
32
|
-
var prevDialogs = document.querySelectorAll('.insert-css-dialog');
|
|
33
|
-
log('[characters:removeDialogs]');
|
|
34
|
-
prevDialogs.forEach(function (s) {
|
|
35
|
-
return s.remove();
|
|
36
|
-
});
|
|
37
|
-
};
|
|
38
|
-
|
|
39
|
-
exports.removeDialogs = removeDialogs;
|
|
40
|
-
|
|
41
|
-
var insertDialog = function insertDialog(_ref) {
|
|
42
|
-
var _parentNode$data, _parentNode$data$get;
|
|
43
|
-
|
|
44
|
-
var editorDOM = _ref.editorDOM,
|
|
45
|
-
value = _ref.value,
|
|
46
|
-
callback = _ref.callback,
|
|
47
|
-
opts = _ref.opts,
|
|
48
|
-
textNode = _ref.textNode,
|
|
49
|
-
parentNode = _ref.parentNode;
|
|
50
|
-
var newEl = document.createElement('div');
|
|
51
|
-
log('[characters:insertDialog]');
|
|
52
|
-
removeDialogs();
|
|
53
|
-
newEl.className = 'insert-css-dialog';
|
|
54
|
-
var popoverEl;
|
|
55
|
-
|
|
56
|
-
var closePopOver = function closePopOver() {
|
|
57
|
-
if (popoverEl) {
|
|
58
|
-
popoverEl.remove();
|
|
59
|
-
}
|
|
60
|
-
};
|
|
61
|
-
|
|
62
|
-
var firstCallMade = false;
|
|
63
|
-
|
|
64
|
-
var listener = function listener(e) {
|
|
65
|
-
// this will be triggered right after setting it because
|
|
66
|
-
// this toolbar is added on the mousedown event
|
|
67
|
-
// so right after mouseup, the click will be triggered
|
|
68
|
-
if (firstCallMade) {
|
|
69
|
-
var focusIsInModals = newEl.contains(e.target) || popoverEl && popoverEl.contains(e.target);
|
|
70
|
-
var focusIsInEditor = editorDOM.contains(e.target);
|
|
71
|
-
|
|
72
|
-
if (!(focusIsInModals || focusIsInEditor)) {
|
|
73
|
-
handleClose();
|
|
74
|
-
}
|
|
75
|
-
} else {
|
|
76
|
-
firstCallMade = true;
|
|
77
|
-
}
|
|
78
|
-
};
|
|
79
|
-
|
|
80
|
-
var handleClose = function handleClose() {
|
|
81
|
-
callback(undefined, true);
|
|
82
|
-
newEl.remove();
|
|
83
|
-
closePopOver();
|
|
84
|
-
document.body.removeEventListener('click', listener);
|
|
85
|
-
};
|
|
86
|
-
|
|
87
|
-
var handleChange = function handleChange(name) {
|
|
88
|
-
callback(name, true);
|
|
89
|
-
newEl.remove();
|
|
90
|
-
closePopOver();
|
|
91
|
-
document.body.removeEventListener('click', listener);
|
|
92
|
-
};
|
|
93
|
-
|
|
94
|
-
var selectedText = textNode.text.slice(value.selection.anchorOffset, value.selection.focusOffset);
|
|
95
|
-
var parentNodeClass = parentNode === null || parentNode === void 0 ? void 0 : (_parentNode$data = parentNode.data) === null || _parentNode$data === void 0 ? void 0 : (_parentNode$data$get = _parentNode$data.get('attributes')) === null || _parentNode$data$get === void 0 ? void 0 : _parentNode$data$get["class"];
|
|
96
|
-
|
|
97
|
-
var createHTML = function createHTML(name) {
|
|
98
|
-
var html = "<span class=\"".concat(name, "\">").concat(selectedText, "</span>");
|
|
99
|
-
|
|
100
|
-
if (parentNode) {
|
|
101
|
-
var tag;
|
|
102
|
-
|
|
103
|
-
if ((parentNode === null || parentNode === void 0 ? void 0 : parentNode.object) === 'inline') {
|
|
104
|
-
tag = 'span';
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
if ((parentNode === null || parentNode === void 0 ? void 0 : parentNode.object) === 'block') {
|
|
108
|
-
tag = 'div';
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
html = "<".concat(tag, " class=\"").concat(parentNodeClass, "\">").concat(parentNode.text.slice(0, value.selection.anchorOffset)).concat(html).concat(parentNode.text.slice(value.selection.focusOffset), "</").concat(tag, ">");
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
return html;
|
|
115
|
-
};
|
|
116
|
-
|
|
117
|
-
var el = /*#__PURE__*/_react["default"].createElement("div", {
|
|
118
|
-
style: {
|
|
119
|
-
background: 'white',
|
|
120
|
-
height: 500,
|
|
121
|
-
padding: 20,
|
|
122
|
-
overflow: 'hidden',
|
|
123
|
-
display: 'flex',
|
|
124
|
-
flexFlow: 'column'
|
|
125
|
-
}
|
|
126
|
-
}, /*#__PURE__*/_react["default"].createElement("h2", null, "Please choose a css class"), parentNodeClass && /*#__PURE__*/_react["default"].createElement("div", null, "The current parent has this class ", parentNodeClass), /*#__PURE__*/_react["default"].createElement(_List["default"], {
|
|
127
|
-
component: "nav",
|
|
128
|
-
style: {
|
|
129
|
-
overflow: 'scroll'
|
|
130
|
-
}
|
|
131
|
-
}, opts.names.map(function (name, i) {
|
|
132
|
-
return /*#__PURE__*/_react["default"].createElement(_ListItem["default"], {
|
|
133
|
-
key: "rule-".concat(i),
|
|
134
|
-
button: true,
|
|
135
|
-
onClick: function onClick() {
|
|
136
|
-
return handleChange(name);
|
|
137
|
-
}
|
|
138
|
-
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
139
|
-
style: {
|
|
140
|
-
marginRight: 20
|
|
141
|
-
}
|
|
142
|
-
}, name), /*#__PURE__*/_react["default"].createElement("div", {
|
|
143
|
-
dangerouslySetInnerHTML: {
|
|
144
|
-
__html: createHTML(name)
|
|
145
|
-
}
|
|
146
|
-
}));
|
|
147
|
-
})));
|
|
148
|
-
|
|
149
|
-
_reactDom["default"].render(el, newEl, function () {
|
|
150
|
-
var cursorItem = document.querySelector("[data-key=\"".concat(value.anchorKey, "\"]"));
|
|
151
|
-
|
|
152
|
-
if (cursorItem) {
|
|
153
|
-
var bodyRect = editorDOM.parentElement.parentElement.parentElement.getBoundingClientRect();
|
|
154
|
-
var boundRect = cursorItem.getBoundingClientRect();
|
|
155
|
-
editorDOM.parentElement.parentElement.parentElement.appendChild(newEl); // when height of toolbar exceeds screen - can happen in scrollable contexts
|
|
156
|
-
|
|
157
|
-
var additionalTopOffset = 0;
|
|
158
|
-
|
|
159
|
-
if (boundRect.y < newEl.offsetHeight) {
|
|
160
|
-
additionalTopOffset = newEl.offsetHeight - boundRect.y + 10;
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
newEl.style.maxWidth = '500px';
|
|
164
|
-
newEl.style.position = 'absolute';
|
|
165
|
-
newEl.style.top = 0;
|
|
166
|
-
newEl.style.zIndex = 99999;
|
|
167
|
-
var leftValue = "".concat(boundRect.left + Math.abs(bodyRect.left) + cursorItem.offsetWidth + 10, "px");
|
|
168
|
-
var rightValue = "".concat(boundRect.x, "px");
|
|
169
|
-
newEl.style.left = leftValue;
|
|
170
|
-
var leftAlignedWidth = newEl.offsetWidth;
|
|
171
|
-
newEl.style.left = 'unset';
|
|
172
|
-
newEl.style.right = rightValue;
|
|
173
|
-
var rightAlignedWidth = newEl.offsetWidth;
|
|
174
|
-
newEl.style.left = 'unset';
|
|
175
|
-
newEl.style.right = 'unset';
|
|
176
|
-
|
|
177
|
-
if (leftAlignedWidth >= rightAlignedWidth) {
|
|
178
|
-
newEl.style.left = leftValue;
|
|
179
|
-
} else {
|
|
180
|
-
newEl.style.right = rightValue;
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
document.body.addEventListener('click', listener);
|
|
184
|
-
}
|
|
185
|
-
});
|
|
186
|
-
};
|
|
187
|
-
|
|
188
|
-
var findParentNodeInfo = function findParentNodeInfo(value, textNode) {
|
|
189
|
-
var _closestInline$nodes, _closestBlock$nodes;
|
|
190
|
-
|
|
191
|
-
var closestInline = value.document.getClosestInline(value.selection.endKey);
|
|
192
|
-
var closestBlock = value.document.getClosestBlock(value.selection.endKey);
|
|
193
|
-
var nodeToUse = null;
|
|
194
|
-
|
|
195
|
-
if (closestInline !== null && closestInline !== void 0 && (_closestInline$nodes = closestInline.nodes) !== null && _closestInline$nodes !== void 0 && _closestInline$nodes.find(function (n) {
|
|
196
|
-
return n.key === textNode.key;
|
|
197
|
-
})) {
|
|
198
|
-
nodeToUse = closestInline;
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
if (closestBlock !== null && closestBlock !== void 0 && (_closestBlock$nodes = closestBlock.nodes) !== null && _closestBlock$nodes !== void 0 && _closestBlock$nodes.find(function (n) {
|
|
202
|
-
return n.key === textNode.key;
|
|
203
|
-
})) {
|
|
204
|
-
nodeToUse = closestBlock;
|
|
205
|
-
}
|
|
206
|
-
|
|
207
|
-
return nodeToUse;
|
|
208
|
-
};
|
|
209
|
-
/**
|
|
210
|
-
* Find the node that has a class attribute and return it.
|
|
211
|
-
* Keeping this in case the implementation of classes needs to be changed
|
|
212
|
-
* @param value
|
|
213
|
-
* @param opts
|
|
214
|
-
* @returns {*}
|
|
215
|
-
*/
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
var getNodeWithClass = function getNodeWithClass(value, opts) {
|
|
219
|
-
var _blocksAtRange$, _inlinesAtRange$, _blockData$attributes, _inlineData$attribute;
|
|
220
|
-
|
|
221
|
-
var blocksAtRange = value.document.getBlocksAtRangeAsArray(value.selection);
|
|
222
|
-
var inlinesAtRange = value.document.getInlinesAtRangeAsArray(value.selection);
|
|
223
|
-
var blockData = ((_blocksAtRange$ = blocksAtRange[0]) === null || _blocksAtRange$ === void 0 ? void 0 : _blocksAtRange$.data.toJSON()) || {};
|
|
224
|
-
var inlineData = ((_inlinesAtRange$ = inlinesAtRange[0]) === null || _inlinesAtRange$ === void 0 ? void 0 : _inlinesAtRange$.data.toJSON()) || {};
|
|
225
|
-
|
|
226
|
-
if (!((_blockData$attributes = blockData.attributes) !== null && _blockData$attributes !== void 0 && _blockData$attributes["class"]) && !((_inlineData$attribute = inlineData.attributes) !== null && _inlineData$attribute !== void 0 && _inlineData$attribute["class"])) {
|
|
227
|
-
return null;
|
|
228
|
-
}
|
|
229
|
-
|
|
230
|
-
var _ref2 = blockData.attributes || {},
|
|
231
|
-
blockClass = _ref2["class"];
|
|
232
|
-
|
|
233
|
-
var _ref3 = inlineData.attributes || {},
|
|
234
|
-
inlineClass = _ref3["class"];
|
|
235
|
-
|
|
236
|
-
var inlineHasClass = opts.names.find(function (name) {
|
|
237
|
-
return inlineClass.includes(name);
|
|
238
|
-
});
|
|
239
|
-
|
|
240
|
-
if (inlineHasClass) {
|
|
241
|
-
return inlinesAtRange[0];
|
|
242
|
-
}
|
|
243
|
-
|
|
244
|
-
var blockHasClass = opts.names.find(function (name) {
|
|
245
|
-
return blockClass.includes(name);
|
|
246
|
-
});
|
|
247
|
-
|
|
248
|
-
if (blockHasClass) {
|
|
249
|
-
return blocksAtRange[0];
|
|
250
|
-
}
|
|
251
|
-
|
|
252
|
-
return null;
|
|
253
|
-
};
|
|
254
|
-
/**
|
|
255
|
-
* Plugin in order to be able to add a css clas that is provided through the model
|
|
256
|
-
* on a text element. Works like a mark (bold, italic etc.).
|
|
257
|
-
* @param opts
|
|
258
|
-
* @constructor
|
|
259
|
-
*/
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
function CSSPlugin(opts) {
|
|
263
|
-
var plugin = {
|
|
264
|
-
name: 'extraCSSRules',
|
|
265
|
-
toolbar: {
|
|
266
|
-
isMark: true,
|
|
267
|
-
icon: /*#__PURE__*/_react["default"].createElement(_icons["default"], null),
|
|
268
|
-
ariaLabel: 'CSS editor',
|
|
269
|
-
type: 'css',
|
|
270
|
-
onToggle: function onToggle(change) {
|
|
271
|
-
var type = 'css';
|
|
272
|
-
var hasMark = change.value.activeMarks.find(function (entry) {
|
|
273
|
-
return entry.type === type;
|
|
274
|
-
});
|
|
275
|
-
|
|
276
|
-
if (hasMark) {
|
|
277
|
-
change.removeMark(hasMark);
|
|
278
|
-
} else {
|
|
279
|
-
var newMark = _slate.Mark.create(type);
|
|
280
|
-
|
|
281
|
-
change.addMark(newMark);
|
|
282
|
-
}
|
|
283
|
-
|
|
284
|
-
return change;
|
|
285
|
-
},
|
|
286
|
-
onClick: function onClick(value, onChange, getFocusedValue) {
|
|
287
|
-
var type = 'css';
|
|
288
|
-
var hasMark = value.activeMarks.find(function (entry) {
|
|
289
|
-
return entry.type === type;
|
|
290
|
-
});
|
|
291
|
-
var change = value.change();
|
|
292
|
-
|
|
293
|
-
if (hasMark) {
|
|
294
|
-
change.removeMark(hasMark);
|
|
295
|
-
onChange(change);
|
|
296
|
-
return;
|
|
297
|
-
} // keeping this if implementation needs to be changed to regular blocks instead of marks
|
|
298
|
-
// let nodeWithClass = getNodeWithClass(value, opts);
|
|
299
|
-
//
|
|
300
|
-
// if (nodeWithClass) {
|
|
301
|
-
// const nodeAttributes = nodeWithClass.data.get('attributes');
|
|
302
|
-
//
|
|
303
|
-
// opts.names.forEach((name) => {
|
|
304
|
-
// if (nodeAttributes.class.includes(name)) {
|
|
305
|
-
// nodeAttributes.class = nodeAttributes.class.replace(name, '');
|
|
306
|
-
// }
|
|
307
|
-
// });
|
|
308
|
-
//
|
|
309
|
-
// // keeping only one space between classes
|
|
310
|
-
// nodeAttributes.class = nodeAttributes.class.replace(/ +/g, ' ');
|
|
311
|
-
//
|
|
312
|
-
// nodeWithClass.data.set('attributes', nodeAttributes);
|
|
313
|
-
//
|
|
314
|
-
// let change = value.change();
|
|
315
|
-
// change.replaceNodeByKey(nodeWithClass.key, nodeWithClass);
|
|
316
|
-
//
|
|
317
|
-
// onChange(change);
|
|
318
|
-
// return;
|
|
319
|
-
// }
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
var editorDOM = document.querySelector("[data-key=\"".concat(value.document.key, "\"]"));
|
|
323
|
-
var valueToUse = value;
|
|
324
|
-
|
|
325
|
-
var callback = function callback(className, focus) {
|
|
326
|
-
if (getFocusedValue) {
|
|
327
|
-
valueToUse = getFocusedValue() || valueToUse;
|
|
328
|
-
}
|
|
329
|
-
|
|
330
|
-
if (className) {
|
|
331
|
-
var _change = valueToUse.change();
|
|
332
|
-
|
|
333
|
-
var newMark = _slate.Mark.create({
|
|
334
|
-
object: 'mark',
|
|
335
|
-
type: 'css',
|
|
336
|
-
data: {
|
|
337
|
-
attributes: {
|
|
338
|
-
"class": className
|
|
339
|
-
}
|
|
340
|
-
}
|
|
341
|
-
});
|
|
342
|
-
|
|
343
|
-
_change.addMark(newMark); // keeping this if implementation needs to be changed to regular blocks instead of marks
|
|
344
|
-
// change = change.wrapInline({ type: 'span', data: { attributes: { class: className } } });
|
|
345
|
-
//
|
|
346
|
-
// // change = change.splitBlockAtRange(adaptedRange);
|
|
347
|
-
// //
|
|
348
|
-
// // const newBlock = change.value.document.getFurthestBlock(change.value.selection.endKey);
|
|
349
|
-
// //
|
|
350
|
-
// // change = change.setNodeByKey(newBlock.key, { data: { attributes: { class: className } } });
|
|
351
|
-
//
|
|
352
|
-
// valueToUse = change.value;
|
|
353
|
-
// log('[characters:insert]: ', value);
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
onChange(_change);
|
|
357
|
-
}
|
|
358
|
-
|
|
359
|
-
log('[characters:click]');
|
|
360
|
-
|
|
361
|
-
if (focus) {
|
|
362
|
-
setTimeout(function () {
|
|
363
|
-
if (editorDOM) {
|
|
364
|
-
editorDOM.focus();
|
|
365
|
-
}
|
|
366
|
-
}, 0);
|
|
367
|
-
}
|
|
368
|
-
};
|
|
369
|
-
|
|
370
|
-
var textNode = value.document.getTextsAtRangeAsArray(value.selection)[0];
|
|
371
|
-
|
|
372
|
-
if (textNode) {
|
|
373
|
-
var parentNode = findParentNodeInfo(value, textNode, opts);
|
|
374
|
-
insertDialog({
|
|
375
|
-
editorDOM: editorDOM,
|
|
376
|
-
value: valueToUse,
|
|
377
|
-
callback: callback,
|
|
378
|
-
opts: opts,
|
|
379
|
-
textNode: textNode,
|
|
380
|
-
parentNode: parentNode
|
|
381
|
-
});
|
|
382
|
-
}
|
|
383
|
-
}
|
|
384
|
-
},
|
|
385
|
-
renderMark: function renderMark(props) {
|
|
386
|
-
if (props.mark.type === 'css') {
|
|
387
|
-
var _ref4 = props.mark || {},
|
|
388
|
-
data = _ref4.data;
|
|
389
|
-
|
|
390
|
-
var jsonData = (data === null || data === void 0 ? void 0 : data.toJSON()) || {};
|
|
391
|
-
return /*#__PURE__*/_react["default"].createElement("span", jsonData.attributes, props.children);
|
|
392
|
-
}
|
|
393
|
-
}
|
|
394
|
-
};
|
|
395
|
-
return plugin;
|
|
396
|
-
}
|
|
397
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/plugins/css/index.jsx"],"names":["log","removeDialogs","prevDialogs","document","querySelectorAll","forEach","s","remove","insertDialog","editorDOM","value","callback","opts","textNode","parentNode","newEl","createElement","className","popoverEl","closePopOver","firstCallMade","listener","e","focusIsInModals","contains","target","focusIsInEditor","handleClose","undefined","body","removeEventListener","handleChange","name","selectedText","text","slice","selection","anchorOffset","focusOffset","parentNodeClass","data","get","createHTML","html","tag","object","el","background","height","padding","overflow","display","flexFlow","names","map","i","marginRight","__html","ReactDOM","render","cursorItem","querySelector","anchorKey","bodyRect","parentElement","getBoundingClientRect","boundRect","appendChild","additionalTopOffset","y","offsetHeight","style","maxWidth","position","top","zIndex","leftValue","left","Math","abs","offsetWidth","rightValue","x","leftAlignedWidth","right","rightAlignedWidth","addEventListener","findParentNodeInfo","closestInline","getClosestInline","endKey","closestBlock","getClosestBlock","nodeToUse","nodes","find","n","key","getNodeWithClass","blocksAtRange","getBlocksAtRangeAsArray","inlinesAtRange","getInlinesAtRangeAsArray","blockData","toJSON","inlineData","attributes","blockClass","inlineClass","inlineHasClass","includes","blockHasClass","CSSPlugin","plugin","toolbar","isMark","icon","ariaLabel","type","onToggle","change","hasMark","activeMarks","entry","removeMark","newMark","Mark","create","addMark","onClick","onChange","getFocusedValue","valueToUse","focus","setTimeout","getTextsAtRangeAsArray","renderMark","props","mark","jsonData","children"],"mappings":"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","sourcesContent":["import React from 'react';\nimport ReactDOM from 'react-dom';\nimport List from '@material-ui/core/List';\nimport { Leaf, Mark } from 'slate';\nimport Immutable from 'immutable';\nimport ListItem from '@material-ui/core/ListItem';\nimport isEmpty from 'lodash/isEmpty';\nimport debug from 'debug';\nimport CssIcon from './icons';\n\nconst log = debug('@pie-lib:editable-html:plugins:characters');\n\nexport const removeDialogs = () => {\n  const prevDialogs = document.querySelectorAll('.insert-css-dialog');\n\n  log('[characters:removeDialogs]');\n  prevDialogs.forEach((s) => s.remove());\n};\n\nconst insertDialog = ({ editorDOM, value, callback, opts, textNode, parentNode }) => {\n  const newEl = document.createElement('div');\n\n  log('[characters:insertDialog]');\n\n  removeDialogs();\n\n  newEl.className = 'insert-css-dialog';\n\n  let popoverEl;\n\n  const closePopOver = () => {\n    if (popoverEl) {\n      popoverEl.remove();\n    }\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 = (name) => {\n    callback(name, true);\n    newEl.remove();\n    closePopOver();\n    document.body.removeEventListener('click', listener);\n  };\n\n  const selectedText = textNode.text.slice(value.selection.anchorOffset, value.selection.focusOffset);\n  const parentNodeClass = parentNode?.data?.get('attributes')?.class;\n  const createHTML = (name) => {\n    let html = `<span class=\"${name}\">${selectedText}</span>`;\n\n    if (parentNode) {\n      let tag;\n\n      if (parentNode?.object === 'inline') {\n        tag = 'span';\n      }\n\n      if (parentNode?.object === 'block') {\n        tag = 'div';\n      }\n\n      html = `<${tag} class=\"${parentNodeClass}\">${parentNode.text.slice(\n        0,\n        value.selection.anchorOffset,\n      )}${html}${parentNode.text.slice(value.selection.focusOffset)}</${tag}>`;\n    }\n\n    return html;\n  };\n\n  const el = (\n    <div\n      style={{ background: 'white', height: 500, padding: 20, overflow: 'hidden', display: 'flex', flexFlow: 'column' }}\n    >\n      <h2>Please choose a css class</h2>\n      {parentNodeClass && <div>The current parent has this class {parentNodeClass}</div>}\n      <List component=\"nav\" style={{ overflow: 'scroll' }}>\n        {opts.names.map((name, i) => (\n          <ListItem key={`rule-${i}`} button onClick={() => handleChange(name)}>\n            <div style={{ marginRight: 20 }}>{name}</div>\n            <div\n              dangerouslySetInnerHTML={{\n                __html: createHTML(name),\n              }}\n            />\n          </ListItem>\n        ))}\n      </List>\n    </div>\n  );\n\n  ReactDOM.render(el, newEl, () => {\n    const cursorItem = document.querySelector(`[data-key=\"${value.anchorKey}\"]`);\n\n    if (cursorItem) {\n      const bodyRect = editorDOM.parentElement.parentElement.parentElement.getBoundingClientRect();\n      const boundRect = cursorItem.getBoundingClientRect();\n\n      editorDOM.parentElement.parentElement.parentElement.appendChild(newEl);\n\n      // when height of toolbar exceeds screen - can happen in scrollable contexts\n      let additionalTopOffset = 0;\n      if (boundRect.y < newEl.offsetHeight) {\n        additionalTopOffset = newEl.offsetHeight - boundRect.y + 10;\n      }\n\n      newEl.style.maxWidth = '500px';\n      newEl.style.position = 'absolute';\n      newEl.style.top = 0;\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 findParentNodeInfo = (value, textNode) => {\n  const closestInline = value.document.getClosestInline(value.selection.endKey);\n  const closestBlock = value.document.getClosestBlock(value.selection.endKey);\n  let nodeToUse = null;\n\n  if (closestInline?.nodes?.find((n) => n.key === textNode.key)) {\n    nodeToUse = closestInline;\n  }\n\n  if (closestBlock?.nodes?.find((n) => n.key === textNode.key)) {\n    nodeToUse = closestBlock;\n  }\n\n  return nodeToUse;\n};\n\n/**\n * Find the node that has a class attribute and return it.\n * Keeping this in case the implementation of classes needs to be changed\n * @param value\n * @param opts\n * @returns {*}\n */\nconst getNodeWithClass = (value, opts) => {\n  const blocksAtRange = value.document.getBlocksAtRangeAsArray(value.selection);\n  const inlinesAtRange = value.document.getInlinesAtRangeAsArray(value.selection);\n  const blockData = blocksAtRange[0]?.data.toJSON() || {};\n  const inlineData = inlinesAtRange[0]?.data.toJSON() || {};\n\n  if (!blockData.attributes?.class && !inlineData.attributes?.class) {\n    return null;\n  }\n\n  const { class: blockClass } = blockData.attributes || {};\n  const { class: inlineClass } = inlineData.attributes || {};\n  const inlineHasClass = opts.names.find((name) => inlineClass.includes(name));\n\n  if (inlineHasClass) {\n    return inlinesAtRange[0];\n  }\n\n  const blockHasClass = opts.names.find((name) => blockClass.includes(name));\n\n  if (blockHasClass) {\n    return blocksAtRange[0];\n  }\n\n  return null;\n};\n\n/**\n * Plugin in order to be able to add a css clas that is provided through the model\n * on a text element. Works like a mark (bold, italic etc.).\n * @param opts\n * @constructor\n */\nexport default function CSSPlugin(opts) {\n  const plugin = {\n    name: 'extraCSSRules',\n    toolbar: {\n      isMark: true,\n      icon: <CssIcon />,\n      ariaLabel: 'CSS editor',\n      type: 'css',\n      onToggle: (change) => {\n        const type = 'css';\n        const hasMark = change.value.activeMarks.find((entry) => {\n          return entry.type === type;\n        });\n\n        if (hasMark) {\n          change.removeMark(hasMark);\n        } else {\n          const newMark = Mark.create(type);\n\n          change.addMark(newMark);\n        }\n\n        return change;\n      },\n      onClick: (value, onChange, getFocusedValue) => {\n        const type = 'css';\n        const hasMark = value.activeMarks.find((entry) => {\n          return entry.type === type;\n        });\n\n        let change = value.change();\n\n        if (hasMark) {\n          change.removeMark(hasMark);\n          onChange(change);\n          return;\n        }\n\n        // keeping this if implementation needs to be changed to regular blocks instead of marks\n        // let nodeWithClass = getNodeWithClass(value, opts);\n        //\n        // if (nodeWithClass) {\n        //   const nodeAttributes = nodeWithClass.data.get('attributes');\n        //\n        //   opts.names.forEach((name) => {\n        //     if (nodeAttributes.class.includes(name)) {\n        //       nodeAttributes.class = nodeAttributes.class.replace(name, '');\n        //     }\n        //   });\n        //\n        //   // keeping only one space between classes\n        //   nodeAttributes.class = nodeAttributes.class.replace(/ +/g, ' ');\n        //\n        //   nodeWithClass.data.set('attributes', nodeAttributes);\n        //\n        //   let change = value.change();\n        //   change.replaceNodeByKey(nodeWithClass.key, nodeWithClass);\n        //\n        //   onChange(change);\n        //   return;\n        // }\n\n        const editorDOM = document.querySelector(`[data-key=\"${value.document.key}\"]`);\n        let valueToUse = value;\n\n        const callback = (className, focus) => {\n          if (getFocusedValue) {\n            valueToUse = getFocusedValue() || valueToUse;\n          }\n\n          if (className) {\n            let change = valueToUse.change();\n\n            const newMark = Mark.create({\n              object: 'mark',\n              type: 'css',\n              data: {\n                attributes: {\n                  class: className,\n                },\n              },\n            });\n\n            change.addMark(newMark);\n            // keeping this if implementation needs to be changed to regular blocks instead of marks\n            // change = change.wrapInline({ type: 'span', data: { attributes: { class: className } } });\n            //\n            // // change = change.splitBlockAtRange(adaptedRange);\n            // //\n            // // const newBlock = change.value.document.getFurthestBlock(change.value.selection.endKey);\n            // //\n            // // change = change.setNodeByKey(newBlock.key, { data: { attributes: { class: className } } });\n            //\n            // valueToUse = change.value;\n            // log('[characters:insert]: ', value);\n            onChange(change);\n          }\n\n          log('[characters:click]');\n\n          if (focus) {\n            setTimeout(() => {\n              if (editorDOM) {\n                editorDOM.focus();\n              }\n            }, 0);\n          }\n        };\n        const textNode = value.document.getTextsAtRangeAsArray(value.selection)[0];\n\n        if (textNode) {\n          const parentNode = findParentNodeInfo(value, textNode, opts);\n\n          insertDialog({ editorDOM, value: valueToUse, callback, opts, textNode, parentNode });\n        }\n      },\n    },\n    renderMark(props) {\n      if (props.mark.type === 'css') {\n        const { data } = props.mark || {};\n        const jsonData = data?.toJSON() || {};\n\n        return <span {...jsonData.attributes}>{props.children}</span>;\n      }\n    },\n  };\n\n  return plugin;\n}\n"]}
|
|
@@ -1,114 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
|
-
Object.defineProperty(exports, "__esModule", {
|
|
6
|
-
value: true
|
|
7
|
-
});
|
|
8
|
-
exports.ICON_TYPE = exports.CONTENT_TYPE = void 0;
|
|
9
|
-
exports["default"] = CustomPlugin;
|
|
10
|
-
|
|
11
|
-
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
12
|
-
|
|
13
|
-
var _react = _interopRequireDefault(require("react"));
|
|
14
|
-
|
|
15
|
-
var _serialization = require("../../serialization");
|
|
16
|
-
|
|
17
|
-
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; }
|
|
18
|
-
|
|
19
|
-
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; }
|
|
20
|
-
|
|
21
|
-
// We're possibly going to have to support content types, so starting it as an enum
|
|
22
|
-
var CONTENT_TYPE = {
|
|
23
|
-
FRAGMENT: 'FRAGMENT'
|
|
24
|
-
}; // We're possibly going to have to support multiple icon types, so starting it as an enum
|
|
25
|
-
|
|
26
|
-
exports.CONTENT_TYPE = CONTENT_TYPE;
|
|
27
|
-
var ICON_TYPE = {
|
|
28
|
-
SVG: 'SVG'
|
|
29
|
-
};
|
|
30
|
-
exports.ICON_TYPE = ICON_TYPE;
|
|
31
|
-
|
|
32
|
-
var getIcon = function getIcon(customPluginProps) {
|
|
33
|
-
var svg = customPluginProps.icon;
|
|
34
|
-
|
|
35
|
-
switch (customPluginProps.iconType) {
|
|
36
|
-
case ICON_TYPE.SVG:
|
|
37
|
-
return /*#__PURE__*/_react["default"].createElement("span", {
|
|
38
|
-
style: {
|
|
39
|
-
width: 28,
|
|
40
|
-
height: 28
|
|
41
|
-
},
|
|
42
|
-
dangerouslySetInnerHTML: {
|
|
43
|
-
__html: svg
|
|
44
|
-
}
|
|
45
|
-
});
|
|
46
|
-
|
|
47
|
-
default:
|
|
48
|
-
return /*#__PURE__*/_react["default"].createElement("span", null, customPluginProps.iconAlt);
|
|
49
|
-
}
|
|
50
|
-
};
|
|
51
|
-
|
|
52
|
-
function CustomPlugin(type, customPluginProps) {
|
|
53
|
-
var toolbar = {
|
|
54
|
-
icon: getIcon(customPluginProps),
|
|
55
|
-
onClick: function onClick(value, onChange, getFocusedValue) {
|
|
56
|
-
var editorDOM = document.querySelector("[data-key=\"".concat(value.document.key, "\"]"));
|
|
57
|
-
var valueToUse = value;
|
|
58
|
-
|
|
59
|
-
var callback = function callback(_ref, focus) {
|
|
60
|
-
var customContent = _ref.customContent,
|
|
61
|
-
contentType = _ref.contentType;
|
|
62
|
-
valueToUse = getFocusedValue();
|
|
63
|
-
|
|
64
|
-
switch (contentType) {
|
|
65
|
-
case CONTENT_TYPE.FRAGMENT:
|
|
66
|
-
default:
|
|
67
|
-
{
|
|
68
|
-
var contentValue = (0, _serialization.htmlToValue)(customContent);
|
|
69
|
-
var change = valueToUse.change().insertFragment(contentValue.document);
|
|
70
|
-
valueToUse = change.value;
|
|
71
|
-
onChange(change);
|
|
72
|
-
break;
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
if (focus) {
|
|
77
|
-
if (editorDOM) {
|
|
78
|
-
editorDOM.focus();
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
}; // NOTE: the emitted event (custom event named by client) will be suffixed with "PIE-"
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
window.dispatchEvent(new CustomEvent("PIE-".concat(customPluginProps.event), {
|
|
85
|
-
detail: _objectSpread(_objectSpread({}, customPluginProps), {}, {
|
|
86
|
-
callback: callback
|
|
87
|
-
})
|
|
88
|
-
}));
|
|
89
|
-
},
|
|
90
|
-
supports: function supports(node) {
|
|
91
|
-
return node.object === 'inline' && node.type === type;
|
|
92
|
-
}
|
|
93
|
-
};
|
|
94
|
-
return {
|
|
95
|
-
name: type,
|
|
96
|
-
toolbar: toolbar,
|
|
97
|
-
renderNode: function renderNode(props) {
|
|
98
|
-
if (props.node.type === type) {
|
|
99
|
-
var node = props.node;
|
|
100
|
-
var data = node.data;
|
|
101
|
-
var jsonData = data.toJSON();
|
|
102
|
-
var customContent = jsonData.customContent,
|
|
103
|
-
contentType = jsonData.contentType;
|
|
104
|
-
|
|
105
|
-
switch (contentType) {
|
|
106
|
-
case CONTENT_TYPE.FRAGMENT:
|
|
107
|
-
default:
|
|
108
|
-
return customContent;
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
}
|
|
112
|
-
};
|
|
113
|
-
}
|
|
114
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9wbHVnaW5zL2N1c3RvbVBsdWdpbi9pbmRleC5qc3giXSwibmFtZXMiOlsiQ09OVEVOVF9UWVBFIiwiRlJBR01FTlQiLCJJQ09OX1RZUEUiLCJTVkciLCJnZXRJY29uIiwiY3VzdG9tUGx1Z2luUHJvcHMiLCJzdmciLCJpY29uIiwiaWNvblR5cGUiLCJ3aWR0aCIsImhlaWdodCIsIl9faHRtbCIsImljb25BbHQiLCJDdXN0b21QbHVnaW4iLCJ0eXBlIiwidG9vbGJhciIsIm9uQ2xpY2siLCJ2YWx1ZSIsIm9uQ2hhbmdlIiwiZ2V0Rm9jdXNlZFZhbHVlIiwiZWRpdG9yRE9NIiwiZG9jdW1lbnQiLCJxdWVyeVNlbGVjdG9yIiwia2V5IiwidmFsdWVUb1VzZSIsImNhbGxiYWNrIiwiZm9jdXMiLCJjdXN0b21Db250ZW50IiwiY29udGVudFR5cGUiLCJjb250ZW50VmFsdWUiLCJjaGFuZ2UiLCJpbnNlcnRGcmFnbWVudCIsIndpbmRvdyIsImRpc3BhdGNoRXZlbnQiLCJDdXN0b21FdmVudCIsImV2ZW50IiwiZGV0YWlsIiwic3VwcG9ydHMiLCJub2RlIiwib2JqZWN0IiwibmFtZSIsInJlbmRlck5vZGUiLCJwcm9wcyIsImRhdGEiLCJqc29uRGF0YSIsInRvSlNPTiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0E7Ozs7OztBQUVBO0FBQ08sSUFBTUEsWUFBWSxHQUFHO0FBQzFCQyxFQUFBQSxRQUFRLEVBQUU7QUFEZ0IsQ0FBckIsQyxDQUlQOzs7QUFDTyxJQUFNQyxTQUFTLEdBQUc7QUFDdkJDLEVBQUFBLEdBQUcsRUFBRTtBQURrQixDQUFsQjs7O0FBSVAsSUFBTUMsT0FBTyxHQUFHLFNBQVZBLE9BQVUsQ0FBQ0MsaUJBQUQsRUFBdUI7QUFDckMsTUFBTUMsR0FBRyxHQUFHRCxpQkFBaUIsQ0FBQ0UsSUFBOUI7O0FBRUEsVUFBUUYsaUJBQWlCLENBQUNHLFFBQTFCO0FBQ0UsU0FBS04sU0FBUyxDQUFDQyxHQUFmO0FB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Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGh0bWxUb1ZhbHVlIH0gZnJvbSAnLi4vLi4vc2VyaWFsaXphdGlvbic7XG5cbi8vIFdlJ3JlIHBvc3NpYmx5IGdvaW5nIHRvIGhhdmUgdG8gc3VwcG9ydCBjb250ZW50IHR5cGVzLCBzbyBzdGFydGluZyBpdCBhcyBhbiBlbnVtXG5leHBvcnQgY29uc3QgQ09OVEVOVF9UWVBFID0ge1xuICBGUkFHTUVOVDogJ0ZSQUdNRU5UJyxcbn07XG5cbi8vIFdlJ3JlIHBvc3NpYmx5IGdvaW5nIHRvIGhhdmUgdG8gc3VwcG9ydCBtdWx0aXBsZSBpY29uIHR5cGVzLCBzbyBzdGFydGluZyBpdCBhcyBhbiBlbnVtXG5leHBvcnQgY29uc3QgSUNPTl9UWVBFID0ge1xuICBTVkc6ICdTVkcnLFxufTtcblxuY29uc3QgZ2V0SWNvbiA9IChjdXN0b21QbHVnaW5Qcm9wcykgPT4ge1xuICBjb25zdCBzdmcgPSBjdXN0b21QbHVnaW5Qcm9wcy5pY29uO1xuXG4gIHN3aXRjaCAoY3VzdG9tUGx1Z2luUHJvcHMuaWNvblR5cGUpIHtcbiAgICBjYXNlIElDT05fVFlQRS5TVkc6XG4gICAgICByZXR1cm4gPHNwYW4gc3R5bGU9e3sgd2lkdGg6IDI4LCBoZWlnaHQ6IDI4IH19IGRhbmdlcm91c2x5U2V0SW5uZXJIVE1MPXt7IF9faHRtbDogc3ZnIH19IC8+O1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gPHNwYW4+e2N1c3RvbVBsdWdpblByb3BzLmljb25BbHR9PC9zcGFuPjtcbiAgfVxufTtcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gQ3VzdG9tUGx1Z2luKHR5cGUsIGN1c3RvbVBsdWdpblByb3BzKSB7XG4gIGNvbnN0IHRvb2xiYXIgPSB7XG4gICAgaWNvbjogZ2V0SWNvbihjdXN0b21QbHVnaW5Qcm9wcyksXG4gICAgb25DbGljazogKHZhbHVlLCBvbkNoYW5nZSwgZ2V0Rm9jdXNlZFZhbHVlKSA9PiB7XG4gICAgICBjb25zdCBlZGl0b3JET00gPSBkb2N1bWVudC5xdWVyeVNlbGVjdG9yKGBbZGF0YS1rZXk9XCIke3ZhbHVlLmRvY3VtZW50LmtleX1cIl1gKTtcbiAgICAgIGxldCB2YWx1ZVRvVXNlID0gdmFsdWU7XG4gICAgICBjb25zdCBjYWxsYmFjayA9ICh7IGN1c3RvbUNvbnRlbnQsIGNvbnRlbnRUeXBlIH0sIGZvY3VzKSA9PiB7XG4gICAgICAgIHZhbHVlVG9Vc2UgPSBnZXRGb2N1c2VkVmFsdWUoKTtcblxuICAgICAgICBzd2l0Y2ggKGNvbnRlbnRUeXBlKSB7XG4gICAgICAgICAgY2FzZSBDT05URU5UX1RZUEUuRlJBR01FTlQ6XG4gICAgICAgICAgZGVmYXVsdDoge1xuICAgICAgICAgICAgY29uc3QgY29udGVudFZhbHVlID0gaHRtbFRvVmFsdWUoY3VzdG9tQ29udGVudCk7XG4gICAgICAgICAgICBjb25zdCBjaGFuZ2UgPSB2YWx1ZVRvVXNlLmNoYW5nZSgpLmluc2VydEZyYWdtZW50KGNvbnRlbnRWYWx1ZS5kb2N1bWVudCk7XG5cbiAgICAgICAgICAgIHZhbHVlVG9Vc2UgPSBjaGFuZ2UudmFsdWU7XG4gICAgICAgICAgICBvbkNoYW5nZShjaGFuZ2UpO1xuXG4gICAgICAgICAgICBicmVhaztcbiAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICBpZiAoZm9jdXMpIHtcbiAgICAgICAgICBpZiAoZWRpdG9yRE9NKSB7XG4gICAgICAgICAgICBlZGl0b3JET00uZm9jdXMoKTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH07XG5cbiAgICAgIC8vIE5PVEU6IHRoZSBlbWl0dGVkIGV2ZW50IChjdXN0b20gZXZlbnQgbmFtZWQgYnkgY2xpZW50KSB3aWxsIGJlIHN1ZmZpeGVkIHdpdGggXCJQSUUtXCJcbiAgICAgIHdpbmRvdy5kaXNwYXRjaEV2ZW50KFxuICAgICAgICBuZXcgQ3VzdG9tRXZlbnQoYFBJRS0ke2N1c3RvbVBsdWdpblByb3BzLmV2ZW50fWAsIHtcbiAgICAgICAgICBkZXRhaWw6IHtcbiAgICAgICAgICAgIC4uLmN1c3RvbVBsdWdpblByb3BzLFxuICAgICAgICAgICAgY2FsbGJhY2ssXG4gICAgICAgICAgfSxcbiAgICAgICAgfSksXG4gICAgICApO1xuICAgIH0sXG4gICAgc3VwcG9ydHM6IChub2RlKSA9PiBub2RlLm9iamVjdCA9PT0gJ2lubGluZScgJiYgbm9kZS50eXBlID09PSB0eXBlLFxuICB9O1xuXG4gIHJldHVybiB7XG4gICAgbmFtZTogdHlwZSxcbiAgICB0b29sYmFyLFxuICAgIHJlbmRlck5vZGUocHJvcHMpIHtcbiAgICAgIGlmIChwcm9wcy5ub2RlLnR5cGUgPT09IHR5cGUpIHtcbiAgICAgICAgY29uc3QgeyBub2RlIH0gPSBwcm9wcztcbiAgICAgICAgY29uc3QgeyBkYXRhIH0gPSBub2RlO1xuICAgICAgICBjb25zdCBqc29uRGF0YSA9IGRhdGEudG9KU09OKCk7XG4gICAgICAgIGNvbnN0IHsgY3VzdG9tQ29udGVudCwgY29udGVudFR5cGUgfSA9IGpzb25EYXRhO1xuXG4gICAgICAgIHN3aXRjaCAoY29udGVudFR5cGUpIHtcbiAgICAgICAgICBjYXNlIENPTlRFTlRfVFlQRS5GUkFHTUVOVDpcbiAgICAgICAgICBkZWZhdWx0OlxuICAgICAgICAgICAgcmV0dXJuIGN1c3RvbUNvbnRlbnQ7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9LFxuICB9O1xufVxuIl19
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
|
-
Object.defineProperty(exports, "__esModule", {
|
|
6
|
-
value: true
|
|
7
|
-
});
|
|
8
|
-
exports["default"] = void 0;
|
|
9
|
-
|
|
10
|
-
var _react = _interopRequireDefault(require("react"));
|
|
11
|
-
|
|
12
|
-
var _styles = require("@material-ui/core/styles");
|
|
13
|
-
|
|
14
|
-
var styles = function styles(theme) {
|
|
15
|
-
return {
|
|
16
|
-
icon: {
|
|
17
|
-
fontFamily: 'Cerebri Sans, Arial, sans-serif',
|
|
18
|
-
fontSize: theme.typography.fontSize,
|
|
19
|
-
fontWeight: 'bold',
|
|
20
|
-
lineHeight: '14px',
|
|
21
|
-
position: 'relative',
|
|
22
|
-
whiteSpace: 'nowrap'
|
|
23
|
-
}
|
|
24
|
-
};
|
|
25
|
-
};
|
|
26
|
-
|
|
27
|
-
var HtmlModeIcon = function HtmlModeIcon(_ref) {
|
|
28
|
-
var classes = _ref.classes,
|
|
29
|
-
isHtmlMode = _ref.isHtmlMode;
|
|
30
|
-
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
31
|
-
className: classes.icon
|
|
32
|
-
}, isHtmlMode ? 'Exit <HTML> mode' : '<HTML>');
|
|
33
|
-
};
|
|
34
|
-
|
|
35
|
-
var _default = (0, _styles.withStyles)(styles)(HtmlModeIcon);
|
|
36
|
-
|
|
37
|
-
exports["default"] = _default;
|
|
38
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9wbHVnaW5zL2h0bWwvaWNvbnMvaW5kZXguanN4Il0sIm5hbWVzIjpbInN0eWxlcyIsInRoZW1lIiwiaWNvbiIsImZvbnRGYW1pbHkiLCJmb250U2l6ZSIsInR5cG9ncmFwaHkiLCJmb250V2VpZ2h0IiwibGluZUhlaWdodCIsInBvc2l0aW9uIiwid2hpdGVTcGFjZSIsIkh0bWxNb2RlSWNvbiIsImNsYXNzZXMiLCJpc0h0bWxNb2RlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFFQSxJQUFNQSxNQUFNLEdBQUcsU0FBVEEsTUFBUyxDQUFDQyxLQUFEO0FBQUEsU0FBWTtBQUN6QkMsSUFBQUEsSUFBSSxFQUFFO0FBQ0pDLE1BQUFBLFVBQVUsRUFBRSxpQ0FEUjtBQUVKQyxNQUFBQSxRQUFRLEVBQUVILEtBQUssQ0FBQ0ksVUFBTixDQUFpQkQsUUFGdkI7QUFHSkUsTUFBQUEsVUFBVSxFQUFFLE1BSFI7QUFJSkMsTUFBQUEsVUFBVSxFQUFFLE1BSlI7QUFLSkMsTUFBQUEsUUFBUSxFQUFFLFVBTE47QUFNSkMsTUFBQUEsVUFBVSxFQUFFO0FBTlI7QUFEbUIsR0FBWjtBQUFBLENBQWY7O0FBV0EsSUFBTUMsWUFBWSxHQUFHLFNBQWZBLFlBQWU7QUFBQSxNQUFHQyxPQUFILFFBQUdBLE9BQUg7QUFBQSxNQUFZQyxVQUFaLFFBQVlBLFVBQVo7QUFBQSxzQkFDbkI7QUFBSyxJQUFBLFNBQVMsRUFBRUQsT0FBTyxDQUFDVDtBQUF4QixLQUErQlUsVUFBVSxHQUFHLGtCQUFILEdBQXdCLFFBQWpFLENBRG1CO0FBQUEsQ0FBckI7O2VBSWUsd0JBQVdaLE1BQVgsRUFBbUJVLFlBQW5CLEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgd2l0aFN0eWxlcyB9IGZyb20gJ0BtYXRlcmlhbC11aS9jb3JlL3N0eWxlcyc7XG5cbmNvbnN0IHN0eWxlcyA9ICh0aGVtZSkgPT4gKHtcbiAgaWNvbjoge1xuICAgIGZvbnRGYW1pbHk6ICdDZXJlYnJpIFNhbnMsIEFyaWFsLCBzYW5zLXNlcmlmJyxcbiAgICBmb250U2l6ZTogdGhlbWUudHlwb2dyYXBoeS5mb250U2l6ZSxcbiAgICBmb250V2VpZ2h0OiAnYm9sZCcsXG4gICAgbGluZUhlaWdodDogJzE0cHgnLFxuICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgIHdoaXRlU3BhY2U6ICdub3dyYXAnLFxuICB9LFxufSk7XG5cbmNvbnN0IEh0bWxNb2RlSWNvbiA9ICh7IGNsYXNzZXMsIGlzSHRtbE1vZGUgfSkgPT4gKFxuICA8ZGl2IGNsYXNzTmFtZT17Y2xhc3Nlcy5pY29ufT57aXNIdG1sTW9kZSA/ICdFeGl0IDxIVE1MPiBtb2RlJyA6ICc8SFRNTD4nfTwvZGl2PlxuKTtcblxuZXhwb3J0IGRlZmF1bHQgd2l0aFN0eWxlcyhzdHlsZXMpKEh0bWxNb2RlSWNvbik7XG4iXX0=
|