mirror of
https://github.com/mermaid-js/mermaid.git
synced 2025-09-17 14:29:48 +02:00
Fix for issue #895
This commit is contained in:
@@ -5,15 +5,29 @@
|
|||||||
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
||||||
<title>Mermaid Quick Test Page</title>
|
<title>Mermaid Quick Test Page</title>
|
||||||
<link rel="icon" type="image/png" href="">
|
<link rel="icon" type="image/png" href="">
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
font-family: 'trebuchet ms', verdana, arial;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<div id="FirstLine" class="mermaid">
|
<div class="mermaid">
|
||||||
graph TD
|
graph TD
|
||||||
A[Christmas] -->|Get money| B(Go shopping)
|
A[Christmas] -->|Get money| B(Go shopping)
|
||||||
subgraph 1test["Text"]
|
subgraph 1test["id starting with number"]
|
||||||
A
|
A
|
||||||
end
|
end
|
||||||
</div>
|
style 1test fill:#F99,stroke-width:2px,stroke:#F0F
|
||||||
|
</div>
|
||||||
|
<div class="mermaid">
|
||||||
|
graph TD
|
||||||
|
A[Christmas] -->|Get money| B(Go shopping)
|
||||||
|
subgraph test["id starting with number"]
|
||||||
|
A
|
||||||
|
end
|
||||||
|
style test fill:#F99,stroke-width:2px,stroke:#F0F
|
||||||
|
</div>
|
||||||
<script src="./mermaid.js"></script>
|
<script src="./mermaid.js"></script>
|
||||||
<script>
|
<script>
|
||||||
function showFullFirstSquad(elemName) {
|
function showFullFirstSquad(elemName) {
|
||||||
|
@@ -37,9 +37,9 @@ const sanitize = text => {
|
|||||||
* @param style
|
* @param style
|
||||||
* @param classes
|
* @param classes
|
||||||
*/
|
*/
|
||||||
export const addVertex = function (id, text, type, style, classes) {
|
export const addVertex = function (_id, text, type, style, classes) {
|
||||||
let txt
|
let txt
|
||||||
|
let id = _id
|
||||||
if (typeof id === 'undefined') {
|
if (typeof id === 'undefined') {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@@ -47,6 +47,8 @@ export const addVertex = function (id, text, type, style, classes) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (id[0].match(/\d/)) id = 's' + id
|
||||||
|
|
||||||
if (typeof vertices[id] === 'undefined') {
|
if (typeof vertices[id] === 'undefined') {
|
||||||
vertices[id] = { id: id, styles: [], classes: [] }
|
vertices[id] = { id: id, styles: [], classes: [] }
|
||||||
}
|
}
|
||||||
@@ -338,7 +340,12 @@ export const defaultStyle = function () {
|
|||||||
/**
|
/**
|
||||||
* Clears the internal graph db so that a new graph can be parsed.
|
* Clears the internal graph db so that a new graph can be parsed.
|
||||||
*/
|
*/
|
||||||
export const addSubGraph = function (id, list, title) {
|
export const addSubGraph = function (_id, list, _title) {
|
||||||
|
let id = _id
|
||||||
|
let title = _title
|
||||||
|
if (_id === _title && _title.match(/\s/)) {
|
||||||
|
id = undefined
|
||||||
|
}
|
||||||
function uniq (a) {
|
function uniq (a) {
|
||||||
const prims = { 'boolean': {}, 'number': {}, 'string': {} }
|
const prims = { 'boolean': {}, 'number': {}, 'string': {} }
|
||||||
const objs = []
|
const objs = []
|
||||||
@@ -357,7 +364,7 @@ export const addSubGraph = function (id, list, title) {
|
|||||||
nodeList = uniq(nodeList.concat.apply(nodeList, list))
|
nodeList = uniq(nodeList.concat.apply(nodeList, list))
|
||||||
|
|
||||||
id = id || ('subGraph' + subCount)
|
id = id || ('subGraph' + subCount)
|
||||||
id = 's' + id
|
if (id[0].match(/\d/)) id = 's' + id
|
||||||
title = title || ''
|
title = title || ''
|
||||||
title = sanitize(title)
|
title = sanitize(title)
|
||||||
subCount = subCount + 1
|
subCount = subCount + 1
|
||||||
|
@@ -251,12 +251,12 @@ statement
|
|||||||
{$$=[];}
|
{$$=[];}
|
||||||
| clickStatement separator
|
| clickStatement separator
|
||||||
{$$=[];}
|
{$$=[];}
|
||||||
| subgraph SPACE alphaNum SQS text SQE separator document end
|
| subgraph SPACE text SQS text SQE separator document end
|
||||||
{$$=yy.addSubGraph($3,$8,$5);}
|
{$$=yy.addSubGraph($3,$8,$5);}
|
||||||
| subgraph SPACE STR separator document end
|
| subgraph SPACE text separator document end
|
||||||
{$$=yy.addSubGraph(undefined,$5,$3);}
|
|
||||||
| subgraph SPACE alphaNum separator document end
|
|
||||||
{$$=yy.addSubGraph($3,$5,$3);}
|
{$$=yy.addSubGraph($3,$5,$3);}
|
||||||
|
// | subgraph SPACE text separator document end
|
||||||
|
// {$$=yy.addSubGraph($3,$5,$3);}
|
||||||
| subgraph separator document end
|
| subgraph separator document end
|
||||||
{$$=yy.addSubGraph(undefined,$3,undefined);}
|
{$$=yy.addSubGraph(undefined,$3,undefined);}
|
||||||
;
|
;
|
||||||
|
@@ -71,7 +71,7 @@ describe('when parsing subgraphs', function () {
|
|||||||
const subgraph = subgraphs[0]
|
const subgraph = subgraphs[0]
|
||||||
expect(subgraph.nodes.length).toBe(1)
|
expect(subgraph.nodes.length).toBe(1)
|
||||||
expect(subgraph.nodes[0]).toBe('A')
|
expect(subgraph.nodes[0]).toBe('A')
|
||||||
expect(subgraph.id).toBe('1test')
|
expect(subgraph.id).toBe('s1test')
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should handle subgraphs1', function () {
|
it('should handle subgraphs1', function () {
|
||||||
@@ -82,6 +82,93 @@ describe('when parsing subgraphs', function () {
|
|||||||
|
|
||||||
expect(edges[0].type).toBe('arrow')
|
expect(edges[0].type).toBe('arrow')
|
||||||
})
|
})
|
||||||
|
it('should handle subgraphs with title in quotes', function () {
|
||||||
|
const res = flow.parser.parse('graph TD;A-->B;subgraph "title in quotes";c-->d;end;')
|
||||||
|
|
||||||
|
const vert = flow.parser.yy.getVertices()
|
||||||
|
const edges = flow.parser.yy.getEdges()
|
||||||
|
|
||||||
|
const subgraphs = flow.parser.yy.getSubGraphs()
|
||||||
|
expect(subgraphs.length).toBe(1)
|
||||||
|
const subgraph = subgraphs[0]
|
||||||
|
|
||||||
|
expect(subgraph.title).toBe('title in quotes')
|
||||||
|
|
||||||
|
expect(edges[0].type).toBe('arrow')
|
||||||
|
})
|
||||||
|
it('should handle subgraphs in old style that was broken', function () {
|
||||||
|
const res = flow.parser.parse('graph TD;A-->B;subgraph old style that is broken;c-->d;end;')
|
||||||
|
|
||||||
|
const vert = flow.parser.yy.getVertices()
|
||||||
|
const edges = flow.parser.yy.getEdges()
|
||||||
|
|
||||||
|
const subgraphs = flow.parser.yy.getSubGraphs()
|
||||||
|
expect(subgraphs.length).toBe(1)
|
||||||
|
const subgraph = subgraphs[0]
|
||||||
|
|
||||||
|
expect(subgraph.title).toBe('old style that is broken')
|
||||||
|
|
||||||
|
expect(edges[0].type).toBe('arrow')
|
||||||
|
})
|
||||||
|
it('should handle subgraphs with dashes in the title', function () {
|
||||||
|
const res = flow.parser.parse('graph TD;A-->B;subgraph a-b-c;c-->d;end;')
|
||||||
|
|
||||||
|
const vert = flow.parser.yy.getVertices()
|
||||||
|
const edges = flow.parser.yy.getEdges()
|
||||||
|
|
||||||
|
const subgraphs = flow.parser.yy.getSubGraphs()
|
||||||
|
expect(subgraphs.length).toBe(1)
|
||||||
|
const subgraph = subgraphs[0]
|
||||||
|
|
||||||
|
expect(subgraph.title).toBe('a-b-c')
|
||||||
|
|
||||||
|
expect(edges[0].type).toBe('arrow')
|
||||||
|
})
|
||||||
|
it('should handle subgraphs with id and title in brackets', function () {
|
||||||
|
const res = flow.parser.parse('graph TD;A-->B;subgraph uid1[text of doom];c-->d;end;')
|
||||||
|
|
||||||
|
const vert = flow.parser.yy.getVertices()
|
||||||
|
const edges = flow.parser.yy.getEdges()
|
||||||
|
|
||||||
|
const subgraphs = flow.parser.yy.getSubGraphs()
|
||||||
|
expect(subgraphs.length).toBe(1)
|
||||||
|
const subgraph = subgraphs[0]
|
||||||
|
|
||||||
|
expect(subgraph.title).toBe('text of doom')
|
||||||
|
expect(subgraph.id).toBe('uid1')
|
||||||
|
|
||||||
|
expect(edges[0].type).toBe('arrow')
|
||||||
|
})
|
||||||
|
it('should handle subgraphs with id and title in brackets and quotes', function () {
|
||||||
|
const res = flow.parser.parse('graph TD;A-->B;subgraph uid2["text of doom"];c-->d;end;')
|
||||||
|
|
||||||
|
const vert = flow.parser.yy.getVertices()
|
||||||
|
const edges = flow.parser.yy.getEdges()
|
||||||
|
|
||||||
|
const subgraphs = flow.parser.yy.getSubGraphs()
|
||||||
|
expect(subgraphs.length).toBe(1)
|
||||||
|
const subgraph = subgraphs[0]
|
||||||
|
|
||||||
|
expect(subgraph.title).toBe('text of doom')
|
||||||
|
expect(subgraph.id).toBe('uid2')
|
||||||
|
|
||||||
|
expect(edges[0].type).toBe('arrow')
|
||||||
|
})
|
||||||
|
it('should handle subgraphs with id and title in brackets without spaces', function () {
|
||||||
|
const res = flow.parser.parse('graph TD;A-->B;subgraph uid2[textofdoom];c-->d;end;')
|
||||||
|
|
||||||
|
const vert = flow.parser.yy.getVertices()
|
||||||
|
const edges = flow.parser.yy.getEdges()
|
||||||
|
|
||||||
|
const subgraphs = flow.parser.yy.getSubGraphs()
|
||||||
|
expect(subgraphs.length).toBe(1)
|
||||||
|
const subgraph = subgraphs[0]
|
||||||
|
|
||||||
|
expect(subgraph.title).toBe('textofdoom')
|
||||||
|
expect(subgraph.id).toBe('uid2')
|
||||||
|
|
||||||
|
expect(edges[0].type).toBe('arrow')
|
||||||
|
})
|
||||||
|
|
||||||
it('should handle subgraphs2', function () {
|
it('should handle subgraphs2', function () {
|
||||||
const res = flow.parser.parse('graph TD\nA-->B\nsubgraph myTitle\n\n c-->d \nend\n')
|
const res = flow.parser.parse('graph TD\nA-->B\nsubgraph myTitle\n\n c-->d \nend\n')
|
||||||
|
Reference in New Issue
Block a user