CWL-SVG
data:image/s3,"s3://crabby-images/efc49/efc496977a8ec7243341c17bcb21839fa405ddf4" alt="Build Status"
CWL-SVG is a Typescript library for visualization of Common Workflow Language workflows
Citation
CWL-SVG: an open-source workflow visualization library for the
Common Workflow Language. Seven Bridges/Rabix (2017)
Available from https://github.com/rabix/cwl-svg
Installation
npm install cwl-svg
Standalone Demo
git clone https://github.com/rabix/cwl-svg
cd cwl-svg
npm install
npm start
// Point browser to http://localhost:8080
Integration
<html>
<head>
<style>
#svg {
width: 100%;
height: 100%;
position: absolute;
}
</style>
</head>
<body>
<svg id="svg" class="cwl-workflow"></svg>
<script src="dist/bundle.js"></script>
</body>
</html>
import "./assets/styles/themes/rabix-dark/theme";
import "./plugins/port-drag/theme.dark.scss";
import "./plugins/selection/theme.dark.scss";
import {WorkflowFactory} from "cwlts/models";
import {Workflow} from "./graph/workflow";
import {SVGArrangePlugin} from "./plugins/arrange/arrange";
import {SVGNodeMovePlugin} from "./plugins/node-move/node-move";
import {SVGPortDragPlugin} from "./plugins/port-drag/port-drag";
import {SelectionPlugin} from "./plugins/selection/selection";
import {SVGEdgeHoverPlugin} from "./plugins/edge-hover/edge-hover";
import {ZoomPlugin} from "./plugins/zoom/zoom";
const sample = require(__dirname + "/../cwl-samples/rna-seq-alignment.json");
const wf = WorkflowFactory.from(sample);
const svgRoot = document.getElementById("svg") as any;
const workflow = new Workflow({
model: wf,
svgRoot: svgRoot,
plugins: [
new SVGArrangePlugin(),
new SVGEdgeHoverPlugin(),
new SVGNodeMovePlugin({
movementSpeed: 10
}),
new SVGPortDragPlugin(),
new SelectionPlugin(),
new ZoomPlugin(),
]
});
window["wf"] = workflow;
Preview
Overview
data:image/s3,"s3://crabby-images/2fcdb/2fcdbe1c57ecfeccbb98a470179111cfe84f5a8b" alt="Arranged and scaled BCBio workflow"
Selection
data:image/s3,"s3://crabby-images/b5d74/b5d748e6e7c98d54b55286bfccd69580d7527ef1" alt="Selection and Highlighting"
Movement
data:image/s3,"s3://crabby-images/176da/176dacace7e23d8b229f7c4467e564a49be44387" alt="Movement"
Connection
data:image/s3,"s3://crabby-images/39e51/39e51a6d0547516aa5b94d23d9d203fde93eadda" alt="Connecting Nodesd"