From 1b9f74167e7aa348b7a2c9a8dbfdb9a3962ff9ad Mon Sep 17 00:00:00 2001 From: Mister-Hope Date: Thu, 26 Dec 2024 01:52:49 +0800 Subject: [PATCH] feat: add chart plugin --- .vscode/settings.json | 6 + docs/.vuepress/config.ts | 9 + docs/package.json | 7 + .../plugins/markdown/markdown-chart/README.md | 58 + .../markdown/markdown-chart/chartjs.md | 294 ++++ .../markdown/markdown-chart/echarts.md | 198 +++ .../markdown/markdown-chart/flowchart.md | 357 +++++ .../markdown/markdown-chart/markmap.md | 102 ++ .../markdown/markdown-chart/mermaid.md | 576 +++++++ .../markdown/markdown-chart/plantuml.md | 667 ++++++++ .../plugin-markdown-chart/package.json | 97 ++ .../plugin-markdown-chart/rollup.config.ts | 16 + .../src/client/components/ChartJS.ts | 142 ++ .../src/client/components/ECharts.ts | 142 ++ .../src/client/components/FlowChart.ts | 112 ++ .../src/client/components/MarkMap.ts | 113 ++ .../src/client/components/Mermaid.ts | 228 +++ .../src/client/helpers/echarts.ts | 38 + .../src/client/helpers/index.ts | 2 + .../src/client/helpers/mermaid.ts | 20 + .../plugin-markdown-chart/src/client/index.ts | 1 + .../src/client/styles/chartjs.scss | 26 + .../src/client/styles/echarts.scss | 34 + .../src/client/styles/flowchart.scss | 33 + .../src/client/styles/markmap.scss | 125 ++ .../src/client/styles/mermaid.scss | 96 ++ .../src/client/typings/index.ts | 1 + .../src/client/typings/mermaid.ts | 171 ++ .../src/client/utils/flowchart-presets/ant.ts | 52 + .../client/utils/flowchart-presets/base.ts | 16 + .../client/utils/flowchart-presets/index.ts | 15 + .../src/client/utils/flowchart-presets/pie.ts | 52 + .../src/client/utils/flowchart-presets/vue.ts | 52 + .../src/client/utils/index.ts | 1 + .../plugin-markdown-chart/src/node/index.ts | 3 + .../src/node/markdown-it-plugins/chartjs.ts | 47 + .../src/node/markdown-it-plugins/echarts.ts | 74 + .../src/node/markdown-it-plugins/flowchart.ts | 31 + .../src/node/markdown-it-plugins/index.ts | 6 + .../src/node/markdown-it-plugins/markmap.ts | 28 + .../src/node/markdown-it-plugins/mermaid.ts | 109 ++ .../src/node/markdown-it-plugins/plantuml.ts | 24 + .../src/node/markdownChartPlugin.ts | 117 ++ .../plugin-markdown-chart/src/node/options.ts | 70 + .../src/node/prepareConfigFile.ts | 64 + .../plugin-markdown-chart/src/node/utils.ts | 25 + .../plugin-markdown-chart/src/shims.d.ts | 6 + .../node/__snapshots__/chartjs.spec.ts.snap | 15 + .../node/__snapshots__/echarts.spec.ts.snap | 19 + .../node/__snapshots__/flowchart.spec.ts.snap | 47 + .../node/__snapshots__/markmap.spec.ts.snap | 66 + .../node/__snapshots__/mermaid.spec.ts.snap | 124 ++ .../tests/node/chartjs.spec.ts | 203 +++ .../tests/node/echarts.spec.ts | 185 +++ .../tests/node/flowchart.spec.ts | 90 ++ .../tests/node/markmap.spec.ts | 66 + .../tests/node/mermaid.spec.ts | 276 ++++ .../plugin-markdown-chart/tsconfig.build.json | 10 + pnpm-lock.yaml | 1422 ++++++++++++++++- tsconfig.build.json | 1 + 60 files changed, 6900 insertions(+), 87 deletions(-) create mode 100644 docs/plugins/markdown/markdown-chart/README.md create mode 100644 docs/plugins/markdown/markdown-chart/chartjs.md create mode 100644 docs/plugins/markdown/markdown-chart/echarts.md create mode 100644 docs/plugins/markdown/markdown-chart/flowchart.md create mode 100644 docs/plugins/markdown/markdown-chart/markmap.md create mode 100644 docs/plugins/markdown/markdown-chart/mermaid.md create mode 100644 docs/plugins/markdown/markdown-chart/plantuml.md create mode 100644 plugins/markdown/plugin-markdown-chart/package.json create mode 100644 plugins/markdown/plugin-markdown-chart/rollup.config.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/components/ChartJS.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/components/ECharts.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/components/FlowChart.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/components/MarkMap.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/components/Mermaid.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/helpers/echarts.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/helpers/index.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/helpers/mermaid.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/index.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/styles/chartjs.scss create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/styles/echarts.scss create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/styles/flowchart.scss create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/styles/markmap.scss create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/styles/mermaid.scss create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/typings/index.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/typings/mermaid.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/utils/flowchart-presets/ant.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/utils/flowchart-presets/base.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/utils/flowchart-presets/index.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/utils/flowchart-presets/pie.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/utils/flowchart-presets/vue.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/client/utils/index.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/node/index.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/chartjs.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/echarts.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/flowchart.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/index.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/markmap.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/mermaid.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/plantuml.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/node/markdownChartPlugin.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/node/options.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/node/prepareConfigFile.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/node/utils.ts create mode 100644 plugins/markdown/plugin-markdown-chart/src/shims.d.ts create mode 100644 plugins/markdown/plugin-markdown-chart/tests/node/__snapshots__/chartjs.spec.ts.snap create mode 100644 plugins/markdown/plugin-markdown-chart/tests/node/__snapshots__/echarts.spec.ts.snap create mode 100644 plugins/markdown/plugin-markdown-chart/tests/node/__snapshots__/flowchart.spec.ts.snap create mode 100644 plugins/markdown/plugin-markdown-chart/tests/node/__snapshots__/markmap.spec.ts.snap create mode 100644 plugins/markdown/plugin-markdown-chart/tests/node/__snapshots__/mermaid.spec.ts.snap create mode 100644 plugins/markdown/plugin-markdown-chart/tests/node/chartjs.spec.ts create mode 100644 plugins/markdown/plugin-markdown-chart/tests/node/echarts.spec.ts create mode 100644 plugins/markdown/plugin-markdown-chart/tests/node/flowchart.spec.ts create mode 100644 plugins/markdown/plugin-markdown-chart/tests/node/markmap.spec.ts create mode 100644 plugins/markdown/plugin-markdown-chart/tests/node/mermaid.spec.ts create mode 100644 plugins/markdown/plugin-markdown-chart/tsconfig.build.json diff --git a/.vscode/settings.json b/.vscode/settings.json index 7e6fc720b8..213efc4d5b 100644 --- a/.vscode/settings.json +++ b/.vscode/settings.json @@ -27,17 +27,20 @@ "artalk", "bumpp", "commitlint", + "chartjs", "composables", "darkmode", "devtool", "docsearch", "domhandler", + "echarts", "envinfo", "esbuild", "execa", "fflate", "frontmatter", "fullscreen", + "gantt", "giscus", "globby", "gtag", @@ -46,9 +49,11 @@ "lazyload", "lightmode", "linkify", + "markmap", "mathjax", "mdit", "meteorlxy", + "mindmap", "nord", "npmmirror", "nprogress", @@ -56,6 +61,7 @@ "pageviews", "pengzhanbo", "photoswipe", + "plantuml", "prefetch", "preload", "prismjs", diff --git a/docs/.vuepress/config.ts b/docs/.vuepress/config.ts index b27210e7f5..e95c9013ec 100644 --- a/docs/.vuepress/config.ts +++ b/docs/.vuepress/config.ts @@ -8,6 +8,7 @@ import { commentPlugin } from '@vuepress/plugin-comment' import { docsearchPlugin } from '@vuepress/plugin-docsearch' import { feedPlugin } from '@vuepress/plugin-feed' import { markdownExtPlugin } from '@vuepress/plugin-markdown-ext' +import { markdownChartPlugin } from '@vuepress/plugin-markdown-chart' import { markdownImagePlugin } from '@vuepress/plugin-markdown-image' import { markdownIncludePlugin } from '@vuepress/plugin-markdown-include' import { markdownMathPlugin } from '@vuepress/plugin-markdown-math' @@ -85,6 +86,14 @@ export default defineUserConfig({ json: true, rss: true, }), + markdownChartPlugin({ + chartjs: true, + echarts: true, + flowchart: true, + markmap: true, + mermaid: true, + plantuml: true, + }), markdownExtPlugin({ gfm: true, component: true, diff --git a/docs/package.json b/docs/package.json index a579aec532..2c7aa77ce7 100644 --- a/docs/package.json +++ b/docs/package.json @@ -19,6 +19,7 @@ "@vuepress/plugin-copy-code": "workspace:*", "@vuepress/plugin-docsearch": "workspace:*", "@vuepress/plugin-feed": "workspace:*", + "@vuepress/plugin-markdown-chart": "workspace:*", "@vuepress/plugin-markdown-ext": "workspace:*", "@vuepress/plugin-markdown-image": "workspace:*", "@vuepress/plugin-markdown-include": "workspace:*", @@ -35,7 +36,13 @@ "@vuepress/plugin-search": "workspace:*", "@vuepress/plugin-shiki": "workspace:*", "@vuepress/theme-default": "workspace:*", + "chart.js": "4.4.6", + "echarts": "5.5.1", + "flowchart.ts": "3.0.1", "katex": "0.16.18", + "markmap-lib": "0.17.2", + "markmap-toolbar": "0.17.2", + "markmap-view": "0.17.2", "mathjax-full": "3.2.2", "sass-embedded": "catalog:", "sass-loader": "^16.0.4", diff --git a/docs/plugins/markdown/markdown-chart/README.md b/docs/plugins/markdown/markdown-chart/README.md new file mode 100644 index 0000000000..f1afb6ad2b --- /dev/null +++ b/docs/plugins/markdown/markdown-chart/README.md @@ -0,0 +1,58 @@ +# markdown-chart + + + +Add powerful charts to your VuePress site. + +This plugin provides 6 ways to let you insert charts into your markdown file. + +- chart.js: A lightweight, easy-to-use, highly customizable chart library. + + chart.js is lighter comparing to echarts. + +- echarts: A powerful, interactive charting and visualization library for browser. + + echarts is more powerful comparing to chart.js. + +- Flowchart: A simple markdown extension to generate flowcharts and sequence diagrams. + + Lightweight, only focusing on flowcharts. + +- Markmap: Create mindmap with markdown + + The runtime is very heavy, not recommended. + +- Mermaid: Generation of diagram and flowchart from text in a similar manner as markdown. + + Powerful collection of common charts. + +- Plantuml: UML diagram driven by Java. + + No runtime, diagram render is processed on plantuml server. + +## Usage + +```bash +npm i -D @vuepress/plugin-markdown-chart@next +``` + +```ts +import { markdownChartPlugin } from '@vuepress/plugin-markdown-chart' + +export default { + plugins: [ + markdownChartPlugin({ + // Enable chart.js + chartjs: true, + // Enable echarts + echarts: true, + // Enable flowchart.ts + flowchart: true, + // Enable markmap + markmap: true, + // Enable mermaid + mermaid: true, + }), + ], +} +``` diff --git a/docs/plugins/markdown/markdown-chart/chartjs.md b/docs/plugins/markdown/markdown-chart/chartjs.md new file mode 100644 index 0000000000..e3c0befb2a --- /dev/null +++ b/docs/plugins/markdown/markdown-chart/chartjs.md @@ -0,0 +1,294 @@ +--- +title: Chart.js +icon: chart-simple +--- + +Add [chart.js][] support to the Markdown files in your VuePress site. + +[chart.js]: https://www.chartjs.org/docs/latest/ + + + +## Settings + +Install [chart.js][] in your project: + +::: code-tabs#shell + +@tab pnpm + +```bash +pnpm add -D chart.js +``` + +@tab yarn + +```bash +yarn add -D chart.js +``` + +@tab npm + +```bash +npm i -D chart.js +``` + +::: + +Then enabling via: + +```js {7} title=".vuepress/config.js" +import { markdownChartPlugin } from '@vuepress/plugin-markdown-chart' + +export default { + plugins: [ + markdownChartPlugin({ + // Enable chart.js + chartjs: true, + }), + ], +} +``` + +## Syntax + +````md +::: chartjs Title + +```json +{ + // Your chart config here. +} +``` + +::: +```` + +`js` and `javascript` code block is also supported, and you are expected to assign your export object to `module.exports`. + +## Demo + +:::: md-demo Bar Chart + +::: chartjs A bar chart + +```json +{ + "type": "bar", + "data": { + "labels": ["Red", "Blue", "Yellow", "Green", "Purple", "Orange"], + "datasets": [ + { + "label": "# of Votes", + "data": [12, 19, 3, 5, 2, 3], + "backgroundColor": [ + "rgba(255, 99, 132, 0.2)", + "rgba(54, 162, 235, 0.2)", + "rgba(255, 206, 86, 0.2)", + "rgba(75, 192, 192, 0.2)", + "rgba(153, 102, 255, 0.2)", + "rgba(255, 159, 64, 0.2)" + ], + "borderColor": [ + "rgba(255, 99, 132, 1)", + "rgba(54, 162, 235, 1)", + "rgba(255, 206, 86, 1)", + "rgba(75, 192, 192, 1)", + "rgba(153, 102, 255, 1)", + "rgba(255, 159, 64, 1)" + ], + "borderWidth": 1 + } + ] + }, + "options": { + "scales": { + "y": { + "beginAtZero": true + } + } + } +} +``` + +::: + +:::: + +:::: md-demo Bubble Chart + +::: chartjs A Bubble Chart + +```json +{ + "type": "bubble", + "data": { + "datasets": [ + { + "label": "First Dataset", + "data": [ + { "x": 20, "y": 30, "r": 15 }, + { "x": 40, "y": 10, "r": 10 } + ], + "backgroundColor": "rgb(255, 99, 132)" + } + ] + } +} +``` + +::: + +:::: + +:::: md-demo Line Chart + +::: chartjs A Line Chart + +```json +{ + "type": "line", + "data": { + "labels": ["January", "February", "March", "April", "May", "June", "July"], + "datasets": [ + { + "label": "My First Dataset", + "data": [65, 59, 80, 81, 56, 55, 40], + "fill": false, + "borderColor": "rgb(75, 192, 192)", + "tension": 0.1 + } + ] + } +} +``` + +::: + +:::: + +:::: md-demo Polar Area Chart + +::: chartjs A Polar Area Chart + +```json +{ + "type": "polarArea", + "data": { + "labels": ["Red", "Green", "Yellow", "Grey", "Blue"], + "datasets": [ + { + "label": "My First Dataset", + "data": [11, 16, 7, 3, 14], + "backgroundColor": [ + "rgb(255, 99, 132)", + "rgb(75, 192, 192)", + "rgb(255, 205, 86)", + "rgb(201, 203, 207)", + "rgb(54, 162, 235)" + ] + } + ] + } +} +``` + +::: + +:::: + +:::: md-demo Radar Chart + +::: chartjs A Radar Chart + +```json +{ + "type": "radar", + "data": { + "labels": [ + "Eating", + "Drinking", + "Sleeping", + "Designing", + "Coding", + "Cycling", + "Running" + ], + "datasets": [ + { + "label": "My First Dataset", + "data": [65, 59, 90, 81, 56, 55, 40], + "fill": true, + "backgroundColor": "rgba(255, 99, 132, 0.2)", + "borderColor": "rgb(255, 99, 132)", + "pointBackgroundColor": "rgb(255, 99, 132)", + "pointBorderColor": "#fff", + "pointHoverBackgroundColor": "#fff", + "pointHoverBorderColor": "rgb(255, 99, 132)" + }, + { + "label": "My Second Dataset", + "data": [28, 48, 40, 19, 96, 27, 100], + "fill": true, + "backgroundColor": "rgba(54, 162, 235, 0.2)", + "borderColor": "rgb(54, 162, 235)", + "pointBackgroundColor": "rgb(54, 162, 235)", + "pointBorderColor": "#fff", + "pointHoverBackgroundColor": "#fff", + "pointHoverBorderColor": "rgb(54, 162, 235)" + } + ] + }, + "options": { + "elements": { + "line": { + "borderWidth": 3 + } + } + } +} +``` + +::: + +:::: + +:::: md-demo Scatter Chart + +::: chartjs A Scatter Chart + +```json +{ + "type": "scatter", + "data": { + "datasets": [ + { + "label": "Scatter Dataset", + "data": [ + { "x": -10, "y": 0 }, + { "x": 0, "y": 10 }, + { "x": 10, "y": 5 }, + { "x": 0.5, "y": 5.5 } + ], + "backgroundColor": "rgb(255, 99, 132)" + } + ] + }, + "options": { + "scales": { + "x": { + "type": "linear", + "position": "bottom" + } + } + } +} +``` + +::: + +:::: + +## Docs + +For details, please see [Chart.js Docs](https://www.chartjs.org/docs/latest/). diff --git a/docs/plugins/markdown/markdown-chart/echarts.md b/docs/plugins/markdown/markdown-chart/echarts.md new file mode 100644 index 0000000000..5f88c7df42 --- /dev/null +++ b/docs/plugins/markdown/markdown-chart/echarts.md @@ -0,0 +1,198 @@ +--- +title: ECharts +icon: chart-simple +--- + + + +Add [echarts][] support to the Markdown files in your VuePress site. + +[echarts]: https://echarts.apache.org/en/index.html + + + +## Settings + +Install [echarts][] in your project: + +::: code-tabs#shell + +@tab pnpm + +```bash +pnpm add -D echarts +``` + +@tab yarn + +```bash +yarn add -D echarts +``` + +@tab npm + +```bash +npm i -D echarts +``` + +::: + +Then enabling via: + + + +```js {7} title=".vuepress/config.js" +import { markdownChartPlugin } from '@vuepress/plugin-markdown-chart' + +export default { + plugins: [ + markdownChartPlugin({ + // Enable echarts + echarts: true, + }), + ], +} +``` + + + +## Syntax + +### With JSON + +If you can generate your chart data easily, you can just provide echarts config using JSON code block: + +````md +::: echarts Title + +```json +{ + // Your echarts config here. +} +``` + +::: +```` + +### With Scripts + +If you need to use script to get the data, you can use `js` or `javascript` code block. + +We will expose the echarts instance as `echarts` in the script, and you are expected to assign the echarts option object to `option` variable. Also, you can assign `width` and `height` variable to set the chart size. + +````md +::: echarts Title + +```js +const option = { + // Your echarts config here. +} +``` + +::: +```` + +::: tip + +You can use top-level await and `fetch` to get data from network requests. + +::: + +## Advanced + +You can import and call `defineEChartsConfig` in [client config file][client-config] to customize echarts. + +```ts title=".vuepress/client.ts" +import { defineClientConfig } from 'vuepress/client' +import { defineEChartsConfig } from 'vuepress-plugin-md-enhance/client' + +defineEChartsConfig({ + options: { + // global echarts options + }, + setup: async () => { + // echarts setup + // e.g.: await import("echarts-wordcloud") + }, +}) + +export default defineClientConfig({ + // ... +}) +``` + +## Docs + +For details, please see [ECharts Docs](https://echarts.apache.org/handbook/en/get-started/). + +## Demo + +:::: md-demo Line Chart + + + +:::: + +:::: md-demo Bar Chart + + + +:::: + +:::: md-demo Pie Chart + + + +:::: + +:::: md-demo Scatter Chart + + + +:::: + +:::: md-demo Polar Chart + + + +:::: + +:::: md-demo Candlestick Chart + + + +:::: + +:::: md-demo Radar Chart + + + +:::: + +:::: md-demo Heat Map + + + +:::: + +:::: md-demo Tree Chart + + + +:::: + +:::: md-demo Multiple Chart + + + +:::: + +:::: md-demo WordCloud (with setup function) + + + +:::: + +[client-config]: https://vuejs.press/guide/configuration.html#client-config-file + + diff --git a/docs/plugins/markdown/markdown-chart/flowchart.md b/docs/plugins/markdown/markdown-chart/flowchart.md new file mode 100644 index 0000000000..83d8e84aa2 --- /dev/null +++ b/docs/plugins/markdown/markdown-chart/flowchart.md @@ -0,0 +1,357 @@ +--- +title: Flowchart +icon: route +--- + + + +Let the Markdown file support flow chart in your VuePress site. + + + +## Settings + +Install [flowchart.ts](http://flowchart.js.org/) in your project: + +::: code-tabs#shell + +@tab pnpm + +```bash +pnpm add -D flowchart.ts +``` + +@tab yarn + +```bash +yarn add -D flowchart.ts +``` + +@tab npm + +```bash +npm i -D flowchart.ts +``` + +::: + +Then enabling via: + + + +```js {7} title=".vuepress/config.js" +import { markdownChartPlugin } from '@vuepress/plugin-markdown-chart' + +export default { + plugins: [ + markdownChartPlugin({ + // Enable flowchart + flowchart: true, + }), + ], +} +``` + + + +## Syntax + +````md + + +```flow:preset + + + +``` +```` + +Available presets for now: + +- `vue` (default) +- `ant` +- `pie` + +## Playground + + + +## Demo + +::: md-demo Vue theme + +```flow +st=>start: Start|past:>http://www.google.com[blank] +e=>end: End|future:>http://www.google.com +op1=>operation: My Operation|past +op2=>operation: Stuff|current +sub1=>subroutine: My Subroutine|invalid +cond=>condition: Yes +or No?|approved:>http://www.google.com +c2=>condition: Good idea|rejected +io=>inputoutput: catch something...|future + +st->op1(right)->cond +cond(yes, right)->c2 +cond(no)->sub1(left)->op1 +c2(yes)->io->e +c2(no)->op2->e +``` + +::: + +::: md-demo Ant theme + +```flow:ant +st=>start: Start|past:>http://www.google.com[blank] +e=>end: End|future:>http://www.google.com +op1=>operation: My Operation|past +op2=>operation: Stuff|current +sub1=>subroutine: My Subroutine|invalid +cond=>condition: Yes +or No?|approved:>http://www.google.com +c2=>condition: Good idea|rejected +io=>inputoutput: catch something...|future + +st->op1(right)->cond +cond(yes, right)->c2 +cond(no)->sub1(left)->op1 +c2(yes)->io->e +c2(no)->op2->e +``` + +::: + +::: md-demo Pie theme + +```flow:pie +st=>start: Start|past:>http://www.google.com[blank] +e=>end: End|future:>http://www.google.com +op1=>operation: My Operation|past +op2=>operation: Stuff|current +sub1=>subroutine: My Subroutine|invalid +cond=>condition: Yes +or No?|approved:>http://www.google.com +c2=>condition: Good idea|rejected +io=>inputoutput: catch something...|future + +st->op1(right)->cond +cond(yes, right)->c2 +cond(no)->sub1(left)->op1 +c2(yes)->io->e +c2(no)->op2->e +``` + +::: + +## Flowchart Intro + +### Node Types + +Defines the shape that the node will take. + +::: md-demo Start & End + +- `[Variable]->start: [Text]` + + Used as the first node where flows start from. + Default text is `Start`. + +- `[Variable]->end: [Text]` + + Used as the last node where a flow ends. + Default text is `End`. + +```flow +st=>start: Start +e=>end: End + +st->e +``` + +::: + +::: md-demo Operation + +Indicates that an operation needs to happen in the flow. + +- `[Variable]->operation: [Text]` + +```flow +process=>operation: Operation +e=>end: End + +process->e +``` + +::: + +::: md-demo Input / Output + +Indicates that IO happens in a flow. + +- `[Variable]->inputoutput: [Text]` + +```flow +process=>inputoutput: Inputoutput +e=>end: End + +process->e +``` + +::: + +::: md-demo Subroutine + +Indicates that a subroutine happens in the flow and that there should be another flowchart that documents this subroutine. + +- `[Variable]->subroutine: [Text]` + +```flow +process=>subroutine: Subroutine +e=>end: End + +process->e +``` + +::: + +::: md-demo Condition + +Allows for a conditional or logical statement to direct the flow into one of two or more paths. + +- `[Variable]->condition: [Text]` + +- `[Variable]([yesText])->[Position]` +- `[Variable]([noText])->[Position]` + +```flow +cond=>condition: Process? +process=>operation: Process +e=>end: End + +cond(yes)->process->e +cond(no)->e +``` + +::: + +::: md-demo Parallel + +Allows for multiple flows to happen simultaneously. + +- `[Variable]->parallel: [Text]` +- `[Variable](path1, direction)->[Position]` +- `[Variable](path1, direction)->[Position]` + +```flow +para=>parallel: parallel tasks +process=>operation: Process +e=>end: End + +para(path1, bottom)->process->e +para(path2)->e +``` + +::: + +## Connections + +Connections are defined in their own section below the node definitions. + +The `->` operator specifies a connection from one node to another like `nodeVar1->nodeVar2->nodeVar3`. + +Not all nodes need to be specified in one string and can be separated like so + +```md +nodeVar1->nodeVar2 +nodeVar2->nodeVar3 +``` + +Connection syntax is as follows: + +`[([, [[([, ]` + +Items in `[]` are optional. + +### Directions + +The following directions are available and define the direction the connection will leave the node from. If there are more than one specifier, it is always the last. All nodes have a default direction making this an optional specification. `` will be used and one of the below list should be used in its place. + +- `left` +- `right` +- `top` +- `bottom` + +### Node Specific Specifiers by Type + +Each node variable has optional specifiers, like direction, and some have special specifiers depending on the node type that are defined below. Specifiers are added after the variable name in `()` and separated with `,` like `nodeVar(spec1, spec2)`. + +- **start** + **operation** + **inputoutput** + **subroutine** + + Optional direction + + `startVar()->nextNode` + + `operationVar()->nextNode` + + `inputoutputVar()->nextNode` + + `subroutineVar()->nextNode` + +- **condition** + + Required logical specification of `yes` or `no` + + Optional direction + + ```md + conditionalVar(yes, )->nextNode1 + conditionalVar(no, )->nextNode2 + ``` + +- **parallel** + + Required path specification of `path1`, `path2`, or `path3` + + Optional direction + + ```md + parallelVar(path1, )->nextNode1 + parallelVar(path2, )->nextNode2 + parallelVar(path3, )->nextNode3 + ``` + +### Links + +An external link can be added to a node with the `:>` operator. + +The `st` node is linked with `http://www.google.com` and will open a new tab because `[blank]` is at the end of the URL. + +The `e` node is linked with `http://www.yahoo.com` and will cause the page to navigate to that page instead of opening a new tab. + +```md +st=>start: Start:>http://www.google.com[blank] +e=>end: End:>http://www.yahoo.com +``` + +## Advice + +Symbols that should possibly not be used in the text: `=>` and `->` and `:>` and `|` and `@>` and `:$` + +To emphasize a specific path in your flowchart, you can define it like this: + +```md +st@>op1({"stroke":"Red"})@>cond({"stroke":"Red","stroke-width":6,"arrow-end":"classic-wide-long"})@>c2({"stroke":"Red"})@>op2({"stroke":"Red"})@>e({"stroke":"Red"}) +``` + + + + diff --git a/docs/plugins/markdown/markdown-chart/markmap.md b/docs/plugins/markdown/markdown-chart/markmap.md new file mode 100644 index 0000000000..bb7cda582c --- /dev/null +++ b/docs/plugins/markdown/markdown-chart/markmap.md @@ -0,0 +1,102 @@ +--- +title: Markmap +icon: fab fa-markdown +--- + + + +Let the Markdown file support markmap in your VuePress site. + + + +## Settings + +Install `markmap-lib`, `markmap-toolbar` and `markmap-view` in your project: + +::: code-tabs#shell + +@tab pnpm + +```bash +pnpm add -D markmap-lib markmap-toolbar markmap-view +``` + +@tab yarn + +```bash +yarn add -D markmap-lib markmap-toolbar markmap-view +``` + +@tab npm + +```bash +npm i -D markmap-lib markmap-toolbar markmap-view +``` + +::: + +Then enabling via: + + + +```js {7} title=".vuepress/config.js" +import { markdownChartPlugin } from '@vuepress/plugin-markdown-chart' + +export default { + plugins: [ + markdownChartPlugin({ + // Enable Markmap + markmap: true, + }), + ], +} +``` + + + +## Syntax + +````md +```markmap + +``` +```` + +Configuring through frontmatter syntax is supported. + +## Demo + +::: md-demo + +````markmap +--- +markmap: + colorFreezeLevel: 2 +--- + +# markmap + +## Links + +- +- [GitHub](https://github.com/markmap/markmap) + +## Features + +- links +- **strong** ~~del~~ *italic* ==highlight== +- multiline + text +- `inline code` +- + ```js + console.log('code block'); + ``` +- Katex + - $x = {-b \pm \sqrt{b^2-4ac} \over 2a}$ +- Now we can wrap very very very very long text based on `maxWidth` option +```` + +::: + + diff --git a/docs/plugins/markdown/markdown-chart/mermaid.md b/docs/plugins/markdown/markdown-chart/mermaid.md new file mode 100644 index 0000000000..b54d854da2 --- /dev/null +++ b/docs/plugins/markdown/markdown-chart/mermaid.md @@ -0,0 +1,576 @@ +--- +title: Mermaid +icon: chart-pie +--- + + + +Let the Markdown file support [mermaid](https://mermaid.js.org/) in your VuePress site. + + + +## Settings + +Install [mermaid](https://mermaid.js.org/) in your project: + +::: code-tabs#shell + +@tab pnpm + +```bash +pnpm add -D mermaid +``` + +@tab yarn + +```bash +yarn add -D mermaid +``` + +@tab npm + +```bash +npm i -D mermaid +``` + +::: + +Then enabling via: + + + +```js {7} title=".vuepress/config.js" +import { markdownChartPlugin } from '@vuepress/plugin-markdown-chart' + +export default { + plugins: [ + markdownChartPlugin({ + // Enable mermaid + mermaid: true, + }), + ], +} +``` + + + +## Syntax + +````md +```mermaid + + + +``` +```` + +Besides using mermaid, you can also use the following code blocks: + +- class: `classDiagram` +- c4c: `C4Context` +- er: `erDiagram` +- gantt: `gantt` +- git-graph: `gitGraph` +- journey: `journey` +- mindmap: `mindmap` +- pie: `pie` +- quadrant: `quadrantChart` +- requirement: `requirementDiagram` +- sankey: `sankey-beta` +- sequence: `sequenceDiagram` +- state: `stateDiagram-v2` +- timeline: `timeline` +- xy: `xychart-beta` + +You do not need to declare diagram type and intent your code. + +When the diagram supports setting title, you can add the title directly after fence info: + +````md +```sequence Chart Title +sequence diagram body +... +``` +```` + +## Usage + +Please see [mermaid](https://mermaid.js.org/). + +## Advanced + +You can import and call `defineMermaidConfig` in [client config file][client-config] to customize mermaid: + +```ts title=".vuepress/client.ts" +import { defineClientConfig } from 'vuepress/client' +import { defineMermaidConfig } from 'vuepress-plugin-md-enhance/client' + +defineMermaidConfig({ + // mermaid options here +}) + +export default defineClientConfig({ + // ... +}) +``` + +## Demo + +::: md-demo Flowchart + +```mermaid +--- +title: Flowchart +--- +flowchart TB + c1-->a2 + subgraph one + a1-->a2 + end + subgraph two + b1-->b2 + end + subgraph three + c1-->c2 + end + one --> two + three --> two + two --> c2 +``` + +::: + +::: md-demo Sequence Diagram + +```sequence Greetings +Alice ->> Bob: Hello Bob, how are you? +Bob-->>John: How about you John? +Bob--x Alice: I am good thanks! +Bob-x John: I am good thanks! +Note right of John: Bob thinks a long
long time, so long
that the text does
not fit on a row. + +Bob-->Alice: Checking with John... +Alice->John: Yes... John, how are you? +``` + +::: + +::: md-demo Class Diagram + +```class Animal Example +note "From Duck till Zebra" +Animal <|-- Duck +note for Duck "can fly\ncan swim\ncan dive\ncan help in debugging" +Animal <|-- Fish +Animal <|-- Zebra +Animal : +int age +Animal : +String gender +Animal: +isMammal() +Animal: +mate() +class Duck{ + +String beakColor + +swim() + +quack() +} +class Fish{ + -int sizeInFeet + -canEat() +} +class Zebra{ + +bool is_wild + +run() +} +``` + +::: + +::: md-demo State Diagram + +```state Check if n is negative + +state if_state <> +[*] --> IsPositive +IsPositive --> if_state +if_state --> False: if n < 0 +if_state --> True : if n >= 0 +``` + +::: + +::: md-demo Entity Relationship Diagrams + +```er Er Example +CAR ||--o{ NAMED-DRIVER : allows +CAR { + string registrationNumber + string make + string model +} +PERSON ||--o{ NAMED-DRIVER : is +PERSON { + string firstName + string lastName + int age +} +``` + +::: + +::: md-demo User Journey Diagram + +```journey +title My working day +section Go to work + Make tea: 5: Me + Go upstairs: 3: Me + Do work: 1: Me, Cat +section Go home + Go downstairs: 5: Me + Sit down: 5: Me +``` + +::: + +::: md-demo Gantt Diagrams + +```gantt +dateFormat YYYY-MM-DD +title Adding GANTT diagram functionality to mermaid +excludes weekends +%% (`excludes` accepts specific dates in YYYY-MM-DD format, days of the week ("sunday") or "weekends", but not the word "weekdays".) + +section A section +Completed task :done, des1, 2014-01-06,2014-01-08 +Active task :active, des2, 2014-01-09, 3d +Future task : des3, after des2, 5d +Future task2 : des4, after des3, 5d + +section Critical tasks +Completed task in the critical line :crit, done, 2014-01-06,24h +Implement parser :crit, done, after des1, 2d +Create tests for parser :crit, active, 3d +Future task in critical line :crit, 5d +Create tests for renderer :2d +Add to mermaid :1d + +section Documentation +Describe gantt syntax :active, a1, after des1, 3d +Add gantt diagram to demo page :after a1 , 20h +Add another diagram to demo page :doc1, after a1 , 48h + +section Last section +Describe gantt syntax :after doc1, 3d +Add gantt diagram to demo page :20h +Add another diagram to demo page :48h +``` + +::: + +::: md-demo Pie Chart Diagrams + +```pie +title What Voldemort doesn't have? + "FRIENDS" : 2 + "FAMILY" : 3 + "NOSE" : 45 +``` + +::: + +::: md-demo Git Graph Diagrams + +```git-graph +commit +branch hotfix +checkout hotfix +commit +branch develop +checkout develop +commit id:"ash" tag:"abc" +branch featureB +checkout featureB +commit type:HIGHLIGHT +checkout main +checkout hotfix +commit type:NORMAL +checkout develop +commit type:REVERSE +checkout featureB +commit +checkout main +merge hotfix +checkout featureB +commit +checkout develop +branch featureA +commit +checkout develop +merge hotfix +checkout featureA +commit +checkout featureB +commit +checkout develop +merge featureA +branch release +checkout release +commit +checkout main +commit +checkout release +merge main +checkout develop +merge release +``` + +::: + +::: md-demo C4C Diagrams + +```c4c +title System Context diagram for Internet Banking System + +Person(customerA, "Banking Customer A", "A customer of the bank, with personal bank accounts.") +Person(customerB, "Banking Customer B") +Person_Ext(customerC, "Banking Customer C") +System(SystemAA, "Internet Banking System", "Allows customers to view information about their bank accounts, and make payments.") + +Person(customerD, "Banking Customer D", "A customer of the bank,
with personal bank accounts.") + +Enterprise_Boundary(b1, "BankBoundary") { + + SystemDb_Ext(SystemE, "Mainframe Banking System", "Stores all of the core banking information about customers, accounts, transactions, etc.") + + System_Boundary(b2, "BankBoundary2") { + System(SystemA, "Banking System A") + System(SystemB, "Banking System B", "A system of the bank, with personal bank accounts.") + } + + System_Ext(SystemC, "E-mail system", "The internal Microsoft Exchange e-mail system.") + SystemDb(SystemD, "Banking System D Database", "A system of the bank, with personal bank accounts.") + + Boundary(b3, "BankBoundary3", "boundary") { + SystemQueue(SystemF, "Banking System F Queue", "A system of the bank, with personal bank accounts.") + SystemQueue_Ext(SystemG, "Banking System G Queue", "A system of the bank, with personal bank accounts.") + } +} + +BiRel(customerA, SystemAA, "Uses") +BiRel(SystemAA, SystemE, "Uses") +Rel(SystemAA, SystemC, "Sends e-mails", "SMTP") +Rel(SystemC, customerA, "Sends e-mails to") +``` + +::: + +::: md-demo Mindmap + +```mindmap +root((VuePress)) + Out of box + Default theme + Navbar + Sidebar + Darkmode + I18n + Search + Search + DocSearch
by algolia + Customize + Theme + (hope) + Plugins + (components) + (md-enhance) +``` + +::: + +::: md-demo Timeline + +```timeline +title Timeline of Industrial Revolution +section 17th-20th century + Industry 1.0 : Machinery, Water power, Steam
power + Industry 2.0 : Electricity, Internal combustion engine, Mass production + Industry 3.0 : Electronics, Computers, Automation +section 21st century + Industry 4.0 : Internet, Robotics, Internet of Things + Industry 5.0 : Artificial intelligence, Big data,3D printing +``` + +::: + +::: md-demo Sankey + +```sankey +Agricultural 'waste',Bio-conversion,124.729 +Bio-conversion,Liquid,0.597 +Bio-conversion,Losses,26.862 +Bio-conversion,Solid,280.322 +Bio-conversion,Gas,81.144 +Biofuel imports,Liquid,35 +Biomass imports,Solid,35 +Coal imports,Coal,11.606 +Coal reserves,Coal,63.965 +Coal,Solid,75.571 +District heating,Industry,10.639 +District heating,Heating and cooling - commercial,22.505 +District heating,Heating and cooling - homes,46.184 +Electricity grid,Over generation / exports,104.453 +Electricity grid,Heating and cooling - homes,113.726 +Electricity grid,H2 conversion,27.14 +Electricity grid,Industry,342.165 +Electricity grid,Road transport,37.797 +Electricity grid,Agriculture,4.412 +Electricity grid,Heating and cooling - commercial,40.858 +Electricity grid,Losses,56.691 +Electricity grid,Rail transport,7.863 +Electricity grid,Lighting & appliances - commercial,90.008 +Electricity grid,Lighting & appliances - homes,93.494 +Gas imports,Ngas,40.719 +Gas reserves,Ngas,82.233 +Gas,Heating and cooling - commercial,0.129 +Gas,Losses,1.401 +Gas,Thermal generation,151.891 +Gas,Agriculture,2.096 +Gas,Industry,48.58 +Geothermal,Electricity grid,7.013 +H2 conversion,H2,20.897 +H2 conversion,Losses,6.242 +H2,Road transport,20.897 +Hydro,Electricity grid,6.995 +Liquid,Industry,121.066 +Liquid,International shipping,128.69 +Liquid,Road transport,135.835 +Liquid,Domestic aviation,14.458 +Liquid,International aviation,206.267 +Liquid,Agriculture,3.64 +Liquid,National navigation,33.218 +Liquid,Rail transport,4.413 +Marine algae,Bio-conversion,4.375 +Ngas,Gas,122.952 +Nuclear,Thermal generation,839.978 +Oil imports,Oil,504.287 +Oil reserves,Oil,107.703 +Oil,Liquid,611.99 +Other waste,Solid,56.587 +Other waste,Bio-conversion,77.81 +Pumped heat,Heating and cooling - homes,193.026 +Pumped heat,Heating and cooling - commercial,70.672 +Solar PV,Electricity grid,59.901 +Solar Thermal,Heating and cooling - homes,19.263 +Solar,Solar Thermal,19.263 +Solar,Solar PV,59.901 +Solid,Agriculture,0.882 +Solid,Thermal generation,400.12 +Solid,Industry,46.477 +Thermal generation,Electricity grid,525.531 +Thermal generation,Losses,787.129 +Thermal generation,District heating,79.329 +Tidal,Electricity grid,9.452 +UK land based bioenergy,Bio-conversion,182.01 +Wave,Electricity grid,19.013 +Wind,Electricity grid,289.366 +``` + +::: + +::: md-demo Requirement + +```requirement +requirement test_req { +id: 1 +text: the test text. +risk: high +verifymethod: test +} + +element test_entity { +type: simulation +} + +test_entity - satisfies -> test_req +``` + +::: + +::: md-demo Quadrant Chart + +```quadrant +title Reach and engagement of campaigns +x-axis Low Reach --> High Reach +y-axis Low Engagement --> High Engagement +quadrant-1 We should expand +quadrant-2 Need to promote +quadrant-3 Re-evaluate +quadrant-4 May be improved +Campaign A: [0.3, 0.6] +Campaign B: [0.45, 0.23] +Campaign C: [0.57, 0.69] +Campaign D: [0.78, 0.34] +Campaign E: [0.40, 0.34] +Campaign F: [0.35, 0.78] +``` + +::: + +::: md-demo XY Chart + +```xy +title "Sales Revenue" +x-axis [jan, feb, mar, apr, may, jun, jul, aug, sep, oct, nov, dec] +y-axis "Revenue (in $)" 4000 --> 11000 +bar [5000, 6000, 7500, 8200, 9500, 10500, 11000, 10200, 9200, 8500, 7000, 6000] +line [5000, 6000, 7500, 8200, 9500, 10500, 11000, 10200, 9200, 8500, 7000, 6000] +``` + +::: + +::: md-demo Block Chart + +```block +columns 3 +Frontend blockArrowId6<[" "]>(right) Backend +space:2 down<[" "]>(down) +Disk left<[" "]>(left) Database[("Database")] + +classDef front fill:#696,stroke:#333; +classDef back fill:#969,stroke:#333; +class Frontend front +class Backend,Database back +``` + +::: + +::: md-demo A Complex Example + +```mermaid +graph TB + sq[Square shape] --> ci((Circle shape)) + + subgraph A + od>Odd shape]-- Two line
edge comment --> ro + di{Diamond with
line break} -.-> ro(Rounded
square
shape) + di==>ro2(Rounded square shape) + end + + %% Notice that no text in shape are added here instead that is appended further down + e --> od3>Really long text with line break
in an Odd shape] + + %% Comments after double percent signs + e((Inner / circle
and some odd
special characters)) --> f(,.?!+-*ز) + + cyr[Cyrillic]-->cyr2((Circle shape)); + + classDef green fill:#9f6,stroke:#333,stroke-width:2px; + classDef orange fill:#f96,stroke:#333,stroke-width:4px; + class sq,e green + class di orange +``` + +::: + +[client-config]: https://vuejs.press/guide/configuration.html#client-config-file + + diff --git a/docs/plugins/markdown/markdown-chart/plantuml.md b/docs/plugins/markdown/markdown-chart/plantuml.md new file mode 100644 index 0000000000..c07c5b423f --- /dev/null +++ b/docs/plugins/markdown/markdown-chart/plantuml.md @@ -0,0 +1,667 @@ +--- +title: Plantuml +icon: diagram-project +--- + + + +Let the Markdown files in your VuePress site support [plantuml][]. + +[plantuml]: https://plantuml.com/ + + + +## Settings + +You can enable this feature via: + + + +```js {7} title=".vuepress/config.js" +import { markdownChartPlugin } from '@vuepress/plugin-markdown-chart' + +export default { + plugins: [ + markdownChartPlugin({ + // Enable plantuml + plantuml: true, + }), + ], +} +``` + + + +## Syntax + +You can insert the same content that [plantuml][] supports, for example: + +```md +@startuml +content +@enduml +``` + +## Demo + + + + +::: md-demo Sequence Diagram + +@startuml +Alice -> Bob: Authentication Request + +alt successful case + + Bob -> Alice: Authentication Accepted + +else some kind of failure + + Bob -> Alice: Authentication Failure + group My own label + Alice -> Log : Log attack start + loop 1000 times + Alice -> Bob: DNS Attack + end + Alice -> Log : Log attack end + end + +else Another type of failure + +Bob -> Alice: Please repeat + +end +@enduml + +::: + +::: md-demo Use Case + +@startuml +:Main Admin: as Admin +(Use the application) as (Use) + +User -> (Start) +User --> (Use) + +Admin ---> (Use) + +note right of Admin : This is an example. + +note right of (Use) +A note can also +be on several lines +end note + +note "This note is connected\nto several objects." as N2 +(Start) .. N2 +N2 .. (Use) +@enduml + +::: + +::: md-demo Class + +@startuml +abstract class AbstractList +abstract AbstractCollection +interface List +interface Collection + +List <|-- AbstractList +Collection <|-- AbstractCollection + +Collection <|- List +AbstractCollection <|- AbstractList +AbstractList <|-- ArrayList + +class ArrayList { + Object[] elementData + size() +} + +enum TimeUnit { + DAYS + HOURS + MINUTES +} + +annotation SuppressWarnings + +annotation Annotation { + annotation with members + String foo() + String bar() +} +@enduml + +::: + +::: md-demo Activity + +@startuml +start +:ClickServlet.handleRequest(); +:new page; +if (Page.onSecurityCheck) then (true) + :Page.onInit(); + if (isForward?) then (no) + :Process controls; + if (continue processing?) then (no) + stop + endif + + if (isPost?) then (yes) + :Page.onPost(); + else (no) + :Page.onGet(); + endif + :Page.onRender(); + endif +else (false) +endif + +if (do redirect?) then (yes) + :redirect process; +else + if (do forward?) then (yes) + :Forward request; + else (no) + :Render page template; + endif +endif + +stop +@enduml + +::: + +::: md-demo Component + +@startuml +package "Some Group" { + HTTP - [First Component] + [Another Component] +} + +node "Other Groups" { + FTP - [Second Component] + [First Component] --> FTP +} + +cloud { + [Example 1] +} + +database "MySql" { + folder "This is my folder" { + [Folder 3] + } + frame "Foo" { + [Frame 4] + } +} + +[Another Component] --> [Example 1] +[Example 1] --> [Folder 3] +[Folder 3] --> [Frame 4] + +@enduml + +::: + +::: md-demo State + +@startuml +state start1 <> +state choice1 <> +state fork1 <> +state join2 <> +state end3 <> + +[*] --> choice1 : from start\nto choice +start1 --> choice1 : from start stereo\nto choice + +choice1 --> fork1 : from choice\nto fork +choice1 --> join2 : from choice\nto join +choice1 --> end3 : from choice\nto end stereo + +fork1 ---> State1 : from fork\nto state +fork1 --> State2 : from fork\nto state + +State2 --> join2 : from state\nto join +State1 --> [*] : from state\nto end + +join2 --> [*] : from join\nto end +@enduml + +::: + +::: md-demo Object + +@startuml +object London +object Washington +object Berlin +object NewYork + +map CapitalCity { + UK *-> London + USA *--> Washington + Germany *---> Berlin +} + +NewYork --> CapitalCity::USA +@enduml + +::: + +::: md-demo Deployment + +@startuml +node node1 +node node2 +node node3 +node node4 +node node5 +node1 -- node2 : label1 +node1 .. node3 : label2 +node1 ~~ node4 : label3 +node1 == node5 +@enduml + +::: + +::: md-demo Timing + +@startuml +scale 5 as 150 pixels + +clock clk with period 1 +binary "enable" as en +binary "R/W" as rw +binary "data Valid" as dv +concise "dataBus" as db +concise "address bus" as addr + +@6 as :write_beg +@10 as :write_end + +@15 as :read_beg +@19 as :read_end + +@0 +en is low +db is "0x0" +addr is "0x03f" +rw is low +dv is 0 + +@:write_beg-3 + en is high +@:write_beg-2 + db is "0xDEADBEEF" +@:write_beg-1 +dv is 1 +@:write_beg +rw is high + +@:write_end +rw is low +dv is low +@:write_end+1 +rw is low +db is "0x0" +addr is "0x23" + +@12 +dv is high +@13 +db is "0xFFFF" + +@20 +en is low +dv is low +@21 +db is "0x0" + +highlight :write_beg to :write_end #Gold:Write +highlight :read_beg to :read_end #lightBlue:Read + +db@:write_beg-1 <-> @:write_end : setup time +db@:write_beg-1 -> addr@:write_end+1 : hold +@enduml + +::: + +::: md-demo RegExp + +@startregex +/([\s\S]+)<\/style> +@endregex + +::: + +::: md-demo Network + +@startuml +nwdiag { + group nightly { + color = "#FFAAAA"; + description = "<&clock> Restarted nightly <&clock>"; + web02; + db01; + } + network dmz { + address = "210.x.x.x/24" + + user [description = "<&person*4.5>\n user1"]; + web01 [address = "210.x.x.1, 210.x.x.20", description = "<&cog*4>\nweb01"] + web02 [address = "210.x.x.2", description = "<&cog*4>\nweb02"]; + + } + network internal { + address = "172.x.x.x/24"; + + web01 [address = "172.x.x.1"]; + web02 [address = "172.x.x.2"]; + db01 [address = "172.x.x.100", description = "<&spreadsheet*4>\n db01"]; + db02 [address = "172.x.x.101", description = "<&spreadsheet*4>\n db02"]; + ptr [address = "172.x.x.110", description = "<&print*4>\n ptr01"]; + } +} +@enduml + +::: + +::: md-demo Salt + +@startsalt +{+ +{/ General | Fullscreen | Behavior | Saving } +{ +{ Open image in: | ^Smart Mode^ } +[X] Smooth images when zoomed +[X] Confirm image deletion +[ ] Show hidden images +} +[Close] +} +@endsalt + +::: + +::: md-demo Archimate + +@startuml +skinparam rectangle<> { + roundCorner 25 +} +sprite $bProcess jar:archimate/business-process +sprite $aService jar:archimate/application-service +sprite $aComponent jar:archimate/application-component + +rectangle "Handle claim" as HC <<$bProcess>><> #Business +rectangle "Capture Information" as CI <<$bProcess>><> #Business +rectangle "Notify\nAdditional Stakeholders" as NAS <<$bProcess>><> #Business +rectangle "Validate" as V <<$bProcess>><> #Business +rectangle "Investigate" as I <<$bProcess>><> #Business +rectangle "Pay" as P <<$bProcess>><> #Business + +HC *-down- CI +HC *-down- NAS +HC *-down- V +HC *-down- I +HC *-down- P + +CI -right->> NAS +NAS -right->> V +V -right->> I +I -right->> P + +rectangle "Scanning" as scanning <<$aService>><> #Application +rectangle "Customer admnistration" as customerAdministration <<$aService>><> #Application +rectangle "Claims admnistration" as claimsAdministration <<$aService>><> #Application +rectangle Printing <<$aService>><> #Application +rectangle Payment <<$aService>><> #Application + +scanning -up-> CI +customerAdministration -up-> CI +claimsAdministration -up-> NAS +claimsAdministration -up-> V +claimsAdministration -up-> I +Payment -up-> P + +Printing -up-> V +Printing -up-> P + +rectangle "Document\nManagement\nSystem" as DMS <<$aComponent>> #Application +rectangle "General\nCRM\nSystem" as CRM <<$aComponent>> #Application +rectangle "Home & Away\nPolicy\nAdministration" as HAPA <<$aComponent>> #Application +rectangle "Home & Away\nFinancial\nAdministration" as HFPA <<$aComponent>> #Application + +DMS .up.|> scanning +DMS .up.|> Printing +CRM .up.|> customerAdministration +HAPA .up.|> claimsAdministration +HFPA .up.|> Payment + +legend left +Example from the "Archisurance case study" (OpenGroup). +See +==== +<$bProcess> :business process +==== +<$aService> : application service +==== +<$aComponent> : application component +endlegend +@enduml + +::: + +::: md-demo Gantt + +@startgantt + +Project starts the 2020-12-01 + +[Task1] requires 10 days +sunday are closed + +note bottom + memo1 ... + memo2 ... + explanations1 ... + explanations2 ... +end note + +[Task2] requires 20 days +[Task2] starts 10 days after [Task1]'s end +-- Separator title -- +[M1] happens on 5 days after [Task1]'s end + + + +-- end -- +@endgantt + +::: + +::: md-demo Mindmap + +@startmindmap +caption figure 1 +title My super title + +* <&flag>Debian +** <&globe>Ubuntu +*** Linux Mint +*** Kubuntu +*** Lubuntu +*** KDE Neon +** <&graph>LMDE +** <&pulse>SolydXK +** <&people>SteamOS +** <&star>Raspbian with a very long name +*** Raspmbc => OSMC +*** Raspyfi => Volumio + +header +My super header +endheader + +center footer My super footer + +legend right + Short + legend +endlegend +@endmindmap + +::: + +::: md-demo WBS + +@startwbs ++ New Job +++ Decide on Job Requirements ++++ Identity gaps ++++ Review JDs +++++ Sign-Up for courses +++++ Volunteer +++++ Reading +++- Checklist ++++- Responsibilities ++++- Location +++ CV Upload Done ++++ CV Updated +++++ Spelling & Grammar +++++ Check dates +---- Skills ++++ Recruitment sites chosen +@endwbs + +::: + +::: md-demo JSON + +@startjson +#highlight "lastName" +#highlight "address" / "city" +#highlight "phoneNumbers" / "0" / "number" +{ + "firstName": "John", + "lastName": "Smith", + "isAlive": true, + "age": 28, + "address": { + "streetAddress": "21 2nd Street", + "city": "New York", + "state": "NY", + "postalCode": "10021-3100" + }, + "phoneNumbers": [ + { + "type": "home", + "number": "212 555-1234" + }, + { + "type": "office", + "number": "646 555-4567" + } + ], + "children": [], + "spouse": null +} +@endjson + +::: + +::: md-demo YAML + +@startyaml +doe: "a deer, a female deer" +ray: "a drop of golden sun" +pi: 3.14159 +xmas: true +french-hens: 3 +calling-birds: + - huey + - dewey + - louie + - fred +xmas-fifth-day: + calling-birds: four + french-hens: 3 + golden-rings: 5 + partridges: + count: 1 + location: "a pear tree" + turtle-doves: two +@endyaml + +::: + + + + + diff --git a/plugins/markdown/plugin-markdown-chart/package.json b/plugins/markdown/plugin-markdown-chart/package.json new file mode 100644 index 0000000000..e8ff3a7089 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/package.json @@ -0,0 +1,97 @@ +{ + "name": "@vuepress/plugin-markdown-chart", + "version": "2.0.0-rc.56", + "description": "VuePress plugin - markdown chart", + "keywords": [ + "vuepress-plugin", + "vuepress", + "plugin", + "markdown", + "chart", + "chartjs", + "echarts", + "flowchart", + "markmap", + "mermaid" + ], + "homepage": "https://ecosystem.vuejs.press/plugins/markdown/markdown-chart.html", + "bugs": { + "url": "https://github.com/vuepress/ecosystem/issues" + }, + "repository": { + "type": "git", + "url": "git+https://github.com/vuepress/ecosystem.git", + "directory": "plugins/markdown/plugin-markdown-chart" + }, + "license": "MIT", + "author": { + "name": "Mr.Hope", + "email": "mister-hope@outlook.com", + "url": "https://mister-hope.com" + }, + "type": "module", + "exports": { + ".": "./lib/node/index.js", + "./client/*": "./lib/client/*", + "./package.json": "./package.json" + }, + "main": "./lib/node/index.js", + "types": "./lib/node/index.d.ts", + "files": [ + "lib" + ], + "scripts": { + "build": "tsc -b tsconfig.build.json", + "bundle": "rollup -c rollup.config.ts --configPlugin esbuild", + "clean": "rimraf --glob ./lib ./*.tsbuildinfo", + "style": "sass src:lib --embed-sources --style=compressed" + }, + "dependencies": { + "@mdit/plugin-container": "^0.13.1", + "@mdit/plugin-plantuml": "^0.13.1", + "@vuepress/helper": "workspace:*", + "@vueuse/core": "^12.0.0", + "vue": "^3.5.13" + }, + "devDependencies": { + "@types/markdown-it": "^14.1.2", + "markdown-it": "^14.1.0", + "markmap-common": "^0.17.1" + }, + "peerDependencies": { + "chart.js": "^4.4.5", + "echarts": "^5.5.1", + "flowchart.ts": "^3.0.1", + "markmap-lib": "^0.17.2", + "markmap-toolbar": "^0.17.2", + "markmap-view": "^0.17.2", + "mermaid": "^11.3.0", + "vuepress": "2.0.0-rc.19" + }, + "peerDependenciesMeta": { + "chart.js": { + "optional": true + }, + "echarts": { + "optional": true + }, + "flowchart.ts": { + "optional": true + }, + "markmap-lib": { + "optional": true + }, + "markmap-toolbar": { + "optional": true + }, + "markmap-view": { + "optional": true + }, + "mermaid": { + "optional": true + } + }, + "publishConfig": { + "access": "public" + } +} diff --git a/plugins/markdown/plugin-markdown-chart/rollup.config.ts b/plugins/markdown/plugin-markdown-chart/rollup.config.ts new file mode 100644 index 0000000000..8deeb099fd --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/rollup.config.ts @@ -0,0 +1,16 @@ +import { rollupBundle } from '../../../scripts/rollup.js' + +export default [ + ...rollupBundle('node/index'), + ...rollupBundle({ + base: 'client', + files: [ + 'components/ChartJS', + 'components/ECharts', + 'components/FlowChart', + 'components/MarkMap', + 'components/Mermaid', + 'index', + ], + }), +] diff --git a/plugins/markdown/plugin-markdown-chart/src/client/components/ChartJS.ts b/plugins/markdown/plugin-markdown-chart/src/client/components/ChartJS.ts new file mode 100644 index 0000000000..41a223deac --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/components/ChartJS.ts @@ -0,0 +1,142 @@ +import { + LoadingIcon, + decodeData, + useDarkmode, + wait, +} from '@vuepress/helper/client' +import type { Chart, ChartConfiguration } from 'chart.js' +import type { PropType, VNode } from 'vue' +import { computed, defineComponent, h, ref, shallowRef, watch } from 'vue' + +import '../styles/chartjs.css' + +declare const __MC_DELAY__: number + +const parseChartConfig = ( + config: string, + type: 'js' | 'json', +): ChartConfiguration => { + if (type === 'json') return JSON.parse(config) as ChartConfiguration + + // eslint-disable-next-line @typescript-eslint/no-implied-eval + const runner = new Function( + `\ +let config,__chart_js_config__; +{ +${config} +__chart_js_config__=config; +} +return __chart_js_config__;\ +`, + ) as () => ChartConfiguration + + return runner() +} + +export default defineComponent({ + name: 'ChartJS', + + props: { + /** + * Chart config + * + * 图表配置 + */ + config: { + type: String, + required: true, + }, + + /** + * Chart id + * + * 图表 id + */ + id: { + type: String, + required: true, + }, + + /** + * Chart title + * + * 图表标题 + */ + title: { + type: String, + default: '', + }, + + /** + * Chart config type + * + * 图表配置类型 + */ + type: { + type: String as PropType<'js' | 'json'>, + default: 'json', + }, + }, + + setup(props) { + const isDarkmode = useDarkmode() + + const chartElement = shallowRef() + const chartCanvasElement = shallowRef() + + const loading = ref(true) + + const config = computed(() => decodeData(props.config)) + + let loaded = false + + let chart: Chart | null + + const renderChart = async (darkmode: boolean): Promise => { + const [{ default: Chart }] = await Promise.all([ + import(/* webpackChunkName: "chartjs" */ 'chart.js/auto'), + loaded ? Promise.resolve() : wait(__MC_DELAY__), + ]) + + loaded = true + + Chart.defaults.borderColor = darkmode ? '#ccc' : '#36A2EB' + Chart.defaults.color = darkmode ? '#fff' : '#000' + Chart.defaults.maintainAspectRatio = false + + const data = parseChartConfig(config.value, props.type) + const ctx = chartCanvasElement.value!.getContext('2d')! + + chart?.destroy() + chart = new Chart(ctx, data) + + loading.value = false + } + + watch(isDarkmode, (value) => renderChart(value), { immediate: true }) + + return (): (VNode | null)[] => [ + props.title + ? h('div', { class: 'chartjs-title' }, decodeURIComponent(props.title)) + : null, + loading.value + ? h(LoadingIcon, { class: 'chartjs-loading', height: 192 }) + : null, + h( + 'div', + { + ref: chartElement, + class: 'chartjs-wrapper', + id: props.id, + style: { + display: loading.value ? 'none' : 'block', + }, + }, + h('canvas', { + ref: chartCanvasElement, + height: 400, + }), + ), + ] + }, +}) diff --git a/plugins/markdown/plugin-markdown-chart/src/client/components/ECharts.ts b/plugins/markdown/plugin-markdown-chart/src/client/components/ECharts.ts new file mode 100644 index 0000000000..f58044af6b --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/components/ECharts.ts @@ -0,0 +1,142 @@ +import { LoadingIcon, decodeData, wait } from '@vuepress/helper/client' +import { useDebounceFn, useEventListener } from '@vueuse/core' +import type { EChartsOption, EChartsType } from 'echarts' +import type { PropType, VNode } from 'vue' +import { + defineComponent, + h, + onMounted, + onUnmounted, + ref, + shallowRef, +} from 'vue' + +import { useEChartsConfig } from '../helpers/index.js' +import '../styles/echarts.css' + +declare const __MC_DELAY__: number + +interface EChartsConfig { + width?: number + height?: number + option: EChartsOption +} + +const AsyncFunction = (async (): Promise => {}).constructor + +const parseEChartsConfig = ( + config: string, + type: 'js' | 'json', + echarts: EChartsType, +): Promise => { + if (type === 'js') { + // eslint-disable-next-line @typescript-eslint/no-unsafe-call + const runner = AsyncFunction( + 'echarts', + `\ +let width,height,option,__echarts_config__; +{ +${config} +__echarts_config__={width,height,option}; +} +return __echarts_config__; +`, + ) as (echarts: EChartsType) => Promise + + return runner(echarts) + } + + return Promise.resolve({ option: JSON.parse(config) as EChartsOption }) +} + +export default defineComponent({ + name: 'ECharts', + + props: { + /** + * ECharts config + * + * 图表配置 + */ + config: { type: String, required: true }, + + /** + * Chart id + * + * 图表 id + */ + id: { type: String, required: true }, + + /** + * Chart title + * + * 图表标题 + */ + title: { type: String, default: '' }, + + /** + * Chart config type + * + * 图表配置类型 + */ + type: { type: String as PropType<'js' | 'json'>, default: 'json' }, + }, + + setup(props) { + const echartsConfig = useEChartsConfig() + + const loading = ref(true) + const echartsContainer = shallowRef() + + let chart: EChartsType | null = null + + useEventListener( + 'resize', + useDebounceFn(() => { + chart?.resize() + }, 100), + ) + + onMounted(() => { + void Promise.all([ + import(/* webpackChunkName: "echarts" */ 'echarts'), + wait(__MC_DELAY__), + ]).then(async ([echarts]) => { + await echartsConfig.setup?.() + + chart = echarts.init(echartsContainer.value) + + const { option, ...size } = await parseEChartsConfig( + decodeData(props.config), + props.type, + chart, + ) + + chart.resize(size) + chart.setOption({ ...echartsConfig.option, ...option }) + + loading.value = false + }) + }) + + onUnmounted(() => { + chart?.dispose() + }) + + return (): (VNode | null)[] => [ + props.title + ? h('div', { class: 'echarts-title' }, decodeURIComponent(props.title)) + : null, + h('div', { class: 'echarts-wrapper' }, [ + h('div', { + ref: echartsContainer, + class: 'echarts-container', + id: props.id, + }), + loading.value + ? h(LoadingIcon, { class: 'echarts-loading', height: 360 }) + : null, + ]), + ] + }, +}) diff --git a/plugins/markdown/plugin-markdown-chart/src/client/components/FlowChart.ts b/plugins/markdown/plugin-markdown-chart/src/client/components/FlowChart.ts new file mode 100644 index 0000000000..f3673c1464 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/components/FlowChart.ts @@ -0,0 +1,112 @@ +import { LoadingIcon, decodeData, wait } from '@vuepress/helper/client' +import { useDebounceFn, useEventListener } from '@vueuse/core' +import type { Chart } from 'flowchart.ts' +import type { PropType, VNode } from 'vue' +import { computed, defineComponent, h, onMounted, ref, shallowRef } from 'vue' + +import { flowchartPresets } from '../utils/index.js' + +import '../styles/flowchart.css' + +declare const __MC_DELAY__: number + +export default defineComponent({ + name: 'FlowChart', + + props: { + /** + * Flowchart code content + * + * 流程图代码内容 + */ + code: { type: String, required: true }, + + /** + * Flowchart id + * + * 流程图 id + */ + id: { type: String, required: true }, + + /** + * Flowchart preset + * + * 流程图预设 + */ + preset: { + type: String as PropType<'ant' | 'pie' | 'vue'>, + default: 'vue', + }, + }, + + setup(props) { + let flowchart: Chart | null = null + const element = shallowRef() + + const loading = ref(true) + const scale = ref(1) + + const preset = computed>(() => { + const current = flowchartPresets[props.preset] + + // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition + if (!current) { + // eslint-disable-next-line no-console + console.warn(`[md-enhance:flowchart] Unknown preset: ${props.preset}`) + + return flowchartPresets.vue + } + + return current + }) + + const getScale = (width: number): number => + width < 419 ? 0.8 : width > 1280 ? 1 : 0.9 + + useEventListener( + 'resize', + useDebounceFn(() => { + if (flowchart) { + const newScale = getScale(window.innerWidth) + + if (scale.value !== newScale) { + scale.value = newScale + + flowchart.draw(props.id, { ...preset.value, scale: newScale }) + } + } + }, 100), + ) + + onMounted(() => { + void Promise.all([ + import(/* webpackChunkName: "flowchart" */ 'flowchart.ts'), + wait(__MC_DELAY__), + ]).then(([{ parse }]) => { + flowchart = parse(decodeData(props.code)) + + // Update scale + scale.value = getScale(window.innerWidth) + + loading.value = false + + // Draw svg to #id + flowchart.draw(props.id, { ...preset.value, scale: scale.value }) + }) + }) + + return (): (VNode | null)[] => [ + loading.value + ? h(LoadingIcon, { class: 'flowchart-loading', height: 192 }) + : null, + h('div', { + ref: element, + class: ['flowchart-wrapper', props.preset], + id: props.id, + style: { + display: loading.value ? 'none' : 'block', + }, + }), + ] + }, +}) diff --git a/plugins/markdown/plugin-markdown-chart/src/client/components/MarkMap.ts b/plugins/markdown/plugin-markdown-chart/src/client/components/MarkMap.ts new file mode 100644 index 0000000000..aeb601c5ba --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/components/MarkMap.ts @@ -0,0 +1,113 @@ +import { LoadingIcon, decodeData } from '@vuepress/helper/client' +import { useDebounceFn, useEventListener } from '@vueuse/core' +import type { Markmap } from 'markmap-view' +import type { VNode } from 'vue' +import { + defineComponent, + h, + onMounted, + onUnmounted, + ref, + shallowRef, +} from 'vue' + +import '../styles/markmap.css' + +declare const __MC_DELAY__: number + +export default defineComponent({ + name: 'MarkMap', + + props: { + /** + * Chart id + * + * 图表 id + */ + id: { type: String, required: true }, + + /** + * Markmap data + * + * Markmap 数据 + */ + data: { type: String, required: true }, + }, + + setup(props) { + const loading = ref(true) + const markupWrapper = shallowRef() + const markmapSvg = shallowRef() + + let markmap: Markmap | null = null + + useEventListener( + 'resize', + useDebounceFn(() => { + void markmap?.fit() + }, 100), + ) + + onMounted(() => { + void Promise.all([ + import(/* webpackChunkName: "markmap" */ 'markmap-lib'), + import(/* webpackChunkName: "markmap" */ 'markmap-view'), + import(/* webpackChunkName: "markmap" */ 'markmap-toolbar'), + // Delay + new Promise((resolve) => { + setTimeout(resolve, __MC_DELAY__) + }), + ]).then( + async ([{ Transformer, builtInPlugins }, markmapView, { Toolbar }]) => { + const { Markmap, deriveOptions, loadCSS, loadJS } = markmapView + + const transformer = new Transformer(builtInPlugins) + const { features, frontmatter, root } = transformer.transform( + decodeData(props.data), + ) + const { styles, scripts } = transformer.getUsedAssets(features) + + if (styles) await loadCSS(styles) + if (scripts) await loadJS(scripts, { getMarkmap: () => markmapView }) + + markmap = Markmap.create( + markmapSvg.value!, + deriveOptions({ + maxWidth: 240, + ...frontmatter?.markmap, + }), + root, + ) + + await markmap.fit() + + const { el } = Toolbar.create(markmap) + + el.style.position = 'absolute' + el.style.bottom = '0.5rem' + el.style.right = '0.5rem' + + markupWrapper.value!.append(el) + + loading.value = false + }, + ) + }) + + onUnmounted(() => { + markmap?.destroy() + }) + + return (): VNode => + h('div', { class: 'markmap-wrapper', ref: markupWrapper }, [ + h('svg', { + ref: markmapSvg, + class: 'markmap-svg', + id: props.id, + }), + loading.value + ? h(LoadingIcon, { class: 'markmap-loading', height: 360 }) + : null, + ]) + }, +}) diff --git a/plugins/markdown/plugin-markdown-chart/src/client/components/Mermaid.ts b/plugins/markdown/plugin-markdown-chart/src/client/components/Mermaid.ts new file mode 100644 index 0000000000..9bb1b9b2c2 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/components/Mermaid.ts @@ -0,0 +1,228 @@ +import { + LoadingIcon, + decodeData, + isFunction, + useDarkmode, +} from '@vuepress/helper/client' +import type { VNode } from 'vue' +import { + computed, + defineComponent, + h, + onMounted, + ref, + shallowRef, + watch, +} from 'vue' + +import { useMermaidOptions } from '../helpers/index.js' +import type { MermaidThemeVariables } from '../typings/index.js' + +import '../styles/mermaid.css' + +declare const __MC_DELAY__: number + +const DEFAULT_CHART_OPTIONS = { useMaxWidth: false } + +const getThemeVariables = (isDarkmode: boolean): MermaidThemeVariables => ({ + dark: isDarkmode, + background: isDarkmode ? '#1e1e1e' : '#fff', + + primaryColor: isDarkmode ? '#389d70' : '#4abf8a', + primaryBorderColor: isDarkmode ? '#389d70' : '#4abf8a', + primaryTextColor: isDarkmode ? '#fff' : '#000', + + secondaryColor: '#ffb500', + secondaryBorderColor: isDarkmode ? '#fff' : '#000', + secondaryTextColor: isDarkmode ? '#ddd' : '#333', + + tertiaryColor: isDarkmode ? '#282828' : '#efeef4', + tertiaryBorderColor: isDarkmode ? '#bbb' : '#242424', + tertiaryTextColor: isDarkmode ? '#ddd' : '#333', + + // Note + noteBkgColor: isDarkmode ? '#f6d365' : '#fff5ad', + noteTextColor: '#242424', + noteBorderColor: isDarkmode ? '#f6d365' : '#333', + + lineColor: isDarkmode ? '#d3d3d3' : '#333', + textColor: isDarkmode ? '#fff' : '#242424', + + mainBkg: isDarkmode ? '#389d70' : '#4abf8a', + errorBkgColor: '#eb4d5d', + errorTextColor: '#fff', + + // Flowchart + nodeBorder: isDarkmode ? '#389d70' : '#4abf8a', + nodeTextColor: isDarkmode ? '#fff' : '#242424', + + // Sequence + signalTextColor: isDarkmode ? '#9e9e9e' : '#242424', + + // Class + classText: '#fff', + + // State + labelColor: '#fff', + + attributeBackgroundColorEven: isDarkmode ? '#0d1117' : '#fff', + attributeBackgroundColorOdd: isDarkmode ? '#161b22' : '#f8f8f8', + + // Colors + fillType0: isDarkmode ? '#cf1322' : '#f1636e', + fillType1: '#f39c12', + fillType2: '#2ecc71', + fillType3: '#fa541c', + fillType4: '#25a55b', + fillType5: '#13c2c2', + fillType6: '#096dd9', + fillType7: '#aa6fe9', +}) + +export default defineComponent({ + name: 'Mermaid', + + props: { + /** + * Mermaid id + */ + id: { type: String, required: true }, + + /** + * Mermaid config + * + * Mermaid 配置 + */ + code: { type: String, required: true }, + + /** + * Mermaid title + * + * Mermaid 标题 + */ + title: { type: String, default: '' }, + }, + + setup(props) { + const isDarkmode = useDarkmode() + const { themeVariables, ...mermaidOptions } = useMermaidOptions() + const mermaidElement = shallowRef() + + const code = computed(() => decodeData(props.code)) + + const svgCode = ref('') + let loaded = false + + const renderMermaid = async (): Promise => { + const [{ default: mermaid }] = await Promise.all([ + import( + /* webpackChunkName: "mermaid" */ 'mermaid/dist/mermaid.esm.min.mjs' + ), + loaded + ? Promise.resolve() + : ((loaded = true), + new Promise((resolve) => { + setTimeout(resolve, __MC_DELAY__) + })), + ]) + + mermaid.initialize({ + theme: 'base', + themeVariables: { + ...getThemeVariables(isDarkmode.value), + ...(isFunction(themeVariables) + ? themeVariables(isDarkmode.value) + : themeVariables), + }, + flowchart: DEFAULT_CHART_OPTIONS, + sequence: DEFAULT_CHART_OPTIONS, + journey: DEFAULT_CHART_OPTIONS, + gantt: DEFAULT_CHART_OPTIONS, + er: DEFAULT_CHART_OPTIONS, + pie: DEFAULT_CHART_OPTIONS, + ...mermaidOptions, + startOnLoad: false, + }) + + svgCode.value = (await mermaid.render(props.id, code.value)).svg + } + + const preview = (): void => { + const { body } = document + const div = document.createElement('div') + + div.classList.add('mermaid-preview') + + div.innerHTML = svgCode.value + body.appendChild(div) + + div.addEventListener('click', () => { + body.removeChild(div) + }) + } + + const download = (): void => { + const dataURI = `data:image/svg+xml;charset=utf8,${svgCode.value + .replace(/
/g, '
') + .replace(/%/g, '%25') + .replace(/"/g, '%22') + .replace(/'/g, '%27') + .replace(/&/g, '%26') + .replace(/#/g, '%23') + .replace(/{/g, '%7B') + .replace(/}/g, '%7D') + .replace(//g, '%3E')}` + + const a = document.createElement('a') + + a.setAttribute('href', dataURI) + a.setAttribute( + 'download', + `${props.title ? decodeData(props.title) : props.id}.svg`, + ) + a.click() + } + + watch(isDarkmode, () => renderMermaid()) + + onMounted(() => { + void renderMermaid() + }) + + return (): VNode[] => [ + h('div', { class: 'mermaid-actions' }, [ + h('button', { + class: 'preview-button', + onClick: () => { + preview() + }, + title: 'preview', + innerHTML: + '', + }), + h('button', { + class: 'download-button', + onClick: () => { + download() + }, + title: 'download', + innerHTML: + '', + }), + ]), + h( + 'div', + { + ref: mermaidElement, + class: 'mermaid-wrapper', + }, + svgCode.value + ? // Mermaid + h('div', { class: 'mermaid-content', innerHTML: svgCode.value }) + : // Loading + h(LoadingIcon, { class: 'mermaid-loading', height: 96 }), + ), + ] + }, +}) diff --git a/plugins/markdown/plugin-markdown-chart/src/client/helpers/echarts.ts b/plugins/markdown/plugin-markdown-chart/src/client/helpers/echarts.ts new file mode 100644 index 0000000000..12d49b0ed8 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/helpers/echarts.ts @@ -0,0 +1,38 @@ +import type { EChartsOption } from 'echarts' +import type { App } from 'vue' +import { inject } from 'vue' + +declare const __VUEPRESS_DEV__: boolean + +export interface EChartsConfig { + /** + * ECharts global options + * + * ECharts 全局选项 + */ + option?: EChartsOption + + /** + * ECharts setup function + * + * ECharts 初始化函数 + */ + setup?: () => Promise +} + +let echartsConfig: EChartsConfig = {} + +const echartsSymbol = Symbol(__VUEPRESS_DEV__ ? 'echarts' : '') + +export const defineEChartsConfig = (config: EChartsConfig): void => { + echartsConfig = config +} + +/** @deprecated: use defineEChartsConfig instead */ +export const defineEchartsConfig = defineEChartsConfig + +export const useEChartsConfig = (): EChartsConfig => inject(echartsSymbol)! + +export const injectEChartsConfig = (app: App): void => { + app.provide(echartsSymbol, echartsConfig) +} diff --git a/plugins/markdown/plugin-markdown-chart/src/client/helpers/index.ts b/plugins/markdown/plugin-markdown-chart/src/client/helpers/index.ts new file mode 100644 index 0000000000..2be54ab565 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/helpers/index.ts @@ -0,0 +1,2 @@ +export * from './echarts.js' +export * from './mermaid.js' diff --git a/plugins/markdown/plugin-markdown-chart/src/client/helpers/mermaid.ts b/plugins/markdown/plugin-markdown-chart/src/client/helpers/mermaid.ts new file mode 100644 index 0000000000..0e51166a60 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/helpers/mermaid.ts @@ -0,0 +1,20 @@ +import type { App } from 'vue' +import { inject } from 'vue' + +import type { MermaidOptions } from '../typings/index.js' + +declare const __VUEPRESS_DEV__: boolean + +let mermaidOptions: MermaidOptions = {} + +const mermaidSymbol = Symbol(__VUEPRESS_DEV__ ? 'mermaid' : '') + +export const defineMermaidConfig = (options: MermaidOptions): void => { + mermaidOptions = options +} + +export const useMermaidOptions = (): MermaidOptions => inject(mermaidSymbol)! + +export const injectMermaidConfig = (app: App): void => { + app.provide(mermaidSymbol, mermaidOptions) +} diff --git a/plugins/markdown/plugin-markdown-chart/src/client/index.ts b/plugins/markdown/plugin-markdown-chart/src/client/index.ts new file mode 100644 index 0000000000..e094067de8 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/index.ts @@ -0,0 +1 @@ +export * from './helpers/index.js' diff --git a/plugins/markdown/plugin-markdown-chart/src/client/styles/chartjs.scss b/plugins/markdown/plugin-markdown-chart/src/client/styles/chartjs.scss new file mode 100644 index 0000000000..83d84a3204 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/styles/chartjs.scss @@ -0,0 +1,26 @@ +.chartjs-title { + margin: 0.5rem auto; + font-weight: 600; + font-size: 18px; + text-align: center; +} + +.chartjs-loading { + color: var(--vp-c-accent-bg); +} + +.chartjs-wrapper { + overflow-x: auto; + padding: 0.6em 0.4em; + text-align: center; + transition: all 1s; + + @media print { + page-break-inside: avoid; + } + + @media (max-width: 719px) { + margin: 0 -1rem; + padding: 0.6em 0; + } +} diff --git a/plugins/markdown/plugin-markdown-chart/src/client/styles/echarts.scss b/plugins/markdown/plugin-markdown-chart/src/client/styles/echarts.scss new file mode 100644 index 0000000000..d1b724e8fe --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/styles/echarts.scss @@ -0,0 +1,34 @@ +.echarts-title { + margin: 1rem auto 0.5rem; + font-weight: 600; + font-size: 18px; + text-align: center; +} + +.echarts-wrapper { + position: relative; + text-align: center; + transition: all 1s; + + @media (max-width: 719px) { + margin: 0 -1rem; + } + + @media print { + page-break-inside: avoid; + } +} + +.echarts-container { + min-height: 360px; + + @media print { + page-break-inside: avoid; + } +} + +.echarts-loading { + position: absolute; + inset: 0 0 auto; + color: var(--vp-c-accent-bg); +} diff --git a/plugins/markdown/plugin-markdown-chart/src/client/styles/flowchart.scss b/plugins/markdown/plugin-markdown-chart/src/client/styles/flowchart.scss new file mode 100644 index 0000000000..065afd35d3 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/styles/flowchart.scss @@ -0,0 +1,33 @@ +.flowchart-loading { + color: var(--vp-c-accent-bg); +} + +.flowchart-wrapper { + overflow-x: auto; + + padding: 0.6em 0.4em; + + text-align: center; + direction: ltr; + + transition: all 1s; + + @media print { + page-break-inside: avoid; + } + + @media (max-width: 719px) { + margin: 0 -1.5rem; + padding: 0.6em 0; + } + + &.vue { + .start-element, + .end-element, + .operation-element, + .parallel-element { + rx: 5px; + ry: 5px; + } + } +} diff --git a/plugins/markdown/plugin-markdown-chart/src/client/styles/markmap.scss b/plugins/markdown/plugin-markdown-chart/src/client/styles/markmap.scss new file mode 100644 index 0000000000..223dfe4b96 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/styles/markmap.scss @@ -0,0 +1,125 @@ +.markmap-title { + margin: 1rem auto 0.5rem; + font-weight: 600; + font-size: 18px; + text-align: center; +} + +// override css variables +.markmap { + --markmap-a-color: var(--vp-c-accent) !important; + --markmap-a-hover-color: var(--vp-c-accent) !important; + --markmap-code-bg: var(--vp-c-border) !important; + --markmap-code-color: var(--vp-c-text) !important; + --markup-circle-open-bg: var(--vp-c-white) !important; + --markup-text-color: var(--vp-c-text) !important; +} + +.markmap-wrapper { + position: relative; + text-align: center; + transition: all 1s; + + @media (max-width: 719px) { + margin: 0 -1rem; + } + + pre { + padding: 0 !important; + line-height: inherit !important; + + code { + padding: 0 !important; + background-color: var(--vp-c-border) !important; + color: inherit; + } + } + + // FIXME: katex can not work with math plugin + .katex-html { + display: none; + } +} + +.markmap-svg { + width: 100%; + min-height: 360px; + color: var(--vp-c-text); + + @media print { + page-break-inside: avoid; + } +} + +.markmap-loading { + position: absolute; + inset: 0 0 auto; + color: var(--vp-c-accent-bg); +} + +.mm-toolbar { + display: flex; + align-items: center; + + padding: 0.25rem; + border-width: 1px; + border-style: solid; + border-color: var(--vp-c-border); + border-radius: 0.25rem; + + background: var(--vp-c-control); + + line-height: 1; + + user-select: none; + + &:hover { + box-shadow: 0 2px 12px 0 var(--vp-c-shadow); + } + + .mm-toolbar-brand { + display: none; + } + + svg { + display: block; + } + + a { + display: inline-block; + text-decoration-line: none; + } + + > span { + padding-right: 0.25rem; + padding-left: 0.25rem; + } +} + +.mm-toolbar-item { + &:not(:first-child) { + margin-left: 0.25rem; + } + + > * { + min-width: 20px; + height: 20px; + + font-size: 0.75rem; + line-height: 1rem; + line-height: 20px; + text-align: center; + + cursor: pointer; + } + + &.active, + &:hover { + border-radius: 0.25rem; + background-color: var(--vp-c-accent-bg); + + > * { + color: var(--vp-c-control); + } + } +} diff --git a/plugins/markdown/plugin-markdown-chart/src/client/styles/mermaid.scss b/plugins/markdown/plugin-markdown-chart/src/client/styles/mermaid.scss new file mode 100644 index 0000000000..0f3a5dd9aa --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/styles/mermaid.scss @@ -0,0 +1,96 @@ +.mermaid-preview, +.mermaid-wrapper { + // mermaid style fix + .node rect, + .clusters rect, + rect.note, + .actor { + rx: 8; + ry: 8; + } +} + +.mermaid-wrapper { + position: relative; + + overflow-x: auto; + + padding: 0.6em 0.4em; + + text-align: center; + + transition: all 1s; + + @media (max-width: 419px) { + margin: 0 -1.5rem; + padding: 0.6em 0; + } +} + +.mermaid-loading { + color: var(--vp-c-accent-bg); +} + +.mermaid-content { + @media print { + page-break-inside: avoid; + } +} + +.mermaid-actions { + text-align: end; + + @media print { + display: none; + } +} + +.mermaid-preview { + position: fixed; + inset: 0; + z-index: 800; + + display: flex; + align-items: center; + justify-content: center; + + background-color: rgb(255 255 255 / 80%); + + [data-theme='dark'] & { + background-color: rgb(0 0 0 / 80%); + } + + svg { + max-width: 100%; + max-height: 100%; + } +} + +.preview-button, +.download-button { + width: 2rem; + height: 2rem; + margin: 0.25rem; + padding: 0.5rem; + border-width: 0; + border-radius: 0.5rem; + + background: var(--vp-c-control); + color: var(--vp-c-text-mute); + + cursor: pointer; + + @media (max-width: 719px) { + width: 1.5rem; + height: 1.5rem; + } + + &:hover { + background: var(--vp-c-control-hover); + } + + svg { + width: 100%; + height: 100%; + } +} diff --git a/plugins/markdown/plugin-markdown-chart/src/client/typings/index.ts b/plugins/markdown/plugin-markdown-chart/src/client/typings/index.ts new file mode 100644 index 0000000000..8f807c7121 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/typings/index.ts @@ -0,0 +1 @@ +export type * from './mermaid.js' diff --git a/plugins/markdown/plugin-markdown-chart/src/client/typings/mermaid.ts b/plugins/markdown/plugin-markdown-chart/src/client/typings/mermaid.ts new file mode 100644 index 0000000000..26aea2b195 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/typings/mermaid.ts @@ -0,0 +1,171 @@ +import type { MermaidConfig } from 'mermaid' + +export interface MermaidThemeVariables { + dark?: boolean + background?: string + + // Basic + textColor?: string + lineColor?: string + mainBkg?: string + errorBkgColor?: string + errorTextColor?: string + fontFamily?: string + titleColor?: string + border1?: string + border2?: string + + // Nodes + nodeBorder?: string + nodeTextColor?: string + + primaryColor?: string + primaryBorderColor?: string + primaryTextColor?: string + + secondaryColor?: string + secondaryBorderColor?: string + secondaryTextColor?: string + + tertiaryColor?: string + tertiaryBorderColor?: string + tertiaryTextColor?: string + + // C4 + personBorder?: string + personBkg?: string + + // Class + classText?: string + + // Er + attributeBackgroundColorOdd?: string + attributeBackgroundColorEven?: string + + // Flowchart + arrowheadColor?: string + clusterBkg?: string + clusterBorder?: string + edgeLabelBackground?: string + + // Gantt + excludeBkgColor?: string + sectionBkgColor?: string + sectionBkgColor2?: string + altSectionBkgColor?: string + gridColor?: string + todayLineColor?: string + taskBkgColor?: string + taskBorderColor?: string + taskTextColor?: string + taskTextDarkColor?: string + taskTextClickableColor?: string + taskTextOutsideColor?: string + activeTaskBorderColor?: string + activeTaskBkgColor?: string + doneTaskBorderColor?: string + doneTaskBkgColor?: string + critBorderColor?: string + critBkgColor?: string + + // Git + git1?: string + git2?: string + git3?: string + git4?: string + git5?: string + git6?: string + git7?: string + gitBranchLabel1?: string + gitBranchLabel2?: string + gitBranchLabel3?: string + gitBranchLabel4?: string + gitBranchLabel5?: string + gitBranchLabel6?: string + gitBranchLabel7?: string + gitInv1?: string + gitInv2?: string + gitInv3?: string + gitInv4?: string + gitInv5?: string + gitInv6?: string + gitInv7?: string + commitLabelBackground?: string + commitLabelColor?: string + commitLabelFontSize?: string + tagLabelBorder?: string + tagLabelBackground?: string + tagLabelColor?: string + tagLabelFontSize?: string + + // Journey + fillType0?: string + fillType1?: string + fillType2?: string + fillType3?: string + fillType4?: string + fillType5?: string + fillType6?: string + fillType7?: string + + // Pie + pie1?: string + pie2?: string + pie3?: string + pie4?: string + pie5?: string + pie6?: string + pie7?: string + pie8?: string + pie9?: string + pie10?: string + pie11?: string + pie12?: string + pieStrokeWidth?: string + pieOpacity?: string + pieOuterStrokeColor?: string + pieOuterStrokeWidth?: string + pieTitleTextSize?: string + pieTitleTextColor?: string + + // Requirement + requirementBackground?: string + requirementBorderColor?: string + requirementBorderSize?: string + requirementTextColor?: string + relationColor?: string + relationLabelBackground?: string + relationLabelColor?: string + + // State + labelColor?: string + + // Sequence + signalColor?: string + signalTextColor?: string + labelBoxBorderColor?: string + labelBoxBkgColor?: string + labelTextColor?: string + loopTextColor?: string + noteBkgColor?: string + noteTextColor?: string + noteBorderColor?: string + activationBorderColor?: string + activationBkgColor?: string + sequenceNumberColor?: string + actorBorder?: string + actorBkg?: string + actorTextColor?: string + actorLineColor?: string + + [props: string]: boolean | string | undefined +} + +export type MermaidOptions = Omit< + MermaidConfig, + 'startOnLoad' | 'themeVariables' +> & { + themeVariables?: + | MermaidThemeVariables + | ((isDarkmode: boolean) => MermaidThemeVariables) +} diff --git a/plugins/markdown/plugin-markdown-chart/src/client/utils/flowchart-presets/ant.ts b/plugins/markdown/plugin-markdown-chart/src/client/utils/flowchart-presets/ant.ts new file mode 100644 index 0000000000..16cae94323 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/utils/flowchart-presets/ant.ts @@ -0,0 +1,52 @@ +import base from './base.js' + +export default { + ...base, + + // Style symbol types + symbols: { + start: { + 'class': 'start-element', + 'font-color': '#fff', + 'fill': '#595959', + 'line-width': '0px', + }, + end: { + 'class': 'end-element', + 'font-color': '#fff', + 'fill': '#595959', + 'line-width': '0px', + }, + operation: { + 'class': 'operation-element', + 'font-color': '#fff', + 'fill': '#1890ff', + 'line-width': '0px', + }, + inputoutput: { + 'class': 'inputoutput-element', + 'font-color': '#fff', + 'fill': '#1890ff', + 'line-width': '0px', + }, + subroutine: { + 'class': 'subroutine-element', + 'font-color': '#fff', + 'fill': '#FF485E', + 'element-color': '#fff', + 'line-color': 'red', + }, + condition: { + 'class': 'condition-element', + 'font-color': '#fff', + 'fill': '#FF485E', + 'line-width': '0px', + }, + parallel: { + 'class': 'parallel-element', + 'font-color': '#fff', + 'fill': '#1890ff', + 'line-width': '0px', + }, + }, +} diff --git a/plugins/markdown/plugin-markdown-chart/src/client/utils/flowchart-presets/base.ts b/plugins/markdown/plugin-markdown-chart/src/client/utils/flowchart-presets/base.ts new file mode 100644 index 0000000000..2b27fd7b08 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/utils/flowchart-presets/base.ts @@ -0,0 +1,16 @@ +export default { + 'x': 0, + 'y': 0, + 'line-width': 2, + 'line-length': 40, + 'text-margin': 8, + 'font-size': 14, + 'font-color': '#8DA1AC', + 'line-color': '#8DA1AC', + 'element-color': 'black', + 'fill': 'white', + 'yes-text': 'Yes', + 'no-text': 'No', + 'arrow-end': 'block', + 'scale': 1, +} diff --git a/plugins/markdown/plugin-markdown-chart/src/client/utils/flowchart-presets/index.ts b/plugins/markdown/plugin-markdown-chart/src/client/utils/flowchart-presets/index.ts new file mode 100644 index 0000000000..93fa914822 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/utils/flowchart-presets/index.ts @@ -0,0 +1,15 @@ +/** + * Forked from https://github.com/ulivz/vuepress-plugin-flowchart/tree/master/lib/presets + * + * MIT LICENSED + */ + +import ant from './ant.js' +import pie from './pie.js' +import vue from './vue.js' + +export const flowchartPresets = { + ant, + vue, + pie, +} diff --git a/plugins/markdown/plugin-markdown-chart/src/client/utils/flowchart-presets/pie.ts b/plugins/markdown/plugin-markdown-chart/src/client/utils/flowchart-presets/pie.ts new file mode 100644 index 0000000000..50c482fef9 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/utils/flowchart-presets/pie.ts @@ -0,0 +1,52 @@ +import base from './base.js' + +export default { + ...base, + + // Style symbol types + 'line-width': 1, + 'symbols': { + start: { + 'class': 'start-element', + 'fill': '#ccc', + 'line-color': '#5c6ac4', + 'font-color': '#000', + }, + end: { + 'class': 'end-element', + 'fill': '#ccc', + 'line-color': '#5c6ac4', + 'font-color': '#000', + }, + operation: { + 'class': 'operation-element', + 'fill': '#f1f1f1', + 'line-color': '#5c6ac4', + 'font-color': '#000', + }, + inputoutput: { + 'class': 'inputoutput-element', + 'fill': '#f1f1f1', + 'line-color': '#5c6ac4', + 'font-color': '#000', + }, + subroutine: { + 'class': 'subroutine-element', + 'fill': '#f1f1f1', + 'line-color': '#5c6ac4', + 'font-color': '#000', + }, + condition: { + 'class': 'condition-element', + 'fill': '#f1f1f1', + 'line-color': '#5c6ac4', + 'font-color': '#000', + }, + parallel: { + 'class': 'parallel-element', + 'fill': '#f1f1f1', + 'line-color': '#5c6ac4', + 'font-color': '#000', + }, + }, +} diff --git a/plugins/markdown/plugin-markdown-chart/src/client/utils/flowchart-presets/vue.ts b/plugins/markdown/plugin-markdown-chart/src/client/utils/flowchart-presets/vue.ts new file mode 100644 index 0000000000..a895093acc --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/utils/flowchart-presets/vue.ts @@ -0,0 +1,52 @@ +import base from './base.js' + +export default { + ...base, + + // Style symbol types + symbols: { + start: { + 'class': 'start-element', + 'font-color': '#fff', + 'fill': '#2F495F', + 'line-width': '0px', + }, + end: { + 'class': 'end-element', + 'font-color': '#fff', + 'fill': '#2F495F', + 'line-width': '0px', + }, + operation: { + 'class': 'operation-element', + 'font-color': '#fff', + 'fill': '#00BC7D', + 'line-width': '0px', + }, + inputoutput: { + 'class': 'inputoutput-element', + 'font-color': '#fff', + 'fill': '#EB4D5D', + 'line-width': '0px', + }, + subroutine: { + 'class': 'subroutine-element', + 'font-color': '#fff', + 'fill': '#937AC4', + 'element-color': '#fff', + 'line-color': 'red', + }, + condition: { + 'class': 'condition-element', + 'font-color': '#fff', + 'fill': '#FFB500', + 'line-width': '0px', + }, + parallel: { + 'class': 'parallel-element', + 'font-color': '#fff', + 'fill': '#2F495F', + 'line-width': '0px', + }, + }, +} diff --git a/plugins/markdown/plugin-markdown-chart/src/client/utils/index.ts b/plugins/markdown/plugin-markdown-chart/src/client/utils/index.ts new file mode 100644 index 0000000000..9ea8a139c6 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/client/utils/index.ts @@ -0,0 +1 @@ +export * from './flowchart-presets/index.js' diff --git a/plugins/markdown/plugin-markdown-chart/src/node/index.ts b/plugins/markdown/plugin-markdown-chart/src/node/index.ts new file mode 100644 index 0000000000..67a63436c3 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/node/index.ts @@ -0,0 +1,3 @@ +export * from './markdown-it-plugins/index.js' +export * from './markdownChartPlugin.js' +export type * from './options.js' diff --git a/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/chartjs.ts b/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/chartjs.ts new file mode 100644 index 0000000000..751c2cd4ee --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/chartjs.ts @@ -0,0 +1,47 @@ +import { container } from '@mdit/plugin-container' +import { encodeData } from '@vuepress/helper' +import type { PluginSimple } from 'markdown-it' + +export const chartjs: PluginSimple = (md) => { + container(md, { + name: 'chartjs', + openRender: (tokens, index) => { + const title = tokens[index].info + .trimStart() + // "chart" length + .slice(7) + .trim() + + const key = `chartjs-${index}` + + let config = '{}' + let configType = '' + + for (let i = index; i < tokens.length; i++) { + const { type, content, info } = tokens[i] + + if (type === 'container_chartjs_close') break + + if (!content) continue + if (type === 'fence') + if (info === 'json') { + config = encodeData(content) + configType = 'json' + } else if (info === 'js' || info === 'javascript') { + config = encodeData(content) + configType = 'js' + } + + // Set to an unknown token type + tokens[i].type = 'chartjs_empty' + // Hide token + tokens[i].hidden = true + } + + return `` + }, + closeRender: () => ``, + }) +} diff --git a/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/echarts.ts b/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/echarts.ts new file mode 100644 index 0000000000..0c4d1f6f5d --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/echarts.ts @@ -0,0 +1,74 @@ +import { container } from '@mdit/plugin-container' +import { encodeData } from '@vuepress/helper' +import type { PluginSimple } from 'markdown-it' +import type Token from 'markdown-it/lib/token.mjs' + +const echartsRender = (tokens: Token[], index: number): string => { + const token = tokens[index] + const key = `echarts-${index}` + const { content, info } = token + const title = info.trim().split(':', 2)[1] + + return `` +} + +export const echarts: PluginSimple = (md) => { + // Handle ```echarts blocks + const { fence } = md.renderer.rules + + md.renderer.rules.fence = (...args): string => { + const [tokens, index] = args + const { info } = tokens[index] + const realInfo = info.split(':', 2)[0] + + if (realInfo === 'echarts') return echartsRender(tokens, index) + + return fence!(...args) + } + + md.renderer.rules.echarts = echartsRender + + container(md, { + name: 'echarts', + + openRender: (tokens, index) => { + const title = tokens[index].info + .trimStart() + // 'echarts' length + .slice(7) + .trim() + + const key = `echarts-${index}` + + let config = '{}' + let isJavaScript = false + + for (let i = index; i < tokens.length; i++) { + const { type, content, info } = tokens[i] + + if (type === 'container_echarts_close') break + + if (!content) continue + if (type === 'fence') + if (info === 'json') { + config = content + } else if (info === 'js' || info === 'javascript') { + config = content + isJavaScript = true + } + + // Set to an unknown token type + tokens[i].type = 'echarts_empty' + // Hide token + tokens[i].hidden = true + } + + return `` + }, + closeRender: () => ``, + }) +} diff --git a/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/flowchart.ts b/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/flowchart.ts new file mode 100644 index 0000000000..d6f217cda7 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/flowchart.ts @@ -0,0 +1,31 @@ +import { encodeData } from '@vuepress/helper' +import type { PluginSimple } from 'markdown-it' +import type Token from 'markdown-it/lib/token.mjs' + +const flowchartRender = (tokens: Token[], index: number): string => { + const token = tokens[index] + const key = `flowchart-${index}` + const { content, info } = token + + return `` +} + +export const flowchart: PluginSimple = (md) => { + // Handle ```flow and ```flowchart blocks + const { fence } = md.renderer.rules + + md.renderer.rules.fence = (...args): string => { + const [tokens, index] = args + const { info } = tokens[index] + const [realInfo] = info.split(':', 2) + + if (realInfo === 'flow' || realInfo === 'flowchart') + return flowchartRender(tokens, index) + + return fence!(...args) + } + + md.renderer.rules.flowchart = flowchartRender +} diff --git a/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/index.ts b/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/index.ts new file mode 100644 index 0000000000..581ec6f2f3 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/index.ts @@ -0,0 +1,6 @@ +export * from './chartjs.js' +export * from './echarts.js' +export * from './flowchart.js' +export * from './markmap.js' +export * from './mermaid.js' +export * from './plantuml.js' diff --git a/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/markmap.ts b/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/markmap.ts new file mode 100644 index 0000000000..994c1d8a1a --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/markmap.ts @@ -0,0 +1,28 @@ +import { encodeData } from '@vuepress/helper' +import type { PluginSimple } from 'markdown-it' +import type Token from 'markdown-it/lib/token.mjs' + +const markmapRender = (tokens: Token[], index: number): string => { + const token = tokens[index] + const key = `markmap-${index}` + const { content } = token + + return `` +} + +export const markmap: PluginSimple = (md) => { + // Handle ```markmap blocks + const { fence } = md.renderer.rules + + md.renderer.rules.fence = (...args): string => { + const [tokens, index] = args + const { info } = tokens[index] + const [realInfo] = info.split(':', 2) + + if (realInfo === 'markmap') return markmapRender(tokens, index) + + return fence!(...args) + } + + md.renderer.rules.markmap = markmapRender +} diff --git a/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/mermaid.ts b/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/mermaid.ts new file mode 100644 index 0000000000..fdedeb0dfa --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/mermaid.ts @@ -0,0 +1,109 @@ +import { encodeData } from '@vuepress/helper' +import type { PluginSimple } from 'markdown-it' +import type { RenderRule } from 'markdown-it/lib/renderer.mjs' + +const mermaidRenderer: RenderRule = (tokens, index) => + `` + +interface MermaidOptions { + content: string + diagram?: string + title?: string + indent?: boolean +} + +export const getMermaidContent = ({ + diagram = 'mermaid', + content, + title = '', + indent = diagram !== 'mermaid', +}: MermaidOptions): string => `\ +${ + title + ? `\ +--- +title: ${title} +--- + +` + : '' +}\ +${ + diagram === 'mermaid' + ? '' + : `\ +${diagram} +` +}\ +${ + indent + ? content + .split('\n') + .map((line) => (line ? ` ${line}` : '')) + .join('\n') + : content +}\ +` + +const getMermaid = (options: MermaidOptions, index: number): string => + `` + +const DIAGRAM_MAP: Record = { + 'class': ['classDiagram'], + 'c4c': ['C4Context'], + 'er': ['erDiagram'], + 'gantt': [''], + 'git-graph': ['gitGraph'], + 'journey': [''], + 'mindmap': [''], + 'kanban': [''], + 'pie': [''], + 'quadrant': ['quadrantChart'], + 'requirement': ['requirementDiagram'], + 'sequence': ['sequenceDiagram'], + 'state': ['stateDiagram-v2'], + 'timeline': [''], + + // beta diagrams + 'architecture': ['architecture-beta'], + 'block': ['block-beta', false], + 'packet': ['packet-beta', false], + 'sankey': ['sankey-beta', false], + 'xy': ['xychart-beta', false], +} + +export const mermaid: PluginSimple = (md) => { + // Handle ```mermaid blocks + const { fence } = md.renderer.rules + + md.renderer.rules.fence = (...args): string => { + const [tokens, index] = args + const { content, info } = tokens[index] + + const fenceInfo = info.trim() + + if (fenceInfo === 'mermaid') + return getMermaid({ content, indent: false }, index) + + const [name, ...rest] = fenceInfo.split(' ') + + if (name in DIAGRAM_MAP) + return getMermaid( + { + diagram: DIAGRAM_MAP[name][0] || name, + title: rest.join(' '), + content, + indent: DIAGRAM_MAP[name][1] ?? true, + }, + index, + ) + + return fence!(...args) + } + + md.renderer.rules.mermaid = mermaidRenderer +} diff --git a/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/plantuml.ts b/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/plantuml.ts new file mode 100644 index 0000000000..aa5613a5cb --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/node/markdown-it-plugins/plantuml.ts @@ -0,0 +1,24 @@ +import type { MarkdownItPlantumlOptions } from '@mdit/plugin-plantuml' +import { plantuml as _plantuml } from '@mdit/plugin-plantuml' +import type { PluginWithOptions } from 'markdown-it' + +export const plantuml: PluginWithOptions = ( + md, + options = [ + 'chronology', + 'gantt', + 'json', + 'latex', + 'math', + 'mindmap', + 'regex', + 'salt', + 'uml', + 'wbs', + 'yaml', + ].map((name) => ({ name })), +) => { + options.forEach((option) => { + md.use(_plantuml, option) + }) +} diff --git a/plugins/markdown/plugin-markdown-chart/src/node/markdownChartPlugin.ts b/plugins/markdown/plugin-markdown-chart/src/node/markdownChartPlugin.ts new file mode 100644 index 0000000000..a683db311a --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/node/markdownChartPlugin.ts @@ -0,0 +1,117 @@ +import { + addViteOptimizeDepsExclude, + addViteOptimizeDepsInclude, + addViteSsrExternal, + addViteSsrNoExternal, + isArray, +} from '@vuepress/helper' +import type { Plugin } from 'vuepress/core' +import { + chartjs, + echarts, + flowchart, + markmap, + mermaid, + plantuml, +} from './markdown-it-plugins/index.js' +import type { MarkdownChartPluginOptions } from './options.js' +import { prepareConfigFile } from './prepareConfigFile.js' +import { PLUGIN_NAME, getInstallStatus, logger } from './utils.js' + +export const markdownChartPlugin = + (options: MarkdownChartPluginOptions = {}): Plugin => + (app) => { + if (app.env.isDebug) logger.info('Options:', options) + + const getStatus = ( + key: keyof MarkdownChartPluginOptions, + pkgs: string[] = [], + ): boolean => { + const enabled = Boolean(options[key]) + const pkgInstalled = pkgs.every((pkg) => + getInstallStatus(pkg, Boolean(options[key])), + ) + + return enabled && pkgInstalled + } + + const status = { + chartjs: getStatus('chartjs', ['chart.js']), + echarts: getStatus('echarts', ['echarts']), + flowchart: getStatus('flowchart', ['flowchart.ts']), + markmap: getStatus('markmap', [ + 'markmap-lib', + 'markmap-toolbar', + 'markmap-view', + ]), + mermaid: getStatus('mermaid', ['mermaid']), + } + + return { + name: PLUGIN_NAME, + + define: { + __MC_DELAY__: options.delay ?? 800, + }, + + extendsMarkdown: (md) => { + if (status.chartjs) md.use(chartjs) + if (status.echarts) md.use(echarts) + if (status.flowchart) md.use(flowchart) + if (isArray(options.plantuml)) md.use(plantuml, options) + else if (options.plantuml) md.use(plantuml) + if (status.markmap) md.use(markmap) + if (status.mermaid) md.use(mermaid) + }, + + extendsBundlerOptions: (bundlerOptions: unknown): void => { + addViteSsrNoExternal(bundlerOptions, app, [ + '@vuepress/helper', + 'fflate', + ]) + + if (status.chartjs) { + addViteOptimizeDepsExclude( + bundlerOptions, + app, + 'chart.js/auto/auto.mjs', + ) + addViteSsrExternal(bundlerOptions, app, 'chart.js') + } + + if (status.echarts) { + addViteOptimizeDepsExclude(bundlerOptions, app, 'echarts') + addViteSsrExternal(bundlerOptions, app, 'echarts') + } + + if (status.flowchart) { + addViteOptimizeDepsExclude(bundlerOptions, app, 'flowchart.ts') + addViteSsrExternal(bundlerOptions, app, 'flowchart.ts') + } + + if (status.markmap) { + addViteOptimizeDepsInclude(bundlerOptions, app, [ + 'markmap-lib', + 'markmap-toolbar', + 'markmap-view', + ]) + addViteSsrExternal(bundlerOptions, app, [ + 'markmap-lib', + 'markmap-toolbar', + 'markmap-view', + ]) + } + + if (status.mermaid) { + addViteOptimizeDepsExclude( + bundlerOptions, + app, + 'mermaid/dist/mermaid.esm.min.mjs', + ) + addViteSsrExternal(bundlerOptions, app, 'mermaid') + } + }, + + clientConfigFile: () => prepareConfigFile(app, status), + } + } diff --git a/plugins/markdown/plugin-markdown-chart/src/node/options.ts b/plugins/markdown/plugin-markdown-chart/src/node/options.ts new file mode 100644 index 0000000000..0380af2c5b --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/node/options.ts @@ -0,0 +1,70 @@ +import type { MarkdownItPlantumlOptions } from '@mdit/plugin-plantuml' + +export interface MarkdownChartPluginOptions { + /** + * Whether to enable chart support + * + * 是否启用 chart 图表支持 + * + * @default false + */ + chartjs?: boolean + + /** + * Whether to enable echarts support + * + * 是否启用 echarts 图表支持 + * + * @default false + */ + echarts?: boolean + + /** + * Whether to enable flowchart support + * + * 是否启用 flowchart 流程图支持 + * + * @default false + */ + flowchart?: boolean + + /** + * Whether to enable markmap support + * + * 是否启用 markmap 流程图支持 + * + * @default false + */ + markmap?: boolean + + /** + * Whether to enable mermaid support + * + * 是否启用 Mermaid 流程图支持 + * + * @default false + */ + mermaid?: boolean + + /** + * Whether enable plantuml support + * + * 是否启用 plantuml 支持 + * + * @default false + */ + plantuml?: MarkdownItPlantumlOptions[] | boolean + + /** + * The delay of operating dom, in ms + * + * If the theme you are using has a switching animation, it is recommended to configure this option to `Switch animation duration + 200` + * + * 操作页面 DOM 的延时,单位 ms + * + * 如果你使用的主题有切换动画,建议配置此选项为 `切换动画时长 + 200` + * + * @default 800 + */ + delay?: number +} diff --git a/plugins/markdown/plugin-markdown-chart/src/node/prepareConfigFile.ts b/plugins/markdown/plugin-markdown-chart/src/node/prepareConfigFile.ts new file mode 100644 index 0000000000..e59fd5fc10 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/node/prepareConfigFile.ts @@ -0,0 +1,64 @@ +import type { App } from 'vuepress/core' + +import { CLIENT_FOLDER } from './utils.js' + +export const prepareConfigFile = async ( + app: App, + status: Record, +): Promise => { + const imports = new Set() + const enhances = new Set() + + if (status.chart) { + imports.add(`import ChartJS from "${CLIENT_FOLDER}components/ChartJS.js";`) + enhances.add(`app.component("ChartJS", ChartJS)`) + } + + if (status.echarts) { + imports.add(`import ECharts from "${CLIENT_FOLDER}components/ECharts.js";`) + imports.add( + `import { injectEChartsConfig } from "${CLIENT_FOLDER}/index.js";`, + ) + enhances.add(`app.component("ECharts", ECharts);`) + enhances.add(`injectEChartsConfig(app);`) + } + + if (status.flowchart) { + imports.add( + `import FlowChart from "${CLIENT_FOLDER}components/FlowChart.js";`, + ) + + enhances.add(`app.component("FlowChart", FlowChart);`) + } + + if (status.markmap) { + imports.add(`import MarkMap from "${CLIENT_FOLDER}components/MarkMap.js";`) + enhances.add(`app.component("MarkMap", MarkMap);`) + } + + if (status.mermaid) { + imports.add(`import Mermaid from "${CLIENT_FOLDER}components/Mermaid.js";`) + imports.add( + `import { injectMermaidConfig } from "${CLIENT_FOLDER}index.js";`, + ) + enhances.add(`injectMermaidConfig(app);`) + enhances.add(`app.component("Mermaid", Mermaid);`) + } + + return app.writeTemp( + `markdown-chart/config.js`, + `\ +import { defineClientConfig } from "vuepress/client"; +${Array.from(imports.values()).join('\n')} + +export default defineClientConfig({ + enhance: ({ app }) => { +${Array.from(enhances.values()) + .map((item) => item.split('\n').map((line) => ` ${line}`)) + .flat() + .join('\n')} + }, +}); +`, + ) +} diff --git a/plugins/markdown/plugin-markdown-chart/src/node/utils.ts b/plugins/markdown/plugin-markdown-chart/src/node/utils.ts new file mode 100644 index 0000000000..bf2064d390 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/node/utils.ts @@ -0,0 +1,25 @@ +import { + Logger, + getInstalledStatus as _getInstalledStatus, + ensureEndingSlash, +} from '@vuepress/helper' +import { getDirname, path } from 'vuepress/utils' + +const __dirname = getDirname(import.meta.url) + +export const PLUGIN_NAME = '@vuepress/plugin-markdown-chart' + +export const logger = new Logger(PLUGIN_NAME) + +export const CLIENT_FOLDER = ensureEndingSlash( + path.resolve(__dirname, '../client'), +) + +export const getInstallStatus = (pkg: string, hint = true): boolean => { + const isInstalled = _getInstalledStatus(pkg, import.meta.url) + + if (hint && !isInstalled) + logger.error(`Package ${pkg} is not installed, please install it manually!`) + + return isInstalled +} diff --git a/plugins/markdown/plugin-markdown-chart/src/shims.d.ts b/plugins/markdown/plugin-markdown-chart/src/shims.d.ts new file mode 100644 index 0000000000..3d95151b15 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/src/shims.d.ts @@ -0,0 +1,6 @@ +declare module 'mermaid/dist/mermaid.esm.min.mjs' { + // eslint-disable-next-line import/no-rename-default + import mermaid from 'mermaid' + + export default mermaid +} diff --git a/plugins/markdown/plugin-markdown-chart/tests/node/__snapshots__/chartjs.spec.ts.snap b/plugins/markdown/plugin-markdown-chart/tests/node/__snapshots__/chartjs.spec.ts.snap new file mode 100644 index 0000000000..d794c0b0ec --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/tests/node/__snapshots__/chartjs.spec.ts.snap @@ -0,0 +1,15 @@ +// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html + +exports[`chartjs > Should not break markdown fence 1`] = ` +"
const a = 1;
+
+" +`; + +exports[`chartjs > Should resolve chart info with javascript block 1`] = `""`; + +exports[`chartjs > Should resolve chart with empty title and body 1`] = `""`; + +exports[`chartjs > Should resolve chartjs info with js block 1`] = `""`; + +exports[`chartjs > Should resolve chartjs info with json block 1`] = `""`; diff --git a/plugins/markdown/plugin-markdown-chart/tests/node/__snapshots__/echarts.spec.ts.snap b/plugins/markdown/plugin-markdown-chart/tests/node/__snapshots__/echarts.spec.ts.snap new file mode 100644 index 0000000000..00c30aec92 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/tests/node/__snapshots__/echarts.spec.ts.snap @@ -0,0 +1,19 @@ +// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html + +exports[`echarts > Should not break markdown fence 1`] = ` +"
const a = 1;
+
+" +`; + +exports[`echarts > Should resolve echarts container with empty title and body 1`] = `""`; + +exports[`echarts > Should resolve echarts container with javascript block 1`] = `""`; + +exports[`echarts > Should resolve echarts container with js block 1`] = `""`; + +exports[`echarts > Should resolve echarts container with json block 1`] = `""`; + +exports[`echarts > Should resolve echarts fence 1`] = `""`; + +exports[`echarts > Should resolve echarts fence with empty title and body 1`] = `""`; diff --git a/plugins/markdown/plugin-markdown-chart/tests/node/__snapshots__/flowchart.spec.ts.snap b/plugins/markdown/plugin-markdown-chart/tests/node/__snapshots__/flowchart.spec.ts.snap new file mode 100644 index 0000000000..1d1de487ca --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/tests/node/__snapshots__/flowchart.spec.ts.snap @@ -0,0 +1,47 @@ +// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html + +exports[`flowchart > Should handle preset 1`] = `""`; + +exports[`flowchart > Should handle preset 2`] = `""`; + +exports[`flowchart > Should not render 1`] = ` +"

st=>start: Start|past:>http://www.google.com[blank] +e=>end: End|future:>http://www.google.com +op1=>operation: My Operation|past +op2=>operation: Stuff|current +sub1=>subroutine: My Subroutine|invalid +cond=>condition: Yes +or No?|approved:>http://www.google.com +c2=>condition: Good idea|rejected +io=>inputoutput: catch something...|future

+

st->op1(right)->cond +cond(yes, right)->c2 +cond(no)->sub1(left)->op1 +c2(yes)->io->e +c2(no)->op2->e

+" +`; + +exports[`flowchart > Should not render 2`] = ` +"
st=>start: Start|past:>http://www.google.com[blank]
+e=>end: End|future:>http://www.google.com
+op1=>operation: My Operation|past
+op2=>operation: Stuff|current
+sub1=>subroutine: My Subroutine|invalid
+cond=>condition: Yes
+or No?|approved:>http://www.google.com
+c2=>condition: Good idea|rejected
+io=>inputoutput: catch something...|future
+
+st->op1(right)->cond
+cond(yes, right)->c2
+cond(no)->sub1(left)->op1
+c2(yes)->io->e
+c2(no)->op2->e
+
+" +`; + +exports[`flowchart > Should render \`\`\`flow 1`] = `""`; + +exports[`flowchart > Should render \`\`\`flowchart 1`] = `""`; diff --git a/plugins/markdown/plugin-markdown-chart/tests/node/__snapshots__/markmap.spec.ts.snap b/plugins/markdown/plugin-markdown-chart/tests/node/__snapshots__/markmap.spec.ts.snap new file mode 100644 index 0000000000..71025aebdd --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/tests/node/__snapshots__/markmap.spec.ts.snap @@ -0,0 +1,66 @@ +// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html + +exports[`markmap plugin > Should not render 1`] = ` +"
+

markmap: +colorFreezeLevel: 2

+

markmap

+

Links

+ +

Features

+
    +
  • links
  • +
  • strong del italic ==highlight==
  • +
  • multiline +text
  • +
  • inline code
  • +
  • +
    const a = 1;
    +
    +
  • +
  • Katex +
      +
    • $x = {-b \\pm \\sqrt{b^2-4ac} \\over 2a}$
    • +
    +
  • +
  • Now we can wrap very very very very long text based on maxWidth option
  • +
+" +`; + +exports[`markmap plugin > Should not render 2`] = ` +"
---
+markmap:
+  colorFreezeLevel: 2
+---
+
+# markmap
+
+## Links
+
+- <https://markmap.js.org/>
+- [GitHub](https://github.com/markmap/markmap)
+
+## Features
+
+- links
+- **strong** ~~del~~ *italic* ==highlight==
+- multiline
+  text
+- \`inline code\`
+-
+    \`\`\`js
+    const a = 1;
+    \`\`\`
+- Katex
+  - $x = {-b \\pm \\sqrt{b^2-4ac} \\over 2a}$
+- Now we can wrap very very very very long text based on \`maxWidth\` option
+
+
+" +`; + +exports[`markmap plugin > Should render \`\`\`markmap 1`] = `""`; diff --git a/plugins/markdown/plugin-markdown-chart/tests/node/__snapshots__/mermaid.spec.ts.snap b/plugins/markdown/plugin-markdown-chart/tests/node/__snapshots__/mermaid.spec.ts.snap new file mode 100644 index 0000000000..36af614d4f --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/tests/node/__snapshots__/mermaid.spec.ts.snap @@ -0,0 +1,124 @@ +// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html + +exports[`getMermaidContent() > Should work with content 1`] = ` +"flowchart TB + c1-->a2 + subgraph one + a1-->a2 + end + subgraph two + b1-->b2 + end + subgraph three + c1-->c2 + end + one --> two + three --> two + two --> c2" +`; + +exports[`getMermaidContent() > Should work with content 2`] = ` +"sequenceDiagram + Alice ->> Bob: Hello Bob, how are you? + Bob-->>John: How about you John? + Bob--x Alice: I am good thanks! + Bob-x John: I am good thanks! + Note right of John: Bob thinks a long
long time, so long
that the text does
not fit on a row. + + Bob-->Alice: Checking with John... + Alice->John: Yes... John, how are you?" +`; + +exports[`getMermaidContent() > Should work with title and content 1`] = ` +"--- +title: Sample Title +--- + +flowchart TB + c1-->a2 + subgraph one + a1-->a2 + end + subgraph two + b1-->b2 + end + subgraph three + c1-->c2 + end + one --> two + three --> two + two --> c2" +`; + +exports[`getMermaidContent() > Should work with title and content 2`] = ` +"--- +title: Sample Title +--- + +sequenceDiagram + Alice ->> Bob: Hello Bob, how are you? + Bob-->>John: How about you John? + Bob--x Alice: I am good thanks! + Bob-x John: I am good thanks! + Note right of John: Bob thinks a long
long time, so long
that the text does
not fit on a row. + + Bob-->Alice: Checking with John... + Alice->John: Yes... John, how are you?" +`; + +exports[`mermaid plugin > Should not render 1`] = ` +"

flowchart TB +c1-->a2 +subgraph one +a1-->a2 +end +subgraph two +b1-->b2 +end +subgraph three +c1-->c2 +end +one --> two +three --> two +two --> c2

+" +`; + +exports[`mermaid plugin > Should not render 2`] = ` +"
flowchart TB
+  c1-->a2
+  subgraph one
+  a1-->a2
+  end
+  subgraph two
+  b1-->b2
+  end
+  subgraph three
+  c1-->c2
+  end
+  one --> two
+  three --> two
+  two --> c2
+
+" +`; + +exports[`mermaid plugin > Should render \`\`\`class 1`] = `""`; + +exports[`mermaid plugin > Should render \`\`\`er 1`] = `""`; + +exports[`mermaid plugin > Should render \`\`\`gantt 1`] = `""`; + +exports[`mermaid plugin > Should render \`\`\`git-graph 1`] = `""`; + +exports[`mermaid plugin > Should render \`\`\`journey 1`] = `""`; + +exports[`mermaid plugin > Should render \`\`\`mermaid 1`] = `""`; + +exports[`mermaid plugin > Should render \`\`\`pie 1`] = `""`; + +exports[`mermaid plugin > Should render \`\`\`sequence 1`] = `""`; + +exports[`mermaid plugin > Should render \`\`\`sequence 2`] = `""`; + +exports[`mermaid plugin > Should render \`\`\`state 1`] = `""`; diff --git a/plugins/markdown/plugin-markdown-chart/tests/node/chartjs.spec.ts b/plugins/markdown/plugin-markdown-chart/tests/node/chartjs.spec.ts new file mode 100644 index 0000000000..bf1f63870a --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/tests/node/chartjs.spec.ts @@ -0,0 +1,203 @@ +import MarkdownIt from 'markdown-it' +import { describe, expect, it } from 'vitest' + +import { chartjs } from '../../src/node/markdown-it-plugins/chartjs.js' + +describe('chartjs', () => { + const markdownIt = MarkdownIt({ linkify: true }).use(chartjs) + + it('Should resolve chartjs info with json block', () => { + const result = markdownIt.render( + ` +::: chartjs A bar chart + +\`\`\`json +{ + "type": "bar", + "data": { + "labels": ["Red", "Blue", "Yellow", "Green", "Purple", "Orange"], + "datasets": [ + { + "label": "# of Votes", + "data": [12, 19, 3, 5, 2, 3], + "backgroundColor": [ + "rgba(255, 99, 132, 0.2)", + "rgba(54, 162, 235, 0.2)", + "rgba(255, 206, 86, 0.2)", + "rgba(75, 192, 192, 0.2)", + "rgba(153, 102, 255, 0.2)", + "rgba(255, 159, 64, 0.2)" + ], + "borderColor": [ + "rgba(255, 99, 132, 1)", + "rgba(54, 162, 235, 1)", + "rgba(255, 206, 86, 1)", + "rgba(75, 192, 192, 1)", + "rgba(153, 102, 255, 1)", + "rgba(255, 159, 64, 1)" + ], + "borderWidth": 1 + } + ] + }, + "options": { + "scales": { + "y": { + "beginAtZero": true + } + } + } +} +\`\`\` + +::: +`, + {}, + ) + + expect(result).toMatch(/<\/ChartJS>/) + expect(result).toContain(`title="${encodeURIComponent('A bar chart')}"`) + expect(result).toContain('type="json"') + expect(result).toMatchSnapshot() + }) + + it('Should resolve chartjs info with js block', () => { + const result = markdownIt.render( + ` +::: chartjs A bar chart + +\`\`\`js +const config = { + type: "bar", + data: { + labels: ["Red", "Blue", "Yellow", "Green", "Purple", "Orange"], + datasets: [ + { + label: "# of Votes", + data: [12, 19, 3, 5, 2, 3], + backgroundColor: [ + "rgba(255, 99, 132, 0.2)", + "rgba(54, 162, 235, 0.2)", + "rgba(255, 206, 86, 0.2)", + "rgba(75, 192, 192, 0.2)", + "rgba(153, 102, 255, 0.2)", + "rgba(255, 159, 64, 0.2)", + ], + borderColor: [ + "rgba(255, 99, 132, 1)", + "rgba(54, 162, 235, 1)", + "rgba(255, 206, 86, 1)", + "rgba(75, 192, 192, 1)", + "rgba(153, 102, 255, 1)", + "rgba(255, 159, 64, 1)", + ], + borderWidth: 1, + }, + ], + }, + options: { + scales: { + y: { + beginAtZero: true, + }, + }, + }, +}; +\`\`\` + +::: +`, + {}, + ) + + expect(result).toMatch(/<\/ChartJS>/) + expect(result).toContain(`title="${encodeURIComponent('A bar chart')}"`) + expect(result).toContain('type="js"') + expect(result).toMatchSnapshot() + }) + + it('Should resolve chart info with javascript block', () => { + const result = markdownIt.render( + ` +::: chartjs A bar chart + +\`\`\`javascript +const config = { + type: "bar", + data: { + labels: ["Red", "Blue", "Yellow", "Green", "Purple", "Orange"], + datasets: [ + { + label: "# of Votes", + data: [12, 19, 3, 5, 2, 3], + backgroundColor: [ + "rgba(255, 99, 132, 0.2)", + "rgba(54, 162, 235, 0.2)", + "rgba(255, 206, 86, 0.2)", + "rgba(75, 192, 192, 0.2)", + "rgba(153, 102, 255, 0.2)", + "rgba(255, 159, 64, 0.2)", + ], + borderColor: [ + "rgba(255, 99, 132, 1)", + "rgba(54, 162, 235, 1)", + "rgba(255, 206, 86, 1)", + "rgba(75, 192, 192, 1)", + "rgba(153, 102, 255, 1)", + "rgba(255, 159, 64, 1)", + ], + borderWidth: 1, + }, + ], + }, + options: { + scales: { + y: { + beginAtZero: true, + }, + }, + }, +}; +\`\`\` + +::: +`, + {}, + ) + + expect(result).toMatch(/<\/ChartJS>/) + expect(result).toContain(`title="${encodeURIComponent('A bar chart')}"`) + expect(result).toContain('type="js"') + expect(result).toMatchSnapshot() + }) + + it('Should resolve chart with empty title and body', () => { + const result = markdownIt.render( + ` +::: chartjs + +::: +`, + {}, + ) + + expect(result).toMatch(/<\/ChartJS>/) + expect(result).not.toContain('title="') + expect(result).toContain('type=""') + expect(result).toMatchSnapshot() + }) + + it('Should not break markdown fence', () => { + const result = markdownIt.render( + ` +\`\`\`js +const a = 1; +\`\`\` +`, + {}, + ) + + expect(result).toMatch(/[\s\S]*<\/pre>/) + expect(result).toMatchSnapshot() + }) +}) diff --git a/plugins/markdown/plugin-markdown-chart/tests/node/echarts.spec.ts b/plugins/markdown/plugin-markdown-chart/tests/node/echarts.spec.ts new file mode 100644 index 0000000000..edd849bd96 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/tests/node/echarts.spec.ts @@ -0,0 +1,185 @@ +import MarkdownIt from 'markdown-it' +import { describe, expect, it } from 'vitest' + +import { echarts } from '../../src/node/markdown-it-plugins/echarts.js' + +describe('echarts', () => { + const markdownIt = MarkdownIt({ linkify: true }).use(echarts) + + it('Should resolve echarts container with json block', () => { + const result = markdownIt.render( + ` +::: echarts A line chart + +\`\`\`json +{ + 'xAxis': { + 'type': 'category', + 'data': ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] + }, + 'yAxis': { + 'type': 'value' + }, + 'series': [ + { + 'data': [150, 230, 224, 218, 135, 147, 260], + 'type': 'line' + } + ] +} +\`\`\` + +::: +`, + {}, + ) + + expect(result).toMatch(/<\/ECharts>/) + expect(result).toContain(`title="${encodeURIComponent('A line chart')}"`) + expect(result).not.toContain('type=""') + expect(result).toMatchSnapshot() + }) + + it('Should resolve echarts container with js block', () => { + const result = markdownIt.render( + ` +::: echarts A line chart + +\`\`\`js +const option = { + xAxis: { + type: "category", + data: ["Mon", "Tue", "Wed", "Thu", "Fri", "Sat", "Sun"], + }, + yAxis: { + type: "value", + }, + series: [ + { + data: [150, 230, 224, 218, 135, 147, 260], + type: "line", + }, + ], +}; +\`\`\` + +::: +`, + {}, + ) + + expect(result).toMatch(/<\/ECharts>/) + expect(result).toContain(`title="${encodeURIComponent('A line chart')}"`) + expect(result).toContain('type="js"') + expect(result).toMatchSnapshot() + }) + + it('Should resolve echarts container with javascript block', () => { + const result = markdownIt.render( + ` +::: echarts A line chart + +\`\`\`javascript +const option = { + xAxis: { + type: "category", + data: ["Mon", "Tue", "Wed", "Thu", "Fri", "Sat", "Sun"], + }, + yAxis: { + type: "value", + }, + series: [ + { + data: [150, 230, 224, 218, 135, 147, 260], + type: "line", + }, + ], +}; +\`\`\` + +::: +`, + {}, + ) + + expect(result).toMatch(/<\/ECharts>/) + expect(result).toContain(`title="${encodeURIComponent('A line chart')}"`) + expect(result).toContain('type="js"') + expect(result).toMatchSnapshot() + }) + + it('Should resolve echarts container with empty title and body', () => { + const result = markdownIt.render( + ` +::: echarts + +::: +`, + {}, + ) + + expect(result).toMatch(/<\/ECharts>/) + expect(result).not.toContain('title="') + expect(result).not.toContain('type=""') + expect(result).toMatchSnapshot() + }) + + it('Should resolve echarts fence', () => { + const result = markdownIt.render( + ` +\`\`\`echarts:A line chart +{ + 'xAxis': { + 'type': 'category', + 'data': ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] + }, + 'yAxis': { + 'type': 'value' + }, + 'series': [ + { + 'data': [150, 230, 224, 218, 135, 147, 260], + 'type': 'line' + } + ] +} +\`\`\` +`, + {}, + ) + + expect(result).toMatch(/<\/ECharts>/) + expect(result).toContain(`title="${encodeURIComponent('A line chart')}"`) + expect(result).not.toContain('type=""') + expect(result).toMatchSnapshot() + }) + + it('Should resolve echarts fence with empty title and body', () => { + const result = markdownIt.render( + ` +\`\`\`echarts +\`\`\` +`, + {}, + ) + + expect(result).toMatch(/<\/ECharts>/) + expect(result).not.toContain('title="') + expect(result).not.toContain('type=""') + expect(result).toMatchSnapshot() + }) + + it('Should not break markdown fence', () => { + const result = markdownIt.render( + ` +\`\`\`js +const a = 1; +\`\`\` +`, + {}, + ) + + expect(result).toMatch(/[\s\S]*<\/pre>/) + expect(result).toMatchSnapshot() + }) +}) diff --git a/plugins/markdown/plugin-markdown-chart/tests/node/flowchart.spec.ts b/plugins/markdown/plugin-markdown-chart/tests/node/flowchart.spec.ts new file mode 100644 index 0000000000..385e17000a --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/tests/node/flowchart.spec.ts @@ -0,0 +1,90 @@ +import MarkdownIt from 'markdown-it' +import { describe, expect, it } from 'vitest' + +import { flowchart } from '../../src/node/markdown-it-plugins/flowchart.js' + +const demo = `st=>start: Start|past:>http://www.google.com[blank] +e=>end: End|future:>http://www.google.com +op1=>operation: My Operation|past +op2=>operation: Stuff|current +sub1=>subroutine: My Subroutine|invalid +cond=>condition: Yes +or No?|approved:>http://www.google.com +c2=>condition: Good idea|rejected +io=>inputoutput: catch something...|future + +st->op1(right)->cond +cond(yes, right)->c2 +cond(no)->sub1(left)->op1 +c2(yes)->io->e +c2(no)->op2->e` + +describe('flowchart', () => { + const markdownIt = MarkdownIt({ linkify: true }).use(flowchart) + + it('Should render ```flow', () => { + const flowRenderResult = markdownIt.render(` +\`\`\`flow +${demo} +\`\`\` +`) + + expect(flowRenderResult).toMatch( + /<\/FlowChart>/, + ) + expect(flowRenderResult).toMatchSnapshot() + }) + + it('Should render ```flowchart', () => { + const flowChartRenderResult = markdownIt.render(` +\`\`\`flowchart +${demo} +\`\`\` +`) + + expect(flowChartRenderResult).toMatch( + /<\/FlowChart>/, + ) + expect(flowChartRenderResult).toMatchSnapshot() + }) + + it('Should not render', () => { + expect( + markdownIt.render(` +${demo} +`), + ).toMatchSnapshot() + + expect( + markdownIt.render(` +\`\`\`md +${demo} +\`\`\` +`), + ).toMatchSnapshot() + }) + + it('Should handle preset', () => { + const flowRenderResult = markdownIt.render(` +\`\`\`flow:ant +${demo} +\`\`\` +`) + + expect(flowRenderResult).toMatch( + /<\/FlowChart>/, + ) + expect(flowRenderResult).toMatchSnapshot() + + const flowChartRenderResult = markdownIt.render(` +\`\`\`flowchart:ant +${demo} +\`\`\` +`) + + expect(flowChartRenderResult).toMatch( + /<\/FlowChart>/, + ) + expect(flowChartRenderResult).toMatchSnapshot() + }) +}) diff --git a/plugins/markdown/plugin-markdown-chart/tests/node/markmap.spec.ts b/plugins/markdown/plugin-markdown-chart/tests/node/markmap.spec.ts new file mode 100644 index 0000000000..4bb4f2d49e --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/tests/node/markmap.spec.ts @@ -0,0 +1,66 @@ +import MarkdownIt from 'markdown-it' +import { describe, expect, it } from 'vitest' + +import { markmap } from '../../src/node/markdown-it-plugins/markmap.js' + +const content = `\ +--- +markmap: + colorFreezeLevel: 2 +--- + +# markmap + +## Links + +- +- [GitHub](https://github.com/markmap/markmap) + +## Features + +- links +- **strong** ~~del~~ *italic* ==highlight== +- multiline + text +- \`inline code\` +- + \`\`\`js + const a = 1; + \`\`\` +- Katex + - $x = {-b \\pm \\sqrt{b^2-4ac} \\over 2a}$ +- Now we can wrap very very very very long text based on \`maxWidth\` option +` + +describe('markmap plugin', () => { + const markdownIt = MarkdownIt({ linkify: true }).use(markmap) + + it('Should render ```markmap', () => { + const renderResult = markdownIt.render(` +\`\`\`\`markmap +${content} +\`\`\`\` +`) + + expect(renderResult).toMatch( + /<\/MarkMap>/, + ) + expect(renderResult).toMatchSnapshot() + }) + + it('Should not render', () => { + expect( + markdownIt.render(` +${content} +`), + ).toMatchSnapshot() + + expect( + markdownIt.render(` +\`\`\`md +${content} +\`\`\` +`), + ).toMatchSnapshot() + }) +}) diff --git a/plugins/markdown/plugin-markdown-chart/tests/node/mermaid.spec.ts b/plugins/markdown/plugin-markdown-chart/tests/node/mermaid.spec.ts new file mode 100644 index 0000000000..c4afd8bb20 --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/tests/node/mermaid.spec.ts @@ -0,0 +1,276 @@ +import { decodeData } from '@vuepress/helper' +import MarkdownIt from 'markdown-it' +import { describe, expect, it } from 'vitest' + +import { + getMermaidContent, + mermaid, +} from '../../src/node/markdown-it-plugins/mermaid.js' + +const title = 'Sample Title' + +const flowchartDemo = `\ +flowchart TB + c1-->a2 + subgraph one + a1-->a2 + end + subgraph two + b1-->b2 + end + subgraph three + c1-->c2 + end + one --> two + three --> two + two --> c2\ +` + +const sequenceDemo = `\ +Alice ->> Bob: Hello Bob, how are you? +Bob-->>John: How about you John? +Bob--x Alice: I am good thanks! +Bob-x John: I am good thanks! +Note right of John: Bob thinks a long
long time, so long
that the text does
not fit on a row. + +Bob-->Alice: Checking with John... +Alice->John: Yes... John, how are you?\ +` + +describe('getMermaidContent()', () => { + it('Should work with content', () => { + expect(getMermaidContent({ content: flowchartDemo })).toMatchSnapshot() + expect( + getMermaidContent({ diagram: 'sequenceDiagram', content: sequenceDemo }), + ).toMatchSnapshot() + }) + + it('Should work with title and content', () => { + expect( + getMermaidContent({ title, content: flowchartDemo }), + ).toMatchSnapshot() + expect( + getMermaidContent({ + diagram: 'sequenceDiagram', + title, + content: sequenceDemo, + }), + ).toMatchSnapshot() + }) +}) + +describe('mermaid plugin', () => { + const markdownIt = MarkdownIt({ linkify: true }).use(mermaid) + + it('Should render ```mermaid', () => { + const renderResult = markdownIt.render(` +\`\`\`mermaid +${flowchartDemo} +\`\`\` +`) + + expect(renderResult).toMatch( + /<\/Mermaid>/, + ) + expect( + decodeData( + /<\/Mermaid>/.exec( + renderResult, + )?.[1] ?? '', + ), + ).toMatch(flowchartDemo) + expect(renderResult).toMatchSnapshot() + }) + + it('Should not render', () => { + expect( + markdownIt.render(` +${flowchartDemo} +`), + ).toMatchSnapshot() + + expect( + markdownIt.render(` +\`\`\`md +${flowchartDemo} +\`\`\` +`), + ).toMatchSnapshot() + }) + + it('Should render ```sequence', () => { + const renderResult1 = markdownIt.render(` +\`\`\`sequence +Alice ->> Bob: Hello Bob, how are you? +Bob-->>John: How about you John? +Bob--x Alice: I am good thanks! +Bob-x John: I am good thanks! +Note right of John: Bob thinks a long
long time, so long
that the text does
not fit on a row. + +Bob-->Alice: Checking with John... +Alice->John: Yes... John, how are you? +\`\`\` +`) + const renderResult2 = markdownIt.render(` +\`\`\`sequence Greetings +Alice ->> Bob: Hello Bob, how are you? +Bob-->>John: How about you John? +Bob--x Alice: I am good thanks! +Bob-x John: I am good thanks! +Note right of John: Bob thinks a long
long time, so long
that the text does
not fit on a row. + +Bob-->Alice: Checking with John... +Alice->John: Yes... John, how are you? +\`\`\` +`) + + expect(renderResult1).toMatchSnapshot() + expect(renderResult2).toMatchSnapshot() + }) + + it('Should render ```class', () => { + const renderResult = markdownIt.render(` +\`\`\`class +class Square~Shape~{ + int id + List~int~ position + setPoints(List~int~ points) + getPoints() List~int~ +} + +Square : -List~string~ messages +Square : +setMessages(List~string~ messages) +Square : +getMessages() List~string~ +\`\`\` +`) + + expect(renderResult).toMatchSnapshot() + }) + + it('Should render ```state', () => { + const renderResult = markdownIt.render(` +\`\`\`state +[*] --> Active + +state Active { + [*] --> NumLockOff + NumLockOff --> NumLockOn : EvNumLockPressed + NumLockOn --> NumLockOff : EvNumLockPressed + -- + [*] --> CapsLockOff + CapsLockOff --> CapsLockOn : EvCapsLockPressed + CapsLockOn --> CapsLockOff : EvCapsLockPressed + -- + [*] --> ScrollLockOff + ScrollLockOff --> ScrollLockOn : EvScrollLockPressed + ScrollLockOn --> ScrollLockOff : EvScrollLockPressed +} +\`\`\` +`) + + expect(renderResult).toMatchSnapshot() + }) + + it('Should render ```er', () => { + const renderResult = markdownIt.render(` +\`\`\`er +CAR ||--o{ NAMED-DRIVER : allows +CAR { + string registrationNumber + string make + string model +} +PERSON ||--o{ NAMED-DRIVER : is +PERSON { + string firstName + string lastName + int age +} +\`\`\` +`) + + expect(renderResult).toMatchSnapshot() + }) + + it('Should render ```journey', () => { + const renderResult = markdownIt.render(` +\`\`\`journey +title My working day +section Go to work + Make tea: 5: Me + Go upstairs: 3: Me + Do work: 1: Me, Cat +section Go home + Go downstairs: 5: Me + Sit down: 5: Me +\`\`\` +`) + + expect(renderResult).toMatchSnapshot() + }) + + it('Should render ```gantt', () => { + const renderResult = markdownIt.render(` +\`\`\`gantt +dateFormat YYYY-MM-DD +title Adding GANTT diagram functionality to mermaid +excludes weekends +%% (\`excludes\` accepts specific dates in YYYY-MM-DD format, days of the week ("sunday") or "weekends", but not the word "weekdays".) + +section A section +Completed task :done, des1, 2014-01-06,2014-01-08 +Active task :active, des2, 2014-01-09, 3d +Future task : des3, after des2, 5d +Future task2 : des4, after des3, 5d + +section Critical tasks +Completed task in the critical line :crit, done, 2014-01-06,24h +Implement parser :crit, done, after des1, 2d +Create tests for parser :crit, active, 3d +Future task in critical line :crit, 5d +Create tests for renderer :2d +Add to mermaid :1d + +section Documentation +Describe gantt syntax :active, a1, after des1, 3d +Add gantt diagram to demo page :after a1 , 20h +Add another diagram to demo page :doc1, after a1 , 48h + +section Last section +Describe gantt syntax :after doc1, 3d +Add gantt diagram to demo page :20h +Add another diagram to demo page :48h +\`\`\` +`) + + expect(renderResult).toMatchSnapshot() + }) + + it('Should render ```pie', () => { + const renderResult = markdownIt.render(` +\`\`\`pie +title What Voldemort doesn’t have? + "FRIENDS" : 2 + "FAMILY" : 3 + "NOSE" : 45 +\`\`\` +`) + + expect(renderResult).toMatchSnapshot() + }) + + it('Should render ```git-graph', () => { + const renderResult = markdownIt.render(` +\`\`\`git-graph +commit id: "Normal" +commit +commit id: "Reverse" type: REVERSE +commit +commit id: "Highlight" type: HIGHLIGHT +commit +\`\`\` +`) + + expect(renderResult).toMatchSnapshot() + }) +}) diff --git a/plugins/markdown/plugin-markdown-chart/tsconfig.build.json b/plugins/markdown/plugin-markdown-chart/tsconfig.build.json new file mode 100644 index 0000000000..f7f7fe795a --- /dev/null +++ b/plugins/markdown/plugin-markdown-chart/tsconfig.build.json @@ -0,0 +1,10 @@ +{ + "extends": "../../../tsconfig.build.json", + "compilerOptions": { + "rootDir": "./src", + "outDir": "./lib", + "types": ["vuepress/client-types", "vite/client", "webpack-env"] + }, + "include": ["./src"], + "references": [{ "path": "../../../tools/helper/tsconfig.build.json" }] +} diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 1819cd9dda..ce5e3a1430 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -65,7 +65,7 @@ importers: version: 1.18.5 '@vitest/coverage-istanbul': specifier: 3.0.0-beta.2 - version: 3.0.0-beta.2(vitest@3.0.0-beta.2(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.4.5)) + version: 3.0.0-beta.2(vitest@3.0.0-beta.2(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1)) conventional-changelog-cli: specifier: ^5.0.0 version: 5.0.0(conventional-commits-filter@5.0.0) @@ -140,19 +140,19 @@ importers: version: 5.7.2 vite: specifier: ~6.0.5 - version: 6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.4.5) + version: 6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1) vitest: specifier: 3.0.0-beta.2 - version: 3.0.0-beta.2(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.4.5) + version: 3.0.0-beta.2(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) docs: dependencies: '@vuepress/bundler-vite': specifier: 'catalog:' - version: 2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5) + version: 2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1) '@vuepress/bundler-webpack': specifier: 'catalog:' version: 2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2) @@ -180,6 +180,9 @@ importers: '@vuepress/plugin-feed': specifier: workspace:* version: link:../plugins/blog/plugin-feed + '@vuepress/plugin-markdown-chart': + specifier: workspace:* + version: link:../plugins/markdown/plugin-markdown-chart '@vuepress/plugin-markdown-ext': specifier: workspace:* version: link:../plugins/markdown/plugin-markdown-ext @@ -228,9 +231,27 @@ importers: '@vuepress/theme-default': specifier: workspace:* version: link:../themes/theme-default + chart.js: + specifier: 4.4.6 + version: 4.4.6 + echarts: + specifier: 5.5.1 + version: 5.5.1 + flowchart.ts: + specifier: 3.0.1 + version: 3.0.1 katex: specifier: 0.16.18 version: 0.16.18 + markmap-lib: + specifier: 0.17.2 + version: 0.17.2(markmap-common@0.17.1) + markmap-toolbar: + specifier: 0.17.2 + version: 0.17.2(markmap-common@0.17.1) + markmap-view: + specifier: 0.17.2 + version: 0.17.2(markmap-common@0.17.1) mathjax-full: specifier: 3.2.2 version: 3.2.2 @@ -245,13 +266,13 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) e2e: dependencies: '@vuepress/bundler-vite': specifier: 'catalog:' - version: 2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5) + version: 2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1) '@vuepress/bundler-webpack': specifier: 'catalog:' version: 2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2) @@ -305,7 +326,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) devDependencies: '@playwright/test': specifier: ^1.49.1 @@ -321,13 +342,13 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/analytics/plugin-google-analytics: dependencies: vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/analytics/plugin-umami-analytics: dependencies: @@ -339,7 +360,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/blog/plugin-blog: dependencies: @@ -354,7 +375,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/blog/plugin-comment: dependencies: @@ -381,7 +402,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/blog/plugin-feed: dependencies: @@ -390,7 +411,7 @@ importers: version: link:../../../tools/helper vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) xml-js: specifier: ^1.6.11 version: 1.6.11 @@ -409,7 +430,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/development/plugin-git: dependencies: @@ -418,7 +439,7 @@ importers: version: 9.5.2 vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/development/plugin-palette: dependencies: @@ -430,7 +451,7 @@ importers: version: 3.6.0 vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/development/plugin-reading-time: dependencies: @@ -442,7 +463,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/development/plugin-rtl: dependencies: @@ -457,7 +478,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/development/plugin-sass-palette: dependencies: @@ -478,11 +499,11 @@ importers: version: 16.0.4(sass-embedded@1.83.0)(sass@1.83.0)(webpack@5.97.1(esbuild@0.24.2)) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) devDependencies: '@vuepress/bundler-vite': specifier: 'catalog:' - version: 2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5) + version: 2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1) '@vuepress/bundler-webpack': specifier: 'catalog:' version: 2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2) @@ -497,7 +518,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/development/plugin-toc: dependencies: @@ -509,7 +530,7 @@ importers: version: 4.5.0(vue@3.5.13(typescript@5.7.2)) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/features/plugin-back-to-top: dependencies: @@ -524,7 +545,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/features/plugin-catalog: dependencies: @@ -536,7 +557,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/features/plugin-copy-code: dependencies: @@ -551,7 +572,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/features/plugin-copyright: dependencies: @@ -566,7 +587,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/features/plugin-medium-zoom: dependencies: @@ -581,7 +602,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/features/plugin-notice: dependencies: @@ -596,7 +617,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/features/plugin-nprogress: dependencies: @@ -608,7 +629,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/features/plugin-photo-swipe: dependencies: @@ -626,7 +647,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/features/plugin-watermark: dependencies: @@ -641,7 +662,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) watermark-js-plus: specifier: ^1.5.7 version: 1.5.7 @@ -656,7 +677,7 @@ importers: version: link:../../development/plugin-git vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/markdown/plugin-links-check: dependencies: @@ -665,7 +686,59 @@ importers: version: link:../../../tools/helper vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + + plugins/markdown/plugin-markdown-chart: + dependencies: + '@mdit/plugin-container': + specifier: ^0.13.1 + version: 0.13.1(markdown-it@14.1.0) + '@mdit/plugin-plantuml': + specifier: ^0.13.1 + version: 0.13.1(markdown-it@14.1.0) + '@vuepress/helper': + specifier: workspace:* + version: link:../../../tools/helper + '@vueuse/core': + specifier: ^12.0.0 + version: 12.0.0(typescript@5.7.2) + chart.js: + specifier: ^4.4.5 + version: 4.4.6 + echarts: + specifier: ^5.5.1 + version: 5.5.1 + flowchart.ts: + specifier: ^3.0.1 + version: 3.0.1 + markmap-lib: + specifier: ^0.17.2 + version: 0.17.2(markmap-common@0.17.1) + markmap-toolbar: + specifier: ^0.17.2 + version: 0.17.2(markmap-common@0.17.1) + markmap-view: + specifier: ^0.17.2 + version: 0.17.2(markmap-common@0.17.1) + mermaid: + specifier: ^11.3.0 + version: 11.4.0 + vue: + specifier: ^3.5.13 + version: 3.5.13(typescript@5.7.2) + vuepress: + specifier: 2.0.0-rc.19 + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + devDependencies: + '@types/markdown-it': + specifier: ^14.1.2 + version: 14.1.2 + markdown-it: + specifier: ^14.1.0 + version: 14.1.0 + markmap-common: + specifier: ^0.17.1 + version: 0.17.1 plugins/markdown/plugin-markdown-container: dependencies: @@ -677,7 +750,7 @@ importers: version: 4.0.0 vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) devDependencies: markdown-it: specifier: ^14.1.0 @@ -705,7 +778,7 @@ importers: version: 4.1.0 vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) devDependencies: '@types/js-yaml': specifier: 4.0.9 @@ -733,7 +806,7 @@ importers: version: 12.2.0(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) devDependencies: markdown-it: specifier: ^14.1.0 @@ -761,7 +834,7 @@ importers: version: link:../../../tools/helper vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/markdown/plugin-markdown-include: dependencies: @@ -776,7 +849,7 @@ importers: version: link:../../../tools/helper vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/markdown/plugin-markdown-math: dependencies: @@ -803,7 +876,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) devDependencies: markdown-it: specifier: ^14.1.0 @@ -840,7 +913,7 @@ importers: version: link:../../../tools/helper vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) devDependencies: markdown-it: specifier: ^14.1.0 @@ -865,7 +938,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) devDependencies: markdown-it: specifier: ^14.1.0 @@ -884,7 +957,7 @@ importers: version: 1.29.0 vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) devDependencies: '@types/markdown-it': specifier: ^14.1.2 @@ -921,7 +994,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) devDependencies: markdown-it: specifier: ^14.1.0 @@ -946,7 +1019,7 @@ importers: version: 1.24.4 vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) devDependencies: '@types/markdown-it': specifier: ^14.1.2 @@ -974,7 +1047,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) workbox-build: specifier: ^7.3.0 version: 7.3.0 @@ -987,7 +1060,7 @@ importers: dependencies: vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/search/plugin-docsearch: dependencies: @@ -1014,7 +1087,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) devDependencies: algoliasearch: specifier: 5.18.0 @@ -1030,7 +1103,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/search/plugin-slimsearch: dependencies: @@ -1054,7 +1127,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) devDependencies: domhandler: specifier: 5.0.3 @@ -1067,7 +1140,7 @@ importers: version: link:../../../tools/helper vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) devDependencies: '@vuepress/plugin-git': specifier: workspace:* @@ -1083,7 +1156,7 @@ importers: version: 8.0.0 vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) devDependencies: '@vuepress/plugin-git': specifier: workspace:* @@ -1099,13 +1172,13 @@ importers: version: 10.4.3 vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/tools/plugin-google-tag-manager: dependencies: vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/tools/plugin-redirect: dependencies: @@ -1123,7 +1196,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) plugins/tools/plugin-register-components: dependencies: @@ -1132,7 +1205,7 @@ importers: version: 3.6.0 vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) themes/theme-default: dependencies: @@ -1198,7 +1271,7 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) tools/create-vuepress: dependencies: @@ -1241,14 +1314,14 @@ importers: version: 3.5.13(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) devDependencies: '@types/connect': specifier: 3.4.38 version: 3.4.38 '@vuepress/bundler-vite': specifier: 'catalog:' - version: 2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5) + version: 2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1) '@vuepress/bundler-webpack': specifier: 'catalog:' version: 2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2) @@ -1260,7 +1333,7 @@ importers: version: 5.0.3 vite: specifier: ~6.0.5 - version: 6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.4.5) + version: 6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1) tools/highlighter-helper: dependencies: @@ -1269,7 +1342,7 @@ importers: version: 12.2.0(typescript@5.7.2) vuepress: specifier: 'catalog:' - version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) + version: 2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)) tools/vp-update: dependencies: @@ -1362,6 +1435,12 @@ packages: resolution: {integrity: sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==} engines: {node: '>=6.0.0'} + '@antfu/install-pkg@0.4.1': + resolution: {integrity: sha512-T7yB5QNG29afhWVkVq7XeIMBa5U/vs9mX69YqayXypPRmYzUmzwnYltplHmPtZ4HPCn+sQKeXW8I47wCbuBOjw==} + + '@antfu/utils@0.7.10': + resolution: {integrity: sha512-+562v9k4aI80m1+VuMHehNJWLOFjBnXn3tdOitzD0il5b7smkSBal4+a3oKiQTbrwMmN/TBUMDvbdoWDehgOww==} + '@apideck/better-ajv-errors@0.3.6': resolution: {integrity: sha512-P+ZygBLZtkp0qqOAJJVX4oX/sFo5JR3eBWwwuqHHhK0GIgQOKWrAfiAaWX0aArHkRWHMuggFEgAZNxVPwPZYaA==} engines: {node: '>=10'} @@ -1853,9 +1932,27 @@ packages: resolution: {integrity: sha512-vN5p+1kl59GVKMvTHt55NzzmYVxprfJD+ql7U9NFIfKCBkYE55LYtS+WtPlaYOyzydrKI8Nezd+aZextrd+FMA==} engines: {node: '>=6.9.0'} + '@braintree/sanitize-url@7.1.0': + resolution: {integrity: sha512-o+UlMLt49RvtCASlOMW0AkHnabN9wR9rwCCherxO0yG4Npy34GkvrAqdXQvrhNs+jh+gkK8gB8Lf05qL/O7KWg==} + '@bufbuild/protobuf@2.2.3': resolution: {integrity: sha512-tFQoXHJdkEOSwj5tRIZSPNUuXK3RaR7T1nUrPgbYX1pUbvqqaaZAsfo+NXBPsz5rZMSKVFrgK1WL8Q/MSLvprg==} + '@chevrotain/cst-dts-gen@11.0.3': + resolution: {integrity: sha512-BvIKpRLeS/8UbfxXxgC33xOumsacaeCKAjAeLyOn7Pcp95HiRbrpl14S+9vaZLolnbssPIUuiUd8IvgkRyt6NQ==} + + '@chevrotain/gast@11.0.3': + resolution: {integrity: sha512-+qNfcoNk70PyS/uxmj3li5NiECO+2YKZZQMbmjTqRI3Qchu8Hig/Q9vgkHpI3alNjr7M+a2St5pw5w5F6NL5/Q==} + + '@chevrotain/regexp-to-ast@11.0.3': + resolution: {integrity: sha512-1fMHaBZxLFvWI067AVbGJav1eRY7N8DDvYCTwGBiE/ytKBgP8azTdgyrKyWZ9Mfh09eHWb5PgTSO8wi7U824RA==} + + '@chevrotain/types@11.0.3': + resolution: {integrity: sha512-gsiM3G8b58kZC2HaWR50gu6Y1440cHiJ+i3JUvcp/35JchYejb2+5MVeJK0iKThYpAa/P2PYFV4hoi44HD+aHQ==} + + '@chevrotain/utils@11.0.3': + resolution: {integrity: sha512-YslZMgtJUyuMbZ+aKvfF3x1f5liK4mWNxghFRv7jqRR9C3R3fAOGTTKvxXDa2Y1s9zSbcpuO0cAxDYsc9SrXoQ==} + '@commitlint/cli@19.6.1': resolution: {integrity: sha512-8hcyA6ZoHwWXC76BoC8qVOSr8xHy00LZhZpauiD0iO0VYbVhMnED0da85lTfIULxl7Lj4c6vZgF0Wu/ed1+jlQ==} engines: {node: '>=v18'} @@ -2452,6 +2549,9 @@ packages: resolution: {integrity: sha512-zSkKow6H5Kdm0ZUQUB2kV5JIXqoG0+uH5YADhaEHswm664N9Db8dXSi0nMJpacpMf+MyyglF1vnZohpEg5yUtg==} engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} + '@gera2ld/jsx-dom@2.2.2': + resolution: {integrity: sha512-EOqf31IATRE6zS1W1EoWmXZhGfLAoO9FIlwTtHduSrBdud4npYBxYAkv8dZ5hudDPwJeeSjn40kbCL4wAzr8dA==} + '@humanfs/core@0.19.1': resolution: {integrity: sha512-5DyQ4+1JEUzejeK1JGICcideyfUbGixgS9jNgex5nqkW+cY7WZhxBigmieN5Qnw9ZosSNVC9KQKyb+GUaGyKUA==} engines: {node: '>=18.18.0'} @@ -2476,6 +2576,15 @@ packages: resolution: {integrity: sha512-e5+YUKENATs1JgYHMzTr2MW/NDcXGfYFAuOQU8gJgF/kEh4EqKgfGrfLI67bMD4tbhZVlkigz/9YYwWcbOFthg==} engines: {node: '>=10.13.0'} + '@iconify/types@2.0.0': + resolution: {integrity: sha512-+wluvCrRhXrhyOmRDJ3q8mux9JkKy5SJ/v8ol2tu4FVjyYvtEzkc/3pK15ET6RKg4b4w4BmTk1+gsCUhf21Ykg==} + + '@iconify/utils@2.1.33': + resolution: {integrity: sha512-jP9h6v/g0BIZx0p7XGJJVtkVnydtbgTgt9mVNcGDYwaa7UhdHdI9dvoq+gKj9sijMSJKxUPEG2JyjsgXjxL7Kw==} + + '@iktakahiro/markdown-it-katex@4.0.1': + resolution: {integrity: sha512-kGFooO7fIOgY34PSG8ZNVsUlKhhNoqhzW2kq94TNGa8COzh73PO4KsEoPOsQVG1mEAe8tg7GqG0FoVao0aMHaw==} + '@inquirer/checkbox@4.0.4': resolution: {integrity: sha512-fYAKCAcGNMdfjL6hZTRUwkIByQ8EIZCXKrIQZH7XjADnN/xvRUhj8UdBbpC4zoUzvChhkSC/zRKaP/tDs3dZpg==} engines: {node: '>=18'} @@ -2614,6 +2723,9 @@ packages: peerDependencies: tslib: '2' + '@kurkle/color@0.3.4': + resolution: {integrity: sha512-M5UknZPHRu3DEDWoipU6sE8PdkZ6Z/S+v4dD+Ke8IaNlpdSQah50lz1KtcFBa2vsdOnwbbnxJwVM4wty6udA5w==} + '@leichtgewicht/ip-codec@2.0.5': resolution: {integrity: sha512-Vo+PSpZG2/fmgmiNzYK9qWRh8h/CHrwD0mo1h1DzL4yzHNSfWYujGTYsWGreD000gcgmZ7K4Ys6Tx9TxtsKdDw==} @@ -2727,6 +2839,15 @@ packages: markdown-it: optional: true + '@mdit/plugin-container@0.13.1': + resolution: {integrity: sha512-mFfm7YViyLHo8uORVa9oLi9+acZZoSVdPf3WPqzC/yLZAJbF27rfJgWZ9Kylt+tyaAYng8L4DiSeVcSNUIHF1A==} + engines: {node: '>= 18'} + peerDependencies: + markdown-it: ^14.1.0 + peerDependenciesMeta: + markdown-it: + optional: true + '@mdit/plugin-container@0.14.0': resolution: {integrity: sha512-sYjR9GPPkdItjGXw2m4f2iKAvKK+9egq/3wnzNnsouK1Hz0Qz8rQM1VELQLBK16PJwqStGNfTQC31BeM7gVmIg==} engines: {node: '>= 18'} @@ -2819,6 +2940,14 @@ packages: mathjax-full: optional: true + '@mdit/plugin-plantuml@0.13.1': + resolution: {integrity: sha512-qupMO/lG1mDYaGHSutB9AO1TsxHjmp4yFnvp3VBNNRdVh9lqWhXFv/htrnr0IGEWAmlik6zlkCvz/YrKRONV5A==} + peerDependencies: + markdown-it: ^14.1.0 + peerDependenciesMeta: + markdown-it: + optional: true + '@mdit/plugin-spoiler@0.14.0': resolution: {integrity: sha512-c+tSj35JygQF9gNRAcH3gk68pBpjS7zGiooz/UK+tw8GSqez2c1Z+PWvu1u4xX0O/HO3y+amu7GqTjwkfgLC7g==} engines: {node: '>= 18'} @@ -2881,6 +3010,15 @@ packages: markdown-it: optional: true + '@mdit/plugin-uml@0.13.1': + resolution: {integrity: sha512-JdCOg25OyG+QJFAba6AWwdpkaOjuht5VmOqYt4/h/AzLsIHh/2j+TnCZBn0XQm3D8yJ9Y4w4oouS4wpPduRW0A==} + engines: {node: '>= 18'} + peerDependencies: + markdown-it: ^14.1.0 + peerDependenciesMeta: + markdown-it: + optional: true + '@mdit/plugin-uml@0.14.0': resolution: {integrity: sha512-eIR4CiJfATlVAGuJh5Nd9L23zaN/ZDXc13SI/CaEPD+JG9/0h9XtyuceD5ncZDuEhmLnlxJua50Qek8NaObWDQ==} engines: {node: '>= 18'} @@ -2890,6 +3028,9 @@ packages: markdown-it: optional: true + '@mermaid-js/parser@0.3.0': + resolution: {integrity: sha512-HsvL6zgE5sUPGgkIDlmAWR1HTNHz2Iy11BAWPTa4Jjabkpguy4Ze2gzfLrg6pdRuBvFwgUYyxiaNqZwrEEXepA==} + '@meteorlxy/eslint-config@4.8.1': resolution: {integrity: sha512-a75qjpFaWf6MjwfXQaVAPt2Qp6GjUIhDLSFXw7JayJLvnglkZeEHoFchQkbhxL/426n2YbskPt3pl+ANzjiKqg==} peerDependencies: @@ -3390,12 +3531,109 @@ packages: '@types/conventional-commits-parser@5.0.1': resolution: {integrity: sha512-7uz5EHdzz2TqoMfV7ee61Egf5y6NkcO4FB/1iCCQnbeiI1F3xzv3vK5dBCXUCLQgGYS+mUeigK1iKQzvED+QnQ==} + '@types/d3-array@3.2.1': + resolution: {integrity: sha512-Y2Jn2idRrLzUfAKV2LyRImR+y4oa2AntrgID95SHJxuMUrkNXmanDSed71sRNZysveJVt1hLLemQZIady0FpEg==} + + '@types/d3-axis@3.0.6': + resolution: {integrity: sha512-pYeijfZuBd87T0hGn0FO1vQ/cgLk6E1ALJjfkC0oJ8cbwkZl3TpgS8bVBLZN+2jjGgg38epgxb2zmoGtSfvgMw==} + + '@types/d3-brush@3.0.6': + resolution: {integrity: sha512-nH60IZNNxEcrh6L1ZSMNA28rj27ut/2ZmI3r96Zd+1jrZD++zD3LsMIjWlvg4AYrHn/Pqz4CF3veCxGjtbqt7A==} + + '@types/d3-chord@3.0.6': + resolution: {integrity: sha512-LFYWWd8nwfwEmTZG9PfQxd17HbNPksHBiJHaKuY1XeqscXacsS2tyoo6OdRsjf+NQYeB6XrNL3a25E3gH69lcg==} + + '@types/d3-color@3.1.3': + resolution: {integrity: sha512-iO90scth9WAbmgv7ogoq57O9YpKmFBbmoEoCHDB2xMBY0+/KVrqAaCDyCE16dUspeOvIxFFRI+0sEtqDqy2b4A==} + + '@types/d3-contour@3.0.6': + resolution: {integrity: sha512-BjzLgXGnCWjUSYGfH1cpdo41/hgdWETu4YxpezoztawmqsvCeep+8QGfiY6YbDvfgHz/DkjeIkkZVJavB4a3rg==} + + '@types/d3-delaunay@6.0.4': + resolution: {integrity: sha512-ZMaSKu4THYCU6sV64Lhg6qjf1orxBthaC161plr5KuPHo3CNm8DTHiLw/5Eq2b6TsNP0W0iJrUOFscY6Q450Hw==} + + '@types/d3-dispatch@3.0.6': + resolution: {integrity: sha512-4fvZhzMeeuBJYZXRXrRIQnvUYfyXwYmLsdiN7XXmVNQKKw1cM8a5WdID0g1hVFZDqT9ZqZEY5pD44p24VS7iZQ==} + + '@types/d3-drag@3.0.7': + resolution: {integrity: sha512-HE3jVKlzU9AaMazNufooRJ5ZpWmLIoc90A37WU2JMmeq28w1FQqCZswHZ3xR+SuxYftzHq6WU6KJHvqxKzTxxQ==} + + '@types/d3-dsv@3.0.7': + resolution: {integrity: sha512-n6QBF9/+XASqcKK6waudgL0pf/S5XHPPI8APyMLLUHd8NqouBGLsU8MgtO7NINGtPBtk9Kko/W4ea0oAspwh9g==} + + '@types/d3-ease@3.0.2': + resolution: {integrity: sha512-NcV1JjO5oDzoK26oMzbILE6HW7uVXOHLQvHshBUW4UMdZGfiY6v5BeQwh9a9tCzv+CeefZQHJt5SRgK154RtiA==} + + '@types/d3-fetch@3.0.7': + resolution: {integrity: sha512-fTAfNmxSb9SOWNB9IoG5c8Hg6R+AzUHDRlsXsDZsNp6sxAEOP0tkP3gKkNSO/qmHPoBFTxNrjDprVHDQDvo5aA==} + + '@types/d3-force@3.0.10': + resolution: {integrity: sha512-ZYeSaCF3p73RdOKcjj+swRlZfnYpK1EbaDiYICEEp5Q6sUiqFaFQ9qgoshp5CzIyyb/yD09kD9o2zEltCexlgw==} + + '@types/d3-format@3.0.4': + resolution: {integrity: sha512-fALi2aI6shfg7vM5KiR1wNJnZ7r6UuggVqtDA+xiEdPZQwy/trcQaHnwShLuLdta2rTymCNpxYTiMZX/e09F4g==} + + '@types/d3-geo@3.1.0': + resolution: {integrity: sha512-856sckF0oP/diXtS4jNsiQw/UuK5fQG8l/a9VVLeSouf1/PPbBE1i1W852zVwKwYCBkFJJB7nCFTbk6UMEXBOQ==} + + '@types/d3-hierarchy@3.1.7': + resolution: {integrity: sha512-tJFtNoYBtRtkNysX1Xq4sxtjK8YgoWUNpIiUee0/jHGRwqvzYxkq0hGVbbOGSz+JgFxxRu4K8nb3YpG3CMARtg==} + + '@types/d3-interpolate@3.0.4': + resolution: {integrity: sha512-mgLPETlrpVV1YRJIglr4Ez47g7Yxjl1lj7YKsiMCb27VJH9W8NVM6Bb9d8kkpG/uAQS5AmbA48q2IAolKKo1MA==} + + '@types/d3-path@3.1.0': + resolution: {integrity: sha512-P2dlU/q51fkOc/Gfl3Ul9kicV7l+ra934qBFXCFhrZMOL6du1TM0pm1ThYvENukyOn5h9v+yMJ9Fn5JK4QozrQ==} + + '@types/d3-polygon@3.0.2': + resolution: {integrity: sha512-ZuWOtMaHCkN9xoeEMr1ubW2nGWsp4nIql+OPQRstu4ypeZ+zk3YKqQT0CXVe/PYqrKpZAi+J9mTs05TKwjXSRA==} + + '@types/d3-quadtree@3.0.6': + resolution: {integrity: sha512-oUzyO1/Zm6rsxKRHA1vH0NEDG58HrT5icx/azi9MF1TWdtttWl0UIUsjEQBBh+SIkrpd21ZjEv7ptxWys1ncsg==} + + '@types/d3-random@3.0.3': + resolution: {integrity: sha512-Imagg1vJ3y76Y2ea0871wpabqp613+8/r0mCLEBfdtqC7xMSfj9idOnmBYyMoULfHePJyxMAw3nWhJxzc+LFwQ==} + + '@types/d3-scale-chromatic@3.0.3': + resolution: {integrity: sha512-laXM4+1o5ImZv3RpFAsTRn3TEkzqkytiOY0Dz0sq5cnd1dtNlk6sHLon4OvqaiJb28T0S/TdsBI3Sjsy+keJrw==} + + '@types/d3-scale@4.0.8': + resolution: {integrity: sha512-gkK1VVTr5iNiYJ7vWDI+yUFFlszhNMtVeneJ6lUTKPjprsvLLI9/tgEGiXJOnlINJA8FyA88gfnQsHbybVZrYQ==} + + '@types/d3-selection@3.0.11': + resolution: {integrity: sha512-bhAXu23DJWsrI45xafYpkQ4NtcKMwWnAC/vKrd2l+nxMFuvOT3XMYTIj2opv8vq8AO5Yh7Qac/nSeP/3zjTK0w==} + + '@types/d3-shape@3.1.6': + resolution: {integrity: sha512-5KKk5aKGu2I+O6SONMYSNflgiP0WfZIQvVUMan50wHsLG1G94JlxEVnCpQARfTtzytuY0p/9PXXZb3I7giofIA==} + + '@types/d3-time-format@4.0.3': + resolution: {integrity: sha512-5xg9rC+wWL8kdDj153qZcsJ0FWiFt0J5RB6LYUNZjwSnesfblqrI/bJ1wBdJ8OQfncgbJG5+2F+qfqnqyzYxyg==} + + '@types/d3-time@3.0.4': + resolution: {integrity: sha512-yuzZug1nkAAaBlBBikKZTgzCeA+k1uy4ZFwWANOfKw5z5LRhV0gNA7gNkKm7HoK+HRN0wX3EkxGk0fpbWhmB7g==} + + '@types/d3-timer@3.0.2': + resolution: {integrity: sha512-Ps3T8E8dZDam6fUyNiMkekK3XUsaUEik+idO9/YjPtfj2qruF8tFBXS7XhtE4iIXBLxhmLjP3SXpLhVf21I9Lw==} + + '@types/d3-transition@3.0.9': + resolution: {integrity: sha512-uZS5shfxzO3rGlu0cC3bjmMFKsXv+SmZZcgp0KD22ts4uGXp5EVYGzu/0YdwZeKmddhcAccYtREJKkPfXkZuCg==} + + '@types/d3-zoom@3.0.8': + resolution: {integrity: sha512-iqMC4/YlFCSlO8+2Ii1GGGliCAY4XdeG748w5vQUbevlbDu0zSjH/+jojorQVBK/se0j6DUFNPBGSqD3YWYnDw==} + + '@types/d3@7.4.3': + resolution: {integrity: sha512-lZXZ9ckh5R8uiFVt8ogUNf+pIrK4EsWrx2Np75WvF/eTpJ0FMHNhjXk8CKEx/+gpHbNQyJWehbFaTvqmHWB3ww==} + '@types/debug@4.1.12': resolution: {integrity: sha512-vIChWdVG3LG1SMxEvI/AK+FWJthlrqlTu7fbrlywTkkaONwk/UAGaULXRlf8vkzFBLVm0zkMdCquhL5aOjhXPQ==} '@types/doctrine@0.0.9': resolution: {integrity: sha512-eOIHzCUSH7SMfonMG1LsC2f8vxBFtho6NGBznK41R84YzPuvSBzrhEps33IsQiOW9+VL6NQ9DbjQJznk/S4uRA==} + '@types/dompurify@3.2.0': + resolution: {integrity: sha512-Fgg31wv9QbLDA0SpTOXO3MaxySc4DKGLi8sna4/Utjo4r3ZRPdCt4UQee8BWr+Q5z21yifghREPJGYaEOEIACg==} + deprecated: This is a stub types definition. dompurify provides its own type definitions, so you do not need this installed. + '@types/eslint-scope@3.7.7': resolution: {integrity: sha512-MzMFlSLBqNF2gcHWO0G1vP/YQyfvrxZ0bF+u7mzUdZ1/xK4A4sru+nraZz5i3iEIk1l1uyicaDVTB4QbbEkAYg==} @@ -3420,6 +3658,9 @@ packages: '@types/fs-extra@11.0.4': resolution: {integrity: sha512-yTbItCNreRooED33qjunPthRcSjERP1r4MqCZc7wv0u2sUkzTFp45tgUfS5+r7FrZPdmCCNflLhVSP/o+SemsQ==} + '@types/geojson@7946.0.14': + resolution: {integrity: sha512-WCfD5Ht3ZesJUsONdhvm84dmzWOiOzOAqOncN0++w0lBw1o8OuDNJF2McvvCef/yBqb/HYRahp1BYtODFQ8bRg==} + '@types/hash-sum@1.0.2': resolution: {integrity: sha512-UP28RddqY8xcU0SCEp9YKutQICXpaAq9N8U2klqF5hegGha7KzTOL8EdhIIV3bOSGBzjEpN9bU/d+nNZBdJYVw==} @@ -3504,6 +3745,9 @@ packages: '@types/range-parser@1.2.7': resolution: {integrity: sha512-hKormJbkJqzQGhziax5PItDUTMAM9uE2XXQmM37dyd4hVM+5aVl7oVxMVUiVQn2oCQFN/LKCZdvSM0pFRqbSmQ==} + '@types/raphael@2.3.9': + resolution: {integrity: sha512-K1dZwoLNvEN+mvleFU/t2swG9Z4SE5Vub7dA5wDYojH0bVTQ8ZAP+lNsl91t1njdu/B+roSEL4QXC67I7Hpiag==} + '@types/resolve@1.20.2': resolution: {integrity: sha512-60BCwRFOZCQhDncwQdxxeOEEkbc5dIMccYLwbxsS4TUNeVECQ/pBJ0j09mrHOl/JJvpRPGwO9SvE4nR2Nb/a4Q==} @@ -4119,6 +4363,10 @@ packages: chardet@0.7.0: resolution: {integrity: sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==} + chart.js@4.4.6: + resolution: {integrity: sha512-8Y406zevUPbbIBA/HRk33khEmQPk5+cxeflWE/2rx1NJsjVWMPw/9mSP9rxHP5eqi6LNoPBVMfZHxbwLSgldYA==} + engines: {pnpm: '>=8'} + check-error@2.1.1: resolution: {integrity: sha512-OAlb+T7V4Op9OwdkjmguYRqncdlx5JiofwOAUkmTF+jNdHwzTaTs4sRAGpzLF3oOz5xAyDGrPgeIDFQmDOTiJw==} engines: {node: '>= 16'} @@ -4130,6 +4378,18 @@ packages: resolution: {integrity: sha512-quS9HgjQpdaXOvsZz82Oz7uxtXiy6UIsIQcpBj7HRw2M63Skasm9qlDocAM7jNuaxdhpPU7c4kJN+gA5MCu4ww==} engines: {node: '>=18.17'} + cheerio@1.0.0-rc.12: + resolution: {integrity: sha512-VqR8m68vM46BNnuZ5NtnGBKIE/DfN0cRIzg9n40EIq9NOv90ayxLBXA8fXC5gquFRGJSTRqBq25Jt2ECLR431Q==} + engines: {node: '>= 6'} + + chevrotain-allstar@0.3.1: + resolution: {integrity: sha512-b7g+y9A0v4mxCW1qUhf3BSVPg+/NvGErk/dOkrDaHA0nQIQGAtrOjlX//9OQtRlSCy+x9rfB5N8yC71lH1nvMw==} + peerDependencies: + chevrotain: ^11.0.0 + + chevrotain@11.0.3: + resolution: {integrity: sha512-ci2iJH6LeIkvP9eJW6gpueU8cnZhv85ELY8w8WiFtNjMHA5ad6pQLaJo9mEly/9qUyCpvqX8/POVUTf18/HFdw==} + chokidar@3.6.0: resolution: {integrity: sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==} engines: {node: '>= 8.10.0'} @@ -4256,6 +4516,9 @@ packages: concat-map@0.0.1: resolution: {integrity: sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==} + confbox@0.1.8: + resolution: {integrity: sha512-RMtmw0iFkeR4YV+fUOSucriAQNb9g8zFR52MWCtl+cCZOFRNL6zeB395vPzFhEjjn4fMxXudmELnl/KF/WrK6w==} + config-chain@1.1.13: resolution: {integrity: sha512-qj+f8APARXHrM0hraqXYb2/bOVSV4PvJQlNZ/DVj0QrmNM2q2euizkeuVckQ57J+W0mRH6Hvi+k50M4Jul2VRQ==} @@ -4409,6 +4672,12 @@ packages: resolution: {integrity: sha512-utCYNzRSQIZNPIcGZdQc92UVJYAhtGAteCFg0yRaFm8f0P+CPtyGyHXJcGXnffjCybUCEx3FQ2G7U3/o9eIkVQ==} engines: {node: '>= 0.4.0'} + cose-base@1.0.3: + resolution: {integrity: sha512-s9whTXInMSgAp/NVXVNuVxVKzGH2qck3aQlVHxDCdAEPgtMKwc4Wq6/QKhgdEdgbLSi9rBTAcPoRa6JpiG4ksg==} + + cose-base@2.2.0: + resolution: {integrity: sha512-AzlgcsCbUMymkADOJtQm3wO9S3ltPfYOFD5033keQn9NJzIbtnZj+UdBJe7DYml/8TdbtHJW3j58SOnKhWY/5g==} + cosmiconfig-typescript-loader@6.1.0: resolution: {integrity: sha512-tJ1w35ZRUiM5FeTzT7DtYWAFFv37ZLqSRkGi2oeCK1gPhvaWjkAtfXvLmvE1pRfxxp9aQo6ba/Pvg1dKj05D4g==} engines: {node: '>=v18'} @@ -4543,6 +4812,168 @@ packages: csstype@3.1.3: resolution: {integrity: sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==} + cytoscape-cose-bilkent@4.1.0: + resolution: {integrity: sha512-wgQlVIUJF13Quxiv5e1gstZ08rnZj2XaLHGoFMYXz7SkNfCDOOteKBE6SYRfA9WxxI/iBc3ajfDoc6hb/MRAHQ==} + peerDependencies: + cytoscape: ^3.2.0 + + cytoscape-fcose@2.2.0: + resolution: {integrity: sha512-ki1/VuRIHFCzxWNrsshHYPs6L7TvLu3DL+TyIGEsRcvVERmxokbf5Gdk7mFxZnTdiGtnA4cfSmjZJMviqSuZrQ==} + peerDependencies: + cytoscape: ^3.2.0 + + cytoscape@3.30.4: + resolution: {integrity: sha512-OxtlZwQl1WbwMmLiyPSEBuzeTIQnwZhJYYWFzZ2PhEHVFwpeaqNIkUzSiso00D98qk60l8Gwon2RP304d3BJ1A==} + engines: {node: '>=0.10'} + + d3-array@2.12.1: + resolution: {integrity: sha512-B0ErZK/66mHtEsR1TkPEEkwdy+WDesimkM5gpZr5Dsg54BiTA5RXtYW5qTLIAcekaS9xfZrzBLF/OAkB3Qn1YQ==} + + d3-array@3.2.4: + resolution: {integrity: sha512-tdQAmyA18i4J7wprpYq8ClcxZy3SC31QMeByyCFyRt7BVHdREQZ5lpzoe5mFEYZUWe+oq8HBvk9JjpibyEV4Jg==} + engines: {node: '>=12'} + + d3-axis@3.0.0: + resolution: {integrity: sha512-IH5tgjV4jE/GhHkRV0HiVYPDtvfjHQlQfJHs0usq7M30XcSBvOotpmH1IgkcXsO/5gEQZD43B//fc7SRT5S+xw==} + engines: {node: '>=12'} + + d3-brush@3.0.0: + resolution: {integrity: sha512-ALnjWlVYkXsVIGlOsuWH1+3udkYFI48Ljihfnh8FZPF2QS9o+PzGLBslO0PjzVoHLZ2KCVgAM8NVkXPJB2aNnQ==} + engines: {node: '>=12'} + + d3-chord@3.0.1: + resolution: {integrity: sha512-VE5S6TNa+j8msksl7HwjxMHDM2yNK3XCkusIlpX5kwauBfXuyLAtNg9jCp/iHH61tgI4sb6R/EIMWCqEIdjT/g==} + engines: {node: '>=12'} + + d3-color@3.1.0: + resolution: {integrity: sha512-zg/chbXyeBtMQ1LbD/WSoW2DpC3I0mpmPdW+ynRTj/x2DAWYrIY7qeZIHidozwV24m4iavr15lNwIwLxRmOxhA==} + engines: {node: '>=12'} + + d3-contour@4.0.2: + resolution: {integrity: sha512-4EzFTRIikzs47RGmdxbeUvLWtGedDUNkTcmzoeyg4sP/dvCexO47AaQL7VKy/gul85TOxw+IBgA8US2xwbToNA==} + engines: {node: '>=12'} + + d3-delaunay@6.0.4: + resolution: {integrity: sha512-mdjtIZ1XLAM8bm/hx3WwjfHt6Sggek7qH043O8KEjDXN40xi3vx/6pYSVTwLjEgiXQTbvaouWKynLBiUZ6SK6A==} + engines: {node: '>=12'} + + d3-dispatch@3.0.1: + resolution: {integrity: sha512-rzUyPU/S7rwUflMyLc1ETDeBj0NRuHKKAcvukozwhshr6g6c5d8zh4c2gQjY2bZ0dXeGLWc1PF174P2tVvKhfg==} + engines: {node: '>=12'} + + d3-drag@3.0.0: + resolution: {integrity: sha512-pWbUJLdETVA8lQNJecMxoXfH6x+mO2UQo8rSmZ+QqxcbyA3hfeprFgIT//HW2nlHChWeIIMwS2Fq+gEARkhTkg==} + engines: {node: '>=12'} + + d3-dsv@3.0.1: + resolution: {integrity: sha512-UG6OvdI5afDIFP9w4G0mNq50dSOsXHJaRE8arAS5o9ApWnIElp8GZw1Dun8vP8OyHOZ/QJUKUJwxiiCCnUwm+Q==} + engines: {node: '>=12'} + hasBin: true + + d3-ease@3.0.1: + resolution: {integrity: sha512-wR/XK3D3XcLIZwpbvQwQ5fK+8Ykds1ip7A2Txe0yxncXSdq1L9skcG7blcedkOX+ZcgxGAmLX1FrRGbADwzi0w==} + engines: {node: '>=12'} + + d3-fetch@3.0.1: + resolution: {integrity: sha512-kpkQIM20n3oLVBKGg6oHrUchHM3xODkTzjMoj7aWQFq5QEM+R6E4WkzT5+tojDY7yjez8KgCBRoj4aEr99Fdqw==} + engines: {node: '>=12'} + + d3-flextree@2.1.2: + resolution: {integrity: sha512-gJiHrx5uTTHq44bjyIb3xpbmmdZcWLYPKeO9EPVOq8EylMFOiH2+9sWqKAiQ4DcFuOZTAxPOQyv0Rnmji/g15A==} + + d3-force@3.0.0: + resolution: {integrity: sha512-zxV/SsA+U4yte8051P4ECydjD/S+qeYtnaIyAs9tgHCqfguma/aAQDjo85A9Z6EKhBirHRJHXIgJUlffT4wdLg==} + engines: {node: '>=12'} + + d3-format@3.1.0: + resolution: {integrity: sha512-YyUI6AEuY/Wpt8KWLgZHsIU86atmikuoOmCfommt0LYHiQSPjvX2AcFc38PX0CBpr2RCyZhjex+NS/LPOv6YqA==} + engines: {node: '>=12'} + + d3-geo@3.1.1: + resolution: {integrity: sha512-637ln3gXKXOwhalDzinUgY83KzNWZRKbYubaG+fGVuc/dxO64RRljtCTnf5ecMyE1RIdtqpkVcq0IbtU2S8j2Q==} + engines: {node: '>=12'} + + d3-hierarchy@1.1.9: + resolution: {integrity: sha512-j8tPxlqh1srJHAtxfvOUwKNYJkQuBFdM1+JAUfq6xqH5eAqf93L7oG1NVqDa4CpFZNvnNKtCYEUC8KY9yEn9lQ==} + + d3-hierarchy@3.1.2: + resolution: {integrity: sha512-FX/9frcub54beBdugHjDCdikxThEqjnR93Qt7PvQTOHxyiNCAlvMrHhclk3cD5VeAaq9fxmfRp+CnWw9rEMBuA==} + engines: {node: '>=12'} + + d3-interpolate@3.0.1: + resolution: {integrity: sha512-3bYs1rOD33uo8aqJfKP3JWPAibgw8Zm2+L9vBKEHJ2Rg+viTR7o5Mmv5mZcieN+FRYaAOWX5SJATX6k1PWz72g==} + engines: {node: '>=12'} + + d3-path@1.0.9: + resolution: {integrity: sha512-VLaYcn81dtHVTjEHd8B+pbe9yHWpXKZUC87PzoFmsFrJqgFwDe/qxfp5MlfsfM1V5E/iVt0MmEbWQ7FVIXh/bg==} + + d3-path@3.1.0: + resolution: {integrity: sha512-p3KP5HCf/bvjBSSKuXid6Zqijx7wIfNW+J/maPs+iwR35at5JCbLUT0LzF1cnjbCHWhqzQTIN2Jpe8pRebIEFQ==} + engines: {node: '>=12'} + + d3-polygon@3.0.1: + resolution: {integrity: sha512-3vbA7vXYwfe1SYhED++fPUQlWSYTTGmFmQiany/gdbiWgU/iEyQzyymwL9SkJjFFuCS4902BSzewVGsHHmHtXg==} + engines: {node: '>=12'} + + d3-quadtree@3.0.1: + resolution: {integrity: sha512-04xDrxQTDTCFwP5H6hRhsRcb9xxv2RzkcsygFzmkSIOJy3PeRJP7sNk3VRIbKXcog561P9oU0/rVH6vDROAgUw==} + engines: {node: '>=12'} + + d3-random@3.0.1: + resolution: {integrity: sha512-FXMe9GfxTxqd5D6jFsQ+DJ8BJS4E/fT5mqqdjovykEB2oFbTMDVdg1MGFxfQW+FBOGoB++k8swBrgwSHT1cUXQ==} + engines: {node: '>=12'} + + d3-sankey@0.12.3: + resolution: {integrity: sha512-nQhsBRmM19Ax5xEIPLMY9ZmJ/cDvd1BG3UVvt5h3WRxKg5zGRbvnteTyWAbzeSvlh3tW7ZEmq4VwR5mB3tutmQ==} + + d3-scale-chromatic@3.1.0: + resolution: {integrity: sha512-A3s5PWiZ9YCXFye1o246KoscMWqf8BsD9eRiJ3He7C9OBaxKhAd5TFCdEx/7VbKtxxTsu//1mMJFrEt572cEyQ==} + engines: {node: '>=12'} + + d3-scale@4.0.2: + resolution: {integrity: sha512-GZW464g1SH7ag3Y7hXjf8RoUuAFIqklOAq3MRl4OaWabTFJY9PN/E1YklhXLh+OQ3fM9yS2nOkCoS+WLZ6kvxQ==} + engines: {node: '>=12'} + + d3-selection@3.0.0: + resolution: {integrity: sha512-fmTRWbNMmsmWq6xJV8D19U/gw/bwrHfNXxrIN+HfZgnzqTHp9jOmKMhsTUjXOJnZOdZY9Q28y4yebKzqDKlxlQ==} + engines: {node: '>=12'} + + d3-shape@1.3.7: + resolution: {integrity: sha512-EUkvKjqPFUAZyOlhY5gzCxCeI0Aep04LwIRpsZ/mLFelJiUfnK56jo5JMDSE7yyP2kLSb6LtF+S5chMk7uqPqw==} + + d3-shape@3.2.0: + resolution: {integrity: sha512-SaLBuwGm3MOViRq2ABk3eLoxwZELpH6zhl3FbAoJ7Vm1gofKx6El1Ib5z23NUEhF9AsGl7y+dzLe5Cw2AArGTA==} + engines: {node: '>=12'} + + d3-time-format@4.1.0: + resolution: {integrity: sha512-dJxPBlzC7NugB2PDLwo9Q8JiTR3M3e4/XANkreKSUxF8vvXKqm1Yfq4Q5dl8budlunRVlUUaDUgFt7eA8D6NLg==} + engines: {node: '>=12'} + + d3-time@3.1.0: + resolution: {integrity: sha512-VqKjzBLejbSMT4IgbmVgDjpkYrNWUYJnbCGo874u7MMKIWsILRX+OpX/gTk8MqjpT1A/c6HY2dCA77ZN0lkQ2Q==} + engines: {node: '>=12'} + + d3-timer@3.0.1: + resolution: {integrity: sha512-ndfJ/JxxMd3nw31uyKoY2naivF+r29V+Lc0svZxe1JvvIRmi8hUsrMvdOwgS1o6uBHmiz91geQ0ylPP0aj1VUA==} + engines: {node: '>=12'} + + d3-transition@3.0.1: + resolution: {integrity: sha512-ApKvfjsSR6tg06xrL434C0WydLr7JewBB3V+/39RMHsaXTOG0zmt/OAXeng5M5LBm0ojmxJrpomQVZ1aPvBL4w==} + engines: {node: '>=12'} + peerDependencies: + d3-selection: 2 - 3 + + d3-zoom@3.0.0: + resolution: {integrity: sha512-b8AmV3kfQaqWAuacbPuNbL6vahnOJflOhexLzMMNLga62+/nh0JzvJ0aO/5a5MVgUFGS7Hu1P9P03o3fJkDCyw==} + engines: {node: '>=12'} + + d3@7.9.0: + resolution: {integrity: sha512-e1U46jVP+w7Iut8Jt8ri1YsPOvFpg46k+K8TpCb0P+zjCkjkPnV7WzfDJzMHy1LnA+wj5pLT1wjO901gLXeEhA==} + engines: {node: '>=12'} + + dagre-d3-es@7.0.11: + resolution: {integrity: sha512-tvlJLyQf834SylNKax8Wkzco/1ias1OPw8DcUMDE7oUIoSEW25riQVuiu/0OWEFqT0cxHT3Pa9/D82Jr47IONw==} + dargs@8.1.0: resolution: {integrity: sha512-wAV9QHOsNbwnWdNW2FYvE1P56wtgSbM+3SZcdGiWQILwVjACCXDCI3Ai8QlCjMDB8YK5zySiXZYBiwGmNY3lnw==} engines: {node: '>=12'} @@ -4563,6 +4994,9 @@ packages: resolution: {integrity: sha512-BS8PfmtDGnrgYdOonGZQdLZslWIeCGFP9tpan0hi1Co2Zr2NKADsvGYA8XxuG/4UWgJ6Cjtv+YJnB6MM69QGlQ==} engines: {node: '>= 0.4'} + dayjs@1.11.13: + resolution: {integrity: sha512-oaMBel6gjolK862uaPQOVTA7q3TZhuSvuMQAAglQDOWYO9A91IrAOUJEyKVlqJlHE0vq5p5UXxzdPfMH/x6xNg==} + debounce@2.2.0: resolution: {integrity: sha512-Xks6RUDLZFdz8LIdR6q0MTH44k7FikOmnh5xkSjMig6ch45afc8sjTjRQf3P6ax8dMgcQrYO/AR2RGWURrruqw==} engines: {node: '>=18'} @@ -4642,6 +5076,9 @@ packages: resolution: {integrity: sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==} engines: {node: '>= 0.4'} + delaunator@5.0.1: + resolution: {integrity: sha512-8nvh+XBe96aCESrGOqMp/84b13H9cdKbG5P2ejQCh4d4sK9RL4371qou9drQjMhvnPmhWl5hnmqbEE0fXr9Xnw==} + depd@1.1.2: resolution: {integrity: sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ==} engines: {node: '>= 0.6'} @@ -4709,6 +5146,9 @@ packages: resolution: {integrity: sha512-cgwlv/1iFQiFnU96XXgROh8xTeetsnJiDsTc7TYCLFd9+/WNkIqPTxiM/8pSd8VIrhXGTf1Ny1q1hquVqDJB5w==} engines: {node: '>= 4'} + dompurify@3.1.6: + resolution: {integrity: sha512-cTOAhc36AalkjtBpfG6O8JimdTMWNXjiePT2xQH/ppBGi/4uIpmj8eKyIkMJErXWARyINV/sB38yf8JCLF5pbQ==} + domutils@2.8.0: resolution: {integrity: sha512-w96Cjofp72M5IIhpjgobBimYEfoPjx1Vx0BSX9P30WBdZW2WIKU0T1Bd0kz2eNZ9ikjKgHbEyKx8BB6H1L3h3A==} @@ -4736,6 +5176,9 @@ packages: eastasianwidth@0.2.0: resolution: {integrity: sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==} + echarts@5.5.1: + resolution: {integrity: sha512-Fce8upazaAXUVUVsjgV6mBnGuqgO+JNDlcgF79Dksy4+wgGpQB2lmYoO4TSweFg/mZITdpGHomw/cNBJZj1icA==} + ee-first@1.1.1: resolution: {integrity: sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==} @@ -4981,6 +5424,9 @@ packages: resolution: {integrity: sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==} engines: {node: '>= 0.6'} + eve-raphael@0.5.0: + resolution: {integrity: sha512-jrxnPsCGqng1UZuEp9DecX/AuSyAszATSjf4oEcRxvfxa1Oux4KkIPKBAAWWnpdwfARtr+Q0o9aPYWjsROD7ug==} + eventemitter3@4.0.7: resolution: {integrity: sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw==} @@ -5121,6 +5567,10 @@ packages: flatted@3.3.2: resolution: {integrity: sha512-AiwGJM8YcNOaobumgtng+6NHuOqC3A7MixFeDafM3X9cIUM+xUXoS5Vfgf+OihAYe20fxqNM9yPBXJzRtZ/4eA==} + flowchart.ts@3.0.1: + resolution: {integrity: sha512-bBlP6IAe6A/Y9UXb27YhbGS39fTaGLHx1dyjNazIc0d6ntVGC2eIHP6siUQj9PMEX1M5vKXbTecpi+dn4Bhhjg==} + engines: {node: ^18.0.0 || >= 20} + follow-redirects@1.15.9: resolution: {integrity: sha512-gew4GsXizNgdoRyqmyfMHyAmXsZDk6mHkSxZFCzW9gwlbtOW44CDtYavM+y+72qD/Vq2l550kMF52DT8fOLJqQ==} engines: {node: '>=4.0'} @@ -5346,6 +5796,9 @@ packages: resolution: {integrity: sha512-5v6yZd4JK3eMI3FqqCouswVqwugaA9r4dNZB1wwcmrD02QkV5H0y7XBQW8QwQqEaZY1pM9aqORSORhJRdNK44Q==} engines: {node: '>=6.0'} + hachure-fill@0.5.2: + resolution: {integrity: sha512-3GKBOn+m2LX9iq+JC1064cSFprJY4jL1jCXTcpnfER5HYE2l/4EfWSGzkPa/ZDBmYI0ZOEj5VHV/eKnPGkHuOg==} + handle-thing@2.0.1: resolution: {integrity: sha512-9Qn4yBxelxoh2Ow62nP+Ka/kMnOXRi8BXnRaUwezLNhqelnN49xKz4F/dPP8OYLxLxq6JDtZb2i9XznUQbNPTg==} @@ -5397,6 +5850,10 @@ packages: resolution: {integrity: sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==} hasBin: true + highlight.js@11.10.0: + resolution: {integrity: sha512-SYVnVFswQER+zu1laSya563s+F8VDGt7o35d4utbamowvUNLLMovFqwCLSocpZTz3MgaSRA1IbqRWZv97dtErQ==} + engines: {node: '>=12.0.0'} + hookable@5.5.3: resolution: {integrity: sha512-Yc+BQe8SvoXH1643Qez1zqLRmbA5rCL+sSmk6TVos0LWVfNIB7PGncdlId77WzLGSIB5KaWgTaNTs2lNVEI6VQ==} @@ -5588,6 +6045,13 @@ packages: resolution: {integrity: sha512-4gd7VpWNQNB4UKKCFFVcp1AVv+FMOgs9NKzjHKusc8jTMhd5eL1NqQqOpE0KzMds804/yHlglp3uxgluOqAPLw==} engines: {node: '>= 0.4'} + internmap@1.0.1: + resolution: {integrity: sha512-lDB5YccMydFBtasVtxnZ3MRBHuaoE8GKsppq+EchKL2U4nK/DmEpPHNH8MZe5HkMtpSiTSOZwfN0tzYjO/lJEw==} + + internmap@2.0.3: + resolution: {integrity: sha512-5Hh7Y1wQbvY5ooGgPbDaL5iYLAPzMTUrjMulskHLH6wnv/A+1q5rgEaiuqEjB+oxGXIVZs1FF+R/KPN3ZSQYYg==} + engines: {node: '>=12'} + ip-address@9.0.5: resolution: {integrity: sha512-zHtQzGojZXTwZTHQqra+ETKd4Sn3vgi7uBmlPoXVWZqYvuKmtI0l/VZTjqGmJY9x88GGOaZ9+G9ES8hC4T4X8g==} engines: {node: '>= 12'} @@ -5966,6 +6430,14 @@ packages: just-diff@6.0.2: resolution: {integrity: sha512-S59eriX5u3/QhMNq3v/gm8Kd0w8OS6Tz2FS1NG4blv+z0MuQcBRJyFWjdovM0Rad4/P4aUPFtnkNjMjyMlMSYA==} + katex@0.12.0: + resolution: {integrity: sha512-y+8btoc/CK70XqcHqjxiGWBOeIL8upbS0peTPXTvgrh21n1RiWWcIpSWM+4uXq+IAgNh9YYQWdc7LVDPDAEEAg==} + hasBin: true + + katex@0.16.11: + resolution: {integrity: sha512-RQrI8rlHY92OLf3rho/Ts8i/XvjgguEjOkO1BEXcU3N8BqPpSzBNwV/G0Ukr+P/l3ivvJUE/Fa/CwbS6HesGNQ==} + hasBin: true + katex@0.16.18: resolution: {integrity: sha512-LRuk0rPdXrecAFwQucYjMiIs0JFefk6N1q/04mlw14aVIVgxq1FO0MA9RiIIGVaKOB5GIP5GH4aBBNraZERmaQ==} hasBin: true @@ -5973,6 +6445,9 @@ packages: keyv@4.5.4: resolution: {integrity: sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==} + khroma@2.1.0: + resolution: {integrity: sha512-Ls993zuzfayK269Svk9hzpeGUKob/sIgZzyHYdjQoAdQetRKpOLj+k/QQQ/6Qi0Yz65mlROrfd+Ev+1+7dz9Kw==} + kind-of@6.0.3: resolution: {integrity: sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==} engines: {node: '>=0.10.0'} @@ -5980,9 +6455,22 @@ packages: known-css-properties@0.35.0: resolution: {integrity: sha512-a/RAk2BfKk+WFGhhOCAYqSiFLc34k8Mt/6NWRI4joER0EYUzXIcFivjjnoD3+XU1DggLn/tZc3DOAgke7l8a4A==} + kolorist@1.8.0: + resolution: {integrity: sha512-Y+60/zizpJ3HRH8DCss+q95yr6145JXZo46OTpFvDZWLfRCE4qChOyk1b26nMaNpfHHgxagk9dXT5OP0Tfe+dQ==} + + langium@3.0.0: + resolution: {integrity: sha512-+Ez9EoiByeoTu/2BXmEaZ06iPNXM6thWJp02KfBO/raSMyCJ4jw7AkWWa+zBCTm0+Tw1Fj9FOxdqSskyN5nAwg==} + engines: {node: '>=16.0.0'} + launch-editor@2.9.1: resolution: {integrity: sha512-Gcnl4Bd+hRO9P9icCP/RVVT2o8SFlPXofuCxvA2SaZuH45whSvf5p8x5oih5ftLiVhEI4sp5xDY+R+b3zJBh5w==} + layout-base@1.0.2: + resolution: {integrity: sha512-8h2oVEZNktL4BH2JCOI90iD1yXwL6iNW7KcCKT2QZgQJR2vbqDsldCTPRU9NifTCqHZci57XvQQ15YTu+sTYPg==} + + layout-base@2.0.1: + resolution: {integrity: sha512-dp3s92+uNI1hWIpPGH3jK2kxE2lMjdXdr+DH8ynZHpd6PUlH6x6cbuXnoMmiNumznqaNO31xu9e79F0uuZ0JFg==} + leven@3.1.0: resolution: {integrity: sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==} engines: {node: '>=6'} @@ -6102,6 +6590,10 @@ packages: resolution: {integrity: sha512-xXqpXoINfFhgua9xiqD8fPFHgkoq1mmmpE92WlDbm9rNRd/EbRb+Gqf908T2DMfuHjjJlksiK2RbHVOdD/MqSw==} engines: {node: '>=8.9.0'} + local-pkg@0.5.1: + resolution: {integrity: sha512-9rrA30MRRP3gBD3HTGnC6cDFpaE1kVDWxWgqWJUN0RvDNAo+Nz/9GxB+nHOH0ifbVFy0hSA1V6vFDvnx54lTEQ==} + engines: {node: '>=14'} + locate-path@5.0.0: resolution: {integrity: sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==} engines: {node: '>=8'} @@ -6114,6 +6606,9 @@ packages: resolution: {integrity: sha512-gvVijfZvn7R+2qyPX8mAuKcFGDf6Nc61GdvGafQsHL0sBIxfKzA+usWn4GFC/bk+QdwPUD4kWFJLhElipq+0VA==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} + lodash-es@4.17.21: + resolution: {integrity: sha512-mKnC+QJ9pWVzv+C4/U3rRsHapFfHvQFoFB92e52xeyGMcX6/OlIl78je1u8vePzYZSkkogMPJ2yjxxsb89cxyw==} + lodash.camelcase@4.3.0: resolution: {integrity: sha512-TwuEnCnxbc3rAvhf/LbG7tJUDzhqXyFnv3dtzLOPgCG/hODL7WFnsbwktkD7yUV0RrreP/l1PALq/YSg6VvjlA==} @@ -6209,6 +6704,18 @@ packages: markdown-it-emoji@3.0.0: resolution: {integrity: sha512-+rUD93bXHubA4arpEZO3q80so0qgoFJEKRkRbjKX8RTdca89v2kfyF+xR3i2sQTwql9tpPZPOQN5B+PunspXRg==} + markdown-it-ins@4.0.0: + resolution: {integrity: sha512-sWbjK2DprrkINE4oYDhHdCijGT+MIDhEupjSHLXe5UXeVr5qmVxs/nTUVtgi0Oh/qtF+QKV0tNWDhQBEPxiMew==} + + markdown-it-mark@4.0.0: + resolution: {integrity: sha512-YLhzaOsU9THO/cal0lUjfMjrqSMPjjyjChYM7oyj4DnyaXEzA8gnW6cVJeyCrCVeyesrY2PlEdUYJSPFYL4Nkg==} + + markdown-it-sub@2.0.0: + resolution: {integrity: sha512-iCBKgwCkfQBRg2vApy9vx1C1Tu6D8XYo8NvevI3OlwzBRmiMtsJ2sXupBgEA7PPxiDwNni3qIUkhZ6j5wofDUA==} + + markdown-it-sup@2.0.0: + resolution: {integrity: sha512-5VgmdKlkBd8sgXuoDoxMpiU+BiEt3I49GItBzzw7Mxq9CxvnhE/k09HFli09zgfFDRixDQDfDxi0mgBCXtaTvA==} + markdown-it@14.1.0: resolution: {integrity: sha512-a54IwgWPaeBCAAsv13YgmALOF1elABB08FxO9i+r4VFk5Vl4pKokRPeX8u5TCgSsPi6ec1otfLjdOpVcgbpshg==} hasBin: true @@ -6218,11 +6725,39 @@ packages: peerDependencies: marked: '>=4 <16' + marked@13.0.3: + resolution: {integrity: sha512-rqRix3/TWzE9rIoFGIn8JmsVfhiuC8VIQ8IdX5TfzmeBucdY05/0UlzKaw0eVtpcN/OdVFpBk7CjKGo9iHJ/zA==} + engines: {node: '>= 18'} + hasBin: true + marked@15.0.4: resolution: {integrity: sha512-TCHvDqmb3ZJ4PWG7VEGVgtefA5/euFmsIhxtD0XsBxI39gUSKL81mIRFdt0AiNQozUahd4ke98ZdirExd/vSEw==} engines: {node: '>= 18'} hasBin: true + markmap-common@0.17.1: + resolution: {integrity: sha512-U1v2+CkdE9OzNgONvBwUW26RMcu27Bqlv/JuAG+l1qRkTduD2aT4cGew6qb4VLjpqhcBwS3mcj0Xd7LVW01QFA==} + + markmap-html-parser@0.17.1: + resolution: {integrity: sha512-wdzneAsNXNIYH3R8xZVNYi/4MXhswuZ4wmZxHS3+BLp9jO6kBCoQybICB90tcAcXUjiSAYRnirq3EvkSK0AdDw==} + peerDependencies: + markmap-common: '*' + + markmap-lib@0.17.2: + resolution: {integrity: sha512-zS5nL8OBR4hRpqegxeXAd4jQq/wd+Xn21bHhW0QHgGzE3dJTG55pLDi1rmdaHLCTpN7lUtO5MBOZ1HyXGYuHwQ==} + peerDependencies: + markmap-common: '*' + + markmap-toolbar@0.17.2: + resolution: {integrity: sha512-WQ05P2xvQmZT0ybRUE0uRzrs30aXlJ6/yEUsA6A9nYEwm8T9jSwBxIM/5zYlkH/XzUcsRRxtCa4k1IWR74gkpQ==} + peerDependencies: + markmap-common: '*' + + markmap-view@0.17.2: + resolution: {integrity: sha512-kF9bbXWF/10UBFTatv0kPQSBgVb8+Xn4Bttep78i9879nzqRaIjCNzZYGtpxK0gx9B4U9NGMZrx/B4cTTwmeQA==} + peerDependencies: + markmap-common: '*' + math-intrinsics@1.1.0: resolution: {integrity: sha512-/IXtbwEk5HTPyEwyKX6hGkYXxM9nbj64B+ilVJnC/R6B0pH5G4V3b0pVbL7DBj4tkhBAppbQUlf6F6Xl9LHu1g==} engines: {node: '>= 0.4'} @@ -6286,6 +6821,9 @@ packages: resolution: {integrity: sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==} engines: {node: '>= 8'} + mermaid@11.4.0: + resolution: {integrity: sha512-mxCfEYvADJqOiHfGpJXLs4/fAjHz448rH0pfY5fAoxiz70rQiDSzUUy4dNET2T08i46IVpjohPd6WWbzmRHiPA==} + methods@1.1.2: resolution: {integrity: sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==} engines: {node: '>= 0.6'} @@ -6418,6 +6956,9 @@ packages: engines: {node: '>=10'} hasBin: true + mlly@1.7.3: + resolution: {integrity: sha512-xUsx5n/mN0uQf4V548PKQ+YShA4/IW0KI1dZhrNrPCLG+xizETbHTkOa1f8/xut9JRPp8kQuMnz0oqwkTiLo/A==} + ms@2.0.0: resolution: {integrity: sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==} @@ -6548,6 +7089,9 @@ packages: resolution: {integrity: sha512-9qny7Z9DsQU8Ou39ERsPU4OZQlSTP47ShQzuKZ6PRXpYLtIFgl/DEBYEXKlvcEa+9tHVcK8CF81Y2V72qaZhWA==} engines: {node: '>=18'} + npm2url@0.2.4: + resolution: {integrity: sha512-arzGp/hQz0Ey+ZGhF64XVH7Xqwd+1Q/po5uGiBbzph8ebX6T0uvt3N7c1nBHQNsQVykQgHhqoRTX7JFcHecGuw==} + nth-check@2.1.1: resolution: {integrity: sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w==} @@ -6671,6 +7215,9 @@ packages: package-json-from-dist@1.0.1: resolution: {integrity: sha512-UEZIS3/by4OC8vL3P2dTXRETpebLI2NiI5vIrjaD/5UtrkFX/tNbwjTSRAGC/+7CAo2pIcBaRgWmcBBHcsaCIw==} + package-manager-detector@0.2.5: + resolution: {integrity: sha512-3dS7y28uua+UDbRCLBqltMBrbI+A5U2mI9YuxHRxIWYmLj3DwntEBmERYzIAQ4DMeuCUOBSak7dBHHoXKpOTYQ==} + pacote@18.0.6: resolution: {integrity: sha512-+eK3G27SMwsB8kLIuj4h1FUhHtwiEUo21Tw8wNjmvdlpOEr613edv+8FUsTj/4F/VN5ywGE19X18N7CC2EJk6A==} engines: {node: ^16.14.0 || >=18.0.0} @@ -6729,6 +7276,9 @@ packages: pascal-case@3.1.2: resolution: {integrity: sha512-uWlGT3YSnK9x3BQJaOdcZwrnV6hPpd8jFH1/ucpiLRPh/2zCVJKS19E4GvYHvaCcACn3foXZ0cLB9Wrx1KGe5g==} + path-data-parser@0.1.0: + resolution: {integrity: sha512-NOnmBpt5Y2RWbuv0LMzsayp3lVylAHLPUTut412ZA3l+C4uw4ZVkQbjShYCQ8TCpUMdPapr4YjUqLYD6v68j+w==} + path-exists@4.0.0: resolution: {integrity: sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==} engines: {node: '>=8'} @@ -6804,6 +7354,9 @@ packages: resolution: {integrity: sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==} engines: {node: '>=8'} + pkg-types@1.2.1: + resolution: {integrity: sha512-sQoqa8alT3nHjGuTjuKgOnvjo4cljkufdtLMnO2LBP/wRwuDlo1tkaEdMxCRhyGRPacv/ztlZgDPm2b7FAmEvw==} + playwright-core@1.49.1: resolution: {integrity: sha512-BzmpVcs4kE2CH15rWfzpjzVGhWERJfmnXmniSyKeRZUs9Ws65m+RGIi7mjJK/euCegfn3i7jvqWeWyHe9y3Vgg==} engines: {node: '>=18'} @@ -6814,6 +7367,12 @@ packages: engines: {node: '>=18'} hasBin: true + points-on-curve@0.2.0: + resolution: {integrity: sha512-0mYKnYYe9ZcqMCWhUjItv/oHjvgEsfKvnUTg8sAtnHr3GVy7rGkXCb6d5cSyqrWqL4k81b9CPg3urd+T7aop3A==} + + points-on-path@0.2.1: + resolution: {integrity: sha512-25ClnWWuw7JbWZcgqY/gJ4FQWadKxGWk+3kR/7kD0tCaDtPPMj7oHu2ToLaVhfpnHrZzYby2w6tUA0eOIuUg8g==} + portfinder@1.0.32: resolution: {integrity: sha512-on2ZJVVDXRADWE6jnQaX0ioEylzgBpQk8r55NE4wjXW1ZxO+BgDlY6DXwj20i0V8eB4SenDQ00WEaxfiIQPcxg==} engines: {node: '>= 0.12.0'} @@ -7185,6 +7744,9 @@ packages: resolution: {integrity: sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==} engines: {node: '>= 0.6'} + raphael@2.3.0: + resolution: {integrity: sha512-w2yIenZAQnp257XUWGni4bLMVxpUpcIl7qgxEgDIXtmSypYtlNxfXWpOBxs7LBTps5sDwhRnrToJrMUrivqNTQ==} + raw-body@2.5.2: resolution: {integrity: sha512-8zGqypfENjCIqGhgXToC8aB2r7YrBX+AQAfIPs/Mlk+BtPTztOvTS01NRW/3Eh60J+a48lt8qsCzirQ6loCVfA==} engines: {node: '>= 0.8'} @@ -7341,6 +7903,9 @@ packages: engines: {node: 20 || >=22} hasBin: true + robust-predicates@3.0.2: + resolution: {integrity: sha512-IXgzBWvWQwE6PrDI05OvmXUIruQTcoMDzRsOd5CDvHCVLcLHMTSYvOK5Cm46kWqlV3yAbuSpBZdJ5oP5OUoStg==} + rollup-plugin-dts@6.1.1: resolution: {integrity: sha512-aSHRcJ6KG2IHIioYlvAOcEq6U99sVtqDDKVhnwt70rW6tsz3tv5OSjEiWcgzfsHdLyGXZ/3b/7b/+Za3Y6r1XA==} engines: {node: '>=16'} @@ -7371,6 +7936,9 @@ packages: engines: {node: '>=18.0.0', npm: '>=8.0.0'} hasBin: true + roughjs@4.6.6: + resolution: {integrity: sha512-ZUz/69+SYpFN/g/lUlo2FXcIjRkSu3nDarreVdGGndHEBJ6cXPdKguS8JGxwj5HA5xIbVKSmLgr5b3AWxtRfvQ==} + run-applescript@7.0.0: resolution: {integrity: sha512-9by4Ij99JUr/MCFBUkDKLWK3G9HVXmabKz9U5MlIAIuvuzkiOicRYs8XJLxX+xahD+mLiiCYDqF9dKAgtzKP1A==} engines: {node: '>=18'} @@ -7378,6 +7946,9 @@ packages: run-parallel@1.2.0: resolution: {integrity: sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==} + rw@1.3.3: + resolution: {integrity: sha512-PdhdWy89SiZogBLaw42zdeqtRJ//zFd2PgQavcICDUgJT5oW10QCRKbJ6bg4r0/UY2M6BWd5tkxuGFRvCkgfHQ==} + rxjs@7.8.1: resolution: {integrity: sha512-AA3TVj+0A2iuIoQkWEK/tqFjBq2j+6PO6Y0zJcvzLAFhEFIO3HL0vls9hWLncZbAAbK0mar7oZ4V079I/qPMxg==} @@ -7951,6 +8522,9 @@ packages: engines: {node: '>=18.12.0'} hasBin: true + stylis@4.3.4: + resolution: {integrity: sha512-osIBl6BGUmSfDkyH2mB7EFvCJntXDrLhKjHTRj/rK6xLH0yuPrHULDRQzKokSOD4VoorhtKpfcfW1GAntu8now==} + subarg@1.0.0: resolution: {integrity: sha512-RIrIdRY0X1xojthNcVtgT9sjpOGagEUKpZdgBUi054OEPFo282yg+zE+t1Rj3+RqKq2xStL7uUHhY+AjbC4BXg==} @@ -8118,9 +8692,16 @@ packages: ts-debounce@4.0.0: resolution: {integrity: sha512-+1iDGY6NmOGidq7i7xZGA4cm8DAa6fqdYcvO5Z6yBevH++Bdo9Qt/mN0TzHUgcCcKv1gmh9+W5dHqz8pMWbCbg==} + ts-dedent@2.2.0: + resolution: {integrity: sha512-q5W7tVM71e2xjHZTlgfTDoPF/SmqKG5hddq9SzR49CH2hayqRKJtQ4mtRlSxKaJlR/+9rEM+mnBHf7I2/BQcpQ==} + engines: {node: '>=6.10'} + tsconfig-vuepress@5.2.1: resolution: {integrity: sha512-9JI4bozH9ISFRj0KIbSTpyk6Metl7rcICnCFcvdgWj+Hx4L8Z/VuWbAdgzNysiMafILfBLJrfsViEj6ZeW6fHQ==} + tslib@2.3.0: + resolution: {integrity: sha512-N82ooyxVNm6h1riLCoyS9e3fuJ3AMG2zIZs2Gd1ATcSFjSA23Q0fzjjZeh0jbJvWVDZ0cJT8yaNNaaXHzueNjg==} + tslib@2.8.1: resolution: {integrity: sha512-oJFu94HQb+KVduSUQL7wnpmqnfmLsOA/nAh6b6EH0wCEoK0/mPeXU6c3wKDV83MkOuHPRHtSXKKU99IBazS/2w==} @@ -8192,6 +8773,9 @@ packages: uc.micro@2.1.0: resolution: {integrity: sha512-ARDJmphmdvUk6Glw7y9DQ2bFkKBHwQHLi2lsaH6PPmz/Ka9sFOBsBluozhDltWmnv9u/cF6Rt87znRTPV+yp/A==} + ufo@1.5.4: + resolution: {integrity: sha512-UsUk3byDzKd04EyoZ7U4DOlxQaD14JUKQl6/P7wiX4FNvUfm3XL246n9W5AmqwW5RSFJ27NAuM0iLscAOYUiGQ==} + uglify-js@3.19.3: resolution: {integrity: sha512-v3Xu+yuwBXisp6QYTcH4UbH+xYJXqnq2m/LtQVWKWzYc1iehYnLixoQDN9FH6/j9/oybfd6W9Ghwkl8+UMKTKQ==} engines: {node: '>=0.8.0'} @@ -8315,6 +8899,10 @@ packages: resolution: {integrity: sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==} hasBin: true + uuid@9.0.1: + resolution: {integrity: sha512-b+1eJOlsR9K8HJpow9Ok3fiWOWSIcIzXodvv0rQjVoOVNpWMpxf1wZNpt4y9h10odCNrqnYp1OBzRktckBe3sA==} + hasBin: true + validate-npm-package-license@3.0.4: resolution: {integrity: sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==} @@ -8405,6 +8993,26 @@ packages: jsdom: optional: true + vscode-jsonrpc@8.2.0: + resolution: {integrity: sha512-C+r0eKJUIfiDIfwJhria30+TYWPtuHJXHtI7J0YlOmKAo7ogxP20T0zxB7HZQIFhIyvoBPwWskjxrvAtfjyZfA==} + engines: {node: '>=14.0.0'} + + vscode-languageserver-protocol@3.17.5: + resolution: {integrity: sha512-mb1bvRJN8SVznADSGWM9u/b07H7Ecg0I3OgXDuLdn307rl/J3A9YD6/eYOssqhecL27hK1IPZAsaqh00i/Jljg==} + + vscode-languageserver-textdocument@1.0.12: + resolution: {integrity: sha512-cxWNPesCnQCcMPeenjKKsOCKQZ/L6Tv19DTRIGuLWe32lyzWhihGVJ/rcckZXJxfdKCFvRLS3fpBIsV/ZGX4zA==} + + vscode-languageserver-types@3.17.5: + resolution: {integrity: sha512-Ld1VelNuX9pdF39h2Hgaeb5hEZM2Z3jUrrMgWQAu82jMtZp7p3vJT3BzToKtZI7NgQssZje5o0zryOrhQvzQAg==} + + vscode-languageserver@9.0.1: + resolution: {integrity: sha512-woByF3PDpkHFUreUa7Hos7+pUWdeWMXRd26+ZX2A8cFx6v/JPTtd4/uN0/jB6XQHYaOlHbio03NTHCqrgG5n7g==} + hasBin: true + + vscode-uri@3.0.8: + resolution: {integrity: sha512-AyFQ0EVmsOZOlAnxoFOGOq1SQDWAB7C6aqMGS23svWAllfOaxbuFvcT8D1i8z3Gyn8fraVeZNNmN6e9bxxXkKw==} + vue-eslint-parser@9.4.3: resolution: {integrity: sha512-2rYRLWlIpaiN8xbPiDyXZXRgLGOtWxERV7ND5fFAv5qo1D2N9Fu9MNajBNc6o13lZ+24DAWCkQCvj4klgmcITg==} engines: {node: ^14.17.0 || >=16.0.0} @@ -8705,8 +9313,8 @@ packages: yallist@4.0.0: resolution: {integrity: sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==} - yaml@2.4.5: - resolution: {integrity: sha512-aBx2bnqDzVOyNKfsysjA2ms5ZlnjSAW2eG3/L5G/CSujfjLJTJsEw1bGw8kCf04KodQWk1pxlGnZ56CRxiawmg==} + yaml@2.6.1: + resolution: {integrity: sha512-7r0XPzioN/Q9kXBro/XPnA6kznR73DHq+GXh5ON7ZozRO6aMjbmiBuKste2wslTFkC5d1dw0GooOCepZXJ2SAg==} engines: {node: '>= 14'} hasBin: true @@ -8734,6 +9342,9 @@ packages: resolution: {integrity: sha512-GQHQqAopRhwU8Kt1DDM8NjibDXHC8eoh1erhGAJPEyveY9qqVeXvVikNKrDz69sHowPMorbPUrH/mx8c50eiBQ==} engines: {node: '>=18'} + zrender@5.6.0: + resolution: {integrity: sha512-uzgraf4njmmHAbEUxMJ8Oxg+P3fT04O+9p7gY+wJRVxo8Ge+KmYv0WJev945EH4wFuc4OY2NLXz46FZrWS9xJg==} + zwitch@2.0.4: resolution: {integrity: sha512-bXE4cR/kVZhKZX/RjPEflHaKVhUVl85noU3v6b8apfQEc1x4A+zBxjZ4lN8LqGd6WZ3dl98pY4o717VFmoPp+A==} @@ -8849,6 +9460,13 @@ snapshots: '@jridgewell/gen-mapping': 0.3.8 '@jridgewell/trace-mapping': 0.3.25 + '@antfu/install-pkg@0.4.1': + dependencies: + package-manager-detector: 0.2.5 + tinyexec: 0.3.1 + + '@antfu/utils@0.7.10': {} + '@apideck/better-ajv-errors@0.3.6(ajv@8.17.1)': dependencies: ajv: 8.17.1 @@ -9495,8 +10113,27 @@ snapshots: '@babel/helper-string-parser': 7.25.9 '@babel/helper-validator-identifier': 7.25.9 + '@braintree/sanitize-url@7.1.0': {} + '@bufbuild/protobuf@2.2.3': {} + '@chevrotain/cst-dts-gen@11.0.3': + dependencies: + '@chevrotain/gast': 11.0.3 + '@chevrotain/types': 11.0.3 + lodash-es: 4.17.21 + + '@chevrotain/gast@11.0.3': + dependencies: + '@chevrotain/types': 11.0.3 + lodash-es: 4.17.21 + + '@chevrotain/regexp-to-ast@11.0.3': {} + + '@chevrotain/types@11.0.3': {} + + '@chevrotain/utils@11.0.3': {} + '@commitlint/cli@19.6.1(@types/node@22.10.2)(typescript@5.7.2)': dependencies: '@commitlint/format': 19.5.0 @@ -9913,6 +10550,10 @@ snapshots: dependencies: levn: 0.4.1 + '@gera2ld/jsx-dom@2.2.2': + dependencies: + '@babel/runtime': 7.26.0 + '@humanfs/core@0.19.1': {} '@humanfs/node@0.16.6': @@ -9928,6 +10569,24 @@ snapshots: '@hutson/parse-repository-url@5.0.0': {} + '@iconify/types@2.0.0': {} + + '@iconify/utils@2.1.33': + dependencies: + '@antfu/install-pkg': 0.4.1 + '@antfu/utils': 0.7.10 + '@iconify/types': 2.0.0 + debug: 4.4.0 + kolorist: 1.8.0 + local-pkg: 0.5.1 + mlly: 1.7.3 + transitivePeerDependencies: + - supports-color + + '@iktakahiro/markdown-it-katex@4.0.1': + dependencies: + katex: 0.12.0 + '@inquirer/checkbox@4.0.4(@types/node@22.10.2)': dependencies: '@inquirer/core': 10.1.2(@types/node@22.10.2) @@ -10098,6 +10757,8 @@ snapshots: dependencies: tslib: 2.8.1 + '@kurkle/color@0.3.4': {} + '@leichtgewicht/ip-codec@2.0.5': {} '@lerna-lite/cli@3.10.1(@lerna-lite/publish@3.10.1(@types/node@22.10.2)(typescript@5.7.2))(@lerna-lite/version@3.10.1(@lerna-lite/publish@3.10.1(@types/node@22.10.2)(typescript@5.7.2))(@types/node@22.10.2)(typescript@5.7.2))(@types/node@22.10.2)(typescript@5.7.2)': @@ -10347,6 +11008,12 @@ snapshots: optionalDependencies: markdown-it: 14.1.0 + '@mdit/plugin-container@0.13.1(markdown-it@14.1.0)': + dependencies: + '@types/markdown-it': 14.1.2 + optionalDependencies: + markdown-it: 14.1.0 + '@mdit/plugin-container@0.14.0(markdown-it@14.1.0)': dependencies: '@types/markdown-it': 14.1.2 @@ -10415,6 +11082,13 @@ snapshots: markdown-it: 14.1.0 mathjax-full: 3.2.2 + '@mdit/plugin-plantuml@0.13.1(markdown-it@14.1.0)': + dependencies: + '@mdit/plugin-uml': 0.13.1(markdown-it@14.1.0) + '@types/markdown-it': 14.1.2 + optionalDependencies: + markdown-it: 14.1.0 + '@mdit/plugin-spoiler@0.14.0(markdown-it@14.1.0)': dependencies: '@types/markdown-it': 14.1.2 @@ -10460,6 +11134,12 @@ snapshots: optionalDependencies: markdown-it: 14.1.0 + '@mdit/plugin-uml@0.13.1(markdown-it@14.1.0)': + dependencies: + '@types/markdown-it': 14.1.2 + optionalDependencies: + markdown-it: 14.1.0 + '@mdit/plugin-uml@0.14.0(markdown-it@14.1.0)': dependencies: '@mdit/helper': 0.14.0(markdown-it@14.1.0) @@ -10467,6 +11147,10 @@ snapshots: optionalDependencies: markdown-it: 14.1.0 + '@mermaid-js/parser@0.3.0': + dependencies: + langium: 3.0.0 + '@meteorlxy/eslint-config@4.8.1(eslint-plugin-vue@9.32.0(eslint@9.17.0(jiti@2.4.2)))(eslint@9.17.0(jiti@2.4.2))(typescript@5.7.2)(vue-eslint-parser@9.4.3(eslint@9.17.0(jiti@2.4.2)))': dependencies: '@typescript-eslint/eslint-plugin': 8.18.2(@typescript-eslint/parser@8.18.2(eslint@9.17.0(jiti@2.4.2))(typescript@5.7.2))(eslint@9.17.0(jiti@2.4.2))(typescript@5.7.2) @@ -11003,12 +11687,133 @@ snapshots: dependencies: '@types/node': 22.10.2 + '@types/d3-array@3.2.1': {} + + '@types/d3-axis@3.0.6': + dependencies: + '@types/d3-selection': 3.0.11 + + '@types/d3-brush@3.0.6': + dependencies: + '@types/d3-selection': 3.0.11 + + '@types/d3-chord@3.0.6': {} + + '@types/d3-color@3.1.3': {} + + '@types/d3-contour@3.0.6': + dependencies: + '@types/d3-array': 3.2.1 + '@types/geojson': 7946.0.14 + + '@types/d3-delaunay@6.0.4': {} + + '@types/d3-dispatch@3.0.6': {} + + '@types/d3-drag@3.0.7': + dependencies: + '@types/d3-selection': 3.0.11 + + '@types/d3-dsv@3.0.7': {} + + '@types/d3-ease@3.0.2': {} + + '@types/d3-fetch@3.0.7': + dependencies: + '@types/d3-dsv': 3.0.7 + + '@types/d3-force@3.0.10': {} + + '@types/d3-format@3.0.4': {} + + '@types/d3-geo@3.1.0': + dependencies: + '@types/geojson': 7946.0.14 + + '@types/d3-hierarchy@3.1.7': {} + + '@types/d3-interpolate@3.0.4': + dependencies: + '@types/d3-color': 3.1.3 + + '@types/d3-path@3.1.0': {} + + '@types/d3-polygon@3.0.2': {} + + '@types/d3-quadtree@3.0.6': {} + + '@types/d3-random@3.0.3': {} + + '@types/d3-scale-chromatic@3.0.3': {} + + '@types/d3-scale@4.0.8': + dependencies: + '@types/d3-time': 3.0.4 + + '@types/d3-selection@3.0.11': {} + + '@types/d3-shape@3.1.6': + dependencies: + '@types/d3-path': 3.1.0 + + '@types/d3-time-format@4.0.3': {} + + '@types/d3-time@3.0.4': {} + + '@types/d3-timer@3.0.2': {} + + '@types/d3-transition@3.0.9': + dependencies: + '@types/d3-selection': 3.0.11 + + '@types/d3-zoom@3.0.8': + dependencies: + '@types/d3-interpolate': 3.0.4 + '@types/d3-selection': 3.0.11 + + '@types/d3@7.4.3': + dependencies: + '@types/d3-array': 3.2.1 + '@types/d3-axis': 3.0.6 + '@types/d3-brush': 3.0.6 + '@types/d3-chord': 3.0.6 + '@types/d3-color': 3.1.3 + '@types/d3-contour': 3.0.6 + '@types/d3-delaunay': 6.0.4 + '@types/d3-dispatch': 3.0.6 + '@types/d3-drag': 3.0.7 + '@types/d3-dsv': 3.0.7 + '@types/d3-ease': 3.0.2 + '@types/d3-fetch': 3.0.7 + '@types/d3-force': 3.0.10 + '@types/d3-format': 3.0.4 + '@types/d3-geo': 3.1.0 + '@types/d3-hierarchy': 3.1.7 + '@types/d3-interpolate': 3.0.4 + '@types/d3-path': 3.1.0 + '@types/d3-polygon': 3.0.2 + '@types/d3-quadtree': 3.0.6 + '@types/d3-random': 3.0.3 + '@types/d3-scale': 4.0.8 + '@types/d3-scale-chromatic': 3.0.3 + '@types/d3-selection': 3.0.11 + '@types/d3-shape': 3.1.6 + '@types/d3-time': 3.0.4 + '@types/d3-time-format': 4.0.3 + '@types/d3-timer': 3.0.2 + '@types/d3-transition': 3.0.9 + '@types/d3-zoom': 3.0.8 + '@types/debug@4.1.12': dependencies: '@types/ms': 0.7.34 '@types/doctrine@0.0.9': {} + '@types/dompurify@3.2.0': + dependencies: + dompurify: 3.1.6 + '@types/eslint-scope@3.7.7': dependencies: '@types/eslint': 9.6.1 @@ -11049,6 +11854,8 @@ snapshots: '@types/jsonfile': 6.1.4 '@types/node': 22.10.2 + '@types/geojson@7946.0.14': {} + '@types/hash-sum@1.0.2': {} '@types/hast@3.0.4': @@ -11128,6 +11935,8 @@ snapshots: '@types/range-parser@1.2.7': {} + '@types/raphael@2.3.9': {} + '@types/resolve@1.20.2': {} '@types/retry@0.12.2': {} @@ -11258,12 +12067,12 @@ snapshots: '@ungap/structured-clone@1.2.1': {} - '@vitejs/plugin-vue@5.2.1(vite@6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.4.5))(vue@3.5.13(typescript@5.7.2))': + '@vitejs/plugin-vue@5.2.1(vite@6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1))(vue@3.5.13(typescript@5.7.2))': dependencies: - vite: 6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.4.5) + vite: 6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1) vue: 3.5.13(typescript@5.7.2) - '@vitest/coverage-istanbul@3.0.0-beta.2(vitest@3.0.0-beta.2(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.4.5))': + '@vitest/coverage-istanbul@3.0.0-beta.2(vitest@3.0.0-beta.2(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1))': dependencies: '@istanbuljs/schema': 0.1.3 debug: 4.4.0 @@ -11275,7 +12084,7 @@ snapshots: magicast: 0.3.5 test-exclude: 7.0.1 tinyrainbow: 1.2.0 - vitest: 3.0.0-beta.2(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.4.5) + vitest: 3.0.0-beta.2(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1) transitivePeerDependencies: - supports-color @@ -11286,13 +12095,13 @@ snapshots: chai: 5.1.2 tinyrainbow: 1.2.0 - '@vitest/mocker@3.0.0-beta.2(vite@6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.4.5))': + '@vitest/mocker@3.0.0-beta.2(vite@6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1))': dependencies: '@vitest/spy': 3.0.0-beta.2 estree-walker: 3.0.3 magic-string: 0.30.17 optionalDependencies: - vite: 6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.4.5) + vite: 6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1) '@vitest/pretty-format@3.0.0-beta.2': dependencies: @@ -11397,9 +12206,9 @@ snapshots: '@vue/shared@3.5.13': {} - '@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5)': + '@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1)': dependencies: - '@vitejs/plugin-vue': 5.2.1(vite@6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.4.5))(vue@3.5.13(typescript@5.7.2)) + '@vitejs/plugin-vue': 5.2.1(vite@6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1))(vue@3.5.13(typescript@5.7.2)) '@vuepress/bundlerutils': 2.0.0-rc.19(typescript@5.7.2) '@vuepress/client': 2.0.0-rc.19(typescript@5.7.2) '@vuepress/core': 2.0.0-rc.19(typescript@5.7.2) @@ -11408,9 +12217,9 @@ snapshots: autoprefixer: 10.4.20(postcss@8.4.49) connect-history-api-fallback: 2.0.0 postcss: 8.4.49 - postcss-load-config: 6.0.1(jiti@2.4.2)(postcss@8.4.49)(tsx@4.19.2)(yaml@2.4.5) + postcss-load-config: 6.0.1(jiti@2.4.2)(postcss@8.4.49)(tsx@4.19.2)(yaml@2.6.1) rollup: 4.29.1 - vite: 6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.4.5) + vite: 6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1) vue: 3.5.13(typescript@5.7.2) vue-router: 4.5.0(vue@3.5.13(typescript@5.7.2)) transitivePeerDependencies: @@ -12030,6 +12839,10 @@ snapshots: chardet@0.7.0: {} + chart.js@4.4.6: + dependencies: + '@kurkle/color': 0.3.4 + check-error@2.1.1: {} cheerio-select@2.1.0: @@ -12055,6 +12868,30 @@ snapshots: undici: 6.21.0 whatwg-mimetype: 4.0.0 + cheerio@1.0.0-rc.12: + dependencies: + cheerio-select: 2.1.0 + dom-serializer: 2.0.0 + domhandler: 5.0.3 + domutils: 3.2.1 + htmlparser2: 8.0.2 + parse5: 7.2.1 + parse5-htmlparser2-tree-adapter: 7.1.0 + + chevrotain-allstar@0.3.1(chevrotain@11.0.3): + dependencies: + chevrotain: 11.0.3 + lodash-es: 4.17.21 + + chevrotain@11.0.3: + dependencies: + '@chevrotain/cst-dts-gen': 11.0.3 + '@chevrotain/gast': 11.0.3 + '@chevrotain/regexp-to-ast': 11.0.3 + '@chevrotain/types': 11.0.3 + '@chevrotain/utils': 11.0.3 + lodash-es: 4.17.21 + chokidar@3.6.0: dependencies: anymatch: 3.1.3 @@ -12167,6 +13004,8 @@ snapshots: concat-map@0.0.1: {} + confbox@0.1.8: {} + config-chain@1.1.13: dependencies: ini: 1.3.8 @@ -12342,6 +13181,14 @@ snapshots: corser@2.0.1: {} + cose-base@1.0.3: + dependencies: + layout-base: 1.0.2 + + cose-base@2.2.0: + dependencies: + layout-base: 2.0.1 + cosmiconfig-typescript-loader@6.1.0(@types/node@22.10.2)(cosmiconfig@9.0.0(typescript@5.7.2))(typescript@5.7.2): dependencies: '@types/node': 22.10.2 @@ -12505,6 +13352,196 @@ snapshots: csstype@3.1.3: {} + cytoscape-cose-bilkent@4.1.0(cytoscape@3.30.4): + dependencies: + cose-base: 1.0.3 + cytoscape: 3.30.4 + + cytoscape-fcose@2.2.0(cytoscape@3.30.4): + dependencies: + cose-base: 2.2.0 + cytoscape: 3.30.4 + + cytoscape@3.30.4: {} + + d3-array@2.12.1: + dependencies: + internmap: 1.0.1 + + d3-array@3.2.4: + dependencies: + internmap: 2.0.3 + + d3-axis@3.0.0: {} + + d3-brush@3.0.0: + dependencies: + d3-dispatch: 3.0.1 + d3-drag: 3.0.0 + d3-interpolate: 3.0.1 + d3-selection: 3.0.0 + d3-transition: 3.0.1(d3-selection@3.0.0) + + d3-chord@3.0.1: + dependencies: + d3-path: 3.1.0 + + d3-color@3.1.0: {} + + d3-contour@4.0.2: + dependencies: + d3-array: 3.2.4 + + d3-delaunay@6.0.4: + dependencies: + delaunator: 5.0.1 + + d3-dispatch@3.0.1: {} + + d3-drag@3.0.0: + dependencies: + d3-dispatch: 3.0.1 + d3-selection: 3.0.0 + + d3-dsv@3.0.1: + dependencies: + commander: 7.2.0 + iconv-lite: 0.6.3 + rw: 1.3.3 + + d3-ease@3.0.1: {} + + d3-fetch@3.0.1: + dependencies: + d3-dsv: 3.0.1 + + d3-flextree@2.1.2: + dependencies: + d3-hierarchy: 1.1.9 + + d3-force@3.0.0: + dependencies: + d3-dispatch: 3.0.1 + d3-quadtree: 3.0.1 + d3-timer: 3.0.1 + + d3-format@3.1.0: {} + + d3-geo@3.1.1: + dependencies: + d3-array: 3.2.4 + + d3-hierarchy@1.1.9: {} + + d3-hierarchy@3.1.2: {} + + d3-interpolate@3.0.1: + dependencies: + d3-color: 3.1.0 + + d3-path@1.0.9: {} + + d3-path@3.1.0: {} + + d3-polygon@3.0.1: {} + + d3-quadtree@3.0.1: {} + + d3-random@3.0.1: {} + + d3-sankey@0.12.3: + dependencies: + d3-array: 2.12.1 + d3-shape: 1.3.7 + + d3-scale-chromatic@3.1.0: + dependencies: + d3-color: 3.1.0 + d3-interpolate: 3.0.1 + + d3-scale@4.0.2: + dependencies: + d3-array: 3.2.4 + d3-format: 3.1.0 + d3-interpolate: 3.0.1 + d3-time: 3.1.0 + d3-time-format: 4.1.0 + + d3-selection@3.0.0: {} + + d3-shape@1.3.7: + dependencies: + d3-path: 1.0.9 + + d3-shape@3.2.0: + dependencies: + d3-path: 3.1.0 + + d3-time-format@4.1.0: + dependencies: + d3-time: 3.1.0 + + d3-time@3.1.0: + dependencies: + d3-array: 3.2.4 + + d3-timer@3.0.1: {} + + d3-transition@3.0.1(d3-selection@3.0.0): + dependencies: + d3-color: 3.1.0 + d3-dispatch: 3.0.1 + d3-ease: 3.0.1 + d3-interpolate: 3.0.1 + d3-selection: 3.0.0 + d3-timer: 3.0.1 + + d3-zoom@3.0.0: + dependencies: + d3-dispatch: 3.0.1 + d3-drag: 3.0.0 + d3-interpolate: 3.0.1 + d3-selection: 3.0.0 + d3-transition: 3.0.1(d3-selection@3.0.0) + + d3@7.9.0: + dependencies: + d3-array: 3.2.4 + d3-axis: 3.0.0 + d3-brush: 3.0.0 + d3-chord: 3.0.1 + d3-color: 3.1.0 + d3-contour: 4.0.2 + d3-delaunay: 6.0.4 + d3-dispatch: 3.0.1 + d3-drag: 3.0.0 + d3-dsv: 3.0.1 + d3-ease: 3.0.1 + d3-fetch: 3.0.1 + d3-force: 3.0.0 + d3-format: 3.1.0 + d3-geo: 3.1.1 + d3-hierarchy: 3.1.2 + d3-interpolate: 3.0.1 + d3-path: 3.1.0 + d3-polygon: 3.0.1 + d3-quadtree: 3.0.1 + d3-random: 3.0.1 + d3-scale: 4.0.2 + d3-scale-chromatic: 3.1.0 + d3-selection: 3.0.0 + d3-shape: 3.2.0 + d3-time: 3.1.0 + d3-time-format: 4.1.0 + d3-timer: 3.0.1 + d3-transition: 3.0.1(d3-selection@3.0.0) + d3-zoom: 3.0.0 + + dagre-d3-es@7.0.11: + dependencies: + d3: 7.9.0 + lodash-es: 4.17.21 + dargs@8.1.0: {} data-uri-to-buffer@4.0.1: {} @@ -12527,6 +13564,8 @@ snapshots: es-errors: 1.3.0 is-data-view: 1.0.2 + dayjs@1.11.13: {} + debounce@2.2.0: {} debug@2.6.9: @@ -12578,6 +13617,10 @@ snapshots: has-property-descriptors: 1.0.2 object-keys: 1.1.1 + delaunator@5.0.1: + dependencies: + robust-predicates: 3.0.2 + depd@1.1.2: {} depd@2.0.0: {} @@ -12636,6 +13679,8 @@ snapshots: dependencies: domelementtype: 2.3.0 + dompurify@3.1.6: {} + domutils@2.8.0: dependencies: dom-serializer: 1.4.1 @@ -12669,6 +13714,11 @@ snapshots: eastasianwidth@0.2.0: {} + echarts@5.5.1: + dependencies: + tslib: 2.3.0 + zrender: 5.6.0 + ee-first@1.1.1: {} ejs@3.1.10: @@ -13062,6 +14112,8 @@ snapshots: etag@1.8.1: {} + eve-raphael@0.5.0: {} + eventemitter3@4.0.7: {} eventemitter3@5.0.1: {} @@ -13253,6 +14305,12 @@ snapshots: flatted@3.3.2: {} + flowchart.ts@3.0.1: + dependencies: + '@types/raphael': 2.3.9 + raphael: 2.3.0 + tslib: 2.8.1 + follow-redirects@1.15.9: {} for-each@0.3.3: @@ -13501,6 +14559,8 @@ snapshots: section-matter: 1.0.0 strip-bom-string: 1.0.0 + hachure-fill@0.5.2: {} + handle-thing@2.0.1: {} handlebars@4.7.8: @@ -13558,6 +14618,8 @@ snapshots: he@1.2.0: {} + highlight.js@11.10.0: {} + hookable@5.5.3: {} hosted-git-info@7.0.2: @@ -13767,6 +14829,10 @@ snapshots: hasown: 2.0.2 side-channel: 1.1.0 + internmap@1.0.1: {} + + internmap@2.0.3: {} + ip-address@9.0.5: dependencies: jsbn: 1.1.0 @@ -14096,6 +15162,14 @@ snapshots: just-diff@6.0.2: {} + katex@0.12.0: + dependencies: + commander: 2.20.3 + + katex@0.16.11: + dependencies: + commander: 8.3.0 + katex@0.16.18: dependencies: commander: 8.3.0 @@ -14104,15 +15178,31 @@ snapshots: dependencies: json-buffer: 3.0.1 + khroma@2.1.0: {} + kind-of@6.0.3: {} known-css-properties@0.35.0: {} + kolorist@1.8.0: {} + + langium@3.0.0: + dependencies: + chevrotain: 11.0.3 + chevrotain-allstar: 0.3.1(chevrotain@11.0.3) + vscode-languageserver: 9.0.1 + vscode-languageserver-textdocument: 1.0.12 + vscode-uri: 3.0.8 + launch-editor@2.9.1: dependencies: picocolors: 1.1.1 shell-quote: 1.8.2 + layout-base@1.0.2: {} + + layout-base@2.0.1: {} + leven@3.1.0: {} levn@0.4.1: @@ -14221,6 +15311,11 @@ snapshots: emojis-list: 3.0.0 json5: 2.2.3 + local-pkg@0.5.1: + dependencies: + mlly: 1.7.3 + pkg-types: 1.2.1 + locate-path@5.0.0: dependencies: p-locate: 4.1.0 @@ -14233,6 +15328,8 @@ snapshots: dependencies: p-locate: 6.0.0 + lodash-es@4.17.21: {} + lodash.camelcase@4.3.0: {} lodash.debounce@4.0.8: {} @@ -14326,6 +15423,14 @@ snapshots: markdown-it-emoji@3.0.0: {} + markdown-it-ins@4.0.0: {} + + markdown-it-mark@4.0.0: {} + + markdown-it-sub@2.0.0: {} + + markdown-it-sup@2.0.0: {} + markdown-it@14.1.0: dependencies: argparse: 2.0.1 @@ -14339,8 +15444,54 @@ snapshots: dependencies: marked: 15.0.4 + marked@13.0.3: {} + marked@15.0.4: {} + markmap-common@0.17.1: + dependencies: + '@babel/runtime': 7.26.0 + '@gera2ld/jsx-dom': 2.2.2 + npm2url: 0.2.4 + + markmap-html-parser@0.17.1(markmap-common@0.17.1): + dependencies: + '@babel/runtime': 7.26.0 + cheerio: 1.0.0-rc.12 + markmap-common: 0.17.1 + + markmap-lib@0.17.2(markmap-common@0.17.1): + dependencies: + '@babel/runtime': 7.26.0 + '@iktakahiro/markdown-it-katex': 4.0.1 + highlight.js: 11.10.0 + katex: 0.16.11 + markdown-it: 14.1.0 + markdown-it-ins: 4.0.0 + markdown-it-mark: 4.0.0 + markdown-it-sub: 2.0.0 + markdown-it-sup: 2.0.0 + markmap-common: 0.17.1 + markmap-html-parser: 0.17.1(markmap-common@0.17.1) + markmap-view: 0.17.2(markmap-common@0.17.1) + prismjs: 1.29.0 + yaml: 2.6.1 + + markmap-toolbar@0.17.2(markmap-common@0.17.1): + dependencies: + '@babel/runtime': 7.26.0 + '@gera2ld/jsx-dom': 2.2.2 + markmap-common: 0.17.1 + + markmap-view@0.17.2(markmap-common@0.17.1): + dependencies: + '@babel/runtime': 7.26.0 + '@gera2ld/jsx-dom': 2.2.2 + '@types/d3': 7.4.3 + d3: 7.9.0 + d3-flextree: 2.1.2 + markmap-common: 0.17.1 + math-intrinsics@1.1.0: {} mathjax-full@3.2.2: @@ -14407,6 +15558,32 @@ snapshots: merge2@1.4.1: {} + mermaid@11.4.0: + dependencies: + '@braintree/sanitize-url': 7.1.0 + '@iconify/utils': 2.1.33 + '@mermaid-js/parser': 0.3.0 + '@types/d3': 7.4.3 + '@types/dompurify': 3.2.0 + cytoscape: 3.30.4 + cytoscape-cose-bilkent: 4.1.0(cytoscape@3.30.4) + cytoscape-fcose: 2.2.0(cytoscape@3.30.4) + d3: 7.9.0 + d3-sankey: 0.12.3 + dagre-d3-es: 7.0.11 + dayjs: 1.11.13 + dompurify: 3.1.6 + katex: 0.16.11 + khroma: 2.1.0 + lodash-es: 4.17.21 + marked: 13.0.3 + roughjs: 4.6.6 + stylis: 4.3.4 + ts-dedent: 2.2.0 + uuid: 9.0.1 + transitivePeerDependencies: + - supports-color + methods@1.1.2: {} mhchemparser@4.2.1: {} @@ -14527,6 +15704,13 @@ snapshots: mkdirp@1.0.4: {} + mlly@1.7.3: + dependencies: + acorn: 8.14.0 + pathe: 1.1.2 + pkg-types: 1.2.1 + ufo: 1.5.4 + ms@2.0.0: {} ms@2.1.3: {} @@ -14663,6 +15847,8 @@ snapshots: path-key: 4.0.0 unicorn-magic: 0.3.0 + npm2url@0.2.4: {} + nth-check@2.1.1: dependencies: boolbase: 1.0.0 @@ -14793,6 +15979,8 @@ snapshots: package-json-from-dist@1.0.1: {} + package-manager-detector@0.2.5: {} + pacote@18.0.6: dependencies: '@npmcli/git': 5.0.8 @@ -14892,6 +16080,8 @@ snapshots: no-case: 3.0.4 tslib: 2.8.1 + path-data-parser@0.1.0: {} + path-exists@4.0.0: {} path-exists@5.0.0: {} @@ -14940,6 +16130,12 @@ snapshots: dependencies: find-up: 4.1.0 + pkg-types@1.2.1: + dependencies: + confbox: 0.1.8 + mlly: 1.7.3 + pathe: 1.1.2 + playwright-core@1.49.1: {} playwright@1.49.1: @@ -14948,6 +16144,13 @@ snapshots: optionalDependencies: fsevents: 2.3.2 + points-on-curve@0.2.0: {} + + points-on-path@0.2.1: + dependencies: + path-data-parser: 0.1.0 + points-on-curve: 0.2.0 + portfinder@1.0.32: dependencies: async: 2.6.4 @@ -15002,14 +16205,14 @@ snapshots: postcss: 8.4.49 postcss-safe-parser: 6.0.0(postcss@8.4.49) - postcss-load-config@6.0.1(jiti@2.4.2)(postcss@8.4.49)(tsx@4.19.2)(yaml@2.4.5): + postcss-load-config@6.0.1(jiti@2.4.2)(postcss@8.4.49)(tsx@4.19.2)(yaml@2.6.1): dependencies: lilconfig: 3.1.3 optionalDependencies: jiti: 2.4.2 postcss: 8.4.49 tsx: 4.19.2 - yaml: 2.4.5 + yaml: 2.6.1 postcss-loader@8.1.1(postcss@8.4.49)(typescript@5.7.2)(webpack@5.97.1(esbuild@0.24.2)): dependencies: @@ -15262,6 +16465,10 @@ snapshots: range-parser@1.2.1: {} + raphael@2.3.0: + dependencies: + eve-raphael: 0.5.0 + raw-body@2.5.2: dependencies: bytes: 3.1.2 @@ -15436,6 +16643,8 @@ snapshots: glob: 11.0.0 package-json-from-dist: 1.0.1 + robust-predicates@3.0.2: {} + rollup-plugin-dts@6.1.1(rollup@4.29.1)(typescript@5.7.2): dependencies: magic-string: 0.30.17 @@ -15489,12 +16698,21 @@ snapshots: '@rollup/rollup-win32-x64-msvc': 4.29.1 fsevents: 2.3.3 + roughjs@4.6.6: + dependencies: + hachure-fill: 0.5.2 + path-data-parser: 0.1.0 + points-on-curve: 0.2.0 + points-on-path: 0.2.1 + run-applescript@7.0.0: {} run-parallel@1.2.0: dependencies: queue-microtask: 1.2.3 + rw@1.3.3: {} + rxjs@7.8.1: dependencies: tslib: 2.8.1 @@ -16149,6 +17367,8 @@ snapshots: - supports-color - typescript + stylis@4.3.4: {} + subarg@1.0.0: dependencies: minimist: 1.2.8 @@ -16301,8 +17521,12 @@ snapshots: ts-debounce@4.0.0: {} + ts-dedent@2.2.0: {} + tsconfig-vuepress@5.2.1: {} + tslib@2.3.0: {} + tslib@2.8.1: {} tsx@4.19.2: @@ -16380,6 +17604,8 @@ snapshots: uc.micro@2.1.0: {} + ufo@1.5.4: {} + uglify-js@3.19.3: optional: true @@ -16484,6 +17710,8 @@ snapshots: uuid@8.3.2: {} + uuid@9.0.1: {} + validate-npm-package-license@3.0.4: dependencies: spdx-correct: 3.2.0 @@ -16505,13 +17733,13 @@ snapshots: '@types/unist': 3.0.3 vfile-message: 4.0.2 - vite-node@3.0.0-beta.2(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.4.5): + vite-node@3.0.0-beta.2(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1): dependencies: cac: 6.7.14 debug: 4.4.0 es-module-lexer: 1.5.4 pathe: 1.1.2 - vite: 6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.4.5) + vite: 6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1) transitivePeerDependencies: - '@types/node' - jiti @@ -16526,7 +17754,7 @@ snapshots: - tsx - yaml - vite@6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.4.5): + vite@6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1): dependencies: esbuild: 0.24.0 postcss: 8.4.49 @@ -16540,12 +17768,12 @@ snapshots: sass-embedded: 1.83.0 terser: 5.37.0 tsx: 4.19.2 - yaml: 2.4.5 + yaml: 2.6.1 - vitest@3.0.0-beta.2(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.4.5): + vitest@3.0.0-beta.2(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1): dependencies: '@vitest/expect': 3.0.0-beta.2 - '@vitest/mocker': 3.0.0-beta.2(vite@6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.4.5)) + '@vitest/mocker': 3.0.0-beta.2(vite@6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1)) '@vitest/pretty-format': 3.0.0-beta.3 '@vitest/runner': 3.0.0-beta.2 '@vitest/snapshot': 3.0.0-beta.2 @@ -16561,8 +17789,8 @@ snapshots: tinyexec: 0.3.1 tinypool: 1.0.2 tinyrainbow: 1.2.0 - vite: 6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.4.5) - vite-node: 3.0.0-beta.2(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.4.5) + vite: 6.0.5(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1) + vite-node: 3.0.0-beta.2(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1) why-is-node-running: 2.3.0 optionalDependencies: '@types/node': 22.10.2 @@ -16580,6 +17808,23 @@ snapshots: - tsx - yaml + vscode-jsonrpc@8.2.0: {} + + vscode-languageserver-protocol@3.17.5: + dependencies: + vscode-jsonrpc: 8.2.0 + vscode-languageserver-types: 3.17.5 + + vscode-languageserver-textdocument@1.0.12: {} + + vscode-languageserver-types@3.17.5: {} + + vscode-languageserver@9.0.1: + dependencies: + vscode-languageserver-protocol: 3.17.5 + + vscode-uri@3.0.8: {} + vue-eslint-parser@9.4.3(eslint@9.17.0(jiti@2.4.2)): dependencies: debug: 4.4.0 @@ -16617,7 +17862,7 @@ snapshots: optionalDependencies: typescript: 5.7.2 - vuepress@2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)): + vuepress@2.0.0-rc.19(@vuepress/bundler-vite@2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1))(@vuepress/bundler-webpack@2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2))(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2)): dependencies: '@vuepress/cli': 2.0.0-rc.19(typescript@5.7.2) '@vuepress/client': 2.0.0-rc.19(typescript@5.7.2) @@ -16627,7 +17872,7 @@ snapshots: '@vuepress/utils': 2.0.0-rc.19 vue: 3.5.13(typescript@5.7.2) optionalDependencies: - '@vuepress/bundler-vite': 2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.4.5) + '@vuepress/bundler-vite': 2.0.0-rc.19(@types/node@22.10.2)(jiti@2.4.2)(lightningcss@1.28.2)(sass-embedded@1.83.0)(sass@1.83.0)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(yaml@2.6.1) '@vuepress/bundler-webpack': 2.0.0-rc.19(esbuild@0.24.2)(typescript@5.7.2) transitivePeerDependencies: - supports-color @@ -17012,8 +18257,7 @@ snapshots: yallist@4.0.0: {} - yaml@2.4.5: - optional: true + yaml@2.6.1: {} yargs-parser@21.1.1: {} @@ -17035,4 +18279,8 @@ snapshots: yoctocolors@2.1.1: {} + zrender@5.6.0: + dependencies: + tslib: 2.3.0 + zwitch@2.0.4: {} diff --git a/tsconfig.build.json b/tsconfig.build.json index 4315e4adbc..9ff2925904 100644 --- a/tsconfig.build.json +++ b/tsconfig.build.json @@ -41,6 +41,7 @@ // markdown { "path": "./plugins/markdown/plugin-append-date/tsconfig.build.json" }, { "path": "./plugins/markdown/plugin-links-check/tsconfig.build.json" }, + { "path": "./plugins/markdown/plugin-markdown-chart/tsconfig.build.json" }, { "path": "./plugins/markdown/plugin-markdown-container/tsconfig.build.json" },