CWL-SVG
CWL-SVG is a Typescript library for visualization of Common Workflow Language workflows
Usage
import "./assets/styles/style.scss";
import {WorkflowFactory} from "cwlts/models";
import {Workflow} from "./graph/workflow";
const wf = WorkflowFactory.from({
label: "Whole Genome Analysis",
class: "Workflow",
outputs: ...
inputs: ...
steps: ...
});
const svgRoot = document.getElementById("svg") as SVGSVGElement;
const workflow = new Workflow(svgRoot, wf);
workflow.fitToViewport();
workflow.arrange();
Todo
- Create a CLI interface for generating images from CWL files directly
- Compile a bundle usable without module loaders
- Make it more theming-friendly
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"