Browse Source

Gray out legend when hidden - #128

pull/155/head
Masayuki Tanaka 11 years ago
parent
commit
aa9069dc40
  1. 22
      c3.js
  2. 6
      c3.min.js

22
c3.js

@ -60,6 +60,7 @@
legendItem: 'c3-legend-item', legendItem: 'c3-legend-item',
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',
dragarea: 'c3-dragarea', dragarea: 'c3-dragarea',
EXPANDED: '_expanded_', EXPANDED: '_expanded_',
SELECTED: '_selected_', SELECTED: '_selected_',
@ -3669,12 +3670,15 @@
/*-- Draw Legend --*/ /*-- Draw Legend --*/
function opacityForLegend(id) {
return d3.select(selectorLegend(id)).classed(CLASS.legendItemHidden) ? 0.5 : 1;
}
function toggleFocusLegend(id, focus) { function toggleFocusLegend(id, focus) {
var legendItem = legend.selectAll('.' + CLASS.legendItem), var legendItem = legend.selectAll('.' + CLASS.legendItem),
isTarget = function (d) { return (!id || d === id); }, isTarget = function (d) { return (!id || d === id); },
notTarget = function (d) { return !isTarget(d); }; notTarget = function (d) { return !isTarget(d); };
legendItem.filter(notTarget).transition().duration(100).style('opacity', focus ? 0.3 : 1); legendItem.filter(notTarget).transition().duration(100).style('opacity', focus ? 0.3 : opacityForLegend);
legendItem.filter(isTarget).transition().duration(100).style('opacity', focus ? 1 : 0.3); legendItem.filter(isTarget).transition().duration(100).style('opacity', focus ? opacityForLegend : 0.3);
} }
function focusLegend(id) { function focusLegend(id) {
toggleFocusLegend(id, true); toggleFocusLegend(id, true);
@ -3685,14 +3689,14 @@
function revertLegend() { function revertLegend() {
legend.selectAll('.' + CLASS.legendItem) legend.selectAll('.' + CLASS.legendItem)
.transition().duration(100) .transition().duration(100)
.style('opacity', 1); .style('opacity', opacityForLegend);
} }
function showLegend(targetIds) { function showLegend(targetIds) {
removeHiddenLegendIds(targetIds); removeHiddenLegendIds(targetIds);
legend.selectAll(selectorLegends(targetIds)) legend.selectAll(selectorLegends(targetIds))
.style('visibility', 'visible') .style('visibility', 'visible')
.transition() .transition()
.style('opacity', 1); .style('opacity', opacityForLegend);
updateLegend(mapToIds(c3.data.targets)); updateLegend(mapToIds(c3.data.targets));
} }
function hideLegend(targetIds) { function hideLegend(targetIds) {
@ -3936,6 +3940,11 @@
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, withTransitionForHorizontalAxis: false}); redraw({withUpdateOrgXDomain: true, withUpdateXDomain: true, withTransitionForHorizontalAxis: false});
@ -3952,6 +3961,11 @@
if (options.withLegend) { if (options.withLegend) {
hideLegend(targetIds); hideLegend(targetIds);
} else {
legend.selectAll(selectorLegends(targetIds))
.classed(CLASS.legendItemHidden, true)
.transition()
.style('opacity', 0.5);
} }
redraw({withUpdateOrgXDomain: true, withUpdateXDomain: true, withTransitionForHorizontalAxis: false}); redraw({withUpdateOrgXDomain: true, withUpdateXDomain: true, withTransitionForHorizontalAxis: false});

6
c3.min.js vendored

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