@uiw/react-codemirror 3.0.14 → 3.2.2
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 +29 -1
- package/{lib/cjs → esm}/codemirror.css +0 -0
- package/esm/index.js +137 -0
- package/esm/index.js.map +75 -0
- package/lib/{esm/codemirror.css → codemirror.css} +0 -0
- package/lib/index.js +197 -0
- package/lib/index.js.map +70 -0
- package/package.json +14 -14
- package/src/codemirror.css +345 -0
- package/src/index.js +110 -0
- package/typings/index.d.ts +12 -5
- package/lib/cjs/index.js +0 -192
- package/lib/esm/index.js +0 -166
package/lib/esm/index.js
DELETED
|
@@ -1,166 +0,0 @@
|
|
|
1
|
-
import _typeof from "@babel/runtime/helpers/typeof";
|
|
2
|
-
import _objectSpread from "@babel/runtime/helpers/objectSpread2";
|
|
3
|
-
import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
|
|
4
|
-
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
|
|
5
|
-
import _regeneratorRuntime from "@babel/runtime/regenerator";
|
|
6
|
-
import React, { useRef, useEffect, useImperativeHandle, useState, useMemo } from 'react';
|
|
7
|
-
import CodeMirror from 'codemirror';
|
|
8
|
-
import 'codemirror/mode/meta';
|
|
9
|
-
import './codemirror.css';
|
|
10
|
-
var defaultOptions = {
|
|
11
|
-
tabSize: 2,
|
|
12
|
-
autoCloseBrackets: true,
|
|
13
|
-
matchBrackets: true,
|
|
14
|
-
showCursorWhenSelecting: true,
|
|
15
|
-
// 显示行号
|
|
16
|
-
lineNumbers: true,
|
|
17
|
-
fullScreen: true
|
|
18
|
-
};
|
|
19
|
-
|
|
20
|
-
function ReactCodeMirror() {
|
|
21
|
-
var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
22
|
-
var ref = arguments.length > 1 ? arguments[1] : undefined;
|
|
23
|
-
var _props$options = props.options,
|
|
24
|
-
options = _props$options === void 0 ? {} : _props$options,
|
|
25
|
-
_props$value = props.value,
|
|
26
|
-
value = _props$value === void 0 ? '' : _props$value,
|
|
27
|
-
_props$width = props.width,
|
|
28
|
-
width = _props$width === void 0 ? '100%' : _props$width,
|
|
29
|
-
_props$height = props.height,
|
|
30
|
-
height = _props$height === void 0 ? '100%' : _props$height;
|
|
31
|
-
|
|
32
|
-
var _useState = useState(),
|
|
33
|
-
_useState2 = _slicedToArray(_useState, 2),
|
|
34
|
-
editor = _useState2[0],
|
|
35
|
-
setEditor = _useState2[1];
|
|
36
|
-
|
|
37
|
-
var textareaRef = useRef();
|
|
38
|
-
var lastestProps = useRef(props);
|
|
39
|
-
useImperativeHandle(ref, function () {
|
|
40
|
-
return {
|
|
41
|
-
editor: editor
|
|
42
|
-
};
|
|
43
|
-
}, [editor]);
|
|
44
|
-
lastestProps.current = props; // 将props中所有的事件处理函数映射并保存
|
|
45
|
-
|
|
46
|
-
function getEventHandleFromProps() {
|
|
47
|
-
var propNames = Object.keys(props);
|
|
48
|
-
var eventHandle = propNames.filter(function (keyName) {
|
|
49
|
-
return /^on+/.test(keyName);
|
|
50
|
-
});
|
|
51
|
-
var eventDict = {};
|
|
52
|
-
eventHandle.forEach(function (ele) {
|
|
53
|
-
var name = ele.slice(2);
|
|
54
|
-
|
|
55
|
-
if (name && name[0]) {
|
|
56
|
-
eventDict[ele] = name.replace(name[0], name[0].toLowerCase());
|
|
57
|
-
}
|
|
58
|
-
});
|
|
59
|
-
return eventDict;
|
|
60
|
-
} // http://codemirror.net/doc/manual.html#config
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
function setOptions(_x) {
|
|
64
|
-
return _setOptions.apply(this, arguments);
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
function _setOptions() {
|
|
68
|
-
_setOptions = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(instance) {
|
|
69
|
-
var opt,
|
|
70
|
-
mode,
|
|
71
|
-
_args = arguments;
|
|
72
|
-
return _regeneratorRuntime.wrap(function _callee$(_context) {
|
|
73
|
-
while (1) {
|
|
74
|
-
switch (_context.prev = _context.next) {
|
|
75
|
-
case 0:
|
|
76
|
-
opt = _args.length > 1 && _args[1] !== undefined ? _args[1] : {};
|
|
77
|
-
|
|
78
|
-
if (!(_typeof(opt) === 'object' && window)) {
|
|
79
|
-
_context.next = 8;
|
|
80
|
-
break;
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
mode = CodeMirror.findModeByName(opt.mode || '');
|
|
84
|
-
|
|
85
|
-
if (!(mode && mode.mode)) {
|
|
86
|
-
_context.next = 6;
|
|
87
|
-
break;
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
_context.next = 6;
|
|
91
|
-
return import("codemirror/mode/".concat(mode.mode, "/").concat(mode.mode, ".js"));
|
|
92
|
-
|
|
93
|
-
case 6:
|
|
94
|
-
if (mode) {
|
|
95
|
-
opt.mode = mode.mime;
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
Object.keys(opt).forEach(function (name) {
|
|
99
|
-
if ((opt[name] || opt[name] === false) && JSON.stringify(opt[name])) {
|
|
100
|
-
instance.setOption(name, opt[name]);
|
|
101
|
-
}
|
|
102
|
-
});
|
|
103
|
-
|
|
104
|
-
case 8:
|
|
105
|
-
case "end":
|
|
106
|
-
return _context.stop();
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
}, _callee);
|
|
110
|
-
}));
|
|
111
|
-
return _setOptions.apply(this, arguments);
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
useEffect(function () {
|
|
115
|
-
if (!editor && window) {
|
|
116
|
-
// 生成codemirror实例
|
|
117
|
-
var instance = CodeMirror.fromTextArea(textareaRef.current, _objectSpread(_objectSpread({}, defaultOptions), options));
|
|
118
|
-
var eventDict = getEventHandleFromProps();
|
|
119
|
-
Object.keys(eventDict).forEach(function (event) {
|
|
120
|
-
instance.on(eventDict[event], function () {
|
|
121
|
-
var _lastestProps$current;
|
|
122
|
-
|
|
123
|
-
return (_lastestProps$current = lastestProps.current)[event].apply(_lastestProps$current, arguments);
|
|
124
|
-
});
|
|
125
|
-
});
|
|
126
|
-
instance.setValue(value || '');
|
|
127
|
-
|
|
128
|
-
if (width || height) {
|
|
129
|
-
// 设置尺寸
|
|
130
|
-
instance.setSize(width, height);
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
setEditor(instance);
|
|
134
|
-
setOptions(instance, _objectSpread(_objectSpread({}, defaultOptions), options));
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
return function () {
|
|
138
|
-
if (editor && window) {
|
|
139
|
-
editor.toTextArea();
|
|
140
|
-
setEditor(undefined);
|
|
141
|
-
}
|
|
142
|
-
};
|
|
143
|
-
}, []);
|
|
144
|
-
useMemo(function () {
|
|
145
|
-
if (!editor || !window) return;
|
|
146
|
-
var val = editor.getValue();
|
|
147
|
-
|
|
148
|
-
if (value !== undefined && value !== val) {
|
|
149
|
-
editor.setValue(value);
|
|
150
|
-
}
|
|
151
|
-
}, [value]);
|
|
152
|
-
useMemo(function () {
|
|
153
|
-
if (!editor || !window) return;
|
|
154
|
-
editor.setSize(width, height);
|
|
155
|
-
}, [width, height]);
|
|
156
|
-
useMemo(function () {
|
|
157
|
-
if (!editor || !window) return;
|
|
158
|
-
setOptions(editor, _objectSpread(_objectSpread({}, defaultOptions), options));
|
|
159
|
-
}, [editor, options]);
|
|
160
|
-
return /*#__PURE__*/React.createElement("textarea", {
|
|
161
|
-
ref: textareaRef
|
|
162
|
-
});
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
export default /*#__PURE__*/React.forwardRef(ReactCodeMirror);
|
|
166
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.js"],"names":["React","useRef","useEffect","useImperativeHandle","useState","useMemo","CodeMirror","defaultOptions","tabSize","autoCloseBrackets","matchBrackets","showCursorWhenSelecting","lineNumbers","fullScreen","ReactCodeMirror","props","ref","options","value","width","height","editor","setEditor","textareaRef","lastestProps","current","getEventHandleFromProps","propNames","Object","keys","eventHandle","filter","keyName","test","eventDict","forEach","ele","name","slice","replace","toLowerCase","setOptions","instance","opt","window","mode","findModeByName","mime","JSON","stringify","setOption","fromTextArea","event","on","setValue","setSize","toTextArea","undefined","val","getValue","forwardRef"],"mappings":"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","sourcesContent":["import React, { useRef, useEffect, useImperativeHandle, useState, useMemo } from 'react';\nimport CodeMirror from 'codemirror';\nimport 'codemirror/mode/meta';\nimport './codemirror.css';\n\nconst defaultOptions = {\n  tabSize: 2,\n  autoCloseBrackets: true,\n  matchBrackets: true,\n  showCursorWhenSelecting: true,\n  // 显示行号\n  lineNumbers: true,\n  fullScreen: true,\n}\n\nfunction ReactCodeMirror(props = {}, ref) {\n  const { options = {}, value = '', width = '100%', height = '100%'  } = props;\n  const [editor, setEditor] = useState();\n  const textareaRef = useRef();\n  const lastestProps = useRef(props);\n\n  useImperativeHandle(ref, () => ({ editor }), [editor]);\n  lastestProps.current = props;\n  \n  // 将props中所有的事件处理函数映射并保存\n  function getEventHandleFromProps() {\n    const propNames = Object.keys(props);\n    const eventHandle = propNames.filter((keyName) => {\n      return /^on+/.test(keyName);\n    });\n\n    const eventDict = {};\n    eventHandle.forEach((ele) => {\n      const name = ele.slice(2);\n      if (name && name[0]) {\n        eventDict[ele] = name.replace(name[0], name[0].toLowerCase());\n      }\n    });\n\n    return eventDict;\n  }\n\n  // http://codemirror.net/doc/manual.html#config\n  async function setOptions(instance, opt = {}) {\n    if (typeof opt === 'object' && window) {\n      const mode = CodeMirror.findModeByName(opt.mode || '');\n      if (mode && mode.mode) {\n        await import(`codemirror/mode/${mode.mode}/${mode.mode}.js`);\n      }\n      if (mode) {\n        opt.mode = mode.mime;\n      }\n      Object.keys(opt).forEach((name) => {\n        if ((opt[name] || opt[name] === false) && JSON.stringify(opt[name])) {\n          instance.setOption(name, opt[name]);\n        }\n      });\n    }\n  }\n\n  useEffect(() => {\n    if (!editor && window) {\n      // 生成codemirror实例\n      const instance = CodeMirror.fromTextArea(textareaRef.current, {...defaultOptions, ...options});\n      const eventDict = getEventHandleFromProps();\n      Object.keys(eventDict).forEach((event) => {\n        instance.on(eventDict[event], (...params) => lastestProps.current[event](...params));\n      });\n      instance.setValue(value || '');\n\n      if (width || height) {\n        // 设置尺寸\n        instance.setSize(width, height);\n      }\n      setEditor(instance);\n      setOptions(instance, {...defaultOptions, ...options});\n    }\n    return () => {\n      if (editor && window) {\n        editor.toTextArea();\n        setEditor(undefined);\n      }\n    }\n  }, []);\n\n  useMemo(() => {\n    if (!editor || !window) return;\n    const val = editor.getValue();\n    if (value !== undefined && value !== val) {\n      editor.setValue(value);\n    }\n  }, [value]);\n\n  useMemo(() => {\n    if (!editor || !window) return;\n    editor.setSize(width, height);\n  }, [width, height]);\n\n\n  useMemo(() => {\n    if (!editor || !window) return;\n    setOptions(editor, {...defaultOptions, ...options});\n  }, [editor, options]);\n  \n  return (\n    <textarea ref={textareaRef} />\n  );\n}\n\nexport default React.forwardRef(ReactCodeMirror);\n"]}
|