@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.
Files changed (78) hide show
  1. package/dist/markdown-editor.css +3 -7
  2. package/lib/cjs/Context.js +2 -8
  3. package/lib/cjs/Editor.js +54 -86
  4. package/lib/cjs/commands/bold.js +5 -9
  5. package/lib/cjs/commands/code.js +5 -11
  6. package/lib/cjs/commands/comment.js +5 -7
  7. package/lib/cjs/commands/divider.js +1 -1
  8. package/lib/cjs/commands/fullscreen.js +1 -5
  9. package/lib/cjs/commands/group.js +3 -10
  10. package/lib/cjs/commands/hr.js +1 -4
  11. package/lib/cjs/commands/image.js +5 -9
  12. package/lib/cjs/commands/index.js +52 -87
  13. package/lib/cjs/commands/italic.js +5 -9
  14. package/lib/cjs/commands/link.js +5 -9
  15. package/lib/cjs/commands/list.js +7 -11
  16. package/lib/cjs/commands/preview.js +2 -5
  17. package/lib/cjs/commands/quote.js +3 -6
  18. package/lib/cjs/commands/strikeThrough.js +5 -9
  19. package/lib/cjs/commands/title.js +1 -6
  20. package/lib/cjs/commands/title1.js +1 -6
  21. package/lib/cjs/commands/title2.js +1 -6
  22. package/lib/cjs/commands/title3.js +1 -6
  23. package/lib/cjs/commands/title4.js +1 -6
  24. package/lib/cjs/commands/title5.js +1 -6
  25. package/lib/cjs/commands/title6.js +1 -6
  26. package/lib/cjs/components/DragBar/index.js +3 -14
  27. package/lib/cjs/components/TextArea/Markdown.js +8 -20
  28. package/lib/cjs/components/TextArea/Textarea.js +17 -36
  29. package/lib/cjs/components/TextArea/handleKeyDown.js +1 -19
  30. package/lib/cjs/components/TextArea/index.js +11 -27
  31. package/lib/cjs/components/TextArea/shortcuts.js +1 -17
  32. package/lib/cjs/components/Toolbar/Child.js +9 -18
  33. package/lib/cjs/components/Toolbar/index.js +12 -32
  34. package/lib/cjs/index.js +2 -11
  35. package/lib/cjs/utils/InsertTextAtPosition.js +28 -33
  36. package/lib/cjs/utils/getSurroundingWord.js +9 -12
  37. package/lib/cjs/utils/index.js +1 -1
  38. package/lib/cjs/utils/markdownUtils.js +12 -23
  39. package/lib/esm/Context.js +1 -1
  40. package/lib/esm/Editor.js +54 -71
  41. package/lib/esm/commands/bold.js +5 -5
  42. package/lib/esm/commands/code.js +5 -7
  43. package/lib/esm/commands/comment.js +5 -5
  44. package/lib/esm/commands/divider.js +1 -1
  45. package/lib/esm/commands/fullscreen.js +1 -2
  46. package/lib/esm/commands/group.js +3 -5
  47. package/lib/esm/commands/hr.js +1 -1
  48. package/lib/esm/commands/image.js +5 -5
  49. package/lib/esm/commands/index.js +8 -18
  50. package/lib/esm/commands/italic.js +5 -5
  51. package/lib/esm/commands/link.js +5 -5
  52. package/lib/esm/commands/list.js +5 -5
  53. package/lib/esm/commands/preview.js +1 -1
  54. package/lib/esm/commands/quote.js +3 -2
  55. package/lib/esm/commands/strikeThrough.js +5 -5
  56. package/lib/esm/commands/title.js +1 -1
  57. package/lib/esm/commands/title1.js +1 -3
  58. package/lib/esm/commands/title2.js +1 -3
  59. package/lib/esm/commands/title3.js +1 -3
  60. package/lib/esm/commands/title4.js +1 -3
  61. package/lib/esm/commands/title5.js +1 -3
  62. package/lib/esm/commands/title6.js +1 -3
  63. package/lib/esm/components/DragBar/index.js +3 -12
  64. package/lib/esm/components/TextArea/Markdown.js +9 -13
  65. package/lib/esm/components/TextArea/Textarea.js +17 -20
  66. package/lib/esm/components/TextArea/handleKeyDown.js +2 -14
  67. package/lib/esm/components/TextArea/index.css +1 -2
  68. package/lib/esm/components/TextArea/index.js +11 -14
  69. package/lib/esm/components/TextArea/shortcuts.js +1 -14
  70. package/lib/esm/components/Toolbar/Child.js +9 -10
  71. package/lib/esm/components/Toolbar/index.css +2 -5
  72. package/lib/esm/components/Toolbar/index.js +12 -23
  73. package/lib/esm/index.js +1 -1
  74. package/lib/esm/utils/InsertTextAtPosition.js +28 -31
  75. package/lib/esm/utils/getSurroundingWord.js +9 -10
  76. package/lib/esm/utils/index.js +1 -1
  77. package/lib/esm/utils/markdownUtils.js +10 -16
  78. 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
- _ref$prefixCls = _ref.prefixCls,
26
- prefixCls = _ref$prefixCls === void 0 ? 'w-md-editor' : _ref$prefixCls,
27
- className = _ref.className,
28
- propsValue = _ref.value,
29
- _ref$commands = _ref.commands,
30
- commands = _ref$commands === void 0 ? getCommands() : _ref$commands,
31
- _ref$extraCommands = _ref.extraCommands,
32
- extraCommands = _ref$extraCommands === void 0 ? getExtraCommands() : _ref$extraCommands,
33
- _ref$height = _ref.height,
34
- height = _ref$height === void 0 ? 200 : _ref$height,
35
- _ref$toolbarHeight = _ref.toolbarHeight,
36
- toolbarHeight = _ref$toolbarHeight === void 0 ? 29 : _ref$toolbarHeight,
37
- _ref$enableScroll = _ref.enableScroll,
38
- enableScroll = _ref$enableScroll === void 0 ? true : _ref$enableScroll,
39
- _ref$visiableDragbar = _ref.visiableDragbar,
40
- visiableDragbar = _ref$visiableDragbar === void 0 ? true : _ref$visiableDragbar,
41
- _ref$highlightEnable = _ref.highlightEnable,
42
- highlightEnable = _ref$highlightEnable === void 0 ? true : _ref$highlightEnable,
43
- _ref$preview = _ref.preview,
44
- previewType = _ref$preview === void 0 ? 'live' : _ref$preview,
45
- _ref$fullscreen = _ref.fullscreen,
46
- fullscreen = _ref$fullscreen === void 0 ? false : _ref$fullscreen,
47
- _ref$previewOptions = _ref.previewOptions,
48
- previewOptions = _ref$previewOptions === void 0 ? {} : _ref$previewOptions,
49
- textareaProps = _ref.textareaProps,
50
- _ref$maxHeight = _ref.maxHeight,
51
- maxHeight = _ref$maxHeight === void 0 ? 1200 : _ref$maxHeight,
52
- _ref$minHeight = _ref.minHeight,
53
- minHeight = _ref$minHeight === void 0 ? 100 : _ref$minHeight,
54
- autoFocus = _ref.autoFocus,
55
- _ref$tabSize = _ref.tabSize,
56
- tabSize = _ref$tabSize === void 0 ? 2 : _ref$tabSize,
57
- onChange = _ref.onChange,
58
- hideToolbar = _ref.hideToolbar,
59
- other = _objectWithoutProperties(_ref, _excluded);
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
- markdown: propsValue,
63
- preview: previewType,
64
- height: height,
65
- highlightEnable: highlightEnable,
66
- tabSize: tabSize,
67
- scrollTop: 0,
68
- scrollTopPreview: 0,
69
- commands: commands,
70
- extraCommands: extraCommands,
71
- fullscreen: fullscreen,
72
- onChange: onChange,
73
- barPopup: {}
74
- }),
75
- _useReducer2 = _slicedToArray(_useReducer, 2),
76
- state = _useReducer2[0],
77
- dispatch = _useReducer2[1];
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
- } // eslint-disable-next-line react-hooks/exhaustive-deps
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":"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","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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"}
@@ -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); // Replaces the current selection with the bold mark up
27
-
28
- var state2 = api.replaceSelection("**".concat(state1.selectedText, "**")); // Adjust the selection to not contain the **
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy9ib2xkLnRzeCJdLCJuYW1lcyI6WyJSZWFjdCIsInNlbGVjdFdvcmQiLCJib2xkIiwibmFtZSIsImtleUNvbW1hbmQiLCJzaG9ydGN1dHMiLCJidXR0b25Qcm9wcyIsInRpdGxlIiwiaWNvbiIsImV4ZWN1dGUiLCJzdGF0ZSIsImFwaSIsIm5ld1NlbGVjdGlvblJhbmdlIiwidGV4dCIsInNlbGVjdGlvbiIsInN0YXRlMSIsInNldFNlbGVjdGlvblJhbmdlIiwic3RhdGUyIiwicmVwbGFjZVNlbGVjdGlvbiIsInNlbGVjdGVkVGV4dCIsInN0YXJ0IiwiZW5kIiwibGVuZ3RoIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUtBLEtBQVosTUFBdUIsT0FBdkI7QUFFQSxTQUFTQyxVQUFULFFBQTJCLHdCQUEzQjtBQUVBLE9BQU8sSUFBTUMsSUFBYyxHQUFHO0FBQzVCQyxFQUFBQSxJQUFJLEVBQUUsTUFEc0I7QUFFNUJDLEVBQUFBLFVBQVUsRUFBRSxNQUZnQjtBQUc1QkMsRUFBQUEsU0FBUyxFQUFFLFdBSGlCO0FBSTVCQyxFQUFBQSxXQUFXLEVBQUU7QUFBRSxrQkFBYyxlQUFoQjtBQUFpQ0MsSUFBQUEsS0FBSyxFQUFFO0FBQXhDLEdBSmU7QUFLNUJDLEVBQUFBLElBQUksZUFDRjtBQUFLLElBQUEsSUFBSSxFQUFDLEtBQVY7QUFBZ0IsSUFBQSxLQUFLLEVBQUMsSUFBdEI7QUFBMkIsSUFBQSxNQUFNLEVBQUMsSUFBbEM7QUFBdUMsSUFBQSxPQUFPLEVBQUM7QUFBL0Msa0JBQ0U7QUFDRSxJQUFBLElBQUksRUFBQyxjQURQO0FBRUUsSUFBQSxDQUFDLEVBQUM7QUFGSixJQURGLENBTjBCO0FBYTVCQyxFQUFBQSxPQUFPLEVBQUUsaUJBQUNDLEtBQUQsRUFBbUJDLEdBQW5CLEVBQTRDO0FBQ25EO0FBQ0EsUUFBTUMsaUJBQWlCLEdBQUdYLFVBQVUsQ0FBQztBQUFFWSxNQUFBQSxJQUFJLEVBQUVILEtBQUssQ0FBQ0csSUFBZDtBQUFvQkMsTUFBQUEsU0FBUyxFQUFFSixLQUFLLENBQUNJO0FBQXJDLEtBQUQsQ0FBcEM7QUFDQSxRQUFNQyxNQUFNLEdBQUdKLEdBQUcsQ0FBQ0ssaUJBQUosQ0FBc0JKLGlCQUF0QixDQUFmLENBSG1ELENBSW5EOztBQUNBLFFBQU1LLE1BQU0sR0FBR04sR0FBRyxDQUFDTyxnQkFBSixhQUEwQkgsTUFBTSxDQUFDSSxZQUFqQyxRQUFmLENBTG1ELENBTW5EOztBQUNBUixJQUFBQSxHQUFHLENBQUNLLGlCQUFKLENBQXNCO0FBQ3BCSSxNQUFBQSxLQUFLLEVBQUVILE1BQU0sQ0FBQ0gsU0FBUCxDQUFpQk8sR0FBakIsR0FBdUIsQ0FBdkIsR0FBMkJOLE1BQU0sQ0FBQ0ksWUFBUCxDQUFvQkcsTUFEbEM7QUFFcEJELE1BQUFBLEdBQUcsRUFBRUosTUFBTSxDQUFDSCxTQUFQLENBQWlCTyxHQUFqQixHQUF1QjtBQUZSLEtBQXRCO0FBSUQ7QUF4QjJCLENBQXZCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgSUNvbW1hbmQsIFRleHRTdGF0ZSwgVGV4dEFyZWFUZXh0QXBpIH0gZnJvbSAnLi8nO1xuaW1wb3J0IHsgc2VsZWN0V29yZCB9IGZyb20gJy4uL3V0aWxzL21hcmtkb3duVXRpbHMnO1xuXG5leHBvcnQgY29uc3QgYm9sZDogSUNvbW1hbmQgPSB7XG4gIG5hbWU6ICdib2xkJyxcbiAga2V5Q29tbWFuZDogJ2JvbGQnLFxuICBzaG9ydGN1dHM6ICdjdHJsY21kK2InLFxuICBidXR0b25Qcm9wczogeyAnYXJpYS1sYWJlbCc6ICdBZGQgYm9sZCB0ZXh0JywgdGl0bGU6ICdBZGQgYm9sZCB0ZXh0JyB9LFxuICBpY29uOiAoXG4gICAgPHN2ZyByb2xlPVwiaW1nXCIgd2lkdGg9XCIxMlwiIGhlaWdodD1cIjEyXCIgdmlld0JveD1cIjAgMCAzODQgNTEyXCI+XG4gICAgICA8cGF0aFxuICAgICAgICBmaWxsPVwiY3VycmVudENvbG9yXCJcbiAgICAgICAgZD1cIk0zMDQuNzkzIDI0My44OTFjMzMuNjM5LTE4LjUzNyA1My42NTctNTQuMTYgNTMuNjU3LTk1LjY5MyAwLTQ4LjIzNi0yNi4yNS04Ny42MjYtNjguNjI2LTEwNC4xNzlDMjY1LjEzOCAzNC4wMSAyNDAuODQ5IDMyIDIwOS42NjEgMzJIMjRjLTguODM3IDAtMTYgNy4xNjMtMTYgMTZ2MzMuMDQ5YzAgOC44MzcgNy4xNjMgMTYgMTYgMTZoMzMuMTEzdjMxOC41M0gyNGMtOC44MzcgMC0xNiA3LjE2My0xNiAxNlY0NjRjMCA4LjgzNyA3LjE2MyAxNiAxNiAxNmgxOTUuNjljMjQuMjAzIDAgNDQuODM0LTEuMjg5IDY2Ljg2Ni03LjU4NEMzMzcuNTIgNDU3LjE5MyAzNzYgNDEwLjY0NyAzNzYgMzUwLjAxNGMwLTUyLjE2OC0yNi41NzMtOTEuNjg0LTcxLjIwNy0xMDYuMTIzek0xNDIuMjE3IDEwMC44MDloNjcuNDQ0YzE2LjI5NCAwIDI3LjUzNiAyLjAxOSAzNy41MjUgNi43MTcgMTUuODI4IDguNDc5IDI0LjkwNiAyNi41MDIgMjQuOTA2IDQ5LjQ0NiAwIDM1LjAyOS0yMC4zMiA1Ni43OS01My4wMjkgNTYuNzloLTc2Ljg0NlYxMDAuODA5em0xMTIuNjQyIDMwNS40NzVjLTEwLjE0IDQuMDU2LTIyLjY3NyA0LjkwNy0zMS40MDkgNC45MDdoLTgxLjIzM1YyODEuOTQzaDg0LjM2N2MzOS42NDUgMCA2My4wNTcgMjUuMzggNjMuMDU3IDYzLjA1Ny4wMDEgMjguNDI1LTEzLjY2IDUyLjQ4My0zNC43ODIgNjEuMjg0elwiXG4gICAgICAvPlxuICAgIDwvc3ZnPlxuICApLFxuICBleGVjdXRlOiAoc3RhdGU6IFRleHRTdGF0ZSwgYXBpOiBUZXh0QXJlYVRleHRBcGkpID0+IHtcbiAgICAvLyBBZGp1c3QgdGhlIHNlbGVjdGlvbiB0byBlbmNvbXBhc3MgdGhlIHdob2xlIHdvcmQgaWYgdGhlIGNhcmV0IGlzIGluc2lkZSBvbmVcbiAgICBjb25zdCBuZXdTZWxlY3Rpb25SYW5nZSA9IHNlbGVjdFdvcmQoeyB0ZXh0OiBzdGF0ZS50ZXh0LCBzZWxlY3Rpb246IHN0YXRlLnNlbGVjdGlvbiB9KTtcbiAgICBjb25zdCBzdGF0ZTEgPSBhcGkuc2V0U2VsZWN0aW9uUmFuZ2UobmV3U2VsZWN0aW9uUmFuZ2UpO1xuICAgIC8vIFJlcGxhY2VzIHRoZSBjdXJyZW50IHNlbGVjdGlvbiB3aXRoIHRoZSBib2xkIG1hcmsgdXBcbiAgICBjb25zdCBzdGF0ZTIgPSBhcGkucmVwbGFjZVNlbGVjdGlvbihgKioke3N0YXRlMS5zZWxlY3RlZFRleHR9KipgKTtcbiAgICAvLyBBZGp1c3QgdGhlIHNlbGVjdGlvbiB0byBub3QgY29udGFpbiB0aGUgKipcbiAgICBhcGkuc2V0U2VsZWN0aW9uUmFuZ2Uoe1xuICAgICAgc3RhcnQ6IHN0YXRlMi5zZWxlY3Rpb24uZW5kIC0gMiAtIHN0YXRlMS5zZWxlY3RlZFRleHQubGVuZ3RoLFxuICAgICAgZW5kOiBzdGF0ZTIuc2VsZWN0aW9uLmVuZCAtIDIsXG4gICAgfSk7XG4gIH0sXG59O1xuIl19
36
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsInNlbGVjdFdvcmQiLCJib2xkIiwibmFtZSIsImtleUNvbW1hbmQiLCJzaG9ydGN1dHMiLCJidXR0b25Qcm9wcyIsInRpdGxlIiwiaWNvbiIsImV4ZWN1dGUiLCJzdGF0ZSIsImFwaSIsIm5ld1NlbGVjdGlvblJhbmdlIiwidGV4dCIsInNlbGVjdGlvbiIsInN0YXRlMSIsInNldFNlbGVjdGlvblJhbmdlIiwic3RhdGUyIiwicmVwbGFjZVNlbGVjdGlvbiIsInNlbGVjdGVkVGV4dCIsInN0YXJ0IiwiZW5kIiwibGVuZ3RoIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbW1hbmRzL2JvbGQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IElDb21tYW5kLCBUZXh0U3RhdGUsIFRleHRBcmVhVGV4dEFwaSB9IGZyb20gJy4vJztcbmltcG9ydCB7IHNlbGVjdFdvcmQgfSBmcm9tICcuLi91dGlscy9tYXJrZG93blV0aWxzJztcblxuZXhwb3J0IGNvbnN0IGJvbGQ6IElDb21tYW5kID0ge1xuICBuYW1lOiAnYm9sZCcsXG4gIGtleUNvbW1hbmQ6ICdib2xkJyxcbiAgc2hvcnRjdXRzOiAnY3RybGNtZCtiJyxcbiAgYnV0dG9uUHJvcHM6IHsgJ2FyaWEtbGFiZWwnOiAnQWRkIGJvbGQgdGV4dCcsIHRpdGxlOiAnQWRkIGJvbGQgdGV4dCcgfSxcbiAgaWNvbjogKFxuICAgIDxzdmcgcm9sZT1cImltZ1wiIHdpZHRoPVwiMTJcIiBoZWlnaHQ9XCIxMlwiIHZpZXdCb3g9XCIwIDAgMzg0IDUxMlwiPlxuICAgICAgPHBhdGhcbiAgICAgICAgZmlsbD1cImN1cnJlbnRDb2xvclwiXG4gICAgICAgIGQ9XCJNMzA0Ljc5MyAyNDMuODkxYzMzLjYzOS0xOC41MzcgNTMuNjU3LTU0LjE2IDUzLjY1Ny05NS42OTMgMC00OC4yMzYtMjYuMjUtODcuNjI2LTY4LjYyNi0xMDQuMTc5QzI2NS4xMzggMzQuMDEgMjQwLjg0OSAzMiAyMDkuNjYxIDMySDI0Yy04LjgzNyAwLTE2IDcuMTYzLTE2IDE2djMzLjA0OWMwIDguODM3IDcuMTYzIDE2IDE2IDE2aDMzLjExM3YzMTguNTNIMjRjLTguODM3IDAtMTYgNy4xNjMtMTYgMTZWNDY0YzAgOC44MzcgNy4xNjMgMTYgMTYgMTZoMTk1LjY5YzI0LjIwMyAwIDQ0LjgzNC0xLjI4OSA2Ni44NjYtNy41ODRDMzM3LjUyIDQ1Ny4xOTMgMzc2IDQxMC42NDcgMzc2IDM1MC4wMTRjMC01Mi4xNjgtMjYuNTczLTkxLjY4NC03MS4yMDctMTA2LjEyM3pNMTQyLjIxNyAxMDAuODA5aDY3LjQ0NGMxNi4yOTQgMCAyNy41MzYgMi4wMTkgMzcuNTI1IDYuNzE3IDE1LjgyOCA4LjQ3OSAyNC45MDYgMjYuNTAyIDI0LjkwNiA0OS40NDYgMCAzNS4wMjktMjAuMzIgNTYuNzktNTMuMDI5IDU2Ljc5aC03Ni44NDZWMTAwLjgwOXptMTEyLjY0MiAzMDUuNDc1Yy0xMC4xNCA0LjA1Ni0yMi42NzcgNC45MDctMzEuNDA5IDQuOTA3aC04MS4yMzNWMjgxLjk0M2g4NC4zNjdjMzkuNjQ1IDAgNjMuMDU3IDI1LjM4IDYzLjA1NyA2My4wNTcuMDAxIDI4LjQyNS0xMy42NiA1Mi40ODMtMzQuNzgyIDYxLjI4NHpcIlxuICAgICAgLz5cbiAgICA8L3N2Zz5cbiAgKSxcbiAgZXhlY3V0ZTogKHN0YXRlOiBUZXh0U3RhdGUsIGFwaTogVGV4dEFyZWFUZXh0QXBpKSA9PiB7XG4gICAgLy8gQWRqdXN0IHRoZSBzZWxlY3Rpb24gdG8gZW5jb21wYXNzIHRoZSB3aG9sZSB3b3JkIGlmIHRoZSBjYXJldCBpcyBpbnNpZGUgb25lXG4gICAgY29uc3QgbmV3U2VsZWN0aW9uUmFuZ2UgPSBzZWxlY3RXb3JkKHsgdGV4dDogc3RhdGUudGV4dCwgc2VsZWN0aW9uOiBzdGF0ZS5zZWxlY3Rpb24gfSk7XG4gICAgY29uc3Qgc3RhdGUxID0gYXBpLnNldFNlbGVjdGlvblJhbmdlKG5ld1NlbGVjdGlvblJhbmdlKTtcbiAgICAvLyBSZXBsYWNlcyB0aGUgY3VycmVudCBzZWxlY3Rpb24gd2l0aCB0aGUgYm9sZCBtYXJrIHVwXG4gICAgY29uc3Qgc3RhdGUyID0gYXBpLnJlcGxhY2VTZWxlY3Rpb24oYCoqJHtzdGF0ZTEuc2VsZWN0ZWRUZXh0fSoqYCk7XG4gICAgLy8gQWRqdXN0IHRoZSBzZWxlY3Rpb24gdG8gbm90IGNvbnRhaW4gdGhlICoqXG4gICAgYXBpLnNldFNlbGVjdGlvblJhbmdlKHtcbiAgICAgIHN0YXJ0OiBzdGF0ZTIuc2VsZWN0aW9uLmVuZCAtIDIgLSBzdGF0ZTEuc2VsZWN0ZWRUZXh0Lmxlbmd0aCxcbiAgICAgIGVuZDogc3RhdGUyLnNlbGVjdGlvbi5lbmQgLSAyLFxuICAgIH0pO1xuICB9LFxufTtcbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLQSxLQUFLLE1BQU0sT0FBTztBQUU5QixTQUFTQyxVQUFVLFFBQVEsd0JBQXdCO0FBRW5ELE9BQU8sSUFBTUMsSUFBYyxHQUFHO0VBQzVCQyxJQUFJLEVBQUUsTUFBTTtFQUNaQyxVQUFVLEVBQUUsTUFBTTtFQUNsQkMsU0FBUyxFQUFFLFdBQVc7RUFDdEJDLFdBQVcsRUFBRTtJQUFFLFlBQVksRUFBRSxlQUFlO0lBQUVDLEtBQUssRUFBRTtFQUFnQixDQUFDO0VBQ3RFQyxJQUFJLGVBQ0Y7SUFBSyxJQUFJLEVBQUMsS0FBSztJQUFDLEtBQUssRUFBQyxJQUFJO0lBQUMsTUFBTSxFQUFDLElBQUk7SUFBQyxPQUFPLEVBQUM7RUFBYSxnQkFDMUQ7SUFDRSxJQUFJLEVBQUMsY0FBYztJQUNuQixDQUFDLEVBQUM7RUFBd3FCLEVBQzFxQixDQUVMO0VBQ0RDLE9BQU8sRUFBRSxpQkFBQ0MsS0FBZ0IsRUFBRUMsR0FBb0IsRUFBSztJQUNuRDtJQUNBLElBQU1DLGlCQUFpQixHQUFHWCxVQUFVLENBQUM7TUFBRVksSUFBSSxFQUFFSCxLQUFLLENBQUNHLElBQUk7TUFBRUMsU0FBUyxFQUFFSixLQUFLLENBQUNJO0lBQVUsQ0FBQyxDQUFDO0lBQ3RGLElBQU1DLE1BQU0sR0FBR0osR0FBRyxDQUFDSyxpQkFBaUIsQ0FBQ0osaUJBQWlCLENBQUM7SUFDdkQ7SUFDQSxJQUFNSyxNQUFNLEdBQUdOLEdBQUcsQ0FBQ08sZ0JBQWdCLGFBQU1ILE1BQU0sQ0FBQ0ksWUFBWSxRQUFLO0lBQ2pFO0lBQ0FSLEdBQUcsQ0FBQ0ssaUJBQWlCLENBQUM7TUFDcEJJLEtBQUssRUFBRUgsTUFBTSxDQUFDSCxTQUFTLENBQUNPLEdBQUcsR0FBRyxDQUFDLEdBQUdOLE1BQU0sQ0FBQ0ksWUFBWSxDQUFDRyxNQUFNO01BQzVERCxHQUFHLEVBQUVKLE1BQU0sQ0FBQ0gsU0FBUyxDQUFDTyxHQUFHLEdBQUc7SUFDOUIsQ0FBQyxDQUFDO0VBQ0o7QUFDRixDQUFDIn0=
@@ -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); // when there's no breaking line
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, "`")); // Adjust the selection to not contain the **
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,{"version":3,"sources":["../../../src/commands/code.tsx"],"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"],"mappings":"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","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"]}
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); // Replaces the current selection with the bold mark up
13
-
14
- var state2 = api.replaceSelection("<!-- ".concat(state1.selectedText, " -->")); // Adjust the selection to not contain the **
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy9jb21tZW50LnRzeCJdLCJuYW1lcyI6WyJzZWxlY3RXb3JkIiwiY29tbWVudCIsIm5hbWUiLCJrZXlDb21tYW5kIiwic2hvcnRjdXRzIiwiZXhlY3V0ZSIsInN0YXRlIiwiYXBpIiwibmV3U2VsZWN0aW9uUmFuZ2UiLCJ0ZXh0Iiwic2VsZWN0aW9uIiwic3RhdGUxIiwic2V0U2VsZWN0aW9uUmFuZ2UiLCJzdGF0ZTIiLCJyZXBsYWNlU2VsZWN0aW9uIiwic2VsZWN0ZWRUZXh0Iiwic3RhcnQiLCJlbmQiLCJsZW5ndGgiXSwibWFwcGluZ3MiOiJBQUNBLFNBQVNBLFVBQVQsUUFBMkIsd0JBQTNCO0FBRUEsT0FBTyxJQUFNQyxPQUFpQixHQUFHO0FBQy9CQyxFQUFBQSxJQUFJLEVBQUUsU0FEeUI7QUFFL0JDLEVBQUFBLFVBQVUsRUFBRSxTQUZtQjtBQUcvQkMsRUFBQUEsU0FBUyxFQUFFLFdBSG9CO0FBSS9CQyxFQUFBQSxPQUFPLEVBQUUsaUJBQUNDLEtBQUQsRUFBbUJDLEdBQW5CLEVBQTRDO0FBQ25EO0FBQ0EsUUFBTUMsaUJBQWlCLEdBQUdSLFVBQVUsQ0FBQztBQUFFUyxNQUFBQSxJQUFJLEVBQUVILEtBQUssQ0FBQ0csSUFBZDtBQUFvQkMsTUFBQUEsU0FBUyxFQUFFSixLQUFLLENBQUNJO0FBQXJDLEtBQUQsQ0FBcEM7QUFDQSxRQUFNQyxNQUFNLEdBQUdKLEdBQUcsQ0FBQ0ssaUJBQUosQ0FBc0JKLGlCQUF0QixDQUFmLENBSG1ELENBSW5EOztBQUNBLFFBQU1LLE1BQU0sR0FBR04sR0FBRyxDQUFDTyxnQkFBSixnQkFBNkJILE1BQU0sQ0FBQ0ksWUFBcEMsVUFBZixDQUxtRCxDQU1uRDs7QUFDQVIsSUFBQUEsR0FBRyxDQUFDSyxpQkFBSixDQUFzQjtBQUNwQkksTUFBQUEsS0FBSyxFQUFFSCxNQUFNLENBQUNILFNBQVAsQ0FBaUJPLEdBQWpCLEdBQXVCLENBQXZCLEdBQTJCTixNQUFNLENBQUNJLFlBQVAsQ0FBb0JHLE1BRGxDO0FBRXBCRCxNQUFBQSxHQUFHLEVBQUVKLE1BQU0sQ0FBQ0gsU0FBUCxDQUFpQk8sR0FBakIsR0FBdUI7QUFGUixLQUF0QjtBQUlEO0FBZjhCLENBQTFCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSUNvbW1hbmQsIFRleHRTdGF0ZSwgVGV4dEFyZWFUZXh0QXBpIH0gZnJvbSAnLi8nO1xuaW1wb3J0IHsgc2VsZWN0V29yZCB9IGZyb20gJy4uL3V0aWxzL21hcmtkb3duVXRpbHMnO1xuXG5leHBvcnQgY29uc3QgY29tbWVudDogSUNvbW1hbmQgPSB7XG4gIG5hbWU6ICdjb21tZW50JyxcbiAga2V5Q29tbWFuZDogJ2NvbW1lbnQnLFxuICBzaG9ydGN1dHM6ICdjdHJsY21kKy8nLFxuICBleGVjdXRlOiAoc3RhdGU6IFRleHRTdGF0ZSwgYXBpOiBUZXh0QXJlYVRleHRBcGkpID0+IHtcbiAgICAvLyBBZGp1c3QgdGhlIHNlbGVjdGlvbiB0byBlbmNvbXBhc3MgdGhlIHdob2xlIHdvcmQgaWYgdGhlIGNhcmV0IGlzIGluc2lkZSBvbmVcbiAgICBjb25zdCBuZXdTZWxlY3Rpb25SYW5nZSA9IHNlbGVjdFdvcmQoeyB0ZXh0OiBzdGF0ZS50ZXh0LCBzZWxlY3Rpb246IHN0YXRlLnNlbGVjdGlvbiB9KTtcbiAgICBjb25zdCBzdGF0ZTEgPSBhcGkuc2V0U2VsZWN0aW9uUmFuZ2UobmV3U2VsZWN0aW9uUmFuZ2UpO1xuICAgIC8vIFJlcGxhY2VzIHRoZSBjdXJyZW50IHNlbGVjdGlvbiB3aXRoIHRoZSBib2xkIG1hcmsgdXBcbiAgICBjb25zdCBzdGF0ZTIgPSBhcGkucmVwbGFjZVNlbGVjdGlvbihgPCEtLSAke3N0YXRlMS5zZWxlY3RlZFRleHR9IC0tPmApO1xuICAgIC8vIEFkanVzdCB0aGUgc2VsZWN0aW9uIHRvIG5vdCBjb250YWluIHRoZSAqKlxuICAgIGFwaS5zZXRTZWxlY3Rpb25SYW5nZSh7XG4gICAgICBzdGFydDogc3RhdGUyLnNlbGVjdGlvbi5lbmQgLSA0IC0gc3RhdGUxLnNlbGVjdGVkVGV4dC5sZW5ndGgsXG4gICAgICBlbmQ6IHN0YXRlMi5zZWxlY3Rpb24uZW5kIC0gNCxcbiAgICB9KTtcbiAgfSxcbn07XG4iXX0=
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy9kaXZpZGVyLnRzeCJdLCJuYW1lcyI6WyJkaXZpZGVyIiwia2V5Q29tbWFuZCJdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxJQUFNQSxPQUFpQixHQUFHO0FBQy9CQyxFQUFBQSxVQUFVLEVBQUU7QUFEbUIsQ0FBMUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJQ29tbWFuZCB9IGZyb20gJy4vJztcblxuZXhwb3J0IGNvbnN0IGRpdmlkZXI6IElDb21tYW5kID0ge1xuICBrZXlDb21tYW5kOiAnZGl2aWRlcicsXG59O1xuIl19
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy9mdWxsc2NyZWVuLnRzeCJdLCJuYW1lcyI6WyJSZWFjdCIsImZ1bGxzY3JlZW4iLCJuYW1lIiwia2V5Q29tbWFuZCIsInNob3J0Y3V0cyIsImJ1dHRvblByb3BzIiwidGl0bGUiLCJpY29uIiwiZXhlY3V0ZSIsInN0YXRlIiwiYXBpIiwiZGlzcGF0Y2giLCJleGVjdXRlQ29tbWFuZFN0YXRlIiwidGV4dEFyZWEiLCJmb2N1cyJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLQSxLQUFaLE1BQXVCLE9BQXZCO0FBSUEsT0FBTyxJQUFNQyxVQUFvQixHQUFHO0FBQ2xDQyxFQUFBQSxJQUFJLEVBQUUsWUFENEI7QUFFbENDLEVBQUFBLFVBQVUsRUFBRSxZQUZzQjtBQUdsQ0MsRUFBQUEsU0FBUyxFQUFFLFFBSHVCO0FBSWxDQyxFQUFBQSxXQUFXLEVBQUU7QUFBRSxrQkFBYyxZQUFoQjtBQUE4QkMsSUFBQUEsS0FBSyxFQUFFO0FBQXJDLEdBSnFCO0FBS2xDQyxFQUFBQSxJQUFJLGVBQ0Y7QUFBSyxJQUFBLEtBQUssRUFBQyxJQUFYO0FBQWdCLElBQUEsTUFBTSxFQUFDLElBQXZCO0FBQTRCLElBQUEsT0FBTyxFQUFDO0FBQXBDLGtCQUNFO0FBQ0UsSUFBQSxJQUFJLEVBQUMsY0FEUDtBQUVFLElBQUEsQ0FBQyxFQUFDO0FBRkosSUFERixDQU5nQztBQWFsQ0MsRUFBQUEsT0FBTyxFQUFFLGlCQUNQQyxLQURPLEVBRVBDLEdBRk8sRUFHUEMsUUFITyxFQUlQQyxtQkFKTyxFQUtKO0FBQ0hGLElBQUFBLEdBQUcsQ0FBQ0csUUFBSixDQUFhQyxLQUFiOztBQUNBLFFBQUlILFFBQVEsSUFBSUMsbUJBQVosSUFBbUNBLG1CQUFtQixDQUFDWCxVQUEzRCxFQUF1RTtBQUNyRVUsTUFBQUEsUUFBUSxDQUFDO0FBQUVWLFFBQUFBLFVBQVUsRUFBRTtBQUFkLE9BQUQsQ0FBUjtBQUNEO0FBQ0Y7QUF2QmlDLENBQTdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgSUNvbW1hbmQsIFRleHRTdGF0ZSwgVGV4dEFyZWFUZXh0QXBpIH0gZnJvbSAnLi8nO1xuaW1wb3J0IHsgQ29udGV4dFN0b3JlLCBFeGVjdXRlQ29tbWFuZFN0YXRlIH0gZnJvbSAnLi4vQ29udGV4dCc7XG5cbmV4cG9ydCBjb25zdCBmdWxsc2NyZWVuOiBJQ29tbWFuZCA9IHtcbiAgbmFtZTogJ2Z1bGxzY3JlZW4nLFxuICBrZXlDb21tYW5kOiAnZnVsbHNjcmVlbicsXG4gIHNob3J0Y3V0czogJ2VzY2FwZScsXG4gIGJ1dHRvblByb3BzOiB7ICdhcmlhLWxhYmVsJzogJ2Z1bGxzY3JlZW4nLCB0aXRsZTogJ2Z1bGxzY3JlZW4nIH0sXG4gIGljb246IChcbiAgICA8c3ZnIHdpZHRoPVwiMTJcIiBoZWlnaHQ9XCIxMlwiIHZpZXdCb3g9XCIwIDAgNTIwIDUyMFwiPlxuICAgICAgPHBhdGhcbiAgICAgICAgZmlsbD1cImN1cnJlbnRDb2xvclwiXG4gICAgICAgIGQ9XCJNMTE4IDE3MS4xMzMzMzRMMTE4IDM0Mi4yMDAyNzFDMTE4IDM1My43NjY5MzggMTI2LjY3NSAzNjUuMzMzNjA1IDE0MS4xMzMzMzMgMzY1LjMzMzYwNUwzODIuNjM0NjE0IDM2NS4zMzM2MDVDMzk0LjIwMTI4MSAzNjUuMzMzNjA1IDQwNS43Njc5NDggMzU2LjY1ODYwNSA0MDUuNzY3OTQ4IDM0Mi4yMDAyNzFMNDA1Ljc2Nzk0OCAxNzEuMTMzMzM0QzQwNS43Njc5NDggMTU5LjU2NjY2NyAzOTcuMDkyOTQ4IDE0OCAzODIuNjM0NjE0IDE0OEwxNDEuMTMzMzMzIDE0OEMxMjYuNjc0OTk5IDE0OCAxMTcuOTk5OTk5IDE1Ni42NzUgMTE4IDE3MS4xMzMzMzR6TTQ2NS4zNTM1OTEgNDEzLjQ0NDQ0NEwzNzAgNDEzLjQ0NDQ0NCAzNzAgNDcxLjIyMjIyMiA0NzQuMDIyMSA0NzEuMjIyMjIyQzUwMC4wMjc2MjQgNDcxLjIyMjIyMiA1MjAuMjU0MTQzIDQ1MSA1MjAuMjU0MTQzIDQyNUw1MjAuMjU0MTQzIDMyMSA0NjIuNDY0MDg5IDMyMSA0NjIuNDY0MDg5IDQxMy40NDQ0NDQgNDY1LjM1MzU5MSA0MTMuNDQ0NDQ0ek00NzEuMDIyMSA0M0wzNjcgNDMgMzY3IDEwMC43Nzc3NzggNDYyLjM1MzU5MSAxMDAuNzc3Nzc4IDQ2Mi4zNTM1OTEgMTk2LjExMTExMSA1MjAuMTQzNjQ3IDE5Ni4xMTExMTEgNTIwLjE0MzY0NyA4OS4yMjIyMjE5QzUxNy4yNTQxNDQgNjMuMjIyMjIxOSA0OTcuMDI3NjI0IDQzIDQ3MS4wMjIxIDQzek01Ny43OTAwNTQ3IDEwMC43Nzc3NzhMMTUzLjE0MzY0NiAxMDAuNzc3Nzc4IDE1My4xNDM2NDYgNDMgNDYuMjMyMDQzOSA0M0MyMC4yMjY1MTkxIDQzIDAgNjMuMjIyMjIxOSAwIDg5LjIyMjIyMTlMMCAxOTMuMjIyMjIyIDU3Ljc5MDA1NDcgMTkzLjIyMjIyMiA1Ny43OTAwNTQ3IDEwMC43Nzc3Nzh6TTU3Ljc5MDA1NDcgMzIxTDAgMzIxIDAgNDI1QzAgNDUxIDIwLjIyNjUxOTEgNDcxLjIyMjIyMiA0Ni4yMzIwNDM5IDQ3MS4yMjIyMjNMMTUwLjI1NDE0MyA0NzEuMjIyMjIzIDE1MC4yNTQxNDMgNDEzLjQ0NDQ0NSA1Ny43OTAwNTQ3IDQxMy40NDQ0NDUgNTcuNzkwMDU0NyAzMjF6XCJcbiAgICAgIC8+XG4gICAgPC9zdmc+XG4gICksXG4gIGV4ZWN1dGU6IChcbiAgICBzdGF0ZTogVGV4dFN0YXRlLFxuICAgIGFwaTogVGV4dEFyZWFUZXh0QXBpLFxuICAgIGRpc3BhdGNoPzogUmVhY3QuRGlzcGF0Y2g8Q29udGV4dFN0b3JlPixcbiAgICBleGVjdXRlQ29tbWFuZFN0YXRlPzogRXhlY3V0ZUNvbW1hbmRTdGF0ZSxcbiAgKSA9PiB7XG4gICAgYXBpLnRleHRBcmVhLmZvY3VzKCk7XG4gICAgaWYgKGRpc3BhdGNoICYmIGV4ZWN1dGVDb21tYW5kU3RhdGUgJiYgZXhlY3V0ZUNvbW1hbmRTdGF0ZS5mdWxsc2NyZWVuKSB7XG4gICAgICBkaXNwYXRjaCh7IGZ1bGxzY3JlZW46IGZhbHNlIH0pO1xuICAgIH1cbiAgfSxcbn07XG4iXX0=
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy9ncm91cC50c3giXSwibmFtZXMiOlsiUmVhY3QiLCJncm91cCIsImFyciIsIm9wdGlvbnMiLCJkYXRhIiwiY2hpbGRyZW4iLCJpY29uIiwiZXhlY3V0ZSIsImtleUNvbW1hbmQiLCJBcnJheSIsImlzQXJyYXkiLCJtYXAiLCJpdGVtIiwicGFyZW50Il0sIm1hcHBpbmdzIjoiOztBQUFBLE9BQU9BLEtBQVAsTUFBa0IsT0FBbEI7QUFPQSxPQUFPLElBQU1DLEtBQUssR0FBRyxTQUFSQSxLQUFRLENBQUNDLEdBQUQsRUFBeUNDLE9BQXpDLEVBQXNGO0FBQ3pHLE1BQUlDLElBQUk7QUFDTkMsSUFBQUEsUUFBUSxFQUFFSCxHQURKO0FBRU5JLElBQUFBLElBQUksZUFDRjtBQUFLLE1BQUEsS0FBSyxFQUFDLElBQVg7QUFBZ0IsTUFBQSxNQUFNLEVBQUMsSUFBdkI7QUFBNEIsTUFBQSxPQUFPLEVBQUM7QUFBcEMsb0JBQ0U7QUFDRSxNQUFBLElBQUksRUFBQyxjQURQO0FBRUUsTUFBQSxDQUFDLEVBQUM7QUFGSixNQURGLENBSEk7QUFVTkMsSUFBQUEsT0FBTyxFQUFFLG1CQUFNLENBQUU7QUFWWCxLQVdISixPQVhHO0FBWU5LLElBQUFBLFVBQVUsRUFBRTtBQVpOLElBQVI7O0FBY0EsTUFBSUMsS0FBSyxDQUFDQyxPQUFOLENBQWNOLElBQUksQ0FBQ0MsUUFBbkIsQ0FBSixFQUFrQztBQUNoQ0QsSUFBQUEsSUFBSSxDQUFDQyxRQUFMLEdBQWdCRCxJQUFJLENBQUNDLFFBQUwsQ0FBY00sR0FBZCxDQUFrQixnQkFBMkI7QUFBQSxVQUFyQkMsSUFBcUI7O0FBQzNEQSxNQUFBQSxJQUFJLENBQUNDLE1BQUwsR0FBY1QsSUFBZDtBQUNBLCtCQUFZUSxJQUFaO0FBQ0QsS0FIZSxDQUFoQjtBQUlEOztBQUNELFNBQU9SLElBQVA7QUFDRCxDQXRCTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBJQ29tbWFuZCwgSUNvbW1hbmRDaGlsZENvbW1hbmRzLCBJQ29tbWFuZENoaWxkSGFuZGxlIH0gZnJvbSAnLi8nO1xuXG5leHBvcnQgdHlwZSBHcm91cE9wdGlvbnMgPSBPbWl0PElDb21tYW5kPHN0cmluZz4sICdjaGlsZHJlbic+ICYge1xuICBjaGlsZHJlbj86IElDb21tYW5kQ2hpbGRIYW5kbGVbJ2NoaWxkcmVuJ107XG59O1xuXG5leHBvcnQgY29uc3QgZ3JvdXAgPSAoYXJyOiBJQ29tbWFuZENoaWxkQ29tbWFuZHNbJ2NoaWxkcmVuJ10sIG9wdGlvbnM/OiBHcm91cE9wdGlvbnMpOiBJQ29tbWFuZDxzdHJpbmc+ID0+IHtcbiAgbGV0IGRhdGEgPSB7XG4gICAgY2hpbGRyZW46IGFyciBhcyBhbnksXG4gICAgaWNvbjogKFxuICAgICAgPHN2ZyB3aWR0aD1cIjEyXCIgaGVpZ2h0PVwiMTJcIiB2aWV3Qm94PVwiMCAwIDUyMCA1MjBcIj5cbiAgICAgICAgPHBhdGhcbiAgICAgICAgICBmaWxsPVwiY3VycmVudENvbG9yXCJcbiAgICAgICAgICBkPVwiTTE1LjcwODMzMzMsNDY4IEM3LjAzMjQyNDQ4LDQ2OCAwLDQ2Mi4wMzA4MzMgMCw0NTQuNjY2NjY3IEwwLDQyMS4zMzMzMzMgQzAsNDEzLjk2OTE2NyA3LjAzMjQyNDQ4LDQwOCAxNS43MDgzMzMzLDQwOCBMMzYxLjI5MTY2Nyw0MDggQzM2OS45Njc1NzYsNDA4IDM3Nyw0MTMuOTY5MTY3IDM3Nyw0MjEuMzMzMzMzIEwzNzcsNDU0LjY2NjY2NyBDMzc3LDQ2Mi4wMzA4MzMgMzY5Ljk2NzU3Niw0NjggMzYxLjI5MTY2Nyw0NjggTDE1LjcwODMzMzMsNDY4IFogTTIxLjY2NjY2NjcsMzY2IEM5LjY5OTg5NTgzLDM2NiAwLDM1OS44MzE4NjEgMCwzNTIuMjIyMjIyIEwwLDMxNy43Nzc3NzggQzAsMzEwLjE2ODEzOSA5LjY5OTg5NTgzLDMwNCAyMS42NjY2NjY3LDMwNCBMNDk4LjMzMzMzMywzMDQgQzUxMC4zMDAxMDQsMzA0IDUyMCwzMTAuMTY4MTM5IDUyMCwzMTcuNzc3Nzc4IEw1MjAsMzUyLjIyMjIyMiBDNTIwLDM1OS44MzE4NjEgNTEwLjMwMDEwNCwzNjYgNDk4LjMzMzMzMywzNjYgTDIxLjY2NjY2NjcsMzY2IFogTTEzNi44MzU5MzgsNjQgTDEzNi44MzU5MzcsMTI2IEwxMDcuMjUsMTI2IEwxMDcuMjUsMjUxIEw0MC43NSwyNTEgTDQwLjc1LDEyNiBMLTUuNjg0MzQxODllLTE0LDEyNiBMLTUuNjg0MzQxODllLTE0LDY0IEwxMzYuODM1OTM4LDY0IFogTTIxMiw2NCBMMjEyLDI1MSBMMTYxLjY0ODQzOCwyNTEgTDE2MS42NDg0MzgsNjQgTDIxMiw2NCBaIE0zNzgsNjQgTDM3OCwxMjYgTDM0My4yNSwxMjYgTDM0My4yNSwyNTEgTDI4MS43NSwyNTEgTDI4MS43NSwxMjYgTDIzOCwxMjYgTDIzOCw2NCBMMzc4LDY0IFogTTQ0OS4wNDc2MTksMTg5LjU1MDc4MSBMNTIwLDE4OS41NTA3ODEgTDUyMCwyNTEgTDQwNSwyNTEgTDQwNSw2NCBMNDQ5LjA0NzYxOSw2NCBMNDQ5LjA0NzYxOSwxODkuNTUwNzgxIFpcIlxuICAgICAgICAvPlxuICAgICAgPC9zdmc+XG4gICAgKSxcbiAgICBleGVjdXRlOiAoKSA9PiB7fSxcbiAgICAuLi5vcHRpb25zLFxuICAgIGtleUNvbW1hbmQ6ICdncm91cCcsXG4gIH07XG4gIGlmIChBcnJheS5pc0FycmF5KGRhdGEuY2hpbGRyZW4pKSB7XG4gICAgZGF0YS5jaGlsZHJlbiA9IGRhdGEuY2hpbGRyZW4ubWFwKCh7IC4uLml0ZW0gfTogSUNvbW1hbmQpID0+IHtcbiAgICAgIGl0ZW0ucGFyZW50ID0gZGF0YTtcbiAgICAgIHJldHVybiB7IC4uLml0ZW0gfTtcbiAgICB9KTtcbiAgfVxuICByZXR1cm4gZGF0YTtcbn07XG4iXX0=
29
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsImdyb3VwIiwiYXJyIiwib3B0aW9ucyIsImRhdGEiLCJjaGlsZHJlbiIsImljb24iLCJleGVjdXRlIiwia2V5Q29tbWFuZCIsIkFycmF5IiwiaXNBcnJheSIsIm1hcCIsIml0ZW0iLCJwYXJlbnQiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tbWFuZHMvZ3JvdXAudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBJQ29tbWFuZCwgSUNvbW1hbmRDaGlsZENvbW1hbmRzLCBJQ29tbWFuZENoaWxkSGFuZGxlIH0gZnJvbSAnLi8nO1xuXG5leHBvcnQgdHlwZSBHcm91cE9wdGlvbnMgPSBPbWl0PElDb21tYW5kPHN0cmluZz4sICdjaGlsZHJlbic+ICYge1xuICBjaGlsZHJlbj86IElDb21tYW5kQ2hpbGRIYW5kbGVbJ2NoaWxkcmVuJ107XG59O1xuXG5leHBvcnQgY29uc3QgZ3JvdXAgPSAoYXJyOiBJQ29tbWFuZENoaWxkQ29tbWFuZHNbJ2NoaWxkcmVuJ10sIG9wdGlvbnM/OiBHcm91cE9wdGlvbnMpOiBJQ29tbWFuZDxzdHJpbmc+ID0+IHtcbiAgbGV0IGRhdGEgPSB7XG4gICAgY2hpbGRyZW46IGFyciBhcyBhbnksXG4gICAgaWNvbjogKFxuICAgICAgPHN2ZyB3aWR0aD1cIjEyXCIgaGVpZ2h0PVwiMTJcIiB2aWV3Qm94PVwiMCAwIDUyMCA1MjBcIj5cbiAgICAgICAgPHBhdGhcbiAgICAgICAgICBmaWxsPVwiY3VycmVudENvbG9yXCJcbiAgICAgICAgICBkPVwiTTE1LjcwODMzMzMsNDY4IEM3LjAzMjQyNDQ4LDQ2OCAwLDQ2Mi4wMzA4MzMgMCw0NTQuNjY2NjY3IEwwLDQyMS4zMzMzMzMgQzAsNDEzLjk2OTE2NyA3LjAzMjQyNDQ4LDQwOCAxNS43MDgzMzMzLDQwOCBMMzYxLjI5MTY2Nyw0MDggQzM2OS45Njc1NzYsNDA4IDM3Nyw0MTMuOTY5MTY3IDM3Nyw0MjEuMzMzMzMzIEwzNzcsNDU0LjY2NjY2NyBDMzc3LDQ2Mi4wMzA4MzMgMzY5Ljk2NzU3Niw0NjggMzYxLjI5MTY2Nyw0NjggTDE1LjcwODMzMzMsNDY4IFogTTIxLjY2NjY2NjcsMzY2IEM5LjY5OTg5NTgzLDM2NiAwLDM1OS44MzE4NjEgMCwzNTIuMjIyMjIyIEwwLDMxNy43Nzc3NzggQzAsMzEwLjE2ODEzOSA5LjY5OTg5NTgzLDMwNCAyMS42NjY2NjY3LDMwNCBMNDk4LjMzMzMzMywzMDQgQzUxMC4zMDAxMDQsMzA0IDUyMCwzMTAuMTY4MTM5IDUyMCwzMTcuNzc3Nzc4IEw1MjAsMzUyLjIyMjIyMiBDNTIwLDM1OS44MzE4NjEgNTEwLjMwMDEwNCwzNjYgNDk4LjMzMzMzMywzNjYgTDIxLjY2NjY2NjcsMzY2IFogTTEzNi44MzU5MzgsNjQgTDEzNi44MzU5MzcsMTI2IEwxMDcuMjUsMTI2IEwxMDcuMjUsMjUxIEw0MC43NSwyNTEgTDQwLjc1LDEyNiBMLTUuNjg0MzQxODllLTE0LDEyNiBMLTUuNjg0MzQxODllLTE0LDY0IEwxMzYuODM1OTM4LDY0IFogTTIxMiw2NCBMMjEyLDI1MSBMMTYxLjY0ODQzOCwyNTEgTDE2MS42NDg0MzgsNjQgTDIxMiw2NCBaIE0zNzgsNjQgTDM3OCwxMjYgTDM0My4yNSwxMjYgTDM0My4yNSwyNTEgTDI4MS43NSwyNTEgTDI4MS43NSwxMjYgTDIzOCwxMjYgTDIzOCw2NCBMMzc4LDY0IFogTTQ0OS4wNDc2MTksMTg5LjU1MDc4MSBMNTIwLDE4OS41NTA3ODEgTDUyMCwyNTEgTDQwNSwyNTEgTDQwNSw2NCBMNDQ5LjA0NzYxOSw2NCBMNDQ5LjA0NzYxOSwxODkuNTUwNzgxIFpcIlxuICAgICAgICAvPlxuICAgICAgPC9zdmc+XG4gICAgKSxcbiAgICBleGVjdXRlOiAoKSA9PiB7fSxcbiAgICAuLi5vcHRpb25zLFxuICAgIGtleUNvbW1hbmQ6ICdncm91cCcsXG4gIH07XG4gIGlmIChBcnJheS5pc0FycmF5KGRhdGEuY2hpbGRyZW4pKSB7XG4gICAgZGF0YS5jaGlsZHJlbiA9IGRhdGEuY2hpbGRyZW4ubWFwKCh7IC4uLml0ZW0gfTogSUNvbW1hbmQpID0+IHtcbiAgICAgIGl0ZW0ucGFyZW50ID0gZGF0YTtcbiAgICAgIHJldHVybiB7IC4uLml0ZW0gfTtcbiAgICB9KTtcbiAgfVxuICByZXR1cm4gZGF0YTtcbn07XG4iXSwibWFwcGluZ3MiOiI7OztBQUFBLE9BQU9BLEtBQUssTUFBTSxPQUFPO0FBT3pCLE9BQU8sSUFBTUMsS0FBSyxHQUFHLFNBQVJBLEtBQUssQ0FBSUMsR0FBc0MsRUFBRUMsT0FBc0IsRUFBdUI7RUFDekcsSUFBSUMsSUFBSTtJQUNOQyxRQUFRLEVBQUVILEdBQVU7SUFDcEJJLElBQUksZUFDRjtNQUFLLEtBQUssRUFBQyxJQUFJO01BQUMsTUFBTSxFQUFDLElBQUk7TUFBQyxPQUFPLEVBQUM7SUFBYSxnQkFDL0M7TUFDRSxJQUFJLEVBQUMsY0FBYztNQUNuQixDQUFDLEVBQUM7SUFBMjRCLEVBQzc0QixDQUVMO0lBQ0RDLE9BQU8sRUFBRSxtQkFBTSxDQUFDO0VBQUMsR0FDZEosT0FBTztJQUNWSyxVQUFVLEVBQUU7RUFBTyxFQUNwQjtFQUNELElBQUlDLEtBQUssQ0FBQ0MsT0FBTyxDQUFDTixJQUFJLENBQUNDLFFBQVEsQ0FBQyxFQUFFO0lBQ2hDRCxJQUFJLENBQUNDLFFBQVEsR0FBR0QsSUFBSSxDQUFDQyxRQUFRLENBQUNNLEdBQUcsQ0FBQyxnQkFBMkI7TUFBQSxJQUFyQkMsSUFBSTtNQUMxQ0EsSUFBSSxDQUFDQyxNQUFNLEdBQUdULElBQUk7TUFDbEIseUJBQVlRLElBQUk7SUFDbEIsQ0FBQyxDQUFDO0VBQ0o7RUFDQSxPQUFPUixJQUFJO0FBQ2IsQ0FBQyJ9
@@ -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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy9oci50c3giXSwibmFtZXMiOlsiUmVhY3QiLCJociIsIm5hbWUiLCJrZXlDb21tYW5kIiwic2hvcnRjdXRzIiwiYnV0dG9uUHJvcHMiLCJ0aXRsZSIsImljb24iLCJleGVjdXRlIiwic3RhdGUiLCJhcGkiLCJyZXBsYWNlU2VsZWN0aW9uIiwic2VsZWN0ZWRUZXh0Il0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUtBLEtBQVosTUFBdUIsT0FBdkI7QUFHQSxPQUFPLElBQU1DLEVBQVksR0FBRztBQUMxQkMsRUFBQUEsSUFBSSxFQUFFLElBRG9CO0FBRTFCQyxFQUFBQSxVQUFVLEVBQUUsSUFGYztBQUcxQkMsRUFBQUEsU0FBUyxFQUFFLFdBSGU7QUFJMUJDLEVBQUFBLFdBQVcsRUFBRTtBQUFFLGtCQUFjLFdBQWhCO0FBQTZCQyxJQUFBQSxLQUFLLEVBQUU7QUFBcEMsR0FKYTtBQUsxQkMsRUFBQUEsSUFBSSxlQUNGO0FBQUssSUFBQSxLQUFLLEVBQUMsSUFBWDtBQUFnQixJQUFBLE1BQU0sRUFBQyxJQUF2QjtBQUE0QixJQUFBLE9BQU8sRUFBQztBQUFwQyxrQkFDRTtBQUNFLElBQUEsSUFBSSxFQUFDLGNBRFA7QUFFRSxJQUFBLENBQUMsRUFBQyx1a0RBRko7QUFHRSxJQUFBLFNBQVMsRUFBQztBQUhaLElBREYsQ0FOd0I7QUFjMUJDLEVBQUFBLE9BQU8sRUFBRSxpQkFBQ0MsS0FBRCxFQUFtQkMsR0FBbkIsRUFBNEM7QUFDbkRBLElBQUFBLEdBQUcsQ0FBQ0MsZ0JBQUosV0FBd0JGLEtBQUssQ0FBQ0csWUFBOUI7QUFDRDtBQWhCeUIsQ0FBckIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBJQ29tbWFuZCwgVGV4dFN0YXRlLCBUZXh0QXJlYVRleHRBcGkgfSBmcm9tICcuLyc7XG5cbmV4cG9ydCBjb25zdCBocjogSUNvbW1hbmQgPSB7XG4gIG5hbWU6ICdocicsXG4gIGtleUNvbW1hbmQ6ICdocicsXG4gIHNob3J0Y3V0czogJ2N0cmxjbWQraCcsXG4gIGJ1dHRvblByb3BzOiB7ICdhcmlhLWxhYmVsJzogJ0luc2VydCBIUicsIHRpdGxlOiAnSW5zZXJ0IEhSJyB9LFxuICBpY29uOiAoXG4gICAgPHN2ZyB3aWR0aD1cIjEyXCIgaGVpZ2h0PVwiMTJcIiB2aWV3Qm94PVwiMCAwIDE3NSAxNzVcIj5cbiAgICAgIDxwYXRoXG4gICAgICAgIGZpbGw9XCJjdXJyZW50Q29sb3JcIlxuICAgICAgICBkPVwiTTAsMTI5IEwxNzUsMTI5IEwxNzUsMTU0IEwwLDE1NCBMMCwxMjkgWiBNMyw5IEwyOC4yMTU4MjAzLDkgTDI4LjIxNTgyMDMsNDcuOTgyNDIxOSBMNTUuNzY5NTMxMyw0Ny45ODI0MjE5IEw1NS43Njk1MzEzLDkgTDgxLjA5NjY3OTcsOSBMODEuMDk2Njc5NywxMDcuMTg1NTQ3IEw1NS43Njk1MzEzLDEwNy4xODU1NDcgTDU1Ljc2OTUzMTMsNjguMDIxNDg0NCBMMjguMjE1ODIwMyw2OC4wMjE0ODQ0IEwyOC4yMTU4MjAzLDEwNy4xODU1NDcgTDMsMTA3LjE4NTU0NyBMMyw5IFogTTkzLjE4NTU0NjksMTAwLjYwMzUxNiBMOTMuMTg1NTQ2OSwxOSBMMTM1LjIxMTkxNCwxOSBDMTQzLjAwNDkyMiwxOSAxNDguOTYwOTE3LDE5LjY2Nzk2MjEgMTUzLjA4MDA3OCwyMS4wMDM5MDYzIEMxNTcuMTk5MjM5LDIyLjMzOTg1MDQgMTYwLjUyMDQ5NSwyNC44MTY4NzY0IDE2My4wNDM5NDUsMjguNDM1MDU4NiBDMTY1LjU2NzM5NSwzMi4wNTMyNDA3IDE2Ni44MjkxMDIsMzYuNDU5OTM1IDE2Ni44MjkxMDIsNDEuNjU1MjczNCBDMTY2LjgyOTEwMiw0Ni4xODI2Mzk4IDE2NS44NjQyNjcsNTAuMDg4MzYyNSAxNjMuOTM0NTcsNTMuMzcyNTU4NiBDMTYyLjAwNDg3Myw1Ni42NTY3NTQ3IDE1OS4zNTE1NzksNTkuMzE5MzI1NyAxNTUuOTc0NjA5LDYxLjM2MDM1MTYgQzE1My44MjIyNTUsNjIuNjU5MTg2MiAxNTAuODcyMDg5LDYzLjczNTM0NzMgMTQ3LjEyNDAyMyw2NC41ODg4NjcyIEMxNTAuMTI5ODk4LDY1LjU5MDgyNTMgMTUyLjMxOTMyOSw2Ni41OTI3Njg0IDE1My42OTIzODMsNjcuNTk0NzI2NiBDMTU0LjYyMDEyMiw2OC4yNjI2OTg3IDE1NS45NjUzMjMsNjkuNjkxMzk1MyAxNTcuNzI4MDI3LDcxLjg4MDg1OTQgQzE1OS40OTA3MzEsNzQuMDcwMzIzNCAxNjAuNjY4OTQyLDc1Ljc1ODc4MzEgMTYxLjI2MjY5NSw3Ni45NDYyODkxIEwxNzMsMTAwLjYwMzUxNiBMMTQ0Ljk1MzEyNSwxMDAuNjAzNTE2IEwxMzEuNDgyNDIyLDc1LjY2NjAxNTYgQzEyOS43NzUzODIsNzIuNDM3NDgzOSAxMjguMjUzOTEzLDcwLjM0MDgyNTEgMTI2LjkxNzk2OSw2OS4zNzU5NzY2IEMxMjUuMDk5Niw2OC4xMTQyNTE1IDEyMy4wNDAwNTEsNjcuNDgzMzk4NCAxMjAuNzM5MjU4LDY3LjQ4MzM5ODQgTDExOC41MTI2OTUsNjcuNDgzMzk4NCBMMTE4LjUxMjY5NSwxMDAuNjAzNTE2IEw5My4xODU1NDY5LDEwMC42MDM1MTYgWiBNMTE4LjUxMjY5NSw1Mi4wNjQ0NTMxIEwxMjkuMTQ0NTMxLDUyLjA2NDQ1MzEgQzEzMC4yOTQ5MjgsNTIuMDY0NDUzMSAxMzIuNTIxNDY4LDUxLjY5MzM2MzEgMTM1LjgyNDIxOSw1MC45NTExNzE5IEMxMzcuNDk0MTQ5LDUwLjYxNzE4NTggMTM4Ljg1NzkwNSw0OS43NjM2Nzg3IDEzOS45MTU1MjcsNDguMzkwNjI1IEMxNDAuOTczMTUsNDcuMDE3NTcxMyAxNDEuNTAxOTUzLDQ1LjQ0MDQzODYgMTQxLjUwMTk1Myw0My42NTkxNzk3IEMxNDEuNTAxOTUzLDQxLjAyNDQwMDkgMTQwLjY2NzAwMSwzOS4wMDE5NjAyIDEzOC45OTcwNywzNy41OTE3OTY5IEMxMzcuMzI3MTQsMzYuMTgxNjMzNiAxMzQuMTkxNDI5LDM1LjQ3NjU2MjUgMTI5LjU4OTg0NCwzNS40NzY1NjI1IEwxMTcuNTEyNjk1LDM1LjQ3NjU2MjUgTDExOC41MTI2OTUsNTIuMDY0NDUzMSBaXCJcbiAgICAgICAgdHJhbnNmb3JtPVwidHJhbnNsYXRlKDAgOSlcIlxuICAgICAgLz5cbiAgICA8L3N2Zz5cbiAgKSxcbiAgZXhlY3V0ZTogKHN0YXRlOiBUZXh0U3RhdGUsIGFwaTogVGV4dEFyZWFUZXh0QXBpKSA9PiB7XG4gICAgYXBpLnJlcGxhY2VTZWxlY3Rpb24oYCR7c3RhdGUuc2VsZWN0ZWRUZXh0fVxcblxcbi0tLS0tLS0tLS1cXG5cXG5gKTtcbiAgfSxcbn07XG4iXX0=
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); // Replaces the current selection with the image
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("![](".concat(imageTemplate, ")")); // Adjust the selection to not contain the **
29
-
28
+ api.replaceSelection("![](".concat(imageTemplate, ")"));
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy9pbWFnZS50c3giXSwibmFtZXMiOlsiUmVhY3QiLCJzZWxlY3RXb3JkIiwiaW1hZ2UiLCJuYW1lIiwia2V5Q29tbWFuZCIsInNob3J0Y3V0cyIsImJ1dHRvblByb3BzIiwidGl0bGUiLCJpY29uIiwiZXhlY3V0ZSIsInN0YXRlIiwiYXBpIiwibmV3U2VsZWN0aW9uUmFuZ2UiLCJ0ZXh0Iiwic2VsZWN0aW9uIiwic3RhdGUxIiwic2V0U2VsZWN0aW9uUmFuZ2UiLCJpbWFnZVRlbXBsYXRlIiwic2VsZWN0ZWRUZXh0IiwicmVwbGFjZVNlbGVjdGlvbiIsInN0YXJ0IiwiZW5kIiwibGVuZ3RoIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUtBLEtBQVosTUFBdUIsT0FBdkI7QUFFQSxTQUFTQyxVQUFULFFBQTJCLHdCQUEzQjtBQUVBLE9BQU8sSUFBTUMsS0FBZSxHQUFHO0FBQzdCQyxFQUFBQSxJQUFJLEVBQUUsT0FEdUI7QUFFN0JDLEVBQUFBLFVBQVUsRUFBRSxPQUZpQjtBQUc3QkMsRUFBQUEsU0FBUyxFQUFFLFdBSGtCO0FBSTdCQyxFQUFBQSxXQUFXLEVBQUU7QUFBRSxrQkFBYyxXQUFoQjtBQUE2QkMsSUFBQUEsS0FBSyxFQUFFO0FBQXBDLEdBSmdCO0FBSzdCQyxFQUFBQSxJQUFJLGVBQ0Y7QUFBSyxJQUFBLEtBQUssRUFBQyxJQUFYO0FBQWdCLElBQUEsTUFBTSxFQUFDLElBQXZCO0FBQTRCLElBQUEsT0FBTyxFQUFDO0FBQXBDLGtCQUNFO0FBQ0UsSUFBQSxJQUFJLEVBQUMsY0FEUDtBQUVFLElBQUEsQ0FBQyxFQUFDO0FBRkosSUFERixDQU4yQjtBQWE3QkMsRUFBQUEsT0FBTyxFQUFFLGlCQUFDQyxLQUFELEVBQW1CQyxHQUFuQixFQUE0QztBQUNuRDtBQUNBLFFBQU1DLGlCQUFpQixHQUFHWCxVQUFVLENBQUM7QUFBRVksTUFBQUEsSUFBSSxFQUFFSCxLQUFLLENBQUNHLElBQWQ7QUFBb0JDLE1BQUFBLFNBQVMsRUFBRUosS0FBSyxDQUFDSTtBQUFyQyxLQUFELENBQXBDO0FBQ0EsUUFBTUMsTUFBTSxHQUFHSixHQUFHLENBQUNLLGlCQUFKLENBQXNCSixpQkFBdEIsQ0FBZixDQUhtRCxDQUluRDs7QUFDQSxRQUFNSyxhQUFhLEdBQUdGLE1BQU0sQ0FBQ0csWUFBUCxJQUF1QixvQ0FBN0M7QUFDQVAsSUFBQUEsR0FBRyxDQUFDUSxnQkFBSixlQUE0QkYsYUFBNUIsUUFObUQsQ0FPbkQ7O0FBQ0FOLElBQUFBLEdBQUcsQ0FBQ0ssaUJBQUosQ0FBc0I7QUFDcEJJLE1BQUFBLEtBQUssRUFBRSxJQUFJTCxNQUFNLENBQUNELFNBQVAsQ0FBaUJNLEtBRFI7QUFFcEJDLE1BQUFBLEdBQUcsRUFBRSxJQUFJTixNQUFNLENBQUNELFNBQVAsQ0FBaUJNLEtBQXJCLEdBQTZCSCxhQUFhLENBQUNLO0FBRjVCLEtBQXRCO0FBSUQ7QUF6QjRCLENBQXhCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgSUNvbW1hbmQsIFRleHRTdGF0ZSwgVGV4dEFyZWFUZXh0QXBpIH0gZnJvbSAnLi8nO1xuaW1wb3J0IHsgc2VsZWN0V29yZCB9IGZyb20gJy4uL3V0aWxzL21hcmtkb3duVXRpbHMnO1xuXG5leHBvcnQgY29uc3QgaW1hZ2U6IElDb21tYW5kID0ge1xuICBuYW1lOiAnaW1hZ2UnLFxuICBrZXlDb21tYW5kOiAnaW1hZ2UnLFxuICBzaG9ydGN1dHM6ICdjdHJsY21kK2knLFxuICBidXR0b25Qcm9wczogeyAnYXJpYS1sYWJlbCc6ICdBZGQgaW1hZ2UnLCB0aXRsZTogJ0FkZCBpbWFnZScgfSxcbiAgaWNvbjogKFxuICAgIDxzdmcgd2lkdGg9XCIxMlwiIGhlaWdodD1cIjEyXCIgdmlld0JveD1cIjAgMCAyMCAyMFwiPlxuICAgICAgPHBhdGhcbiAgICAgICAgZmlsbD1cImN1cnJlbnRDb2xvclwiXG4gICAgICAgIGQ9XCJNMTUgOWMxLjEgMCAyLS45IDItMnMtLjktMi0yLTItMiAuOS0yIDIgLjkgMiAyIDJ6bTQtN0gxYy0uNTUgMC0xIC40NS0xIDF2MTRjMCAuNTUuNDUgMSAxIDFoMThjLjU1IDAgMS0uNDUgMS0xVjNjMC0uNTUtLjQ1LTEtMS0xem0tMSAxM2wtNi01LTIgMi00LTUtNCA4VjRoMTZ2MTF6XCJcbiAgICAgIC8+XG4gICAgPC9zdmc+XG4gICksXG4gIGV4ZWN1dGU6IChzdGF0ZTogVGV4dFN0YXRlLCBhcGk6IFRleHRBcmVhVGV4dEFwaSkgPT4ge1xuICAgIC8vIFNlbGVjdCBldmVyeXRoaW5nXG4gICAgY29uc3QgbmV3U2VsZWN0aW9uUmFuZ2UgPSBzZWxlY3RXb3JkKHsgdGV4dDogc3RhdGUudGV4dCwgc2VsZWN0aW9uOiBzdGF0ZS5zZWxlY3Rpb24gfSk7XG4gICAgY29uc3Qgc3RhdGUxID0gYXBpLnNldFNlbGVjdGlvblJhbmdlKG5ld1NlbGVjdGlvblJhbmdlKTtcbiAgICAvLyBSZXBsYWNlcyB0aGUgY3VycmVudCBzZWxlY3Rpb24gd2l0aCB0aGUgaW1hZ2VcbiAgICBjb25zdCBpbWFnZVRlbXBsYXRlID0gc3RhdGUxLnNlbGVjdGVkVGV4dCB8fCAnaHR0cHM6Ly9leGFtcGxlLmNvbS95b3VyLWltYWdlLnBuZyc7XG4gICAgYXBpLnJlcGxhY2VTZWxlY3Rpb24oYCFbXSgke2ltYWdlVGVtcGxhdGV9KWApO1xuICAgIC8vIEFkanVzdCB0aGUgc2VsZWN0aW9uIHRvIG5vdCBjb250YWluIHRoZSAqKlxuICAgIGFwaS5zZXRTZWxlY3Rpb25SYW5nZSh7XG4gICAgICBzdGFydDogNCArIHN0YXRlMS5zZWxlY3Rpb24uc3RhcnQsXG4gICAgICBlbmQ6IDQgKyBzdGF0ZTEuc2VsZWN0aW9uLnN0YXJ0ICsgaW1hZ2VUZW1wbGF0ZS5sZW5ndGgsXG4gICAgfSk7XG4gIH0sXG59O1xuIl19
36
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsInNlbGVjdFdvcmQiLCJpbWFnZSIsIm5hbWUiLCJrZXlDb21tYW5kIiwic2hvcnRjdXRzIiwiYnV0dG9uUHJvcHMiLCJ0aXRsZSIsImljb24iLCJleGVjdXRlIiwic3RhdGUiLCJhcGkiLCJuZXdTZWxlY3Rpb25SYW5nZSIsInRleHQiLCJzZWxlY3Rpb24iLCJzdGF0ZTEiLCJzZXRTZWxlY3Rpb25SYW5nZSIsImltYWdlVGVtcGxhdGUiLCJzZWxlY3RlZFRleHQiLCJyZXBsYWNlU2VsZWN0aW9uIiwic3RhcnQiLCJlbmQiLCJsZW5ndGgiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tbWFuZHMvaW1hZ2UudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IElDb21tYW5kLCBUZXh0U3RhdGUsIFRleHRBcmVhVGV4dEFwaSB9IGZyb20gJy4vJztcbmltcG9ydCB7IHNlbGVjdFdvcmQgfSBmcm9tICcuLi91dGlscy9tYXJrZG93blV0aWxzJztcblxuZXhwb3J0IGNvbnN0IGltYWdlOiBJQ29tbWFuZCA9IHtcbiAgbmFtZTogJ2ltYWdlJyxcbiAga2V5Q29tbWFuZDogJ2ltYWdlJyxcbiAgc2hvcnRjdXRzOiAnY3RybGNtZCtpJyxcbiAgYnV0dG9uUHJvcHM6IHsgJ2FyaWEtbGFiZWwnOiAnQWRkIGltYWdlJywgdGl0bGU6ICdBZGQgaW1hZ2UnIH0sXG4gIGljb246IChcbiAgICA8c3ZnIHdpZHRoPVwiMTJcIiBoZWlnaHQ9XCIxMlwiIHZpZXdCb3g9XCIwIDAgMjAgMjBcIj5cbiAgICAgIDxwYXRoXG4gICAgICAgIGZpbGw9XCJjdXJyZW50Q29sb3JcIlxuICAgICAgICBkPVwiTTE1IDljMS4xIDAgMi0uOSAyLTJzLS45LTItMi0yLTIgLjktMiAyIC45IDIgMiAyem00LTdIMWMtLjU1IDAtMSAuNDUtMSAxdjE0YzAgLjU1LjQ1IDEgMSAxaDE4Yy41NSAwIDEtLjQ1IDEtMVYzYzAtLjU1LS40NS0xLTEtMXptLTEgMTNsLTYtNS0yIDItNC01LTQgOFY0aDE2djExelwiXG4gICAgICAvPlxuICAgIDwvc3ZnPlxuICApLFxuICBleGVjdXRlOiAoc3RhdGU6IFRleHRTdGF0ZSwgYXBpOiBUZXh0QXJlYVRleHRBcGkpID0+IHtcbiAgICAvLyBTZWxlY3QgZXZlcnl0aGluZ1xuICAgIGNvbnN0IG5ld1NlbGVjdGlvblJhbmdlID0gc2VsZWN0V29yZCh7IHRleHQ6IHN0YXRlLnRleHQsIHNlbGVjdGlvbjogc3RhdGUuc2VsZWN0aW9uIH0pO1xuICAgIGNvbnN0IHN0YXRlMSA9IGFwaS5zZXRTZWxlY3Rpb25SYW5nZShuZXdTZWxlY3Rpb25SYW5nZSk7XG4gICAgLy8gUmVwbGFjZXMgdGhlIGN1cnJlbnQgc2VsZWN0aW9uIHdpdGggdGhlIGltYWdlXG4gICAgY29uc3QgaW1hZ2VUZW1wbGF0ZSA9IHN0YXRlMS5zZWxlY3RlZFRleHQgfHwgJ2h0dHBzOi8vZXhhbXBsZS5jb20veW91ci1pbWFnZS5wbmcnO1xuICAgIGFwaS5yZXBsYWNlU2VsZWN0aW9uKGAhW10oJHtpbWFnZVRlbXBsYXRlfSlgKTtcbiAgICAvLyBBZGp1c3QgdGhlIHNlbGVjdGlvbiB0byBub3QgY29udGFpbiB0aGUgKipcbiAgICBhcGkuc2V0U2VsZWN0aW9uUmFuZ2Uoe1xuICAgICAgc3RhcnQ6IDQgKyBzdGF0ZTEuc2VsZWN0aW9uLnN0YXJ0LFxuICAgICAgZW5kOiA0ICsgc3RhdGUxLnNlbGVjdGlvbi5zdGFydCArIGltYWdlVGVtcGxhdGUubGVuZ3RoLFxuICAgIH0pO1xuICB9LFxufTtcbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLQSxLQUFLLE1BQU0sT0FBTztBQUU5QixTQUFTQyxVQUFVLFFBQVEsd0JBQXdCO0FBRW5ELE9BQU8sSUFBTUMsS0FBZSxHQUFHO0VBQzdCQyxJQUFJLEVBQUUsT0FBTztFQUNiQyxVQUFVLEVBQUUsT0FBTztFQUNuQkMsU0FBUyxFQUFFLFdBQVc7RUFDdEJDLFdBQVcsRUFBRTtJQUFFLFlBQVksRUFBRSxXQUFXO0lBQUVDLEtBQUssRUFBRTtFQUFZLENBQUM7RUFDOURDLElBQUksZUFDRjtJQUFLLEtBQUssRUFBQyxJQUFJO0lBQUMsTUFBTSxFQUFDLElBQUk7SUFBQyxPQUFPLEVBQUM7RUFBVyxnQkFDN0M7SUFDRSxJQUFJLEVBQUMsY0FBYztJQUNuQixDQUFDLEVBQUM7RUFBa0ssRUFDcEssQ0FFTDtFQUNEQyxPQUFPLEVBQUUsaUJBQUNDLEtBQWdCLEVBQUVDLEdBQW9CLEVBQUs7SUFDbkQ7SUFDQSxJQUFNQyxpQkFBaUIsR0FBR1gsVUFBVSxDQUFDO01BQUVZLElBQUksRUFBRUgsS0FBSyxDQUFDRyxJQUFJO01BQUVDLFNBQVMsRUFBRUosS0FBSyxDQUFDSTtJQUFVLENBQUMsQ0FBQztJQUN0RixJQUFNQyxNQUFNLEdBQUdKLEdBQUcsQ0FBQ0ssaUJBQWlCLENBQUNKLGlCQUFpQixDQUFDO0lBQ3ZEO0lBQ0EsSUFBTUssYUFBYSxHQUFHRixNQUFNLENBQUNHLFlBQVksSUFBSSxvQ0FBb0M7SUFDakZQLEdBQUcsQ0FBQ1EsZ0JBQWdCLGVBQVFGLGFBQWEsT0FBSTtJQUM3QztJQUNBTixHQUFHLENBQUNLLGlCQUFpQixDQUFDO01BQ3BCSSxLQUFLLEVBQUUsQ0FBQyxHQUFHTCxNQUFNLENBQUNELFNBQVMsQ0FBQ00sS0FBSztNQUNqQ0MsR0FBRyxFQUFFLENBQUMsR0FBR04sTUFBTSxDQUFDRCxTQUFTLENBQUNNLEtBQUssR0FBR0gsYUFBYSxDQUFDSztJQUNsRCxDQUFDLENBQUM7RUFDSjtBQUNGLENBQUMifQ==