@pie-lib/editable-html-tip-tap 1.0.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.
Files changed (167) hide show
  1. package/CHANGELOG.json +32 -0
  2. package/CHANGELOG.md +2280 -0
  3. package/lib/__tests__/editor.test.js +470 -0
  4. package/lib/__tests__/serialization.test.js +246 -0
  5. package/lib/__tests__/utils.js +106 -0
  6. package/lib/block-tags.js +25 -0
  7. package/lib/constants.js +16 -0
  8. package/lib/editor.js +1356 -0
  9. package/lib/extensions/MediaView.js +112 -0
  10. package/lib/extensions/characters.js +65 -0
  11. package/lib/extensions/component.js +325 -0
  12. package/lib/extensions/css.js +252 -0
  13. package/lib/extensions/custom-toolbar-wrapper.js +124 -0
  14. package/lib/extensions/image.js +106 -0
  15. package/lib/extensions/math.js +330 -0
  16. package/lib/extensions/media.js +276 -0
  17. package/lib/extensions/responseArea.js +278 -0
  18. package/lib/index.js +1213 -0
  19. package/lib/old-index.js +269 -0
  20. package/lib/parse-html.js +16 -0
  21. package/lib/plugins/characters/custom-popper.js +73 -0
  22. package/lib/plugins/characters/index.js +305 -0
  23. package/lib/plugins/characters/utils.js +381 -0
  24. package/lib/plugins/css/icons/index.js +37 -0
  25. package/lib/plugins/css/index.js +390 -0
  26. package/lib/plugins/customPlugin/index.js +114 -0
  27. package/lib/plugins/html/icons/index.js +38 -0
  28. package/lib/plugins/html/index.js +81 -0
  29. package/lib/plugins/image/__tests__/component.test.js +51 -0
  30. package/lib/plugins/image/__tests__/image-toolbar-logic.test.js +56 -0
  31. package/lib/plugins/image/__tests__/image-toolbar.test.js +26 -0
  32. package/lib/plugins/image/__tests__/index.test.js +98 -0
  33. package/lib/plugins/image/__tests__/insert-image-handler.test.js +125 -0
  34. package/lib/plugins/image/__tests__/mock-change.js +25 -0
  35. package/lib/plugins/image/alt-dialog.js +129 -0
  36. package/lib/plugins/image/component.js +419 -0
  37. package/lib/plugins/image/image-toolbar.js +177 -0
  38. package/lib/plugins/image/index.js +263 -0
  39. package/lib/plugins/image/insert-image-handler.js +117 -0
  40. package/lib/plugins/index.js +413 -0
  41. package/lib/plugins/list/__tests__/index.test.js +79 -0
  42. package/lib/plugins/list/index.js +334 -0
  43. package/lib/plugins/math/__tests__/index.test.js +300 -0
  44. package/lib/plugins/math/index.js +454 -0
  45. package/lib/plugins/media/__tests__/index.test.js +71 -0
  46. package/lib/plugins/media/index.js +387 -0
  47. package/lib/plugins/media/media-dialog.js +709 -0
  48. package/lib/plugins/media/media-toolbar.js +101 -0
  49. package/lib/plugins/media/media-wrapper.js +93 -0
  50. package/lib/plugins/rendering/index.js +46 -0
  51. package/lib/plugins/respArea/drag-in-the-blank/choice.js +289 -0
  52. package/lib/plugins/respArea/drag-in-the-blank/index.js +94 -0
  53. package/lib/plugins/respArea/explicit-constructed-response/index.js +120 -0
  54. package/lib/plugins/respArea/icons/index.js +95 -0
  55. package/lib/plugins/respArea/index.js +341 -0
  56. package/lib/plugins/respArea/inline-dropdown/index.js +126 -0
  57. package/lib/plugins/respArea/math-templated/index.js +130 -0
  58. package/lib/plugins/respArea/utils.js +125 -0
  59. package/lib/plugins/table/CustomTablePlugin.js +133 -0
  60. package/lib/plugins/table/__tests__/index.test.js +442 -0
  61. package/lib/plugins/table/__tests__/table-toolbar.test.js +54 -0
  62. package/lib/plugins/table/icons/index.js +69 -0
  63. package/lib/plugins/table/index.js +483 -0
  64. package/lib/plugins/table/table-toolbar.js +187 -0
  65. package/lib/plugins/textAlign/icons/index.js +194 -0
  66. package/lib/plugins/textAlign/index.js +34 -0
  67. package/lib/plugins/toolbar/__tests__/default-toolbar.test.js +128 -0
  68. package/lib/plugins/toolbar/__tests__/editor-and-toolbar.test.js +51 -0
  69. package/lib/plugins/toolbar/__tests__/toolbar-buttons.test.js +54 -0
  70. package/lib/plugins/toolbar/__tests__/toolbar.test.js +120 -0
  71. package/lib/plugins/toolbar/default-toolbar.js +229 -0
  72. package/lib/plugins/toolbar/done-button.js +53 -0
  73. package/lib/plugins/toolbar/editor-and-toolbar.js +286 -0
  74. package/lib/plugins/toolbar/index.js +34 -0
  75. package/lib/plugins/toolbar/toolbar-buttons.js +194 -0
  76. package/lib/plugins/toolbar/toolbar.js +376 -0
  77. package/lib/plugins/utils.js +62 -0
  78. package/lib/serialization.js +677 -0
  79. package/lib/shared/alert-dialog.js +75 -0
  80. package/lib/theme.js +9 -0
  81. package/package.json +69 -0
  82. package/src/__tests__/editor.test.jsx +363 -0
  83. package/src/__tests__/serialization.test.js +291 -0
  84. package/src/__tests__/utils.js +36 -0
  85. package/src/block-tags.js +17 -0
  86. package/src/constants.js +7 -0
  87. package/src/editor.jsx +1197 -0
  88. package/src/extensions/characters.js +46 -0
  89. package/src/extensions/component.jsx +294 -0
  90. package/src/extensions/css.js +217 -0
  91. package/src/extensions/custom-toolbar-wrapper.jsx +100 -0
  92. package/src/extensions/image.js +55 -0
  93. package/src/extensions/math.js +259 -0
  94. package/src/extensions/media.js +182 -0
  95. package/src/extensions/responseArea.js +205 -0
  96. package/src/index.jsx +1462 -0
  97. package/src/old-index.jsx +162 -0
  98. package/src/parse-html.js +8 -0
  99. package/src/plugins/README.md +27 -0
  100. package/src/plugins/characters/custom-popper.js +48 -0
  101. package/src/plugins/characters/index.jsx +284 -0
  102. package/src/plugins/characters/utils.js +447 -0
  103. package/src/plugins/css/icons/index.jsx +17 -0
  104. package/src/plugins/css/index.jsx +340 -0
  105. package/src/plugins/customPlugin/index.jsx +85 -0
  106. package/src/plugins/html/icons/index.jsx +19 -0
  107. package/src/plugins/html/index.jsx +72 -0
  108. package/src/plugins/image/__tests__/__snapshots__/component.test.jsx.snap +51 -0
  109. package/src/plugins/image/__tests__/__snapshots__/image-toolbar-logic.test.jsx.snap +27 -0
  110. package/src/plugins/image/__tests__/__snapshots__/image-toolbar.test.jsx.snap +44 -0
  111. package/src/plugins/image/__tests__/component.test.jsx +41 -0
  112. package/src/plugins/image/__tests__/image-toolbar-logic.test.jsx +42 -0
  113. package/src/plugins/image/__tests__/image-toolbar.test.jsx +11 -0
  114. package/src/plugins/image/__tests__/index.test.js +95 -0
  115. package/src/plugins/image/__tests__/insert-image-handler.test.js +113 -0
  116. package/src/plugins/image/__tests__/mock-change.js +15 -0
  117. package/src/plugins/image/alt-dialog.jsx +82 -0
  118. package/src/plugins/image/component.jsx +343 -0
  119. package/src/plugins/image/image-toolbar.jsx +100 -0
  120. package/src/plugins/image/index.jsx +227 -0
  121. package/src/plugins/image/insert-image-handler.js +79 -0
  122. package/src/plugins/index.jsx +377 -0
  123. package/src/plugins/list/__tests__/index.test.js +54 -0
  124. package/src/plugins/list/index.jsx +305 -0
  125. package/src/plugins/math/__tests__/__snapshots__/index.test.jsx.snap +48 -0
  126. package/src/plugins/math/__tests__/index.test.jsx +245 -0
  127. package/src/plugins/math/index.jsx +379 -0
  128. package/src/plugins/media/__tests__/index.test.js +75 -0
  129. package/src/plugins/media/index.jsx +325 -0
  130. package/src/plugins/media/media-dialog.js +624 -0
  131. package/src/plugins/media/media-toolbar.jsx +56 -0
  132. package/src/plugins/media/media-wrapper.jsx +43 -0
  133. package/src/plugins/rendering/index.js +31 -0
  134. package/src/plugins/respArea/drag-in-the-blank/choice.jsx +215 -0
  135. package/src/plugins/respArea/drag-in-the-blank/index.jsx +70 -0
  136. package/src/plugins/respArea/explicit-constructed-response/index.jsx +92 -0
  137. package/src/plugins/respArea/icons/index.jsx +71 -0
  138. package/src/plugins/respArea/index.jsx +299 -0
  139. package/src/plugins/respArea/inline-dropdown/index.jsx +108 -0
  140. package/src/plugins/respArea/math-templated/index.jsx +104 -0
  141. package/src/plugins/respArea/utils.jsx +90 -0
  142. package/src/plugins/table/CustomTablePlugin.js +113 -0
  143. package/src/plugins/table/__tests__/__snapshots__/table-toolbar.test.jsx.snap +44 -0
  144. package/src/plugins/table/__tests__/index.test.jsx +401 -0
  145. package/src/plugins/table/__tests__/table-toolbar.test.jsx +42 -0
  146. package/src/plugins/table/icons/index.jsx +53 -0
  147. package/src/plugins/table/index.jsx +427 -0
  148. package/src/plugins/table/table-toolbar.jsx +136 -0
  149. package/src/plugins/textAlign/icons/index.jsx +114 -0
  150. package/src/plugins/textAlign/index.jsx +23 -0
  151. package/src/plugins/toolbar/__tests__/__snapshots__/default-toolbar.test.jsx.snap +923 -0
  152. package/src/plugins/toolbar/__tests__/__snapshots__/editor-and-toolbar.test.jsx.snap +20 -0
  153. package/src/plugins/toolbar/__tests__/__snapshots__/toolbar-buttons.test.jsx.snap +36 -0
  154. package/src/plugins/toolbar/__tests__/__snapshots__/toolbar.test.jsx.snap +46 -0
  155. package/src/plugins/toolbar/__tests__/default-toolbar.test.jsx +94 -0
  156. package/src/plugins/toolbar/__tests__/editor-and-toolbar.test.jsx +37 -0
  157. package/src/plugins/toolbar/__tests__/toolbar-buttons.test.jsx +51 -0
  158. package/src/plugins/toolbar/__tests__/toolbar.test.jsx +106 -0
  159. package/src/plugins/toolbar/default-toolbar.jsx +206 -0
  160. package/src/plugins/toolbar/done-button.jsx +38 -0
  161. package/src/plugins/toolbar/editor-and-toolbar.jsx +257 -0
  162. package/src/plugins/toolbar/index.jsx +23 -0
  163. package/src/plugins/toolbar/toolbar-buttons.jsx +138 -0
  164. package/src/plugins/toolbar/toolbar.jsx +338 -0
  165. package/src/plugins/utils.js +31 -0
  166. package/src/serialization.jsx +621 -0
  167. package/src/theme.js +1 -0
@@ -0,0 +1,390 @@
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);
156
+ newEl.style.maxWidth = '500px';
157
+ newEl.style.position = 'absolute';
158
+ newEl.style.top = 0;
159
+ newEl.style.zIndex = 99999;
160
+ var leftValue = "".concat(boundRect.left + Math.abs(bodyRect.left) + cursorItem.offsetWidth + 10, "px");
161
+ var rightValue = "".concat(boundRect.x, "px");
162
+ newEl.style.left = leftValue;
163
+ var leftAlignedWidth = newEl.offsetWidth;
164
+ newEl.style.left = 'unset';
165
+ newEl.style.right = rightValue;
166
+ var rightAlignedWidth = newEl.offsetWidth;
167
+ newEl.style.left = 'unset';
168
+ newEl.style.right = 'unset';
169
+
170
+ if (leftAlignedWidth >= rightAlignedWidth) {
171
+ newEl.style.left = leftValue;
172
+ } else {
173
+ newEl.style.right = rightValue;
174
+ }
175
+
176
+ document.body.addEventListener('click', listener);
177
+ }
178
+ });
179
+ };
180
+
181
+ var findParentNodeInfo = function findParentNodeInfo(value, textNode) {
182
+ var _closestInline$nodes, _closestBlock$nodes;
183
+
184
+ var closestInline = value.document.getClosestInline(value.selection.endKey);
185
+ var closestBlock = value.document.getClosestBlock(value.selection.endKey);
186
+ var nodeToUse = null;
187
+
188
+ if (closestInline !== null && closestInline !== void 0 && (_closestInline$nodes = closestInline.nodes) !== null && _closestInline$nodes !== void 0 && _closestInline$nodes.find(function (n) {
189
+ return n.key === textNode.key;
190
+ })) {
191
+ nodeToUse = closestInline;
192
+ }
193
+
194
+ if (closestBlock !== null && closestBlock !== void 0 && (_closestBlock$nodes = closestBlock.nodes) !== null && _closestBlock$nodes !== void 0 && _closestBlock$nodes.find(function (n) {
195
+ return n.key === textNode.key;
196
+ })) {
197
+ nodeToUse = closestBlock;
198
+ }
199
+
200
+ return nodeToUse;
201
+ };
202
+ /**
203
+ * Find the node that has a class attribute and return it.
204
+ * Keeping this in case the implementation of classes needs to be changed
205
+ * @param value
206
+ * @param opts
207
+ * @returns {*}
208
+ */
209
+
210
+
211
+ var getNodeWithClass = function getNodeWithClass(value, opts) {
212
+ var _blocksAtRange$, _inlinesAtRange$, _blockData$attributes, _inlineData$attribute;
213
+
214
+ var blocksAtRange = value.document.getBlocksAtRangeAsArray(value.selection);
215
+ var inlinesAtRange = value.document.getInlinesAtRangeAsArray(value.selection);
216
+ var blockData = ((_blocksAtRange$ = blocksAtRange[0]) === null || _blocksAtRange$ === void 0 ? void 0 : _blocksAtRange$.data.toJSON()) || {};
217
+ var inlineData = ((_inlinesAtRange$ = inlinesAtRange[0]) === null || _inlinesAtRange$ === void 0 ? void 0 : _inlinesAtRange$.data.toJSON()) || {};
218
+
219
+ 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"])) {
220
+ return null;
221
+ }
222
+
223
+ var _ref2 = blockData.attributes || {},
224
+ blockClass = _ref2["class"];
225
+
226
+ var _ref3 = inlineData.attributes || {},
227
+ inlineClass = _ref3["class"];
228
+
229
+ var inlineHasClass = opts.names.find(function (name) {
230
+ return inlineClass.includes(name);
231
+ });
232
+
233
+ if (inlineHasClass) {
234
+ return inlinesAtRange[0];
235
+ }
236
+
237
+ var blockHasClass = opts.names.find(function (name) {
238
+ return blockClass.includes(name);
239
+ });
240
+
241
+ if (blockHasClass) {
242
+ return blocksAtRange[0];
243
+ }
244
+
245
+ return null;
246
+ };
247
+ /**
248
+ * Plugin in order to be able to add a css clas that is provided through the model
249
+ * on a text element. Works like a mark (bold, italic etc.).
250
+ * @param opts
251
+ * @constructor
252
+ */
253
+
254
+
255
+ function CSSPlugin(opts) {
256
+ var plugin = {
257
+ name: 'extraCSSRules',
258
+ toolbar: {
259
+ isMark: true,
260
+ icon: /*#__PURE__*/_react["default"].createElement(_icons["default"], null),
261
+ ariaLabel: 'CSS editor',
262
+ type: 'css',
263
+ onToggle: function onToggle(change) {
264
+ var type = 'css';
265
+ var hasMark = change.value.activeMarks.find(function (entry) {
266
+ return entry.type === type;
267
+ });
268
+
269
+ if (hasMark) {
270
+ change.removeMark(hasMark);
271
+ } else {
272
+ var newMark = _slate.Mark.create(type);
273
+
274
+ change.addMark(newMark);
275
+ }
276
+
277
+ return change;
278
+ },
279
+ onClick: function onClick(value, onChange, getFocusedValue) {
280
+ var type = 'css';
281
+ var hasMark = value.activeMarks.find(function (entry) {
282
+ return entry.type === type;
283
+ });
284
+ var change = value.change();
285
+
286
+ if (hasMark) {
287
+ change.removeMark(hasMark);
288
+ onChange(change);
289
+ return;
290
+ } // keeping this if implementation needs to be changed to regular blocks instead of marks
291
+ // let nodeWithClass = getNodeWithClass(value, opts);
292
+ //
293
+ // if (nodeWithClass) {
294
+ // const nodeAttributes = nodeWithClass.data.get('attributes');
295
+ //
296
+ // opts.names.forEach((name) => {
297
+ // if (nodeAttributes.class.includes(name)) {
298
+ // nodeAttributes.class = nodeAttributes.class.replace(name, '');
299
+ // }
300
+ // });
301
+ //
302
+ // // keeping only one space between classes
303
+ // nodeAttributes.class = nodeAttributes.class.replace(/ +/g, ' ');
304
+ //
305
+ // nodeWithClass.data.set('attributes', nodeAttributes);
306
+ //
307
+ // let change = value.change();
308
+ // change.replaceNodeByKey(nodeWithClass.key, nodeWithClass);
309
+ //
310
+ // onChange(change);
311
+ // return;
312
+ // }
313
+
314
+
315
+ var editorDOM = document.querySelector("[data-key=\"".concat(value.document.key, "\"]"));
316
+ var valueToUse = value;
317
+
318
+ var callback = function callback(className, focus) {
319
+ if (getFocusedValue) {
320
+ valueToUse = getFocusedValue() || valueToUse;
321
+ }
322
+
323
+ if (className) {
324
+ var _change = valueToUse.change();
325
+
326
+ var newMark = _slate.Mark.create({
327
+ object: 'mark',
328
+ type: 'css',
329
+ data: {
330
+ attributes: {
331
+ "class": className
332
+ }
333
+ }
334
+ });
335
+
336
+ _change.addMark(newMark); // keeping this if implementation needs to be changed to regular blocks instead of marks
337
+ // change = change.wrapInline({ type: 'span', data: { attributes: { class: className } } });
338
+ //
339
+ // // change = change.splitBlockAtRange(adaptedRange);
340
+ // //
341
+ // // const newBlock = change.value.document.getFurthestBlock(change.value.selection.endKey);
342
+ // //
343
+ // // change = change.setNodeByKey(newBlock.key, { data: { attributes: { class: className } } });
344
+ //
345
+ // valueToUse = change.value;
346
+ // log('[characters:insert]: ', value);
347
+
348
+
349
+ onChange(_change);
350
+ }
351
+
352
+ log('[characters:click]');
353
+
354
+ if (focus) {
355
+ setTimeout(function () {
356
+ if (editorDOM) {
357
+ editorDOM.focus();
358
+ }
359
+ }, 0);
360
+ }
361
+ };
362
+
363
+ var textNode = value.document.getTextsAtRangeAsArray(value.selection)[0];
364
+
365
+ if (textNode) {
366
+ var parentNode = findParentNodeInfo(value, textNode, opts);
367
+ insertDialog({
368
+ editorDOM: editorDOM,
369
+ value: valueToUse,
370
+ callback: callback,
371
+ opts: opts,
372
+ textNode: textNode,
373
+ parentNode: parentNode
374
+ });
375
+ }
376
+ }
377
+ },
378
+ renderMark: function renderMark(props) {
379
+ if (props.mark.type === 'css') {
380
+ var _ref4 = props.mark || {},
381
+ data = _ref4.data;
382
+
383
+ var jsonData = (data === null || data === void 0 ? void 0 : data.toJSON()) || {};
384
+ return /*#__PURE__*/_react["default"].createElement("span", jsonData.attributes, props.children);
385
+ }
386
+ }
387
+ };
388
+ return plugin;
389
+ }
390
+ //# 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","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      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"]}
@@ -0,0 +1,114 @@
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
@@ -0,0 +1,38 @@
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=