@uiw/react-md-editor 3.3.6 → 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/README.md +2 -8
- 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.d.ts +11 -12
- 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 +14 -34
- 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.d.ts +11 -12
- 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 +14 -25
- 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 +14 -66
- package/src/commands/index.ts +17 -13
- package/src/components/Toolbar/index.tsx +2 -4
|
@@ -1,33 +1,24 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
4
|
-
|
|
5
4
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
6
|
-
|
|
7
5
|
Object.defineProperty(exports, "__esModule", {
|
|
8
6
|
value: true
|
|
9
7
|
});
|
|
10
8
|
exports.default = Child;
|
|
11
|
-
|
|
12
9
|
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
13
|
-
|
|
14
10
|
var _react = _interopRequireWildcard(require("react"));
|
|
15
|
-
|
|
16
11
|
var _ = _interopRequireDefault(require("./"));
|
|
17
|
-
|
|
18
12
|
var _Context = require("../../Context");
|
|
19
|
-
|
|
20
13
|
function Child(props) {
|
|
21
14
|
var _ref = props || {},
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
15
|
+
prefixCls = _ref.prefixCls,
|
|
16
|
+
groupName = _ref.groupName,
|
|
17
|
+
commands = _ref.commands,
|
|
18
|
+
children = _ref.children;
|
|
27
19
|
var _useContext = (0, _react.useContext)(_Context.EditorContext),
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
20
|
+
_useContext$barPopup = _useContext.barPopup,
|
|
21
|
+
barPopup = _useContext$barPopup === void 0 ? {} : _useContext$barPopup;
|
|
31
22
|
return (0, _react.useMemo)(function () {
|
|
32
23
|
return /*#__PURE__*/_react.default.createElement("div", {
|
|
33
24
|
className: "".concat(prefixCls, "-toolbar-child ").concat(groupName && barPopup[groupName] ? 'active' : ''),
|
|
@@ -40,9 +31,9 @@ function Child(props) {
|
|
|
40
31
|
height: "",
|
|
41
32
|
isChild: true
|
|
42
33
|
})) : children);
|
|
43
|
-
},
|
|
34
|
+
},
|
|
35
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
44
36
|
[commands, barPopup, groupName, prefixCls]);
|
|
45
37
|
}
|
|
46
|
-
|
|
47
38
|
module.exports = exports.default;
|
|
48
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
39
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJDaGlsZCIsInByb3BzIiwicHJlZml4Q2xzIiwiZ3JvdXBOYW1lIiwiY29tbWFuZHMiLCJjaGlsZHJlbiIsInVzZUNvbnRleHQiLCJFZGl0b3JDb250ZXh0IiwiYmFyUG9wdXAiLCJ1c2VNZW1vIiwiZSIsInN0b3BQcm9wYWdhdGlvbiIsIkFycmF5IiwiaXNBcnJheSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1Rvb2xiYXIvQ2hpbGQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyB1c2VDb250ZXh0LCB1c2VNZW1vIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0ICcuL0NoaWxkLmxlc3MnO1xuaW1wb3J0IFRvb2xiYXIsIHsgSVRvb2xiYXJQcm9wcyB9IGZyb20gJy4vJztcbmltcG9ydCB7IEVkaXRvckNvbnRleHQgfSBmcm9tICcuLi8uLi9Db250ZXh0JztcblxuZXhwb3J0IHR5cGUgQ2hpbGRQcm9wcyA9IElUb29sYmFyUHJvcHMgJiB7XG4gIGNoaWxkcmVuPzogSlNYLkVsZW1lbnQ7XG4gIGdyb3VwTmFtZT86IHN0cmluZztcbn07XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIENoaWxkKHByb3BzOiBDaGlsZFByb3BzKSB7XG4gIGNvbnN0IHsgcHJlZml4Q2xzLCBncm91cE5hbWUsIGNvbW1hbmRzLCBjaGlsZHJlbiB9ID0gcHJvcHMgfHwge307XG4gIGNvbnN0IHsgYmFyUG9wdXAgPSB7fSB9ID0gdXNlQ29udGV4dChFZGl0b3JDb250ZXh0KTtcbiAgcmV0dXJuIHVzZU1lbW8oXG4gICAgKCkgPT4gKFxuICAgICAgPGRpdlxuICAgICAgICBjbGFzc05hbWU9e2Ake3ByZWZpeENsc30tdG9vbGJhci1jaGlsZCAke2dyb3VwTmFtZSAmJiBiYXJQb3B1cFtncm91cE5hbWVdID8gJ2FjdGl2ZScgOiAnJ31gfVxuICAgICAgICBvbkNsaWNrPXsoZSkgPT4gZS5zdG9wUHJvcGFnYXRpb24oKX1cbiAgICAgID5cbiAgICAgICAge0FycmF5LmlzQXJyYXkoY29tbWFuZHMpID8gPFRvb2xiYXIgY29tbWFuZHM9e2NvbW1hbmRzfSB7Li4ucHJvcHN9IGhlaWdodD1cIlwiIGlzQ2hpbGQgLz4gOiBjaGlsZHJlbn1cbiAgICAgIDwvZGl2PlxuICAgICksXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIHJlYWN0LWhvb2tzL2V4aGF1c3RpdmUtZGVwc1xuICAgIFtjb21tYW5kcywgYmFyUG9wdXAsIGdyb3VwTmFtZSwgcHJlZml4Q2xzXSxcbiAgKTtcbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUE7QUFFQTtBQUNBO0FBT2UsU0FBU0EsS0FBSyxDQUFDQyxLQUFpQixFQUFFO0VBQy9DLFdBQXFEQSxLQUFLLElBQUksQ0FBQyxDQUFDO0lBQXhEQyxTQUFTLFFBQVRBLFNBQVM7SUFBRUMsU0FBUyxRQUFUQSxTQUFTO0lBQUVDLFFBQVEsUUFBUkEsUUFBUTtJQUFFQyxRQUFRLFFBQVJBLFFBQVE7RUFDaEQsa0JBQTBCLElBQUFDLGlCQUFVLEVBQUNDLHNCQUFhLENBQUM7SUFBQSxtQ0FBM0NDLFFBQVE7SUFBUkEsUUFBUSxxQ0FBRyxDQUFDLENBQUM7RUFDckIsT0FBTyxJQUFBQyxjQUFPLEVBQ1o7SUFBQSxvQkFDRTtNQUNFLFNBQVMsWUFBS1AsU0FBUyw0QkFBa0JDLFNBQVMsSUFBSUssUUFBUSxDQUFDTCxTQUFTLENBQUMsR0FBRyxRQUFRLEdBQUcsRUFBRSxDQUFHO01BQzVGLE9BQU8sRUFBRSxpQkFBQ08sQ0FBQztRQUFBLE9BQUtBLENBQUMsQ0FBQ0MsZUFBZSxFQUFFO01BQUE7SUFBQyxHQUVuQ0MsS0FBSyxDQUFDQyxPQUFPLENBQUNULFFBQVEsQ0FBQyxnQkFBRyw2QkFBQyxTQUFPO01BQUMsUUFBUSxFQUFFQTtJQUFTLEdBQUtILEtBQUs7TUFBRSxNQUFNLEVBQUMsRUFBRTtNQUFDLE9BQU87SUFBQSxHQUFHLEdBQUdJLFFBQVEsQ0FDOUY7RUFBQSxDQUNQO0VBQ0Q7RUFDQSxDQUFDRCxRQUFRLEVBQUVJLFFBQVEsRUFBRUwsU0FBUyxFQUFFRCxTQUFTLENBQUMsQ0FDM0M7QUFDSDtBQUFDIn0=
|
|
@@ -1,50 +1,37 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
4
|
-
|
|
5
4
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
6
|
-
|
|
7
5
|
Object.defineProperty(exports, "__esModule", {
|
|
8
6
|
value: true
|
|
9
7
|
});
|
|
10
8
|
exports.ToolbarItems = ToolbarItems;
|
|
11
9
|
exports.default = Toolbar;
|
|
12
|
-
|
|
13
10
|
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
14
|
-
|
|
15
11
|
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
|
16
|
-
|
|
17
12
|
var _react = _interopRequireWildcard(require("react"));
|
|
18
|
-
|
|
19
13
|
var _Context = require("../../Context");
|
|
20
|
-
|
|
21
14
|
var _Child = _interopRequireDefault(require("./Child"));
|
|
22
|
-
|
|
23
15
|
function ToolbarItems(props) {
|
|
24
16
|
var prefixCls = props.prefixCls;
|
|
25
|
-
|
|
26
17
|
var _useContext = (0, _react.useContext)(_Context.EditorContext),
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
18
|
+
fullscreen = _useContext.fullscreen,
|
|
19
|
+
preview = _useContext.preview,
|
|
20
|
+
_useContext$barPopup = _useContext.barPopup,
|
|
21
|
+
barPopup = _useContext$barPopup === void 0 ? {} : _useContext$barPopup,
|
|
22
|
+
commandOrchestrator = _useContext.commandOrchestrator,
|
|
23
|
+
dispatch = _useContext.dispatch;
|
|
34
24
|
function handleClick(command, name) {
|
|
35
25
|
if (!dispatch) return;
|
|
36
26
|
var state = {
|
|
37
27
|
barPopup: (0, _objectSpread2.default)({}, barPopup)
|
|
38
28
|
};
|
|
39
|
-
|
|
40
29
|
if (command.keyCommand === 'preview') {
|
|
41
30
|
state.preview = command.value;
|
|
42
31
|
}
|
|
43
|
-
|
|
44
32
|
if (command.keyCommand === 'fullscreen') {
|
|
45
33
|
state.fullscreen = !fullscreen;
|
|
46
34
|
}
|
|
47
|
-
|
|
48
35
|
if (props.commands && command.keyCommand === 'group') {
|
|
49
36
|
props.commands.forEach(function (item) {
|
|
50
37
|
if (name === item.groupName) {
|
|
@@ -58,14 +45,11 @@ function ToolbarItems(props) {
|
|
|
58
45
|
state.barPopup[keyName] = false;
|
|
59
46
|
});
|
|
60
47
|
}
|
|
61
|
-
|
|
62
48
|
if (Object.keys(state).length) {
|
|
63
49
|
dispatch((0, _objectSpread2.default)({}, state));
|
|
64
50
|
}
|
|
65
|
-
|
|
66
51
|
commandOrchestrator && commandOrchestrator.executeCommand(command);
|
|
67
52
|
}
|
|
68
|
-
|
|
69
53
|
(0, _react.useEffect)(function () {
|
|
70
54
|
if (document) {
|
|
71
55
|
document.body.style.overflow = !fullscreen ? 'initial' : 'hidden';
|
|
@@ -79,10 +63,9 @@ function ToolbarItems(props) {
|
|
|
79
63
|
className: "".concat(prefixCls, "-toolbar-divider")
|
|
80
64
|
}));
|
|
81
65
|
}
|
|
82
|
-
|
|
83
66
|
if (!item.keyCommand) return /*#__PURE__*/_react.default.createElement(_react.Fragment, null);
|
|
84
67
|
var activeBtn = fullscreen && item.keyCommand === 'fullscreen' || item.keyCommand === 'preview' && preview === item.value;
|
|
85
|
-
var childNode = typeof item.children === 'function' ? item.children({
|
|
68
|
+
var childNode = item.children && typeof item.children === 'function' ? item.children({
|
|
86
69
|
getState: function getState() {
|
|
87
70
|
return commandOrchestrator.getState();
|
|
88
71
|
},
|
|
@@ -114,22 +97,19 @@ function ToolbarItems(props) {
|
|
|
114
97
|
groupName: item.groupName,
|
|
115
98
|
prefixCls: prefixCls,
|
|
116
99
|
children: childNode,
|
|
117
|
-
commands: Array.isArray(item.children)
|
|
100
|
+
commands: Array.isArray(item.children) ? item.children : undefined
|
|
118
101
|
}));
|
|
119
102
|
}));
|
|
120
103
|
}
|
|
121
|
-
|
|
122
104
|
function Toolbar() {
|
|
123
105
|
var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
124
106
|
var prefixCls = props.prefixCls,
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
107
|
+
_props$height = props.height,
|
|
108
|
+
height = _props$height === void 0 ? 29 : _props$height,
|
|
109
|
+
isChild = props.isChild;
|
|
129
110
|
var _useContext2 = (0, _react.useContext)(_Context.EditorContext),
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
111
|
+
commands = _useContext2.commands,
|
|
112
|
+
extraCommands = _useContext2.extraCommands;
|
|
133
113
|
return /*#__PURE__*/_react.default.createElement("div", {
|
|
134
114
|
className: "".concat(prefixCls, "-toolbar"),
|
|
135
115
|
style: {
|
|
@@ -141,4 +121,4 @@ function Toolbar() {
|
|
|
141
121
|
commands: extraCommands || []
|
|
142
122
|
})));
|
|
143
123
|
}
|
|
144
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Toolbar/index.tsx"],"names":["ToolbarItems","props","prefixCls","EditorContext","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","React","createElement","type","onClick","evn","stopPropagation","Array","isArray","Toolbar","height","isChild","extraCommands"],"mappings":";;;;;;;;;;;;;;;;AAAA;;AAEA;;AAEA;;AAUO,SAASA,YAAT,CAAsBC,KAAtB,EAA4C;AACjD,MAAQC,SAAR,GAAsBD,KAAtB,CAAQC,SAAR;;AACA,oBAA8E,uBAAWC,sBAAX,CAA9E;AAAA,MAAQC,UAAR,eAAQA,UAAR;AAAA,MAAoBC,OAApB,eAAoBA,OAApB;AAAA,yCAA6BC,QAA7B;AAAA,MAA6BA,QAA7B,qCAAwC,EAAxC;AAAA,MAA4CC,mBAA5C,eAA4CA,mBAA5C;AAAA,MAAiEC,QAAjE,eAAiEA,QAAjE;;AACA,WAASC,WAAT,CAAqBC,OAArB,EAAgDC,IAAhD,EAA+D;AAC7D,QAAI,CAACH,QAAL,EAAe;AACf,QAAMI,KAAmB,GAAG;AAAEN,MAAAA,QAAQ,kCAAOA,QAAP;AAAV,KAA5B;;AACA,QAAII,OAAO,CAACG,UAAR,KAAuB,SAA3B,EAAsC;AACpCD,MAAAA,KAAK,CAACP,OAAN,GAAgBK,OAAO,CAACI,KAAxB;AACD;;AACD,QAAIJ,OAAO,CAACG,UAAR,KAAuB,YAA3B,EAAyC;AACvCD,MAAAA,KAAK,CAACR,UAAN,GAAmB,CAACA,UAApB;AACD;;AACD,QAAIH,KAAK,CAACc,QAAN,IAAkBL,OAAO,CAACG,UAAR,KAAuB,OAA7C,EAAsD;AACpDZ,MAAAA,KAAK,CAACc,QAAN,CAAeC,OAAf,CAAuB,UAACC,IAAD,EAAU;AAC/B,YAAIN,IAAI,KAAKM,IAAI,CAACC,SAAlB,EAA6B;AAC3BN,UAAAA,KAAK,CAACN,QAAN,CAAgBK,IAAhB,IAAyB,IAAzB;AACD,SAFD,MAEO,IAAIM,IAAI,CAACJ,UAAT,EAAqB;AAC1BD,UAAAA,KAAK,CAACN,QAAN,CAAgBW,IAAI,CAACC,SAArB,IAAmC,KAAnC;AACD;AACF,OAND;AAOD,KARD,MAQO,IAAIP,IAAI,IAAID,OAAO,CAACS,MAApB,EAA4B;AACjCC,MAAAA,MAAM,CAACC,IAAP,CAAYT,KAAK,CAACN,QAAN,IAAkB,EAA9B,EAAkCU,OAAlC,CAA0C,UAACM,OAAD,EAAa;AACrDV,QAAAA,KAAK,CAACN,QAAN,CAAgBgB,OAAhB,IAA2B,KAA3B;AACD,OAFD;AAGD;;AAED,QAAIF,MAAM,CAACC,IAAP,CAAYT,KAAZ,EAAmBW,MAAvB,EAA+B;AAC7Bf,MAAAA,QAAQ,iCAAMI,KAAN,EAAR;AACD;;AACDL,IAAAA,mBAAmB,IAAIA,mBAAmB,CAACiB,cAApB,CAAmCd,OAAnC,CAAvB;AACD;;AAED,wBAAU,YAAM;AACd,QAAIe,QAAJ,EAAc;AACZA,MAAAA,QAAQ,CAACC,IAAT,CAAcC,KAAd,CAAoBC,QAApB,GAA+B,CAACxB,UAAD,GAAc,SAAd,GAA0B,QAAzD;AACD;AACF,GAJD,EAIG,CAACA,UAAD,CAJH;AAMA,sBACE,yCACG,CAACH,KAAK,CAACc,QAAN,IAAkB,EAAnB,EAAuBc,GAAvB,CAA2B,UAACZ,IAAD,EAAOa,GAAP,EAAe;AACzC,QAAIb,IAAI,CAACJ,UAAL,KAAoB,SAAxB,EAAmC;AACjC,0BAAO;AAAI,QAAA,GAAG,EAAEiB;AAAT,SAAkBb,IAAI,CAACc,OAAvB;AAAgC,QAAA,SAAS,YAAK7B,SAAL;AAAzC,SAAP;AACD;;AACD,QAAI,CAACe,IAAI,CAACJ,UAAV,EAAsB,oBAAO,6BAAC,eAAD,OAAP;AACtB,QAAMmB,SAAS,GACZ5B,UAAU,IAAIa,IAAI,CAACJ,UAAL,KAAoB,YAAnC,IAAqDI,IAAI,CAACJ,UAAL,KAAoB,SAApB,IAAiCR,OAAO,KAAKY,IAAI,CAACH,KADzG;AAEA,QAAMmB,SAAS,GACb,OAAOhB,IAAI,CAACiB,QAAZ,KAAyB,UAAzB,GACIjB,IAAI,CAACiB,QAAL,CAAc;AACZC,MAAAA,QAAQ,EAAE;AAAA,eAAM5B,mBAAmB,CAAE4B,QAArB,EAAN;AAAA,OADE;AAEZC,MAAAA,OAAO,EAAE7B,mBAAmB,GAAGA,mBAAmB,CAAE6B,OAAxB,GAAkCC,SAFlD;AAGZC,MAAAA,KAAK,EAAE;AAAA,eAAM7B,WAAW,CAAC,EAAD,EAAKQ,IAAI,CAACC,SAAV,CAAjB;AAAA,OAHK;AAIZqB,MAAAA,OAAO,EAAE;AAAA,eAAM9B,WAAW,CAAC;AAAE8B,UAAAA,OAAO,EAAEtB,IAAI,CAACsB;AAAhB,SAAD,CAAjB;AAAA;AAJG,KAAd,CADJ,GAOIF,SARN;AASA,QAAMG,QAAQ,GAAGlC,QAAQ,IAAID,OAAZ,IAAuBA,OAAO,KAAK,SAAnC,IAAgD,CAAC,uBAAuBoC,IAAvB,CAA4BxB,IAAI,CAACJ,UAAjC,CAAlE;AACA,wBACE;AAAI,MAAA,GAAG,EAAEiB;AAAT,OAAkBb,IAAI,CAACc,OAAvB;AAAgC,MAAA,SAAS,EAAEC,SAAS,cAAc;AAAlE,QACG,CAACf,IAAI,CAACyB,WAAN,IAAqBzB,IAAI,CAAC0B,IAD7B,EAEG1B,IAAI,CAACyB,WAAL,iBACCE,eAAMC,aAAN,CACE,QADF;AAGIC,MAAAA,IAAI,EAAE,QAHV;AAIIN,MAAAA,QAAQ,EAARA,QAJJ;AAKI,mBAAavB,IAAI,CAACN;AALtB,OAMOM,IAAI,CAACyB,WANZ;AAOIK,MAAAA,OAAO,EAAE,iBAACC,GAAD,EAA0D;AACjEA,QAAAA,GAAG,CAACC,eAAJ;AACAxC,QAAAA,WAAW,CAACQ,IAAD,EAAOA,IAAI,CAACC,SAAZ,CAAX;AACD;AAVL,QAYED,IAAI,CAAC0B,IAZP,CAHJ,EAiBG1B,IAAI,CAACiB,QAAL,iBACC,6BAAC,cAAD;AACE,MAAA,SAAS,EAAEjB,IAAI,CAACC,SADlB;AAEE,MAAA,SAAS,EAAEhB,SAFb;AAGE,MAAA,QAAQ,EAAE+B,SAHZ;AAIE,MAAA,QAAQ,EACNiB,KAAK,CAACC,OAAN,CAAclC,IAAI,CAACiB,QAAnB,KAAgC,OAAOjB,IAAI,CAACiB,QAAZ,KAAyB,UAAzD,GAAsEjB,IAAI,CAACiB,QAA3E,GAAsFG;AAL1F,MAlBJ,CADF;AA8BD,GA/CA,CADH,CADF;AAoDD;;AAEc,SAASe,OAAT,GAA4C;AAAA,MAA3BnD,KAA2B,uEAAJ,EAAI;AACzD,MAAQC,SAAR,GAA4CD,KAA5C,CAAQC,SAAR;AAAA,sBAA4CD,KAA5C,CAAmBoD,MAAnB;AAAA,MAAmBA,MAAnB,8BAA4B,EAA5B;AAAA,MAAgCC,OAAhC,GAA4CrD,KAA5C,CAAgCqD,OAAhC;;AACA,qBAAoC,uBAAWnD,sBAAX,CAApC;AAAA,MAAQY,QAAR,gBAAQA,QAAR;AAAA,MAAkBwC,aAAlB,gBAAkBA,aAAlB;;AACA,sBACE;AAAK,IAAA,SAAS,YAAKrD,SAAL,aAAd;AAAwC,IAAA,KAAK,EAAE;AAAEmD,MAAAA,MAAM,EAANA;AAAF;AAA/C,kBACE,6BAAC,YAAD,6BAAkBpD,KAAlB;AAAyB,IAAA,QAAQ,EAAEA,KAAK,CAACc,QAAN,IAAkBA,QAAlB,IAA8B;AAAjE,KADF,EAEG,CAACuC,OAAD,iBAAY,6BAAC,YAAD,6BAAkBrD,KAAlB;AAAyB,IAAA,QAAQ,EAAEsD,aAAa,IAAI;AAApD,KAFf,CADF;AAMD","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          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={\n                  Array.isArray(item.children) && typeof item.children !== 'function' ? item.children : undefined\n                }\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"]}
|
|
124
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["ToolbarItems","props","prefixCls","useContext","EditorContext","fullscreen","preview","barPopup","commandOrchestrator","dispatch","handleClick","command","name","state","keyCommand","value","commands","forEach","item","groupName","parent","Object","keys","keyName","length","executeCommand","useEffect","document","body","style","overflow","map","idx","liProps","activeBtn","childNode","children","getState","textApi","undefined","close","execute","disabled","test","buttonProps","icon","React","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/cjs/index.js
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
@@ -9,10 +8,8 @@ var _exportNames = {
|
|
|
9
8
|
commands: true,
|
|
10
9
|
MarkdownUtil: true
|
|
11
10
|
};
|
|
12
|
-
exports.
|
|
13
|
-
|
|
11
|
+
exports.default = exports.commands = exports.MarkdownUtil = void 0;
|
|
14
12
|
var _Editor = _interopRequireWildcard(require("./Editor"));
|
|
15
|
-
|
|
16
13
|
Object.keys(_Editor).forEach(function (key) {
|
|
17
14
|
if (key === "default" || key === "__esModule") return;
|
|
18
15
|
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
|
@@ -24,9 +21,7 @@ Object.keys(_Editor).forEach(function (key) {
|
|
|
24
21
|
}
|
|
25
22
|
});
|
|
26
23
|
});
|
|
27
|
-
|
|
28
24
|
var commands = _interopRequireWildcard(require("./commands"));
|
|
29
|
-
|
|
30
25
|
exports.commands = commands;
|
|
31
26
|
Object.keys(commands).forEach(function (key) {
|
|
32
27
|
if (key === "default" || key === "__esModule") return;
|
|
@@ -39,9 +34,7 @@ Object.keys(commands).forEach(function (key) {
|
|
|
39
34
|
}
|
|
40
35
|
});
|
|
41
36
|
});
|
|
42
|
-
|
|
43
37
|
var MarkdownUtil = _interopRequireWildcard(require("./utils/markdownUtils"));
|
|
44
|
-
|
|
45
38
|
exports.MarkdownUtil = MarkdownUtil;
|
|
46
39
|
Object.keys(MarkdownUtil).forEach(function (key) {
|
|
47
40
|
if (key === "default" || key === "__esModule") return;
|
|
@@ -54,9 +47,7 @@ Object.keys(MarkdownUtil).forEach(function (key) {
|
|
|
54
47
|
}
|
|
55
48
|
});
|
|
56
49
|
});
|
|
57
|
-
|
|
58
50
|
var _Context = require("./Context");
|
|
59
|
-
|
|
60
51
|
Object.keys(_Context).forEach(function (key) {
|
|
61
52
|
if (key === "default" || key === "__esModule") return;
|
|
62
53
|
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
|
@@ -70,4 +61,4 @@ Object.keys(_Context).forEach(function (key) {
|
|
|
70
61
|
});
|
|
71
62
|
var _default = _Editor.default;
|
|
72
63
|
exports.default = _default;
|
|
73
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
64
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJNREVkaXRvciJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9pbmRleC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IE1ERWRpdG9yIGZyb20gJy4vRWRpdG9yJztcbmltcG9ydCAqIGFzIGNvbW1hbmRzIGZyb20gJy4vY29tbWFuZHMnO1xuaW1wb3J0ICogYXMgTWFya2Rvd25VdGlsIGZyb20gJy4vdXRpbHMvbWFya2Rvd25VdGlscyc7XG5cbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9tYXJrZG93blV0aWxzJztcbmV4cG9ydCAqIGZyb20gJy4vRWRpdG9yJztcbmV4cG9ydCAqIGZyb20gJy4vQ29udGV4dCc7XG5cbmV4cG9ydCB7IE1hcmtkb3duVXRpbCwgY29tbWFuZHMgfTtcblxuZXhwb3J0IGRlZmF1bHQgTURFZGl0b3I7XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBQUE7QUFNQTtFQUFBO0VBQUE7RUFBQTtFQUFBO0lBQUE7SUFBQTtNQUFBO0lBQUE7RUFBQTtBQUFBO0FBTEE7QUFBdUM7QUFHdkM7RUFBQTtFQUFBO0VBQUE7RUFBQTtJQUFBO0lBQUE7TUFBQTtJQUFBO0VBQUE7QUFBQTtBQUZBO0FBQXNEO0FBR3REO0VBQUE7RUFBQTtFQUFBO0VBQUE7SUFBQTtJQUFBO01BQUE7SUFBQTtFQUFBO0FBQUE7QUFFQTtBQUFBO0VBQUE7RUFBQTtFQUFBO0VBQUE7SUFBQTtJQUFBO01BQUE7SUFBQTtFQUFBO0FBQUE7QUFBMEIsZUFJWEEsZUFBUTtBQUFBIn0=
|
|
@@ -4,70 +4,66 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = insertTextAtPosition;
|
|
7
|
-
|
|
8
7
|
/**
|
|
9
8
|
* The MIT License
|
|
10
9
|
* Copyright (c) 2018 Dmitriy Kubyshkin
|
|
11
10
|
* Copied from https://github.com/grassator/insert-text-at-cursor
|
|
12
11
|
*/
|
|
12
|
+
|
|
13
13
|
var browserSupportsTextareaTextNodes;
|
|
14
|
+
|
|
14
15
|
/**
|
|
15
16
|
* @param {HTMLElement} input
|
|
16
17
|
* @return {boolean}
|
|
17
18
|
*/
|
|
18
|
-
|
|
19
19
|
function canManipulateViaTextNodes(input) {
|
|
20
20
|
if (input.nodeName !== 'TEXTAREA') {
|
|
21
21
|
return false;
|
|
22
22
|
}
|
|
23
|
-
|
|
24
23
|
if (typeof browserSupportsTextareaTextNodes === 'undefined') {
|
|
25
24
|
var textarea = document.createElement('textarea');
|
|
26
25
|
textarea.value = '1';
|
|
27
26
|
browserSupportsTextareaTextNodes = !!textarea.firstChild;
|
|
28
27
|
}
|
|
29
|
-
|
|
30
28
|
return browserSupportsTextareaTextNodes;
|
|
31
29
|
}
|
|
30
|
+
|
|
32
31
|
/**
|
|
33
32
|
* @param {HTMLTextAreaElement|HTMLInputElement} input
|
|
34
33
|
* @param {string} text
|
|
35
34
|
* @returns {void}
|
|
36
35
|
*/
|
|
37
|
-
|
|
38
|
-
|
|
39
36
|
function insertTextAtPosition(input, text) {
|
|
40
37
|
// Most of the used APIs only work with the field selected
|
|
41
|
-
input.focus();
|
|
38
|
+
input.focus();
|
|
42
39
|
|
|
40
|
+
// IE 8-10
|
|
43
41
|
if (document.selection) {
|
|
44
42
|
var ieRange = document.selection.createRange();
|
|
45
|
-
ieRange.text = text;
|
|
43
|
+
ieRange.text = text;
|
|
46
44
|
|
|
47
|
-
|
|
48
|
-
/* to the end */
|
|
49
|
-
);
|
|
45
|
+
// Move cursor after the inserted text
|
|
46
|
+
ieRange.collapse(false /* to the end */);
|
|
50
47
|
ieRange.select();
|
|
51
48
|
return;
|
|
52
|
-
}
|
|
53
|
-
|
|
49
|
+
}
|
|
54
50
|
|
|
51
|
+
// Webkit + Edge
|
|
55
52
|
var isSuccess = document.execCommand('insertText', false, text);
|
|
56
|
-
|
|
57
53
|
if (!isSuccess) {
|
|
58
54
|
var start = input.selectionStart;
|
|
59
|
-
var end = input.selectionEnd;
|
|
60
|
-
|
|
55
|
+
var end = input.selectionEnd;
|
|
56
|
+
// Firefox (non-standard method)
|
|
61
57
|
if (typeof input.setRangeText === 'function') {
|
|
62
58
|
input.setRangeText(text);
|
|
63
59
|
} else {
|
|
64
60
|
// To make a change we just need a Range, not a Selection
|
|
65
61
|
var range = document.createRange();
|
|
66
62
|
var textNode = document.createTextNode(text);
|
|
67
|
-
|
|
68
63
|
if (canManipulateViaTextNodes(input)) {
|
|
69
|
-
var node = input.firstChild;
|
|
64
|
+
var node = input.firstChild;
|
|
70
65
|
|
|
66
|
+
// If textarea is empty, just insert the text
|
|
71
67
|
if (!node) {
|
|
72
68
|
input.appendChild(textNode);
|
|
73
69
|
} else {
|
|
@@ -75,35 +71,34 @@ function insertTextAtPosition(input, text) {
|
|
|
75
71
|
var offset = 0;
|
|
76
72
|
var startNode = null;
|
|
77
73
|
var endNode = null;
|
|
78
|
-
|
|
79
74
|
while (node && (startNode === null || endNode === null)) {
|
|
80
|
-
var nodeLength = node.nodeValue.length;
|
|
75
|
+
var nodeLength = node.nodeValue.length;
|
|
81
76
|
|
|
77
|
+
// if start of the selection falls into current node
|
|
82
78
|
if (start >= offset && start <= offset + nodeLength) {
|
|
83
79
|
range.setStart(startNode = node, start - offset);
|
|
84
|
-
}
|
|
85
|
-
|
|
80
|
+
}
|
|
86
81
|
|
|
82
|
+
// if end of the selection falls into current node
|
|
87
83
|
if (end >= offset && end <= offset + nodeLength) {
|
|
88
84
|
range.setEnd(endNode = node, end - offset);
|
|
89
85
|
}
|
|
90
|
-
|
|
91
86
|
offset += nodeLength;
|
|
92
87
|
node = node.nextSibling;
|
|
93
|
-
}
|
|
94
|
-
|
|
88
|
+
}
|
|
95
89
|
|
|
90
|
+
// If there is some text selected, remove it as we should replace it
|
|
96
91
|
if (start !== end) {
|
|
97
92
|
range.deleteContents();
|
|
98
93
|
}
|
|
99
94
|
}
|
|
100
|
-
}
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
// If the node is a textarea and the range doesn't span outside the element
|
|
101
98
|
//
|
|
102
99
|
// Get the commonAncestorContainer of the selected range and test its type
|
|
103
100
|
// If the node is of type `#text` it means that we're still working with text nodes within our textarea element
|
|
104
101
|
// otherwise, if it's of type `#document` for example it means our selection spans outside the textarea.
|
|
105
|
-
|
|
106
|
-
|
|
107
102
|
if (canManipulateViaTextNodes(input) && range.commonAncestorContainer.nodeName === '#text') {
|
|
108
103
|
// Finally insert a new node. The browser will automatically split start and end nodes into two if necessary
|
|
109
104
|
range.insertNode(textNode);
|
|
@@ -112,16 +107,16 @@ function insertTextAtPosition(input, text) {
|
|
|
112
107
|
var value = input.value;
|
|
113
108
|
input.value = value.slice(0, start) + text + value.slice(end);
|
|
114
109
|
}
|
|
115
|
-
}
|
|
116
|
-
|
|
110
|
+
}
|
|
117
111
|
|
|
118
|
-
|
|
112
|
+
// Correct the cursor position to be at the end of the insertion
|
|
113
|
+
input.setSelectionRange(start + text.length, start + text.length);
|
|
119
114
|
|
|
115
|
+
// Notify any possible listeners of the change
|
|
120
116
|
var e = document.createEvent('UIEvent');
|
|
121
117
|
e.initEvent('input', true, false);
|
|
122
118
|
input.dispatchEvent(e);
|
|
123
119
|
}
|
|
124
120
|
}
|
|
125
|
-
|
|
126
121
|
module.exports = exports.default;
|
|
127
|
-
//# 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"]}
|
|
122
|
+
//# 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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"}
|
|
@@ -4,39 +4,36 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = getSurroundingWord;
|
|
7
|
-
|
|
8
7
|
function getSurroundingWord(text, position) {
|
|
9
8
|
if (!text) throw Error("Argument 'text' should be truthy");
|
|
10
|
-
|
|
11
9
|
var isWordDelimiter = function isWordDelimiter(c) {
|
|
12
10
|
return c === ' ' || c.charCodeAt(0) === 10;
|
|
13
|
-
};
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
var start = 0; // rightIndex is initialized to text.length because if selection is equal to text.length it won't even enter the interation
|
|
11
|
+
};
|
|
17
12
|
|
|
18
|
-
|
|
13
|
+
// leftIndex is initialized to 0 because if selection is 0, it won't even enter the iteration
|
|
14
|
+
var start = 0;
|
|
15
|
+
// rightIndex is initialized to text.length because if selection is equal to text.length it won't even enter the interation
|
|
16
|
+
var end = text.length;
|
|
19
17
|
|
|
18
|
+
// iterate to the left
|
|
20
19
|
for (var i = position; i - 1 > -1; i--) {
|
|
21
20
|
if (isWordDelimiter(text[i - 1])) {
|
|
22
21
|
start = i;
|
|
23
22
|
break;
|
|
24
23
|
}
|
|
25
|
-
}
|
|
26
|
-
|
|
24
|
+
}
|
|
27
25
|
|
|
26
|
+
// iterate to the right
|
|
28
27
|
for (var _i = position; _i < text.length; _i++) {
|
|
29
28
|
if (isWordDelimiter(text[_i])) {
|
|
30
29
|
end = _i;
|
|
31
30
|
break;
|
|
32
31
|
}
|
|
33
32
|
}
|
|
34
|
-
|
|
35
33
|
return {
|
|
36
34
|
start: start,
|
|
37
35
|
end: end
|
|
38
36
|
};
|
|
39
37
|
}
|
|
40
|
-
|
|
41
38
|
module.exports = exports.default;
|
|
42
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
39
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJnZXRTdXJyb3VuZGluZ1dvcmQiLCJ0ZXh0IiwicG9zaXRpb24iLCJFcnJvciIsImlzV29yZERlbGltaXRlciIsImMiLCJjaGFyQ29kZUF0Iiwic3RhcnQiLCJlbmQiLCJsZW5ndGgiLCJpIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3V0aWxzL2dldFN1cnJvdW5kaW5nV29yZC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUZXh0UmFuZ2UgfSBmcm9tICcuLi9jb21tYW5kcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGdldFN1cnJvdW5kaW5nV29yZCh0ZXh0OiBzdHJpbmcsIHBvc2l0aW9uOiBudW1iZXIpOiBUZXh0UmFuZ2Uge1xuICBpZiAoIXRleHQpIHRocm93IEVycm9yKFwiQXJndW1lbnQgJ3RleHQnIHNob3VsZCBiZSB0cnV0aHlcIik7XG5cbiAgY29uc3QgaXNXb3JkRGVsaW1pdGVyID0gKGM6IHN0cmluZykgPT4gYyA9PT0gJyAnIHx8IGMuY2hhckNvZGVBdCgwKSA9PT0gMTA7XG5cbiAgLy8gbGVmdEluZGV4IGlzIGluaXRpYWxpemVkIHRvIDAgYmVjYXVzZSBpZiBzZWxlY3Rpb24gaXMgMCwgaXQgd29uJ3QgZXZlbiBlbnRlciB0aGUgaXRlcmF0aW9uXG4gIGxldCBzdGFydCA9IDA7XG4gIC8vIHJpZ2h0SW5kZXggaXMgaW5pdGlhbGl6ZWQgdG8gdGV4dC5sZW5ndGggYmVjYXVzZSBpZiBzZWxlY3Rpb24gaXMgZXF1YWwgdG8gdGV4dC5sZW5ndGggaXQgd29uJ3QgZXZlbiBlbnRlciB0aGUgaW50ZXJhdGlvblxuICBsZXQgZW5kID0gdGV4dC5sZW5ndGg7XG5cbiAgLy8gaXRlcmF0ZSB0byB0aGUgbGVmdFxuICBmb3IgKGxldCBpID0gcG9zaXRpb247IGkgLSAxID4gLTE7IGktLSkge1xuICAgIGlmIChpc1dvcmREZWxpbWl0ZXIodGV4dFtpIC0gMV0pKSB7XG4gICAgICBzdGFydCA9IGk7XG4gICAgICBicmVhaztcbiAgICB9XG4gIH1cblxuICAvLyBpdGVyYXRlIHRvIHRoZSByaWdodFxuICBmb3IgKGxldCBpID0gcG9zaXRpb247IGkgPCB0ZXh0Lmxlbmd0aDsgaSsrKSB7XG4gICAgaWYgKGlzV29yZERlbGltaXRlcih0ZXh0W2ldKSkge1xuICAgICAgZW5kID0gaTtcbiAgICAgIGJyZWFrO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiB7IHN0YXJ0LCBlbmQgfTtcbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBRWUsU0FBU0Esa0JBQWtCLENBQUNDLElBQVksRUFBRUMsUUFBZ0IsRUFBYTtFQUNwRixJQUFJLENBQUNELElBQUksRUFBRSxNQUFNRSxLQUFLLENBQUMsa0NBQWtDLENBQUM7RUFFMUQsSUFBTUMsZUFBZSxHQUFHLFNBQWxCQSxlQUFlLENBQUlDLENBQVM7SUFBQSxPQUFLQSxDQUFDLEtBQUssR0FBRyxJQUFJQSxDQUFDLENBQUNDLFVBQVUsQ0FBQyxDQUFDLENBQUMsS0FBSyxFQUFFO0VBQUE7O0VBRTFFO0VBQ0EsSUFBSUMsS0FBSyxHQUFHLENBQUM7RUFDYjtFQUNBLElBQUlDLEdBQUcsR0FBR1AsSUFBSSxDQUFDUSxNQUFNOztFQUVyQjtFQUNBLEtBQUssSUFBSUMsQ0FBQyxHQUFHUixRQUFRLEVBQUVRLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUVBLENBQUMsRUFBRSxFQUFFO0lBQ3RDLElBQUlOLGVBQWUsQ0FBQ0gsSUFBSSxDQUFDUyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRTtNQUNoQ0gsS0FBSyxHQUFHRyxDQUFDO01BQ1Q7SUFDRjtFQUNGOztFQUVBO0VBQ0EsS0FBSyxJQUFJQSxFQUFDLEdBQUdSLFFBQVEsRUFBRVEsRUFBQyxHQUFHVCxJQUFJLENBQUNRLE1BQU0sRUFBRUMsRUFBQyxFQUFFLEVBQUU7SUFDM0MsSUFBSU4sZUFBZSxDQUFDSCxJQUFJLENBQUNTLEVBQUMsQ0FBQyxDQUFDLEVBQUU7TUFDNUJGLEdBQUcsR0FBR0UsRUFBQztNQUNQO0lBQ0Y7RUFDRjtFQUVBLE9BQU87SUFBRUgsS0FBSyxFQUFMQSxLQUFLO0lBQUVDLEdBQUcsRUFBSEE7RUFBSSxDQUFDO0FBQ3ZCO0FBQUMifQ==
|
package/lib/cjs/utils/index.js
CHANGED
|
@@ -3,4 +3,4 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3V0aWxzL2luZGV4LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgSVByb3BzIHtcbiAgcHJlZml4Q2xzPzogc3RyaW5nO1xuICBjbGFzc05hbWU/OiBzdHJpbmc7XG59XG4iXSwibWFwcGluZ3MiOiIifQ==
|