Browse Source

Revert chart state when legend clicked

pull/200/merge
Masayuki Tanaka 11 years ago
parent
commit
740b558194
  1. 22
      c3.js
  2. 4
      c3.min.js

22
c3.js

@ -1747,9 +1747,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;
@ -4090,6 +4090,12 @@
.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) { return isTargetToShow(id) ? 1 : legendOpacityForHidden; });
// Update all to reflect change of legend // Update all to reflect change of legend
updateLegendItemWidth(maxWidth); updateLegendItemWidth(maxWidth);
updateLegendItemHeight(maxHeight); updateLegendItemHeight(maxHeight);
@ -4183,14 +4189,10 @@
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});
c3.revert();
}; };
c3.hide = function (targetIds, options) { c3.hide = function (targetIds, options) {
@ -4204,14 +4206,10 @@
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});
c3.revert();
}; };
c3.toggle = function (targetId) { c3.toggle = function (targetId) {

4
c3.min.js vendored

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