STRATO-apps/wordpress_03/app/wp-content/plugins/fluent-smtp/assets/libs/chartjs/Chart.BarFunnel.js

SHA-256: 74a65d7f99307b8a181e6d3fb19c711d2d45d28fb7134c13b8ca124f23933088
/*!
 * Chart.BarFunnel.js
 * http://chartjs.org/
 * Version: 0.1.0
 *
 * Copyright 2016 Jorge Conde
 * Released under the MIT license
 * https://github.com/chartjs/Chart.Zoom.js/blob/master/LICENSE.md
 */
(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
(function(Chart) {
	var helpers = Chart.helpers;

	Chart.defaults.barFunnel = {
		hover: {
			mode: "label"
		},

		region: {
			display: true,
			borderColor: "#F6C85F",
			backgroundColor: "rgba(246, 200, 95, 0.2)"
		},

		elements: {
			rectangle: {
				stepLabel: {
					display: true,
					fontSize: 20
					// color: "red"
				}
			}
		},

		scales: {
			xAxes: [{
				type: "category",

				// Specific to Bar Controller
				categoryPercentage: 0.8,
				barPercentage: 0.7,

				// grid line settings
				gridLines: {
					offsetGridLines: true
				}
			}],
			yAxes: [{
				type: "linear"
			}]
		}
	};

	Chart.controllers.barFunnel = Chart.controllers.bar.extend({
		updateElement: function updateElement(rectangle, index, reset, numBars) {
			var meta = this.getMeta();
			var xScale = this.getScaleForId(meta.xAxisID);
			var yScale = this.getScaleForId(meta.yAxisID);

			var yScalePoint;

			if (yScale.min < 0 && yScale.max < 0) {
				// all less than 0. use the top
				yScalePoint = yScale.getPixelForValue(yScale.max);
			} else if (yScale.min > 0 && yScale.max > 0) {
				yScalePoint = yScale.getPixelForValue(yScale.min);
			} else {
				yScalePoint = yScale.getPixelForValue(0);
			}

			var chartOptions = this.chart.options;
			var rectangleElementOptions = this.chart.options.elements.rectangle;
			var custom = rectangle.custom || {};
			var dataset = this.getDataset();
      var ruler = this.getRuler(this.index);

			helpers.extend(rectangle, {
				// Utility
				_chart: this.chart.chart,
				_xScale: xScale,
				_yScale: yScale,
				_datasetIndex: this.index,
				_index: index,


				// Desired view properties
				_model: {
					x: this.calculateBarX(index, this.index, ruler),
					y: reset ? yScalePoint : this.calculateBarY(index, this.index),

					// Tooltip
					label: this.chart.data.labels[index],
					datasetLabel: dataset.label,

					// Appearance
					base: reset ? yScalePoint : this.calculateBarBase(this.index, index),
					width: this.calculateBarWidth(ruler),
					backgroundColor: custom.backgroundColor ? custom.backgroundColor : helpers.getValueAtIndexOrDefault(dataset.backgroundColor, index, rectangleElementOptions.backgroundColor),
					borderSkipped: custom.borderSkipped ? custom.borderSkipped : rectangleElementOptions.borderSkipped,
					borderColor: custom.borderColor ? custom.borderColor : helpers.getValueAtIndexOrDefault(dataset.borderColor, index, rectangleElementOptions.borderColor),
					borderWidth: custom.borderWidth ? custom.borderWidth : helpers.getValueAtIndexOrDefault(dataset.borderWidth, index, rectangleElementOptions.borderWidth),
					stepLabelColor: rectangleElementOptions.stepLabel.color ? rectangleElementOptions.stepLabel.color : helpers.getValueAtIndexOrDefault(dataset.borderColor, index, rectangleElementOptions.borderColor),
					stepLabelFontSize: rectangleElementOptions.stepLabel.fontSize ? rectangleElementOptions.stepLabel.fontSize : chartOptions.defaultFontSize
				},

				draw: function () {

					var ctx = this._chart.ctx;
					var vm = this._view;
					var options = this._chart.config.options;

					var halfWidth = vm.width / 2,
						leftX = vm.x - halfWidth,
						rightX = vm.x + halfWidth,
						top = vm.base - (vm.base - vm.y),
						halfStroke = vm.borderWidth / 2;

					// Canvas doesn't allow us to stroke inside the width so we can
					// adjust the sizes to fit if we're setting a stroke on the line
					if (vm.borderWidth) {
						leftX += halfStroke;
						rightX -= halfStroke;
						top += halfStroke;
					}

					ctx.beginPath();
					ctx.fillStyle = vm.backgroundColor;
					ctx.strokeStyle = vm.borderColor;
					ctx.lineWidth = vm.borderWidth;

					// Corner points, from bottom-left to bottom-right clockwise
					// | 1 2 |
					// | 0 3 |
					var corners = [
						[leftX, vm.base],
						[leftX, top],
						[rightX, top],
						[rightX, vm.base]
					];

					// Find first (starting) corner with fallback to 'bottom'
					var borders = ['bottom', 'left', 'top', 'right'];
					var startCorner = borders.indexOf(vm.borderSkipped, 0);
					if (startCorner === -1)
						startCorner = 0;

					function cornerAt(index) {
						return corners[(startCorner + index) % 4];
					}

					// Draw rectangle from 'startCorner'
					ctx.moveTo.apply(ctx, cornerAt(0));
					for (var i = 1; i < 4; i++)
						ctx.lineTo.apply(ctx, cornerAt(i));

					ctx.fill();
					if (vm.borderWidth) {
						ctx.stroke();
					}

					if(rectangleElementOptions.stepLabel.display && (index != 0)) {
						var label = (dataset.data[index] / dataset.data[0]) * 100;

						if (dataset.data[index] > 0) {
							// Draw Step Label
							ctx.font = vm.stepLabelFontSize + "px " + options.defaultFontFamily;
							ctx.fillStyle = vm.stepLabelColor;
							ctx.textAlign = "center";
							ctx.fillText(label.toFixed(0) + "%", vm.x, vm.y - vm.stepLabelFontSize);
						}
					}

					if (chartOptions.region.display && (index < meta.data.length - 1)) {
						var nextVm = meta.data[index + 1]._view;

						var regionCorners = [
							[vm.x + halfWidth, top],
							[nextVm.x - halfWidth, nextVm.base - (nextVm.base - nextVm.y - 1)],
							[nextVm.x - halfWidth, nextVm.base],
							[vm.x + halfWidth, vm.base]
						];

						ctx.beginPath();
						ctx.strokeStyle = chartOptions.region.borderColor;
						ctx.moveTo.apply(ctx, regionCorners[0]);
						ctx.lineTo.apply(ctx, regionCorners[1]);
						ctx.stroke();

						ctx.beginPath();
						ctx.strokeStyle = "transparent";
						ctx.fillStyle = chartOptions.region.backgroundColor;
						ctx.moveTo.apply(ctx, regionCorners[1]);
						ctx.lineTo.apply(ctx, regionCorners[2]);
						ctx.lineTo.apply(ctx, regionCorners[3]);
						ctx.lineTo.apply(ctx, regionCorners[0]);
						ctx.fill();
						ctx.stroke();
					}

				}
			});
			rectangle.pivot();
		}
	});
}).call(this, Chart);

},{}]},{},[1]);