@uiw/react-md-editor 3.3.7 → 3.3.8
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/markdown-editor.css +3 -7
- package/lib/cjs/Context.js +2 -8
- package/lib/cjs/Editor.js +54 -86
- package/lib/cjs/commands/bold.js +5 -9
- package/lib/cjs/commands/code.js +5 -11
- package/lib/cjs/commands/comment.js +5 -7
- package/lib/cjs/commands/divider.js +1 -1
- package/lib/cjs/commands/fullscreen.js +1 -5
- package/lib/cjs/commands/group.js +3 -10
- package/lib/cjs/commands/hr.js +1 -4
- package/lib/cjs/commands/image.js +5 -9
- package/lib/cjs/commands/index.js +52 -87
- package/lib/cjs/commands/italic.js +5 -9
- package/lib/cjs/commands/link.js +5 -9
- package/lib/cjs/commands/list.js +7 -11
- package/lib/cjs/commands/preview.js +2 -5
- package/lib/cjs/commands/quote.js +3 -6
- package/lib/cjs/commands/strikeThrough.js +5 -9
- package/lib/cjs/commands/title.js +1 -6
- package/lib/cjs/commands/title1.js +1 -6
- package/lib/cjs/commands/title2.js +1 -6
- package/lib/cjs/commands/title3.js +1 -6
- package/lib/cjs/commands/title4.js +1 -6
- package/lib/cjs/commands/title5.js +1 -6
- package/lib/cjs/commands/title6.js +1 -6
- package/lib/cjs/components/DragBar/index.js +3 -14
- package/lib/cjs/components/TextArea/Markdown.js +8 -20
- package/lib/cjs/components/TextArea/Textarea.js +17 -36
- package/lib/cjs/components/TextArea/handleKeyDown.js +1 -19
- package/lib/cjs/components/TextArea/index.js +11 -27
- package/lib/cjs/components/TextArea/shortcuts.js +1 -17
- package/lib/cjs/components/Toolbar/Child.js +9 -18
- package/lib/cjs/components/Toolbar/index.js +12 -32
- package/lib/cjs/index.js +2 -11
- package/lib/cjs/utils/InsertTextAtPosition.js +28 -33
- package/lib/cjs/utils/getSurroundingWord.js +9 -12
- package/lib/cjs/utils/index.js +1 -1
- package/lib/cjs/utils/markdownUtils.js +12 -23
- package/lib/esm/Context.js +1 -1
- package/lib/esm/Editor.js +54 -71
- package/lib/esm/commands/bold.js +5 -5
- package/lib/esm/commands/code.js +5 -7
- package/lib/esm/commands/comment.js +5 -5
- package/lib/esm/commands/divider.js +1 -1
- package/lib/esm/commands/fullscreen.js +1 -2
- package/lib/esm/commands/group.js +3 -5
- package/lib/esm/commands/hr.js +1 -1
- package/lib/esm/commands/image.js +5 -5
- package/lib/esm/commands/index.js +8 -18
- package/lib/esm/commands/italic.js +5 -5
- package/lib/esm/commands/link.js +5 -5
- package/lib/esm/commands/list.js +5 -5
- package/lib/esm/commands/preview.js +1 -1
- package/lib/esm/commands/quote.js +3 -2
- package/lib/esm/commands/strikeThrough.js +5 -5
- package/lib/esm/commands/title.js +1 -1
- package/lib/esm/commands/title1.js +1 -3
- package/lib/esm/commands/title2.js +1 -3
- package/lib/esm/commands/title3.js +1 -3
- package/lib/esm/commands/title4.js +1 -3
- package/lib/esm/commands/title5.js +1 -3
- package/lib/esm/commands/title6.js +1 -3
- package/lib/esm/components/DragBar/index.js +3 -12
- package/lib/esm/components/TextArea/Markdown.js +9 -13
- package/lib/esm/components/TextArea/Textarea.js +17 -20
- package/lib/esm/components/TextArea/handleKeyDown.js +2 -14
- package/lib/esm/components/TextArea/index.css +1 -2
- package/lib/esm/components/TextArea/index.js +11 -14
- package/lib/esm/components/TextArea/shortcuts.js +1 -14
- package/lib/esm/components/Toolbar/Child.js +9 -10
- package/lib/esm/components/Toolbar/index.css +2 -5
- package/lib/esm/components/Toolbar/index.js +12 -23
- package/lib/esm/index.js +1 -1
- package/lib/esm/utils/InsertTextAtPosition.js +28 -31
- package/lib/esm/utils/getSurroundingWord.js +9 -10
- package/lib/esm/utils/index.js +1 -1
- package/lib/esm/utils/markdownUtils.js +10 -16
- package/package.json +2 -49
package/lib/esm/Editor.js
CHANGED
|
@@ -11,7 +11,6 @@ import DragBar from './components/DragBar';
|
|
|
11
11
|
import { getCommands, getExtraCommands } from './commands';
|
|
12
12
|
import { reducer, EditorContext } from './Context';
|
|
13
13
|
import "./index.css";
|
|
14
|
-
|
|
15
14
|
function setGroupPopFalse() {
|
|
16
15
|
var data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
17
16
|
Object.keys(data).forEach(function (keyname) {
|
|
@@ -19,63 +18,60 @@ function setGroupPopFalse() {
|
|
|
19
18
|
});
|
|
20
19
|
return data;
|
|
21
20
|
}
|
|
22
|
-
|
|
23
21
|
var InternalMDEditor = function InternalMDEditor(props, ref) {
|
|
24
22
|
var _ref = props || {},
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
23
|
+
_ref$prefixCls = _ref.prefixCls,
|
|
24
|
+
prefixCls = _ref$prefixCls === void 0 ? 'w-md-editor' : _ref$prefixCls,
|
|
25
|
+
className = _ref.className,
|
|
26
|
+
propsValue = _ref.value,
|
|
27
|
+
_ref$commands = _ref.commands,
|
|
28
|
+
commands = _ref$commands === void 0 ? getCommands() : _ref$commands,
|
|
29
|
+
_ref$extraCommands = _ref.extraCommands,
|
|
30
|
+
extraCommands = _ref$extraCommands === void 0 ? getExtraCommands() : _ref$extraCommands,
|
|
31
|
+
_ref$height = _ref.height,
|
|
32
|
+
height = _ref$height === void 0 ? 200 : _ref$height,
|
|
33
|
+
_ref$toolbarHeight = _ref.toolbarHeight,
|
|
34
|
+
toolbarHeight = _ref$toolbarHeight === void 0 ? 29 : _ref$toolbarHeight,
|
|
35
|
+
_ref$enableScroll = _ref.enableScroll,
|
|
36
|
+
enableScroll = _ref$enableScroll === void 0 ? true : _ref$enableScroll,
|
|
37
|
+
_ref$visiableDragbar = _ref.visiableDragbar,
|
|
38
|
+
visiableDragbar = _ref$visiableDragbar === void 0 ? true : _ref$visiableDragbar,
|
|
39
|
+
_ref$highlightEnable = _ref.highlightEnable,
|
|
40
|
+
highlightEnable = _ref$highlightEnable === void 0 ? true : _ref$highlightEnable,
|
|
41
|
+
_ref$preview = _ref.preview,
|
|
42
|
+
previewType = _ref$preview === void 0 ? 'live' : _ref$preview,
|
|
43
|
+
_ref$fullscreen = _ref.fullscreen,
|
|
44
|
+
fullscreen = _ref$fullscreen === void 0 ? false : _ref$fullscreen,
|
|
45
|
+
_ref$previewOptions = _ref.previewOptions,
|
|
46
|
+
previewOptions = _ref$previewOptions === void 0 ? {} : _ref$previewOptions,
|
|
47
|
+
textareaProps = _ref.textareaProps,
|
|
48
|
+
_ref$maxHeight = _ref.maxHeight,
|
|
49
|
+
maxHeight = _ref$maxHeight === void 0 ? 1200 : _ref$maxHeight,
|
|
50
|
+
_ref$minHeight = _ref.minHeight,
|
|
51
|
+
minHeight = _ref$minHeight === void 0 ? 100 : _ref$minHeight,
|
|
52
|
+
autoFocus = _ref.autoFocus,
|
|
53
|
+
_ref$tabSize = _ref.tabSize,
|
|
54
|
+
tabSize = _ref$tabSize === void 0 ? 2 : _ref$tabSize,
|
|
55
|
+
onChange = _ref.onChange,
|
|
56
|
+
hideToolbar = _ref.hideToolbar,
|
|
57
|
+
other = _objectWithoutProperties(_ref, _excluded);
|
|
61
58
|
var _useReducer = useReducer(reducer, {
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
59
|
+
markdown: propsValue,
|
|
60
|
+
preview: previewType,
|
|
61
|
+
height: height,
|
|
62
|
+
highlightEnable: highlightEnable,
|
|
63
|
+
tabSize: tabSize,
|
|
64
|
+
scrollTop: 0,
|
|
65
|
+
scrollTopPreview: 0,
|
|
66
|
+
commands: commands,
|
|
67
|
+
extraCommands: extraCommands,
|
|
68
|
+
fullscreen: fullscreen,
|
|
69
|
+
onChange: onChange,
|
|
70
|
+
barPopup: {}
|
|
71
|
+
}),
|
|
72
|
+
_useReducer2 = _slicedToArray(_useReducer, 2),
|
|
73
|
+
state = _useReducer2[0],
|
|
74
|
+
dispatch = _useReducer2[1];
|
|
79
75
|
var container = useRef(null);
|
|
80
76
|
var previewRef = useRef(null);
|
|
81
77
|
var enableScrollRef = useRef(enableScroll);
|
|
@@ -87,18 +83,15 @@ var InternalMDEditor = function InternalMDEditor(props, ref) {
|
|
|
87
83
|
}, [enableScroll]);
|
|
88
84
|
useEffect(function () {
|
|
89
85
|
var stateInit = {};
|
|
90
|
-
|
|
91
86
|
if (container.current) {
|
|
92
87
|
stateInit.container = container.current || undefined;
|
|
93
88
|
}
|
|
94
|
-
|
|
95
89
|
stateInit.markdown = propsValue || '';
|
|
96
90
|
stateInit.barPopup = {};
|
|
97
|
-
|
|
98
91
|
if (dispatch) {
|
|
99
92
|
dispatch(_objectSpread(_objectSpread({}, state), stateInit));
|
|
100
|
-
}
|
|
101
|
-
|
|
93
|
+
}
|
|
94
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
102
95
|
}, []);
|
|
103
96
|
var cls = [className, prefixCls, state.preview ? "".concat(prefixCls, "-show-").concat(state.preview) : null, state.fullscreen ? "".concat(prefixCls, "-fullscreen") : null].filter(Boolean).join(' ').trim();
|
|
104
97
|
useMemo(function () {
|
|
@@ -140,7 +133,6 @@ var InternalMDEditor = function InternalMDEditor(props, ref) {
|
|
|
140
133
|
var active = useRef();
|
|
141
134
|
useMemo(function () {
|
|
142
135
|
textareaDomRef.current = state.textareaWarp;
|
|
143
|
-
|
|
144
136
|
if (state.textareaWarp) {
|
|
145
137
|
state.textareaWarp.addEventListener('mouseover', function () {
|
|
146
138
|
active.current = 'text';
|
|
@@ -150,37 +142,29 @@ var InternalMDEditor = function InternalMDEditor(props, ref) {
|
|
|
150
142
|
});
|
|
151
143
|
}
|
|
152
144
|
}, [state.textareaWarp]);
|
|
153
|
-
|
|
154
145
|
var handleScroll = function handleScroll(e) {
|
|
155
146
|
if (!enableScrollRef.current) return;
|
|
156
147
|
var textareaDom = textareaDomRef.current;
|
|
157
148
|
var previewDom = previewRef.current ? previewRef.current.mdp.current : undefined;
|
|
158
|
-
|
|
159
149
|
if (textareaDom && previewDom) {
|
|
160
150
|
var scale = (textareaDom.scrollHeight - textareaDom.offsetHeight) / (previewDom.scrollHeight - previewDom.offsetHeight);
|
|
161
|
-
|
|
162
151
|
if (e.target === textareaDom && active.current === 'text') {
|
|
163
152
|
previewDom.scrollTop = textareaDom.scrollTop / scale;
|
|
164
153
|
}
|
|
165
|
-
|
|
166
154
|
if (e.target === previewDom && active.current === 'preview') {
|
|
167
155
|
textareaDom.scrollTop = previewDom.scrollTop * scale;
|
|
168
156
|
}
|
|
169
|
-
|
|
170
157
|
var scrollTop = 0;
|
|
171
|
-
|
|
172
158
|
if (active.current === 'text') {
|
|
173
159
|
scrollTop = textareaDom.scrollTop || 0;
|
|
174
160
|
} else if (active.current === 'preview') {
|
|
175
161
|
scrollTop = previewDom.scrollTop || 0;
|
|
176
162
|
}
|
|
177
|
-
|
|
178
163
|
dispatch({
|
|
179
164
|
scrollTop: scrollTop
|
|
180
165
|
});
|
|
181
166
|
}
|
|
182
167
|
};
|
|
183
|
-
|
|
184
168
|
return /*#__PURE__*/React.createElement(EditorContext.Provider, {
|
|
185
169
|
value: _objectSpread(_objectSpread({}, state), {}, {
|
|
186
170
|
dispatch: dispatch
|
|
@@ -227,8 +211,7 @@ var InternalMDEditor = function InternalMDEditor(props, ref) {
|
|
|
227
211
|
}
|
|
228
212
|
})));
|
|
229
213
|
};
|
|
230
|
-
|
|
231
214
|
var mdEditor = /*#__PURE__*/React.forwardRef(InternalMDEditor);
|
|
232
215
|
mdEditor.Markdown = MarkdownPreview;
|
|
233
216
|
export default mdEditor;
|
|
234
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Editor.tsx"],"names":["React","useEffect","useReducer","useMemo","useRef","useImperativeHandle","MarkdownPreview","TextArea","Toolbar","DragBar","getCommands","getExtraCommands","reducer","EditorContext","setGroupPopFalse","data","Object","keys","forEach","keyname","InternalMDEditor","props","ref","prefixCls","className","propsValue","value","commands","extraCommands","height","toolbarHeight","enableScroll","visiableDragbar","highlightEnable","preview","previewType","fullscreen","previewOptions","textareaProps","maxHeight","minHeight","autoFocus","tabSize","onChange","hideToolbar","other","markdown","scrollTop","scrollTopPreview","barPopup","state","dispatch","container","previewRef","enableScrollRef","current","stateInit","undefined","cls","filter","Boolean","join","trim","textareaDomRef","active","textareaWarp","addEventListener","handleScroll","e","textareaDom","previewDom","mdp","scale","scrollHeight","offsetHeight","target","Number","test","newHeight","mdEditor","forwardRef","Markdown"],"mappings":";;;;;AAAA,OAAOA,KAAP,IAAgBC,SAAhB,EAA2BC,UAA3B,EAAuCC,OAAvC,EAAgDC,MAAhD,EAAwDC,mBAAxD,QAAmF,OAAnF;AACA,OAAOC,eAAP,MAA0E,6BAA1E;AAEA,OAAOC,QAAP,MAAyC,uBAAzC;AACA,OAAOC,OAAP,MAAoB,sBAApB;AACA,OAAOC,OAAP,MAAoB,sBAApB;AACA,SAASC,WAAT,EAAsBC,gBAAtB,QAAwD,YAAxD;AACA,SAASC,OAAT,EAAkBC,aAAlB,QAAkE,WAAlE;AACA;;AAgFA,SAASC,gBAAT,GAA8D;AAAA,MAApCC,IAAoC,uEAAJ,EAAI;AAC5DC,EAAAA,MAAM,CAACC,IAAP,CAAYF,IAAZ,EAAkBG,OAAlB,CAA0B,UAACC,OAAD,EAAa;AACrCJ,IAAAA,IAAI,CAACI,OAAD,CAAJ,GAAgB,KAAhB;AACD,GAFD;AAGA,SAAOJ,IAAP;AACD;;AAED,IAAMK,gBAAgB,GAAG,SAAnBA,gBAAmB,CACvBC,KADuB,EAEvBC,GAFuB,EAGpB;AACH,aAsBID,KAAK,IAAI,EAtBb;AAAA,4BACEE,SADF;AAAA,MACEA,SADF,+BACc,aADd;AAAA,MAEEC,SAFF,QAEEA,SAFF;AAAA,MAGSC,UAHT,QAGEC,KAHF;AAAA,2BAIEC,QAJF;AAAA,MAIEA,QAJF,8BAIajB,WAAW,EAJxB;AAAA,gCAKEkB,aALF;AAAA,MAKEA,aALF,mCAKkBjB,gBAAgB,EALlC;AAAA,yBAMEkB,MANF;AAAA,MAMEA,MANF,4BAMW,GANX;AAAA,gCAOEC,aAPF;AAAA,MAOEA,aAPF,mCAOkB,EAPlB;AAAA,+BAQEC,YARF;AAAA,MAQEA,YARF,kCAQiB,IARjB;AAAA,kCASEC,eATF;AAAA,MASEA,eATF,qCASoB,IATpB;AAAA,kCAUEC,eAVF;AAAA,MAUEA,eAVF,qCAUoB,IAVpB;AAAA,0BAWEC,OAXF;AAAA,MAWWC,WAXX,6BAWyB,MAXzB;AAAA,6BAYEC,UAZF;AAAA,MAYEA,UAZF,gCAYe,KAZf;AAAA,iCAaEC,cAbF;AAAA,MAaEA,cAbF,oCAamB,EAbnB;AAAA,MAcEC,aAdF,QAcEA,aAdF;AAAA,4BAeEC,SAfF;AAAA,MAeEA,SAfF,+BAec,IAfd;AAAA,4BAgBEC,SAhBF;AAAA,MAgBEA,SAhBF,+BAgBc,GAhBd;AAAA,MAiBEC,SAjBF,QAiBEA,SAjBF;AAAA,0BAkBEC,OAlBF;AAAA,MAkBEA,OAlBF,6BAkBY,CAlBZ;AAAA,MAmBEC,QAnBF,QAmBEA,QAnBF;AAAA,MAoBEC,WApBF,QAoBEA,WApBF;AAAA,MAqBKC,KArBL;;AAuBA,oBAAwB3C,UAAU,CAACU,OAAD,EAAU;AAC1CkC,IAAAA,QAAQ,EAAErB,UADgC;AAE1CS,IAAAA,OAAO,EAAEC,WAFiC;AAG1CN,IAAAA,MAAM,EAANA,MAH0C;AAI1CI,IAAAA,eAAe,EAAfA,eAJ0C;AAK1CS,IAAAA,OAAO,EAAPA,OAL0C;AAM1CK,IAAAA,SAAS,EAAE,CAN+B;AAO1CC,IAAAA,gBAAgB,EAAE,CAPwB;AAQ1CrB,IAAAA,QAAQ,EAARA,QAR0C;AAS1CC,IAAAA,aAAa,EAAbA,aAT0C;AAU1CQ,IAAAA,UAAU,EAAVA,UAV0C;AAW1CO,IAAAA,QAAQ,EAARA,QAX0C;AAY1CM,IAAAA,QAAQ,EAAE;AAZgC,GAAV,CAAlC;AAAA;AAAA,MAAKC,KAAL;AAAA,MAAYC,QAAZ;;AAcA,MAAMC,SAAS,GAAGhD,MAAM,CAAiB,IAAjB,CAAxB;AACA,MAAMiD,UAAU,GAAGjD,MAAM,CAAqB,IAArB,CAAzB;AACA,MAAMkD,eAAe,GAAGlD,MAAM,CAAC2B,YAAD,CAA9B;AAEA1B,EAAAA,mBAAmB,CAACiB,GAAD,EAAM;AAAA,6BAAY4B,KAAZ;AAAA,GAAN,CAAnB;AACA/C,EAAAA,OAAO,CAAC;AAAA,WAAOmD,eAAe,CAACC,OAAhB,GAA0BxB,YAAjC;AAAA,GAAD,EAAiD,CAACA,YAAD,CAAjD,CAAP;AACA9B,EAAAA,SAAS,CAAC,YAAM;AACd,QAAMuD,SAAuB,GAAG,EAAhC;;AACA,QAAIJ,SAAS,CAACG,OAAd,EAAuB;AACrBC,MAAAA,SAAS,CAACJ,SAAV,GAAsBA,SAAS,CAACG,OAAV,IAAqBE,SAA3C;AACD;;AACDD,IAAAA,SAAS,CAACV,QAAV,GAAqBrB,UAAU,IAAI,EAAnC;AACA+B,IAAAA,SAAS,CAACP,QAAV,GAAqB,EAArB;;AACA,QAAIE,QAAJ,EAAc;AACZA,MAAAA,QAAQ,iCAAMD,KAAN,GAAgBM,SAAhB,EAAR;AACD,KATa,CAUd;;AACD,GAXQ,EAWN,EAXM,CAAT;AAaA,MAAME,GAAG,GAAG,CACVlC,SADU,EAEVD,SAFU,EAGV2B,KAAK,CAAChB,OAAN,aAAmBX,SAAnB,mBAAqC2B,KAAK,CAAChB,OAA3C,IAAuD,IAH7C,EAIVgB,KAAK,CAACd,UAAN,aAAsBb,SAAtB,mBAA+C,IAJrC,EAMToC,MANS,CAMFC,OANE,EAOTC,IAPS,CAOJ,GAPI,EAQTC,IARS,EAAZ;AAUA3D,EAAAA,OAAO,CAAC;AAAA,WAAMsB,UAAU,KAAKyB,KAAK,CAACJ,QAArB,IAAiCK,QAAQ,CAAC;AAAEL,MAAAA,QAAQ,EAAErB,UAAU,IAAI;AAA1B,KAAD,CAA/C;AAAA,GAAD,EAAkF,CAACA,UAAD,CAAlF,CAAP;AACAtB,EAAAA,OAAO,CAAC;AAAA,WAAMgC,WAAW,KAAKe,KAAK,CAAChB,OAAtB,IAAiCiB,QAAQ,CAAC;AAAEjB,MAAAA,OAAO,EAAEC;AAAX,KAAD,CAA/C;AAAA,GAAD,EAA4E,CAACA,WAAD,CAA5E,CAAP;AACAhC,EAAAA,OAAO,CAAC;AAAA,WAAM0B,MAAM,KAAKqB,KAAK,CAACrB,MAAjB,IAA2BsB,QAAQ,CAAC;AAAEtB,MAAAA,MAAM,EAAEA;AAAV,KAAD,CAAzC;AAAA,GAAD,EAAgE,CAACA,MAAD,CAAhE,CAAP;AACA1B,EAAAA,OAAO,CAAC;AAAA,WAAMuC,OAAO,KAAKQ,KAAK,CAACR,OAAlB,IAA6BS,QAAQ,CAAC;AAAET,MAAAA,OAAO,EAAPA;AAAF,KAAD,CAA3C;AAAA,GAAD,EAA2D,CAACA,OAAD,CAA3D,CAAP;AACAvC,EAAAA,OAAO,CAAC;AAAA,WAAM8B,eAAe,KAAKiB,KAAK,CAACjB,eAA1B,IAA6CkB,QAAQ,CAAC;AAAElB,MAAAA,eAAe,EAAfA;AAAF,KAAD,CAA3D;AAAA,GAAD,EAAmF,CAACA,eAAD,CAAnF,CAAP;AACA9B,EAAAA,OAAO,CAAC;AAAA,WAAMsC,SAAS,KAAKS,KAAK,CAACT,SAApB,IAAiCU,QAAQ,CAAC;AAAEV,MAAAA,SAAS,EAAEA;AAAb,KAAD,CAA/C;AAAA,GAAD,EAA4E,CAACA,SAAD,CAA5E,CAAP;AACAtC,EAAAA,OAAO,CAAC;AAAA,WAAMiC,UAAU,KAAKc,KAAK,CAACd,UAArB,IAAmCe,QAAQ,CAAC;AAAEf,MAAAA,UAAU,EAAEA;AAAd,KAAD,CAAjD;AAAA,GAAD,EAAgF,CAACA,UAAD,CAAhF,CAAP;AAEA,MAAM2B,cAAc,GAAG3D,MAAM,EAA7B;AACA,MAAM4D,MAAM,GAAG5D,MAAM,EAArB;AAEAD,EAAAA,OAAO,CAAC,YAAM;AACZ4D,IAAAA,cAAc,CAACR,OAAf,GAAyBL,KAAK,CAACe,YAA/B;;AACA,QAAIf,KAAK,CAACe,YAAV,EAAwB;AACtBf,MAAAA,KAAK,CAACe,YAAN,CAAmBC,gBAAnB,CAAoC,WAApC,EAAiD,YAAM;AACrDF,QAAAA,MAAM,CAACT,OAAP,GAAiB,MAAjB;AACD,OAFD;AAGAL,MAAAA,KAAK,CAACe,YAAN,CAAmBC,gBAAnB,CAAoC,YAApC,EAAkD,YAAM;AACtDF,QAAAA,MAAM,CAACT,OAAP,GAAiB,SAAjB;AACD,OAFD;AAGD;AACF,GAVM,EAUJ,CAACL,KAAK,CAACe,YAAP,CAVI,CAAP;;AAYA,MAAME,YAAY,GAAG,SAAfA,YAAe,CAACC,CAAD,EAAsC;AACzD,QAAI,CAACd,eAAe,CAACC,OAArB,EAA8B;AAC9B,QAAMc,WAAW,GAAGN,cAAc,CAACR,OAAnC;AACA,QAAMe,UAAU,GAAGjB,UAAU,CAACE,OAAX,GAAqBF,UAAU,CAACE,OAAX,CAAmBgB,GAAnB,CAAuBhB,OAA5C,GAAsDE,SAAzE;;AACA,QAAIY,WAAW,IAAIC,UAAnB,EAA+B;AAC7B,UAAME,KAAK,GACT,CAACH,WAAW,CAACI,YAAZ,GAA2BJ,WAAW,CAACK,YAAxC,KAAyDJ,UAAU,CAACG,YAAX,GAA0BH,UAAU,CAACI,YAA9F,CADF;;AAEA,UAAIN,CAAC,CAACO,MAAF,KAAaN,WAAb,IAA4BL,MAAM,CAACT,OAAP,KAAmB,MAAnD,EAA2D;AACzDe,QAAAA,UAAU,CAACvB,SAAX,GAAuBsB,WAAW,CAACtB,SAAZ,GAAwByB,KAA/C;AACD;;AACD,UAAIJ,CAAC,CAACO,MAAF,KAAaL,UAAb,IAA2BN,MAAM,CAACT,OAAP,KAAmB,SAAlD,EAA6D;AAC3Dc,QAAAA,WAAW,CAACtB,SAAZ,GAAwBuB,UAAU,CAACvB,SAAX,GAAuByB,KAA/C;AACD;;AACD,UAAIzB,SAAS,GAAG,CAAhB;;AACA,UAAIiB,MAAM,CAACT,OAAP,KAAmB,MAAvB,EAA+B;AAC7BR,QAAAA,SAAS,GAAGsB,WAAW,CAACtB,SAAZ,IAAyB,CAArC;AACD,OAFD,MAEO,IAAIiB,MAAM,CAACT,OAAP,KAAmB,SAAvB,EAAkC;AACvCR,QAAAA,SAAS,GAAGuB,UAAU,CAACvB,SAAX,IAAwB,CAApC;AACD;;AACDI,MAAAA,QAAQ,CAAC;AAAEJ,QAAAA,SAAS,EAATA;AAAF,OAAD,CAAR;AACD;AACF,GArBD;;AAuBA,sBACE,oBAAC,aAAD,CAAe,QAAf;AAAwB,IAAA,KAAK,kCAAOG,KAAP;AAAcC,MAAAA,QAAQ,EAARA;AAAd;AAA7B,kBACE;AACE,IAAA,GAAG,EAAEC,SADP;AAEE,IAAA,SAAS,EAAEM,GAFb;AAGE,IAAA,OAAO,EAAE,mBAAM;AACbP,MAAAA,QAAQ,CAAC;AAAEF,QAAAA,QAAQ,oBAAOnC,gBAAgB,CAACoC,KAAK,CAACD,QAAP,CAAvB;AAAV,OAAD,CAAR;AACD,KALH;AAME,IAAA,KAAK,EAAE;AACLpB,MAAAA,MAAM,EAAEqB,KAAK,CAACd,UAAN,GAAmB,MAAnB,GAA4BQ,WAAW,GAAGgC,MAAM,CAAC1B,KAAK,CAACrB,MAAP,CAAN,GAAuBC,aAA1B,GAA0CoB,KAAK,CAACrB;AAD1F;AANT,KASMgB,KATN,GAWG,CAACD,WAAD,iBAAgB,oBAAC,OAAD;AAAS,IAAA,SAAS,EAAErB,SAApB;AAA+B,IAAA,MAAM,EAAEO;AAAvC,IAXnB,eAYE;AACE,IAAA,SAAS,YAAKP,SAAL,aADX;AAEE,IAAA,KAAK,EAAE;AACLM,MAAAA,MAAM,EAAEqB,KAAK,CAACd,UAAN,yBAAkCN,aAAlC,WAAuD8C,MAAM,CAAC1B,KAAK,CAACrB,MAAP,CAAN,GAAuBC;AADjF;AAFT,KAMG,cAAc+C,IAAd,CAAmB3B,KAAK,CAAChB,OAAN,IAAiB,EAApC,kBACC,oBAAC,QAAD;AACE,IAAA,SAAS,YAAKX,SAAL,WADX;AAEE,IAAA,SAAS,EAAEA,SAFb;AAGE,IAAA,SAAS,EAAEkB;AAHb,KAIMH,aAJN;AAKE,IAAA,QAAQ,EAAE6B;AALZ,KAPJ,EAeG,iBAAiBU,IAAjB,CAAsB3B,KAAK,CAAChB,OAAN,IAAiB,EAAvC,kBACC,oBAAC,eAAD,eACOG,cADP;AAEE,IAAA,QAAQ,EAAE8B,YAFZ;AAGE,IAAA,GAAG,EAAEd,UAHP;AAIE,IAAA,MAAM,EAAEH,KAAK,CAACJ,QAAN,IAAkB,EAJ5B;AAKE,IAAA,SAAS,YAAKvB,SAAL;AALX,KAhBJ,CAZF,EAqCGS,eAAe,IAAI,CAACkB,KAAK,CAACd,UAA1B,iBACC,oBAAC,OAAD;AACE,IAAA,SAAS,EAAEb,SADb;AAEE,IAAA,MAAM,EAAE2B,KAAK,CAACrB,MAFhB;AAGE,IAAA,SAAS,EAAEU,SAHb;AAIE,IAAA,SAAS,EAAEC,SAJb;AAKE,IAAA,QAAQ,EAAE,kBAACsC,SAAD,EAAe;AACvB3B,MAAAA,QAAQ,CAAC;AAAEtB,QAAAA,MAAM,EAAEiD;AAAV,OAAD,CAAR;AACD;AAPH,IAtCJ,CADF,CADF;AAqDD,CAzKD;;AA2KA,IAAMC,QAAQ,gBAAG/E,KAAK,CAACgF,UAAN,CAA8C5D,gBAA9C,CAAjB;AAMC2D,QAAD,CAAuBE,QAAvB,GAAkC3E,eAAlC;AAEA,eAAeyE,QAAf","sourcesContent":["import React, { useEffect, useReducer, useMemo, useRef, useImperativeHandle } from 'react';\nimport MarkdownPreview, { MarkdownPreviewProps, MarkdownPreviewRef } from '@uiw/react-markdown-preview';\nimport { IProps } from './utils';\nimport TextArea, { ITextAreaProps } from './components/TextArea';\nimport Toolbar from './components/Toolbar';\nimport DragBar from './components/DragBar';\nimport { getCommands, getExtraCommands, ICommand } from './commands';\nimport { reducer, EditorContext, ContextStore, PreviewType } from './Context';\nimport './index.less';\n\nexport interface MDEditorProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange'>, IProps {\n  /**\n   * The Markdown value.\n   */\n  value?: string;\n  /**\n   * Event handler for the `onChange` event.\n   */\n  onChange?: (value?: string) => void;\n  /**\n   * Can be used to make `Markdown Editor` focus itself on initialization. Defaults to on.\n   * it will be set to true when either the source `textarea` is focused,\n   * or it has an `autofocus` attribute and no other element is focused.\n   */\n  autoFocus?: ITextAreaProps['autoFocus'];\n  /**\n   * The height of the editor.\n   */\n  height?: number;\n  /**\n   * Custom toolbar heigth\n   * @default 29px\n   */\n  toolbarHeight?: number;\n  /**\n   * Show drag and drop tool. Set the height of the editor.\n   */\n  visiableDragbar?: boolean;\n  /**\n   * Show markdown preview.\n   */\n  preview?: PreviewType;\n  /**\n   * Full screen display editor.\n   */\n  fullscreen?: boolean;\n  /**\n   * Maximum drag height. `visiableDragbar=true`\n   */\n  maxHeight?: number;\n  /**\n   * Minimum drag height. `visiableDragbar=true`\n   */\n  minHeight?: number;\n  /**\n   * This is reset [react-markdown](https://github.com/rexxars/react-markdown) settings.\n   */\n  previewOptions?: Omit<MarkdownPreviewProps, 'source'>;\n  /**\n   * Set the `textarea` related props.\n   */\n  textareaProps?: ITextAreaProps;\n  /**\n   * Disable editing area code highlighting. The value is `false`, which increases the editing speed.\n   * @default true\n   */\n  highlightEnable?: boolean;\n  /**\n   * The number of characters to insert when pressing tab key.\n   * Default `2` spaces.\n   */\n  tabSize?: number;\n  /**\n   * You can create your own commands or reuse existing commands.\n   */\n  commands?: ICommand[];\n  /**\n   * You can create your own commands or reuse existing commands.\n   */\n  extraCommands?: ICommand[];\n  /**\n   * Hide the tool bar\n   */\n  hideToolbar?: boolean;\n  /** Whether to enable scrolling */\n  enableScroll?: boolean;\n}\n\nfunction setGroupPopFalse(data: Record<string, boolean> = {}) {\n  Object.keys(data).forEach((keyname) => {\n    data[keyname] = false;\n  });\n  return data;\n}\n\nconst InternalMDEditor = (\n  props: MDEditorProps,\n  ref?: ((instance: ContextStore) => void) | React.RefObject<ContextStore> | null,\n) => {\n  const {\n    prefixCls = 'w-md-editor',\n    className,\n    value: propsValue,\n    commands = getCommands(),\n    extraCommands = getExtraCommands(),\n    height = 200,\n    toolbarHeight = 29,\n    enableScroll = true,\n    visiableDragbar = true,\n    highlightEnable = true,\n    preview: previewType = 'live',\n    fullscreen = false,\n    previewOptions = {},\n    textareaProps,\n    maxHeight = 1200,\n    minHeight = 100,\n    autoFocus,\n    tabSize = 2,\n    onChange,\n    hideToolbar,\n    ...other\n  } = props || {};\n  let [state, dispatch] = useReducer(reducer, {\n    markdown: propsValue,\n    preview: previewType,\n    height,\n    highlightEnable,\n    tabSize,\n    scrollTop: 0,\n    scrollTopPreview: 0,\n    commands,\n    extraCommands,\n    fullscreen,\n    onChange,\n    barPopup: {},\n  });\n  const container = useRef<HTMLDivElement>(null);\n  const previewRef = useRef<MarkdownPreviewRef>(null);\n  const enableScrollRef = useRef(enableScroll);\n\n  useImperativeHandle(ref, () => ({ ...state }));\n  useMemo(() => (enableScrollRef.current = enableScroll), [enableScroll]);\n  useEffect(() => {\n    const stateInit: ContextStore = {};\n    if (container.current) {\n      stateInit.container = container.current || undefined;\n    }\n    stateInit.markdown = propsValue || '';\n    stateInit.barPopup = {};\n    if (dispatch) {\n      dispatch({ ...state, ...stateInit });\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, []);\n\n  const cls = [\n    className,\n    prefixCls,\n    state.preview ? `${prefixCls}-show-${state.preview}` : null,\n    state.fullscreen ? `${prefixCls}-fullscreen` : null,\n  ]\n    .filter(Boolean)\n    .join(' ')\n    .trim();\n\n  useMemo(() => propsValue !== state.markdown && dispatch({ markdown: propsValue || '' }), [propsValue]);\n  useMemo(() => previewType !== state.preview && dispatch({ preview: previewType }), [previewType]);\n  useMemo(() => height !== state.height && dispatch({ height: height }), [height]);\n  useMemo(() => tabSize !== state.tabSize && dispatch({ tabSize }), [tabSize]);\n  useMemo(() => highlightEnable !== state.highlightEnable && dispatch({ highlightEnable }), [highlightEnable]);\n  useMemo(() => autoFocus !== state.autoFocus && dispatch({ autoFocus: autoFocus }), [autoFocus]);\n  useMemo(() => fullscreen !== state.fullscreen && dispatch({ fullscreen: fullscreen }), [fullscreen]);\n\n  const textareaDomRef = useRef<HTMLDivElement>();\n  const active = useRef<'text' | 'preview'>();\n\n  useMemo(() => {\n    textareaDomRef.current = state.textareaWarp;\n    if (state.textareaWarp) {\n      state.textareaWarp.addEventListener('mouseover', () => {\n        active.current = 'text';\n      });\n      state.textareaWarp.addEventListener('mouseleave', () => {\n        active.current = 'preview';\n      });\n    }\n  }, [state.textareaWarp]);\n\n  const handleScroll = (e: React.UIEvent<HTMLDivElement>) => {\n    if (!enableScrollRef.current) return;\n    const textareaDom = textareaDomRef.current;\n    const previewDom = previewRef.current ? previewRef.current.mdp.current : undefined;\n    if (textareaDom && previewDom) {\n      const scale =\n        (textareaDom.scrollHeight - textareaDom.offsetHeight) / (previewDom.scrollHeight - previewDom.offsetHeight);\n      if (e.target === textareaDom && active.current === 'text') {\n        previewDom.scrollTop = textareaDom.scrollTop / scale;\n      }\n      if (e.target === previewDom && active.current === 'preview') {\n        textareaDom.scrollTop = previewDom.scrollTop * scale;\n      }\n      let scrollTop = 0;\n      if (active.current === 'text') {\n        scrollTop = textareaDom.scrollTop || 0;\n      } else if (active.current === 'preview') {\n        scrollTop = previewDom.scrollTop || 0;\n      }\n      dispatch({ scrollTop });\n    }\n  };\n\n  return (\n    <EditorContext.Provider value={{ ...state, dispatch }}>\n      <div\n        ref={container}\n        className={cls}\n        onClick={() => {\n          dispatch({ barPopup: { ...setGroupPopFalse(state.barPopup) } });\n        }}\n        style={{\n          height: state.fullscreen ? '100%' : hideToolbar ? Number(state.height) - toolbarHeight : state.height,\n        }}\n        {...other}\n      >\n        {!hideToolbar && <Toolbar prefixCls={prefixCls} height={toolbarHeight} />}\n        <div\n          className={`${prefixCls}-content`}\n          style={{\n            height: state.fullscreen ? `calc(100% - ${toolbarHeight}px)` : Number(state.height) - toolbarHeight,\n          }}\n        >\n          {/(edit|live)/.test(state.preview || '') && (\n            <TextArea\n              className={`${prefixCls}-input`}\n              prefixCls={prefixCls}\n              autoFocus={autoFocus}\n              {...textareaProps}\n              onScroll={handleScroll}\n            />\n          )}\n          {/(live|preview)/.test(state.preview || '') && (\n            <MarkdownPreview\n              {...(previewOptions as unknown)}\n              onScroll={handleScroll}\n              ref={previewRef}\n              source={state.markdown || ''}\n              className={`${prefixCls}-preview`}\n            />\n          )}\n        </div>\n        {visiableDragbar && !state.fullscreen && (\n          <DragBar\n            prefixCls={prefixCls}\n            height={state.height as number}\n            maxHeight={maxHeight!}\n            minHeight={minHeight!}\n            onChange={(newHeight) => {\n              dispatch({ height: newHeight });\n            }}\n          />\n        )}\n      </div>\n    </EditorContext.Provider>\n  );\n};\n\nconst mdEditor = React.forwardRef<ContextStore, MDEditorProps>(InternalMDEditor);\n\ntype MDEditor = typeof mdEditor & {\n  Markdown: typeof MarkdownPreview;\n};\n\n(mdEditor as MDEditor).Markdown = MarkdownPreview;\n\nexport default mdEditor as MDEditor;\n"]}
|
|
217
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useEffect","useReducer","useMemo","useRef","useImperativeHandle","MarkdownPreview","TextArea","Toolbar","DragBar","getCommands","getExtraCommands","reducer","EditorContext","setGroupPopFalse","data","Object","keys","forEach","keyname","InternalMDEditor","props","ref","prefixCls","className","propsValue","value","commands","extraCommands","height","toolbarHeight","enableScroll","visiableDragbar","highlightEnable","preview","previewType","fullscreen","previewOptions","textareaProps","maxHeight","minHeight","autoFocus","tabSize","onChange","hideToolbar","other","markdown","scrollTop","scrollTopPreview","barPopup","state","dispatch","container","previewRef","enableScrollRef","current","stateInit","undefined","cls","filter","Boolean","join","trim","textareaDomRef","active","textareaWarp","addEventListener","handleScroll","e","textareaDom","previewDom","mdp","scale","scrollHeight","offsetHeight","target","Number","test","newHeight","mdEditor","forwardRef","Markdown"],"sources":["../../src/Editor.tsx"],"sourcesContent":["import React, { useEffect, useReducer, useMemo, useRef, useImperativeHandle } from 'react';\nimport MarkdownPreview, { MarkdownPreviewProps, MarkdownPreviewRef } from '@uiw/react-markdown-preview';\nimport { IProps } from './utils';\nimport TextArea, { ITextAreaProps } from './components/TextArea';\nimport Toolbar from './components/Toolbar';\nimport DragBar from './components/DragBar';\nimport { getCommands, getExtraCommands, ICommand } from './commands';\nimport { reducer, EditorContext, ContextStore, PreviewType } from './Context';\nimport './index.less';\n\nexport interface MDEditorProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange'>, IProps {\n  /**\n   * The Markdown value.\n   */\n  value?: string;\n  /**\n   * Event handler for the `onChange` event.\n   */\n  onChange?: (value?: string) => void;\n  /**\n   * Can be used to make `Markdown Editor` focus itself on initialization. Defaults to on.\n   * it will be set to true when either the source `textarea` is focused,\n   * or it has an `autofocus` attribute and no other element is focused.\n   */\n  autoFocus?: ITextAreaProps['autoFocus'];\n  /**\n   * The height of the editor.\n   */\n  height?: number;\n  /**\n   * Custom toolbar heigth\n   * @default 29px\n   */\n  toolbarHeight?: number;\n  /**\n   * Show drag and drop tool. Set the height of the editor.\n   */\n  visiableDragbar?: boolean;\n  /**\n   * Show markdown preview.\n   */\n  preview?: PreviewType;\n  /**\n   * Full screen display editor.\n   */\n  fullscreen?: boolean;\n  /**\n   * Maximum drag height. `visiableDragbar=true`\n   */\n  maxHeight?: number;\n  /**\n   * Minimum drag height. `visiableDragbar=true`\n   */\n  minHeight?: number;\n  /**\n   * This is reset [react-markdown](https://github.com/rexxars/react-markdown) settings.\n   */\n  previewOptions?: Omit<MarkdownPreviewProps, 'source'>;\n  /**\n   * Set the `textarea` related props.\n   */\n  textareaProps?: ITextAreaProps;\n  /**\n   * Disable editing area code highlighting. The value is `false`, which increases the editing speed.\n   * @default true\n   */\n  highlightEnable?: boolean;\n  /**\n   * The number of characters to insert when pressing tab key.\n   * Default `2` spaces.\n   */\n  tabSize?: number;\n  /**\n   * You can create your own commands or reuse existing commands.\n   */\n  commands?: ICommand[];\n  /**\n   * You can create your own commands or reuse existing commands.\n   */\n  extraCommands?: ICommand[];\n  /**\n   * Hide the tool bar\n   */\n  hideToolbar?: boolean;\n  /** Whether to enable scrolling */\n  enableScroll?: boolean;\n}\n\nfunction setGroupPopFalse(data: Record<string, boolean> = {}) {\n  Object.keys(data).forEach((keyname) => {\n    data[keyname] = false;\n  });\n  return data;\n}\n\nconst InternalMDEditor = (\n  props: MDEditorProps,\n  ref?: ((instance: ContextStore) => void) | React.RefObject<ContextStore> | null,\n) => {\n  const {\n    prefixCls = 'w-md-editor',\n    className,\n    value: propsValue,\n    commands = getCommands(),\n    extraCommands = getExtraCommands(),\n    height = 200,\n    toolbarHeight = 29,\n    enableScroll = true,\n    visiableDragbar = true,\n    highlightEnable = true,\n    preview: previewType = 'live',\n    fullscreen = false,\n    previewOptions = {},\n    textareaProps,\n    maxHeight = 1200,\n    minHeight = 100,\n    autoFocus,\n    tabSize = 2,\n    onChange,\n    hideToolbar,\n    ...other\n  } = props || {};\n  let [state, dispatch] = useReducer(reducer, {\n    markdown: propsValue,\n    preview: previewType,\n    height,\n    highlightEnable,\n    tabSize,\n    scrollTop: 0,\n    scrollTopPreview: 0,\n    commands,\n    extraCommands,\n    fullscreen,\n    onChange,\n    barPopup: {},\n  });\n  const container = useRef<HTMLDivElement>(null);\n  const previewRef = useRef<MarkdownPreviewRef>(null);\n  const enableScrollRef = useRef(enableScroll);\n\n  useImperativeHandle(ref, () => ({ ...state }));\n  useMemo(() => (enableScrollRef.current = enableScroll), [enableScroll]);\n  useEffect(() => {\n    const stateInit: ContextStore = {};\n    if (container.current) {\n      stateInit.container = container.current || undefined;\n    }\n    stateInit.markdown = propsValue || '';\n    stateInit.barPopup = {};\n    if (dispatch) {\n      dispatch({ ...state, ...stateInit });\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, []);\n\n  const cls = [\n    className,\n    prefixCls,\n    state.preview ? `${prefixCls}-show-${state.preview}` : null,\n    state.fullscreen ? `${prefixCls}-fullscreen` : null,\n  ]\n    .filter(Boolean)\n    .join(' ')\n    .trim();\n\n  useMemo(() => propsValue !== state.markdown && dispatch({ markdown: propsValue || '' }), [propsValue]);\n  useMemo(() => previewType !== state.preview && dispatch({ preview: previewType }), [previewType]);\n  useMemo(() => height !== state.height && dispatch({ height: height }), [height]);\n  useMemo(() => tabSize !== state.tabSize && dispatch({ tabSize }), [tabSize]);\n  useMemo(() => highlightEnable !== state.highlightEnable && dispatch({ highlightEnable }), [highlightEnable]);\n  useMemo(() => autoFocus !== state.autoFocus && dispatch({ autoFocus: autoFocus }), [autoFocus]);\n  useMemo(() => fullscreen !== state.fullscreen && dispatch({ fullscreen: fullscreen }), [fullscreen]);\n\n  const textareaDomRef = useRef<HTMLDivElement>();\n  const active = useRef<'text' | 'preview'>();\n\n  useMemo(() => {\n    textareaDomRef.current = state.textareaWarp;\n    if (state.textareaWarp) {\n      state.textareaWarp.addEventListener('mouseover', () => {\n        active.current = 'text';\n      });\n      state.textareaWarp.addEventListener('mouseleave', () => {\n        active.current = 'preview';\n      });\n    }\n  }, [state.textareaWarp]);\n\n  const handleScroll = (e: React.UIEvent<HTMLDivElement>) => {\n    if (!enableScrollRef.current) return;\n    const textareaDom = textareaDomRef.current;\n    const previewDom = previewRef.current ? previewRef.current.mdp.current : undefined;\n    if (textareaDom && previewDom) {\n      const scale =\n        (textareaDom.scrollHeight - textareaDom.offsetHeight) / (previewDom.scrollHeight - previewDom.offsetHeight);\n      if (e.target === textareaDom && active.current === 'text') {\n        previewDom.scrollTop = textareaDom.scrollTop / scale;\n      }\n      if (e.target === previewDom && active.current === 'preview') {\n        textareaDom.scrollTop = previewDom.scrollTop * scale;\n      }\n      let scrollTop = 0;\n      if (active.current === 'text') {\n        scrollTop = textareaDom.scrollTop || 0;\n      } else if (active.current === 'preview') {\n        scrollTop = previewDom.scrollTop || 0;\n      }\n      dispatch({ scrollTop });\n    }\n  };\n\n  return (\n    <EditorContext.Provider value={{ ...state, dispatch }}>\n      <div\n        ref={container}\n        className={cls}\n        onClick={() => {\n          dispatch({ barPopup: { ...setGroupPopFalse(state.barPopup) } });\n        }}\n        style={{\n          height: state.fullscreen ? '100%' : hideToolbar ? Number(state.height) - toolbarHeight : state.height,\n        }}\n        {...other}\n      >\n        {!hideToolbar && <Toolbar prefixCls={prefixCls} height={toolbarHeight} />}\n        <div\n          className={`${prefixCls}-content`}\n          style={{\n            height: state.fullscreen ? `calc(100% - ${toolbarHeight}px)` : Number(state.height) - toolbarHeight,\n          }}\n        >\n          {/(edit|live)/.test(state.preview || '') && (\n            <TextArea\n              className={`${prefixCls}-input`}\n              prefixCls={prefixCls}\n              autoFocus={autoFocus}\n              {...textareaProps}\n              onScroll={handleScroll}\n            />\n          )}\n          {/(live|preview)/.test(state.preview || '') && (\n            <MarkdownPreview\n              {...(previewOptions as unknown)}\n              onScroll={handleScroll}\n              ref={previewRef}\n              source={state.markdown || ''}\n              className={`${prefixCls}-preview`}\n            />\n          )}\n        </div>\n        {visiableDragbar && !state.fullscreen && (\n          <DragBar\n            prefixCls={prefixCls}\n            height={state.height as number}\n            maxHeight={maxHeight!}\n            minHeight={minHeight!}\n            onChange={(newHeight) => {\n              dispatch({ height: newHeight });\n            }}\n          />\n        )}\n      </div>\n    </EditorContext.Provider>\n  );\n};\n\nconst mdEditor = React.forwardRef<ContextStore, MDEditorProps>(InternalMDEditor);\n\ntype MDEditor = typeof mdEditor & {\n  Markdown: typeof MarkdownPreview;\n};\n\n(mdEditor as MDEditor).Markdown = MarkdownPreview;\n\nexport default mdEditor as MDEditor;\n"],"mappings":"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"}
|
package/lib/esm/commands/bold.js
CHANGED
|
@@ -23,14 +23,14 @@ export var bold = {
|
|
|
23
23
|
text: state.text,
|
|
24
24
|
selection: state.selection
|
|
25
25
|
});
|
|
26
|
-
var state1 = api.setSelectionRange(newSelectionRange);
|
|
27
|
-
|
|
28
|
-
var state2 = api.replaceSelection("**".concat(state1.selectedText, "**"));
|
|
29
|
-
|
|
26
|
+
var state1 = api.setSelectionRange(newSelectionRange);
|
|
27
|
+
// Replaces the current selection with the bold mark up
|
|
28
|
+
var state2 = api.replaceSelection("**".concat(state1.selectedText, "**"));
|
|
29
|
+
// Adjust the selection to not contain the **
|
|
30
30
|
api.setSelectionRange({
|
|
31
31
|
start: state2.selection.end - 2 - state1.selectedText.length,
|
|
32
32
|
end: state2.selection.end - 2
|
|
33
33
|
});
|
|
34
34
|
}
|
|
35
35
|
};
|
|
36
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsInNlbGVjdFdvcmQiLCJib2xkIiwibmFtZSIsImtleUNvbW1hbmQiLCJzaG9ydGN1dHMiLCJidXR0b25Qcm9wcyIsInRpdGxlIiwiaWNvbiIsImV4ZWN1dGUiLCJzdGF0ZSIsImFwaSIsIm5ld1NlbGVjdGlvblJhbmdlIiwidGV4dCIsInNlbGVjdGlvbiIsInN0YXRlMSIsInNldFNlbGVjdGlvblJhbmdlIiwic3RhdGUyIiwicmVwbGFjZVNlbGVjdGlvbiIsInNlbGVjdGVkVGV4dCIsInN0YXJ0IiwiZW5kIiwibGVuZ3RoIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbW1hbmRzL2JvbGQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IElDb21tYW5kLCBUZXh0U3RhdGUsIFRleHRBcmVhVGV4dEFwaSB9IGZyb20gJy4vJztcbmltcG9ydCB7IHNlbGVjdFdvcmQgfSBmcm9tICcuLi91dGlscy9tYXJrZG93blV0aWxzJztcblxuZXhwb3J0IGNvbnN0IGJvbGQ6IElDb21tYW5kID0ge1xuICBuYW1lOiAnYm9sZCcsXG4gIGtleUNvbW1hbmQ6ICdib2xkJyxcbiAgc2hvcnRjdXRzOiAnY3RybGNtZCtiJyxcbiAgYnV0dG9uUHJvcHM6IHsgJ2FyaWEtbGFiZWwnOiAnQWRkIGJvbGQgdGV4dCcsIHRpdGxlOiAnQWRkIGJvbGQgdGV4dCcgfSxcbiAgaWNvbjogKFxuICAgIDxzdmcgcm9sZT1cImltZ1wiIHdpZHRoPVwiMTJcIiBoZWlnaHQ9XCIxMlwiIHZpZXdCb3g9XCIwIDAgMzg0IDUxMlwiPlxuICAgICAgPHBhdGhcbiAgICAgICAgZmlsbD1cImN1cnJlbnRDb2xvclwiXG4gICAgICAgIGQ9XCJNMzA0Ljc5MyAyNDMuODkxYzMzLjYzOS0xOC41MzcgNTMuNjU3LTU0LjE2IDUzLjY1Ny05NS42OTMgMC00OC4yMzYtMjYuMjUtODcuNjI2LTY4LjYyNi0xMDQuMTc5QzI2NS4xMzggMzQuMDEgMjQwLjg0OSAzMiAyMDkuNjYxIDMySDI0Yy04LjgzNyAwLTE2IDcuMTYzLTE2IDE2djMzLjA0OWMwIDguODM3IDcuMTYzIDE2IDE2IDE2aDMzLjExM3YzMTguNTNIMjRjLTguODM3IDAtMTYgNy4xNjMtMTYgMTZWNDY0YzAgOC44MzcgNy4xNjMgMTYgMTYgMTZoMTk1LjY5YzI0LjIwMyAwIDQ0LjgzNC0xLjI4OSA2Ni44NjYtNy41ODRDMzM3LjUyIDQ1Ny4xOTMgMzc2IDQxMC42NDcgMzc2IDM1MC4wMTRjMC01Mi4xNjgtMjYuNTczLTkxLjY4NC03MS4yMDctMTA2LjEyM3pNMTQyLjIxNyAxMDAuODA5aDY3LjQ0NGMxNi4yOTQgMCAyNy41MzYgMi4wMTkgMzcuNTI1IDYuNzE3IDE1LjgyOCA4LjQ3OSAyNC45MDYgMjYuNTAyIDI0LjkwNiA0OS40NDYgMCAzNS4wMjktMjAuMzIgNTYuNzktNTMuMDI5IDU2Ljc5aC03Ni44NDZWMTAwLjgwOXptMTEyLjY0MiAzMDUuNDc1Yy0xMC4xNCA0LjA1Ni0yMi42NzcgNC45MDctMzEuNDA5IDQuOTA3aC04MS4yMzNWMjgxLjk0M2g4NC4zNjdjMzkuNjQ1IDAgNjMuMDU3IDI1LjM4IDYzLjA1NyA2My4wNTcuMDAxIDI4LjQyNS0xMy42NiA1Mi40ODMtMzQuNzgyIDYxLjI4NHpcIlxuICAgICAgLz5cbiAgICA8L3N2Zz5cbiAgKSxcbiAgZXhlY3V0ZTogKHN0YXRlOiBUZXh0U3RhdGUsIGFwaTogVGV4dEFyZWFUZXh0QXBpKSA9PiB7XG4gICAgLy8gQWRqdXN0IHRoZSBzZWxlY3Rpb24gdG8gZW5jb21wYXNzIHRoZSB3aG9sZSB3b3JkIGlmIHRoZSBjYXJldCBpcyBpbnNpZGUgb25lXG4gICAgY29uc3QgbmV3U2VsZWN0aW9uUmFuZ2UgPSBzZWxlY3RXb3JkKHsgdGV4dDogc3RhdGUudGV4dCwgc2VsZWN0aW9uOiBzdGF0ZS5zZWxlY3Rpb24gfSk7XG4gICAgY29uc3Qgc3RhdGUxID0gYXBpLnNldFNlbGVjdGlvblJhbmdlKG5ld1NlbGVjdGlvblJhbmdlKTtcbiAgICAvLyBSZXBsYWNlcyB0aGUgY3VycmVudCBzZWxlY3Rpb24gd2l0aCB0aGUgYm9sZCBtYXJrIHVwXG4gICAgY29uc3Qgc3RhdGUyID0gYXBpLnJlcGxhY2VTZWxlY3Rpb24oYCoqJHtzdGF0ZTEuc2VsZWN0ZWRUZXh0fSoqYCk7XG4gICAgLy8gQWRqdXN0IHRoZSBzZWxlY3Rpb24gdG8gbm90IGNvbnRhaW4gdGhlICoqXG4gICAgYXBpLnNldFNlbGVjdGlvblJhbmdlKHtcbiAgICAgIHN0YXJ0OiBzdGF0ZTIuc2VsZWN0aW9uLmVuZCAtIDIgLSBzdGF0ZTEuc2VsZWN0ZWRUZXh0Lmxlbmd0aCxcbiAgICAgIGVuZDogc3RhdGUyLnNlbGVjdGlvbi5lbmQgLSAyLFxuICAgIH0pO1xuICB9LFxufTtcbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLQSxLQUFLLE1BQU0sT0FBTztBQUU5QixTQUFTQyxVQUFVLFFBQVEsd0JBQXdCO0FBRW5ELE9BQU8sSUFBTUMsSUFBYyxHQUFHO0VBQzVCQyxJQUFJLEVBQUUsTUFBTTtFQUNaQyxVQUFVLEVBQUUsTUFBTTtFQUNsQkMsU0FBUyxFQUFFLFdBQVc7RUFDdEJDLFdBQVcsRUFBRTtJQUFFLFlBQVksRUFBRSxlQUFlO0lBQUVDLEtBQUssRUFBRTtFQUFnQixDQUFDO0VBQ3RFQyxJQUFJLGVBQ0Y7SUFBSyxJQUFJLEVBQUMsS0FBSztJQUFDLEtBQUssRUFBQyxJQUFJO0lBQUMsTUFBTSxFQUFDLElBQUk7SUFBQyxPQUFPLEVBQUM7RUFBYSxnQkFDMUQ7SUFDRSxJQUFJLEVBQUMsY0FBYztJQUNuQixDQUFDLEVBQUM7RUFBd3FCLEVBQzFxQixDQUVMO0VBQ0RDLE9BQU8sRUFBRSxpQkFBQ0MsS0FBZ0IsRUFBRUMsR0FBb0IsRUFBSztJQUNuRDtJQUNBLElBQU1DLGlCQUFpQixHQUFHWCxVQUFVLENBQUM7TUFBRVksSUFBSSxFQUFFSCxLQUFLLENBQUNHLElBQUk7TUFBRUMsU0FBUyxFQUFFSixLQUFLLENBQUNJO0lBQVUsQ0FBQyxDQUFDO0lBQ3RGLElBQU1DLE1BQU0sR0FBR0osR0FBRyxDQUFDSyxpQkFBaUIsQ0FBQ0osaUJBQWlCLENBQUM7SUFDdkQ7SUFDQSxJQUFNSyxNQUFNLEdBQUdOLEdBQUcsQ0FBQ08sZ0JBQWdCLGFBQU1ILE1BQU0sQ0FBQ0ksWUFBWSxRQUFLO0lBQ2pFO0lBQ0FSLEdBQUcsQ0FBQ0ssaUJBQWlCLENBQUM7TUFDcEJJLEtBQUssRUFBRUgsTUFBTSxDQUFDSCxTQUFTLENBQUNPLEdBQUcsR0FBRyxDQUFDLEdBQUdOLE1BQU0sQ0FBQ0ksWUFBWSxDQUFDRyxNQUFNO01BQzVERCxHQUFHLEVBQUVKLE1BQU0sQ0FBQ0gsU0FBUyxDQUFDTyxHQUFHLEdBQUc7SUFDOUIsQ0FBQyxDQUFDO0VBQ0o7QUFDRixDQUFDIn0=
|
package/lib/esm/commands/code.js
CHANGED
|
@@ -22,22 +22,20 @@ export var code = {
|
|
|
22
22
|
text: tate.text,
|
|
23
23
|
selection: tate.selection
|
|
24
24
|
});
|
|
25
|
-
var state1 = api.setSelectionRange(newSelectionRange);
|
|
26
|
-
|
|
25
|
+
var state1 = api.setSelectionRange(newSelectionRange);
|
|
26
|
+
// when there's no breaking line
|
|
27
27
|
if (state1.selectedText.indexOf('\n') === -1) {
|
|
28
|
-
api.replaceSelection("`".concat(state1.selectedText, "`"));
|
|
28
|
+
api.replaceSelection("`".concat(state1.selectedText, "`"));
|
|
29
|
+
// Adjust the selection to not contain the **
|
|
29
30
|
|
|
30
31
|
var _selectionStart = state1.selection.start + 1;
|
|
31
|
-
|
|
32
32
|
var _selectionEnd = _selectionStart + state1.selectedText.length;
|
|
33
|
-
|
|
34
33
|
api.setSelectionRange({
|
|
35
34
|
start: _selectionStart,
|
|
36
35
|
end: _selectionEnd
|
|
37
36
|
});
|
|
38
37
|
return;
|
|
39
38
|
}
|
|
40
|
-
|
|
41
39
|
var breaksBeforeCount = getBreaksNeededForEmptyLineBefore(state1.text, state1.selection.start);
|
|
42
40
|
var breaksBefore = Array(breaksBeforeCount + 1).join('\n');
|
|
43
41
|
var breaksAfterCount = getBreaksNeededForEmptyLineAfter(state1.text, state1.selection.end);
|
|
@@ -75,4 +73,4 @@ export var codeBlock = {
|
|
|
75
73
|
});
|
|
76
74
|
}
|
|
77
75
|
};
|
|
78
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
76
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","selectWord","getBreaksNeededForEmptyLineBefore","getBreaksNeededForEmptyLineAfter","code","name","keyCommand","shortcuts","buttonProps","icon","execute","tate","api","newSelectionRange","text","selection","state1","setSelectionRange","selectedText","indexOf","replaceSelection","selectionStart","start","selectionEnd","length","end","breaksBeforeCount","breaksBefore","Array","join","breaksAfterCount","breaksAfter","codeBlock"],"sources":["../../../src/commands/code.tsx"],"sourcesContent":["import * as React from 'react';\nimport { ICommand, TextState, TextAreaTextApi } from './';\nimport {\n  selectWord,\n  getBreaksNeededForEmptyLineBefore,\n  getBreaksNeededForEmptyLineAfter,\n} from '../utils/markdownUtils';\n\nexport const code: ICommand = {\n  name: 'code',\n  keyCommand: 'code',\n  shortcuts: 'ctrlcmd+j',\n  buttonProps: { 'aria-label': 'Insert code' },\n  icon: (\n    <svg width=\"12\" height=\"12\" role=\"img\" viewBox=\"0 0 640 512\">\n      <path\n        fill=\"currentColor\"\n        d=\"M278.9 511.5l-61-17.7c-6.4-1.8-10-8.5-8.2-14.9L346.2 8.7c1.8-6.4 8.5-10 14.9-8.2l61 17.7c6.4 1.8 10 8.5 8.2 14.9L293.8 503.3c-1.9 6.4-8.5 10.1-14.9 8.2zm-114-112.2l43.5-46.4c4.6-4.9 4.3-12.7-.8-17.2L117 256l90.6-79.7c5.1-4.5 5.5-12.3.8-17.2l-43.5-46.4c-4.5-4.8-12.1-5.1-17-.5L3.8 247.2c-5.1 4.7-5.1 12.8 0 17.5l144.1 135.1c4.9 4.6 12.5 4.4 17-.5zm327.2.6l144.1-135.1c5.1-4.7 5.1-12.8 0-17.5L492.1 112.1c-4.8-4.5-12.4-4.3-17 .5L431.6 159c-4.6 4.9-4.3 12.7.8 17.2L523 256l-90.6 79.7c-5.1 4.5-5.5 12.3-.8 17.2l43.5 46.4c4.5 4.9 12.1 5.1 17 .6z\"\n      />\n    </svg>\n  ),\n  execute: (tate: TextState, api: TextAreaTextApi) => {\n    // Adjust the selection to encompass the whole word if the caret is inside one\n    const newSelectionRange = selectWord({ text: tate.text, selection: tate.selection });\n    const state1 = api.setSelectionRange(newSelectionRange);\n    // when there's no breaking line\n    if (state1.selectedText.indexOf('\\n') === -1) {\n      api.replaceSelection(`\\`${state1.selectedText}\\``);\n      // Adjust the selection to not contain the **\n\n      const selectionStart = state1.selection.start + 1;\n      const selectionEnd = selectionStart + state1.selectedText.length;\n\n      api.setSelectionRange({\n        start: selectionStart,\n        end: selectionEnd,\n      });\n      return;\n    }\n\n    const breaksBeforeCount = getBreaksNeededForEmptyLineBefore(state1.text, state1.selection.start);\n    const breaksBefore = Array(breaksBeforeCount + 1).join('\\n');\n\n    const breaksAfterCount = getBreaksNeededForEmptyLineAfter(state1.text, state1.selection.end);\n    const breaksAfter = Array(breaksAfterCount + 1).join('\\n');\n\n    api.replaceSelection(`${breaksBefore}\\`\\`\\`\\n${state1.selectedText}\\n\\`\\`\\`${breaksAfter}`);\n\n    const selectionStart = state1.selection.start + breaksBeforeCount + 4;\n    const selectionEnd = selectionStart + state1.selectedText.length;\n\n    api.setSelectionRange({\n      start: selectionStart,\n      end: selectionEnd,\n    });\n  },\n};\n\nexport const codeBlock: ICommand = {\n  name: 'codeBlock',\n  keyCommand: 'codeBlock',\n  shortcuts: 'ctrlcmd+shift+j',\n  execute: (tate: TextState, api: TextAreaTextApi) => {\n    // Adjust the selection to encompass the whole word if the caret is inside one\n    const newSelectionRange = selectWord({ text: tate.text, selection: tate.selection });\n    const state1 = api.setSelectionRange(newSelectionRange);\n\n    const breaksBeforeCount = getBreaksNeededForEmptyLineBefore(state1.text, state1.selection.start);\n    const breaksBefore = Array(breaksBeforeCount + 1).join('\\n');\n\n    const breaksAfterCount = getBreaksNeededForEmptyLineAfter(state1.text, state1.selection.end);\n    const breaksAfter = Array(breaksAfterCount + 1).join('\\n');\n\n    api.replaceSelection(`${breaksBefore}\\`\\`\\`\\n${state1.selectedText}\\n\\`\\`\\`${breaksAfter}`);\n\n    const selectionStart = state1.selection.start + breaksBeforeCount + 4;\n    const selectionEnd = selectionStart + state1.selectedText.length;\n\n    api.setSelectionRange({\n      start: selectionStart,\n      end: selectionEnd,\n    });\n  },\n};\n"],"mappings":"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"}
|
|
@@ -9,14 +9,14 @@ export var comment = {
|
|
|
9
9
|
text: state.text,
|
|
10
10
|
selection: state.selection
|
|
11
11
|
});
|
|
12
|
-
var state1 = api.setSelectionRange(newSelectionRange);
|
|
13
|
-
|
|
14
|
-
var state2 = api.replaceSelection("<!-- ".concat(state1.selectedText, " -->"));
|
|
15
|
-
|
|
12
|
+
var state1 = api.setSelectionRange(newSelectionRange);
|
|
13
|
+
// Replaces the current selection with the bold mark up
|
|
14
|
+
var state2 = api.replaceSelection("<!-- ".concat(state1.selectedText, " -->"));
|
|
15
|
+
// Adjust the selection to not contain the **
|
|
16
16
|
api.setSelectionRange({
|
|
17
17
|
start: state2.selection.end - 4 - state1.selectedText.length,
|
|
18
18
|
end: state2.selection.end - 4
|
|
19
19
|
});
|
|
20
20
|
}
|
|
21
21
|
};
|
|
22
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
22
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzZWxlY3RXb3JkIiwiY29tbWVudCIsIm5hbWUiLCJrZXlDb21tYW5kIiwic2hvcnRjdXRzIiwiZXhlY3V0ZSIsInN0YXRlIiwiYXBpIiwibmV3U2VsZWN0aW9uUmFuZ2UiLCJ0ZXh0Iiwic2VsZWN0aW9uIiwic3RhdGUxIiwic2V0U2VsZWN0aW9uUmFuZ2UiLCJzdGF0ZTIiLCJyZXBsYWNlU2VsZWN0aW9uIiwic2VsZWN0ZWRUZXh0Iiwic3RhcnQiLCJlbmQiLCJsZW5ndGgiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tbWFuZHMvY29tbWVudC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSUNvbW1hbmQsIFRleHRTdGF0ZSwgVGV4dEFyZWFUZXh0QXBpIH0gZnJvbSAnLi8nO1xuaW1wb3J0IHsgc2VsZWN0V29yZCB9IGZyb20gJy4uL3V0aWxzL21hcmtkb3duVXRpbHMnO1xuXG5leHBvcnQgY29uc3QgY29tbWVudDogSUNvbW1hbmQgPSB7XG4gIG5hbWU6ICdjb21tZW50JyxcbiAga2V5Q29tbWFuZDogJ2NvbW1lbnQnLFxuICBzaG9ydGN1dHM6ICdjdHJsY21kKy8nLFxuICBleGVjdXRlOiAoc3RhdGU6IFRleHRTdGF0ZSwgYXBpOiBUZXh0QXJlYVRleHRBcGkpID0+IHtcbiAgICAvLyBBZGp1c3QgdGhlIHNlbGVjdGlvbiB0byBlbmNvbXBhc3MgdGhlIHdob2xlIHdvcmQgaWYgdGhlIGNhcmV0IGlzIGluc2lkZSBvbmVcbiAgICBjb25zdCBuZXdTZWxlY3Rpb25SYW5nZSA9IHNlbGVjdFdvcmQoeyB0ZXh0OiBzdGF0ZS50ZXh0LCBzZWxlY3Rpb246IHN0YXRlLnNlbGVjdGlvbiB9KTtcbiAgICBjb25zdCBzdGF0ZTEgPSBhcGkuc2V0U2VsZWN0aW9uUmFuZ2UobmV3U2VsZWN0aW9uUmFuZ2UpO1xuICAgIC8vIFJlcGxhY2VzIHRoZSBjdXJyZW50IHNlbGVjdGlvbiB3aXRoIHRoZSBib2xkIG1hcmsgdXBcbiAgICBjb25zdCBzdGF0ZTIgPSBhcGkucmVwbGFjZVNlbGVjdGlvbihgPCEtLSAke3N0YXRlMS5zZWxlY3RlZFRleHR9IC0tPmApO1xuICAgIC8vIEFkanVzdCB0aGUgc2VsZWN0aW9uIHRvIG5vdCBjb250YWluIHRoZSAqKlxuICAgIGFwaS5zZXRTZWxlY3Rpb25SYW5nZSh7XG4gICAgICBzdGFydDogc3RhdGUyLnNlbGVjdGlvbi5lbmQgLSA0IC0gc3RhdGUxLnNlbGVjdGVkVGV4dC5sZW5ndGgsXG4gICAgICBlbmQ6IHN0YXRlMi5zZWxlY3Rpb24uZW5kIC0gNCxcbiAgICB9KTtcbiAgfSxcbn07XG4iXSwibWFwcGluZ3MiOiJBQUNBLFNBQVNBLFVBQVUsUUFBUSx3QkFBd0I7QUFFbkQsT0FBTyxJQUFNQyxPQUFpQixHQUFHO0VBQy9CQyxJQUFJLEVBQUUsU0FBUztFQUNmQyxVQUFVLEVBQUUsU0FBUztFQUNyQkMsU0FBUyxFQUFFLFdBQVc7RUFDdEJDLE9BQU8sRUFBRSxpQkFBQ0MsS0FBZ0IsRUFBRUMsR0FBb0IsRUFBSztJQUNuRDtJQUNBLElBQU1DLGlCQUFpQixHQUFHUixVQUFVLENBQUM7TUFBRVMsSUFBSSxFQUFFSCxLQUFLLENBQUNHLElBQUk7TUFBRUMsU0FBUyxFQUFFSixLQUFLLENBQUNJO0lBQVUsQ0FBQyxDQUFDO0lBQ3RGLElBQU1DLE1BQU0sR0FBR0osR0FBRyxDQUFDSyxpQkFBaUIsQ0FBQ0osaUJBQWlCLENBQUM7SUFDdkQ7SUFDQSxJQUFNSyxNQUFNLEdBQUdOLEdBQUcsQ0FBQ08sZ0JBQWdCLGdCQUFTSCxNQUFNLENBQUNJLFlBQVksVUFBTztJQUN0RTtJQUNBUixHQUFHLENBQUNLLGlCQUFpQixDQUFDO01BQ3BCSSxLQUFLLEVBQUVILE1BQU0sQ0FBQ0gsU0FBUyxDQUFDTyxHQUFHLEdBQUcsQ0FBQyxHQUFHTixNQUFNLENBQUNJLFlBQVksQ0FBQ0csTUFBTTtNQUM1REQsR0FBRyxFQUFFSixNQUFNLENBQUNILFNBQVMsQ0FBQ08sR0FBRyxHQUFHO0lBQzlCLENBQUMsQ0FBQztFQUNKO0FBQ0YsQ0FBQyJ9
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
export var divider = {
|
|
2
2
|
keyCommand: 'divider'
|
|
3
3
|
};
|
|
4
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
4
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJkaXZpZGVyIiwia2V5Q29tbWFuZCJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy9kaXZpZGVyLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJQ29tbWFuZCB9IGZyb20gJy4vJztcblxuZXhwb3J0IGNvbnN0IGRpdmlkZXI6IElDb21tYW5kID0ge1xuICBrZXlDb21tYW5kOiAnZGl2aWRlcicsXG59O1xuIl0sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLElBQU1BLE9BQWlCLEdBQUc7RUFDL0JDLFVBQVUsRUFBRTtBQUNkLENBQUMifQ==
|
|
@@ -17,7 +17,6 @@ export var fullscreen = {
|
|
|
17
17
|
})),
|
|
18
18
|
execute: function execute(state, api, dispatch, executeCommandState) {
|
|
19
19
|
api.textArea.focus();
|
|
20
|
-
|
|
21
20
|
if (dispatch && executeCommandState && executeCommandState.fullscreen) {
|
|
22
21
|
dispatch({
|
|
23
22
|
fullscreen: false
|
|
@@ -25,4 +24,4 @@ export var fullscreen = {
|
|
|
25
24
|
}
|
|
26
25
|
}
|
|
27
26
|
};
|
|
28
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
27
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsImZ1bGxzY3JlZW4iLCJuYW1lIiwia2V5Q29tbWFuZCIsInNob3J0Y3V0cyIsImJ1dHRvblByb3BzIiwidGl0bGUiLCJpY29uIiwiZXhlY3V0ZSIsInN0YXRlIiwiYXBpIiwiZGlzcGF0Y2giLCJleGVjdXRlQ29tbWFuZFN0YXRlIiwidGV4dEFyZWEiLCJmb2N1cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy9mdWxsc2NyZWVuLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBJQ29tbWFuZCwgVGV4dFN0YXRlLCBUZXh0QXJlYVRleHRBcGkgfSBmcm9tICcuLyc7XG5pbXBvcnQgeyBDb250ZXh0U3RvcmUsIEV4ZWN1dGVDb21tYW5kU3RhdGUgfSBmcm9tICcuLi9Db250ZXh0JztcblxuZXhwb3J0IGNvbnN0IGZ1bGxzY3JlZW46IElDb21tYW5kID0ge1xuICBuYW1lOiAnZnVsbHNjcmVlbicsXG4gIGtleUNvbW1hbmQ6ICdmdWxsc2NyZWVuJyxcbiAgc2hvcnRjdXRzOiAnZXNjYXBlJyxcbiAgYnV0dG9uUHJvcHM6IHsgJ2FyaWEtbGFiZWwnOiAnZnVsbHNjcmVlbicsIHRpdGxlOiAnZnVsbHNjcmVlbicgfSxcbiAgaWNvbjogKFxuICAgIDxzdmcgd2lkdGg9XCIxMlwiIGhlaWdodD1cIjEyXCIgdmlld0JveD1cIjAgMCA1MjAgNTIwXCI+XG4gICAgICA8cGF0aFxuICAgICAgICBmaWxsPVwiY3VycmVudENvbG9yXCJcbiAgICAgICAgZD1cIk0xMTggMTcxLjEzMzMzNEwxMTggMzQyLjIwMDI3MUMxMTggMzUzLjc2NjkzOCAxMjYuNjc1IDM2NS4zMzM2MDUgMTQxLjEzMzMzMyAzNjUuMzMzNjA1TDM4Mi42MzQ2MTQgMzY1LjMzMzYwNUMzOTQuMjAxMjgxIDM2NS4zMzM2MDUgNDA1Ljc2Nzk0OCAzNTYuNjU4NjA1IDQwNS43Njc5NDggMzQyLjIwMDI3MUw0MDUuNzY3OTQ4IDE3MS4xMzMzMzRDNDA1Ljc2Nzk0OCAxNTkuNTY2NjY3IDM5Ny4wOTI5NDggMTQ4IDM4Mi42MzQ2MTQgMTQ4TDE0MS4xMzMzMzMgMTQ4QzEyNi42NzQ5OTkgMTQ4IDExNy45OTk5OTkgMTU2LjY3NSAxMTggMTcxLjEzMzMzNHpNNDY1LjM1MzU5MSA0MTMuNDQ0NDQ0TDM3MCA0MTMuNDQ0NDQ0IDM3MCA0NzEuMjIyMjIyIDQ3NC4wMjIxIDQ3MS4yMjIyMjJDNTAwLjAyNzYyNCA0NzEuMjIyMjIyIDUyMC4yNTQxNDMgNDUxIDUyMC4yNTQxNDMgNDI1TDUyMC4yNTQxNDMgMzIxIDQ2Mi40NjQwODkgMzIxIDQ2Mi40NjQwODkgNDEzLjQ0NDQ0NCA0NjUuMzUzNTkxIDQxMy40NDQ0NDR6TTQ3MS4wMjIxIDQzTDM2NyA0MyAzNjcgMTAwLjc3Nzc3OCA0NjIuMzUzNTkxIDEwMC43Nzc3NzggNDYyLjM1MzU5MSAxOTYuMTExMTExIDUyMC4xNDM2NDcgMTk2LjExMTExMSA1MjAuMTQzNjQ3IDg5LjIyMjIyMTlDNTE3LjI1NDE0NCA2My4yMjIyMjE5IDQ5Ny4wMjc2MjQgNDMgNDcxLjAyMjEgNDN6TTU3Ljc5MDA1NDcgMTAwLjc3Nzc3OEwxNTMuMTQzNjQ2IDEwMC43Nzc3NzggMTUzLjE0MzY0NiA0MyA0Ni4yMzIwNDM5IDQzQzIwLjIyNjUxOTEgNDMgMCA2My4yMjIyMjE5IDAgODkuMjIyMjIxOUwwIDE5My4yMjIyMjIgNTcuNzkwMDU0NyAxOTMuMjIyMjIyIDU3Ljc5MDA1NDcgMTAwLjc3Nzc3OHpNNTcuNzkwMDU0NyAzMjFMMCAzMjEgMCA0MjVDMCA0NTEgMjAuMjI2NTE5MSA0NzEuMjIyMjIyIDQ2LjIzMjA0MzkgNDcxLjIyMjIyM0wxNTAuMjU0MTQzIDQ3MS4yMjIyMjMgMTUwLjI1NDE0MyA0MTMuNDQ0NDQ1IDU3Ljc5MDA1NDcgNDEzLjQ0NDQ0NSA1Ny43OTAwNTQ3IDMyMXpcIlxuICAgICAgLz5cbiAgICA8L3N2Zz5cbiAgKSxcbiAgZXhlY3V0ZTogKFxuICAgIHN0YXRlOiBUZXh0U3RhdGUsXG4gICAgYXBpOiBUZXh0QXJlYVRleHRBcGksXG4gICAgZGlzcGF0Y2g/OiBSZWFjdC5EaXNwYXRjaDxDb250ZXh0U3RvcmU+LFxuICAgIGV4ZWN1dGVDb21tYW5kU3RhdGU/OiBFeGVjdXRlQ29tbWFuZFN0YXRlLFxuICApID0+IHtcbiAgICBhcGkudGV4dEFyZWEuZm9jdXMoKTtcbiAgICBpZiAoZGlzcGF0Y2ggJiYgZXhlY3V0ZUNvbW1hbmRTdGF0ZSAmJiBleGVjdXRlQ29tbWFuZFN0YXRlLmZ1bGxzY3JlZW4pIHtcbiAgICAgIGRpc3BhdGNoKHsgZnVsbHNjcmVlbjogZmFsc2UgfSk7XG4gICAgfVxuICB9LFxufTtcbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLQSxLQUFLLE1BQU0sT0FBTztBQUk5QixPQUFPLElBQU1DLFVBQW9CLEdBQUc7RUFDbENDLElBQUksRUFBRSxZQUFZO0VBQ2xCQyxVQUFVLEVBQUUsWUFBWTtFQUN4QkMsU0FBUyxFQUFFLFFBQVE7RUFDbkJDLFdBQVcsRUFBRTtJQUFFLFlBQVksRUFBRSxZQUFZO0lBQUVDLEtBQUssRUFBRTtFQUFhLENBQUM7RUFDaEVDLElBQUksZUFDRjtJQUFLLEtBQUssRUFBQyxJQUFJO0lBQUMsTUFBTSxFQUFDLElBQUk7SUFBQyxPQUFPLEVBQUM7RUFBYSxnQkFDL0M7SUFDRSxJQUFJLEVBQUMsY0FBYztJQUNuQixDQUFDLEVBQUM7RUFBcy9CLEVBQ3gvQixDQUVMO0VBQ0RDLE9BQU8sRUFBRSxpQkFDUEMsS0FBZ0IsRUFDaEJDLEdBQW9CLEVBQ3BCQyxRQUF1QyxFQUN2Q0MsbUJBQXlDLEVBQ3RDO0lBQ0hGLEdBQUcsQ0FBQ0csUUFBUSxDQUFDQyxLQUFLLEVBQUU7SUFDcEIsSUFBSUgsUUFBUSxJQUFJQyxtQkFBbUIsSUFBSUEsbUJBQW1CLENBQUNYLFVBQVUsRUFBRTtNQUNyRVUsUUFBUSxDQUFDO1FBQUVWLFVBQVUsRUFBRTtNQUFNLENBQUMsQ0FBQztJQUNqQztFQUNGO0FBQ0YsQ0FBQyJ9
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import _objectDestructuringEmpty from "@babel/runtime/helpers/objectDestructuringEmpty";
|
|
1
2
|
import _extends from "@babel/runtime/helpers/extends";
|
|
2
3
|
import _objectSpread from "@babel/runtime/helpers/objectSpread2";
|
|
3
4
|
import React from 'react';
|
|
@@ -16,16 +17,13 @@ export var group = function group(arr, options) {
|
|
|
16
17
|
}, options), {}, {
|
|
17
18
|
keyCommand: 'group'
|
|
18
19
|
});
|
|
19
|
-
|
|
20
20
|
if (Array.isArray(data.children)) {
|
|
21
21
|
data.children = data.children.map(function (_ref) {
|
|
22
|
-
var item = _extends({}, _ref);
|
|
23
|
-
|
|
22
|
+
var item = _extends({}, (_objectDestructuringEmpty(_ref), _ref));
|
|
24
23
|
item.parent = data;
|
|
25
24
|
return _objectSpread({}, item);
|
|
26
25
|
});
|
|
27
26
|
}
|
|
28
|
-
|
|
29
27
|
return data;
|
|
30
28
|
};
|
|
31
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsImdyb3VwIiwiYXJyIiwib3B0aW9ucyIsImRhdGEiLCJjaGlsZHJlbiIsImljb24iLCJleGVjdXRlIiwia2V5Q29tbWFuZCIsIkFycmF5IiwiaXNBcnJheSIsIm1hcCIsIml0ZW0iLCJwYXJlbnQiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tbWFuZHMvZ3JvdXAudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBJQ29tbWFuZCwgSUNvbW1hbmRDaGlsZENvbW1hbmRzLCBJQ29tbWFuZENoaWxkSGFuZGxlIH0gZnJvbSAnLi8nO1xuXG5leHBvcnQgdHlwZSBHcm91cE9wdGlvbnMgPSBPbWl0PElDb21tYW5kPHN0cmluZz4sICdjaGlsZHJlbic+ICYge1xuICBjaGlsZHJlbj86IElDb21tYW5kQ2hpbGRIYW5kbGVbJ2NoaWxkcmVuJ107XG59O1xuXG5leHBvcnQgY29uc3QgZ3JvdXAgPSAoYXJyOiBJQ29tbWFuZENoaWxkQ29tbWFuZHNbJ2NoaWxkcmVuJ10sIG9wdGlvbnM/OiBHcm91cE9wdGlvbnMpOiBJQ29tbWFuZDxzdHJpbmc+ID0+IHtcbiAgbGV0IGRhdGEgPSB7XG4gICAgY2hpbGRyZW46IGFyciBhcyBhbnksXG4gICAgaWNvbjogKFxuICAgICAgPHN2ZyB3aWR0aD1cIjEyXCIgaGVpZ2h0PVwiMTJcIiB2aWV3Qm94PVwiMCAwIDUyMCA1MjBcIj5cbiAgICAgICAgPHBhdGhcbiAgICAgICAgICBmaWxsPVwiY3VycmVudENvbG9yXCJcbiAgICAgICAgICBkPVwiTTE1LjcwODMzMzMsNDY4IEM3LjAzMjQyNDQ4LDQ2OCAwLDQ2Mi4wMzA4MzMgMCw0NTQuNjY2NjY3IEwwLDQyMS4zMzMzMzMgQzAsNDEzLjk2OTE2NyA3LjAzMjQyNDQ4LDQwOCAxNS43MDgzMzMzLDQwOCBMMzYxLjI5MTY2Nyw0MDggQzM2OS45Njc1NzYsNDA4IDM3Nyw0MTMuOTY5MTY3IDM3Nyw0MjEuMzMzMzMzIEwzNzcsNDU0LjY2NjY2NyBDMzc3LDQ2Mi4wMzA4MzMgMzY5Ljk2NzU3Niw0NjggMzYxLjI5MTY2Nyw0NjggTDE1LjcwODMzMzMsNDY4IFogTTIxLjY2NjY2NjcsMzY2IEM5LjY5OTg5NTgzLDM2NiAwLDM1OS44MzE4NjEgMCwzNTIuMjIyMjIyIEwwLDMxNy43Nzc3NzggQzAsMzEwLjE2ODEzOSA5LjY5OTg5NTgzLDMwNCAyMS42NjY2NjY3LDMwNCBMNDk4LjMzMzMzMywzMDQgQzUxMC4zMDAxMDQsMzA0IDUyMCwzMTAuMTY4MTM5IDUyMCwzMTcuNzc3Nzc4IEw1MjAsMzUyLjIyMjIyMiBDNTIwLDM1OS44MzE4NjEgNTEwLjMwMDEwNCwzNjYgNDk4LjMzMzMzMywzNjYgTDIxLjY2NjY2NjcsMzY2IFogTTEzNi44MzU5MzgsNjQgTDEzNi44MzU5MzcsMTI2IEwxMDcuMjUsMTI2IEwxMDcuMjUsMjUxIEw0MC43NSwyNTEgTDQwLjc1LDEyNiBMLTUuNjg0MzQxODllLTE0LDEyNiBMLTUuNjg0MzQxODllLTE0LDY0IEwxMzYuODM1OTM4LDY0IFogTTIxMiw2NCBMMjEyLDI1MSBMMTYxLjY0ODQzOCwyNTEgTDE2MS42NDg0MzgsNjQgTDIxMiw2NCBaIE0zNzgsNjQgTDM3OCwxMjYgTDM0My4yNSwxMjYgTDM0My4yNSwyNTEgTDI4MS43NSwyNTEgTDI4MS43NSwxMjYgTDIzOCwxMjYgTDIzOCw2NCBMMzc4LDY0IFogTTQ0OS4wNDc2MTksMTg5LjU1MDc4MSBMNTIwLDE4OS41NTA3ODEgTDUyMCwyNTEgTDQwNSwyNTEgTDQwNSw2NCBMNDQ5LjA0NzYxOSw2NCBMNDQ5LjA0NzYxOSwxODkuNTUwNzgxIFpcIlxuICAgICAgICAvPlxuICAgICAgPC9zdmc+XG4gICAgKSxcbiAgICBleGVjdXRlOiAoKSA9PiB7fSxcbiAgICAuLi5vcHRpb25zLFxuICAgIGtleUNvbW1hbmQ6ICdncm91cCcsXG4gIH07XG4gIGlmIChBcnJheS5pc0FycmF5KGRhdGEuY2hpbGRyZW4pKSB7XG4gICAgZGF0YS5jaGlsZHJlbiA9IGRhdGEuY2hpbGRyZW4ubWFwKCh7IC4uLml0ZW0gfTogSUNvbW1hbmQpID0+IHtcbiAgICAgIGl0ZW0ucGFyZW50ID0gZGF0YTtcbiAgICAgIHJldHVybiB7IC4uLml0ZW0gfTtcbiAgICB9KTtcbiAgfVxuICByZXR1cm4gZGF0YTtcbn07XG4iXSwibWFwcGluZ3MiOiI7OztBQUFBLE9BQU9BLEtBQUssTUFBTSxPQUFPO0FBT3pCLE9BQU8sSUFBTUMsS0FBSyxHQUFHLFNBQVJBLEtBQUssQ0FBSUMsR0FBc0MsRUFBRUMsT0FBc0IsRUFBdUI7RUFDekcsSUFBSUMsSUFBSTtJQUNOQyxRQUFRLEVBQUVILEdBQVU7SUFDcEJJLElBQUksZUFDRjtNQUFLLEtBQUssRUFBQyxJQUFJO01BQUMsTUFBTSxFQUFDLElBQUk7TUFBQyxPQUFPLEVBQUM7SUFBYSxnQkFDL0M7TUFDRSxJQUFJLEVBQUMsY0FBYztNQUNuQixDQUFDLEVBQUM7SUFBMjRCLEVBQzc0QixDQUVMO0lBQ0RDLE9BQU8sRUFBRSxtQkFBTSxDQUFDO0VBQUMsR0FDZEosT0FBTztJQUNWSyxVQUFVLEVBQUU7RUFBTyxFQUNwQjtFQUNELElBQUlDLEtBQUssQ0FBQ0MsT0FBTyxDQUFDTixJQUFJLENBQUNDLFFBQVEsQ0FBQyxFQUFFO0lBQ2hDRCxJQUFJLENBQUNDLFFBQVEsR0FBR0QsSUFBSSxDQUFDQyxRQUFRLENBQUNNLEdBQUcsQ0FBQyxnQkFBMkI7TUFBQSxJQUFyQkMsSUFBSTtNQUMxQ0EsSUFBSSxDQUFDQyxNQUFNLEdBQUdULElBQUk7TUFDbEIseUJBQVlRLElBQUk7SUFDbEIsQ0FBQyxDQUFDO0VBQ0o7RUFDQSxPQUFPUixJQUFJO0FBQ2IsQ0FBQyJ9
|
package/lib/esm/commands/hr.js
CHANGED
|
@@ -20,4 +20,4 @@ export var hr = {
|
|
|
20
20
|
api.replaceSelection("".concat(state.selectedText, "\n\n----------\n\n"));
|
|
21
21
|
}
|
|
22
22
|
};
|
|
23
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsImhyIiwibmFtZSIsImtleUNvbW1hbmQiLCJzaG9ydGN1dHMiLCJidXR0b25Qcm9wcyIsInRpdGxlIiwiaWNvbiIsImV4ZWN1dGUiLCJzdGF0ZSIsImFwaSIsInJlcGxhY2VTZWxlY3Rpb24iLCJzZWxlY3RlZFRleHQiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tbWFuZHMvaHIudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IElDb21tYW5kLCBUZXh0U3RhdGUsIFRleHRBcmVhVGV4dEFwaSB9IGZyb20gJy4vJztcblxuZXhwb3J0IGNvbnN0IGhyOiBJQ29tbWFuZCA9IHtcbiAgbmFtZTogJ2hyJyxcbiAga2V5Q29tbWFuZDogJ2hyJyxcbiAgc2hvcnRjdXRzOiAnY3RybGNtZCtoJyxcbiAgYnV0dG9uUHJvcHM6IHsgJ2FyaWEtbGFiZWwnOiAnSW5zZXJ0IEhSJywgdGl0bGU6ICdJbnNlcnQgSFInIH0sXG4gIGljb246IChcbiAgICA8c3ZnIHdpZHRoPVwiMTJcIiBoZWlnaHQ9XCIxMlwiIHZpZXdCb3g9XCIwIDAgMTc1IDE3NVwiPlxuICAgICAgPHBhdGhcbiAgICAgICAgZmlsbD1cImN1cnJlbnRDb2xvclwiXG4gICAgICAgIGQ9XCJNMCwxMjkgTDE3NSwxMjkgTDE3NSwxNTQgTDAsMTU0IEwwLDEyOSBaIE0zLDkgTDI4LjIxNTgyMDMsOSBMMjguMjE1ODIwMyw0Ny45ODI0MjE5IEw1NS43Njk1MzEzLDQ3Ljk4MjQyMTkgTDU1Ljc2OTUzMTMsOSBMODEuMDk2Njc5Nyw5IEw4MS4wOTY2Nzk3LDEwNy4xODU1NDcgTDU1Ljc2OTUzMTMsMTA3LjE4NTU0NyBMNTUuNzY5NTMxMyw2OC4wMjE0ODQ0IEwyOC4yMTU4MjAzLDY4LjAyMTQ4NDQgTDI4LjIxNTgyMDMsMTA3LjE4NTU0NyBMMywxMDcuMTg1NTQ3IEwzLDkgWiBNOTMuMTg1NTQ2OSwxMDAuNjAzNTE2IEw5My4xODU1NDY5LDE5IEwxMzUuMjExOTE0LDE5IEMxNDMuMDA0OTIyLDE5IDE0OC45NjA5MTcsMTkuNjY3OTYyMSAxNTMuMDgwMDc4LDIxLjAwMzkwNjMgQzE1Ny4xOTkyMzksMjIuMzM5ODUwNCAxNjAuNTIwNDk1LDI0LjgxNjg3NjQgMTYzLjA0Mzk0NSwyOC40MzUwNTg2IEMxNjUuNTY3Mzk1LDMyLjA1MzI0MDcgMTY2LjgyOTEwMiwzNi40NTk5MzUgMTY2LjgyOTEwMiw0MS42NTUyNzM0IEMxNjYuODI5MTAyLDQ2LjE4MjYzOTggMTY1Ljg2NDI2Nyw1MC4wODgzNjI1IDE2My45MzQ1Nyw1My4zNzI1NTg2IEMxNjIuMDA0ODczLDU2LjY1Njc1NDcgMTU5LjM1MTU3OSw1OS4zMTkzMjU3IDE1NS45NzQ2MDksNjEuMzYwMzUxNiBDMTUzLjgyMjI1NSw2Mi42NTkxODYyIDE1MC44NzIwODksNjMuNzM1MzQ3MyAxNDcuMTI0MDIzLDY0LjU4ODg2NzIgQzE1MC4xMjk4OTgsNjUuNTkwODI1MyAxNTIuMzE5MzI5LDY2LjU5Mjc2ODQgMTUzLjY5MjM4Myw2Ny41OTQ3MjY2IEMxNTQuNjIwMTIyLDY4LjI2MjY5ODcgMTU1Ljk2NTMyMyw2OS42OTEzOTUzIDE1Ny43MjgwMjcsNzEuODgwODU5NCBDMTU5LjQ5MDczMSw3NC4wNzAzMjM0IDE2MC42Njg5NDIsNzUuNzU4NzgzMSAxNjEuMjYyNjk1LDc2Ljk0NjI4OTEgTDE3MywxMDAuNjAzNTE2IEwxNDQuOTUzMTI1LDEwMC42MDM1MTYgTDEzMS40ODI0MjIsNzUuNjY2MDE1NiBDMTI5Ljc3NTM4Miw3Mi40Mzc0ODM5IDEyOC4yNTM5MTMsNzAuMzQwODI1MSAxMjYuOTE3OTY5LDY5LjM3NTk3NjYgQzEyNS4wOTk2LDY4LjExNDI1MTUgMTIzLjA0MDA1MSw2Ny40ODMzOTg0IDEyMC43MzkyNTgsNjcuNDgzMzk4NCBMMTE4LjUxMjY5NSw2Ny40ODMzOTg0IEwxMTguNTEyNjk1LDEwMC42MDM1MTYgTDkzLjE4NTU0NjksMTAwLjYwMzUxNiBaIE0xMTguNTEyNjk1LDUyLjA2NDQ1MzEgTDEyOS4xNDQ1MzEsNTIuMDY0NDUzMSBDMTMwLjI5NDkyOCw1Mi4wNjQ0NTMxIDEzMi41MjE0NjgsNTEuNjkzMzYzMSAxMzUuODI0MjE5LDUwLjk1MTE3MTkgQzEzNy40OTQxNDksNTAuNjE3MTg1OCAxMzguODU3OTA1LDQ5Ljc2MzY3ODcgMTM5LjkxNTUyNyw0OC4zOTA2MjUgQzE0MC45NzMxNSw0Ny4wMTc1NzEzIDE0MS41MDE5NTMsNDUuNDQwNDM4NiAxNDEuNTAxOTUzLDQzLjY1OTE3OTcgQzE0MS41MDE5NTMsNDEuMDI0NDAwOSAxNDAuNjY3MDAxLDM5LjAwMTk2MDIgMTM4Ljk5NzA3LDM3LjU5MTc5NjkgQzEzNy4zMjcxNCwzNi4xODE2MzM2IDEzNC4xOTE0MjksMzUuNDc2NTYyNSAxMjkuNTg5ODQ0LDM1LjQ3NjU2MjUgTDExNy41MTI2OTUsMzUuNDc2NTYyNSBMMTE4LjUxMjY5NSw1Mi4wNjQ0NTMxIFpcIlxuICAgICAgICB0cmFuc2Zvcm09XCJ0cmFuc2xhdGUoMCA5KVwiXG4gICAgICAvPlxuICAgIDwvc3ZnPlxuICApLFxuICBleGVjdXRlOiAoc3RhdGU6IFRleHRTdGF0ZSwgYXBpOiBUZXh0QXJlYVRleHRBcGkpID0+IHtcbiAgICBhcGkucmVwbGFjZVNlbGVjdGlvbihgJHtzdGF0ZS5zZWxlY3RlZFRleHR9XFxuXFxuLS0tLS0tLS0tLVxcblxcbmApO1xuICB9LFxufTtcbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLQSxLQUFLLE1BQU0sT0FBTztBQUc5QixPQUFPLElBQU1DLEVBQVksR0FBRztFQUMxQkMsSUFBSSxFQUFFLElBQUk7RUFDVkMsVUFBVSxFQUFFLElBQUk7RUFDaEJDLFNBQVMsRUFBRSxXQUFXO0VBQ3RCQyxXQUFXLEVBQUU7SUFBRSxZQUFZLEVBQUUsV0FBVztJQUFFQyxLQUFLLEVBQUU7RUFBWSxDQUFDO0VBQzlEQyxJQUFJLGVBQ0Y7SUFBSyxLQUFLLEVBQUMsSUFBSTtJQUFDLE1BQU0sRUFBQyxJQUFJO0lBQUMsT0FBTyxFQUFDO0VBQWEsZ0JBQy9DO0lBQ0UsSUFBSSxFQUFDLGNBQWM7SUFDbkIsQ0FBQyxFQUFDLHVrREFBdWtEO0lBQ3prRCxTQUFTLEVBQUM7RUFBZ0IsRUFDMUIsQ0FFTDtFQUNEQyxPQUFPLEVBQUUsaUJBQUNDLEtBQWdCLEVBQUVDLEdBQW9CLEVBQUs7SUFDbkRBLEdBQUcsQ0FBQ0MsZ0JBQWdCLFdBQUlGLEtBQUssQ0FBQ0csWUFBWSx3QkFBcUI7RUFDakU7QUFDRixDQUFDIn0=
|
|
@@ -22,15 +22,15 @@ export var image = {
|
|
|
22
22
|
text: state.text,
|
|
23
23
|
selection: state.selection
|
|
24
24
|
});
|
|
25
|
-
var state1 = api.setSelectionRange(newSelectionRange);
|
|
26
|
-
|
|
25
|
+
var state1 = api.setSelectionRange(newSelectionRange);
|
|
26
|
+
// Replaces the current selection with the image
|
|
27
27
|
var imageTemplate = state1.selectedText || 'https://example.com/your-image.png';
|
|
28
|
-
api.replaceSelection(""));
|
|
29
|
-
|
|
28
|
+
api.replaceSelection(""));
|
|
29
|
+
// Adjust the selection to not contain the **
|
|
30
30
|
api.setSelectionRange({
|
|
31
31
|
start: 4 + state1.selection.start,
|
|
32
32
|
end: 4 + state1.selection.start + imageTemplate.length
|
|
33
33
|
});
|
|
34
34
|
}
|
|
35
35
|
};
|
|
36
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsInNlbGVjdFdvcmQiLCJpbWFnZSIsIm5hbWUiLCJrZXlDb21tYW5kIiwic2hvcnRjdXRzIiwiYnV0dG9uUHJvcHMiLCJ0aXRsZSIsImljb24iLCJleGVjdXRlIiwic3RhdGUiLCJhcGkiLCJuZXdTZWxlY3Rpb25SYW5nZSIsInRleHQiLCJzZWxlY3Rpb24iLCJzdGF0ZTEiLCJzZXRTZWxlY3Rpb25SYW5nZSIsImltYWdlVGVtcGxhdGUiLCJzZWxlY3RlZFRleHQiLCJyZXBsYWNlU2VsZWN0aW9uIiwic3RhcnQiLCJlbmQiLCJsZW5ndGgiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tbWFuZHMvaW1hZ2UudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IElDb21tYW5kLCBUZXh0U3RhdGUsIFRleHRBcmVhVGV4dEFwaSB9IGZyb20gJy4vJztcbmltcG9ydCB7IHNlbGVjdFdvcmQgfSBmcm9tICcuLi91dGlscy9tYXJrZG93blV0aWxzJztcblxuZXhwb3J0IGNvbnN0IGltYWdlOiBJQ29tbWFuZCA9IHtcbiAgbmFtZTogJ2ltYWdlJyxcbiAga2V5Q29tbWFuZDogJ2ltYWdlJyxcbiAgc2hvcnRjdXRzOiAnY3RybGNtZCtpJyxcbiAgYnV0dG9uUHJvcHM6IHsgJ2FyaWEtbGFiZWwnOiAnQWRkIGltYWdlJywgdGl0bGU6ICdBZGQgaW1hZ2UnIH0sXG4gIGljb246IChcbiAgICA8c3ZnIHdpZHRoPVwiMTJcIiBoZWlnaHQ9XCIxMlwiIHZpZXdCb3g9XCIwIDAgMjAgMjBcIj5cbiAgICAgIDxwYXRoXG4gICAgICAgIGZpbGw9XCJjdXJyZW50Q29sb3JcIlxuICAgICAgICBkPVwiTTE1IDljMS4xIDAgMi0uOSAyLTJzLS45LTItMi0yLTIgLjktMiAyIC45IDIgMiAyem00LTdIMWMtLjU1IDAtMSAuNDUtMSAxdjE0YzAgLjU1LjQ1IDEgMSAxaDE4Yy41NSAwIDEtLjQ1IDEtMVYzYzAtLjU1LS40NS0xLTEtMXptLTEgMTNsLTYtNS0yIDItNC01LTQgOFY0aDE2djExelwiXG4gICAgICAvPlxuICAgIDwvc3ZnPlxuICApLFxuICBleGVjdXRlOiAoc3RhdGU6IFRleHRTdGF0ZSwgYXBpOiBUZXh0QXJlYVRleHRBcGkpID0+IHtcbiAgICAvLyBTZWxlY3QgZXZlcnl0aGluZ1xuICAgIGNvbnN0IG5ld1NlbGVjdGlvblJhbmdlID0gc2VsZWN0V29yZCh7IHRleHQ6IHN0YXRlLnRleHQsIHNlbGVjdGlvbjogc3RhdGUuc2VsZWN0aW9uIH0pO1xuICAgIGNvbnN0IHN0YXRlMSA9IGFwaS5zZXRTZWxlY3Rpb25SYW5nZShuZXdTZWxlY3Rpb25SYW5nZSk7XG4gICAgLy8gUmVwbGFjZXMgdGhlIGN1cnJlbnQgc2VsZWN0aW9uIHdpdGggdGhlIGltYWdlXG4gICAgY29uc3QgaW1hZ2VUZW1wbGF0ZSA9IHN0YXRlMS5zZWxlY3RlZFRleHQgfHwgJ2h0dHBzOi8vZXhhbXBsZS5jb20veW91ci1pbWFnZS5wbmcnO1xuICAgIGFwaS5yZXBsYWNlU2VsZWN0aW9uKGAhW10oJHtpbWFnZVRlbXBsYXRlfSlgKTtcbiAgICAvLyBBZGp1c3QgdGhlIHNlbGVjdGlvbiB0byBub3QgY29udGFpbiB0aGUgKipcbiAgICBhcGkuc2V0U2VsZWN0aW9uUmFuZ2Uoe1xuICAgICAgc3RhcnQ6IDQgKyBzdGF0ZTEuc2VsZWN0aW9uLnN0YXJ0LFxuICAgICAgZW5kOiA0ICsgc3RhdGUxLnNlbGVjdGlvbi5zdGFydCArIGltYWdlVGVtcGxhdGUubGVuZ3RoLFxuICAgIH0pO1xuICB9LFxufTtcbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLQSxLQUFLLE1BQU0sT0FBTztBQUU5QixTQUFTQyxVQUFVLFFBQVEsd0JBQXdCO0FBRW5ELE9BQU8sSUFBTUMsS0FBZSxHQUFHO0VBQzdCQyxJQUFJLEVBQUUsT0FBTztFQUNiQyxVQUFVLEVBQUUsT0FBTztFQUNuQkMsU0FBUyxFQUFFLFdBQVc7RUFDdEJDLFdBQVcsRUFBRTtJQUFFLFlBQVksRUFBRSxXQUFXO0lBQUVDLEtBQUssRUFBRTtFQUFZLENBQUM7RUFDOURDLElBQUksZUFDRjtJQUFLLEtBQUssRUFBQyxJQUFJO0lBQUMsTUFBTSxFQUFDLElBQUk7SUFBQyxPQUFPLEVBQUM7RUFBVyxnQkFDN0M7SUFDRSxJQUFJLEVBQUMsY0FBYztJQUNuQixDQUFDLEVBQUM7RUFBa0ssRUFDcEssQ0FFTDtFQUNEQyxPQUFPLEVBQUUsaUJBQUNDLEtBQWdCLEVBQUVDLEdBQW9CLEVBQUs7SUFDbkQ7SUFDQSxJQUFNQyxpQkFBaUIsR0FBR1gsVUFBVSxDQUFDO01BQUVZLElBQUksRUFBRUgsS0FBSyxDQUFDRyxJQUFJO01BQUVDLFNBQVMsRUFBRUosS0FBSyxDQUFDSTtJQUFVLENBQUMsQ0FBQztJQUN0RixJQUFNQyxNQUFNLEdBQUdKLEdBQUcsQ0FBQ0ssaUJBQWlCLENBQUNKLGlCQUFpQixDQUFDO0lBQ3ZEO0lBQ0EsSUFBTUssYUFBYSxHQUFHRixNQUFNLENBQUNHLFlBQVksSUFBSSxvQ0FBb0M7SUFDakZQLEdBQUcsQ0FBQ1EsZ0JBQWdCLGVBQVFGLGFBQWEsT0FBSTtJQUM3QztJQUNBTixHQUFHLENBQUNLLGlCQUFpQixDQUFDO01BQ3BCSSxLQUFLLEVBQUUsQ0FBQyxHQUFHTCxNQUFNLENBQUNELFNBQVMsQ0FBQ00sS0FBSztNQUNqQ0MsR0FBRyxFQUFFLENBQUMsR0FBR04sTUFBTSxDQUFDRCxTQUFTLENBQUNNLEtBQUssR0FBR0gsYUFBYSxDQUFDSztJQUNsRCxDQUFDLENBQUM7RUFDSjtBQUNGLENBQUMifQ==
|