Skip to content

Instantly share code, notes, and snippets.

@evaristoc
Last active January 14, 2018 13:42
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save evaristoc/f8ddc4b4e9b6ead2860c8e80316ddbe5 to your computer and use it in GitHub Desktop.
Save evaristoc/f8ddc4b4e9b6ead2860c8e80316ddbe5 to your computer and use it in GitHub Desktop.
freeCodeCamp Emojis : visualization of approximate dates at which each emoji was seen in the main chat for the first time

freeCodeCamp Emojis :

Beeswarm visualization of approximate dates at which each emoji was seen in the main chat for the first time. d3.js, v4.

<!DOCTYPE html>
<meta charset="utf-8">
<style>
svg {
background-color: grey;
}
.axis path,
.axis line {
fill: none;
stroke: #000;
shape-rendering: crispEdges;
}
.axis text {
font: 14px sans-serif;
fill: white;
}
.cells path {
fill: none;
pointer-events: all;
}
.cells :hover circle {
fill: white;
}
</style>
<svg width="1120" height="500"></svg>
<script src="https://d3js.org/d3.v4.min.js"></script>
<script>
var svg = d3.select("svg"),
margin = {top: 40, right: 40, bottom: 40, left: 40},
width = svg.attr("width") - margin.left - margin.right,
height = svg.attr("height") - margin.top - margin.bottom;
// parse the date / time
var parseTime = d3.timeParse("%d-%b-%y");
// set the ranges
var xDom = d3.scaleTime().range([0, width]);
var g = svg.append("g")
.attr("transform", "translate(" + margin.left + "," + margin.top + ")");
d3.json("https://raw.githubusercontent.com/evaristoc/fCC_emojis/master/views/emojis_date_final.json", function(err, data){
if (err) console.log(err);
var withdate = []
var withoutdate = []
Object.keys(data).forEach(key => {
data[key]['unicode'] = key
if (data[key].first == '2018-12-31') {
withoutdate.push(data[key])
}else{
withdate.push(data[key])
}
});
//console.log(d3.extent(withdate, function(d){console.log(d.first); return new Date(d.first)}))
xDom.domain(d3.extent(withdate, function(d){return new Date(d.first)}))
var simulation = d3.forceSimulation(withdate)
.force("x", d3.forceX(function(d) { return xDom(new Date(d.first)); }).strength(1))
.force("y", d3.forceY(height / 2))
.force("collide", d3.forceCollide(10))
.stop();
for (var i = 0; i < 120; ++i) simulation.tick();
g.append("g")
.attr("class", "axis axis--x")
.attr("transform", "translate(0," + height + ")")
.call(d3.axisBottom(xDom).ticks(20));
//the values of d.x and d.y are assigned to each data point at the *.forceSimulation(...) step
var cell = g.append("g")
.attr("class", "cells")
.selectAll("g").data(d3.voronoi()
.extent([[-margin.left, -margin.top], [width + margin.right, height + margin.top]])
.x(function(d) { return d.x; })
.y(function(d) { return d.y; })
.polygons(withdate))
.enter()
.append("g");
cell
.append("circle")
.attr("r", 5)
.attr("cx", function(d) { return d.data.x; })
.attr("cy", function(d) { return d.data.y; })
.attr("fill", "transparent")
.attr("stroke", "black")
//var testimg = ""
cell
.append("image")
.attr('x',function(d) { return d.data.x - 5; })
.attr('y',function(d) { return d.data.y - 5; })
.attr('width', 10)
.attr('height', 10)
//.attr("xlink:href",testimg);
//.attr("xlink:href",function(d,i){console.log("xlink ",d.data); return d.data.Apple_img})
.attr("xlink:href",function(d,i){return d.data.Apple_img})
cell
.on("mouseover", function(d){
//console.log(d, this);
var _sel = d3
.select(this)
_sel
.select("circle")
.attr("r", 15)
_sel
.select("image")
.attr('x',function(d) { return d.data.x - 10; })
.attr('y',function(d) { return d.data.y - 10; })
.attr('width', 20)
.attr('height', 20)
})
.on("mouseout", function(d){
var _sel = d3
.select(this)
_sel
.select("circle")
.attr("r", 5)
_sel
.select("image")
.attr('x',function(d) { return d.data.x - 5; })
.attr('y',function(d) { return d.data.y - 5; })
.attr('width', 10)
.attr('height', 10)
})
cell.append("path")
.attr("d", function(d) { return "M" + d.join("L") + "Z"; })
cell.append("title")
.text(function(d) {
//console.error(d);
//console.log("title ",d);
return d.data.CLRDname + "\nin chat: " + d.data.first });
cell
.append("rect")
.attr("width",1)
//.attr("height",function(d, i){return height - d.data.y})
.attr("height",function(d, i){return 20})
.attr("x",function(d, i){return d.data.x})
.attr("y",function(d, i){return d.data.y})
.attr("transform",function(d,i){return "translate(0," + (height - d.data.y - 20) + ")"})
})
</script>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment