Commit a812685084b45ce3c6b6675bb1569e324f742416
1 parent
c04e8943
feat: add codeEditor component
Showing
19 changed files
with
1159 additions
and
41 deletions
CHANGELOG.zh_CN.md
package.json
... | ... | @@ -39,6 +39,7 @@ |
39 | 39 | "@zxcvbn-ts/core": "^0.3.0", |
40 | 40 | "ant-design-vue": "^2.1.2", |
41 | 41 | "axios": "^0.21.1", |
42 | + "codemirror": "^5.60.0", | |
42 | 43 | "cropperjs": "^1.5.11", |
43 | 44 | "crypto-js": "^4.0.0", |
44 | 45 | "echarts": "^5.1.0", |
... | ... | @@ -64,6 +65,7 @@ |
64 | 65 | "@commitlint/config-conventional": "^12.1.1", |
65 | 66 | "@iconify/json": "^1.1.330", |
66 | 67 | "@purge-icons/generated": "^0.7.0", |
68 | + "@types/codemirror": "^0.0.109", | |
67 | 69 | "@types/crypto-js": "^4.0.1", |
68 | 70 | "@types/fs-extra": "^9.0.11", |
69 | 71 | "@types/inquirer": "^7.3.1", | ... | ... |
src/components/CodeEditor/index.ts
0 → 100644
src/components/CodeEditor/src/CodeEditor.vue
0 → 100644
1 | +<template> | |
2 | + <div class="h-full"> | |
3 | + <CodeMirrorEditor :value="getValue" @change="handleValueChange" :mode="mode" /> | |
4 | + </div> | |
5 | +</template> | |
6 | +<script lang="ts"> | |
7 | + import { defineComponent, computed } from 'vue'; | |
8 | + import CodeMirrorEditor from './codemirror/CodeMirror.vue'; | |
9 | + import { isString } from '/@/utils/is'; | |
10 | + | |
11 | + const MODE = { | |
12 | + JSON: 'application/json', | |
13 | + html: 'htmlmixed', | |
14 | + js: 'javascript', | |
15 | + }; | |
16 | + export default defineComponent({ | |
17 | + name: 'CodeEditor', | |
18 | + components: { CodeMirrorEditor }, | |
19 | + props: { | |
20 | + value: { | |
21 | + type: [Object, String], | |
22 | + }, | |
23 | + mode: { | |
24 | + type: String, | |
25 | + default: MODE.JSON, | |
26 | + }, | |
27 | + }, | |
28 | + emits: ['change'], | |
29 | + setup(props, { emit }) { | |
30 | + const getValue = computed(() => { | |
31 | + const { value, mode } = props; | |
32 | + | |
33 | + if (mode === MODE.JSON) { | |
34 | + return isString(value) | |
35 | + ? JSON.stringify(JSON.parse(value), null, 2) | |
36 | + : JSON.stringify(value, null, 2); | |
37 | + } | |
38 | + return value; | |
39 | + }); | |
40 | + | |
41 | + function handleValueChange(v) { | |
42 | + emit('change', v); | |
43 | + } | |
44 | + | |
45 | + return { | |
46 | + handleValueChange, | |
47 | + getValue, | |
48 | + }; | |
49 | + }, | |
50 | + }); | |
51 | +</script> | ... | ... |
src/components/CodeEditor/src/codemirror/CodeMirror.vue
0 → 100644
1 | +<template> | |
2 | + <div class="relative h-100 !h-full w-full overflow-hidden" ref="el"> </div> | |
3 | +</template> | |
4 | + | |
5 | +<script lang="ts"> | |
6 | + import { | |
7 | + ref, | |
8 | + onMounted, | |
9 | + onUnmounted, | |
10 | + watchEffect, | |
11 | + watch, | |
12 | + defineComponent, | |
13 | + unref, | |
14 | + nextTick, | |
15 | + } from 'vue'; | |
16 | + import { useDebounceFn } from '@vueuse/core'; | |
17 | + import { useAppStore } from '/@/store/modules/app'; | |
18 | + | |
19 | + import CodeMirror from 'codemirror'; | |
20 | + import './codemirror.css'; | |
21 | + import 'codemirror/theme/idea.css'; | |
22 | + import 'codemirror/theme/material-palenight.css'; | |
23 | + | |
24 | + // modes | |
25 | + import 'codemirror/mode/javascript/javascript'; | |
26 | + import 'codemirror/mode/css/css'; | |
27 | + import 'codemirror/mode/htmlmixed/htmlmixed'; | |
28 | + export default defineComponent({ | |
29 | + props: { | |
30 | + mode: { | |
31 | + type: String, | |
32 | + default: 'application/json', | |
33 | + }, | |
34 | + value: { | |
35 | + type: String, | |
36 | + default: '', | |
37 | + }, | |
38 | + readonly: { | |
39 | + type: Boolean, | |
40 | + default: false, | |
41 | + }, | |
42 | + }, | |
43 | + emits: ['change'], | |
44 | + setup(props, { emit }) { | |
45 | + const el = ref(); | |
46 | + let editor: Nullable<CodeMirror.Editor>; | |
47 | + | |
48 | + const debounceRefresh = useDebounceFn(refresh, 100); | |
49 | + const appStore = useAppStore(); | |
50 | + | |
51 | + watch( | |
52 | + () => props.value, | |
53 | + async (v) => { | |
54 | + await nextTick(); | |
55 | + const oldValue = editor?.getValue(); | |
56 | + v && v !== oldValue && editor?.setValue(v); | |
57 | + }, | |
58 | + { flush: 'post' } | |
59 | + ); | |
60 | + | |
61 | + watchEffect(() => { | |
62 | + editor?.setOption('mode', props.mode); | |
63 | + }); | |
64 | + | |
65 | + watch( | |
66 | + () => appStore.getDarkMode, | |
67 | + async () => { | |
68 | + setTheme(); | |
69 | + }, | |
70 | + { | |
71 | + immediate: true, | |
72 | + } | |
73 | + ); | |
74 | + | |
75 | + function setTheme() { | |
76 | + unref(editor)?.setOption( | |
77 | + 'theme', | |
78 | + appStore.getDarkMode === 'light' ? 'idea' : 'material-palenight' | |
79 | + ); | |
80 | + } | |
81 | + | |
82 | + function refresh() { | |
83 | + editor?.refresh(); | |
84 | + } | |
85 | + | |
86 | + async function init() { | |
87 | + const addonOptions = { | |
88 | + autoCloseBrackets: true, | |
89 | + autoCloseTags: true, | |
90 | + foldGutter: true, | |
91 | + gutters: ['CodeMirror-linenumbers'], | |
92 | + }; | |
93 | + | |
94 | + editor = CodeMirror(el.value!, { | |
95 | + value: '', | |
96 | + mode: props.mode, | |
97 | + readOnly: props.readonly, | |
98 | + tabSize: 2, | |
99 | + theme: 'material-palenight', | |
100 | + lineWrapping: true, | |
101 | + lineNumbers: true, | |
102 | + ...addonOptions, | |
103 | + }); | |
104 | + editor?.setValue(props.value); | |
105 | + setTheme(); | |
106 | + editor?.on('change', () => { | |
107 | + emit('change', editor?.getValue()); | |
108 | + }); | |
109 | + } | |
110 | + | |
111 | + onMounted(async () => { | |
112 | + await nextTick(); | |
113 | + init(); | |
114 | + window.addEventListener('resize', debounceRefresh); | |
115 | + setTimeout(refresh, 50); | |
116 | + }); | |
117 | + | |
118 | + onUnmounted(() => { | |
119 | + window.removeEventListener('resize', debounceRefresh); | |
120 | + editor = null; | |
121 | + }); | |
122 | + return { el }; | |
123 | + }, | |
124 | + }); | |
125 | +</script> | ... | ... |
src/components/CodeEditor/src/codemirror/codeMirror.ts
0 → 100644
1 | +import CodeMirror from 'codemirror'; | |
2 | +import './codemirror.css'; | |
3 | +import 'codemirror/theme/idea.css'; | |
4 | +import 'codemirror/theme/material-palenight.css'; | |
5 | +// import 'codemirror/addon/lint/lint.css'; | |
6 | + | |
7 | +// modes | |
8 | +import 'codemirror/mode/javascript/javascript'; | |
9 | +import 'codemirror/mode/css/css'; | |
10 | +import 'codemirror/mode/htmlmixed/htmlmixed'; | |
11 | +// addons | |
12 | +// import 'codemirror/addon/edit/closebrackets'; | |
13 | +// import 'codemirror/addon/edit/closetag'; | |
14 | +// import 'codemirror/addon/comment/comment'; | |
15 | +// import 'codemirror/addon/fold/foldcode'; | |
16 | +// import 'codemirror/addon/fold/foldgutter'; | |
17 | +// import 'codemirror/addon/fold/brace-fold'; | |
18 | +// import 'codemirror/addon/fold/indent-fold'; | |
19 | +// import 'codemirror/addon/lint/json-lint'; | |
20 | +// import 'codemirror/addon/fold/comment-fold'; | |
21 | +export { CodeMirror }; | ... | ... |
src/components/CodeEditor/src/codemirror/codemirror.css
0 → 100644
1 | +/* BASICS */ | |
2 | + | |
3 | +.CodeMirror { | |
4 | + --base: #545281; | |
5 | + --comment: hsl(210, 25%, 60%); | |
6 | + --keyword: #af4ab1; | |
7 | + --variable: #0055d1; | |
8 | + --function: #c25205; | |
9 | + --string: #2ba46d; | |
10 | + --number: #c25205; | |
11 | + --tags: #d00; | |
12 | + --qualifier: #ff6032; | |
13 | + --important: var(--string); | |
14 | + | |
15 | + height: auto; | |
16 | + height: 100%; | |
17 | + font-family: var(--font-code); | |
18 | + direction: ltr; | |
19 | +} | |
20 | + | |
21 | +/* PADDING */ | |
22 | + | |
23 | +.CodeMirror-lines { | |
24 | + padding: 4px 0; /* Vertical padding around content */ | |
25 | +} | |
26 | + | |
27 | +.CodeMirror pre { | |
28 | + padding: 0 4px; /* Horizontal padding of content */ | |
29 | +} | |
30 | + | |
31 | +.CodeMirror-scrollbar-filler, | |
32 | +.CodeMirror-gutter-filler { | |
33 | + background-color: white; /* The little square between H and V scrollbars */ | |
34 | +} | |
35 | + | |
36 | +/* GUTTER */ | |
37 | + | |
38 | +.CodeMirror-gutters { | |
39 | + white-space: nowrap; | |
40 | + background-color: transparent; | |
41 | + border-right: 1px solid #ddd; | |
42 | +} | |
43 | + | |
44 | +.CodeMirror-linenumber { | |
45 | + min-width: 20px; | |
46 | + padding: 0 3px 0 5px; | |
47 | + color: var(--comment); | |
48 | + text-align: right; | |
49 | + white-space: nowrap; | |
50 | + opacity: 0.6; | |
51 | +} | |
52 | + | |
53 | +.CodeMirror-guttermarker { | |
54 | + color: black; | |
55 | +} | |
56 | + | |
57 | +.CodeMirror-guttermarker-subtle { | |
58 | + color: #999; | |
59 | +} | |
60 | + | |
61 | +/* FOLD GUTTER */ | |
62 | + | |
63 | +.CodeMirror-foldmarker { | |
64 | + font-family: arial; | |
65 | + line-height: 0.3; | |
66 | + color: #414141; | |
67 | + text-shadow: #f96 1px 1px 2px, #f96 -1px -1px 2px, #f96 1px -1px 2px, #f96 -1px 1px 2px; | |
68 | + cursor: pointer; | |
69 | +} | |
70 | + | |
71 | +.CodeMirror-foldgutter { | |
72 | + width: 0.7em; | |
73 | +} | |
74 | + | |
75 | +.CodeMirror-foldgutter-open, | |
76 | +.CodeMirror-foldgutter-folded { | |
77 | + cursor: pointer; | |
78 | +} | |
79 | + | |
80 | +.CodeMirror-foldgutter-open::after, | |
81 | +.CodeMirror-foldgutter-folded::after { | |
82 | + position: relative; | |
83 | + top: -0.1em; | |
84 | + display: inline-block; | |
85 | + font-size: 0.8em; | |
86 | + content: '>'; | |
87 | + opacity: 0.8; | |
88 | + transform: rotate(90deg); | |
89 | + transition: transform 0.2s; | |
90 | +} | |
91 | + | |
92 | +.CodeMirror-foldgutter-folded::after { | |
93 | + transform: none; | |
94 | +} | |
95 | + | |
96 | +/* CURSOR */ | |
97 | + | |
98 | +.CodeMirror-cursor { | |
99 | + width: 0; | |
100 | + border-right: none; | |
101 | + border-left: 1px solid black; | |
102 | +} | |
103 | + | |
104 | +/* Shown when moving in bi-directional text */ | |
105 | +.CodeMirror div.CodeMirror-secondarycursor { | |
106 | + border-left: 1px solid silver; | |
107 | +} | |
108 | + | |
109 | +.cm-fat-cursor .CodeMirror-cursor { | |
110 | + width: auto; | |
111 | + background: #7e7; | |
112 | + border: 0 !important; | |
113 | +} | |
114 | + | |
115 | +.cm-fat-cursor div.CodeMirror-cursors { | |
116 | + z-index: 1; | |
117 | +} | |
118 | + | |
119 | +.cm-fat-cursor-mark { | |
120 | + background-color: rgba(20, 255, 20, 0.5); | |
121 | + -webkit-animation: blink 1.06s steps(1) infinite; | |
122 | + -moz-animation: blink 1.06s steps(1) infinite; | |
123 | + animation: blink 1.06s steps(1) infinite; | |
124 | +} | |
125 | + | |
126 | +.cm-animate-fat-cursor { | |
127 | + width: auto; | |
128 | + background-color: #7e7; | |
129 | + border: 0; | |
130 | + -webkit-animation: blink 1.06s steps(1) infinite; | |
131 | + -moz-animation: blink 1.06s steps(1) infinite; | |
132 | + animation: blink 1.06s steps(1) infinite; | |
133 | +} | |
134 | +@-moz-keyframes blink { | |
135 | + 0% { | |
136 | + } | |
137 | + | |
138 | + 50% { | |
139 | + background-color: transparent; | |
140 | + } | |
141 | + | |
142 | + 100% { | |
143 | + } | |
144 | +} | |
145 | +@-webkit-keyframes blink { | |
146 | + 0% { | |
147 | + } | |
148 | + | |
149 | + 50% { | |
150 | + background-color: transparent; | |
151 | + } | |
152 | + | |
153 | + 100% { | |
154 | + } | |
155 | +} | |
156 | +@keyframes blink { | |
157 | + 0% { | |
158 | + } | |
159 | + | |
160 | + 50% { | |
161 | + background-color: transparent; | |
162 | + } | |
163 | + | |
164 | + 100% { | |
165 | + } | |
166 | +} | |
167 | + | |
168 | +.cm-tab { | |
169 | + display: inline-block; | |
170 | + text-decoration: inherit; | |
171 | +} | |
172 | + | |
173 | +.CodeMirror-rulers { | |
174 | + position: absolute; | |
175 | + top: -50px; | |
176 | + right: 0; | |
177 | + bottom: -20px; | |
178 | + left: 0; | |
179 | + overflow: hidden; | |
180 | +} | |
181 | + | |
182 | +.CodeMirror-ruler { | |
183 | + position: absolute; | |
184 | + top: 0; | |
185 | + bottom: 0; | |
186 | + border-left: 1px solid #ccc; | |
187 | +} | |
188 | + | |
189 | +/* DEFAULT THEME */ | |
190 | +.cm-s-default.CodeMirror { | |
191 | + background-color: transparent; | |
192 | +} | |
193 | + | |
194 | +.cm-s-default .cm-header { | |
195 | + color: blue; | |
196 | +} | |
197 | + | |
198 | +.cm-s-default .cm-quote { | |
199 | + color: #090; | |
200 | +} | |
201 | + | |
202 | +.cm-negative { | |
203 | + color: #d44; | |
204 | +} | |
205 | + | |
206 | +.cm-positive { | |
207 | + color: #292; | |
208 | +} | |
209 | + | |
210 | +.cm-header, | |
211 | +.cm-strong { | |
212 | + font-weight: bold; | |
213 | +} | |
214 | + | |
215 | +.cm-em { | |
216 | + font-style: italic; | |
217 | +} | |
218 | + | |
219 | +.cm-link { | |
220 | + text-decoration: underline; | |
221 | +} | |
222 | + | |
223 | +.cm-strikethrough { | |
224 | + text-decoration: line-through; | |
225 | +} | |
226 | + | |
227 | +.cm-s-default .cm-atom, | |
228 | +.cm-s-default .cm-def, | |
229 | +.cm-s-default .cm-property, | |
230 | +.cm-s-default .cm-variable-2, | |
231 | +.cm-s-default .cm-variable-3, | |
232 | +.cm-s-default .cm-punctuation { | |
233 | + color: var(--base); | |
234 | +} | |
235 | + | |
236 | +.cm-s-default .cm-hr, | |
237 | +.cm-s-default .cm-comment { | |
238 | + color: var(--comment); | |
239 | +} | |
240 | + | |
241 | +.cm-s-default .cm-attribute, | |
242 | +.cm-s-default .cm-keyword { | |
243 | + color: var(--keyword); | |
244 | +} | |
245 | + | |
246 | +.cm-s-default .cm-variable { | |
247 | + color: var(--variable); | |
248 | +} | |
249 | + | |
250 | +.cm-s-default .cm-bracket, | |
251 | +.cm-s-default .cm-tag { | |
252 | + color: var(--tags); | |
253 | +} | |
254 | + | |
255 | +.cm-s-default .cm-number { | |
256 | + color: var(--number); | |
257 | +} | |
258 | + | |
259 | +.cm-s-default .cm-string, | |
260 | +.cm-s-default .cm-string-2 { | |
261 | + color: var(--string); | |
262 | +} | |
263 | + | |
264 | +.cm-s-default .cm-type { | |
265 | + color: #085; | |
266 | +} | |
267 | + | |
268 | +.cm-s-default .cm-meta { | |
269 | + color: #555; | |
270 | +} | |
271 | + | |
272 | +.cm-s-default .cm-qualifier { | |
273 | + color: var(--qualifier); | |
274 | +} | |
275 | + | |
276 | +.cm-s-default .cm-builtin { | |
277 | + color: #7539ff; | |
278 | +} | |
279 | + | |
280 | +.cm-s-default .cm-link { | |
281 | + color: var(--flash); | |
282 | +} | |
283 | + | |
284 | +.cm-s-default .cm-error { | |
285 | + color: #ff008c; | |
286 | +} | |
287 | + | |
288 | +.cm-invalidchar { | |
289 | + color: #ff008c; | |
290 | +} | |
291 | + | |
292 | +.CodeMirror-composing { | |
293 | + border-bottom: 2px solid; | |
294 | +} | |
295 | + | |
296 | +/* Default styles for common addons */ | |
297 | + | |
298 | +div.CodeMirror span.CodeMirror-matchingbracket { | |
299 | + color: #0b0; | |
300 | +} | |
301 | + | |
302 | +div.CodeMirror span.CodeMirror-nonmatchingbracket { | |
303 | + color: #a22; | |
304 | +} | |
305 | + | |
306 | +.CodeMirror-matchingtag { | |
307 | + background: rgba(255, 150, 0, 0.3); | |
308 | +} | |
309 | + | |
310 | +.CodeMirror-activeline-background { | |
311 | + background: #e8f2ff; | |
312 | +} | |
313 | + | |
314 | +/* STOP */ | |
315 | + | |
316 | +/* The rest of this file contains styles related to the mechanics of | |
317 | + the editor. You probably shouldn't touch them. */ | |
318 | + | |
319 | +.CodeMirror { | |
320 | + position: relative; | |
321 | + overflow: hidden; | |
322 | + background: white; | |
323 | +} | |
324 | + | |
325 | +.CodeMirror-scroll { | |
326 | + position: relative; | |
327 | + height: 100%; | |
328 | + padding-bottom: 30px; | |
329 | + margin-right: -30px; | |
330 | + | |
331 | + /* 30px is the magic margin used to hide the element's real scrollbars */ | |
332 | + | |
333 | + /* See overflow: hidden in .CodeMirror */ | |
334 | + margin-bottom: -30px; | |
335 | + overflow: scroll !important; /* Things will break if this is overridden */ | |
336 | + outline: none; /* Prevent dragging from highlighting the element */ | |
337 | +} | |
338 | + | |
339 | +.CodeMirror-sizer { | |
340 | + position: relative; | |
341 | + border-right: 30px solid transparent; | |
342 | +} | |
343 | + | |
344 | +/* The fake, visible scrollbars. Used to force redraw during scrolling | |
345 | + before actual scrolling happens, thus preventing shaking and | |
346 | + flickering artifacts. */ | |
347 | +.CodeMirror-vscrollbar, | |
348 | +.CodeMirror-hscrollbar, | |
349 | +.CodeMirror-scrollbar-filler, | |
350 | +.CodeMirror-gutter-filler { | |
351 | + position: absolute; | |
352 | + z-index: 6; | |
353 | + display: none; | |
354 | +} | |
355 | + | |
356 | +.CodeMirror-vscrollbar { | |
357 | + top: 0; | |
358 | + right: 0; | |
359 | + overflow-x: hidden; | |
360 | + overflow-y: scroll; | |
361 | +} | |
362 | + | |
363 | +.CodeMirror-hscrollbar { | |
364 | + bottom: 0; | |
365 | + left: 0; | |
366 | + overflow-x: scroll; | |
367 | + overflow-y: hidden; | |
368 | +} | |
369 | + | |
370 | +.CodeMirror-scrollbar-filler { | |
371 | + right: 0; | |
372 | + bottom: 0; | |
373 | +} | |
374 | + | |
375 | +.CodeMirror-gutter-filler { | |
376 | + bottom: 0; | |
377 | + left: 0; | |
378 | +} | |
379 | + | |
380 | +.CodeMirror-gutters { | |
381 | + position: absolute; | |
382 | + top: 0; | |
383 | + left: 0; | |
384 | + z-index: 3; | |
385 | + min-height: 100%; | |
386 | +} | |
387 | + | |
388 | +.CodeMirror-gutter { | |
389 | + display: inline-block; | |
390 | + height: 100%; | |
391 | + margin-bottom: -30px; | |
392 | + white-space: normal; | |
393 | + vertical-align: top; | |
394 | +} | |
395 | + | |
396 | +.CodeMirror-gutter-wrapper { | |
397 | + position: absolute; | |
398 | + z-index: 4; | |
399 | + background: none !important; | |
400 | + border: none !important; | |
401 | +} | |
402 | + | |
403 | +.CodeMirror-gutter-background { | |
404 | + position: absolute; | |
405 | + top: 0; | |
406 | + bottom: 0; | |
407 | + z-index: 4; | |
408 | +} | |
409 | + | |
410 | +.CodeMirror-gutter-elt { | |
411 | + position: absolute; | |
412 | + z-index: 4; | |
413 | + cursor: default; | |
414 | +} | |
415 | + | |
416 | +.CodeMirror-gutter-wrapper ::selection { | |
417 | + background-color: transparent; | |
418 | +} | |
419 | + | |
420 | +.CodeMirror-gutter-wrapper ::-moz-selection { | |
421 | + background-color: transparent; | |
422 | +} | |
423 | + | |
424 | +.CodeMirror-lines { | |
425 | + min-height: 1px; /* prevents collapsing before first draw */ | |
426 | + cursor: text; | |
427 | +} | |
428 | + | |
429 | +.CodeMirror pre { | |
430 | + position: relative; | |
431 | + z-index: 2; | |
432 | + margin: 0; | |
433 | + overflow: visible; | |
434 | + font-family: inherit; | |
435 | + font-size: inherit; | |
436 | + line-height: inherit; | |
437 | + color: inherit; | |
438 | + word-wrap: normal; | |
439 | + white-space: pre; | |
440 | + background: transparent; | |
441 | + border-width: 0; | |
442 | + | |
443 | + /* Reset some styles that the rest of the page might have set */ | |
444 | + -moz-border-radius: 0; | |
445 | + -webkit-border-radius: 0; | |
446 | + border-radius: 0; | |
447 | + -webkit-tap-highlight-color: transparent; | |
448 | + -webkit-font-variant-ligatures: contextual; | |
449 | + font-variant-ligatures: contextual; | |
450 | +} | |
451 | + | |
452 | +.CodeMirror-wrap pre { | |
453 | + word-break: normal; | |
454 | + word-wrap: break-word; | |
455 | + white-space: pre-wrap; | |
456 | +} | |
457 | + | |
458 | +.CodeMirror-linebackground { | |
459 | + position: absolute; | |
460 | + top: 0; | |
461 | + right: 0; | |
462 | + bottom: 0; | |
463 | + left: 0; | |
464 | + z-index: 0; | |
465 | +} | |
466 | + | |
467 | +.CodeMirror-linewidget { | |
468 | + position: relative; | |
469 | + z-index: 2; | |
470 | + padding: 0.1px; /* Force widget margins to stay inside of the container */ | |
471 | +} | |
472 | + | |
473 | +.CodeMirror-rtl pre { | |
474 | + direction: rtl; | |
475 | +} | |
476 | + | |
477 | +.CodeMirror-code { | |
478 | + outline: none; | |
479 | +} | |
480 | + | |
481 | +/* Force content-box sizing for the elements where we expect it */ | |
482 | +.CodeMirror-scroll, | |
483 | +.CodeMirror-sizer, | |
484 | +.CodeMirror-gutter, | |
485 | +.CodeMirror-gutters, | |
486 | +.CodeMirror-linenumber { | |
487 | + -moz-box-sizing: content-box; | |
488 | + box-sizing: content-box; | |
489 | +} | |
490 | + | |
491 | +.CodeMirror-measure { | |
492 | + position: absolute; | |
493 | + width: 100%; | |
494 | + height: 0; | |
495 | + overflow: hidden; | |
496 | + visibility: hidden; | |
497 | +} | |
498 | + | |
499 | +.CodeMirror-cursor { | |
500 | + position: absolute; | |
501 | + pointer-events: none; | |
502 | +} | |
503 | + | |
504 | +.CodeMirror-measure pre { | |
505 | + position: static; | |
506 | +} | |
507 | + | |
508 | +div.CodeMirror-cursors { | |
509 | + position: relative; | |
510 | + z-index: 3; | |
511 | + visibility: hidden; | |
512 | +} | |
513 | + | |
514 | +div.CodeMirror-dragcursors { | |
515 | + visibility: visible; | |
516 | +} | |
517 | + | |
518 | +.CodeMirror-focused div.CodeMirror-cursors { | |
519 | + visibility: visible; | |
520 | +} | |
521 | + | |
522 | +.CodeMirror-selected { | |
523 | + background: #d9d9d9; | |
524 | +} | |
525 | + | |
526 | +.CodeMirror-focused .CodeMirror-selected { | |
527 | + background: #d7d4f0; | |
528 | +} | |
529 | + | |
530 | +.CodeMirror-crosshair { | |
531 | + cursor: crosshair; | |
532 | +} | |
533 | + | |
534 | +.CodeMirror-line::selection, | |
535 | +.CodeMirror-line > span::selection, | |
536 | +.CodeMirror-line > span > span::selection { | |
537 | + background: #d7d4f0; | |
538 | +} | |
539 | + | |
540 | +.CodeMirror-line::-moz-selection, | |
541 | +.CodeMirror-line > span::-moz-selection, | |
542 | +.CodeMirror-line > span > span::-moz-selection { | |
543 | + background: #d7d4f0; | |
544 | +} | |
545 | + | |
546 | +.cm-searching { | |
547 | + background-color: #ffa; | |
548 | + background-color: rgba(255, 255, 0, 0.4); | |
549 | +} | |
550 | + | |
551 | +/* Used to force a border model for a node */ | |
552 | +.cm-force-border { | |
553 | + padding-right: 0.1px; | |
554 | +} | |
555 | + | |
556 | +@media print { | |
557 | + /* Hide the cursor when printing */ | |
558 | + .CodeMirror div.CodeMirror-cursors { | |
559 | + visibility: hidden; | |
560 | + } | |
561 | +} | |
562 | + | |
563 | +/* See issue #2901 */ | |
564 | +.cm-tab-wrap-hack::after { | |
565 | + content: ''; | |
566 | +} | |
567 | + | |
568 | +/* Help users use markselection to safely style text background */ | |
569 | +span.CodeMirror-selectedtext { | |
570 | + background: none; | |
571 | +} | ... | ... |
src/components/FlowChart/index.ts
src/components/FlowChart/src/index.css
0 → 100644
1 | +.lf-control { | |
2 | + position: absolute; | |
3 | + top: 0; | |
4 | + right: 10px; | |
5 | + display: flex; | |
6 | + padding: 0 15px; | |
7 | + margin: 5px; | |
8 | + background: rgba(255, 255, 255, 0.8); | |
9 | + border-radius: 5px; | |
10 | + -webkit-box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3); | |
11 | + box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3); | |
12 | +} | |
13 | + | |
14 | +.lf-control-item { | |
15 | + display: flex; | |
16 | + padding: 5px 10px; | |
17 | + cursor: pointer; | |
18 | + flex-direction: column; | |
19 | + align-items: center; | |
20 | + justify-content: center; | |
21 | +} | |
22 | + | |
23 | +.lf-control-item:hover { | |
24 | + background: #efefef; | |
25 | +} | |
26 | + | |
27 | +.lf-control-item.disabled { | |
28 | + cursor: not-allowed; | |
29 | + filter: opacity(0.6); | |
30 | +} | |
31 | + | |
32 | +.lf-control-item.disabled:hover { | |
33 | + background: #fff; | |
34 | +} | |
35 | + | |
36 | +.lf-control-item.disabled i { | |
37 | + pointer-events: none; | |
38 | +} | |
39 | + | |
40 | +.lf-control-item i { | |
41 | + display: inline-block; | |
42 | + width: 20px; | |
43 | + height: 20px; | |
44 | + vertical-align: middle; | |
45 | + background-size: cover; | |
46 | +} | |
47 | + | |
48 | +.lf-control-text { | |
49 | + margin-top: 5px; | |
50 | + font-size: 12px; | |
51 | +} | |
52 | + | |
53 | +.lf-control-zoomOut { | |
54 | + background-image: url(); | |
55 | +} | |
56 | + | |
57 | +.lf-control-zoomIn { | |
58 | + background-image: url(); | |
59 | +} | |
60 | + | |
61 | +.lf-control-fit { | |
62 | + background-image: url(); | |
63 | +} | |
64 | + | |
65 | +.lf-control-undo { | |
66 | + background-image: url(); | |
67 | +} | |
68 | + | |
69 | +.lf-control-redo { | |
70 | + background-image: url(); | |
71 | +} | |
72 | + | |
73 | +/* menu */ | |
74 | +.lf-menu { | |
75 | + position: absolute; | |
76 | + display: none; | |
77 | + width: 200px; | |
78 | + padding: 10px 0; | |
79 | + margin: 0 0 0 10px; | |
80 | + background: #fff; | |
81 | + border: 1px solid #efefee; | |
82 | + border-radius: 3px; | |
83 | +} | |
84 | + | |
85 | +.lf-menu > li { | |
86 | + position: relative; | |
87 | + padding: 3px 12px; | |
88 | + font-size: 12px; | |
89 | + line-height: 18px; | |
90 | + list-style: none; | |
91 | + cursor: pointer; | |
92 | + transition: all 120ms ease-in-out; | |
93 | +} | |
94 | + | |
95 | +.lf-menu-item__disabled { | |
96 | + color: #aaa; | |
97 | + pointer-events: none; | |
98 | + cursor: default; | |
99 | + opacity: 0.88; | |
100 | +} | |
101 | + | |
102 | +.lf-menu-item:hover { | |
103 | + background: #f3f3f3; | |
104 | +} | |
105 | + | |
106 | +/* dnd */ | |
107 | +.lf-dnd { | |
108 | + position: absolute; | |
109 | + padding: 15px 5px; | |
110 | + margin: 5px; | |
111 | + background: rgba(255, 255, 255, 0.8); | |
112 | + border-radius: 5px; | |
113 | + box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3); | |
114 | +} | |
115 | + | |
116 | +.lf-dnd-item { | |
117 | + margin-top: 5px; | |
118 | + font-size: 14px; | |
119 | + text-align: center; | |
120 | +} | |
121 | + | |
122 | +.lf-dnd-item:first-child { | |
123 | + margin-top: 0; | |
124 | +} | |
125 | + | |
126 | +.lf-dnd-item div { | |
127 | + width: 40px; | |
128 | + height: 40px; | |
129 | +} | |
130 | + | |
131 | +.lf-dnd-item div:hover { | |
132 | + cursor: grab; | |
133 | +} | |
134 | + | |
135 | +.lf-dnd-circle { | |
136 | + background: url('') | |
137 | + center center no-repeat; | |
138 | +} | |
139 | + | |
140 | +.lf-dnd-rect { | |
141 | + background: url('') | |
142 | + center center no-repeat; | |
143 | +} | |
144 | + | |
145 | +.lf-dnd-polygon { | |
146 | + background: url('') | |
147 | + center center no-repeat; | |
148 | +} | |
149 | + | |
150 | +.lf-dnd-triangle { | |
151 | + background: url('') | |
152 | + center center no-repeat; | |
153 | +} | |
154 | + | |
155 | +.lf-dnd-hexagon { | |
156 | + background: url('') | |
157 | + center center no-repeat; | |
158 | +} | |
159 | + | |
160 | +.lf-dnd-star { | |
161 | + background: url('') | |
162 | + center center no-repeat; | |
163 | +} | |
164 | + | |
165 | +.lf-selection-select { | |
166 | + position: absolute; | |
167 | + border: 2px dashed darkorange; | |
168 | +} | |
169 | + | |
170 | +.lf-mini-map { | |
171 | + position: absolute; | |
172 | + padding-top: 20px; | |
173 | + overflow: hidden; | |
174 | + background: rgba(255, 255, 255, 1); | |
175 | + border: 1px solid #93a3b4; | |
176 | +} | |
177 | + | |
178 | +.lf-mini-map-graph { | |
179 | + position: relative; | |
180 | + overflow: hidden; | |
181 | +} | |
182 | + | |
183 | +.lf-minimap-viewport { | |
184 | + position: absolute; | |
185 | + top: 0; | |
186 | + left: 0; | |
187 | + cursor: grab; | |
188 | + border: 2px solid rgb(24, 125, 255); | |
189 | +} | |
190 | + | |
191 | +.lf-mini-map-header { | |
192 | + position: absolute; | |
193 | + top: 0; | |
194 | + right: 0; | |
195 | + left: 0; | |
196 | + height: 18px; | |
197 | + padding: 0 10px; | |
198 | + line-height: 18px; | |
199 | + text-shadow: 0 1px 0 rgb(255 255 255 / 33%); | |
200 | + background-color: #a6a6a6; | |
201 | + background-image: linear-gradient(to top, #b2b2b2, #9b9b9b); | |
202 | + border: 1px solid #999; | |
203 | + border-top: #bfbfbf solid 1px; | |
204 | + border-bottom: #666 solid 1px; | |
205 | +} | |
206 | + | |
207 | +.lf-mini-map-close { | |
208 | + position: absolute; | |
209 | + top: 0; | |
210 | + right: 2px; | |
211 | + width: 18px; | |
212 | + height: 18px; | |
213 | + cursor: pointer; | |
214 | + background-image: url(''); | |
215 | + background-size: contain; | |
216 | +} | ... | ... |
src/components/FlowChart/src/index.vue
... | ... | @@ -19,7 +19,7 @@ |
19 | 19 | import { toLogicFlowData } from './adpterForTurbo'; |
20 | 20 | |
21 | 21 | import '@logicflow/core/dist/style/index.css'; |
22 | - import '@logicflow/extension/lib/style/index.css'; | |
22 | + import './index.css'; | |
23 | 23 | export default defineComponent({ |
24 | 24 | name: 'FlowChart', |
25 | 25 | components: { FlowChartToolbar }, | ... | ... |
src/components/Tinymce/src/Editor.vue
... | ... | @@ -12,6 +12,40 @@ |
12 | 12 | </template> |
13 | 13 | |
14 | 14 | <script lang="ts"> |
15 | + import tinymce from 'tinymce/tinymce'; | |
16 | + import 'tinymce/themes/silver'; | |
17 | + | |
18 | + import 'tinymce/icons/default/icons'; | |
19 | + import 'tinymce/plugins/advlist'; | |
20 | + import 'tinymce/plugins/anchor'; | |
21 | + import 'tinymce/plugins/autolink'; | |
22 | + import 'tinymce/plugins/autosave'; | |
23 | + import 'tinymce/plugins/code'; | |
24 | + import 'tinymce/plugins/codesample'; | |
25 | + import 'tinymce/plugins/directionality'; | |
26 | + import 'tinymce/plugins/fullscreen'; | |
27 | + import 'tinymce/plugins/hr'; | |
28 | + import 'tinymce/plugins/insertdatetime'; | |
29 | + import 'tinymce/plugins/link'; | |
30 | + import 'tinymce/plugins/lists'; | |
31 | + import 'tinymce/plugins/media'; | |
32 | + import 'tinymce/plugins/nonbreaking'; | |
33 | + import 'tinymce/plugins/noneditable'; | |
34 | + import 'tinymce/plugins/pagebreak'; | |
35 | + import 'tinymce/plugins/paste'; | |
36 | + import 'tinymce/plugins/preview'; | |
37 | + import 'tinymce/plugins/print'; | |
38 | + import 'tinymce/plugins/save'; | |
39 | + import 'tinymce/plugins/searchreplace'; | |
40 | + import 'tinymce/plugins/spellchecker'; | |
41 | + import 'tinymce/plugins/tabfocus'; | |
42 | + // import 'tinymce/plugins/table'; | |
43 | + import 'tinymce/plugins/template'; | |
44 | + import 'tinymce/plugins/textpattern'; | |
45 | + import 'tinymce/plugins/visualblocks'; | |
46 | + import 'tinymce/plugins/visualchars'; | |
47 | + import 'tinymce/plugins/wordcount'; | |
48 | + | |
15 | 49 | import { |
16 | 50 | defineComponent, |
17 | 51 | computed, |
... | ... | @@ -25,7 +59,7 @@ |
25 | 59 | |
26 | 60 | import ImgUpload from './ImgUpload.vue'; |
27 | 61 | |
28 | - import { tinymce, toolbar, plugins } from './tinymce'; | |
62 | + import { toolbar, plugins } from './tinymce'; | |
29 | 63 | |
30 | 64 | import { buildShortUUID } from '/@/utils/uuid'; |
31 | 65 | import { bindHandlers } from './helper'; | ... | ... |
src/components/Tinymce/src/tinymce.ts
1 | -import tinymce from 'tinymce/tinymce'; | |
2 | -import 'tinymce/themes/silver'; | |
3 | - | |
4 | -import 'tinymce/icons/default/icons'; | |
5 | -import 'tinymce/plugins/advlist'; | |
6 | -import 'tinymce/plugins/anchor'; | |
7 | -import 'tinymce/plugins/autolink'; | |
8 | -import 'tinymce/plugins/autosave'; | |
9 | -import 'tinymce/plugins/code'; | |
10 | -import 'tinymce/plugins/codesample'; | |
11 | -import 'tinymce/plugins/directionality'; | |
12 | -import 'tinymce/plugins/fullscreen'; | |
13 | -import 'tinymce/plugins/hr'; | |
14 | -import 'tinymce/plugins/insertdatetime'; | |
15 | -import 'tinymce/plugins/link'; | |
16 | -import 'tinymce/plugins/lists'; | |
17 | -import 'tinymce/plugins/media'; | |
18 | -import 'tinymce/plugins/nonbreaking'; | |
19 | -import 'tinymce/plugins/noneditable'; | |
20 | -import 'tinymce/plugins/pagebreak'; | |
21 | -import 'tinymce/plugins/paste'; | |
22 | -import 'tinymce/plugins/preview'; | |
23 | -import 'tinymce/plugins/print'; | |
24 | -import 'tinymce/plugins/save'; | |
25 | -import 'tinymce/plugins/searchreplace'; | |
26 | -import 'tinymce/plugins/spellchecker'; | |
27 | -import 'tinymce/plugins/tabfocus'; | |
28 | -// import 'tinymce/plugins/table'; | |
29 | -import 'tinymce/plugins/template'; | |
30 | -import 'tinymce/plugins/textpattern'; | |
31 | -import 'tinymce/plugins/visualblocks'; | |
32 | -import 'tinymce/plugins/visualchars'; | |
33 | -import 'tinymce/plugins/wordcount'; | |
34 | - | |
35 | 1 | // Any plugins you want to setting has to be imported |
36 | 2 | // Detail plugins list see https://www.tinymce.com/docs/plugins/ |
37 | 3 | // Custom builds see https://www.tinymce.com/download/custom-builds/ |
... | ... | @@ -45,5 +11,3 @@ export const toolbar = [ |
45 | 11 | 'fontsizeselect lineheight searchreplace bold italic underline strikethrough alignleft aligncenter alignright outdent indent blockquote undo redo removeformat subscript superscript code codesample', |
46 | 12 | 'hr bullist numlist link preview anchor pagebreak insertdatetime media forecolor backcolor fullscreen', |
47 | 13 | ]; |
48 | - | |
49 | -export { tinymce }; | ... | ... |
src/locales/lang/en/routes/demo/editor.ts
src/locales/lang/zh_CN/routes/demo/editor.ts
src/router/menus/modules/demo/comp.ts
... | ... | @@ -6,7 +6,9 @@ const menu: MenuModule = { |
6 | 6 | menu: { |
7 | 7 | name: t('routes.demo.comp.comp'), |
8 | 8 | path: '/comp', |
9 | - | |
9 | + tag: { | |
10 | + dot: true, | |
11 | + }, | |
10 | 12 | children: [ |
11 | 13 | { |
12 | 14 | path: 'basic', |
... | ... | @@ -181,8 +183,18 @@ const menu: MenuModule = { |
181 | 183 | { |
182 | 184 | name: t('routes.demo.editor.editor'), |
183 | 185 | path: 'editor', |
186 | + tag: { | |
187 | + dot: true, | |
188 | + }, | |
184 | 189 | children: [ |
185 | 190 | { |
191 | + path: 'json', | |
192 | + name: t('routes.demo.editor.jsonEditor'), | |
193 | + tag: { | |
194 | + content: 'new', | |
195 | + }, | |
196 | + }, | |
197 | + { | |
186 | 198 | path: 'markdown', |
187 | 199 | name: t('routes.demo.editor.markdown'), |
188 | 200 | children: [ | ... | ... |
src/router/routes/modules/demo/comp.ts
... | ... | @@ -304,6 +304,14 @@ const comp: AppRouteModule = { |
304 | 304 | }, |
305 | 305 | children: [ |
306 | 306 | { |
307 | + path: 'json', | |
308 | + component: () => import('/@/views/demo/editor/json/index.vue'), | |
309 | + name: 'JsonEditorDemo', | |
310 | + meta: { | |
311 | + title: t('routes.demo.editor.jsonEditor'), | |
312 | + }, | |
313 | + }, | |
314 | + { | |
307 | 315 | path: 'markdown', |
308 | 316 | component: getParentLayout('MarkdownDemo'), |
309 | 317 | name: 'MarkdownDemo', | ... | ... |
src/views/demo/editor/json/index.vue
0 → 100644
1 | +<template> | |
2 | + <PageWrapper title="代码编辑器组件示例" contentFullHeight fixedHeight contentBackground> | |
3 | + <template #extra> | |
4 | + <RadioGroup button-style="solid" v-model:value="modeValue" @change="handleModeChange"> | |
5 | + <RadioButton value="application/json"> json数据 </RadioButton> | |
6 | + <RadioButton value="htmlmixed"> html代码 </RadioButton> | |
7 | + <RadioButton value="javascript"> javascript代码 </RadioButton> | |
8 | + </RadioGroup> | |
9 | + </template> | |
10 | + <CodeEditor v-model:value="value" :mode="modeValue" /> | |
11 | + </PageWrapper> | |
12 | +</template> | |
13 | +<script lang="ts"> | |
14 | + import { defineComponent, ref } from 'vue'; | |
15 | + import { CodeEditor } from '/@/components/CodeEditor'; | |
16 | + import { PageWrapper } from '/@/components/Page'; | |
17 | + import { Radio } from 'ant-design-vue'; | |
18 | + | |
19 | + const jsonData = | |
20 | + '{"name":"BeJson","url":"http://www.xxx.com","page":88,"isNonProfit":true,"address":{"street":"科技园路.","city":"江苏苏州","country":"中国"},"links":[{"name":"Google","url":"http://www.xxx.com"},{"name":"Baidu","url":"http://www.xxx.com"},{"name":"SoSo","url":"http://www.xxx.com"}]}'; | |
21 | + | |
22 | + const jsData = ` | |
23 | + (() => { | |
24 | + var htmlRoot = document.getElementById('htmlRoot'); | |
25 | + var theme = window.localStorage.getItem('__APP__DARK__MODE__'); | |
26 | + if (htmlRoot && theme) { | |
27 | + htmlRoot.setAttribute('data-theme', theme); | |
28 | + theme = htmlRoot = null; | |
29 | + } | |
30 | + })(); | |
31 | + `; | |
32 | + | |
33 | + const htmlData = ` | |
34 | + <!DOCTYPE html> | |
35 | +<html lang="en" id="htmlRoot"> | |
36 | + <head> | |
37 | + <meta charset="UTF-8" /> | |
38 | + <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" /> | |
39 | + <meta name="renderer" content="webkit" /> | |
40 | + <meta | |
41 | + name="viewport" | |
42 | + content="width=device-width,initial-scale=1.0,minimum-scale=1.0,maximum-scale=1.0,user-scalable=0" | |
43 | + /> | |
44 | + <title><%= title %></title> | |
45 | + <link rel="icon" href="/favicon.ico" /> | |
46 | + </head> | |
47 | + <body> | |
48 | + <div id="app"> | |
49 | + </div> | |
50 | + </body> | |
51 | +</html> | |
52 | + `; | |
53 | + export default defineComponent({ | |
54 | + components: { CodeEditor, PageWrapper, RadioButton: Radio.Button, RadioGroup: Radio.Group }, | |
55 | + setup() { | |
56 | + const modeValue = ref('application/json'); | |
57 | + const value = ref(jsonData); | |
58 | + | |
59 | + function handleModeChange(e: ChangeEvent) { | |
60 | + const mode = e.target.value; | |
61 | + if (mode === 'application/json') { | |
62 | + value.value = jsonData; | |
63 | + return; | |
64 | + } | |
65 | + if (mode === 'htmlmixed') { | |
66 | + value.value = htmlData; | |
67 | + return; | |
68 | + } | |
69 | + if (mode === 'javascript') { | |
70 | + value.value = jsData; | |
71 | + return; | |
72 | + } | |
73 | + } | |
74 | + | |
75 | + return { value, modeValue, handleModeChange }; | |
76 | + }, | |
77 | + }); | |
78 | +</script> | ... | ... |
vite.config.ts
yarn.lock
... | ... | @@ -1301,11 +1301,23 @@ |
1301 | 1301 | resolved "https://registry.npmjs.org/@trysound/sax/-/sax-0.1.1.tgz#3348564048e7a2d7398c935d466c0414ebb6a669" |
1302 | 1302 | integrity sha512-Z6DoceYb/1xSg5+e+ZlPZ9v0N16ZvZ+wYMraFue4HYrE4ttONKtsvruIRf6t9TBR0YvSOfi1hUU0fJfBLCDYow== |
1303 | 1303 | |
1304 | +"@types/codemirror@^0.0.109": | |
1305 | + version "0.0.109" | |
1306 | + resolved "https://registry.npmjs.org/@types/codemirror/-/codemirror-0.0.109.tgz#89d575ff1c7b462c4c3b8654f8bb38e5622e9036" | |
1307 | + integrity sha512-cSdiHeeLjvGn649lRTNeYrVCDOgDrtP+bDDSFDd1TF+i0jKGPDRozno2NOJ9lTniso+taiv4kiVS8dgM8Jm5lg== | |
1308 | + dependencies: | |
1309 | + "@types/tern" "*" | |
1310 | + | |
1304 | 1311 | "@types/crypto-js@^4.0.1": |
1305 | 1312 | version "4.0.1" |
1306 | 1313 | resolved "https://registry.npmjs.org/@types/crypto-js/-/crypto-js-4.0.1.tgz#3a4bd24518b0e6c5940da4e2659eeb2ef0806963" |
1307 | 1314 | integrity sha512-6+OPzqhKX/cx5xh+yO8Cqg3u3alrkhoxhE5ZOdSEv0DOzJ13lwJ6laqGU0Kv6+XDMFmlnGId04LtY22PsFLQUw== |
1308 | 1315 | |
1316 | +"@types/estree@*": | |
1317 | + version "0.0.47" | |
1318 | + resolved "https://registry.npmjs.org/@types/estree/-/estree-0.0.47.tgz#d7a51db20f0650efec24cd04994f523d93172ed4" | |
1319 | + integrity sha512-c5ciR06jK8u9BstrmJyO97m+klJrrhCf9u3rLu3DEAJBirxRqSCvDQoYKmxuYwQI5SZChAWu+tq9oVlGRuzPAg== | |
1320 | + | |
1309 | 1321 | "@types/estree@0.0.39": |
1310 | 1322 | version "0.0.39" |
1311 | 1323 | resolved "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz#e177e699ee1b8c22d23174caaa7422644389509f" |
... | ... | @@ -1477,6 +1489,13 @@ |
1477 | 1489 | resolved "https://registry.npmjs.org/@types/svgo/-/svgo-1.3.5.tgz#18a0166fbcdfbfc7f17d0491da2ea07ee397d3f9" |
1478 | 1490 | integrity sha512-y9Pw8IK50OqFRDpdI9Is29KlWiENVW9FDvlTmGHelvTfR2brYFJbsClvulZfeq6YKacFrDsG9a39w0kJZdHLaw== |
1479 | 1491 | |
1492 | +"@types/tern@*": | |
1493 | + version "0.23.3" | |
1494 | + resolved "https://registry.npmjs.org/@types/tern/-/tern-0.23.3.tgz#4b54538f04a88c9ff79de1f6f94f575a7f339460" | |
1495 | + integrity sha512-imDtS4TAoTcXk0g7u4kkWqedB3E4qpjXzCpD2LU5M5NAXHzCDsypyvXSaG7mM8DKYkCRa7tFp4tS/lp/Wo7Q3w== | |
1496 | + dependencies: | |
1497 | + "@types/estree" "*" | |
1498 | + | |
1480 | 1499 | "@types/through@*": |
1481 | 1500 | version "0.0.30" |
1482 | 1501 | resolved "https://registry.npmjs.org/@types/through/-/through-0.0.30.tgz#e0e42ce77e897bd6aead6f6ea62aeb135b8a3895" |
... | ... | @@ -2610,6 +2629,11 @@ coa@^2.0.2: |
2610 | 2629 | chalk "^2.4.1" |
2611 | 2630 | q "^1.1.2" |
2612 | 2631 | |
2632 | +codemirror@^5.60.0: | |
2633 | + version "5.60.0" | |
2634 | + resolved "https://registry.npmjs.org/codemirror/-/codemirror-5.60.0.tgz#00a8cfd287d5d8737ceb73987f04aee2fe5860da" | |
2635 | + integrity sha512-AEL7LhFOlxPlCL8IdTcJDblJm8yrAGib7I+DErJPdZd4l6imx8IMgKK3RblVgBQqz3TZJR4oknQ03bz+uNjBYA== | |
2636 | + | |
2613 | 2637 | codepage@~1.14.0: |
2614 | 2638 | version "1.14.0" |
2615 | 2639 | resolved "https://registry.npmjs.org/codepage/-/codepage-1.14.0.tgz#8cbe25481323559d7d307571b0fff91e7a1d2f99" |
... | ... | @@ -7729,7 +7753,7 @@ rollup-plugin-visualizer@5.3.4: |
7729 | 7753 | source-map "^0.7.3" |
7730 | 7754 | yargs "^16.2.0" |
7731 | 7755 | |
7732 | -rollup@^2.25.0, rollup@^2.38.5, rollup@^2.44.0: | |
7756 | +rollup@^2.25.0, rollup@^2.38.5, rollup@^2.44.0, rollup@^2.45.2: | |
7733 | 7757 | version "2.45.2" |
7734 | 7758 | resolved "https://registry.npmjs.org/rollup/-/rollup-2.45.2.tgz#8fb85917c9f35605720e92328f3ccbfba6f78b48" |
7735 | 7759 | integrity sha512-kRRU7wXzFHUzBIv0GfoFFIN3m9oteY4uAsKllIpQDId5cfnkWF2J130l+27dzDju0E6MScKiV0ZM5Bw8m4blYQ== | ... | ... |