phx-react 1.3.126 → 1.3.130
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/dist/cjs/components/Table/Table.d.ts +3 -1
- package/dist/cjs/components/Table/Table.js +25 -3
- package/dist/cjs/components/Table/Table.js.map +1 -1
- package/dist/cjs/components/TextEditor/index.d.ts +1 -0
- package/dist/cjs/components/TextEditor/index.js +5 -0
- package/dist/cjs/components/TextEditor/index.js.map +1 -0
- package/dist/cjs/components/TextEditor/plugins/AutoLinkPlugin.d.ts +2 -0
- package/dist/cjs/components/TextEditor/plugins/AutoLinkPlugin.js +32 -0
- package/dist/cjs/components/TextEditor/plugins/AutoLinkPlugin.js.map +1 -0
- package/dist/cjs/components/TextEditor/plugins/CodeHighlightPlugin.d.ts +1 -0
- package/dist/cjs/components/TextEditor/plugins/CodeHighlightPlugin.js +12 -0
- package/dist/cjs/components/TextEditor/plugins/CodeHighlightPlugin.js.map +1 -0
- package/dist/cjs/components/TextEditor/plugins/ListMaxIndentLevelPlugin.d.ts +1 -0
- package/dist/cjs/components/TextEditor/plugins/ListMaxIndentLevelPlugin.js +46 -0
- package/dist/cjs/components/TextEditor/plugins/ListMaxIndentLevelPlugin.js.map +1 -0
- package/dist/cjs/components/TextEditor/plugins/ToolbarPlugin.d.ts +2 -0
- package/dist/cjs/components/TextEditor/plugins/ToolbarPlugin.js +499 -0
- package/dist/cjs/components/TextEditor/plugins/ToolbarPlugin.js.map +1 -0
- package/dist/cjs/components/TextEditor/textEditor.d.ts +2 -0
- package/dist/cjs/components/TextEditor/textEditor.js +86 -0
- package/dist/cjs/components/TextEditor/textEditor.js.map +1 -0
- package/dist/cjs/components/TextEditor/themes/ExampleTheme.d.ts +68 -0
- package/dist/cjs/components/TextEditor/themes/ExampleTheme.js +71 -0
- package/dist/cjs/components/TextEditor/themes/ExampleTheme.js.map +1 -0
- package/dist/cjs/index.d.ts +2 -1
- package/dist/cjs/index.js +3 -1
- package/dist/cjs/index.js.map +1 -1
- package/dist/esm/components/Table/Table.d.ts +3 -1
- package/dist/esm/components/Table/Table.js +25 -3
- package/dist/esm/components/Table/Table.js.map +1 -1
- package/dist/esm/components/TextEditor/index.d.ts +1 -0
- package/dist/esm/components/TextEditor/index.js +2 -0
- package/dist/esm/components/TextEditor/index.js.map +1 -0
- package/dist/esm/components/TextEditor/plugins/AutoLinkPlugin.d.ts +2 -0
- package/dist/esm/components/TextEditor/plugins/AutoLinkPlugin.js +28 -0
- package/dist/esm/components/TextEditor/plugins/AutoLinkPlugin.js.map +1 -0
- package/dist/esm/components/TextEditor/plugins/CodeHighlightPlugin.d.ts +1 -0
- package/dist/esm/components/TextEditor/plugins/CodeHighlightPlugin.js +9 -0
- package/dist/esm/components/TextEditor/plugins/CodeHighlightPlugin.js.map +1 -0
- package/dist/esm/components/TextEditor/plugins/ListMaxIndentLevelPlugin.d.ts +1 -0
- package/dist/esm/components/TextEditor/plugins/ListMaxIndentLevelPlugin.js +43 -0
- package/dist/esm/components/TextEditor/plugins/ListMaxIndentLevelPlugin.js.map +1 -0
- package/dist/esm/components/TextEditor/plugins/ToolbarPlugin.d.ts +2 -0
- package/dist/esm/components/TextEditor/plugins/ToolbarPlugin.js +495 -0
- package/dist/esm/components/TextEditor/plugins/ToolbarPlugin.js.map +1 -0
- package/dist/esm/components/TextEditor/textEditor.d.ts +2 -0
- package/dist/esm/components/TextEditor/textEditor.js +81 -0
- package/dist/esm/components/TextEditor/textEditor.js.map +1 -0
- package/dist/esm/components/TextEditor/themes/ExampleTheme.d.ts +68 -0
- package/dist/esm/components/TextEditor/themes/ExampleTheme.js +69 -0
- package/dist/esm/components/TextEditor/themes/ExampleTheme.js.map +1 -0
- package/dist/esm/index.d.ts +2 -1
- package/dist/esm/index.js +2 -1
- package/dist/esm/index.js.map +1 -1
- package/package.json +17 -15
|
@@ -0,0 +1,499 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
exports.__esModule = true;
|
|
3
|
+
var tslib_1 = require("tslib");
|
|
4
|
+
var react_1 = tslib_1.__importDefault(require("react"));
|
|
5
|
+
var code_1 = require("@lexical/code");
|
|
6
|
+
var link_1 = require("@lexical/link");
|
|
7
|
+
var list_1 = require("@lexical/list");
|
|
8
|
+
var LexicalComposerContext_1 = require("@lexical/react/LexicalComposerContext");
|
|
9
|
+
var rich_text_1 = require("@lexical/rich-text");
|
|
10
|
+
var selection_1 = require("@lexical/selection");
|
|
11
|
+
var utils_1 = require("@lexical/utils");
|
|
12
|
+
var lexical_1 = require("lexical");
|
|
13
|
+
var react_2 = require("react");
|
|
14
|
+
var react_dom_1 = require("react-dom");
|
|
15
|
+
var LowPriority = 1;
|
|
16
|
+
var supportedBlockTypes = new Set(['paragraph', 'quote', 'code', 'h1', 'h2', 'ul', 'ol']);
|
|
17
|
+
var blockTypeToBlockName = {
|
|
18
|
+
code: 'Code Block',
|
|
19
|
+
h1: 'Large Heading',
|
|
20
|
+
h2: 'Small Heading',
|
|
21
|
+
h3: 'Heading',
|
|
22
|
+
h4: 'Heading',
|
|
23
|
+
h5: 'Heading',
|
|
24
|
+
ol: 'Numbered List',
|
|
25
|
+
paragraph: 'Normal',
|
|
26
|
+
quote: 'Quote',
|
|
27
|
+
ul: 'Bulleted List'
|
|
28
|
+
};
|
|
29
|
+
function Divider() {
|
|
30
|
+
return react_1["default"].createElement("div", { className: 'divider' });
|
|
31
|
+
}
|
|
32
|
+
function positionEditorElement(editor, rect) {
|
|
33
|
+
if (rect === null) {
|
|
34
|
+
editor.style.opacity = '0';
|
|
35
|
+
editor.style.top = '-1000px';
|
|
36
|
+
editor.style.left = '-1000px';
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
editor.style.opacity = '1';
|
|
40
|
+
// eslint-disable-next-line no-undef
|
|
41
|
+
editor.style.top = "".concat(rect.top + rect.height + window.pageYOffset + 10, "px");
|
|
42
|
+
editor.style.left = "".concat(
|
|
43
|
+
// eslint-disable-next-line no-undef
|
|
44
|
+
rect.left + window.pageXOffset - editor.offsetWidth / 2 + rect.width / 2, "px");
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
// eslint-disable-next-line react/prop-types
|
|
48
|
+
function FloatingLinkEditor(_a) {
|
|
49
|
+
var editor = _a.editor;
|
|
50
|
+
var editorRef = (0, react_2.useRef)(null);
|
|
51
|
+
var inputRef = (0, react_2.useRef)(null);
|
|
52
|
+
var mouseDownRef = (0, react_2.useRef)(false);
|
|
53
|
+
var _b = (0, react_2.useState)(''), linkUrl = _b[0], setLinkUrl = _b[1];
|
|
54
|
+
var _c = (0, react_2.useState)(false), isEditMode = _c[0], setEditMode = _c[1];
|
|
55
|
+
var _d = (0, react_2.useState)(null), lastSelection = _d[0], setLastSelection = _d[1];
|
|
56
|
+
var updateLinkEditor = (0, react_2.useCallback)(function () {
|
|
57
|
+
var selection = (0, lexical_1.$getSelection)();
|
|
58
|
+
if ((0, lexical_1.$isRangeSelection)(selection)) {
|
|
59
|
+
var node = getSelectedNode(selection);
|
|
60
|
+
var parent_1 = node.getParent();
|
|
61
|
+
if ((0, link_1.$isLinkNode)(parent_1)) {
|
|
62
|
+
setLinkUrl(parent_1.getURL());
|
|
63
|
+
}
|
|
64
|
+
else if ((0, link_1.$isLinkNode)(node)) {
|
|
65
|
+
setLinkUrl(node.getURL());
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
setLinkUrl('');
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
var editorElem = editorRef.current;
|
|
72
|
+
// eslint-disable-next-line no-undef
|
|
73
|
+
var nativeSelection = window.getSelection();
|
|
74
|
+
// eslint-disable-next-line no-undef
|
|
75
|
+
var activeElement = document.activeElement;
|
|
76
|
+
if (editorElem === null) {
|
|
77
|
+
return;
|
|
78
|
+
}
|
|
79
|
+
// eslint-disable-next-line react/prop-types
|
|
80
|
+
var rootElement = editor.getRootElement();
|
|
81
|
+
if (selection !== null &&
|
|
82
|
+
!nativeSelection.isCollapsed &&
|
|
83
|
+
rootElement !== null &&
|
|
84
|
+
rootElement.contains(nativeSelection.anchorNode)) {
|
|
85
|
+
var domRange = nativeSelection.getRangeAt(0);
|
|
86
|
+
var rect = void 0;
|
|
87
|
+
if (nativeSelection.anchorNode === rootElement) {
|
|
88
|
+
var inner = rootElement;
|
|
89
|
+
while (inner.firstElementChild != null) {
|
|
90
|
+
inner = inner.firstElementChild;
|
|
91
|
+
}
|
|
92
|
+
rect = inner.getBoundingClientRect();
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
rect = domRange.getBoundingClientRect();
|
|
96
|
+
}
|
|
97
|
+
if (!mouseDownRef.current) {
|
|
98
|
+
positionEditorElement(editorElem, rect);
|
|
99
|
+
}
|
|
100
|
+
setLastSelection(selection);
|
|
101
|
+
}
|
|
102
|
+
else if (!activeElement || activeElement.className !== 'link-input') {
|
|
103
|
+
positionEditorElement(editorElem, null);
|
|
104
|
+
setLastSelection(null);
|
|
105
|
+
setEditMode(false);
|
|
106
|
+
setLinkUrl('');
|
|
107
|
+
}
|
|
108
|
+
return true;
|
|
109
|
+
}, [editor]);
|
|
110
|
+
(0, react_2.useEffect)(function () {
|
|
111
|
+
return (0, utils_1.mergeRegister)(editor.registerUpdateListener(function (_a) {
|
|
112
|
+
var editorState = _a.editorState;
|
|
113
|
+
editorState.read(function () {
|
|
114
|
+
updateLinkEditor();
|
|
115
|
+
});
|
|
116
|
+
}), editor.registerCommand(lexical_1.SELECTION_CHANGE_COMMAND, function () {
|
|
117
|
+
updateLinkEditor();
|
|
118
|
+
return true;
|
|
119
|
+
}, LowPriority));
|
|
120
|
+
}, [editor, updateLinkEditor]);
|
|
121
|
+
(0, react_2.useEffect)(function () {
|
|
122
|
+
editor.getEditorState().read(function () {
|
|
123
|
+
updateLinkEditor();
|
|
124
|
+
});
|
|
125
|
+
}, [editor, updateLinkEditor]);
|
|
126
|
+
(0, react_2.useEffect)(function () {
|
|
127
|
+
if (isEditMode && inputRef.current) {
|
|
128
|
+
inputRef.current.focus();
|
|
129
|
+
}
|
|
130
|
+
}, [isEditMode]);
|
|
131
|
+
return (react_1["default"].createElement("div", { ref: editorRef, className: 'link-editor' }, isEditMode ? (react_1["default"].createElement("input", { ref: inputRef, className: 'link-input', onChange: function (event) {
|
|
132
|
+
setLinkUrl(event.target.value);
|
|
133
|
+
}, onKeyDown: function (event) {
|
|
134
|
+
if (event.key === 'Enter') {
|
|
135
|
+
event.preventDefault();
|
|
136
|
+
if (lastSelection !== null) {
|
|
137
|
+
if (linkUrl !== '') {
|
|
138
|
+
editor.dispatchCommand(link_1.TOGGLE_LINK_COMMAND, linkUrl);
|
|
139
|
+
}
|
|
140
|
+
setEditMode(false);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
else if (event.key === 'Escape') {
|
|
144
|
+
event.preventDefault();
|
|
145
|
+
setEditMode(false);
|
|
146
|
+
}
|
|
147
|
+
}, value: linkUrl })) : (react_1["default"].createElement(react_1["default"].Fragment, null,
|
|
148
|
+
react_1["default"].createElement("div", { className: 'link-input' },
|
|
149
|
+
react_1["default"].createElement("a", { href: linkUrl, rel: 'noopener noreferrer', target: '_blank' }, linkUrl),
|
|
150
|
+
react_1["default"].createElement("div", { className: 'link-edit', onClick: function () {
|
|
151
|
+
setEditMode(true);
|
|
152
|
+
}, onMouseDown: function (event) { return event.preventDefault(); }, role: 'button', tabIndex: 0 }))))));
|
|
153
|
+
}
|
|
154
|
+
function Select(_a) {
|
|
155
|
+
var className = _a.className, onChange = _a.onChange, options = _a.options, value = _a.value;
|
|
156
|
+
return (react_1["default"].createElement("select", { className: className, onChange: onChange, value: value },
|
|
157
|
+
react_1["default"].createElement("option", { hidden: true, value: '' }),
|
|
158
|
+
options.map(function (option) { return (react_1["default"].createElement("option", { key: option, value: option }, option)); })));
|
|
159
|
+
}
|
|
160
|
+
function getSelectedNode(selection) {
|
|
161
|
+
var anchor = selection.anchor;
|
|
162
|
+
var focus = selection.focus;
|
|
163
|
+
var anchorNode = selection.anchor.getNode();
|
|
164
|
+
var focusNode = selection.focus.getNode();
|
|
165
|
+
if (anchorNode === focusNode) {
|
|
166
|
+
return anchorNode;
|
|
167
|
+
}
|
|
168
|
+
var isBackward = selection.isBackward();
|
|
169
|
+
if (isBackward) {
|
|
170
|
+
return (0, selection_1.$isAtNodeEnd)(focus) ? anchorNode : focusNode;
|
|
171
|
+
}
|
|
172
|
+
else {
|
|
173
|
+
return (0, selection_1.$isAtNodeEnd)(anchor) ? focusNode : anchorNode;
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
function BlockOptionsDropdownList(_a) {
|
|
177
|
+
var blockType = _a.blockType, editor = _a.editor, setShowBlockOptionsDropDown = _a.setShowBlockOptionsDropDown, toolbarRef = _a.toolbarRef;
|
|
178
|
+
var dropDownRef = (0, react_2.useRef)(null);
|
|
179
|
+
(0, react_2.useEffect)(function () {
|
|
180
|
+
var toolbar = toolbarRef.current;
|
|
181
|
+
var dropDown = dropDownRef.current;
|
|
182
|
+
if (toolbar !== null && dropDown !== null) {
|
|
183
|
+
var _a = toolbar.getBoundingClientRect(), left = _a.left, top_1 = _a.top;
|
|
184
|
+
dropDown.style.top = "".concat(top_1 + 40, "px");
|
|
185
|
+
dropDown.style.left = "".concat(left, "px");
|
|
186
|
+
}
|
|
187
|
+
}, [dropDownRef, toolbarRef]);
|
|
188
|
+
(0, react_2.useEffect)(function () {
|
|
189
|
+
var dropDown = dropDownRef.current;
|
|
190
|
+
var toolbar = toolbarRef.current;
|
|
191
|
+
if (dropDown !== null && toolbar !== null) {
|
|
192
|
+
var handle = function (event) {
|
|
193
|
+
var target = event.target;
|
|
194
|
+
if (!dropDown.contains(target) && !toolbar.contains(target)) {
|
|
195
|
+
setShowBlockOptionsDropDown(false);
|
|
196
|
+
}
|
|
197
|
+
};
|
|
198
|
+
document.addEventListener('click', handle);
|
|
199
|
+
}
|
|
200
|
+
}, [dropDownRef, setShowBlockOptionsDropDown, toolbarRef]);
|
|
201
|
+
var formatParagraph = function () {
|
|
202
|
+
if (blockType !== 'paragraph') {
|
|
203
|
+
editor.update(function () {
|
|
204
|
+
var selection = (0, lexical_1.$getSelection)();
|
|
205
|
+
if ((0, lexical_1.$isRangeSelection)(selection)) {
|
|
206
|
+
(0, selection_1.$wrapNodes)(selection, function () { return (0, lexical_1.$createParagraphNode)(); });
|
|
207
|
+
}
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
setShowBlockOptionsDropDown(false);
|
|
211
|
+
};
|
|
212
|
+
var formatLargeHeading = function () {
|
|
213
|
+
if (blockType !== 'h1') {
|
|
214
|
+
editor.update(function () {
|
|
215
|
+
var selection = (0, lexical_1.$getSelection)();
|
|
216
|
+
if ((0, lexical_1.$isRangeSelection)(selection)) {
|
|
217
|
+
(0, selection_1.$wrapNodes)(selection, function () { return (0, rich_text_1.$createHeadingNode)('h1'); });
|
|
218
|
+
}
|
|
219
|
+
});
|
|
220
|
+
}
|
|
221
|
+
setShowBlockOptionsDropDown(false);
|
|
222
|
+
};
|
|
223
|
+
var formatSmallHeading = function () {
|
|
224
|
+
if (blockType !== 'h2') {
|
|
225
|
+
editor.update(function () {
|
|
226
|
+
var selection = (0, lexical_1.$getSelection)();
|
|
227
|
+
if ((0, lexical_1.$isRangeSelection)(selection)) {
|
|
228
|
+
(0, selection_1.$wrapNodes)(selection, function () { return (0, rich_text_1.$createHeadingNode)('h2'); });
|
|
229
|
+
}
|
|
230
|
+
});
|
|
231
|
+
}
|
|
232
|
+
setShowBlockOptionsDropDown(false);
|
|
233
|
+
};
|
|
234
|
+
var formatBulletList = function () {
|
|
235
|
+
if (blockType !== 'ul') {
|
|
236
|
+
editor.dispatchCommand(list_1.INSERT_UNORDERED_LIST_COMMAND);
|
|
237
|
+
}
|
|
238
|
+
else {
|
|
239
|
+
editor.dispatchCommand(list_1.REMOVE_LIST_COMMAND);
|
|
240
|
+
}
|
|
241
|
+
setShowBlockOptionsDropDown(false);
|
|
242
|
+
};
|
|
243
|
+
var formatNumberedList = function () {
|
|
244
|
+
if (blockType !== 'ol') {
|
|
245
|
+
editor.dispatchCommand(list_1.INSERT_ORDERED_LIST_COMMAND);
|
|
246
|
+
}
|
|
247
|
+
else {
|
|
248
|
+
editor.dispatchCommand(list_1.REMOVE_LIST_COMMAND);
|
|
249
|
+
}
|
|
250
|
+
setShowBlockOptionsDropDown(false);
|
|
251
|
+
};
|
|
252
|
+
var formatQuote = function () {
|
|
253
|
+
if (blockType !== 'quote') {
|
|
254
|
+
editor.update(function () {
|
|
255
|
+
var selection = (0, lexical_1.$getSelection)();
|
|
256
|
+
if ((0, lexical_1.$isRangeSelection)(selection)) {
|
|
257
|
+
(0, selection_1.$wrapNodes)(selection, function () { return (0, rich_text_1.$createQuoteNode)(); });
|
|
258
|
+
}
|
|
259
|
+
});
|
|
260
|
+
}
|
|
261
|
+
setShowBlockOptionsDropDown(false);
|
|
262
|
+
};
|
|
263
|
+
var formatCode = function () {
|
|
264
|
+
if (blockType !== 'code') {
|
|
265
|
+
editor.update(function () {
|
|
266
|
+
var selection = (0, lexical_1.$getSelection)();
|
|
267
|
+
if ((0, lexical_1.$isRangeSelection)(selection)) {
|
|
268
|
+
(0, selection_1.$wrapNodes)(selection, function () { return (0, code_1.$createCodeNode)(); });
|
|
269
|
+
}
|
|
270
|
+
});
|
|
271
|
+
}
|
|
272
|
+
setShowBlockOptionsDropDown(false);
|
|
273
|
+
};
|
|
274
|
+
return (react_1["default"].createElement("div", { ref: dropDownRef, className: 'dropdown' },
|
|
275
|
+
react_1["default"].createElement("button", { className: 'item', onClick: formatParagraph },
|
|
276
|
+
react_1["default"].createElement("span", { className: 'icon paragraph' }),
|
|
277
|
+
react_1["default"].createElement("span", { className: 'text' }, "Normal"),
|
|
278
|
+
blockType === 'paragraph' && react_1["default"].createElement("span", { className: 'active' })),
|
|
279
|
+
react_1["default"].createElement("button", { className: 'item', onClick: formatLargeHeading },
|
|
280
|
+
react_1["default"].createElement("span", { className: 'icon large-heading' }),
|
|
281
|
+
react_1["default"].createElement("span", { className: 'text' }, "Large Heading"),
|
|
282
|
+
blockType === 'h1' && react_1["default"].createElement("span", { className: 'active' })),
|
|
283
|
+
react_1["default"].createElement("button", { className: 'item', onClick: formatSmallHeading },
|
|
284
|
+
react_1["default"].createElement("span", { className: 'icon small-heading' }),
|
|
285
|
+
react_1["default"].createElement("span", { className: 'text' }, "Small Heading"),
|
|
286
|
+
blockType === 'h2' && react_1["default"].createElement("span", { className: 'active' })),
|
|
287
|
+
react_1["default"].createElement("button", { className: 'item', onClick: formatBulletList },
|
|
288
|
+
react_1["default"].createElement("span", { className: 'icon bullet-list' }),
|
|
289
|
+
react_1["default"].createElement("span", { className: 'text' }, "Bullet List"),
|
|
290
|
+
blockType === 'ul' && react_1["default"].createElement("span", { className: 'active' })),
|
|
291
|
+
react_1["default"].createElement("button", { className: 'item', onClick: formatNumberedList },
|
|
292
|
+
react_1["default"].createElement("span", { className: 'icon numbered-list' }),
|
|
293
|
+
react_1["default"].createElement("span", { className: 'text' }, "Numbered List"),
|
|
294
|
+
blockType === 'ol' && react_1["default"].createElement("span", { className: 'active' })),
|
|
295
|
+
react_1["default"].createElement("button", { className: 'item', onClick: formatQuote },
|
|
296
|
+
react_1["default"].createElement("span", { className: 'icon quote' }),
|
|
297
|
+
react_1["default"].createElement("span", { className: 'text' }, "Quote"),
|
|
298
|
+
blockType === 'quote' && react_1["default"].createElement("span", { className: 'active' })),
|
|
299
|
+
react_1["default"].createElement("button", { className: 'item', onClick: formatCode },
|
|
300
|
+
react_1["default"].createElement("span", { className: 'icon code' }),
|
|
301
|
+
react_1["default"].createElement("span", { className: 'text' }, "Code Block"),
|
|
302
|
+
blockType === 'code' && react_1["default"].createElement("span", { className: 'active' }))));
|
|
303
|
+
}
|
|
304
|
+
function ToolbarPlugin() {
|
|
305
|
+
var editor = (0, LexicalComposerContext_1.useLexicalComposerContext)()[0];
|
|
306
|
+
var toolbarRef = (0, react_2.useRef)(null);
|
|
307
|
+
var _a = (0, react_2.useState)(false), canUndo = _a[0], setCanUndo = _a[1];
|
|
308
|
+
var _b = (0, react_2.useState)(false), canRedo = _b[0], setCanRedo = _b[1];
|
|
309
|
+
var _c = (0, react_2.useState)('paragraph'), blockType = _c[0], setBlockType = _c[1];
|
|
310
|
+
var _d = (0, react_2.useState)(null), selectedElementKey = _d[0], setSelectedElementKey = _d[1];
|
|
311
|
+
var _e = (0, react_2.useState)(false), showBlockOptionsDropDown = _e[0], setShowBlockOptionsDropDown = _e[1];
|
|
312
|
+
var _f = (0, react_2.useState)(''), codeLanguage = _f[0], setCodeLanguage = _f[1];
|
|
313
|
+
var _g = (0, react_2.useState)(false), setIsRTL = _g[1];
|
|
314
|
+
var _h = (0, react_2.useState)(false), isLink = _h[0], setIsLink = _h[1];
|
|
315
|
+
var _j = (0, react_2.useState)(false), isBold = _j[0], setIsBold = _j[1];
|
|
316
|
+
var _k = (0, react_2.useState)(false), isItalic = _k[0], setIsItalic = _k[1];
|
|
317
|
+
var _l = (0, react_2.useState)(false), isUnderline = _l[0], setIsUnderline = _l[1];
|
|
318
|
+
var _m = (0, react_2.useState)(false), isStrikethrough = _m[0], setIsStrikethrough = _m[1];
|
|
319
|
+
var _o = (0, react_2.useState)(false), isCode = _o[0], setIsCode = _o[1];
|
|
320
|
+
var updateToolbar = (0, react_2.useCallback)(function () {
|
|
321
|
+
var selection = (0, lexical_1.$getSelection)();
|
|
322
|
+
if ((0, lexical_1.$isRangeSelection)(selection)) {
|
|
323
|
+
var anchorNode = selection.anchor.getNode();
|
|
324
|
+
var element = anchorNode.getKey() === 'root' ? anchorNode : anchorNode.getTopLevelElementOrThrow();
|
|
325
|
+
var elementKey = element.getKey();
|
|
326
|
+
var elementDOM = editor.getElementByKey(elementKey);
|
|
327
|
+
if (elementDOM !== null) {
|
|
328
|
+
setSelectedElementKey(elementKey);
|
|
329
|
+
if ((0, list_1.$isListNode)(element)) {
|
|
330
|
+
var parentList = (0, utils_1.$getNearestNodeOfType)(anchorNode, list_1.ListNode);
|
|
331
|
+
var type = parentList ? parentList.getTag() : element.getTag();
|
|
332
|
+
setBlockType(type);
|
|
333
|
+
}
|
|
334
|
+
else {
|
|
335
|
+
var type = (0, rich_text_1.$isHeadingNode)(element) ? element.getTag() : element.getType();
|
|
336
|
+
setBlockType(type);
|
|
337
|
+
if ((0, code_1.$isCodeNode)(element)) {
|
|
338
|
+
setCodeLanguage(element.getLanguage() || (0, code_1.getDefaultCodeLanguage)());
|
|
339
|
+
}
|
|
340
|
+
}
|
|
341
|
+
}
|
|
342
|
+
// Update text format
|
|
343
|
+
setIsBold(selection.hasFormat('bold'));
|
|
344
|
+
setIsItalic(selection.hasFormat('italic'));
|
|
345
|
+
setIsUnderline(selection.hasFormat('underline'));
|
|
346
|
+
setIsStrikethrough(selection.hasFormat('strikethrough'));
|
|
347
|
+
setIsCode(selection.hasFormat('code'));
|
|
348
|
+
setIsRTL((0, selection_1.$isParentElementRTL)(selection));
|
|
349
|
+
// Update links
|
|
350
|
+
var node = getSelectedNode(selection);
|
|
351
|
+
var parent_2 = node.getParent();
|
|
352
|
+
if ((0, link_1.$isLinkNode)(parent_2) || (0, link_1.$isLinkNode)(node)) {
|
|
353
|
+
setIsLink(true);
|
|
354
|
+
}
|
|
355
|
+
else {
|
|
356
|
+
setIsLink(false);
|
|
357
|
+
}
|
|
358
|
+
}
|
|
359
|
+
}, [editor]);
|
|
360
|
+
// useEffect(
|
|
361
|
+
// () =>
|
|
362
|
+
// mergeRegister(
|
|
363
|
+
// editor.registerUpdateListener(({ editorState }: any) => {
|
|
364
|
+
// editorState.read(() => {
|
|
365
|
+
// updateToolbar()
|
|
366
|
+
// })
|
|
367
|
+
// }),
|
|
368
|
+
// editor.registerCommand(
|
|
369
|
+
// SELECTION_CHANGE_COMMAND,
|
|
370
|
+
// () => {
|
|
371
|
+
// updateToolbar()
|
|
372
|
+
// return false
|
|
373
|
+
// },
|
|
374
|
+
// LowPriority,
|
|
375
|
+
// ),
|
|
376
|
+
// editor.registerCommand(
|
|
377
|
+
// CAN_UNDO_COMMAND,
|
|
378
|
+
// (payload: any) => {
|
|
379
|
+
// console.log('payload', payload)
|
|
380
|
+
// setCanUndo(payload)
|
|
381
|
+
// return false
|
|
382
|
+
// },
|
|
383
|
+
// LowPriority,
|
|
384
|
+
// ),
|
|
385
|
+
// editor.registerCommand(
|
|
386
|
+
// CAN_REDO_COMMAND,
|
|
387
|
+
// (payload: any) => {
|
|
388
|
+
// setCanRedo(payload)
|
|
389
|
+
// return false
|
|
390
|
+
// },
|
|
391
|
+
// LowPriority,
|
|
392
|
+
// ),
|
|
393
|
+
// ),
|
|
394
|
+
// [editor, updateToolbar],
|
|
395
|
+
// )
|
|
396
|
+
(0, react_2.useEffect)(function () {
|
|
397
|
+
console.log('chay vao day');
|
|
398
|
+
(0, utils_1.mergeRegister)(editor.registerUpdateListener(function (_a) {
|
|
399
|
+
var editorState = _a.editorState;
|
|
400
|
+
editorState.read(function () {
|
|
401
|
+
updateToolbar();
|
|
402
|
+
});
|
|
403
|
+
}), editor.registerCommand(lexical_1.SELECTION_CHANGE_COMMAND, function () {
|
|
404
|
+
updateToolbar();
|
|
405
|
+
return false;
|
|
406
|
+
}, LowPriority), editor.registerCommand(lexical_1.CAN_UNDO_COMMAND, function (payload) {
|
|
407
|
+
setCanUndo(payload);
|
|
408
|
+
return false;
|
|
409
|
+
}, LowPriority), editor.registerCommand(lexical_1.CAN_REDO_COMMAND, function (payload) {
|
|
410
|
+
setCanRedo(payload);
|
|
411
|
+
return false;
|
|
412
|
+
}, LowPriority));
|
|
413
|
+
}, [editor, updateToolbar]);
|
|
414
|
+
var codeLanguges = (0, react_2.useMemo)(function () { return (0, code_1.getCodeLanguages)(); }, []);
|
|
415
|
+
var onCodeLanguageSelect = (0, react_2.useCallback)(function (e) {
|
|
416
|
+
editor.update(function () {
|
|
417
|
+
if (selectedElementKey !== null) {
|
|
418
|
+
var node = (0, lexical_1.$getNodeByKey)(selectedElementKey);
|
|
419
|
+
if ((0, code_1.$isCodeNode)(node)) {
|
|
420
|
+
node.setLanguage(e.target.value);
|
|
421
|
+
}
|
|
422
|
+
}
|
|
423
|
+
});
|
|
424
|
+
}, [editor, selectedElementKey]);
|
|
425
|
+
var insertLink = (0, react_2.useCallback)(function () {
|
|
426
|
+
if (!isLink) {
|
|
427
|
+
editor.dispatchCommand(link_1.TOGGLE_LINK_COMMAND, 'https://');
|
|
428
|
+
}
|
|
429
|
+
else {
|
|
430
|
+
editor.dispatchCommand(link_1.TOGGLE_LINK_COMMAND, null);
|
|
431
|
+
}
|
|
432
|
+
}, [editor, isLink]);
|
|
433
|
+
return (react_1["default"].createElement(react_1["default"].Fragment, null,
|
|
434
|
+
react_1["default"].createElement("div", { ref: toolbarRef, className: 'toolbar' },
|
|
435
|
+
react_1["default"].createElement("button", { type: 'button', "aria-label": 'Undo', className: 'toolbar-item spaced', disabled: !canUndo, onClick: function () {
|
|
436
|
+
editor.dispatchCommand(lexical_1.UNDO_COMMAND);
|
|
437
|
+
} },
|
|
438
|
+
react_1["default"].createElement("i", { className: 'format undo' })),
|
|
439
|
+
react_1["default"].createElement("button", { type: 'button', "aria-label": 'Redo', className: 'toolbar-item', disabled: !canRedo, onClick: function () {
|
|
440
|
+
editor.dispatchCommand(lexical_1.REDO_COMMAND);
|
|
441
|
+
} },
|
|
442
|
+
react_1["default"].createElement("i", { className: 'format redo' })),
|
|
443
|
+
react_1["default"].createElement(Divider, null),
|
|
444
|
+
supportedBlockTypes.has(blockType) && (react_1["default"].createElement(react_1["default"].Fragment, null,
|
|
445
|
+
react_1["default"].createElement("button", { "aria-label": 'Formatting Options', className: 'toolbar-item block-controls', onClick: function () { return setShowBlockOptionsDropDown(!showBlockOptionsDropDown); }, type: 'button' },
|
|
446
|
+
react_1["default"].createElement("span", { className: 'icon block-type ' + blockType }),
|
|
447
|
+
react_1["default"].createElement("span", { className: 'text' }, blockTypeToBlockName[blockType]),
|
|
448
|
+
react_1["default"].createElement("i", { className: 'chevron-down' })),
|
|
449
|
+
showBlockOptionsDropDown &&
|
|
450
|
+
(0, react_dom_1.createPortal)(react_1["default"].createElement(BlockOptionsDropdownList, { blockType: blockType, editor: editor, setShowBlockOptionsDropDown: setShowBlockOptionsDropDown, toolbarRef: toolbarRef }), document.body),
|
|
451
|
+
react_1["default"].createElement(Divider, null))),
|
|
452
|
+
blockType === 'code' ? (react_1["default"].createElement(react_1["default"].Fragment, null,
|
|
453
|
+
react_1["default"].createElement(Select, { className: 'toolbar-item code-language', onChange: onCodeLanguageSelect, options: codeLanguges, value: codeLanguage }),
|
|
454
|
+
react_1["default"].createElement("i", { className: 'chevron-down inside' }))) : (react_1["default"].createElement(react_1["default"].Fragment, null,
|
|
455
|
+
react_1["default"].createElement("button", { "aria-label": 'Format Bold', className: 'toolbar-item spaced ' + (isBold ? 'active' : ''), onClick: function () {
|
|
456
|
+
editor.dispatchCommand(lexical_1.FORMAT_TEXT_COMMAND, 'bold');
|
|
457
|
+
}, type: 'button' },
|
|
458
|
+
react_1["default"].createElement("i", { className: 'format bold' })),
|
|
459
|
+
react_1["default"].createElement("button", { "aria-label": 'Format Italics', className: 'toolbar-item spaced ' + (isItalic ? 'active' : ''), onClick: function () {
|
|
460
|
+
editor.dispatchCommand(lexical_1.FORMAT_TEXT_COMMAND, 'italic');
|
|
461
|
+
}, type: 'button' },
|
|
462
|
+
react_1["default"].createElement("i", { className: 'format italic' })),
|
|
463
|
+
react_1["default"].createElement("button", { "aria-label": 'Format Underline', className: 'toolbar-item spaced ' + (isUnderline ? 'active' : ''), onClick: function () {
|
|
464
|
+
editor.dispatchCommand(lexical_1.FORMAT_TEXT_COMMAND, 'underline');
|
|
465
|
+
}, type: 'button' },
|
|
466
|
+
react_1["default"].createElement("i", { className: 'format underline' })),
|
|
467
|
+
react_1["default"].createElement("button", { "aria-label": 'Format Strikethrough', className: 'toolbar-item spaced ' + (isStrikethrough ? 'active' : ''), onClick: function () {
|
|
468
|
+
editor.dispatchCommand(lexical_1.FORMAT_TEXT_COMMAND, 'strikethrough');
|
|
469
|
+
}, type: 'button' },
|
|
470
|
+
react_1["default"].createElement("i", { className: 'format strikethrough' })),
|
|
471
|
+
react_1["default"].createElement("button", { "aria-label": 'Insert Code', className: 'toolbar-item spaced ' + (isCode ? 'active' : ''), onClick: function () {
|
|
472
|
+
editor.dispatchCommand(lexical_1.FORMAT_TEXT_COMMAND, 'code');
|
|
473
|
+
}, type: 'button' },
|
|
474
|
+
react_1["default"].createElement("i", { className: 'format code' })),
|
|
475
|
+
react_1["default"].createElement("button", { "aria-label": 'Insert Link', className: 'toolbar-item spaced ' + (isLink ? 'active' : ''), onClick: insertLink, type: 'button' },
|
|
476
|
+
react_1["default"].createElement("i", { className: 'format link' })),
|
|
477
|
+
isLink && (0, react_dom_1.createPortal)(react_1["default"].createElement(FloatingLinkEditor, { editor: editor }), document.body),
|
|
478
|
+
react_1["default"].createElement(Divider, null),
|
|
479
|
+
react_1["default"].createElement("button", { "aria-label": 'Left Align', className: 'toolbar-item spaced', onClick: function () {
|
|
480
|
+
editor.dispatchCommand(lexical_1.FORMAT_ELEMENT_COMMAND, 'left');
|
|
481
|
+
}, type: 'button' },
|
|
482
|
+
react_1["default"].createElement("i", { className: 'format left-align' })),
|
|
483
|
+
react_1["default"].createElement("button", { "aria-label": 'Center Align', className: 'toolbar-item spaced', onClick: function () {
|
|
484
|
+
editor.dispatchCommand(lexical_1.FORMAT_ELEMENT_COMMAND, 'center');
|
|
485
|
+
}, type: 'button' },
|
|
486
|
+
react_1["default"].createElement("i", { className: 'format center-align' })),
|
|
487
|
+
react_1["default"].createElement("button", { "aria-label": 'Right Align', className: 'toolbar-item spaced', onClick: function () {
|
|
488
|
+
editor.dispatchCommand(lexical_1.FORMAT_ELEMENT_COMMAND, 'right');
|
|
489
|
+
}, type: 'button' },
|
|
490
|
+
react_1["default"].createElement("i", { className: 'format right-align' })),
|
|
491
|
+
react_1["default"].createElement("button", { "aria-label": 'Justify Align', className: 'toolbar-item', onClick: function () {
|
|
492
|
+
editor.dispatchCommand(lexical_1.FORMAT_ELEMENT_COMMAND, 'justify');
|
|
493
|
+
}, type: 'button' },
|
|
494
|
+
react_1["default"].createElement("i", { className: 'format justify-align' })),
|
|
495
|
+
' '))),
|
|
496
|
+
react_1["default"].createElement("style", null, "\n ul li {\n /* list-style: inherit !important; */\n list-style-type: disc !important;\n \n }\n \n ol {\n /* list-style: inherit !important; */\n list-style-type: decimal !important;\n }\n .other h2 {\n font-size: 18px;\n color: #444;\n margin-bottom: 7px;\n }\n \n .other a {\n color: #777;\n text-decoration: underline;\n font-size: 14px;\n }\n \n .other ul {\n padding: 0;\n margin: 0;\n list-style-type: none;\n }\n \n .App {\n font-family: sans-serif;\n text-align: center;\n }\n \n h1 {\n font-size: 24px;\n color: #333;\n }\n \n .ltr {\n text-align: left;\n }\n \n .rtl {\n text-align: right;\n }\n \n .editor-container {\n margin: 20px 0px;\n border-radius: 2px;\n max-width: 600px;\n color: #000;\n position: relative;\n line-height: 20px;\n font-weight: 400;\n text-align: left;\n border-top-left-radius: 10px;\n border-top-right-radius: 10px;\n }\n \n .editor-inner {\n background: #fff;\n position: relative;\n }\n \n .editor-input {\n min-height: 150px;\n resize: none;\n font-size: 15px;\n caret-color: rgb(5, 5, 5);\n position: relative;\n tab-size: 1;\n outline: 0;\n padding: 15px 10px;\n caret-color: #444;\n }\n \n .editor-placeholder {\n color: #999;\n overflow: hidden;\n position: absolute;\n text-overflow: ellipsis;\n top: 15px;\n left: 10px;\n font-size: 15px;\n user-select: none;\n display: inline-block;\n pointer-events: none;\n }\n \n .editor-text-bold {\n font-weight: bold;\n }\n \n .editor-text-italic {\n font-style: italic;\n }\n \n .editor-text-underline {\n text-decoration: underline;\n }\n \n .editor-text-strikethrough {\n text-decoration: line-through;\n }\n \n .editor-text-underlineStrikethrough {\n text-decoration: underline line-through;\n }\n \n .editor-text-code {\n background-color: rgb(240, 242, 245);\n padding: 1px 0.25rem;\n font-family: Menlo, Consolas, Monaco, monospace;\n font-size: 94%;\n }\n \n .editor-link {\n color: rgb(33, 111, 219);\n text-decoration: none;\n }\n \n .tree-view-output {\n display: block;\n background: #222;\n color: #fff;\n padding: 5px;\n font-size: 12px;\n white-space: pre-wrap;\n margin: 1px auto 10px auto;\n max-height: 250px;\n position: relative;\n border-bottom-left-radius: 10px;\n border-bottom-right-radius: 10px;\n overflow: auto;\n line-height: 14px;\n }\n \n .editor-code {\n background-color: rgb(240, 242, 245);\n font-family: Menlo, Consolas, Monaco, monospace;\n display: block;\n padding: 8px 8px 8px 52px;\n line-height: 1.53;\n font-size: 13px;\n margin: 0;\n margin-top: 8px;\n margin-bottom: 8px;\n tab-size: 2;\n /* white-space: pre; */\n overflow-x: auto;\n position: relative;\n }\n \n .editor-code:before {\n content: attr(data-gutter);\n position: absolute;\n background-color: #eee;\n left: 0;\n top: 0;\n border-right: 1px solid #ccc;\n padding: 8px;\n color: #777;\n white-space: pre-wrap;\n text-align: right;\n min-width: 25px;\n }\n .editor-code:after {\n content: attr(data-highlight-language);\n top: 0;\n right: 3px;\n padding: 3px;\n font-size: 10px;\n text-transform: uppercase;\n position: absolute;\n color: rgba(0, 0, 0, 0.5);\n }\n \n .editor-tokenComment {\n color: slategray;\n }\n \n .editor-tokenPunctuation {\n color: #999;\n }\n \n .editor-tokenProperty {\n color: #905;\n }\n \n .editor-tokenSelector {\n color: #690;\n }\n \n .editor-tokenOperator {\n color: #9a6e3a;\n }\n \n .editor-tokenAttr {\n color: #07a;\n }\n \n .editor-tokenVariable {\n color: #e90;\n }\n \n .editor-tokenFunction {\n color: #dd4a68;\n }\n \n .editor-paragraph {\n margin: 0;\n margin-bottom: 8px;\n position: relative;\n }\n \n .editor-paragraph:last-child {\n margin-bottom: 0;\n }\n \n .editor-heading-h1 {\n font-size: 24px;\n color: rgb(5, 5, 5);\n font-weight: 400;\n margin: 0;\n margin-bottom: 12px;\n padding: 0;\n }\n \n .editor-heading-h2 {\n font-size: 15px;\n color: rgb(101, 103, 107);\n font-weight: 700;\n margin: 0;\n margin-top: 10px;\n padding: 0;\n text-transform: uppercase;\n }\n \n .editor-quote {\n margin: 0;\n margin-left: 20px;\n font-size: 15px;\n color: rgb(101, 103, 107);\n border-left-color: rgb(206, 208, 212);\n border-left-width: 4px;\n border-left-style: solid;\n padding-left: 16px;\n }\n \n .editor-list-ol {\n padding: 0;\n margin: 0;\n margin-left: 16px;\n }\n \n .editor-list-ul {\n padding: 0;\n margin: 0;\n margin-left: 16px;\n }\n \n .editor-listitem {\n margin: 8px 32px 8px 32px;\n }\n \n .editor-nested-listitem {\n list-style-type: none;\n }\n \n pre::-webkit-scrollbar {\n background: transparent;\n width: 10px;\n }\n \n pre::-webkit-scrollbar-thumb {\n background: #999;\n }\n \n .debug-timetravel-panel {\n overflow: hidden;\n padding: 0 0 10px 0;\n margin: auto;\n display: flex;\n }\n \n .debug-timetravel-panel-slider {\n padding: 0;\n flex: 8;\n }\n \n .debug-timetravel-panel-button {\n padding: 0;\n border: 0;\n background: none;\n flex: 1;\n color: #fff;\n font-size: 12px;\n }\n \n .debug-timetravel-panel-button:hover {\n text-decoration: underline;\n }\n \n .debug-timetravel-button {\n border: 0;\n padding: 0;\n font-size: 12px;\n top: 10px;\n right: 15px;\n position: absolute;\n background: none;\n color: #fff;\n }\n \n .debug-timetravel-button:hover {\n text-decoration: underline;\n }\n \n .toolbar {\n display: flex;\n margin-bottom: 1px;\n background: #fff;\n padding: 4px;\n border-top-left-radius: 10px;\n border-top-right-radius: 10px;\n vertical-align: middle;\n }\n \n .toolbar button.toolbar-item {\n border: 0;\n display: flex;\n background: none;\n border-radius: 10px;\n padding: 8px;\n cursor: pointer;\n vertical-align: middle;\n }\n \n .toolbar button.toolbar-item:disabled {\n cursor: not-allowed;\n }\n \n .toolbar button.toolbar-item.spaced {\n margin-right: 2px;\n }\n \n .toolbar button.toolbar-item i.format {\n background-size: contain;\n display: inline-block;\n height: 18px;\n width: 18px;\n margin-top: 2px;\n vertical-align: -0.25em;\n display: flex;\n opacity: 0.6;\n }\n \n .toolbar button.toolbar-item:disabled i.format {\n opacity: 0.2;\n }\n \n .toolbar button.toolbar-item.active {\n background-color: rgba(223, 232, 250, 0.3);\n }\n \n .toolbar button.toolbar-item.active i {\n opacity: 1;\n }\n \n .toolbar .toolbar-item:hover:not([disabled]) {\n background-color: #eee;\n }\n \n .toolbar .divider {\n width: 1px;\n background-color: #eee;\n margin: 0 4px;\n }\n \n .toolbar select.toolbar-item {\n border: 0;\n display: flex;\n background: none;\n border-radius: 10px;\n padding: 8px;\n vertical-align: middle;\n -webkit-appearance: none;\n -moz-appearance: none;\n width: 70px;\n font-size: 14px;\n color: #777;\n text-overflow: ellipsis;\n }\n \n .toolbar select.code-language {\n text-transform: capitalize;\n width: 130px;\n }\n \n .toolbar .toolbar-item .text {\n display: flex;\n line-height: 20px;\n width: 200px;\n vertical-align: middle;\n font-size: 14px;\n color: #777;\n text-overflow: ellipsis;\n width: 70px;\n overflow: hidden;\n height: 20px;\n text-align: left;\n }\n \n .toolbar .toolbar-item .icon {\n display: flex;\n width: 20px;\n height: 20px;\n user-select: none;\n margin-right: 8px;\n line-height: 16px;\n background-size: contain;\n }\n \n .toolbar i.chevron-down {\n margin-top: 3px;\n width: 16px;\n height: 16px;\n display: flex;\n user-select: none;\n }\n \n .toolbar i.chevron-down.inside {\n width: 16px;\n height: 16px;\n display: flex;\n margin-left: -25px;\n margin-top: 11px;\n margin-right: 10px;\n pointer-events: none;\n }\n \n i.chevron-down {\n background-color: transparent;\n background-size: contain;\n display: inline-block;\n height: 8px;\n width: 8px;\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/chevron-down.svg);\n }\n \n #block-controls button:hover {\n background-color: #efefef;\n }\n \n #block-controls button:focus-visible {\n border-color: blue;\n }\n \n #block-controls span.block-type {\n background-size: contain;\n display: block;\n width: 18px;\n height: 18px;\n margin: 2px;\n }\n \n #block-controls span.block-type.paragraph {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/text-paragraph.svg);\n }\n \n #block-controls span.block-type.h1 {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/type-h1.svg);\n }\n \n #block-controls span.block-type.h2 {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/type-h2.svg);\n }\n \n #block-controls span.block-type.quote {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/chat-square-quote.svg);\n }\n \n #block-controls span.block-type.ul {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/list-ul.svg);\n }\n \n #block-controls span.block-type.ol {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/list-ol.svg);\n }\n \n #block-controls span.block-type.code {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/code.svg);\n }\n \n .dropdown {\n z-index: 5;\n display: block;\n position: absolute;\n box-shadow: 0 12px 28px 0 rgba(0, 0, 0, 0.2), 0 2px 4px 0 rgba(0, 0, 0, 0.1),\n inset 0 0 0 1px rgba(255, 255, 255, 0.5);\n border-radius: 8px;\n min-width: 100px;\n min-height: 40px;\n background-color: #fff;\n }\n \n .dropdown .item {\n margin: 0 8px 0 8px;\n padding: 8px;\n color: #050505;\n cursor: pointer;\n line-height: 16px;\n font-size: 15px;\n display: flex;\n align-content: center;\n flex-direction: row;\n flex-shrink: 0;\n justify-content: space-between;\n background-color: #fff;\n border-radius: 8px;\n border: 0;\n min-width: 268px;\n }\n \n .dropdown .item .active {\n display: flex;\n width: 20px;\n height: 20px;\n background-size: contain;\n }\n \n .dropdown .item:first-child {\n margin-top: 8px;\n }\n \n .dropdown .item:last-child {\n margin-bottom: 8px;\n }\n \n .dropdown .item:hover {\n background-color: #eee;\n }\n \n .dropdown .item .text {\n display: flex;\n line-height: 20px;\n flex-grow: 1;\n width: 200px;\n }\n \n .dropdown .item .icon {\n display: flex;\n width: 20px;\n height: 20px;\n user-select: none;\n margin-right: 12px;\n line-height: 16px;\n background-size: contain;\n }\n \n .link-editor {\n position: absolute;\n z-index: 100;\n top: -10000px;\n left: -10000px;\n margin-top: -6px;\n max-width: 300px;\n width: 100%;\n opacity: 0;\n background-color: #fff;\n box-shadow: 0px 5px 10px rgba(0, 0, 0, 0.3);\n border-radius: 8px;\n transition: opacity 0.5s;\n }\n \n .link-editor .link-input {\n display: block;\n width: calc(100% - 24px);\n box-sizing: border-box;\n margin: 8px 12px;\n padding: 8px 12px;\n border-radius: 15px;\n background-color: #eee;\n font-size: 15px;\n color: rgb(5, 5, 5);\n border: 0;\n outline: 0;\n position: relative;\n font-family: inherit;\n }\n \n .link-editor div.link-edit {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/pencil-fill.svg);\n background-size: 16px;\n background-position: center;\n background-repeat: no-repeat;\n width: 35px;\n vertical-align: -0.25em;\n position: absolute;\n right: 0;\n top: 0;\n bottom: 0;\n cursor: pointer;\n }\n \n .link-editor .link-input a {\n color: rgb(33, 111, 219);\n text-decoration: none;\n display: block;\n white-space: nowrap;\n overflow: hidden;\n margin-right: 30px;\n text-overflow: ellipsis;\n }\n \n .link-editor .link-input a:hover {\n text-decoration: underline;\n }\n \n .link-editor .button {\n width: 20px;\n height: 20px;\n display: inline-block;\n padding: 6px;\n border-radius: 8px;\n cursor: pointer;\n margin: 0 2px;\n }\n \n .link-editor .button.hovered {\n width: 20px;\n height: 20px;\n display: inline-block;\n background-color: #eee;\n }\n \n .link-editor .button i,\n .actions i {\n background-size: contain;\n display: inline-block;\n height: 20px;\n width: 20px;\n vertical-align: -0.25em;\n }\n \n i.undo {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/arrow-counterclockwise.svg);\n }\n \n i.redo {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/arrow-clockwise.svg);\n }\n \n .icon.paragraph {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/text-paragraph.svg);\n }\n \n .icon.large-heading,\n .icon.h1 {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/type-h1.svg);\n }\n \n .icon.small-heading,\n .icon.h2 {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/type-h2.svg);\n }\n \n .icon.bullet-list,\n .icon.ul {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/list-ul.svg);\n }\n \n .icon.numbered-list,\n .icon.ol {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/list-ol.svg);\n }\n \n .icon.quote {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/chat-square-quote.svg);\n }\n \n .icon.code {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/code.svg);\n }\n \n i.bold {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/type-bold.svg);\n }\n \n i.italic {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/type-italic.svg);\n }\n \n i.underline {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/type-underline.svg);\n }\n \n i.strikethrough {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/type-strikethrough.svg);\n }\n \n i.code {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/code.svg);\n }\n \n i.link {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/link.svg);\n }\n \n i.left-align {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/text-left.svg);\n }\n \n i.center-align {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/text-center.svg);\n }\n \n i.right-align {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/text-right.svg);\n }\n \n i.justify-align {\n background-image: url(https://static-data-sisv2.phx-smartschool.com/common/prod/text-editor/images/icons/justify.svg);\n }\n \n \n \n ")));
|
|
497
|
+
}
|
|
498
|
+
exports["default"] = ToolbarPlugin;
|
|
499
|
+
//# sourceMappingURL=ToolbarPlugin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ToolbarPlugin.js","sourceRoot":"","sources":["../../../../../src/components/TextEditor/plugins/ToolbarPlugin.tsx"],"names":[],"mappings":"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"}
|