Commit a812685084b45ce3c6b6675bb1569e324f742416

Authored by Vben
1 parent c04e8943

feat: add codeEditor component

CHANGELOG.zh_CN.md
@@ -3,6 +3,7 @@ @@ -3,6 +3,7 @@
3 ### ✨ Features 3 ### ✨ Features
4 4
5 - 新增图形编辑器示例 5 - 新增图形编辑器示例
  6 +- 新增代码编辑器(包含 Json 编辑器)
6 7
7 ### ⚡ Performance Improvements 8 ### ⚡ Performance Improvements
8 9
package.json
@@ -39,6 +39,7 @@ @@ -39,6 +39,7 @@
39 "@zxcvbn-ts/core": "^0.3.0", 39 "@zxcvbn-ts/core": "^0.3.0",
40 "ant-design-vue": "^2.1.2", 40 "ant-design-vue": "^2.1.2",
41 "axios": "^0.21.1", 41 "axios": "^0.21.1",
  42 + "codemirror": "^5.60.0",
42 "cropperjs": "^1.5.11", 43 "cropperjs": "^1.5.11",
43 "crypto-js": "^4.0.0", 44 "crypto-js": "^4.0.0",
44 "echarts": "^5.1.0", 45 "echarts": "^5.1.0",
@@ -64,6 +65,7 @@ @@ -64,6 +65,7 @@
64 "@commitlint/config-conventional": "^12.1.1", 65 "@commitlint/config-conventional": "^12.1.1",
65 "@iconify/json": "^1.1.330", 66 "@iconify/json": "^1.1.330",
66 "@purge-icons/generated": "^0.7.0", 67 "@purge-icons/generated": "^0.7.0",
  68 + "@types/codemirror": "^0.0.109",
67 "@types/crypto-js": "^4.0.1", 69 "@types/crypto-js": "^4.0.1",
68 "@types/fs-extra": "^9.0.11", 70 "@types/fs-extra": "^9.0.11",
69 "@types/inquirer": "^7.3.1", 71 "@types/inquirer": "^7.3.1",
src/components/CodeEditor/index.ts 0 → 100644
  1 +import type { App } from 'vue';
  2 +import codeEditor from './src/CodeEditor.vue';
  3 +
  4 +export const CodeEditor = Object.assign(codeEditor, {
  5 + install(app: App) {
  6 + app.component(codeEditor.name, codeEditor);
  7 + },
  8 +});
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
1 -import { App } from 'vue'; 1 +import type { App } from 'vue';
2 import dataDialog from './src/DataDialog.vue'; 2 import dataDialog from './src/DataDialog.vue';
3 import flowChart from './src/index.vue'; 3 import flowChart from './src/index.vue';
4 4
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,7 +19,7 @@
19 import { toLogicFlowData } from './adpterForTurbo'; 19 import { toLogicFlowData } from './adpterForTurbo';
20 20
21 import '@logicflow/core/dist/style/index.css'; 21 import '@logicflow/core/dist/style/index.css';
22 - import '@logicflow/extension/lib/style/index.css'; 22 + import './index.css';
23 export default defineComponent({ 23 export default defineComponent({
24 name: 'FlowChart', 24 name: 'FlowChart',
25 components: { FlowChartToolbar }, 25 components: { FlowChartToolbar },
src/components/Tinymce/src/Editor.vue
@@ -12,6 +12,40 @@ @@ -12,6 +12,40 @@
12 </template> 12 </template>
13 13
14 <script lang="ts"> 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 import { 49 import {
16 defineComponent, 50 defineComponent,
17 computed, 51 computed,
@@ -25,7 +59,7 @@ @@ -25,7 +59,7 @@
25 59
26 import ImgUpload from './ImgUpload.vue'; 60 import ImgUpload from './ImgUpload.vue';
27 61
28 - import { tinymce, toolbar, plugins } from './tinymce'; 62 + import { toolbar, plugins } from './tinymce';
29 63
30 import { buildShortUUID } from '/@/utils/uuid'; 64 import { buildShortUUID } from '/@/utils/uuid';
31 import { bindHandlers } from './helper'; 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 // Any plugins you want to setting has to be imported 1 // Any plugins you want to setting has to be imported
36 // Detail plugins list see https://www.tinymce.com/docs/plugins/ 2 // Detail plugins list see https://www.tinymce.com/docs/plugins/
37 // Custom builds see https://www.tinymce.com/download/custom-builds/ 3 // Custom builds see https://www.tinymce.com/download/custom-builds/
@@ -45,5 +11,3 @@ export const toolbar = [ @@ -45,5 +11,3 @@ export const toolbar = [
45 'fontsizeselect lineheight searchreplace bold italic underline strikethrough alignleft aligncenter alignright outdent indent blockquote undo redo removeformat subscript superscript code codesample', 11 'fontsizeselect lineheight searchreplace bold italic underline strikethrough alignleft aligncenter alignright outdent indent blockquote undo redo removeformat subscript superscript code codesample',
46 'hr bullist numlist link preview anchor pagebreak insertdatetime media forecolor backcolor fullscreen', 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
1 export default { 1 export default {
2 editor: 'Editor', 2 editor: 'Editor',
  3 + jsonEditor: 'Json editor',
3 markdown: 'Markdown editor', 4 markdown: 'Markdown editor',
4 5
5 tinymce: 'Rich text', 6 tinymce: 'Rich text',
src/locales/lang/zh_CN/routes/demo/editor.ts
1 export default { 1 export default {
2 editor: '编辑器', 2 editor: '编辑器',
  3 + jsonEditor: 'Json编辑器',
3 markdown: 'markdown编辑器', 4 markdown: 'markdown编辑器',
4 5
5 tinymce: '富文本', 6 tinymce: '富文本',
src/router/menus/modules/demo/comp.ts
@@ -6,7 +6,9 @@ const menu: MenuModule = { @@ -6,7 +6,9 @@ const menu: MenuModule = {
6 menu: { 6 menu: {
7 name: t('routes.demo.comp.comp'), 7 name: t('routes.demo.comp.comp'),
8 path: '/comp', 8 path: '/comp',
9 - 9 + tag: {
  10 + dot: true,
  11 + },
10 children: [ 12 children: [
11 { 13 {
12 path: 'basic', 14 path: 'basic',
@@ -181,8 +183,18 @@ const menu: MenuModule = { @@ -181,8 +183,18 @@ const menu: MenuModule = {
181 { 183 {
182 name: t('routes.demo.editor.editor'), 184 name: t('routes.demo.editor.editor'),
183 path: 'editor', 185 path: 'editor',
  186 + tag: {
  187 + dot: true,
  188 + },
184 children: [ 189 children: [
185 { 190 {
  191 + path: 'json',
  192 + name: t('routes.demo.editor.jsonEditor'),
  193 + tag: {
  194 + content: 'new',
  195 + },
  196 + },
  197 + {
186 path: 'markdown', 198 path: 'markdown',
187 name: t('routes.demo.editor.markdown'), 199 name: t('routes.demo.editor.markdown'),
188 children: [ 200 children: [
src/router/routes/modules/demo/comp.ts
@@ -304,6 +304,14 @@ const comp: AppRouteModule = { @@ -304,6 +304,14 @@ const comp: AppRouteModule = {
304 }, 304 },
305 children: [ 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 path: 'markdown', 315 path: 'markdown',
308 component: getParentLayout('MarkdownDemo'), 316 component: getParentLayout('MarkdownDemo'),
309 name: 'MarkdownDemo', 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
@@ -58,6 +58,7 @@ export default ({ command, mode }: ConfigEnv): UserConfig =&gt; { @@ -58,6 +58,7 @@ export default ({ command, mode }: ConfigEnv): UserConfig =&gt; {
58 proxy: createProxy(VITE_PROXY), 58 proxy: createProxy(VITE_PROXY),
59 }, 59 },
60 build: { 60 build: {
  61 + minify: 'esbuild',
61 target: 'es2015', 62 target: 'es2015',
62 outDir: OUTPUT_DIR, 63 outDir: OUTPUT_DIR,
63 terserOptions: { 64 terserOptions: {
yarn.lock
@@ -1301,11 +1301,23 @@ @@ -1301,11 +1301,23 @@
1301 resolved "https://registry.npmjs.org/@trysound/sax/-/sax-0.1.1.tgz#3348564048e7a2d7398c935d466c0414ebb6a669" 1301 resolved "https://registry.npmjs.org/@trysound/sax/-/sax-0.1.1.tgz#3348564048e7a2d7398c935d466c0414ebb6a669"
1302 integrity sha512-Z6DoceYb/1xSg5+e+ZlPZ9v0N16ZvZ+wYMraFue4HYrE4ttONKtsvruIRf6t9TBR0YvSOfi1hUU0fJfBLCDYow== 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 "@types/crypto-js@^4.0.1": 1311 "@types/crypto-js@^4.0.1":
1305 version "4.0.1" 1312 version "4.0.1"
1306 resolved "https://registry.npmjs.org/@types/crypto-js/-/crypto-js-4.0.1.tgz#3a4bd24518b0e6c5940da4e2659eeb2ef0806963" 1313 resolved "https://registry.npmjs.org/@types/crypto-js/-/crypto-js-4.0.1.tgz#3a4bd24518b0e6c5940da4e2659eeb2ef0806963"
1307 integrity sha512-6+OPzqhKX/cx5xh+yO8Cqg3u3alrkhoxhE5ZOdSEv0DOzJ13lwJ6laqGU0Kv6+XDMFmlnGId04LtY22PsFLQUw== 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 "@types/estree@0.0.39": 1321 "@types/estree@0.0.39":
1310 version "0.0.39" 1322 version "0.0.39"
1311 resolved "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz#e177e699ee1b8c22d23174caaa7422644389509f" 1323 resolved "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz#e177e699ee1b8c22d23174caaa7422644389509f"
@@ -1477,6 +1489,13 @@ @@ -1477,6 +1489,13 @@
1477 resolved "https://registry.npmjs.org/@types/svgo/-/svgo-1.3.5.tgz#18a0166fbcdfbfc7f17d0491da2ea07ee397d3f9" 1489 resolved "https://registry.npmjs.org/@types/svgo/-/svgo-1.3.5.tgz#18a0166fbcdfbfc7f17d0491da2ea07ee397d3f9"
1478 integrity sha512-y9Pw8IK50OqFRDpdI9Is29KlWiENVW9FDvlTmGHelvTfR2brYFJbsClvulZfeq6YKacFrDsG9a39w0kJZdHLaw== 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 "@types/through@*": 1499 "@types/through@*":
1481 version "0.0.30" 1500 version "0.0.30"
1482 resolved "https://registry.npmjs.org/@types/through/-/through-0.0.30.tgz#e0e42ce77e897bd6aead6f6ea62aeb135b8a3895" 1501 resolved "https://registry.npmjs.org/@types/through/-/through-0.0.30.tgz#e0e42ce77e897bd6aead6f6ea62aeb135b8a3895"
@@ -2610,6 +2629,11 @@ coa@^2.0.2: @@ -2610,6 +2629,11 @@ coa@^2.0.2:
2610 chalk "^2.4.1" 2629 chalk "^2.4.1"
2611 q "^1.1.2" 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 codepage@~1.14.0: 2637 codepage@~1.14.0:
2614 version "1.14.0" 2638 version "1.14.0"
2615 resolved "https://registry.npmjs.org/codepage/-/codepage-1.14.0.tgz#8cbe25481323559d7d307571b0fff91e7a1d2f99" 2639 resolved "https://registry.npmjs.org/codepage/-/codepage-1.14.0.tgz#8cbe25481323559d7d307571b0fff91e7a1d2f99"
@@ -7729,7 +7753,7 @@ rollup-plugin-visualizer@5.3.4: @@ -7729,7 +7753,7 @@ rollup-plugin-visualizer@5.3.4:
7729 source-map "^0.7.3" 7753 source-map "^0.7.3"
7730 yargs "^16.2.0" 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 version "2.45.2" 7757 version "2.45.2"
7734 resolved "https://registry.npmjs.org/rollup/-/rollup-2.45.2.tgz#8fb85917c9f35605720e92328f3ccbfba6f78b48" 7758 resolved "https://registry.npmjs.org/rollup/-/rollup-2.45.2.tgz#8fb85917c9f35605720e92328f3ccbfba6f78b48"
7735 integrity sha512-kRRU7wXzFHUzBIv0GfoFFIN3m9oteY4uAsKllIpQDId5cfnkWF2J130l+27dzDju0E6MScKiV0ZM5Bw8m4blYQ== 7759 integrity sha512-kRRU7wXzFHUzBIv0GfoFFIN3m9oteY4uAsKllIpQDId5cfnkWF2J130l+27dzDju0E6MScKiV0ZM5Bw8m4blYQ==