Example for http://stackoverflow.com/questions/29880870/d3-calendar-view-using-json/29888069#29888069
-
-
Save benlyall/b237f16dda3125423130 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
[{ | |
"category": "business", | |
"date": "01/10/2011", | |
"city": "New York" | |
}, | |
{ | |
"category": "holidays", | |
"date": "02/10/2011", | |
"city": "New York" | |
}, | |
{ | |
"category": "business", | |
"date": "03/10/2011", | |
"city": "New York" | |
}, | |
{ | |
"category": "family", | |
"date": "03/10/2011", | |
"city": "New York" | |
}, | |
{ | |
"category": "holidays", | |
"date": "01/10/2011", | |
"city": "San Francisco" | |
}, | |
{ | |
"category": "family", | |
"date": "02/10/2011", | |
"city": "San Francisco" | |
}, | |
{ | |
"category": "holidays", | |
"date": "03/10/2011", | |
"city": "San Francisco" | |
}, | |
{ | |
"category": "family", | |
"date": "01/10/2011", | |
"city": "Austin" | |
}, | |
{ | |
"category": "holidays", | |
"date": "02/10/2011", | |
"city": "Austin" | |
}, | |
{ | |
"category": "family", | |
"date": "03/10/2011", | |
"city": "Austin" | |
} | |
] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<!DOCTYPE html> | |
<meta charset="utf-8"> | |
<style> | |
body { | |
font: 10px sans-serif; | |
shape-rendering: crispEdges; | |
} | |
.day { | |
fill: #fff; | |
stroke: #ccc; | |
} | |
.month { | |
fill: none; | |
stroke: #000; | |
stroke-width: 2px; | |
} | |
.RdYlGn .q0-11{fill:rgb(165,0,38)} | |
.RdYlGn .q1-11{fill:rgb(215,48,39)} | |
.RdYlGn .q2-11{fill:rgb(244,109,67)} | |
.RdYlGn .q3-11{fill:rgb(253,174,97)} | |
.RdYlGn .q4-11{fill:rgb(254,224,139)} | |
.RdYlGn .q5-11{fill:rgb(255,255,191)} | |
.RdYlGn .q6-11{fill:rgb(217,239,139)} | |
.RdYlGn .q7-11{fill:rgb(166,217,106)} | |
.RdYlGn .q8-11{fill:rgb(102,189,99)} | |
.RdYlGn .q9-11{fill:rgb(26,152,80)} | |
.RdYlGn .q10-11{fill:rgb(0,104,55)} | |
</style> | |
<body> | |
<script src="http://d3js.org/d3.v3.min.js"></script> | |
<script> | |
var width = 960, | |
height = 136, | |
cellSize = 17; // cell size | |
var day = d3.time.format("%w"), | |
week = d3.time.format("%U"), | |
percent = d3.format(".1%"), | |
format = d3.time.format("%Y-%m-%d"); | |
/* | |
var color = d3.scale.quantize() | |
.domain([-.05, .05]) | |
.range(d3.range(11).map(function(d) { return "q" + d + "-11"; })); | |
*/ | |
var color = d3.scale.category10(); | |
var dateParse = d3.time.format("%m/%d/%Y"); | |
var svg = d3.select("body").selectAll("svg") | |
.data(d3.range(2010, 2013)) | |
.enter().append("svg") | |
.attr("width", width) | |
.attr("height", height) | |
.attr("class", "RdYlGn") | |
.append("g") | |
.attr("transform", "translate(" + ((width - cellSize * 53) / 2) + "," + (height - cellSize * 7 - 1) + ")"); | |
svg.append("text") | |
.attr("transform", "translate(-6," + cellSize * 3.5 + ")rotate(-90)") | |
.style("text-anchor", "middle") | |
.text(function(d) { return d; }); | |
var rect = svg.selectAll(".day") | |
.data(function(d) { return d3.time.days(new Date(d, 0, 1), new Date(d + 1, 0, 1)); }) | |
.enter().append("rect") | |
.attr("class", "day") | |
.attr("width", cellSize) | |
.attr("height", cellSize) | |
.attr("x", function(d) { return week(d) * cellSize; }) | |
.attr("y", function(d) { return day(d) * cellSize; }) | |
.datum(format); | |
rect.append("title") | |
.text(function(d) { return d; }); | |
svg.selectAll(".month") | |
.data(function(d) { return d3.time.months(new Date(d, 0, 1), new Date(d + 1, 0, 1)); }) | |
.enter().append("path") | |
.attr("class", "month") | |
.attr("d", monthPath); | |
//d3.csv("dji.csv", function(error, csv) { | |
d3.json("data3.json", function(error, data) { | |
/*var data = d3.nest() | |
.key(function(d) { return d.Date; }) | |
.rollup(function(d) { return (d[0].Close - d[0].Open) / d[0].Open; }) | |
.map(csv); | |
*/ | |
data.forEach(function(d) { | |
d.dd = format(dateParse.parse(d.date)); | |
}); | |
var nest = d3.nest() | |
.key(function(d) { return d.dd; }) | |
.map(data); | |
color.domain(d3.set(data.map(function(d) { return d.category; })).values()); | |
rect.filter(function(d) { return d in nest; }) | |
//.attr("class", function(d) { return "day " + color(data[d]); }) | |
.attr("class", function(d) { return "day"; }) | |
.style("fill", function(d) { return color(nest[d][0].category); }) | |
.select("title") | |
//.text(function(d) { return d + ": " + percent(data[d]); }); | |
.text(function(d) { return d + ": " + nest[d][0].city; }); | |
}); | |
function monthPath(t0) { | |
var t1 = new Date(t0.getFullYear(), t0.getMonth() + 1, 0), | |
d0 = +day(t0), w0 = +week(t0), | |
d1 = +day(t1), w1 = +week(t1); | |
return "M" + (w0 + 1) * cellSize + "," + d0 * cellSize | |
+ "H" + w0 * cellSize + "V" + 7 * cellSize | |
+ "H" + w1 * cellSize + "V" + (d1 + 1) * cellSize | |
+ "H" + (w1 + 1) * cellSize + "V" + 0 | |
+ "H" + (w0 + 1) * cellSize + "Z"; | |
} | |
//d3.select(self.frameElement).style("height", "2910px"); | |
</script> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment