mirror of
				https://github.com/mermaid-js/mermaid.git
				synced 2025-10-24 16:34:09 +02:00 
			
		
		
		
	Compare commits
	
		
			34 Commits
		
	
	
		
			v10.7.0
			...
			sidv/runCo
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 84a2bf1b58 | ||
|   | ef28eb8be1 | ||
|   | c78573d9aa | ||
|   | 1aeef62db1 | ||
|   | d639d5bdc9 | ||
|   | f946c3da06 | ||
|   | 156fbd1958 | ||
|   | 7dd0d126e2 | ||
|   | 8678ceeb3c | ||
|   | 9cb62f4d2e | ||
|   | fd731c5ccd | ||
|   | 222d8eed4e | ||
|   | 718d52a72c | ||
|   | fe1a06271a | ||
|   | bd2370555b | ||
|   | 86c9ee4e90 | ||
|   | b26bcf1343 | ||
|   | 5d5c6275f9 | ||
|   | 9c1a47d1fc | ||
|   | 13852b7f4e | ||
|   | 4fd7a88a15 | ||
|   | 5c2a6b5eb1 | ||
|   | 9cbebbb8a0 | ||
|   | e26d987c4e | ||
|   | 53669efaf8 | ||
|   | b68f45ef59 | ||
|   | 8f44de651b | ||
|   | 2ede244da0 | ||
|   | 77a181978e | ||
|   | 170bbce0d3 | ||
|   | fc99d9be41 | ||
|   | 9fb9bed806 | ||
|   | 01b2f80a95 | ||
|   | da7ff777d1 | 
							
								
								
									
										20
									
								
								.build/common.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								.build/common.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | |||||||
|  | /** | ||||||
|  |  * Shared common options for both ESBuild and Vite | ||||||
|  |  */ | ||||||
|  | export const packageOptions = { | ||||||
|  |   mermaid: { | ||||||
|  |     name: 'mermaid', | ||||||
|  |     packageName: 'mermaid', | ||||||
|  |     file: 'mermaid.ts', | ||||||
|  |   }, | ||||||
|  |   'mermaid-example-diagram': { | ||||||
|  |     name: 'mermaid-example-diagram', | ||||||
|  |     packageName: 'mermaid-example-diagram', | ||||||
|  |     file: 'detector.ts', | ||||||
|  |   }, | ||||||
|  |   'mermaid-zenuml': { | ||||||
|  |     name: 'mermaid-zenuml', | ||||||
|  |     packageName: 'mermaid-zenuml', | ||||||
|  |     file: 'detector.ts', | ||||||
|  |   }, | ||||||
|  | } as const; | ||||||
							
								
								
									
										122
									
								
								.build/jsonSchema.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										122
									
								
								.build/jsonSchema.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,122 @@ | |||||||
|  | import { load, JSON_SCHEMA } from 'js-yaml'; | ||||||
|  | import assert from 'node:assert'; | ||||||
|  | import Ajv2019, { type JSONSchemaType } from 'ajv/dist/2019.js'; | ||||||
|  |  | ||||||
|  | import type { MermaidConfig, BaseDiagramConfig } from '../packages/mermaid/src/config.type.js'; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * All of the keys in the mermaid config that have a mermaid diagram config. | ||||||
|  |  */ | ||||||
|  | const MERMAID_CONFIG_DIAGRAM_KEYS = [ | ||||||
|  |   'flowchart', | ||||||
|  |   'sequence', | ||||||
|  |   'gantt', | ||||||
|  |   'journey', | ||||||
|  |   'class', | ||||||
|  |   'state', | ||||||
|  |   'er', | ||||||
|  |   'pie', | ||||||
|  |   'quadrantChart', | ||||||
|  |   'requirement', | ||||||
|  |   'mindmap', | ||||||
|  |   'timeline', | ||||||
|  |   'gitGraph', | ||||||
|  |   'c4', | ||||||
|  |   'sankey', | ||||||
|  | ] as const; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Generate default values from the JSON Schema. | ||||||
|  |  * | ||||||
|  |  * AJV does not support nested default values yet (or default values with $ref), | ||||||
|  |  * so we need to manually find them (this may be fixed in ajv v9). | ||||||
|  |  * | ||||||
|  |  * @param mermaidConfigSchema - The Mermaid JSON Schema to use. | ||||||
|  |  * @returns The default mermaid config object. | ||||||
|  |  */ | ||||||
|  | export function generateDefaults(mermaidConfigSchema: JSONSchemaType<MermaidConfig>) { | ||||||
|  |   const ajv = new Ajv2019({ | ||||||
|  |     useDefaults: true, | ||||||
|  |     allowUnionTypes: true, | ||||||
|  |     strict: true, | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   ajv.addKeyword({ | ||||||
|  |     keyword: 'meta:enum', // used by jsonschema2md | ||||||
|  |     errors: false, | ||||||
|  |   }); | ||||||
|  |   ajv.addKeyword({ | ||||||
|  |     keyword: 'tsType', // used by json-schema-to-typescript | ||||||
|  |     errors: false, | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   // ajv currently doesn't support nested default values, see https://github.com/ajv-validator/ajv/issues/1718 | ||||||
|  |   // (may be fixed in v9) so we need to manually use sub-schemas | ||||||
|  |   const mermaidDefaultConfig = {}; | ||||||
|  |  | ||||||
|  |   assert.ok(mermaidConfigSchema.$defs); | ||||||
|  |   const baseDiagramConfig = mermaidConfigSchema.$defs.BaseDiagramConfig; | ||||||
|  |  | ||||||
|  |   for (const key of MERMAID_CONFIG_DIAGRAM_KEYS) { | ||||||
|  |     const subSchemaRef = mermaidConfigSchema.properties[key].$ref; | ||||||
|  |     const [root, defs, defName] = subSchemaRef.split('/'); | ||||||
|  |     assert.strictEqual(root, '#'); | ||||||
|  |     assert.strictEqual(defs, '$defs'); | ||||||
|  |     const subSchema = { | ||||||
|  |       $schema: mermaidConfigSchema.$schema, | ||||||
|  |       $defs: mermaidConfigSchema.$defs, | ||||||
|  |       ...mermaidConfigSchema.$defs[defName], | ||||||
|  |     } as JSONSchemaType<BaseDiagramConfig>; | ||||||
|  |  | ||||||
|  |     const validate = ajv.compile(subSchema); | ||||||
|  |  | ||||||
|  |     mermaidDefaultConfig[key] = {}; | ||||||
|  |  | ||||||
|  |     for (const required of subSchema.required ?? []) { | ||||||
|  |       if (subSchema.properties[required] === undefined && baseDiagramConfig.properties[required]) { | ||||||
|  |         mermaidDefaultConfig[key][required] = baseDiagramConfig.properties[required].default; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     if (!validate(mermaidDefaultConfig[key])) { | ||||||
|  |       throw new Error( | ||||||
|  |         `schema for subconfig ${key} does not have valid defaults! Errors were ${JSON.stringify( | ||||||
|  |           validate.errors, | ||||||
|  |           undefined, | ||||||
|  |           2, | ||||||
|  |         )}`, | ||||||
|  |       ); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   const validate = ajv.compile(mermaidConfigSchema); | ||||||
|  |  | ||||||
|  |   if (!validate(mermaidDefaultConfig)) { | ||||||
|  |     throw new Error( | ||||||
|  |       `Mermaid config JSON Schema does not have valid defaults! Errors were ${JSON.stringify( | ||||||
|  |         validate.errors, | ||||||
|  |         undefined, | ||||||
|  |         2, | ||||||
|  |       )}`, | ||||||
|  |     ); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return mermaidDefaultConfig; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export const loadSchema = (src: string, filename: string): JSONSchemaType<MermaidConfig> => { | ||||||
|  |   const jsonSchema = load(src, { | ||||||
|  |     filename, | ||||||
|  |     // only allow JSON types in our YAML doc (will probably be default in YAML 1.3) | ||||||
|  |     // e.g. `true` will be parsed a boolean `true`, `True` will be parsed as string `"True"`. | ||||||
|  |     schema: JSON_SCHEMA, | ||||||
|  |   }) as JSONSchemaType<MermaidConfig>; | ||||||
|  |   return jsonSchema; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export const getDefaults = (schema: JSONSchemaType<MermaidConfig>) => { | ||||||
|  |   return `export default ${JSON.stringify(generateDefaults(schema), undefined, 2)};`; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export const getSchema = (schema: JSONSchemaType<MermaidConfig>) => { | ||||||
|  |   return `export default ${JSON.stringify(schema, undefined, 2)};`; | ||||||
|  | }; | ||||||
							
								
								
									
										60
									
								
								.esbuild/build.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								.esbuild/build.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,60 @@ | |||||||
|  | import { build } from 'esbuild'; | ||||||
|  | import { mkdir, writeFile } from 'node:fs/promises'; | ||||||
|  | import { MermaidBuildOptions, defaultOptions, getBuildConfig } from './util.js'; | ||||||
|  | import { packageOptions } from '../.build/common.js'; | ||||||
|  |  | ||||||
|  | const shouldVisualize = process.argv.includes('--visualize'); | ||||||
|  |  | ||||||
|  | const buildPackage = async (entryName: keyof typeof packageOptions) => { | ||||||
|  |   const commonOptions = { ...defaultOptions, entryName } as const; | ||||||
|  |   const buildConfigs = [ | ||||||
|  |     // package.mjs | ||||||
|  |     { ...commonOptions }, | ||||||
|  |     // package.min.mjs | ||||||
|  |     { | ||||||
|  |       ...commonOptions, | ||||||
|  |       minify: true, | ||||||
|  |       metafile: shouldVisualize, | ||||||
|  |     }, | ||||||
|  |     // package.core.mjs | ||||||
|  |     { ...commonOptions, core: true }, | ||||||
|  |   ]; | ||||||
|  |  | ||||||
|  |   if (entryName === 'mermaid') { | ||||||
|  |     const iifeOptions: MermaidBuildOptions = { ...commonOptions, format: 'iife' }; | ||||||
|  |     buildConfigs.push( | ||||||
|  |       // mermaid.js | ||||||
|  |       { ...iifeOptions }, | ||||||
|  |       // mermaid.min.js | ||||||
|  |       { ...iifeOptions, minify: true, metafile: shouldVisualize }, | ||||||
|  |     ); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   const results = await Promise.all(buildConfigs.map((option) => build(getBuildConfig(option)))); | ||||||
|  |  | ||||||
|  |   if (shouldVisualize) { | ||||||
|  |     for (const { metafile } of results) { | ||||||
|  |       if (!metafile) { | ||||||
|  |         continue; | ||||||
|  |       } | ||||||
|  |       const fileName = Object.keys(metafile.outputs) | ||||||
|  |         .filter((file) => !file.includes('chunks') && file.endsWith('js'))[0] | ||||||
|  |         .replace('dist/', ''); | ||||||
|  |       // Upload metafile into https://esbuild.github.io/analyze/ | ||||||
|  |       await writeFile(`stats/${fileName}.meta.json`, JSON.stringify(metafile)); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const handler = (e) => { | ||||||
|  |   console.error(e); | ||||||
|  |   process.exit(1); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const main = async () => { | ||||||
|  |   await mkdir('stats').catch(() => {}); | ||||||
|  |   const packageNames = Object.keys(packageOptions) as (keyof typeof packageOptions)[]; | ||||||
|  |   await Promise.allSettled(packageNames.map((pkg) => buildPackage(pkg).catch(handler))); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | void main(); | ||||||
							
								
								
									
										15
									
								
								.esbuild/jisonPlugin.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								.esbuild/jisonPlugin.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | |||||||
|  | import { readFile } from 'node:fs/promises'; | ||||||
|  | import { transformJison } from '../.build/jisonTransformer.js'; | ||||||
|  | import { Plugin } from 'esbuild'; | ||||||
|  |  | ||||||
|  | export const jisonPlugin: Plugin = { | ||||||
|  |   name: 'jison', | ||||||
|  |   setup(build) { | ||||||
|  |     build.onLoad({ filter: /\.jison$/ }, async (args) => { | ||||||
|  |       // Load the file from the file system | ||||||
|  |       const source = await readFile(args.path, 'utf8'); | ||||||
|  |       const contents = transformJison(source); | ||||||
|  |       return { contents, warnings: [] }; | ||||||
|  |     }); | ||||||
|  |   }, | ||||||
|  | }; | ||||||
							
								
								
									
										35
									
								
								.esbuild/jsonSchemaPlugin.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								.esbuild/jsonSchemaPlugin.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | |||||||
|  | import type { JSONSchemaType } from 'ajv/dist/2019.js'; | ||||||
|  | import type { MermaidConfig } from '../packages/mermaid/src/config.type.js'; | ||||||
|  | import { readFile } from 'node:fs/promises'; | ||||||
|  | import { getDefaults, getSchema, loadSchema } from '../.build/jsonSchema.js'; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * ESBuild plugin that handles JSON Schemas saved as a `.schema.yaml` file. | ||||||
|  |  * | ||||||
|  |  * Use `my-example.schema.yaml?only-defaults=true` to only load the default values. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | export const jsonSchemaPlugin = { | ||||||
|  |   name: 'json-schema-plugin', | ||||||
|  |   setup(build) { | ||||||
|  |     let schema: JSONSchemaType<MermaidConfig> | undefined = undefined; | ||||||
|  |     let content = ''; | ||||||
|  |  | ||||||
|  |     build.onLoad({ filter: /config\.schema\.yaml$/ }, async (args) => { | ||||||
|  |       // Load the file from the file system | ||||||
|  |       const source = await readFile(args.path, 'utf8'); | ||||||
|  |       const resolvedSchema: JSONSchemaType<MermaidConfig> = | ||||||
|  |         content === source && schema ? schema : loadSchema(source, args.path); | ||||||
|  |       if (content !== source) { | ||||||
|  |         content = source; | ||||||
|  |         schema = resolvedSchema; | ||||||
|  |       } | ||||||
|  |       const contents = args.suffix.includes('only-defaults') | ||||||
|  |         ? getDefaults(resolvedSchema) | ||||||
|  |         : getSchema(resolvedSchema); | ||||||
|  |       return { contents, warnings: [] }; | ||||||
|  |     }); | ||||||
|  |   }, | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export default jsonSchemaPlugin; | ||||||
							
								
								
									
										107
									
								
								.esbuild/server.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								.esbuild/server.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,107 @@ | |||||||
|  | import express from 'express'; | ||||||
|  | import type { NextFunction, Request, Response } from 'express'; | ||||||
|  | import cors from 'cors'; | ||||||
|  | import { getBuildConfig, defaultOptions } from './util.js'; | ||||||
|  | import { context } from 'esbuild'; | ||||||
|  | import chokidar from 'chokidar'; | ||||||
|  |  | ||||||
|  | const mermaidCtx = await context( | ||||||
|  |   getBuildConfig({ ...defaultOptions, minify: false, core: false, entryName: 'mermaid' }), | ||||||
|  | ); | ||||||
|  | const mermaidIIFECtx = await context( | ||||||
|  |   getBuildConfig({ | ||||||
|  |     ...defaultOptions, | ||||||
|  |     minify: false, | ||||||
|  |     core: false, | ||||||
|  |     entryName: 'mermaid', | ||||||
|  |     format: 'iife', | ||||||
|  |   }), | ||||||
|  | ); | ||||||
|  | const externalCtx = await context( | ||||||
|  |   getBuildConfig({ | ||||||
|  |     ...defaultOptions, | ||||||
|  |     minify: false, | ||||||
|  |     core: false, | ||||||
|  |     entryName: 'mermaid-example-diagram', | ||||||
|  |   }), | ||||||
|  | ); | ||||||
|  | const zenumlCtx = await context( | ||||||
|  |   getBuildConfig({ ...defaultOptions, minify: false, core: false, entryName: 'mermaid-zenuml' }), | ||||||
|  | ); | ||||||
|  | const contexts = [mermaidCtx, mermaidIIFECtx, externalCtx, zenumlCtx]; | ||||||
|  |  | ||||||
|  | const rebuildAll = async () => { | ||||||
|  |   console.time('Rebuild time'); | ||||||
|  |   await Promise.all(contexts.map((ctx) => ctx.rebuild())); | ||||||
|  |   console.timeEnd('Rebuild time'); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | let clients: { id: number; response: Response }[] = []; | ||||||
|  | function eventsHandler(request: Request, response: Response, next: NextFunction) { | ||||||
|  |   const headers = { | ||||||
|  |     'Content-Type': 'text/event-stream', | ||||||
|  |     Connection: 'keep-alive', | ||||||
|  |     'Cache-Control': 'no-cache', | ||||||
|  |   }; | ||||||
|  |   response.writeHead(200, headers); | ||||||
|  |   const clientId = Date.now(); | ||||||
|  |   clients.push({ | ||||||
|  |     id: clientId, | ||||||
|  |     response, | ||||||
|  |   }); | ||||||
|  |   request.on('close', () => { | ||||||
|  |     clients = clients.filter((client) => client.id !== clientId); | ||||||
|  |   }); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | let timeoutId: NodeJS.Timeout | undefined = undefined; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Debounce file change events to avoid rebuilding multiple times. | ||||||
|  |  */ | ||||||
|  | function handleFileChange() { | ||||||
|  |   if (timeoutId !== undefined) { | ||||||
|  |     clearTimeout(timeoutId); | ||||||
|  |   } | ||||||
|  |   timeoutId = setTimeout(async () => { | ||||||
|  |     await rebuildAll(); | ||||||
|  |     sendEventsToAll(); | ||||||
|  |     timeoutId = undefined; | ||||||
|  |   }, 100); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function sendEventsToAll() { | ||||||
|  |   clients.forEach(({ response }) => response.write(`data: ${Date.now()}\n\n`)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | async function createServer() { | ||||||
|  |   handleFileChange(); | ||||||
|  |   const app = express(); | ||||||
|  |   chokidar | ||||||
|  |     .watch('**/src/**/*.{js,ts,yaml,json}', { | ||||||
|  |       ignoreInitial: true, | ||||||
|  |       ignored: [/node_modules/, /dist/, /docs/, /coverage/], | ||||||
|  |     }) | ||||||
|  |     .on('all', async (event, path) => { | ||||||
|  |       // Ignore other events. | ||||||
|  |       if (!['add', 'change'].includes(event)) { | ||||||
|  |         return; | ||||||
|  |       } | ||||||
|  |       console.log(`${path} changed. Rebuilding...`); | ||||||
|  |       handleFileChange(); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |   app.use(cors()); | ||||||
|  |   app.get('/events', eventsHandler); | ||||||
|  |   app.use(express.static('./packages/mermaid/dist')); | ||||||
|  |   app.use(express.static('./packages/mermaid-zenuml/dist')); | ||||||
|  |   app.use(express.static('./packages/mermaid-example-diagram/dist')); | ||||||
|  |   app.use(express.static('demos')); | ||||||
|  |   app.use(express.static('cypress/platform')); | ||||||
|  |  | ||||||
|  |   app.listen(9000, () => { | ||||||
|  |     console.log(`Listening on http://localhost:9000`); | ||||||
|  |   }); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | createServer(); | ||||||
							
								
								
									
										98
									
								
								.esbuild/util.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										98
									
								
								.esbuild/util.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,98 @@ | |||||||
|  | import { resolve } from 'path'; | ||||||
|  | import { fileURLToPath } from 'url'; | ||||||
|  | import type { BuildOptions } from 'esbuild'; | ||||||
|  | import { readFileSync } from 'fs'; | ||||||
|  | import jsonSchemaPlugin from './jsonSchemaPlugin.js'; | ||||||
|  | import { packageOptions } from '../.build/common.js'; | ||||||
|  | import { jisonPlugin } from './jisonPlugin.js'; | ||||||
|  |  | ||||||
|  | const __dirname = fileURLToPath(new URL('.', import.meta.url)); | ||||||
|  |  | ||||||
|  | export interface MermaidBuildOptions { | ||||||
|  |   minify: boolean; | ||||||
|  |   core: boolean; | ||||||
|  |   metafile: boolean; | ||||||
|  |   format: 'esm' | 'iife'; | ||||||
|  |   entryName: keyof typeof packageOptions; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export const defaultOptions: Omit<MermaidBuildOptions, 'entryName'> = { | ||||||
|  |   minify: false, | ||||||
|  |   metafile: false, | ||||||
|  |   core: false, | ||||||
|  |   format: 'esm', | ||||||
|  | } as const; | ||||||
|  |  | ||||||
|  | const buildOptions = (override: BuildOptions): BuildOptions => { | ||||||
|  |   return { | ||||||
|  |     bundle: true, | ||||||
|  |     minify: true, | ||||||
|  |     keepNames: true, | ||||||
|  |     platform: 'browser', | ||||||
|  |     tsconfig: 'tsconfig.json', | ||||||
|  |     resolveExtensions: ['.ts', '.js', '.json', '.jison', '.yaml'], | ||||||
|  |     external: ['require', 'fs', 'path'], | ||||||
|  |     outdir: 'dist', | ||||||
|  |     plugins: [jisonPlugin, jsonSchemaPlugin], | ||||||
|  |     sourcemap: 'external', | ||||||
|  |     ...override, | ||||||
|  |   }; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const getFileName = (fileName: string, { core, format, minify }: MermaidBuildOptions) => { | ||||||
|  |   if (core) { | ||||||
|  |     fileName += '.core'; | ||||||
|  |   } else if (format === 'esm') { | ||||||
|  |     fileName += '.esm'; | ||||||
|  |   } | ||||||
|  |   if (minify) { | ||||||
|  |     fileName += '.min'; | ||||||
|  |   } | ||||||
|  |   return fileName; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export const getBuildConfig = (options: MermaidBuildOptions): BuildOptions => { | ||||||
|  |   const { core, entryName, metafile, format, minify } = options; | ||||||
|  |   const external: string[] = ['require', 'fs', 'path']; | ||||||
|  |   const { name, file, packageName } = packageOptions[entryName]; | ||||||
|  |   const outFileName = getFileName(name, options); | ||||||
|  |   let output: BuildOptions = buildOptions({ | ||||||
|  |     absWorkingDir: resolve(__dirname, `../packages/${packageName}`), | ||||||
|  |     entryPoints: { | ||||||
|  |       [outFileName]: `src/${file}`, | ||||||
|  |     }, | ||||||
|  |     metafile, | ||||||
|  |     minify, | ||||||
|  |     logLevel: 'info', | ||||||
|  |     chunkNames: `chunks/${outFileName}/[name]-[hash]`, | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   if (core) { | ||||||
|  |     const { dependencies } = JSON.parse( | ||||||
|  |       readFileSync(resolve(__dirname, `../packages/${packageName}/package.json`), 'utf-8'), | ||||||
|  |     ); | ||||||
|  |     // Core build is used to generate file without bundled dependencies. | ||||||
|  |     // This is used by downstream projects to bundle dependencies themselves. | ||||||
|  |     // Ignore dependencies and any dependencies of dependencies | ||||||
|  |     external.push(...Object.keys(dependencies)); | ||||||
|  |     output.external = external; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   if (format === 'iife') { | ||||||
|  |     output.format = 'iife'; | ||||||
|  |     output.splitting = false; | ||||||
|  |     output.globalName = '__esbuild_esm_mermaid'; | ||||||
|  |     // Workaround for removing the .default access in esbuild IIFE. | ||||||
|  |     // https://github.com/mermaid-js/mermaid/pull/4109#discussion_r1292317396 | ||||||
|  |     output.footer = { | ||||||
|  |       js: 'globalThis.mermaid = globalThis.__esbuild_esm_mermaid.default;', | ||||||
|  |     }; | ||||||
|  |     output.outExtension = { '.js': '.js' }; | ||||||
|  |   } else { | ||||||
|  |     output.format = 'esm'; | ||||||
|  |     output.splitting = true; | ||||||
|  |     output.outExtension = { '.js': '.mjs' }; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return output; | ||||||
|  | }; | ||||||
| @@ -48,6 +48,8 @@ module.exports = { | |||||||
|     'no-prototype-builtins': 'off', |     'no-prototype-builtins': 'off', | ||||||
|     'no-unused-vars': 'off', |     'no-unused-vars': 'off', | ||||||
|     'cypress/no-async-tests': 'off', |     'cypress/no-async-tests': 'off', | ||||||
|  |     '@typescript-eslint/no-unused-vars': 'warn', | ||||||
|  |     '@typescript-eslint/no-explicit-any': 'warn', | ||||||
|     '@typescript-eslint/no-floating-promises': 'error', |     '@typescript-eslint/no-floating-promises': 'error', | ||||||
|     '@typescript-eslint/no-misused-promises': 'error', |     '@typescript-eslint/no-misused-promises': 'error', | ||||||
|     '@typescript-eslint/ban-ts-comment': [ |     '@typescript-eslint/ban-ts-comment': [ | ||||||
|   | |||||||
							
								
								
									
										15
									
								
								.github/workflows/e2e.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										15
									
								
								.github/workflows/e2e.yml
									
									
									
									
										vendored
									
									
								
							| @@ -30,7 +30,7 @@ jobs: | |||||||
|       # Install NPM dependencies, cache them correctly |       # Install NPM dependencies, cache them correctly | ||||||
|       # and run all Cypress tests |       # and run all Cypress tests | ||||||
|       - name: Cypress run |       - name: Cypress run | ||||||
|         uses: cypress-io/github-action@v4 |         uses: cypress-io/github-action@v6 | ||||||
|         id: cypress |         id: cypress | ||||||
|         # If CYPRESS_RECORD_KEY is set, run in parallel on all containers |         # If CYPRESS_RECORD_KEY is set, run in parallel on all containers | ||||||
|         # Otherwise (e.g. if running from fork), we run on a single container only |         # Otherwise (e.g. if running from fork), we run on a single container only | ||||||
| @@ -44,14 +44,19 @@ jobs: | |||||||
|           parallel: ${{ secrets.CYPRESS_RECORD_KEY != '' }} |           parallel: ${{ secrets.CYPRESS_RECORD_KEY != '' }} | ||||||
|         env: |         env: | ||||||
|           CYPRESS_RECORD_KEY: ${{ secrets.CYPRESS_RECORD_KEY }} |           CYPRESS_RECORD_KEY: ${{ secrets.CYPRESS_RECORD_KEY }} | ||||||
|           VITEST_COVERAGE: true |           VITE_COVERAGE: true | ||||||
|  |           CYPRESS_COVERAGE: true | ||||||
|           CYPRESS_COMMIT: ${{ github.sha }} |           CYPRESS_COMMIT: ${{ github.sha }} | ||||||
|  |  | ||||||
|  |       - name: Check coverage files | ||||||
|  |         run: | | ||||||
|  |           ls -lh ./coverage | ||||||
|  |           ls -lh ./coverage/cypress | ||||||
|  |  | ||||||
|       - name: Upload Coverage to Codecov |       - name: Upload Coverage to Codecov | ||||||
|         uses: codecov/codecov-action@v3 |         uses: codecov/codecov-action@v3 | ||||||
|         # Run step only pushes to develop and pull_requests |  | ||||||
|         if: ${{ steps.cypress.conclusion == 'success' && (github.event_name == 'pull_request' || github.ref == 'refs/heads/develop')}} |  | ||||||
|         with: |         with: | ||||||
|           files: coverage/cypress/lcov.info |           files: ./coverage/cypress/lcov.info | ||||||
|           flags: e2e |           flags: e2e | ||||||
|           name: mermaid-codecov |           name: mermaid-codecov | ||||||
|           fail_ci_if_error: false |           fail_ci_if_error: false | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							| @@ -43,8 +43,6 @@ jobs: | |||||||
|  |  | ||||||
|       - name: Upload Coverage to Codecov |       - name: Upload Coverage to Codecov | ||||||
|         uses: codecov/codecov-action@v3 |         uses: codecov/codecov-action@v3 | ||||||
|         # Run step only pushes to develop and pull_requests |  | ||||||
|         if: ${{ github.event_name == 'pull_request' || github.ref == 'refs/heads/develop' }} |  | ||||||
|         with: |         with: | ||||||
|           files: ./coverage/vitest/lcov.info |           files: ./coverage/vitest/lcov.info | ||||||
|           flags: unit |           flags: unit | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -46,3 +46,4 @@ stats/ | |||||||
|  |  | ||||||
| demos/dev/** | demos/dev/** | ||||||
| !/demos/dev/example.html | !/demos/dev/example.html | ||||||
|  | !/demos/dev/reload.js | ||||||
|   | |||||||
| @@ -3,11 +3,11 @@ import { resolve } from 'path'; | |||||||
| import { fileURLToPath } from 'url'; | import { fileURLToPath } from 'url'; | ||||||
| import jisonPlugin from './jisonPlugin.js'; | import jisonPlugin from './jisonPlugin.js'; | ||||||
| import jsonSchemaPlugin from './jsonSchemaPlugin.js'; | import jsonSchemaPlugin from './jsonSchemaPlugin.js'; | ||||||
| import { readFileSync } from 'fs'; |  | ||||||
| import typescript from '@rollup/plugin-typescript'; | import typescript from '@rollup/plugin-typescript'; | ||||||
| import { visualizer } from 'rollup-plugin-visualizer'; | import { visualizer } from 'rollup-plugin-visualizer'; | ||||||
| import type { TemplateType } from 'rollup-plugin-visualizer/dist/plugin/template-types.js'; | import type { TemplateType } from 'rollup-plugin-visualizer/dist/plugin/template-types.js'; | ||||||
| import istanbul from 'vite-plugin-istanbul'; | import istanbul from 'vite-plugin-istanbul'; | ||||||
|  | import { packageOptions } from '../.build/common.js'; | ||||||
|  |  | ||||||
| const visualize = process.argv.includes('--visualize'); | const visualize = process.argv.includes('--visualize'); | ||||||
| const watch = process.argv.includes('--watch'); | const watch = process.argv.includes('--watch'); | ||||||
| @@ -32,28 +32,10 @@ const visualizerOptions = (packageName: string, core = false): PluginOption[] => | |||||||
|         template: chartType as TemplateType, |         template: chartType as TemplateType, | ||||||
|         gzipSize: true, |         gzipSize: true, | ||||||
|         brotliSize: true, |         brotliSize: true, | ||||||
|       }) as PluginOption |       }) as PluginOption, | ||||||
|   ); |   ); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| const packageOptions = { |  | ||||||
|   mermaid: { |  | ||||||
|     name: 'mermaid', |  | ||||||
|     packageName: 'mermaid', |  | ||||||
|     file: 'mermaid.ts', |  | ||||||
|   }, |  | ||||||
|   'mermaid-example-diagram': { |  | ||||||
|     name: 'mermaid-example-diagram', |  | ||||||
|     packageName: 'mermaid-example-diagram', |  | ||||||
|     file: 'detector.ts', |  | ||||||
|   }, |  | ||||||
|   'mermaid-zenuml': { |  | ||||||
|     name: 'mermaid-zenuml', |  | ||||||
|     packageName: 'mermaid-zenuml', |  | ||||||
|     file: 'detector.ts', |  | ||||||
|   }, |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| interface BuildOptions { | interface BuildOptions { | ||||||
|   minify: boolean | 'esbuild'; |   minify: boolean | 'esbuild'; | ||||||
|   core?: boolean; |   core?: boolean; | ||||||
| @@ -72,34 +54,8 @@ export const getBuildConfig = ({ minify, core, watch, entryName }: BuildOptions) | |||||||
|       sourcemap, |       sourcemap, | ||||||
|       entryFileNames: `${name}.esm${minify ? '.min' : ''}.mjs`, |       entryFileNames: `${name}.esm${minify ? '.min' : ''}.mjs`, | ||||||
|     }, |     }, | ||||||
|     { |  | ||||||
|       name, |  | ||||||
|       format: 'umd', |  | ||||||
|       sourcemap, |  | ||||||
|       entryFileNames: `${name}${minify ? '.min' : ''}.js`, |  | ||||||
|     }, |  | ||||||
|   ]; |   ]; | ||||||
|  |  | ||||||
|   if (core) { |  | ||||||
|     const { dependencies } = JSON.parse( |  | ||||||
|       readFileSync(resolve(__dirname, `../packages/${packageName}/package.json`), 'utf-8') |  | ||||||
|     ); |  | ||||||
|     // Core build is used to generate file without bundled dependencies. |  | ||||||
|     // This is used by downstream projects to bundle dependencies themselves. |  | ||||||
|     // Ignore dependencies and any dependencies of dependencies |  | ||||||
|     // Adapted from the RegEx used by `rollup-plugin-node` |  | ||||||
|     external.push(new RegExp('^(?:' + Object.keys(dependencies).join('|') + ')(?:/.+)?$')); |  | ||||||
|     // This needs to be an array. Otherwise vite will build esm & umd with same name and overwrite esm with umd. |  | ||||||
|     output = [ |  | ||||||
|       { |  | ||||||
|         name, |  | ||||||
|         format: 'esm', |  | ||||||
|         sourcemap, |  | ||||||
|         entryFileNames: `${name}.core.mjs`, |  | ||||||
|       }, |  | ||||||
|     ]; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   const config: InlineConfig = { |   const config: InlineConfig = { | ||||||
|     configFile: false, |     configFile: false, | ||||||
|     build: { |     build: { | ||||||
| @@ -146,8 +102,6 @@ export const getBuildConfig = ({ minify, core, watch, entryName }: BuildOptions) | |||||||
|  |  | ||||||
| const buildPackage = async (entryName: keyof typeof packageOptions) => { | const buildPackage = async (entryName: keyof typeof packageOptions) => { | ||||||
|   await build(getBuildConfig({ minify: false, entryName })); |   await build(getBuildConfig({ minify: false, entryName })); | ||||||
|   await build(getBuildConfig({ minify: 'esbuild', entryName })); |  | ||||||
|   await build(getBuildConfig({ minify: false, core: true, entryName })); |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| const main = async () => { | const main = async () => { | ||||||
|   | |||||||
| @@ -1,10 +1,10 @@ | |||||||
| import { transformJison } from './jisonTransformer.js'; | import { transformJison } from '../.build/jisonTransformer.js'; | ||||||
|  |  | ||||||
| const fileRegex = /\.(jison)$/; | const fileRegex = /\.(jison)$/; | ||||||
|  |  | ||||||
| export default function jison() { | export default function jison() { | ||||||
|   return { |   return { | ||||||
|     name: 'jison', |     name: 'jison', | ||||||
|  |  | ||||||
|     transform(src: string, id: string) { |     transform(src: string, id: string) { | ||||||
|       if (fileRegex.test(id)) { |       if (fileRegex.test(id)) { | ||||||
|         return { |         return { | ||||||
|   | |||||||
| @@ -1,108 +1,5 @@ | |||||||
| import { load, JSON_SCHEMA } from 'js-yaml'; |  | ||||||
| import assert from 'node:assert'; |  | ||||||
| import Ajv2019, { type JSONSchemaType } from 'ajv/dist/2019.js'; |  | ||||||
| import { PluginOption } from 'vite'; | import { PluginOption } from 'vite'; | ||||||
|  | import { getDefaults, getSchema, loadSchema } from '../.build/jsonSchema.js'; | ||||||
| import type { MermaidConfig, BaseDiagramConfig } from '../packages/mermaid/src/config.type.js'; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * All of the keys in the mermaid config that have a mermaid diagram config. |  | ||||||
|  */ |  | ||||||
| const MERMAID_CONFIG_DIAGRAM_KEYS = [ |  | ||||||
|   'flowchart', |  | ||||||
|   'sequence', |  | ||||||
|   'gantt', |  | ||||||
|   'journey', |  | ||||||
|   'class', |  | ||||||
|   'state', |  | ||||||
|   'er', |  | ||||||
|   'pie', |  | ||||||
|   'quadrantChart', |  | ||||||
|   'requirement', |  | ||||||
|   'mindmap', |  | ||||||
|   'timeline', |  | ||||||
|   'gitGraph', |  | ||||||
|   'c4', |  | ||||||
|   'sankey', |  | ||||||
| ] as const; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Generate default values from the JSON Schema. |  | ||||||
|  * |  | ||||||
|  * AJV does not support nested default values yet (or default values with $ref), |  | ||||||
|  * so we need to manually find them (this may be fixed in ajv v9). |  | ||||||
|  * |  | ||||||
|  * @param mermaidConfigSchema - The Mermaid JSON Schema to use. |  | ||||||
|  * @returns The default mermaid config object. |  | ||||||
|  */ |  | ||||||
| function generateDefaults(mermaidConfigSchema: JSONSchemaType<MermaidConfig>) { |  | ||||||
|   const ajv = new Ajv2019({ |  | ||||||
|     useDefaults: true, |  | ||||||
|     allowUnionTypes: true, |  | ||||||
|     strict: true, |  | ||||||
|   }); |  | ||||||
|  |  | ||||||
|   ajv.addKeyword({ |  | ||||||
|     keyword: 'meta:enum', // used by jsonschema2md |  | ||||||
|     errors: false, |  | ||||||
|   }); |  | ||||||
|   ajv.addKeyword({ |  | ||||||
|     keyword: 'tsType', // used by json-schema-to-typescript |  | ||||||
|     errors: false, |  | ||||||
|   }); |  | ||||||
|  |  | ||||||
|   // ajv currently doesn't support nested default values, see https://github.com/ajv-validator/ajv/issues/1718 |  | ||||||
|   // (may be fixed in v9) so we need to manually use sub-schemas |  | ||||||
|   const mermaidDefaultConfig = {}; |  | ||||||
|  |  | ||||||
|   assert.ok(mermaidConfigSchema.$defs); |  | ||||||
|   const baseDiagramConfig = mermaidConfigSchema.$defs.BaseDiagramConfig; |  | ||||||
|  |  | ||||||
|   for (const key of MERMAID_CONFIG_DIAGRAM_KEYS) { |  | ||||||
|     const subSchemaRef = mermaidConfigSchema.properties[key].$ref; |  | ||||||
|     const [root, defs, defName] = subSchemaRef.split('/'); |  | ||||||
|     assert.strictEqual(root, '#'); |  | ||||||
|     assert.strictEqual(defs, '$defs'); |  | ||||||
|     const subSchema = { |  | ||||||
|       $schema: mermaidConfigSchema.$schema, |  | ||||||
|       $defs: mermaidConfigSchema.$defs, |  | ||||||
|       ...mermaidConfigSchema.$defs[defName], |  | ||||||
|     } as JSONSchemaType<BaseDiagramConfig>; |  | ||||||
|  |  | ||||||
|     const validate = ajv.compile(subSchema); |  | ||||||
|  |  | ||||||
|     mermaidDefaultConfig[key] = {}; |  | ||||||
|  |  | ||||||
|     for (const required of subSchema.required ?? []) { |  | ||||||
|       if (subSchema.properties[required] === undefined && baseDiagramConfig.properties[required]) { |  | ||||||
|         mermaidDefaultConfig[key][required] = baseDiagramConfig.properties[required].default; |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|     if (!validate(mermaidDefaultConfig[key])) { |  | ||||||
|       throw new Error( |  | ||||||
|         `schema for subconfig ${key} does not have valid defaults! Errors were ${JSON.stringify( |  | ||||||
|           validate.errors, |  | ||||||
|           undefined, |  | ||||||
|           2 |  | ||||||
|         )}` |  | ||||||
|       ); |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   const validate = ajv.compile(mermaidConfigSchema); |  | ||||||
|  |  | ||||||
|   if (!validate(mermaidDefaultConfig)) { |  | ||||||
|     throw new Error( |  | ||||||
|       `Mermaid config JSON Schema does not have valid defaults! Errors were ${JSON.stringify( |  | ||||||
|         validate.errors, |  | ||||||
|         undefined, |  | ||||||
|         2 |  | ||||||
|       )}` |  | ||||||
|     ); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   return mermaidDefaultConfig; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Vite plugin that handles JSON Schemas saved as a `.schema.yaml` file. |  * Vite plugin that handles JSON Schemas saved as a `.schema.yaml` file. | ||||||
| @@ -119,32 +16,13 @@ export default function jsonSchemaPlugin(): PluginOption { | |||||||
|         return; |         return; | ||||||
|       } |       } | ||||||
|  |  | ||||||
|       if (idAsUrl.searchParams.get('only-defaults')) { |       const jsonSchema = loadSchema(src, idAsUrl.pathname); | ||||||
|         const jsonSchema = load(src, { |       return { | ||||||
|           filename: idAsUrl.pathname, |         code: idAsUrl.searchParams.get('only-defaults') | ||||||
|           // only allow JSON types in our YAML doc (will probably be default in YAML 1.3) |           ? getDefaults(jsonSchema) | ||||||
|           // e.g. `true` will be parsed a boolean `true`, `True` will be parsed as string `"True"`. |           : getSchema(jsonSchema), | ||||||
|           schema: JSON_SCHEMA, |         map: null, // no source map | ||||||
|         }) as JSONSchemaType<MermaidConfig>; |       }; | ||||||
|         return { |  | ||||||
|           code: `export default ${JSON.stringify(generateDefaults(jsonSchema), undefined, 2)};`, |  | ||||||
|           map: null, // no source map |  | ||||||
|         }; |  | ||||||
|       } else { |  | ||||||
|         return { |  | ||||||
|           code: `export default ${JSON.stringify( |  | ||||||
|             load(src, { |  | ||||||
|               filename: idAsUrl.pathname, |  | ||||||
|               // only allow JSON types in our YAML doc (will probably be default in YAML 1.3) |  | ||||||
|               // e.g. `true` will be parsed a boolean `true`, `True` will be parsed as string `"True"`. |  | ||||||
|               schema: JSON_SCHEMA, |  | ||||||
|             }), |  | ||||||
|             undefined, |  | ||||||
|             2 |  | ||||||
|           )};`, |  | ||||||
|           map: null, // provide source map if available |  | ||||||
|         }; |  | ||||||
|       } |  | ||||||
|     }, |     }, | ||||||
|   }; |   }; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -57,6 +57,7 @@ | |||||||
|     "gzipped", |     "gzipped", | ||||||
|     "huynh", |     "huynh", | ||||||
|     "huynhicode", |     "huynhicode", | ||||||
|  |     "iife", | ||||||
|     "inkdrop", |     "inkdrop", | ||||||
|     "jaoude", |     "jaoude", | ||||||
|     "jgreywolf", |     "jgreywolf", | ||||||
| @@ -81,6 +82,7 @@ | |||||||
|     "mdbook", |     "mdbook", | ||||||
|     "mermaidjs", |     "mermaidjs", | ||||||
|     "mermerd", |     "mermerd", | ||||||
|  |     "metafile", | ||||||
|     "mindaugas", |     "mindaugas", | ||||||
|     "mindmap", |     "mindmap", | ||||||
|     "mindmaps", |     "mindmaps", | ||||||
| @@ -93,6 +95,7 @@ | |||||||
|     "nikolay", |     "nikolay", | ||||||
|     "nirname", |     "nirname", | ||||||
|     "orlandoni", |     "orlandoni", | ||||||
|  |     "outdir", | ||||||
|     "pathe", |     "pathe", | ||||||
|     "pbrolin", |     "pbrolin", | ||||||
|     "phpbb", |     "phpbb", | ||||||
|   | |||||||
							
								
								
									
										11
									
								
								cypress/integration/other/iife.spec.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								cypress/integration/other/iife.spec.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | |||||||
|  | describe('IIFE', () => { | ||||||
|  |   beforeEach(() => { | ||||||
|  |     cy.visit('http://localhost:9000/iife.html'); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('should render when using mermaid.min.js', () => { | ||||||
|  |     cy.window().should('have.property', 'rendered', true); | ||||||
|  |     cy.get('svg').should('be.visible'); | ||||||
|  |     cy.get('#d2').should('contain', 'Hello'); | ||||||
|  |   }); | ||||||
|  | }); | ||||||
| @@ -1,16 +0,0 @@ | |||||||
| describe('Sequencediagram', () => { |  | ||||||
|   it('should render a simple sequence diagrams', () => { |  | ||||||
|     const url = 'http://localhost:9000/webpackUsage.html'; |  | ||||||
|  |  | ||||||
|     cy.visit(url); |  | ||||||
|     cy.get('body').find('svg').should('have.length', 1); |  | ||||||
|   }); |  | ||||||
|   it('should handle html escapings properly', () => { |  | ||||||
|     const url = 'http://localhost:9000/webpackUsage.html?test-html-escaping=true'; |  | ||||||
|  |  | ||||||
|     cy.visit(url); |  | ||||||
|     cy.get('body').find('svg').should('have.length', 1); |  | ||||||
|  |  | ||||||
|     cy.get('g.label > foreignobject > div').should('not.contain.text', '<b>'); |  | ||||||
|   }); |  | ||||||
| }); |  | ||||||
| @@ -1,7 +1,7 @@ | |||||||
| <html> | <html> | ||||||
|   <head> |   <head> | ||||||
|     <meta charset="utf-8" /> |     <meta charset="utf-8" /> | ||||||
|     <script src="./viewer.js" type="module"></script> |     <script type="module" src="./viewer.js"></script> | ||||||
|     <link |     <link | ||||||
|       href="https://fonts.googleapis.com/css?family=Noto+Sans+SC&display=swap" |       href="https://fonts.googleapis.com/css?family=Noto+Sans+SC&display=swap" | ||||||
|       rel="stylesheet" |       rel="stylesheet" | ||||||
|   | |||||||
| @@ -11,8 +11,7 @@ example-diagram | |||||||
|     <!-- <script src="//cdn.jsdelivr.net/npm/mermaid@9.1.7/dist/mermaid.min.js"></script> --> |     <!-- <script src="//cdn.jsdelivr.net/npm/mermaid@9.1.7/dist/mermaid.min.js"></script> --> | ||||||
|     <!-- <script type="module" src="./external-diagrams-mindmap.mjs" /> --> |     <!-- <script type="module" src="./external-diagrams-mindmap.mjs" /> --> | ||||||
|     <script type="module"> |     <script type="module"> | ||||||
|       import exampleDiagram from '../../packages/mermaid-example-diagram/dist/mermaid-example-diagram.core.mjs'; |       import exampleDiagram from './mermaid-example-diagram.esm.mjs'; | ||||||
|       // import example from '../../packages/mermaid-example-diagram/src/detector'; |  | ||||||
|       import mermaid from './mermaid.esm.mjs'; |       import mermaid from './mermaid.esm.mjs'; | ||||||
|  |  | ||||||
|       await mermaid.registerExternalDiagrams([exampleDiagram]); |       await mermaid.registerExternalDiagrams([exampleDiagram]); | ||||||
|   | |||||||
							
								
								
									
										29
									
								
								cypress/platform/iife.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								cypress/platform/iife.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | |||||||
|  | <html> | ||||||
|  |   <body> | ||||||
|  |     <pre id="diagram" class="mermaid"> | ||||||
|  | graph TB | ||||||
|  |       a --> b | ||||||
|  |       a --> c | ||||||
|  |       b --> d | ||||||
|  |       c --> d | ||||||
|  |     </pre> | ||||||
|  |  | ||||||
|  |     <div id="d2"></div> | ||||||
|  |  | ||||||
|  |     <script src="/mermaid.min.js"></script> | ||||||
|  |     <script> | ||||||
|  |       mermaid.initialize({ | ||||||
|  |         startOnLoad: true, | ||||||
|  |       }); | ||||||
|  |       const value = `graph TD\nHello --> World`; | ||||||
|  |       const el = document.getElementById('d2'); | ||||||
|  |       mermaid.render('did', value).then(({ svg }) => { | ||||||
|  |         console.log(svg); | ||||||
|  |         el.innerHTML = svg; | ||||||
|  |         if (window.Cypress) { | ||||||
|  |           window.rendered = true; | ||||||
|  |         } | ||||||
|  |       }); | ||||||
|  |     </script> | ||||||
|  |   </body> | ||||||
|  | </html> | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| <!DOCTYPE html> | <!doctype html> | ||||||
| <html> | <html> | ||||||
|   <head> |   <head> | ||||||
|     <meta charset="utf-8" /> |     <meta charset="utf-8" /> | ||||||
| @@ -17,20 +17,20 @@ | |||||||
|     graph TB |     graph TB | ||||||
|       Function-->URL |       Function-->URL | ||||||
|       click Function clickByFlow "Add a div" |       click Function clickByFlow "Add a div" | ||||||
|       click URL "http://localhost:9000/webpackUsage.html" "Visit <strong>mermaid docs</strong>" |       click URL "http://localhost:9000/info.html" "Visit <strong>mermaid docs</strong>" | ||||||
|       </pre> |       </pre> | ||||||
|       <pre id="FirstLine" class="mermaid2"> |       <pre id="FirstLine" class="mermaid2"> | ||||||
|   graph TB |   graph TB | ||||||
|     1Function-->2URL |     1Function-->2URL | ||||||
|     click 1Function clickByFlow "Add a div" |     click 1Function clickByFlow "Add a div" | ||||||
|     click 2URL "http://localhost:9000/webpackUsage.html" "Visit <strong>mermaid docs</strong>" |     click 2URL "http://localhost:9000/info.html" "Visit <strong>mermaid docs</strong>" | ||||||
|       </pre> |       </pre> | ||||||
|  |  | ||||||
|       <pre id="FirstLine" class="mermaid2"> |       <pre id="FirstLine" class="mermaid2"> | ||||||
|   classDiagram |   classDiagram | ||||||
|     class Test |     class Test | ||||||
|     class ShapeLink |     class ShapeLink | ||||||
|     link ShapeLink "http://localhost:9000/webpackUsage.html" "This is a tooltip for a link" |     link ShapeLink "http://localhost:9000/info.html" "This is a tooltip for a link" | ||||||
|     class ShapeCallback |     class ShapeCallback | ||||||
|     callback ShapeCallback "clickByClass" "This is a tooltip for a callback" |     callback ShapeCallback "clickByClass" "This is a tooltip for a callback" | ||||||
|       </pre> |       </pre> | ||||||
| @@ -42,7 +42,7 @@ | |||||||
|       <pre id="FirstLine" class="mermaid"> |       <pre id="FirstLine" class="mermaid"> | ||||||
|   classDiagram-v2 |   classDiagram-v2 | ||||||
|     class ShapeLink |     class ShapeLink | ||||||
|     link ShapeLink "http://localhost:9000/webpackUsage.html" "This is a tooltip for a link" |     link ShapeLink "http://localhost:9000/info.html" "This is a tooltip for a link" | ||||||
|       </pre> |       </pre> | ||||||
|     </div> |     </div> | ||||||
|  |  | ||||||
| @@ -77,7 +77,7 @@ | |||||||
|     Calling a Callback (look at the console log) :cl2, after cl1, 3d |     Calling a Callback (look at the console log) :cl2, after cl1, 3d | ||||||
|     Calling a Callback with args :cl3, after cl1, 3d |     Calling a Callback with args :cl3, after cl1, 3d | ||||||
|  |  | ||||||
|     click cl1 href "http://localhost:9000/webpackUsage.html" |     click cl1 href "http://localhost:9000/info.html" | ||||||
|     click cl2 call clickByGantt() |     click cl2 call clickByGantt() | ||||||
|     click cl3 call clickByGantt("test1", test2, test3) |     click cl3 call clickByGantt("test1", test2, test3) | ||||||
|  |  | ||||||
| @@ -102,9 +102,15 @@ | |||||||
|         div.className = 'created-by-gant-click'; |         div.className = 'created-by-gant-click'; | ||||||
|         div.style = 'padding: 20px; background: green; color: white;'; |         div.style = 'padding: 20px; background: green; color: white;'; | ||||||
|         div.innerText = 'Clicked By Gant'; |         div.innerText = 'Clicked By Gant'; | ||||||
|         if (arg1) div.innerText += ' ' + arg1; |         if (arg1) { | ||||||
|         if (arg2) div.innerText += ' ' + arg2; |           div.innerText += ' ' + arg1; | ||||||
|         if (arg3) div.innerText += ' ' + arg3; |         } | ||||||
|  |         if (arg2) { | ||||||
|  |           div.innerText += ' ' + arg2; | ||||||
|  |         } | ||||||
|  |         if (arg3) { | ||||||
|  |           div.innerText += ' ' + arg3; | ||||||
|  |         } | ||||||
|  |  | ||||||
|         document.getElementsByTagName('body')[0].appendChild(div); |         document.getElementsByTagName('body')[0].appendChild(div); | ||||||
|       } |       } | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| import mermaid2 from './mermaid.esm.mjs'; | import mermaid from './mermaid.esm.mjs'; | ||||||
| import externalExample from '../../packages/mermaid-example-diagram/dist/mermaid-example-diagram.core.mjs'; | import externalExample from './mermaid-example-diagram.esm.mjs'; | ||||||
| import zenUml from '../../packages/mermaid-zenuml/dist/mermaid-zenuml.core.mjs'; | import zenUml from './mermaid-zenuml.esm.mjs'; | ||||||
|  |  | ||||||
| function b64ToUtf8(str) { | function b64ToUtf8(str) { | ||||||
|   return decodeURIComponent(escape(window.atob(str))); |   return decodeURIComponent(escape(window.atob(str))); | ||||||
| @@ -45,9 +45,9 @@ const contentLoaded = async function () { | |||||||
|       document.getElementsByTagName('body')[0].appendChild(div); |       document.getElementsByTagName('body')[0].appendChild(div); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     await mermaid2.registerExternalDiagrams([externalExample, zenUml]); |     await mermaid.registerExternalDiagrams([externalExample, zenUml]); | ||||||
|     mermaid2.initialize(graphObj.mermaid); |     mermaid.initialize(graphObj.mermaid); | ||||||
|     await mermaid2.run(); |     await mermaid.run(); | ||||||
|   } |   } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -95,18 +95,14 @@ const contentLoadedApi = async function () { | |||||||
|         divs[i] = div; |         divs[i] = div; | ||||||
|       } |       } | ||||||
|  |  | ||||||
|       const defaultE2eCnf = { theme: 'forest' }; |       const defaultE2eCnf = { theme: 'forest', startOnLoad: false }; | ||||||
|  |  | ||||||
|       const cnf = merge(defaultE2eCnf, graphObj.mermaid); |       const cnf = merge(defaultE2eCnf, graphObj.mermaid); | ||||||
|  |  | ||||||
|       mermaid2.initialize(cnf); |       mermaid.initialize(cnf); | ||||||
|  |  | ||||||
|       for (let i = 0; i < numCodes; i++) { |       for (let i = 0; i < numCodes; i++) { | ||||||
|         const { svg, bindFunctions } = await mermaid2.render( |         const { svg, bindFunctions } = await mermaid.render('newid' + i, graphObj.code[i], divs[i]); | ||||||
|           'newid' + i, |  | ||||||
|           graphObj.code[i], |  | ||||||
|           divs[i] |  | ||||||
|         ); |  | ||||||
|         div.innerHTML = svg; |         div.innerHTML = svg; | ||||||
|         bindFunctions(div); |         bindFunctions(div); | ||||||
|       } |       } | ||||||
| @@ -114,18 +110,21 @@ const contentLoadedApi = async function () { | |||||||
|       const div = document.createElement('div'); |       const div = document.createElement('div'); | ||||||
|       div.id = 'block'; |       div.id = 'block'; | ||||||
|       div.className = 'mermaid'; |       div.className = 'mermaid'; | ||||||
|       console.warn('graphObj.mermaid', graphObj.mermaid); |       console.warn('graphObj', graphObj); | ||||||
|       document.getElementsByTagName('body')[0].appendChild(div); |       document.getElementsByTagName('body')[0].appendChild(div); | ||||||
|       mermaid2.initialize(graphObj.mermaid); |       mermaid.initialize(graphObj.mermaid); | ||||||
|  |       const { svg, bindFunctions } = await mermaid.render('newid', graphObj.code, div); | ||||||
|       const { svg, bindFunctions } = await mermaid2.render('newid', graphObj.code, div); |  | ||||||
|       div.innerHTML = svg; |       div.innerHTML = svg; | ||||||
|  |       console.log(div.innerHTML); | ||||||
|       bindFunctions(div); |       bindFunctions(div); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| if (typeof document !== 'undefined') { | if (typeof document !== 'undefined') { | ||||||
|  |   mermaid.initialize({ | ||||||
|  |     startOnLoad: false, | ||||||
|  |   }); | ||||||
|   /*! |   /*! | ||||||
|    * Wait for document loaded before starting the execution |    * Wait for document loaded before starting the execution | ||||||
|    */ |    */ | ||||||
| @@ -140,6 +139,6 @@ if (typeof document !== 'undefined') { | |||||||
|         void contentLoaded().finally(markRendered); |         void contentLoaded().finally(markRendered); | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     false |     false, | ||||||
|   ); |   ); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,19 +0,0 @@ | |||||||
| <!DOCTYPE html> |  | ||||||
| <html> |  | ||||||
|   <head> |  | ||||||
|     <style> |  | ||||||
|       /* .mermaid { |  | ||||||
|     font-family: "trebuchet ms", verdana, arial;; |  | ||||||
|   } */ |  | ||||||
|       /* .mermaid { |  | ||||||
|     font-family: 'arial'; |  | ||||||
|   } */ |  | ||||||
|     </style> |  | ||||||
|   </head> |  | ||||||
|   <body> |  | ||||||
|     <div id="graph-to-be"></div> |  | ||||||
|     <script type="module" charset="utf-8"> |  | ||||||
|       import './bundle-test.js'; |  | ||||||
|     </script> |  | ||||||
|   </body> |  | ||||||
| </html> |  | ||||||
| @@ -1,6 +1,5 @@ | |||||||
| <html> | <html> | ||||||
|   <head> |   <head> | ||||||
|     <script src="./viewer.js" type="module"></script> |  | ||||||
|     <link href="https://fonts.googleapis.com/css?family=Montserrat&display=swap" rel="stylesheet" /> |     <link href="https://fonts.googleapis.com/css?family=Montserrat&display=swap" rel="stylesheet" /> | ||||||
|     <style> |     <style> | ||||||
|       .malware { |       .malware { | ||||||
| @@ -33,12 +32,6 @@ | |||||||
|     </script> |     </script> | ||||||
|   </head> |   </head> | ||||||
|   <body> |   <body> | ||||||
|     <script type="module"> |     <script type="module" src="./viewer.js"></script> | ||||||
|       import mermaid from './mermaid.esm.mjs'; |  | ||||||
|       mermaid.initialize({ |  | ||||||
|         startOnLoad: false, |  | ||||||
|         useMaxWidth: true, |  | ||||||
|       }); |  | ||||||
|     </script> |  | ||||||
|   </body> |   </body> | ||||||
| </html> | </html> | ||||||
|   | |||||||
| @@ -5,6 +5,8 @@ | |||||||
|     <title>Mermaid development page</title> |     <title>Mermaid development page</title> | ||||||
|   </head> |   </head> | ||||||
|   <body> |   <body> | ||||||
|  |     <pre class="mermaid">info</pre> | ||||||
|  |  | ||||||
|     <pre id="diagram" class="mermaid"> |     <pre id="diagram" class="mermaid"> | ||||||
| graph TB | graph TB | ||||||
|       a --> b |       a --> b | ||||||
| @@ -30,5 +32,7 @@ graph TB | |||||||
|       console.log(svg); |       console.log(svg); | ||||||
|       el.innerHTML = svg; |       el.innerHTML = svg; | ||||||
|     </script> |     </script> | ||||||
|  |  | ||||||
|  |     <script src="/dev/reload.js"></script> | ||||||
|   </body> |   </body> | ||||||
| </html> | </html> | ||||||
|   | |||||||
							
								
								
									
										22
									
								
								demos/dev/reload.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								demos/dev/reload.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | |||||||
|  | // Connect to the server and reload the page if the server sends a reload message | ||||||
|  | const connectToEvents = () => { | ||||||
|  |   const events = new EventSource('/events'); | ||||||
|  |   const loadTime = Date.now(); | ||||||
|  |   events.onmessage = (event) => { | ||||||
|  |     const time = JSON.parse(event.data); | ||||||
|  |     if (time && time > loadTime) { | ||||||
|  |       location.reload(); | ||||||
|  |     } | ||||||
|  |   }; | ||||||
|  |   events.onerror = (error) => { | ||||||
|  |     console.error(error); | ||||||
|  |     events.close(); | ||||||
|  |     // Try to reconnect after 1 second in case of errors | ||||||
|  |     setTimeout(connectToEvents, 1000); | ||||||
|  |   }; | ||||||
|  |   events.onopen = () => { | ||||||
|  |     console.log('Connected to live reload server'); | ||||||
|  |   }; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | setTimeout(connectToEvents, 500); | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| <!DOCTYPE html> | <!doctype html> | ||||||
| <html lang="en"> | <html lang="en"> | ||||||
|   <head> |   <head> | ||||||
|     <meta charset="utf-8" /> |     <meta charset="utf-8" /> | ||||||
| @@ -37,7 +37,7 @@ | |||||||
|     </pre> |     </pre> | ||||||
|  |  | ||||||
|     <script type="module"> |     <script type="module"> | ||||||
|       import mermaid from './mermaid.esm.mjs'; |       import mermaid from '/mermaid.esm.mjs'; | ||||||
|       mermaid.initialize({ |       mermaid.initialize({ | ||||||
|         theme: 'forest', |         theme: 'forest', | ||||||
|         logLevel: 3, |         logLevel: 3, | ||||||
|   | |||||||
| @@ -64,7 +64,7 @@ Example: | |||||||
|  |  | ||||||
| ```html | ```html | ||||||
| <script type="module"> | <script type="module"> | ||||||
|   import mermaid from 'https://cdn.jsdelivr.net/npm/mermaid@10/dist/mermaid.esm.min.mjs'; |   import mermaid from 'https://cdn.jsdelivr.net/npm/mermaid@11/dist/mermaid.esm.min.mjs'; | ||||||
| </script> | </script> | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| @@ -83,7 +83,7 @@ Example: | |||||||
|       B-->D(fa:fa-spinner); |       B-->D(fa:fa-spinner); | ||||||
|     </pre> |     </pre> | ||||||
|     <script type="module"> |     <script type="module"> | ||||||
|       import mermaid from 'https://cdn.jsdelivr.net/npm/mermaid@10/dist/mermaid.esm.min.mjs'; |       import mermaid from 'https://cdn.jsdelivr.net/npm/mermaid@11/dist/mermaid.esm.min.mjs'; | ||||||
|     </script> |     </script> | ||||||
|   </body> |   </body> | ||||||
| </html> | </html> | ||||||
|   | |||||||
| @@ -289,7 +289,7 @@ To select a version: | |||||||
|  |  | ||||||
| Replace `<version>` with the desired version number. | Replace `<version>` with the desired version number. | ||||||
|  |  | ||||||
| Latest Version: <https://cdn.jsdelivr.net/npm/mermaid@10> | Latest Version: <https://cdn.jsdelivr.net/npm/mermaid@11> | ||||||
|  |  | ||||||
| ## Deploying Mermaid | ## Deploying Mermaid | ||||||
|  |  | ||||||
| @@ -307,7 +307,7 @@ To Deploy Mermaid: | |||||||
|  |  | ||||||
| ```html | ```html | ||||||
| <script type="module"> | <script type="module"> | ||||||
|   import mermaid from 'https://cdn.jsdelivr.net/npm/mermaid@10/dist/mermaid.esm.min.mjs'; |   import mermaid from 'https://cdn.jsdelivr.net/npm/mermaid@11/dist/mermaid.esm.min.mjs'; | ||||||
|   mermaid.initialize({ startOnLoad: true }); |   mermaid.initialize({ startOnLoad: true }); | ||||||
| </script> | </script> | ||||||
| ``` | ``` | ||||||
|   | |||||||
| @@ -128,7 +128,7 @@ b. The importing of mermaid library through the `mermaid.esm.mjs` or `mermaid.es | |||||||
| ```html | ```html | ||||||
| <body> | <body> | ||||||
|   <script type="module"> |   <script type="module"> | ||||||
|     import mermaid from 'https://cdn.jsdelivr.net/npm/mermaid@10/dist/mermaid.esm.min.mjs'; |     import mermaid from 'https://cdn.jsdelivr.net/npm/mermaid@11/dist/mermaid.esm.min.mjs'; | ||||||
|     mermaid.initialize({ startOnLoad: true }); |     mermaid.initialize({ startOnLoad: true }); | ||||||
|   </script> |   </script> | ||||||
| </body> | </body> | ||||||
| @@ -168,7 +168,7 @@ Rendering in Mermaid is initialized by `mermaid.initialize()` call. However, doi | |||||||
|     </pre> |     </pre> | ||||||
|  |  | ||||||
|     <script type="module"> |     <script type="module"> | ||||||
|       import mermaid from 'https://cdn.jsdelivr.net/npm/mermaid@10/dist/mermaid.esm.min.mjs'; |       import mermaid from 'https://cdn.jsdelivr.net/npm/mermaid@11/dist/mermaid.esm.min.mjs'; | ||||||
|       mermaid.initialize({ startOnLoad: true }); |       mermaid.initialize({ startOnLoad: true }); | ||||||
|     </script> |     </script> | ||||||
|   </body> |   </body> | ||||||
|   | |||||||
| @@ -300,7 +300,7 @@ From version 9.4.0 you can simplify this code to: | |||||||
|  |  | ||||||
| ```html | ```html | ||||||
| <script type="module"> | <script type="module"> | ||||||
|   import mermaid from 'https://cdn.jsdelivr.net/npm/mermaid@10/dist/mermaid.esm.min.mjs'; |   import mermaid from 'https://cdn.jsdelivr.net/npm/mermaid@11/dist/mermaid.esm.min.mjs'; | ||||||
| </script> | </script> | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|   | |||||||
| @@ -469,7 +469,7 @@ You can use this method to add mermaid including the timeline diagram to a web p | |||||||
|  |  | ||||||
| ```html | ```html | ||||||
| <script type="module"> | <script type="module"> | ||||||
|   import mermaid from 'https://cdn.jsdelivr.net/npm/mermaid@10/dist/mermaid.esm.min.mjs'; |   import mermaid from 'https://cdn.jsdelivr.net/npm/mermaid@11/dist/mermaid.esm.min.mjs'; | ||||||
| </script> | </script> | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										55
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										55
									
								
								package.json
									
									
									
									
									
								
							| @@ -15,14 +15,14 @@ | |||||||
|     "git graph" |     "git graph" | ||||||
|   ], |   ], | ||||||
|   "scripts": { |   "scripts": { | ||||||
|     "build:vite": "ts-node-esm --transpileOnly .vite/build.ts", |     "build": "pnpm run -r clean && pnpm build:esbuild && pnpm build:types", | ||||||
|     "build:mermaid": "pnpm build:vite --mermaid", |     "build:esbuild": "pnpm run -r clean && ts-node-esm --transpileOnly .esbuild/build.ts", | ||||||
|     "build:viz": "pnpm build:mermaid --visualize", |     "build:mermaid": "pnpm build:esbuild --mermaid", | ||||||
|  |     "build:viz": "pnpm build:esbuild --visualize", | ||||||
|     "build:types": "tsc -p ./packages/mermaid/tsconfig.json --emitDeclarationOnly && tsc -p ./packages/mermaid-zenuml/tsconfig.json --emitDeclarationOnly && tsc -p ./packages/mermaid-example-diagram/tsconfig.json --emitDeclarationOnly", |     "build:types": "tsc -p ./packages/mermaid/tsconfig.json --emitDeclarationOnly && tsc -p ./packages/mermaid-zenuml/tsconfig.json --emitDeclarationOnly && tsc -p ./packages/mermaid-example-diagram/tsconfig.json --emitDeclarationOnly", | ||||||
|     "build:watch": "pnpm build:vite --watch", |     "dev": "ts-node-esm --transpileOnly .esbuild/server.ts", | ||||||
|     "build": "pnpm run -r clean && pnpm build:types && pnpm build:vite", |     "dev:vite": "ts-node-esm --transpileOnly .vite/server.ts", | ||||||
|     "dev": "concurrently \"pnpm build:vite --watch\" \"ts-node-esm .vite/server.ts\"", |     "dev:coverage": "pnpm coverage:cypress:clean && VITE_COVERAGE=true pnpm dev:vite", | ||||||
|     "dev:coverage": "pnpm coverage:cypress:clean && VITE_COVERAGE=true pnpm dev", |  | ||||||
|     "release": "pnpm build", |     "release": "pnpm build", | ||||||
|     "lint": "eslint --cache --cache-strategy content --ignore-path .gitignore . && pnpm lint:jison && prettier --cache --check .", |     "lint": "eslint --cache --cache-strategy content --ignore-path .gitignore . && pnpm lint:jison && prettier --cache --check .", | ||||||
|     "lint:fix": "eslint --cache --cache-strategy content --fix --ignore-path .gitignore . && prettier --write . && ts-node-esm scripts/fixCSpell.ts", |     "lint:fix": "eslint --cache --cache-strategy content --fix --ignore-path .gitignore . && prettier --write . && ts-node-esm scripts/fixCSpell.ts", | ||||||
| @@ -31,8 +31,8 @@ | |||||||
|     "cypress": "cypress run", |     "cypress": "cypress run", | ||||||
|     "cypress:open": "cypress open", |     "cypress:open": "cypress open", | ||||||
|     "e2e": "start-server-and-test dev http://localhost:9000/ cypress", |     "e2e": "start-server-and-test dev http://localhost:9000/ cypress", | ||||||
|  |     "e2e:coverage": "start-server-and-test dev:coverage http://localhost:9000/ cypress", | ||||||
|     "coverage:cypress:clean": "rimraf .nyc_output coverage/cypress", |     "coverage:cypress:clean": "rimraf .nyc_output coverage/cypress", | ||||||
|     "e2e:coverage": "pnpm coverage:cypress:clean && VITE_COVERAGE=true pnpm e2e", |  | ||||||
|     "coverage:merge": "ts-node-esm scripts/coverage.ts", |     "coverage:merge": "ts-node-esm scripts/coverage.ts", | ||||||
|     "coverage": "pnpm test:coverage --run && pnpm e2e:coverage && pnpm coverage:merge", |     "coverage": "pnpm test:coverage --run && pnpm e2e:coverage && pnpm coverage:merge", | ||||||
|     "ci": "vitest run", |     "ci": "vitest run", | ||||||
| @@ -60,36 +60,37 @@ | |||||||
|     ] |     ] | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "@applitools/eyes-cypress": "^3.33.1", |     "@applitools/eyes-cypress": "^3.37.0", | ||||||
|     "@commitlint/cli": "^17.6.1", |     "@commitlint/cli": "^17.6.1", | ||||||
|     "@commitlint/config-conventional": "^17.6.1", |     "@commitlint/config-conventional": "^17.6.1", | ||||||
|     "@cspell/eslint-plugin": "^6.31.1", |     "@cspell/eslint-plugin": "^7.0.1", | ||||||
|     "@cypress/code-coverage": "^3.10.7", |     "@cypress/code-coverage": "^3.11.0", | ||||||
|     "@rollup/plugin-typescript": "^11.1.1", |     "@rollup/plugin-typescript": "^11.1.2", | ||||||
|     "@types/cors": "^2.8.13", |     "@types/cors": "^2.8.13", | ||||||
|     "@types/eslint": "^8.37.0", |     "@types/eslint": "^8.44.2", | ||||||
|     "@types/express": "^4.17.17", |     "@types/express": "^4.17.17", | ||||||
|     "@types/js-yaml": "^4.0.5", |     "@types/js-yaml": "^4.0.5", | ||||||
|     "@types/jsdom": "^21.1.1", |     "@types/jsdom": "^21.1.1", | ||||||
|     "@types/lodash": "^4.14.194", |     "@types/lodash": "^4.14.194", | ||||||
|     "@types/mdast": "^3.0.11", |     "@types/mdast": "^3.0.11", | ||||||
|     "@types/node": "^18.16.0", |     "@types/node": "^18.16.0", | ||||||
|     "@types/prettier": "^2.7.2", |     "@types/prettier": "^3.0.0", | ||||||
|     "@types/rollup-plugin-visualizer": "^4.2.1", |     "@types/rollup-plugin-visualizer": "^4.2.1", | ||||||
|     "@typescript-eslint/eslint-plugin": "^5.59.0", |     "@typescript-eslint/eslint-plugin": "^6.4.1", | ||||||
|     "@typescript-eslint/parser": "^5.59.0", |     "@typescript-eslint/parser": "^6.4.1", | ||||||
|     "@vitest/coverage-v8": "^0.34.0", |     "@vitest/coverage-v8": "^0.34.2", | ||||||
|     "@vitest/spy": "^0.34.0", |     "@vitest/spy": "^0.34.0", | ||||||
|     "@vitest/ui": "^0.34.0", |     "@vitest/ui": "^0.34.0", | ||||||
|     "ajv": "^8.12.0", |     "ajv": "^8.12.0", | ||||||
|  |     "chokidar": "^3.5.3", | ||||||
|     "concurrently": "^8.0.1", |     "concurrently": "^8.0.1", | ||||||
|     "cors": "^2.8.5", |     "cors": "^2.8.5", | ||||||
|     "cypress": "^12.10.0", |     "cypress": "^12.17.4", | ||||||
|     "cypress-image-snapshot": "^4.0.1", |     "cypress-image-snapshot": "^4.0.1", | ||||||
|     "esbuild": "^0.19.0", |     "esbuild": "^0.19.2", | ||||||
|     "eslint": "^8.39.0", |     "eslint": "^8.47.0", | ||||||
|     "eslint-config-prettier": "^8.8.0", |     "eslint-config-prettier": "^9.0.0", | ||||||
|     "eslint-plugin-cypress": "^2.13.2", |     "eslint-plugin-cypress": "^2.14.0", | ||||||
|     "eslint-plugin-html": "^7.1.0", |     "eslint-plugin-html": "^7.1.0", | ||||||
|     "eslint-plugin-jest": "^27.2.1", |     "eslint-plugin-jest": "^27.2.1", | ||||||
|     "eslint-plugin-jsdoc": "^46.0.0", |     "eslint-plugin-jsdoc": "^46.0.0", | ||||||
| @@ -110,16 +111,16 @@ | |||||||
|     "nyc": "^15.1.0", |     "nyc": "^15.1.0", | ||||||
|     "path-browserify": "^1.0.1", |     "path-browserify": "^1.0.1", | ||||||
|     "pnpm": "^8.6.8", |     "pnpm": "^8.6.8", | ||||||
|     "prettier": "^2.8.8", |     "prettier": "^3.0.2", | ||||||
|     "prettier-plugin-jsdoc": "^0.4.2", |     "prettier-plugin-jsdoc": "^0.4.2", | ||||||
|     "rimraf": "^5.0.0", |     "rimraf": "^5.0.0", | ||||||
|     "rollup-plugin-visualizer": "^5.9.2", |     "rollup-plugin-visualizer": "^5.9.2", | ||||||
|     "start-server-and-test": "^2.0.0", |     "start-server-and-test": "^2.0.0", | ||||||
|     "ts-node": "^10.9.1", |     "ts-node": "^10.9.1", | ||||||
|     "typescript": "^5.1.3", |     "typescript": "^5.1.6", | ||||||
|     "vite": "^4.3.9", |     "vite": "^4.4.9", | ||||||
|     "vite-plugin-istanbul": "^4.1.0", |     "vite-plugin-istanbul": "^5.0.0", | ||||||
|     "vitest": "^0.34.0" |     "vitest": "^0.34.2" | ||||||
|   }, |   }, | ||||||
|   "volta": { |   "volta": { | ||||||
|     "node": "18.17.1" |     "node": "18.17.1" | ||||||
|   | |||||||
| @@ -43,8 +43,7 @@ | |||||||
|     "cytoscape-cose-bilkent": "^4.1.0", |     "cytoscape-cose-bilkent": "^4.1.0", | ||||||
|     "cytoscape-fcose": "^2.1.0", |     "cytoscape-fcose": "^2.1.0", | ||||||
|     "d3": "^7.0.0", |     "d3": "^7.0.0", | ||||||
|     "khroma": "^2.0.0", |     "khroma": "^2.0.0" | ||||||
|     "non-layered-tidy-tree-layout": "^2.0.2" |  | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "@types/cytoscape": "^3.19.9", |     "@types/cytoscape": "^3.19.9", | ||||||
|   | |||||||
| @@ -19,6 +19,7 @@ | |||||||
|     "mermaid" |     "mermaid" | ||||||
|   ], |   ], | ||||||
|   "scripts": { |   "scripts": { | ||||||
|  |     "clean": "rimraf dist", | ||||||
|     "prepublishOnly": "pnpm -w run build" |     "prepublishOnly": "pnpm -w run build" | ||||||
|   }, |   }, | ||||||
|   "repository": { |   "repository": { | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "mermaid", |   "name": "mermaid", | ||||||
|   "version": "10.3.1", |   "version": "11.0.0-alpha.2", | ||||||
|   "description": "Markdown-ish syntax for generating flowcharts, sequence diagrams, class diagrams, gantt charts and git graphs.", |   "description": "Markdown-ish syntax for generating flowcharts, sequence diagrams, class diagrams, gantt charts and git graphs.", | ||||||
|   "type": "module", |   "type": "module", | ||||||
|   "module": "./dist/mermaid.core.mjs", |   "module": "./dist/mermaid.core.mjs", | ||||||
| @@ -60,8 +60,6 @@ | |||||||
|   }, |   }, | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@braintree/sanitize-url": "^6.0.1", |     "@braintree/sanitize-url": "^6.0.1", | ||||||
|     "@types/d3-scale": "^4.0.3", |  | ||||||
|     "@types/d3-scale-chromatic": "^3.0.0", |  | ||||||
|     "cytoscape": "^3.23.0", |     "cytoscape": "^3.23.0", | ||||||
|     "cytoscape-cose-bilkent": "^4.1.0", |     "cytoscape-cose-bilkent": "^4.1.0", | ||||||
|     "cytoscape-fcose": "^2.1.0", |     "cytoscape-fcose": "^2.1.0", | ||||||
| @@ -74,11 +72,9 @@ | |||||||
|     "khroma": "^2.0.0", |     "khroma": "^2.0.0", | ||||||
|     "lodash-es": "^4.17.21", |     "lodash-es": "^4.17.21", | ||||||
|     "mdast-util-from-markdown": "^1.3.0", |     "mdast-util-from-markdown": "^1.3.0", | ||||||
|     "non-layered-tidy-tree-layout": "^2.0.2", |  | ||||||
|     "stylis": "^4.1.3", |     "stylis": "^4.1.3", | ||||||
|     "ts-dedent": "^2.2.0", |     "ts-dedent": "^2.2.0", | ||||||
|     "uuid": "^9.0.0", |     "uuid": "^9.0.0" | ||||||
|     "web-worker": "^1.2.0" |  | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "@adobe/jsonschema2md": "^7.1.4", |     "@adobe/jsonschema2md": "^7.1.4", | ||||||
| @@ -86,6 +82,7 @@ | |||||||
|     "@types/d3": "^7.4.0", |     "@types/d3": "^7.4.0", | ||||||
|     "@types/d3-sankey": "^0.12.1", |     "@types/d3-sankey": "^0.12.1", | ||||||
|     "@types/d3-scale": "^4.0.3", |     "@types/d3-scale": "^4.0.3", | ||||||
|  |     "@types/d3-scale-chromatic": "^3.0.0", | ||||||
|     "@types/d3-selection": "^3.0.5", |     "@types/d3-selection": "^3.0.5", | ||||||
|     "@types/d3-shape": "^3.1.1", |     "@types/d3-shape": "^3.1.1", | ||||||
|     "@types/dompurify": "^3.0.2", |     "@types/dompurify": "^3.0.2", | ||||||
|   | |||||||
| @@ -24,6 +24,7 @@ import _Ajv2019, { type JSONSchemaType } from 'ajv/dist/2019.js'; | |||||||
|  |  | ||||||
| // Workaround for wrong AJV types, see | // Workaround for wrong AJV types, see | ||||||
| // https://github.com/ajv-validator/ajv/issues/2132#issuecomment-1290409907 | // https://github.com/ajv-validator/ajv/issues/2132#issuecomment-1290409907 | ||||||
|  | // @ts-ignore Incorrect types | ||||||
| const Ajv2019 = _Ajv2019 as unknown as typeof _Ajv2019.default; | const Ajv2019 = _Ajv2019 as unknown as typeof _Ajv2019.default; | ||||||
|  |  | ||||||
| // !!! -- The config.type.js file is created by this script -- !!! | // !!! -- The config.type.js file is created by this script -- !!! | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ | |||||||
| #   - `scripts/create-types-from-json-schema.mjs` | #   - `scripts/create-types-from-json-schema.mjs` | ||||||
| #     Used to generate the `src/config.type.ts` TypeScript types for MermaidConfig | #     Used to generate the `src/config.type.ts` TypeScript types for MermaidConfig | ||||||
| #     with the `json-schema-to-typescript` NPM package. | #     with the `json-schema-to-typescript` NPM package. | ||||||
| #   - `.vite/jsonSchemaPlugin.ts` | #   - `.build/jsonSchema.ts` | ||||||
| #     Used to generate the default values from the `default` keys in this | #     Used to generate the default values from the `default` keys in this | ||||||
| #     JSON Schema using the `ajv` NPM package. | #     JSON Schema using the `ajv` NPM package. | ||||||
| #     Non-JSON values, like functions or `undefined`, still need to be manually | #     Non-JSON values, like functions or `undefined`, still need to be manually | ||||||
| @@ -21,7 +21,7 @@ | |||||||
| # - Use `meta:enum` to document enum values (from jsonschema2md) | # - Use `meta:enum` to document enum values (from jsonschema2md) | ||||||
| # - Use `tsType` to override the TypeScript type (from json-schema-to-typescript) | # - Use `tsType` to override the TypeScript type (from json-schema-to-typescript) | ||||||
| # - If adding a new object to `MermaidConfig` (e.g. a new diagram type), | # - If adding a new object to `MermaidConfig` (e.g. a new diagram type), | ||||||
| #   you may need to add it to `.vite/jsonSchemaPlugin.ts` and `src/docs.mts` | #   you may need to add it to `.build/jsonSchema.ts` and `src/docs.mts` | ||||||
| #   to get the docs/default values to generate properly. | #   to get the docs/default values to generate properly. | ||||||
| $id: https://mermaid-js.github.io/schemas/config.schema.json | $id: https://mermaid-js.github.io/schemas/config.schema.json | ||||||
| $schema: https://json-schema.org/draft/2019-09/schema | $schema: https://json-schema.org/draft/2019-09/schema | ||||||
|   | |||||||
							
								
								
									
										1590
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										1590
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -5,20 +5,24 @@ | |||||||
|  * (i.e. the root of the Mermaid project). |  * (i.e. the root of the Mermaid project). | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| import { readFileSync, writeFileSync } from 'node:fs'; | import { readFile, writeFile } from 'node:fs/promises'; | ||||||
| import prettier from 'prettier'; | import prettier from 'prettier'; | ||||||
|  |  | ||||||
| const filepath = './cSpell.json'; | const main = async () => { | ||||||
| const cSpell: { words: string[] } = JSON.parse(readFileSync(filepath, 'utf8')); |   const filepath = './cSpell.json'; | ||||||
|  |   const cSpell: { words: string[] } = JSON.parse(await readFile(filepath, 'utf8')); | ||||||
|  |  | ||||||
| cSpell.words = [...new Set(cSpell.words.map((word) => word.toLowerCase()))]; |   cSpell.words = [...new Set(cSpell.words.map((word) => word.toLowerCase()))]; | ||||||
| cSpell.words.sort((a, b) => a.localeCompare(b)); |   cSpell.words.sort((a, b) => a.localeCompare(b)); | ||||||
|  |  | ||||||
| const prettierConfig = prettier.resolveConfig.sync(filepath) ?? {}; |   const prettierConfig = (await prettier.resolveConfig(filepath)) ?? {}; | ||||||
| writeFileSync( |   await writeFile( | ||||||
|   filepath, |  | ||||||
|   prettier.format(JSON.stringify(cSpell), { |  | ||||||
|     ...prettierConfig, |  | ||||||
|     filepath, |     filepath, | ||||||
|   }) |     await prettier.format(JSON.stringify(cSpell), { | ||||||
| ); |       ...prettierConfig, | ||||||
|  |       filepath, | ||||||
|  |     }), | ||||||
|  |   ); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | void main(); | ||||||
|   | |||||||
| @@ -5,5 +5,14 @@ | |||||||
|     // ensure that nobody can accidentally use this config for a build |     // ensure that nobody can accidentally use this config for a build | ||||||
|     "noEmit": true |     "noEmit": true | ||||||
|   }, |   }, | ||||||
|   "include": ["packages", "tests", "scripts", "cypress", "__mocks__", "./.eslintrc.cjs", "./*"] |   "include": [ | ||||||
|  |     "packages", | ||||||
|  |     "tests", | ||||||
|  |     "scripts", | ||||||
|  |     "cypress", | ||||||
|  |     "__mocks__", | ||||||
|  |     "./.eslintrc.cjs", | ||||||
|  |     "./*", | ||||||
|  |     "demos/dev" | ||||||
|  |   ] | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user