|
|
@ -648,7 +648,7 @@ |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// when gauge, hide legend // TODO: fix
|
|
|
|
// when gauge, hide legend // TODO: fix
|
|
|
|
if ($$[hasType](TYPE_GAUGE)) { |
|
|
|
if ($$[hasType]($$.data.targets, TYPE_GAUGE)) { |
|
|
|
config[__legend_show] = false; |
|
|
|
config[__legend_show] = false; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -842,7 +842,7 @@ |
|
|
|
} |
|
|
|
} |
|
|
|
$$.tooltip.html(config[__tooltip_contents].call($$, $$.data.targets.map(function (d) { |
|
|
|
$$.tooltip.html(config[__tooltip_contents].call($$, $$.data.targets.map(function (d) { |
|
|
|
return $$[addName](d.values[config[__tooltip_init_x]]); |
|
|
|
return $$[addName](d.values[config[__tooltip_init_x]]); |
|
|
|
}), $$[getXAxisTickFormat](), $$[getYFormat]($$[hasArcType]()), $$.color)); |
|
|
|
}), $$[getXAxisTickFormat](), $$[getYFormat]($$[hasArcType]($$.data.targets)), $$.color)); |
|
|
|
$$.tooltip.style("top", config[__tooltip_init_position].top) |
|
|
|
$$.tooltip.style("top", config[__tooltip_init_position].top) |
|
|
|
.style("left", config[__tooltip_init_position].left) |
|
|
|
.style("left", config[__tooltip_init_position].left) |
|
|
|
.style("display", "block"); |
|
|
|
.style("display", "block"); |
|
|
@ -895,7 +895,7 @@ |
|
|
|
var $$ = this, config = $$.config; |
|
|
|
var $$ = this, config = $$.config; |
|
|
|
var legendHeight = $$[getLegendHeight](), legendWidth = $$[getLegendWidth](), |
|
|
|
var legendHeight = $$[getLegendHeight](), legendWidth = $$[getLegendWidth](), |
|
|
|
legendHeightForBottom = $$[isLegendRight] || $$[isLegendInset] ? 0 : legendHeight, |
|
|
|
legendHeightForBottom = $$[isLegendRight] || $$[isLegendInset] ? 0 : legendHeight, |
|
|
|
hasArc = $$[hasArcType](), |
|
|
|
hasArc = $$[hasArcType]($$.data.targets), |
|
|
|
xAxisHeight = config[__axis_rotated] || hasArc ? 0 : $$[getHorizontalAxisHeight]('x'), |
|
|
|
xAxisHeight = config[__axis_rotated] || hasArc ? 0 : $$[getHorizontalAxisHeight]('x'), |
|
|
|
subchartHeight = config[__subchart_show] && !hasArc ? (config[__subchart_size_height] + xAxisHeight) : 0; |
|
|
|
subchartHeight = config[__subchart_show] && !hasArc ? (config[__subchart_size_height] + xAxisHeight) : 0; |
|
|
|
|
|
|
|
|
|
|
@ -1047,7 +1047,7 @@ |
|
|
|
var areaIndices = $$[getShapeIndices]($$.isAreaType), barIndices = $$[getShapeIndices]($$.isBarType), lineIndices = $$[getShapeIndices]($$.isLineType), maxDataCountTarget, tickOffset; |
|
|
|
var areaIndices = $$[getShapeIndices]($$.isAreaType), barIndices = $$[getShapeIndices]($$.isBarType), lineIndices = $$[getShapeIndices]($$.isLineType), maxDataCountTarget, tickOffset; |
|
|
|
var rectX, rectW; |
|
|
|
var rectX, rectW; |
|
|
|
var withY, withSubchart, withTransition, withTransitionForExit, withTransitionForAxis, withTransform, withUpdateXDomain, withUpdateOrgXDomain, withLegend; |
|
|
|
var withY, withSubchart, withTransition, withTransitionForExit, withTransitionForAxis, withTransform, withUpdateXDomain, withUpdateOrgXDomain, withLegend; |
|
|
|
var hideAxis = $$[hasArcType](); |
|
|
|
var hideAxis = $$[hasArcType]($$.data.targets); |
|
|
|
var drawArea, drawBar, drawLine, xForText, yForText; |
|
|
|
var drawArea, drawBar, drawLine, xForText, yForText; |
|
|
|
var duration, durationForExit, durationForAxis, waitForDraw; |
|
|
|
var duration, durationForExit, durationForAxis, waitForDraw; |
|
|
|
var targetsToShow = $$[filterTargetsToShow]($$.data.targets), tickValues, i, intervalForCulling; |
|
|
|
var targetsToShow = $$[filterTargetsToShow]($$.data.targets), tickValues, i, intervalForCulling; |
|
|
@ -1666,7 +1666,7 @@ |
|
|
|
var index = d.index, selectedData, newData; |
|
|
|
var index = d.index, selectedData, newData; |
|
|
|
|
|
|
|
|
|
|
|
if ($$[dragging]) { return; } // do nothing if dragging
|
|
|
|
if ($$[dragging]) { return; } // do nothing if dragging
|
|
|
|
if ($$[hasArcType]()) { return; } |
|
|
|
if ($$[hasArcType]($$.data.targets)) { return; } |
|
|
|
|
|
|
|
|
|
|
|
selectedData = $$.data.targets.map(function (t) { |
|
|
|
selectedData = $$.data.targets.map(function (t) { |
|
|
|
return $$[addName]($$[getValueOnIndex](t.values, index)); |
|
|
|
return $$[addName]($$[getValueOnIndex](t.values, index)); |
|
|
@ -1696,7 +1696,7 @@ |
|
|
|
}) |
|
|
|
}) |
|
|
|
.on('mouseout', function (d) { |
|
|
|
.on('mouseout', function (d) { |
|
|
|
var index = d.index; |
|
|
|
var index = d.index; |
|
|
|
if ($$[hasArcType]()) { return; } |
|
|
|
if ($$[hasArcType]($$.data.targets)) { return; } |
|
|
|
$$[hideXGridFocus](); |
|
|
|
$$[hideXGridFocus](); |
|
|
|
$$[hideTooltip](); |
|
|
|
$$[hideTooltip](); |
|
|
|
// Undo expanded shapes
|
|
|
|
// Undo expanded shapes
|
|
|
@ -1712,7 +1712,7 @@ |
|
|
|
eventRect = $$.svg.select('.' + CLASS[eventRect] + '-' + index); |
|
|
|
eventRect = $$.svg.select('.' + CLASS[eventRect] + '-' + index); |
|
|
|
|
|
|
|
|
|
|
|
if ($$[dragging]) { return; } // do nothing when dragging
|
|
|
|
if ($$[dragging]) { return; } // do nothing when dragging
|
|
|
|
if ($$[hasArcType]()) { return; } |
|
|
|
if ($$[hasArcType]($$.data.targets)) { return; } |
|
|
|
|
|
|
|
|
|
|
|
// Show tooltip
|
|
|
|
// Show tooltip
|
|
|
|
selectedData = $$[filterTargetsToShow]($$.data.targets).map(function (t) { |
|
|
|
selectedData = $$[filterTargetsToShow]($$.data.targets).map(function (t) { |
|
|
@ -1765,7 +1765,7 @@ |
|
|
|
}) |
|
|
|
}) |
|
|
|
.on('click', function (d) { |
|
|
|
.on('click', function (d) { |
|
|
|
var index = d.index; |
|
|
|
var index = d.index; |
|
|
|
if ($$[hasArcType]()) { return; } |
|
|
|
if ($$[hasArcType]($$.data.targets)) { return; } |
|
|
|
if ($$[cancelClick]) { |
|
|
|
if ($$[cancelClick]) { |
|
|
|
$$[cancelClick] = false; |
|
|
|
$$[cancelClick] = false; |
|
|
|
return; |
|
|
|
return; |
|
|
@ -1791,7 +1791,7 @@ |
|
|
|
.attr('height', $$.height) |
|
|
|
.attr('height', $$.height) |
|
|
|
.attr(CSS_CLASS, CLASS[eventRect]) |
|
|
|
.attr(CSS_CLASS, CLASS[eventRect]) |
|
|
|
.on('mouseout', function () { |
|
|
|
.on('mouseout', function () { |
|
|
|
if ($$[hasArcType]()) { return; } |
|
|
|
if ($$[hasArcType]($$.data.targets)) { return; } |
|
|
|
$$[hideXGridFocus](); |
|
|
|
$$[hideXGridFocus](); |
|
|
|
$$[hideTooltip](); |
|
|
|
$$[hideTooltip](); |
|
|
|
$$[unexpandCircles](); |
|
|
|
$$[unexpandCircles](); |
|
|
@ -2115,7 +2115,7 @@ |
|
|
|
leftAxis = $$.main.select('.' + leftAxisClass).node(), |
|
|
|
leftAxis = $$.main.select('.' + leftAxisClass).node(), |
|
|
|
svgRect = leftAxis ? leftAxis.getBoundingClientRect() : {right: 0}, |
|
|
|
svgRect = leftAxis ? leftAxis.getBoundingClientRect() : {right: 0}, |
|
|
|
chartRect = $$.selectChart.node().getBoundingClientRect(), |
|
|
|
chartRect = $$.selectChart.node().getBoundingClientRect(), |
|
|
|
hasArc = $$[hasArcType](), |
|
|
|
hasArc = $$[hasArcType]($$.data.targets), |
|
|
|
svgLeft = svgRect.right - chartRect.left - (hasArc ? 0 : $$[getCurrentPaddingLeft]()); |
|
|
|
svgLeft = svgRect.right - chartRect.left - (hasArc ? 0 : $$[getCurrentPaddingLeft]()); |
|
|
|
return svgLeft > 0 ? svgLeft : 0; |
|
|
|
return svgLeft > 0 ? svgLeft : 0; |
|
|
|
}; |
|
|
|
}; |
|
|
@ -2150,7 +2150,7 @@ |
|
|
|
return $$.config[__axis_rotated] ? $$.height : $$.width; |
|
|
|
return $$.config[__axis_rotated] ? $$.height : $$.width; |
|
|
|
} |
|
|
|
} |
|
|
|
maxDataCount = $$[getMaxDataCount](); |
|
|
|
maxDataCount = $$[getMaxDataCount](); |
|
|
|
ratio = ($$[hasType](TYPE_BAR) ? (maxDataCount - ($$[isCategorized] ? 0.25 : 1)) / maxDataCount : 1); |
|
|
|
ratio = ($$[hasType]($$.data.targets, TYPE_BAR) ? (maxDataCount - ($$[isCategorized] ? 0.25 : 1)) / maxDataCount : 1); |
|
|
|
w = maxDataCount > 1 ? (base * ratio) / (maxDataCount - 1) : base; |
|
|
|
w = maxDataCount > 1 ? (base * ratio) / (maxDataCount - 1) : base; |
|
|
|
return w < 1 ? 1 : w; |
|
|
|
return w < 1 ? 1 : w; |
|
|
|
}; |
|
|
|
}; |
|
|
@ -2163,7 +2163,7 @@ |
|
|
|
c3_chart_internal_fn[showTooltip] = function (selectedData, mouse) { |
|
|
|
c3_chart_internal_fn[showTooltip] = function (selectedData, mouse) { |
|
|
|
var $$ = this, config = $$.config; |
|
|
|
var $$ = this, config = $$.config; |
|
|
|
var tWidth, tHeight, svgLeft, tooltipLeft, tooltipRight, tooltipTop, chartRight; |
|
|
|
var tWidth, tHeight, svgLeft, tooltipLeft, tooltipRight, tooltipTop, chartRight; |
|
|
|
var forArc = $$[hasArcType](), |
|
|
|
var forArc = $$[hasArcType]($$.data.targets), |
|
|
|
dataToShow = selectedData.filter(function (d) { return d && isValue(d.value); }); |
|
|
|
dataToShow = selectedData.filter(function (d) { return d && isValue(d.value); }); |
|
|
|
if (dataToShow.length === 0 || !config[__tooltip_show]) { |
|
|
|
if (dataToShow.length === 0 || !config[__tooltip_show]) { |
|
|
|
return; |
|
|
|
return; |
|
|
@ -2218,7 +2218,7 @@ |
|
|
|
var $$ = this, dataToShow = selectedData.filter(function (d) { return d && isValue(d.value); }); |
|
|
|
var $$ = this, dataToShow = selectedData.filter(function (d) { return d && isValue(d.value); }); |
|
|
|
if (! config[__tooltip_show]) { return; } |
|
|
|
if (! config[__tooltip_show]) { return; } |
|
|
|
// Hide when scatter plot exists
|
|
|
|
// Hide when scatter plot exists
|
|
|
|
if ($$[hasType](TYPE_SCATTER) || $$[hasArcType]()) { return; } |
|
|
|
if ($$[hasType]($$.data.targets, TYPE_SCATTER) || $$[hasArcType]($$.data.targets)) { return; } |
|
|
|
var focusEl = $$.main.selectAll('line.' + CLASS[xgridFocus]); |
|
|
|
var focusEl = $$.main.selectAll('line.' + CLASS[xgridFocus]); |
|
|
|
focusEl |
|
|
|
focusEl |
|
|
|
.style(CSS_VISIBILITY, "visible") |
|
|
|
.style(CSS_VISIBILITY, "visible") |
|
|
@ -3755,9 +3755,9 @@ |
|
|
|
} |
|
|
|
} |
|
|
|
}; |
|
|
|
}; |
|
|
|
var hasType = 'hasType'; |
|
|
|
var hasType = 'hasType'; |
|
|
|
c3_chart_internal_fn[hasType] = function (type, targets) { |
|
|
|
c3_chart_internal_fn[hasType] = function (targets, type) { |
|
|
|
var $$ = this, config = $$.config, has = false; |
|
|
|
var $$ = this, config = $$.config, has = false; |
|
|
|
(targets || $$.data.targets).forEach(function (t) { |
|
|
|
targets.forEach(function (t) { |
|
|
|
if (config[__data_types][t.id] === type) { has = true; } |
|
|
|
if (config[__data_types][t.id] === type) { has = true; } |
|
|
|
if (!(t.id in config[__data_types]) && type === 'line') { has = true; } |
|
|
|
if (!(t.id in config[__data_types]) && type === 'line') { has = true; } |
|
|
|
}); |
|
|
|
}); |
|
|
@ -3765,7 +3765,7 @@ |
|
|
|
}; |
|
|
|
}; |
|
|
|
var hasArcType = 'hasArcType'; |
|
|
|
var hasArcType = 'hasArcType'; |
|
|
|
c3_chart_internal_fn[hasArcType] = function (targets) { |
|
|
|
c3_chart_internal_fn[hasArcType] = function (targets) { |
|
|
|
return this[hasType](TYPE_PIE, targets) || this[hasType](TYPE_DONUT, targets) || this[hasType](TYPE_GAUGE, targets); |
|
|
|
return this[hasType](targets, TYPE_PIE) || this[hasType](targets, TYPE_DONUT) || this[hasType](targets, TYPE_GAUGE); |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
var isLineType = 'isLineType'; |
|
|
|
var isLineType = 'isLineType'; |
|
|
@ -4087,7 +4087,7 @@ |
|
|
|
domainLength, padding, padding_top, padding_bottom, |
|
|
|
domainLength, padding, padding_top, padding_bottom, |
|
|
|
center = axisId === 'y2' ? config[__axis_y2_center] : config[__axis_y_center], |
|
|
|
center = axisId === 'y2' ? config[__axis_y2_center] : config[__axis_y_center], |
|
|
|
yDomainAbs, lengths, diff, ratio, isAllPositive, isAllNegative, |
|
|
|
yDomainAbs, lengths, diff, ratio, isAllPositive, isAllNegative, |
|
|
|
isZeroBased = ($$[hasType](TYPE_BAR, yTargets) && config[__bar_zerobased]) || ($$[hasType](TYPE_AREA, yTargets) && config[__area_zerobased]), |
|
|
|
isZeroBased = ($$[hasType](yTargets, TYPE_BAR) && config[__bar_zerobased]) || ($$[hasType](yTargets, TYPE_AREA) && config[__area_zerobased]), |
|
|
|
showHorizontalDataLabel = $$[hasDataLabel]() && config[__axis_rotated], |
|
|
|
showHorizontalDataLabel = $$[hasDataLabel]() && config[__axis_rotated], |
|
|
|
showVerticalDataLabel = $$[hasDataLabel]() && !config[__axis_rotated]; |
|
|
|
showVerticalDataLabel = $$[hasDataLabel]() && !config[__axis_rotated]; |
|
|
|
if (yTargets.length === 0) { // use current domain if target of axisId is none
|
|
|
|
if (yTargets.length === 0) { // use current domain if target of axisId is none
|
|
|
@ -4161,7 +4161,7 @@ |
|
|
|
maxDataCount, padding, paddingLeft, paddingRight; |
|
|
|
maxDataCount, padding, paddingLeft, paddingRight; |
|
|
|
if ($$[isCategorized]) { |
|
|
|
if ($$[isCategorized]) { |
|
|
|
padding = 0; |
|
|
|
padding = 0; |
|
|
|
} else if ($$[hasType](TYPE_BAR, targets)) { |
|
|
|
} else if ($$[hasType](targets, TYPE_BAR)) { |
|
|
|
maxDataCount = $$[getMaxDataCount](); |
|
|
|
maxDataCount = $$[getMaxDataCount](); |
|
|
|
padding = maxDataCount > 1 ? (diff / (maxDataCount - 1)) / 2 : 0.5; |
|
|
|
padding = maxDataCount > 1 ? (diff / (maxDataCount - 1)) / 2 : 0.5; |
|
|
|
} else { |
|
|
|
} else { |
|
|
@ -4614,7 +4614,7 @@ |
|
|
|
$$.radiusExpanded = Math.min($$.arcWidth, $$.arcHeight) / 2; |
|
|
|
$$.radiusExpanded = Math.min($$.arcWidth, $$.arcHeight) / 2; |
|
|
|
$$.radius = $$.radiusExpanded * 0.95; |
|
|
|
$$.radius = $$.radiusExpanded * 0.95; |
|
|
|
$$.innerRadiusRatio = w ? ($$.radius - w) / $$.radius : 0.6; |
|
|
|
$$.innerRadiusRatio = w ? ($$.radius - w) / $$.radius : 0.6; |
|
|
|
$$.innerRadius = $$[hasType](TYPE_DONUT) || $$[hasType](TYPE_GAUGE) ? $$.radius * $$.innerRadiusRatio : 0; |
|
|
|
$$.innerRadius = $$[hasType]($$.data.targets, TYPE_DONUT) || $$[hasType]($$.data.targets, TYPE_GAUGE) ? $$.radius * $$.innerRadiusRatio : 0; |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
var updateArc = 'updateArc', svgArc = 'svgArc', svgArcExpanded = 'svgArcExpanded', svgArcExpandedSub = 'svgArcExpandedSub'; |
|
|
|
var updateArc = 'updateArc', svgArc = 'svgArc', svgArcExpanded = 'svgArcExpanded', svgArcExpandedSub = 'svgArcExpandedSub'; |
|
|
@ -4685,7 +4685,7 @@ |
|
|
|
c3_chart_internal_fn[transformForArcLabel] = function (d) { |
|
|
|
c3_chart_internal_fn[transformForArcLabel] = function (d) { |
|
|
|
var $$ = this, |
|
|
|
var $$ = this, |
|
|
|
updated = $$[updateAngle](d), c, x, y, h, ratio, translate = ""; |
|
|
|
updated = $$[updateAngle](d), c, x, y, h, ratio, translate = ""; |
|
|
|
if (updated && !$$[hasType](TYPE_GAUGE)) { |
|
|
|
if (updated && !$$[hasType]($$.data.targets, TYPE_GAUGE)) { |
|
|
|
c = this.svgArc.centroid(updated); |
|
|
|
c = this.svgArc.centroid(updated); |
|
|
|
x = isNaN(c[0]) ? 0 : c[0]; |
|
|
|
x = isNaN(c[0]) ? 0 : c[0]; |
|
|
|
y = isNaN(c[1]) ? 0 : c[1]; |
|
|
|
y = isNaN(c[1]) ? 0 : c[1]; |
|
|
@ -4700,7 +4700,7 @@ |
|
|
|
var getArcRatio = 'getArcRatio'; |
|
|
|
var getArcRatio = 'getArcRatio'; |
|
|
|
c3_chart_internal_fn[getArcRatio] = function (d) { |
|
|
|
c3_chart_internal_fn[getArcRatio] = function (d) { |
|
|
|
var $$ = this, |
|
|
|
var $$ = this, |
|
|
|
whole = $$[hasType](TYPE_GAUGE) ? Math.PI : (Math.PI * 2); |
|
|
|
whole = $$[hasType]($$.data.targets, TYPE_GAUGE) ? Math.PI : (Math.PI * 2); |
|
|
|
return d ? (d.endAngle - d.startAngle) / whole : null; |
|
|
|
return d ? (d.endAngle - d.startAngle) / whole : null; |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
@ -4722,7 +4722,7 @@ |
|
|
|
updated = $$[updateAngle](d); |
|
|
|
updated = $$[updateAngle](d); |
|
|
|
value = updated ? updated.value : null; |
|
|
|
value = updated ? updated.value : null; |
|
|
|
ratio = $$[getArcRatio](updated); |
|
|
|
ratio = $$[getArcRatio](updated); |
|
|
|
if (! $$[hasType](TYPE_GAUGE) && ! $$[meetsArcLabelThreshold](ratio)) { return ""; } |
|
|
|
if (! $$[hasType]($$.data.targets, TYPE_GAUGE) && ! $$[meetsArcLabelThreshold](ratio)) { return ""; } |
|
|
|
format = $$[getArcLabelFormat](); |
|
|
|
format = $$[getArcLabelFormat](); |
|
|
|
return format ? format(value, ratio) : $$[defaultArcValueFormat](value, ratio); |
|
|
|
return format ? format(value, ratio) : $$[defaultArcValueFormat](value, ratio); |
|
|
|
}; |
|
|
|
}; |
|
|
@ -4770,9 +4770,9 @@ |
|
|
|
var shouldShowArcLabel = 'shouldShowArcLabel'; |
|
|
|
var shouldShowArcLabel = 'shouldShowArcLabel'; |
|
|
|
c3_chart_internal_fn[shouldShowArcLabel] = function () { |
|
|
|
c3_chart_internal_fn[shouldShowArcLabel] = function () { |
|
|
|
var $$ = this, config = $$.config, shouldShow = true; |
|
|
|
var $$ = this, config = $$.config, shouldShow = true; |
|
|
|
if ($$[hasType](TYPE_DONUT)) { |
|
|
|
if ($$[hasType]($$.data.targets, TYPE_DONUT)) { |
|
|
|
shouldShow = config[__donut_label_show]; |
|
|
|
shouldShow = config[__donut_label_show]; |
|
|
|
} else if ($$[hasType](TYPE_PIE)) { |
|
|
|
} else if ($$[hasType]($$.data.targets, TYPE_PIE)) { |
|
|
|
shouldShow = config[__pie_label_show]; |
|
|
|
shouldShow = config[__pie_label_show]; |
|
|
|
} |
|
|
|
} |
|
|
|
// when gauge, always true
|
|
|
|
// when gauge, always true
|
|
|
@ -4782,7 +4782,7 @@ |
|
|
|
var meetsArcLabelThreshold = 'meetsArcLabelThreshold'; |
|
|
|
var meetsArcLabelThreshold = 'meetsArcLabelThreshold'; |
|
|
|
c3_chart_internal_fn[meetsArcLabelThreshold] = function (ratio) { |
|
|
|
c3_chart_internal_fn[meetsArcLabelThreshold] = function (ratio) { |
|
|
|
var $$ = this, config = $$.config, |
|
|
|
var $$ = this, config = $$.config, |
|
|
|
threshold = $$[hasType](TYPE_DONUT) ? config[__donut_label_threshold] : config[__pie_label_threshold]; |
|
|
|
threshold = $$[hasType]($$.data.targets, TYPE_DONUT) ? config[__donut_label_threshold] : config[__pie_label_threshold]; |
|
|
|
return ratio >= threshold; |
|
|
|
return ratio >= threshold; |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
@ -4790,9 +4790,9 @@ |
|
|
|
c3_chart_internal_fn[getArcLabelFormat] = function () { |
|
|
|
c3_chart_internal_fn[getArcLabelFormat] = function () { |
|
|
|
var $$ = this, config = $$.config, |
|
|
|
var $$ = this, config = $$.config, |
|
|
|
format = config[__pie_label_format]; |
|
|
|
format = config[__pie_label_format]; |
|
|
|
if ($$[hasType](TYPE_GAUGE)) { |
|
|
|
if ($$[hasType]($$.data.targets, TYPE_GAUGE)) { |
|
|
|
format = config[__gauge_label_format]; |
|
|
|
format = config[__gauge_label_format]; |
|
|
|
} else if ($$[hasType](TYPE_DONUT)) { |
|
|
|
} else if ($$[hasType]($$.data.targets, TYPE_DONUT)) { |
|
|
|
format = config[__donut_label_format]; |
|
|
|
format = config[__donut_label_format]; |
|
|
|
} |
|
|
|
} |
|
|
|
return format; |
|
|
|
return format; |
|
|
@ -4801,7 +4801,7 @@ |
|
|
|
var getArcTitle = 'getArcTitle'; |
|
|
|
var getArcTitle = 'getArcTitle'; |
|
|
|
c3_chart_internal_fn[getArcTitle] = function () { |
|
|
|
c3_chart_internal_fn[getArcTitle] = function () { |
|
|
|
var $$ = this; |
|
|
|
var $$ = this; |
|
|
|
return $$[hasType](TYPE_DONUT) ? $$.config[__donut_title] : ""; |
|
|
|
return $$[hasType]($$.data.targets, TYPE_DONUT) ? $$.config[__donut_title] : ""; |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
var descByStartAngle = 'descByStartAngle'; |
|
|
|
var descByStartAngle = 'descByStartAngle'; |
|
|
@ -4820,7 +4820,7 @@ |
|
|
|
mainPieEnter.append('g') |
|
|
|
mainPieEnter.append('g') |
|
|
|
.attr(CSS_CLASS, generateCall($$[classArcs], $$)); |
|
|
|
.attr(CSS_CLASS, generateCall($$[classArcs], $$)); |
|
|
|
mainPieEnter.append("text") |
|
|
|
mainPieEnter.append("text") |
|
|
|
.attr("dy", $$[hasType](TYPE_GAUGE) ? "-0.35em" : ".35em") |
|
|
|
.attr("dy", $$[hasType]($$.data.targets, TYPE_GAUGE) ? "-0.35em" : ".35em") |
|
|
|
.style(CSS_OPACITY, 0) |
|
|
|
.style(CSS_OPACITY, 0) |
|
|
|
.style(CSS_TEXT_ANCHOR, "middle") |
|
|
|
.style(CSS_TEXT_ANCHOR, "middle") |
|
|
|
.style(CSS_POINTER_EVENTS, "none"); |
|
|
|
.style(CSS_POINTER_EVENTS, "none"); |
|
|
@ -4935,7 +4935,7 @@ |
|
|
|
.transition().duration(duration) |
|
|
|
.transition().duration(duration) |
|
|
|
.style(CSS_OPACITY, function (d) { return $$[isTargetToShow](d.data.id) && $$[isArcType](d.data) ? 1 : 0; }); |
|
|
|
.style(CSS_OPACITY, function (d) { return $$[isTargetToShow](d.data.id) && $$[isArcType](d.data) ? 1 : 0; }); |
|
|
|
main.select('.' + CLASS[chartArcsTitle]) |
|
|
|
main.select('.' + CLASS[chartArcsTitle]) |
|
|
|
.style(CSS_OPACITY, $$[hasType](TYPE_DONUT) || $$[hasType](TYPE_GAUGE) ? 1 : 0); |
|
|
|
.style(CSS_OPACITY, $$[hasType]($$.data.targets, TYPE_DONUT) || $$[hasType]($$.data.targets, TYPE_GAUGE) ? 1 : 0); |
|
|
|
|
|
|
|
|
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
@ -4944,7 +4944,7 @@ |
|
|
|
var initGauge = 'initGauge'; |
|
|
|
var initGauge = 'initGauge'; |
|
|
|
c3_chart_internal_fn[initGauge] = function () { |
|
|
|
c3_chart_internal_fn[initGauge] = function () { |
|
|
|
var $$ = this, config = $$.config, arcs; |
|
|
|
var $$ = this, config = $$.config, arcs; |
|
|
|
if ($$[hasType](TYPE_GAUGE)) { |
|
|
|
if ($$[hasType]($$.data.targets, TYPE_GAUGE)) { |
|
|
|
arcs.append('path') |
|
|
|
arcs.append('path') |
|
|
|
.attr(CSS_CLASS, CLASS[chartArcsBackground]) |
|
|
|
.attr(CSS_CLASS, CLASS[chartArcsBackground]) |
|
|
|
.attr("d", function () { |
|
|
|
.attr("d", function () { |
|
|
@ -5413,7 +5413,7 @@ |
|
|
|
var transformTo = 'transformTo'; |
|
|
|
var transformTo = 'transformTo'; |
|
|
|
c3_chart_internal_fn[transformTo] = function (targetIds, type, optionsForRedraw) { |
|
|
|
c3_chart_internal_fn[transformTo] = function (targetIds, type, optionsForRedraw) { |
|
|
|
var $$ = this, |
|
|
|
var $$ = this, |
|
|
|
withTransitionForAxis = !$$[hasArcType](), |
|
|
|
withTransitionForAxis = !$$[hasArcType]($$.data.targets), |
|
|
|
options = optionsForRedraw || {withTransitionForAxis: withTransitionForAxis}; |
|
|
|
options = optionsForRedraw || {withTransitionForAxis: withTransitionForAxis}; |
|
|
|
options.withTransitionForTransform = false; |
|
|
|
options.withTransitionForTransform = false; |
|
|
|
$$[transiting] = false; |
|
|
|
$$[transiting] = false; |
|
|
@ -5694,8 +5694,8 @@ |
|
|
|
var getYFormat = 'getYFormat'; |
|
|
|
var getYFormat = 'getYFormat'; |
|
|
|
c3_chart_internal_fn[getYFormat] = function (forArc) { |
|
|
|
c3_chart_internal_fn[getYFormat] = function (forArc) { |
|
|
|
var $$ = this, |
|
|
|
var $$ = this, |
|
|
|
formatForY = forArc && !$$[hasType](TYPE_GAUGE) ? $$.defaultArcValueFormat : $$.yFormat, |
|
|
|
formatForY = forArc && !$$[hasType]($$.data.targets, TYPE_GAUGE) ? $$.defaultArcValueFormat : $$.yFormat, |
|
|
|
formatForY2 = forArc && !$$[hasType](TYPE_GAUGE) ? $$.defaultArcValueFormat : $$.y2Format; |
|
|
|
formatForY2 = forArc && !$$[hasType]($$.data.targets, TYPE_GAUGE) ? $$.defaultArcValueFormat : $$.y2Format; |
|
|
|
return function (v, ratio, id) { |
|
|
|
return function (v, ratio, id) { |
|
|
|
var format = $$[getAxisId](id) === 'y2' ? formatForY2 : formatForY; |
|
|
|
var format = $$[getAxisId](id) === 'y2' ? formatForY2 : formatForY; |
|
|
|
return format.call($$, v, ratio); |
|
|
|
return format.call($$, v, ratio); |
|
|
@ -5746,7 +5746,7 @@ |
|
|
|
var $$ = this, config = $$.config, main = $$.main, d3 = $$.d3; |
|
|
|
var $$ = this, config = $$.config, main = $$.main, d3 = $$.d3; |
|
|
|
var sx, sy, mx, my, minX, maxX, minY, maxY; |
|
|
|
var sx, sy, mx, my, minX, maxX, minY, maxY; |
|
|
|
|
|
|
|
|
|
|
|
if ($$[hasArcType]()) { return; } |
|
|
|
if ($$[hasArcType]($$.data.targets)) { return; } |
|
|
|
if (! config[__data_selection_enabled]) { return; } // do nothing if not selectable
|
|
|
|
if (! config[__data_selection_enabled]) { return; } // do nothing if not selectable
|
|
|
|
if (config[__zoom_enabled] && ! $$.zoom.altDomain) { return; } // skip if zoomable because of conflict drag dehavior
|
|
|
|
if (config[__zoom_enabled] && ! $$.zoom.altDomain) { return; } // skip if zoomable because of conflict drag dehavior
|
|
|
|
if (!config[__data_selection_multiple]) { return; } // skip when single selection because drag is used for multiple selection
|
|
|
|
if (!config[__data_selection_multiple]) { return; } // skip when single selection because drag is used for multiple selection
|
|
|
@ -5803,7 +5803,7 @@ |
|
|
|
var dragstart = 'dragstart'; |
|
|
|
var dragstart = 'dragstart'; |
|
|
|
c3_chart_internal_fn[dragstart] = function (mouse) { |
|
|
|
c3_chart_internal_fn[dragstart] = function (mouse) { |
|
|
|
var $$ = this, config = $$.config; |
|
|
|
var $$ = this, config = $$.config; |
|
|
|
if ($$[hasArcType]()) { return; } |
|
|
|
if ($$[hasArcType]($$.data.targets)) { return; } |
|
|
|
if (! config[__data_selection_enabled]) { return; } // do nothing if not selectable
|
|
|
|
if (! config[__data_selection_enabled]) { return; } // do nothing if not selectable
|
|
|
|
$$[dragStart] = mouse; |
|
|
|
$$[dragStart] = mouse; |
|
|
|
$$.main.select('.' + CLASS[chart]).append('rect') |
|
|
|
$$.main.select('.' + CLASS[chart]).append('rect') |
|
|
@ -5816,7 +5816,7 @@ |
|
|
|
var dragend = 'dragend'; |
|
|
|
var dragend = 'dragend'; |
|
|
|
c3_chart_internal_fn[dragend] = function () { |
|
|
|
c3_chart_internal_fn[dragend] = function () { |
|
|
|
var $$ = this, config = $$.config; |
|
|
|
var $$ = this, config = $$.config; |
|
|
|
if ($$[hasArcType]()) { return; } |
|
|
|
if ($$[hasArcType]($$.data.targets)) { return; } |
|
|
|
if (! config[__data_selection_enabled]) { return; } // do nothing if not selectable
|
|
|
|
if (! config[__data_selection_enabled]) { return; } // do nothing if not selectable
|
|
|
|
$$.main.select('.' + CLASS[dragarea]) |
|
|
|
$$.main.select('.' + CLASS[dragarea]) |
|
|
|
.transition().duration(100) |
|
|
|
.transition().duration(100) |
|
|
@ -5847,7 +5847,7 @@ |
|
|
|
this.defocus(); |
|
|
|
this.defocus(); |
|
|
|
focus(candidatesForNoneArc.classed(CLASS[focused], true)); |
|
|
|
focus(candidatesForNoneArc.classed(CLASS[focused], true)); |
|
|
|
focus(candidatesForArc); |
|
|
|
focus(candidatesForArc); |
|
|
|
if ($$[hasArcType]()) { |
|
|
|
if ($$[hasArcType]($$.data.targets)) { |
|
|
|
$$[expandArc](targetId, true); |
|
|
|
$$[expandArc](targetId, true); |
|
|
|
} |
|
|
|
} |
|
|
|
$$[toggleFocusLegend](targetId, true); |
|
|
|
$$[toggleFocusLegend](targetId, true); |
|
|
@ -5864,7 +5864,7 @@ |
|
|
|
this.revert(); |
|
|
|
this.revert(); |
|
|
|
defocus(candidatesForNoneArc.classed(CLASS[focused], false)); |
|
|
|
defocus(candidatesForNoneArc.classed(CLASS[focused], false)); |
|
|
|
defocus(candidatesForArc); |
|
|
|
defocus(candidatesForArc); |
|
|
|
if ($$[hasArcType]()) { |
|
|
|
if ($$[hasArcType]($$.data.targets)) { |
|
|
|
$$[unexpandArc](targetId); |
|
|
|
$$[unexpandArc](targetId); |
|
|
|
} |
|
|
|
} |
|
|
|
$$[toggleFocusLegend](targetId, false); |
|
|
|
$$[toggleFocusLegend](targetId, false); |
|
|
@ -5880,7 +5880,7 @@ |
|
|
|
} |
|
|
|
} |
|
|
|
revert(candidatesForNoneArc.classed(CLASS[focused], false)); |
|
|
|
revert(candidatesForNoneArc.classed(CLASS[focused], false)); |
|
|
|
revert(candidatesForArc); |
|
|
|
revert(candidatesForArc); |
|
|
|
if ($$[hasArcType]()) { |
|
|
|
if ($$[hasArcType]($$.data.targets)) { |
|
|
|
$$[unexpandArc](targetId); |
|
|
|
$$[unexpandArc](targetId); |
|
|
|
} |
|
|
|
} |
|
|
|
$$[revertLegend](); |
|
|
|
$$[revertLegend](); |
|
|
|