Skip to content

Instantly share code, notes, and snippets.

@Gozala
Created May 3, 2012 00:37
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
Star You must be signed in to star a gist
Save Gozala/2582184 to your computer and use it in GitHub Desktop.
Module graph visualisation
<html>
<head>
<meta charset="utf-8">
<title>Module dependency graph</title>
<style>
.module .node {
stroke: black;
stroke-width: 1.5px;
}
.module .text {
font-size: 12px;
fill: white;
stroke: none;
margin: 50px;
}
.module[data-type="system"] {
fill: green;
}
.module[data-type="std"] {
fill: orange;
}
.module[data-type="local"] {
fill: gray;
}
.module[data-type="external"] {
fill: brown;
}
.link {
stroke: #999;
stroke-width: 1px;
stroke-opacity: .6;
}
body {
background: #222 url();
color: white;
font-family: Monaco, Menlo,"Andale Mono","lucida console","Courier New", monospace;
}
</style>
</head>
<body>
<script type="text/javascript" src="http://mbostock.github.com/d3/d3.v2.js?2.9.1"></script>
<script type="text/javascript" src="visualize.js"></script>
</body>
</html>
document.body.innerHTML = "";
var graph = {
"./main": {
"type": "local",
"requirements": {
"./utils/model": "./utils/model"
}
},
"./utils/model": {
"type": "local",
"requirements": {
"panel": "sdk/panel",
"api-utils/functional": "api-utils/functional",
"devtools/scratchpad": "devtools/scratchpad",
"./controller": "./utils/controller",
"backbone/events": "backbone/events"
}
},
"./utils/controller": {
"type": "local",
"requirements": {
// ...
}
},
"api-utils/functional": {
"type": "deprecated",
"correction": "sdk/functional"
},
"sdk/functional": {
"type": "std"
},
"sdk/panel": {
"type": "std"
},
"devtools/scratchpad": {
"type": "system"
},
"backbone/events": {
"type": "external"
}
}
var width = window.innerWidth - 10
var height = window.innerHeight - 10
var svg = d3.
select('body').
append('svg:svg').
attr('width', width).
attr('height', height)
var force = d3.
layout.
force().
charge(-500).
distance(100).
size([ width, height ])
function modules(graph) {
return Object.keys(graph).map(function(id) {
var node = graph[id]
return {
id: id,
type: node.type,
requirements: node.requirements
}
})
}
function connections(modules) {
var ids = modules.map(function(module) { return module.id })
return modules.reduce(function(links, module) {
var requirements = module.requirements || {}
var dependencies = Object.keys(requirements).map(function(path) {
return requirements[path]
})
return links.concat(dependencies.map(function(id) {
return {
from: module.id,
to: id,
source: modules.indexOf(module),
target: ids.indexOf(id)
}
}))
}, [])
}
function links(graph) {
return modules(graph).reduce(function(links, module) {
var requirements = module.requirements || {}
var dependencies = Object.keys(requirements).map(function(path) {
return requirements[path]
})
return links.concat(dependencies .map(function(id) {
return { from: module.id, to: id }
}))
}, [])
}
function draw(graph) {
var nodes = modules(graph)
var links = connections(nodes)
force.
nodes(nodes).
links(links).
start()
var link = svg.
selectAll('line.link').
data(links).
enter().
append('svg:line').
attr('class', 'link requirement').
call(force.drag)
var node = svg.
selectAll('g.node').
data(nodes)
node.
transition().
duration(1000).
attr('r', 20)
// For each node, create svg group <g> to hold circle, image, and title
var module = node.
enter().
append('svg:g').
attr('class', 'node module').
attr('data-type', function(node) {
return node.type
}).
call(force.drag)
module.
append('svg:circle').
attr('class', 'node').
attr('r', 15).
attr('cx', 0).
attr('cy', 0).
attr('id', function(node) {
return node.id
})
module.
append('svg:text').
attr('class', 'text').
text(function(node) {
return node.id
})
force.on("tick", function() {
link.
attr("x1", function(d) { return d.source.x; }).
attr("y1", function(d) { return d.source.y; }).
attr("x2", function(d) { return d.target.x; }).
attr("y2", function(d) { return d.target.y; })
node.
//attr("cx", function($) { return $.x; }).
//attr("cy", function($) { return $.y; })
attr("transform", function($) {
// <g> doesn't take x or y attributes but it can be
// positioned with a transformation
return "translate(" + $.x + "," + $.y + ")";
})
})
}
draw(graph)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment