Skip to content

Instantly share code, notes, and snippets.

@Meroje

Meroje/index.html

Created Apr 10, 2015
Embed
What would you like to do?
Novius OS js modules graph, created with https://github.com/auchenberg/dependo
<html>
<head>
<title>dependo</title>
<style>
body {
background: #fff;
padding:0;
margin:0;
font-family:helvetica,arial;
overflow: hidden;
}
.graph {
width:100%;
height: 100%;
fill: #000;
overflow: hidden;
position: relative;
}
svg {
height: 100%;
width: 100%;
}
g.dimmed {
stroke-opacity: 0.05;
}
g.dimmed text.shadow {
stroke-opacity: 0;
}
circle {
fill: #ccc;
stroke: #333;
stroke-width: 1.5px;
}
text {
font: 10px sans-serif;
pointer-events: none;
}
text.shadow {
stroke: #fff;
stroke-width: 3px;
stroke-opacity: .8;
}
path.link {
fill: none;
stroke: #666;
stroke-width: 1.5px;
}
path.link.licensing {
stroke: green;
}
path.link.resolved {
stroke-dasharray: 0,2 1;
}
.control-zoom {
position: fixed;
top: 10px;
left: 10px;
background: rgba(0, 0, 0, 0.25);
padding: 5px;
border-radius: 7px;
z-index: 100;
}
.control-zoom a {
background: rgba(255, 255, 255, 0.75);
background-position: 50% 50%;
background-repeat: no-repeat;
display: block;
width: 19px;
height: 19px;
border-radius: 4px;
}
.control-zoom a:last-child {
margin: 0;
}
.control-zoom a:hover {
background-color: white;
}
.control-zoom > .control-zoom-in {
background-image: url();
margin-bottom: 5px;
}
.control-zoom > .control-zoom-out {
background-image: url();
margin-bottom: 5px;
}
</style>
</head>
<body>
<div class="graph">
<div class="control-zoom">
<a class="control-zoom-in" href="#" title="Zoom in"></a>
<a class="control-zoom-out" href="#" title="Zoom out"></a>
</div>
</div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/3.0.1/d3.v3.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/underscore.js/1.4.3/underscore-min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/1.9.0/jquery.min.js"></script>
<script>
var getGraphData = function() { return {"directed":true,"multigraph":false,"graph":[],"nodes":[{"id":"inspector/jquery.novius-os.inspector-date"},{"id":"jquery-nos-listgrid"},{"id":"jquery-nos-renderer-datetimepicker"},{"id":"inspector/jquery.novius-os.inspector-model"},{"id":"jquery-ui.datepicker"},{"id":"inspector/jquery.novius-os.inspector-plain-data"},{"id":"inspector/jquery.novius-os.inspector-tree-model"},{"id":"jquery-nos-treegrid"},{"id":"inspector/jquery.novius-os.inspector-tree-model-checkbox"},{"id":"jquery"},{"id":"inspector/jquery.novius-os.inspector-tree-model-radio"},{"id":"inspector/minified/jquery.novius-os.inspector-date"},{"id":"inspector/minified/jquery.novius-os.inspector-model"},{"id":"inspector/minified/jquery.novius-os.inspector-plain-data"},{"id":"inspector/minified/jquery.novius-os.inspector-tree-model"},{"id":"inspector/minified/jquery.novius-os.inspector-tree-model-checkbox"},{"id":"inspector/minified/jquery.novius-os.inspector-tree-model-radio"},{"id":"jquery.novius-os"},{"id":"jquery-form"},{"id":"jquery-nos-validate"},{"id":"jquery-ui.button"},{"id":"wijmo.wijaccordion"},{"id":"wijmo.wijdialog"},{"id":"wijmo.wijexpander"},{"id":"wijmo.wijmenu"},{"id":"jquery.novius-os.appdesk"},{"id":"jquery-nos"},{"id":"jquery-nos-preview"},{"id":"jquery-nos-thumbnailsgrid"},{"id":"jquery-ui.widget"},{"id":"wijmo.wijgrid"},{"id":"wijmo.wijsplitter"},{"id":"wijmo.wijsuperpanel"},{"id":"wijmo.wijtabs"},{"id":"jquery.novius-os.contextmenu"},{"id":"modernizr"},{"id":"jquery.novius-os.datacatchers"},{"id":"jquery.novius-os.listgrid"},{"id":"jquery.novius-os.loadspinner"},{"id":"jquery.novius-os.ostabs"},{"id":"jquery-nos-contextmenu"},{"id":"jquery-nos-loadspinner"},{"id":"jquery-ui.sortable"},{"id":"jquery.simulate"},{"id":"jquery.novius-os.preview"},{"id":"jquery.novius-os.thumbnailsgrid"},{"id":"wijmo.wijpager"},{"id":"jquery.novius-os.tray"},{"id":"jquery.novius-os.treegrid"},{"id":"wijmo.wijdatasource"},{"id":"jquery.novius-os.validate"},{"id":"jquery.validate"},{"id":"wijmo.wijtooltip"},{"id":"jquery.novius-os.wysiwyg"},{"id":"tinymce"},{"id":"media/jquery.novius-os.image-wysiwyg"},{"id":"media/jquery.novius-os.media-add-form"},{"id":"static/apps/noviusos_media/config/seo_compliant"},{"id":"media/jquery.novius-os.media-edit-form"},{"id":"media/jquery.novius-os.media-folder-form"},{"id":"media/minified/jquery.novius-os.image-wysiwyg"},{"id":"media/minified/jquery.novius-os.media-add-form"},{"id":"media/minified/jquery.novius-os.media-edit-form"},{"id":"media/minified/jquery.novius-os.media-folder-form"},{"id":"page/jquery.novius-os.link-wysiwyg"},{"id":"page/minified/jquery.novius-os.link-wysiwyg"},{"id":"renderer/jquery.novius-os.renderer.datetime-picker"},{"id":"jquery-ui.datepicker.i18n"},{"id":"jquery-ui.datetimepicker.i18n"},{"id":"renderer/jquery.novius-os.renderer.item-picker"},{"id":"renderer/minified/jquery.novius-os.renderer.datetime-picker"},{"id":"renderer/minified/jquery.novius-os.renderer.item-picker"},{"id":"views/jquery.novius-os.context-common-fields"},{"id":"views/jquery.novius-os.layout-standard"},{"id":"views/jquery.novius-os.nosdesktop"},{"id":"views/jquery.novius-os.permissions"},{"id":"views/jquery.novius-os.publishable"},{"id":"views/jquery.novius-os.toolbar-crud"},{"id":"views/jquery.novius-os.update-tab-crud"},{"id":"jquery-nos-ostabs"},{"id":"views/jquery.novius-os.virtualname"},{"id":"views/minified/jquery.novius-os.context-common-fields"},{"id":"views/minified/jquery.novius-os.layout-standard"},{"id":"views/minified/jquery.novius-os.nosdesktop"},{"id":"views/minified/jquery.novius-os.permissions"},{"id":"views/minified/jquery.novius-os.publishable"},{"id":"views/minified/jquery.novius-os.toolbar-crud"},{"id":"views/minified/jquery.novius-os.update-tab-crud"},{"id":"views/minified/jquery.novius-os.virtualname"}],"links":[{"source":0,"target":1},{"source":0,"target":2},{"source":3,"target":1},{"source":3,"target":4},{"source":5,"target":1},{"source":6,"target":7},{"source":8,"target":9},{"source":8,"target":7},{"source":10,"target":9},{"source":10,"target":7},{"source":11,"target":1},{"source":11,"target":2},{"source":12,"target":1},{"source":12,"target":4},{"source":13,"target":1},{"source":14,"target":7},{"source":15,"target":9},{"source":15,"target":7},{"source":16,"target":9},{"source":16,"target":7},{"source":17,"target":9},{"source":17,"target":18},{"source":17,"target":19},{"source":17,"target":20},{"source":17,"target":21},{"source":17,"target":22},{"source":17,"target":23},{"source":17,"target":24},{"source":25,"target":9},{"source":25,"target":26},{"source":25,"target":1},{"source":25,"target":27},{"source":25,"target":28},{"source":25,"target":7},{"source":25,"target":20},{"source":25,"target":29},{"source":25,"target":30},{"source":25,"target":24},{"source":25,"target":31},{"source":25,"target":32},{"source":25,"target":33},{"source":34,"target":9},{"source":34,"target":26},{"source":34,"target":29},{"source":34,"target":35},{"source":34,"target":24},{"source":36,"target":9},{"source":36,"target":26},{"source":36,"target":20},{"source":36,"target":29},{"source":36,"target":21},{"source":37,"target":9},{"source":37,"target":26},{"source":37,"target":29},{"source":37,"target":30},{"source":38,"target":9},{"source":38,"target":26},{"source":38,"target":29},{"source":39,"target":9},{"source":39,"target":26},{"source":39,"target":40},{"source":39,"target":41},{"source":39,"target":42},{"source":39,"target":29},{"source":39,"target":43},{"source":39,"target":35},{"source":39,"target":32},{"source":44,"target":9},{"source":44,"target":26},{"source":44,"target":29},{"source":44,"target":32},{"source":45,"target":9},{"source":45,"target":26},{"source":45,"target":29},{"source":45,"target":46},{"source":45,"target":32},{"source":47,"target":26},{"source":48,"target":9},{"source":48,"target":26},{"source":48,"target":1},{"source":48,"target":29},{"source":48,"target":49},{"source":48,"target":30},{"source":50,"target":9},{"source":50,"target":51},{"source":50,"target":52},{"source":53,"target":9},{"source":53,"target":26},{"source":53,"target":54},{"source":55,"target":26},{"source":55,"target":33},{"source":56,"target":26},{"source":56,"target":57},{"source":58,"target":26},{"source":58,"target":57},{"source":59,"target":26},{"source":59,"target":57},{"source":60,"target":26},{"source":60,"target":33},{"source":61,"target":26},{"source":61,"target":57},{"source":62,"target":26},{"source":62,"target":57},{"source":63,"target":26},{"source":63,"target":57},{"source":64,"target":26},{"source":64,"target":33},{"source":65,"target":26},{"source":65,"target":33},{"source":66,"target":26},{"source":66,"target":67},{"source":66,"target":68},{"source":69,"target":9},{"source":69,"target":26},{"source":69,"target":29},{"source":70,"target":26},{"source":70,"target":67},{"source":70,"target":68},{"source":71,"target":9},{"source":71,"target":26},{"source":71,"target":29},{"source":72,"target":26},{"source":73,"target":26},{"source":74,"target":26},{"source":74,"target":42},{"source":75,"target":9},{"source":75,"target":26},{"source":76,"target":26},{"source":76,"target":20},{"source":76,"target":68},{"source":77,"target":26},{"source":78,"target":79},{"source":80,"target":26},{"source":81,"target":26},{"source":82,"target":26},{"source":83,"target":26},{"source":83,"target":42},{"source":84,"target":9},{"source":84,"target":26},{"source":85,"target":26},{"source":85,"target":20},{"source":85,"target":68},{"source":86,"target":26},{"source":87,"target":79},{"source":88,"target":26}]};};
(function() {
var url = 'data.json'
var r = 10;
var graph, layout, zoom, nodes, links, data;
var linkedByIndex = {};
var graphWidth, graphHeight;
// Helpers
function formatClassName(prefix, object) {
return prefix + '-' + object.id.replace(/(\.|\/)/gi, '-');
}
function findElementByNode(prefix, node) {
var selector = '.'+formatClassName(prefix, node);
return graph.select(selector);
}
function isConnected(a, b) {
return linkedByIndex[a.index + "," + b.index] || linkedByIndex[b.index + "," + a.index] || a.index == b.index;
}
function fadeRelatedNodes(d, opacity, nodes, links) {
// Clean
$('path.link').removeAttr('data-show');
nodes.style("stroke-opacity", function(o) {
if (isConnected(d, o)) {
thisOpacity = 1;
} else {
thisOpacity = opacity;
}
this.setAttribute('fill-opacity', thisOpacity);
this.setAttribute('stroke-opacity', thisOpacity);
if(thisOpacity == 1) {
this.classList.remove('dimmed');
} else {
this.classList.add('dimmed');
}
return thisOpacity;
});
links.style("stroke-opacity", function(o) {
if (o.source === d) {
// Highlight target/sources of the link
var elmNodes = graph.selectAll('.'+formatClassName('node', o.target));
elmNodes.attr('fill-opacity', 1);
elmNodes.attr('stroke-opacity', 1);
elmNodes.classed('dimmed', false);
// Highlight arrows
var elmCurrentLink = $('path.link[data-source=' + o.source.index + ']');
elmCurrentLink.attr('data-show', true);
elmCurrentLink.attr('marker-end', 'url(#regular)');
return 1;
} else {
var elmAllLinks = $('path.link:not([data-show])');
if(opacity == 1) {
elmAllLinks.attr('marker-end', 'url(#regular)');
} else {
elmAllLinks.attr('marker-end', '');
}
return opacity;
}
});
}
function render() {
zoom = d3.behavior.zoom();
zoom.on("zoom", onZoomChanged);
// Setup layout
layout = d3.layout.force()
.gravity(.05)
.charge(-300)
.linkDistance(100);
// Setup graph
graph = d3.select(".graph")
.append("svg:svg")
.attr("pointer-events", "all")
.call(zoom)
.append('svg:g')
.attr('width', graphWidth)
.attr('height', graphHeight);
d3.select(window).on("resize", resize);
// Load graph data
var graphData = window.getGraphData();
renderGraph(graphData);
data = graphData;
// Resize
resize();
centerGraph();
// Controlers
$('.control-zoom a').on('click', onControlZoomClicked);
}
function resize() {
graphWidth = window.innerWidth,
graphHeight = window.innerHeight;
graph.attr("width", graphWidth)
.attr("height", graphHeight);
layout.size([graphWidth, graphHeight])
.resume();
}
function centerGraph() {
var centerTranslate = [
(graphWidth / 2) - (graphWidth * 0.2 / 2),
(graphHeight / 2) - (graphHeight * 0.2 / 2),
];
zoom.translate(centerTranslate);
// Render transition
graph.transition()
.duration(500)
.attr("transform", "translate(" + zoom.translate() + ")" + " scale(" + zoom.scale() + ")");
}
function renderGraph(data) {
// Markers
graph.append("svg:defs").selectAll("marker")
.data(['regular'])
.enter().append("svg:marker")
.attr("id", String)
.attr("viewBox", "0 -5 10 10")
.attr("refX", 15)
.attr("refY", -1.5)
.attr("markerWidth", 6)
.attr("markerHeight", 6)
.attr("orient", "auto")
.append("svg:path")
.attr("d", "M0,-5L10,0L0,5");
// Lines
links = graph.append('svg:g').selectAll("line")
.data(data.links)
.enter().append("svg:path")
.attr('class', 'link')
.attr("data-target", function(o) { return o.target })
.attr("data-source", function(o) { return o.source })
.attr("marker-end", function(d) { return "url(#regular)"; });
// Nodes
nodes = graph.append('svg:g').selectAll("node")
.data(data.nodes)
.enter().append("svg:g")
.attr("class","node")
.call(layout.drag)
.on("mousedown", onNodeMouseDown);
// Circles
nodes.attr("class", function(d) { return formatClassName('node', d) })
nodes.append("svg:circle")
.attr("class", function(d) { return formatClassName('circle', d) })
.attr("r", 6)
.on("mouseover", _.bind(onNodeMouseOver, this, nodes, links))
.on("mouseout", _.bind(onNodeMouseOut, this, nodes, links) );
// A copy of the text with a thick white stroke for legibility.
nodes.append("svg:text")
.attr("x", 15)
.attr("y", ".31em")
.attr("class", function(d) { return 'shadow ' + formatClassName('text', d) })
.text(function(d) { return d.id; });
nodes.append("svg:text")
.attr("class", function(d) { return formatClassName('text', d) })
.attr("x", 15)
.attr("y", ".31em")
.text(function(d) { return d.id; });
// Build linked index
data.links.forEach(function(d) {
linkedByIndex[d.source.index + "," + d.target.index] = 1;
});
// Draw the
layout.nodes(data.nodes);
layout.links(data.links);
layout.on("tick", onTick);
layout.start();
zoom.scale(0.4);
// Render transition
graph.transition()
.duration(500)
.attr("transform", "scale(" + zoom.scale() + ")");
}
function onNodeMouseOver(nodes, links, d) {
// Highlight circle
var elm = findElementByNode('circle', d);
elm.style("fill", '#b94431');
// Highlight related nodes
fadeRelatedNodes(d, .05, nodes, links);
}
function onNodeMouseOut(nodes, links, d) {
// Highlight circle
var elm = findElementByNode('circle', d);
elm.style("fill", '#ccc');
// Highlight related nodes
fadeRelatedNodes(d, 1, nodes, links);
}
function onTick(e) {
links.attr("d", function(d) {
var dx = d.target.x - d.source.x,
dy = d.target.y - d.source.y,
dr = Math.sqrt(dx * dx + dy * dy);
return "M" + d.source.x + "," + d.source.y + "A" + dr + "," + dr + " 0 0,1 " + d.target.x + "," + d.target.y;
});
nodes.attr("cx", function(d) { return d.x; })
.attr("cy", function(d) { return d.y; })
.attr("transform", function(d) { return "translate(" + d.x + "," + d.y + ")"; });
}
function onControlZoomClicked(e) {
var elmTarget = $(this)
var scaleProcentile = 0.20;
// Scale
var currentScale = zoom.scale();
var newScale;
if(elmTarget.hasClass('control-zoom-in')) {
newScale = currentScale * (1 + scaleProcentile);
} else {
newScale = currentScale * (1 - scaleProcentile);
}
newScale = Math.max(newScale, 0);
// Translate
var centerTranslate = [
(graphWidth / 2) - (graphWidth * newScale / 2),
(graphHeight / 2) - (graphHeight * newScale / 2)
];
// Store values
zoom
.translate(centerTranslate)
.scale(newScale);
// Render transition
graph.transition()
.duration(500)
.attr("transform", "translate(" + zoom.translate() + ")" + " scale(" + zoom.scale() + ")");
}
function onZoomChanged() {
graph.attr("transform", "translate(" + d3.event.translate + ")" + " scale(" + d3.event.scale + ")");
}
function onNodeMouseDown(d) {
d.fixed = true;
d3.select(this).classed("sticky", true);
}
render();
})();
</script>
</body>
</html>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
You can’t perform that action at this time.