@likec4/generators 0.35.0 → 0.37.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.d.ts CHANGED
@@ -1,4 +1,5 @@
1
1
  export { generateReact } from './react/generate-react';
2
2
  export { generateD2 } from './d2/generate-d2';
3
+ export { generateMermaid } from './mmd/generate-mmd';
3
4
  export { generateViewsDataTs } from './views-data-ts/generate-views-data';
4
5
  //# sourceMappingURL=index.d.ts.map
package/dist/index.js CHANGED
@@ -1,3 +1,4 @@
1
1
  export { generateReact } from './react/generate-react';
2
2
  export { generateD2 } from './d2/generate-d2';
3
+ export { generateMermaid } from './mmd/generate-mmd';
3
4
  export { generateViewsDataTs } from './views-data-ts/generate-views-data';
@@ -0,0 +1,3 @@
1
+ import type { ComputedView } from '@likec4/core/types';
2
+ export declare function generateMermaid<V extends ComputedView>(view: V): string;
3
+ //# sourceMappingURL=generate-mmd.d.ts.map
@@ -0,0 +1,62 @@
1
+ import { CompositeGeneratorNode, NL, joinToNode, toString } from 'langium';
2
+ import { isNil } from 'rambdax';
3
+ const capitalizeFirstLetter = (value) => value.charAt(0).toLocaleUpperCase() + value.slice(1);
4
+ const fqnName = (nodeId) => nodeId.split('.').map(capitalizeFirstLetter).join('');
5
+ const nodeName = (node) => {
6
+ return fqnName(node.parent ? node.id.slice(node.parent.length + 1) : node.id);
7
+ };
8
+ const mmdshape = ({ shape }) => {
9
+ switch (shape) {
10
+ case 'queue':
11
+ case 'cylinder':
12
+ return ['[(', ')]'];
13
+ case 'person': {
14
+ return ['[fa:fa-user ', ']'];
15
+ }
16
+ case 'storage':
17
+ return ['([', '])'];
18
+ case 'mobile':
19
+ case 'browser':
20
+ case 'rectangle': {
21
+ return ['[', ']'];
22
+ }
23
+ }
24
+ };
25
+ export function generateMermaid(view) {
26
+ const { nodes, edges } = view;
27
+ const names = new Map();
28
+ const printNode = (node, parentName) => {
29
+ const name = nodeName(node);
30
+ const fqnName = (parentName ? parentName + '.' : '') + name;
31
+ names.set(node.id, fqnName);
32
+ const label = node.title.replaceAll('\n', '\\n');
33
+ const shape = mmdshape(node);
34
+ const baseNode = new CompositeGeneratorNode();
35
+ if (node.children.length > 0) {
36
+ baseNode
37
+ .append('subgraph ', fqnName, '["', label, '"]', NL)
38
+ .indent({
39
+ indentedChildren: indent => indent.appendIf(node.children.length > 0, NL, joinToNode(nodes.filter(n => n.parent === node.id), n => printNode(n, fqnName))),
40
+ indentation: 2
41
+ })
42
+ .append('end', NL);
43
+ }
44
+ else {
45
+ baseNode.append(fqnName, shape[0], label, shape[1], NL);
46
+ }
47
+ return baseNode;
48
+ };
49
+ // return `${names.get(edge.source)} -> ${names.get(edge.target)}${edge.label ? ': ' + edge.label : ''}`
50
+ const printEdge = (edge) => {
51
+ return new CompositeGeneratorNode().append(names.get(edge.source), ' --', edge.label ? '"' + edge.label.replaceAll('\n', '\\n') + '"--' : '', '> ', names.get(edge.target));
52
+ };
53
+ return toString(new CompositeGeneratorNode()
54
+ .appendIf(view.title !== null && view.title.length > 0, '---', NL, `title: ${view.title}`, NL, '---', NL)
55
+ .append('graph ', view.autoLayout, NL, NL)
56
+ .append(joinToNode(nodes.filter(n => isNil(n.parent)), n => printNode(n), {
57
+ appendNewLineIfNotEmpty: true
58
+ }))
59
+ .appendIf(edges.length > 0, NL, joinToNode(edges, e => printEdge(e), {
60
+ appendNewLineIfNotEmpty: true
61
+ })));
62
+ }
@@ -0,0 +1,2 @@
1
+ export * from './generate-mmd';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ export * from './generate-mmd';
@@ -25,7 +25,7 @@ export function generateReact(views) {
25
25
  ******************************************************************************/
26
26
  /* eslint-disable */
27
27
 
28
- import type { DiagramView } from '@likec4/core'
28
+ import type { DiagramView } from '@likec4/diagrams'
29
29
  import { LikeC4 } from '@likec4/diagrams'
30
30
  `.append(NL, NL);
31
31
  if (components.length == 0) {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@likec4/generators",
3
- "version": "0.35.0",
3
+ "version": "0.37.0",
4
4
  "license": "MIT",
5
5
  "bugs": "https://github.com/likec4/likec4/issues",
6
6
  "homepage": "https://likec4.dev",
@@ -38,7 +38,7 @@
38
38
  "test:watch": "run -T vitest"
39
39
  },
40
40
  "dependencies": {
41
- "@likec4/core": "0.35.0",
41
+ "@likec4/core": "0.37.0",
42
42
  "json5": "^2.2.3",
43
43
  "langium": "^2.0.2",
44
44
  "rambdax": "^9.1.1"