Browse Source

Merge pull request #1 from masayuki0812/master

Update fork
pull/200/head
Peter Göbel 11 years ago
parent
commit
e72fc63666
  1. 165
      c3.js
  2. 6
      c3.min.js
  3. 24
      htdocs/samples/data_hide.html
  4. 28
      htdocs/samples/point_r.html

165
c3.js

@ -61,6 +61,7 @@
legendItemEvent: 'c3-legend-item-event', legendItemEvent: 'c3-legend-item-event',
legendItemTile: 'c3-legend-item-tile', legendItemTile: 'c3-legend-item-tile',
legendItemHidden: 'c3-legend-item-hidden', legendItemHidden: 'c3-legend-item-hidden',
legendItemFocused: 'c3-legend-item-focused',
dragarea: 'c3-dragarea', dragarea: 'c3-dragarea',
EXPANDED: '_expanded_', EXPANDED: '_expanded_',
SELECTED: '_selected_', SELECTED: '_selected_',
@ -91,7 +92,7 @@
// Check next key's value // Check next key's value
isLast = (i === keys.length - 1); isLast = (i === keys.length - 1);
nextTarget = target[keys[i]]; nextTarget = target[keys[i]];
if ((!isLast && typeof nextTarget !== 'object') || (isLast && typeof defaultValue !== 'object' && typeof nextTarget === 'object' && nextTarget !== null)) { if (!isLast && typeof nextTarget !== 'object') {
return defaultValue; return defaultValue;
} }
target = nextTarget; target = nextTarget;
@ -105,7 +106,7 @@
var __size_width = getConfig(['size', 'width']), var __size_width = getConfig(['size', 'width']),
__size_height = getConfig(['size', 'height']); __size_height = getConfig(['size', 'height']);
var __padding_left = getConfig(['padding', 'left']), var __padding_left = getConfig(['padding', 'left'], 50),
__padding_right = getConfig(['padding', 'right']); __padding_right = getConfig(['padding', 'right']);
var __zoom_enabled = getConfig(['zoom', 'enabled'], false), var __zoom_enabled = getConfig(['zoom', 'enabled'], false),
@ -137,6 +138,7 @@
__data_regions = getConfig(['data', 'regions'], {}), __data_regions = getConfig(['data', 'regions'], {}),
__data_color = getConfig(['data', 'color']), __data_color = getConfig(['data', 'color']),
__data_colors = getConfig(['data', 'colors'], {}), __data_colors = getConfig(['data', 'colors'], {}),
__data_hide = getConfig(['data', 'hide'], false),
__data_selection_enabled = getConfig(['data', 'selection', 'enabled'], false), __data_selection_enabled = getConfig(['data', 'selection', 'enabled'], false),
__data_selection_grouped = getConfig(['data', 'selection', 'grouped'], false), __data_selection_grouped = getConfig(['data', 'selection', 'grouped'], false),
__data_selection_isselectable = getConfig(['data', 'selection', 'isselectable'], function () { return true; }), __data_selection_isselectable = getConfig(['data', 'selection', 'isselectable'], function () { return true; }),
@ -215,11 +217,11 @@
// point - point of each data // point - point of each data
var __point_show = getConfig(['point', 'show'], true), var __point_show = getConfig(['point', 'show'], true),
__point_r = __point_show ? getConfig(['point', 'r'], 2.5) : 0, __point_r = getConfig(['point', 'r'], 2.5),
__point_focus_line_enabled = getConfig(['point', 'focus', 'line', 'enabled'], true), __point_focus_line_enabled = getConfig(['point', 'focus', 'line', 'enabled'], true),
__point_focus_expand_enabled = getConfig(['point', 'focus', 'expand', 'enabled'], true), __point_focus_expand_enabled = getConfig(['point', 'focus', 'expand', 'enabled'], true),
__point_focus_expand_r = getConfig(['point', 'focus', 'expand', 'r'], __point_focus_expand_enabled ? 4 : __point_r), __point_focus_expand_r = getConfig(['point', 'focus', 'expand', 'r']),
__point_select_r = getConfig(['point', 'focus', 'select', 'r'], 8); __point_select_r = getConfig(['point', 'focus', 'select', 'r']);
var __line_connect_null = getConfig(['line', 'connect_null'], false); var __line_connect_null = getConfig(['line', 'connect_null'], false);
@ -350,7 +352,6 @@
function transformMain(withTransition, transitions) { function transformMain(withTransition, transitions) {
var xAxis, yAxis, y2Axis; var xAxis, yAxis, y2Axis;
if (transitions && transitions.axisX) { if (transitions && transitions.axisX) {
xAxis = transitions.axisX; xAxis = transitions.axisX;
} else { } else {
@ -369,7 +370,6 @@
y2Axis = main.select('.' + CLASS.axisY2); y2Axis = main.select('.' + CLASS.axisY2);
if (withTransition) { y2Axis = y2Axis.transition(); } if (withTransition) { y2Axis = y2Axis.transition(); }
} }
main.attr("transform", translate.main); main.attr("transform", translate.main);
xAxis.attr("transform", translate.x); xAxis.attr("transform", translate.x);
yAxis.attr("transform", translate.y); yAxis.attr("transform", translate.y);
@ -377,14 +377,18 @@
main.select('.' + CLASS.chartArcs).attr("transform", translate.arc); main.select('.' + CLASS.chartArcs).attr("transform", translate.arc);
} }
function transformContext(withTransition, transitions) { function transformContext(withTransition, transitions) {
var duration = withTransition !== false ? 250 : 0, var subXAxis;
subXAxis = (transitions && transitions.axisSubX) ? transitions.axisSubX : context.select('.' + CLASS.axisX).transition().duration(duration); if (transitions && transitions.axisSubX) {
subXAxis = transitions.axisSubX;
} else {
subXAxis = context.select('.' + CLASS.axisX);
if (withTransition) { subXAxis = subXAxis.transition(); }
}
context.attr("transform", translate.context); context.attr("transform", translate.context);
subXAxis.attr("transform", translate.subx); subXAxis.attr("transform", translate.subx);
} }
function transformLegend(withTransition) { function transformLegend(withTransition) {
var duration = withTransition !== false ? 250 : 0; (withTransition ? legend.transition() : legend).attr("transform", translate.legend);
legend.transition().duration(duration).attr("transform", translate.legend);
} }
function transformAll(withTransition, transitions) { function transformAll(withTransition, transitions) {
transformMain(withTransition, transitions); transformMain(withTransition, transitions);
@ -876,17 +880,20 @@
} }
function updateAxisLabels() { function updateAxisLabels() {
main.select('.' + CLASS.axisX + ' .' + CLASS.axisXLabel) main.select('.' + CLASS.axisX + ' .' + CLASS.axisXLabel)
.transition()
.attr("x", xForXAxisLabel) .attr("x", xForXAxisLabel)
.attr("dx", dxForXAxisLabel) .attr("dx", dxForXAxisLabel)
.attr("dy", dyForXAxisLabel) .attr("dy", dyForXAxisLabel)
.text(textForXAxisLabel); .text(textForXAxisLabel);
main.select('.' + CLASS.axisY + ' .' + CLASS.axisYLabel) main.select('.' + CLASS.axisY + ' .' + CLASS.axisYLabel)
.transition()
.attr("x", xForYAxisLabel) .attr("x", xForYAxisLabel)
.attr("dx", dxForYAxisLabel) .attr("dx", dxForYAxisLabel)
.attr("dy", dyForYAxisLabel) .attr("dy", dyForYAxisLabel)
.attr("dy", dyForYAxisLabel) .attr("dy", dyForYAxisLabel)
.text(textForYAxisLabel); .text(textForYAxisLabel);
main.select('.' + CLASS.axisY2 + ' .' + CLASS.axisY2Label) main.select('.' + CLASS.axisY2 + ' .' + CLASS.axisY2Label)
.transition()
.attr("x", xForY2AxisLabel) .attr("x", xForY2AxisLabel)
.attr("dx", dxForY2AxisLabel) .attr("dx", dxForY2AxisLabel)
.attr("dy", dyForY2AxisLabel) .attr("dy", dyForY2AxisLabel)
@ -1747,9 +1754,9 @@
return targetId || targetId === 0 ? '-' + (targetId.replace ? targetId.replace(/([^a-zA-Z0-9-_])/g, '-') : targetId) : ''; return targetId || targetId === 0 ? '-' + (targetId.replace ? targetId.replace(/([^a-zA-Z0-9-_])/g, '-') : targetId) : '';
} }
function selectorTarget(id) { return '.' + CLASS.target + getTargetSelectorSuffix(id); } function selectorTarget(id) { return '.' + CLASS.target + getTargetSelectorSuffix(id); }
function selectorTargets(ids) { return ids.map(function (id) { return selectorTarget(id); }); } function selectorTargets(ids) { return ids.length ? ids.map(function (id) { return selectorTarget(id); }) : null; }
function selectorLegend(id) { return '.' + CLASS.legendItem + getTargetSelectorSuffix(id); } function selectorLegend(id) { return '.' + CLASS.legendItem + getTargetSelectorSuffix(id); }
function selectorLegends(ids) { return ids.map(function (id) { return selectorLegend(id); }); } function selectorLegends(ids) { return ids.length ? ids.map(function (id) { return selectorLegend(id); }) : null; }
function initialOpacity(d) { function initialOpacity(d) {
return d.value !== null && withoutFadeIn[d.id] ? 1 : 0; return d.value !== null && withoutFadeIn[d.id] ? 1 : 0;
@ -1896,7 +1903,7 @@
return closest; return closest;
} }
function filterSameX(targets, x) { function filterSameX(targets, x) {
return d3.merge(targets.map(function (t) { return t.values; })).filter(function (v) { return v.x === x; }); return d3.merge(targets.map(function (t) { return t.values; })).filter(function (v) { return v.x - x === 0; });
} }
function getPathBox(path) { function getPathBox(path) {
@ -2047,7 +2054,7 @@
}; };
} }
function getBarW(axis, barTargetsNum) { function getBarW(axis, barTargetsNum) {
return __bar_width ? __bar_width : barTargetsNum ? (axis.tickOffset() * 2 * __bar_width_ratio) / barTargetsNum : 0; return typeof __bar_width === 'number' ? __bar_width : barTargetsNum ? (axis.tickOffset() * 2 * __bar_width_ratio) / barTargetsNum : 0;
} }
//-- Type --// //-- Type --//
@ -2237,9 +2244,9 @@
.attr("cx", __axis_rotated ? circleY : circleX) .attr("cx", __axis_rotated ? circleY : circleX)
.attr("cy", __axis_rotated ? circleX : circleY) .attr("cy", __axis_rotated ? circleX : circleY)
.attr("stroke", function () { return color(d); }) .attr("stroke", function () { return color(d); })
.attr("r", __point_select_r * 1.4) .attr("r", pointSelectR(d) * 1.4)
.transition().duration(100) .transition().duration(100)
.attr("r", __point_select_r); .attr("r", pointSelectR);
} }
function unselectPoint(target, d, i) { function unselectPoint(target, d, i) {
__data_onunselected(d, target.node()); __data_onunselected(d, target.node());
@ -2268,6 +2275,18 @@
return data.filter(function (d) { return isValue(d.value); }); return data.filter(function (d) { return isValue(d.value); });
} }
//-- Point --//
function pointR(d) {
return __point_show ? (typeof __point_r === 'function' ? __point_r(d) : __point_r) : 0;
}
function pointExpandedR(d) {
return __point_focus_expand_enabled ? (__point_focus_expand_r ? __point_focus_expand_r : pointR(d) * 1.75) : pointR(d);
}
function pointSelectR(d) {
return __point_select_r ? __point_select_r : pointR(d) * 4;
}
//-- Shape --// //-- Shape --//
function getCircles(i, id) { function getCircles(i, id) {
@ -2276,13 +2295,13 @@
function expandCircles(i, id) { function expandCircles(i, id) {
getCircles(i, id) getCircles(i, id)
.classed(CLASS.EXPANDED, true) .classed(CLASS.EXPANDED, true)
.attr('r', __point_focus_expand_r); .attr('r', pointExpandedR);
} }
function unexpandCircles(i) { function unexpandCircles(i) {
getCircles(i) getCircles(i)
.filter(function () { return d3.select(this).classed(CLASS.EXPANDED); }) .filter(function () { return d3.select(this).classed(CLASS.EXPANDED); })
.classed(CLASS.EXPANDED, false) .classed(CLASS.EXPANDED, false)
.attr('r', __point_r); .attr('r', pointR);
} }
function getBars(i) { function getBars(i) {
return main.selectAll('.' + CLASS.bar + (isValue(i) ? '-' + i : '')); return main.selectAll('.' + CLASS.bar + (isValue(i) ? '-' + i : ''));
@ -2546,6 +2565,11 @@
c3.data.xs = {}; c3.data.xs = {};
c3.data.targets = convertDataToTargets(data); c3.data.targets = convertDataToTargets(data);
// Set targets to hide if needed
if (__data_hide) {
addHiddenTargetIds(__data_hide === true ? mapToIds(c3.data.targets) : __data_hide);
}
// Init sizes and scales // Init sizes and scales
updateSizes(); updateSizes();
updateScales(); updateScales();
@ -2887,12 +2911,12 @@
.filter(function (d) { return __data_selection_isselectable(d); }) .filter(function (d) { return __data_selection_isselectable(d); })
.each(function () { .each(function () {
var _this = d3.select(this).classed(CLASS.EXPANDED, true); var _this = d3.select(this).classed(CLASS.EXPANDED, true);
if (this.nodeName === 'circle') { _this.attr('r', __point_focus_expand_r); } if (this.nodeName === 'circle') { _this.attr('r', pointExpandedR); }
svg.select('.' + CLASS.eventRect + '-' + i).style('cursor', null); svg.select('.' + CLASS.eventRect + '-' + i).style('cursor', null);
}) })
.filter(function () { .filter(function (d) {
if (this.nodeName === 'circle') { if (this.nodeName === 'circle') {
return isWithinCircle(this, __point_select_r); return isWithinCircle(this, pointSelectR(d));
} }
else if (this.nodeName === 'path') { else if (this.nodeName === 'path') {
return isWithinBar(this); return isWithinBar(this);
@ -2902,7 +2926,7 @@
var _this = d3.select(this); var _this = d3.select(this);
if (! _this.classed(CLASS.EXPANDED)) { if (! _this.classed(CLASS.EXPANDED)) {
_this.classed(CLASS.EXPANDED, true); _this.classed(CLASS.EXPANDED, true);
if (this.nodeName === 'circle') { _this.attr('r', __point_select_r); } if (this.nodeName === 'circle') { _this.attr('r', pointSelectR); }
} }
svg.select('.' + CLASS.eventRect + '-' + i).style('cursor', 'pointer'); svg.select('.' + CLASS.eventRect + '-' + i).style('cursor', 'pointer');
}); });
@ -3015,7 +3039,7 @@
isSelected = shape.classed(CLASS.SELECTED); isSelected = shape.classed(CLASS.SELECTED);
var isWithin = false, toggle; var isWithin = false, toggle;
if (target.nodeName === 'circle') { if (target.nodeName === 'circle') {
isWithin = isWithinCircle(target, __point_select_r * 1.5); isWithin = isWithinCircle(target, pointSelectR(d) * 1.5);
toggle = togglePoint; toggle = togglePoint;
} }
else if (target.nodeName === 'path') { else if (target.nodeName === 'path') {
@ -3413,7 +3437,7 @@
mainCircle.enter().append("circle") mainCircle.enter().append("circle")
.attr("class", classCircle) .attr("class", classCircle)
.style('opacity', 0) .style('opacity', 0)
.attr("r", __point_r); .attr("r", pointR);
mainCircle mainCircle
.style("opacity", initialOpacity) .style("opacity", initialOpacity)
.transition().duration(duration) .transition().duration(duration)
@ -3674,6 +3698,7 @@
.attr('class', classChartText); .attr('class', classChartText);
mainTextEnter = mainTextUpdate.enter().append('g') mainTextEnter = mainTextUpdate.enter().append('g')
.attr('class', classChartText) .attr('class', classChartText)
.style('opacity', 0)
.style("pointer-events", "none"); .style("pointer-events", "none");
mainTextEnter.append('g') mainTextEnter.append('g')
.attr('class', classTexts) .attr('class', classTexts)
@ -3685,6 +3710,7 @@
.attr('class', classChartBar); .attr('class', classChartBar);
mainBarEnter = mainBarUpdate.enter().append('g') mainBarEnter = mainBarUpdate.enter().append('g')
.attr('class', classChartBar) .attr('class', classChartBar)
.style('opacity', 0)
.style("pointer-events", "none"); .style("pointer-events", "none");
// Bars for each data // Bars for each data
mainBarEnter.append('g') mainBarEnter.append('g')
@ -3699,6 +3725,7 @@
.attr('class', classChartLine); .attr('class', classChartLine);
mainLineEnter = mainLineUpdate.enter().append('g') mainLineEnter = mainLineUpdate.enter().append('g')
.attr('class', classChartLine) .attr('class', classChartLine)
.style('opacity', 0)
.style("pointer-events", "none"); .style("pointer-events", "none");
// Lines for each data // Lines for each data
mainLineEnter.append("path") mainLineEnter.append("path")
@ -3748,7 +3775,7 @@
callback = getArcOnMouseOver(); callback = getArcOnMouseOver();
// transitions // transitions
expandArc(updated.data.id); expandArc(updated.data.id);
focusLegend(updated.data.id); toggleFocusLegend(updated.data.id, true);
callback(arcData, i); callback(arcData, i);
}) })
.on('mousemove', function (d) { .on('mousemove', function (d) {
@ -3789,6 +3816,7 @@
.data(targets) .data(targets)
.attr('class', classChartBar); .attr('class', classChartBar);
contextBarEnter = contextBarUpdate.enter().append('g') contextBarEnter = contextBarUpdate.enter().append('g')
.style('opacity', 0)
.attr('class', classChartBar); .attr('class', classChartBar);
// Bars for each data // Bars for each data
contextBarEnter.append('g') contextBarEnter.append('g')
@ -3800,6 +3828,7 @@
.data(targets) .data(targets)
.attr('class', classChartLine); .attr('class', classChartLine);
contextLineEnter = contextLineUpdate.enter().append('g') contextLineEnter = contextLineUpdate.enter().append('g')
.style('opacity', 0)
.attr('class', classChartLine); .attr('class', classChartLine);
// Lines for each data // Lines for each data
contextLineEnter.append("path") contextLineEnter.append("path")
@ -3812,7 +3841,7 @@
// Fade-in each chart // Fade-in each chart
svg.selectAll('.' + CLASS.target).filter(function (d) { return isTargetToShow(d.id); }) svg.selectAll('.' + CLASS.target).filter(function (d) { return isTargetToShow(d.id); })
.transition() .transition().duration(__transition_duration)
.style("opacity", 1); .style("opacity", 1);
} }
@ -3896,38 +3925,45 @@
/*-- Draw Legend --*/ /*-- Draw Legend --*/
function opacityForLegend(id) { function opacityForLegend(legendItem) {
return d3.select(selectorLegend(id)).classed(CLASS.legendItemHidden) ? legendOpacityForHidden : 1; return legendItem.classed(CLASS.legendItemHidden) ? legendOpacityForHidden : 1;
} }
function opacityForUnfocusedLegend(id) { function opacityForUnfocusedLegend(legendItem) {
return d3.select(selectorLegend(id)).classed(CLASS.legendItemHidden) ? legendOpacityForHidden : 0.3; return legendItem.classed(CLASS.legendItemHidden) ? legendOpacityForHidden : 0.3;
} }
function toggleFocusLegend(id, focus) { function toggleFocusLegend(id, focus) {
var legendItem = legend.selectAll('.' + CLASS.legendItem), legend.selectAll('.' + CLASS.legendItem)
isTarget = function (d) { return (!id || d === id); }, .transition().duration(100)
notTarget = function (d) { return !isTarget(d); }; .style('opacity', function (_id) {
legendItem.filter(notTarget).transition().duration(100).style('opacity', focus ? opacityForUnfocusedLegend : opacityForLegend); var This = d3.select(this);
legendItem.filter(isTarget).transition().duration(100).style('opacity', focus ? opacityForLegend : opacityForUnfocusedLegend); if (id && _id !== id) {
} return focus ? opacityForUnfocusedLegend(This) : opacityForLegend(This);
function focusLegend(id) { } else {
toggleFocusLegend(id, true); return focus ? opacityForLegend(This) : opacityForUnfocusedLegend(This);
} }
function defocusLegend(id) { });
toggleFocusLegend(id, false);
} }
function revertLegend() { function revertLegend() {
legend.selectAll('.' + CLASS.legendItem) legend.selectAll('.' + CLASS.legendItem)
.transition().duration(100) .transition().duration(100)
.style('opacity', opacityForLegend); .style('opacity', function () { return opacityForLegend(d3.select(this)); });
} }
function showLegend(targetIds) { function showLegend(targetIds) {
if (!__legend_show) {
__legend_show = true;
legend.style('visibility', 'visible');
}
removeHiddenLegendIds(targetIds); removeHiddenLegendIds(targetIds);
legend.selectAll(selectorLegends(targetIds)) legend.selectAll(selectorLegends(targetIds))
.style('visibility', 'visible') .style('visibility', 'visible')
.transition() .transition()
.style('opacity', opacityForLegend); .style('opacity', function () { return opacityForLegend(d3.select(this)); });
} }
function hideLegend(targetIds) { function hideLegend(targetIds) {
if (__legend_show && isEmpty(targetIds)) {
__legend_show = false;
legend.style('visibility', 'hidden');
}
addHiddenLegendIds(targetIds); addHiddenLegendIds(targetIds);
legend.selectAll(selectorLegends(targetIds)) legend.selectAll(selectorLegends(targetIds))
.style('opacity', 0) .style('opacity', 0)
@ -3938,12 +3974,12 @@
var xForLegend, xForLegendText, xForLegendRect, yForLegend, yForLegendText, yForLegendRect; var xForLegend, xForLegendText, xForLegendRect, yForLegend, yForLegendText, yForLegendRect;
var paddingTop = 4, paddingRight = 26, maxWidth = 0, maxHeight = 0, posMin = 10; var paddingTop = 4, paddingRight = 26, maxWidth = 0, maxHeight = 0, posMin = 10;
var l, totalLength = 0, offsets = {}, widths = {}, heights = {}, margins = [0], steps = {}, step = 0; var l, totalLength = 0, offsets = {}, widths = {}, heights = {}, margins = [0], steps = {}, step = 0;
var withTransition, withTransitionForTransform, withTransformAll; var withTransition, withTransitionForTransform;
var hasFocused = legend.selectAll('.' + CLASS.legendItemFocused).size();
options = options || {}; options = options || {};
withTransition = isDefined(options.withTransition) ? options.withTransition : true; withTransition = isDefined(options.withTransition) ? options.withTransition : true;
withTransitionForTransform = isDefined(options.withTransitionForTransform) ? options.withTransitionForTransform : true; withTransitionForTransform = isDefined(options.withTransitionForTransform) ? options.withTransitionForTransform : true;
withTransformAll = isDefined(options.withTransformAll) ? options.withTransformAll : true;
function updatePositions(textElement, id, reset) { function updatePositions(textElement, id, reset) {
var box = textElement.getBoundingClientRect(), var box = textElement.getBoundingClientRect(),
@ -4028,6 +4064,7 @@
typeof __legend_item_onclick === 'function' ? __legend_item_onclick(id) : c3.toggle(id); typeof __legend_item_onclick === 'function' ? __legend_item_onclick(id) : c3.toggle(id);
}) })
.on('mouseover', function (id) { .on('mouseover', function (id) {
d3.select(this).classed(CLASS.legendItemFocused, true);
if (!transiting) { if (!transiting) {
c3.focus(id); c3.focus(id);
} }
@ -4036,6 +4073,7 @@
} }
}) })
.on('mouseout', function (id) { .on('mouseout', function (id) {
d3.select(this).classed(CLASS.legendItemFocused, false);
if (!transiting) { if (!transiting) {
c3.revert(); c3.revert();
} }
@ -4085,6 +4123,19 @@
.attr('x', xForLegend) .attr('x', xForLegend)
.attr('y', yForLegend); .attr('y', yForLegend);
// toggle legend state
legend.selectAll('.' + CLASS.legendItem)
.classed(CLASS.legendItemHidden, function (id) { return !isTargetToShow(id); })
.transition()
.style('opacity', function (id) {
var This = d3.select(this);
if (isTargetToShow(id)) {
return !hasFocused || This.classed(CLASS.legendItemFocused) ? opacityForLegend(This) : opacityForUnfocusedLegend(This);
} else {
return legendOpacityForHidden;
}
});
// Update all to reflect change of legend // Update all to reflect change of legend
updateLegendItemWidth(maxWidth); updateLegendItemWidth(maxWidth);
updateLegendItemHeight(maxHeight); updateLegendItemHeight(maxHeight);
@ -4094,10 +4145,8 @@
updateScales(); updateScales();
updateSvgSize(); updateSvgSize();
// Update g positions // Update g positions
if (withTransformAll) {
transformAll(withTransitionForTransform, transitions); transformAll(withTransitionForTransform, transitions);
} }
}
/*-- Event Handling --*/ /*-- Event Handling --*/
@ -4133,7 +4182,7 @@
if (hasArcType(c3.data.targets)) { if (hasArcType(c3.data.targets)) {
expandArc(targetId, true); expandArc(targetId, true);
} }
focusLegend(targetId); toggleFocusLegend(targetId, true);
}; };
c3.defocus = function (targetId) { c3.defocus = function (targetId) {
@ -4149,7 +4198,7 @@
if (hasArcType(c3.data.targets)) { if (hasArcType(c3.data.targets)) {
unexpandArc(targetId); unexpandArc(targetId);
} }
defocusLegend(targetId); toggleFocusLegend(targetId, false);
}; };
c3.revert = function (targetId) { c3.revert = function (targetId) {
@ -4178,11 +4227,6 @@
if (options.withLegend) { if (options.withLegend) {
showLegend(targetIds); showLegend(targetIds);
} else {
legend.selectAll(selectorLegends(targetIds))
.classed(CLASS.legendItemHidden, false)
.transition()
.style('opacity', 1);
} }
redraw({withUpdateOrgXDomain: true, withUpdateXDomain: true, withLegend: true}); redraw({withUpdateOrgXDomain: true, withUpdateXDomain: true, withLegend: true});
@ -4199,11 +4243,6 @@
if (options.withLegend) { if (options.withLegend) {
hideLegend(targetIds); hideLegend(targetIds);
} else {
legend.selectAll(selectorLegends(targetIds))
.classed(CLASS.legendItemHidden, true)
.transition()
.style('opacity', legendOpacityForHidden);
} }
redraw({withUpdateOrgXDomain: true, withUpdateXDomain: true, withLegend: true}); redraw({withUpdateOrgXDomain: true, withUpdateXDomain: true, withLegend: true});
@ -4472,20 +4511,12 @@
}; };
c3.legend.show = function (targetIds) { c3.legend.show = function (targetIds) {
if (!__legend_show) {
__legend_show = true;
legend.style('visibility', 'visible');
}
showLegend(mapToTargetIds(targetIds)); showLegend(mapToTargetIds(targetIds));
redraw({withLegend: true}); redraw({withLegend: true});
}; };
c3.legend.hide = function (targetIds) { c3.legend.hide = function (targetIds) {
hideLegend(mapToTargetIds(targetIds)); hideLegend(mapToTargetIds(targetIds));
redraw({withLegend: true}); redraw({withLegend: true});
if (__legend_show && isEmpty(targetIds)) {
__legend_show = false;
legend.style('visibility', 'hidden');
}
}; };
c3.resize = function (size) { c3.resize = function (size) {

6
c3.min.js vendored

File diff suppressed because one or more lines are too long

24
htdocs/samples/data_hide.html

@ -0,0 +1,24 @@
<html>
<head>
<link href="/css/c3.css" rel="stylesheet" type="text/css">
</head>
<body>
<div id="chart"></div>
<script src="http://d3js.org/d3.v3.min.js" charset="utf-8"></script>
<script src="/js/c3.min.js"></script>
<script>
var chart = c3.generate({
data: {
columns: [
['data1', 30, 20, 50, 40, 60, 50],
['data2', 200, 130, 90, 240, 130, 220],
['data3', 300, 200, 160, 400, 250, 250]
],
// hide: ['data1', 'data3']
hide: true // hide all data
}
});
</script>
</body>
</html>

28
htdocs/samples/point_r.html

@ -0,0 +1,28 @@
<html>
<head>
<link rel="stylesheet" type="text/css" href="/css/c3.css">
</head>
<body>
<div id="chart"></div>
<script src="http://d3js.org/d3.v3.min.js" charset="utf-8"></script>
<script src="/js/c3.min.js"></script>
<script>
var chart = c3.generate({
bindto: '#chart',
data: {
columns: [
['data1', 30, 200, 100, 400, 150, 250],
['data2', 130, 300, 200, 600, 250, 150]
],
},
point: {
// r: 10
r: function (d) {
return d.id === 'data2' ? 10 : 2.5;
}
}
});
</script>
</body>
</html>
Loading…
Cancel
Save