Browse Source

MAP-5800: WIP

pull/254/head
Brandon Bernal 11 years ago
parent
commit
0428621852
  1. 82
      c3.js
  2. 2
      c3.min.js

82
c3.js

@ -17,6 +17,9 @@
chartArc: 'c3-chart-arc', chartArc: 'c3-chart-arc',
chartArcs: 'c3-chart-arcs', chartArcs: 'c3-chart-arcs',
chartArcsTitle: 'c3-chart-arcs-title', chartArcsTitle: 'c3-chart-arcs-title',
// gauge: 'c3-gauge',
// gaugeDial: 'c3-gauge-dial',
// gaugeTitle: 'c3-gauge-title',
selectedCircle: 'c3-selected-circle', selectedCircle: 'c3-selected-circle',
selectedCircles: 'c3-selected-circles', selectedCircles: 'c3-selected-circles',
eventRect: 'c3-event-rect', eventRect: 'c3-event-rect',
@ -143,6 +146,12 @@
__data_ondragstart = getConfig(['data', 'ondragstart'], function () {}), __data_ondragstart = getConfig(['data', 'ondragstart'], function () {}),
__data_ondragend = getConfig(['data', 'ondragend'], function () {}); __data_ondragend = getConfig(['data', 'ondragend'], function () {});
// configuration for no plot-able data supplied.
var __data_empty_abort = getConfig(['data', 'empty', 'abort'], true),
__data_empty_label_text = getConfig(['data', 'empty', 'label', 'text'], ""),
__data_empty_label_size = getConfig(['data', 'empty', 'label', 'size'], false),
__data_empty_label_fill = getConfig(['data', 'empty', 'label', 'fill'], false);
// subchart // subchart
var __subchart_show = getConfig(['subchart', 'show'], false), var __subchart_show = getConfig(['subchart', 'show'], false),
__subchart_size_height = __subchart_show ? getConfig(['subchart', 'size', 'height'], 60) : 0; __subchart_size_height = __subchart_show ? getConfig(['subchart', 'size', 'height'], 60) : 0;
@ -229,6 +238,11 @@
__donut_onmouseover = getConfig(['donut', 'onmouseover'], function () {}), __donut_onmouseover = getConfig(['donut', 'onmouseover'], function () {}),
__donut_onmouseout = getConfig(['donut', 'onmouseout'], function () {}); __donut_onmouseout = getConfig(['donut', 'onmouseout'], function () {});
// var __gauge_label_show = getConfig(['gauge', 'label', 'show'], true),
// __gauge_label_format = getConfig(['gauge', 'label', 'format']),
// __gauge_title = getConfig(['gauge', 'title'], ""),
// __gauge_onclick = getConfig(['gauge', 'onclick'], function () {});
// region - region to change style // region - region to change style
var __regions = getConfig(['regions'], []); var __regions = getConfig(['regions'], []);
@ -1077,6 +1091,12 @@
return typeof callback === 'function' ? callback : function () {}; return typeof callback === 'function' ? callback : function () {};
} }
// -- Gauge --//
// function getGaugeTitle() {
// return hasGaugeType(c3.data.targets) ? __gauge_title : "";
// }
//-- Domain --// //-- Domain --//
function getYDomainMin(targets) { function getYDomainMin(targets) {
@ -1213,8 +1233,8 @@
var xDomain = [getXDomainMin(targets), getXDomainMax(targets)], var xDomain = [getXDomainMin(targets), getXDomainMax(targets)],
firstX = xDomain[0], lastX = xDomain[1], firstX = xDomain[0], lastX = xDomain[1],
padding = getXDomainPadding(targets, xDomain), padding = getXDomainPadding(targets, xDomain),
min = isTimeSeries ? new Date(firstX.getTime() - padding) : firstX - padding, min = firstX == undefined ? padding : (isTimeSeries ? new Date(firstX.getTime() - padding) : firstX - padding),
max = isTimeSeries ? new Date(lastX.getTime() + padding) : lastX + padding; max = lastX == undefined ? padding : (isTimeSeries ? new Date(lastX.getTime() + padding) : lastX + padding);
return [min, max]; return [min, max];
} }
function diffDomain(d) { function diffDomain(d) {
@ -1334,6 +1354,11 @@
} }
return new_rows; return new_rows;
} }
// function convertValueToData(value) {
// var new_rows = [];
// new_rows[0] = {'value': value};
// return new_rows;
// }
function convertDataToTargets(data) { function convertDataToTargets(data) {
var ids = d3.keys(data[0]).filter(isNotX), xs = d3.keys(data[0]).filter(isX), targets; var ids = d3.keys(data[0]).filter(isNotX), xs = d3.keys(data[0]).filter(isX), targets;
@ -1969,8 +1994,11 @@
function hasDonutType(targets) { function hasDonutType(targets) {
return hasType(targets, 'donut'); return hasType(targets, 'donut');
} }
// function hasGaugeType(targets) {
// return hasType(targets, 'gauge') || hasType(targets, 'google-gauge');
// }
function hasArcType(targets) { function hasArcType(targets) {
return hasPieType(targets) || hasDonutType(targets); return hasPieType(targets) || hasDonutType(targets);// || hasGaugeType(targets);
} }
function isLineType(d) { function isLineType(d) {
var id = (typeof d === 'string') ? d : d.id; var id = (typeof d === 'string') ? d : d.id;
@ -2004,8 +2032,12 @@
var id = (typeof d === 'string') ? d : d.id; var id = (typeof d === 'string') ? d : d.id;
return __data_types[id] === 'donut'; return __data_types[id] === 'donut';
} }
// function isGaugeType(d) {
// var id = (typeof d === 'string') ? d : d.id;
// return __data_types[id] === 'gauge' || __data_types[id] === 'google-gauge'
// }
function isArcType(d) { function isArcType(d) {
return isPieType(d) || isDonutType(d); return isPieType(d) || isDonutType(d);// || isGaugeType(d);
} }
/* not used /* not used
function lineData(d) { function lineData(d) {
@ -2595,6 +2627,15 @@
.style("display", "none"); .style("display", "none");
/*-- Main Region --*/ /*-- Main Region --*/
if (c3.data.targets.length == 0) {
main.append("text")
.attr("class", CLASS.text)
.attr("x", (main[0][0].parentNode.width.baseVal.value / 2) - margin.left)
.attr("y", (main[0][0].parentNode.height.baseVal.value / 2) - margin.top)
.attr("text-anchor", "middle")
.attr("style", (__data_empty_label_fill ? "fill:"+ __data_empty_label_fill +"; " : "") + (__data_empty_label_size ? "font-size:"+ __data_empty_label_size +"; " : "") )
.text(__data_empty_label_text);
}
// Add Axis // Add Axis
main.append("g") main.append("g")
@ -2696,6 +2737,30 @@
.style("text-anchor", "middle") .style("text-anchor", "middle")
.text(getArcTitle()); .text(getArcTitle());
// Define g for gauge chart area
// main.select('.' + CLASS.chart).append("g")
// .attr('class', CLASS.gauge)
// .attr("width", height)
// .attr("height", height);
// main.select('.' + CLASS.gauge).append('circle')
// .attr("cx", height / 2)
// .attr("cy", height / 2)
// .attr("r", height * 0.97 / 2)
// .style("fill", "#ccc")
// .style("stroke", "#000")
// .style("stroke-width", "0.5px");
// main.select('.' + CLASS.gauge).append("circle")
// .attr("cx", (height / 2))
// .attr("cy", (height / 2))
// .attr("r", 0.9 * (height * 0.97 / 2) )
// .style("fill", "#fff")
// .style("stroke", "#e0e0e0")
// .style("stroke-width", "2px");
// main.select('.' + CLASS.gauge).append('text')
// .attr('class', CLASS.gaugeTitle)
// .style("text-anchor", "middle")
// .text(getGaugeTitle());
main.select('.' + CLASS.chart).append("g") main.select('.' + CLASS.chart).append("g")
.attr("class", CLASS.chartTexts); .attr("class", CLASS.chartTexts);
@ -3084,7 +3149,7 @@
var targetsToShow = filterTargetsToShow(c3.data.targets), tickValues, i, intervalForCulling; var targetsToShow = filterTargetsToShow(c3.data.targets), tickValues, i, intervalForCulling;
// abort if no targets to show // abort if no targets to show
if (targetsToShow.length === 0) { if (targetsToShow.length === 0 && __data_empty_abort) {
return; return;
} }
@ -3150,6 +3215,7 @@
drawArea = generateDrawArea(areaIndices); drawArea = generateDrawArea(areaIndices);
drawBar = generateDrawBar(barIndices); drawBar = generateDrawBar(barIndices);
drawLine = generateDrawLine(lineIndices); drawLine = generateDrawLine(lineIndices);
// drawNeedle = generateDrawNeedle();
xForText = generateXYForText(barIndices, true); xForText = generateXYForText(barIndices, true);
yForText = generateXYForText(barIndices, false); yForText = generateXYForText(barIndices, false);
@ -3372,6 +3438,9 @@
main.select('.' + CLASS.chartArcsTitle) main.select('.' + CLASS.chartArcsTitle)
.style("opacity", hasDonutType(c3.data.targets) ? 1 : 0); .style("opacity", hasDonutType(c3.data.targets) ? 1 : 0);
// gauge
// main.selectAll('.' + CLASS.gauge).select('.' + CLASS.arc);
// subchart // subchart
if (__subchart_show) { if (__subchart_show) {
// reflect main chart to extent on subchart if zoomed // reflect main chart to extent on subchart if zoomed
@ -4316,6 +4385,9 @@
else if ('columns' in config.data) { else if ('columns' in config.data) {
init(convertColumnsToData(config.data.columns)); init(convertColumnsToData(config.data.columns));
} }
// else if ('value' in config.data) {
// init(convertValueToData(config.data.value));
// }
else { else {
throw Error('url or rows or columns is required.'); throw Error('url or rows or columns is required.');
} }

2
c3.min.js vendored

File diff suppressed because one or more lines are too long
Loading…
Cancel
Save