|
|
@ -3670,12 +3670,13 @@ |
|
|
|
$$.api.show(id); |
|
|
|
$$.api.show(id); |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
$$.api.toggle(id); |
|
|
|
$$.api.toggle(id); |
|
|
|
|
|
|
|
$$.isTargetToShow(id) ? $$.api.focus(id) : $$.api.revert(); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
}) |
|
|
|
}) |
|
|
|
.on('mouseover', function (id) { |
|
|
|
.on('mouseover', function (id) { |
|
|
|
$$.d3.select(this).classed(CLASS.legendItemFocused, true); |
|
|
|
$$.d3.select(this).classed(CLASS.legendItemFocused, true); |
|
|
|
if (!$$.transiting) { |
|
|
|
if (!$$.transiting && $$.isTargetToShow(id)) { |
|
|
|
$$.api.focus(id); |
|
|
|
$$.api.focus(id); |
|
|
|
} |
|
|
|
} |
|
|
|
if (config.legend_item_onmouseover) { |
|
|
|
if (config.legend_item_onmouseover) { |
|
|
@ -4286,17 +4287,23 @@ |
|
|
|
return format ? format(value, ratio) : $$.defaultArcValueFormat(value, ratio); |
|
|
|
return format ? format(value, ratio) : $$.defaultArcValueFormat(value, ratio); |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
c3_chart_internal_fn.expandArc = function (targetIds, withoutFadeOut) { |
|
|
|
c3_chart_internal_fn.expandArc = function (targetIds) { |
|
|
|
var $$ = this, targets, noneTargets; |
|
|
|
var $$ = this, interval; |
|
|
|
|
|
|
|
|
|
|
|
targetIds = $$.mapToTargetIds(targetIds); |
|
|
|
// MEMO: avoid to cancel transition
|
|
|
|
|
|
|
|
if ($$.transiting) { |
|
|
|
|
|
|
|
interval = window.setInterval(function () { |
|
|
|
|
|
|
|
if (!$$.transiting) { |
|
|
|
|
|
|
|
window.clearInterval(interval); |
|
|
|
|
|
|
|
$$.expandArc(targetIds); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}, 10); |
|
|
|
|
|
|
|
return; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
targets = $$.svg.selectAll($$.selectorTargets(targetIds, '.' + CLASS.chartArc)), |
|
|
|
targetIds = $$.mapToTargetIds(targetIds); |
|
|
|
noneTargets = $$.svg.selectAll('.' + CLASS.arc).filter(function (data) { |
|
|
|
|
|
|
|
return targetIds.indexOf(data.data.id) < 0; |
|
|
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
targets.each(function (d) { |
|
|
|
$$.svg.selectAll($$.selectorTargets(targetIds, '.' + CLASS.chartArc)).each(function (d) { |
|
|
|
if (! $$.shouldExpand(d.data.id)) { return; } |
|
|
|
if (! $$.shouldExpand(d.data.id)) { return; } |
|
|
|
$$.d3.select(this).selectAll('path') |
|
|
|
$$.d3.select(this).selectAll('path') |
|
|
|
.transition().duration(50) |
|
|
|
.transition().duration(50) |
|
|
@ -4309,18 +4316,16 @@ |
|
|
|
} |
|
|
|
} |
|
|
|
}); |
|
|
|
}); |
|
|
|
}); |
|
|
|
}); |
|
|
|
if (!withoutFadeOut) { |
|
|
|
|
|
|
|
noneTargets.style("opacity", 0.3); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
c3_chart_internal_fn.unexpandArc = function (targetIds) { |
|
|
|
c3_chart_internal_fn.unexpandArc = function (targetIds) { |
|
|
|
var $$ = this, targets; |
|
|
|
var $$ = this; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if ($$.transiting) { return; } |
|
|
|
|
|
|
|
|
|
|
|
targetIds = $$.mapToTargetIds(targetIds); |
|
|
|
targetIds = $$.mapToTargetIds(targetIds); |
|
|
|
targets = $$.svg.selectAll($$.selectorTargets(targetIds, '.' + CLASS.chartArc)); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
targets.selectAll('path.' + CLASS.arc) |
|
|
|
$$.svg.selectAll($$.selectorTargets(targetIds, '.' + CLASS.chartArc)).selectAll('path') |
|
|
|
.transition().duration(50) |
|
|
|
.transition().duration(50) |
|
|
|
.attr("d", $$.svgArc); |
|
|
|
.attr("d", $$.svgArc); |
|
|
|
$$.svg.selectAll('.' + CLASS.arc) |
|
|
|
$$.svg.selectAll('.' + CLASS.arc) |
|
|
@ -5369,7 +5374,7 @@ |
|
|
|
this.defocus(); |
|
|
|
this.defocus(); |
|
|
|
candidates.classed(CLASS.focused, true).classed(CLASS.defocused, false); |
|
|
|
candidates.classed(CLASS.focused, true).classed(CLASS.defocused, false); |
|
|
|
if ($$.hasArcType()) { |
|
|
|
if ($$.hasArcType()) { |
|
|
|
$$.expandArc(targetIds, true); |
|
|
|
$$.expandArc(targetIds); |
|
|
|
} |
|
|
|
} |
|
|
|
$$.toggleFocusLegend(targetIds, true); |
|
|
|
$$.toggleFocusLegend(targetIds, true); |
|
|
|
|
|
|
|
|
|
|
@ -5402,7 +5407,7 @@ |
|
|
|
var $$ = this.internal, candidates; |
|
|
|
var $$ = this.internal, candidates; |
|
|
|
|
|
|
|
|
|
|
|
targetIds = $$.mapToTargetIds(targetIds); |
|
|
|
targetIds = $$.mapToTargetIds(targetIds); |
|
|
|
candidates = $$.svg.selectAll($$.selectorTargets(targetIds.filter($$.isTargetToShow, $$))); |
|
|
|
candidates = $$.svg.selectAll($$.selectorTargets(targetIds)); // should be for all targets
|
|
|
|
|
|
|
|
|
|
|
|
candidates.classed(CLASS.focused, false).classed(CLASS.defocused, false); |
|
|
|
candidates.classed(CLASS.focused, false).classed(CLASS.defocused, false); |
|
|
|
if ($$.hasArcType()) { |
|
|
|
if ($$.hasArcType()) { |
|
|
@ -5426,9 +5431,7 @@ |
|
|
|
targets.transition() |
|
|
|
targets.transition() |
|
|
|
.style('opacity', 1, 'important') |
|
|
|
.style('opacity', 1, 'important') |
|
|
|
.call($$.endall, function () { |
|
|
|
.call($$.endall, function () { |
|
|
|
targets.style('opacity', null).style('opacity', 1) |
|
|
|
targets.style('opacity', null).style('opacity', 1); |
|
|
|
.classed(CLASS.focused, false) |
|
|
|
|
|
|
|
.classed(CLASS.defocused, false); |
|
|
|
|
|
|
|
}); |
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
if (options.withLegend) { |
|
|
|
if (options.withLegend) { |
|
|
@ -5450,9 +5453,7 @@ |
|
|
|
targets.transition() |
|
|
|
targets.transition() |
|
|
|
.style('opacity', 0, 'important') |
|
|
|
.style('opacity', 0, 'important') |
|
|
|
.call($$.endall, function () { |
|
|
|
.call($$.endall, function () { |
|
|
|
targets.style('opacity', null).style('opacity', 0) |
|
|
|
targets.style('opacity', null).style('opacity', 0); |
|
|
|
.classed(CLASS.focused, false) |
|
|
|
|
|
|
|
.classed(CLASS.defocused, false); |
|
|
|
|
|
|
|
}); |
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
if (options.withLegend) { |
|
|
|
if (options.withLegend) { |
|
|
|