From 1a9795dc4f1ddb005ee1974751a7a9d1983438e4 Mon Sep 17 00:00:00 2001 From: nagix Date: Mon, 23 Jul 2018 15:27:41 +0000 Subject: [PATCH] Release 0.3.1 --- bower.json | 15 + dist/chartjs-plugin-style.js | 1994 ++++++++++++++++++++++++++++++ dist/chartjs-plugin-style.min.js | 11 + 3 files changed, 2020 insertions(+) create mode 100644 bower.json create mode 100644 dist/chartjs-plugin-style.js create mode 100644 dist/chartjs-plugin-style.min.js diff --git a/bower.json b/bower.json new file mode 100644 index 0000000..a092b0f --- /dev/null +++ b/bower.json @@ -0,0 +1,15 @@ +{ + "name": "chartjs-plugin-style", + "description": "Chart.js plugin for more styling options", + "homepage": "https://nagix.github.io/chartjs-plugin-style", + "license": "MIT", + "version": "0.3.1", + "main": "./dist/chartjs-plugin-style.js", + "ignore": [ + ".codeclimate.yml", + ".gitignore", + ".npmignore", + ".travis.yml", + "scripts" + ] +} \ No newline at end of file diff --git a/dist/chartjs-plugin-style.js b/dist/chartjs-plugin-style.js new file mode 100644 index 0000000..e745d21 --- /dev/null +++ b/dist/chartjs-plugin-style.js @@ -0,0 +1,1994 @@ +/* + * @license + * chartjs-plugin-style + * /~https://github.com/nagix/chartjs-plugin-style/ + * Version: 0.3.1 + * + * Copyright 2018 Akihiko Kusanagi + * Released under the MIT license + * /~https://github.com/nagix/chartjs-plugin-style/blob/master/LICENSE.md + */ +(function (global, factory) { + typeof exports === 'object' && typeof module !== 'undefined' ? factory(require('chart.js')) : + typeof define === 'function' && define.amd ? define(['chart.js'], factory) : + (factory(global.Chart)); +}(this, (function (Chart) { 'use strict'; + +Chart = Chart && Chart.hasOwnProperty('default') ? Chart['default'] : Chart; + +'use strict'; + +var StyleHelper = function() { + + return { + drawBackground: function(view, drawCallback) { + var borderWidth = view.borderWidth; + + view.borderWidth = 0; + drawCallback(); + view.borderWidth = borderWidth; + }, + + drawBorder: function(view, drawCallback) { + var backgroundColor = view.backgroundColor; + + if (view.borderWidth) { + view.backgroundColor = 'rgba(0, 0, 0, 0)'; + drawCallback(); + view.backgroundColor = backgroundColor; + } + }, + + drawShadow: function(chart, offsetX, offsetY, blur, color, drawCallback, backmost) { + var ctx = chart.ctx; + var offset = chart.width; + var pixelRatio = chart.currentDevicePixelRatio; + + ctx.save(); + + ctx.shadowOffsetX = (offsetX + offset) * pixelRatio; + ctx.shadowOffsetY = offsetY * pixelRatio; + ctx.shadowBlur = blur * pixelRatio; + ctx.shadowColor = color; + if (backmost) { + ctx.globalCompositeOperation = 'destination-over'; + } + ctx.translate(-offset, 0); + + drawCallback(); + + ctx.restore(); + }, + + setPath: function(ctx, drawCallback) { + ctx.save(); + ctx.beginPath(); + ctx.clip(); + drawCallback(); + ctx.restore(); + }, + + drawBevel: function(chart, width, highlightColor, shadowColor, drawCallback) { + var ctx = chart.ctx; + var offset = chart.width; + var pixelRatio = chart.currentDevicePixelRatio; + var shadowOffset = (width * pixelRatio) / 2; + + if (!width) { + return; + } + + ctx.save(); + ctx.clip(); + + // Make stencil + ctx.translate(-offset, 0); + this.setPath(ctx, drawCallback); + ctx.rect(0, 0, chart.width, chart.height); + + // Draw bevel shadow + ctx.fillStyle = 'black'; + ctx.shadowOffsetX = offset * pixelRatio - shadowOffset; + ctx.shadowOffsetY = -shadowOffset; + ctx.shadowBlur = shadowOffset; + ctx.shadowColor = shadowColor; + ctx.globalCompositeOperation = 'source-atop'; + ctx.fill('evenodd'); + + // Draw Bevel highlight + ctx.shadowOffsetX = offset * pixelRatio + shadowOffset; + ctx.shadowOffsetY = shadowOffset; + ctx.shadowColor = highlightColor; + ctx.fill('evenodd'); + + ctx.restore(); + }, + + drawGlow: function(chart, width, color, borderWidth, drawCallback, isOuter) { + var ctx = chart.ctx; + var offset = chart.width; + var pixelRatio = chart.currentDevicePixelRatio; + + if (!width) { + return; + } + + ctx.save(); + + // Clip inner or outer area + this.setPath(ctx, drawCallback); + if (isOuter) { + ctx.rect(0, 0, chart.width, chart.height); + } + ctx.clip('evenodd'); + + // Set path + ctx.translate(-offset, 0); + this.setPath(ctx, drawCallback); + if (!isOuter) { + ctx.rect(0, 0, chart.width, chart.height); + } + + // Draw glow + ctx.lineWidth = borderWidth; + ctx.strokeStyle = 'black'; + ctx.fillStyle = 'black'; + ctx.shadowOffsetX = offset * pixelRatio; + ctx.shadowBlur = width * pixelRatio; + ctx.shadowColor = color; + ctx.fill('evenodd'); + if (borderWidth) { + ctx.stroke(); + } + + ctx.restore(); + }, + + drawInnerGlow: function(chart, width, color, borderWidth, drawCallback) { + this.drawGlow(chart, width, color, borderWidth, drawCallback); + }, + + drawOuterGlow: function(chart, width, color, borderWidth, drawCallback) { + this.drawGlow(chart, width, color, borderWidth, drawCallback, true); + } + }; +}; + +'use strict'; + +var StyleArcElement = function(Chart$$1) { + + var helpers = Chart$$1.helpers; + var styleHelpers = helpers.style; + + return Chart$$1.elements.Arc.extend({ + + draw: function() { + var me = this; + var args = arguments; + var chart = me._chart; + var vm = me._view; + var borderAlpha = helpers.color(vm.borderColor).alpha(); + var backgroundAlpha = helpers.color(vm.backgroundColor).alpha(); + var bevelExtra = borderAlpha > 0 && vm.borderWidth > 0 ? vm.borderWidth / 2 : 0; + + var drawCallback = function() { + Chart$$1.elements.Arc.prototype.draw.apply(me, args); + }; + + styleHelpers.drawShadow(chart, vm.shadowOffsetX, vm.shadowOffsetY, + vm.shadowBlur, vm.shadowColor, drawCallback, true); + + if (backgroundAlpha > 0) { + styleHelpers.drawBackground(vm, drawCallback); + styleHelpers.drawBevel(chart, vm.bevelWidth + bevelExtra, + vm.bevelHighlightColor, vm.bevelShadowColor, drawCallback); + } + + styleHelpers.drawInnerGlow(chart, vm.innerGlowWidth, vm.innerGlowColor, + vm.borderWidth, drawCallback); + styleHelpers.drawOuterGlow(chart, vm.outerGlowWidth, vm.outerGlowColor, + vm.borderWidth, drawCallback); + + styleHelpers.drawBorder(vm, drawCallback); + } + }); +}; + +'use strict'; + +var StyleLineElement = function(Chart$$1) { + + var styleHelpers = Chart$$1.helpers.style; + + return Chart$$1.elements.Line.extend({ + + draw: function() { + var me = this; + var args = arguments; + var chart = me._chart; + var vm = me._view; + + var drawCallback = function() { + Chart$$1.elements.Line.prototype.draw.apply(me, args); + }; + + styleHelpers.drawShadow(chart, vm.shadowOffsetX, vm.shadowOffsetY, + vm.shadowBlur, vm.shadowColor, drawCallback); + + styleHelpers.drawOuterGlow(chart, vm.outerGlowWidth, vm.outerGlowColor, + vm.borderWidth, drawCallback); + + styleHelpers.drawBorder(vm, drawCallback); + } + }); +}; + +'use strict'; + +var StylePointElement = function(Chart$$1) { + + var helpers = Chart$$1.helpers; + var styleHelpers = helpers.style; + + return Chart$$1.elements.Point.extend({ + + draw: function() { + var me = this; + var args = arguments; + var chart = me._chart; + var vm = me._view; + var borderAlpha = helpers.color(vm.borderColor).alpha(); + var backgroundAlpha = helpers.color(vm.backgroundColor).alpha(); + var bevelExtra = borderAlpha > 0 && vm.borderWidth > 0 ? vm.borderWidth / 2 : 0; + + var drawCallback = function() { + Chart$$1.elements.Point.prototype.draw.apply(me, args); + }; + + styleHelpers.drawShadow(chart, vm.shadowOffsetX, vm.shadowOffsetY, + vm.shadowBlur, vm.shadowColor, drawCallback, true); + + if (backgroundAlpha > 0) { + styleHelpers.drawBackground(vm, drawCallback); + styleHelpers.drawBevel(chart, vm.bevelWidth + bevelExtra, + vm.bevelHighlightColor, vm.bevelShadowColor, drawCallback); + } + + styleHelpers.drawInnerGlow(chart, vm.innerGlowWidth, vm.innerGlowColor, + vm.borderWidth, drawCallback); + styleHelpers.drawOuterGlow(chart, vm.outerGlowWidth, vm.outerGlowColor, + vm.borderWidth, drawCallback); + + styleHelpers.drawBorder(vm, drawCallback); + } + }); +}; + +'use strict'; + +var StyleRectangleElement = function(Chart$$1) { + + var helpers = Chart$$1.helpers; + var styleHelpers = helpers.style; + + return Chart$$1.elements.Rectangle.extend({ + + draw: function() { + var me = this; + var args = arguments; + var chart = me._chart; + var vm = me._view; + var borderAlpha = helpers.color(vm.borderColor).alpha(); + var backgroundAlpha = helpers.color(vm.backgroundColor).alpha(); + var bevelExtra = borderAlpha > 0 && vm.borderWidth > 0 ? vm.borderWidth / 2 : 0; + + var drawCallback = function() { + Chart$$1.elements.Rectangle.prototype.draw.apply(me, args); + }; + + styleHelpers.drawShadow(chart, vm.shadowOffsetX, vm.shadowOffsetY, + vm.shadowBlur, vm.shadowColor, drawCallback, true); + + if (backgroundAlpha > 0) { + styleHelpers.drawBackground(vm, drawCallback); + styleHelpers.drawBevel(chart, vm.bevelWidth + bevelExtra, + vm.bevelHighlightColor, vm.bevelShadowColor, drawCallback); + } + + styleHelpers.drawInnerGlow(chart, vm.innerGlowWidth, vm.innerGlowColor, + vm.borderWidth, drawCallback); + styleHelpers.drawOuterGlow(chart, vm.outerGlowWidth, vm.outerGlowColor, + vm.borderWidth, drawCallback); + + styleHelpers.drawBorder(vm, drawCallback); + } + }); +}; + +'use strict'; + +var StyleTooltip = function(Chart$$1) { + + var helpers = Chart$$1.helpers; + var styleHelpers = helpers.style; + + var Tooltip = Chart$$1.Tooltip; + + /** + * Ported from Chart.js 2.7.2. + * + * Helper method to merge the opacity into a color + */ + function mergeOpacity(colorString, opacity) { + var color = helpers.color(colorString); + return color.alpha(opacity * color.alpha()).rgbaString(); + } + + return Chart$$1.Tooltip.extend({ + + initialize: function() { + Tooltip.prototype.initialize.apply(this, arguments); + + var model = this._model; + var tooltipOpts = this._options; + + model.shadowOffsetX = tooltipOpts.shadowOffsetX; + model.shadowOffsetY = tooltipOpts.shadowOffsetY; + model.shadowBlur = tooltipOpts.shadowBlur; + model.shadowColor = tooltipOpts.shadowColor; + model.bevelWidth = tooltipOpts.bevelWidth; + model.bevelHighlightColor = tooltipOpts.bevelHighlightColor; + model.bevelShadowColor = tooltipOpts.bevelShadowColor; + model.innerGlowWidth = tooltipOpts.innerGlowWidth; + model.innerGlowColor = tooltipOpts.innerGlowColor; + model.outerGlowWidth = tooltipOpts.outerGlowWidth; + model.outerGlowColor = tooltipOpts.outerGlowColor; + }, + + update: function() { + Tooltip.prototype.update.apply(this, arguments); + + var me = this; + var model = me._model; + var opts = me._options; + + model.shadowOffsetX = opts.shadowOffsetX; + model.shadowOffsetY = opts.shadowOffsetY; + model.shadowBlur = opts.shadowBlur; + model.shadowColor = opts.shadowColor; + model.bevelWidth = opts.bevelWidth; + model.bevelHighlightColor = opts.bevelHighlightColor; + model.bevelShadowColor = opts.bevelShadowColor; + model.innerGlowWidth = opts.innerGlowWidth; + model.innerGlowColor = opts.innerGlowColor; + model.outerGlowWidth = opts.outerGlowWidth; + model.outerGlowColor = opts.outerGlowColor; + + return me; + }, + + drawBackground: function(pt, vm, ctx, tooltipSize, opacity) { + var me = this; + var args = arguments; + var chart = me._chart; + var borderAlpha = helpers.color(vm.borderColor).alpha(); + var backgroundAlpha = helpers.color(vm.backgroundColor).alpha(); + var bevelExtra = borderAlpha > 0 && vm.borderWidth > 0 ? vm.borderWidth / 2 : 0; + + var drawCallback = function() { + Tooltip.prototype.drawBackground.apply(me, args); + }; + + styleHelpers.drawShadow(chart, vm.shadowOffsetX, vm.shadowOffsetY, + vm.shadowBlur, vm.shadowColor, drawCallback); + + if (backgroundAlpha > 0) { + styleHelpers.drawBackground(vm, drawCallback); + styleHelpers.drawBevel(chart, vm.bevelWidth + bevelExtra, + mergeOpacity(vm.bevelHighlightColor, opacity), + mergeOpacity(vm.bevelShadowColor, opacity), drawCallback); + } + + styleHelpers.drawInnerGlow(chart, vm.innerGlowWidth, + mergeOpacity(vm.innerGlowColor, opacity), vm.borderWidth, drawCallback); + styleHelpers.drawOuterGlow(chart, vm.outerGlowWidth, + mergeOpacity(vm.outerGlowColor, opacity), vm.borderWidth, drawCallback); + + styleHelpers.drawBorder(vm, drawCallback); + } + }); +}; + +'use strict'; + +var StyleController = function(Chart$$1) { + + var helpers = Chart$$1.helpers; + + helpers.extend(Chart$$1.prototype, { + + // Ported from Chart.js 2.7.2. Modified for style tooltip. + initToolTip: function() { + var me = this; + me.tooltip = new Chart$$1.StyleTooltip({ + _chart: me, + _chartInstance: me, // deprecated, backward compatibility + _data: me.data, + _options: me.options.tooltips + }, me); + } + }); +}; + +'use strict'; + +var StyleBarController = function(Chart$$1) { + + var elements = Chart$$1.elements; + var helpers = Chart$$1.helpers; + + var BarController = Chart$$1.controllers.bar; + + return Chart$$1.controllers.bar.extend({ + + dataElementType: elements.StyleRectangle, + + // Ported from Chart.js 2.7.2. Modified for style bar. + updateElement: function(rectangle, index, reset) { + var me = this; + var chart = me.chart; + var meta = me.getMeta(); + var dataset = me.getDataset(); + var custom = rectangle.custom || {}; + var rectangleOptions = chart.options.elements.rectangle; + + rectangle._xScale = me.getScaleForId(meta.xAxisID); + rectangle._yScale = me.getScaleForId(meta.yAxisID); + rectangle._datasetIndex = me.index; + rectangle._index = index; + + rectangle._model = { + datasetLabel: dataset.label, + label: chart.data.labels[index], + borderSkipped: custom.borderSkipped ? custom.borderSkipped : rectangleOptions.borderSkipped, + backgroundColor: custom.backgroundColor ? custom.backgroundColor : helpers.valueAtIndexOrDefault(dataset.backgroundColor, index, rectangleOptions.backgroundColor), + borderColor: custom.borderColor ? custom.borderColor : helpers.valueAtIndexOrDefault(dataset.borderColor, index, rectangleOptions.borderColor), + borderWidth: custom.borderWidth ? custom.borderWidth : helpers.valueAtIndexOrDefault(dataset.borderWidth, index, rectangleOptions.borderWidth), + + shadowOffsetX: custom.shadowOffsetX ? custom.shadowOffsetX : helpers.valueAtIndexOrDefault(dataset.shadowOffsetX, index, rectangleOptions.shadowOffsetX), + shadowOffsetY: custom.shadowOffsetY ? custom.shadowOffsetY : helpers.valueAtIndexOrDefault(dataset.shadowOffsetY, index, rectangleOptions.shadowOffsetY), + shadowBlur: custom.shadowBlur ? custom.shadowBlur : helpers.valueAtIndexOrDefault(dataset.shadowBlur, index, rectangleOptions.shadowBlur), + shadowColor: custom.shadowColor ? custom.shadowColor : helpers.valueAtIndexOrDefault(dataset.shadowColor, index, rectangleOptions.shadowColor), + bevelWidth: custom.bevelWidth ? custom.bevelWidth : helpers.valueAtIndexOrDefault(dataset.bevelWidth, index, rectangleOptions.bevelWidth), + bevelHighlightColor: custom.bevelHighlightColor ? custom.bevelHighlightColor : helpers.valueAtIndexOrDefault(dataset.bevelHighlightColor, index, rectangleOptions.bevelHighlightColor), + bevelShadowColor: custom.bevelShadowColor ? custom.bevelShadowColor : helpers.valueAtIndexOrDefault(dataset.bevelShadowColor, index, rectangleOptions.bevelShadowColor), + innerGlowWidth: custom.innerGlowWidth ? custom.innerGlowWidth : helpers.valueAtIndexOrDefault(dataset.innerGlowWidth, index, rectangleOptions.innerGlowWidth), + innerGlowColor: custom.innerGlowColor ? custom.innerGlowColor : helpers.valueAtIndexOrDefault(dataset.innerGlowColor, index, rectangleOptions.innerGlowColor), + outerGlowWidth: custom.outerGlowWidth ? custom.outerGlowWidth : helpers.valueAtIndexOrDefault(dataset.outerGlowWidth, index, rectangleOptions.outerGlowWidth), + outerGlowColor: custom.outerGlowColor ? custom.outerGlowColor : helpers.valueAtIndexOrDefault(dataset.outerGlowColor, index, rectangleOptions.outerGlowColor) + }; + + me.updateElementGeometry(rectangle, index, reset); + + rectangle.pivot(); + }, + + setHoverStyle: function(element) { + BarController.prototype.setHoverStyle.apply(this, arguments); + + var dataset = this.chart.data.datasets[element._datasetIndex]; + var index = element._index; + var custom = element.custom || {}; + var valueOrDefault = helpers.valueAtIndexOrDefault; + var model = element._model; + + if (element.$previousStyle) { + element.$previousStyle.shadowOffsetX = model.shadowOffsetX; + element.$previousStyle.shadowOffsetY = model.shadowOffsetY; + element.$previousStyle.shadowBlur = model.shadowBlur; + element.$previousStyle.shadowColor = model.shadowColor; + element.$previousStyle.bevelWidth = model.bevelWidth; + element.$previousStyle.bevelHighlightColor = model.bevelHighlightColor; + element.$previousStyle.bevelShadowColor = model.bevelShadowColor; + element.$previousStyle.innerGlowWidth = model.innerGlowWidth; + element.$previousStyle.innerGlowColor = model.innerGlowColor; + element.$previousStyle.outerGlowWidth = model.outerGlowWidth; + element.$previousStyle.outerGlowColor = model.outerGlowColor; + } + + model.shadowOffsetX = custom.hoverShadowOffsetX ? custom.hoverShadowOffsetX : valueOrDefault(dataset.hoverShadowOffsetX, index, model.shadowOffsetX); + model.shadowOffsetY = custom.hoverShadowOffsetY ? custom.hoverShadowOffsetY : valueOrDefault(dataset.hoverShadowOffsetY, index, model.shadowOffsetY); + model.shadowBlur = custom.hoverShadowBlur ? custom.hoverShadowBlur : valueOrDefault(dataset.hoverShadowBlur, index, model.shadowBlur); + model.shadowColor = custom.hoverShadowColor ? custom.hoverShadowColor : valueOrDefault(dataset.hoverShadowColor, index, helpers.getHoverColor(model.shadowColor)); + model.bevelWidth = custom.hoverBevelWidth ? custom.hoverBevelWidth : valueOrDefault(dataset.hoverBevelWidth, index, model.bevelWidth); + model.bevelHighlightColor = custom.hoverBevelHighlightColor ? custom.hoverBevelHighlightColor : valueOrDefault(dataset.hoverBevelHighlightColor, index, helpers.getHoverColor(model.bevelHighlightColor)); + model.bevelShadowColor = custom.hoverBevelShadowColor ? custom.hoverBevelShadowColor : valueOrDefault(dataset.hoverBevelShadowColor, index, helpers.getHoverColor(model.bevelShadowColor)); + model.innerGlowWidth = custom.hoverInnerGlowWidth ? custom.hoverInnerGlowWidth : valueOrDefault(dataset.hoverInnerGlowWidth, index, model.innerGlowWidth); + model.innerGlowColor = custom.hoverInnerGlowColor ? custom.hoverInnerGlowColor : valueOrDefault(dataset.hoverInnerGlowColor, index, helpers.getHoverColor(model.innerGlowColor)); + model.outerGlowWidth = custom.hoverOuterGlowWidth ? custom.hoverOuterGlowWidth : valueOrDefault(dataset.hoverOuterGlowWidth, index, model.outerGlowWidth); + model.outerGlowColor = custom.hoverOuterGlowColor ? custom.hoverOuterGlowColor : valueOrDefault(dataset.hoverOuterGlowColor, index, helpers.getHoverColor(model.outerGlowColor)); + }, + + removeHoverStyle: function(element) { + var dataset = this.chart.data.datasets[element._datasetIndex]; + var index = element._index; + var custom = element.custom || {}; + var valueOrDefault = helpers.valueAtIndexOrDefault; + var model = element._model; + var elementOpts = this.chart.options.elements.rectangle; + + // For Chart.js 2.7.2 backward compatibility + if (!element.$previousStyle) { + model.shadowOffsetX = custom.shadowOffsetX ? custom.shadowOffsetX : valueOrDefault(dataset.shadowOffsetX, index, elementOpts.shadowOffsetX); + model.shadowOffsetY = custom.shadowOffsetY ? custom.shadowOffsetY : valueOrDefault(dataset.shadowOffsetY, index, elementOpts.shadowOffsetY); + model.shadowBlur = custom.shadowBlur ? custom.shadowBlur : valueOrDefault(dataset.shadowBlur, index, elementOpts.shadowBlur); + model.shadowColor = custom.shadowColor ? custom.shadowColor : valueOrDefault(dataset.shadowColor, index, elementOpts.shadowColor); + model.bevelWidth = custom.bevelWidth ? custom.bevelWidth : valueOrDefault(dataset.bevelWidth, index, elementOpts.bevelWidth); + model.bevelHighlightColor = custom.bevelHighlightColor ? custom.bevelHighlightColor : valueOrDefault(dataset.bevelHighlightColor, index, elementOpts.bevelHighlightColor); + model.bevelShadowColor = custom.bevelShadowColor ? custom.bevelShadowColor : valueOrDefault(dataset.bevelShadowColor, index, elementOpts.bevelShadowColor); + model.innerGlowWidth = custom.innerGlowWidth ? custom.innerGlowWidth : valueOrDefault(dataset.innerGlowWidth, index, elementOpts.innerGlowWidth); + model.innerGlowColor = custom.innerGlowColor ? custom.innerGlowColor : valueOrDefault(dataset.innerGlowColor, index, elementOpts.innerGlowColor); + model.outerGlowWidth = custom.outerGlowWidth ? custom.outerGlowWidth : valueOrDefault(dataset.outerGlowWidth, index, elementOpts.outerGlowWidth); + model.outerGlowColor = custom.outerGlowColor ? custom.outerGlowColor : valueOrDefault(dataset.outerGlowColor, index, elementOpts.outerGlowColor); + } + + BarController.prototype.removeHoverStyle.apply(this, arguments); + } + }); +}; + +'use strict'; + +var StyleBubbleController = function(Chart$$1) { + + var elements = Chart$$1.elements; + var helpers = Chart$$1.helpers; + + var BubbleController = Chart$$1.controllers.bubble; + + return Chart$$1.controllers.bubble.extend({ + + dataElementType: elements.StylePoint, + + /** + * Ported from Chart.js 2.7.2. Modified for style bubble. + * @protected + */ + updateElement: function(point, index, reset) { + var me = this; + var meta = me.getMeta(); + var custom = point.custom || {}; + var xScale = me.getScaleForId(meta.xAxisID); + var yScale = me.getScaleForId(meta.yAxisID); + var options = me._resolveElementOptions(point, index); + var data = me.getDataset().data[index]; + var dsIndex = me.index; + + var x = reset ? xScale.getPixelForDecimal(0.5) : xScale.getPixelForValue(typeof data === 'object' ? data : NaN, index, dsIndex); + var y = reset ? yScale.getBasePixel() : yScale.getPixelForValue(data, index, dsIndex); + + point._xScale = xScale; + point._yScale = yScale; + point._options = options; + point._datasetIndex = dsIndex; + point._index = index; + point._model = { + backgroundColor: options.backgroundColor, + borderColor: options.borderColor, + borderWidth: options.borderWidth, + hitRadius: options.hitRadius, + pointStyle: options.pointStyle, + radius: reset ? 0 : options.radius, + skip: custom.skip || isNaN(x) || isNaN(y), + x: x, + y: y, + + shadowOffsetX: options.shadowOffsetX, + shadowOffsetY: options.shadowOffsetY, + shadowBlur: options.shadowBlur, + shadowColor: options.shadowColor, + bevelWidth: options.bevelWidth, + bevelHighlightColor: options.bevelHighlightColor, + bevelShadowColor: options.bevelShadowColor, + innerGlowWidth: options.innerGlowWidth, + innerGlowColor: options.innerGlowColor, + outerGlowWidth: options.outerGlowWidth, + outerGlowColor: options.outerGlowColor + }; + + point.pivot(); + }, + + /** + * @protected + */ + setHoverStyle: function(element) { + BubbleController.prototype.setHoverStyle.apply(this, arguments); + + var valueOrDefault = helpers.valueOrDefault; + var model = element._model; + var options = element._options; + + if (element.$previousStyle) { + element.$previousStyle.shadowOffsetX = model.shadowOffsetX; + element.$previousStyle.shadowOffsetY = model.shadowOffsetY; + element.$previousStyle.shadowBlur = model.shadowBlur; + element.$previousStyle.shadowColor = model.shadowColor; + element.$previousStyle.bevelWidth = model.bevelWidth; + element.$previousStyle.bevelHighlightColor = model.bevelHighlightColor; + element.$previousStyle.bevelShadowColor = model.bevelShadowColor; + element.$previousStyle.innerGlowWidth = model.innerGlowWidth; + element.$previousStyle.innerGlowColor = model.innerGlowColor; + element.$previousStyle.outerGlowWidth = model.outerGlowWidth; + element.$previousStyle.outerGlowColor = model.outerGlowColor; + } + + model.shadowOffsetX = valueOrDefault(options.hoverShadowOffsetX, options.shadowOffsetX); + model.shadowOffsetY = valueOrDefault(options.hoverShadowOffsetY, options.shadowOffsetY); + model.shadowBlur = valueOrDefault(options.hoverShadowBlur, options.shadowBlur); + model.shadowColor = valueOrDefault(options.hoverShadowColor, helpers.getHoverColor(options.shadowColor)); + model.bevelWidth = valueOrDefault(options.hoverBevelWidth, options.bevelWidth); + model.bevelHighlightColor = valueOrDefault(options.hoverBevelHighlightColor, helpers.getHoverColor(options.bevelHighlightColor)); + model.bevelShadowColor = valueOrDefault(options.hoverBevelShadowColor, helpers.getHoverColor(options.bevelShadowColor)); + model.innerGlowWidth = valueOrDefault(options.hoverInnerGlowWidth, options.innerGlowWidth); + model.innerGlowColor = valueOrDefault(options.hoverInnerGlowColor, helpers.getHoverColor(options.innerGlowColor)); + model.outerGlowWidth = valueOrDefault(options.hoverOuterGlowWidth, options.outerGlowWidth); + model.outerGlowColor = valueOrDefault(options.hoverOuterGlowColor, helpers.getHoverColor(options.outerGlowColor)); + }, + + /** + * @protected + */ + removeHoverStyle: function(element) { + var model = element._model; + var options = element._options; + + // For Chart.js 2.7.2 backward compatibility + if (!element.$previousStyle) { + model.shadowOffsetX = options.shadowOffsetX; + model.shadowOffsetY = options.shadowOffsetY; + model.shadowBlur = options.shadowBlur; + model.shadowColor = options.shadowColor; + model.bevelWidth = options.bevelWidth; + model.bevelHighlightColor = options.bevelHighlightColor; + model.bevelShadowColor = options.bevelShadowColor; + model.innerGlowWidth = options.innerGlowWidth; + model.innerGlowColor = options.innerGlowColor; + model.outerGlowWidth = options.outerGlowWidth; + model.outerGlowColor = options.outerGlowColor; + } + + BubbleController.prototype.removeHoverStyle.apply(this, arguments); + }, + + /** + * Ported from Chart.js 2.7.2. Modified for style bubble. + * @private + */ + _resolveElementOptions: function(point, index) { + var me = this; + var chart = me.chart; + var datasets = chart.data.datasets; + var dataset = datasets[me.index]; + var custom = point.custom || {}; + var options = chart.options.elements.point; + var resolve = helpers.options.resolve; + var data = dataset.data[index]; + var values = {}; + var i, ilen, key; + + // Scriptable options + var context = { + chart: chart, + dataIndex: index, + dataset: dataset, + datasetIndex: me.index + }; + + var keys = [ + 'backgroundColor', + 'borderColor', + 'borderWidth', + 'hoverBackgroundColor', + 'hoverBorderColor', + 'hoverBorderWidth', + 'hoverRadius', + 'hitRadius', + 'pointStyle', + 'shadowOffsetX', + 'shadowOffsetY', + 'shadowBlur', + 'shadowColor', + 'hoverShadowOffsetX', + 'hoverShadowOffsetY', + 'hoverShadowBlur', + 'hoverShadowColor', + 'bevelWidth', + 'bevelHighlightColor', + 'bevelShadowColor', + 'hoverBevelWidth', + 'hoverBevelHighlightColor', + 'hoverBevelShadowColor', + 'innerGlowWidth', + 'innerGlowColor', + 'outerGlowWidth', + 'outerGlowColor', + 'hoverInnerGlowWidth', + 'hoverInnerGlowColor', + 'hoverOuterGlowWidth', + 'hoverOuterGlowColor' + ]; + + for (i = 0, ilen = keys.length; i < ilen; ++i) { + key = keys[i]; + values[key] = resolve([ + custom[key], + dataset[key], + options[key] + ], context, index); + } + + // Custom radius resolution + values.radius = resolve([ + custom.radius, + data ? data.r : undefined, + dataset.radius, + options.radius + ], context, index); + + return values; + } + }); +}; + +'use strict'; + +var StyleDoughnutController = function(Chart$$1) { + + var elements = Chart$$1.elements; + var helpers = Chart$$1.helpers; + + // Ported from Chart.js 2.7.2. Modified for style doughnut. + Chart$$1.defaults.doughnut.legend.labels.generateLabels = function(chart) { + var data = chart.data; + if (data.labels.length && data.datasets.length) { + return data.labels.map(function(label, i) { + var meta = chart.getDatasetMeta(0); + var ds = data.datasets[0]; + var arc = meta.data[i]; + var custom = arc && arc.custom || {}; + var valueAtIndexOrDefault = helpers.valueAtIndexOrDefault; + var arcOpts = chart.options.elements.arc; + var fill = custom.backgroundColor ? custom.backgroundColor : valueAtIndexOrDefault(ds.backgroundColor, i, arcOpts.backgroundColor); + var stroke = custom.borderColor ? custom.borderColor : valueAtIndexOrDefault(ds.borderColor, i, arcOpts.borderColor); + var bw = custom.borderWidth ? custom.borderWidth : valueAtIndexOrDefault(ds.borderWidth, i, arcOpts.borderWidth); + + return { + text: label, + fillStyle: fill, + strokeStyle: stroke, + lineWidth: bw, + hidden: isNaN(ds.data[i]) || meta.data[i].hidden, + + shadowOffsetX: custom.shadowOffsetX ? custom.shadowOffsetX : valueAtIndexOrDefault(ds.shadowOffsetX, i, arcOpts.shadowOffsetX), + shadowOffsetY: custom.shadowOffsetY ? custom.shadowOffsetY : valueAtIndexOrDefault(ds.shadowOffsetY, i, arcOpts.shadowOffsetY), + shadowBlur: custom.shadowBlur ? custom.shadowBlur : valueAtIndexOrDefault(ds.shadowBlur, i, arcOpts.shadowBlur), + shadowColor: custom.shadowColor ? custom.shadowColor : valueAtIndexOrDefault(ds.shadowColor, i, arcOpts.shadowColor), + bevelWidth: custom.bevelWidth ? custom.bevelWidth : valueAtIndexOrDefault(ds.bevelWidth, i, arcOpts.bevelWidth), + bevelHighlightColor: custom.bevelHighlightColor ? custom.bevelHighlightColor : valueAtIndexOrDefault(ds.bevelHighlightColor, i, arcOpts.bevelHighlightColor), + bevelShadowColor: custom.bevelShadowColor ? custom.bevelShadowColor : valueAtIndexOrDefault(ds.bevelShadowColor, i, arcOpts.bevelShadowColor), + innerGlowWidth: custom.innerGlowWidth ? custom.innerGlowWidth : valueAtIndexOrDefault(ds.innerGlowWidth, i, arcOpts.innerGlowWidth), + innerGlowColor: custom.innerGlowColor ? custom.innerGlowColor : valueAtIndexOrDefault(ds.innerGlowColor, i, arcOpts.innerGlowColor), + outerGlowWidth: custom.outerGlowWidth ? custom.outerGlowWidth : valueAtIndexOrDefault(ds.outerGlowWidth, i, arcOpts.outerGlowWidth), + outerGlowColor: custom.outerGlowColor ? custom.outerGlowColor : valueAtIndexOrDefault(ds.outerGlowColor, i, arcOpts.outerGlowColor), + + // Extra data used for toggling the correct item + index: i + }; + }); + } + return []; + }; + + var DoughnutController = Chart$$1.controllers.doughnut; + + return Chart$$1.controllers.doughnut.extend({ + + dataElementType: elements.StyleArc, + + // Ported from Chart.js 2.7.2. Modified for style doughnut. + updateElement: function(arc, index, reset) { + var me = this; + var chart = me.chart; + var chartArea = chart.chartArea; + var opts = chart.options; + var animationOpts = opts.animation; + var centerX = (chartArea.left + chartArea.right) / 2; + var centerY = (chartArea.top + chartArea.bottom) / 2; + var startAngle = opts.rotation; // non reset case handled later + var endAngle = opts.rotation; // non reset case handled later + var dataset = me.getDataset(); + var circumference = reset && animationOpts.animateRotate ? 0 : arc.hidden ? 0 : me.calculateCircumference(dataset.data[index]) * (opts.circumference / (2.0 * Math.PI)); + var innerRadius = reset && animationOpts.animateScale ? 0 : me.innerRadius; + var outerRadius = reset && animationOpts.animateScale ? 0 : me.outerRadius; + var valueAtIndexOrDefault = helpers.valueAtIndexOrDefault; + + helpers.extend(arc, { + // Utility + _datasetIndex: me.index, + _index: index, + + // Desired view properties + _model: { + x: centerX + chart.offsetX, + y: centerY + chart.offsetY, + startAngle: startAngle, + endAngle: endAngle, + circumference: circumference, + outerRadius: outerRadius, + innerRadius: innerRadius, + label: valueAtIndexOrDefault(dataset.label, index, chart.data.labels[index]) + } + }); + + var model = arc._model; + + // Resets the visual styles + var custom = arc.custom || {}; + var valueOrDefault = helpers.valueAtIndexOrDefault; + var elementOpts = this.chart.options.elements.arc; + model.backgroundColor = custom.backgroundColor ? custom.backgroundColor : valueOrDefault(dataset.backgroundColor, index, elementOpts.backgroundColor); + model.borderColor = custom.borderColor ? custom.borderColor : valueOrDefault(dataset.borderColor, index, elementOpts.borderColor); + model.borderWidth = custom.borderWidth ? custom.borderWidth : valueOrDefault(dataset.borderWidth, index, elementOpts.borderWidth); + + model.shadowOffsetX = custom.shadowOffsetX ? custom.shadowOffsetX : valueOrDefault(dataset.shadowOffsetX, index, elementOpts.shadowOffsetX); + model.shadowOffsetY = custom.shadowOffsetY ? custom.shadowOffsetY : valueOrDefault(dataset.shadowOffsetY, index, elementOpts.shadowOffsetY); + model.shadowBlur = custom.shadowBlur ? custom.shadowBlur : valueOrDefault(dataset.shadowBlur, index, elementOpts.shadowBlur); + model.shadowColor = custom.shadowColor ? custom.shadowColor : valueOrDefault(dataset.shadowColor, index, elementOpts.shadowColor); + model.bevelWidth = custom.bevelWidth ? custom.bevelWidth : valueOrDefault(dataset.bevelWidth, index, elementOpts.bevelWidth); + model.bevelHighlightColor = custom.bevelHighlightColor ? custom.bevelHighlightColor : valueOrDefault(dataset.bevelHighlightColor, index, elementOpts.bevelHighlightColor); + model.bevelShadowColor = custom.bevelShadowColor ? custom.bevelShadowColor : valueOrDefault(dataset.bevelShadowColor, index, elementOpts.bevelShadowColor); + model.innerGlowWidth = custom.innerGlowWidth ? custom.innerGlowWidth : valueOrDefault(dataset.innerGlowWidth, index, elementOpts.innerGlowWidth); + model.innerGlowColor = custom.innerGlowColor ? custom.innerGlowColor : valueOrDefault(dataset.innerGlowColor, index, elementOpts.innerGlowColor); + model.outerGlowWidth = custom.outerGlowWidth ? custom.outerGlowWidth : valueOrDefault(dataset.outerGlowWidth, index, elementOpts.outerGlowWidth); + model.outerGlowColor = custom.outerGlowColor ? custom.outerGlowColor : valueOrDefault(dataset.outerGlowColor, index, elementOpts.outerGlowColor); + + // Set correct angles if not resetting + if (!reset || !animationOpts.animateRotate) { + if (index === 0) { + model.startAngle = opts.rotation; + } else { + model.startAngle = me.getMeta().data[index - 1]._model.endAngle; + } + + model.endAngle = model.startAngle + model.circumference; + } + + arc.pivot(); + }, + + setHoverStyle: function(element) { + DoughnutController.prototype.setHoverStyle.apply(this, arguments); + + var dataset = this.chart.data.datasets[element._datasetIndex]; + var index = element._index; + var custom = element.custom || {}; + var valueOrDefault = helpers.valueAtIndexOrDefault; + var model = element._model; + + if (element.$previousStyle) { + element.$previousStyle.shadowOffsetX = model.shadowOffsetX; + element.$previousStyle.shadowOffsetY = model.shadowOffsetY; + element.$previousStyle.shadowBlur = model.shadowBlur; + element.$previousStyle.shadowColor = model.shadowColor; + element.$previousStyle.bevelWidth = model.bevelWidth; + element.$previousStyle.bevelHighlightColor = model.bevelHighlightColor; + element.$previousStyle.bevelShadowColor = model.bevelShadowColor; + element.$previousStyle.innerGlowWidth = model.innerGlowWidth; + element.$previousStyle.innerGlowColor = model.innerGlowColor; + element.$previousStyle.outerGlowWidth = model.outerGlowWidth; + element.$previousStyle.outerGlowColor = model.outerGlowColor; + } + + model.shadowOffsetX = custom.hoverShadowOffsetX ? custom.hoverShadowOffsetX : valueOrDefault(dataset.hoverShadowOffsetX, index, model.shadowOffsetX); + model.shadowOffsetY = custom.hoverShadowOffsetY ? custom.hoverShadowOffsetY : valueOrDefault(dataset.hoverShadowOffsetY, index, model.shadowOffsetY); + model.shadowBlur = custom.hoverShadowBlur ? custom.hoverShadowBlur : valueOrDefault(dataset.hoverShadowBlur, index, model.shadowBlur); + model.shadowColor = custom.hoverShadowColor ? custom.hoverShadowColor : valueOrDefault(dataset.hoverShadowColor, index, helpers.getHoverColor(model.shadowColor)); + model.bevelWidth = custom.hoverBevelWidth ? custom.hoverBevelWidth : valueOrDefault(dataset.hoverBevelWidth, index, model.bevelWidth); + model.bevelHighlightColor = custom.hoverBevelHighlightColor ? custom.hoverBevelHighlightColor : valueOrDefault(dataset.hoverBevelHighlightColor, index, helpers.getHoverColor(model.bevelHighlightColor)); + model.bevelShadowColor = custom.hoverBevelShadowColor ? custom.hoverBevelShadowColor : valueOrDefault(dataset.hoverBevelShadowColor, index, helpers.getHoverColor(model.bevelShadowColor)); + model.innerGlowWidth = custom.hoverInnerGlowWidth ? custom.hoverInnerGlowWidth : valueOrDefault(dataset.hoverInnerGlowWidth, index, model.innerGlowWidth); + model.innerGlowColor = custom.hoverInnerGlowColor ? custom.hoverInnerGlowColor : valueOrDefault(dataset.hoverInnerGlowColor, index, helpers.getHoverColor(model.innerGlowColor)); + model.outerGlowWidth = custom.hoverOuterGlowWidth ? custom.hoverOuterGlowWidth : valueOrDefault(dataset.hoverOuterGlowWidth, index, model.outerGlowWidth); + model.outerGlowColor = custom.hoverOuterGlowColor ? custom.hoverOuterGlowColor : valueOrDefault(dataset.hoverOuterGlowColor, index, helpers.getHoverColor(model.outerGlowColor)); + }, + + removeHoverStyle: function(element) { + var dataset = this.chart.data.datasets[element._datasetIndex]; + var index = element._index; + var custom = element.custom || {}; + var valueOrDefault = helpers.valueAtIndexOrDefault; + var model = element._model; + var elementOpts = this.chart.options.elements.arc; + + // For Chart.js 2.7.2 backward compatibility + if (!element.$previousStyle) { + model.shadowOffsetX = custom.shadowOffsetX ? custom.shadowOffsetX : valueOrDefault(dataset.shadowOffsetX, index, elementOpts.shadowOffsetX); + model.shadowOffsetY = custom.shadowOffsetY ? custom.shadowOffsetY : valueOrDefault(dataset.shadowOffsetY, index, elementOpts.shadowOffsetY); + model.shadowBlur = custom.shadowBlur ? custom.shadowBlur : valueOrDefault(dataset.shadowBlur, index, elementOpts.shadowBlur); + model.shadowColor = custom.shadowColor ? custom.shadowColor : valueOrDefault(dataset.shadowColor, index, elementOpts.shadowColor); + model.bevelWidth = custom.bevelWidth ? custom.bevelWidth : valueOrDefault(dataset.bevelWidth, index, elementOpts.bevelWidth); + model.bevelHighlightColor = custom.bevelHighlightColor ? custom.bevelHighlightColor : valueOrDefault(dataset.bevelHighlightColor, index, elementOpts.bevelHighlightColor); + model.bevelShadowColor = custom.bevelShadowColor ? custom.bevelShadowColor : valueOrDefault(dataset.bevelShadowColor, index, elementOpts.bevelShadowColor); + model.innerGlowWidth = custom.innerGlowWidth ? custom.innerGlowWidth : valueOrDefault(dataset.innerGlowWidth, index, elementOpts.innerGlowWidth); + model.innerGlowColor = custom.innerGlowColor ? custom.innerGlowColor : valueOrDefault(dataset.innerGlowColor, index, elementOpts.innerGlowColor); + model.outerGlowWidth = custom.outerGlowWidth ? custom.outerGlowWidth : valueOrDefault(dataset.outerGlowWidth, index, elementOpts.outerGlowWidth); + model.outerGlowColor = custom.outerGlowColor ? custom.outerGlowColor : valueOrDefault(dataset.outerGlowColor, index, elementOpts.outerGlowColor); + } + + DoughnutController.prototype.removeHoverStyle.apply(this, arguments); + } + }); +}; + +'use strict'; + +var StyleLineController = function(Chart$$1) { + + var elements = Chart$$1.elements; + var helpers = Chart$$1.helpers; + + var LineController = Chart$$1.controllers.line; + + // Ported from Chart.js 2.7.2. + function lineEnabled(dataset, options) { + return helpers.valueOrDefault(dataset.showLine, options.showLines); + } + + return Chart$$1.controllers.line.extend({ + + datasetElementType: elements.StyleLine, + + dataElementType: elements.StylePoint, + + // Ported from Chart.js 2.7.2. Modified for style line. + update: function(reset) { + var me = this; + var meta = me.getMeta(); + var line = meta.dataset; + var points = meta.data || []; + var options = me.chart.options; + var lineElementOptions = options.elements.line; + var scale = me.getScaleForId(meta.yAxisID); + var i, ilen, custom; + var dataset = me.getDataset(); + var showLine = lineEnabled(dataset, options); + + // Update Line + if (showLine) { + custom = line.custom || {}; + + // Compatibility: If the properties are defined with only the old name, use those values + if ((dataset.tension !== undefined) && (dataset.lineTension === undefined)) { + dataset.lineTension = dataset.tension; + } + + // Utility + line._scale = scale; + line._datasetIndex = me.index; + // Data + line._children = points; + // Model + line._model = { + // Appearance + // The default behavior of lines is to break at null values, according + // to /~https://github.com/chartjs/Chart.js/issues/2435#issuecomment-216718158 + // This option gives lines the ability to span gaps + spanGaps: dataset.spanGaps ? dataset.spanGaps : options.spanGaps, + tension: custom.tension ? custom.tension : helpers.valueOrDefault(dataset.lineTension, lineElementOptions.tension), + backgroundColor: custom.backgroundColor ? custom.backgroundColor : (dataset.backgroundColor || lineElementOptions.backgroundColor), + borderWidth: custom.borderWidth ? custom.borderWidth : (dataset.borderWidth || lineElementOptions.borderWidth), + borderColor: custom.borderColor ? custom.borderColor : (dataset.borderColor || lineElementOptions.borderColor), + borderCapStyle: custom.borderCapStyle ? custom.borderCapStyle : (dataset.borderCapStyle || lineElementOptions.borderCapStyle), + borderDash: custom.borderDash ? custom.borderDash : (dataset.borderDash || lineElementOptions.borderDash), + borderDashOffset: custom.borderDashOffset ? custom.borderDashOffset : (dataset.borderDashOffset || lineElementOptions.borderDashOffset), + borderJoinStyle: custom.borderJoinStyle ? custom.borderJoinStyle : (dataset.borderJoinStyle || lineElementOptions.borderJoinStyle), + fill: custom.fill ? custom.fill : (dataset.fill !== undefined ? dataset.fill : lineElementOptions.fill), + steppedLine: custom.steppedLine ? custom.steppedLine : helpers.valueOrDefault(dataset.steppedLine, lineElementOptions.stepped), + cubicInterpolationMode: custom.cubicInterpolationMode ? custom.cubicInterpolationMode : helpers.valueOrDefault(dataset.cubicInterpolationMode, lineElementOptions.cubicInterpolationMode), + + shadowOffsetX: custom.shadowOffsetX ? custom.shadowOffsetX : (dataset.shadowOffsetX || lineElementOptions.shadowOffsetX), + shadowOffsetY: custom.shadowOffsetY ? custom.shadowOffsetY : (dataset.shadowOffsetY || lineElementOptions.shadowOffsetY), + shadowBlur: custom.shadowBlur ? custom.shadowBlur : (dataset.shadowBlur || lineElementOptions.shadowBlur), + shadowColor: custom.shadowColor ? custom.shadowColor : (dataset.shadowColor || lineElementOptions.shadowColor), + outerGlowWidth: custom.outerGlowWidth ? custom.outerGlowWidth : (dataset.outerGlowWidth || lineElementOptions.outerGlowWidth), + outerGlowColor: custom.outerGlowColor ? custom.outerGlowColor : (dataset.outerGlowColor || lineElementOptions.outerGlowColor) + }; + + line.pivot(); + } + + // Update Points + for (i = 0, ilen = points.length; i < ilen; ++i) { + me.updateElement(points[i], i, reset); + } + + if (showLine && line._model.tension !== 0) { + me.updateBezierControlPoints(); + } + + // Now pivot the point for animation + for (i = 0, ilen = points.length; i < ilen; ++i) { + points[i].pivot(); + } + }, + + getPointShadowOffsetX: function(point, index) { + var shadowOffsetX = this.chart.options.elements.point.shadowOffsetX; + var dataset = this.getDataset(); + var custom = point.custom || {}; + + if (custom.shadowOffsetX) { + shadowOffsetX = custom.shadowOffsetX; + } else if (dataset.pointShadowOffsetX) { + shadowOffsetX = helpers.valueAtIndexOrDefault(dataset.pointShadowOffsetX, index, shadowOffsetX); + } else if (dataset.shadowOffsetX) { + shadowOffsetX = dataset.shadowOffsetX; + } + + return shadowOffsetX; + }, + + getPointShadowOffsetY: function(point, index) { + var shadowOffsetY = this.chart.options.elements.point.shadowOffsetY; + var dataset = this.getDataset(); + var custom = point.custom || {}; + + if (custom.shadowOffsetY) { + shadowOffsetY = custom.shadowOffsetY; + } else if (dataset.pointShadowOffsetY) { + shadowOffsetY = helpers.valueAtIndexOrDefault(dataset.pointShadowOffsetY, index, shadowOffsetY); + } else if (dataset.shadowOffsetY) { + shadowOffsetY = dataset.shadowOffsetY; + } + + return shadowOffsetY; + }, + + getPointShadowBlur: function(point, index) { + var shadowBlur = this.chart.options.elements.point.shadowBlur; + var dataset = this.getDataset(); + var custom = point.custom || {}; + + if (custom.shadowBlur) { + shadowBlur = custom.shadowBlur; + } else if (dataset.pointShadowBlur) { + shadowBlur = helpers.valueAtIndexOrDefault(dataset.pointShadowBlur, index, shadowBlur); + } else if (dataset.shadowBlur) { + shadowBlur = dataset.shadowBlur; + } + + return shadowBlur; + }, + + getPointShadowColor: function(point, index) { + var shadowColor = this.chart.options.elements.point.shadowColor; + var dataset = this.getDataset(); + var custom = point.custom || {}; + + if (custom.shadowColor) { + shadowColor = custom.shadowColor; + } else if (dataset.pointShadowColor) { + shadowColor = helpers.valueAtIndexOrDefault(dataset.pointShadowColor, index, shadowColor); + } else if (dataset.shadowColor) { + shadowColor = dataset.shadowColor; + } + + return shadowColor; + }, + + getPointBevelWidth: function(point, index) { + var bevelWidth = this.chart.options.elements.point.bevelWidth; + var dataset = this.getDataset(); + var custom = point.custom || {}; + + if (custom.bevelWidth) { + bevelWidth = custom.bevelWidth; + } else if (dataset.pointBevelWidth) { + bevelWidth = helpers.valueAtIndexOrDefault(dataset.pointBevelWidth, index, bevelWidth); + } else if (dataset.bevelWidth) { + bevelWidth = dataset.bevelWidth; + } + + return bevelWidth; + }, + + getPointBevelHighlightColor: function(point, index) { + var bevelHighlightColor = this.chart.options.elements.point.bevelHighlightColor; + var dataset = this.getDataset(); + var custom = point.custom || {}; + + if (custom.bevelHighlightColor) { + bevelHighlightColor = custom.bevelHighlightColor; + } else if (dataset.pointBevelHighlightColor) { + bevelHighlightColor = helpers.valueAtIndexOrDefault(dataset.pointBevelHighlightColor, index, bevelHighlightColor); + } else if (dataset.bevelHighlightColor) { + bevelHighlightColor = dataset.bevelHighlightColor; + } + + return bevelHighlightColor; + }, + + getPointBevelShadowColor: function(point, index) { + var bevelShadowColor = this.chart.options.elements.point.bevelShadowColor; + var dataset = this.getDataset(); + var custom = point.custom || {}; + + if (custom.bevelShadowColor) { + bevelShadowColor = custom.bevelShadowColor; + } else if (dataset.pointBevelShadowColor) { + bevelShadowColor = helpers.valueAtIndexOrDefault(dataset.pointBevelShadowColor, index, bevelShadowColor); + } else if (dataset.bevelShadowColor) { + bevelShadowColor = dataset.bevelShadowColor; + } + + return bevelShadowColor; + }, + + getPointInnerGlowWidth: function(point, index) { + var innerGlowWidth = this.chart.options.elements.point.innerGlowWidth; + var dataset = this.getDataset(); + var custom = point.custom || {}; + + if (custom.innerGlowWidth) { + innerGlowWidth = custom.innerGlowWidth; + } else if (dataset.pointInnerGlowWidth) { + innerGlowWidth = helpers.valueAtIndexOrDefault(dataset.pointInnerGlowWidth, index, innerGlowWidth); + } else if (dataset.innerGlowWidth) { + innerGlowWidth = dataset.innerGlowWidth; + } + + return innerGlowWidth; + }, + + getPointInnerGlowColor: function(point, index) { + var innerGlowColor = this.chart.options.elements.point.innerGlowColor; + var dataset = this.getDataset(); + var custom = point.custom || {}; + + if (custom.innerGlowColor) { + innerGlowColor = custom.innerGlowColor; + } else if (dataset.pointInnerGlowColor) { + innerGlowColor = helpers.valueAtIndexOrDefault(dataset.pointInnerGlowColor, index, innerGlowColor); + } else if (dataset.innerGlowColor) { + innerGlowColor = dataset.innerGlowColor; + } + + return innerGlowColor; + }, + + getPointOuterGlowWidth: function(point, index) { + var outerGlowWidth = this.chart.options.elements.point.outerGlowWidth; + var dataset = this.getDataset(); + var custom = point.custom || {}; + + if (custom.outerGlowWidth) { + outerGlowWidth = custom.outerGlowWidth; + } else if (dataset.pointOuterGlowWidth) { + outerGlowWidth = helpers.valueAtIndexOrDefault(dataset.pointOuterGlowWidth, index, outerGlowWidth); + } else if (dataset.outerGlowWidth) { + outerGlowWidth = dataset.outerGlowWidth; + } + + return outerGlowWidth; + }, + + getPointOuterGlowColor: function(point, index) { + var outerGlowColor = this.chart.options.elements.point.outerGlowColor; + var dataset = this.getDataset(); + var custom = point.custom || {}; + + if (custom.outerGlowColor) { + outerGlowColor = custom.outerGlowColor; + } else if (dataset.pointOuterGlowColor) { + outerGlowColor = helpers.valueAtIndexOrDefault(dataset.pointOuterGlowColor, index, outerGlowColor); + } else if (dataset.outerGlowColor) { + outerGlowColor = dataset.outerGlowColor; + } + + return outerGlowColor; + }, + + updateElement: function(point, index) { + LineController.prototype.updateElement.apply(this, arguments); + + var me = this; + + point._model.shadowOffsetX = me.getPointShadowOffsetX(point, index); + point._model.shadowOffsetY = me.getPointShadowOffsetY(point, index); + point._model.shadowBlur = me.getPointShadowBlur(point, index); + point._model.shadowColor = me.getPointShadowColor(point, index); + point._model.bevelWidth = me.getPointBevelWidth(point, index); + point._model.bevelHighlightColor = me.getPointBevelHighlightColor(point, index); + point._model.bevelShadowColor = me.getPointBevelShadowColor(point, index); + point._model.innerGlowWidth = me.getPointInnerGlowWidth(point, index); + point._model.innerGlowColor = me.getPointInnerGlowColor(point, index); + point._model.outerGlowWidth = me.getPointOuterGlowWidth(point, index); + point._model.outerGlowColor = me.getPointOuterGlowColor(point, index); + }, + + setHoverStyle: function(element) { + LineController.prototype.setHoverStyle.apply(this, arguments); + + // Point + var dataset = this.chart.data.datasets[element._datasetIndex]; + var index = element._index; + var custom = element.custom || {}; + var valueOrDefault = helpers.valueAtIndexOrDefault; + var model = element._model; + + if (element.$previousStyle) { + element.$previousStyle.shadowOffsetX = model.shadowOffsetX; + element.$previousStyle.shadowOffsetY = model.shadowOffsetY; + element.$previousStyle.shadowBlur = model.shadowBlur; + element.$previousStyle.shadowColor = model.shadowColor; + element.$previousStyle.bevelWidth = model.bevelWidth; + element.$previousStyle.bevelHighlightColor = model.bevelHighlightColor; + element.$previousStyle.bevelShadowColor = model.bevelShadowColor; + element.$previousStyle.innerGlowWidth = model.innerGlowWidth; + element.$previousStyle.innerGlowColor = model.innerGlowColor; + element.$previousStyle.outerGlowWidth = model.outerGlowWidth; + element.$previousStyle.outerGlowColor = model.outerGlowColor; + } + + model.shadowOffsetX = custom.hoverShadowOffsetX || valueOrDefault(dataset.pointHoverShadowOffsetX, index, model.shadowOffsetX); + model.shadowOffsetY = custom.hoverShadowOffsetY || valueOrDefault(dataset.pointHoverShadowOffsetY, index, model.shadowOffsetY); + model.shadowBlur = custom.hoverShadowBlur || valueOrDefault(dataset.pointHoverShadowBlur, index, model.shadowBlur); + model.shadowColor = custom.hoverShadowColor || valueOrDefault(dataset.pointHoverShadowColor, index, helpers.getHoverColor(model.shadowColor)); + model.bevelWidth = custom.hoverBevelWidth || valueOrDefault(dataset.pointHoverBevelWidth, index, model.bevelWidth); + model.bevelHighlightColor = custom.hoverBevelHighlightColor || valueOrDefault(dataset.pointHoverBevelHighlightColor, index, helpers.getHoverColor(model.bevelHighlightColor)); + model.bevelShadowColor = custom.hoverBevelShadowColor || valueOrDefault(dataset.pointHoverBevelShadowColor, index, helpers.getHoverColor(model.bevelShadowColor)); + model.innerGlowWidth = custom.hoverInnerGlowWidth || valueOrDefault(dataset.pointHoverInnerGlowWidth, index, model.innerGlowWidth); + model.innerGlowColor = custom.hoverInnerGlowColor || valueOrDefault(dataset.pointHoverInnerGlowColor, index, helpers.getHoverColor(model.innerGlowColor)); + model.outerGlowWidth = custom.hoverOuterGlowWidth || valueOrDefault(dataset.pointHoverOuterGlowWidth, index, model.outerGlowWidth); + model.outerGlowColor = custom.hoverOuterGlowColor || valueOrDefault(dataset.pointHoverOuterGlowColor, index, helpers.getHoverColor(model.outerGlowColor)); + }, + + removeHoverStyle: function(element) { + var me = this; + var index = element._index; + var model = element._model; + + // For Chart.js 2.7.2 backward compatibility + if (!element.$previousStyle) { + model.shadowOffsetX = me.getPointShadowOffsetX(element, index); + model.shadowOffsetY = me.getPointShadowOffsetY(element, index); + model.shadowBlur = me.getPointShadowBlur(element, index); + model.shadowColor = me.getPointShadowColor(element, index); + model.bevelWidth = me.getPointBevelWidth(element, index); + model.bevelHighlightColor = me.getPointBevelHighlightColor(element, index); + model.bevelShadowColor = me.getPointBevelShadowColor(element, index); + model.innerGlowWidth = me.getPointInnerGlowWidth(element, index); + model.innerGlowColor = me.getPointInnerGlowColor(element, index); + model.outerGlowWidth = me.getPointOuterGlowWidth(element, index); + model.outerGlowColor = me.getPointOuterGlowColor(element, index); + } + + LineController.prototype.removeHoverStyle.apply(this, arguments); + } + }); +}; + +'use strict'; + +var StylePolarAreaController = function(Chart$$1) { + + var elements = Chart$$1.elements; + var helpers = Chart$$1.helpers; + + // Ported from Chart.js 2.7.2. Modified for style polarArea. + Chart$$1.defaults.doughnut.legend.labels.generateLabels = function(chart) { + var data = chart.data; + if (data.labels.length && data.datasets.length) { + return data.labels.map(function(label, i) { + var meta = chart.getDatasetMeta(0); + var ds = data.datasets[0]; + var arc = meta.data[i]; + var custom = arc.custom || {}; + var valueAtIndexOrDefault = helpers.valueAtIndexOrDefault; + var arcOpts = chart.options.elements.arc; + var fill = custom.backgroundColor ? custom.backgroundColor : valueAtIndexOrDefault(ds.backgroundColor, i, arcOpts.backgroundColor); + var stroke = custom.borderColor ? custom.borderColor : valueAtIndexOrDefault(ds.borderColor, i, arcOpts.borderColor); + var bw = custom.borderWidth ? custom.borderWidth : valueAtIndexOrDefault(ds.borderWidth, i, arcOpts.borderWidth); + + return { + text: label, + fillStyle: fill, + strokeStyle: stroke, + lineWidth: bw, + hidden: isNaN(ds.data[i]) || meta.data[i].hidden, + + shadowOffsetX: custom.shadowOffsetX ? custom.shadowOffsetX : valueAtIndexOrDefault(ds.shadowOffsetX, i, arcOpts.shadowOffsetX), + shadowOffsetY: custom.shadowOffsetY ? custom.shadowOffsetY : valueAtIndexOrDefault(ds.shadowOffsetY, i, arcOpts.shadowOffsetY), + shadowBlur: custom.shadowBlur ? custom.shadowBlur : valueAtIndexOrDefault(ds.shadowBlur, i, arcOpts.shadowBlur), + shadowColor: custom.shadowColor ? custom.shadowColor : valueAtIndexOrDefault(ds.shadowColor, i, arcOpts.shadowColor), + bevelWidth: custom.bevelWidth ? custom.bevelWidth : valueAtIndexOrDefault(ds.bevelWidth, i, arcOpts.bevelWidth), + bevelHighlightColor: custom.bevelHighlightColor ? custom.bevelHighlightColor : valueAtIndexOrDefault(ds.bevelHighlightColor, i, arcOpts.bevelHighlightColor), + bevelShadowColor: custom.bevelShadowColor ? custom.bevelShadowColor : valueAtIndexOrDefault(ds.bevelShadowColor, i, arcOpts.bevelShadowColor), + innerGlowWidth: custom.innerGlowWidth ? custom.innerGlowWidth : valueAtIndexOrDefault(ds.innerGlowWidth, i, arcOpts.innerGlowWidth), + innerGlowColor: custom.innerGlowColor ? custom.innerGlowColor : valueAtIndexOrDefault(ds.innerGlowColor, i, arcOpts.innerGlowColor), + outerGlowWidth: custom.outerGlowWidth ? custom.outerGlowWidth : valueAtIndexOrDefault(ds.outerGlowWidth, i, arcOpts.outerGlowWidth), + outerGlowColor: custom.outerGlowColor ? custom.outerGlowColor : valueAtIndexOrDefault(ds.outerGlowColor, i, arcOpts.outerGlowColor), + + // Extra data used for toggling the correct item + index: i + }; + }); + } + return []; + }; + + var PolarAreaController = Chart$$1.controllers.polarArea; + + return Chart$$1.controllers.polarArea.extend({ + + dataElementType: elements.StyleArc, + + // Ported from Chart.js 2.7.2. Modified for style polarArea. + updateElement: function(arc, index, reset) { + var me = this; + var chart = me.chart; + var dataset = me.getDataset(); + var opts = chart.options; + var animationOpts = opts.animation; + var scale = chart.scale; + var labels = chart.data.labels; + + // For Chart.js 2.7.2 backward compatibility + var circumference = me.calculateCircumference(dataset.data[index]); + + var centerX = scale.xCenter; + var centerY = scale.yCenter; + + // For Chart.js 2.7.2 backward compatibility + // If there is NaN data before us, we need to calculate the starting angle correctly. + // We could be way more efficient here, but its unlikely that the polar area chart will have a lot of data + var visibleCount = 0; + var meta = me.getMeta(); + for (var i = 0; i < index; ++i) { + if (!isNaN(dataset.data[i]) && !meta.data[i].hidden) { + ++visibleCount; + } + } + + // var negHalfPI = -0.5 * Math.PI; + var datasetStartAngle = opts.startAngle; + var distance = arc.hidden ? 0 : scale.getDistanceFromCenterForValue(dataset.data[index]); + + // For Chart.js 2.7.2 backward compatibility + var startAngle = circumference ? datasetStartAngle + (circumference * visibleCount) : me._starts[index]; + var endAngle = startAngle + (arc.hidden ? 0 : (circumference || me._angles[index])); + + var resetRadius = animationOpts.animateScale ? 0 : scale.getDistanceFromCenterForValue(dataset.data[index]); + + helpers.extend(arc, { + // Utility + _datasetIndex: me.index, + _index: index, + _scale: scale, + + // Desired view properties + _model: { + x: centerX, + y: centerY, + innerRadius: 0, + outerRadius: reset ? resetRadius : distance, + startAngle: reset && animationOpts.animateRotate ? datasetStartAngle : startAngle, + endAngle: reset && animationOpts.animateRotate ? datasetStartAngle : endAngle, + label: helpers.valueAtIndexOrDefault(labels, index, labels[index]) + } + }); + + // Apply border and fill style + var elementOpts = this.chart.options.elements.arc; + var custom = arc.custom || {}; + var valueOrDefault = helpers.valueAtIndexOrDefault; + var model = arc._model; + + model.backgroundColor = custom.backgroundColor ? custom.backgroundColor : valueOrDefault(dataset.backgroundColor, index, elementOpts.backgroundColor); + model.borderColor = custom.borderColor ? custom.borderColor : valueOrDefault(dataset.borderColor, index, elementOpts.borderColor); + model.borderWidth = custom.borderWidth ? custom.borderWidth : valueOrDefault(dataset.borderWidth, index, elementOpts.borderWidth); + + model.shadowOffsetX = custom.shadowOffsetX ? custom.shadowOffsetX : valueOrDefault(dataset.shadowOffsetX, index, elementOpts.shadowOffsetX); + model.shadowOffsetY = custom.shadowOffsetY ? custom.shadowOffsetY : valueOrDefault(dataset.shadowOffsetY, index, elementOpts.shadowOffsetY); + model.shadowBlur = custom.shadowBlur ? custom.shadowBlur : valueOrDefault(dataset.shadowBlur, index, elementOpts.shadowBlur); + model.shadowColor = custom.shadowColor ? custom.shadowColor : valueOrDefault(dataset.shadowColor, index, elementOpts.shadowColor); + model.bevelWidth = custom.bevelWidth ? custom.bevelWidth : valueOrDefault(dataset.bevelWidth, index, elementOpts.bevelWidth); + model.bevelHighlightColor = custom.bevelHighlightColor ? custom.bevelHighlightColor : valueOrDefault(dataset.bevelHighlightColor, index, elementOpts.bevelHighlightColor); + model.bevelShadowColor = custom.bevelShadowColor ? custom.bevelShadowColor : valueOrDefault(dataset.bevelShadowColor, index, elementOpts.bevelShadowColor); + model.innerGlowWidth = custom.innerGlowWidth ? custom.innerGlowWidth : valueOrDefault(dataset.innerGlowWidth, index, elementOpts.innerGlowWidth); + model.innerGlowColor = custom.innerGlowColor ? custom.innerGlowColor : valueOrDefault(dataset.innerGlowColor, index, elementOpts.innerGlowColor); + model.outerGlowWidth = custom.outerGlowWidth ? custom.outerGlowWidth : valueOrDefault(dataset.outerGlowWidth, index, elementOpts.outerGlowWidth); + model.outerGlowColor = custom.outerGlowColor ? custom.outerGlowColor : valueOrDefault(dataset.outerGlowColor, index, elementOpts.outerGlowColor); + + arc.pivot(); + }, + + setHoverStyle: function(element) { + PolarAreaController.prototype.setHoverStyle.apply(this, arguments); + + var dataset = this.chart.data.datasets[element._datasetIndex]; + var index = element._index; + var custom = element.custom || {}; + var valueOrDefault = helpers.valueAtIndexOrDefault; + var model = element._model; + + if (element.$previousStyle) { + element.$previousStyle.shadowOffsetX = model.shadowOffsetX; + element.$previousStyle.shadowOffsetY = model.shadowOffsetY; + element.$previousStyle.shadowBlur = model.shadowBlur; + element.$previousStyle.shadowColor = model.shadowColor; + element.$previousStyle.bevelWidth = model.bevelWidth; + element.$previousStyle.bevelHighlightColor = model.bevelHighlightColor; + element.$previousStyle.bevelShadowColor = model.bevelShadowColor; + element.$previousStyle.innerGlowWidth = model.innerGlowWidth; + element.$previousStyle.innerGlowColor = model.innerGlowColor; + element.$previousStyle.outerGlowWidth = model.outerGlowWidth; + element.$previousStyle.outerGlowColor = model.outerGlowColor; + } + + model.shadowOffsetX = custom.hoverShadowOffsetX ? custom.hoverShadowOffsetX : valueOrDefault(dataset.hoverShadowOffsetX, index, model.shadowOffsetX); + model.shadowOffsetY = custom.hoverShadowOffsetY ? custom.hoverShadowOffsetY : valueOrDefault(dataset.hoverShadowOffsetY, index, model.shadowOffsetY); + model.shadowBlur = custom.hoverShadowBlur ? custom.hoverShadowBlur : valueOrDefault(dataset.hoverShadowBlur, index, model.shadowBlur); + model.shadowColor = custom.hoverShadowColor ? custom.hoverShadowColor : valueOrDefault(dataset.hoverShadowColor, index, helpers.getHoverColor(model.shadowColor)); + model.bevelWidth = custom.hoverBevelWidth ? custom.hoverBevelWidth : valueOrDefault(dataset.hoverBevelWidth, index, model.bevelWidth); + model.bevelHighlightColor = custom.hoverBevelHighlightColor ? custom.hoverBevelHighlightColor : valueOrDefault(dataset.hoverBevelHighlightColor, index, helpers.getHoverColor(model.bevelHighlightColor)); + model.bevelShadowColor = custom.hoverBevelShadowColor ? custom.hoverBevelShadowColor : valueOrDefault(dataset.hoverBevelShadowColor, index, helpers.getHoverColor(model.bevelShadowColor)); + model.innerGlowWidth = custom.hoverInnerGlowWidth ? custom.hoverInnerGlowWidth : valueOrDefault(dataset.hoverInnerGlowWidth, index, model.innerGlowWidth); + model.innerGlowColor = custom.hoverInnerGlowColor ? custom.hoverInnerGlowColor : valueOrDefault(dataset.hoverInnerGlowColor, index, helpers.getHoverColor(model.innerGlowColor)); + model.outerGlowWidth = custom.hoverOuterGlowWidth ? custom.hoverOuterGlowWidth : valueOrDefault(dataset.hoverOuterGlowWidth, index, model.outerGlowWidth); + model.outerGlowColor = custom.hoverOuterGlowColor ? custom.hoverOuterGlowColor : valueOrDefault(dataset.hoverOuterGlowColor, index, helpers.getHoverColor(model.outerGlowColor)); + }, + + removeHoverStyle: function(element) { + var dataset = this.chart.data.datasets[element._datasetIndex]; + var index = element._index; + var custom = element.custom || {}; + var valueOrDefault = helpers.valueAtIndexOrDefault; + var model = element._model; + var elementOpts = this.chart.options.elements.arc; + + // For Chart.js 2.7.2 backward compatibility + if (!element.$previousStyle) { + model.shadowOffsetX = custom.shadowOffsetX ? custom.shadowOffsetX : valueOrDefault(dataset.shadowOffsetX, index, elementOpts.shadowOffsetX); + model.shadowOffsetY = custom.shadowOffsetY ? custom.shadowOffsetY : valueOrDefault(dataset.shadowOffsetY, index, elementOpts.shadowOffsetY); + model.shadowBlur = custom.shadowBlur ? custom.shadowBlur : valueOrDefault(dataset.shadowBlur, index, elementOpts.shadowBlur); + model.shadowColor = custom.shadowColor ? custom.shadowColor : valueOrDefault(dataset.shadowColor, index, elementOpts.shadowColor); + model.bevelWidth = custom.bevelWidth ? custom.bevelWidth : valueOrDefault(dataset.bevelWidth, index, elementOpts.bevelWidth); + model.bevelHighlightColor = custom.bevelHighlightColor ? custom.bevelHighlightColor : valueOrDefault(dataset.bevelHighlightColor, index, elementOpts.bevelHighlightColor); + model.bevelShadowColor = custom.bevelShadowColor ? custom.bevelShadowColor : valueOrDefault(dataset.bevelShadowColor, index, elementOpts.bevelShadowColor); + model.innerGlowWidth = custom.innerGlowWidth ? custom.innerGlowWidth : valueOrDefault(dataset.innerGlowWidth, index, elementOpts.innerGlowWidth); + model.innerGlowColor = custom.innerGlowColor ? custom.innerGlowColor : valueOrDefault(dataset.innerGlowColor, index, elementOpts.innerGlowColor); + model.outerGlowWidth = custom.outerGlowWidth ? custom.outerGlowWidth : valueOrDefault(dataset.outerGlowWidth, index, elementOpts.outerGlowWidth); + model.outerGlowColor = custom.outerGlowColor ? custom.outerGlowColor : valueOrDefault(dataset.outerGlowColor, index, elementOpts.outerGlowColor); + } + + PolarAreaController.prototype.removeHoverStyle.apply(this, arguments); + } + }); +}; + +'use strict'; + +var StyleRadarController = function(Chart$$1) { + + var elements = Chart$$1.elements; + var helpers = Chart$$1.helpers; + + var RadarController = Chart$$1.controllers.radar; + + return Chart$$1.controllers.radar.extend({ + + datasetElementType: elements.StyleLine, + + dataElementType: elements.StylePoint, + + // Ported from Chart.js 2.7.2. Modified for style radar. + update: function(reset) { + var me = this; + var meta = me.getMeta(); + var line = meta.dataset; + var points = meta.data; + var custom = line.custom || {}; + var dataset = me.getDataset(); + var lineElementOptions = me.chart.options.elements.line; + var scale = me.chart.scale; + + // Compatibility: If the properties are defined with only the old name, use those values + if ((dataset.tension !== undefined) && (dataset.lineTension === undefined)) { + dataset.lineTension = dataset.tension; + } + + helpers.extend(meta.dataset, { + // Utility + _datasetIndex: me.index, + _scale: scale, + // Data + _children: points, + _loop: true, + // Model + _model: { + // Appearance + tension: custom.tension ? custom.tension : helpers.valueOrDefault(dataset.lineTension, lineElementOptions.tension), + backgroundColor: custom.backgroundColor ? custom.backgroundColor : (dataset.backgroundColor || lineElementOptions.backgroundColor), + borderWidth: custom.borderWidth ? custom.borderWidth : (dataset.borderWidth || lineElementOptions.borderWidth), + borderColor: custom.borderColor ? custom.borderColor : (dataset.borderColor || lineElementOptions.borderColor), + fill: custom.fill ? custom.fill : (dataset.fill !== undefined ? dataset.fill : lineElementOptions.fill), + borderCapStyle: custom.borderCapStyle ? custom.borderCapStyle : (dataset.borderCapStyle || lineElementOptions.borderCapStyle), + borderDash: custom.borderDash ? custom.borderDash : (dataset.borderDash || lineElementOptions.borderDash), + borderDashOffset: custom.borderDashOffset ? custom.borderDashOffset : (dataset.borderDashOffset || lineElementOptions.borderDashOffset), + borderJoinStyle: custom.borderJoinStyle ? custom.borderJoinStyle : (dataset.borderJoinStyle || lineElementOptions.borderJoinStyle), + + shadowOffsetX: custom.shadowOffsetX ? custom.shadowOffsetX : (dataset.shadowOffsetX || lineElementOptions.shadowOffsetX), + shadowOffsetY: custom.shadowOffsetY ? custom.shadowOffsetY : (dataset.shadowOffsetY || lineElementOptions.shadowOffsetY), + shadowBlur: custom.shadowBlur ? custom.shadowBlur : (dataset.shadowBlur || lineElementOptions.shadowBlur), + shadowColor: custom.shadowColor ? custom.shadowColor : (dataset.shadowColor || lineElementOptions.shadowColor), + outerGlowWidth: custom.outerGlowWidth ? custom.outerGlowWidth : (dataset.outerGlowWidth || lineElementOptions.outerGlowWidth), + outerGlowColor: custom.outerGlowColor ? custom.outerGlowColor : (dataset.outerGlowColor || lineElementOptions.outerGlowColor) + } + }); + + meta.dataset.pivot(); + + // Update Points + helpers.each(points, function(point, index) { + me.updateElement(point, index, reset); + }, me); + + // Update bezier control points + me.updateBezierControlPoints(); + }, + + updateElement: function(point, index) { + RadarController.prototype.updateElement.apply(this, arguments); + + var me = this; + var custom = point.custom || {}; + var dataset = me.getDataset(); + var pointElementOptions = me.chart.options.elements.point; + + point._model.shadowOffsetX = !isNaN(custom.shadowOffsetX) ? custom.shadowOffsetX : helpers.valueAtIndexOrDefault(dataset.pointShadowOffsetX, index, !isNaN(dataset.shadowOffsetX) ? dataset.shadowOffsetX : pointElementOptions.shadowOffsetX); + point._model.shadowOffsetY = !isNaN(custom.shadowOffsetY) ? custom.shadowOffsetY : helpers.valueAtIndexOrDefault(dataset.pointShadowOffsetY, index, !isNaN(dataset.shadowOffsetY) ? dataset.shadowOffsetY : pointElementOptions.shadowOffsetY); + point._model.shadowBlur = !isNaN(custom.shadowBlur) ? custom.shadowBlur : helpers.valueAtIndexOrDefault(dataset.pointShadowBlur, index, !isNaN(dataset.shadowBlur) ? dataset.shadowBlur : pointElementOptions.shadowBlur); + point._model.shadowColor = custom.shadowColor ? custom.shadowColor : helpers.valueAtIndexOrDefault(dataset.pointShadowColor, index, dataset.shadowColor ? dataset.shadowColor : pointElementOptions.shadowColor); + point._model.bevelWidth = !isNaN(custom.bevelWidth) ? custom.bevelWidth : helpers.valueAtIndexOrDefault(dataset.pointBevelWidth, index, !isNaN(dataset.bevelWidth) ? dataset.bevelWidth : pointElementOptions.bevelWidth); + point._model.bevelHighlightColor = custom.bevelHighlightColor ? custom.bevelHighlightColor : helpers.valueAtIndexOrDefault(dataset.pointBevelHighlightColor, index, dataset.bevelHighlightColor ? dataset.bevelHighlightColor : pointElementOptions.bevelHighlightColor); + point._model.bevelShadowColor = custom.bevelShadowColor ? custom.bevelShadowColor : helpers.valueAtIndexOrDefault(dataset.pointBevelShadowColor, index, dataset.bevelShadowColor ? dataset.bevelShadowColor : pointElementOptions.bevelShadowColor); + point._model.innerGlowWidth = !isNaN(custom.innerGlowWidth) ? custom.innerGlowWidth : helpers.valueAtIndexOrDefault(dataset.pointInnerGlowWidth, index, !isNaN(dataset.innerGlowWidth) ? dataset.innerGlowWidth : pointElementOptions.innerGlowWidth); + point._model.innerGlowColor = custom.innerGlowColor ? custom.innerGlowColor : helpers.valueAtIndexOrDefault(dataset.pointInnerGlowColor, index, dataset.innerGlowColor ? dataset.innerGlowColor : pointElementOptions.innerGlowColor); + point._model.outerGlowWidth = !isNaN(custom.outerGlowWidth) ? custom.outerGlowWidth : helpers.valueAtIndexOrDefault(dataset.pointOuterGlowWidth, index, !isNaN(dataset.outerGlowWidth) ? dataset.outerGlowWidth : pointElementOptions.outerGlowWidth); + point._model.outerGlowColor = custom.outerGlowColor ? custom.outerGlowColor : helpers.valueAtIndexOrDefault(dataset.pointOuterGlowColor, index, dataset.outerGlowColor ? dataset.outerGlowColor : pointElementOptions.outerGlowColor); + }, + + setHoverStyle: function(element) { + RadarController.prototype.setHoverStyle.apply(this, arguments); + + // Point + var dataset = this.chart.data.datasets[element._datasetIndex]; + var index = element._index; + var custom = element.custom || {}; + var valueOrDefault = helpers.valueAtIndexOrDefault; + var model = element._model; + + if (element.$previousStyle) { + element.$previousStyle.shadowOffsetX = model.shadowOffsetX; + element.$previousStyle.shadowOffsetY = model.shadowOffsetY; + element.$previousStyle.shadowBlur = model.shadowBlur; + element.$previousStyle.shadowColor = model.shadowColor; + element.$previousStyle.bevelWidth = model.bevelWidth; + element.$previousStyle.bevelHighlightColor = model.bevelHighlightColor; + element.$previousStyle.bevelShadowColor = model.bevelShadowColor; + element.$previousStyle.innerGlowWidth = model.innerGlowWidth; + element.$previousStyle.innerGlowColor = model.innerGlowColor; + element.$previousStyle.outerGlowWidth = model.outerGlowWidth; + element.$previousStyle.outerGlowColor = model.outerGlowColor; + } + + model.shadowOffsetX = custom.hoverShadowOffsetX ? custom.hoverShadowOffsetX : valueOrDefault(dataset.pointHoverShadowOffsetX, index, model.shadowOffsetX); + model.shadowOffsetY = custom.hoverShadowOffsetY ? custom.hoverShadowOffsetY : valueOrDefault(dataset.pointHoverShadowOffsetY, index, model.shadowOffsetY); + model.shadowBlur = custom.hoverShadowBlur ? custom.hoverShadowBlur : valueOrDefault(dataset.pointHoverShadowBlur, index, model.shadowBlur); + model.shadowColor = custom.hoverShadowColor ? custom.hoverShadowColor : valueOrDefault(dataset.pointHoverShadowColor, index, helpers.getHoverColor(model.shadowColor)); + model.bevelWidth = custom.hoverBevelWidth ? custom.hoverBevelWidth : valueOrDefault(dataset.pointHoverBevelWidth, index, model.bevelWidth); + model.bevelHighlightColor = custom.hoverBevelHighlightColor ? custom.hoverBevelHighlightColor : valueOrDefault(dataset.pointHoverBevelHighlightColor, index, helpers.getHoverColor(model.bevelHighlightColor)); + model.bevelShadowColor = custom.hoverBevelShadowColor ? custom.hoverBevelShadowColor : valueOrDefault(dataset.pointHoverBevelShadowColor, index, helpers.getHoverColor(model.bevelShadowColor)); + model.innerGlowWidth = custom.hoverInnerGlowWidth ? custom.hoverInnerGlowWidth : valueOrDefault(dataset.pointHoverInnerGlowWidth, index, model.innerGlowWidth); + model.innerGlowColor = custom.hoverInnerGlowColor ? custom.hoverInnerGlowColor : valueOrDefault(dataset.pointHoverInnerGlowColor, index, helpers.getHoverColor(model.innerGlowColor)); + model.outerGlowWidth = custom.hoverOuterGlowWidth ? custom.hoverOuterGlowWidth : valueOrDefault(dataset.pointHoverOuterGlowWidth, index, model.outerGlowWidth); + model.outerGlowColor = custom.hoverOuterGlowColor ? custom.hoverOuterGlowColor : valueOrDefault(dataset.pointHoverOuterGlowColor, index, helpers.getHoverColor(model.outerGlowColor)); + }, + + removeHoverStyle: function(element) { + var dataset = this.chart.data.datasets[element._datasetIndex]; + var index = element._index; + var custom = element.custom || {}; + var valueOrDefault = helpers.valueAtIndexOrDefault; + var model = element._model; + var elementOpts = this.chart.options.elements.point; + + // For Chart.js 2.7.2 backward compatibility + if (!element.$previousStyle) { + model.shadowOffsetX = !isNaN(custom.shadowOffsetX) ? custom.shadowOffsetX : valueOrDefault(dataset.pointShadowOffsetX, index, !isNaN(dataset.shadowOffsetX) ? dataset.shadowOffsetX : elementOpts.shadowOffsetX); + model.shadowOffsetY = !isNaN(custom.shadowOffsetY) ? custom.shadowOffsetY : valueOrDefault(dataset.pointShadowOffsetY, index, !isNaN(dataset.shadowOffsetY) ? dataset.shadowOffsetY : elementOpts.shadowOffsetY); + model.shadowBlur = !isNaN(custom.shadowBlur) ? custom.shadowBlur : valueOrDefault(dataset.pointShadowBlur, index, !isNaN(dataset.shadowBlur) ? dataset.shadowBlur : elementOpts.shadowBlur); + model.shadowColor = custom.shadowColor ? custom.shadowColor : valueOrDefault(dataset.pointShadowColor, index, dataset.shadowColor ? dataset.shadowColor : elementOpts.shadowColor); + model.bevelWidth = !isNaN(custom.bevelWidth) ? custom.bevelWidth : valueOrDefault(dataset.pointBevelWidth, index, !isNaN(dataset.bevelWidth) ? dataset.bevelWidth : elementOpts.bevelWidth); + model.bevelHighlightColor = custom.bevelHighlightColor ? custom.bevelHighlightColor : valueOrDefault(dataset.pointBevelHighlightColor, index, dataset.bevelHighlightColor ? dataset.bevelHighlightColor : elementOpts.bevelHighlightColor); + model.bevelShadowColor = custom.bevelShadowColor ? custom.bevelShadowColor : valueOrDefault(dataset.pointBevelShadowColor, index, dataset.bevelShadowColor ? dataset.bevelShadowColor : elementOpts.bevelShadowColor); + model.innerGlowWidth = !isNaN(custom.innerGlowWidth) ? custom.innerGlowWidth : valueOrDefault(dataset.pointInnerGlowWidth, index, !isNaN(dataset.innerGlowWidth) ? dataset.innerGlowWidth : elementOpts.innerGlowWidth); + model.innerGlowColor = custom.innerGlowColor ? custom.innerGlowColor : valueOrDefault(dataset.pointInnerGlowColor, index, dataset.innerGlowColor ? dataset.innerGlowColor : elementOpts.innerGlowColor); + model.outerGlowWidth = !isNaN(custom.outerGlowWidth) ? custom.outerGlowWidth : valueOrDefault(dataset.pointOuterGlowWidth, index, !isNaN(dataset.outerGlowWidth) ? dataset.outerGlowWidth : elementOpts.outerGlowWidth); + model.outerGlowColor = custom.outerGlowColor ? custom.outerGlowColor : valueOrDefault(dataset.pointOuterGlowColor, index, dataset.outerGlowColor ? dataset.outerGlowColor : elementOpts.outerGlowColor); + } + + RadarController.prototype.removeHoverStyle.apply(this, arguments); + } + }); +}; + +var StyleLegendPlugin = function(Chart$$1) { + + var defaults = Chart$$1.defaults; + var helpers = Chart$$1.helpers; + var styleHelpers = Chart$$1.helpers.style; + var layouts = Chart$$1.layouts; + + // Ported from Chart.js 2.7.2. Modified for style legend. + // Generates labels shown in the legend + defaults.global.legend.labels.generateLabels = function(chart) { + var data = chart.data; + return helpers.isArray(data.datasets) ? data.datasets.map(function(dataset, i) { + return { + text: dataset.label, + fillStyle: (!helpers.isArray(dataset.backgroundColor) ? dataset.backgroundColor : dataset.backgroundColor[0]), + hidden: !chart.isDatasetVisible(i), + lineCap: dataset.borderCapStyle, + lineDash: dataset.borderDash, + lineDashOffset: dataset.borderDashOffset, + lineJoin: dataset.borderJoinStyle, + lineWidth: dataset.borderWidth, + strokeStyle: dataset.borderColor, + pointStyle: dataset.pointStyle, + + shadowOffsetX: (!helpers.isArray(dataset.shadowOffsetX) ? dataset.shadowOffsetX : dataset.shadowOffsetX[0]), + shadowOffsetY: (!helpers.isArray(dataset.shadowOffsetY) ? dataset.shadowOffsetY : dataset.shadowOffsetY[0]), + shadowBlur: (!helpers.isArray(dataset.shadowBlur) ? dataset.shadowBlur : dataset.shadowBlur[0]), + shadowColor: (!helpers.isArray(dataset.shadowColor) ? dataset.shadowColor : dataset.shadowColor[0]), + bevelWidth: helpers.valueOrDefault((!helpers.isArray(dataset.pointBevelWidth) ? dataset.pointBevelWidth : dataset.pointBevelWidth[0]), dataset.bevelWidth), + bevelHighlightColor: helpers.valueOrDefault((!helpers.isArray(dataset.pointBevelHighlightColor) ? dataset.pointBevelHighlightColor : dataset.pointBevelHighlightColor[0]), dataset.bevelHighlightColor), + bevelShadowColor: helpers.valueOrDefault((!helpers.isArray(dataset.pointBevelShadowColor) ? dataset.pointBevelShadowColor : dataset.pointBevelShadowColor[0]), dataset.bevelShadowColor), + innerGlowWidth: helpers.valueOrDefault((!helpers.isArray(dataset.pointInnerGlowWidth) ? dataset.pointInnerGlowWidth : dataset.pointInnerGlowWidth[0]), dataset.innerGlowWidth), + innerGlowColor: helpers.valueOrDefault((!helpers.isArray(dataset.pointInnerGlowColor) ? dataset.pointInnerGlowColor : dataset.pointInnerGlowColor[0]), dataset.innerGlowColor), + outerGlowWidth: helpers.valueOrDefault((!helpers.isArray(dataset.pointOuterGlowWidth) ? dataset.pointOuterGlowWidth : dataset.pointOuterGlowWidth[0]), dataset.outerGlowWidth), + outerGlowColor: helpers.valueOrDefault((!helpers.isArray(dataset.pointOuterGlowColor) ? dataset.pointOuterGlowColor : dataset.pointOuterGlowColor[0]), dataset.outerGlowColor), + + // Below is extra data used for toggling the datasets + datasetIndex: i + }; + }, this) : []; + }; + + /** + * Ported from Chart.js 2.7.2. + * + * Helper function to get the box width based on the usePointStyle option + * @param labelopts {Object} the label options on the legend + * @param fontSize {Number} the label font size + * @return {Number} width of the color box area + */ + function getBoxWidth(labelOpts, fontSize) { + return labelOpts.usePointStyle ? + fontSize * Math.SQRT2 : + labelOpts.boxWidth; + } + + var StyleLegend = Chart$$1.Legend.extend({ + + // Ported from Chart.js 2.7.2. Modified for style legend. + // Actually draw the legend on the canvas + draw: function() { + var me = this; + var opts = me.options; + var labelOpts = opts.labels; + var globalDefault = defaults.global; + var lineDefault = globalDefault.elements.line; + var legendWidth = me.width; + var lineWidths = me.lineWidths; + + if (opts.display) { + var ctx = me.ctx; + var valueOrDefault = helpers.valueOrDefault; + var fontColor = valueOrDefault(labelOpts.fontColor, globalDefault.defaultFontColor); + var fontSize = valueOrDefault(labelOpts.fontSize, globalDefault.defaultFontSize); + var fontStyle = valueOrDefault(labelOpts.fontStyle, globalDefault.defaultFontStyle); + var fontFamily = valueOrDefault(labelOpts.fontFamily, globalDefault.defaultFontFamily); + var labelFont = helpers.fontString(fontSize, fontStyle, fontFamily); + var cursor; + + // Canvas setup + ctx.textAlign = 'left'; + ctx.textBaseline = 'middle'; + ctx.lineWidth = 0.5; + ctx.strokeStyle = fontColor; // for strikethrough effect + ctx.fillStyle = fontColor; // render in correct colour + ctx.font = labelFont; + + var boxWidth = getBoxWidth(labelOpts, fontSize); + var hitboxes = me.legendHitBoxes; + + // current position + var drawLegendBox = function(x, y, legendItem) { + var drawCallback; + + if (isNaN(boxWidth) || boxWidth <= 0) { + return; + } + + // Set the ctx for the box + ctx.save(); + + ctx.fillStyle = valueOrDefault(legendItem.fillStyle, globalDefault.defaultColor); + ctx.lineCap = valueOrDefault(legendItem.lineCap, lineDefault.borderCapStyle); + ctx.lineDashOffset = valueOrDefault(legendItem.lineDashOffset, lineDefault.borderDashOffset); + ctx.lineJoin = valueOrDefault(legendItem.lineJoin, lineDefault.borderJoinStyle); + ctx.lineWidth = valueOrDefault(legendItem.lineWidth, lineDefault.borderWidth); + ctx.strokeStyle = valueOrDefault(legendItem.strokeStyle, globalDefault.defaultColor); + var isLineWidthZero = (valueOrDefault(legendItem.lineWidth, lineDefault.borderWidth) === 0); + + if (ctx.setLineDash) { + // IE 9 and 10 do not support line dash + ctx.setLineDash(valueOrDefault(legendItem.lineDash, lineDefault.borderDash)); + } + + if (opts.labels && opts.labels.usePointStyle) { + // Recalculate x and y for drawPoint() because its expecting + // x and y to be center of figure (instead of top left) + var radius = fontSize * Math.SQRT2 / 2; + var offSet = radius / Math.SQRT2; + var centerX = x + offSet; + var centerY = y + offSet; + + drawCallback = function() { + // Draw pointStyle as legend symbol + helpers.canvas.drawPoint(ctx, legendItem.pointStyle, radius, centerX, centerY); + }; + } else { + drawCallback = function() { + // Draw box as legend symbol + ctx.beginPath(); + ctx.rect(x, y, boxWidth, fontSize); + ctx.fill(); + if (!isLineWidthZero) { + ctx.stroke(); + } + }; + } + + styleHelpers.drawShadow(me.chart, legendItem.shadowOffsetX, legendItem.shadowOffsetY, + legendItem.shadowBlur, legendItem.shadowColor, drawCallback, true); + + if (helpers.color(ctx.fillStyle).alpha() > 0) { + var borderAlpha = helpers.color(ctx.strokeStyle).alpha(); + var bevelExtra = borderAlpha > 0 && ctx.lineWidth > 0 ? ctx.lineWidth / 2 : 0; + + ctx.save(); + + ctx.strokeStyle = 'rgba(0, 0, 0, 0)'; + drawCallback(); + + styleHelpers.drawBevel(me.chart, legendItem.bevelWidth + bevelExtra, + legendItem.bevelHighlightColor, legendItem.bevelShadowColor, drawCallback); + + ctx.restore(); + } + + styleHelpers.drawInnerGlow(me.chart, legendItem.innerGlowWidth, legendItem.innerGlowColor, + ctx.lineWidth, drawCallback); + styleHelpers.drawOuterGlow(me.chart, legendItem.outerGlowWidth, legendItem.outerGlowColor, + ctx.lineWidth, drawCallback); + + if (!isLineWidthZero) { + ctx.fillStyle = 'rgba(0, 0, 0, 0)'; + drawCallback(); + } + + ctx.restore(); + }; + var fillText = function(x, y, legendItem, textWidth) { + var halfFontSize = fontSize / 2; + var xLeft = boxWidth + halfFontSize + x; + var yMiddle = y + halfFontSize; + + ctx.fillText(legendItem.text, xLeft, yMiddle); + + if (legendItem.hidden) { + // Strikethrough the text if hidden + ctx.beginPath(); + ctx.lineWidth = 2; + ctx.moveTo(xLeft, yMiddle); + ctx.lineTo(xLeft + textWidth, yMiddle); + ctx.stroke(); + } + }; + + // Horizontal + var isHorizontal = me.isHorizontal(); + if (isHorizontal) { + cursor = { + x: me.left + ((legendWidth - lineWidths[0]) / 2), + y: me.top + labelOpts.padding, + line: 0 + }; + } else { + cursor = { + x: me.left + labelOpts.padding, + y: me.top + labelOpts.padding, + line: 0 + }; + } + + var itemHeight = fontSize + labelOpts.padding; + helpers.each(me.legendItems, function(legendItem, i) { + var textWidth = ctx.measureText(legendItem.text).width; + var width = boxWidth + (fontSize / 2) + textWidth; + var x = cursor.x; + var y = cursor.y; + + if (isHorizontal) { + if (x + width >= legendWidth) { + y = cursor.y += itemHeight; + cursor.line++; + x = cursor.x = me.left + ((legendWidth - lineWidths[cursor.line]) / 2); + } + } else if (y + itemHeight > me.bottom) { + x = cursor.x = x + me.columnWidths[cursor.line] + labelOpts.padding; + y = cursor.y = me.top + labelOpts.padding; + cursor.line++; + } + + drawLegendBox(x, y, legendItem); + + hitboxes[i].left = x; + hitboxes[i].top = y; + + // Fill the actual label + fillText(x, y, legendItem, textWidth); + + if (isHorizontal) { + cursor.x += width + (labelOpts.padding); + } else { + cursor.y += itemHeight; + } + + }); + } + }, + }); + + // Ported from Chart.js 2.7.2. Modified for style legend. + function createNewLegendAndAttach(chart, legendOpts) { + var legend = new StyleLegend({ + ctx: chart.ctx, + options: legendOpts, + chart: chart + }); + + layouts.configure(chart, legend, legendOpts); + layouts.addBox(chart, legend); + chart.legend = legend; + } + + return { + id: 'legend', + + _element: StyleLegend, + + // Ported from Chart.js 2.7.2. + beforeInit: function(chart) { + var legendOpts = chart.options.legend; + + if (legendOpts) { + createNewLegendAndAttach(chart, legendOpts); + } + }, + + // Ported from Chart.js 2.7.2. + beforeUpdate: function(chart) { + var legendOpts = chart.options.legend; + var legend = chart.legend; + + if (legendOpts) { + helpers.mergeIf(legendOpts, defaults.global.legend); + + if (legend) { + layouts.configure(chart, legend, legendOpts); + legend.options = legendOpts; + } else { + createNewLegendAndAttach(chart, legendOpts); + } + } else if (legend) { + layouts.removeBox(chart, legend); + delete chart.legend; + } + }, + + // Ported from Chart.js 2.7.2. + afterEvent: function(chart, e) { + var legend = chart.legend; + if (legend) { + legend.handleEvent(e); + } + } + }; +}; + +'use strict'; + +// For Chart.js 2.6.0 backward compatibility +Chart.helpers.valueOrDefault = Chart.helpers.valueOrDefault || Chart.helpers.getValueOrDefault; +Chart.helpers.valueAtIndexOrDefault = Chart.helpers.valueAtIndexOrDefault || Chart.helpers.getValueAtIndexOrDefault; +Chart.helpers.mergeIf = Chart.helpers.mergeIf || function(target, source) { + return Chart.helpers.configMerge.call(this, source, target); +}; +Chart.helpers.options = Chart.helpers.options || {}; +Chart.helpers.options.resolve = Chart.helpers.options.resolve || function(inputs, context, index) { + var i, ilen, value; + + for (i = 0, ilen = inputs.length; i < ilen; ++i) { + value = inputs[i]; + if (value === undefined) { + continue; + } + if (context !== undefined && typeof value === 'function') { + value = value(context); + } + if (index !== undefined && Chart.helpers.isArray(value)) { + value = value[index]; + } + if (value !== undefined) { + return value; + } + } +}; + +// For Chart.js 2.7.1 backward compatibility +Chart.layouts = Chart.layouts || Chart.layoutService; + +Chart.helpers.style = StyleHelper(Chart); + +Chart.elements.StyleArc = StyleArcElement(Chart); +Chart.elements.StyleLine = StyleLineElement(Chart); +Chart.elements.StylePoint = StylePointElement(Chart); +Chart.elements.StyleRectangle = StyleRectangleElement(Chart); + +Chart.StyleTooltip = StyleTooltip(Chart); +StyleController(Chart); + +Chart.controllers.bar = StyleBarController(Chart); +Chart.controllers.bubble = StyleBubbleController(Chart); +Chart.controllers.doughnut = StyleDoughnutController(Chart); +Chart.controllers.line = StyleLineController(Chart); +Chart.controllers.pie = Chart.controllers.doughnut; +Chart.controllers.polarArea = StylePolarAreaController(Chart); +Chart.controllers.radar = StyleRadarController(Chart); +Chart.controllers.scatter = Chart.controllers.line; + +Chart.plugins.getAll().forEach(function(plugin) { + if (plugin.id === 'legend') { + Chart.plugins.unregister(plugin); + } +}); +Chart.plugins.register(StyleLegendPlugin(Chart)); +Chart.Legend = StyleLegendPlugin._element; + +}))); diff --git a/dist/chartjs-plugin-style.min.js b/dist/chartjs-plugin-style.min.js new file mode 100644 index 0000000..afc3d47 --- /dev/null +++ b/dist/chartjs-plugin-style.min.js @@ -0,0 +1,11 @@ +/* + * @license + * chartjs-plugin-style + * /~https://github.com/nagix/chartjs-plugin-style/ + * Version: 0.3.1 + * + * Copyright 2018 Akihiko Kusanagi + * Released under the MIT license + * /~https://github.com/nagix/chartjs-plugin-style/blob/master/LICENSE.md + */ +!function(o,e){"object"==typeof exports&&"undefined"!=typeof module?e(require("chart.js")):"function"==typeof define&&define.amd?define(["chart.js"],e):e(o.Chart)}(this,function(h){"use strict";var a,n,s,d,i,w,u,v,f,C,b,e,o,l,G,g,r,t,p,W,O,S,c,y,B,H,m,x,I=function(o){var h=o.defaults,H=o.helpers,m=o.helpers.style,r=o.layouts;h.global.legend.labels.generateLabels=function(l){var o=l.data;return H.isArray(o.datasets)?o.datasets.map(function(o,e){return{text:o.label,fillStyle:H.isArray(o.backgroundColor)?o.backgroundColor[0]:o.backgroundColor,hidden:!l.isDatasetVisible(e),lineCap:o.borderCapStyle,lineDash:o.borderDash,lineDashOffset:o.borderDashOffset,lineJoin:o.borderJoinStyle,lineWidth:o.borderWidth,strokeStyle:o.borderColor,pointStyle:o.pointStyle,shadowOffsetX:H.isArray(o.shadowOffsetX)?o.shadowOffsetX[0]:o.shadowOffsetX,shadowOffsetY:H.isArray(o.shadowOffsetY)?o.shadowOffsetY[0]:o.shadowOffsetY,shadowBlur:H.isArray(o.shadowBlur)?o.shadowBlur[0]:o.shadowBlur,shadowColor:H.isArray(o.shadowColor)?o.shadowColor[0]:o.shadowColor,bevelWidth:H.valueOrDefault(H.isArray(o.pointBevelWidth)?o.pointBevelWidth[0]:o.pointBevelWidth,o.bevelWidth),bevelHighlightColor:H.valueOrDefault(H.isArray(o.pointBevelHighlightColor)?o.pointBevelHighlightColor[0]:o.pointBevelHighlightColor,o.bevelHighlightColor),bevelShadowColor:H.valueOrDefault(H.isArray(o.pointBevelShadowColor)?o.pointBevelShadowColor[0]:o.pointBevelShadowColor,o.bevelShadowColor),innerGlowWidth:H.valueOrDefault(H.isArray(o.pointInnerGlowWidth)?o.pointInnerGlowWidth[0]:o.pointInnerGlowWidth,o.innerGlowWidth),innerGlowColor:H.valueOrDefault(H.isArray(o.pointInnerGlowColor)?o.pointInnerGlowColor[0]:o.pointInnerGlowColor,o.innerGlowColor),outerGlowWidth:H.valueOrDefault(H.isArray(o.pointOuterGlowWidth)?o.pointOuterGlowWidth[0]:o.pointOuterGlowWidth,o.outerGlowWidth),outerGlowColor:H.valueOrDefault(H.isArray(o.pointOuterGlowColor)?o.pointOuterGlowColor[0]:o.pointOuterGlowColor,o.outerGlowColor),datasetIndex:e}},this):[]};var t=o.Legend.extend({draw:function(){var o,e,w=this,u=w.options,v=u.labels,f=h.global,C=f.elements.line,b=w.width,G=w.lineWidths;if(u.display){var g,p=w.ctx,W=H.valueOrDefault,l=W(v.fontColor,f.defaultFontColor),O=W(v.fontSize,f.defaultFontSize),r=W(v.fontStyle,f.defaultFontStyle),t=W(v.fontFamily,f.defaultFontFamily),d=H.fontString(O,r,t);p.textAlign="left",p.textBaseline="middle",p.lineWidth=.5,p.strokeStyle=l,p.fillStyle=l,p.font=d;var S=(e=O,(o=v).usePointStyle?e*Math.SQRT2:o.boxWidth),c=w.legendHitBoxes,y=w.isHorizontal();g=y?{x:w.left+(b-G[0])/2,y:w.top+v.padding,line:0}:{x:w.left+v.padding,y:w.top+v.padding,line:0};var B=O+v.padding;H.each(w.legendItems,function(o,e){var l,r,t,d,h,i=p.measureText(o.text).width,a=S+O/2+i,n=g.x,s=g.y;y?b<=n+a&&(s=g.y+=B,g.line++,n=g.x=w.left+(b-G[g.line])/2):s+B>w.bottom&&(n=g.x=n+w.columnWidths[g.line]+v.padding,s=g.y=w.top+v.padding,g.line++),function(o,e,l){var r;if(!(isNaN(S)||S<=0)){p.save(),p.fillStyle=W(l.fillStyle,f.defaultColor),p.lineCap=W(l.lineCap,C.borderCapStyle),p.lineDashOffset=W(l.lineDashOffset,C.borderDashOffset),p.lineJoin=W(l.lineJoin,C.borderJoinStyle),p.lineWidth=W(l.lineWidth,C.borderWidth),p.strokeStyle=W(l.strokeStyle,f.defaultColor);var t=0===W(l.lineWidth,C.borderWidth);if(p.setLineDash&&p.setLineDash(W(l.lineDash,C.borderDash)),u.labels&&u.labels.usePointStyle){var d=O*Math.SQRT2/2,h=d/Math.SQRT2,i=o+h,a=e+h;r=function(){H.canvas.drawPoint(p,l.pointStyle,d,i,a)}}else r=function(){p.beginPath(),p.rect(o,e,S,O),p.fill(),t||p.stroke()};if(m.drawShadow(w.chart,l.shadowOffsetX,l.shadowOffsetY,l.shadowBlur,l.shadowColor,r,!0),0