@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 +1 -0
- package/dist/index.js +1 -0
- package/dist/mmd/generate-mmd.d.ts +3 -0
- package/dist/mmd/generate-mmd.js +62 -0
- package/dist/mmd/index.d.ts +2 -0
- package/dist/mmd/index.js +1 -0
- package/dist/react/generate-react.js +1 -1
- package/package.json +2 -2
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
|
@@ -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 @@
|
|
|
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/
|
|
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.
|
|
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.
|
|
41
|
+
"@likec4/core": "0.37.0",
|
|
42
42
|
"json5": "^2.2.3",
|
|
43
43
|
"langium": "^2.0.2",
|
|
44
44
|
"rambdax": "^9.1.1"
|