2016-05-16 20:59:38 -04:00
|
|
|
// JS
|
2016-08-22 16:21:30 -04:00
|
|
|
import d3 from 'd3';
|
2016-05-16 20:59:38 -04:00
|
|
|
|
|
|
|
// CSS
|
|
|
|
require('./cal_heatmap.css');
|
|
|
|
require('../node_modules/cal-heatmap/cal-heatmap.css');
|
|
|
|
|
2016-08-22 16:21:30 -04:00
|
|
|
const CalHeatMap = require('cal-heatmap');
|
2016-05-16 20:59:38 -04:00
|
|
|
|
|
|
|
function calHeatmap(slice) {
|
2016-08-22 16:21:30 -04:00
|
|
|
const div = d3.select(slice.selector);
|
2016-05-16 20:59:38 -04:00
|
|
|
|
2016-08-22 16:21:30 -04:00
|
|
|
const render = function () {
|
2016-05-16 20:59:38 -04:00
|
|
|
d3.json(slice.jsonEndpoint(), function (error, json) {
|
2016-08-22 16:21:30 -04:00
|
|
|
const data = json.data;
|
2016-05-16 20:59:38 -04:00
|
|
|
if (error !== null) {
|
2016-06-21 12:42:44 -04:00
|
|
|
slice.error(error.responseText, error);
|
2016-08-22 16:21:30 -04:00
|
|
|
return;
|
2016-05-16 20:59:38 -04:00
|
|
|
}
|
|
|
|
|
2016-08-22 16:21:30 -04:00
|
|
|
div.selectAll('*').remove();
|
|
|
|
const cal = new CalHeatMap();
|
2016-05-16 20:59:38 -04:00
|
|
|
|
2016-08-22 16:21:30 -04:00
|
|
|
const timestamps = data.timestamps;
|
|
|
|
const extents = d3.extent(Object.keys(timestamps), (key) => timestamps[key]);
|
|
|
|
const step = (extents[1] - extents[0]) / 5;
|
2016-05-16 20:59:38 -04:00
|
|
|
|
|
|
|
try {
|
|
|
|
cal.init({
|
2016-08-22 16:21:30 -04:00
|
|
|
start: data.start,
|
2016-05-16 20:59:38 -04:00
|
|
|
data: timestamps,
|
|
|
|
itemSelector: slice.selector,
|
|
|
|
tooltip: true,
|
2016-08-22 16:21:30 -04:00
|
|
|
domain: data.domain,
|
|
|
|
subDomain: data.subdomain,
|
|
|
|
range: data.range,
|
2016-05-16 20:59:38 -04:00
|
|
|
browsing: true,
|
2016-08-22 16:21:30 -04:00
|
|
|
legend: [extents[0], extents[0] + step, extents[0] + step * 2, extents[0] + step * 3],
|
2016-05-16 20:59:38 -04:00
|
|
|
});
|
|
|
|
} catch (e) {
|
|
|
|
slice.error(e);
|
|
|
|
}
|
|
|
|
|
|
|
|
slice.done(json);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
return {
|
2016-08-22 16:21:30 -04:00
|
|
|
render,
|
2016-07-21 00:32:20 -04:00
|
|
|
resize: render,
|
2016-05-16 20:59:38 -04:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = calHeatmap;
|