@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/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"]}