|
|
|
c3_chart_internal_fn.selectPoint = function (target, d, i) {
|
|
|
|
var $$ = this, config = $$.config,
|
|
|
|
cx = generateCall(config[__axis_rotated] ? $$.circleY : $$.circleX, $$),
|
|
|
|
cy = generateCall(config[__axis_rotated] ? $$.circleX : $$.circleY, $$);
|
|
|
|
|
|
|
|
config[__data_onselected].call($$.api, d, target.node());
|
|
|
|
// add selected-circle on low layer g
|
|
|
|
$$.main.select('.' + CLASS[_selectedCircles] + $$.getTargetSelectorSuffix(d.id)).selectAll('.' + CLASS[_selectedCircle] + '-' + i)
|
|
|
|
.data([d])
|
|
|
|
.enter().append('circle')
|
|
|
|
.attr("class", function () { return $$.generateClass(CLASS[_selectedCircle], i); })
|
|
|
|
.attr("cx", cx)
|
|
|
|
.attr("cy", cy)
|
|
|
|
.attr("stroke", function () { return $$.color(d); })
|
|
|
|
.attr("r", function (d) { return $$.pointSelectR(d) * 1.4; })
|
|
|
|
.transition().duration(100)
|
|
|
|
.attr("r", generateCall($$.pointSelectR, $$));
|
|
|
|
};
|
|
|
|
c3_chart_internal_fn.unselectPoint = function (target, d, i) {
|
|
|
|
var $$ = this;
|
|
|
|
$$.config[__data_onunselected](d, target.node());
|
|
|
|
// remove selected-circle from low layer g
|
|
|
|
$$.main.select('.' + CLASS[_selectedCircles] + $$.getTargetSelectorSuffix(d.id)).selectAll('.' + CLASS[_selectedCircle] + '-' + i)
|
|
|
|
.transition().duration(100).attr('r', 0)
|
|
|
|
.remove();
|
|
|
|
};
|
|
|
|
c3_chart_internal_fn.togglePoint = function (selected, target, d, i) {
|
|
|
|
selected ? this.selectPoint(target, d, i) : this.unselectPoint(target, d, i);
|
|
|
|
};
|
|
|
|
c3_chart_internal_fn.selectBar = function (target, d) {
|
|
|
|
var $$ = this;
|
|
|
|
$$.config[__data_onselected].call($$, d, target.node());
|
|
|
|
target.transition().duration(100)
|
|
|
|
.style("fill", function () { return $$.d3.rgb($$.color(d)).brighter(0.75); });
|
|
|
|
};
|
|
|
|
c3_chart_internal_fn.unselectBar = function (target, d) {
|
|
|
|
var $$ = this;
|
|
|
|
$$.config[__data_onunselected].call($$, d, target.node());
|
|
|
|
target.transition().duration(100)
|
|
|
|
.style("fill", function () { return $$.color(d); });
|
|
|
|
};
|
|
|
|
c3_chart_internal_fn.toggleBar = function (selected, target, d, i) {
|
|
|
|
selected ? this.selectBar(target, d, i) : this.unselectBar(target, d, i);
|
|
|
|
};
|
|
|
|
c3_chart_internal_fn.toggleArc = function (selected, target, d, i) {
|
|
|
|
this.toggleBar(selected, target, d.data, i);
|
|
|
|
};
|
|
|
|
c3_chart_internal_fn.getToggle = function (that) {
|
|
|
|
var $$ = this;
|
|
|
|
// path selection not supported yet
|
|
|
|
return that.nodeName === 'circle' ? $$.togglePoint : ($$.d3.select(that).classed(CLASS[_bar]) ? $$.toggleBar : $$.toggleArc);
|
|
|
|
};
|
|
|
|
c3_chart_internal_fn.toggleShape = function (that, d, i) {
|
|
|
|
var $$ = this, d3 = $$.d3, config = $$.config,
|
|
|
|
shape = d3.select(that), isSelected = shape.classed(CLASS[_SELECTED]), isWithin, toggle;
|
|
|
|
if (that.nodeName === 'circle') {
|
|
|
|
isWithin = $$.isWithinCircle(that, $$.pointSelectR(d) * 1.5);
|
|
|
|
toggle = $$.togglePoint;
|
|
|
|
}
|
|
|
|
else if (that.nodeName === 'path') {
|
|
|
|
if (shape.classed(CLASS[_bar])) {
|
|
|
|
isWithin = $$.isWithinBar(that);
|
|
|
|
toggle = $$.toggleBar;
|
|
|
|
} else { // would be arc
|
|
|
|
isWithin = true;
|
|
|
|
toggle = $$.toggleArc;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (config[__data_selection_grouped] || isWithin) {
|
|
|
|
if (config[__data_selection_enabled] && config[__data_selection_isselectable](d)) {
|
|
|
|
if (!config[__data_selection_multiple]) {
|
|
|
|
$$.main.selectAll('.' + CLASS[_shapes] + (config[__data_selection_grouped] ? $$.getTargetSelectorSuffix(d.id) : "")).selectAll('.' + CLASS[_shape]).each(function (d, i) {
|
|
|
|
var shape = d3.select(this);
|
|
|
|
if (shape.classed(CLASS[_SELECTED])) { toggle.call($$, false, shape.classed(CLASS[_SELECTED], false), d, i); }
|
|
|
|
});
|
|
|
|
}
|
|
|
|
shape.classed(CLASS[_SELECTED], !isSelected);
|
|
|
|
toggle.call($$, !isSelected, shape, d, i);
|
|
|
|
}
|
|
|
|
$$.config[__data_onclick].call($$.api, d, that);
|
|
|
|
}
|
|
|
|
};
|