@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
|
@@ -6,29 +6,24 @@ import Child from './Child';
|
|
|
6
6
|
import "./index.css";
|
|
7
7
|
export function ToolbarItems(props) {
|
|
8
8
|
var prefixCls = props.prefixCls;
|
|
9
|
-
|
|
10
9
|
var _useContext = useContext(EditorContext),
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
10
|
+
fullscreen = _useContext.fullscreen,
|
|
11
|
+
preview = _useContext.preview,
|
|
12
|
+
_useContext$barPopup = _useContext.barPopup,
|
|
13
|
+
barPopup = _useContext$barPopup === void 0 ? {} : _useContext$barPopup,
|
|
14
|
+
commandOrchestrator = _useContext.commandOrchestrator,
|
|
15
|
+
dispatch = _useContext.dispatch;
|
|
18
16
|
function handleClick(command, name) {
|
|
19
17
|
if (!dispatch) return;
|
|
20
18
|
var state = {
|
|
21
19
|
barPopup: _objectSpread({}, barPopup)
|
|
22
20
|
};
|
|
23
|
-
|
|
24
21
|
if (command.keyCommand === 'preview') {
|
|
25
22
|
state.preview = command.value;
|
|
26
23
|
}
|
|
27
|
-
|
|
28
24
|
if (command.keyCommand === 'fullscreen') {
|
|
29
25
|
state.fullscreen = !fullscreen;
|
|
30
26
|
}
|
|
31
|
-
|
|
32
27
|
if (props.commands && command.keyCommand === 'group') {
|
|
33
28
|
props.commands.forEach(function (item) {
|
|
34
29
|
if (name === item.groupName) {
|
|
@@ -42,14 +37,11 @@ export function ToolbarItems(props) {
|
|
|
42
37
|
state.barPopup[keyName] = false;
|
|
43
38
|
});
|
|
44
39
|
}
|
|
45
|
-
|
|
46
40
|
if (Object.keys(state).length) {
|
|
47
41
|
dispatch(_objectSpread({}, state));
|
|
48
42
|
}
|
|
49
|
-
|
|
50
43
|
commandOrchestrator && commandOrchestrator.executeCommand(command);
|
|
51
44
|
}
|
|
52
|
-
|
|
53
45
|
useEffect(function () {
|
|
54
46
|
if (document) {
|
|
55
47
|
document.body.style.overflow = !fullscreen ? 'initial' : 'hidden';
|
|
@@ -63,7 +55,6 @@ export function ToolbarItems(props) {
|
|
|
63
55
|
className: "".concat(prefixCls, "-toolbar-divider")
|
|
64
56
|
}));
|
|
65
57
|
}
|
|
66
|
-
|
|
67
58
|
if (!item.keyCommand) return /*#__PURE__*/React.createElement(Fragment, null);
|
|
68
59
|
var activeBtn = fullscreen && item.keyCommand === 'fullscreen' || item.keyCommand === 'preview' && preview === item.value;
|
|
69
60
|
var childNode = item.children && typeof item.children === 'function' ? item.children({
|
|
@@ -105,14 +96,12 @@ export function ToolbarItems(props) {
|
|
|
105
96
|
export default function Toolbar() {
|
|
106
97
|
var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
107
98
|
var prefixCls = props.prefixCls,
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
99
|
+
_props$height = props.height,
|
|
100
|
+
height = _props$height === void 0 ? 29 : _props$height,
|
|
101
|
+
isChild = props.isChild;
|
|
112
102
|
var _useContext2 = useContext(EditorContext),
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
103
|
+
commands = _useContext2.commands,
|
|
104
|
+
extraCommands = _useContext2.extraCommands;
|
|
116
105
|
return /*#__PURE__*/React.createElement("div", {
|
|
117
106
|
className: "".concat(prefixCls, "-toolbar"),
|
|
118
107
|
style: {
|
|
@@ -124,4 +113,4 @@ export default function Toolbar() {
|
|
|
124
113
|
commands: extraCommands || []
|
|
125
114
|
})));
|
|
126
115
|
}
|
|
127
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Toolbar/index.tsx"],"names":["React","Fragment","useContext","useEffect","EditorContext","Child","ToolbarItems","props","prefixCls","fullscreen","preview","barPopup","commandOrchestrator","dispatch","handleClick","command","name","state","keyCommand","value","commands","forEach","item","groupName","parent","Object","keys","keyName","length","executeCommand","document","body","style","overflow","map","idx","liProps","activeBtn","childNode","children","getState","textApi","undefined","close","execute","disabled","test","buttonProps","icon","createElement","type","onClick","evn","stopPropagation","Array","isArray","Toolbar","height","isChild","extraCommands"],"mappings":"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","sourcesContent":["import React, { Fragment, useContext, useEffect } from 'react';\nimport { IProps } from '../../utils';\nimport { EditorContext, PreviewType, ContextStore } from '../../Context';\nimport { ICommand } from '../../commands';\nimport Child from './Child';\nimport './index.less';\n\nexport interface IToolbarProps extends IProps {\n  height?: React.CSSProperties['height'];\n  onCommand?: (command: ICommand<string>, groupName?: string) => void;\n  commands?: ICommand<string>[];\n  isChild?: boolean;\n}\n\nexport function ToolbarItems(props: IToolbarProps) {\n  const { prefixCls } = props;\n  const { fullscreen, preview, barPopup = {}, commandOrchestrator, dispatch } = useContext(EditorContext);\n  function handleClick(command: ICommand<string>, name?: string) {\n    if (!dispatch) return;\n    const state: ContextStore = { barPopup: { ...barPopup } };\n    if (command.keyCommand === 'preview') {\n      state.preview = command.value as PreviewType;\n    }\n    if (command.keyCommand === 'fullscreen') {\n      state.fullscreen = !fullscreen;\n    }\n    if (props.commands && command.keyCommand === 'group') {\n      props.commands.forEach((item) => {\n        if (name === item.groupName) {\n          state.barPopup![name!] = true;\n        } else if (item.keyCommand) {\n          state.barPopup![item.groupName!] = false;\n        }\n      });\n    } else if (name || command.parent) {\n      Object.keys(state.barPopup || {}).forEach((keyName) => {\n        state.barPopup![keyName] = false;\n      });\n    }\n\n    if (Object.keys(state).length) {\n      dispatch({ ...state });\n    }\n    commandOrchestrator && commandOrchestrator.executeCommand(command);\n  }\n\n  useEffect(() => {\n    if (document) {\n      document.body.style.overflow = !fullscreen ? 'initial' : 'hidden';\n    }\n  }, [fullscreen]);\n\n  return (\n    <ul>\n      {(props.commands || []).map((item, idx) => {\n        if (item.keyCommand === 'divider') {\n          return <li key={idx} {...item.liProps} className={`${prefixCls}-toolbar-divider`} />;\n        }\n        if (!item.keyCommand) return <Fragment />;\n        const activeBtn =\n          (fullscreen && item.keyCommand === 'fullscreen') || (item.keyCommand === 'preview' && preview === item.value);\n        const childNode =\n          item.children && typeof item.children === 'function'\n            ? item.children({\n                getState: () => commandOrchestrator!.getState(),\n                textApi: commandOrchestrator ? commandOrchestrator!.textApi : undefined,\n                close: () => handleClick({}, item.groupName),\n                execute: () => handleClick({ execute: item.execute }),\n              })\n            : undefined;\n        const disabled = barPopup && preview && preview === 'preview' && !/(preview|fullscreen)/.test(item.keyCommand);\n        return (\n          <li key={idx} {...item.liProps} className={activeBtn ? `active` : ''}>\n            {!item.buttonProps && item.icon}\n            {item.buttonProps &&\n              React.createElement(\n                'button',\n                {\n                  type: 'button',\n                  disabled,\n                  'data-name': item.name,\n                  ...item.buttonProps,\n                  onClick: (evn: React.MouseEvent<HTMLButtonElement, MouseEvent>) => {\n                    evn.stopPropagation();\n                    handleClick(item, item.groupName);\n                  },\n                },\n                item.icon,\n              )}\n            {item.children && (\n              <Child\n                groupName={item.groupName}\n                prefixCls={prefixCls}\n                children={childNode}\n                commands={Array.isArray(item.children) ? item.children : undefined}\n              />\n            )}\n          </li>\n        );\n      })}\n    </ul>\n  );\n}\n\nexport default function Toolbar(props: IToolbarProps = {}) {\n  const { prefixCls, height = 29, isChild } = props;\n  const { commands, extraCommands } = useContext(EditorContext);\n  return (\n    <div className={`${prefixCls}-toolbar`} style={{ height }}>\n      <ToolbarItems {...props} commands={props.commands || commands || []} />\n      {!isChild && <ToolbarItems {...props} commands={extraCommands || []} />}\n    </div>\n  );\n}\n"]}
|
|
116
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","Fragment","useContext","useEffect","EditorContext","Child","ToolbarItems","props","prefixCls","fullscreen","preview","barPopup","commandOrchestrator","dispatch","handleClick","command","name","state","keyCommand","value","commands","forEach","item","groupName","parent","Object","keys","keyName","length","executeCommand","document","body","style","overflow","map","idx","liProps","activeBtn","childNode","children","getState","textApi","undefined","close","execute","disabled","test","buttonProps","icon","createElement","type","onClick","evn","stopPropagation","Array","isArray","Toolbar","height","isChild","extraCommands"],"sources":["../../../../src/components/Toolbar/index.tsx"],"sourcesContent":["import React, { Fragment, useContext, useEffect } from 'react';\nimport { IProps } from '../../utils';\nimport { EditorContext, PreviewType, ContextStore } from '../../Context';\nimport { ICommand } from '../../commands';\nimport Child from './Child';\nimport './index.less';\n\nexport interface IToolbarProps extends IProps {\n  height?: React.CSSProperties['height'];\n  onCommand?: (command: ICommand<string>, groupName?: string) => void;\n  commands?: ICommand<string>[];\n  isChild?: boolean;\n}\n\nexport function ToolbarItems(props: IToolbarProps) {\n  const { prefixCls } = props;\n  const { fullscreen, preview, barPopup = {}, commandOrchestrator, dispatch } = useContext(EditorContext);\n  function handleClick(command: ICommand<string>, name?: string) {\n    if (!dispatch) return;\n    const state: ContextStore = { barPopup: { ...barPopup } };\n    if (command.keyCommand === 'preview') {\n      state.preview = command.value as PreviewType;\n    }\n    if (command.keyCommand === 'fullscreen') {\n      state.fullscreen = !fullscreen;\n    }\n    if (props.commands && command.keyCommand === 'group') {\n      props.commands.forEach((item) => {\n        if (name === item.groupName) {\n          state.barPopup![name!] = true;\n        } else if (item.keyCommand) {\n          state.barPopup![item.groupName!] = false;\n        }\n      });\n    } else if (name || command.parent) {\n      Object.keys(state.barPopup || {}).forEach((keyName) => {\n        state.barPopup![keyName] = false;\n      });\n    }\n\n    if (Object.keys(state).length) {\n      dispatch({ ...state });\n    }\n    commandOrchestrator && commandOrchestrator.executeCommand(command);\n  }\n\n  useEffect(() => {\n    if (document) {\n      document.body.style.overflow = !fullscreen ? 'initial' : 'hidden';\n    }\n  }, [fullscreen]);\n\n  return (\n    <ul>\n      {(props.commands || []).map((item, idx) => {\n        if (item.keyCommand === 'divider') {\n          return <li key={idx} {...item.liProps} className={`${prefixCls}-toolbar-divider`} />;\n        }\n        if (!item.keyCommand) return <Fragment />;\n        const activeBtn =\n          (fullscreen && item.keyCommand === 'fullscreen') || (item.keyCommand === 'preview' && preview === item.value);\n        const childNode =\n          item.children && typeof item.children === 'function'\n            ? item.children({\n                getState: () => commandOrchestrator!.getState(),\n                textApi: commandOrchestrator ? commandOrchestrator!.textApi : undefined,\n                close: () => handleClick({}, item.groupName),\n                execute: () => handleClick({ execute: item.execute }),\n              })\n            : undefined;\n        const disabled = barPopup && preview && preview === 'preview' && !/(preview|fullscreen)/.test(item.keyCommand);\n        return (\n          <li key={idx} {...item.liProps} className={activeBtn ? `active` : ''}>\n            {!item.buttonProps && item.icon}\n            {item.buttonProps &&\n              React.createElement(\n                'button',\n                {\n                  type: 'button',\n                  disabled,\n                  'data-name': item.name,\n                  ...item.buttonProps,\n                  onClick: (evn: React.MouseEvent<HTMLButtonElement, MouseEvent>) => {\n                    evn.stopPropagation();\n                    handleClick(item, item.groupName);\n                  },\n                },\n                item.icon,\n              )}\n            {item.children && (\n              <Child\n                groupName={item.groupName}\n                prefixCls={prefixCls}\n                children={childNode}\n                commands={Array.isArray(item.children) ? item.children : undefined}\n              />\n            )}\n          </li>\n        );\n      })}\n    </ul>\n  );\n}\n\nexport default function Toolbar(props: IToolbarProps = {}) {\n  const { prefixCls, height = 29, isChild } = props;\n  const { commands, extraCommands } = useContext(EditorContext);\n  return (\n    <div className={`${prefixCls}-toolbar`} style={{ height }}>\n      <ToolbarItems {...props} commands={props.commands || commands || []} />\n      {!isChild && <ToolbarItems {...props} commands={extraCommands || []} />}\n    </div>\n  );\n}\n"],"mappings":"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"}
|
package/lib/esm/index.js
CHANGED
|
@@ -7,4 +7,4 @@ export * from './Editor';
|
|
|
7
7
|
export * from './Context';
|
|
8
8
|
export { MarkdownUtil, commands };
|
|
9
9
|
export default MDEditor;
|
|
10
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJNREVkaXRvciIsImNvbW1hbmRzIiwiTWFya2Rvd25VdGlsIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2luZGV4LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgTURFZGl0b3IgZnJvbSAnLi9FZGl0b3InO1xuaW1wb3J0ICogYXMgY29tbWFuZHMgZnJvbSAnLi9jb21tYW5kcyc7XG5pbXBvcnQgKiBhcyBNYXJrZG93blV0aWwgZnJvbSAnLi91dGlscy9tYXJrZG93blV0aWxzJztcblxuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcyc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzL21hcmtkb3duVXRpbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9FZGl0b3InO1xuZXhwb3J0ICogZnJvbSAnLi9Db250ZXh0JztcblxuZXhwb3J0IHsgTWFya2Rvd25VdGlsLCBjb21tYW5kcyB9O1xuXG5leHBvcnQgZGVmYXVsdCBNREVkaXRvcjtcbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsUUFBUSxNQUFNLFVBQVU7QUFDL0IsT0FBTyxLQUFLQyxRQUFRLE1BQU0sWUFBWTtBQUN0QyxPQUFPLEtBQUtDLFlBQVksTUFBTSx1QkFBdUI7QUFFckQsY0FBYyxZQUFZO0FBQzFCLGNBQWMsdUJBQXVCO0FBQ3JDLGNBQWMsVUFBVTtBQUN4QixjQUFjLFdBQVc7QUFFekIsU0FBU0EsWUFBWSxFQUFFRCxRQUFRO0FBRS9CLGVBQWVELFFBQVEifQ==
|
|
@@ -3,64 +3,61 @@
|
|
|
3
3
|
* Copyright (c) 2018 Dmitriy Kubyshkin
|
|
4
4
|
* Copied from https://github.com/grassator/insert-text-at-cursor
|
|
5
5
|
*/
|
|
6
|
+
|
|
6
7
|
var browserSupportsTextareaTextNodes;
|
|
8
|
+
|
|
7
9
|
/**
|
|
8
10
|
* @param {HTMLElement} input
|
|
9
11
|
* @return {boolean}
|
|
10
12
|
*/
|
|
11
|
-
|
|
12
13
|
function canManipulateViaTextNodes(input) {
|
|
13
14
|
if (input.nodeName !== 'TEXTAREA') {
|
|
14
15
|
return false;
|
|
15
16
|
}
|
|
16
|
-
|
|
17
17
|
if (typeof browserSupportsTextareaTextNodes === 'undefined') {
|
|
18
18
|
var textarea = document.createElement('textarea');
|
|
19
19
|
textarea.value = '1';
|
|
20
20
|
browserSupportsTextareaTextNodes = !!textarea.firstChild;
|
|
21
21
|
}
|
|
22
|
-
|
|
23
22
|
return browserSupportsTextareaTextNodes;
|
|
24
23
|
}
|
|
24
|
+
|
|
25
25
|
/**
|
|
26
26
|
* @param {HTMLTextAreaElement|HTMLInputElement} input
|
|
27
27
|
* @param {string} text
|
|
28
28
|
* @returns {void}
|
|
29
29
|
*/
|
|
30
|
-
|
|
31
|
-
|
|
32
30
|
export default function insertTextAtPosition(input, text) {
|
|
33
31
|
// Most of the used APIs only work with the field selected
|
|
34
|
-
input.focus();
|
|
32
|
+
input.focus();
|
|
35
33
|
|
|
34
|
+
// IE 8-10
|
|
36
35
|
if (document.selection) {
|
|
37
36
|
var ieRange = document.selection.createRange();
|
|
38
|
-
ieRange.text = text;
|
|
37
|
+
ieRange.text = text;
|
|
39
38
|
|
|
40
|
-
|
|
41
|
-
/* to the end */
|
|
42
|
-
);
|
|
39
|
+
// Move cursor after the inserted text
|
|
40
|
+
ieRange.collapse(false /* to the end */);
|
|
43
41
|
ieRange.select();
|
|
44
42
|
return;
|
|
45
|
-
}
|
|
46
|
-
|
|
43
|
+
}
|
|
47
44
|
|
|
45
|
+
// Webkit + Edge
|
|
48
46
|
var isSuccess = document.execCommand('insertText', false, text);
|
|
49
|
-
|
|
50
47
|
if (!isSuccess) {
|
|
51
48
|
var start = input.selectionStart;
|
|
52
|
-
var end = input.selectionEnd;
|
|
53
|
-
|
|
49
|
+
var end = input.selectionEnd;
|
|
50
|
+
// Firefox (non-standard method)
|
|
54
51
|
if (typeof input.setRangeText === 'function') {
|
|
55
52
|
input.setRangeText(text);
|
|
56
53
|
} else {
|
|
57
54
|
// To make a change we just need a Range, not a Selection
|
|
58
55
|
var range = document.createRange();
|
|
59
56
|
var textNode = document.createTextNode(text);
|
|
60
|
-
|
|
61
57
|
if (canManipulateViaTextNodes(input)) {
|
|
62
|
-
var node = input.firstChild;
|
|
58
|
+
var node = input.firstChild;
|
|
63
59
|
|
|
60
|
+
// If textarea is empty, just insert the text
|
|
64
61
|
if (!node) {
|
|
65
62
|
input.appendChild(textNode);
|
|
66
63
|
} else {
|
|
@@ -68,35 +65,34 @@ export default function insertTextAtPosition(input, text) {
|
|
|
68
65
|
var offset = 0;
|
|
69
66
|
var startNode = null;
|
|
70
67
|
var endNode = null;
|
|
71
|
-
|
|
72
68
|
while (node && (startNode === null || endNode === null)) {
|
|
73
|
-
var nodeLength = node.nodeValue.length;
|
|
69
|
+
var nodeLength = node.nodeValue.length;
|
|
74
70
|
|
|
71
|
+
// if start of the selection falls into current node
|
|
75
72
|
if (start >= offset && start <= offset + nodeLength) {
|
|
76
73
|
range.setStart(startNode = node, start - offset);
|
|
77
|
-
}
|
|
78
|
-
|
|
74
|
+
}
|
|
79
75
|
|
|
76
|
+
// if end of the selection falls into current node
|
|
80
77
|
if (end >= offset && end <= offset + nodeLength) {
|
|
81
78
|
range.setEnd(endNode = node, end - offset);
|
|
82
79
|
}
|
|
83
|
-
|
|
84
80
|
offset += nodeLength;
|
|
85
81
|
node = node.nextSibling;
|
|
86
|
-
}
|
|
87
|
-
|
|
82
|
+
}
|
|
88
83
|
|
|
84
|
+
// If there is some text selected, remove it as we should replace it
|
|
89
85
|
if (start !== end) {
|
|
90
86
|
range.deleteContents();
|
|
91
87
|
}
|
|
92
88
|
}
|
|
93
|
-
}
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
// If the node is a textarea and the range doesn't span outside the element
|
|
94
92
|
//
|
|
95
93
|
// Get the commonAncestorContainer of the selected range and test its type
|
|
96
94
|
// If the node is of type `#text` it means that we're still working with text nodes within our textarea element
|
|
97
95
|
// otherwise, if it's of type `#document` for example it means our selection spans outside the textarea.
|
|
98
|
-
|
|
99
|
-
|
|
100
96
|
if (canManipulateViaTextNodes(input) && range.commonAncestorContainer.nodeName === '#text') {
|
|
101
97
|
// Finally insert a new node. The browser will automatically split start and end nodes into two if necessary
|
|
102
98
|
range.insertNode(textNode);
|
|
@@ -105,14 +101,15 @@ export default function insertTextAtPosition(input, text) {
|
|
|
105
101
|
var value = input.value;
|
|
106
102
|
input.value = value.slice(0, start) + text + value.slice(end);
|
|
107
103
|
}
|
|
108
|
-
}
|
|
109
|
-
|
|
104
|
+
}
|
|
110
105
|
|
|
111
|
-
|
|
106
|
+
// Correct the cursor position to be at the end of the insertion
|
|
107
|
+
input.setSelectionRange(start + text.length, start + text.length);
|
|
112
108
|
|
|
109
|
+
// Notify any possible listeners of the change
|
|
113
110
|
var e = document.createEvent('UIEvent');
|
|
114
111
|
e.initEvent('input', true, false);
|
|
115
112
|
input.dispatchEvent(e);
|
|
116
113
|
}
|
|
117
114
|
}
|
|
118
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/utils/InsertTextAtPosition.ts"],"names":["browserSupportsTextareaTextNodes","canManipulateViaTextNodes","input","nodeName","textarea","document","createElement","value","firstChild","insertTextAtPosition","text","focus","selection","ieRange","createRange","collapse","select","isSuccess","execCommand","start","selectionStart","end","selectionEnd","setRangeText","range","textNode","createTextNode","node","appendChild","offset","startNode","endNode","nodeLength","nodeValue","length","setStart","setEnd","nextSibling","deleteContents","commonAncestorContainer","insertNode","slice","setSelectionRange","e","createEvent","initEvent","dispatchEvent"],"mappings":"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","sourcesContent":["/**\n * The MIT License\n * Copyright (c) 2018 Dmitriy Kubyshkin\n * Copied from https://github.com/grassator/insert-text-at-cursor\n */\n\nlet browserSupportsTextareaTextNodes: any;\n\n/**\n * @param {HTMLElement} input\n * @return {boolean}\n */\nfunction canManipulateViaTextNodes(input: HTMLTextAreaElement | HTMLInputElement) {\n  if (input.nodeName !== 'TEXTAREA') {\n    return false;\n  }\n  if (typeof browserSupportsTextareaTextNodes === 'undefined') {\n    const textarea: HTMLTextAreaElement = document.createElement('textarea');\n    textarea.value = '1';\n    browserSupportsTextareaTextNodes = !!textarea.firstChild;\n  }\n  return browserSupportsTextareaTextNodes;\n}\n\n/**\n * @param {HTMLTextAreaElement|HTMLInputElement} input\n * @param {string} text\n * @returns {void}\n */\nexport default function insertTextAtPosition(input: HTMLTextAreaElement | HTMLInputElement, text: string) {\n  // Most of the used APIs only work with the field selected\n  input.focus();\n\n  // IE 8-10\n  if ((document as any).selection) {\n    const ieRange = (document as any).selection.createRange();\n    ieRange.text = text;\n\n    // Move cursor after the inserted text\n    ieRange.collapse(false /* to the end */);\n    ieRange.select();\n\n    return;\n  }\n\n  // Webkit + Edge\n  const isSuccess = document.execCommand('insertText', false, text);\n  if (!isSuccess) {\n    const start = input.selectionStart!;\n    const end = input.selectionEnd!;\n    // Firefox (non-standard method)\n    if (typeof input.setRangeText === 'function') {\n      input.setRangeText(text);\n    } else {\n      // To make a change we just need a Range, not a Selection\n      const range = document.createRange();\n      const textNode = document.createTextNode(text);\n\n      if (canManipulateViaTextNodes(input)) {\n        let node = input.firstChild;\n\n        // If textarea is empty, just insert the text\n        if (!node) {\n          input.appendChild(textNode);\n        } else {\n          // Otherwise we need to find a nodes for start and end\n          let offset = 0;\n          let startNode = null;\n          let endNode = null;\n\n          while (node && (startNode === null || endNode === null)) {\n            const nodeLength = node.nodeValue!.length;\n\n            // if start of the selection falls into current node\n            if (start >= offset && start <= offset + nodeLength) {\n              range.setStart((startNode = node), start - offset);\n            }\n\n            // if end of the selection falls into current node\n            if (end >= offset && end <= offset + nodeLength) {\n              range.setEnd((endNode = node), end - offset);\n            }\n\n            offset += nodeLength;\n            node = node.nextSibling;\n          }\n\n          // If there is some text selected, remove it as we should replace it\n          if (start !== end) {\n            range.deleteContents();\n          }\n        }\n      }\n\n      // If the node is a textarea and the range doesn't span outside the element\n      //\n      // Get the commonAncestorContainer of the selected range and test its type\n      // If the node is of type `#text` it means that we're still working with text nodes within our textarea element\n      // otherwise, if it's of type `#document` for example it means our selection spans outside the textarea.\n      if (canManipulateViaTextNodes(input) && range.commonAncestorContainer.nodeName === '#text') {\n        // Finally insert a new node. The browser will automatically split start and end nodes into two if necessary\n        range.insertNode(textNode);\n      } else {\n        // If the node is not a textarea or the range spans outside a textarea the only way is to replace the whole value\n        const value = input.value;\n        input.value = value.slice(0, start) + text + value.slice(end);\n      }\n    }\n\n    // Correct the cursor position to be at the end of the insertion\n    input.setSelectionRange(start + text.length, start + text.length);\n\n    // Notify any possible listeners of the change\n    const e = document.createEvent('UIEvent');\n    e.initEvent('input', true, false);\n    input.dispatchEvent(e);\n  }\n}\n"]}
|
|
115
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["browserSupportsTextareaTextNodes","canManipulateViaTextNodes","input","nodeName","textarea","document","createElement","value","firstChild","insertTextAtPosition","text","focus","selection","ieRange","createRange","collapse","select","isSuccess","execCommand","start","selectionStart","end","selectionEnd","setRangeText","range","textNode","createTextNode","node","appendChild","offset","startNode","endNode","nodeLength","nodeValue","length","setStart","setEnd","nextSibling","deleteContents","commonAncestorContainer","insertNode","slice","setSelectionRange","e","createEvent","initEvent","dispatchEvent"],"sources":["../../../src/utils/InsertTextAtPosition.ts"],"sourcesContent":["/**\n * The MIT License\n * Copyright (c) 2018 Dmitriy Kubyshkin\n * Copied from https://github.com/grassator/insert-text-at-cursor\n */\n\nlet browserSupportsTextareaTextNodes: any;\n\n/**\n * @param {HTMLElement} input\n * @return {boolean}\n */\nfunction canManipulateViaTextNodes(input: HTMLTextAreaElement | HTMLInputElement) {\n  if (input.nodeName !== 'TEXTAREA') {\n    return false;\n  }\n  if (typeof browserSupportsTextareaTextNodes === 'undefined') {\n    const textarea: HTMLTextAreaElement = document.createElement('textarea');\n    textarea.value = '1';\n    browserSupportsTextareaTextNodes = !!textarea.firstChild;\n  }\n  return browserSupportsTextareaTextNodes;\n}\n\n/**\n * @param {HTMLTextAreaElement|HTMLInputElement} input\n * @param {string} text\n * @returns {void}\n */\nexport default function insertTextAtPosition(input: HTMLTextAreaElement | HTMLInputElement, text: string) {\n  // Most of the used APIs only work with the field selected\n  input.focus();\n\n  // IE 8-10\n  if ((document as any).selection) {\n    const ieRange = (document as any).selection.createRange();\n    ieRange.text = text;\n\n    // Move cursor after the inserted text\n    ieRange.collapse(false /* to the end */);\n    ieRange.select();\n\n    return;\n  }\n\n  // Webkit + Edge\n  const isSuccess = document.execCommand('insertText', false, text);\n  if (!isSuccess) {\n    const start = input.selectionStart!;\n    const end = input.selectionEnd!;\n    // Firefox (non-standard method)\n    if (typeof input.setRangeText === 'function') {\n      input.setRangeText(text);\n    } else {\n      // To make a change we just need a Range, not a Selection\n      const range = document.createRange();\n      const textNode = document.createTextNode(text);\n\n      if (canManipulateViaTextNodes(input)) {\n        let node = input.firstChild;\n\n        // If textarea is empty, just insert the text\n        if (!node) {\n          input.appendChild(textNode);\n        } else {\n          // Otherwise we need to find a nodes for start and end\n          let offset = 0;\n          let startNode = null;\n          let endNode = null;\n\n          while (node && (startNode === null || endNode === null)) {\n            const nodeLength = node.nodeValue!.length;\n\n            // if start of the selection falls into current node\n            if (start >= offset && start <= offset + nodeLength) {\n              range.setStart((startNode = node), start - offset);\n            }\n\n            // if end of the selection falls into current node\n            if (end >= offset && end <= offset + nodeLength) {\n              range.setEnd((endNode = node), end - offset);\n            }\n\n            offset += nodeLength;\n            node = node.nextSibling;\n          }\n\n          // If there is some text selected, remove it as we should replace it\n          if (start !== end) {\n            range.deleteContents();\n          }\n        }\n      }\n\n      // If the node is a textarea and the range doesn't span outside the element\n      //\n      // Get the commonAncestorContainer of the selected range and test its type\n      // If the node is of type `#text` it means that we're still working with text nodes within our textarea element\n      // otherwise, if it's of type `#document` for example it means our selection spans outside the textarea.\n      if (canManipulateViaTextNodes(input) && range.commonAncestorContainer.nodeName === '#text') {\n        // Finally insert a new node. The browser will automatically split start and end nodes into two if necessary\n        range.insertNode(textNode);\n      } else {\n        // If the node is not a textarea or the range spans outside a textarea the only way is to replace the whole value\n        const value = input.value;\n        input.value = value.slice(0, start) + text + value.slice(end);\n      }\n    }\n\n    // Correct the cursor position to be at the end of the insertion\n    input.setSelectionRange(start + text.length, start + text.length);\n\n    // Notify any possible listeners of the change\n    const e = document.createEvent('UIEvent');\n    e.initEvent('input', true, false);\n    input.dispatchEvent(e);\n  }\n}\n"],"mappings":"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"}
|
|
@@ -1,33 +1,32 @@
|
|
|
1
1
|
export default function getSurroundingWord(text, position) {
|
|
2
2
|
if (!text) throw Error("Argument 'text' should be truthy");
|
|
3
|
-
|
|
4
3
|
var isWordDelimiter = function isWordDelimiter(c) {
|
|
5
4
|
return c === ' ' || c.charCodeAt(0) === 10;
|
|
6
|
-
};
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
var start = 0; // rightIndex is initialized to text.length because if selection is equal to text.length it won't even enter the interation
|
|
5
|
+
};
|
|
10
6
|
|
|
11
|
-
|
|
7
|
+
// leftIndex is initialized to 0 because if selection is 0, it won't even enter the iteration
|
|
8
|
+
var start = 0;
|
|
9
|
+
// rightIndex is initialized to text.length because if selection is equal to text.length it won't even enter the interation
|
|
10
|
+
var end = text.length;
|
|
12
11
|
|
|
12
|
+
// iterate to the left
|
|
13
13
|
for (var i = position; i - 1 > -1; i--) {
|
|
14
14
|
if (isWordDelimiter(text[i - 1])) {
|
|
15
15
|
start = i;
|
|
16
16
|
break;
|
|
17
17
|
}
|
|
18
|
-
}
|
|
19
|
-
|
|
18
|
+
}
|
|
20
19
|
|
|
20
|
+
// iterate to the right
|
|
21
21
|
for (var _i = position; _i < text.length; _i++) {
|
|
22
22
|
if (isWordDelimiter(text[_i])) {
|
|
23
23
|
end = _i;
|
|
24
24
|
break;
|
|
25
25
|
}
|
|
26
26
|
}
|
|
27
|
-
|
|
28
27
|
return {
|
|
29
28
|
start: start,
|
|
30
29
|
end: end
|
|
31
30
|
};
|
|
32
31
|
}
|
|
33
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
32
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJnZXRTdXJyb3VuZGluZ1dvcmQiLCJ0ZXh0IiwicG9zaXRpb24iLCJFcnJvciIsImlzV29yZERlbGltaXRlciIsImMiLCJjaGFyQ29kZUF0Iiwic3RhcnQiLCJlbmQiLCJsZW5ndGgiLCJpIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3V0aWxzL2dldFN1cnJvdW5kaW5nV29yZC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUZXh0UmFuZ2UgfSBmcm9tICcuLi9jb21tYW5kcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGdldFN1cnJvdW5kaW5nV29yZCh0ZXh0OiBzdHJpbmcsIHBvc2l0aW9uOiBudW1iZXIpOiBUZXh0UmFuZ2Uge1xuICBpZiAoIXRleHQpIHRocm93IEVycm9yKFwiQXJndW1lbnQgJ3RleHQnIHNob3VsZCBiZSB0cnV0aHlcIik7XG5cbiAgY29uc3QgaXNXb3JkRGVsaW1pdGVyID0gKGM6IHN0cmluZykgPT4gYyA9PT0gJyAnIHx8IGMuY2hhckNvZGVBdCgwKSA9PT0gMTA7XG5cbiAgLy8gbGVmdEluZGV4IGlzIGluaXRpYWxpemVkIHRvIDAgYmVjYXVzZSBpZiBzZWxlY3Rpb24gaXMgMCwgaXQgd29uJ3QgZXZlbiBlbnRlciB0aGUgaXRlcmF0aW9uXG4gIGxldCBzdGFydCA9IDA7XG4gIC8vIHJpZ2h0SW5kZXggaXMgaW5pdGlhbGl6ZWQgdG8gdGV4dC5sZW5ndGggYmVjYXVzZSBpZiBzZWxlY3Rpb24gaXMgZXF1YWwgdG8gdGV4dC5sZW5ndGggaXQgd29uJ3QgZXZlbiBlbnRlciB0aGUgaW50ZXJhdGlvblxuICBsZXQgZW5kID0gdGV4dC5sZW5ndGg7XG5cbiAgLy8gaXRlcmF0ZSB0byB0aGUgbGVmdFxuICBmb3IgKGxldCBpID0gcG9zaXRpb247IGkgLSAxID4gLTE7IGktLSkge1xuICAgIGlmIChpc1dvcmREZWxpbWl0ZXIodGV4dFtpIC0gMV0pKSB7XG4gICAgICBzdGFydCA9IGk7XG4gICAgICBicmVhaztcbiAgICB9XG4gIH1cblxuICAvLyBpdGVyYXRlIHRvIHRoZSByaWdodFxuICBmb3IgKGxldCBpID0gcG9zaXRpb247IGkgPCB0ZXh0Lmxlbmd0aDsgaSsrKSB7XG4gICAgaWYgKGlzV29yZERlbGltaXRlcih0ZXh0W2ldKSkge1xuICAgICAgZW5kID0gaTtcbiAgICAgIGJyZWFrO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiB7IHN0YXJ0LCBlbmQgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBRUEsZUFBZSxTQUFTQSxrQkFBa0IsQ0FBQ0MsSUFBWSxFQUFFQyxRQUFnQixFQUFhO0VBQ3BGLElBQUksQ0FBQ0QsSUFBSSxFQUFFLE1BQU1FLEtBQUssQ0FBQyxrQ0FBa0MsQ0FBQztFQUUxRCxJQUFNQyxlQUFlLEdBQUcsU0FBbEJBLGVBQWUsQ0FBSUMsQ0FBUztJQUFBLE9BQUtBLENBQUMsS0FBSyxHQUFHLElBQUlBLENBQUMsQ0FBQ0MsVUFBVSxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUU7RUFBQTs7RUFFMUU7RUFDQSxJQUFJQyxLQUFLLEdBQUcsQ0FBQztFQUNiO0VBQ0EsSUFBSUMsR0FBRyxHQUFHUCxJQUFJLENBQUNRLE1BQU07O0VBRXJCO0VBQ0EsS0FBSyxJQUFJQyxDQUFDLEdBQUdSLFFBQVEsRUFBRVEsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRUEsQ0FBQyxFQUFFLEVBQUU7SUFDdEMsSUFBSU4sZUFBZSxDQUFDSCxJQUFJLENBQUNTLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFO01BQ2hDSCxLQUFLLEdBQUdHLENBQUM7TUFDVDtJQUNGO0VBQ0Y7O0VBRUE7RUFDQSxLQUFLLElBQUlBLEVBQUMsR0FBR1IsUUFBUSxFQUFFUSxFQUFDLEdBQUdULElBQUksQ0FBQ1EsTUFBTSxFQUFFQyxFQUFDLEVBQUUsRUFBRTtJQUMzQyxJQUFJTixlQUFlLENBQUNILElBQUksQ0FBQ1MsRUFBQyxDQUFDLENBQUMsRUFBRTtNQUM1QkYsR0FBRyxHQUFHRSxFQUFDO01BQ1A7SUFDRjtFQUNGO0VBRUEsT0FBTztJQUFFSCxLQUFLLEVBQUxBLEtBQUs7SUFBRUMsR0FBRyxFQUFIQTtFQUFJLENBQUM7QUFDdkIifQ==
|
package/lib/esm/utils/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3V0aWxzL2luZGV4LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgSVByb3BzIHtcbiAgcHJlZml4Q2xzPzogc3RyaW5nO1xuICBjbGFzc05hbWU/OiBzdHJpbmc7XG59XG4iXSwibWFwcGluZ3MiOiIifQ==
|
|
@@ -1,83 +1,77 @@
|
|
|
1
1
|
import getSurroundingWord from './getSurroundingWord';
|
|
2
2
|
export function selectWord(_ref) {
|
|
3
3
|
var text = _ref.text,
|
|
4
|
-
|
|
5
|
-
|
|
4
|
+
selection = _ref.selection;
|
|
6
5
|
if (text && text.length && selection.start === selection.end) {
|
|
7
6
|
// the user is pointing to a word
|
|
8
7
|
return getSurroundingWord(text, selection.start);
|
|
9
8
|
}
|
|
10
|
-
|
|
11
9
|
return selection;
|
|
12
10
|
}
|
|
11
|
+
|
|
13
12
|
/**
|
|
14
13
|
* Gets the number of line-breaks that would have to be inserted before the given 'startPosition'
|
|
15
14
|
* to make sure there's an empty line between 'startPosition' and the previous text
|
|
16
15
|
*/
|
|
17
|
-
|
|
18
16
|
export function getBreaksNeededForEmptyLineBefore() {
|
|
19
17
|
var text = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
|
|
20
18
|
var startPosition = arguments.length > 1 ? arguments[1] : undefined;
|
|
21
|
-
if (startPosition === 0) return 0;
|
|
19
|
+
if (startPosition === 0) return 0;
|
|
20
|
+
|
|
21
|
+
// rules:
|
|
22
22
|
// - If we're in the first line, no breaks are needed
|
|
23
23
|
// - Otherwise there must be 2 breaks before the previous character. Depending on how many breaks exist already, we
|
|
24
24
|
// may need to insert 0, 1 or 2 breaks
|
|
25
25
|
|
|
26
26
|
var neededBreaks = 2;
|
|
27
27
|
var isInFirstLine = true;
|
|
28
|
-
|
|
29
28
|
for (var i = startPosition - 1; i >= 0 && neededBreaks >= 0; i--) {
|
|
30
29
|
switch (text.charCodeAt(i)) {
|
|
31
30
|
case 32:
|
|
32
31
|
// blank space
|
|
33
32
|
continue;
|
|
34
|
-
|
|
35
33
|
case 10:
|
|
36
34
|
// line break
|
|
37
35
|
neededBreaks--;
|
|
38
36
|
isInFirstLine = false;
|
|
39
37
|
break;
|
|
40
|
-
|
|
41
38
|
default:
|
|
42
39
|
return neededBreaks;
|
|
43
40
|
}
|
|
44
41
|
}
|
|
45
|
-
|
|
46
42
|
return isInFirstLine ? 0 : neededBreaks;
|
|
47
43
|
}
|
|
44
|
+
|
|
48
45
|
/**
|
|
49
46
|
* Gets the number of line-breaks that would have to be inserted after the given 'startPosition'
|
|
50
47
|
* to make sure there's an empty line between 'startPosition' and the next text
|
|
51
48
|
*/
|
|
52
|
-
|
|
53
49
|
export function getBreaksNeededForEmptyLineAfter() {
|
|
54
50
|
var text = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
|
|
55
51
|
var startPosition = arguments.length > 1 ? arguments[1] : undefined;
|
|
56
|
-
if (startPosition === text.length - 1) return 0;
|
|
52
|
+
if (startPosition === text.length - 1) return 0;
|
|
53
|
+
|
|
54
|
+
// rules:
|
|
57
55
|
// - If we're in the first line, no breaks are needed
|
|
58
56
|
// - Otherwise there must be 2 breaks before the previous character. Depending on how many breaks exist already, we
|
|
59
57
|
// may need to insert 0, 1 or 2 breaks
|
|
60
58
|
|
|
61
59
|
var neededBreaks = 2;
|
|
62
60
|
var isInLastLine = true;
|
|
63
|
-
|
|
64
61
|
for (var i = startPosition; i < text.length && neededBreaks >= 0; i++) {
|
|
65
62
|
switch (text.charCodeAt(i)) {
|
|
66
63
|
case 32:
|
|
67
64
|
continue;
|
|
68
|
-
|
|
69
65
|
case 10:
|
|
70
66
|
{
|
|
71
67
|
neededBreaks--;
|
|
72
68
|
isInLastLine = false;
|
|
73
69
|
break;
|
|
74
70
|
}
|
|
75
|
-
|
|
76
71
|
default:
|
|
77
72
|
return neededBreaks;
|
|
78
73
|
}
|
|
79
74
|
}
|
|
80
|
-
|
|
81
75
|
return isInLastLine ? 0 : neededBreaks;
|
|
82
76
|
}
|
|
83
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
77
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJnZXRTdXJyb3VuZGluZ1dvcmQiLCJzZWxlY3RXb3JkIiwidGV4dCIsInNlbGVjdGlvbiIsImxlbmd0aCIsInN0YXJ0IiwiZW5kIiwiZ2V0QnJlYWtzTmVlZGVkRm9yRW1wdHlMaW5lQmVmb3JlIiwic3RhcnRQb3NpdGlvbiIsIm5lZWRlZEJyZWFrcyIsImlzSW5GaXJzdExpbmUiLCJpIiwiY2hhckNvZGVBdCIsImdldEJyZWFrc05lZWRlZEZvckVtcHR5TGluZUFmdGVyIiwiaXNJbkxhc3RMaW5lIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3V0aWxzL21hcmtkb3duVXRpbHMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGV4dFJhbmdlIH0gZnJvbSAnLi4vY29tbWFuZHMnO1xuaW1wb3J0IGdldFN1cnJvdW5kaW5nV29yZCBmcm9tICcuL2dldFN1cnJvdW5kaW5nV29yZCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGV4dFNlY3Rpb24ge1xuICB0ZXh0OiBzdHJpbmc7XG4gIHNlbGVjdGlvbjogVGV4dFJhbmdlO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc2VsZWN0V29yZCh7IHRleHQsIHNlbGVjdGlvbiB9OiBUZXh0U2VjdGlvbik6IFRleHRSYW5nZSB7XG4gIGlmICh0ZXh0ICYmIHRleHQubGVuZ3RoICYmIHNlbGVjdGlvbi5zdGFydCA9PT0gc2VsZWN0aW9uLmVuZCkge1xuICAgIC8vIHRoZSB1c2VyIGlzIHBvaW50aW5nIHRvIGEgd29yZFxuICAgIHJldHVybiBnZXRTdXJyb3VuZGluZ1dvcmQodGV4dCwgc2VsZWN0aW9uLnN0YXJ0KTtcbiAgfVxuICByZXR1cm4gc2VsZWN0aW9uO1xufVxuXG4vKipcbiAqICBHZXRzIHRoZSBudW1iZXIgb2YgbGluZS1icmVha3MgdGhhdCB3b3VsZCBoYXZlIHRvIGJlIGluc2VydGVkIGJlZm9yZSB0aGUgZ2l2ZW4gJ3N0YXJ0UG9zaXRpb24nXG4gKiAgdG8gbWFrZSBzdXJlIHRoZXJlJ3MgYW4gZW1wdHkgbGluZSBiZXR3ZWVuICdzdGFydFBvc2l0aW9uJyBhbmQgdGhlIHByZXZpb3VzIHRleHRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldEJyZWFrc05lZWRlZEZvckVtcHR5TGluZUJlZm9yZSh0ZXh0ID0gJycsIHN0YXJ0UG9zaXRpb246IG51bWJlcik6IG51bWJlciB7XG4gIGlmIChzdGFydFBvc2l0aW9uID09PSAwKSByZXR1cm4gMDtcblxuICAvLyBydWxlczpcbiAgLy8gLSBJZiB3ZSdyZSBpbiB0aGUgZmlyc3QgbGluZSwgbm8gYnJlYWtzIGFyZSBuZWVkZWRcbiAgLy8gLSBPdGhlcndpc2UgdGhlcmUgbXVzdCBiZSAyIGJyZWFrcyBiZWZvcmUgdGhlIHByZXZpb3VzIGNoYXJhY3Rlci4gRGVwZW5kaW5nIG9uIGhvdyBtYW55IGJyZWFrcyBleGlzdCBhbHJlYWR5LCB3ZVxuICAvLyAgICAgIG1heSBuZWVkIHRvIGluc2VydCAwLCAxIG9yIDIgYnJlYWtzXG5cbiAgbGV0IG5lZWRlZEJyZWFrcyA9IDI7XG4gIGxldCBpc0luRmlyc3RMaW5lID0gdHJ1ZTtcbiAgZm9yIChsZXQgaSA9IHN0YXJ0UG9zaXRpb24gLSAxOyBpID49IDAgJiYgbmVlZGVkQnJlYWtzID49IDA7IGktLSkge1xuICAgIHN3aXRjaCAodGV4dC5jaGFyQ29kZUF0KGkpKSB7XG4gICAgICBjYXNlIDMyOiAvLyBibGFuayBzcGFjZVxuICAgICAgICBjb250aW51ZTtcbiAgICAgIGNhc2UgMTA6IC8vIGxpbmUgYnJlYWtcbiAgICAgICAgbmVlZGVkQnJlYWtzLS07XG4gICAgICAgIGlzSW5GaXJzdExpbmUgPSBmYWxzZTtcbiAgICAgICAgYnJlYWs7XG4gICAgICBkZWZhdWx0OlxuICAgICAgICByZXR1cm4gbmVlZGVkQnJlYWtzO1xuICAgIH1cbiAgfVxuICByZXR1cm4gaXNJbkZpcnN0TGluZSA/IDAgOiBuZWVkZWRCcmVha3M7XG59XG5cbi8qKlxuICogIEdldHMgdGhlIG51bWJlciBvZiBsaW5lLWJyZWFrcyB0aGF0IHdvdWxkIGhhdmUgdG8gYmUgaW5zZXJ0ZWQgYWZ0ZXIgdGhlIGdpdmVuICdzdGFydFBvc2l0aW9uJ1xuICogIHRvIG1ha2Ugc3VyZSB0aGVyZSdzIGFuIGVtcHR5IGxpbmUgYmV0d2VlbiAnc3RhcnRQb3NpdGlvbicgYW5kIHRoZSBuZXh0IHRleHRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldEJyZWFrc05lZWRlZEZvckVtcHR5TGluZUFmdGVyKHRleHQgPSAnJywgc3RhcnRQb3NpdGlvbjogbnVtYmVyKTogbnVtYmVyIHtcbiAgaWYgKHN0YXJ0UG9zaXRpb24gPT09IHRleHQubGVuZ3RoIC0gMSkgcmV0dXJuIDA7XG5cbiAgLy8gcnVsZXM6XG4gIC8vIC0gSWYgd2UncmUgaW4gdGhlIGZpcnN0IGxpbmUsIG5vIGJyZWFrcyBhcmUgbmVlZGVkXG4gIC8vIC0gT3RoZXJ3aXNlIHRoZXJlIG11c3QgYmUgMiBicmVha3MgYmVmb3JlIHRoZSBwcmV2aW91cyBjaGFyYWN0ZXIuIERlcGVuZGluZyBvbiBob3cgbWFueSBicmVha3MgZXhpc3QgYWxyZWFkeSwgd2VcbiAgLy8gICAgICBtYXkgbmVlZCB0byBpbnNlcnQgMCwgMSBvciAyIGJyZWFrc1xuXG4gIGxldCBuZWVkZWRCcmVha3MgPSAyO1xuICBsZXQgaXNJbkxhc3RMaW5lID0gdHJ1ZTtcbiAgZm9yIChsZXQgaSA9IHN0YXJ0UG9zaXRpb247IGkgPCB0ZXh0Lmxlbmd0aCAmJiBuZWVkZWRCcmVha3MgPj0gMDsgaSsrKSB7XG4gICAgc3dpdGNoICh0ZXh0LmNoYXJDb2RlQXQoaSkpIHtcbiAgICAgIGNhc2UgMzI6XG4gICAgICAgIGNvbnRpbnVlO1xuICAgICAgY2FzZSAxMDoge1xuICAgICAgICBuZWVkZWRCcmVha3MtLTtcbiAgICAgICAgaXNJbkxhc3RMaW5lID0gZmFsc2U7XG4gICAgICAgIGJyZWFrO1xuICAgICAgfVxuICAgICAgZGVmYXVsdDpcbiAgICAgICAgcmV0dXJuIG5lZWRlZEJyZWFrcztcbiAgICB9XG4gIH1cbiAgcmV0dXJuIGlzSW5MYXN0TGluZSA/IDAgOiBuZWVkZWRCcmVha3M7XG59XG4iXSwibWFwcGluZ3MiOiJBQUNBLE9BQU9BLGtCQUFrQixNQUFNLHNCQUFzQjtBQU9yRCxPQUFPLFNBQVNDLFVBQVUsT0FBOEM7RUFBQSxJQUEzQ0MsSUFBSSxRQUFKQSxJQUFJO0lBQUVDLFNBQVMsUUFBVEEsU0FBUztFQUMxQyxJQUFJRCxJQUFJLElBQUlBLElBQUksQ0FBQ0UsTUFBTSxJQUFJRCxTQUFTLENBQUNFLEtBQUssS0FBS0YsU0FBUyxDQUFDRyxHQUFHLEVBQUU7SUFDNUQ7SUFDQSxPQUFPTixrQkFBa0IsQ0FBQ0UsSUFBSSxFQUFFQyxTQUFTLENBQUNFLEtBQUssQ0FBQztFQUNsRDtFQUNBLE9BQU9GLFNBQVM7QUFDbEI7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPLFNBQVNJLGlDQUFpQyxHQUEyQztFQUFBLElBQTFDTCxJQUFJLHVFQUFHLEVBQUU7RUFBQSxJQUFFTSxhQUFxQjtFQUNoRixJQUFJQSxhQUFhLEtBQUssQ0FBQyxFQUFFLE9BQU8sQ0FBQzs7RUFFakM7RUFDQTtFQUNBO0VBQ0E7O0VBRUEsSUFBSUMsWUFBWSxHQUFHLENBQUM7RUFDcEIsSUFBSUMsYUFBYSxHQUFHLElBQUk7RUFDeEIsS0FBSyxJQUFJQyxDQUFDLEdBQUdILGFBQWEsR0FBRyxDQUFDLEVBQUVHLENBQUMsSUFBSSxDQUFDLElBQUlGLFlBQVksSUFBSSxDQUFDLEVBQUVFLENBQUMsRUFBRSxFQUFFO0lBQ2hFLFFBQVFULElBQUksQ0FBQ1UsVUFBVSxDQUFDRCxDQUFDLENBQUM7TUFDeEIsS0FBSyxFQUFFO1FBQUU7UUFDUDtNQUNGLEtBQUssRUFBRTtRQUFFO1FBQ1BGLFlBQVksRUFBRTtRQUNkQyxhQUFhLEdBQUcsS0FBSztRQUNyQjtNQUNGO1FBQ0UsT0FBT0QsWUFBWTtJQUFDO0VBRTFCO0VBQ0EsT0FBT0MsYUFBYSxHQUFHLENBQUMsR0FBR0QsWUFBWTtBQUN6Qzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU8sU0FBU0ksZ0NBQWdDLEdBQTJDO0VBQUEsSUFBMUNYLElBQUksdUVBQUcsRUFBRTtFQUFBLElBQUVNLGFBQXFCO0VBQy9FLElBQUlBLGFBQWEsS0FBS04sSUFBSSxDQUFDRSxNQUFNLEdBQUcsQ0FBQyxFQUFFLE9BQU8sQ0FBQzs7RUFFL0M7RUFDQTtFQUNBO0VBQ0E7O0VBRUEsSUFBSUssWUFBWSxHQUFHLENBQUM7RUFDcEIsSUFBSUssWUFBWSxHQUFHLElBQUk7RUFDdkIsS0FBSyxJQUFJSCxDQUFDLEdBQUdILGFBQWEsRUFBRUcsQ0FBQyxHQUFHVCxJQUFJLENBQUNFLE1BQU0sSUFBSUssWUFBWSxJQUFJLENBQUMsRUFBRUUsQ0FBQyxFQUFFLEVBQUU7SUFDckUsUUFBUVQsSUFBSSxDQUFDVSxVQUFVLENBQUNELENBQUMsQ0FBQztNQUN4QixLQUFLLEVBQUU7UUFDTDtNQUNGLEtBQUssRUFBRTtRQUFFO1VBQ1BGLFlBQVksRUFBRTtVQUNkSyxZQUFZLEdBQUcsS0FBSztVQUNwQjtRQUNGO01BQ0E7UUFDRSxPQUFPTCxZQUFZO0lBQUM7RUFFMUI7RUFDQSxPQUFPSyxZQUFZLEdBQUcsQ0FBQyxHQUFHTCxZQUFZO0FBQ3hDIn0=
|
package/package.json
CHANGED
|
@@ -1,33 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@uiw/react-md-editor",
|
|
3
|
-
"version": "3.3.
|
|
3
|
+
"version": "3.3.8",
|
|
4
4
|
"description": "A markdown editor with preview, implemented with React.js and TypeScript.",
|
|
5
5
|
"homepage": "https://uiwjs.github.io/react-md-editor/",
|
|
6
6
|
"author": "kenny wang <wowohoo@qq.com>",
|
|
7
7
|
"main": "lib/cjs/index.js",
|
|
8
8
|
"module": "lib/esm/index.js",
|
|
9
9
|
"typings": "lib/cjs/index.d.ts",
|
|
10
|
-
"scripts": {
|
|
11
|
-
"prepare": "husky install && npm run build",
|
|
12
|
-
"test": "tsbb test --env=jsdom",
|
|
13
|
-
"coverage": "tsbb test --env=jsdom --coverage",
|
|
14
|
-
"released": "npm run build && npm run doc",
|
|
15
|
-
"doc": "kkt build --app-src ./website",
|
|
16
|
-
"start": "kkt start --app-src ./website",
|
|
17
|
-
"build": "npm run ts:build && npm run types:esm && npm run types:cjs && npm run css:build && npm run css:build:dist",
|
|
18
|
-
"watch": "npm run ts:watch & npm run types:watch & npm run css:watch",
|
|
19
|
-
"types:build": "tsbb types --sourceRoot src --target ESNEXT",
|
|
20
|
-
"types:watch": "npm run types:esm -- --watch & npm run types:cjs -- --watch",
|
|
21
|
-
"types:esm": "npm run types:build -- --outDir ../lib/esm",
|
|
22
|
-
"types:cjs": "npm run types:build -- --outDir ../lib/cjs",
|
|
23
|
-
"css:build": "compile-less -d src -o lib/esm",
|
|
24
|
-
"css:watch": "compile-less -d src -o lib/esm --watch",
|
|
25
|
-
"css:build:dist": "compile-less -d src --combine dist/markdown-editor.css --rm-global",
|
|
26
|
-
"ts:watch": "tsbb watch --env-name esm:dev --env-name cjs --target react",
|
|
27
|
-
"ts:build": "tsbb build --target react",
|
|
28
|
-
"prettier": "prettier --write '**/*.{js,jsx,tsx,ts,less,md,json}'",
|
|
29
|
-
"map": "source-map-explorer build/static/js/*.js --html build/website-result.html"
|
|
30
|
-
},
|
|
31
10
|
"repository": {
|
|
32
11
|
"type": "git",
|
|
33
12
|
"url": "https://github.com/uiwjs/react-md-editor"
|
|
@@ -84,31 +63,5 @@
|
|
|
84
63
|
"uiw",
|
|
85
64
|
"uiwjs",
|
|
86
65
|
"code"
|
|
87
|
-
]
|
|
88
|
-
"lint-staged": {
|
|
89
|
-
"*.{js,jsx,less,md,json}": [
|
|
90
|
-
"prettier --write"
|
|
91
|
-
],
|
|
92
|
-
"*.ts?(x)": [
|
|
93
|
-
"prettier --parser=typescript --write"
|
|
94
|
-
]
|
|
95
|
-
},
|
|
96
|
-
"eslintConfig": {
|
|
97
|
-
"extends": [
|
|
98
|
-
"react-app",
|
|
99
|
-
"react-app/jest"
|
|
100
|
-
]
|
|
101
|
-
},
|
|
102
|
-
"browserslist": {
|
|
103
|
-
"production": [
|
|
104
|
-
">0.2%",
|
|
105
|
-
"not dead",
|
|
106
|
-
"not op_mini all"
|
|
107
|
-
],
|
|
108
|
-
"development": [
|
|
109
|
-
"last 1 chrome version",
|
|
110
|
-
"last 1 firefox version",
|
|
111
|
-
"last 1 safari version"
|
|
112
|
-
]
|
|
113
|
-
}
|
|
66
|
+
]
|
|
114
67
|
}
|