@webiny/lexical-editor 5.40.0-beta.1 → 5.40.0-beta.3
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/commands/image.js +1 -2
- package/commands/image.js.map +1 -1
- package/commands/index.js.map +1 -1
- package/commands/list.js +3 -6
- package/commands/list.js.map +1 -1
- package/commands/quote.js +1 -2
- package/commands/quote.js.map +1 -1
- package/components/Editor/HeadingEditor.d.ts +2 -2
- package/components/Editor/HeadingEditor.js +1 -2
- package/components/Editor/HeadingEditor.js.map +1 -1
- package/components/Editor/ParagraphEditor.d.ts +2 -2
- package/components/Editor/ParagraphEditor.js +1 -2
- package/components/Editor/ParagraphEditor.js.map +1 -1
- package/components/Editor/RichTextEditor.d.ts +3 -2
- package/components/Editor/RichTextEditor.js +16 -32
- package/components/Editor/RichTextEditor.js.map +1 -1
- package/components/LexicalEditorConfig/LexicalEditorConfig.d.ts +5 -5
- package/components/LexicalEditorConfig/LexicalEditorConfig.js +2 -4
- package/components/LexicalEditorConfig/LexicalEditorConfig.js.map +1 -1
- package/components/LexicalEditorConfig/components/Node.d.ts +2 -2
- package/components/LexicalEditorConfig/components/Node.js +1 -2
- package/components/LexicalEditorConfig/components/Node.js.map +1 -1
- package/components/LexicalEditorConfig/components/Plugin.d.ts +1 -1
- package/components/LexicalEditorConfig/components/Plugin.js +1 -2
- package/components/LexicalEditorConfig/components/Plugin.js.map +1 -1
- package/components/LexicalEditorConfig/components/ToolbarElement.d.ts +1 -1
- package/components/LexicalEditorConfig/components/ToolbarElement.js +1 -2
- package/components/LexicalEditorConfig/components/ToolbarElement.js.map +1 -1
- package/components/LexicalHtmlRenderer.d.ts +2 -6
- package/components/LexicalHtmlRenderer.js +13 -21
- package/components/LexicalHtmlRenderer.js.map +1 -1
- package/components/Toolbar/StaticToolbar.css +1 -1
- package/components/Toolbar/StaticToolbar.d.ts +2 -2
- package/components/Toolbar/StaticToolbar.js +4 -8
- package/components/Toolbar/StaticToolbar.js.map +1 -1
- package/components/Toolbar/Toolbar.css +73 -72
- package/components/Toolbar/Toolbar.js +19 -7
- package/components/Toolbar/Toolbar.js.map +1 -1
- package/components/ToolbarActions/BoldAction.d.ts +2 -2
- package/components/ToolbarActions/BoldAction.js +4 -7
- package/components/ToolbarActions/BoldAction.js.map +1 -1
- package/components/ToolbarActions/BulletListAction.d.ts +2 -2
- package/components/ToolbarActions/BulletListAction.js +6 -10
- package/components/ToolbarActions/BulletListAction.js.map +1 -1
- package/components/ToolbarActions/CodeHighlightAction.d.ts +2 -2
- package/components/ToolbarActions/CodeHighlightAction.js +4 -7
- package/components/ToolbarActions/CodeHighlightAction.js.map +1 -1
- package/components/ToolbarActions/FontColorAction.d.ts +2 -1
- package/components/ToolbarActions/FontColorAction.js +5 -10
- package/components/ToolbarActions/FontColorAction.js.map +1 -1
- package/components/ToolbarActions/FontSizeAction.d.ts +2 -2
- package/components/ToolbarActions/FontSizeAction.js +4 -6
- package/components/ToolbarActions/FontSizeAction.js.map +1 -1
- package/components/ToolbarActions/ImageAction.d.ts +2 -2
- package/components/ToolbarActions/ImageAction.js +2 -6
- package/components/ToolbarActions/ImageAction.js.map +1 -1
- package/components/ToolbarActions/ItalicAction.d.ts +2 -2
- package/components/ToolbarActions/ItalicAction.js +4 -7
- package/components/ToolbarActions/ItalicAction.js.map +1 -1
- package/components/ToolbarActions/LinkAction.d.ts +2 -2
- package/components/ToolbarActions/LinkAction.js +4 -8
- package/components/ToolbarActions/LinkAction.js.map +1 -1
- package/components/ToolbarActions/NumberedListAction.d.ts +2 -2
- package/components/ToolbarActions/NumberedListAction.js +2 -7
- package/components/ToolbarActions/NumberedListAction.js.map +1 -1
- package/components/ToolbarActions/QuoteAction.d.ts +2 -2
- package/components/ToolbarActions/QuoteAction.js +2 -7
- package/components/ToolbarActions/QuoteAction.js.map +1 -1
- package/components/ToolbarActions/TextAlignmentAction.d.ts +2 -1
- package/components/ToolbarActions/TextAlignmentAction.js +5 -10
- package/components/ToolbarActions/TextAlignmentAction.js.map +1 -1
- package/components/ToolbarActions/TypographyAction.d.ts +2 -1
- package/components/ToolbarActions/TypographyAction.js +3 -8
- package/components/ToolbarActions/TypographyAction.js.map +1 -1
- package/components/ToolbarActions/UnderlineAction.d.ts +2 -2
- package/components/ToolbarActions/UnderlineAction.js +5 -9
- package/components/ToolbarActions/UnderlineAction.js.map +1 -1
- package/context/FontColorActionContext.js +1 -2
- package/context/FontColorActionContext.js.map +1 -1
- package/context/RichTextEditorContext.d.ts +6 -11
- package/context/RichTextEditorContext.js +13 -39
- package/context/RichTextEditorContext.js.map +1 -1
- package/context/SharedHistoryContext.js +7 -8
- package/context/SharedHistoryContext.js.map +1 -1
- package/context/TextAlignmentActionContextProps.js +1 -2
- package/context/TextAlignmentActionContextProps.js.map +1 -1
- package/context/TypographyActionContext.js +1 -2
- package/context/TypographyActionContext.js.map +1 -1
- package/hooks/index.d.ts +1 -0
- package/hooks/index.js +11 -0
- package/hooks/index.js.map +1 -1
- package/hooks/useCurrentElement.js.map +1 -1
- package/hooks/useCurrentSelection.js +5 -7
- package/hooks/useCurrentSelection.js.map +1 -1
- package/hooks/useFontColorPicker.js.map +1 -1
- package/hooks/useIsMounted.js.map +1 -1
- package/hooks/useList.js.map +1 -1
- package/hooks/useQuote.js.map +1 -1
- package/hooks/useRichTextEditor.js.map +1 -1
- package/hooks/useTextAlignmentAction.js.map +1 -1
- package/hooks/useTypographyAction.js.map +1 -1
- package/index.d.ts +1 -1
- package/index.js +2 -2
- package/index.js.map +1 -1
- package/package.json +12 -10
- package/plugins/BlurEventPlugin/BlurEventPlugin.js +4 -8
- package/plugins/BlurEventPlugin/BlurEventPlugin.js.map +1 -1
- package/plugins/CodeHighlightPlugin/CodeHighlightPlugin.js +3 -6
- package/plugins/CodeHighlightPlugin/CodeHighlightPlugin.js.map +1 -1
- package/plugins/CodeHighlightPlugin/index.js.map +1 -1
- package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorPlugin.css +58 -5
- package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorPlugin.d.ts +14 -1
- package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorPlugin.js +60 -141
- package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorPlugin.js.map +1 -1
- package/plugins/FloatingLinkEditorPlugin/LinkEditForm.d.ts +9 -0
- package/plugins/FloatingLinkEditorPlugin/LinkEditForm.js +118 -0
- package/plugins/FloatingLinkEditorPlugin/LinkEditForm.js.map +1 -0
- package/plugins/FloatingLinkEditorPlugin/LinkPreviewForm.d.ts +9 -0
- package/plugins/FloatingLinkEditorPlugin/LinkPreviewForm.js +44 -0
- package/plugins/FloatingLinkEditorPlugin/LinkPreviewForm.js.map +1 -0
- package/plugins/FloatingLinkEditorPlugin/index.js.map +1 -1
- package/plugins/FloatingLinkEditorPlugin/isChildOfLinkEditor.d.ts +1 -0
- package/plugins/FloatingLinkEditorPlugin/isChildOfLinkEditor.js +18 -0
- package/plugins/FloatingLinkEditorPlugin/isChildOfLinkEditor.js.map +1 -0
- package/plugins/FloatingLinkEditorPlugin/useFloatingLinkEditor.d.ts +2 -0
- package/plugins/FloatingLinkEditorPlugin/useFloatingLinkEditor.js +72 -0
- package/plugins/FloatingLinkEditorPlugin/useFloatingLinkEditor.js.map +1 -0
- package/plugins/FontColorPlugin/FontColorPlugin.js +4 -8
- package/plugins/FontColorPlugin/FontColorPlugin.js.map +1 -1
- package/plugins/ImagesPlugin/ImagesPlugin.js +4 -7
- package/plugins/ImagesPlugin/ImagesPlugin.js.map +1 -1
- package/plugins/LexicalUpdateStatePlugin/UpdateStatePlugin.d.ts +1 -1
- package/plugins/LexicalUpdateStatePlugin/UpdateStatePlugin.js +5 -9
- package/plugins/LexicalUpdateStatePlugin/UpdateStatePlugin.js.map +1 -1
- package/plugins/LexicalUpdateStatePlugin/index.js.map +1 -1
- package/plugins/LinkPlugin/LinkPlugin.js +4 -6
- package/plugins/LinkPlugin/LinkPlugin.js.map +1 -1
- package/plugins/ListPLugin/ListPlugin.js +5 -9
- package/plugins/ListPLugin/ListPlugin.js.map +1 -1
- package/plugins/QuoteNodePlugin/QuoteNodePlugin.js +23 -0
- package/plugins/QuoteNodePlugin/QuoteNodePlugin.js.map +1 -0
- package/plugins/TypographyPlugin/TypographyPlugin.js +4 -8
- package/plugins/TypographyPlugin/TypographyPlugin.js.map +1 -1
- package/types.js.map +1 -1
- package/ui/ContentEditable.js.map +1 -1
- package/ui/Divider.js.map +1 -1
- package/ui/DropDown.d.ts +1 -1
- package/ui/DropDown.js +16 -15
- package/ui/DropDown.js.map +1 -1
- package/ui/ImageResizer.js +5 -4
- package/ui/ImageResizer.js.map +1 -1
- package/ui/LinkPreview.js +3 -2
- package/ui/LinkPreview.js.map +1 -1
- package/ui/Placeholder.js.map +1 -1
- package/ui/TextInput.js.map +1 -1
- package/ui/ToolbarActionDialog.d.ts +2 -3
- package/ui/ToolbarActionDialog.js +13 -32
- package/ui/ToolbarActionDialog.js.map +1 -1
- package/utils/canUseDOM.js +1 -2
- package/utils/canUseDOM.js.map +1 -1
- package/utils/files.js +2 -4
- package/utils/files.js.map +1 -1
- package/utils/generateInitialLexicalValue.js +1 -2
- package/utils/generateInitialLexicalValue.js.map +1 -1
- package/utils/getDOMRangeRect.js.map +1 -1
- package/utils/getSelectedNode.js.map +1 -1
- package/utils/getTransparentImage.js +1 -2
- package/utils/getTransparentImage.js.map +1 -1
- package/utils/insertImage.js +1 -2
- package/utils/insertImage.js.map +1 -1
- package/utils/isAnchorLink.d.ts +1 -0
- package/utils/isAnchorLink.js +11 -0
- package/utils/isAnchorLink.js.map +1 -0
- package/utils/isChildOfFloatingToolbar.d.ts +1 -0
- package/utils/isChildOfFloatingToolbar.js +18 -0
- package/utils/isChildOfFloatingToolbar.js.map +1 -0
- package/utils/isHTMLElement.js.map +1 -1
- package/utils/isValidJSON.js +1 -2
- package/utils/isValidJSON.js.map +1 -1
- package/utils/isValidLexicalData.js +2 -4
- package/utils/isValidLexicalData.js.map +1 -1
- package/utils/point.js +2 -4
- package/utils/point.js.map +1 -1
- package/utils/rect.js +2 -4
- package/utils/rect.js.map +1 -1
- package/utils/sanitizeUrl.js +3 -4
- package/utils/sanitizeUrl.js.map +1 -1
- package/utils/setFloatingElemPosition.js.map +1 -1
- package/plugins/WebinyQuoteNodePlugin/WebinyQuoteNodePlugin.js +0 -26
- package/plugins/WebinyQuoteNodePlugin/WebinyQuoteNodePlugin.js.map +0 -1
- package/utils/isUrlLinkReference.d.ts +0 -1
- package/utils/isUrlLinkReference.js +0 -12
- package/utils/isUrlLinkReference.js.map +0 -1
- /package/plugins/{WebinyQuoteNodePlugin/WebinyQuoteNodePlugin.d.ts → QuoteNodePlugin/QuoteNodePlugin.d.ts} +0 -0
|
@@ -5,33 +5,34 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
5
5
|
Object.defineProperty(exports, "__esModule", {
|
|
6
6
|
value: true
|
|
7
7
|
});
|
|
8
|
+
exports.FloatingLinkEditor = FloatingLinkEditor;
|
|
8
9
|
exports.FloatingLinkEditorPlugin = FloatingLinkEditorPlugin;
|
|
9
|
-
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
|
10
10
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
11
11
|
var _react = _interopRequireWildcard(require("react"));
|
|
12
|
-
var _reactDom = require("react-dom");
|
|
13
|
-
require("./FloatingLinkEditorPlugin.css");
|
|
14
|
-
var _LexicalComposerContext = require("@lexical/react/LexicalComposerContext");
|
|
15
12
|
var _utils = require("@lexical/utils");
|
|
16
13
|
var _lexical = require("lexical");
|
|
17
14
|
var _lexicalNodes = require("@webiny/lexical-nodes");
|
|
18
|
-
var _LinkPreview = require("../../ui/LinkPreview");
|
|
19
15
|
var _getSelectedNode = require("../../utils/getSelectedNode");
|
|
20
|
-
var _sanitizeUrl = require("../../utils/sanitizeUrl");
|
|
21
16
|
var _setFloatingElemPosition = require("../../utils/setFloatingElemPosition");
|
|
22
|
-
var
|
|
17
|
+
var _useFloatingLinkEditor = require("./useFloatingLinkEditor");
|
|
18
|
+
var _LinkEditForm = require("./LinkEditForm");
|
|
19
|
+
var _LinkPreviewForm = require("./LinkPreviewForm");
|
|
20
|
+
require("./FloatingLinkEditorPlugin.css");
|
|
21
|
+
var _sanitizeUrl = require("../../utils/sanitizeUrl");
|
|
22
|
+
var _isChildOfLinkEditor = require("./isChildOfLinkEditor");
|
|
23
23
|
function FloatingLinkEditor(_ref) {
|
|
24
24
|
var editor = _ref.editor,
|
|
25
|
+
isVisible = _ref.isVisible,
|
|
25
26
|
anchorElem = _ref.anchorElem;
|
|
26
27
|
var editorRef = (0, _react.useRef)(null);
|
|
27
|
-
var inputRef = (0, _react.useRef)(null);
|
|
28
28
|
var _useState = (0, _react.useState)({
|
|
29
29
|
url: "",
|
|
30
|
-
target: null
|
|
30
|
+
target: null,
|
|
31
|
+
alt: null
|
|
31
32
|
}),
|
|
32
33
|
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
33
|
-
|
|
34
|
-
|
|
34
|
+
linkData = _useState2[0],
|
|
35
|
+
setLinkData = _useState2[1];
|
|
35
36
|
var _useState3 = (0, _react.useState)(false),
|
|
36
37
|
_useState4 = (0, _slicedToArray2.default)(_useState3, 2),
|
|
37
38
|
isEditMode = _useState4[0],
|
|
@@ -42,24 +43,30 @@ function FloatingLinkEditor(_ref) {
|
|
|
42
43
|
setLastSelection = _useState6[1];
|
|
43
44
|
var updateLinkEditor = (0, _react.useCallback)(function () {
|
|
44
45
|
var selection = (0, _lexical.$getSelection)();
|
|
46
|
+
var emptyLinkData = {
|
|
47
|
+
url: "",
|
|
48
|
+
target: null,
|
|
49
|
+
alt: null
|
|
50
|
+
};
|
|
45
51
|
if ((0, _lexical.$isRangeSelection)(selection)) {
|
|
46
52
|
var node = (0, _getSelectedNode.getSelectedNode)(selection);
|
|
47
53
|
var parent = node.getParent();
|
|
48
54
|
if ((0, _lexicalNodes.$isLinkNode)(parent)) {
|
|
49
|
-
|
|
55
|
+
var _linkData = {
|
|
50
56
|
url: parent.getURL(),
|
|
51
|
-
target: parent.getTarget()
|
|
52
|
-
|
|
57
|
+
target: parent.getTarget(),
|
|
58
|
+
alt: (0, _lexicalNodes.$isLinkNode)(parent) ? parent.getAlt() : null
|
|
59
|
+
};
|
|
60
|
+
setLinkData(_linkData);
|
|
53
61
|
} else if ((0, _lexicalNodes.$isLinkNode)(node)) {
|
|
54
|
-
|
|
62
|
+
var _linkData2 = {
|
|
55
63
|
url: node.getURL(),
|
|
56
|
-
target: node.getTarget()
|
|
57
|
-
|
|
64
|
+
target: node.getTarget(),
|
|
65
|
+
alt: (0, _lexicalNodes.$isLinkNode)(node) ? node.getAlt() : null
|
|
66
|
+
};
|
|
67
|
+
setLinkData(_linkData2);
|
|
58
68
|
} else {
|
|
59
|
-
|
|
60
|
-
url: "",
|
|
61
|
-
target: null
|
|
62
|
-
});
|
|
69
|
+
setLinkData(emptyLinkData);
|
|
63
70
|
}
|
|
64
71
|
}
|
|
65
72
|
var editorElem = editorRef.current;
|
|
@@ -89,10 +96,7 @@ function FloatingLinkEditor(_ref) {
|
|
|
89
96
|
}
|
|
90
97
|
setLastSelection(null);
|
|
91
98
|
setEditMode(false);
|
|
92
|
-
|
|
93
|
-
url: "",
|
|
94
|
-
target: null
|
|
95
|
-
});
|
|
99
|
+
setLinkData(emptyLinkData);
|
|
96
100
|
}
|
|
97
101
|
return true;
|
|
98
102
|
}, [anchorElem, editor]);
|
|
@@ -100,6 +104,17 @@ function FloatingLinkEditor(_ref) {
|
|
|
100
104
|
editor.dispatchCommand(_lexicalNodes.TOGGLE_LINK_COMMAND, null);
|
|
101
105
|
setEditMode(false);
|
|
102
106
|
};
|
|
107
|
+
var applyChanges = function applyChanges(linkData) {
|
|
108
|
+
var confirmedLinkData = {
|
|
109
|
+
url: (0, _sanitizeUrl.sanitizeUrl)(linkData.url),
|
|
110
|
+
target: linkData.target,
|
|
111
|
+
alt: linkData.alt
|
|
112
|
+
};
|
|
113
|
+
if (lastSelection !== null) {
|
|
114
|
+
editor.dispatchCommand(_lexicalNodes.TOGGLE_LINK_COMMAND, confirmedLinkData);
|
|
115
|
+
setEditMode(false);
|
|
116
|
+
}
|
|
117
|
+
};
|
|
103
118
|
(0, _react.useEffect)(function () {
|
|
104
119
|
var scrollerElem = anchorElem.parentElement;
|
|
105
120
|
var update = function update() {
|
|
@@ -126,7 +141,12 @@ function FloatingLinkEditor(_ref) {
|
|
|
126
141
|
});
|
|
127
142
|
}), editor.registerCommand(_lexical.SELECTION_CHANGE_COMMAND, function () {
|
|
128
143
|
updateLinkEditor();
|
|
129
|
-
return
|
|
144
|
+
return false;
|
|
145
|
+
}, _lexical.COMMAND_PRIORITY_LOW), editor.registerCommand(_lexical.BLUR_COMMAND, function (payload) {
|
|
146
|
+
if (!(0, _isChildOfLinkEditor.isChildOfLinkEditor)(payload.relatedTarget)) {
|
|
147
|
+
setEditMode(false);
|
|
148
|
+
}
|
|
149
|
+
return false;
|
|
130
150
|
}, _lexical.COMMAND_PRIORITY_LOW));
|
|
131
151
|
}, [editor, updateLinkEditor]);
|
|
132
152
|
(0, _react.useEffect)(function () {
|
|
@@ -134,131 +154,30 @@ function FloatingLinkEditor(_ref) {
|
|
|
134
154
|
updateLinkEditor();
|
|
135
155
|
});
|
|
136
156
|
}, [editor, updateLinkEditor]);
|
|
137
|
-
(0, _react.useEffect)(function () {
|
|
138
|
-
if (isEditMode && inputRef.current) {
|
|
139
|
-
inputRef.current.focus();
|
|
140
|
-
}
|
|
141
|
-
}, [isEditMode]);
|
|
142
157
|
return /*#__PURE__*/_react.default.createElement("div", {
|
|
143
158
|
ref: editorRef,
|
|
144
|
-
className: "link-editor"
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
}, /*#__PURE__*/_react.default.createElement("input", {
|
|
148
|
-
type: "checkbox",
|
|
149
|
-
checked: linkUrl.target === "_blank",
|
|
150
|
-
disabled: (0, _isUrlLinkReference.isUrlLinkReference)(linkUrl.url),
|
|
151
|
-
onChange: function onChange() {
|
|
152
|
-
return setLinkUrl((0, _objectSpread2.default)((0, _objectSpread2.default)({}, linkUrl), {}, {
|
|
153
|
-
target: linkUrl.target ? null : "_blank"
|
|
154
|
-
}));
|
|
159
|
+
className: "link-editor",
|
|
160
|
+
style: {
|
|
161
|
+
display: isVisible ? "block" : "none"
|
|
155
162
|
}
|
|
156
|
-
}
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
setLinkUrl({
|
|
162
|
-
url: event.target.value,
|
|
163
|
-
target: null
|
|
164
|
-
});
|
|
165
|
-
},
|
|
166
|
-
onKeyDown: function onKeyDown(event) {
|
|
167
|
-
if (event.key === "Enter") {
|
|
168
|
-
event.preventDefault();
|
|
169
|
-
if (lastSelection !== null) {
|
|
170
|
-
if (linkUrl.url !== "") {
|
|
171
|
-
editor.dispatchCommand(_lexicalNodes.TOGGLE_LINK_COMMAND, {
|
|
172
|
-
url: (0, _sanitizeUrl.sanitizeUrl)(linkUrl.url),
|
|
173
|
-
target: linkUrl.target
|
|
174
|
-
});
|
|
175
|
-
}
|
|
176
|
-
setEditMode(false);
|
|
177
|
-
}
|
|
178
|
-
} else if (event.key === "Escape") {
|
|
179
|
-
event.preventDefault();
|
|
180
|
-
setEditMode(false);
|
|
181
|
-
}
|
|
163
|
+
}, isEditMode ? /*#__PURE__*/_react.default.createElement(_LinkEditForm.LinkEditForm, {
|
|
164
|
+
linkData: linkData,
|
|
165
|
+
onSave: applyChanges,
|
|
166
|
+
onCancel: function onCancel() {
|
|
167
|
+
return setEditMode(false);
|
|
182
168
|
}
|
|
183
|
-
})
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
checked: linkUrl.target === "_blank",
|
|
188
|
-
readOnly: true
|
|
189
|
-
}), " ", /*#__PURE__*/_react.default.createElement("span", null, "New tab")), /*#__PURE__*/_react.default.createElement("div", {
|
|
190
|
-
className: "link-input"
|
|
191
|
-
}, /*#__PURE__*/_react.default.createElement("a", {
|
|
192
|
-
href: linkUrl.url,
|
|
193
|
-
target: "_blank",
|
|
194
|
-
rel: "noopener noreferrer"
|
|
195
|
-
}, linkUrl.url), /*#__PURE__*/_react.default.createElement("div", {
|
|
196
|
-
className: "link-edit",
|
|
197
|
-
role: "button",
|
|
198
|
-
tabIndex: 0,
|
|
199
|
-
onMouseDown: function onMouseDown(event) {
|
|
200
|
-
return event.preventDefault();
|
|
201
|
-
},
|
|
202
|
-
onClick: function onClick() {
|
|
169
|
+
}) : /*#__PURE__*/_react.default.createElement(_LinkPreviewForm.LinkPreviewForm, {
|
|
170
|
+
linkData: linkData,
|
|
171
|
+
removeLink: removeLink,
|
|
172
|
+
onEdit: function onEdit() {
|
|
203
173
|
setEditMode(true);
|
|
204
174
|
}
|
|
205
|
-
})
|
|
206
|
-
className: "link-unlink",
|
|
207
|
-
role: "button",
|
|
208
|
-
tabIndex: 0,
|
|
209
|
-
onMouseDown: function onMouseDown(event) {
|
|
210
|
-
return event.preventDefault();
|
|
211
|
-
},
|
|
212
|
-
onClick: function onClick() {
|
|
213
|
-
removeLink();
|
|
214
|
-
}
|
|
215
|
-
})), /*#__PURE__*/_react.default.createElement(_LinkPreview.LinkPreview, {
|
|
216
|
-
url: linkUrl.url
|
|
217
|
-
})));
|
|
218
|
-
}
|
|
219
|
-
function useFloatingLinkEditorToolbar(editor, anchorElem) {
|
|
220
|
-
var _useState7 = (0, _react.useState)(editor),
|
|
221
|
-
_useState8 = (0, _slicedToArray2.default)(_useState7, 2),
|
|
222
|
-
activeEditor = _useState8[0],
|
|
223
|
-
setActiveEditor = _useState8[1];
|
|
224
|
-
var _useState9 = (0, _react.useState)(false),
|
|
225
|
-
_useState10 = (0, _slicedToArray2.default)(_useState9, 2),
|
|
226
|
-
isLink = _useState10[0],
|
|
227
|
-
setIsLink = _useState10[1];
|
|
228
|
-
var updateToolbar = (0, _react.useCallback)(function () {
|
|
229
|
-
var selection = (0, _lexical.$getSelection)();
|
|
230
|
-
if ((0, _lexical.$isRangeSelection)(selection)) {
|
|
231
|
-
var node = (0, _getSelectedNode.getSelectedNode)(selection);
|
|
232
|
-
var linkParent = (0, _utils.$findMatchingParent)(node, _lexicalNodes.$isLinkNode);
|
|
233
|
-
var autoLinkParent = (0, _utils.$findMatchingParent)(node, _lexicalNodes.$isAutoLinkNode);
|
|
234
|
-
|
|
235
|
-
// We don't want this menu to open for auto links.
|
|
236
|
-
if (linkParent != null && autoLinkParent == null) {
|
|
237
|
-
setIsLink(true);
|
|
238
|
-
} else {
|
|
239
|
-
setIsLink(false);
|
|
240
|
-
}
|
|
241
|
-
}
|
|
242
|
-
}, []);
|
|
243
|
-
(0, _react.useEffect)(function () {
|
|
244
|
-
return editor.registerCommand(_lexical.SELECTION_CHANGE_COMMAND, function (_payload, newEditor) {
|
|
245
|
-
updateToolbar();
|
|
246
|
-
setActiveEditor(newEditor);
|
|
247
|
-
return false;
|
|
248
|
-
}, _lexical.COMMAND_PRIORITY_CRITICAL);
|
|
249
|
-
}, [editor, updateToolbar]);
|
|
250
|
-
return isLink ? /*#__PURE__*/(0, _reactDom.createPortal)( /*#__PURE__*/_react.default.createElement(FloatingLinkEditor, {
|
|
251
|
-
editor: activeEditor,
|
|
252
|
-
anchorElem: anchorElem
|
|
253
|
-
}), anchorElem) : null;
|
|
175
|
+
}));
|
|
254
176
|
}
|
|
255
177
|
function FloatingLinkEditorPlugin(_ref3) {
|
|
256
178
|
var _ref3$anchorElem = _ref3.anchorElem,
|
|
257
179
|
anchorElem = _ref3$anchorElem === void 0 ? document.body : _ref3$anchorElem;
|
|
258
|
-
|
|
259
|
-
_useLexicalComposerCo2 = (0, _slicedToArray2.default)(_useLexicalComposerCo, 1),
|
|
260
|
-
editor = _useLexicalComposerCo2[0];
|
|
261
|
-
return useFloatingLinkEditorToolbar(editor, anchorElem);
|
|
180
|
+
return (0, _useFloatingLinkEditor.useFloatingLinkEditor)(anchorElem);
|
|
262
181
|
}
|
|
263
182
|
|
|
264
183
|
//# sourceMappingURL=FloatingLinkEditorPlugin.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_react","_interopRequireWildcard","require","_reactDom","_LexicalComposerContext","_utils","_lexical","_lexicalNodes","_LinkPreview","_getSelectedNode","_sanitizeUrl","_setFloatingElemPosition","_isUrlLinkReference","FloatingLinkEditor","_ref","editor","anchorElem","editorRef","useRef","inputRef","_useState","useState","url","target","_useState2","_slicedToArray2","default","linkUrl","setLinkUrl","_useState3","_useState4","isEditMode","setEditMode","_useState5","_useState6","lastSelection","setLastSelection","updateLinkEditor","useCallback","selection","$getSelection","$isRangeSelection","node","getSelectedNode","parent","getParent","$isLinkNode","getURL","getTarget","editorElem","current","nativeSelection","window","getSelection","activeElement","document","rootElement","getRootElement","contains","anchorNode","domRange","getRangeAt","rect","inner","firstElementChild","getBoundingClientRect","setFloatingElemPosition","className","removeLink","dispatchCommand","TOGGLE_LINK_COMMAND","useEffect","scrollerElem","parentElement","update","getEditorState","read","addEventListener","removeEventListener","mergeRegister","registerUpdateListener","_ref2","editorState","registerCommand","SELECTION_CHANGE_COMMAND","COMMAND_PRIORITY_LOW","focus","createElement","ref","Fragment","type","checked","disabled","isUrlLinkReference","onChange","_objectSpread2","value","event","onKeyDown","key","preventDefault","sanitizeUrl","readOnly","href","rel","role","tabIndex","onMouseDown","onClick","LinkPreview","useFloatingLinkEditorToolbar","_useState7","_useState8","activeEditor","setActiveEditor","_useState9","_useState10","isLink","setIsLink","updateToolbar","linkParent","$findMatchingParent","autoLinkParent","$isAutoLinkNode","_payload","newEditor","COMMAND_PRIORITY_CRITICAL","createPortal","FloatingLinkEditorPlugin","_ref3","_ref3$anchorElem","body","_useLexicalComposerCo","useLexicalComposerContext","_useLexicalComposerCo2"],"sources":["FloatingLinkEditorPlugin.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { createPortal } from \"react-dom\";\nimport \"./FloatingLinkEditorPlugin.css\";\nimport { useLexicalComposerContext } from \"@lexical/react/LexicalComposerContext\";\nimport { $findMatchingParent, mergeRegister } from \"@lexical/utils\";\nimport {\n $getSelection,\n $isRangeSelection,\n COMMAND_PRIORITY_CRITICAL,\n COMMAND_PRIORITY_LOW,\n GridSelection,\n LexicalEditor,\n NodeSelection,\n RangeSelection,\n SELECTION_CHANGE_COMMAND\n} from \"lexical\";\n\nimport { $isAutoLinkNode, $isLinkNode, TOGGLE_LINK_COMMAND } from \"@webiny/lexical-nodes\";\nimport { LinkPreview } from \"~/ui/LinkPreview\";\nimport { getSelectedNode } from \"~/utils/getSelectedNode\";\nimport { sanitizeUrl } from \"~/utils/sanitizeUrl\";\nimport { setFloatingElemPosition } from \"~/utils/setFloatingElemPosition\";\nimport { isUrlLinkReference } from \"~/utils/isUrlLinkReference\";\n\nfunction FloatingLinkEditor({\n editor,\n anchorElem\n}: {\n editor: LexicalEditor;\n anchorElem: HTMLElement;\n}): JSX.Element {\n const editorRef = useRef<HTMLDivElement | null>(null);\n const inputRef = useRef<HTMLInputElement>(null);\n const [linkUrl, setLinkUrl] = useState<{ url: string; target: string | null }>({\n url: \"\",\n target: null\n });\n const [isEditMode, setEditMode] = useState(false);\n const [lastSelection, setLastSelection] = useState<\n RangeSelection | GridSelection | NodeSelection | null\n >(null);\n\n const updateLinkEditor = useCallback(() => {\n const selection = $getSelection();\n if ($isRangeSelection(selection)) {\n const node = getSelectedNode(selection);\n const parent = node.getParent();\n if ($isLinkNode(parent)) {\n setLinkUrl({ url: parent.getURL(), target: parent.getTarget() });\n } else if ($isLinkNode(node)) {\n setLinkUrl({ url: node.getURL(), target: node.getTarget() });\n } else {\n setLinkUrl({ url: \"\", target: null });\n }\n }\n const editorElem = editorRef.current;\n const nativeSelection = window.getSelection();\n const activeElement = document.activeElement;\n\n if (editorElem === null) {\n return;\n }\n\n const rootElement = editor.getRootElement();\n\n if (\n selection !== null &&\n nativeSelection !== null &&\n rootElement !== null &&\n rootElement.contains(nativeSelection.anchorNode)\n ) {\n const domRange = nativeSelection.getRangeAt(0);\n let rect;\n if (nativeSelection.anchorNode === rootElement) {\n let inner = rootElement;\n while (inner.firstElementChild != null) {\n inner = inner.firstElementChild as HTMLElement;\n }\n rect = inner.getBoundingClientRect();\n } else {\n rect = domRange.getBoundingClientRect();\n }\n\n setFloatingElemPosition(rect, editorElem, anchorElem);\n setLastSelection(selection);\n } else if (!activeElement || activeElement.className !== \"link-input\") {\n if (rootElement !== null) {\n setFloatingElemPosition(null, editorElem, anchorElem);\n }\n setLastSelection(null);\n setEditMode(false);\n setLinkUrl({ url: \"\", target: null });\n }\n\n return true;\n }, [anchorElem, editor]);\n\n const removeLink = () => {\n editor.dispatchCommand(TOGGLE_LINK_COMMAND, null);\n setEditMode(false);\n };\n\n useEffect(() => {\n const scrollerElem = anchorElem.parentElement;\n\n const update = () => {\n editor.getEditorState().read(() => {\n updateLinkEditor();\n });\n };\n\n window.addEventListener(\"resize\", update);\n\n if (scrollerElem) {\n scrollerElem.addEventListener(\"scroll\", update);\n }\n\n return () => {\n window.removeEventListener(\"resize\", update);\n\n if (scrollerElem) {\n scrollerElem.removeEventListener(\"scroll\", update);\n }\n };\n }, [anchorElem.parentElement, editor, updateLinkEditor]);\n\n useEffect(() => {\n return mergeRegister(\n editor.registerUpdateListener(({ editorState }) => {\n editorState.read(() => {\n updateLinkEditor();\n });\n }),\n\n editor.registerCommand(\n SELECTION_CHANGE_COMMAND,\n () => {\n updateLinkEditor();\n return true;\n },\n COMMAND_PRIORITY_LOW\n )\n );\n }, [editor, updateLinkEditor]);\n\n useEffect(() => {\n editor.getEditorState().read(() => {\n updateLinkEditor();\n });\n }, [editor, updateLinkEditor]);\n\n useEffect(() => {\n if (isEditMode && inputRef.current) {\n inputRef.current.focus();\n }\n }, [isEditMode]);\n\n return (\n <div ref={editorRef} className=\"link-editor\">\n {isEditMode ? (\n <>\n <div className={\"link-editor-target-checkbox\"}>\n <input\n type={\"checkbox\"}\n checked={linkUrl.target === \"_blank\"}\n disabled={isUrlLinkReference(linkUrl.url)}\n onChange={() =>\n setLinkUrl({ ...linkUrl, target: linkUrl.target ? null : \"_blank\" })\n }\n />{\" \"}\n <span>New tab</span>\n </div>\n <input\n ref={inputRef}\n className=\"link-input\"\n value={linkUrl.url}\n onChange={event => {\n setLinkUrl({ url: event.target.value, target: null });\n }}\n onKeyDown={event => {\n if (event.key === \"Enter\") {\n event.preventDefault();\n if (lastSelection !== null) {\n if (linkUrl.url !== \"\") {\n editor.dispatchCommand(TOGGLE_LINK_COMMAND, {\n url: sanitizeUrl(linkUrl.url),\n target: linkUrl.target\n });\n }\n setEditMode(false);\n }\n } else if (event.key === \"Escape\") {\n event.preventDefault();\n setEditMode(false);\n }\n }}\n />\n </>\n ) : (\n <>\n <div className={\"link-editor-target-checkbox\"}>\n <input type={\"checkbox\"} checked={linkUrl.target === \"_blank\"} readOnly />{\" \"}\n <span>New tab</span>\n </div>\n <div className=\"link-input\">\n <a href={linkUrl.url} target=\"_blank\" rel=\"noopener noreferrer\">\n {linkUrl.url}\n </a>\n <div\n className=\"link-edit\"\n role=\"button\"\n tabIndex={0}\n onMouseDown={event => event.preventDefault()}\n onClick={() => {\n setEditMode(true);\n }}\n />\n <div\n className=\"link-unlink\"\n role=\"button\"\n tabIndex={0}\n onMouseDown={event => event.preventDefault()}\n onClick={() => {\n removeLink();\n }}\n />\n </div>\n <LinkPreview url={linkUrl.url} />\n </>\n )}\n </div>\n );\n}\n\nfunction useFloatingLinkEditorToolbar(\n editor: LexicalEditor,\n anchorElem: HTMLElement\n): JSX.Element | null {\n const [activeEditor, setActiveEditor] = useState(editor);\n const [isLink, setIsLink] = useState(false);\n\n const updateToolbar = useCallback(() => {\n const selection = $getSelection();\n if ($isRangeSelection(selection)) {\n const node = getSelectedNode(selection);\n const linkParent = $findMatchingParent(node, $isLinkNode);\n const autoLinkParent = $findMatchingParent(node, $isAutoLinkNode);\n\n // We don't want this menu to open for auto links.\n if (linkParent != null && autoLinkParent == null) {\n setIsLink(true);\n } else {\n setIsLink(false);\n }\n }\n }, []);\n\n useEffect(() => {\n return editor.registerCommand(\n SELECTION_CHANGE_COMMAND,\n (_payload, newEditor) => {\n updateToolbar();\n setActiveEditor(newEditor);\n return false;\n },\n COMMAND_PRIORITY_CRITICAL\n );\n }, [editor, updateToolbar]);\n\n return isLink\n ? createPortal(\n <FloatingLinkEditor editor={activeEditor} anchorElem={anchorElem} />,\n anchorElem\n )\n : null;\n}\n\nexport function FloatingLinkEditorPlugin({\n anchorElem = document.body\n}: {\n anchorElem?: HTMLElement;\n}): JSX.Element | null {\n const [editor] = useLexicalComposerContext();\n return useFloatingLinkEditorToolbar(editor, anchorElem);\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireWildcard","require","_utils","_lexical","_lexicalNodes","_getSelectedNode","_setFloatingElemPosition","_useFloatingLinkEditor","_LinkEditForm","_LinkPreviewForm","_sanitizeUrl","_isChildOfLinkEditor","FloatingLinkEditor","_ref","editor","isVisible","anchorElem","editorRef","useRef","_useState","useState","url","target","alt","_useState2","_slicedToArray2","default","linkData","setLinkData","_useState3","_useState4","isEditMode","setEditMode","_useState5","_useState6","lastSelection","setLastSelection","updateLinkEditor","useCallback","selection","$getSelection","emptyLinkData","$isRangeSelection","node","getSelectedNode","parent","getParent","$isLinkNode","getURL","getTarget","getAlt","editorElem","current","nativeSelection","window","getSelection","activeElement","document","rootElement","getRootElement","contains","anchorNode","domRange","getRangeAt","rect","inner","firstElementChild","getBoundingClientRect","setFloatingElemPosition","className","removeLink","dispatchCommand","TOGGLE_LINK_COMMAND","applyChanges","confirmedLinkData","sanitizeUrl","useEffect","scrollerElem","parentElement","update","getEditorState","read","addEventListener","removeEventListener","mergeRegister","registerUpdateListener","_ref2","editorState","registerCommand","SELECTION_CHANGE_COMMAND","COMMAND_PRIORITY_LOW","BLUR_COMMAND","payload","isChildOfLinkEditor","relatedTarget","createElement","ref","style","display","LinkEditForm","onSave","onCancel","LinkPreviewForm","onEdit","FloatingLinkEditorPlugin","_ref3","_ref3$anchorElem","body","useFloatingLinkEditor"],"sources":["FloatingLinkEditorPlugin.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { mergeRegister } from \"@lexical/utils\";\nimport {\n $getSelection,\n $isRangeSelection,\n BLUR_COMMAND,\n COMMAND_PRIORITY_LOW,\n GridSelection,\n LexicalEditor,\n NodeSelection,\n RangeSelection,\n SELECTION_CHANGE_COMMAND\n} from \"lexical\";\nimport { $isLinkNode, TOGGLE_LINK_COMMAND } from \"@webiny/lexical-nodes\";\nimport { getSelectedNode } from \"~/utils/getSelectedNode\";\nimport { setFloatingElemPosition } from \"~/utils/setFloatingElemPosition\";\nimport { useFloatingLinkEditor } from \"./useFloatingLinkEditor\";\nimport { LinkEditForm } from \"./LinkEditForm\";\nimport { LinkPreviewForm } from \"./LinkPreviewForm\";\nimport \"./FloatingLinkEditorPlugin.css\";\nimport { sanitizeUrl } from \"~/utils/sanitizeUrl\";\nimport { isChildOfLinkEditor } from \"~/plugins/FloatingLinkEditorPlugin/isChildOfLinkEditor\";\n\nexport interface LinkData {\n url: string;\n target: string | null;\n alt: string | null;\n}\n\ninterface FloatingLinkEditorProps {\n editor: LexicalEditor;\n isVisible: boolean;\n anchorElem: HTMLElement;\n}\n\nexport function FloatingLinkEditor({ editor, isVisible, anchorElem }: FloatingLinkEditorProps) {\n const editorRef = useRef<HTMLDivElement | null>(null);\n const [linkData, setLinkData] = useState<LinkData>({\n url: \"\",\n target: null,\n alt: null\n });\n\n const [isEditMode, setEditMode] = useState(false);\n const [lastSelection, setLastSelection] = useState<\n RangeSelection | GridSelection | NodeSelection | null\n >(null);\n\n const updateLinkEditor = useCallback(() => {\n const selection = $getSelection();\n const emptyLinkData = { url: \"\", target: null, alt: null };\n if ($isRangeSelection(selection)) {\n const node = getSelectedNode(selection);\n const parent = node.getParent();\n\n if ($isLinkNode(parent)) {\n const linkData = {\n url: parent.getURL(),\n target: parent.getTarget(),\n alt: $isLinkNode(parent) ? parent.getAlt() : null\n };\n setLinkData(linkData);\n } else if ($isLinkNode(node)) {\n const linkData = {\n url: node.getURL(),\n target: node.getTarget(),\n alt: $isLinkNode(node) ? node.getAlt() : null\n };\n setLinkData(linkData);\n } else {\n setLinkData(emptyLinkData);\n }\n }\n const editorElem = editorRef.current;\n const nativeSelection = window.getSelection();\n const activeElement = document.activeElement;\n\n if (editorElem === null) {\n return;\n }\n\n const rootElement = editor.getRootElement();\n\n if (\n selection !== null &&\n nativeSelection !== null &&\n rootElement !== null &&\n rootElement.contains(nativeSelection.anchorNode)\n ) {\n const domRange = nativeSelection.getRangeAt(0);\n let rect;\n if (nativeSelection.anchorNode === rootElement) {\n let inner = rootElement;\n while (inner.firstElementChild != null) {\n inner = inner.firstElementChild as HTMLElement;\n }\n rect = inner.getBoundingClientRect();\n } else {\n rect = domRange.getBoundingClientRect();\n }\n\n setFloatingElemPosition(rect, editorElem, anchorElem);\n setLastSelection(selection);\n } else if (!activeElement || activeElement.className !== \"link-input\") {\n if (rootElement !== null) {\n setFloatingElemPosition(null, editorElem, anchorElem);\n }\n setLastSelection(null);\n setEditMode(false);\n setLinkData(emptyLinkData);\n }\n\n return true;\n }, [anchorElem, editor]);\n\n const removeLink = () => {\n editor.dispatchCommand(TOGGLE_LINK_COMMAND, null);\n setEditMode(false);\n };\n\n const applyChanges = (linkData: LinkData) => {\n const confirmedLinkData = {\n url: sanitizeUrl(linkData.url),\n target: linkData.target,\n alt: linkData.alt\n };\n\n if (lastSelection !== null) {\n editor.dispatchCommand(TOGGLE_LINK_COMMAND, confirmedLinkData);\n setEditMode(false);\n }\n };\n\n useEffect(() => {\n const scrollerElem = anchorElem.parentElement;\n\n const update = () => {\n editor.getEditorState().read(() => {\n updateLinkEditor();\n });\n };\n\n window.addEventListener(\"resize\", update);\n\n if (scrollerElem) {\n scrollerElem.addEventListener(\"scroll\", update);\n }\n\n return () => {\n window.removeEventListener(\"resize\", update);\n\n if (scrollerElem) {\n scrollerElem.removeEventListener(\"scroll\", update);\n }\n };\n }, [anchorElem.parentElement, editor, updateLinkEditor]);\n\n useEffect(() => {\n return mergeRegister(\n editor.registerUpdateListener(({ editorState }) => {\n editorState.read(() => {\n updateLinkEditor();\n });\n }),\n\n editor.registerCommand(\n SELECTION_CHANGE_COMMAND,\n () => {\n updateLinkEditor();\n return false;\n },\n COMMAND_PRIORITY_LOW\n ),\n\n editor.registerCommand(\n BLUR_COMMAND,\n payload => {\n if (!isChildOfLinkEditor(payload.relatedTarget as HTMLElement)) {\n setEditMode(false);\n }\n return false;\n },\n COMMAND_PRIORITY_LOW\n )\n );\n }, [editor, updateLinkEditor]);\n\n useEffect(() => {\n editor.getEditorState().read(() => {\n updateLinkEditor();\n });\n }, [editor, updateLinkEditor]);\n\n return (\n <div\n ref={editorRef}\n className=\"link-editor\"\n style={{ display: isVisible ? \"block\" : \"none\" }}\n >\n {isEditMode ? (\n <LinkEditForm\n linkData={linkData}\n onSave={applyChanges}\n onCancel={() => setEditMode(false)}\n />\n ) : (\n <LinkPreviewForm\n linkData={linkData}\n removeLink={removeLink}\n onEdit={() => {\n setEditMode(true);\n }}\n />\n )}\n </div>\n );\n}\n\nexport function FloatingLinkEditorPlugin({\n anchorElem = document.body\n}: {\n anchorElem?: HTMLElement;\n}): JSX.Element | null {\n return useFloatingLinkEditor(anchorElem);\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { LinkData } from "./FloatingLinkEditorPlugin";
|
|
3
|
+
interface LinkFormProps {
|
|
4
|
+
linkData: LinkData;
|
|
5
|
+
onSave: (linkData: LinkData) => void;
|
|
6
|
+
onCancel: () => void;
|
|
7
|
+
}
|
|
8
|
+
export declare const LinkEditForm: ({ linkData, onSave, onCancel }: LinkFormProps) => React.JSX.Element;
|
|
9
|
+
export {};
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
4
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.LinkEditForm = void 0;
|
|
9
|
+
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
|
10
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
11
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
12
|
+
var _sanitizeUrl = require("../../utils/sanitizeUrl");
|
|
13
|
+
var _isAnchorLink = require("../../utils/isAnchorLink");
|
|
14
|
+
var LinkEditForm = exports.LinkEditForm = function LinkEditForm(_ref) {
|
|
15
|
+
var linkData = _ref.linkData,
|
|
16
|
+
onSave = _ref.onSave,
|
|
17
|
+
onCancel = _ref.onCancel;
|
|
18
|
+
var _useState = (0, _react.useState)(linkData),
|
|
19
|
+
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
20
|
+
linkState = _useState2[0],
|
|
21
|
+
setLinkState = _useState2[1];
|
|
22
|
+
var onInputKeyDown = function onInputKeyDown(event) {
|
|
23
|
+
if (event.key === "Enter") {
|
|
24
|
+
event.preventDefault();
|
|
25
|
+
onSubmit();
|
|
26
|
+
} else if (event.key === "Escape") {
|
|
27
|
+
event.preventDefault();
|
|
28
|
+
onCancel();
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
var onSubmit = function onSubmit() {
|
|
32
|
+
onSave((0, _objectSpread2.default)((0, _objectSpread2.default)({}, linkState), {}, {
|
|
33
|
+
target: (0, _isAnchorLink.isAnchorLink)(linkState.url) ? null : linkState.target,
|
|
34
|
+
url: (0, _sanitizeUrl.sanitizeUrl)(linkState.url)
|
|
35
|
+
}));
|
|
36
|
+
};
|
|
37
|
+
return /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("h5", {
|
|
38
|
+
className: "link-editor-popup-title"
|
|
39
|
+
}, "Edit Link"), /*#__PURE__*/_react.default.createElement("div", {
|
|
40
|
+
className: "link-editor-section"
|
|
41
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
42
|
+
className: "header"
|
|
43
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
44
|
+
className: "header_title"
|
|
45
|
+
}, "URL")), /*#__PURE__*/_react.default.createElement("div", {
|
|
46
|
+
className: "section-desc"
|
|
47
|
+
}, /*#__PURE__*/_react.default.createElement("input", {
|
|
48
|
+
autoFocus: true,
|
|
49
|
+
placeholder: "URL: https://example.com",
|
|
50
|
+
className: "link-input full-with",
|
|
51
|
+
value: linkState.url,
|
|
52
|
+
onKeyDown: onInputKeyDown,
|
|
53
|
+
onChange: function onChange(e) {
|
|
54
|
+
return setLinkState(function (state) {
|
|
55
|
+
return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, state), {}, {
|
|
56
|
+
url: e.target.value
|
|
57
|
+
});
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
}))), /*#__PURE__*/_react.default.createElement("div", {
|
|
61
|
+
className: "link-editor-section"
|
|
62
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
63
|
+
className: "header"
|
|
64
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
65
|
+
className: "header_title"
|
|
66
|
+
}, "Alt text")), /*#__PURE__*/_react.default.createElement("div", {
|
|
67
|
+
className: "section-desc"
|
|
68
|
+
}, /*#__PURE__*/_react.default.createElement("input", {
|
|
69
|
+
placeholder: "Enter alt text",
|
|
70
|
+
className: "link-input full-with",
|
|
71
|
+
type: "text",
|
|
72
|
+
value: linkState.alt || "",
|
|
73
|
+
onKeyDown: onInputKeyDown,
|
|
74
|
+
onChange: function onChange(e) {
|
|
75
|
+
return setLinkState(function (state) {
|
|
76
|
+
return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, state), {}, {
|
|
77
|
+
alt: e.target.value
|
|
78
|
+
});
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
}))), /*#__PURE__*/_react.default.createElement("div", {
|
|
82
|
+
className: "link-editor-section"
|
|
83
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
84
|
+
className: "section-desc"
|
|
85
|
+
}, /*#__PURE__*/_react.default.createElement("input", {
|
|
86
|
+
id: "link-editor-new-tab",
|
|
87
|
+
type: "checkbox",
|
|
88
|
+
checked: linkState.target === "_blank",
|
|
89
|
+
disabled: (0, _isAnchorLink.isAnchorLink)(linkState.url),
|
|
90
|
+
onChange: function onChange(e) {
|
|
91
|
+
return setLinkState(function (state) {
|
|
92
|
+
return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, state), {}, {
|
|
93
|
+
target: e.target.checked ? "_blank" : null
|
|
94
|
+
});
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
}), /*#__PURE__*/_react.default.createElement("label", {
|
|
98
|
+
htmlFor: "link-editor-new-tab"
|
|
99
|
+
}, "Open link in a new tab"))), /*#__PURE__*/_react.default.createElement("div", {
|
|
100
|
+
className: "link-editor-section full-with edit-form-bottom-menu"
|
|
101
|
+
}, /*#__PURE__*/_react.default.createElement("button", {
|
|
102
|
+
className: "webiny-ui-button mdc-button",
|
|
103
|
+
onClick: onCancel
|
|
104
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
105
|
+
className: "mdc-button__ripple"
|
|
106
|
+
}), /*#__PURE__*/_react.default.createElement("span", {
|
|
107
|
+
className: "mdc-button__label"
|
|
108
|
+
}, "Cancel")), /*#__PURE__*/_react.default.createElement("button", {
|
|
109
|
+
className: "webiny-ui-button webiny-ui-button--primary mdc-button mdc-button--raised",
|
|
110
|
+
onClick: onSubmit
|
|
111
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
112
|
+
className: "mdc-button__ripple"
|
|
113
|
+
}), /*#__PURE__*/_react.default.createElement("span", {
|
|
114
|
+
className: "mdc-button__label"
|
|
115
|
+
}, "Confirm"))));
|
|
116
|
+
};
|
|
117
|
+
|
|
118
|
+
//# sourceMappingURL=LinkEditForm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireWildcard","require","_sanitizeUrl","_isAnchorLink","LinkEditForm","exports","_ref","linkData","onSave","onCancel","_useState","useState","_useState2","_slicedToArray2","default","linkState","setLinkState","onInputKeyDown","event","key","preventDefault","onSubmit","_objectSpread2","target","isAnchorLink","url","sanitizeUrl","createElement","className","autoFocus","placeholder","value","onKeyDown","onChange","e","state","type","alt","id","checked","disabled","htmlFor","onClick"],"sources":["LinkEditForm.tsx"],"sourcesContent":["import React, { useState } from \"react\";\nimport { sanitizeUrl } from \"~/utils/sanitizeUrl\";\nimport { isAnchorLink } from \"~/utils/isAnchorLink\";\nimport { LinkData } from \"./FloatingLinkEditorPlugin\";\n\ninterface LinkFormProps {\n linkData: LinkData;\n onSave: (linkData: LinkData) => void;\n onCancel: () => void;\n}\n\nexport const LinkEditForm = ({ linkData, onSave, onCancel }: LinkFormProps) => {\n const [linkState, setLinkState] = useState(linkData);\n\n const onInputKeyDown = (event: React.KeyboardEvent<HTMLInputElement>) => {\n if (event.key === \"Enter\") {\n event.preventDefault();\n onSubmit();\n } else if (event.key === \"Escape\") {\n event.preventDefault();\n onCancel();\n }\n };\n\n const onSubmit = () => {\n onSave({\n ...linkState,\n target: isAnchorLink(linkState.url) ? null : linkState.target,\n url: sanitizeUrl(linkState.url)\n });\n };\n\n return (\n <div>\n <h5 className={\"link-editor-popup-title\"}>Edit Link</h5>\n\n <div className={\"link-editor-section\"}>\n <div className={\"header\"}>\n <div className={\"header_title\"}>URL</div>\n </div>\n <div className={\"section-desc\"}>\n <input\n autoFocus\n placeholder={\"URL: https://example.com\"}\n className=\"link-input full-with\"\n value={linkState.url}\n onKeyDown={onInputKeyDown}\n onChange={e => {\n return setLinkState(state => ({\n ...state,\n url: e.target.value\n }));\n }}\n />\n </div>\n </div>\n <div className={\"link-editor-section\"}>\n <div className={\"header\"}>\n <div className={\"header_title\"}>Alt text</div>\n </div>\n <div className={\"section-desc\"}>\n <input\n placeholder={\"Enter alt text\"}\n className={\"link-input full-with\"}\n type={\"text\"}\n value={linkState.alt || \"\"}\n onKeyDown={onInputKeyDown}\n onChange={e => {\n return setLinkState(state => ({\n ...state,\n alt: e.target.value\n }));\n }}\n />\n </div>\n </div>\n <div className={\"link-editor-section\"}>\n <div className={\"section-desc\"}>\n <input\n id={\"link-editor-new-tab\"}\n type={\"checkbox\"}\n checked={linkState.target === \"_blank\"}\n disabled={isAnchorLink(linkState.url)}\n onChange={e => {\n return setLinkState(state => ({\n ...state,\n target: e.target.checked ? \"_blank\" : null\n }));\n }}\n />\n <label htmlFor={\"link-editor-new-tab\"}>Open link in a new tab</label>\n </div>\n </div>\n\n <div className={\"link-editor-section full-with edit-form-bottom-menu\"}>\n <button className=\"webiny-ui-button mdc-button\" onClick={onCancel}>\n <div className=\"mdc-button__ripple\"></div>\n <span className=\"mdc-button__label\">Cancel</span>\n </button>\n <button\n className=\"webiny-ui-button webiny-ui-button--primary mdc-button mdc-button--raised\"\n onClick={onSubmit}\n >\n <div className=\"mdc-button__ripple\"></div>\n <span className=\"mdc-button__label\">Confirm</span>\n </button>\n </div>\n </div>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { LinkData } from "./FloatingLinkEditorPlugin";
|
|
3
|
+
interface LinkFormProps {
|
|
4
|
+
linkData: LinkData;
|
|
5
|
+
onEdit: () => void;
|
|
6
|
+
removeLink: () => void;
|
|
7
|
+
}
|
|
8
|
+
export declare const LinkPreviewForm: ({ linkData, onEdit, removeLink }: LinkFormProps) => React.JSX.Element;
|
|
9
|
+
export {};
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.LinkPreviewForm = void 0;
|
|
8
|
+
var _react = _interopRequireDefault(require("react"));
|
|
9
|
+
var LinkPreviewForm = exports.LinkPreviewForm = function LinkPreviewForm(_ref) {
|
|
10
|
+
var linkData = _ref.linkData,
|
|
11
|
+
onEdit = _ref.onEdit,
|
|
12
|
+
removeLink = _ref.removeLink;
|
|
13
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
14
|
+
className: "link-preview-form"
|
|
15
|
+
}, /*#__PURE__*/_react.default.createElement("h5", {
|
|
16
|
+
className: "link-editor-popup-title"
|
|
17
|
+
}, "Preview Link"), /*#__PURE__*/_react.default.createElement("div", {
|
|
18
|
+
className: "link-input"
|
|
19
|
+
}, /*#__PURE__*/_react.default.createElement("a", {
|
|
20
|
+
href: linkData.url,
|
|
21
|
+
target: "_blank",
|
|
22
|
+
rel: "noopener noreferrer"
|
|
23
|
+
}, linkData.url), /*#__PURE__*/_react.default.createElement("div", {
|
|
24
|
+
className: "link-edit",
|
|
25
|
+
role: "button",
|
|
26
|
+
tabIndex: 0,
|
|
27
|
+
onMouseDown: function onMouseDown(event) {
|
|
28
|
+
return event.preventDefault();
|
|
29
|
+
},
|
|
30
|
+
onClick: onEdit
|
|
31
|
+
}), /*#__PURE__*/_react.default.createElement("div", {
|
|
32
|
+
className: "link-unlink",
|
|
33
|
+
role: "button",
|
|
34
|
+
tabIndex: 0,
|
|
35
|
+
onMouseDown: function onMouseDown(event) {
|
|
36
|
+
return event.preventDefault();
|
|
37
|
+
},
|
|
38
|
+
onClick: removeLink
|
|
39
|
+
})), /*#__PURE__*/_react.default.createElement("div", {
|
|
40
|
+
className: "link-editor-section"
|
|
41
|
+
}, /*#__PURE__*/_react.default.createElement("ul", null, /*#__PURE__*/_react.default.createElement("li", null, linkData.target === "_blank" ? /*#__PURE__*/_react.default.createElement("span", null, "Open link in a new tab") : /*#__PURE__*/_react.default.createElement("span", null, "Open link in the same tab")), linkData.alt && /*#__PURE__*/_react.default.createElement("li", null, /*#__PURE__*/_react.default.createElement("span", null, "Alt text: ", /*#__PURE__*/_react.default.createElement("span", null, linkData.alt))))));
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
//# sourceMappingURL=LinkPreviewForm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireDefault","require","LinkPreviewForm","exports","_ref","linkData","onEdit","removeLink","default","createElement","className","href","url","target","rel","role","tabIndex","onMouseDown","event","preventDefault","onClick","alt"],"sources":["LinkPreviewForm.tsx"],"sourcesContent":["import React from \"react\";\nimport { LinkData } from \"./FloatingLinkEditorPlugin\";\n\ninterface LinkFormProps {\n linkData: LinkData;\n onEdit: () => void;\n removeLink: () => void;\n}\n\nexport const LinkPreviewForm = ({ linkData, onEdit, removeLink }: LinkFormProps) => {\n return (\n <div className={\"link-preview-form\"}>\n <h5 className={\"link-editor-popup-title\"}>Preview Link</h5>\n <div className=\"link-input\">\n <a href={linkData.url} target=\"_blank\" rel=\"noopener noreferrer\">\n {linkData.url}\n </a>\n <div\n className=\"link-edit\"\n role=\"button\"\n tabIndex={0}\n onMouseDown={event => event.preventDefault()}\n onClick={onEdit}\n />\n <div\n className=\"link-unlink\"\n role=\"button\"\n tabIndex={0}\n onMouseDown={event => event.preventDefault()}\n onClick={removeLink}\n />\n </div>\n <div className={\"link-editor-section\"}>\n <ul>\n <li>\n {linkData.target === \"_blank\" ? (\n <span>Open link in a new tab</span>\n ) : (\n <span>Open link in the same tab</span>\n )}\n </li>\n {linkData.alt && (\n <li>\n <span>\n Alt text: <span>{linkData.alt}</span>\n </span>\n </li>\n )}\n </ul>\n </div>\n </div>\n );\n};\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AASO,IAAMC,eAAe,GAAAC,OAAA,CAAAD,eAAA,GAAG,SAAlBA,eAAeA,CAAAE,IAAA,EAAwD;EAAA,IAAlDC,QAAQ,GAAAD,IAAA,CAARC,QAAQ;IAAEC,MAAM,GAAAF,IAAA,CAANE,MAAM;IAAEC,UAAU,GAAAH,IAAA,CAAVG,UAAU;EAC1D,oBACIR,MAAA,CAAAS,OAAA,CAAAC,aAAA;IAAKC,SAAS,EAAE;EAAoB,gBAChCX,MAAA,CAAAS,OAAA,CAAAC,aAAA;IAAIC,SAAS,EAAE;EAA0B,GAAC,cAAgB,CAAC,eAC3DX,MAAA,CAAAS,OAAA,CAAAC,aAAA;IAAKC,SAAS,EAAC;EAAY,gBACvBX,MAAA,CAAAS,OAAA,CAAAC,aAAA;IAAGE,IAAI,EAAEN,QAAQ,CAACO,GAAI;IAACC,MAAM,EAAC,QAAQ;IAACC,GAAG,EAAC;EAAqB,GAC3DT,QAAQ,CAACO,GACX,CAAC,eACJb,MAAA,CAAAS,OAAA,CAAAC,aAAA;IACIC,SAAS,EAAC,WAAW;IACrBK,IAAI,EAAC,QAAQ;IACbC,QAAQ,EAAE,CAAE;IACZC,WAAW,EAAE,SAAAA,YAAAC,KAAK;MAAA,OAAIA,KAAK,CAACC,cAAc,CAAC,CAAC;IAAA,CAAC;IAC7CC,OAAO,EAAEd;EAAO,CACnB,CAAC,eACFP,MAAA,CAAAS,OAAA,CAAAC,aAAA;IACIC,SAAS,EAAC,aAAa;IACvBK,IAAI,EAAC,QAAQ;IACbC,QAAQ,EAAE,CAAE;IACZC,WAAW,EAAE,SAAAA,YAAAC,KAAK;MAAA,OAAIA,KAAK,CAACC,cAAc,CAAC,CAAC;IAAA,CAAC;IAC7CC,OAAO,EAAEb;EAAW,CACvB,CACA,CAAC,eACNR,MAAA,CAAAS,OAAA,CAAAC,aAAA;IAAKC,SAAS,EAAE;EAAsB,gBAClCX,MAAA,CAAAS,OAAA,CAAAC,aAAA,0BACIV,MAAA,CAAAS,OAAA,CAAAC,aAAA,aACKJ,QAAQ,CAACQ,MAAM,KAAK,QAAQ,gBACzBd,MAAA,CAAAS,OAAA,CAAAC,aAAA,eAAM,wBAA4B,CAAC,gBAEnCV,MAAA,CAAAS,OAAA,CAAAC,aAAA,eAAM,2BAA+B,CAEzC,CAAC,EACJJ,QAAQ,CAACgB,GAAG,iBACTtB,MAAA,CAAAS,OAAA,CAAAC,aAAA,0BACIV,MAAA,CAAAS,OAAA,CAAAC,aAAA,eAAM,YACQ,eAAAV,MAAA,CAAAS,OAAA,CAAAC,aAAA,eAAOJ,QAAQ,CAACgB,GAAU,CAClC,CACN,CAER,CACH,CACJ,CAAC;AAEd,CAAC","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_FloatingLinkEditorPlugin","require","Object","keys","forEach","key","exports","defineProperty","enumerable","get"],"sources":["index.ts"],"sourcesContent":["export * from \"./FloatingLinkEditorPlugin\";\n"],"mappings":";;;;;AAAA,IAAAA,yBAAA,GAAAC,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAH,yBAAA,EAAAI,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAL,yBAAA,CAAAK,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,IAAA;MAAA,OAAAT,yBAAA,CAAAK,GAAA;IAAA;EAAA;AAAA"}
|
|
1
|
+
{"version":3,"names":["_FloatingLinkEditorPlugin","require","Object","keys","forEach","key","exports","defineProperty","enumerable","get"],"sources":["index.ts"],"sourcesContent":["export * from \"./FloatingLinkEditorPlugin\";\n"],"mappings":";;;;;AAAA,IAAAA,yBAAA,GAAAC,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAH,yBAAA,EAAAI,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAL,yBAAA,CAAAK,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,IAAA;MAAA,OAAAT,yBAAA,CAAAK,GAAA;IAAA;EAAA;AAAA","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const isChildOfLinkEditor: (element: HTMLElement | null) => boolean;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.isChildOfLinkEditor = void 0;
|
|
7
|
+
var isChildOfLinkEditor = exports.isChildOfLinkEditor = function isChildOfLinkEditor(element) {
|
|
8
|
+
var parent = element ? element.parentElement : null;
|
|
9
|
+
if (!parent) {
|
|
10
|
+
return false;
|
|
11
|
+
}
|
|
12
|
+
if (parent.classList.contains("link-editor")) {
|
|
13
|
+
return true;
|
|
14
|
+
}
|
|
15
|
+
return isChildOfLinkEditor(parent);
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
//# sourceMappingURL=isChildOfLinkEditor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["isChildOfLinkEditor","exports","element","parent","parentElement","classList","contains"],"sources":["isChildOfLinkEditor.ts"],"sourcesContent":["export const isChildOfLinkEditor = (element: HTMLElement | null): boolean => {\n const parent = element ? element.parentElement : null;\n\n if (!parent) {\n return false;\n }\n\n if (parent.classList.contains(\"link-editor\")) {\n return true;\n }\n\n return isChildOfLinkEditor(parent);\n};\n"],"mappings":";;;;;;AAAO,IAAMA,mBAAmB,GAAAC,OAAA,CAAAD,mBAAA,GAAG,SAAtBA,mBAAmBA,CAAIE,OAA2B,EAAc;EACzE,IAAMC,MAAM,GAAGD,OAAO,GAAGA,OAAO,CAACE,aAAa,GAAG,IAAI;EAErD,IAAI,CAACD,MAAM,EAAE;IACT,OAAO,KAAK;EAChB;EAEA,IAAIA,MAAM,CAACE,SAAS,CAACC,QAAQ,CAAC,aAAa,CAAC,EAAE;IAC1C,OAAO,IAAI;EACf;EAEA,OAAON,mBAAmB,CAACG,MAAM,CAAC;AACtC,CAAC","ignoreList":[]}
|