A simple utility to convert a CASA Plan into mermaid flowchart notation, which can be then used in webpages alongside mermaid.js or in the live editor.
npm install casa-mermaidplan -g
or as a dependency:
npm install casa-mermaidplan --save
Usage: mermaidplan [opts]
Available options:
-p/--plan
Path to plan file, file must export a Plan or a function that returns a Plan.
-l/--labels
Label graph edges with route condition function names.
-d/--direction
Direction of graph, must be either:
TB - top to bottom
TD - top-down, same as top to bottom
BT - bottom to top
RL - right to left
LR - left to right
-t/--title
Set title for graph
-h/--help
Print this menu.
For the following plan:
// plan.js
'use strict'
const { Plan } = require('@dwp/govuk-casa')
const plan = new Plan({})
plan.addSequence('page-a', 'page-b', 'page-c')
plan.setRoute('page-c', 'page-d', function yes (r, c) {
return c.data['page-c'].field === 'yes'
})
plan.setRoute('page-c', 'page-e', function no (r, c) {
return c.data['page-c'].field === 'no'
})
module.exports = plan
mermaidplan -p plan.js
will output:
flowchart LR
page-a --> page-b
page-b --> page-c
page-c --> page-d
page-c --> page-e
flowchart LR
page-a --> page-b
page-b --> page-c
page-c --> page-d
page-c --> page-e
You can also label the graph edges with route condition function names:
mermaidplan -p plan.js -l
flowchart LR
page-a --> page-b
page-b --> page-c
page-c -->|yes| page-d
page-c -->|no| page-e
flowchart LR
page-a --> page-b
page-b --> page-c
page-c -->|yes| page-d
page-c -->|no| page-e
Set the graph direction:
mermaidplan -p plan.js -l -d td
flowchart TD
page-a --> page-b
page-b --> page-c
page-c -->|yes| page-d
page-c -->|no| page-e
flowchart TD
page-a --> page-b
page-b --> page-c
page-c -->|yes| page-d
page-c -->|no| page-e
Set the graph title:
mermaidplan -p plan.js -t "My journey"
---
title: My journey
---
flowchart TD
page-a --> page-b
page-b --> page-c
page-c -->|yes| page-d
page-c -->|no| page-e
---
title: My journey
---
flowchart TD
page-a --> page-b
page-b --> page-c
page-c -->|yes| page-d
page-c -->|no| page-e
Or redirect the stdout into a file:
mermaidplan -p plan.js > plan.mmd
Combined with the mermaid-cli tool, you can produce SVG flowcharts straight from the command line:
mermaidplan -p plan.js | mmdc -o plan.svg
planToMermaid(plan[, showLabels, direction, title]);
plan
a CASA Plan or function that returns a PlanshowLabels
boolean value, show edge labelsdirection
string, set direction of flowchart: TB, TD, BT, RL or LRtitle
string, title of the graph
'use strict'
const planToMermaid = require('casa-mermaidplan')
const plan = require('./plan.js')
const notationLeftRight = planToMermaid(plan)
// flowchart LR
// page-a --> page-b
// page-b --> page-c
// page-c --> page-d
// page-c --> page-e
const notationLabelled = planToMermaid(plan, true)
// flowchart LR
// page-a --> page-b
// page-b --> page-c
// page-c -->|yes| page-d
// page-c -->|no| page-e
const notationTopDown = planToMermaid(plan, false, 'TD')
// flowchart TD
// page-a --> page-b
// page-b --> page-c
// page-c --> page-d
// page-c --> page-e
const notationTitled = planToMermaid(plan, false, 'LR', 'My journey')
// ---
// title: My journey
// ---
// flowchart TD
// page-a --> page-b
// page-b --> page-c
// page-c --> page-d
// page-c --> page-e