mirror of
https://github.com/mermaid-js/mermaid.git
synced 2025-10-24 16:34:09 +02:00
Compare commits
3 Commits
e12036ed6c
...
sidv/refac
Author | SHA1 | Date | |
---|---|---|---|
![]() |
e1a71296fe | ||
![]() |
3f21f59f55 | ||
![]() |
76557a628f |
@@ -1,3 +1,9 @@
|
|||||||
|
export interface PackageOptions {
|
||||||
|
name: string;
|
||||||
|
packageName: string;
|
||||||
|
file: string;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Shared common options for both ESBuild and Vite
|
* Shared common options for both ESBuild and Vite
|
||||||
*/
|
*/
|
||||||
@@ -27,4 +33,4 @@ export const packageOptions = {
|
|||||||
packageName: 'mermaid-layout-elk',
|
packageName: 'mermaid-layout-elk',
|
||||||
file: 'layouts.ts',
|
file: 'layouts.ts',
|
||||||
},
|
},
|
||||||
} as const;
|
} as const satisfies Record<string, PackageOptions>;
|
||||||
|
@@ -8,7 +8,10 @@ import { defaultOptions, getBuildConfig } from './util.js';
|
|||||||
const shouldVisualize = process.argv.includes('--visualize');
|
const shouldVisualize = process.argv.includes('--visualize');
|
||||||
|
|
||||||
const buildPackage = async (entryName: keyof typeof packageOptions) => {
|
const buildPackage = async (entryName: keyof typeof packageOptions) => {
|
||||||
const commonOptions: MermaidBuildOptions = { ...defaultOptions, entryName } as const;
|
const commonOptions: MermaidBuildOptions = {
|
||||||
|
...defaultOptions,
|
||||||
|
options: packageOptions[entryName],
|
||||||
|
} as const;
|
||||||
const buildConfigs: MermaidBuildOptions[] = [
|
const buildConfigs: MermaidBuildOptions[] = [
|
||||||
// package.mjs
|
// package.mjs
|
||||||
{ ...commonOptions },
|
{ ...commonOptions },
|
||||||
@@ -40,7 +43,7 @@ const buildPackage = async (entryName: keyof typeof packageOptions) => {
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
const fileName = Object.keys(metafile.outputs)
|
const fileName = Object.keys(metafile.outputs)
|
||||||
.find((file) => !file.includes('chunks') && file.endsWith('js'))
|
.find((file) => !file.includes('chunks') && file.endsWith('js'))!
|
||||||
.replace('dist/', '');
|
.replace('dist/', '');
|
||||||
// Upload metafile into https://esbuild.github.io/analyze/
|
// Upload metafile into https://esbuild.github.io/analyze/
|
||||||
await writeFile(`stats/${fileName}.meta.json`, JSON.stringify(metafile));
|
await writeFile(`stats/${fileName}.meta.json`, JSON.stringify(metafile));
|
||||||
|
34
.esbuild/docs.ts
Normal file
34
.esbuild/docs.ts
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
import { execFileSync } from 'child_process';
|
||||||
|
import { build } from 'esbuild';
|
||||||
|
import { rm } from 'fs/promises';
|
||||||
|
import { generateLangium } from '../.build/generateLangium.js';
|
||||||
|
import type { MermaidBuildOptions } from './util.js';
|
||||||
|
import { defaultOptions, getBuildConfig } from './util.js';
|
||||||
|
|
||||||
|
const buildDocs = async () => {
|
||||||
|
const option: MermaidBuildOptions = {
|
||||||
|
...defaultOptions,
|
||||||
|
options: {
|
||||||
|
file: 'rendering-util/rendering-elements/shapes.cli.ts',
|
||||||
|
name: 'mermaid-shapes',
|
||||||
|
packageName: 'mermaid',
|
||||||
|
},
|
||||||
|
} as const;
|
||||||
|
|
||||||
|
await build({ ...getBuildConfig(option), splitting: false, sourcemap: false });
|
||||||
|
};
|
||||||
|
|
||||||
|
const handler = (e) => {
|
||||||
|
// eslint-disable-next-line no-console
|
||||||
|
console.error(e);
|
||||||
|
process.exit(1);
|
||||||
|
};
|
||||||
|
|
||||||
|
const main = async () => {
|
||||||
|
await generateLangium();
|
||||||
|
await buildDocs().catch(handler);
|
||||||
|
execFileSync('node', ['packages/mermaid/dist/mermaid-shapes.esm.mjs']);
|
||||||
|
await rm('packages/mermaid/dist/mermaid-shapes.esm.mjs');
|
||||||
|
};
|
||||||
|
|
||||||
|
void main();
|
@@ -3,7 +3,7 @@ import { fileURLToPath } from 'url';
|
|||||||
import type { BuildOptions } from 'esbuild';
|
import type { BuildOptions } from 'esbuild';
|
||||||
import { readFileSync } from 'fs';
|
import { readFileSync } from 'fs';
|
||||||
import jsonSchemaPlugin from './jsonSchemaPlugin.js';
|
import jsonSchemaPlugin from './jsonSchemaPlugin.js';
|
||||||
import { packageOptions } from '../.build/common.js';
|
import type { PackageOptions } from '../.build/common.js';
|
||||||
import { jisonPlugin } from './jisonPlugin.js';
|
import { jisonPlugin } from './jisonPlugin.js';
|
||||||
|
|
||||||
const __dirname = fileURLToPath(new URL('.', import.meta.url));
|
const __dirname = fileURLToPath(new URL('.', import.meta.url));
|
||||||
@@ -13,10 +13,10 @@ export interface MermaidBuildOptions extends BuildOptions {
|
|||||||
core: boolean;
|
core: boolean;
|
||||||
metafile: boolean;
|
metafile: boolean;
|
||||||
format: 'esm' | 'iife';
|
format: 'esm' | 'iife';
|
||||||
entryName: keyof typeof packageOptions;
|
options: PackageOptions;
|
||||||
}
|
}
|
||||||
|
|
||||||
export const defaultOptions: Omit<MermaidBuildOptions, 'entryName'> = {
|
export const defaultOptions: Omit<MermaidBuildOptions, 'entryName' | 'options'> = {
|
||||||
minify: false,
|
minify: false,
|
||||||
metafile: false,
|
metafile: false,
|
||||||
core: false,
|
core: false,
|
||||||
@@ -52,9 +52,14 @@ const getFileName = (fileName: string, { core, format, minify }: MermaidBuildOpt
|
|||||||
};
|
};
|
||||||
|
|
||||||
export const getBuildConfig = (options: MermaidBuildOptions): BuildOptions => {
|
export const getBuildConfig = (options: MermaidBuildOptions): BuildOptions => {
|
||||||
const { core, entryName, metafile, format, minify } = options;
|
const {
|
||||||
|
core,
|
||||||
|
metafile,
|
||||||
|
format,
|
||||||
|
minify,
|
||||||
|
options: { name, file, packageName },
|
||||||
|
} = options;
|
||||||
const external: string[] = ['require', 'fs', 'path'];
|
const external: string[] = ['require', 'fs', 'path'];
|
||||||
const { name, file, packageName } = packageOptions[entryName];
|
|
||||||
const outFileName = getFileName(name, options);
|
const outFileName = getFileName(name, options);
|
||||||
const output: BuildOptions = buildOptions({
|
const output: BuildOptions = buildOptions({
|
||||||
absWorkingDir: resolve(__dirname, `../packages/${packageName}`),
|
absWorkingDir: resolve(__dirname, `../packages/${packageName}`),
|
||||||
|
@@ -316,53 +316,55 @@ This syntax creates a node A as a rectangle. It renders in the same way as `A["A
|
|||||||
|
|
||||||
Below is a comprehensive list of the newly introduced shapes and their corresponding semantic meanings, short names, and aliases:
|
Below is a comprehensive list of the newly introduced shapes and their corresponding semantic meanings, short names, and aliases:
|
||||||
|
|
||||||
|
<!-- Will be auto generated with `pnpm --filter mermaid docs:shapes` -->
|
||||||
|
|
||||||
| **Semantic Name** | **Shape Name** | **Short Name** | **Description** | **Alias Supported** |
|
| **Semantic Name** | **Shape Name** | **Short Name** | **Description** | **Alias Supported** |
|
||||||
| ------------------------------------- | ---------------------- | -------------- | ------------------------------ | -------------------------------------------------------------- |
|
| --------------------------------- | ---------------------- | -------------- | ------------------------------ | ---------------------------------------------------------------- |
|
||||||
| **Process** | Rectangle | `rect` | Standard process shape | `proc`, `process`, `rectangle` |
|
| Card | Notched Rectangle | `notch-rect` | Represents a card | `card`, `notched-rectangle` |
|
||||||
| **Event** | Rounded Rectangle | `rounded` | Represents an event | `event` |
|
| Collate | Hourglass | `hourglass` | Represents a collate operation | `collate`, `hourglass` |
|
||||||
| **Terminal Point** | Stadium | `stadium` | Terminal point | `terminal`, `pill` |
|
| Com Link | Lightning Bolt | `bolt` | Communication link | `com-link`, `lightning-bolt` |
|
||||||
| **Subprocess** | Framed Rectangle | `fr-rect` | Subprocess | `subprocess`,`subproc`, `framed-rectangle`, `subroutine` |
|
| Comment | Curly Brace | `brace` | Adds a comment | `brace-l`, `comment` |
|
||||||
| **Database** | Cylinder | `cyl` | Database storage | `db`, `database`, `cylinder` |
|
| Comment Right | Curly Brace | `brace-r` | Adds a comment | |
|
||||||
| **Start** | Circle | `circle` | Starting point | `circ` |
|
| Comment with braces on both sides | Curly Braces | `braces` | Adds a comment | |
|
||||||
| **Odd** | Odd | `odd` | Odd shape | |
|
| Data Input/Output | Lean Right | `lean-r` | Represents input or output | `in-out`, `lean-right` |
|
||||||
| **Decision** | Diamond | `diam` | Decision-making step | `decision`, `diamond` |
|
| Data Input/Output | Lean Left | `lean-l` | Represents output or input | `lean-left`, `out-in` |
|
||||||
| **Prepare Conditional** | Hexagon | `hex` | Preparation or condition step | `hexagon`, `prepare` |
|
| Database | Cylinder | `cyl` | Database storage | `cylinder`, `database`, `db` |
|
||||||
| **Data Input/Output** | Lean Right | `lean-r` | Represents input or output | `lean-right`, `in-out` |
|
| Decision | Diamond | `diam` | Decision-making step | `decision`, `diamond`, `question` |
|
||||||
| **Data Input/Output** | Lean Left | `lean-l` | Represents output or input | `lean-left`, `out-in` |
|
| Delay | Half-Rounded Rectangle | `delay` | Represents a delay | `half-rounded-rectangle` |
|
||||||
| **Priority Action** | Trapezoid Base Bottom | `trap-b` | Priority action | `priority`, `trapezoid-bottom` |
|
| Direct Access Storage | Horizontal Cylinder | `h-cyl` | Direct access storage | `das`, `horizontal-cylinder` |
|
||||||
| **Manual Operation** | Trapezoid Base Top | `trap-t` | Represents a manual task | `manual`, `trapezoid-top` |
|
| Disk Storage | Lined Cylinder | `lin-cyl` | Disk storage | `disk`, `lined-cylinder` |
|
||||||
| **Stop** | Double Circle | `dbl-circ` | Represents a stop point | `double-circle` |
|
| Display | Curved Trapezoid | `curv-trap` | Represents a display | `curved-trapezoid`, `display` |
|
||||||
| **Text Block** | Text Block | `text` | Text block | - |
|
| Divided Process | Divided Rectangle | `div-rect` | Divided process shape | `div-proc`, `divided-process`, `divided-rectangle` |
|
||||||
| **Card** | Notched Rectangle | `notch-rect` | Represents a card | `card`, `notched-rectangle` |
|
| Document | Document | `doc` | Represents a document | `doc`, `document` |
|
||||||
| **Lined/Shaded Process** | Lined Rectangle | `lin-rect` | Lined process shape | `lined-rectangle`,`lined-process`, `lin-proc`,`shaded-process` |
|
| Event | Rounded Rectangle | `rounded` | Represents an event | `event` |
|
||||||
| **Start** | Small Circle | `sm-circ` | Small starting point | `start`, `small-circle` |
|
| Extract | Triangle | `tri` | Extraction process | `extract`, `triangle` |
|
||||||
| **Stop** | Framed Circle | `fr-circ` | Stop point | `stop`, `framed-circle` |
|
| Fork/Join | Filled Rectangle | `fork` | Fork or join in process flow | `join` |
|
||||||
| **Fork/Join** | Filled Rectangle | `fork` | Fork or join in process flow | `join` |
|
| Internal Storage | Window Pane | `win-pane` | Internal storage | `internal-storage`, `window-pane` |
|
||||||
| **Collate** | Hourglass | `hourglass` | Represents a collate operation | `hourglass` |
|
| Junction | Filled Circle | `f-circ` | Junction point | `filled-circle`, `junction` |
|
||||||
| **Comment** | Curly Brace | `brace` | Adds a comment | `comment`, `brace-l` |
|
| Lined Document | Lined Document | `lin-doc` | Lined document | `lined-document` |
|
||||||
| **Comment Right** | Curly Brace | `brace-r` | Adds a comment | - |
|
| Lined/Shaded Process | Lined Rectangle | `lin-rect` | Lined process shape | `lin-proc`, `lined-process`, `lined-rectangle`, `shaded-process` |
|
||||||
| **Comment with braces on both sides** | Curly Braces | `braces` | Adds a comment | - |
|
| Loop Limit | Trapezoidal Pentagon | `notch-pent` | Loop limit step | `loop-limit`, `notched-pentagon` |
|
||||||
| **Com Link** | Lightning Bolt | `bolt` | Communication link | `com-link`, `lightning-bolt` |
|
| Manual File | Flipped Triangle | `flip-tri` | Manual file operation | `flipped-triangle`, `manual-file` |
|
||||||
| **Document** | Document | `doc` | Represents a document | `doc`, `document` |
|
| Manual Input | Sloped Rectangle | `sl-rect` | Manual input step | `manual-input`, `sloped-rectangle` |
|
||||||
| **Delay** | Half-Rounded Rectangle | `delay` | Represents a delay | `half-rounded-rectangle` |
|
| Manual Operation | Trapezoid Base Top | `trap-t` | Represents a manual task | `inv-trapezoid`, `manual`, `trapezoid-top` |
|
||||||
| **Direct Access Storage** | Horizontal Cylinder | `h-cyl` | Direct access storage | `das`, `horizontal-cylinder` |
|
| Multi-Document | Stacked Document | `docs` | Multiple documents | `documents`, `st-doc`, `stacked-document` |
|
||||||
| **Disk Storage** | Lined Cylinder | `lin-cyl` | Disk storage | `disk`, `lined-cylinder` |
|
| Multi-Process | Stacked Rectangle | `st-rect` | Multiple processes | `processes`, `procs`, `stacked-rectangle` |
|
||||||
| **Display** | Curved Trapezoid | `curv-trap` | Represents a display | `curved-trapezoid`, `display` |
|
| Odd | Odd | `odd` | Odd shape | |
|
||||||
| **Divided Process** | Divided Rectangle | `div-rect` | Divided process shape | `div-proc`, `divided-rectangle`, `divided-process` |
|
| Paper Tape | Flag | `flag` | Paper tape | `paper-tape` |
|
||||||
| **Extract** | Triangle | `tri` | Extraction process | `extract`, `triangle` |
|
| Prepare Conditional | Hexagon | `hex` | Preparation or condition step | `hexagon`, `prepare` |
|
||||||
| **Internal Storage** | Window Pane | `win-pane` | Internal storage | `internal-storage`, `window-pane` |
|
| Priority Action | Trapezoid Base Bottom | `trap-b` | Priority action | `priority`, `trapezoid`, `trapezoid-bottom` |
|
||||||
| **Junction** | Filled Circle | `f-circ` | Junction point | `junction`, `filled-circle` |
|
| Process | Rectangle | `rect` | Standard process shape | `proc`, `process`, `rectangle` |
|
||||||
| **Lined Document** | Lined Document | `lin-doc` | Lined document | `lined-document` |
|
| Start | Circle | `circle` | Starting point | `circ` |
|
||||||
| **Loop Limit** | Trapezoidal Pentagon | `notch-pent` | Loop limit step | `loop-limit`, `notched-pentagon` |
|
| Start | Small Circle | `sm-circ` | Small starting point | `small-circle`, `start` |
|
||||||
| **Manual File** | Flipped Triangle | `flip-tri` | Manual file operation | `manual-file`, `flipped-triangle` |
|
| Stop | Double Circle | `dbl-circ` | Represents a stop point | `double-circle` |
|
||||||
| **Manual Input** | Sloped Rectangle | `sl-rect` | Manual input step | `manual-input`, `sloped-rectangle` |
|
| Stop | Framed Circle | `fr-circ` | Stop point | `framed-circle`, `stop` |
|
||||||
| **Multi-Document** | Stacked Document | `docs` | Multiple documents | `documents`, `st-doc`, `stacked-document` |
|
| Stored Data | Bow Tie Rectangle | `bow-rect` | Stored data | `bow-tie-rectangle`, `stored-data` |
|
||||||
| **Multi-Process** | Stacked Rectangle | `st-rect` | Multiple processes | `procs`, `processes`, `stacked-rectangle` |
|
| Subprocess | Framed Rectangle | `fr-rect` | Subprocess | `framed-rectangle`, `subproc`, `subprocess`, `subroutine` |
|
||||||
| **Paper Tape** | Flag | `flag` | Paper tape | `paper-tape` |
|
| Summary | Crossed Circle | `cross-circ` | Summary | `crossed-circle`, `summary` |
|
||||||
| **Stored Data** | Bow Tie Rectangle | `bow-rect` | Stored data | `stored-data`, `bow-tie-rectangle` |
|
| Tagged Document | Tagged Document | `tag-doc` | Tagged document | `tag-doc`, `tagged-document` |
|
||||||
| **Summary** | Crossed Circle | `cross-circ` | Summary | `summary`, `crossed-circle` |
|
| Tagged Process | Tagged Rectangle | `tag-rect` | Tagged process | `tag-proc`, `tagged-process`, `tagged-rectangle` |
|
||||||
| **Tagged Document** | Tagged Document | `tag-doc` | Tagged document | `tag-doc`, `tagged-document` |
|
| Terminal Point | Stadium | `stadium` | Terminal point | `pill`, `terminal` |
|
||||||
| **Tagged Process** | Tagged Rectangle | `tag-rect` | Tagged process | `tagged-rectangle`,`tag-proc`, `tagged-process` |
|
| Text Block | Text Block | `text` | Text block | |
|
||||||
|
|
||||||
### Example Flowchart with New Shapes
|
### Example Flowchart with New Shapes
|
||||||
|
|
||||||
|
1
packages/mermaid/.gitignore
vendored
1
packages/mermaid/.gitignore
vendored
@@ -4,3 +4,4 @@ README.*
|
|||||||
src/docs/public/user-avatars/
|
src/docs/public/user-avatars/
|
||||||
src/docs/.vitepress/cache
|
src/docs/.vitepress/cache
|
||||||
src/docs/.vitepress/components.d.ts
|
src/docs/.vitepress/components.d.ts
|
||||||
|
src/docs/syntax/shapesTable.md
|
||||||
|
@@ -35,7 +35,8 @@
|
|||||||
"clean": "rimraf dist",
|
"clean": "rimraf dist",
|
||||||
"dev": "pnpm -w dev",
|
"dev": "pnpm -w dev",
|
||||||
"docs:code": "typedoc src/defaultConfig.ts src/config.ts src/mermaid.ts && prettier --write ./src/docs/config/setup",
|
"docs:code": "typedoc src/defaultConfig.ts src/config.ts src/mermaid.ts && prettier --write ./src/docs/config/setup",
|
||||||
"docs:build": "rimraf ../../docs && pnpm docs:spellcheck && pnpm docs:code && tsx scripts/docs.cli.mts",
|
"docs:build": "rimraf ../../docs && pnpm docs:shapes && pnpm docs:spellcheck && pnpm docs:code && tsx scripts/docs.cli.mts",
|
||||||
|
"docs:shapes": "cd ../.. && tsx .esbuild/docs.ts",
|
||||||
"docs:verify": "pnpm docs:spellcheck && pnpm docs:code && tsx scripts/docs.cli.mts --verify",
|
"docs:verify": "pnpm docs:spellcheck && pnpm docs:code && tsx scripts/docs.cli.mts --verify",
|
||||||
"docs:pre:vitepress": "pnpm --filter ./src/docs prefetch && rimraf src/vitepress && pnpm docs:code && tsx scripts/docs.cli.mts --vitepress && pnpm --filter ./src/vitepress install --no-frozen-lockfile --ignore-scripts",
|
"docs:pre:vitepress": "pnpm --filter ./src/docs prefetch && rimraf src/vitepress && pnpm docs:code && tsx scripts/docs.cli.mts --vitepress && pnpm --filter ./src/vitepress install --no-frozen-lockfile --ignore-scripts",
|
||||||
"docs:build:vitepress": "pnpm docs:pre:vitepress && (cd src/vitepress && pnpm run build) && cpy --flat src/docs/landing/ ./src/vitepress/.vitepress/dist/landing",
|
"docs:build:vitepress": "pnpm docs:pre:vitepress && (cd src/vitepress && pnpm run build) && cpy --flat src/docs/landing/ ./src/vitepress/.vitepress/dist/landing",
|
||||||
|
@@ -212,53 +212,8 @@ This syntax creates a node A as a rectangle. It renders in the same way as `A["A
|
|||||||
|
|
||||||
Below is a comprehensive list of the newly introduced shapes and their corresponding semantic meanings, short names, and aliases:
|
Below is a comprehensive list of the newly introduced shapes and their corresponding semantic meanings, short names, and aliases:
|
||||||
|
|
||||||
| **Semantic Name** | **Shape Name** | **Short Name** | **Description** | **Alias Supported** |
|
<!-- Will be auto generated with `pnpm --filter mermaid docs:shapes` -->
|
||||||
| ------------------------------------- | ---------------------- | -------------- | ------------------------------ | -------------------------------------------------------------- |
|
<!--@include: ./shapesTable.md -->
|
||||||
| **Process** | Rectangle | `rect` | Standard process shape | `proc`, `process`, `rectangle` |
|
|
||||||
| **Event** | Rounded Rectangle | `rounded` | Represents an event | `event` |
|
|
||||||
| **Terminal Point** | Stadium | `stadium` | Terminal point | `terminal`, `pill` |
|
|
||||||
| **Subprocess** | Framed Rectangle | `fr-rect` | Subprocess | `subprocess`,`subproc`, `framed-rectangle`, `subroutine` |
|
|
||||||
| **Database** | Cylinder | `cyl` | Database storage | `db`, `database`, `cylinder` |
|
|
||||||
| **Start** | Circle | `circle` | Starting point | `circ` |
|
|
||||||
| **Odd** | Odd | `odd` | Odd shape | |
|
|
||||||
| **Decision** | Diamond | `diam` | Decision-making step | `decision`, `diamond` |
|
|
||||||
| **Prepare Conditional** | Hexagon | `hex` | Preparation or condition step | `hexagon`, `prepare` |
|
|
||||||
| **Data Input/Output** | Lean Right | `lean-r` | Represents input or output | `lean-right`, `in-out` |
|
|
||||||
| **Data Input/Output** | Lean Left | `lean-l` | Represents output or input | `lean-left`, `out-in` |
|
|
||||||
| **Priority Action** | Trapezoid Base Bottom | `trap-b` | Priority action | `priority`, `trapezoid-bottom` |
|
|
||||||
| **Manual Operation** | Trapezoid Base Top | `trap-t` | Represents a manual task | `manual`, `trapezoid-top` |
|
|
||||||
| **Stop** | Double Circle | `dbl-circ` | Represents a stop point | `double-circle` |
|
|
||||||
| **Text Block** | Text Block | `text` | Text block | - |
|
|
||||||
| **Card** | Notched Rectangle | `notch-rect` | Represents a card | `card`, `notched-rectangle` |
|
|
||||||
| **Lined/Shaded Process** | Lined Rectangle | `lin-rect` | Lined process shape | `lined-rectangle`,`lined-process`, `lin-proc`,`shaded-process` |
|
|
||||||
| **Start** | Small Circle | `sm-circ` | Small starting point | `start`, `small-circle` |
|
|
||||||
| **Stop** | Framed Circle | `fr-circ` | Stop point | `stop`, `framed-circle` |
|
|
||||||
| **Fork/Join** | Filled Rectangle | `fork` | Fork or join in process flow | `join` |
|
|
||||||
| **Collate** | Hourglass | `hourglass` | Represents a collate operation | `hourglass` |
|
|
||||||
| **Comment** | Curly Brace | `brace` | Adds a comment | `comment`, `brace-l` |
|
|
||||||
| **Comment Right** | Curly Brace | `brace-r` | Adds a comment | - |
|
|
||||||
| **Comment with braces on both sides** | Curly Braces | `braces` | Adds a comment | - |
|
|
||||||
| **Com Link** | Lightning Bolt | `bolt` | Communication link | `com-link`, `lightning-bolt` |
|
|
||||||
| **Document** | Document | `doc` | Represents a document | `doc`, `document` |
|
|
||||||
| **Delay** | Half-Rounded Rectangle | `delay` | Represents a delay | `half-rounded-rectangle` |
|
|
||||||
| **Direct Access Storage** | Horizontal Cylinder | `h-cyl` | Direct access storage | `das`, `horizontal-cylinder` |
|
|
||||||
| **Disk Storage** | Lined Cylinder | `lin-cyl` | Disk storage | `disk`, `lined-cylinder` |
|
|
||||||
| **Display** | Curved Trapezoid | `curv-trap` | Represents a display | `curved-trapezoid`, `display` |
|
|
||||||
| **Divided Process** | Divided Rectangle | `div-rect` | Divided process shape | `div-proc`, `divided-rectangle`, `divided-process` |
|
|
||||||
| **Extract** | Triangle | `tri` | Extraction process | `extract`, `triangle` |
|
|
||||||
| **Internal Storage** | Window Pane | `win-pane` | Internal storage | `internal-storage`, `window-pane` |
|
|
||||||
| **Junction** | Filled Circle | `f-circ` | Junction point | `junction`, `filled-circle` |
|
|
||||||
| **Lined Document** | Lined Document | `lin-doc` | Lined document | `lined-document` |
|
|
||||||
| **Loop Limit** | Trapezoidal Pentagon | `notch-pent` | Loop limit step | `loop-limit`, `notched-pentagon` |
|
|
||||||
| **Manual File** | Flipped Triangle | `flip-tri` | Manual file operation | `manual-file`, `flipped-triangle` |
|
|
||||||
| **Manual Input** | Sloped Rectangle | `sl-rect` | Manual input step | `manual-input`, `sloped-rectangle` |
|
|
||||||
| **Multi-Document** | Stacked Document | `docs` | Multiple documents | `documents`, `st-doc`, `stacked-document` |
|
|
||||||
| **Multi-Process** | Stacked Rectangle | `st-rect` | Multiple processes | `procs`, `processes`, `stacked-rectangle` |
|
|
||||||
| **Paper Tape** | Flag | `flag` | Paper tape | `paper-tape` |
|
|
||||||
| **Stored Data** | Bow Tie Rectangle | `bow-rect` | Stored data | `stored-data`, `bow-tie-rectangle` |
|
|
||||||
| **Summary** | Crossed Circle | `cross-circ` | Summary | `summary`, `crossed-circle` |
|
|
||||||
| **Tagged Document** | Tagged Document | `tag-doc` | Tagged document | `tag-doc`, `tagged-document` |
|
|
||||||
| **Tagged Process** | Tagged Rectangle | `tag-rect` | Tagged process | `tagged-rectangle`,`tag-proc`, `tagged-process` |
|
|
||||||
|
|
||||||
### Example Flowchart with New Shapes
|
### Example Flowchart with New Shapes
|
||||||
|
|
||||||
|
@@ -10,12 +10,7 @@ import {
|
|||||||
findNonClusterChild,
|
findNonClusterChild,
|
||||||
sortNodesByHierarchy,
|
sortNodesByHierarchy,
|
||||||
} from './mermaid-graphlib.js';
|
} from './mermaid-graphlib.js';
|
||||||
import {
|
import { Nodes } from '../../rendering-elements/nodes.js';
|
||||||
insertNode,
|
|
||||||
positionNode,
|
|
||||||
clear as clearNodes,
|
|
||||||
setNodeElem,
|
|
||||||
} from '../../rendering-elements/nodes.js';
|
|
||||||
import { insertCluster, clear as clearClusters } from '../../rendering-elements/clusters.js';
|
import { insertCluster, clear as clearClusters } from '../../rendering-elements/clusters.js';
|
||||||
import {
|
import {
|
||||||
insertEdgeLabel,
|
insertEdgeLabel,
|
||||||
@@ -27,8 +22,16 @@ import { log } from '../../../logger.js';
|
|||||||
import { getSubGraphTitleMargins } from '../../../utils/subGraphTitleMargins.js';
|
import { getSubGraphTitleMargins } from '../../../utils/subGraphTitleMargins.js';
|
||||||
import { getConfig } from '../../../diagram-api/diagramAPI.js';
|
import { getConfig } from '../../../diagram-api/diagramAPI.js';
|
||||||
|
|
||||||
const recursiveRender = async (_elem, graph, diagramType, id, parentCluster, siteConfig) => {
|
const recursiveRender = async (
|
||||||
log.warn('Graph in recursive render:XAX', graphlibJson.write(graph), parentCluster);
|
_elem,
|
||||||
|
graph,
|
||||||
|
diagramType,
|
||||||
|
id,
|
||||||
|
parentCluster,
|
||||||
|
siteConfig,
|
||||||
|
nodeData
|
||||||
|
) => {
|
||||||
|
log.debug('Graph in recursive render:XAX', graphlibJson.write(graph), parentCluster);
|
||||||
const dir = graph.graph().rankdir;
|
const dir = graph.graph().rankdir;
|
||||||
log.trace('Dir in recursive render - dir:', dir);
|
log.trace('Dir in recursive render - dir:', dir);
|
||||||
|
|
||||||
@@ -89,7 +92,8 @@ const recursiveRender = async (_elem, graph, diagramType, id, parentCluster, sit
|
|||||||
diagramType,
|
diagramType,
|
||||||
id,
|
id,
|
||||||
graph.node(v),
|
graph.node(v),
|
||||||
siteConfig
|
siteConfig,
|
||||||
|
nodeData
|
||||||
);
|
);
|
||||||
const newEl = o.elem;
|
const newEl = o.elem;
|
||||||
updateNodeBounds(node, newEl);
|
updateNodeBounds(node, newEl);
|
||||||
@@ -106,7 +110,7 @@ const recursiveRender = async (_elem, graph, diagramType, id, parentCluster, sit
|
|||||||
// node.x,
|
// node.x,
|
||||||
// node.y
|
// node.y
|
||||||
);
|
);
|
||||||
setNodeElem(newEl, node);
|
nodeData.setNodeElem(newEl, node);
|
||||||
} else {
|
} else {
|
||||||
if (graph.children(v).length > 0) {
|
if (graph.children(v).length > 0) {
|
||||||
// This is a cluster but not to be rendered recursively
|
// This is a cluster but not to be rendered recursively
|
||||||
@@ -125,7 +129,7 @@ const recursiveRender = async (_elem, graph, diagramType, id, parentCluster, sit
|
|||||||
// insertCluster(clusters, graph.node(v));
|
// insertCluster(clusters, graph.node(v));
|
||||||
} else {
|
} else {
|
||||||
log.trace('Node - the non recursive path XAX', v, nodes, graph.node(v), dir);
|
log.trace('Node - the non recursive path XAX', v, nodes, graph.node(v), dir);
|
||||||
await insertNode(nodes, graph.node(v), { config: siteConfig, dir });
|
await nodeData.insertNode(nodes, graph.node(v), { config: siteConfig, dir });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
@@ -194,7 +198,7 @@ const recursiveRender = async (_elem, graph, diagramType, id, parentCluster, sit
|
|||||||
graph.parent(v)
|
graph.parent(v)
|
||||||
);
|
);
|
||||||
clusterDb.get(node.id).node = node;
|
clusterDb.get(node.id).node = node;
|
||||||
positionNode(node);
|
nodeData.positionNode(node);
|
||||||
} else {
|
} else {
|
||||||
// A tainted cluster node
|
// A tainted cluster node
|
||||||
if (graph.children(v).length > 0) {
|
if (graph.children(v).length > 0) {
|
||||||
@@ -239,7 +243,7 @@ const recursiveRender = async (_elem, graph, diagramType, id, parentCluster, sit
|
|||||||
node
|
node
|
||||||
);
|
);
|
||||||
|
|
||||||
positionNode(node);
|
nodeData.positionNode(node);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
@@ -264,7 +268,7 @@ const recursiveRender = async (_elem, graph, diagramType, id, parentCluster, sit
|
|||||||
diff = n.diff;
|
diff = n.diff;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
log.warn('Returning from recursive render XAX', elem, diff);
|
log.debug('Returning from recursive render XAX', elem, diff);
|
||||||
return { elem, diff };
|
return { elem, diff };
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -291,7 +295,6 @@ export const render = async (data4Layout, svg) => {
|
|||||||
});
|
});
|
||||||
const element = svg.select('g');
|
const element = svg.select('g');
|
||||||
insertMarkers(element, data4Layout.markers, data4Layout.type, data4Layout.diagramId);
|
insertMarkers(element, data4Layout.markers, data4Layout.type, data4Layout.diagramId);
|
||||||
clearNodes();
|
|
||||||
clearEdges();
|
clearEdges();
|
||||||
clearClusters();
|
clearClusters();
|
||||||
clearGraphlib();
|
clearGraphlib();
|
||||||
@@ -362,16 +365,18 @@ export const render = async (data4Layout, svg) => {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
log.warn('Graph at first:', JSON.stringify(graphlibJson.write(graph)));
|
log.debug('Graph at first:', JSON.stringify(graphlibJson.write(graph)));
|
||||||
adjustClustersAndEdges(graph);
|
adjustClustersAndEdges(graph);
|
||||||
log.warn('Graph after XAX:', JSON.stringify(graphlibJson.write(graph)));
|
log.debug('Graph after XAX:', JSON.stringify(graphlibJson.write(graph)));
|
||||||
const siteConfig = getConfig();
|
const siteConfig = getConfig();
|
||||||
|
const nodeData = new Nodes();
|
||||||
await recursiveRender(
|
await recursiveRender(
|
||||||
element,
|
element,
|
||||||
graph,
|
graph,
|
||||||
data4Layout.type,
|
data4Layout.type,
|
||||||
data4Layout.diagramId,
|
data4Layout.diagramId,
|
||||||
undefined,
|
undefined,
|
||||||
siteConfig
|
siteConfig,
|
||||||
|
nodeData
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
@@ -1,82 +0,0 @@
|
|||||||
import { log } from '../../logger.js';
|
|
||||||
import { shapes } from './shapes.js';
|
|
||||||
|
|
||||||
const nodeElems = new Map();
|
|
||||||
|
|
||||||
export const insertNode = async (elem, node, renderOptions) => {
|
|
||||||
let newEl;
|
|
||||||
let el;
|
|
||||||
|
|
||||||
//special check for rect shape (with or without rounded corners)
|
|
||||||
if (node.shape === 'rect') {
|
|
||||||
if (node.rx && node.ry) {
|
|
||||||
node.shape = 'roundedRect';
|
|
||||||
} else {
|
|
||||||
node.shape = 'squareRect';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const shapeHandler = shapes[node.shape];
|
|
||||||
|
|
||||||
if (!shapeHandler) {
|
|
||||||
throw new Error(`No such shape: ${node.shape}. Please check your syntax.`);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (node.link) {
|
|
||||||
// Add link when appropriate
|
|
||||||
let target;
|
|
||||||
if (renderOptions.config.securityLevel === 'sandbox') {
|
|
||||||
target = '_top';
|
|
||||||
} else if (node.linkTarget) {
|
|
||||||
target = node.linkTarget || '_blank';
|
|
||||||
}
|
|
||||||
newEl = elem.insert('svg:a').attr('xlink:href', node.link).attr('target', target);
|
|
||||||
el = await shapeHandler(newEl, node, renderOptions);
|
|
||||||
} else {
|
|
||||||
el = await shapeHandler(elem, node, renderOptions);
|
|
||||||
newEl = el;
|
|
||||||
}
|
|
||||||
if (node.tooltip) {
|
|
||||||
el.attr('title', node.tooltip);
|
|
||||||
}
|
|
||||||
|
|
||||||
nodeElems.set(node.id, newEl);
|
|
||||||
|
|
||||||
if (node.haveCallback) {
|
|
||||||
nodeElems.get(node.id).attr('class', nodeElems.get(node.id).attr('class') + ' clickable');
|
|
||||||
}
|
|
||||||
return newEl;
|
|
||||||
};
|
|
||||||
|
|
||||||
export const setNodeElem = (elem, node) => {
|
|
||||||
nodeElems.set(node.id, elem);
|
|
||||||
};
|
|
||||||
|
|
||||||
export const clear = () => {
|
|
||||||
nodeElems.clear();
|
|
||||||
};
|
|
||||||
|
|
||||||
export const positionNode = (node) => {
|
|
||||||
const el = nodeElems.get(node.id);
|
|
||||||
log.trace(
|
|
||||||
'Transforming node',
|
|
||||||
node.diff,
|
|
||||||
node,
|
|
||||||
'translate(' + (node.x - node.width / 2 - 5) + ', ' + node.width / 2 + ')'
|
|
||||||
);
|
|
||||||
const padding = 8;
|
|
||||||
const diff = node.diff || 0;
|
|
||||||
if (node.clusterNode) {
|
|
||||||
el.attr(
|
|
||||||
'transform',
|
|
||||||
'translate(' +
|
|
||||||
(node.x + diff - node.width / 2) +
|
|
||||||
', ' +
|
|
||||||
(node.y - node.height / 2 - padding) +
|
|
||||||
')'
|
|
||||||
);
|
|
||||||
} else {
|
|
||||||
el.attr('transform', 'translate(' + node.x + ', ' + node.y + ')');
|
|
||||||
}
|
|
||||||
return diff;
|
|
||||||
};
|
|
@@ -0,0 +1,83 @@
|
|||||||
|
/* eslint-disable @typescript-eslint/no-explicit-any */
|
||||||
|
import { log } from '../../logger.js';
|
||||||
|
import type { SVG } from '../../mermaid.js';
|
||||||
|
import type { Node, ShapeRenderOptions } from '../types.js';
|
||||||
|
import { shapes } from './shapes.js';
|
||||||
|
|
||||||
|
// TODO: Need a better name for the class.
|
||||||
|
export class Nodes {
|
||||||
|
private readonly nodeElems = new Map();
|
||||||
|
positionNode = (node: any) => {
|
||||||
|
const el = this.nodeElems.get(node.id);
|
||||||
|
log.trace(
|
||||||
|
'Transforming node',
|
||||||
|
node.diff,
|
||||||
|
node,
|
||||||
|
'translate(' + (node.x - node.width / 2 - 5) + ', ' + node.width / 2 + ')'
|
||||||
|
);
|
||||||
|
const padding = 8;
|
||||||
|
const diff = node.diff || 0;
|
||||||
|
if (node.clusterNode) {
|
||||||
|
el.attr(
|
||||||
|
'transform',
|
||||||
|
'translate(' +
|
||||||
|
(node.x + diff - node.width / 2) +
|
||||||
|
', ' +
|
||||||
|
(node.y - node.height / 2 - padding) +
|
||||||
|
')'
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
el.attr('transform', 'translate(' + node.x + ', ' + node.y + ')');
|
||||||
|
}
|
||||||
|
return diff;
|
||||||
|
};
|
||||||
|
setNodeElem = (elem: any, node: any) => {
|
||||||
|
this.nodeElems.set(node.id, elem);
|
||||||
|
};
|
||||||
|
insertNode = async (elem: SVG, node: Node, renderOptions: ShapeRenderOptions) => {
|
||||||
|
let newEl: any;
|
||||||
|
let el: any;
|
||||||
|
|
||||||
|
//special check for rect shape (with or without rounded corners)
|
||||||
|
if (node.shape === 'rect') {
|
||||||
|
if (node.rx && node.ry) {
|
||||||
|
node.shape = 'roundedRect';
|
||||||
|
} else {
|
||||||
|
node.shape = 'squareRect';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!node.shape) {
|
||||||
|
throw new Error(`No shape defined for node ${node.id}. Please check your syntax.`);
|
||||||
|
}
|
||||||
|
|
||||||
|
const shapeHandler = shapes[node.shape];
|
||||||
|
|
||||||
|
if (!shapeHandler) {
|
||||||
|
throw new Error(`No such shape: ${node.shape}. Please check your syntax.`);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (node.link) {
|
||||||
|
// Add link when appropriate
|
||||||
|
const target =
|
||||||
|
renderOptions.config.securityLevel === 'sandbox' ? '_top' : (node.linkTarget ?? '_blank');
|
||||||
|
newEl = elem.insert('svg:a').attr('xlink:href', node.link).attr('target', target);
|
||||||
|
el = await shapeHandler(newEl, node, renderOptions);
|
||||||
|
} else {
|
||||||
|
el = await shapeHandler(elem, node, renderOptions);
|
||||||
|
newEl = el;
|
||||||
|
}
|
||||||
|
if (node.tooltip) {
|
||||||
|
el.attr('title', node.tooltip);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.nodeElems.set(node.id, newEl);
|
||||||
|
|
||||||
|
if (node.haveCallback) {
|
||||||
|
this.nodeElems
|
||||||
|
.get(node.id)
|
||||||
|
.attr('class', this.nodeElems.get(node.id).attr('class') + ' clickable');
|
||||||
|
}
|
||||||
|
return newEl;
|
||||||
|
};
|
||||||
|
}
|
@@ -0,0 +1,8 @@
|
|||||||
|
import { writeFile } from 'fs/promises';
|
||||||
|
import { buildShapeDoc } from './shapesDoc.js';
|
||||||
|
|
||||||
|
export const writeShapeDoc = async () => {
|
||||||
|
await writeFile('packages/mermaid/src/docs/syntax/shapesTable.md', buildShapeDoc());
|
||||||
|
};
|
||||||
|
|
||||||
|
void writeShapeDoc();
|
@@ -0,0 +1,56 @@
|
|||||||
|
import { describe, it } from 'vitest';
|
||||||
|
import { buildShapeDoc } from './shapesDoc.js';
|
||||||
|
|
||||||
|
describe('build shapesTable', () => {
|
||||||
|
it('should build shapesTable based on the shapeDefs', () => {
|
||||||
|
expect(buildShapeDoc()).toMatchInlineSnapshot(`
|
||||||
|
"| **Semantic Name** | **Shape Name** | **Short Name** | **Description** | **Alias Supported** |
|
||||||
|
| --------------------------------- | ---------------------- | -------------- | ------------------------------ | ---------------------------------------------------------------- |
|
||||||
|
| Card | Notched Rectangle | \`notch-rect\` | Represents a card | \`card\`, \`notched-rectangle\` |
|
||||||
|
| Collate | Hourglass | \`hourglass\` | Represents a collate operation | \`collate\`, \`hourglass\` |
|
||||||
|
| Com Link | Lightning Bolt | \`bolt\` | Communication link | \`com-link\`, \`lightning-bolt\` |
|
||||||
|
| Comment | Curly Brace | \`brace\` | Adds a comment | \`brace-l\`, \`comment\` |
|
||||||
|
| Comment Right | Curly Brace | \`brace-r\` | Adds a comment | |
|
||||||
|
| Comment with braces on both sides | Curly Braces | \`braces\` | Adds a comment | |
|
||||||
|
| Data Input/Output | Lean Right | \`lean-r\` | Represents input or output | \`in-out\`, \`lean-right\` |
|
||||||
|
| Data Input/Output | Lean Left | \`lean-l\` | Represents output or input | \`lean-left\`, \`out-in\` |
|
||||||
|
| Database | Cylinder | \`cyl\` | Database storage | \`cylinder\`, \`database\`, \`db\` |
|
||||||
|
| Decision | Diamond | \`diam\` | Decision-making step | \`decision\`, \`diamond\`, \`question\` |
|
||||||
|
| Delay | Half-Rounded Rectangle | \`delay\` | Represents a delay | \`half-rounded-rectangle\` |
|
||||||
|
| Direct Access Storage | Horizontal Cylinder | \`h-cyl\` | Direct access storage | \`das\`, \`horizontal-cylinder\` |
|
||||||
|
| Disk Storage | Lined Cylinder | \`lin-cyl\` | Disk storage | \`disk\`, \`lined-cylinder\` |
|
||||||
|
| Display | Curved Trapezoid | \`curv-trap\` | Represents a display | \`curved-trapezoid\`, \`display\` |
|
||||||
|
| Divided Process | Divided Rectangle | \`div-rect\` | Divided process shape | \`div-proc\`, \`divided-process\`, \`divided-rectangle\` |
|
||||||
|
| Document | Document | \`doc\` | Represents a document | \`doc\`, \`document\` |
|
||||||
|
| Event | Rounded Rectangle | \`rounded\` | Represents an event | \`event\` |
|
||||||
|
| Extract | Triangle | \`tri\` | Extraction process | \`extract\`, \`triangle\` |
|
||||||
|
| Fork/Join | Filled Rectangle | \`fork\` | Fork or join in process flow | \`join\` |
|
||||||
|
| Internal Storage | Window Pane | \`win-pane\` | Internal storage | \`internal-storage\`, \`window-pane\` |
|
||||||
|
| Junction | Filled Circle | \`f-circ\` | Junction point | \`filled-circle\`, \`junction\` |
|
||||||
|
| Lined Document | Lined Document | \`lin-doc\` | Lined document | \`lined-document\` |
|
||||||
|
| Lined/Shaded Process | Lined Rectangle | \`lin-rect\` | Lined process shape | \`lin-proc\`, \`lined-process\`, \`lined-rectangle\`, \`shaded-process\` |
|
||||||
|
| Loop Limit | Trapezoidal Pentagon | \`notch-pent\` | Loop limit step | \`loop-limit\`, \`notched-pentagon\` |
|
||||||
|
| Manual File | Flipped Triangle | \`flip-tri\` | Manual file operation | \`flipped-triangle\`, \`manual-file\` |
|
||||||
|
| Manual Input | Sloped Rectangle | \`sl-rect\` | Manual input step | \`manual-input\`, \`sloped-rectangle\` |
|
||||||
|
| Manual Operation | Trapezoid Base Top | \`trap-t\` | Represents a manual task | \`inv-trapezoid\`, \`manual\`, \`trapezoid-top\` |
|
||||||
|
| Multi-Document | Stacked Document | \`docs\` | Multiple documents | \`documents\`, \`st-doc\`, \`stacked-document\` |
|
||||||
|
| Multi-Process | Stacked Rectangle | \`st-rect\` | Multiple processes | \`processes\`, \`procs\`, \`stacked-rectangle\` |
|
||||||
|
| Odd | Odd | \`odd\` | Odd shape | |
|
||||||
|
| Paper Tape | Flag | \`flag\` | Paper tape | \`paper-tape\` |
|
||||||
|
| Prepare Conditional | Hexagon | \`hex\` | Preparation or condition step | \`hexagon\`, \`prepare\` |
|
||||||
|
| Priority Action | Trapezoid Base Bottom | \`trap-b\` | Priority action | \`priority\`, \`trapezoid\`, \`trapezoid-bottom\` |
|
||||||
|
| Process | Rectangle | \`rect\` | Standard process shape | \`proc\`, \`process\`, \`rectangle\` |
|
||||||
|
| Start | Circle | \`circle\` | Starting point | \`circ\` |
|
||||||
|
| Start | Small Circle | \`sm-circ\` | Small starting point | \`small-circle\`, \`start\` |
|
||||||
|
| Stop | Double Circle | \`dbl-circ\` | Represents a stop point | \`double-circle\` |
|
||||||
|
| Stop | Framed Circle | \`fr-circ\` | Stop point | \`framed-circle\`, \`stop\` |
|
||||||
|
| Stored Data | Bow Tie Rectangle | \`bow-rect\` | Stored data | \`bow-tie-rectangle\`, \`stored-data\` |
|
||||||
|
| Subprocess | Framed Rectangle | \`fr-rect\` | Subprocess | \`framed-rectangle\`, \`subproc\`, \`subprocess\`, \`subroutine\` |
|
||||||
|
| Summary | Crossed Circle | \`cross-circ\` | Summary | \`crossed-circle\`, \`summary\` |
|
||||||
|
| Tagged Document | Tagged Document | \`tag-doc\` | Tagged document | \`tag-doc\`, \`tagged-document\` |
|
||||||
|
| Tagged Process | Tagged Rectangle | \`tag-rect\` | Tagged process | \`tag-proc\`, \`tagged-process\`, \`tagged-rectangle\` |
|
||||||
|
| Terminal Point | Stadium | \`stadium\` | Terminal point | \`pill\`, \`terminal\` |
|
||||||
|
| Text Block | Text Block | \`text\` | Text block | |"
|
||||||
|
`);
|
||||||
|
});
|
||||||
|
});
|
@@ -0,0 +1,29 @@
|
|||||||
|
import { writeFile } from 'fs/promises';
|
||||||
|
import { markdownTable } from 'markdown-table';
|
||||||
|
import { shapesDefs } from './shapes.js';
|
||||||
|
|
||||||
|
export const buildShapeDoc = () => {
|
||||||
|
const data = shapesDefs.map((shape) => {
|
||||||
|
const { name, semanticName, description, shortName, aliases } = shape;
|
||||||
|
aliases?.sort();
|
||||||
|
const aliasString = aliases?.join('`, `');
|
||||||
|
return [
|
||||||
|
semanticName,
|
||||||
|
name,
|
||||||
|
`\`${shortName}\``,
|
||||||
|
description,
|
||||||
|
aliasString ? `\`${aliasString}\`` : '',
|
||||||
|
];
|
||||||
|
});
|
||||||
|
data.sort((a, b) => a[0].localeCompare(b[0]));
|
||||||
|
return markdownTable([
|
||||||
|
['Semantic Name', 'Shape Name', 'Short Name', 'Description', 'Alias Supported'].map(
|
||||||
|
(s) => `**${s}**`
|
||||||
|
),
|
||||||
|
...data,
|
||||||
|
]);
|
||||||
|
};
|
||||||
|
|
||||||
|
export const writeShapeDoc = async () => {
|
||||||
|
await writeFile('packages/mermaid/src/docs/syntax/shapesTable.md', buildShapeDoc());
|
||||||
|
};
|
Reference in New Issue
Block a user