+ /*!
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ *
+ * billboard.js, JavaScript chart library
+ * http://naver.github.io/billboard.js/
+ *
+ * @version 1.6.0
+ */
+(function webpackUniversalModuleDefinition(root, factory) {
+ if(typeof exports === 'object' && typeof module === 'object')
+ module.exports = factory(require("d3-time-format"), require("d3-selection"), require("d3-array"), require("d3-transition"), require("d3-scale"), require("d3-brush"), require("d3-collection"), require("d3-dsv"), require("d3-drag"), require("d3-shape"), require("d3-interpolate"), require("d3-color"), require("d3-zoom"), require("d3-ease"));
+ else if(typeof define === 'function' && define.amd)
+ define(["d3-time-format", "d3-selection", "d3-array", "d3-transition", "d3-scale", "d3-brush", "d3-collection", "d3-dsv", "d3-drag", "d3-shape", "d3-interpolate", "d3-color", "d3-zoom", "d3-ease"], factory);
+ else {
+ var a = typeof exports === 'object' ? factory(require("d3-time-format"), require("d3-selection"), require("d3-array"), require("d3-transition"), require("d3-scale"), require("d3-brush"), require("d3-collection"), require("d3-dsv"), require("d3-drag"), require("d3-shape"), require("d3-interpolate"), require("d3-color"), require("d3-zoom"), require("d3-ease")) : factory(root["d3"], root["d3"], root["d3"], root["d3"], root["d3"], root["d3"], root["d3"], root["d3"], root["d3"], root["d3"], root["d3"], root["d3"], root["d3"], root["d3"]);
+ for(var i in a) (typeof exports === 'object' ? exports : root)[i] = a[i];
+ }
+})(window, function(__WEBPACK_EXTERNAL_MODULE__4__, __WEBPACK_EXTERNAL_MODULE__5__, __WEBPACK_EXTERNAL_MODULE__6__, __WEBPACK_EXTERNAL_MODULE__7__, __WEBPACK_EXTERNAL_MODULE__10__, __WEBPACK_EXTERNAL_MODULE__13__, __WEBPACK_EXTERNAL_MODULE__22__, __WEBPACK_EXTERNAL_MODULE__24__, __WEBPACK_EXTERNAL_MODULE__28__, __WEBPACK_EXTERNAL_MODULE__31__, __WEBPACK_EXTERNAL_MODULE__33__, __WEBPACK_EXTERNAL_MODULE__49__, __WEBPACK_EXTERNAL_MODULE__52__, __WEBPACK_EXTERNAL_MODULE__62__) {
+return /******/ (function(modules) { // webpackBootstrap
+/******/ // The module cache
+/******/ var installedModules = {};
+/******/
+/******/ // The require function
+/******/ function __webpack_require__(moduleId) {
+/******/
+/******/ // Check if module is in cache
+/******/ if(installedModules[moduleId]) {
+/******/ return installedModules[moduleId].exports;
+/******/ }
+/******/ // Create a new module (and put it into the cache)
+/******/ var module = installedModules[moduleId] = {
+/******/ i: moduleId,
+/******/ l: false,
+/******/ exports: {}
+/******/ };
+/******/
+/******/ // Execute the module function
+/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
+/******/
+/******/ // Flag the module as loaded
+/******/ module.l = true;
+/******/
+/******/ // Return the exports of the module
+/******/ return module.exports;
+/******/ }
+/******/
+/******/
+/******/ // expose the modules object (__webpack_modules__)
+/******/ __webpack_require__.m = modules;
+/******/
+/******/ // expose the module cache
+/******/ __webpack_require__.c = installedModules;
+/******/
+/******/ // define getter function for harmony exports
+/******/ __webpack_require__.d = function(exports, name, getter) {
+/******/ if(!__webpack_require__.o(exports, name)) {
+/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/ }
+/******/ };
+/******/
+/******/ // define __esModule on exports
+/******/ __webpack_require__.r = function(exports) {
+/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
+/******/ }
+/******/ Object.defineProperty(exports, '__esModule', { value: true });
+/******/ };
+/******/
+/******/ // create a fake namespace object
+/******/ // mode & 1: value is a module id, require it
+/******/ // mode & 2: merge all properties of value into the ns
+/******/ // mode & 4: return value when already ns object
+/******/ // mode & 8|1: behave like require
+/******/ __webpack_require__.t = function(value, mode) {
+/******/ if(mode & 1) value = __webpack_require__(value);
+/******/ if(mode & 8) return value;
+/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/ var ns = Object.create(null);
+/******/ __webpack_require__.r(ns);
+/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/ return ns;
+/******/ };
+/******/
+/******/ // getDefaultExport function for compatibility with non-harmony modules
+/******/ __webpack_require__.n = function(module) {
+/******/ var getter = module && module.__esModule ?
+/******/ function getDefault() { return module['default']; } :
+/******/ function getModuleExports() { return module; };
+/******/ __webpack_require__.d(getter, 'a', getter);
+/******/ return getter;
+/******/ };
+/******/
+/******/ // Object.prototype.hasOwnProperty.call
+/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
+/******/
+/******/ // __webpack_public_path__
+/******/ __webpack_require__.p = "";
+/******/
+/******/
+/******/ // Load entry module and return exports
+/******/ return __webpack_require__(__webpack_require__.s = 0);
+/******/ })
+/************************************************************************/
+/******/ ([
+/* 0 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+exports.__esModule = !0;
+exports.bb = undefined;
+
+var _Chart = __webpack_require__(1),
+ _Chart2 = _interopRequireDefault(_Chart),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _Axis = __webpack_require__(8),
+ _Axis2 = _interopRequireDefault(_Axis);
+
+__webpack_require__(15);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * @namespace bb
+ * @version 1.6.0
+ */
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+var bb = {
+ /**
+ * Version information
+ * @property {String} version version
+ * @example
+ * bb.version; // "1.0.0"
+ * @memberOf bb
+ */
+ version: "1.6.0",
+
+ /**
+ * Generate chart
+ * @param {Options} options chart options
+ * @memberOf bb
+ * @return {Chart}
+ * @see {@link Options} for different generation options
+ * @see {@link Chart} for different methods API
+ * @example
+ * <!-- chart holder -->
+ * <div id="LineChart"></div>
+ * @example
+ * // generate chart with options
+ * var chart = bb.generate({
+ * "bindto": "#LineChart"
+ * "data": {
+ * "columns": [
+ * ["data1", 30, 200, 100, 400, 150, 250],
+ * ["data2", 50, 20, 10, 40, 15, 25]
+ * ]
+ * }
+ * });
+ *
+ * // call some API
+ * // ex) get the data of 'data1'
+ * chart.data("data1");
+ */
+ generate: function generate(config) {
+ var inst = new _Chart2.default(config);
+
+ return inst.internal.charts = this.instance, this.instance.push(inst), inst;
+ },
+
+
+ /**
+ * An array containing instance created
+ * @property {Array} instance instance array
+ * @example
+ * // generate charts
+ * var chart1 = bb.generate(...);
+ * var chart2 = bb.generate(...);
+ *
+ * bb.instance; // [ chart1, chart2, ... ]
+ * @memberOf bb
+ */
+ instance: [],
+
+ /**
+ * Internal chart object
+ * @private
+ */
+ chart: {
+ fn: _Chart2.default.prototype,
+ internal: {
+ fn: _ChartInternal2.default.prototype,
+ axis: {
+ fn: _Axis2.default.prototype
+ }
+ }
+ }
+};
+
+__webpack_require__(17), __webpack_require__(19), __webpack_require__(20), __webpack_require__(21), __webpack_require__(23), __webpack_require__(25), __webpack_require__(26), __webpack_require__(27), __webpack_require__(29), __webpack_require__(30), __webpack_require__(32), __webpack_require__(34), __webpack_require__(35), __webpack_require__(36), __webpack_require__(37), __webpack_require__(38), __webpack_require__(39), __webpack_require__(40), __webpack_require__(41), __webpack_require__(42), __webpack_require__(43), __webpack_require__(44), __webpack_require__(45), __webpack_require__(46), __webpack_require__(47), __webpack_require__(48), __webpack_require__(50), __webpack_require__(51), __webpack_require__(53), __webpack_require__(54), __webpack_require__(55), __webpack_require__(56), __webpack_require__(57), __webpack_require__(58), __webpack_require__(59), __webpack_require__(60), __webpack_require__(61), __webpack_require__(63), __webpack_require__(64), __webpack_require__(65), __webpack_require__(66), __webpack_require__(67), __webpack_require__(68), __webpack_require__(69), __webpack_require__(70), __webpack_require__(71), __webpack_require__(72), __webpack_require__(73), __webpack_require__(74), __webpack_require__(76), __webpack_require__(9), __webpack_require__(77), __webpack_require__(78);
+exports.bb = bb;
+exports.default = bb;
+
+/***/ }),
+/* 1 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+exports.__esModule = !0;
+
+var _classCallCheck2 = __webpack_require__(2),
+ _classCallCheck3 = _interopRequireDefault(_classCallCheck2),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Main chart class.
+ * - Note: Instantiated via `bb.generate()`.
+ * @class Chart
+ * @example
+ * var chart = bb.generate({
+ * data: {
+ * columns: [
+ * ["x", "2015-11-02", "2015-12-01", "2016-01-01", "2016-02-01", "2016-03-01"],
+ * ["count1", 11, 8, 7, 6, 5 ],
+ * ["count2", 9, 3, 6, 2, 8 ]
+ * ]}
+ * }
+ * @see {@link bb.generate} for the initialization.
+*/
+var Chart = function Chart(config) {
+ (0, _classCallCheck3.default)(this, Chart);
+
+ var $$ = new _ChartInternal2.default(this);
+
+ this.internal = $$, $$.loadConfig(config), $$.beforeInit(config), $$.init(), this.$ = $$.getChartElements(), $$.afterInit(config), function bindThis(fn, target, argThis) {
+ Object.keys(fn).forEach(function (key) {
+ target[key] = fn[key].bind(argThis), Object.keys(fn[key]).length && bindThis(fn[key], target[key], argThis);
+ });
+ }(Chart.prototype, this, this);
+}; /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ * @license MIT
+ * @ignore
+ */
+
+
+exports.default = Chart;
+module.exports = exports["default"];
+
+/***/ }),
+/* 2 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+exports.__esModule = true;
+
+exports.default = function (instance, Constructor) {
+ if (!(instance instanceof Constructor)) {
+ throw new TypeError("Cannot call a class as a function");
+ }
+};
+
+/***/ }),
+/* 3 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+exports.__esModule = !0;
+
+var _classCallCheck2 = __webpack_require__(2),
+ _classCallCheck3 = _interopRequireDefault(_classCallCheck2),
+ _d3TimeFormat = __webpack_require__(4),
+ _d3Selection = __webpack_require__(5),
+ _d3Array = __webpack_require__(6),
+ _d3Transition = __webpack_require__(7),
+ _Axis = __webpack_require__(8),
+ _Axis2 = _interopRequireDefault(_Axis),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Internal chart class.
+ * - Note: Instantiated internally, not exposed for public.
+ * @class ChartInternal
+ * @ignore
+ * @private
+*/
+var ChartInternal = function () {
+ function ChartInternal(api) {
+ (0, _classCallCheck3.default)(this, ChartInternal);
+
+ var $$ = this;
+
+ $$.api = api, $$.config = $$.getOptions(), $$.data = {}, $$.cache = {}, $$.axes = {};
+ }
+
+ return ChartInternal.prototype.beforeInit = function beforeInit() {
+ var $$ = this,
+ config = $$.config;
+ (0, _util.callFn)(config.onbeforeinit, $$);
+ }, ChartInternal.prototype.afterInit = function afterInit() {
+ var $$ = this,
+ config = $$.config;
+ (0, _util.callFn)(config.onafterinit, $$);
+ }, ChartInternal.prototype.init = function init() {
+ var $$ = this,
+ config = $$.config,
+ convertedData = void 0;
+
+
+ if ($$.initParams(), config.data_url) $$.convertUrlToData(config.data_url, config.data_mimeType, config.data_headers, config.data_keys, $$.initWithData);else if (config.data_json) convertedData = $$.convertJsonToData(config.data_json, config.data_keys);else if (config.data_rows) convertedData = $$.convertRowsToData(config.data_rows);else if (config.data_columns) convertedData = $$.convertColumnsToData(config.data_columns);else throw Error("url or json or rows or columns is required.");
+
+ convertedData && $$.initWithData(convertedData);
+ }, ChartInternal.prototype.initParams = function initParams() {
+ var $$ = this,
+ config = $$.config,
+ isRotated = config.axis_rotated;
+ $$.datetimeId = "bb-" + +new Date(), $$.clipId = $$.datetimeId + "-clip", $$.clipIdForXAxis = $$.clipId + "-xaxis", $$.clipIdForYAxis = $$.clipId + "-yaxis", $$.clipIdForGrid = $$.clipId + "-grid", $$.clipIdForSubchart = $$.clipId + "-subchart", $$.clipPath = $$.getClipPath($$.clipId), $$.clipPathForXAxis = $$.getClipPath($$.clipIdForXAxis), $$.clipPathForYAxis = $$.getClipPath($$.clipIdForYAxis), $$.clipPathForGrid = $$.getClipPath($$.clipIdForGrid), $$.clipPathForSubchart = $$.getClipPath($$.clipIdForSubchart), $$.dragStart = null, $$.dragging = !1, $$.flowing = !1, $$.cancelClick = !1, $$.mouseover = !1, $$.transiting = !1, $$.color = $$.generateColor(), $$.levelColor = $$.generateLevelColor(), $$.point = $$.generatePoint(), $$.extraLineClasses = $$.generateExtraLineClass(), $$.dataTimeFormat = config.data_xLocaltime ? _d3TimeFormat.timeParse : _d3TimeFormat.utcParse, $$.axisTimeFormat = config.axis_x_localtime ? _d3TimeFormat.timeFormat : _d3TimeFormat.utcFormat, $$.defaultAxisTimeFormat = function (d) {
+ var specifier = d.getMilliseconds() && ".%L" || d.getSeconds() && ".:%S" || d.getMinutes() && "%I:%M" || d.getHours() && "%I %p" || d.getDay() && d.getDate() !== 1 && "%-m/%-d" || d.getDate() !== 1 && "%b %d" || d.getMonth() && "%-m/%-d" || "%Y/%-m/%-d";
+
+ return $$.axisTimeFormat(specifier)(d);
+ }, $$.hiddenTargetIds = [], $$.hiddenLegendIds = [], $$.focusedTargetIds = [], $$.defocusedTargetIds = [], $$.xOrient = isRotated ? "left" : "bottom", $$.yOrient = isRotated ? config.axis_y_inner ? "top" : "bottom" : config.axis_y_inner ? "right" : "left", $$.y2Orient = isRotated ? config.axis_y2_inner ? "bottom" : "top" : config.axis_y2_inner ? "left" : "right", $$.subXOrient = isRotated ? "left" : "bottom", $$.isLegendRight = config.legend_position === "right", $$.isLegendInset = config.legend_position === "inset", $$.isLegendTop = config.legend_inset_anchor === "top-left" || config.legend_inset_anchor === "top-right", $$.isLegendLeft = config.legend_inset_anchor === "top-left" || config.legend_inset_anchor === "bottom-left", $$.legendStep = 0, $$.legendItemWidth = 0, $$.legendItemHeight = 0, $$.currentMaxTickWidths = {
+ x: 0, y: 0, y2: 0
+ }, $$.rotated_padding_left = 30, $$.rotated_padding_right = isRotated && !config.axis_x_show ? 0 : 30, $$.rotated_padding_top = 5, $$.withoutFadeIn = {}, $$.inputType = $$.convertInputType(), $$.axes.subx = (0, _d3Selection.selectAll)([]);
+ }, ChartInternal.prototype.initWithData = function initWithData(data) {
+ var $$ = this,
+ config = $$.config;
+ $$.axis = new _Axis2.default($$), config.subchart_show && $$.initBrush(), config.zoom_enabled && ($$.initZoom(), $$.initZoomBehaviour());
+
+
+ var bindto = {
+ element: config.bindto,
+ classname: "bb"
+ };
+
+ if ((0, _util.isObject)(config.bindto) && (bindto.element = config.bindto.element || "#chart", bindto.classname = config.bindto.classname || bindto.classname), $$.selectChart = (0, _util.isFunction)(bindto.element.node) ? config.bindto.element : (0, _d3Selection.select)(bindto.element ? bindto.element : []), $$.selectChart.html("").classed(bindto.classname, !0), $$.data.xs = {}, $$.data.targets = $$.convertDataToTargets(data), config.data_filter && ($$.data.targets = $$.data.targets.filter(config.data_filter)), config.data_hide && $$.addHiddenTargetIds(config.data_hide === !0 ? $$.mapToIds($$.data.targets) : config.data_hide), config.legend_hide && $$.addHiddenLegendIds(config.legend_hide === !0 ? $$.mapToIds($$.data.targets) : config.legend_hide), $$.hasType("gauge") && (config.legend_show = !1), $$.updateSizes(), $$.updateScales(), $$.x.domain((0, _d3Array.extent)($$.getXDomain($$.data.targets))), $$.y.domain($$.getYDomain($$.data.targets, "y")), $$.y2.domain($$.getYDomain($$.data.targets, "y2")), $$.subX.domain($$.x.domain()), $$.subY.domain($$.y.domain()), $$.subY2.domain($$.y2.domain()), $$.orgXDomain = $$.x.domain(), $$.svg = $$.selectChart.append("svg").style("overflow", "hidden").style("display", "block"), config.interaction_enabled && $$.inputType) {
+ var isTouch = $$.inputType === "touch";
+
+ $$.svg.on(isTouch ? "touchstart" : "mouseenter", function () {
+ return (0, _util.callFn)(config.onover, $$);
+ }).on(isTouch ? "touchend" : "mouseleave", function () {
+ return (0, _util.callFn)(config.onout, $$);
+ });
+ }
+
+ config.svg_classname && $$.svg.attr("class", config.svg_classname), $$.defs = $$.svg.append("defs"), $$.clipChart = $$.appendClip($$.defs, $$.clipId), $$.clipXAxis = $$.appendClip($$.defs, $$.clipIdForXAxis), $$.clipYAxis = $$.appendClip($$.defs, $$.clipIdForYAxis), $$.clipGrid = $$.appendClip($$.defs, $$.clipIdForGrid), $$.clipSubchart = $$.appendClip($$.defs, $$.clipIdForSubchart), (0, _util.isFunction)(config.color_tiles) && $$.patterns && $$.patterns.forEach(function (p) {
+ return $$.defs.append(function () {
+ return p.node;
+ });
+ }), $$.updateSvgSize();
+
+
+ // Define regions
+ var main = $$.svg.append("g").attr("transform", $$.getTranslate("main"));
+
+ // data.onmin/max callback
+ if ($$.main = main, config.subchart_show && $$.initSubchart && $$.initSubchart(), $$.initTooltip && $$.initTooltip(), $$.initLegend && $$.initLegend(), $$.initTitle && $$.initTitle(), main.append("text").attr("class", _classes2.default.text + " " + _classes2.default.empty).attr("text-anchor", "middle") // horizontal centering of text at x position in all browsers.
+ .attr("dominant-baseline", "middle"), $$.initRegion(), $$.initGrid(), config.clipPath || $$.axis.init(), main.append("g").attr("class", _classes2.default.chart).attr("clip-path", $$.clipPath), config.grid_lines_front && $$.initGridLines(), config.grid_front && $$.initXYFocusGrid(), $$.initEventRect(), $$.initChartElements(), main.insert("rect", config.zoom_privileged ? null : "g." + _classes2.default.regions).attr("class", _classes2.default.zoomRect).attr("width", $$.width).attr("height", $$.height).style("opacity", "0").on("dblclick.zoom", null), config.axis_x_extent && $$.brush.scale($$.getDefaultExtent()), config.clipPath && $$.axis.init(), $$.updateTargets($$.data.targets), $$.updateDimension(), config.oninit.call($$), $$.redraw({
+ withTransition: !1,
+ withTransform: !0,
+ withUpdateXDomain: !0,
+ withUpdateOrgXDomain: !0,
+ withTransitionForAxis: !1,
+ initializing: !0
+ }), config.data_onmin || config.data_onmax) {
+ var minMax = $$.getMinMaxData();
+
+ (0, _util.callFn)(config.data_onmin, $$, minMax.min), (0, _util.callFn)(config.data_onmax, $$, minMax.max);
+ }
+
+ // Bind resize event
+ $$.bindResize(), $$.api.element = $$.selectChart.node();
+ }, ChartInternal.prototype.initChartElements = function initChartElements() {
+ var _this = this;
+
+ ["Pie", "Bar", "Line", "Arc", "Gauge", "Bubble", "Radar", "Text"].forEach(function (v) {
+ var method = "init" + v;
+
+ _this[method] && _this[method]();
+ });
+ }, ChartInternal.prototype.getChartElements = function getChartElements() {
+ var $$ = this;
+
+ return {
+ chart: $$.selectChart,
+ svg: $$.svg,
+ defs: $$.defs,
+ main: $$.main,
+ tooltip: $$.tooltip,
+ legend: $$.legend,
+ title: $$.title,
+ grid: $$.grid,
+ arc: $$.arcs,
+ bar: {
+ bars: $$.mainBar
+ },
+ line: {
+ lines: $$.mainLine,
+ areas: $$.mainArea,
+ circles: $$.mainCircle
+ },
+ text: {
+ texts: $$.texts
+ }
+ };
+ }, ChartInternal.prototype.smoothLines = function smoothLines(el, type) {
+ type === "grid" && el.each(function () {
+ var g = (0, _d3Selection.select)(this),
+ _map = ["x1", "x2", "y1", "y2"].map(function (v) {
+ return Math.ceil(g.attr(v));
+ }),
+ x1 = _map[0],
+ x2 = _map[1],
+ y1 = _map[2],
+ y2 = _map[3];g.attr({ x1: x1, x2: x2, y1: y1, y2: y2 });
+ });
+ }, ChartInternal.prototype.updateSizes = function updateSizes() {
+ var $$ = this,
+ config = $$.config,
+ isRotated = config.axis_rotated,
+ hasArc = $$.hasArcType(),
+ legendHeight = $$.legend ? $$.getLegendHeight() : 0,
+ legendWidth = $$.legend ? $$.getLegendWidth() : 0,
+ legendHeightForBottom = $$.isLegendRight || $$.isLegendInset ? 0 : legendHeight,
+ xAxisHeight = isRotated || hasArc ? 0 : $$.getHorizontalAxisHeight("x"),
+ subchartHeight = config.subchart_show && !hasArc ? config.subchart_size_height + xAxisHeight : 0;
+ $$.currentWidth = $$.getCurrentWidth(), $$.currentHeight = $$.getCurrentHeight(), $$.margin = isRotated ? {
+ top: $$.getHorizontalAxisHeight("y2") + $$.getCurrentPaddingTop(),
+ right: hasArc ? 0 : $$.getCurrentPaddingRight(),
+ bottom: $$.getHorizontalAxisHeight("y") + legendHeightForBottom + $$.getCurrentPaddingBottom(),
+ left: subchartHeight + (hasArc ? 0 : $$.getCurrentPaddingLeft())
+ } : {
+ top: 4 + $$.getCurrentPaddingTop(), // for top tick text
+ right: hasArc ? 0 : $$.getCurrentPaddingRight(),
+ bottom: xAxisHeight + subchartHeight + legendHeightForBottom + $$.getCurrentPaddingBottom(),
+ left: hasArc ? 0 : $$.getCurrentPaddingLeft()
+ }, $$.margin2 = isRotated ? {
+ top: $$.margin.top,
+ right: NaN,
+ bottom: 20 + legendHeightForBottom,
+ left: $$.rotated_padding_left
+ } : {
+ top: $$.currentHeight - subchartHeight - legendHeightForBottom,
+ right: NaN,
+ bottom: xAxisHeight + legendHeightForBottom,
+ left: $$.margin.left
+ }, $$.margin3 = {
+ top: 0,
+ right: NaN,
+ bottom: 0,
+ left: 0
+ }, $$.updateSizeForLegend && $$.updateSizeForLegend(legendHeight, legendWidth), $$.width = $$.currentWidth - $$.margin.left - $$.margin.right, $$.height = $$.currentHeight - $$.margin.top - $$.margin.bottom, $$.width < 0 && ($$.width = 0), $$.height < 0 && ($$.height = 0), $$.width2 = isRotated ? $$.margin.left - $$.rotated_padding_left - $$.rotated_padding_right : $$.width, $$.height2 = isRotated ? $$.height : $$.currentHeight - $$.margin2.top - $$.margin2.bottom, $$.width2 < 0 && ($$.width2 = 0), $$.height2 < 0 && ($$.height2 = 0), $$.arcWidth = $$.width - ($$.isLegendRight ? legendWidth + 10 : 0), $$.arcHeight = $$.height - ($$.isLegendRight ? 0 : 10), $$.hasType("gauge") && !config.gauge_fullCircle && ($$.arcHeight += $$.height - $$.getGaugeLabelHeight()), $$.updateRadius && $$.updateRadius(), $$.isLegendRight && hasArc && ($$.margin3.left = $$.arcWidth / 2 + $$.radiusExpanded * 1.1);
+ }, ChartInternal.prototype.updateTargets = function updateTargets(targets) {
+ var $$ = this;
+
+ // Text
+ $$.updateTargetsForText(targets), $$.updateTargetsForBar(targets), $$.updateTargetsForLine(targets), $$.hasArcType(targets) && ($$.hasType("radar") ? $$.updateTargetsForRadar(targets) : $$.updateTargetsForArc(targets)), $$.updateTargetsForSubchart && $$.updateTargetsForSubchart(targets), $$.showTargets();
+ }, ChartInternal.prototype.showTargets = function showTargets() {
+ var $$ = this;
+
+ $$.svg.selectAll("." + _classes2.default.target).filter(function (d) {
+ return $$.isTargetToShow(d.id);
+ }).transition().duration($$.config.transition_duration).style("opacity", "1");
+ }, ChartInternal.prototype.getWithOption = function getWithOption(options) {
+ var withOptions = {
+ Y: !0,
+ Subchart: !0,
+ Transition: !0,
+ EventRect: !0,
+ Dimension: !0,
+ TrimXDomain: !0,
+ Transform: !1,
+ UpdateXDomain: !1,
+ UpdateOrgXDomain: !1,
+ Legend: !1,
+ UpdateXAxis: "UpdateXDomain",
+ TransitionForExit: "Transition",
+ TransitionForAxis: "Transition"
+ };
+
+ return Object.keys(withOptions).forEach(function (key) {
+ var defVal = withOptions[key];
+
+ (0, _util.isString)(defVal) && (defVal = withOptions[defVal]), withOptions[key] = (0, _util.getOption)(options, "with" + key, defVal);
+ }), withOptions;
+ }, ChartInternal.prototype.redraw = function redraw() {
+ var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
+ transitionsValue = arguments[1],
+ $$ = this,
+ main = $$.main,
+ config = $$.config,
+ isRotated = config.axis_rotated,
+ hasRadar = $$.hasType("radar"),
+ areaIndices = $$.getShapeIndices($$.isAreaType),
+ barIndices = $$.getShapeIndices($$.isBarType),
+ lineIndices = $$.getShapeIndices($$.isLineType),
+ hideAxis = $$.hasArcType(),
+ targetsToShow = $$.filterTargetsToShow($$.data.targets),
+ xv = $$.xv.bind($$),
+ tickValues = void 0,
+ intervalForCulling = void 0,
+ xDomainForZoom = void 0,
+ wth = $$.getWithOption(options),
+ duration = wth.Transition ? config.transition_duration : 0,
+ durationForExit = wth.TransitionForExit ? duration : 0,
+ durationForAxis = wth.TransitionForAxis ? duration : 0,
+ transitions = transitionsValue || $$.axis.generateTransitions(durationForAxis);
+
+
+ // show/hide if manual culling needed
+ if (options.initializing && config.tooltip_init_show || $$.inputType !== "touch" || $$.hideTooltip(), wth.Legend && config.legend_show && !config.legend_contents_bindto ? $$.updateLegend($$.mapToIds($$.data.targets), options, transitions) : wth.Dimension && $$.updateDimension(!0), $$.isCategorized() && targetsToShow.length === 0 && $$.x.domain([0, $$.axes.x.selectAll(".tick").size()]), targetsToShow.length ? ($$.updateXDomain(targetsToShow, wth.UpdateXDomain, wth.UpdateOrgXDomain, wth.TrimXDomain), !config.axis_x_tick_values && (tickValues = $$.axis.updateXAxisTickValues(targetsToShow))) : ($$.xAxis.tickValues([]), $$.subXAxis.tickValues([])), config.zoom_rescale && !options.flow && (xDomainForZoom = $$.x.orgDomain()), ["y", "y2"].forEach(function (key) {
+ var axis = $$[key],
+ tickValues = config["axis_" + key + "_tick_values"],
+ tickCount = config["axis_" + key + "_tick_count"];
+
+
+ if (axis.domain($$.getYDomain(targetsToShow, key, xDomainForZoom)), !tickValues && tickCount) {
+ var domain = axis.domain();
+
+ $$[key + "Axis"].tickValues($$.axis.generateTickValues(domain, domain.every(function (v) {
+ return v === 0;
+ }) ? 1 : tickCount, $$.isTimeSeriesY()));
+ }
+ }), $$.axis.redraw(transitions, hideAxis), $$.axis.updateLabels(wth.Transition), (wth.UpdateXDomain || wth.UpdateXAxis) && targetsToShow.length) if (config.axis_x_tick_culling && tickValues) {
+ for (var _i = 1; _i < tickValues.length; _i++) if (tickValues.length / _i < config.axis_x_tick_culling_max) {
+ intervalForCulling = _i;
+
+ break;
+ }
+
+ $$.svg.selectAll("." + _classes2.default.axisX + " .tick text").each(function (e) {
+ var index = tickValues.indexOf(e);
+
+ index >= 0 && (0, _d3Selection.select)(this).style("display", index % intervalForCulling ? "none" : "block");
+ });
+ } else $$.svg.selectAll("." + _classes2.default.axisX + " .tick text").style("display", "block");
+
+ // setup drawer - MEMO: these must be called after axis updated
+ var drawArea = $$.generateDrawArea ? $$.generateDrawArea(areaIndices, !1) : undefined,
+ drawBar = $$.generateDrawBar ? $$.generateDrawBar(barIndices) : undefined,
+ drawLine = $$.generateDrawLine ? $$.generateDrawLine(lineIndices, !1) : undefined,
+ xForText = $$.generateXYForText(areaIndices, barIndices, lineIndices, !0),
+ yForText = $$.generateXYForText(areaIndices, barIndices, lineIndices, !1);
+ wth.Y && ($$.subY.domain($$.getYDomain(targetsToShow, "y")), $$.subY2.domain($$.getYDomain(targetsToShow, "y2"))), $$.updateXgridFocus(), main.select("text." + _classes2.default.text + "." + _classes2.default.empty).attr("x", $$.width / 2).attr("y", $$.height / 2).text(config.data_empty_label_text).transition().style("opacity", targetsToShow.length ? 0 : 1), $$.updateGrid(duration), $$.updateRegion(duration), $$.updateBar(durationForExit), $$.updateLine(durationForExit), $$.updateArea(durationForExit), $$.updateCircle(), $$.hasDataLabel() && $$.updateText(durationForExit), $$.redrawTitle && $$.redrawTitle(), $$.redrawArc && $$.redrawArc(duration, durationForExit, wth.Transform), hasRadar && $$.redrawRadar(duration, durationForExit), config.subchart_show && $$.redrawSubchart && $$.redrawSubchart(wth.Subchart, transitions, duration, durationForExit, areaIndices, barIndices, lineIndices), main.selectAll("." + _classes2.default.selectedCircles).filter($$.isBarType.bind($$)).selectAll("circle").remove(), config.interaction_enabled && !options.flow && wth.EventRect && ($$.redrawEventRect(), $$.bindZoomEvent()), $$.updateCircleY();
+
+
+ // generate circle x/y functions depending on updated params
+ var cx = (hasRadar ? $$.radarCircleX : isRotated ? $$.circleY : $$.circleX).bind($$),
+ cy = (hasRadar ? $$.radarCircleY : isRotated ? $$.circleX : $$.circleY).bind($$),
+ flow = options.flow && $$.generateFlow({
+ targets: targetsToShow,
+ flow: options.flow,
+ duration: options.flow.duration,
+ drawBar: drawBar,
+ drawLine: drawLine,
+ drawArea: drawArea,
+ cx: cx,
+ cy: cy,
+ xv: xv,
+ xForText: xForText,
+ yForText: yForText
+ }),
+ isTransition = (duration || flow) && $$.isTabVisible(),
+ redrawList = [$$.redrawBar(drawBar, isTransition), $$.redrawLine(drawLine, isTransition), $$.redrawArea(drawArea, isTransition), $$.redrawCircle(cx, cy, isTransition, flow), $$.redrawText(xForText, yForText, options.flow, isTransition), $$.redrawRegion(isTransition), $$.redrawGrid(isTransition)],
+ afterRedraw = flow || config.onrendered ? function () {
+ flow && flow(), (0, _util.callFn)(config.onrendered, $$);
+ } : null;
+
+ // generate flow
+
+
+ // redraw list
+
+
+ // callback function after redraw ends
+
+ if (afterRedraw)
+ // Only use transition when current tab is visible.
+ if (isTransition) {
+ // Wait for end of transitions for callback
+ var waitForDraw = $$.generateWait();
+
+ // transition should be derived from one transition
+ (0, _d3Transition.transition)().duration(duration).each(function () {
+ redrawList.reduce(function (acc, t1) {
+ return acc.concat(t1);
+ }, []).forEach(function (t) {
+ return waitForDraw.add(t);
+ });
+ }).call(waitForDraw, afterRedraw);
+ } else afterRedraw();
+
+ // update fadein condition
+ $$.mapToIds($$.data.targets).forEach(function (id) {
+ $$.withoutFadeIn[id] = !0;
+ });
+ }, ChartInternal.prototype.updateAndRedraw = function updateAndRedraw() {
+ var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
+ $$ = this,
+ config = $$.config,
+ transitions = void 0;
+ options.withTransition = (0, _util.getOption)(options, "withTransition", !0), options.withTransform = (0, _util.getOption)(options, "withTransform", !1), options.withLegend = (0, _util.getOption)(options, "withLegend", !1), options.withUpdateXDomain = !0, options.withUpdateOrgXDomain = !0, options.withTransitionForExit = !1, options.withTransitionForTransform = (0, _util.getOption)(options, "withTransitionForTransform", options.withTransition), $$.updateSizes(), options.withLegend && config.legend_show || (transitions = $$.axis.generateTransitions(options.withTransitionForAxis ? config.transition_duration : 0), $$.updateScales(), $$.updateSvgSize(), $$.transformAll(options.withTransitionForTransform, transitions)), $$.redraw(options, transitions);
+ }, ChartInternal.prototype.redrawWithoutRescale = function redrawWithoutRescale() {
+ this.redraw({
+ withY: !1,
+ withSubchart: !1,
+ withEventRect: !1,
+ withTransitionForAxis: !1
+ });
+ }, ChartInternal.prototype.isTimeSeries = function isTimeSeries() {
+ return this.config.axis_x_type === "timeseries";
+ }, ChartInternal.prototype.isCategorized = function isCategorized() {
+ return this.config.axis_x_type.indexOf("category") >= 0 || this.hasType("radar");
+ }, ChartInternal.prototype.isCustomX = function isCustomX() {
+ var $$ = this,
+ config = $$.config;
+
+
+ return !$$.isTimeSeries() && (config.data_x || (0, _util.notEmpty)(config.data_xs));
+ }, ChartInternal.prototype.isTimeSeriesY = function isTimeSeriesY() {
+ return this.config.axis_y_type === "timeseries";
+ }, ChartInternal.prototype.getTranslate = function getTranslate(target) {
+ var $$ = this,
+ config = $$.config,
+ isRotated = config.axis_rotated,
+ x = void 0,
+ y = void 0;
+
+
+ if (target === "main") x = (0, _util.asHalfPixel)($$.margin.left), y = (0, _util.asHalfPixel)($$.margin.top);else if (target === "context") x = (0, _util.asHalfPixel)($$.margin2.left), y = (0, _util.asHalfPixel)($$.margin2.top);else if (target === "legend") x = $$.margin3.left, y = $$.margin3.top;else if (target === "x") x = 0, y = isRotated ? 0 : $$.height;else if (target === "y") x = 0, y = isRotated ? $$.height : 0;else if (target === "y2") x = isRotated ? 0 : $$.width, y = isRotated ? 1 : 0;else if (target === "subx") x = 0, y = isRotated ? 0 : $$.height2;else if (target === "arc") x = $$.arcWidth / 2, y = $$.arcHeight / 2;else if (target === "radar") {
+ var diff = ($$.arcWidth - $$.arcHeight) / 2;
+
+ x = Math.max(diff, 0) + 4, y = diff < 0 ? Math.abs(diff) : (0, _util.asHalfPixel)($$.margin.top);
+ }
+
+ return "translate(" + x + ", " + y + ")";
+ }, ChartInternal.prototype.initialOpacity = function initialOpacity(d) {
+ return this.getBaseValue(d) !== null && this.withoutFadeIn[d.id] ? "1" : "0";
+ }, ChartInternal.prototype.initialOpacityForCircle = function initialOpacityForCircle(d) {
+ return this.getBaseValue(d) !== null && this.withoutFadeIn[d.id] ? this.opacityForCircle(d) : "0";
+ }, ChartInternal.prototype.opacityForCircle = function opacityForCircle(d) {
+ var opacity = this.config.point_show ? "1" : "0";
+
+ return (0, _util.isValue)(this.getBaseValue(d)) ? this.isBubbleType(d) || this.isScatterType(d) ? "0.5" : opacity : "0";
+ }, ChartInternal.prototype.opacityForText = function opacityForText() {
+ return this.hasDataLabel() ? "1" : "0";
+ }, ChartInternal.prototype.xx = function xx(d) {
+ var fn = this.config.zoom_enabled && this.zoomScale ? this.zoomScale : this.x;
+
+ return d ? fn(d.x) : null;
+ }, ChartInternal.prototype.xv = function xv(d) {
+ var $$ = this,
+ value = $$.getBaseValue(d);
+
+
+ return $$.isTimeSeries() ? value = $$.parseDate(value) : $$.isCategorized() && (0, _util.isString)(value) && (value = $$.config.axis_x_categories.indexOf(value)), Math.ceil($$.x(value));
+ }, ChartInternal.prototype.yv = function yv(d) {
+ var $$ = this,
+ yScale = d.axis && d.axis === "y2" ? $$.y2 : $$.y;
+
+
+ return Math.ceil(yScale($$.getBaseValue(d)));
+ }, ChartInternal.prototype.subxx = function subxx(d) {
+ return d ? this.subX(d.x) : null;
+ }, ChartInternal.prototype.transformMain = function transformMain(withTransition, transitions) {
+ var $$ = this,
+ xAxis = void 0,
+ yAxis = void 0,
+ y2Axis = void 0;
+ transitions && transitions.axisX ? xAxis = transitions.axisX : (xAxis = $$.main.select("." + _classes2.default.axisX), withTransition && (xAxis = xAxis.transition())), transitions && transitions.axisY ? yAxis = transitions.axisY : (yAxis = $$.main.select("." + _classes2.default.axisY), withTransition && (yAxis = yAxis.transition())), transitions && transitions.axisY2 ? y2Axis = transitions.axisY2 : (y2Axis = $$.main.select("." + _classes2.default.axisY2), withTransition && (y2Axis = y2Axis.transition())), (withTransition ? $$.main.transition() : $$.main).attr("transform", $$.getTranslate("main")), xAxis.attr("transform", $$.getTranslate("x")), yAxis.attr("transform", $$.getTranslate("y")), y2Axis.attr("transform", $$.getTranslate("y2")), $$.main.select("." + _classes2.default.chartArcs).attr("transform", $$.getTranslate("arc"));
+ }, ChartInternal.prototype.transformAll = function transformAll(withTransition, transitions) {
+ var $$ = this;
+
+ $$.transformMain(withTransition, transitions), $$.config.subchart_show && $$.transformContext(withTransition, transitions), $$.legend && $$.transformLegend(withTransition);
+ }, ChartInternal.prototype.updateSvgSize = function updateSvgSize() {
+ var $$ = this,
+ brush = $$.svg.select("." + _classes2.default.brush + " .overlay"),
+ brushHeight = brush.size() ? brush.attr("height") : 0;
+ $$.svg.attr("width", $$.currentWidth).attr("height", $$.currentHeight), $$.svg.selectAll(["#" + $$.clipId, "#" + $$.clipIdForGrid]).select("rect").attr("width", $$.width).attr("height", $$.height), $$.svg.select("#" + $$.clipIdForXAxis).select("rect").attr("x", $$.getXAxisClipX.bind($$)).attr("y", $$.getXAxisClipY.bind($$)).attr("width", $$.getXAxisClipWidth.bind($$)).attr("height", $$.getXAxisClipHeight.bind($$)), $$.svg.select("#" + $$.clipIdForYAxis).select("rect").attr("x", $$.getYAxisClipX.bind($$)).attr("y", $$.getYAxisClipY.bind($$)).attr("width", $$.getYAxisClipWidth.bind($$)).attr("height", $$.getYAxisClipHeight.bind($$)), $$.svg.select("#" + $$.clipIdForSubchart).select("rect").attr("width", $$.width).attr("height", brushHeight), $$.svg.select("." + _classes2.default.zoomRect).attr("width", $$.width).attr("height", $$.height), $$.brush && $$.brush.scale($$.subX, brushHeight);
+ }, ChartInternal.prototype.updateDimension = function updateDimension(withoutAxis) {
+ var $$ = this;
+
+ withoutAxis || ($$.config.axis_rotated ? ($$.axes.x.call($$.xAxis), $$.axes.subx.call($$.subXAxis)) : ($$.axes.y.call($$.yAxis), $$.axes.y2.call($$.y2Axis))), $$.updateSizes(), $$.updateScales(withoutAxis), $$.updateSvgSize(), $$.transformAll(!1);
+ }, ChartInternal.prototype.bindResize = function bindResize() {
+ var $$ = this,
+ config = $$.config;
+ $$.resizeFunction = $$.generateResize(), $$.resizeFunction.add(function () {
+ return config.onresize.call($$);
+ }), config.resize_auto && $$.resizeFunction.add(function () {
+ (0, _util.isDefined)($$.resizeTimeout) && window.clearTimeout($$.resizeTimeout), $$.resizeTimeout = window.setTimeout(function () {
+ delete $$.resizeTimeout, $$.api.flush();
+ }, 100);
+ }), $$.resizeFunction.add(function () {
+ return config.onresized.call($$);
+ });
+
+
+ // attach resize event
+ // get the possible previous attached
+ var resizeEvents = (0, _d3Selection.select)(window).on("resize.bb");
+
+ resizeEvents && $$.resizeFunction.add(resizeEvents), (0, _d3Selection.select)(window).on("resize.bb", $$.resizeFunction);
+ }, ChartInternal.prototype.generateResize = function generateResize() {
+
+ function callResizeFunctions() {
+ resizeFunctions.forEach(function (f) {
+ return f();
+ });
+ }
+
+ var resizeFunctions = [];
+
+ return callResizeFunctions.add = function (f) {
+ resizeFunctions.push(f);
+ }, callResizeFunctions.remove = function (f) {
+ for (var i = 0, len = resizeFunctions.length; i < len; i++) if (resizeFunctions[i] === f) {
+ resizeFunctions.splice(i, 1);
+
+ break;
+ }
+ }, callResizeFunctions;
+ }, ChartInternal.prototype.endall = function endall(transition, callback) {
+ var n = 0;
+
+ transition.each(function () {
+ return ++n;
+ }).on("end", function () {
+ for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) args[_key] = arguments[_key];
+
+ --n || callback.apply.apply(callback, [this].concat(args));
+ });
+ }, ChartInternal.prototype.generateWait = function generateWait() {
+ var transitionsToWait = [],
+ f = function (transition, callback) {
+
+ function loop() {
+ var done = 0;
+
+ transitionsToWait.forEach(function (t) {
+ if (t.empty()) return void done++;
+
+ try {
+ t.transition();
+ } catch (e) {
+ done++;
+ }
+ }), timer && clearTimeout(timer), done === transitionsToWait.length ? callback && callback() : timer = setTimeout(loop, 50);
+ }
+
+ var timer = void 0;loop();
+ };
+
+ return f.add = function (transition) {
+ (0, _util.isArray)(transition) ? transitionsToWait = transitionsToWait.concat(transition) : transitionsToWait.push(transition);
+ }, f;
+ }, ChartInternal.prototype.parseDate = function parseDate(date) {
+ var $$ = this,
+ parsedDate = void 0;
+
+
+ return date instanceof Date ? parsedDate = date : (0, _util.isString)(date) ? parsedDate = $$.dataTimeFormat($$.config.data_xFormat)(date) : (0, _util.isNumber)(date) && !isNaN(date) && (parsedDate = new Date(+date)), (!parsedDate || isNaN(+parsedDate)) && console && console.error && console.error("Failed to parse x '" + date + "' to Date object"), parsedDate;
+ }, ChartInternal.prototype.isTabVisible = function isTabVisible() {
+ return !document[["hidden", "mozHidden", "msHidden", "webkitHidden"].filter(function (v) {
+ return v in document;
+ })[0]];
+ }, ChartInternal.prototype.convertInputType = function convertInputType() {
+ var $$ = this,
+ config = $$.config,
+ isMobile = $$.isMobile(),
+ hasMouse = config.interaction_inputType_mouse && !isMobile && "onmouseover" in window,
+ hasTouch = !1;
+
+
+ return config.interaction_inputType_touch && (hasTouch = "ontouchmove" in window || window.DocumentTouch && document instanceof window.DocumentTouch), hasMouse && "mouse" || hasTouch && "touch" || null;
+ }, ChartInternal;
+}(); /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ * @ignore
+ */
+
+
+exports.default = ChartInternal;
+module.exports = exports["default"];
+
+/***/ }),
+/* 4 */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE__4__;
+
+/***/ }),
+/* 5 */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE__5__;
+
+/***/ }),
+/* 6 */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE__6__;
+
+/***/ }),
+/* 7 */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE__7__;
+
+/***/ }),
+/* 8 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+exports.__esModule = !0;
+
+var _classCallCheck2 = __webpack_require__(2),
+ _classCallCheck3 = _interopRequireDefault(_classCallCheck2),
+ _bb = __webpack_require__(9),
+ _bb2 = _interopRequireDefault(_bb),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var isHorizontal = function ($$, forHorizontal) {
+ var isRotated = $$.config.axis_rotated;
+
+ return forHorizontal ? isRotated : !isRotated;
+}; /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+var Axis = function () {
+ function Axis(owner) {
+ (0, _classCallCheck3.default)(this, Axis), this.owner = owner;
+ }
+
+ return Axis.prototype.init = function init() {
+ var _this = this,
+ $$ = this.owner,
+ config = $$.config,
+ isRotated = config.axis_rotated,
+ main = $$.main;
+
+ ["x", "y", "y2"].forEach(function (v) {
+ var axisStr = "axis" + (0, _util.capitalize)(v),
+ classAxis = _classes2.default.axis + " " + _classes2.default[axisStr],
+ classLabel = _classes2.default[axisStr + "Label"];
+ $$.axes[v] = main.append("g").attr("class", classAxis).attr("clip-path", function () {
+ var res = null;
+
+ return v === "x" ? res = $$.clipPathForXAxis : v === "y" && config.axis_y_inner && (res = $$.clipPathForYAxis), res;
+ }).attr("transform", $$.getTranslate(v)).style("visibility", config["axis_" + v + "_show"] ? "visible" : "hidden"), $$.axes[v].append("text").attr("class", classLabel).attr("transform", ["rotate(-90)", null][v === "x" ? +!isRotated : +isRotated]).style("text-anchor", _this.textAnchorForXAxisLabel.bind(_this));
+ });
+ }, Axis.prototype.getXAxis = function getXAxis(axisName, scale, orient, tickFormat, tickValues, withOuterTick, withoutTransition, withoutRotateTickText) {
+ var $$ = this.owner,
+ config = $$.config,
+ isCategory = $$.isCategorized(),
+ axisParams = {
+ isCategory: isCategory,
+ withOuterTick: withOuterTick,
+ withoutTransition: withoutTransition,
+ config: config,
+ axisName: axisName,
+ tickMultiline: config.axis_x_tick_multiline,
+ tickWidth: config.axis_x_tick_width,
+ tickTextRotate: withoutRotateTickText ? 0 : config.axis_x_tick_rotate,
+ tickTitle: isCategory && config.axis_x_tick_tooltip && $$.api.categories(),
+ orgXScale: $$.x
+ },
+ axis = (0, _bb2.default)(axisParams).scale($$.zoomScale || scale).orient(orient),
+ newTickValues = tickValues;
+
+
+ return $$.isTimeSeries() && tickValues && !(0, _util.isFunction)(tickValues) && (newTickValues = tickValues.map(function (v) {
+ return $$.parseDate(v);
+ })), axis.tickFormat(tickFormat).tickValues(newTickValues), isCategory && (axis.tickCentered(config.axis_x_tick_centered), (0, _util.isEmpty)(config.axis_x_tick_culling) && (config.axis_x_tick_culling = !1)), axis;
+ }, Axis.prototype.getYAxis = function getYAxis(axisName, scale, orient, tickFormat, tickValues, withOuterTick, withoutTransition, withoutRotateTickText) {
+ var $$ = this.owner,
+ config = $$.config,
+ axisParams = {
+ withOuterTick: withOuterTick,
+ withoutTransition: withoutTransition,
+ config: config,
+ axisName: axisName,
+ tickTextRotate: withoutRotateTickText ? 0 : config.axis_y_tick_rotate
+ },
+ axis = (0, _bb2.default)(axisParams).scale(scale).orient(orient).tickFormat(tickFormat);
+
+
+ return $$.isTimeSeriesY() ?
+ // https://github.com/d3/d3/blob/master/CHANGES.md#time-intervals-d3-time
+ axis.ticks(config.axis_y_tick_time_value) : axis.tickValues(tickValues), axis;
+ }, Axis.prototype.updateXAxisTickValues = function updateXAxisTickValues(targets, axis) {
+ var $$ = this.owner,
+ config = $$.config,
+ xTickCount = config.axis_x_tick_count,
+ tickValues = void 0;
+
+
+ return (config.axis_x_tick_fit || xTickCount) && (tickValues = this.generateTickValues($$.mapTargetsToUniqueXs(targets), xTickCount, $$.isTimeSeries())), axis ? axis.tickValues(tickValues) : ($$.xAxis.tickValues(tickValues), $$.subXAxis.tickValues(tickValues)), tickValues;
+ }, Axis.prototype.getId = function getId(id) {
+ var config = this.owner.config;
+
+ return id in config.data_axes ? config.data_axes[id] : "y";
+ }, Axis.prototype.getXAxisTickFormat = function getXAxisTickFormat() {
+ var $$ = this.owner,
+ config = $$.config,
+ tickFormat = config.axis_x_tick_format,
+ isTimeSeries = $$.isTimeSeries(),
+ isCategorized = $$.isCategorized(),
+ format = void 0;
+
+
+ return tickFormat ? (0, _util.isFunction)(tickFormat) ? format = tickFormat : isTimeSeries && (format = function (date) {
+ return date ? $$.axisTimeFormat(tickFormat)(date) : "";
+ }) : format = isTimeSeries ? $$.defaultAxisTimeFormat : isCategorized ? $$.categoryName : function (v) {
+ return v < 0 ? v.toFixed(0) : v;
+ }, (0, _util.isFunction)(format) ? function (v) {
+ return format.apply($$, isCategorized ? [v, $$.categoryName(v)] : [v]);
+ } : format;
+ }, Axis.prototype.getTickValues = function getTickValues(type) {
+ var $$ = this.owner,
+ tickValues = $$.config["axis_" + type + "_tick_values"],
+ axis = $$[type + "Axis"];
+
+
+ return tickValues || (axis ? axis.tickValues() : undefined);
+ }, Axis.prototype.getXAxisTickValues = function getXAxisTickValues() {
+ return this.getTickValues("x");
+ }, Axis.prototype.getYAxisTickValues = function getYAxisTickValues() {
+ return this.getTickValues("y");
+ }, Axis.prototype.getY2AxisTickValues = function getY2AxisTickValues() {
+ return this.getTickValues("y2");
+ }, Axis.prototype.getLabelOptionByAxisId = function getLabelOptionByAxisId(axisId) {
+ return this.owner.config["axis_" + axisId + "_label"];
+ }, Axis.prototype.getLabelText = function getLabelText(axisId) {
+ var option = this.getLabelOptionByAxisId(axisId);
+
+ return (0, _util.isString)(option) ? option : option ? option.text : null;
+ }, Axis.prototype.setLabelText = function setLabelText(axisId, text) {
+ var $$ = this.owner,
+ config = $$.config,
+ option = this.getLabelOptionByAxisId(axisId);
+ (0, _util.isString)(option) ? config["axis_" + axisId + "_label"] = text : option && (option.text = text);
+ }, Axis.prototype.getLabelPosition = function getLabelPosition(axisId, defaultPosition) {
+ var isRotated = this.owner.config.axis_rotated,
+ option = this.getLabelOptionByAxisId(axisId),
+ position = (0, _util.isObjectType)(option) && option.position ? option.position : defaultPosition[+!isRotated],
+ has = function (v) {
+ return !!~position.indexOf(v);
+ };
+
+ return {
+ isInner: has("inner"),
+ isOuter: has("outer"),
+ isLeft: has("left"),
+ isCenter: has("center"),
+ isRight: has("right"),
+ isTop: has("top"),
+ isMiddle: has("middle"),
+ isBottom: has("bottom")
+ };
+ }, Axis.prototype.getXAxisLabelPosition = function getXAxisLabelPosition() {
+ return this.getLabelPosition("x", ["inner-top", "inner-right"]);
+ }, Axis.prototype.getYAxisLabelPosition = function getYAxisLabelPosition() {
+ return this.getLabelPosition("y", ["inner-right", "inner-top"]);
+ }, Axis.prototype.getY2AxisLabelPosition = function getY2AxisLabelPosition() {
+ return this.getLabelPosition("y2", ["inner-right", "inner-top"]);
+ }, Axis.prototype.getLabelPositionById = function getLabelPositionById(id) {
+ return this["get" + id.toUpperCase() + "AxisLabelPosition"]();
+ }, Axis.prototype.textForXAxisLabel = function textForXAxisLabel() {
+ return this.getLabelText("x");
+ }, Axis.prototype.textForYAxisLabel = function textForYAxisLabel() {
+ return this.getLabelText("y");
+ }, Axis.prototype.textForY2AxisLabel = function textForY2AxisLabel() {
+ return this.getLabelText("y2");
+ }, Axis.prototype.xForAxisLabel = function xForAxisLabel(position) {
+ var forHorizontal = !(arguments.length > 1 && arguments[1] !== undefined) || arguments[1],
+ $$ = this.owner,
+ x = position.isMiddle ? -$$.height / 2 : 0;
+
+
+ return isHorizontal($$, forHorizontal) ? x = position.isLeft ? 0 : position.isCenter ? $$.width / 2 : $$.width : position.isBottom && (x = -$$.height), x;
+ }, Axis.prototype.dxForAxisLabel = function dxForAxisLabel(position) {
+ var forHorizontal = !(arguments.length > 1 && arguments[1] !== undefined) || arguments[1],
+ $$ = this.owner,
+ dx = position.isBottom ? "0.5em" : "0";
+
+
+ return isHorizontal($$, forHorizontal) ? dx = position.isLeft ? "0.5em" : position.isRight ? "-0.5em" : "0" : position.isTop && (dx = "-0.5em"), dx;
+ }, Axis.prototype.textAnchorForAxisLabel = function textAnchorForAxisLabel(position) {
+ var forHorizontal = !(arguments.length > 1 && arguments[1] !== undefined) || arguments[1],
+ $$ = this.owner,
+ anchor = position.isMiddle ? "middle" : "end";
+
+
+ return isHorizontal($$, forHorizontal) ? anchor = position.isLeft ? "start" : position.isCenter ? "middle" : "end" : position.isBottom && (anchor = "start"), anchor;
+ }, Axis.prototype.xForXAxisLabel = function xForXAxisLabel() {
+ return this.xForAxisLabel(this.getXAxisLabelPosition(), !1);
+ }, Axis.prototype.xForYAxisLabel = function xForYAxisLabel() {
+ return this.xForAxisLabel(this.getYAxisLabelPosition());
+ }, Axis.prototype.xForY2AxisLabel = function xForY2AxisLabel() {
+ return this.xForAxisLabel(this.getY2AxisLabelPosition());
+ }, Axis.prototype.dxForXAxisLabel = function dxForXAxisLabel() {
+ return this.dxForAxisLabel(this.getXAxisLabelPosition(), !1);
+ }, Axis.prototype.dxForYAxisLabel = function dxForYAxisLabel() {
+ return this.dxForAxisLabel(this.getYAxisLabelPosition());
+ }, Axis.prototype.dxForY2AxisLabel = function dxForY2AxisLabel() {
+ return this.dxForAxisLabel(this.getY2AxisLabelPosition());
+ }, Axis.prototype.dyForXAxisLabel = function dyForXAxisLabel() {
+ var $$ = this.owner,
+ config = $$.config,
+ isInner = this.getXAxisLabelPosition().isInner,
+ xHeight = config.axis_x_height;
+ return config.axis_rotated ? isInner ? "1.2em" : -25 - this.getMaxTickWidth("x") : isInner ? "-0.5em" : xHeight ? xHeight - 10 : "3em";
+ }, Axis.prototype.dyForYAxisLabel = function dyForYAxisLabel() {
+ var $$ = this.owner,
+ isInner = this.getYAxisLabelPosition().isInner;
+ return $$.config.axis_rotated ? isInner ? "-0.5em" : "3em" : isInner ? "1.2em" : -10 - ($$.config.axis_y_inner ? 0 : this.getMaxTickWidth("y") + 10);
+ }, Axis.prototype.dyForY2AxisLabel = function dyForY2AxisLabel() {
+ var $$ = this.owner,
+ isInner = this.getY2AxisLabelPosition().isInner;
+ return $$.config.axis_rotated ? isInner ? "1.2em" : "-2.2em" : isInner ? "-0.5em" : 15 + ($$.config.axis_y2_inner ? 0 : this.getMaxTickWidth("y2") + 15);
+ }, Axis.prototype.textAnchorForXAxisLabel = function textAnchorForXAxisLabel() {
+ return this.textAnchorForAxisLabel(this.getXAxisLabelPosition(), !1);
+ }, Axis.prototype.textAnchorForYAxisLabel = function textAnchorForYAxisLabel() {
+ return this.textAnchorForAxisLabel(this.getYAxisLabelPosition());
+ }, Axis.prototype.textAnchorForY2AxisLabel = function textAnchorForY2AxisLabel() {
+ return this.textAnchorForAxisLabel(this.getY2AxisLabelPosition());
+ }, Axis.prototype.getMaxTickWidth = function getMaxTickWidth(id, withoutRecompute) {
+ var $$ = this.owner,
+ config = $$.config,
+ currentTickMax = $$.currentMaxTickWidths,
+ maxWidth = 0;
+
+
+ if (withoutRecompute && currentTickMax[id]) return currentTickMax[id];
+
+ if ($$.svg) {
+ var isYAxis = /^y2?$/.test(id),
+ targetsToShow = $$.filterTargetsToShow($$.data.targets),
+ getFrom = isYAxis ? "getY" : "getX",
+ scale = $$[id].copy().domain($$[getFrom + "Domain"](targetsToShow, id)),
+ axis = this[getFrom + "Axis"](id, scale, $$[id + "Orient"], isYAxis ? config["axis_" + id + "_tick_format"] : $$.xAxisTickFormat, null, !1, !0, !0);
+ isYAxis || this.updateXAxisTickValues(targetsToShow, axis);
+
+
+ var dummy = $$.selectChart.append("svg").style("visibility", "hidden");
+
+ dummy.call(axis).selectAll("text").each(function () {
+ maxWidth = Math.max(maxWidth, this.getBoundingClientRect().width);
+ }), dummy.remove();
+ }
+
+ return maxWidth > 0 && (currentTickMax[id] = maxWidth), currentTickMax[id];
+ }, Axis.prototype.updateLabels = function updateLabels(withTransition) {
+ var _this2 = this,
+ $$ = this.owner,
+ labels = {
+ X: $$.main.select("." + _classes2.default.axisX + " ." + _classes2.default.axisXLabel),
+ Y: $$.main.select("." + _classes2.default.axisY + " ." + _classes2.default.axisYLabel),
+ Y2: $$.main.select("." + _classes2.default.axisY2 + " ." + _classes2.default.axisY2Label)
+ };
+
+ Object.keys(labels).forEach(function (v) {
+ var node = labels[v],
+ axisLabel = v + "AxisLabel";
+ (withTransition ? node.transition() : node).attr("x", _this2["xFor" + axisLabel].bind(_this2)).attr("dx", _this2["dxFor" + axisLabel].bind(_this2)).attr("dy", _this2["dyFor" + axisLabel].bind(_this2)).text(_this2["textFor" + axisLabel].bind(_this2));
+ });
+ }, Axis.prototype.getPadding = function getPadding(padding, key, defaultValue, domainLength) {
+ var p = (0, _util.isNumber)(padding) ? padding : padding[key];
+
+ // assume padding is pixels if unit is not specified
+ return (0, _util.isValue)(p) ? padding.unit === "ratio" ? padding[key] * domainLength : this.convertPixelsToAxisPadding(p, domainLength) : defaultValue;
+ }, Axis.prototype.convertPixelsToAxisPadding = function convertPixelsToAxisPadding(pixels, domainLength) {
+ var $$ = this.owner,
+ length = $$.config.axis_rotated ? $$.width : $$.height;
+
+
+ return domainLength * (pixels / length);
+ }, Axis.prototype.generateTickValues = function generateTickValues(values, tickCount, forTimeSeries) {
+ var tickValues = values,
+ start = void 0,
+ end = void 0,
+ count = void 0,
+ interval = void 0,
+ i = void 0,
+ tickValue = void 0;
+
+
+ if (tickCount) {
+ var targetCount = (0, _util.isFunction)(tickCount) ? tickCount() : tickCount;
+
+ // compute ticks according to tickCount
+ if (targetCount === 1) tickValues = [values[0]];else if (targetCount === 2) tickValues = [values[0], values[values.length - 1]];else if (targetCount > 2) {
+
+ for (count = targetCount - 2, start = values[0], end = values[values.length - 1], interval = (end - start) / (count + 1), tickValues = [start], i = 0; i < count; i++) tickValue = +start + interval * (i + 1), tickValues.push(forTimeSeries ? new Date(tickValue) : tickValue);
+
+ tickValues.push(end);
+ }
+ }
+
+ return forTimeSeries || (tickValues = tickValues.sort(function (a, b) {
+ return a - b;
+ })), tickValues;
+ }, Axis.prototype.generateTransitions = function generateTransitions(duration) {
+ var $$ = this.owner,
+ axes = $$.axes,
+ _map = ["x", "y", "y2", "subx"].map(function (v) {
+ return duration ? axes[v].transition().duration(duration) : axes[v];
+ }),
+ axisX = _map[0],
+ axisY = _map[1],
+ axisY2 = _map[2],
+ axisSubX = _map[3];
+
+ return { axisX: axisX, axisY: axisY, axisY2: axisY2, axisSubX: axisSubX };
+ }, Axis.prototype.redraw = function redraw(transitions, isHidden) {
+ var $$ = this.owner,
+ opacity = isHidden ? "0" : "1";
+ ["x", "y", "y2", "subx"].forEach(function (v) {
+ $$.axes[v].style("opacity", opacity);
+ }), transitions.axisX.call($$.xAxis), transitions.axisY.call($$.yAxis), transitions.axisY2.call($$.y2Axis), transitions.axisSubX.call($$.subXAxis);
+ }, Axis;
+}();
+
+exports.default = Axis;
+module.exports = exports["default"];
+
+/***/ }),
+/* 9 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+exports.__esModule = !0;
+
+exports.default = function () {
+
+ function axisX(selection, x) {
+ selection.attr("transform", function (d) {
+ return "translate(" + Math.ceil(x(d) + tickOffset) + ", 0)";
+ });
+ }
+
+ function axisY(selection, y) {
+ selection.attr("transform", function (d) {
+ return "translate(0," + Math.ceil(y(d)) + ")";
+ });
+ }
+
+ function scaleExtent(domain) {
+ var start = domain[0],
+ stop = domain[domain.length - 1];
+
+
+ return start < stop ? [start, stop] : [stop, start];
+ }
+
+ function generateTicks(scale) {
+ var ticks = [];
+
+ if (scale.ticks) return scale.ticks.apply(scale, tickArguments ? (0, _util.toArray)(tickArguments) : []).map(function (v) {
+ return (
+ // round the tick value if is number
+ (0, _util.isString)(v) && (0, _util.isNumber)(v) && !isNaN(v) && Math.round(v * 10) / 10 || v
+ );
+ });
+
+ for (var domain = scale.domain(), i = Math.ceil(domain[0]); i < domain[1]; i++) ticks.push(i);
+
+ return ticks.length > 0 && ticks[0] > 0 && ticks.unshift(ticks[0] - (ticks[1] - ticks[0])), ticks;
+ }
+
+ function copyScale() {
+ var newScale = scale.copy();
+
+ return newScale.domain().length || newScale.domain(scale.domain()), newScale;
+ }
+
+ function textFormatted(v) {
+ // to round float numbers from 'binary floating point'
+ // https://en.wikipedia.org/wiki/Double-precision_floating-point_format
+ // https://stackoverflow.com/questions/17849101/laymans-explanation-for-why-javascript-has-weird-floating-math-ieee-754-stand
+ var value = /\d+\.\d+0{5,}\d$/.test(v) ? +(v + "").replace(/0+\d$/, "") : v,
+ formatted = tickFormat ? tickFormat(value) : value;
+
+
+ return (0, _util.isDefined)(formatted) ? formatted : "";
+ }
+
+ function transitionise(selection) {
+ return params.withoutTransition ? selection.interrupt() : selection.transition(transition);
+ }
+
+ function axis(g) {
+ g.each(function () {
+
+ // this should be called only when category axis
+ function splitTickText(d, maxWidthValue) {
+
+ function split(splitted, text) {
+ spaceIndex = undefined;
+
+
+ for (var i = 1; i < text.length; i++)
+
+ // if text width gets over tick width, split by space index or current index
+ if (text.charAt(i) === " " && (spaceIndex = i), subtext = text.substr(0, i + 1), textWidth = sizeFor1Char.w * subtext.length, maxWidth < textWidth) return split(splitted.concat(text.substr(0, spaceIndex || i)), text.slice(spaceIndex ? spaceIndex + 1 : i));
+
+ return splitted.concat(text);
+ }
+
+ var tickText = textFormatted(d),
+ splitted = (0, _util.isString)(tickText) && tickText.indexOf("\n") > -1 ? tickText.split("\n") : [];
+
+
+ if (splitted.length) return splitted;
+
+ var maxWidth = maxWidthValue,
+ subtext = void 0,
+ spaceIndex = void 0,
+ textWidth = void 0;
+ return (0, _util.isArray)(tickText) ? tickText : ((!maxWidth || maxWidth <= 0) && (maxWidth = isLeftRight ? 95 : params.isCategory ? Math.ceil(scale1(ticks[1]) - scale1(ticks[0])) - 12 : 110), split(splitted, tickText + ""));
+ }
+
+ var g = (0, _d3Selection.select)(this);
+
+ axis.g = g;
+ var scale0 = this.__chart__ || scale,
+ scale1 = copyScale();
+ this.__chart__ = scale1;
+
+
+ // count of tick data in array
+ var ticks = tickValues || generateTicks(scale1),
+ tick = g.selectAll(".tick").data(ticks, scale1),
+ tickEnter = tick.enter().insert("g", ".domain").attr("class", "tick").style("opacity", "1"),
+ tickExit = tick.exit().remove();
+
+ // update selection
+
+
+ // enter selection
+
+
+ // MEMO: No exit transition. The reason is this transition affects max tick width calculation because old tick will be included in the ticks.
+
+ tick = tickEnter.merge(tick);
+ var tickUpdate = transitionise(tick).style("opacity", "1"),
+ tickX = void 0,
+ tickY = void 0,
+ range = scale.rangeExtent ? scale.rangeExtent() : scaleExtent((params.orgXScale || scale).range()),
+ path = g.selectAll(".domain").data([0]),
+ pathUpdate = path.enter().append("path").attr("class", "domain").merge(transitionise(path));
+
+ // update selection - data join
+
+
+ // enter + update selection
+
+ tickEnter.append("line"), tickEnter.append("text");
+ var lineEnter = tickEnter.select("line"),
+ lineUpdate = tickUpdate.select("line"),
+ textEnter = tickEnter.select("text"),
+ textUpdate = tickUpdate.select("text");
+ params.isCategory ? (tickOffset = Math.ceil((scale1(1) - scale1(0)) / 2), tickX = tickCentered ? 0 : tickOffset, tickY = tickCentered ? tickOffset : 0) : (tickX = 0, tickOffset = tickX);
+ var sizeFor1Char = getSizeFor1Char.size || getSizeFor1Char(g.select(".tick")),
+ counts = [],
+ tickLength = Math.max(6, 0) + 3,
+ isLeftRight = /^(left|right)$/.test(orient),
+ isTopBottom = /^(top|bottom)$/.test(orient),
+ tspan = tick.select("text").selectAll("tspan").data(function (d, index) {
+ var split = params.tickMultiline ? splitTickText(d, params.tickWidth) : (0, _util.isArray)(textFormatted(d)) ? textFormatted(d).concat() : [textFormatted(d)];
+
+ return counts[index] = split.length, split.map(function (splitted) {
+ return { index: index, splitted: splitted };
+ });
+ });
+ tspan.exit().remove(), tspan = tspan.enter().append("tspan").merge(tspan).text(function (d) {
+ return d.splitted;
+ });
+
+
+ // line/text enter and path update
+ var tickTransform = isTopBottom ? axisX : axisY,
+ sign = /^(top|left)$/.test(orient) ? -1 : 1,
+ axisPx = tickTransform === axisX ? "y" : "x";
+ lineEnter.attr(axisPx + "2", 6 * sign), textEnter.attr("" + axisPx, 9 * sign), pathUpdate.attr("d", function () {
+ var outerTickSized = outerTickSize * sign;
+
+ return isTopBottom ? "M" + range[0] + "," + outerTickSized + "V0H" + range[1] + "V" + outerTickSized : "M" + outerTickSized + "," + range[0] + "H0V" + range[1] + "H" + outerTickSized;
+ });
+
+ // tick text helpers
+ var rotate = params.tickTextRotate,
+ tickSize = function tickSize(d) {
+ var tickPosition = scale(d) + (tickCentered ? 0 : tickOffset);
+
+ return range[0] < tickPosition && tickPosition < range[1] ? 6 : 0;
+ },
+ tickTextPos = params.axisName && /^(x|y|y2)$/.test(params.axisName) ? params.config["axis_" + params.axisName + "_tick_text_position"] : { x: 0, y: 0 };
+
+ // get the axis' tick position configuration
+
+
+ if (tspan.attr("x", isTopBottom ? 0 : 9 * sign).attr("dx", function () {
+ var dx = 0;
+
+ return orient === "bottom" && rotate && (dx = 8 * Math.sin(Math.PI * (rotate / 180))), dx + (tickTextPos.x || 0);
+ }()).attr("dy", function (d, i) {
+ var dy = 0;
+
+
+ return orient !== "top" && (i === 0 ? dy = isLeftRight ? -((counts[d.index] - 1) * (sizeFor1Char.h / 2) - 3) : tickTextPos.y === 0 ? ".71em" : 0 : dy = sizeFor1Char.h), (0, _util.isNumber)(dy) && tickTextPos.y ? dy + tickTextPos.y : dy || ".71em";
+ }), orient === "bottom" ? (lineUpdate.attr("x1", tickX).attr("x2", tickX).attr("y2", tickSize), textUpdate.attr("x", 0).attr("y", function yForText(r) {
+ return r ? 11.5 - 2.5 * (r / 15) * (r > 0 ? 1 : -1) : 9;
+ }(rotate)).style("text-anchor", function textAnchorForText(r) {
+ return r ? r > 0 ? "start" : "end" : "middle";
+ }(rotate)).attr("transform", function textTransform(r) {
+ return r ? "rotate(" + r + ")" : null;
+ }(rotate))) : orient === "top" ? (lineUpdate.attr("x2", 0).attr("y2", -6), textUpdate.attr("x", 0).attr("y", -9).style("text-anchor", "middle")) : orient === "left" ? (lineUpdate.attr("x2", -6).attr("y1", tickY).attr("y2", tickY), textUpdate.attr("x", -9).attr("y", tickOffset).style("text-anchor", "end")) : orient === "right" ? (lineUpdate.attr("x2", 6).attr("y2", 0), textUpdate.attr("x", 9).attr("y", 0).style("text-anchor", "start")) : void 0, (params.tickTitle && textUpdate.append && textUpdate.append("title").each(function (index) {
+ (0, _d3Selection.select)(this).text(params.tickTitle[index]);
+ }), scale1.bandwidth)) {
+ var x = scale1,
+ dx = x.bandwidth() / 2;
+ scale0 = function scale0(d) {
+ return x(d) + dx;
+ }, scale1 = scale0;
+ } else scale0.bandwidth ? scale0 = scale1 : tickExit.call(tickTransform, scale1);
+
+ tickEnter.call(tickTransform, scale0), tickUpdate.call(tickTransform, scale1);
+ });
+ }
+
+ var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
+ scale = (0, _d3Scale.scaleLinear)(),
+ orient = "bottom",
+ outerTickSize = params.withOuterTick ? 6 : 0,
+ tickValues = null,
+ tickFormat = void 0,
+ tickArguments = void 0,
+ tickOffset = 0,
+ tickCulling = !0,
+ tickCentered = void 0,
+ transition = void 0;
+
+
+ return axis.scale = function (x) {
+ return arguments.length ? (scale = x, axis) : scale;
+ }, axis.orient = function (x) {
+ return arguments.length ? (orient = x in {
+ top: 1,
+ right: 1,
+ bottom: 1,
+ left: 1
+ } ? x + "" : "bottom", axis) : orient;
+ }, axis.tickFormat = function (format) {
+ return arguments.length ? (tickFormat = format, axis) : tickFormat;
+ }, axis.tickCentered = function (isCentered) {
+ return arguments.length ? (tickCentered = isCentered, axis) : tickCentered;
+ }, axis.tickOffset = function () {
+ return tickOffset;
+ }, axis.tickInterval = function (size) {
+ var interval = void 0;
+
+ if (params.isCategory) interval = tickOffset * 2;else {
+ var length = axis.g.select("path.domain").node().getTotalLength() - outerTickSize * 2;
+
+ interval = length / (size || axis.g.selectAll("line").size());
+ }
+
+ return interval === Infinity ? 0 : interval;
+ }, axis.ticks = function () {
+ for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) args[_key] = arguments[_key];
+
+ return args.length ? (tickArguments = (0, _util.toArray)(args), axis) : tickArguments;
+ }, axis.tickCulling = function (culling) {
+ return arguments.length ? (tickCulling = culling, axis) : tickCulling;
+ }, axis.tickValues = function (x) {
+ if ((0, _util.isFunction)(x)) tickValues = function tickValues() {
+ return x(scale.domain());
+ };else {
+ if (!arguments.length) return tickValues;
+
+ tickValues = x;
+ }
+
+ return axis;
+ }, axis.setTransition = function (t) {
+
+ return transition = t, axis;
+ }, axis;
+};
+
+var _d3Scale = __webpack_require__(10),
+ _d3Selection = __webpack_require__(5),
+ _util = __webpack_require__(11),
+ getSizeFor1Char = function getSizeFor1Char(node) {
+ // default size for one character
+ var size = {
+ w: 5.5,
+ h: 11.5
+ };
+
+ return node.empty() || node.select("text").text("0").call(function (el) {
+ try {
+ var box = el.node().getBBox(),
+ h = box.height,
+ w = box.width;
+ h && w && (size.h = h, size.w = w), el.text("");
+ } catch (e) {}
+ }), getSizeFor1Char.size = size;
+};
+
+// Features:
+// 1. category axis
+// 2. ceil values of translate/x/y to int for half pixel anti-aliasing
+// 3. multiline tick text
+
+/**
+ * Compute a character dimension
+ * @param {d3.selection} node
+ * @return {{w: number, h: number}}
+ * @private
+ */
+
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ * @ignore
+ */
+module.exports = exports["default"];
+
+/***/ }),
+/* 10 */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE__10__;
+
+/***/ }),
+/* 11 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+exports.__esModule = !0;
+exports.toArray = exports.sanitise = exports.merge = exports.notEmpty = exports.isValue = exports.isUndefined = exports.isString = exports.isObjectType = exports.isObject = exports.isNumber = exports.isFunction = exports.isEmpty = exports.isDefined = exports.isBoolean = exports.isArray = exports.hasValue = exports.getRectSegList = exports.getPathBox = exports.getOption = exports.getCssRules = exports.getBrushSelection = exports.extend = exports.emulateEvent = exports.diffDomain = exports.ceil10 = exports.capitalize = exports.callFn = exports.brushEmpty = exports.asHalfPixel = undefined;
+
+var _typeof2 = __webpack_require__(12),
+ _typeof3 = _interopRequireDefault(_typeof2),
+ _d3Selection = __webpack_require__(5),
+ _d3Brush = __webpack_require__(13),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var isValue = function (v) {
+ return v || v === 0;
+},
+ isFunction = function (v) {
+ return typeof v === "function";
+},
+ isString = function (v) {
+ return typeof v === "string";
+},
+ isNumber = function (v) {
+ return typeof v === "number";
+},
+ isUndefined = function (v) {
+ return typeof v === "undefined";
+},
+ isDefined = function (v) {
+ return typeof v !== "undefined";
+},
+ isBoolean = function (v) {
+ return typeof v === "boolean";
+},
+ ceil10 = function (v) {
+ return Math.ceil(v / 10) * 10;
+},
+ asHalfPixel = function (n) {
+ return Math.ceil(n) + .5;
+},
+ diffDomain = function (d) {
+ return d[1] - d[0];
+},
+ isObjectType = function (v) {
+ return (typeof v === "undefined" ? "undefined" : (0, _typeof3.default)(v)) === "object";
+},
+ isEmpty = function (o) {
+ return isUndefined(o) || o === null || isString(o) && o.length === 0 || isObjectType(o) && Object.keys(o).length === 0;
+},
+ notEmpty = function (o) {
+ return !isEmpty(o);
+},
+ isArray = function (arr) {
+ return arr && arr.constructor === Array;
+},
+ isObject = function (obj) {
+ return obj && !obj.nodeType && isObjectType(obj) && !isArray(obj);
+},
+ getOption = function (options, key, defaultValue) {
+ return isDefined(options[key]) ? options[key] : defaultValue;
+},
+ hasValue = function (dict, value) {
+ var found = !1;
+
+ return Object.keys(dict).forEach(function (key) {
+ return dict[key] === value && (found = !0);
+ }), found;
+},
+ callFn = function (fn) {
+ for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) args[_key - 1] = arguments[_key];
+
+ var isFn = isFunction(fn);
+
+ return isFn && fn.call.apply(fn, args), isFn;
+},
+ sanitise = function (str) {
+ return isString(str) ? str.replace(/</g, "<").replace(/>/g, ">") : str;
+},
+ getRectSegList = function (path) {
+ /*
+ * seg1 ---------- seg2
+ * | |
+ * | |
+ * | |
+ * seg0 ---------- seg3
+ * */
+ var bbox = path.getBBox(),
+ _ref = [bbox.x, bbox.y, bbox.width, bbox.height],
+ x = _ref[0],
+ y = _ref[1],
+ width = _ref[2],
+ height = _ref[3];
+
+ return [{ x: x, y: y + height }, // seg0
+ { x: x, y: y }, // seg1
+ { x: x + width, y: y }, // seg2
+ { x: x + width, y: y + height // seg3
+ }];
+},
+ getPathBox = function (path) {
+ var box = path.getBoundingClientRect(),
+ _ref2 = [box.width, box.height],
+ width = _ref2[0],
+ height = _ref2[1],
+ items = getRectSegList(path),
+ x = items[0].x,
+ y = Math.min(items[0].y, items[1].y);
+
+ return {
+ x: x, y: y, width: width, height: height
+ };
+},
+ getBrushSelection = function (ctx) {
+ var selection = null,
+ event = _d3Selection.event,
+ main = ctx.context || ctx.main;
+
+ // check from event
+
+ return event && event.constructor.name === "BrushEvent" ? selection = event.selection : main && (selection = main.select("." + _classes2.default.brush).node()) && (selection = (0, _d3Brush.brushSelection)(selection)), selection;
+},
+ brushEmpty = function (ctx) {
+ var selection = getBrushSelection(ctx);
+
+ return !selection || selection[0] === selection[1];
+},
+ extend = function () {
+ var target = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
+ source = arguments[1];
+
+ for (var p in source) target[p] = source[p];
+
+ return target;
+},
+ capitalize = function (str) {
+ return str.charAt(0).toUpperCase() + str.slice(1);
+},
+ merge = function (target) {
+ for (var _len2 = arguments.length, objectN = Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) objectN[_key2 - 1] = arguments[_key2];
+
+ if (!objectN.length || objectN.length === 1 && !objectN[0]) return target;
+
+ var source = objectN.shift();
+
+ return isObject(target) && isObject(source) && Object.keys(source).forEach(function (key) {
+ var value = source[key];
+
+ isObject(value) ? (!target[key] && (target[key] = {}), target[key] = merge(target[key], value)) : target[key] = isArray(value) ? value.concat() : value;
+ }), extend.apply(undefined, [target].concat(objectN));
+},
+ toArray = function (v) {
+ return [].slice.call(v);
+},
+ getCssRules = function (styleSheets) {
+ var rules = [];
+
+ return styleSheets.forEach(function (sheet) {
+ try {
+ sheet.cssRules && sheet.cssRules.length && (rules = rules.concat(toArray(sheet.cssRules)));
+ } catch (e) {
+ console.error("Error while reading rules from " + sheet.href + ": " + e.toString());
+ }
+ }), rules;
+},
+ emulateEvent = {
+ mouse: function () {
+ var getParams = function () {
+ return {
+ bubbles: !1, cancelable: !1, screenX: 0, screenY: 0, clientX: 0, clientY: 0
+ };
+ };
+
+ try {
+
+ return new MouseEvent("t"), function (el, eventType) {
+ var params = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : getParams();
+ el.dispatchEvent(new MouseEvent(eventType, params));
+ };
+ } catch (e) {
+ // Polyfills DOM4 MouseEvent
+ return function (el, eventType) {
+ var params = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : getParams(),
+ mouseEvent = document.createEvent("MouseEvent");
+ mouseEvent.initMouseEvent(eventType, params.bubbles, params.cancelable, window, 0, // the event's mouse click count
+ params.screenX, params.screenY, params.clientX, params.clientY, !1, !1, !1, !1, 0, null), el.dispatchEvent(mouseEvent);
+ };
+ }
+ }(),
+ touch: function touch(el, eventType, params) {
+ var touchObj = new Touch(Object.assign({
+ identifier: Date.now(),
+ target: el,
+ radiusX: 2.5,
+ radiusY: 2.5,
+ rotationAngle: 10,
+ force: .5
+ }, params));
+
+ el.dispatchEvent(new TouchEvent(eventType, {
+ cancelable: !0,
+ bubbles: !0,
+ shiftKey: !0,
+ touches: [touchObj],
+ targetTouches: [],
+ changedTouches: [touchObj]
+ }));
+ }
+};
+
+/**
+ * Check if is array
+ * @param {Array} arr
+ * @returns {Boolean}
+ * @private
+ */
+
+
+/**
+ * Check if is object
+ * @param {Object} obj
+ * @returns {Boolean}
+ * @private
+ */
+
+
+/**
+ * Call function with arguments
+ * @param {Function} fn Function to be called
+ * @param {*} args Arguments
+ * @return {Boolean} true: fn is function, false: fn is not function
+ * @private
+ */
+
+
+/**
+ * Replace tag sign to html entity
+ * @param {String} str
+ * @return {String}
+ * @private
+ */
+
+
+// substitution of SVGPathSeg API polyfill
+
+
+// return brush selection array
+
+
+/**
+ * Return first letter capitalized
+ * @param {String} str
+ * @return {String} capitalized string
+ * @private
+ */
+
+
+/**
+ * Merge object returning new object
+ * @param {Object} target
+ * @param {Object} objectN
+ * @returns {Object} merged target object
+ * @private
+ * @example
+ * var target = { a: 1 };
+ * utils.extend(target, { b: 2, c: 3 });
+ * target; // { a: 1, b: 2, c: 3 };
+ */
+
+
+/**
+ * Convert to array
+ * @param {Object} v
+ * @returns {Array}
+ * @private
+ */
+
+
+/**
+ * Get css rules for specified stylesheets
+ * @param {Array} styleSheets The stylesheets to get the rules from
+ * @returns {Array}
+ * @private
+ */
+
+
+// emulate event
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+
+exports.asHalfPixel = asHalfPixel;
+exports.brushEmpty = brushEmpty;
+exports.callFn = callFn;
+exports.capitalize = capitalize;
+exports.ceil10 = ceil10;
+exports.diffDomain = diffDomain;
+exports.emulateEvent = emulateEvent;
+exports.extend = extend;
+exports.getBrushSelection = getBrushSelection;
+exports.getCssRules = getCssRules;
+exports.getOption = getOption;
+exports.getPathBox = getPathBox;
+exports.getRectSegList = getRectSegList;
+exports.hasValue = hasValue;
+exports.isArray = isArray;
+exports.isBoolean = isBoolean;
+exports.isDefined = isDefined;
+exports.isEmpty = isEmpty;
+exports.isFunction = isFunction;
+exports.isNumber = isNumber;
+exports.isObject = isObject;
+exports.isObjectType = isObjectType;
+exports.isString = isString;
+exports.isUndefined = isUndefined;
+exports.isValue = isValue;
+exports.notEmpty = notEmpty;
+exports.merge = merge;
+exports.sanitise = sanitise;
+exports.toArray = toArray;
+
+/***/ }),
+/* 12 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+exports.__esModule = true;
+
+function _typeof(obj) { return obj && typeof Symbol !== "undefined" && obj.constructor === Symbol ? "symbol" : typeof obj; }
+
+exports.default = function (obj) {
+ return obj && typeof Symbol !== "undefined" && obj.constructor === Symbol ? "symbol" : typeof obj === "undefined" ? "undefined" : _typeof(obj);
+};
+
+/***/ }),
+/* 13 */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE__13__;
+
+/***/ }),
+/* 14 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+exports.__esModule = !0;
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+/**
+ * CSS class names definition
+ * @private
+ */
+exports.default = {
+ arc: "bb-arc",
+ arcs: "bb-arcs",
+ area: "bb-area",
+ areas: "bb-areas",
+ axis: "bb-axis",
+ axisX: "bb-axis-x",
+ axisXLabel: "bb-axis-x-label",
+ axisY: "bb-axis-y",
+ axisY2: "bb-axis-y2",
+ axisY2Label: "bb-axis-y2-label",
+ axisYLabel: "bb-axis-y-label",
+ bar: "bb-bar",
+ bars: "bb-bars",
+ brush: "bb-brush",
+ button: "bb-button",
+ buttonZoomReset: "bb-zoom-reset",
+ chart: "bb-chart",
+ chartArc: "bb-chart-arc",
+ chartArcs: "bb-chart-arcs",
+ chartArcsBackground: "bb-chart-arcs-background",
+ chartArcsGaugeMax: "bb-chart-arcs-gauge-max",
+ chartArcsGaugeMin: "bb-chart-arcs-gauge-min",
+ chartArcsGaugeUnit: "bb-chart-arcs-gauge-unit",
+ chartArcsTitle: "bb-chart-arcs-title",
+ chartBar: "bb-chart-bar",
+ chartBars: "bb-chart-bars",
+ chartLine: "bb-chart-line",
+ chartLines: "bb-chart-lines",
+ chartRadar: "bb-chart-radar",
+ chartRadars: "bb-chart-radars",
+ chartText: "bb-chart-text",
+ chartTexts: "bb-chart-texts",
+ circle: "bb-circle",
+ circles: "bb-circles",
+ colorPattern: "bb-color-pattern",
+ defocused: "bb-defocused",
+ dragarea: "bb-dragarea",
+ empty: "bb-empty",
+ eventRect: "bb-event-rect",
+ eventRects: "bb-event-rects",
+ eventRectsMultiple: "bb-event-rects-multiple",
+ eventRectsSingle: "bb-event-rects-single",
+ focused: "bb-focused",
+ gaugeValue: "bb-gauge-value",
+ grid: "bb-grid",
+ gridLines: "bb-grid-lines",
+ legendBackground: "bb-legend-background",
+ legendItem: "bb-legend-item",
+ legendItemEvent: "bb-legend-item-event",
+ legendItemFocused: "bb-legend-item-focused",
+ legendItemHidden: "bb-legend-item-hidden",
+ legendItemPoint: "bb-legend-item-point",
+ legendItemTile: "bb-legend-item-tile",
+ level: "bb-level",
+ levels: "bb-levels",
+ line: "bb-line",
+ lines: "bb-lines",
+ region: "bb-region",
+ regions: "bb-regions",
+ selectedCircle: "bb-selected-circle",
+ selectedCircles: "bb-selected-circles",
+ shape: "bb-shape",
+ shapes: "bb-shapes",
+ target: "bb-target",
+ text: "bb-text",
+ texts: "bb-texts",
+ title: "bb-title",
+ tooltip: "bb-tooltip",
+ tooltipContainer: "bb-tooltip-container",
+ tooltipName: "bb-tooltip-name",
+ xgrid: "bb-xgrid",
+ xgridFocus: "bb-xgrid-focus",
+ xgridLine: "bb-xgrid-line",
+ xgridLines: "bb-xgrid-lines",
+ xgrids: "bb-xgrids",
+ ygrid: "bb-ygrid",
+ ygridLine: "bb-ygrid-line",
+ ygridLines: "bb-ygrid-lines",
+ ygrids: "bb-ygrids",
+ zoomBrush: "bb-zoom-brush",
+ zoomRect: "bb-zoom-rect",
+ EXPANDED: "_expanded_",
+ SELECTED: "_selected_",
+ INCLUDED: "_included_"
+};
+module.exports = exports["default"];
+
+/***/ }),
+/* 15 */
+/***/ (function(module, exports, __webpack_require__) {
+
+// extracted by mini-css-extract-plugin
+
+/***/ }),
+/* 16 */,
+/* 17 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _Options = __webpack_require__(18),
+ _Options2 = _interopRequireDefault(_Options),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ getOptions: function getOptions() {
+ var config = new _Options2.default();
+
+ return (0, _util.merge)(config.value, this.additionalConfig);
+ },
+
+
+ additionalConfig: {},
+
+ /**
+ * Load configuration option
+ * @param {Object} config User's generation config value
+ * @private
+ */
+ loadConfig: function loadConfig(config) {
+ var thisConfig = this.config,
+ target = void 0,
+ keys = void 0,
+ read = void 0,
+ find = function () {
+ var key = keys.shift();
+
+ return key && target && (0, _util.isObjectType)(target) && key in target ? (target = target[key], find()) : key ? undefined : target;
+ };
+
+ Object.keys(thisConfig).forEach(function (key) {
+ target = config, keys = key.split("_"), read = find(), (0, _util.isDefined)(read) && (thisConfig[key] = read);
+ });
+ }
+}); /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+/***/ }),
+/* 18 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+exports.__esModule = !0;
+
+var _classCallCheck2 = __webpack_require__(2),
+ _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+/**
+ * Class to set options on generating chart.
+ * - It's instantiated internally, not exposed for public.
+ * @class Options
+ * @see {@link bb.generate} to use these options on generating the chart
+ */
+var Options = function Options() {
+ (0, _classCallCheck3.default)(this, Options), this.value = {
+ /**
+ * Specify the CSS selector or the element which the chart will be set to. D3 selection object can be specified also.
+ * If other chart is set already, it will be replaced with the new one (only one chart can be set in one element).<br><br>
+ * If this option is not specified, the chart will be generated but not be set. Instead, we can access the element by chart.element and set it by ourselves.<br>
+ * @name bindto
+ * @memberOf Options
+ * @property {String|HTMLElement|d3.selection} bindto=#chart Specify the element where chart will be drawn.
+ * @property {String|HTMLElement|d3.selection} bindto.element=#chart Specify the element where chart will be drawn.
+ * @property {String} [bindto.classname=bb] Specify the class name of bind element.<br>
+ * **NOTE:** When class name isn't `bb`, then you also need to update the default CSS to be rendered correctly.
+ * @default #chart
+ * @example
+ * bindto: "#myContainer"
+ *
+ * // or HTMLElement
+ * bindto: document.getElementById("myContainer")
+ *
+ * // or D3 selection object
+ * bindto: d3.select("#myContainer")
+ *
+ * // or to change default classname
+ * bindto: {
+ * element: "#chart",
+ * classname: "bill-board" // ex) <div id='chart' class='bill-board'>
+ * }
+ */
+ bindto: "#chart",
+
+ /**
+ * Set 'clip-path' attribute for chart element
+ * - **NOTE:**
+ * > When is false, chart node element is positioned after the axis node in DOM tree hierarchy.
+ * > Is to make chart element positioned over axis element.
+ * @name clipPath
+ * @memberOf Options
+ * @type {Boolean}
+ * @default true
+ * @example
+ * // don't set 'clip-path' attribute
+ * clipPath: false
+ */
+ clipPath: !0,
+
+ /**
+ * Set svg element's class name
+ * @name svg
+ * @memberOf Options
+ * @type {Object}
+ * @property {String} [svg.classname] class name for svg element
+ * @example
+ * svg: {
+ * classname: "test_class"
+ * }
+ */
+ svg_classname: undefined,
+
+ /**
+ * The desired size of the chart element.
+ * If value is not specified, the width of the chart will be calculated by the size of the parent element it's appended to.
+ * @name size
+ * @memberOf Options
+ * @type {Object}
+ * @property {Number} [size.width] width of the chart element
+ * @property {Number} [size.height] height of the chart element
+ * @example
+ * size: {
+ * width: 640,
+ * height: 480
+ * }
+ */
+ size_width: undefined,
+ size_height: undefined,
+
+ /**
+ * The padding of the chart element.
+ * @name padding
+ * @memberOf Options
+ * @type {Object}
+ * @property {Number} [padding.top] padding on the top of chart
+ * @property {Number} [padding.right] padding on the right of chart
+ * @property {Number} [padding.bottom] padding on the bottom of chart
+ * @property {Number} [padding.left] padding on the left of chart
+ * @example
+ * padding: {
+ * top: 20,
+ * right: 20,
+ * bottom: 20,
+ * left: 20
+ * }
+ */
+ padding_left: undefined,
+ padding_right: undefined,
+ padding_top: undefined,
+ padding_bottom: undefined,
+
+ /**
+ * Set chart resize options
+ * @name resize
+ * @memberOf Options
+ * @type {Object}
+ * @property {Boolean} [resize.auto=true] Set chart resize automatically on viewport changes.
+ * @example
+ * resize: {
+ * auto: false
+ * }
+ */
+ resize_auto: !0,
+
+ /**
+ * Set zoom options
+ * @name zoom
+ * @memberOf Options
+ * @type {Object}
+ * @property {Boolean} [zoom.enabled=false] Enable zooming.
+ * @property {String} [zoom.enabled.type='wheel'] Set zoom interaction type.
+ * - **Available types:**
+ * - wheel
+ * - drag
+ * @property {Boolean} [zoom.rescale=false] Enable to rescale after zooming.<br>
+ * If true set, y domain will be updated according to the zoomed region.
+ * @property {Array} [zoom.extent=[1, 10]] Change zoom extent.
+ * @property {Number} [zoom.x.min] Set x Axis minimum zoom range
+ * @property {Number} [zoom.x.max] Set x Axis maximum zoom range
+ * @property {Function} [zoom.onzoomstart=undefined] Set callback that is called when zooming starts.<br>
+ * Specified function receives the zoom event.
+ * @property {Function} [zoom.onzoom=undefined] Set callback that is called when the chart is zooming.<br>
+ * Specified function receives the zoomed domain.
+ * @property {Function} [zoom.onzoomend=undefined] Set callback that is called when zooming ends.<br>
+ * Specified function receives the zoomed domain.
+ * @property {Boolean|Object} [zoom.resetButton=true] Set to display zoom reset button for 'drag' type zoom
+ * @property {String} [zoom.resetButton.text='Reset Zoom'] Text value for zoom reset button.
+ * @example
+ * zoom: {
+ * enabled: {
+ * type: "drag"
+ * },
+ * rescale: true,
+ * extent: [1, 100] // enable more zooming
+ * x: {
+ * min: -1, // set min range
+ * max: 10 // set max range
+ * },
+ * onzoomstart: function(event) { ... },
+ * onzoom: function(domain) { ... },
+ * onzoomend: function(domain) { ... },
+ *
+ * // show reset button when is zoomed-in
+ * resetButton: true,
+ *
+ * // customized text value for reset zoom button
+ * resetButton: {
+ * text: "Unzoom"
+ * }
+ * }
+ */
+ zoom_enabled: undefined,
+ zoom_extent: undefined,
+ zoom_privileged: !1,
+ zoom_rescale: !1,
+ zoom_onzoom: undefined,
+ zoom_onzoomstart: undefined,
+ zoom_onzoomend: undefined,
+ zoom_resetButton: !0,
+ zoom_x_min: undefined,
+ zoom_x_max: undefined,
+
+ /**
+ * Interaction options
+ * @name interaction
+ * @memberOf Options
+ * @type {Object}
+ * @property {Boolean} [interaction.enabled=true] Indicate if the chart should have interactions.<br>
+ * If `false` is set, all of interactions (showing/hiding tooltip, selection, mouse events, etc) will be disabled.
+ * @property {Boolean} [interaction.brighten=true] Make brighter for the selected area (ex. 'pie' type data selected area)
+ * @property {Boolean} [interaction.inputType.mouse=true] enable or disable mouse interaction
+ * @property {Boolean} [interaction.inputType.touch=true] enable or disable touch interaction
+ * @property {Boolean|Number} [interaction.inputType.touch.preventDefault=false] enable or disable to call event.preventDefault on touchstart & touchmove event. It's usually used to prevent document scrolling.
+ * @example
+ * interaction: {
+ * enabled: false,
+ * inputType: {
+ * mouse: true,
+ * touch: false
+ *
+ * // or declare preventDefault explicitly.
+ * // In this case touch inputType is enabled by default
+ * touch: {
+ * preventDefault: true
+ *
+ * // or threshold pixel value (pixel moved from touchstart to touchmove)
+ * preventDefault: 5
+ * }
+ * }
+ * }
+ */
+ interaction_enabled: !0,
+ interaction_brighten: !0,
+ interaction_inputType_mouse: !0,
+ interaction_inputType_touch: {},
+
+ /**
+ * Set a callback to execute when mouse/touch enters the chart.
+ * @name onover
+ * @memberOf Options
+ * @type {Function}
+ * @default function(){}
+ * @example
+ * onover: function() {
+ * ...
+ * }
+ */
+ onover: function onover() {},
+
+ /**
+ * Set a callback to execute when mouse/touch leaves the chart.
+ * @name onout
+ * @memberOf Options
+ * @type {Function}
+ * @default function(){}
+ * @example
+ * onout: function() {
+ * ...
+ * }
+ */
+ onout: function onout() {},
+
+ /**
+ * Set a callback to execute when user resizes the screen.
+ * @name onresize
+ * @memberOf Options
+ * @type {Function}
+ * @default function(){}
+ * @example
+ * onresize: function() {
+ * ...
+ * }
+ */
+ onresize: function onresize() {},
+
+ /**
+ * SSet a callback to execute when screen resize finished.
+ * @name onresized
+ * @memberOf Options
+ * @type {Function}
+ * @default function(){}
+ * @example
+ * onresized: function() {
+ * ...
+ * }
+ */
+ onresized: function onresized() {},
+
+ /**
+ * Set a callback to execute before the chart is initialized
+ * @name onbeforeinit
+ * @memberOf Options
+ * @type {Function}
+ * @default function(){}
+ * @example
+ * onbeforeinit: function() {
+ * ...
+ * }
+ */
+ onbeforeinit: undefined,
+
+ /**
+ * Set a callback to execute when the chart is initialized.
+ * @name oninit
+ * @memberOf Options
+ * @type {Function}
+ * @default function(){}
+ * @example
+ * oninit: function() {
+ * ...
+ * }
+ */
+ oninit: function oninit() {},
+
+ /**
+ * Set a callback to execute after the chart is initialized
+ * @name onafterinit
+ * @memberOf Options
+ * @type {Function}
+ * @default function(){}
+ * @example
+ * onafterinit: function() {
+ * ...
+ * }
+ */
+ onafterinit: undefined,
+
+ /**
+ * Set a callback which is executed when the chart is rendered. Basically, this callback will be called in each time when the chart is redrawed.
+ * @name onrendered
+ * @memberOf Options
+ * @type {Function}
+ * @default undefined
+ * @example
+ * onrendered: function() {
+ * ...
+ * }
+ */
+ onrendered: undefined,
+
+ /**
+ * Set duration of transition (in milliseconds) for chart animation.<br><br>
+ * - **NOTE:** If `0 `or `null` set, transition will be skipped. So, this makes initial rendering faster especially in case you have a lot of data.
+ * @name transition
+ * @memberOf Options
+ * @type {Object}
+ * @property {Number} [transition.duration=350] duration in milliseconds
+ * @example
+ * transition: {
+ * duration: 500
+ * }
+ */
+ transition_duration: 350,
+
+ /**
+ * Specify the key of x values in the data.<br><br>
+ * We can show the data with non-index x values by this option. This option is required when the type of x axis is timeseries. If this option is set on category axis, the values of the data on the key will be used for category names.
+ * @name data․x
+ * @memberOf Options
+ * @type {String}
+ * @default undefined
+ * @example
+ * data: {
+ * x: "date"
+ * }
+ */
+ data_x: undefined,
+
+ /**
+ * Specify the keys of the x values for each data.<br><br>
+ * This option can be used if we want to show the data that has different x values.
+ * @name data․xs
+ * @memberOf Options
+ * @type {Object}
+ * @default {}
+ * @example
+ * data: {
+ * xs: {
+ * data1: "x1",
+ * data2: "x2"
+ * }
+ * }
+ */
+ data_xs: {},
+
+ /**
+ * Set a format to parse string specifed as x.
+ * @name data․xFormat
+ * @memberOf Options
+ * @type {String}
+ * @default %Y-%m-%d
+ * @example
+ * data: {
+ * xFormat: "%Y-%m-%d %H:%M:%S"
+ * }
+ * @see [D3's time specifier](https://npm.runkit.com/d3-time-format)
+ */
+ data_xFormat: "%Y-%m-%d",
+
+ /**
+ * Set localtime format to parse x axis.
+ * @name data․xLocaltime
+ * @memberOf Options
+ * @type {Boolean}
+ * @default true
+ * @example
+ * data: {
+ * xLocaltime: false
+ * }
+ */
+ data_xLocaltime: !0,
+
+ /**
+ * Sort on x axis.
+ * @name data․xSort
+ * @memberOf Options
+ * @type {Boolean}
+ * @default true
+ * @example
+ * data: {
+ * xSort: false
+ * }
+ */
+ data_xSort: !0,
+ data_idConverter: function data_idConverter(id) {
+ return id;
+ },
+
+ /**
+ * Set custom data name.
+ * @name data․names
+ * @memberOf Options
+ * @type {Object}
+ * @default {}
+ * @example
+ * data: {
+ * names: {
+ * data1: "Data Name 1",
+ * data2: "Data Name 2"
+ * }
+ * }
+ */
+ data_names: {},
+
+ /**
+ * Set custom data class.<br><br>
+ * If this option is specified, the element g for the data has an additional class that has the prefix 'bb-target-' (eg. bb-target-additional-data1-class).
+ * @name data․classes
+ * @memberOf Options
+ * @type {Object}
+ * @default {}
+ * @example
+ * data: {
+ * classes: {
+ * data1: "additional-data1-class",
+ * data2: "additional-data2-class"
+ * }
+ * }
+ */
+ data_classes: {},
+
+ /**
+ * Set groups for the data for stacking.
+ * @name data․groups
+ * @memberOf Options
+ * @type {Array}
+ * @default []
+ * @example
+ * data: {
+ * groups: [
+ * ["data1", "data2"],
+ * ["data3"]
+ * ]
+ * }
+ */
+ data_groups: [],
+
+ /**
+ * Set y axis the data related to. y and y2 can be used.
+ * @name data․axes
+ * @memberOf Options
+ * @type {Object}
+ * @default {}
+ * @example
+ * data: {
+ * axes: {
+ * data1: "y",
+ * data2: "y2"
+ * }
+ * }
+ */
+ data_axes: {},
+
+ /**
+ * Set chart type at once.<br><br>
+ * If this option is specified, the type will be applied to every data. This setting can be overwritten by data.types.<br><br>
+ * **Available Values:**
+ * - area
+ * - area-line-range
+ * - area-spline
+ * - area-spline-range
+ * - area-step
+ * - bar
+ * - bubble
+ * - donut
+ * - gauge
+ * - line
+ * - pie
+ * - radar
+ * - scatter
+ * - spline
+ * - step
+ * @name data․type
+ * @memberOf Options
+ * @type {String}
+ * @default line
+ * @example
+ * data: {
+ * type: "bar"
+ * }
+ */
+ data_type: undefined,
+
+ /**
+ * Set chart type for each data.<br>
+ * This setting overwrites data.type setting.
+ * - **NOTE:** `radar` type can't be combined with other types.
+ * @name data․types
+ * @memberOf Options
+ * @type {Object}
+ * @default {}
+ * @example
+ * data: {
+ * types: {
+ * data1: "bar",
+ * data2: "spline"
+ * }
+ * }
+ */
+ data_types: {},
+
+ /**
+ * Set labels options
+ * @name data․labels
+ * @memberOf Options
+ * @type {Object}
+ * @property {Boolean} [data.labels=false] Show or hide labels on each data points
+ * @property {Function} [data.labels.format={}] Set formatter function for data labels.<br>
+ * The formatter function receives 4 arguments such as v, id, i, j and it must return a string that will be shown as the label. The arguments are:<br>
+ * - `v` is the value of the data point where the label is shown.
+ * - `id` is the id of the data where the label is shown.
+ * - `i` is the index of the data point where the label is shown.
+ * - `j` is the sub index of the data point where the label is shown.<br><br>
+ * Formatter function can be defined for each data by specifying as an object and D3 formatter function can be set (ex. d3.format('$'))
+ * @property {Number} [data.labels.position.x=0] x coordinate position, relative the original.
+ * @property {NUmber} [data.labels.position.y=0] y coordinate position, relative the original.
+ * @memberOf Options
+ * @type {Object}
+ * @default {}
+ * @example
+ * data: {
+ * labels: true,
+ *
+ * // or set specific options
+ * labels: {
+ * format: function(v, id, i, j) { ... },
+ *
+ * // it's possible to set for each data
+ * format: {
+ * data1: function(v, id, i, j) { ... },
+ * ...
+ * },
+ * position: {
+ * x: -10,
+ * y: 10
+ * }
+ * }
+ * }
+ */
+ data_labels: {},
+ data_labels_position: {},
+
+ /**
+ * This option changes the order of stacking data and pieces of pie/donut.
+ * - If `null` specified, it will be the order the data loaded.
+ * - If function specified, it will be used as [Array.sort compareFunction](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort#Parameters)<br><br>
+ *
+ * **Available Values:**
+ * - `desc`: In descending order
+ * - `asc`: In ascending order
+ * - `null`: It keeps the data load order
+ * - `function(data1, data2) { ... }`: Array.sort compareFunction
+ * @name data․order
+ * @memberOf Options
+ * @type {String|Function|null}
+ * @default desc
+ * @example
+ * data: {
+ * // in descending order (default)
+ * order: "desc"
+ *
+ * // in ascending order
+ * order: "asc"
+ *
+ * // keeps data input order
+ * order: null
+ *
+ * // specifying sort function
+ * order: function(a, b) {
+ * // param data passed format
+ * {
+ * id: "data1", id_org: "data1", values: [
+ * {x: 5, value: 250, id: "data1", index: 5, name: "data1"},
+ * ...
+ * ]
+ * }
+ * }
+ * }
+ */
+ data_order: "desc",
+
+ /**
+ * Define regions for each data.<br>
+ * The values must be an array for each data and it should include an object that has `start`, `end` and `style`.
+ * - The object type should be as:
+ * - start {Number}: Start data point number. If not set, the start will be the first data point.
+ * - [end] {Number}: End data point number. If not set, the end will be the last data point.
+ * - [style.dasharray="2 2"] {Object}: The first number specifies a distance for the filled area, and the second a distance for the unfilled area.
+ * - **NOTE:** Currently this option supports only line chart and dashed style. If this option specified, the line will be dashed only in the regions.
+ * @name data․regions
+ * @memberOf Options
+ * @type {Object}
+ * @default {}
+ * @example
+ * data: {
+ * regions: {
+ * data1: [{
+ * start: 1,
+ * end: 2,
+ * style: {
+ * dasharray: "5 2"
+ * }
+ * }, {
+ * start: 3
+ * }],
+ * ...
+ * }
+ * }
+ */
+ data_regions: {},
+
+ /**
+ * Set color converter function.<br><br>
+ * This option should a function and the specified function receives color (e.g. '#ff0000') and d that has data parameters like id, value, index, etc. And it must return a string that represents color (e.g. '#00ff00').
+ * @name data․color
+ * @memberOf Options
+ * @type {Function}
+ * @default undefined
+ * @example
+ * data: {
+ * color: function(color, d) { ... }
+ * }
+ */
+ data_color: undefined,
+
+ /**
+ * Set color for each data.
+ * @name data․colors
+ * @memberOf Options
+ * @type {Object}
+ * @default {}
+ * @example
+ * data: {
+ * colors: {
+ * data1: "#ff0000",
+ * ...
+ * }
+ * }
+ */
+ data_colors: {},
+
+ /**
+ * Hide each data when the chart appears.<br><br>
+ * If true specified, all of data will be hidden. If multiple ids specified as an array, those will be hidden.
+ * @name data․hide
+ * @memberOf Options
+ * @type {Boolean|Array}
+ * @default false
+ * @example
+ * data: {
+ * // all of data will be hidden
+ * hide: true
+ *
+ * // specified data will be hidden
+ * hide: ["data1", ...]
+ * }
+ */
+ data_hide: !1,
+ data_filter: undefined,
+
+ /**
+ * Set data selection enabled.<br><br>
+ * If this option is set true, we can select the data points and get/set its state of selection by API (e.g. select, unselect, selected).
+ * @name data․selection․enabled
+ * @memberOf Options
+ * @type {Boolean}
+ * @default false
+ * @example
+ * data: {
+ * selection: {
+ * enabled: true
+ * }
+ * }
+ */
+ data_selection_enabled: !1,
+
+ /**
+ * Set grouped selection enabled.<br><br>
+ * If this option set true, multiple data points that have same x value will be selected by one selection.
+ * @name data․selection․grouped
+ * @memberOf Options
+ * @type {Boolean}
+ * @default false
+ * @example
+ * data: {
+ * selection: {
+ * grouped: true
+ * }
+ * }
+ */
+ data_selection_grouped: !1,
+
+ /**
+ * Set a callback for each data point to determine if it's selectable or not.<br><br>
+ * The callback will receive d as an argument and it has some parameters like id, value, index. This callback should return boolean.
+ * @name data․selection․isselectable
+ * @memberOf Options
+ * @type {Function}
+ * @default function() { return true; }
+ * @example
+ * data: {
+ * selection: {
+ * isselectable: function(d) { ... }
+ * }
+ * }
+ */
+ data_selection_isselectable: function data_selection_isselectable() {
+ return !0;
+ },
+
+ /**
+ * Set multiple data points selection enabled.<br><br>
+ * If this option set true, multile data points can have the selected state at the same time. If false set, only one data point can have the selected state and the others will be unselected when the new data point is selected.
+ * @name data․selection․multiple
+ * @memberOf Options
+ * @type {Boolean}
+ * @default true
+ * @example
+ * data: {
+ * selection: {
+ * multiple: false
+ * }
+ * }
+ */
+ data_selection_multiple: !0,
+
+ /**
+ * Enable to select data points by dragging.
+ * If this option set true, data points can be selected by dragging.
+ * - **NOTE:** If this option set true, scrolling on the chart will be disabled because dragging event will handle the event.
+ * @name data․selection․draggable
+ * @memberOf Options
+ * @type {Boolean}
+ * @default false
+ * @example
+ * data: {
+ * selection: {
+ * draggable: true
+ * }
+ * }
+ */
+ data_selection_draggable: !1,
+
+ /**
+ * Set a callback for click event on each data point.<br><br>
+ * This callback will be called when each data point clicked and will receive d and element as the arguments. d is the data clicked and element is the element clicked. In this callback, this will be the Chart object.
+ * @name data․onclick
+ * @memberOf Options
+ * @type {Function}
+ * @default function() {}
+ * @example
+ * data: {
+ * onclick: function(d, element) { ... }
+ * }
+ */
+ data_onclick: function data_onclick() {},
+
+ /**
+ * Set a callback for mouse/touch over event on each data point.<br><br>
+ * This callback will be called when mouse cursor or via touch moves onto each data point and will receive d as the argument. d is the data where mouse cursor moves onto. In this callback, this will be the Chart object.
+ * @name data․onover
+ * @memberOf Options
+ * @type {Function}
+ * @default function() {}
+ * @example
+ * data: {
+ * onover: function(d) { ... }
+ * }
+ */
+ data_onover: function data_onover() {},
+
+ /**
+ * Set a callback for mouse/touch out event on each data point.<br><br>
+ * This callback will be called when mouse cursor or via touch moves out each data point and will receive d as the argument. d is the data where mouse cursor moves out. In this callback, this will be the Chart object.
+ * @name data․onout
+ * @memberOf Options
+ * @type {Function}
+ * @default function() {}
+ * @example
+ * data: {
+ * onout: function(d) { ... }
+ * }
+ */
+ data_onout: function data_onout() {},
+
+ /**
+ * Set a callback for on data selection.
+ * @name data․onselected
+ * @memberOf Options
+ * @type {Function}
+ * @default function() {}
+ * @example
+ * data: {
+ * onselected: function(d, element) {
+ * // d - ex) {x: 4, value: 150, id: "data1", index: 4, name: "data1"}
+ * // element - <circle>
+ * ...
+ * }
+ * }
+ */
+ data_onselected: function data_onselected() {},
+
+ /**
+ * Set a callback for on data un-selection.
+ * @name data․onunselected
+ * @memberOf Options
+ * @type {Function}
+ * @default function() {}
+ * @example
+ * data: {
+ * onunselected: function(d, element) {
+ * // d - ex) {x: 4, value: 150, id: "data1", index: 4, name: "data1"}
+ * // element - <circle>
+ * ...
+ * }
+ * }
+ */
+ data_onunselected: function data_onunselected() {},
+
+ /**
+ * Set a callback for minimum data
+ * - **NOTE:** For 'area-line-range' and 'area-spline-range', `mid` data will be taken for the comparison
+ * @name data․onmin
+ * @memberOf Options
+ * @type {Function}
+ * @default undefined
+ * @example
+ * onmin: function(data) {
+ * // data - ex) [{x: 3, value: 400, id: "data1", index: 3}, ... ]
+ * ...
+ * }
+ */
+ data_onmin: undefined,
+
+ /**
+ * Set a callback for maximum data
+ * - **NOTE:** For 'area-line-range' and 'area-spline-range', `mid` data will be taken for the comparison
+ * @name data․onmax
+ * @memberOf Options
+ * @type {Function}
+ * @default undefined
+ * @example
+ * onmax: function(data) {
+ * // data - ex) [{x: 3, value: 400, id: "data1", index: 3}, ... ]
+ * ...
+ * }
+ */
+ data_onmax: undefined,
+
+ /**
+ * Load a CSV or JSON file from a URL. NOTE that this will not work if loading via the "file://" protocol as the most browsers will block XMLHTTPRequests.
+ * @name data․url
+ * @memberOf Options
+ * @type {String}
+ * @default undefined
+ * @example
+ * data: {
+ * url: "/data/test.csv"
+ * }
+ */
+ data_url: undefined,
+ data_headers: undefined,
+
+ /**
+ * Parse a JSON object for data. See also data.keys.
+ * @name data․json
+ * @memberOf Options
+ * @type {Object}
+ * @default undefined
+ * @see data․keys
+ * @example
+ * data: {
+ * json: [
+ * {name: "www.site1.com", upload: 200, download: 200, total: 400},
+ * {name: "www.site2.com", upload: 100, download: 300, total: 400},
+ * {name: "www.site3.com", upload: 300, download: 200, total: 500},
+ * {name: "www.site4.com", upload: 400, download: 100, total: 500}
+ * ],
+ * keys: {
+ * // x: "name", // it's possible to specify 'x' when category axis
+ * value: ["upload", "download"]
+ * }
+ * }
+ */
+ data_json: undefined,
+
+ /**
+ * Load data from a multidimensional array, with the first element containing the data names, the following containing related data in that order.
+ * @name data․rows
+ * @memberOf Options
+ * @type {Array}
+ * @default undefined
+ * @example
+ * data: {
+ * rows: [
+ * ["A", "B", "C"],
+ * [90, 120, 300],
+ * [40, 160, 240],
+ * [50, 200, 290],
+ * [120, 160, 230],
+ * [80, 130, 300],
+ * [90, 220, 320]
+ * ]
+ * }
+ *
+ * // for 'range' types('area-line-range' or 'area-spline-range'), data should contain:
+ * // - an array of [high, mid, low] data following the order
+ * // - or an object with 'high', 'mid' and 'low' key value
+ * data: {
+ * rows: [
+ * ["data1", "data2"],
+ * [
+ * // or {high:150, mid: 140, low: 110}, 120
+ * [150, 140, 110], 120
+ * ],
+ * [[155, 130, 115], 55],
+ * [[160, 135, 120], 60]
+ * ],
+ * types: {
+ * data1: "area-line-range",
+ * data2: "line"
+ * }
+ * }
+ */
+ data_rows: undefined,
+
+ /**
+ * Load data from a multidimensional array, with each element containing an array consisting of a datum name and associated data values.
+ * @name data․columns
+ * @memberOf Options
+ * @type {Array}
+ * @default undefined
+ * @example
+ * data: {
+ * columns: [
+ * ["data1", 30, 20, 50, 40, 60, 50],
+ * ["data2", 200, 130, 90, 240, 130, 220],
+ * ["data3", 300, 200, 160, 400, 250, 250]
+ * ]
+ * }
+ *
+ * // for 'range' types('area-line-range' or 'area-spline-range'), data should contain:
+ * // - an array of [high, mid, low] data following the order
+ * // - or an object with 'high', 'mid' and 'low' key value
+ * data: {
+ * columns: [
+ * ["data1",
+ * [150, 140, 110], // or {high:150, mid: 140, low: 110}
+ * [150, 140, 110],
+ * [150, 140, 110]
+ * ]
+ * ],
+ * type: "area-line-range"
+ * }
+ */
+ data_columns: undefined,
+
+ /**
+ * Used if loading JSON via data.url.
+ * @name data․mimeType
+ * @memberOf Options
+ * @type {String}
+ * @default undefined
+ * @example
+ * data: {
+ * mimeType: "json"
+ * }
+ */
+ data_mimeType: undefined,
+
+ /**
+ * Choose which JSON object keys correspond to desired data.
+ * @name data․keys
+ * @memberOf Options
+ * @type {String}
+ * @default undefined
+ * @example
+ * data: {
+ * json: [
+ * {name: "www.site1.com", upload: 200, download: 200, total: 400},
+ * {name: "www.site2.com", upload: 100, download: 300, total: 400},
+ * {name: "www.site3.com", upload: 300, download: 200, total: 500},
+ * {name: "www.site4.com", upload: 400, download: 100, total: 500}
+ * ],
+ * keys: {
+ * // x: "name", // it's possible to specify 'x' when category axis
+ * value: ["upload", "download"]
+ * }
+ * }
+ */
+ data_keys: undefined,
+
+ /**
+ * Set text displayed when empty data.
+ * @name data․empty․label․text
+ * @memberOf Options
+ * @type {String}
+ * @default ""
+ * @example
+ * data: {
+ * empty: {
+ * label: {
+ * text: "No Data"
+ * }
+ * }
+ * }
+ */
+ data_empty_label_text: "",
+
+ /**
+ * Set subchart options
+ * @name subchart
+ * @memberOf Options
+ * @type {Object}
+ * @property {Boolean} [subchart.show=false] Show sub chart on the bottom of the chart.
+ * @property {Boolean} [subchart.size.height] Change the height of the subchart.
+ * @property {Boolean} [subchart.onbrush] Set callback for brush event.<br>
+ * Specified function receives the current zoomed x domain.
+ * @example
+ * subchart: {
+ * show: true,
+ * size: {
+ * height: 20
+ * },
+ * onbrush: function(domain) { ... }
+ * }
+ */
+ subchart_show: !1,
+ subchart_size_height: 60,
+ subchart_axis_x_show: !0,
+ subchart_onbrush: function subchart_onbrush() {},
+
+ /**
+ * Set color of the data values
+ * @name color
+ * @memberOf Options
+ * @type {Object}
+ * @property {Array} [color.pattern] custom color pattern
+ * @property {Function} [color.tiles] if defined, allows use svg's patterns to fill data area. It should return an array of [SVGPatternElement](https://developer.mozilla.org/en-US/docs/Web/API/SVGPatternElement).
+ * - **NOTE:** The pattern element's id will be defined as `bb-colorize-pattern-$COLOR-VALUE`.<br>
+ * ex. When color pattern value is `['red', '#fff']` and defined 2 patterns,then ids for pattern elements are:<br>
+ * - `bb-colorize-pattern-red`
+ * - `bb-colorize-pattern-fff`
+ * @property {Object} [color.threshold] color threshold
+ * @property {String} [color.threshold.unit] unit
+ * @property {Array} [color.threshold.value] value
+ * @property {Array} [color.threshold.max=100] max value
+ * @example
+ * color: {
+ * pattern: ["#1f77b4", "#aec7e8", ...],
+ *
+ * // Set colors' patterns
+ * // it should return an array of SVGPatternElement
+ * tiles: function() {
+ * var pattern = document.createElementNS("http://www.w3.org/2000/svg", "pattern");
+ * var g = document.createElementNS("http://www.w3.org/2000/svg", "g");
+ * var circle1 = document.createElementNS("http://www.w3.org/2000/svg", "circle");
+ *
+ * pattern.setAttribute("patternUnits", "userSpaceOnUse");
+ * pattern.setAttribute("width", "32");
+ * pattern.setAttribute("height", "32");
+ *
+ * g.style.fill = "#000";
+ * g.style.opacity = "0.2";
+ *
+ * circle1.setAttribute("cx", "3");
+ * circle1.setAttribute("cy", "3");
+ * circle1.setAttribute("r", "3");
+ *
+ * g.appendChild(circle1);
+ * pattern.appendChild(g);
+ *
+ * return [pattern];
+ * }
+ * }
+ */
+ color_pattern: [],
+ color_tiles: undefined,
+ color_threshold: {},
+
+ /**
+ * Legend options
+ * @name legend
+ * @memberOf Options
+ * @type {Object}
+ * @property {Boolean} [legend.show=true] Show or hide legend.
+ * @property {Boolean} [legend.hide=false] Hide legend
+ * If true given, all legend will be hidden. If string or array given, only the legend that has the id will be hidden.
+ * @property {String|HTMLElement} [legend.contents.bindto=undefined] Set CSS selector or element reference to bind legend items.
+ * @property {String|Function} [legend.contents.template=undefined] Set item's template.<br>
+ * - If set `string` value, within template the 'color' and 'title' can be replaced using template-like syntax string:
+ * - {=COLOR}: data color value
+ * - {=TITLE}: data title value
+ * - If set `function` value, will pass following arguments to the given function:
+ * - title {String}: data's id value
+ * - color {String}: color string
+ * - data {Array}: data array
+ * @property {String} [legend.position=bottom] Change the position of legend.<br>
+ * Available values are: `bottom`, `right` and `inset` are supported.
+ * @property {Object} [legend.inset={anchor: 'top-left',x: 10,y: 0,step: undefined}] Change inset legend attributes.<br>
+ * This option accepts object that has the keys `anchor`, `x`, `y` and `step`.
+ * - **anchor** decides the position of the legend:
+ * - top-left
+ * - top-right
+ * - bottom-left
+ * - bottom-right
+ * - **x** and **y**:
+ * - set the position of the legend based on the anchor.
+ * - **step**:
+ * - defines the max step the legend has (e.g. If 2 set and legend has 3 legend item, the legend 2 columns).
+ * @property {Boolean} [legend.equally=false] Set to all items have same width size.
+ * @property {Boolean} [legend.padding=0] Set padding value
+ * @property {Function} [legend.item.onclick=undefined] Set click event handler to the legend item.
+ * @property {Function} [legend.item.onover=undefined] Set mouse/touch over event handler to the legend item.
+ * @property {Function} [legend.item.onout=undefined] Set mouse/touch out event handler to the legend item.
+ * @property {Number} [legend.item.tile.width=10] Set width of item tile element
+ * @property {Number} [legend.item.tile.height=10] Set height of item tile element
+ * @property {Boolean} [legend.usePoint=false] Whether to use custom points in legend.
+ * @example
+ * legend: {
+ * show: true,
+ * hide: true,
+ * //or hide: "data1"
+ * //or hide: ["data1", "data2"]
+ * contents: {
+ * bindto: "#legend", // <ul id='legend'></ul>
+ *
+ * // will be as: <li style='background-color:#1f77b4'>data1</li>
+ * template: "<li style='background-color:{=COLOR}'>{=TITLE}</li>"
+ *
+ * // or using function
+ * template: function(id, color, data) {
+ * // if you want omit some legend, return falsy value
+ * if (title !== "data1") {
+ * return "<li style='background-color:"+ color +">"+ title +"</li>";
+ * }
+ * }
+ * },
+ * position: "bottom", // bottom, right, inset
+ * inset: {
+ * anchor: "top-right" // top-left, top-right, bottom-left, bottom-right
+ * x: 20,
+ * y: 10,
+ * step: 2
+ * },
+ * equally: false,
+ * padding: 10,
+ * item: {
+ * onclick: function(id) { ... },
+ * onover: function(id) { ... },
+ * onout: function(id) { ... },
+ *
+ * // set tile's size
+ * tile: {
+ * width: 20,
+ * height: 15
+ * }
+ * },
+ * usePoint: true
+ * }
+ */
+ legend_show: !0,
+ legend_hide: !1,
+ legend_contents_bindto: undefined,
+ legend_contents_template: undefined,
+ legend_position: "bottom",
+ legend_inset_anchor: "top-left",
+ legend_inset_x: 10,
+ legend_inset_y: 0,
+ legend_inset_step: undefined,
+ legend_item_onclick: undefined,
+ legend_item_onover: undefined,
+ legend_item_onout: undefined,
+ legend_equally: !1,
+ legend_padding: 0,
+ legend_item_tile_width: 10,
+ legend_item_tile_height: 10,
+ legend_usePoint: !1,
+
+ /**
+ * Switch x and y axis position.
+ * @name axis․rotated
+ * @memberOf Options
+ * @type {Boolean}
+ * @default false
+ * @example
+ * axis: {
+ * rotated: true
+ * }
+ */
+ axis_rotated: !1,
+
+ /**
+ * Set clip-path attribute for x axis element
+ * @name axis․x․clipPath
+ * @memberOf Options
+ * @type {Boolean}
+ * @default true
+ * @example
+ * // don't set 'clip-path' attribute
+ * clipPath: false
+ */
+ axis_x_clipPath: !0,
+
+ /**
+ * Show or hide x axis.
+ * @name axis․x․show
+ * @memberOf Options
+ * @type {Boolean}
+ * @default true
+ * @example
+ * axis: {
+ * x: {
+ * show: false
+ * }
+ * }
+ */
+ axis_x_show: !0,
+
+ /**
+ * Set type of x axis.<br><br>
+ * **Available Values:**
+ * - timeseries
+ * - category
+ * - indexed
+ * @name axis․x․type
+ * @memberOf Options
+ * @type {String}
+ * @default indexed
+ * @example
+ * axis: {
+ * x: {
+ * type: "timeseries"
+ * }
+ * }
+ */
+ axis_x_type: "indexed",
+
+ /**
+ * Set how to treat the timezone of x values.<br>
+ * If true, treat x value as localtime. If false, convert to UTC internally.
+ * @name axis․x․localtime
+ * @memberOf Options
+ * @type {Boolean}
+ * @default true
+ * @example
+ * axis: {
+ * x: {
+ * localtime: false
+ * }
+ * }
+ */
+ axis_x_localtime: !0,
+
+ /**
+ * Set category names on category axis.
+ * This must be an array that includes category names in string. If category names are included in the date by data.x option, this is not required.
+ * @name axis․x․categories
+ * @memberOf Options
+ * @type {Array}
+ * @default []
+ * @example
+ * axis: {
+ * x: {
+ * categories: ["Category 1", "Category 2", ...]
+ * }
+ * }
+ */
+ axis_x_categories: [],
+
+ /**
+ * Centerise ticks on category axis.
+ * @name axis․x․tick․centered
+ * @memberOf Options
+ * @type {Boolean}
+ * @default false
+ * @example
+ * axis: {
+ * x: {
+ * tick: {
+ * centered: true
+ * }
+ * }
+ * }
+ */
+ axis_x_tick_centered: !1,
+
+ /**
+ * A function to format tick value. Format string is also available for timeseries data.
+ * @name axis․x․tick․format
+ * @memberOf Options
+ * @type {Function}
+ * @default undefined
+ * @example
+ * axis: {
+ * x: {
+ * tick: {
+ * // for timeseries, a 'datetime' object is given as parameter
+ * format: function(x) {
+ * return x.getFullYear();
+ * }
+ *
+ * // for category, index(Number) and categoryName(String) are given as parameter
+ * format: function(index, categoryName) {
+ * return categoryName.substr(0, 10);
+ * }
+ * }
+ * }
+ * }
+ */
+ axis_x_tick_format: undefined,
+
+ /**
+ * Setting for culling ticks.<br><br>
+ * If true is set, the ticks will be culled, then only limitted tick text will be shown. This option does not hide the tick lines. If false is set, all of ticks will be shown.<br><br>
+ * We can change the number of ticks to be shown by axis.x.tick.culling.max.
+ * @name axis․x․tick․culling
+ * @memberOf Options
+ * @type {Boolean}
+ * @default
+ * - true for indexed axis and timeseries axis
+ * - false for category axis
+ * @example
+ * axis: {
+ * x: {
+ * tick: {
+ * culling: false
+ * }
+ * }
+ * }
+ */
+ axis_x_tick_culling: {},
+
+ /**
+ * The number of tick texts will be adjusted to less than this value.
+ * @name axis․x․tick․culling․max
+ * @memberOf Options
+ * @type {Number}
+ * @default 10
+ * @example
+ * axis: {
+ * x: {
+ * tick: {
+ * culling: {
+ * max: 5
+ * }
+ * }
+ * }
+ * }
+ */
+ axis_x_tick_culling_max: 10,
+
+ /**
+ * The number of x axis ticks to show.<br><br>
+ * This option hides tick lines together with tick text. If this option is used on timeseries axis, the ticks position will be determined precisely and not nicely positioned (e.g. it will have rough second value).
+ * @name axis․x․tick․count
+ * @memberOf Options
+ * @type {Number}
+ * @default undefined
+ * @example
+ * axis: {
+ * x: {
+ * tick: {
+ * count: 5
+ * }
+ * }
+ * }
+ */
+ axis_x_tick_count: undefined,
+
+ /**
+ * Set the x Axis tick text's position relatively its original position
+ * @name axis․x․tick․text․position
+ * @memberOf Options
+ * @type {Object}
+ * @default {x: 0, y:0}
+ * @example
+ * axis: {
+ * x: {
+ * tick: {
+ * text: {
+ * position: {
+ * x: 10,
+ * y: 10
+ * }
+ * }
+ * }
+ * }
+ * }
+ */
+ axis_x_tick_text_position: { x: 0, y: 0 },
+
+ /**
+ * Fit x axis ticks.<br><br>
+ * If true set, the ticks will be positioned nicely. If false set, the ticks will be positioned according to x value of the data points.
+ * @name axis․x․tick․fit
+ * @memberOf Options
+ * @type {Boolean}
+ * @default true
+ * @example
+ * axis: {
+ * x: {
+ * tick: {
+ * fit: false
+ * }
+ * }
+ * }
+ */
+ axis_x_tick_fit: !0,
+
+ /**
+ * Set the x values of ticks manually.<br><br>
+ * If this option is provided, the position of the ticks will be determined based on those values. This option works with timeseries data and the x values will be parsed accoding to the type of the value and data.xFormat option.
+ * @name axis․x․tick․values
+ * @memberOf Options
+ * @type {Array}
+ * @default null
+ * @example
+ * axis: {
+ * x: {
+ * tick: {
+ * values: [1, 2, 4, 8, 16, 32, ...]
+ * }
+ * }
+ * }
+ */
+ axis_x_tick_values: null,
+
+ /**
+ * Rotate x axis tick text.<br>
+ * If you set negative value, it will rotate to opposite direction.
+ * @name axis․x․tick․rotate
+ * @memberOf Options
+ * @type {Number}
+ * @default 0
+ * @example
+ * axis: {
+ * x: {
+ * tick: {
+ * rotate: 60
+ * }
+ * }
+ * }
+ */
+ axis_x_tick_rotate: 0,
+
+ /**
+ * Show x axis outer tick.
+ * @name axis․x․tick․outer
+ * @memberOf Options
+ * @type {Boolean}
+ * @default true
+ * @example
+ * axis: {
+ * x: {
+ * tick: {
+ * outer: false
+ * }
+ * }
+ * }
+ */
+ axis_x_tick_outer: !0,
+
+ /**
+ * Set tick text to be multiline
+ * - **NOTE:**
+ * > When x tick text contains `\n`, it's used as line break and 'axis.x.tick.width' option is ignored.
+ * @name axis․x․tick․multiline
+ * @memberOf Options
+ * @type {Boolean}
+ * @default true
+ * @example
+ * axis: {
+ * x: {
+ * tick: {
+ * multiline: false
+ * }
+ * }
+ * }
+ * @example
+ * // example of line break with '\n'
+ * // In this case, 'axis.x.tick.width' is ignored
+ * data: {
+ * x: "x",
+ * columns: [
+ * ["x", "long\ntext", "Another\nLong\nText"],
+ * ...
+ * ],
+ * }
+ */
+ axis_x_tick_multiline: !0,
+
+ /**
+ * Set tick width
+ * - **NOTE:**
+ * > When x tick text contains `\n`, this option is ignored.
+ * @name axis․x․tick․width
+ * @memberOf Options
+ * @type {Number}
+ * @default null
+ * @example
+ * axis: {
+ * x: {
+ * tick: {
+ * width: 50
+ * }
+ * }
+ * }
+ */
+ axis_x_tick_width: null,
+
+ /**
+ * Set to display system tooltip for tick text
+ * - **NOTE:** Only available for category axis type (`axis.x.type='category'`)
+ * @name axis․x․tick․tooltip
+ * @memberOf Options
+ * @type {Boolean}
+ * @default false
+ * @example
+ * axis: {
+ * x: {
+ * tick: {
+ * tooltip: true
+ * }
+ * }
+ * }
+ */
+ axis_x_tick_tooltip: !1,
+
+ /**
+ * Set max value of x axis range.
+ * @name axis․x․max
+ * @memberOf Options
+ * @type {Number}
+ * @default undefined
+ * @example
+ * axis: {
+ * x: {
+ * max: 100
+ * }
+ * }
+ */
+ axis_x_max: undefined,
+
+ /**
+ * Set min value of x axis range.
+ * @name axis․x․min
+ * @memberOf Options
+ * @type {Number}
+ * @default undefined
+ * @example
+ * axis: {
+ * x: {
+ * min: -100
+ * }
+ * }
+ */
+ axis_x_min: undefined,
+
+ /**
+ * Set padding for x axis.<br><br>
+ * If this option is set, the range of x axis will increase/decrease according to the values.
+ * If no padding is needed in the rage of x axis, 0 should be set.
+ * - **NOTE:**
+ * The padding values aren't based on pixels. It differs according axis types<br>
+ * - **category:** The unit of tick value
+ * ex. the given value `1`, is same as the width of 1 tick width
+ * - **timeseries:** Numeric time value
+ * ex. the given value `1000*60*60*24`, which is numeric time equivalent of a day, is same as the width of 1 tick width
+ * @name axis․x․padding
+ * @memberOf Options
+ * @type {Object}
+ * @default {}
+ * @example
+ * axis: {
+ * x: {
+ * padding: {
+ * // when axis type is 'category'
+ * left: 1, // set left padding width of equivalent value of a tick's width
+ * right: 0.5 // set right padding width as half of equivalent value of tick's width
+ *
+ * // when axis type is 'timeseries'
+ * left: 1000*60*60*24, // set left padding width of equivalent value of a day tick's width
+ * right: 1000*60*60*12 // set right padding width as half of equivalent value of a day tick's width
+ * }
+ * }
+ * }
+ */
+ axis_x_padding: {},
+
+ /**
+ * Set height of x axis.<br><br>
+ * The height of x axis can be set manually by this option. If you need more space for x axis, please use this option for that. The unit is pixel.
+ * @name axis․x․height
+ * @memberOf Options
+ * @type {Number}
+ * @default undefined
+ * @example
+ * axis: {
+ * x: {
+ * height: 20
+ * }
+ * }
+ */
+ axis_x_height: undefined,
+
+ /**
+ * Set default extent for subchart and zoom. This can be an array or function that returns an array.
+ * @name axis․x․extent
+ * @memberOf Options
+ * @type {Array}
+ * @default undefined
+ * @example
+ * axis: {
+ * x: {
+ * // [[x0, y0], [x1, y1]], where [x0, y0] is the top-left corner and [x1, y1] is the bottom-right corner
+ * // https://github.com/d3/d3-brush/blob/master/src/brush.js#L521
+ * extent: [
+ * [0, 0], [200, 60]
+ * ]
+ * }
+ * }
+ */
+ axis_x_extent: undefined,
+
+ /**
+ * Set label on x axis.<br><br>
+ * You can set x axis label and change its position by this option. string and object can be passed and we can change the poisiton by passing object that has position key. Available position differs according to the axis direction (vertical or horizontal). If string set, the position will be the default.
+ * - **If it's horizontal axis:**
+ * - inner-right [default]
+ * - inner-center
+ * - inner-left
+ * - outer-right
+ * - outer-center
+ * - outer-left
+ * - **If it's vertical axis:**
+ * - inner-top [default]
+ * - inner-middle
+ * - inner-bottom
+ * - outer-top
+ * - outer-middle
+ * - outer-bottom
+ * @name axis․x․label
+ * @memberOf Options
+ * @type {String|Object}
+ * @default undefined
+ * @example
+ * axis: {
+ * x: {
+ * label: "Your X Axis"
+ * }
+ * }
+ *
+ * axis: {
+ * x: {
+ * label: {
+ * text: "Your X Axis",
+ * position: "outer-center"
+ * }
+ * }
+ * }
+ */
+ axis_x_label: {},
+
+ /**
+ * Set clip-path attribute for y axis element
+ * @name axis․y․clipPath
+ * @memberOf Options
+ * @type {Boolean}
+ * @default true
+ * @example
+ * // don't set 'clip-path' attribute
+ * clipPath: false
+ */
+ axis_y_clipPath: !0,
+
+ /**
+ * Show or hide y axis.
+ * @name axis․y․show
+ * @memberOf Options
+ * @type {Boolean}
+ * @default true
+ * @example
+ * axis: {
+ * y: {
+ * show: false
+ * }
+ * }
+ */
+ axis_y_show: !0,
+
+ /**
+ * Set type of y axis.<br><br>
+ * **Available Values:**
+ * - timeseries
+ * - category
+ * - indexed
+ * @name axis․y․type
+ * @memberOf Options
+ * @type {String}
+ * @default undefined
+ * @example
+ * axis: {
+ * y: {
+ * type: "timeseries"
+ * }
+ * }
+ */
+ axis_y_type: undefined,
+
+ /**
+ * Set max value of y axis.
+ * - **NOTE:** Padding will be added based on this value, so if you don't need the padding, please set axis.y.padding to disable it (e.g. axis.y.padding = 0).
+ * @name axis․y․max
+ * @memberOf Options
+ * @type {Number}
+ * @default undefined
+ * @example
+ * axis: {
+ * y: {
+ * max: 1000
+ * }
+ * }
+ */
+ axis_y_max: undefined,
+
+ /**
+ * Set min value of y axis.
+ * - **NOTE:**
+ * Padding will be added based on this value, so if you don't need the padding, please set axis.y.padding to disable it (e.g. axis.y.padding = 0).
+ * @name axis․y․min
+ * @memberOf Options
+ * @type {Number}
+ * @default undefined
+ * @example
+ * axis: {
+ * y: {
+ * min: 1000
+ * }
+ * }
+ */
+ axis_y_min: undefined,
+
+ /**
+ * Change the direction of y axis.<br><br>
+ * If true set, the direction will be from the top to the bottom.
+ * @name axis․y․inverted
+ * @memberOf Options
+ * @type {Boolean}
+ * @default false
+ * @example
+ * axis: {
+ * y: {
+ * inverted: true
+ * }
+ * }
+ */
+ axis_y_inverted: !1,
+
+ /**
+ * Set center value of y axis.
+ * @name axis․y․center
+ * @memberOf Options
+ * @type {Number}
+ * @default undefined
+ * @example
+ * axis: {
+ * y: {
+ * center: 0
+ * }
+ * }
+ */
+ axis_y_center: undefined,
+
+ /**
+ * Show y axis inside of the chart.
+ * @name axis․y․inner
+ * @memberOf Options
+ * @type {Boolean}
+ * @default false
+ * @example
+ * axis: {
+ * y: {
+ * inner: true
+ * }
+ * }
+ */
+ axis_y_inner: !1,
+
+ /**
+ * Set label on y axis.<br><br>
+ * You can set y axis label and change its position by this option. This option works in the same way as axis.x.label.
+ * @name axis․y․label
+ * @memberOf Options
+ * @type {String|Object}
+ * @default {}
+ * @example
+ * axis: {
+ * y: {
+ * label: "Your Y Axis"
+ * }
+ * }
+ *
+ * axis: {
+ * y: {
+ * label: {
+ * text: "Your Y Axis",
+ * position: "outer-middle"
+ * }
+ * }
+ * }
+ */
+ axis_y_label: {},
+
+ /**
+ * Set formatter for y axis tick text.<br><br>
+ * This option accepts d3.format object as well as a function you define.
+ * @name axis․y․tick․format
+ * @memberOf Options
+ * @type {Function}
+ * @default undefined
+ * @example
+ * axis: {
+ * y: {
+ * tick: {
+ * format: function(x) {
+ * return x.getFullYear();
+ * }
+ * }
+ * }
+ * }
+ */
+ axis_y_tick_format: undefined,
+
+ /**
+ * Show y axis outer tick.
+ * @name axis․y․tick․outer
+ * @memberOf Options
+ * @type {Boolean}
+ * @default true
+ * @example
+ * axis: {
+ * y: {
+ * tick: {
+ * outer: false
+ * }
+ * }
+ * }
+ */
+ axis_y_tick_outer: !0,
+
+ /**
+ * Set y axis tick values manually.
+ * @name axis․y․tick․values
+ * @memberOf Options
+ * @type {Array}
+ * @default null
+ * @example
+ * axis: {
+ * y: {
+ * tick: {
+ * values: [100, 1000, 10000]
+ * }
+ * }
+ * }
+ */
+ axis_y_tick_values: null,
+ axis_y_tick_rotate: 0,
+
+ /**
+ * Set the number of y axis ticks.<br><br>
+ * - **NOTE:** The position of the ticks will be calculated precisely, so the values on the ticks will not be rounded nicely. In the case, axis.y.tick.format or axis.y.tick.values will be helpful.
+ * @name axis․y․tick․count
+ * @memberOf Options
+ * @type {Number}
+ * @default undefined
+ * @example
+ * axis: {
+ * y: {
+ * tick: {
+ * count: 5
+ * }
+ * }
+ * }
+ */
+ axis_y_tick_count: undefined,
+
+ /**
+ * Set the y Axis tick text's position relatively its original position
+ * @name axis․y․tick․text․position
+ * @memberOf Options
+ * @type {Object}
+ * @default {x: 0, y:0}
+ * @example
+ * axis: {
+ * y: {
+ * tick: {
+ * text: {
+ * position: {
+ * x: 10,
+ * y: 10
+ * }
+ * }
+ * }
+ * }
+ * }
+ */
+ axis_y_tick_text_position: { x: 0, y: 0 },
+
+ /**
+ * Set the number of y axis ticks.<br><br>
+ * - **NOTE:** The position of the ticks will be calculated precisely, so the values on the ticks will not be rounded nicely. In the case, axis.y.tick.format or axis.y.tick.values will be helpful.
+ * @name axis․y․tick․time
+ * @memberOf Options
+ * @private
+ * @type {Object}
+ * @property {Function} [time.value] D3's time interval function (https://github.com/d3/d3-time#intervals)
+ * @example
+ * axis: {
+ * y: {
+ * tick: {
+ * time: {
+ * // ticks at 15-minute intervals
+ * // https://github.com/d3/d3-scale/blob/master/README.md#time_ticks
+ * value: d3.timeMinute.every(15)
+ * }
+ * }
+ * }
+ * }
+ */
+ // @TODO: not fully implemented yet
+ axis_y_tick_time_value: undefined,
+
+ /**
+ * Set padding for y axis.<br><br>
+ * You can set padding for y axis to create more space on the edge of the axis.
+ * This option accepts object and it can include top and bottom. top, bottom will be treated as pixels.
+ *
+ * - **NOTE:** For area and bar type charts, [area.zerobased](#.area) or [bar.zerobased](#.bar) options should be set to 'false` to get padded bottom.
+ * @name axis․y․padding
+ * @memberOf Options
+ * @type {Object}
+ * @default {}
+ * @example
+ * axis: {
+ * y: {
+ * padding: {
+ * top: 0,
+ * bottom: 0
+ * }
+ * }
+ * }
+ */
+ axis_y_padding: {},
+
+ /**
+ * Set default range of y axis.<br><br>
+ * This option set the default value for y axis when there is no data on init.
+ * @name axis․y․default
+ * @memberOf Options
+ * @type {Array}
+ * @default undefined
+ * @example
+ * axis: {
+ * y: {
+ * default: [0, 1000]
+ * }
+ * }
+ */
+ axis_y_default: undefined,
+
+ /**
+ * Show or hide y2 axis.
+ * @name axis․y2․show
+ * @memberOf Options
+ * @type {Boolean}
+ * @default false
+ * @example
+ * axis: {
+ * y2: {
+ * show: true
+ * }
+ * }
+ */
+ axis_y2_show: !1,
+
+ /**
+ * Set max value of y2 axis.
+ * @name axis․y2․max
+ * @memberOf Options
+ * @type {Number}
+ * @default undefined
+ * @example
+ * axis: {
+ * y2: {
+ * max: 1000
+ * }
+ * }
+ */
+ axis_y2_max: undefined,
+
+ /**
+ * Set min value of y2 axis.
+ * @name axis․y2․min
+ * @memberOf Options
+ * @type {Number}
+ * @default undefined
+ * @example
+ * axis: {
+ * y2: {
+ * min: -1000
+ * }
+ * }
+ */
+ axis_y2_min: undefined,
+
+ /**
+ * Change the direction of y2 axis.<br><br>
+ * If true set, the direction will be from the top to the bottom.
+ * @name axis․y2․inverted
+ * @memberOf Options
+ * @type {Boolean}
+ * @default false
+ * @example
+ * axis: {
+ * y2: {
+ * inverted: true
+ * }
+ * }
+ */
+ axis_y2_inverted: !1,
+
+ /**
+ * Set center value of y2 axis.
+ * @name axis․y2․center
+ * @memberOf Options
+ * @type {Number}
+ * @default undefined
+ * @example
+ * axis: {
+ * y2: {
+ * center: 0
+ * }
+ * }
+ */
+ axis_y2_center: undefined,
+
+ /**
+ * Show y2 axis inside of the chart.
+ * @name axis․y2․inner
+ * @memberOf Options
+ * @type {Boolean}
+ * @default false
+ * @example
+ * axis: {
+ * y2: {
+ * inner: true
+ * }
+ * }
+ */
+ axis_y2_inner: !1,
+
+ /**
+ * Set label on y2 axis.<br><br>
+ * You can set y2 axis label and change its position by this option. This option works in the same way as axis.x.label.
+ * @name axis․y2․label
+ * @memberOf Options
+ * @type {String|Object}
+ * @default {}
+ * @example
+ * axis: {
+ * y2: {
+ * label: "Your Y2 Axis"
+ * }
+ * }
+ *
+ * axis: {
+ * y2: {
+ * label: {
+ * text: "Your Y2 Axis",
+ * position: "outer-middle"
+ * }
+ * }
+ * }
+ */
+ axis_y2_label: {},
+
+ /**
+ * Set formatter for y2 axis tick text.<br><br>
+ * This option works in the same way as axis.y.format.
+ * @name axis․y2․tick․format
+ * @memberOf Options
+ * @type {Function}
+ * @default undefined
+ * @example
+ * axis: {
+ * y2: {
+ * tick: {
+ * format: d3.format("$,")
+ * //or format: function(d) { return "$" + d; }
+ * }
+ * }
+ * }
+ */
+ axis_y2_tick_format: undefined,
+
+ /**
+ * Show or hide y2 axis outer tick.
+ * @name axis․y2․tick․outer
+ * @memberOf Options
+ * @type {Boolean}
+ * @default true
+ * @example
+ * axis: {
+ * y2: {
+ * tick: {
+ * outer: false
+ * }
+ * }
+ * }
+ */
+ axis_y2_tick_outer: !0,
+
+ /**
+ * Set y2 axis tick values manually.
+ * @name axis․y2․tick․values
+ * @memberOf Options
+ * @type {Array}
+ * @default null
+ * @example
+ * axis: {
+ * y2: {
+ * tick: {
+ * values: [100, 1000, 10000]
+ * }
+ * }
+ * }
+ */
+ axis_y2_tick_values: null,
+
+ /**
+ * Set the number of y2 axis ticks.
+ * - **NOTE:** This works in the same way as axis.y.tick.count.
+ * @name axis․y2․tick․count
+ * @memberOf Options
+ * @type {Number}
+ * @default undefined
+ * @example
+ * axis: {
+ * y2: {
+ * tick: {
+ * count: 5
+ * }
+ * }
+ * }
+ */
+ axis_y2_tick_count: undefined,
+
+ /**
+ * Set the y2 Axis tick text's position relatively its original position
+ * @name axis․y2․tick․text․position
+ * @memberOf Options
+ * @type {Object}
+ * @default {x: 0, y:0}
+ * @example
+ * axis: {
+ * y2: {
+ * tick: {
+ * text: {
+ * position: {
+ * x: 10,
+ * y: 10
+ * }
+ * }
+ * }
+ * }
+ * }
+ */
+ axis_y2_tick_text_position: { x: 0, y: 0 },
+
+ /**
+ * Set the number of y2 axis ticks.
+ * - **NOTE:** This works in the same way as axis.y.tick.count.
+ * @name axis․y2․padding
+ * @memberOf Options
+ * @type {Object}
+ * @default {}
+ * @example
+ * axis: {
+ * y2: {
+ * padding: {
+ * top: 100,
+ * bottom: 100
+ * }
+ * }
+ * }
+ */
+ axis_y2_padding: {},
+
+ /**
+ * Set default range of y2 axis.<br><br>
+ * This option set the default value for y2 axis when there is no data on init.
+ * @name axis․y2․default
+ * @memberOf Options
+ * @type {Array}
+ * @default undefined
+ * @example
+ * axis: {
+ * y2: {
+ * default: [0, 1000]
+ * }
+ * }
+ */
+ axis_y2_default: undefined,
+
+ /**
+ * Set related options
+ * @name grid
+ * @memberOf Options
+ * @type {Object}
+ * @property {Boolean} [front=false] Set 'grid & focus lines' to be positioned over grid lines and chart elements.
+ * @property {Boolean} [x.show=false] Show grids along x axis.
+ * @property {Boolean} [x.lines=[]] Show additional grid lines along x axis.<br>
+ * This option accepts array including object that has value, text, position and class. text, position and class are optional. For position, start, middle and end (default) are available.
+ * If x axis is category axis, value can be category name. If x axis is timeseries axis, value can be date string, Date object and unixtime integer.
+ * @property {Boolean} [y.show=false] Show grids along x axis.
+ * @property {Boolean} [y.lines=[]] Show additional grid lines along y axis.<br>
+ * This option accepts array including object that has value, text, position and class.
+ * @property {Boolean} [y.ticks=10] Number of y grids to be shown.
+ * @property {Boolean} [focus.show=true] Show grids when focus.
+ * @property {Boolean} [lines.front=true] Set grid lines to be positioned over chart elements.
+ * @default undefined
+ * @example
+ * grid: {
+ * x: {
+ * show: true,
+ * lines: [
+ * {value: 2, text: "Label on 2"},
+ * {value: 5, text: "Label on 5", class: "label-5"}
+ * {value: 6, text: "Label on 6", position: "start"}
+ * ]
+ * },
+ * y: {
+ * show: true,
+ * lines: [
+ * {value: 100, text: "Label on 100"},
+ * {value: 200, text: "Label on 200", class: "label-200"}
+ * {value: 300, text: "Label on 300", position: 'middle'}
+ * ],
+ * ticks: 5
+ * },
+ * front: true,
+ * focus: {
+ * show: false
+ * },
+ * lines: {
+ * front: false
+ * }
+ * }
+ */
+ grid_x_show: !1,
+ grid_x_type: "tick",
+ grid_x_lines: [],
+ grid_y_show: !1,
+ grid_y_lines: [],
+ grid_y_ticks: 10,
+ grid_focus_show: !0,
+ grid_front: !1,
+ grid_lines_front: !0,
+
+ /**
+ * Set point options
+ * @name point
+ * @memberOf Options
+ * @type {Object}
+ * @property {Boolean} [point.show=true] Whether to show each point in line.
+ * @property {Number|Function} [point.r=2.5] The radius size of each point.<br>
+ * - **NOTE:** Disabled for 'bubble' type
+ * @property {Boolean} [point.focus.expand.enabled=true] Whether to expand each point on focus.
+ * @property {Boolean} [point.focus.expand.r=point.r*1.75] The radius size of each point on focus.<br>
+ * - **NOTE:** For 'bubble' type, the default is `bubbleSize*1.15`
+ * @property {Number} [point.select.r=point.r*4] The radius size of each point on selected.
+ * @property {String} [point.type="circle"] The type of point to be drawn<br>
+ * - **NOTE:**
+ * - If chart has 'bubble' type, only circle can be used.
+ * - For IE, non circle point expansions are not supported due to lack of transform support.
+ * - **Available Values:**
+ * - circle
+ * - rectangle
+ * @property {Array} [point.pattern=[]] The type of point or svg shape as string, to be drawn for each line<br>
+ * - **NOTE:**
+ * - This is an `experimental` feature and can have some unexpected behaviors.
+ * - If chart has 'bubble' type, only circle can be used.
+ * - For IE, non circle point expansions are not supported due to lack of transform support.
+ * - **Available Values:**
+ * - circle
+ * - rectangle
+ * - svg shape tag interpreted as string<br>
+ * (ex. `<polygon points='2.5 0 0 5 5 5'></polygon>`)
+ * @example
+ * point: {
+ * show: false,
+ * r: 5,
+ *
+ * // or customize the radius
+ * r: function(d) {
+ * ...
+ * return r;
+ * },
+ *
+ * focus: {
+ * expand: {
+ * enabled: true,
+ * r: 1
+ * }
+ * },
+ * select: {
+ * r: 3
+ * },
+ *
+ * // valid values are "circle" or "rectangle"
+ * type: "rectangle",
+ *
+ * // or indicate as pattern
+ * pattern: [
+ * "circle",
+ * "rectangle",
+ * "<polygon points='0 6 4 0 -4 0'></polygon>"
+ * ],
+ * }
+ */
+ point_show: !0,
+ point_r: 2.5,
+ point_sensitivity: 10,
+ point_focus_expand_enabled: !0,
+ point_focus_expand_r: undefined,
+ point_pattern: [],
+ point_select_r: undefined,
+ point_type: "circle",
+
+ /**
+ * Set line options
+ * @name line
+ * @memberOf Options
+ * @type {Object}
+ * @property {Boolean} [line.connectNull=false] Set if null data point will be connected or not.<br>
+ * If true set, the region of null data will be connected without any data point. If false set, the region of null data will not be connected and get empty.
+ * @property {Array} [line.classes=undefined] If set, used to set a css class on each line.
+ * @property {Boolean} [line.step.type=step] Change step type for step chart.<br>
+ * **Available values:**
+ * - step
+ * - step-before
+ * - step-after
+ * @property {Boolean|Array} [line.point=true] Set to false to not draw points on linecharts. Or pass an array of line ids to draw points for.
+ * @example
+ * line: {
+ * connectNull: true,
+ * classes: [
+ * "line-class1",
+ * "line-class2"
+ * ],
+ * step: {
+ * type: "step-after"
+ * },
+ *
+ * // hide all data points ('point.show=false' also has similar effect)
+ * point: false,
+ *
+ * // show data points for only indicated datas
+ * point: [
+ * "data1", "data3"
+ * ]
+ * }
+ */
+ line_connectNull: !1,
+ line_step_type: "step",
+ line_classes: undefined,
+ line_point: !0,
+
+ /**
+ * Set bar options
+ * @name bar
+ * @memberOf Options
+ * @type {Object}
+ * @property {Boolean} [bar.padding=0] The padding pixel value between each bar.
+ * @property {Number} [bar.radius] Set the radius of bar edge in pixel.<br>- **NOTE:** Only for non-stacking bars.
+ * @property {Number} [bar.radius.ratio] Set the radius ratio of bar edge in relative the bar's width.
+ * @property {Number} [bar.width] Change the width of bar chart.
+ * @property {Number} [bar.width.ratio=0.6] Change the width of bar chart by ratio.
+ * @property {Number} [bar.width.max] The maximum width value for ratio.
+ * @property {Boolean} [bar.zerobased=true] Set if min or max value will be 0 on bar chart.
+ * @example
+ * bar: {
+ * padding: 1,
+ *
+ * // the 'radius' option can be used only for non-stacking bars
+ * radius: 10,
+ * // or
+ * radius: {
+ * ratio: 0.5
+ * }
+ *
+ * width: 10,
+ * // or
+ * width: {
+ * ratio: 0.2,
+ * max: 20
+ * },
+ *
+ * zerobased: false
+ * }
+ */
+ bar_padding: 0,
+ bar_radius: undefined,
+ bar_radius_ratio: undefined,
+ bar_width: undefined,
+ bar_width_ratio: .6,
+ bar_width_max: undefined,
+ bar_zerobased: !0,
+
+ /**
+ * Set bubble options
+ * @name bubble
+ * @memberOf Options
+ * @type {Object}
+ * @property {Number|Function} [bubble.maxR=35] Set the max bubble radius value
+ * @example
+ * bubble: {
+ * // ex) If 100 is the highest value among data bound, the representation bubble of 100 will have radius of 50.
+ * // And the lesser will have radius relatively from tha max value.
+ * maxR: 50,
+ *
+ * // or set radius callback
+ * maxR: function(d) {
+ * // ex. of d param - {x: Fri Oct 06 2017 00:00:00 GMT+0900, value: 80, id: "data2", index: 5}
+ * ...
+ * return Math.sqrt(d.value * 2);
+ * }
+ * }
+ */
+ bubble_maxR: 35,
+
+ /**
+ * Set area options
+ * @name area
+ * @memberOf Options
+ * @type {Object}
+ * @property {Boolean} [area.zerobased=true] Set if min or max value will be 0 on area chart.
+ * @property {Boolean} [area.above=false]
+ * @example
+ * area: {
+ * zerobased: false,
+ * above: true
+ * }
+ */
+ area_zerobased: !0,
+ area_above: !1,
+
+ /**
+ * Set pie options
+ * @name pie
+ * @memberOf Options
+ * @type {Object}
+ * @property {Boolean} [pie.label.show=true] Show or hide label on each pie piece.
+ * @property {Function} [pie.label.format] Set formatter for the label on each pie piece.
+ * @property {Number} [pie.label.threshold=0.05] Set threshold to show/hide labels.
+ * @property {Number|Function} [pie.label.ratio=undefined] Set ratio of labels position.
+ * @property {Boolean} [pie.expand=true] Enable or disable expanding pie pieces.
+ * @property {Number} [pie.innerRadius=0] Sets the inner radius of pie arc.
+ * @property {Number} [pie.padAngle=0] Set padding between data.
+ * @property {Number} [pie.padding=0] Sets the gap between pie arcs.
+ * @example
+ * pie: {
+ * label: {
+ * show: false,
+ * format: function(value, ratio, id) {
+ * return d3.format("$")(value);
+ * },
+ * threshold: 0.1,
+ *
+ * // set ratio callback. Should return ratio value
+ * ratio: function(d, radius, h) {
+ * ...
+ * return ratio;
+ * },
+ * // or set ratio number
+ * ratio: 0.5
+ * },
+ * expand: false,
+ * innerRadius: 0,
+ * padAngle: 0.1,
+ * padding: 0
+ * }
+ */
+ pie_label_show: !0,
+ pie_label_format: undefined,
+ pie_label_threshold: .05,
+ pie_label_ratio: undefined,
+ pie_expand: {},
+ pie_expand_duration: 50,
+ pie_innerRadius: 0,
+ pie_padAngle: 0,
+ pie_padding: 0,
+
+ /**
+ * Set gauge options
+ * @name gauge
+ * @memberOf Options
+ * @type {Object}
+ * @property {Boolean} [gauge.fullCircle=false] Show full circle as donut. When set to 'true', the max label will not be showed due to start and end points are same location.
+ * @property {Boolean} [gauge.label.show=true] Show or hide label on gauge.
+ * @property {Function} [gauge.label.format] Set formatter for the label on gauge. Label text can be multilined with `\n` character.
+ * @property {Function} [gauge.label.extents] Set customized min/max label text.
+ * @property {Boolean} [gauge.expand=true] Enable or disable expanding gauge.
+ * @property {Number} [gauge.expand.duration=50] Set the expand transition time in milliseconds.
+ * @property {Number} [gauge.min=0] Set min value of the gauge.
+ * @property {Number} [gauge.max=100] Set max value of the gauge.
+ * @property {Number} [gauge.startingAngle=-1 * Math.PI / 2]
+ * @property {String} [gauge.units] Set units of the gauge.
+ * @property {Number} [gauge.width] Set width of gauge chart.
+ * @example
+ * gauge: {
+ * fullCircle: false,
+ * label: {
+ * show: false,
+ * format: function(value, ratio) {
+ * return value;
+ *
+ * // to multiline, return with '\n' character
+ * // return value +"%\nLine1\n2Line2";
+ * },
+ * extents: function(value, isMax) {
+ * return (isMax ? "Max:" : "Min:") + value;
+ * }
+ * },
+ * expand: false,
+ *
+ * // or set duration
+ * expand: {
+ * duration: 20
+ * },
+ * min: -100,
+ * max: 200,
+ * units: "%",
+ * width: 10
+ * }
+ */
+ gauge_fullCircle: !1,
+ gauge_label_show: !0,
+ gauge_label_format: undefined,
+ gauge_min: 0,
+ gauge_max: 100,
+ gauge_startingAngle: -1 * Math.PI / 2,
+ gauge_label_extents: undefined,
+ gauge_units: undefined,
+ gauge_width: undefined,
+ gauge_expand: {},
+ gauge_expand_duration: 50,
+
+ /**
+ * Set donut options
+ * @name donut
+ * @memberOf Options
+ * @type {Object}
+ * @property {Boolean} [donut.label.show=true] Show or hide label on each donut piece.
+ * @property {Function} [donut.label.format] Set formatter for the label on each donut piece.
+ * @property {Number} [donut.label.threshold=0.05] Set threshold to show/hide labels.
+ * @property {Number|Function} [donut.label.ratio=undefined] Set ratio of labels position.
+ * @property {Boolean} [donut.expand=true] Enable or disable expanding donut pieces.
+ * @property {Number} [donut.width] Set width of donut chart.
+ * @property {String} [donut.title=""] Set title of donut chart. Use `\n` character to enter line break.
+ * @property {Number} [donut.padAngle=0] Set padding between data.
+ * @example
+ * donut: {
+ * label: {
+ * show: false,
+ * format: function(value, ratio, id) {
+ * return d3.format("$")(value);
+ * },
+ * threshold: 0.1,
+ *
+ * // set ratio callback. Should return ratio value
+ * ratio: function(d, radius, h) {
+ * ...
+ * return ratio;
+ * },
+ * // or set ratio number
+ * ratio: 0.5
+ * },
+ * expand: false,
+ * width: 10,
+ * padAngle: 0.2,
+ * title: "Donut Title"
+ *
+ * // title with line break
+ * title: "Title1\nTitle2"
+ * }
+ */
+ donut_label_show: !0,
+ donut_label_format: undefined,
+ donut_label_threshold: .05,
+ donut_label_ratio: undefined,
+ donut_width: undefined,
+ donut_title: "",
+ donut_expand: {},
+ donut_expand_duration: 50,
+ donut_padAngle: 0,
+
+ /**
+ * Set spline options
+ * @name spline
+ * @memberOf Options
+ * @type {Object}
+ * @property {String} [spline.interpolation.type=cardinal]
+ * @example
+ * spline: {
+ * interpolation: {
+ * type: "cardinal"
+ * }
+ * }
+ */
+ spline_interpolation_type: "cardinal",
+
+ /**
+ * Set radar options
+ * @name radar
+ * @memberOf Options
+ * @type {Object}
+ * @property {Number} [radar.axis.max=undefined] The max value of axis. If not given, it'll take the max value from the given data.
+ * @property {Boolean} [radar.axis.line.show=true] Show or hide axis line.
+ * @property {Boolean} [radar.axis.text.show=true] Show or hide axis text.
+ * @property {Boolean} [radar.direction.clockwise=false] Set the direction to be drawn.
+ * @property {Number} [radar.level.depth=3] Set the level depth.
+ * @property {Boolean} [radar.level.show=true] Show or hide level.
+ * @property {Function} [radar.level.text.format=(x) => (x % 1 === 0 ? x : x.toFixed(2))] Set format function for the level value.
+ * @property {Boolean} [radar.level.text.show=true] Show or hide level text.
+ * @property {Number} [radar.size.ratio=0.87] Set size ratio.
+ * @example
+ * radar: {
+ * axis: {
+ * max: 50,
+ * line: {
+ * show: false
+ * },
+ * text: {
+ * show: false
+ * }
+ * },
+ * direction: {
+ * clockwise: true
+ * },
+ * level: {
+ * show: false,
+ * text: {
+ * format: function(x) {
+ * return x + "%";
+ * },
+ * show: true
+ * }
+ * },
+ * size: {
+ * ratio: 0.7
+ * }
+ * }
+ */
+ radar_axis_max: undefined,
+ radar_axis_line_show: !0,
+ radar_axis_text_show: !0,
+ radar_level_depth: 3,
+ radar_level_show: !0,
+ radar_level_text_format: function radar_level_text_format(x) {
+ return x % 1 === 0 ? x : x.toFixed(2);
+ },
+ radar_level_text_show: !0,
+ radar_size_ratio: .87,
+ radar_direction_clockwise: !1,
+
+ /**
+ * Show rectangles inside the chart.<br><br>
+ * This option accepts array including object that has axis, start, end and class. The keys start, end and class are optional.
+ * axis must be x, y or y2. start and end should be the value where regions start and end. If not specified, the edge values will be used. If timeseries x axis, date string, Date object and unixtime integer can be used. If class is set, the region element will have it as class.
+ * @name regions
+ * @memberOf Options
+ * @type {Array}
+ * @default []
+ * @example
+ * regions: [
+ * {
+ * axis: "x",
+ * start: 1,
+ * end: 4,
+ * class: "region-1-4"
+ * }
+ * ]
+ */
+ regions: [],
+
+ /**
+ * Tooltip options
+ * @name tooltip
+ * @memberOf Options
+ * @type {Object}
+ * @property {Boolean} [tooltip.show=true] Show or hide tooltip.<br>
+ * @property {Boolean} [tooltip.grouped=true] Set if tooltip is grouped or not for the data points.
+ * - **NOTE:** The overlapped data points will be displayed as grouped even if set false.
+ * @property {Boolean} [tooltip.linked=false] Set if tooltips on all visible charts with like x points are shown together when one is shown.
+ * @property {String} [tooltip.linked.name=""] Groping name for linked tooltip.<br>If specified, linked tooltip will be groped interacting to be worked only with the same name.
+ * @property {Function} [tooltip.format.title] Set format for the title of tooltip.<br>
+ * Specified function receives x of the data point to show.
+ * @property {Function} [tooltip.format.name] Set format for the name of each data in tooltip.<br>
+ * Specified function receives name, ratio, id and index of the data point to show. ratio will be undefined if the chart is not donut/pie/gauge.
+ * @property {Function} [tooltip.format.value] Set format for the value of each data in tooltip.<br>
+ * Specified function receives name, ratio, id and index of the data point to show. ratio will be undefined if the chart is not donut/pie/gauge.
+ * If undefined returned, the row of that value will be skipped.
+ * @property {Function} [tooltip.position] Set custom position for the tooltip.<br>
+ * This option can be used to modify the tooltip position by returning object that has top and left.
+ * @property {Function} [tooltip.contents] Set custom HTML for the tooltip.<br>
+ * Specified function receives data, defaultTitleFormat, defaultValueFormat and color of the data point to show. If tooltip.grouped is true, data includes multiple data points.
+ * @property {Boolean} [tooltip.init.show=false] Show tooltip at the initialization.
+ * @property {Number} [tooltip.init.x=0] Set x Axis index to be shown at the initialization.
+ * @property {Object} [tooltip.init.position={top: "0px",left: "50px"}] Set the position of tooltip at the initialization.
+ * @property {Function} [tooltip.onshow] Set a callback that will be invoked before the tooltip is shown.
+ * @property {Function} [tooltip.onhide] Set a callback that will be invoked before the tooltip is hidden.
+ * @property {Function} [tooltip.onshown] Set a callback that will be invoked after the tooltip is shown
+ * @property {Function} [tooltip.onhidden] Set a callback that will be invoked after the tooltip is hidden.
+ * @property {String|Function|null} [tooltip.order=null] Set tooltip data display order.<br><br>
+ * **Available Values:**
+ * - `desc`: In descending data value order
+ * - `asc`: In ascending data value order
+ * - `null`: It keeps the data display order<br>
+ * **NOTE:** When `data.groups` is set, the order will follow as the stacked graph order.<br>
+ * If want to order as data bound, set any value rather than asc, desc or null. (ex. empty string "")
+ * - `function(data1, data2) { ... }`: [Array.sort compareFunction](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort#Parameters)
+ * @example
+ * tooltip: {
+ * show: true,
+ * grouped: false,
+ * format: {
+ * title: function(x) { return "Data " + x; },
+ * name: function(name, ratio, id, index) { return name; },
+ * value: function(value, ratio, id, index) { return ratio; }
+ * },
+ * position: function(data, width, height, element) {
+ * return {top: 0, left: 0}
+ * },
+ * contents: function(d, defaultTitleFormat, defaultValueFormat, color) {
+ * return ... // formatted html as you want
+ * },
+ *
+ * // sort tooltip data value display in ascending order
+ * order: "asc",
+ *
+ * // specifying sort function
+ * order: function(a, b) {
+ * // param data passed format
+ * {x: 5, value: 250, id: "data1", index: 5, name: "data1"}
+ * ...
+ * },
+ *
+ * // show at the initialization
+ * init: {
+ * show: true,
+ * x: 2,
+ * position: {
+ * top: "150px",
+ * left: "250px"
+ * }
+ * },
+ *
+ * // fires prior tooltip is shown
+ * onshow: function() { ...},
+ * // fires prior tooltip is hidden
+ * onhide: function() { ... },
+ * // fires after tooltip is shown
+ * onshown: function() { ... },
+ * // fires after tooltip is hidden
+ * onhidden: function() { ... },
+ *
+ * // Link any tooltips when multiple charts are on the screen where same x coordinates are available
+ * // Useful for timeseries correlation
+ * linked: true,
+ *
+ * // Specify name to interact those with the same name only.
+ * linked: {
+ * name: "some-group"
+ * }
+ * }
+ */
+ tooltip_show: !0,
+ tooltip_grouped: !0,
+ tooltip_format_title: undefined,
+ tooltip_format_name: undefined,
+ tooltip_format_value: undefined,
+ tooltip_position: undefined,
+ tooltip_contents: function tooltip_contents(d, defaultTitleFormat, defaultValueFormat, color) {
+ return this.getTooltipContent ? this.getTooltipContent(d, defaultTitleFormat, defaultValueFormat, color) : "";
+ },
+ tooltip_init_show: !1,
+ tooltip_init_x: 0,
+ tooltip_init_position: {
+ top: "0px",
+ left: "50px"
+ },
+ tooltip_linked: !1,
+ tooltip_linked_name: "",
+ tooltip_onshow: function tooltip_onshow() {},
+ tooltip_onhide: function tooltip_onhide() {},
+ tooltip_onshown: function tooltip_onshown() {},
+ tooltip_onhidden: function tooltip_onhidden() {},
+ tooltip_order: null,
+
+ /**
+ * Set title options
+ * @name title
+ * @memberOf Options
+ * @type {Object}
+ * @property {String} [title.text]
+ * @property {Number} [title.padding.top=0]
+ * @property {Number} [title.padding.right=0]
+ * @property {Number} [title.padding.bottom=0]
+ * @property {Number} [title.padding.left=0]
+ * @property {String} [title.position=top-center]
+ * @example
+ * title: {
+ * text: "Title Text",
+ * padding: {
+ * top: 10,
+ * right: 10,
+ * bottom: 10,
+ * left: 10
+ * },
+ * position: "top-center"
+ * }
+ */
+ title_text: undefined,
+ title_padding: {
+ top: 0,
+ right: 0,
+ bottom: 0,
+ left: 0
+ },
+ title_position: "top-center"
+ };
+};
+
+exports.default = Options;
+module.exports = exports["default"];
+
+/***/ }),
+/* 19 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Scale = __webpack_require__(10),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ getScale: function getScale(min, max, forTimeseries) {
+ return (forTimeseries ? (0, _d3Scale.scaleTime)() : (0, _d3Scale.scaleLinear)()).range([min, max]);
+ },
+
+
+ /**
+ * Get x Axis scale function
+ * @param {Number} min
+ * @param {Number} max
+ * @param {Number} domain
+ * @param {Function} offset The offset getter to be sum
+ * @return {Function} scale
+ * @private
+ */
+ getX: function getX(min, max, domain, offset) {
+ var $$ = this,
+ scale = $$.zoomScale || $$.getScale(min, max, $$.isTimeSeries());
+
+
+ return $$.getCustomizedScale(domain ? scale.domain(domain) : scale, offset);
+ },
+ getY: function getY(min, max, domain) {
+ var scale = this.getScale(min, max, this.isTimeSeriesY());
+
+ return domain && scale.domain(domain), scale;
+ },
+
+
+ /**
+ * Get customized scale
+ * @param {d3.scaleLinear|d3.scaleTime} scaleValue
+ * @param {Function} offsetValue Offset getter to be sum
+ * @return {} scale
+ * @private
+ */
+ getCustomizedScale: function getCustomizedScale(scaleValue, offsetValue) {
+ var $$ = this,
+ offset = offsetValue || function () {
+ return $$.xAxis.tickOffset();
+ },
+ scale = function (d, raw) {
+ var v = scaleValue(d) + offset();
+
+ return raw ? v : Math.ceil(v);
+ };
+
+ // copy original scale methods
+ for (var key in scaleValue) scale[key] = scaleValue[key];
+
+ return scale.orgDomain = function () {
+ return scaleValue.domain();
+ }, scale.orgScale = function () {
+ return scaleValue;
+ }, $$.isCategorized() && (scale.domain = function (domainValue) {
+ var domain = domainValue;
+
+ return arguments.length ? (scaleValue.domain(domain), scale) : (domain = this.orgDomain(), [domain[0], domain[1] + 1]);
+ }), scale;
+ },
+ getYScale: function getYScale(id) {
+ return this.axis.getId(id) === "y2" ? this.y2 : this.y;
+ },
+ getSubYScale: function getSubYScale(id) {
+ return this.axis.getId(id) === "y2" ? this.subY2 : this.subY;
+ },
+
+
+ /**
+ * Update scale
+ * @private
+ * @param {Boolean} withoutTransitionAtInit - param is given at the init rendering
+ */
+ updateScales: function updateScales(withoutTransitionAtInit) {
+ var $$ = this,
+ config = $$.config,
+ isRotated = config.axis_rotated,
+ isInit = !$$.x;
+
+
+ // update edges
+ $$.xMin = isRotated ? 1 : 0, $$.xMax = isRotated ? $$.height : $$.width, $$.yMin = isRotated ? 0 : $$.height, $$.yMax = isRotated ? $$.width : 1, $$.subXMin = $$.xMin, $$.subXMax = $$.xMax, $$.subYMin = isRotated ? 0 : $$.height2, $$.subYMax = isRotated ? $$.width2 : 1, $$.x = $$.getX($$.xMin, $$.xMax, isInit ? undefined : $$.x.orgDomain(), function () {
+ return $$.xAxis.tickOffset();
+ }), $$.y = $$.getY($$.yMin, $$.yMax, isInit ? config.axis_y_default : $$.y.domain()), $$.y2 = $$.getY($$.yMin, $$.yMax, isInit ? config.axis_y2_default : $$.y2.domain()), $$.subX = $$.getX($$.xMin, $$.xMax, $$.orgXDomain, function (d) {
+ return d % 1 ? 0 : $$.subXAxis.tickOffset();
+ }), $$.subY = $$.getY($$.subYMin, $$.subYMax, isInit ? config.axis_y_default : $$.subY.domain()), $$.subY2 = $$.getY($$.subYMin, $$.subYMax, isInit ? config.axis_y2_default : $$.subY2.domain()), $$.xAxisTickFormat = $$.axis.getXAxisTickFormat(), $$.xAxisTickValues = $$.axis.getXAxisTickValues(), $$.yAxisTickValues = $$.axis.getYAxisTickValues(), $$.y2AxisTickValues = $$.axis.getY2AxisTickValues(), $$.xAxis = $$.axis.getXAxis("x", $$.x, $$.xOrient, $$.xAxisTickFormat, $$.xAxisTickValues, config.axis_x_tick_outer, withoutTransitionAtInit), $$.subXAxis = $$.axis.getXAxis("subx", $$.subX, $$.subXOrient, $$.xAxisTickFormat, $$.xAxisTickValues, config.axis_x_tick_outer), $$.yAxis = $$.axis.getYAxis("y", $$.y, $$.yOrient, config.axis_y_tick_format, $$.yAxisTickValues, config.axis_y_tick_outer), $$.y2Axis = $$.axis.getYAxis("y2", $$.y2, $$.y2Orient, config.axis_y2_tick_format, $$.y2AxisTickValues, config.axis_y2_tick_outer), $$.updateArc && $$.updateArc();
+ }
+}); /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+/***/ }),
+/* 20 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Array = __webpack_require__(6),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// selection
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ getYDomainMinMax: function getYDomainMinMax(targets, type) {
+ var $$ = this,
+ config = $$.config,
+ isMin = type === "min",
+ dataGroups = config.data_groups,
+ ids = $$.mapToIds(targets),
+ ys = $$.getValuesAsIdKeyed(targets),
+ f = isMin ? _d3Array.min : _d3Array.max;
+
+
+ return dataGroups.length > 0 && function () {
+
+ for (var hasValue = $$["has" + (isMin ? "Negative" : "Positive") + "ValueInTargets"](targets), baseId = void 0, idsInGroup = void 0, j = 0; idsInGroup = dataGroups[j]; j++) if (idsInGroup = idsInGroup.filter(function (v) {
+ return ids.indexOf(v) >= 0;
+ }), idsInGroup.length !== 0) {
+
+ // Consider values
+ if (baseId = idsInGroup[0], hasValue && ys[baseId]) {
+ var setter = isMin ? function (v, i) {
+ ys[baseId][i] = v < 0 ? v : 0;
+ } : function (v, i) {
+ ys[baseId][i] = v > 0 ? v : 0;
+ };
+
+ ys[baseId].forEach(setter);
+ }
+
+ // Compute min
+ for (var id, _ret2, _loop = function (k, id) {
+ return ys[id] ? void ys[id].forEach(function (v, i) {
+ var val = +v,
+ meetCondition = isMin ? val > 0 : val < 0;
+ $$.axis.getId(id) === $$.axis.getId(baseId) && ys[baseId] && !(hasValue && meetCondition) && (ys[baseId][i] += val);
+ }) : "continue";
+ }, k = 1; id = idsInGroup[k]; k++) _ret2 = _loop(k, id), _ret2 === "continue";
+ }
+ }(), f(Object.keys(ys).map(function (key) {
+ return f(ys[key]);
+ }));
+ },
+ getYDomainMin: function getYDomainMin(targets) {
+ return this.getYDomainMinMax(targets, "min");
+ },
+ getYDomainMax: function getYDomainMax(targets) {
+ return this.getYDomainMinMax(targets, "max");
+ },
+ getYDomain: function getYDomain(targets, axisId, xDomain) {
+ var $$ = this,
+ config = $$.config,
+ targetsByAxisId = targets.filter(function (t) {
+ return $$.axis.getId(t.id) === axisId;
+ }),
+ yTargets = xDomain ? $$.filterByXDomain(targetsByAxisId, xDomain) : targetsByAxisId,
+ yMin = axisId === "y2" ? config.axis_y2_min : config.axis_y_min,
+ yMax = axisId === "y2" ? config.axis_y2_max : config.axis_y_max,
+ yDomainMin = $$.getYDomainMin(yTargets),
+ yDomainMax = $$.getYDomainMax(yTargets),
+ center = axisId === "y2" ? config.axis_y2_center : config.axis_y_center,
+ isZeroBased = $$.hasType("bar", yTargets) && config.bar_zerobased || $$.hasType("area", yTargets) && config.area_zerobased,
+ isInverted = axisId === "y2" ? config.axis_y2_inverted : config.axis_y_inverted,
+ showHorizontalDataLabel = $$.hasDataLabel() && config.axis_rotated,
+ showVerticalDataLabel = $$.hasDataLabel() && !config.axis_rotated,
+ lengths = void 0;
+
+ // MEMO: avoid inverting domain unexpectedly
+
+ if (yDomainMin = (0, _util.isValue)(yMin) ? yMin : (0, _util.isValue)(yMax) ? yDomainMin < yMax ? yDomainMin : yMax - 10 : yDomainMin, yDomainMax = (0, _util.isValue)(yMax) ? yMax : (0, _util.isValue)(yMin) ? yMin < yDomainMax ? yDomainMax : yMin + 10 : yDomainMax, yTargets.length === 0) // use current domain if target of axisId is none
+ return axisId === "y2" ? $$.y2.domain() : $$.y.domain();
+
+ isNaN(yDomainMin) && (yDomainMin = 0), isNaN(yDomainMax) && (yDomainMax = yDomainMin), yDomainMin === yDomainMax && (yDomainMin < 0 ? yDomainMax = 0 : yDomainMin = 0);
+ var isAllPositive = yDomainMin >= 0 && yDomainMax >= 0,
+ isAllNegative = yDomainMin <= 0 && yDomainMax <= 0;
+ ((0, _util.isValue)(yMin) && isAllPositive || (0, _util.isValue)(yMax) && isAllNegative) && (isZeroBased = !1), isZeroBased && (isAllPositive && (yDomainMin = 0), isAllNegative && (yDomainMax = 0));
+ var domainLength = Math.abs(yDomainMax - yDomainMin),
+ paddingTop = domainLength * .1,
+ paddingBottom = domainLength * .1;
+
+
+ if ((0, _util.isDefined)(center)) {
+ var yDomainAbs = Math.max(Math.abs(yDomainMin), Math.abs(yDomainMax));
+
+ yDomainMax = center + yDomainAbs, yDomainMin = center - yDomainAbs;
+ }
+
+ // add padding for data label
+ if (showHorizontalDataLabel) {
+ lengths = $$.getDataLabelLength(yDomainMin, yDomainMax, "width");
+ var diff = (0, _util.diffDomain)($$.y.range()),
+ ratio = [lengths[0] / diff, lengths[1] / diff];
+ paddingTop += domainLength * (ratio[1] / (1 - ratio[0] - ratio[1])), paddingBottom += domainLength * (ratio[0] / (1 - ratio[0] - ratio[1]));
+ } else showVerticalDataLabel && (lengths = $$.getDataLabelLength(yDomainMin, yDomainMax, "height"), paddingTop += $$.axis.convertPixelsToAxisPadding(lengths[1], domainLength), paddingBottom += $$.axis.convertPixelsToAxisPadding(lengths[0], domainLength));
+
+ axisId === "y" && (0, _util.notEmpty)(config.axis_y_padding) && (paddingTop = $$.axis.getPadding(config.axis_y_padding, "top", paddingTop, domainLength), paddingBottom = $$.axis.getPadding(config.axis_y_padding, "bottom", paddingBottom, domainLength)), axisId === "y2" && (0, _util.notEmpty)(config.axis_y2_padding) && (paddingTop = $$.axis.getPadding(config.axis_y2_padding, "top", paddingTop, domainLength), paddingBottom = $$.axis.getPadding(config.axis_y2_padding, "bottom", paddingBottom, domainLength)), isZeroBased && (isAllPositive && (paddingBottom = yDomainMin), isAllNegative && (paddingTop = -yDomainMax));
+
+
+ var domain = [yDomainMin - paddingBottom, yDomainMax + paddingTop];
+
+ return isInverted ? domain.reverse() : domain;
+ },
+ getXDomainMinMax: function getXDomainMinMax(targets, type) {
+ var $$ = this,
+ value = $$.config["axis_x_" + type],
+ f = type === "min" ? _d3Array.min : _d3Array.max;
+
+
+ return (0, _util.isDefined)(value) ? $$.isTimeSeries() ? $$.parseDate(value) : value : f(targets, function (t) {
+ return f(t.values, function (v) {
+ return v.x;
+ });
+ });
+ },
+ getXDomainMin: function getXDomainMin(targets) {
+ return this.getXDomainMinMax(targets, "min");
+ },
+ getXDomainMax: function getXDomainMax(targets) {
+ return this.getXDomainMinMax(targets, "max");
+ },
+ getXDomainPadding: function getXDomainPadding(domain) {
+ var $$ = this,
+ config = $$.config,
+ diff = domain[1] - domain[0],
+ xPadding = config.axis_x_padding,
+ maxDataCount = void 0,
+ padding = void 0;
+ $$.isCategorized() ? padding = 0 : $$.hasType("bar") ? (maxDataCount = $$.getMaxDataCount(), padding = maxDataCount > 1 ? diff / (maxDataCount - 1) / 2 : .5) : padding = diff * .01;
+ var left = padding,
+ right = padding;
+
+
+ return (0, _util.isObject)(xPadding) && (0, _util.notEmpty)(xPadding) ? (left = (0, _util.isValue)(xPadding.left) ? xPadding.left : padding, right = (0, _util.isValue)(xPadding.right) ? xPadding.right : padding) : (0, _util.isNumber)(config.axis_x_padding) && (left = xPadding, right = xPadding), { left: left, right: right };
+ },
+ getXDomain: function getXDomain(targets) {
+ var $$ = this,
+ xDomain = [$$.getXDomainMin(targets), $$.getXDomainMax(targets)],
+ firstX = xDomain[0],
+ lastX = xDomain[1],
+ padding = $$.getXDomainPadding(xDomain),
+ min = 0,
+ max = 0;
+ // show center of x domain if min and max are the same
+
+ return firstX - lastX !== 0 || $$.isCategorized() || ($$.isTimeSeries() ? (firstX = new Date(firstX.getTime() * .5), lastX = new Date(lastX.getTime() * 1.5)) : (firstX = firstX === 0 ? 1 : firstX * .5, lastX = lastX === 0 ? -1 : lastX * 1.5)), (firstX || firstX === 0) && (min = $$.isTimeSeries() ? new Date(firstX.getTime() - padding.left) : firstX - padding.left), (lastX || lastX === 0) && (max = $$.isTimeSeries() ? new Date(lastX.getTime() + padding.right) : lastX + padding.right), [min, max];
+ },
+ updateXDomain: function updateXDomain(targets, withUpdateXDomain, withUpdateOrgXDomain, withTrim, domain) {
+ var $$ = this,
+ config = $$.config,
+ zoomEnabled = config.zoom_enabled;
+
+
+ if (withUpdateOrgXDomain && ($$.x.domain(domain || (0, _d3Array.extent)($$.getXDomain(targets))), $$.orgXDomain = $$.x.domain(), zoomEnabled && $$.zoom.updateScaleExtent(), $$.subX.domain($$.x.domain()), $$.brush && $$.brush.scale($$.subX)), withUpdateXDomain) {
+ var domainValue = domain || !$$.brush || (0, _util.brushEmpty)($$) ? $$.orgXDomain : (0, _util.getBrushSelection)($$).map($$.subX.invert);
+
+ $$.x.domain(domainValue), zoomEnabled && $$.zoom.updateScaleExtent();
+ }
+
+ // Trim domain when too big by zoom mousemove event
+
+
+ return withTrim && $$.x.domain($$.trimXDomain($$.x.orgDomain())), $$.x.domain();
+ },
+ trimXDomain: function trimXDomain(domain) {
+ var zoomDomain = this.getZoomDomain(),
+ min = zoomDomain[0],
+ max = zoomDomain[1];
+
+
+ return domain[0] <= min && (domain[1] = +domain[1] + (min - domain[0]), domain[0] = min), max <= domain[1] && (domain[0] = +domain[0] - (domain[1] - max), domain[1] = max), domain;
+ }
+}); /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+/***/ }),
+/* 21 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Array = __webpack_require__(6),
+ _d3Collection = __webpack_require__(22),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ isX: function isX(key) {
+ var $$ = this,
+ config = $$.config,
+ dataKey = config.data_x && key === config.data_x,
+ existValue = (0, _util.notEmpty)(config.data_xs) && (0, _util.hasValue)(config.data_xs, key);
+
+
+ return dataKey || existValue;
+ },
+ isNotX: function isNotX(key) {
+ return !this.isX(key);
+ },
+ getXKey: function getXKey(id) {
+ var $$ = this,
+ config = $$.config;
+
+
+ return config.data_x ? config.data_x : (0, _util.notEmpty)(config.data_xs) ? config.data_xs[id] : null;
+ },
+ getXValuesOfXKey: function getXValuesOfXKey(key, targets) {
+ var $$ = this,
+ ids = targets && (0, _util.notEmpty)(targets) ? $$.mapToIds(targets) : [],
+ xValues = void 0;
+
+
+ return ids.forEach(function (id) {
+ $$.getXKey(id) === key && (xValues = $$.data.xs[id]);
+ }), xValues;
+ },
+ getIndexByX: function getIndexByX(x) {
+ var $$ = this,
+ data = $$.filterByX($$.data.targets, x);
+
+
+ return data.length ? data[0].index : null;
+ },
+ getXValue: function getXValue(id, i) {
+ var $$ = this;
+
+ return id in $$.data.xs && $$.data.xs[id] && (0, _util.isValue)($$.data.xs[id][i]) ? $$.data.xs[id][i] : i;
+ },
+ getOtherTargetXs: function getOtherTargetXs() {
+ var $$ = this,
+ idsForX = Object.keys($$.data.xs);
+
+
+ return idsForX.length ? $$.data.xs[idsForX[0]] : null;
+ },
+ getOtherTargetX: function getOtherTargetX(index) {
+ var xs = this.getOtherTargetXs();
+
+ return xs && index < xs.length ? xs[index] : null;
+ },
+ addXs: function addXs(xs) {
+ var $$ = this;
+
+ Object.keys(xs).forEach(function (id) {
+ $$.config.data_xs[id] = xs[id];
+ });
+ },
+ hasMultipleX: function hasMultipleX(xs) {
+ // https://github.com/d3/d3-collection
+ return (0, _d3Collection.set)(Object.keys(xs).map(function (id) {
+ return xs[id];
+ })).size() > 1;
+ },
+ isMultipleX: function isMultipleX() {
+ return (0, _util.notEmpty)(this.config.data_xs) || !this.config.data_xSort || this.hasType("bubble") || this.hasType("scatter");
+ },
+ addName: function addName(data) {
+ var $$ = this,
+ name = void 0;
+
+
+ return data && (name = $$.config.data_names[data.id], data.name = name === undefined ? data.id : name), data;
+ },
+ getAllValuesOnIndex: function getAllValuesOnIndex(index) {
+ var $$ = this;
+
+ return $$.filterTargetsToShow($$.data.targets).map(function (t) {
+ return $$.addName($$.getValueOnIndex(t.values, index));
+ });
+ },
+ getValueOnIndex: function getValueOnIndex(values, index) {
+ var valueOnIndex = values.filter(function (v) {
+ return v.index === index;
+ });
+
+ return valueOnIndex.length ? valueOnIndex[0] : null;
+ },
+ updateTargetX: function updateTargetX(targets, x) {
+ var $$ = this;
+
+ targets.forEach(function (t) {
+ t.values.forEach(function (v, i) {
+ v.x = $$.generateTargetX(x[i], t.id, i);
+ }), $$.data.xs[t.id] = x;
+ });
+ },
+ updateTargetXs: function updateTargetXs(targets, xs) {
+ var $$ = this;
+
+ targets.forEach(function (t) {
+ xs[t.id] && $$.updateTargetX([t], xs[t.id]);
+ });
+ },
+ generateTargetX: function generateTargetX(rawX, id, index) {
+ var $$ = this,
+ x = index;
+
+
+ return $$.isTimeSeries() ? x = rawX ? $$.parseDate(rawX) : $$.parseDate($$.getXValue(id, index)) : $$.isCustomX() && !$$.isCategorized() && (x = (0, _util.isValue)(rawX) ? +rawX : $$.getXValue(id, index)), x;
+ },
+ cloneTarget: function cloneTarget(target) {
+ return {
+ id: target.id,
+ id_org: target.id_org,
+ values: target.values.map(function (d) {
+ return { x: d.x, value: d.value, id: d.id };
+ })
+ };
+ },
+ updateXs: function updateXs() {
+ var $$ = this;
+
+ $$.data.targets.length && ($$.xs = [], $$.data.targets[0].values.forEach(function (v) {
+ $$.xs[v.index] = v.x;
+ }));
+ },
+ getPrevX: function getPrevX(i) {
+ var x = this.xs[i - 1];
+
+ return (0, _util.isDefined)(x) ? x : null;
+ },
+ getNextX: function getNextX(i) {
+ var x = this.xs[i + 1];
+
+ return (0, _util.isDefined)(x) ? x : null;
+ },
+
+
+ /**
+ * Get base value isAreaRangeType
+ * @param data Data object
+ * @return {Number}
+ * @private
+ */
+ getBaseValue: function getBaseValue(data) {
+ var $$ = this,
+ value = data.value;
+
+ // In case of area-range, data is given as: [low, mid, high] or {low, mid, high}
+ // will take the 'mid' as the base value
+
+ return value && $$.isAreaRangeType(data) && (value = $$.getAreaRangeData(data, "mid")), value;
+ },
+
+
+ /**
+ * Get min/max value from the data
+ * @private
+ * @param {Array} data array data to be evaluated
+ * @return {{min: {Number}, max: {Number}}}
+ */
+ getMinMaxValue: function getMinMaxValue(data) {
+ var getBaseValue = this.getBaseValue.bind(this),
+ min = void 0,
+ max = void 0;
+
+
+ return (data || this.data.targets.map(function (t) {
+ return t.values;
+ })).forEach(function (v) {
+ min = (0, _d3Array.min)([min, (0, _d3Array.min)(v, getBaseValue)]), max = (0, _d3Array.max)([max, (0, _d3Array.max)(v, getBaseValue)]);
+ }), { min: min, max: max };
+ },
+
+
+ /**
+ * Get the min/max data
+ * @private
+ * @return {{min: Array, max: Array}}
+ */
+ getMinMaxData: function getMinMaxData() {
+ var $$ = this,
+ minMaxData = $$.getCache("$minMaxData");
+
+
+ if (!minMaxData) {
+ var data = $$.data.targets.map(function (t) {
+ return t.values;
+ }),
+ minMax = $$.getMinMaxValue(data),
+ min = [],
+ max = [];
+ data.forEach(function (v) {
+ var minData = $$.getFilteredDataByValue(v, minMax.min),
+ maxData = $$.getFilteredDataByValue(v, minMax.max);
+ minData.length && (min = min.concat(minData)), maxData.length && (max = max.concat(maxData));
+ }), $$.addCache("$minMaxData", minMaxData = { min: min, max: max });
+ }
+
+ return minMaxData;
+ },
+
+
+ /**
+ * Get total data sum
+ * @private
+ * @return {Number}
+ */
+ getTotalDataSum: function getTotalDataSum() {
+ var $$ = this,
+ totalDataSum = $$.getCache("$totalDataSum");
+
+
+ if (!totalDataSum) {
+ var total = 0;
+
+ $$.data.targets.map(function (t) {
+ return t.values;
+ }).forEach(function (v) {
+ total += (0, _d3Array.sum)(v, function (t) {
+ return t.value;
+ });
+ }), $$.addCache("$totalDataSum", totalDataSum = total);
+ }
+
+ return totalDataSum;
+ },
+
+
+ /**
+ * Get filtered data by value
+ * @param {Object} data
+ * @param {Number} value
+ * @return {Array} filtered array data
+ * @private
+ */
+ getFilteredDataByValue: function getFilteredDataByValue(data, value) {
+ var _this = this;
+
+ return data.filter(function (t) {
+ return _this.getBaseValue(t) === value;
+ });
+ },
+
+
+ /**
+ * Return the max length of the data
+ * @return {Number} max data length
+ * @private
+ */
+ getMaxDataCount: function getMaxDataCount() {
+ return (0, _d3Array.max)(this.data.targets, function (t) {
+ return t.values.length;
+ });
+ },
+ getMaxDataCountTarget: function getMaxDataCountTarget(targets) {
+ var length = targets.length,
+ max = 0,
+ maxTarget = void 0;
+
+
+ return length > 1 ? targets.forEach(function (t) {
+ t.values.length > max && (maxTarget = t, max = t.values.length);
+ }) : maxTarget = length ? targets[0] : null, maxTarget;
+ },
+ mapToIds: function mapToIds(targets) {
+ return targets.map(function (d) {
+ return d.id;
+ });
+ },
+ mapToTargetIds: function mapToTargetIds(ids) {
+ var $$ = this;
+
+ return ids ? (0, _util.isArray)(ids) ? ids.concat() : [ids] : $$.mapToIds($$.data.targets);
+ },
+ hasTarget: function hasTarget(targets, id) {
+ var ids = this.mapToIds(targets);
+
+ for (var val, i = 0; val = ids[i]; i++) if (val === id) return !0;
+
+ return !1;
+ },
+ isTargetToShow: function isTargetToShow(targetId) {
+ return this.hiddenTargetIds.indexOf(targetId) < 0;
+ },
+ isLegendToShow: function isLegendToShow(targetId) {
+ return this.hiddenLegendIds.indexOf(targetId) < 0;
+ },
+ filterTargetsToShow: function filterTargetsToShow(targets) {
+ var $$ = this;
+
+ return targets.filter(function (t) {
+ return $$.isTargetToShow(t.id);
+ });
+ },
+ mapTargetsToUniqueXs: function mapTargetsToUniqueXs(targets) {
+ var $$ = this,
+ xs = (0, _d3Collection.set)((0, _d3Array.merge)(targets.map(function (t) {
+ return t.values.map(function (v) {
+ return +v.x;
+ });
+ }))).values();
+
+
+ return xs = $$.isTimeSeries() ? xs.map(function (x) {
+ return new Date(+x);
+ }) : xs.map(function (x) {
+ return +x;
+ }), xs.sort(function (a, b) {
+ return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;
+ });
+ },
+ addHiddenTargetIds: function addHiddenTargetIds(targetIds) {
+ this.hiddenTargetIds = this.hiddenTargetIds.concat(targetIds);
+ },
+ removeHiddenTargetIds: function removeHiddenTargetIds(targetIds) {
+ this.hiddenTargetIds = this.hiddenTargetIds.filter(function (id) {
+ return targetIds.indexOf(id) < 0;
+ });
+ },
+ addHiddenLegendIds: function addHiddenLegendIds(targetIds) {
+ this.hiddenLegendIds = this.hiddenLegendIds.concat(targetIds);
+ },
+ removeHiddenLegendIds: function removeHiddenLegendIds(targetIds) {
+ this.hiddenLegendIds = this.hiddenLegendIds.filter(function (id) {
+ return targetIds.indexOf(id) < 0;
+ });
+ },
+ getValuesAsIdKeyed: function getValuesAsIdKeyed(targets) {
+ var ys = {};
+
+ return targets.forEach(function (t) {
+ var data = [];
+
+ t.values.forEach(function (v) {
+ var value = v.value;
+
+ (0, _util.isArray)(value) ? data.push.apply(data, value) : (0, _util.isObject)(value) && "high" in value ? data.push.apply(data, Object.values(value)) : data.push(value);
+ }), ys[t.id] = data;
+ }), ys;
+ },
+ checkValueInTargets: function checkValueInTargets(targets, checker) {
+ var ids = Object.keys(targets),
+ values = void 0;
+
+
+ for (var i = 0; i < ids.length; i++) {
+ values = targets[ids[i]].values;
+
+
+ for (var j = 0; j < values.length; j++) if (checker(values[j].value)) return !0;
+ }
+
+ return !1;
+ },
+ hasNegativeValueInTargets: function hasNegativeValueInTargets(targets) {
+ return this.checkValueInTargets(targets, function (v) {
+ return v < 0;
+ });
+ },
+ hasPositiveValueInTargets: function hasPositiveValueInTargets(targets) {
+ return this.checkValueInTargets(targets, function (v) {
+ return v > 0;
+ });
+ },
+ _checkOrder: function _checkOrder(type) {
+ var config = this.config;
+
+ return (0, _util.isString)(config.data_order) && config.data_order.toLowerCase() === type;
+ },
+ isOrderDesc: function isOrderDesc() {
+ return this._checkOrder("desc");
+ },
+ isOrderAsc: function isOrderAsc() {
+ return this._checkOrder("asc");
+ },
+
+
+ /**
+ * Sort targets data
+ * @param {Array} targetsValue
+ * @return {Array}
+ * @private
+ */
+ orderTargets: function orderTargets(targetsValue) {
+ var $$ = this,
+ config = $$.config,
+ targets = [].concat(targetsValue),
+ orderAsc = $$.isOrderAsc(),
+ orderDesc = $$.isOrderDesc();
+ // TODO: accept name array for order
+
+ return orderAsc || orderDesc ? targets.sort(function (t1, t2) {
+ var reducer = function (p, c) {
+ return p + Math.abs(c.value);
+ },
+ t1Sum = t1.values.reduce(reducer, 0),
+ t2Sum = t2.values.reduce(reducer, 0);
+
+ return orderAsc ? t2Sum - t1Sum : t1Sum - t2Sum;
+ }) : (0, _util.isFunction)(config.data_order) && targets.sort(config.data_order), targets;
+ },
+ filterByX: function filterByX(targets, x) {
+ return (0, _d3Array.merge)(targets.map(function (t) {
+ return t.values;
+ })).filter(function (v) {
+ return v.x - x === 0;
+ });
+ },
+ filterRemoveNull: function filterRemoveNull(data) {
+ var _this2 = this;
+
+ return data.filter(function (d) {
+ return (0, _util.isValue)(_this2.getBaseValue(d));
+ });
+ },
+ filterByXDomain: function filterByXDomain(targets, xDomain) {
+ return targets.map(function (t) {
+ return {
+ id: t.id,
+ id_org: t.id_org,
+ values: t.values.filter(function (v) {
+ return xDomain[0] <= v.x && v.x <= xDomain[1];
+ })
+ };
+ });
+ },
+ hasDataLabel: function hasDataLabel() {
+ var dataLabels = this.config.data_labels;
+
+ return (0, _util.isBoolean)(dataLabels) && dataLabels || (0, _util.isObjectType)(dataLabels) && (0, _util.notEmpty)(dataLabels);
+ },
+ getDataLabelLength: function getDataLabelLength(min, max, key) {
+ var $$ = this,
+ lengths = [0, 0];
+
+
+ return $$.selectChart.select("svg").selectAll(".dummy").data([min, max]).enter().append("text").text(function (d) {
+ return $$.dataLabelFormat(d.id)(d);
+ }).each(function (d, i) {
+ lengths[i] = this.getBoundingClientRect()[key] * 1.3;
+ }).remove(), lengths;
+ },
+ isNoneArc: function isNoneArc(d) {
+ return this.hasTarget(this.data.targets, d.id);
+ },
+ isArc: function isArc(d) {
+ return "data" in d && this.hasTarget(this.data.targets, d.data.id);
+ },
+ findSameXOfValues: function findSameXOfValues(values, index) {
+ var targetX = values[index].x,
+ sames = [],
+ i = void 0;
+
+
+ for (i = index - 1; i >= 0 && !(targetX !== values[i].x); i--) sames.push(values[i]);
+
+ for (i = index; i < values.length && !(targetX !== values[i].x); i++) sames.push(values[i]);
+
+ return sames;
+ },
+ findClosestFromTargets: function findClosestFromTargets(targets, pos) {
+ var $$ = this,
+ candidates = targets.map(function (target) {
+ return $$.findClosest(target.values, pos);
+ });
+ // map to array of closest points of each target
+
+ // decide closest point and return
+ return $$.findClosest(candidates, pos);
+ },
+ findClosest: function findClosest(values, pos) {
+ var $$ = this,
+ minDist = $$.config.point_sensitivity,
+ closest = void 0;
+
+ // find mouseovering bar
+
+ return values.filter(function (v) {
+ return v && $$.isBarType(v.id);
+ }).forEach(function (v) {
+ var shape = $$.main.select("." + _classes2.default.bars + $$.getTargetSelectorSuffix(v.id) + " ." + _classes2.default.bar + "-" + v.index).node();
+
+ !closest && $$.isWithinBar(shape) && (closest = v);
+ }), values.filter(function (v) {
+ return v && !$$.isBarType(v.id);
+ }).forEach(function (v) {
+ var d = $$.dist(v, pos);
+
+ d < minDist && (minDist = d, closest = v);
+ }), closest;
+ },
+ dist: function dist(data, pos) {
+ var $$ = this,
+ isRotated = $$.config.axis_rotated,
+ xIndex = isRotated ? 1 : 0,
+ yIndex = isRotated ? 0 : 1,
+ y = $$.circleY(data, data.index),
+ x = $$.x(data.x);
+
+
+ return Math.sqrt(Math.pow(x - pos[xIndex], 2) + Math.pow(y - pos[yIndex], 2));
+ },
+
+
+ /**
+ * Convert data for step type
+ * @param {Array} values Object data values
+ * @return {Array}
+ * @private
+ */
+ convertValuesToStep: function convertValuesToStep(values) {
+ var $$ = this,
+ config = $$.config,
+ isRotated = config.axis_rotated,
+ stepType = config.line_step_type,
+ isCategorized = $$.isCategorized(),
+ converted = (0, _util.isArray)(values) ? values.concat() : [values];
+
+
+ if (!isRotated && !isCategorized) return values;
+
+ // insert & append cloning first/last value to be fully rendered covering on each gap sides
+ var id = converted[0].id,
+ x = converted[0].x - 1,
+ value = converted[0].value;
+
+ // insert
+
+ return isCategorized && converted.unshift({ x: x, value: value, id: id }), stepType === "step-after" && converted.unshift({ x: x - 1, value: value, id: id }), x = converted.length, value = converted[x - 1].value, isCategorized && converted.push({ x: x, value: value, id: id }), stepType === "step-before" && converted.push({ x: x + 1, value: value, id: id }), converted;
+ },
+ convertValuesToRange: function convertValuesToRange(values) {
+ var converted = (0, _util.isArray)(values) ? values.concat() : [values],
+ ranges = [];
+
+
+ return converted.forEach(function (range) {
+ var x = range.x,
+ id = range.id;
+ ranges.push({
+ x: x,
+ id: id,
+ value: range.value[0]
+ }), ranges.push({
+ x: x,
+ id: id,
+ value: range.value[2]
+ });
+ }), ranges;
+ },
+ updateDataAttributes: function updateDataAttributes(name, attrs) {
+ var $$ = this,
+ config = $$.config,
+ current = config["data_" + name];
+ return (0, _util.isUndefined)(attrs) ? current : (Object.keys(attrs).forEach(function (id) {
+ current[id] = attrs[id];
+ }), $$.redraw({ withLegend: !0 }), current);
+ },
+ getAreaRangeData: function getAreaRangeData(d, type) {
+ var value = d.value;
+
+ if ((0, _util.isArray)(value)) {
+ var index = ["high", "mid", "low"].indexOf(type);
+
+ return index === -1 ? null : value[index];
+ }
+
+ return value[type];
+ }
+}); /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+/***/ }),
+/* 22 */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE__22__;
+
+/***/ }),
+/* 23 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Dsv = __webpack_require__(24),
+ _d3Collection = __webpack_require__(22),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ convertUrlToData: function convertUrlToData(url) {
+ var _this = this,
+ mimeType = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : "csv",
+ headers = arguments[2],
+ keys = arguments[3],
+ done = arguments[4],
+ req = new XMLHttpRequest();
+
+ if (headers) for (var _iterator = Object.keys(headers), _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
+ var _ref;
+
+ if (_isArray) {
+ if (_i >= _iterator.length) break;
+ _ref = _iterator[_i++];
+ } else {
+ if (_i = _iterator.next(), _i.done) break;
+ _ref = _i.value;
+ }
+
+ var header = _ref;
+ req.setRequestHeader(header, headers[header]);
+ }
+
+ req.open("GET", url), req.onreadystatechange = function () {
+ if (req.readyState === 4) if (req.status === 200) {
+ var response = req.responseText;
+
+ response && done.call(_this, _this["convert" + (0, _util.capitalize)(mimeType) + "ToData"](mimeType === "json" ? JSON.parse(response) : response, keys));
+ } else throw new Error(url + ": Something went wrong loading!");
+ }, req.send();
+ },
+ _convertCsvTsvToData: function _convertCsvTsvToData(parser, xsv) {
+ var rows = parser.rows(xsv),
+ d = void 0;
+
+
+ return rows.length === 1 ? (d = [{}], rows[0].forEach(function (id) {
+ d[0][id] = null;
+ })) : d = parser.parse(xsv), d;
+ },
+ convertCsvToData: function convertCsvToData(xsv) {
+ return this._convertCsvTsvToData({
+ rows: _d3Dsv.csvParseRows,
+ parse: _d3Dsv.csvParse
+ }, xsv);
+ },
+ convertTsvToData: function convertTsvToData(tsv) {
+ return this._convertCsvTsvToData({
+ rows: _d3Dsv.tsvParseRows,
+ parse: _d3Dsv.tsvParse
+ }, tsv);
+ },
+ convertJsonToData: function convertJsonToData(json, keysParam) {
+ var _this2 = this,
+ config = this.config,
+ newRows = [],
+ targetKeys = void 0,
+ data = void 0;
+
+ if ((0, _util.isArray)(json)) {
+ var keys = keysParam || config.data_keys;
+
+ keys.x ? (targetKeys = keys.value.concat(keys.x), config.data_x = keys.x) : targetKeys = keys.value, newRows.push(targetKeys), json.forEach(function (o) {
+ var newRow = [];
+
+ for (var _iterator2 = targetKeys, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {
+ var _ref2;
+
+ if (_isArray2) {
+ if (_i2 >= _iterator2.length) break;
+ _ref2 = _iterator2[_i2++];
+ } else {
+ if (_i2 = _iterator2.next(), _i2.done) break;
+ _ref2 = _i2.value;
+ }
+
+ var key = _ref2;
+
+ // convert undefined to null because undefined data will be removed in convertDataToTargets()
+ var v = _this2.findValueInJson(o, key);
+
+ (0, _util.isUndefined)(v) && (v = null), newRow.push(v);
+ }
+
+ newRows.push(newRow);
+ }), data = this.convertRowsToData(newRows);
+ } else Object.keys(json).forEach(function (key) {
+ var tmp = json[key].concat();
+
+ tmp.unshift(key), newRows.push(tmp);
+ }), data = this.convertColumnsToData(newRows);
+
+ return data;
+ },
+ findValueInJson: function findValueInJson(object, path) {
+ if (object[path] !== undefined) return object[path];
+
+ var convertedPath = path.replace(/\[(\w+)\]/g, ".$1"),
+ pathArray = convertedPath.replace(/^\./, "").split("."),
+ target = object; // convert indexes to properties (replace [] with .)
+ // strip a leading dot
+
+ for (var _iterator3 = pathArray, _isArray3 = Array.isArray(_iterator3), _i3 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) {
+ var _ref3;
+
+ if (_isArray3) {
+ if (_i3 >= _iterator3.length) break;
+ _ref3 = _iterator3[_i3++];
+ } else {
+ if (_i3 = _iterator3.next(), _i3.done) break;
+ _ref3 = _i3.value;
+ }
+
+ var k = _ref3;
+
+ if (k in target) target = target[k];else {
+ target = undefined;
+
+ break;
+ }
+ }
+
+ return target;
+ },
+ convertRowsToData: function convertRowsToData(rows) {
+ var keys = rows[0],
+ newRows = [];
+
+
+ for (var i = 1, len1 = rows.length; i < len1; i++) {
+ var newRow = {};
+
+ for (var j = 0, len2 = rows[i].length; j < len2; j++) {
+ if ((0, _util.isUndefined)(rows[i][j])) throw new Error("Source data is missing a component at (" + i + ", " + j + ")!");
+
+ newRow[keys[j]] = rows[i][j];
+ }
+
+ newRows.push(newRow);
+ }
+
+ return newRows;
+ },
+ convertColumnsToData: function convertColumnsToData(columns) {
+ var newRows = [];
+
+ for (var i = 0, len1 = columns.length; i < len1; i++) {
+ var key = columns[i][0];
+
+ for (var j = 1, len2 = columns[i].length; j < len2; j++) {
+
+ if ((0, _util.isUndefined)(newRows[j - 1]) && (newRows[j - 1] = {}), (0, _util.isUndefined)(columns[i][j])) throw new Error("Source data is missing a component at (" + i + ", " + j + ")!");
+
+ newRows[j - 1][key] = columns[i][j];
+ }
+ }
+
+ return newRows;
+ },
+ convertDataToTargets: function convertDataToTargets(data, appendXs) {
+ var _this3 = this,
+ $$ = this,
+ config = $$.config,
+ ids = (0, _d3Collection.keys)(data[0]).filter($$.isNotX, $$),
+ xs = (0, _d3Collection.keys)(data[0]).filter($$.isX, $$),
+ xsData = void 0;
+
+ ids.forEach(function (id) {
+ var xKey = _this3.getXKey(id);
+
+ _this3.isCustomX() || _this3.isTimeSeries() ? xs.indexOf(xKey) >= 0 ? xsData = (appendXs && $$.data.xs[id] || []).concat(data.map(function (d) {
+ return d[xKey];
+ }).filter(_util.isValue).map(function (rawX, i) {
+ return $$.generateTargetX(rawX, id, i);
+ })) : config.data_x ? xsData = _this3.getOtherTargetXs() : (0, _util.notEmpty)(config.data_xs) && (xsData = $$.getXValuesOfXKey(xKey, $$.data.targets)) : xsData = data.map(function (d, i) {
+ return i;
+ }), xsData && (_this3.data.xs[id] = xsData);
+ }), ids.forEach(function (id) {
+ if (!xsData) throw new Error("x is not defined for id = \"" + id + "\".");
+ });
+
+
+ // convert to target
+ var targets = ids.map(function (id, index) {
+ var convertedId = config.data_idConverter(id),
+ xKey = $$.getXKey(id),
+ isCategorized = $$.isCustomX() && $$.isCategorized(),
+ hasCategory = isCategorized && data.map(function (v) {
+ return v.x;
+ }).every(function (v) {
+ return config.axis_x_categories.indexOf(v) > -1;
+ });
+
+
+ return {
+ id: convertedId,
+ id_org: id,
+ values: data.map(function (d, i) {
+ var rawX = d[xKey],
+ value = d[id],
+ x = void 0;
+
+
+ return value = value === null || isNaN(value) ? (0, _util.isArray)(value) || (0, _util.isObject)(value) && value.high ? value : null : +d[id], isCategorized && index === 0 && !(0, _util.isUndefined)(rawX) ? (!hasCategory && index === 0 && i === 0 && (config.axis_x_categories = []), x = config.axis_x_categories.indexOf(rawX), x === -1 && (x = config.axis_x_categories.length, config.axis_x_categories.push(rawX))) : x = $$.generateTargetX(rawX, id, i), ((0, _util.isUndefined)(d[id]) || $$.data.xs[id].length <= i) && (x = undefined), { x: x, value: value, id: convertedId };
+ }).filter(function (v) {
+ return (0, _util.isDefined)(v.x);
+ })
+ };
+ });
+
+ // finish targets
+
+
+ return targets.forEach(function (t) {
+ config.data_xSort && (t.values = t.values.sort(function (v1, v2) {
+ var x1 = v1.x || v1.x === 0 ? v1.x : Infinity,
+ x2 = v2.x || v2.x === 0 ? v2.x : Infinity;
+
+
+ return x1 - x2;
+ })), t.values.forEach(function (v, i) {
+ var index = $$.data.targets ? $$.getIndexByX(v.x) : null;
+
+ v.index = index === null ? i : index;
+ }), $$.data.xs[t.id].sort(function (v1, v2) {
+ return v1 - v2;
+ });
+ }), $$.hasNegativeValue = $$.hasNegativeValueInTargets(targets), $$.hasPositiveValue = $$.hasPositiveValueInTargets(targets), config.data_type && $$.setTargetType($$.mapToIds(targets).filter(function (id) {
+ return !(id in config.data_types);
+ }), config.data_type), targets.forEach(function (d) {
+ return $$.addCache(d.id_org, d, !0);
+ }), targets;
+ }
+});
+
+/***/ }),
+/* 24 */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE__24__;
+
+/***/ }),
+/* 25 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ load: function load(rawTargets, args) {
+ var $$ = this,
+ targets = rawTargets;
+ targets && (args.filter && (targets = targets.filter(args.filter)), (args.type || args.types) && targets.forEach(function (t) {
+ var type = args.types && args.types[t.id] || args.type;
+
+ $$.setTargetType(t.id, type);
+ }), $$.data.targets.forEach(function (d) {
+ for (var i = 0; i < targets.length; i++) if (d.id === targets[i].id) {
+ d.values = targets[i].values, targets.splice(i, 1);
+
+ break;
+ }
+ }), $$.data.targets = $$.data.targets.concat(targets)), $$.updateTargets($$.data.targets), $$.redraw({
+ withUpdateOrgXDomain: !0,
+ withUpdateXDomain: !0,
+ withLegend: !0
+ }), args.done && args.done();
+ },
+ loadFromArgs: function loadFromArgs(args) {
+ var $$ = this,
+ data = void 0;
+
+
+ // reset internally cached data
+ $$.resetCache(), args.data ? data = args.data : args.url ? $$.convertUrlToData(args.url, args.mimeType, args.headers, args.keys, function (d) {
+ $$.load($$.convertDataToTargets(d), args);
+ }) : args.json ? data = $$.convertJsonToData(args.json, args.keys) : args.rows ? data = $$.convertRowsToData(args.rows) : args.columns && (data = $$.convertColumnsToData(args.columns)), $$.load(data ? $$.convertDataToTargets(data) : null, args);
+ },
+ unload: function unload(rawTargetIds, customDoneCb) {
+ var $$ = this,
+ done = customDoneCb,
+ targetIds = rawTargetIds;
+
+ // reset internally cached data
+
+ // If no target, call done and return
+ return $$.resetCache(), done || (done = function () {}), targetIds = targetIds.filter(function (id) {
+ return $$.hasTarget($$.data.targets, id);
+ }), targetIds && targetIds.length !== 0 ? void ($$.svg.selectAll(targetIds.map(function (id) {
+ return $$.selectorTarget(id);
+ })).transition().style("opacity", "0").remove().call($$.endall, done), targetIds.forEach(function (id) {
+ $$.withoutFadeIn[id] = !1, $$.legend && $$.legend.selectAll("." + _classes2.default.legendItem + $$.getTargetSelectorSuffix(id)).remove(), $$.data.targets = $$.data.targets.filter(function (t) {
+ return t.id !== id;
+ });
+ })) : void done();
+ }
+}); /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+/***/ }),
+/* 26 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ /**
+ * Category Name
+ * @private
+ * @param {Number} index
+ * @returns {String} gategory Name
+ */
+ categoryName: function categoryName(i) {
+ var config = this.config;
+
+ return i < config.axis_x_categories.length ? config.axis_x_categories[i] : i;
+ }
+});
+
+/***/ }),
+/* 27 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Selection = __webpack_require__(5),
+ _d3Drag = __webpack_require__(28),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ /**
+ * Initialize the area that detects the event.
+ * Add a container for the zone that detects the event.
+ * @private
+ */
+ initEventRect: function initEventRect() {
+ var $$ = this;
+
+ $$.main.select("." + _classes2.default.chart).append("g").attr("class", _classes2.default.eventRects).style("fill-opacity", "0");
+ },
+
+
+ /**
+ * Redraws the area that detects the event.
+ * @private
+ */
+ redrawEventRect: function redrawEventRect() {
+ var $$ = this,
+ config = $$.config,
+ zoomEnabled = config.zoom_enabled,
+ isMultipleX = $$.isMultipleX(),
+ eventRectUpdate = void 0,
+ eventRects = $$.main.select("." + _classes2.default.eventRects).style("cursor", zoomEnabled && (zoomEnabled === !0 || zoomEnabled.type === "wheel") ? config.axis_rotate ? "ns-resize" : "ew-resize" : null).classed(_classes2.default.eventRectsMultiple, isMultipleX).classed(_classes2.default.eventRectsSingle, !isMultipleX);
+
+ // clear old rects
+
+ if (eventRects.selectAll("." + _classes2.default.eventRect).remove(), $$.eventRect = eventRects.selectAll("." + _classes2.default.eventRect), isMultipleX) eventRectUpdate = $$.eventRect.data([0]), eventRectUpdate = $$.generateEventRectsForMultipleXs(eventRectUpdate.enter()).merge(eventRectUpdate);else {
+ // Set data and update $$.eventRect
+ var maxDataCountTarget = $$.getMaxDataCountTarget($$.data.targets);
+
+ eventRects.datum(maxDataCountTarget ? maxDataCountTarget.values : []), $$.eventRect = eventRects.selectAll("." + _classes2.default.eventRect), eventRectUpdate = $$.eventRect.data(function (d) {
+ return d;
+ }), eventRectUpdate.exit().remove(), eventRectUpdate = $$.generateEventRectsForSingleX(eventRectUpdate.enter()).merge(eventRectUpdate);
+ }
+
+ $$.updateEventRect(eventRectUpdate), $$.inputType !== "touch" || $$.svg.on("touchstart.eventRect") || $$.hasArcType() || $$.bindTouchOnEventRect(isMultipleX);
+ },
+ bindTouchOnEventRect: function bindTouchOnEventRect(isMultipleX) {
+ var $$ = this,
+ config = $$.config,
+ getEventRect = function () {
+ var touch = _d3Selection.event.changedTouches[0];
+
+ return (0, _d3Selection.select)(document.elementFromPoint(touch.clientX, touch.clientY));
+ },
+ getIndex = function (eventRect) {
+ var index = eventRect && eventRect.attr("class") && eventRect.attr("class").replace(new RegExp("(" + _classes2.default.eventRect + "-?|s)", "g"), "") * 1;
+
+ return (isNaN(index) || index === null) && (index = -1), index;
+ },
+ selectRect = function (context) {
+ if (isMultipleX) $$.selectRectForMultipleXs(context);else {
+ var eventRect = getEventRect(),
+ index = getIndex(eventRect);
+ $$.setOver(index), index === -1 ? $$.unselectRect() : $$.selectRectForSingle(context, eventRect, index);
+ }
+ },
+ preventDefault = config.interaction_inputType_touch.preventDefault,
+ isPrevented = (0, _util.isBoolean)(preventDefault) && preventDefault || !1,
+ preventThreshold = !isNaN(preventDefault) && preventDefault || null,
+ startPx = void 0,
+ preventEvent = function (event) {
+ var eventType = event.type,
+ touch = event.changedTouches[0],
+ currentXY = touch["client" + (config.axis_rotated ? "Y" : "X")];
+
+
+ // prevent document scrolling
+ eventType === "touchstart" ? isPrevented ? event.preventDefault() : preventThreshold !== null && (startPx = currentXY) : eventType === "touchmove" && (isPrevented || startPx === !0 || preventThreshold !== null && Math.abs(startPx - currentXY) >= preventThreshold) && (startPx = !0, event.preventDefault());
+ };
+
+ // call event.preventDefault()
+ // according 'interaction.inputType.touch.preventDefault' option
+
+
+ // bind touch events
+ $$.svg.on("touchstart.eventRect touchmove.eventRect", function () {
+ var eventRect = getEventRect();
+
+ if (!eventRect.empty() && eventRect.classed(_classes2.default.eventRect)) {
+ if ($$.dragging || $$.flowing || $$.hasArcType()) return;
+
+ preventEvent(_d3Selection.event), selectRect(this);
+ } else $$.unselectRect();
+ }).on("touchend.eventRect", function () {
+ var eventRect = getEventRect();
+
+ if (!eventRect.empty() && eventRect.classed(_classes2.default.eventRect)) {
+ if ($$.hasArcType() || !$$.toggleShape || $$.cancelClick) return void ($$.cancelClick && ($$.cancelClick = !1));
+
+ // Call event handler
+ var index = getIndex(eventRect);
+
+ isMultipleX || index === -1 || $$.main.selectAll("." + _classes2.default.shape + "-" + index).each(function (d2) {
+ return config.data_onout.call($$.api, d2);
+ });
+ }
+ });
+ },
+
+
+ /**
+ * Updates the location and size of the eventRect.
+ * @private
+ * @param {Object} d3.select(CLASS.eventRects) object.
+ */
+ updateEventRect: function updateEventRect(eventRectUpdate) {
+ var $$ = this,
+ config = $$.config,
+ xScale = $$.zoomScale || $$.x,
+ eventRectData = eventRectUpdate || $$.eventRect.data(),
+ isRotated = config.axis_rotated,
+ x = void 0,
+ y = void 0,
+ w = void 0,
+ h = void 0; // set update selection if null
+
+ if ($$.isMultipleX()) x = 0, y = 0, w = $$.width, h = $$.height;else {
+ var rectW = void 0,
+ rectX = void 0;
+
+
+ if ($$.isCategorized()) rectW = $$.getEventRectWidth(), rectX = function (d) {
+ return xScale(d.x) - rectW / 2;
+ };else {
+ $$.updateXs();
+
+
+ var getPrevNextX = function (d) {
+ var index = d.index;
+
+ return {
+ prev: $$.getPrevX(index),
+ next: $$.getNextX(index)
+ };
+ };
+
+ rectW = function (d) {
+ var x = getPrevNextX(d);
+
+ // if there this is a single data point make the eventRect full width (or height)
+ return x.prev === null && x.next === null ? isRotated ? $$.height : $$.width : (x.prev === null && (x.prev = xScale.domain()[0]), x.next === null && (x.next = xScale.domain()[1]), Math.max(0, (xScale(x.next) - xScale(x.prev)) / 2));
+ }, rectX = function (d) {
+ var x = getPrevNextX(d),
+ thisX = $$.data.xs[d.id][d.index];
+
+
+ // if there this is a single data point position the eventRect at 0
+ return x.prev === null && x.next === null ? 0 : (x.prev === null && (x.prev = xScale.domain()[0]), (xScale(thisX) + xScale(x.prev)) / 2);
+ };
+ }
+
+ x = isRotated ? 0 : rectX, y = isRotated ? rectX : 0, w = isRotated ? $$.width : rectW, h = isRotated ? rectW : $$.height;
+ }
+
+ eventRectData.attr("class", $$.classEvent.bind($$)).attr("x", x).attr("y", y).attr("width", w).attr("height", h);
+ },
+ selectRectForSingle: function selectRectForSingle(context, eventRect, index) {
+ var $$ = this,
+ config = $$.config,
+ isSelectionEnabled = config.data_selection_enabled,
+ isSelectionGrouped = config.data_selection_grouped,
+ isTooltipGrouped = config.tooltip_grouped,
+ selectedData = $$.getAllValuesOnIndex(index);
+ isTooltipGrouped && ($$.showTooltip(selectedData, context), $$.showXGridFocus(selectedData), !isSelectionEnabled || isSelectionGrouped) || $$.main.selectAll("." + _classes2.default.shape + "-" + index).each(function () {
+ (0, _d3Selection.select)(this).classed(_classes2.default.EXPANDED, !0), isSelectionEnabled && eventRect.style("cursor", isSelectionGrouped ? "pointer" : null), isTooltipGrouped || ($$.hideXGridFocus(), $$.hideTooltip(), !isSelectionGrouped && $$.expandCirclesBars(index));
+ }).filter(function (d) {
+ return $$.isWithinShape(this, d);
+ }).call(function (selected) {
+ var d = selected.data();
+
+ isSelectionEnabled && (isSelectionGrouped || config.data_selection_isselectable(d)) && eventRect.style("cursor", "pointer"), isTooltipGrouped || ($$.showTooltip(d, context), $$.showXGridFocus(d), $$.unexpandCircles(), selected.each(function (d) {
+ return $$.expandCirclesBars(index, d.id);
+ }));
+ });
+ },
+ expandCirclesBars: function expandCirclesBars(index, id, reset) {
+ var $$ = this,
+ config = $$.config;
+ config.point_focus_expand_enabled && $$.expandCircles(index, id, reset), $$.expandBars(index, id, reset);
+ },
+ selectRectForMultipleXs: function selectRectForMultipleXs(context) {
+ var $$ = this,
+ config = $$.config,
+ targetsToShow = $$.filterTargetsToShow($$.data.targets);
+
+
+ // do nothing when dragging
+ if (!($$.dragging || $$.hasArcType(targetsToShow))) {
+ var mouse = (0, _d3Selection.mouse)(context),
+ closest = $$.findClosestFromTargets(targetsToShow, mouse);
+
+
+ if ($$.mouseover && (!closest || closest.id !== $$.mouseover.id) && (config.data_onout.call($$.api, $$.mouseover), $$.mouseover = undefined), !closest) return void $$.unselectRect();
+
+ var sameXData = $$.isBubbleType(closest) || $$.isScatterType(closest) || !config.tooltip_grouped ? [closest] : $$.filterByX(targetsToShow, closest.x),
+ selectedData = sameXData.map(function (d) {
+ return $$.addName(d);
+ });
+
+ // show tooltip when cursor is close to some point
+
+ $$.showTooltip(selectedData, context), $$.expandCirclesBars(closest.index, closest.id, !0), $$.showXGridFocus(selectedData), ($$.isBarType(closest.id) || $$.dist(closest, mouse) < config.point_sensitivity) && ($$.svg.select("." + _classes2.default.eventRect).style("cursor", "pointer"), !$$.mouseover && (config.data_onover.call($$.api, closest), $$.mouseover = closest));
+ }
+ },
+
+
+ /**
+ * Unselect EventRect.
+ * @private
+ */
+ unselectRect: function unselectRect() {
+ var $$ = this;
+
+ $$.svg.select("." + _classes2.default.eventRect).style("cursor", null), $$.hideXGridFocus(), $$.hideTooltip(), $$.unexpandCircles(), $$.unexpandBars();
+ },
+ setOver: function setOver(index) {
+ var $$ = this,
+ config = $$.config;
+ $$.expandCirclesBars(index, null, !0), index !== -1 && $$.main.selectAll("." + _classes2.default.shape + "-" + index).each(function (d2) {
+ return config.data_onover.call($$.api, d2);
+ });
+ },
+
+
+ /**
+ * Return draggable selection function
+ * @return {Function}
+ * @private
+ */
+ getDraggableSelection: function getDraggableSelection() {
+ var $$ = this,
+ config = $$.config;
+
+
+ return config.interaction_enabled && config.data_selection_draggable && $$.drag ? (0, _d3Drag.drag)().on("drag", function () {
+ $$.drag((0, _d3Selection.mouse)(this));
+ }).on("start", function () {
+ $$.dragstart((0, _d3Selection.mouse)(this));
+ }).on("end", function () {
+ $$.dragend();
+ }) : function () {};
+ },
+
+
+ /**
+ * Create eventRect for each data on the x-axis.
+ * Register touch and drag events.
+ * @private
+ * @param {Object} d3.select(CLASS.eventRects) object.
+ * @returns {Object} d3.select(CLASS.eventRects) object.
+ */
+ generateEventRectsForSingleX: function generateEventRectsForSingleX(eventRectEnter) {
+ var $$ = this,
+ config = $$.config,
+ rect = eventRectEnter.append("rect").attr("class", $$.classEvent.bind($$)).style("cursor", config.data_selection_enabled && config.data_selection_grouped ? "pointer" : null).on("click", function (d) {
+ if ($$.hasArcType() || !$$.toggleShape || $$.cancelClick) return void ($$.cancelClick && ($$.cancelClick = !1));
+
+ var index = d.index;
+
+ $$.main.selectAll("." + _classes2.default.shape + "-" + index).each(function (d2) {
+ (config.data_selection_grouped || $$.isWithinShape(this, d2)) && ($$.toggleShape(this, d2, index), $$.config.data_onclick.call($$.api, d2, this));
+ });
+ }).call($$.getDraggableSelection());
+
+
+ return $$.inputType === "mouse" && rect.on("mouseover", function (d) {
+ $$.dragging || $$.flowing || $$.hasArcType() || $$.setOver(d.index);
+ }).on("mousemove", function (d) {
+ // do nothing while dragging/flowing
+ if (!($$.dragging || $$.flowing || $$.hasArcType())) {
+ var index = d.index,
+ eventRect = $$.svg.select("." + _classes2.default.eventRect + "-" + index);
+ $$.isStepType(d) && $$.config.line_step_type === "step-after" && (0, _d3Selection.mouse)(this)[0] < $$.x($$.getXValue(d.id, index)) && (index -= 1), index === -1 ? $$.unselectRect() : $$.selectRectForSingle(this, eventRect, index);
+ }
+ }).on("mouseout", function (d) {
+ // chart is destroyed
+ if ($$.config && !$$.hasArcType()) {
+
+ var index = d.index;
+
+ $$.unselectRect(), $$.main.selectAll("." + _classes2.default.shape + "-" + index).each(function (d2) {
+ return config.data_onout.call($$.api, d2);
+ });
+ }
+ }), rect;
+ },
+
+
+ /**
+ * Create an eventRect,
+ * Register touch and drag events.
+ * @private
+ * @param {Object} d3.select(CLASS.eventRects) object.
+ * @returns {Object} d3.select(CLASS.eventRects) object.
+ */
+ generateEventRectsForMultipleXs: function generateEventRectsForMultipleXs(eventRectEnter) {
+ var $$ = this,
+ config = $$.config,
+ rect = eventRectEnter.append("rect").attr("x", 0).attr("y", 0).attr("width", $$.width).attr("height", $$.height).attr("class", _classes2.default.eventRect).on("click", function () {
+ var targetsToShow = $$.filterTargetsToShow($$.data.targets);
+
+ // select if selection enabled
+ if (!$$.hasArcType(targetsToShow)) {
+ var mouse = (0, _d3Selection.mouse)(this),
+ closest = $$.findClosestFromTargets(targetsToShow, mouse);
+ !closest || ($$.isBarType(closest.id) || $$.dist(closest, mouse) < config.point_sensitivity) && $$.main.selectAll("." + _classes2.default.shapes + $$.getTargetSelectorSuffix(closest.id)).selectAll("." + _classes2.default.shape + "-" + closest.index).each(function () {
+ (config.data_selection_grouped || $$.isWithinShape(this, closest)) && ($$.toggleShape(this, closest, closest.index), $$.config.data_onclick.call($$.api, closest, this));
+ });
+ }
+ }).call($$.getDraggableSelection());
+
+
+ return $$.inputType === "mouse" && rect.on("mouseover mousemove", function () {
+ $$.selectRectForMultipleXs(this);
+ }).on("mouseout", function () {
+ !$$.config || $$.hasArcType() || $$.unselectRect();
+ }), rect;
+ },
+
+
+ /**
+ * Dispatch a mouse event.
+ * @private
+ * @param {String} type event type
+ * @param {Number} index Index of eventRect
+ * @param {Array} mouse x and y coordinate value
+ */
+ dispatchEvent: function dispatchEvent(type, index, mouse) {
+ var $$ = this,
+ selector = "." + ($$.isMultipleX() ? _classes2.default.eventRect : _classes2.default.eventRect + "-" + index),
+ eventRect = $$.main.select(selector).node(),
+ box = eventRect.getBoundingClientRect(),
+ x = box.left + (mouse ? mouse[0] : 0) + box.width / 2,
+ y = box.top + (mouse ? mouse[1] : 0);
+
+ _util.emulateEvent[/^mouse/.test(type) ? "mouse" : "touch"](eventRect, type, {
+ screenX: x,
+ screenY: y,
+ clientX: x,
+ clientY: y
+ });
+ }
+}); /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+/***/ }),
+/* 28 */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE__28__;
+
+/***/ }),
+/* 29 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ getCurrentWidth: function getCurrentWidth() {
+ var $$ = this;
+
+ return $$.config.size_width || $$.getParentWidth();
+ },
+ getCurrentHeight: function getCurrentHeight() {
+ var $$ = this,
+ config = $$.config,
+ h = config.size_height || $$.getParentHeight();
+
+
+ return h > 0 ? h : 320 / ($$.hasType("gauge") && !config.gauge_fullCircle ? 2 : 1);
+ },
+ getCurrentPaddingTop: function getCurrentPaddingTop() {
+ var $$ = this,
+ config = $$.config,
+ padding = (0, _util.isValue)(config.padding_top) ? config.padding_top : 0;
+
+
+ return $$.title && $$.title.node() && (padding += $$.getTitlePadding()), padding;
+ },
+ getCurrentPaddingBottom: function getCurrentPaddingBottom() {
+ var config = this.config;
+
+ return (0, _util.isValue)(config.padding_bottom) ? config.padding_bottom : 0;
+ },
+ getCurrentPaddingLeft: function getCurrentPaddingLeft(withoutRecompute) {
+ var $$ = this,
+ config = $$.config,
+ paddingLeft = void 0;
+
+
+ return paddingLeft = (0, _util.isValue)(config.padding_left) ? config.padding_left : config.axis_rotated ? config.axis_x_show ? Math.max((0, _util.ceil10)($$.getAxisWidthByAxisId("x", withoutRecompute)), 40) : 1 : !config.axis_y_show || config.axis_y_inner ? $$.axis.getYAxisLabelPosition().isOuter ? 30 : 1 : (0, _util.ceil10)($$.getAxisWidthByAxisId("y", withoutRecompute)), paddingLeft;
+ },
+ getCurrentPaddingRight: function getCurrentPaddingRight() {
+ var $$ = this,
+ config = $$.config,
+ legendWidthOnRight = $$.isLegendRight ? $$.getLegendWidth() + 20 : 0,
+ paddingRight = void 0;
+
+
+ return paddingRight = (0, _util.isValue)(config.padding_right) ? config.padding_right + 1 : config.axis_rotated ? 10 + legendWidthOnRight : !config.axis_y2_show || config.axis_y2_inner ? 2 + legendWidthOnRight + ($$.axis.getY2AxisLabelPosition().isOuter ? 20 : 0) : (0, _util.ceil10)($$.getAxisWidthByAxisId("y2")) + legendWidthOnRight, paddingRight;
+ },
+
+
+ /**
+ * Get the parent rect element's size
+ * @param {String} key property/attribute name
+ * @private
+ */
+ getParentRectValue: function getParentRectValue(key) {
+ for (var offsetName = "offset" + (0, _util.capitalize)(key), parent = this.selectChart.node(), v = void 0; !v && parent && parent.tagName !== "BODY";) {
+ try {
+ v = parent.getBoundingClientRect()[key];
+ } catch (e) {
+ offsetName in parent && (v = parent[offsetName]);
+ }
+
+ parent = parent.parentNode;
+ }
+
+ if (key === "width") {
+ // Sometimes element's width value is incorrect(ex. flex container)
+ // In this case, use body's offsetWidth instead.
+ var bodyWidth = document.body.offsetWidth;
+
+ v > bodyWidth && (v = bodyWidth);
+ }
+
+ return v;
+ },
+ getParentWidth: function getParentWidth() {
+ return this.getParentRectValue("width");
+ },
+ getParentHeight: function getParentHeight() {
+ var h = this.selectChart.style("height");
+
+ return h.indexOf("px") > 0 ? +h.replace("px", "") : 0;
+ },
+ getSvgLeft: function getSvgLeft(withoutRecompute) {
+ var $$ = this,
+ config = $$.config,
+ hasLeftAxisRect = config.axis_rotated || !config.axis_rotated && !config.axis_y_inner,
+ leftAxisClass = config.axis_rotated ? _classes2.default.axisX : _classes2.default.axisY,
+ leftAxis = $$.main.select("." + leftAxisClass).node(),
+ svgRect = leftAxis && hasLeftAxisRect ? leftAxis.getBoundingClientRect() : { right: 0 },
+ chartRect = $$.selectChart.node().getBoundingClientRect(),
+ hasArc = $$.hasArcType(),
+ svgLeft = svgRect.right - chartRect.left - (hasArc ? 0 : $$.getCurrentPaddingLeft(withoutRecompute));
+
+
+ return svgLeft > 0 ? svgLeft : 0;
+ },
+ getAxisWidthByAxisId: function getAxisWidthByAxisId(id, withoutRecompute) {
+ var $$ = this,
+ position = $$.axis.getLabelPositionById(id);
+
+
+ return $$.axis.getMaxTickWidth(id, withoutRecompute) + (position.isInner ? 20 : 40);
+ },
+ getHorizontalAxisHeight: function getHorizontalAxisHeight(axisId) {
+ var $$ = this,
+ config = $$.config,
+ h = 30;
+
+
+ // Calculate x axis height when tick rotated
+ return axisId !== "x" || config.axis_x_show ? axisId === "x" && config.axis_x_height ? config.axis_x_height : axisId !== "y" || config.axis_y_show ? axisId !== "y2" || config.axis_y2_show ? (axisId === "x" && !config.axis_rotated && config.axis_x_tick_rotate && (h = 30 + $$.axis.getMaxTickWidth(axisId) * Math.cos(Math.PI * (90 - config.axis_x_tick_rotate) / 180)), axisId === "y" && config.axis_rotated && config.axis_y_tick_rotate && (h = 30 + $$.axis.getMaxTickWidth(axisId) * Math.cos(Math.PI * (90 - config.axis_y_tick_rotate) / 180)), h + ($$.axis.getLabelPositionById(axisId).isInner ? 0 : 10) + (axisId === "y2" ? -10 : 0)) : $$.rotated_padding_top : !config.legend_show || $$.isLegendRight || $$.isLegendInset ? 1 : 10 : 8;
+ },
+ getEventRectWidth: function getEventRectWidth() {
+ return Math.max(0, this.xAxis.tickInterval());
+ }
+}); /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+/***/ }),
+/* 30 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Shape = __webpack_require__(31),
+ _d3Selection = __webpack_require__(5),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ getShapeIndices: function getShapeIndices(typeFilter) {
+ var $$ = this,
+ config = $$.config,
+ indices = {},
+ i = 0;
+
+
+ return $$.filterTargetsToShow($$.data.targets.filter(typeFilter, $$)).forEach(function (d) {
+ for (var groups, j = 0; groups = config.data_groups[j]; j++) if (!(groups.indexOf(d.id) < 0)) for (var _row5, _k5 = 0; _row5 = groups[_k5]; _k5++) if (_row5 in indices) {
+ indices[d.id] = indices[_row5];
+
+ break;
+ }
+
+ (0, _util.isUndefined)(indices[d.id]) && (indices[d.id] = i++);
+ }), indices.__max__ = i - 1, indices;
+ },
+ getShapeX: function getShapeX(offset, targetsNum, indices, isSub) {
+ var $$ = this,
+ scale = isSub ? $$.subX : $$.zoomScale || $$.x,
+ barPadding = $$.config.bar_padding;
+
+
+ return function (d) {
+ var index = d.id in indices ? indices[d.id] : 0,
+ x = d.x || d.x === 0 ? scale(d.x) - offset * (targetsNum / 2 - index) : 0;
+
+ // adjust x position for bar.padding option
+
+ return offset && x && targetsNum > 1 && barPadding && (index && (x += barPadding * index), targetsNum > 2 ? x -= (targetsNum - 1) * barPadding / 2 : targetsNum === 2 && (x -= barPadding / 2)), x;
+ };
+ },
+ getShapeY: function getShapeY(isSub) {
+ var $$ = this;
+
+ return function (d) {
+ var scale = isSub ? $$.getSubYScale(d.id) : $$.getYScale(d.id);
+
+ return scale(d.value);
+ };
+ },
+ getShapeOffset: function getShapeOffset(typeFilter, indices, isSub) {
+ var $$ = this,
+ targets = $$.orderTargets($$.filterTargetsToShow($$.data.targets.filter(typeFilter, $$))),
+ targetIds = targets.map(function (t) {
+ return t.id;
+ });
+
+
+ return function (d, idx) {
+ var scale = isSub ? $$.getSubYScale(d.id) : $$.getYScale(d.id),
+ y0 = scale(0),
+ offset = y0,
+ i = idx;
+
+
+ return targets.forEach(function (t) {
+ var values = $$.isStepType(d) ? $$.convertValuesToStep(t.values) : t.values;
+
+ t.id === d.id || indices[t.id] !== indices[d.id] || targetIds.indexOf(t.id) < targetIds.indexOf(d.id) && (((0, _util.isUndefined)(values[i]) || +values[i].x !== +d.x) && (i = -1, values.forEach(function (v, j) {
+ var x1 = v.x.constructor === Date ? +v.x : v.x,
+ x2 = d.x.constructor === Date ? +d.x : d.x;
+ x1 === x2 && (i = j);
+ })), i in values && values[i].value * d.value >= 0 && (offset += scale(values[i].value) - y0));
+ }), offset;
+ };
+ },
+ isWithinShape: function isWithinShape(that, d) {
+ var $$ = this,
+ shape = (0, _d3Selection.select)(that),
+ isWithin = void 0;
+
+
+ return $$.isTargetToShow(d.id) ? $$.hasValidPointType(that.nodeName) ? isWithin = $$.isStepType(d) ? $$.isWithinStep(that, $$.getYScale(d.id)(d.value)) : $$.isWithinCircle(that, $$.pointSelectR(d) * 1.5) : that.nodeName === "path" && (isWithin = !shape.classed(_classes2.default.bar) || $$.isWithinBar(that)) : isWithin = !1, isWithin;
+ },
+ getInterpolate: function getInterpolate(d) {
+ var $$ = this,
+ interpolation = $$.getInterpolateType(d);
+
+
+ return {
+ "basis": _d3Shape.curveBasis,
+ "basis-closed": _d3Shape.curveBasisClosed,
+ "basis-open": _d3Shape.curveBasisOpen,
+ "bundle": _d3Shape.curveBundle,
+ "cardinal": _d3Shape.curveCardinal,
+ "cardinal-closed": _d3Shape.curveCardinalClosed,
+ "cardinal-open": _d3Shape.curveCardinalOpen,
+ "catmull-rom": _d3Shape.curveCatmullRom,
+ "catmull-rom-closed": _d3Shape.curveCatmullRomClosed,
+ "catmull-rom-open": _d3Shape.curveCatmullRomOpen,
+ "monotone-x": _d3Shape.curveMonotoneX,
+ "monotone-y": _d3Shape.curveMonotoneY,
+ "natural": _d3Shape.curveNatural,
+ "linear-closed": _d3Shape.curveLinearClosed,
+ "linear": _d3Shape.curveLinear,
+ "step": _d3Shape.curveStep,
+ "step-after": _d3Shape.curveStepAfter,
+ "step-before": _d3Shape.curveStepBefore
+ }[interpolation];
+ },
+ getInterpolateType: function getInterpolateType(d) {
+ var $$ = this,
+ type = $$.config.spline_interpolation_type,
+ interpolation = $$.isInterpolationType(type) ? type : "cardinal";
+
+
+ return $$.isSplineType(d) ? interpolation : $$.isStepType(d) ? $$.config.line_step_type : "linear";
+ }
+}); /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+/***/ }),
+/* 31 */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE__31__;
+
+/***/ }),
+/* 32 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Selection = __webpack_require__(5),
+ _d3Shape = __webpack_require__(31),
+ _d3Array = __webpack_require__(6),
+ _d3Interpolate = __webpack_require__(33),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ initPie: function initPie() {
+ var $$ = this,
+ config = $$.config,
+ padding = config.pie_padding,
+ padAngle = $$.hasType("pie") && padding ? padding * .01 : config[config.data_type + "_padAngle"] ? config[config.data_type + "_padAngle"] : 0;
+ $$.pie = (0, _d3Shape.pie)().padAngle(padAngle).value(function (d) {
+ return d.values.reduce(function (a, b) {
+ return a + b.value;
+ }, 0);
+ }), config.data_order || $$.pie.sort(null);
+ },
+ updateRadius: function updateRadius() {
+ var $$ = this,
+ config = $$.config,
+ radius = config.pie_innerRadius,
+ padding = config.pie_padding,
+ w = config.gauge_width || config.donut_width;
+ $$.radiusExpanded = Math.min($$.arcWidth, $$.arcHeight) / 2, $$.radius = $$.radiusExpanded * .95, $$.innerRadiusRatio = w ? ($$.radius - w) / $$.radius : .6;
+
+
+ var innerRadius = radius || (padding ? padding * ($$.innerRadiusRatio + .1) : 0);
+
+ $$.innerRadius = $$.hasType("donut") || $$.hasType("gauge") ? $$.radius * $$.innerRadiusRatio : innerRadius;
+ },
+ updateArc: function updateArc() {
+ var $$ = this;
+
+ $$.svgArc = $$.getSvgArc(), $$.svgArcExpanded = $$.getSvgArcExpanded(), $$.svgArcExpandedSub = $$.getSvgArcExpanded(.98);
+ },
+ updateAngle: function updateAngle(dValue) {
+ var $$ = this,
+ config = $$.config,
+ d = dValue,
+ found = !1,
+ index = 0,
+ gMin = void 0,
+ gMax = void 0,
+ gTic = void 0,
+ gValue = void 0;
+ return config ? ($$.pie($$.filterTargetsToShow($$.data.targets)).forEach(function (t) {
+ found || t.data.id !== d.data.id || (found = !0, d = t, d.index = index), index++;
+ }), isNaN(d.startAngle) && (d.startAngle = 0), isNaN(d.endAngle) && (d.endAngle = d.startAngle), $$.isGaugeType(d.data) && (gMin = config.gauge_min, gMax = config.gauge_max, gTic = Math.PI * (config.gauge_fullCircle ? 2 : 1) / (gMax - gMin), gValue = d.value < gMin ? 0 : d.value < gMax ? d.value - gMin : gMax - gMin, d.startAngle = config.gauge_startingAngle, d.endAngle = d.startAngle + gTic * gValue), found ? d : null) : null;
+ },
+ getSvgArc: function getSvgArc() {
+ var $$ = this,
+ arc = (0, _d3Shape.arc)().outerRadius($$.radius).innerRadius($$.innerRadius),
+ newArc = function (d, withoutUpdate) {
+ if (withoutUpdate) return arc(d); // for interpolate
+
+ var updated = $$.updateAngle(d);
+
+ return updated ? arc(updated) : "M 0 0";
+ };
+
+ // TODO: extends all function
+
+
+ return newArc.centroid = arc.centroid, newArc;
+ },
+ getSvgArcExpanded: function getSvgArcExpanded(rate) {
+ var $$ = this,
+ arc = (0, _d3Shape.arc)().outerRadius($$.radiusExpanded * (rate || 1)).innerRadius($$.innerRadius);
+
+
+ return function (d) {
+ var updated = $$.updateAngle(d);
+
+ return updated ? arc(updated) : "M 0 0";
+ };
+ },
+ getArc: function getArc(d, withoutUpdate, force) {
+ return force || this.isArcType(d.data) ? this.svgArc(d, withoutUpdate) : "M 0 0";
+ },
+ transformForArcLabel: function transformForArcLabel(d) {
+ var $$ = this,
+ config = $$.config,
+ updated = $$.updateAngle(d),
+ translate = "";
+
+
+ if (updated && !$$.hasType("gauge")) {
+ var c = this.svgArc.centroid(updated),
+ x = isNaN(c[0]) ? 0 : c[0],
+ y = isNaN(c[1]) ? 0 : c[1],
+ h = Math.sqrt(x * x + y * y),
+ ratio = $$.hasType("donut") && config.donut_label_ratio || $$.hasType("pie") && config.pie_label_ratio;
+ ratio = ratio ? (0, _util.isFunction)(ratio) ? ratio(d, $$.radius, h) : ratio : $$.radius && (h ? (36 / $$.radius > .375 ? 1.175 - 36 / $$.radius : .8) * $$.radius / h : 0), translate = "translate(" + x * ratio + "," + y * ratio + ")";
+ }
+
+ return translate;
+ },
+ getArcRatio: function getArcRatio(d) {
+ var $$ = this,
+ config = $$.config,
+ val = null;
+
+
+ if (d)
+ // if has padAngle set, calculate rate based on value
+ if ($$.pie.padAngle()()) {
+ var total = $$.getTotalDataSum();
+
+ $$.hiddenTargetIds.length && (total -= (0, _d3Array.sum)($$.api.data.values.call($$.api, $$.hiddenTargetIds))), val = d.value / total;
+ } else val = (d.endAngle - d.startAngle) / (Math.PI * ($$.hasType("gauge") && !config.gauge_fullCircle ? 1 : 2));
+
+ return val;
+ },
+ convertToArcData: function convertToArcData(d) {
+ return this.addName({
+ id: d.data.id,
+ value: d.value,
+ ratio: this.getArcRatio(d),
+ index: d.index
+ });
+ },
+ textForArcLabel: function textForArcLabel(val) {
+ var $$ = this,
+ d = val.node ? val.datum() : val;
+
+
+ if (!$$.shouldShowArcLabel()) return "";
+
+ var updated = $$.updateAngle(d),
+ value = updated ? updated.value : null,
+ ratio = $$.getArcRatio(updated),
+ id = d.data.id;
+
+
+ if (!$$.hasType("gauge") && !$$.meetsArcLabelThreshold(ratio)) return "";
+
+ var text = ($$.getArcLabelFormat() || $$.defaultArcValueFormat)(value, ratio, id).toString();
+
+ if (val.node) if (text.indexOf("\n") === -1) val.text(text);else {
+ var multiline = text.split("\n"),
+ len = multiline.length - 1;
+ multiline.forEach(function (v, i) {
+ val.append("tspan").attr("x", 0).attr("dy", (i === 0 ? -len : 1) + "em").text(v);
+ });
+ }
+
+ return text;
+ },
+ textForGaugeMinMax: function textForGaugeMinMax(value, isMax) {
+ var format = this.getGaugeLabelExtents();
+
+ return format ? format(value, isMax) : value;
+ },
+ expandArc: function expandArc(targetIds) {
+ var $$ = this,
+ interval = void 0;
+
+
+ // MEMO: avoid to cancel transition
+ if ($$.transiting) return void (interval = window.setInterval(function () {
+ $$.transiting || (window.clearInterval(interval), $$.legend.selectAll("." + _classes2.default.legendItemFocused).size() > 0 && $$.expandArc(targetIds));
+ }, 10));
+
+ var newTargetIds = $$.mapToTargetIds(targetIds);
+
+ $$.svg.selectAll($$.selectorTargets(newTargetIds, "." + _classes2.default.chartArc)).each(function (d) {
+ $$.shouldExpand(d.data.id) && (0, _d3Selection.select)(this).selectAll("path").transition().duration($$.expandDuration(d.data.id)).attr("d", $$.svgArcExpanded).transition().duration($$.expandDuration(d.data.id) * 2).attr("d", $$.svgArcExpandedSub);
+ });
+ },
+ unexpandArc: function unexpandArc(targetIds) {
+ var $$ = this;
+
+ if (!$$.transiting) {
+
+ var newTargetIds = $$.mapToTargetIds(targetIds);
+
+ $$.svg.selectAll($$.selectorTargets(newTargetIds, "." + _classes2.default.chartArc)).selectAll("path").transition().duration(function (d) {
+ return $$.expandDuration(d.data.id);
+ }).attr("d", $$.svgArc), $$.svg.selectAll("" + _classes2.default.arc).style("opacity", "1");
+ }
+ },
+ expandDuration: function expandDuration(id) {
+ var $$ = this,
+ config = $$.config;
+ return $$.isDonutType(id) ? config.donut_expand_duration : $$.isGaugeType(id) ? config.gauge_expand_duration : $$.isPieType(id) ? config.pie_expand_duration : 50;
+ },
+ shouldExpand: function shouldExpand(id) {
+ var $$ = this,
+ config = $$.config;
+
+
+ return $$.isDonutType(id) && config.donut_expand || $$.isGaugeType(id) && config.gauge_expand || $$.isPieType(id) && config.pie_expand;
+ },
+ shouldShowArcLabel: function shouldShowArcLabel() {
+ var $$ = this,
+ config = $$.config,
+ shouldShow = !0;
+
+
+ // when gauge, always true
+ return $$.hasType("donut") ? shouldShow = config.donut_label_show : $$.hasType("pie") && (shouldShow = config.pie_label_show), shouldShow;
+ },
+ meetsArcLabelThreshold: function meetsArcLabelThreshold(ratio) {
+ var $$ = this,
+ config = $$.config,
+ threshold = $$.hasType("donut") ? config.donut_label_threshold : config.pie_label_threshold;
+
+
+ return ratio >= threshold;
+ },
+ getArcLabelFormat: function getArcLabelFormat() {
+ var $$ = this,
+ config = $$.config,
+ format = config.pie_label_format;
+
+
+ return $$.hasType("gauge") ? format = config.gauge_label_format : $$.hasType("donut") && (format = config.donut_label_format), format;
+ },
+ getGaugeLabelExtents: function getGaugeLabelExtents() {
+ var config = this.config;
+
+ return config.gauge_label_extents;
+ },
+ getArcTitle: function getArcTitle() {
+ var $$ = this;
+
+ return $$.hasType("donut") ? $$.config.donut_title : "";
+ },
+ updateTargetsForArc: function updateTargetsForArc(targets) {
+ var $$ = this,
+ main = $$.main,
+ classChartArc = $$.classChartArc.bind($$),
+ classArcs = $$.classArcs.bind($$),
+ classFocus = $$.classFocus.bind($$),
+ mainPieUpdate = main.select("." + _classes2.default.chartArcs).selectAll("." + _classes2.default.chartArc).data($$.pie(targets)).attr("class", function (d) {
+ return classChartArc(d) + classFocus(d.data);
+ }),
+ mainPieEnter = mainPieUpdate.enter().append("g").attr("class", classChartArc);
+ mainPieEnter.append("g").attr("class", classArcs).merge(mainPieUpdate), mainPieEnter.append("text").attr("dy", $$.hasType("gauge") ? "-.1em" : ".35em").style("opacity", "0").style("text-anchor", "middle").style("pointer-events", "none");
+ },
+ initArc: function initArc() {
+ var $$ = this;
+
+ $$.arcs = $$.main.select("." + _classes2.default.chart).append("g").attr("class", _classes2.default.chartArcs).attr("transform", $$.getTranslate("arc")), $$.setArcTitle();
+ },
+
+
+ /**
+ * Set arc title text
+ * @private
+ */
+ setArcTitle: function setArcTitle() {
+ var $$ = this,
+ title = $$.getArcTitle();
+
+
+ if (title) {
+ var multiline = title.split("\n"),
+ text = $$.arcs.append("text").attr("class", _classes2.default.chartArcsTitle).style("text-anchor", "middle");
+
+
+ // if is multiline text
+ if (multiline.length > 1) {
+ var fontSize = +text.style("font-size").replace("px", ""),
+ height = Math.floor(text.text(".").node().getBBox().height, text.text(""));
+ multiline.forEach(function (v, i) {
+ return text.insert("tspan").text(v).attr("x", 0).attr("dy", i ? height : 0);
+ }), text.attr("y", "-" + (fontSize * (multiline.length - 2) || fontSize / 2));
+ } else text.text(title);
+ }
+ },
+ redrawArc: function redrawArc(duration, durationForExit, withTransform) {
+
+ function selectArc(_this, arcData, id) {
+ $$.expandArc(id), $$.api.focus(id), $$.toggleFocusLegend(id, !0), $$.showTooltip([arcData], _this);
+ }
+
+ function unselectArc(arcData) {
+ var id = arcData && arcData.id || undefined;
+
+ $$.unexpandArc(id), $$.api.revert(), $$.revertLegend(), $$.hideTooltip();
+ }
+
+ var $$ = this,
+ config = $$.config,
+ main = $$.main,
+ isTouch = $$.inputType === "touch",
+ isMouse = $$.inputType === "mouse",
+ mainArc = main.selectAll("." + _classes2.default.arcs).selectAll("." + _classes2.default.arc).data($$.arcData.bind($$));
+
+
+ if (mainArc.exit().transition().duration(durationForExit).style("opacity", "0").remove(), mainArc = mainArc.enter().append("path").attr("class", $$.classArc.bind($$)).style("fill", function (d) {
+ return $$.color(d.data);
+ }).style("cursor", function (d) {
+ return config.interaction_enabled && (config.data_selection_isselectable(d) ? "pointer" : null);
+ }).style("opacity", "0").each(function (d) {
+ $$.isGaugeType(d.data) && (d.startAngle = config.gauge_startingAngle, d.endAngle = config.gauge_startingAngle), this._current = d;
+ }).merge(mainArc), mainArc.attr("transform", function (d) {
+ return !$$.isGaugeType(d.data) && withTransform ? "scale(0)" : "";
+ }).style("opacity", function (d) {
+ return d === this._current ? "0" : "1";
+ }).each(function () {
+ $$.transiting = !0;
+ }).transition().duration(duration).attrTween("d", function (d) {
+ var updated = $$.updateAngle(d);
+
+ if (!updated) return function () {
+ return "M 0 0";
+ };
+
+ isNaN(this._current.startAngle) && (this._current.startAngle = 0), isNaN(this._current.endAngle) && (this._current.endAngle = this._current.startAngle);
+
+
+ var interpolate = (0, _d3Interpolate.interpolate)(this._current, updated);
+
+ return this._current = interpolate(0), function (t) {
+ var interpolated = interpolate(t);
+
+ // data.id will be updated by interporator
+ return interpolated.data = d.data, $$.getArc(interpolated, !0);
+ };
+ }).attr("transform", withTransform ? "scale(1)" : "").style("fill", function (d) {
+ return $$.levelColor ? $$.levelColor(d.data.values[0].value) : $$.color(d.data.id);
+ })
+ // Where gauge reading color would receive customization.
+ .style("opacity", "1").call($$.endall, function () {
+ $$.transiting = !1;
+ }), config.interaction_enabled && (mainArc.on("click", function (d, i) {
+ var updated = $$.updateAngle(d),
+ arcData = void 0;
+ updated && (arcData = $$.convertToArcData(updated), $$.toggleShape && $$.toggleShape(this, arcData, i), $$.config.data_onclick.call($$.api, arcData, this));
+ }), isMouse && mainArc.on("mouseover", function (d) {
+ if (!$$.transiting) // skip while transiting
+ {
+ var updated = $$.updateAngle(d),
+ arcData = updated ? $$.convertToArcData(updated) : null,
+ id = arcData && arcData.id || undefined;
+ selectArc(this, arcData, id), $$.config.data_onover(arcData, this);
+ }
+ }).on("mouseout", function (d) {
+ if (!$$.transiting) // skip while transiting
+ {
+ var updated = $$.updateAngle(d),
+ arcData = updated ? $$.convertToArcData(updated) : null;
+ unselectArc(), $$.config.data_onout(arcData, this);
+ }
+ }).on("mousemove", function (d) {
+ var updated = $$.updateAngle(d),
+ arcData = updated ? $$.convertToArcData(updated) : null;
+ $$.showTooltip([arcData], this);
+ }), isTouch && $$.hasArcType())) {
+ var _getEventArc = function () {
+ var touch = _d3Selection.event.changedTouches[0],
+ eventArc = (0, _d3Selection.select)(document.elementFromPoint(touch.clientX, touch.clientY));
+
+
+ return eventArc;
+ };
+
+ $$.svg.on("touchstart", function () {
+ if (!$$.transiting) // skip while transiting
+ {
+ var eventArc = _getEventArc(),
+ datum = eventArc.datum(),
+ updated = datum && datum.data && datum.data.id ? $$.updateAngle(datum) : null,
+ arcData = updated ? $$.convertToArcData(updated) : null,
+ id = arcData && arcData.id || undefined;
+
+ id === undefined ? unselectArc() : selectArc(this, arcData, id), $$.config.data_onover(arcData, this);
+ }
+ }).on("touchend", function () {
+ if (!$$.transiting) // skip while transiting
+ {
+ var eventArc = _getEventArc(),
+ datum = eventArc.datum(),
+ updated = datum && datum.data && datum.data.id ? $$.updateAngle(datum) : null,
+ arcData = updated ? $$.convertToArcData(updated) : null,
+ id = arcData && arcData.id || undefined;
+
+ id === undefined ? unselectArc() : selectArc(this, arcData, id), $$.config.data_onout(arcData, this);
+ }
+ }).on("touchmove", function () {
+ var eventArc = _getEventArc(),
+ datum = eventArc.datum(),
+ updated = datum && datum.data && datum.data.id ? $$.updateAngle(datum) : null,
+ arcData = updated ? $$.convertToArcData(updated) : null,
+ id = arcData && arcData.id || undefined;
+
+ id === undefined ? unselectArc() : selectArc(this, arcData, id);
+ });
+ }
+
+ var gaugeTextValue = main.selectAll("." + _classes2.default.chartArc).select("text").style("opacity", "0").attr("class", function (d) {
+ return $$.isGaugeType(d.data) ? _classes2.default.gaugeValue : "";
+ });
+
+ config.gauge_fullCircle && gaugeTextValue.attr("dy", "" + Math.round($$.radius / 14));
+
+
+ // to handle multiline text for gauge type
+ var textMethod = !gaugeTextValue.empty() && gaugeTextValue.classed(_classes2.default.gaugeValue) ? "call" : "text";
+
+ if (gaugeTextValue[textMethod]($$.textForArcLabel.bind($$)).attr("transform", $$.transformForArcLabel.bind($$)).style("font-size", function (d) {
+ return $$.isGaugeType(d.data) ? Math.round($$.radius / 5) + "px" : "";
+ }).transition().duration(duration).style("opacity", function (d) {
+ return $$.isTargetToShow(d.data.id) && $$.isArcType(d.data) ? "1" : "0";
+ }), main.select("." + _classes2.default.chartArcsTitle).style("opacity", $$.hasType("donut") || $$.hasType("gauge") ? "1" : "0"), $$.hasType("gauge")) {
+ var endAngle = (config.gauge_fullCircle ? -4 : -1) * config.gauge_startingAngle;
+
+ $$.arcs.select("." + _classes2.default.chartArcsBackground).attr("d", function () {
+ var d = {
+ data: [{ value: config.gauge_max }],
+ startAngle: config.gauge_startingAngle,
+ endAngle: endAngle
+ };
+
+ return $$.getArc(d, !0, !0);
+ }), $$.arcs.select("." + _classes2.default.chartArcsGaugeUnit).attr("dy", ".75em").text(config.gauge_label_show ? config.gauge_units : ""), config.gauge_label_show && ($$.arcs.select("." + _classes2.default.chartArcsGaugeMin).attr("dx", -1 * ($$.innerRadius + ($$.radius - $$.innerRadius) / (config.gauge_fullCircle ? 1 : 2)) + "px").attr("dy", "1.2em").text($$.textForGaugeMinMax(config.gauge_min, !1)), !config.gauge_fullCircle && $$.arcs.select("." + _classes2.default.chartArcsGaugeMax).attr("dx", $$.innerRadius + ($$.radius - $$.innerRadius) / 2 + "px").attr("dy", "1.2em").text($$.textForGaugeMinMax(config.gauge_max, !0)));
+ }
+ },
+ initGauge: function initGauge() {
+ var $$ = this,
+ config = $$.config,
+ arcs = $$.arcs;
+ $$.hasType("gauge") && (arcs.append("path").attr("class", _classes2.default.chartArcsBackground), arcs.append("text").attr("class", _classes2.default.chartArcsGaugeUnit).style("text-anchor", "middle").style("pointer-events", "none"), config.gauge_label_show && (arcs.append("text").attr("class", _classes2.default.chartArcsGaugeMin).style("text-anchor", "middle").style("pointer-events", "none"), !config.gauge_fullCircle && arcs.append("text").attr("class", _classes2.default.chartArcsGaugeMax).style("text-anchor", "middle").style("pointer-events", "none")));
+ },
+ getGaugeLabelHeight: function getGaugeLabelHeight() {
+ return this.config.gauge_label_show ? 20 : 0;
+ }
+}); /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+/***/ }),
+/* 33 */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE__33__;
+
+/***/ }),
+/* 34 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Selection = __webpack_require__(5),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ initBar: function initBar() {
+ var $$ = this;
+
+ $$.main.select("." + _classes2.default.chart).append("g").attr("class", _classes2.default.chartBars);
+ },
+ updateTargetsForBar: function updateTargetsForBar(targets) {
+ var $$ = this,
+ config = $$.config,
+ classChartBar = $$.classChartBar.bind($$),
+ classBars = $$.classBars.bind($$),
+ classFocus = $$.classFocus.bind($$),
+ mainBarUpdate = $$.main.select("." + _classes2.default.chartBars).selectAll("." + _classes2.default.chartBar).data(targets).attr("class", function (d) {
+ return classChartBar(d) + classFocus(d);
+ }),
+ mainBarEnter = mainBarUpdate.enter().append("g").attr("class", classChartBar).style("opacity", "0").style("pointer-events", "none");
+
+
+ // Bars for each data
+ mainBarEnter.append("g").attr("class", classBars).style("cursor", function (d) {
+ return config.data_selection_isselectable(d) ? "pointer" : null;
+ });
+ },
+ updateBar: function updateBar(durationForExit) {
+ var $$ = this,
+ barData = $$.barData.bind($$),
+ classBar = $$.classBar.bind($$),
+ initialOpacity = $$.initialOpacity.bind($$),
+ color = function (d) {
+ return $$.color(d.id);
+ };
+
+ $$.mainBar = $$.main.selectAll("." + _classes2.default.bars).selectAll("." + _classes2.default.bar).data(barData), $$.mainBar.exit().transition().duration(durationForExit).style("opacity", "0").remove(), $$.mainBar = $$.mainBar.enter().append("path").attr("class", classBar).style("stroke", color).style("fill", color).merge($$.mainBar).style("opacity", initialOpacity);
+ },
+ redrawBar: function redrawBar(drawBar, withTransition) {
+ return [(withTransition ? this.mainBar.transition(Math.random().toString()) : this.mainBar).attr("d", drawBar).style("fill", this.color).style("opacity", "1")];
+ },
+ getBarW: function getBarW(axis, barTargetsNum) {
+ var $$ = this,
+ config = $$.config,
+ w = (0, _util.isNumber)(config.bar_width) ? config.bar_width : barTargetsNum ? axis.tickInterval($$.getMaxDataCount()) * config.bar_width_ratio / barTargetsNum : 0;
+
+
+ return config.bar_width_max && w > config.bar_width_max ? config.bar_width_max : w;
+ },
+ getBars: function getBars(i, id) {
+ var $$ = this,
+ suffix = (0, _util.isValue)(i) ? "-" + i : "";
+
+
+ return (id ? $$.main.selectAll("." + _classes2.default.bars + $$.getTargetSelectorSuffix(id)) : $$.main).selectAll("." + _classes2.default.bar + suffix);
+ },
+ expandBars: function expandBars(i, id, reset) {
+ var $$ = this;
+
+ reset && $$.unexpandBars(), $$.getBars(i, id).classed(_classes2.default.EXPANDED, !0);
+ },
+ unexpandBars: function unexpandBars(i) {
+ this.getBars(i).classed(_classes2.default.EXPANDED, !1);
+ },
+ generateDrawBar: function generateDrawBar(barIndices, isSub) {
+ var $$ = this,
+ config = $$.config,
+ getPoints = $$.generateGetBarPoints(barIndices, isSub),
+ isRotated = config.axis_rotated,
+ isGrouped = config.data_groups.length,
+ barRadius = config.bar_radius,
+ barRadiusRatio = config.bar_radius_ratio,
+ getRadius = (0, _util.isNumber)(barRadius) && barRadius > 0 ? function () {
+ return barRadius;
+ } : (0, _util.isNumber)(barRadiusRatio) ? function (w) {
+ return w * barRadiusRatio;
+ } : null;
+
+ // get the bar radius
+
+ return function (d, i) {
+ // 4 points that make a bar
+ var points = getPoints(d, i),
+ indexX = +isRotated,
+ indexY = +!indexX,
+ isNegative = d.value < 0,
+ pathRadius = ["", ""],
+ radius = 0;
+
+ // switch points if axis is rotated, not applicable for sub chart
+
+ if (getRadius && !isGrouped) {
+ var index = isRotated ? indexY : indexX,
+ barW = points[2][index] - points[0][index];
+ radius = getRadius(barW);
+
+
+ var arc = "a" + radius + "," + radius + " " + (isNegative ? "1 0 0" : "0 0 1") + " ";
+
+ pathRadius[+!isRotated] = "" + arc + radius + "," + radius, pathRadius[+isRotated] = "" + arc + [-radius, radius][isRotated ? "sort" : "reverse"](), isNegative && pathRadius.reverse();
+ }
+
+ // path string data shouldn't be containing new line chars
+ // https://github.com/naver/billboard.js/issues/530
+ var path = isRotated ? "H" + (points[1][indexX] - radius) + " " + pathRadius[0] + "V" + (points[2][indexY] - radius) + " " + pathRadius[1] + "H" + points[3][indexX] : "V" + (points[1][indexY] + (isNegative ? -radius : radius)) + " " + pathRadius[0] + "H" + (points[2][indexX] - radius) + " " + pathRadius[1] + "V" + points[3][indexY];
+
+ return "M" + points[0][indexX] + "," + points[0][indexY] + path + "z";
+ };
+ },
+ generateGetBarPoints: function generateGetBarPoints(barIndices, isSub) {
+ var $$ = this,
+ axis = isSub ? $$.subXAxis : $$.xAxis,
+ barTargetsNum = barIndices.__max__ + 1,
+ barW = $$.getBarW(axis, barTargetsNum),
+ barX = $$.getShapeX(barW, barTargetsNum, barIndices, !!isSub),
+ barY = $$.getShapeY(!!isSub),
+ barOffset = $$.getShapeOffset($$.isBarType, barIndices, !!isSub),
+ yScale = isSub ? $$.getSubYScale : $$.getYScale;
+
+
+ return function (d, i) {
+ var y0 = yScale.call($$, d.id)(0),
+ offset = barOffset(d, i) || y0,
+ posX = barX(d),
+ posY = barY(d); // offset is for stacked bar chart
+
+
+ // fix posY not to overflow opposite quadrant
+
+ // 4 points that make a bar
+ return $$.config.axis_rotated && (d.value > 0 && posY < y0 || d.value < 0 && y0 < posY) && (posY = y0), [[posX, offset], [posX, posY - (y0 - offset)], [posX + barW, posY - (y0 - offset)], [posX + barW, offset]];
+ };
+ },
+ isWithinBar: function isWithinBar(that) {
+ var mouse = (0, _d3Selection.mouse)(that),
+ list = (0, _util.getRectSegList)(that),
+ box = that.getBBox(),
+ seg0 = list[0],
+ seg1 = list[1],
+ x = Math.min(seg0.x, seg1.x),
+ y = Math.min(seg0.y, seg1.y),
+ w = box.width,
+ h = box.height;
+
+
+ return x - 2 < mouse[0] && mouse[0] < x + w + 2 && y - 2 < mouse[1] && mouse[1] < y + h + 2;
+ }
+});
+
+/***/ }),
+/* 35 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Array = __webpack_require__(6),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ /**
+ * Initializer
+ * @private
+ */
+ initBubble: function initBubble() {
+ var $$ = this,
+ config = $$.config;
+ $$.hasType("bubble") && (config.point_show = !0, config.point_type = "circle", config.point_sensitivity = 25);
+ },
+
+
+ /**
+ * Get user agent's computed value for the total length of the path in user units
+ * https://developer.mozilla.org/en-US/docs/Web/API/SVGGeometryElement/getTotalLength
+ * @return {Number}
+ * @private
+ */
+ getBaseLength: function getBaseLength() {
+ var $$ = this,
+ baseLength = $$.getCache("$baseLength");
+
+
+ return baseLength || $$.addCache("$baseLength", baseLength = (0, _d3Array.min)([$$.axes.x.select("path").node().getTotalLength(), $$.axes.y.select("path").node().getTotalLength()])), baseLength;
+ },
+
+
+ /**
+ * Get the radius value for bubble circle
+ * @param {Object} d
+ * @return {Number}
+ * @private
+ */
+ getBubbleR: function getBubbleR(d) {
+ var $$ = this,
+ maxR = $$.config.bubble_maxR;
+ (0, _util.isFunction)(maxR) ? maxR = maxR(d) : !(0, _util.isNumber)(maxR) && (maxR = $$.getBaseLength() / ($$.getMaxDataCount() * 2) + 12);
+ var max = (0, _d3Array.max)($$.getMinMaxData().max.map(function (d) {
+ return (0, _util.isObject)(d.value) ? d.value.mid : d.value;
+ })),
+ maxArea = maxR * maxR * Math.PI,
+ area = d.value * (maxArea / max);
+
+
+ return Math.sqrt(area / Math.PI);
+ }
+}); /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+/***/ }),
+/* 36 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Shape = __webpack_require__(31),
+ _d3Selection = __webpack_require__(5),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ initLine: function initLine() {
+ var $$ = this;
+
+ $$.main.select("." + _classes2.default.chart).append("g").attr("class", _classes2.default.chartLines);
+ },
+ updateTargetsForLine: function updateTargetsForLine(targets) {
+ var $$ = this,
+ config = $$.config,
+ classChartLine = $$.classChartLine.bind($$),
+ classLines = $$.classLines.bind($$),
+ classAreas = $$.classAreas.bind($$),
+ classCircles = $$.classCircles.bind($$),
+ classFocus = $$.classFocus.bind($$),
+ mainLineUpdate = $$.main.select("." + _classes2.default.chartLines).selectAll("." + _classes2.default.chartLine).data(targets).attr("class", function (d) {
+ return classChartLine(d) + classFocus(d);
+ }),
+ mainLineEnter = mainLineUpdate.enter().append("g").attr("class", classChartLine).style("opacity", "0").style("pointer-events", "none");
+
+
+ // Lines for each data
+ mainLineEnter.append("g").attr("class", classLines), mainLineEnter.append("g").attr("class", classAreas), config.point_show && (config.data_selection_enabled && mainLineEnter.append("g").attr("class", function (d) {
+ return $$.generateClass(_classes2.default.selectedCircles, d.id);
+ }), mainLineEnter.append("g").attr("class", classCircles).style("cursor", function (d) {
+ return config.data_selection_isselectable(d) ? "pointer" : null;
+ })), targets.forEach(function (t) {
+ $$.main.selectAll("." + _classes2.default.selectedCircles + $$.getTargetSelectorSuffix(t.id)).selectAll("" + _classes2.default.selectedCircle).each(function (d) {
+ d.value = t.values[d.index].value;
+ });
+ });
+ },
+ updateLine: function updateLine(durationForExit) {
+ var $$ = this;
+
+ $$.mainLine = $$.main.selectAll("." + _classes2.default.lines).selectAll("." + _classes2.default.line).data($$.lineData.bind($$)), $$.mainLine.exit().transition().duration(durationForExit).style("opacity", "0").remove(), $$.mainLine = $$.mainLine.enter().append("path").attr("class", function (d) {
+ return $$.classLine.bind($$)(d) + " " + ($$.extraLineClasses(d) || "");
+ }).style("stroke", $$.color).merge($$.mainLine).style("opacity", $$.initialOpacity.bind($$)).style("shape-rendering", function (d) {
+ return $$.isStepType(d) ? "crispEdges" : "";
+ }).attr("transform", null);
+ },
+ redrawLine: function redrawLine(drawLine, withTransition) {
+ return [(withTransition ? this.mainLine.transition(Math.random().toString()) : this.mainLine).attr("d", drawLine).style("stroke", this.color).style("opacity", "1")];
+ },
+
+
+ /**
+ * Get the curve interpolate
+ * @param {Array} d Data object
+ * @return {Function}
+ * @private
+ */
+ getCurve: function getCurve(d) {
+ var $$ = this,
+ isRotatedStepType = $$.config.axis_rotated && $$.isStepType(d);
+
+
+ // when is step & rotated, should be computed in different way
+ // https://github.com/naver/billboard.js/issues/471
+ return isRotatedStepType ? function (context) {
+ var step = $$.getInterpolate(d)(context);
+
+ // keep the original method
+
+
+ return step.orgPoint = step.point, step.pointRotated = function (x, y) {
+ this._point === 1 && (this._point = 2);
+
+
+ var y1 = this._y * (1 - this._t) + y * this._t;
+
+ this._context.lineTo(this._x, y1), this._context.lineTo(x, y1), this._x = x, this._y = y;
+ }, step.point = function (x, y) {
+ this._point === 0 ? this.orgPoint(x, y) : this.pointRotated(x, y);
+ }, step;
+ } : $$.getInterpolate(d);
+ },
+ generateDrawLine: function generateDrawLine(lineIndices, isSub) {
+ var $$ = this,
+ config = $$.config,
+ lineConnectNull = config.line_connectNull,
+ isRotated = config.axis_rotated,
+ getPoints = $$.generateGetLinePoints(lineIndices, isSub),
+ yScaleGetter = isSub ? $$.getSubYScale : $$.getYScale,
+ xValue = function (d) {
+ return (isSub ? $$.subxx : $$.xx).call($$, d);
+ },
+ yValue = function (d, i) {
+ return config.data_groups.length > 0 ? getPoints(d, i)[0][1] : yScaleGetter.call($$, d.id)($$.getBaseValue(d));
+ },
+ line = (0, _d3Shape.line)();
+
+ return line = isRotated ? line.x(yValue).y(xValue) : line.x(xValue).y(yValue), lineConnectNull || (line = line.defined(function (d) {
+ return $$.getBaseValue(d) !== null;
+ })), function (d) {
+ var x = isSub ? $$.x : $$.subX,
+ y = yScaleGetter.call($$, d.id),
+ values = lineConnectNull ? $$.filterRemoveNull(d.values) : d.values,
+ x0 = 0,
+ y0 = 0,
+ path = void 0;
+
+
+ return $$.isLineType(d) ? config.data_regions[d.id] ? path = $$.lineWithRegions(values, x, y, config.data_regions[d.id]) : ($$.isStepType(d) && (values = $$.convertValuesToStep(values)), path = line.curve($$.getCurve(d))(values)) : (values[0] && (x0 = x(values[0].x), y0 = y(values[0].value)), path = isRotated ? "M " + y0 + " " + x0 : "M " + x0 + " " + y0), path || "M 0 0";
+ };
+ },
+ generateGetLinePoints: function generateGetLinePoints(lineIndices, isSubValue) {
+ // partial duplication of generateGetBarPoints
+ var $$ = this,
+ config = $$.config,
+ lineTargetsNum = lineIndices.__max__ + 1,
+ isSub = !!isSubValue,
+ x = $$.getShapeX(0, lineTargetsNum, lineIndices, isSub),
+ y = $$.getShapeY(isSub),
+ lineOffset = $$.getShapeOffset($$.isLineType, lineIndices, isSub),
+ yScale = isSub ? $$.getSubYScale : $$.getYScale;
+
+
+ return function (d, i) {
+ var y0 = yScale.call($$, d.id)(0),
+ offset = lineOffset(d, i) || y0,
+ posX = x(d),
+ posY = y(d); // offset is for stacked area chart
+
+ // fix posY not to overflow opposite quadrant
+ config.axis_rotated && (d.value > 0 && posY < y0 || d.value < 0 && y0 < posY) && (posY = y0);
+
+
+ // 1 point that marks the line position
+ var point = [posX, posY - (y0 - offset)];
+
+ return [point, point, // from here and below, needed for compatibility
+ point, point];
+ };
+ },
+ lineWithRegions: function lineWithRegions(d, x, y, _regions) {
+ var $$ = this,
+ config = $$.config,
+ isRotated = config.axis_rotated,
+ isTimeSeries = $$.isTimeSeries(),
+ xOffset = $$.isCategorized() ? .5 : 0,
+ regions = [],
+ xp = void 0,
+ yp = void 0,
+ diff = void 0,
+ diffx2 = void 0,
+ isWithinRegions = function (withinX, withinRegions) {
+ for (var reg, i = 0; reg = withinRegions[i]; i++) if (reg.start < withinX && withinX <= reg.end) return reg.style;
+
+ return !1;
+ }; // default value
+
+ // check weather data is within region
+
+
+ // Check start/end of regions
+ if ((0, _util.isDefined)(_regions)) {
+ var getValue = function (v, def) {
+ return (0, _util.isUndefined)(v) ? def : isTimeSeries ? $$.parseDate(v) : v;
+ };
+
+ for (var reg, i = 0; reg = _regions[i]; i++) {
+ var start = getValue(reg.start, d[0].x),
+ end = getValue(reg.end, d[d.length - 1].x),
+ style = reg.style || { dasharray: "2 2" };
+ regions[i] = { start: start, end: end, style: style };
+ }
+ }
+
+ // Set scales
+
+ var xValue = isRotated ? function (dt) {
+ return y(dt.value);
+ } : function (dt) {
+ return x(dt.x);
+ },
+ yValue = isRotated ? function (dt) {
+ return x(dt.x);
+ } : function (dt) {
+ return y(dt.value);
+ },
+ generateM = function (points) {
+ return "M" + points[0][0] + "," + points[0][1] + "L" + points[1][0] + "," + points[1][1];
+ },
+ sWithRegion = isTimeSeries ? function (d0, d1, k, timeseriesDiff) {
+ var x0 = d0.x.getTime(),
+ xDiff = d1.x - d0.x,
+ xv0 = new Date(x0 + xDiff * k),
+ xv1 = new Date(x0 + xDiff * (k + timeseriesDiff)),
+ points = isRotated ? [[y(yp(k)), x(xv0)], [y(yp(k + diff)), x(xv1)]] : [[x(xv0), y(yp(k))], [x(xv1), y(yp(k + diff))]];
+
+
+ return generateM(points);
+ } : function (d0, d1, k, otherDiff) {
+ var points = isRotated ? [[y(yp(k), !0), x(xp(k))], [y(yp(k + otherDiff), !0), x(xp(k + otherDiff))]] : [[x(xp(k), !0), y(yp(k))], [x(xp(k + otherDiff), !0), y(yp(k + otherDiff))]];
+
+ return generateM(points);
+ },
+ path = "M";
+
+ // Define svg generator function for region
+
+
+ // Generate
+
+
+ for (var data, _i = 0; data = d[_i]; _i++) {
+ var prevData = d[_i - 1],
+ style = isWithinRegions(data.x, regions);
+
+
+ // Draw as normal
+ if ((0, _util.isUndefined)(regions) || !style) path += "" + (_i ? "L" : "") + xValue(data) + "," + yValue(data);else {
+ try {
+ style = style.dasharray.split(" ");
+ } catch (e) {
+ style = "2 2".split(" ");
+ }
+
+ // Draw with region // TODO: Fix for horizotal charts
+ xp = $$.getScale(prevData.x + xOffset, data.x + xOffset, isTimeSeries), yp = $$.getScale(prevData.value, data.value);
+ var dx = x(data.x) - x(prevData.x),
+ dy = y(data.value) - y(prevData.value),
+ dd = Math.sqrt(Math.pow(dx, 2) + Math.pow(dy, 2));
+ diff = style[0] / dd, diffx2 = diff * style[1];
+
+
+ for (var j = diff; j <= 1; j += diffx2) path += sWithRegion(prevData, data, j, diff), j + diffx2 >= 1 && (path += sWithRegion(prevData, data, 1, 0));
+ }
+ }
+
+ return path;
+ },
+ updateArea: function updateArea(durationForExit) {
+ var $$ = this;
+
+ $$.mainArea = $$.main.selectAll("." + _classes2.default.areas).selectAll("." + _classes2.default.area).data($$.lineData.bind($$)), $$.mainArea.exit().transition().duration(durationForExit).style("opacity", "0").remove(), $$.mainArea = $$.mainArea.enter().append("path").attr("class", $$.classArea.bind($$)).style("fill", $$.color).style("opacity", function () {
+ return $$.orgAreaOpacity = (0, _d3Selection.select)(this).style("opacity"), "0";
+ }).merge($$.mainArea), $$.mainArea.style("opacity", $$.orgAreaOpacity);
+ },
+ redrawArea: function redrawArea(drawArea, withTransition) {
+ var $$ = this;
+
+ return [(withTransition ? this.mainArea.transition(Math.random().toString()) : this.mainArea).attr("d", drawArea).style("fill", this.color).style("opacity", function (d) {
+ return $$.isAreaRangeType(d) ? $$.orgAreaOpacity / 1.75 : $$.orgAreaOpacity;
+ })];
+ },
+
+
+ /**
+ * Generate area path data
+ * @param areaIndices
+ * @param isSub
+ * @return {function(*=): (*|string)}
+ * @private
+ */
+ generateDrawArea: function generateDrawArea(areaIndices, isSub) {
+ var $$ = this,
+ config = $$.config,
+ lineConnectNull = config.line_connectNull,
+ isRotated = config.axis_rotated,
+ isGrouped = config.data_groups.length > 0,
+ getPoints = $$.generateGetAreaPoints(areaIndices, isSub),
+ yScaleGetter = isSub ? $$.getSubYScale : $$.getYScale,
+ xValue = function (d) {
+ return (isSub ? $$.subxx : $$.xx).call($$, d);
+ },
+ value0 = function (d, i) {
+ return isGrouped ? getPoints(d, i)[0][1] : yScaleGetter.call($$, d.id)($$.isAreaRangeType(d) ? $$.getAreaRangeData(d, "high") : $$.getAreaBaseValue(d.id));
+ },
+ value1 = function (d, i) {
+ return isGrouped ? getPoints(d, i)[1][1] : yScaleGetter.call($$, d.id)($$.isAreaRangeType(d) ? $$.getAreaRangeData(d, "low") : d.value);
+ };
+
+ return function (d) {
+ var values = lineConnectNull ? $$.filterRemoveNull(d.values) : d.values,
+ x0 = 0,
+ y0 = 0,
+ path = void 0;
+
+
+ if ($$.isAreaType(d)) {
+ var area = (0, _d3Shape.area)();
+
+ area = isRotated ? area.y(xValue).x0(value0).x1(value1) : area.x(xValue).y0(config.area_above ? 0 : value0).y1(value1), lineConnectNull || (area = area.defined(function (d) {
+ return $$.getBaseValue(d) !== null;
+ })), $$.isStepType(d) && (values = $$.convertValuesToStep(values)), path = area.curve($$.getCurve(d))(values);
+ } else values[0] && (x0 = $$.x(values[0].x), y0 = $$.getYScale(d.id)(values[0].value)), path = isRotated ? "M " + y0 + " " + x0 : "M " + x0 + " " + y0;
+
+ return path || "M 0 0";
+ };
+ },
+ getAreaBaseValue: function getAreaBaseValue() {
+ return 0;
+ },
+ generateGetAreaPoints: function generateGetAreaPoints(areaIndices, isSub) {
+ // partial duplication of generateGetBarPoints
+ var $$ = this,
+ config = $$.config,
+ areaTargetsNum = areaIndices.__max__ + 1,
+ x = $$.getShapeX(0, areaTargetsNum, areaIndices, !!isSub),
+ y = $$.getShapeY(!!isSub),
+ areaOffset = $$.getShapeOffset($$.isAreaType, areaIndices, !!isSub),
+ yScale = isSub ? $$.getSubYScale : $$.getYScale;
+
+
+ return function (d, i) {
+ var y0 = yScale.call($$, d.id)(0),
+ offset = areaOffset(d, i) || y0,
+ posX = x(d),
+ posY = y(d); // offset is for stacked area chart
+
+
+ // fix posY not to overflow opposite quadrant
+
+ // 1 point that marks the area position
+ return config.axis_rotated && (d.value > 0 && posY < y0 || d.value < 0 && y0 < posY) && (posY = y0), [[posX, offset], [posX, posY - (y0 - offset)], [posX, posY - (y0 - offset)], // needed for compatibility
+ [posX, offset] // needed for compatibility
+ ];
+ };
+ },
+ updateCircle: function updateCircle() {
+ var $$ = this;
+
+ $$.config.point_show && ($$.mainCircle = $$.main.selectAll("." + _classes2.default.circles).selectAll("." + _classes2.default.circle).data(function (d) {
+ return !$$.isBarType(d) && (!$$.isLineType(d) || $$.shouldDrawPointsForLine(d)) && $$.labelishData(d);
+ }), $$.mainCircle.exit().remove(), $$.mainCircle = $$.mainCircle.enter().append($$.point("create", this, $$.classCircle.bind($$), $$.pointR.bind($$), $$.color)).merge($$.mainCircle).style("stroke", $$.color).style("opacity", $$.initialOpacityForCircle.bind($$)));
+ },
+ redrawCircle: function redrawCircle(cx, cy, withTransition, flow) {
+ var $$ = this,
+ selectedCircles = $$.main.selectAll("." + _classes2.default.selectedCircle);
+
+
+ if (!$$.config.point_show) return [];
+
+ var mainCircles = [];
+
+ $$.mainCircle.each(function (d) {
+ var fn = $$.point("update", $$, cx, cy, $$.opacityForCircle.bind($$), $$.color, withTransition, flow, selectedCircles).bind(this),
+ result = fn(d);
+ mainCircles.push(result);
+ });
+
+
+ var posAttr = $$.isCirclePoint() ? "c" : "";
+
+ return [mainCircles, selectedCircles.attr(posAttr + "x", cx).attr(posAttr + "y", cy)];
+ },
+ circleX: function circleX(d) {
+ var $$ = this,
+ hasValue = (0, _util.isValue)(d.x);
+
+
+ return $$.config.zoom_enabled && $$.zoomScale ? hasValue ? $$.zoomScale(d.x) : null : hasValue ? $$.x(d.x) : null;
+ },
+ updateCircleY: function updateCircleY() {
+ var $$ = this,
+ lineIndices = void 0,
+ getPoints = void 0;
+ $$.config.data_groups.length > 0 ? (lineIndices = $$.getShapeIndices($$.isLineType), getPoints = $$.generateGetLinePoints(lineIndices), $$.circleY = function (d, i) {
+ return getPoints(d, i)[0][1];
+ }) : $$.circleY = function (d) {
+ return $$.getYScale(d.id)($$.getBaseValue(d));
+ };
+ },
+ getCircles: function getCircles(i, id) {
+ var $$ = this,
+ suffix = (0, _util.isValue)(i) ? "-" + i : "";
+
+
+ return (id ? $$.main.selectAll("." + _classes2.default.circles + $$.getTargetSelectorSuffix(id)) : $$.main).selectAll("." + _classes2.default.circle + suffix);
+ },
+ expandCircles: function expandCircles(i, id, reset) {
+ var $$ = this,
+ r = $$.pointExpandedR.bind($$);
+ reset && $$.unexpandCircles();
+ var circles = $$.getCircles(i, id).classed(_classes2.default.EXPANDED, !0),
+ scale = r(circles) / $$.config.point_r;
+ $$.isCirclePoint() ? circles.attr("r", r) : circles.each(function () {
+ var point = (0, _d3Selection.select)(this),
+ box = this.getBBox(),
+ x1 = box.x + box.width * .5,
+ y1 = box.y + box.height * .5;
+ this.tagName === "circle" ? point.attr("r", r) : point.style("transform", "translate(" + (1 - scale) * x1 + "px, " + (1 - scale) * y1 + "px) scale(" + scale + ")");
+ });
+ },
+ unexpandCircles: function unexpandCircles(i) {
+ var $$ = this,
+ r = $$.pointR.bind($$),
+ circles = $$.getCircles(i).filter(function () {
+ return (0, _d3Selection.select)(this).classed(_classes2.default.EXPANDED);
+ }).classed(_classes2.default.EXPANDED, !1);
+ circles.attr("r", r), $$.isCirclePoint() || circles.style("transform", "scale(" + r(circles) / $$.config.point_r + ")");
+ },
+ pointR: function (d) {
+ var $$ = this,
+ config = $$.config,
+ pointR = config.point_r,
+ r = pointR;
+
+
+ return $$.isStepType(d) ? r = 0 : $$.isBubbleType(d) ? r = $$.getBubbleR(d) : (0, _util.isFunction)(pointR) && (r = pointR(d)), r;
+ },
+ pointExpandedR: function pointExpandedR(d) {
+ var $$ = this,
+ config = $$.config,
+ scale = $$.isBubbleType(d) ? 1.15 : 1.75;
+
+
+ return config.point_focus_expand_enabled ? config.point_focus_expand_r || $$.pointR(d) * scale : $$.pointR(d);
+ },
+ pointSelectR: function pointSelectR(d) {
+ var $$ = this,
+ selectR = $$.config.point_select_r;
+
+
+ return (0, _util.isFunction)(selectR) ? selectR(d) : selectR || $$.pointR(d) * 4;
+ },
+ isWithinCircle: function isWithinCircle(node, r) {
+ var mouse = (0, _d3Selection.mouse)(node),
+ element = (0, _d3Selection.select)(node),
+ prefix = this.isCirclePoint() ? "c" : "",
+ cx = +element.attr(prefix + "x"),
+ cy = +element.attr(prefix + "y");
+
+
+ // if node don't have cx/y or x/y attribute value
+ if (!(cx || cy) && node.nodeType === 1) {
+ var domRect = node.getBBox ? node.getBBox() : node.getBoundingClientRect();
+
+ cx = domRect.x, cy = domRect.y;
+ }
+
+ return Math.sqrt(Math.pow(cx - mouse[0], 2) + Math.pow(cy - mouse[1], 2)) < r;
+ },
+ isWithinStep: function isWithinStep(that, y) {
+ return Math.abs(y - (0, _d3Selection.mouse)(that)[1]) < 30;
+ },
+ shouldDrawPointsForLine: function shouldDrawPointsForLine(d) {
+ var linePoint = this.config.line_point;
+
+ return linePoint === !0 || (0, _util.isArray)(linePoint) && linePoint.indexOf(d.id) !== -1;
+ }
+}); /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+/***/ }),
+/* 37 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Selection = __webpack_require__(5),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ hasValidPointType: function hasValidPointType(type) {
+ return (/^(circle|rect(angle)?|polygon|ellipse|use)$/i.test(type || this.config.point_type)
+ );
+ },
+ hasValidPointDrawMethods: function hasValidPointDrawMethods(type) {
+ var pointType = type || this.config.point_type;
+
+ return (0, _util.isObjectType)(pointType) && (0, _util.isFunction)(pointType.create) && (0, _util.isFunction)(pointType.update);
+ },
+ insertPointInfoDefs: function insertPointInfoDefs(point, id) {
+ var $$ = this,
+ parser = new DOMParser(),
+ doc = parser.parseFromString(point, "image/svg+xml"),
+ node = doc.firstChild,
+ clone = document.createElementNS(_d3Selection.namespaces.svg, node.nodeName.toLowerCase()),
+ attribs = node.attributes;
+
+
+ for (var name, i = 0; name = attribs[i]; i++) name = name.name, clone.setAttribute(name, node.getAttribute(name));
+
+ clone.id = id, clone.style.fill = "inherit", clone.style.stroke = "inherit", node.children.length && (clone.innerHTML = (0, _util.toArray)(node.children).map(function (v) {
+ return v.outerHTML;
+ }).join("")), $$.defs.node().appendChild(clone);
+ },
+ pointFromDefs: function pointFromDefs(id) {
+ return this.defs.select("#" + id);
+ },
+ generatePoint: function generatePoint() {
+ var $$ = this,
+ config = $$.config,
+ ids = [],
+ pattern = (0, _util.notEmpty)(config.point_pattern) ? config.point_pattern : [config.point_type];
+
+
+ return function (method, context) {
+ for (var _len = arguments.length, args = Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) args[_key - 2] = arguments[_key];
+
+ return function (d) {
+ var id = d.id || d.data && d.data.id || d,
+ element = (0, _d3Selection.select)(this),
+ point = void 0;
+
+
+ if (ids.indexOf(id) < 0 && ids.push(id), point = pattern[ids.indexOf(id) % pattern.length], $$.hasValidPointType(point)) point = $$[point];else if (!$$.hasValidPointDrawMethods(point)) {
+ var pointId = $$.datetimeId + "-point-" + id,
+ pointFromDefs = $$.pointFromDefs(pointId);
+
+
+ if (pointFromDefs.size() < 1 && $$.insertPointInfoDefs(point, pointId), method === "create") return $$.custom.create.bind(context).apply(undefined, [element, pointId].concat(args));
+ if (method === "update") return $$.custom.update.bind(context).apply(undefined, [element].concat(args));
+ }
+
+ return point[method].bind(context).apply(undefined, [element].concat(args));
+ };
+ };
+ },
+ getTransitionName: function getTransitionName() {
+ return Math.random().toString();
+ },
+
+
+ custom: {
+ create: function create(element, id, cssClassFn, sizeFn, fillStyleFn) {
+ return element.append("use").attr("xlink:href", "#" + id).attr("class", cssClassFn).style("fill", fillStyleFn).node();
+ },
+ update: function update(element, xPosFn, yPosFn, opacityStyleFn, fillStyleFn, withTransition, flow, selectedCircles) {
+ var $$ = this,
+ box = element.node().getBBox();
+ box.width /= 2, box.height /= 2;
+
+ var xPosFn2 = function (d) {
+ return xPosFn(d) - box.width;
+ },
+ yPosFn2 = function (d) {
+ return yPosFn(d) - box.height;
+ },
+ mainCircles = element;
+
+ if (withTransition) {
+ var transitionName = $$.getTransitionName();
+
+ flow && (mainCircles = element.attr("x", xPosFn2)), mainCircles = element.transition(transitionName).attr("x", xPosFn2).attr("y", yPosFn2).transition(transitionName), selectedCircles.transition($$.getTransitionName());
+ } else mainCircles = element.attr("x", xPosFn2).attr("y", yPosFn2);
+
+ return mainCircles.style("opacity", opacityStyleFn).style("fill", fillStyleFn);
+ }
+ },
+
+ // 'circle' data point
+ circle: {
+ create: function create(element, cssClassFn, sizeFn, fillStyleFn) {
+ return element.append("circle").attr("class", cssClassFn).attr("r", sizeFn).style("fill", fillStyleFn).node();
+ },
+ update: function update(element, xPosFn, yPosFn, opacityStyleFn, fillStyleFn, withTransition, flow, selectedCircles) {
+ var $$ = this,
+ mainCircles = element;
+
+ // when '.load()' called, bubble size should be updated
+
+ if ($$.hasType("bubble") && (mainCircles = mainCircles.attr("r", $$.pointR.bind($$))), withTransition) {
+ var transitionName = $$.getTransitionName();
+
+ flow && (mainCircles = mainCircles.attr("cx", xPosFn)), mainCircles = mainCircles.transition(transitionName).attr("cx", xPosFn).attr("cy", yPosFn).transition(transitionName), selectedCircles.transition($$.getTransitionName());
+ } else mainCircles = mainCircles.attr("cx", xPosFn).attr("cy", yPosFn);
+
+ return mainCircles.style("opacity", opacityStyleFn).style("fill", fillStyleFn);
+ }
+ },
+
+ // 'rectangle' data point
+ rectangle: {
+ create: function create(element, cssClassFn, sizeFn, fillStyleFn) {
+ var rectSizeFn = function (d) {
+ return sizeFn(d) * 2;
+ };
+
+ return element.append("rect").attr("class", cssClassFn).attr("width", rectSizeFn).attr("height", rectSizeFn).style("fill", fillStyleFn).node();
+ },
+ update: function update(element, xPosFn, yPosFn, opacityStyleFn, fillStyleFn, withTransition, flow, selectedCircles) {
+ var $$ = this,
+ r = $$.config.point_r,
+ rectXPosFn = function (d) {
+ return xPosFn(d) - r;
+ },
+ rectYPosFn = function (d) {
+ return yPosFn(d) - r;
+ },
+ mainCircles = element;
+
+ if (withTransition) {
+ var transitionName = $$.getTransitionName();
+
+ flow && (mainCircles = mainCircles.attr("x", rectXPosFn)), mainCircles = mainCircles.transition(transitionName).attr("x", rectXPosFn).attr("y", rectYPosFn).transition(transitionName), selectedCircles.transition($$.getTransitionName());
+ } else mainCircles = mainCircles.attr("x", rectXPosFn).attr("y", rectYPosFn);
+
+ return mainCircles.style("opacity", opacityStyleFn).style("fill", fillStyleFn);
+ }
+ }
+}); /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+/***/ }),
+/* 38 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Selection = __webpack_require__(5),
+ _d3Array = __webpack_require__(6),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Get the position value
+ * @param {Boolean} isClockwise If the direction is clockwise
+ * @param {String} type Coordinate type 'x' or 'y'
+ * @param {Number} edge Number of edge
+ * @param {Number} pos The indexed position
+ * @param {Number} range
+ * @param {Number} ratio
+ * @return {number}
+ * @private
+ */
+function getPosition(isClockwise, type, edge, pos, range, ratio) {
+ var index = isClockwise && pos > 0 ? edge - pos : pos,
+ r = 2 * Math.PI,
+ func = type === "x" ? Math.sin : Math.cos;
+
+
+ return range * (1 - ratio * func(index * r / edge));
+}
+
+// cache key
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+var cacheKey = "$radarPoints";
+
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ initRadar: function initRadar() {
+ var $$ = this,
+ config = $$.config;
+ $$.hasType("radar") && ($$.radars = $$.main.select("." + _classes2.default.chart).append("g").attr("class", _classes2.default.chartRadars), $$.radars.levels = $$.radars.append("g").attr("class", _classes2.default.levels), $$.radars.axes = $$.radars.append("g").attr("class", _classes2.default.axis), $$.radars.shapes = $$.radars.append("g").attr("class", _classes2.default.shapes), $$.maxValue = config.radar_axis_max || $$.getMinMaxData().max[0].value);
+ },
+ getRadarSize: function getRadarSize() {
+ var $$ = this,
+ config = $$.config,
+ padding = config.axis_x_categories.length < 4 ? -20 : 10,
+ size = (Math.min($$.arcWidth, $$.arcHeight) - padding) / 2;
+
+
+ return [size, size];
+ },
+ updateTargetsForRadar: function updateTargetsForRadar(targets) {
+ var $$ = this,
+ config = $$.config;
+ (0, _util.isEmpty)(config.axis_x_categories) && (config.axis_x_categories = (0, _d3Array.range)(0, (0, _d3Array.max)(targets).values.length)), $$.generateRadarPoints();
+ },
+ getRadarPosition: function getRadarPosition(type, index, range, ratio) {
+ var $$ = this,
+ config = $$.config,
+ _$$$getRadarSize = $$.getRadarSize(),
+ width = _$$$getRadarSize[0],
+ height = _$$$getRadarSize[1],
+ edge = config.axis_x_categories.length,
+ isClockwise = config.radar_direction_clockwise,
+ pos = (0, _util.toArray)(type).map(function (v) {
+ return getPosition(isClockwise, v, edge, index, (0, _util.isDefined)(range) ? range : type === "x" ? width : height, ratio || config.radar_size_ratio);
+ });
+
+ return pos.length === 1 ? pos[0] : pos;
+ },
+
+
+ /**
+ * Generate data points
+ * @private
+ */
+ generateRadarPoints: function generateRadarPoints() {
+ var $$ = this,
+ config = $$.config,
+ targets = $$.data.targets,
+ _$$$getRadarSize2 = $$.getRadarSize(),
+ width = _$$$getRadarSize2[0],
+ height = _$$$getRadarSize2[1],
+ points = $$.getCache(cacheKey) || {},
+ size = points._size;
+
+ // recalculate position only when the previous dimension has been changed
+ if (!size || size.width !== width && size.height !== height) {
+ var getRatio = function (v) {
+ return parseFloat(Math.max(v, 0)) / $$.maxValue * config.radar_size_ratio;
+ };
+
+ targets.forEach(function (d) {
+ points[d.id] = d.values.map(function (v, i) {
+ return $$.getRadarPosition(["x", "y"], i, undefined, getRatio(v.value));
+ });
+ }), points._size = { width: width, height: height }, $$.addCache(cacheKey, points);
+ }
+ },
+ redrawRadar: function redrawRadar(duration, durationForExit) {
+ var $$ = this,
+ translate = $$.getTranslate("radar");
+
+
+ // Adjust radar, circles and texts' position
+ translate && ($$.radars.attr("transform", translate), $$.main.selectAll("." + _classes2.default.circles).attr("transform", translate), $$.main.select("." + _classes2.default.chartTexts).attr("transform", translate), $$.generateRadarPoints(), $$.updateRadarLevel(), $$.updateRadarAxes(), $$.updateRadarShape(duration, durationForExit));
+ },
+ generateGetRadarPoints: function generateGetRadarPoints() {
+ var $$ = this,
+ points = $$.getCache(cacheKey);
+
+
+ return function (d, i) {
+ var point = points[d.id][i];
+
+ return [point, point, point, point];
+ };
+ },
+ updateRadarLevel: function updateRadarLevel() {
+ var $$ = this,
+ config = $$.config,
+ _$$$getRadarSize3 = $$.getRadarSize(),
+ width = _$$$getRadarSize3[0],
+ height = _$$$getRadarSize3[1],
+ depth = config.radar_level_depth,
+ edge = config.axis_x_categories.length,
+ showText = config.radar_level_text_show,
+ radarLevels = $$.radars.levels,
+ levelData = (0, _d3Array.range)(0, depth),
+ radius = config.radar_size_ratio * Math.min(width, height),
+ levelRatio = levelData.map(function (l) {
+ return radius * ((l + 1) / depth);
+ }),
+ levelTextFormat = config.radar_level_text_format,
+ points = levelData.map(function (v) {
+ var range = levelRatio[v],
+ pos = (0, _d3Array.range)(0, edge).map(function (i) {
+ return $$.getRadarPosition(["x", "y"], i, range, 1).join(",");
+ });
+
+
+ return pos.join(" ");
+ }),
+ level = radarLevels.selectAll("." + _classes2.default.level).data(levelData);
+
+ // Generate points
+ level.exit().remove();
+
+
+ var levelEnter = level.enter().append("g").attr("class", function (d, i) {
+ return _classes2.default.level + " " + _classes2.default.level + "-" + i;
+ });
+
+ levelEnter.append("polygon").style("visibility", config.radar_level_show ? null : "hidden"), showText && (radarLevels.select("text").empty() && radarLevels.append("text").attr("dx", "-.5em").attr("dy", "-.7em").style("text-anchor", "end").text(function () {
+ return levelTextFormat(0);
+ }), levelEnter.append("text").attr("dx", "-.5em").style("text-anchor", "end").text(function (d) {
+ return levelTextFormat($$.maxValue / levelData.length * (d + 1));
+ })), levelEnter.merge(level).attr("transform", function (d) {
+ return "translate(" + (width - levelRatio[d]) + ", " + (height - levelRatio[d]) + ")";
+ }).selectAll("polygon").attr("points", function (d) {
+ return points[d];
+ }), showText && radarLevels.selectAll("text").attr("x", function (d) {
+ return (0, _util.isUndefined)(d) ? width : points[d].split(",")[0];
+ }).attr("y", function (d) {
+ return (0, _util.isUndefined)(d) ? height : 0;
+ });
+ },
+ updateRadarAxes: function updateRadarAxes() {
+ var $$ = this,
+ config = $$.config,
+ _$$$getRadarSize4 = $$.getRadarSize(),
+ width = _$$$getRadarSize4[0],
+ height = _$$$getRadarSize4[1],
+ categories = config.axis_x_categories,
+ axis = $$.radars.axes.selectAll("g").data(categories);axis.exit().remove();
+
+
+ var axisEnter = axis.enter().append("g").attr("class", function (d, i) {
+ return _classes2.default.axis + "-" + i;
+ });
+
+ config.radar_axis_line_show && axisEnter.append("line"), config.radar_axis_text_show && axisEnter.append("text"), axis = axisEnter.merge(axis), config.radar_axis_line_show && axis.select("line").attr("x1", width).attr("y1", height).attr("x2", function (d, i) {
+ return $$.getRadarPosition("x", i);
+ }).attr("y2", function (d, i) {
+ return $$.getRadarPosition("y", i);
+ }), config.radar_axis_text_show && axis.select("text").style("text-anchor", "middle").attr("dy", ".5em").text(function (d) {
+ return d;
+ }).datum(function (d, i) {
+ return { index: i };
+ }).attr("x", function (d, i) {
+ return $$.getRadarPosition("x", i, undefined, 1);
+ }).attr("y", function (d, i) {
+ return $$.getRadarPosition("y", i, undefined, 1);
+ }), $$.bindEvent();
+ },
+ bindEvent: function bindEvent() {
+ var _this = this,
+ $$ = this,
+ config = $$.config;
+
+ if (config.interaction_enabled) {
+ var isMouse = $$.inputType === "mouse";
+
+ $$.radars.select("." + _classes2.default.axis).on((isMouse ? "mouseover " : "") + "click", function () {
+ if (!$$.transiting) // skip while transiting
+ {
+ var target = (0, _d3Selection.select)(_d3Selection.event.target),
+ index = target.datum().index;
+ $$.selectRectForSingle($$.svg.node(), null, index), $$.setOver(index);
+ }
+ }).on("mouseout", isMouse ? function () {
+ _this.hideTooltip(), _this.unexpandCircles();
+ } : null);
+ }
+ },
+ updateRadarShape: function updateRadarShape(duration, durationForExit) {
+ var $$ = this,
+ targets = $$.data.targets,
+ points = $$.getCache(cacheKey),
+ areas = $$.radars.shapes.selectAll("polygon").data(targets),
+ areasEnter = areas.enter().append("g").attr("class", $$.classChartRadar.bind($$));
+ areas.exit().transition().duration(durationForExit).remove(), areasEnter.append("polygon").merge(areas).transition().duration(duration).style("fill", function (d) {
+ return $$.color(d);
+ }).style("stroke", function (d) {
+ return $$.color(d);
+ }).attr("points", function (d) {
+ return points[d.id].join(" ");
+ });
+ },
+
+
+ /**
+ * Get data point x coordinate
+ * @param {Object} d Data object
+ * @return {Number}
+ * @private
+ */
+ radarCircleX: function radarCircleX(d) {
+ return this.getCache(cacheKey)[d.id][d.index][0];
+ },
+
+
+ /**
+ * Get data point y coordinate
+ * @param {Object} d Data object
+ * @return {Number}
+ * @private
+ */
+ radarCircleY: function radarCircleY(d) {
+ return this.getCache(cacheKey)[d.id][d.index][1];
+ }
+});
+
+/***/ }),
+/* 39 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Selection = __webpack_require__(5),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ /**
+ * Initializes the text
+ * @private
+ */
+ initText: function initText() {
+ var $$ = this;
+
+ $$.main.select("." + _classes2.default.chart).append("g").attr("class", _classes2.default.chartTexts), $$.mainText = (0, _d3Selection.selectAll)([]);
+ },
+
+
+ /**
+ * Update chartText
+ * @private
+ * @param {Object} $$.data.targets
+ */
+ updateTargetsForText: function updateTargetsForText(targets) {
+ var $$ = this,
+ classChartText = $$.classChartText.bind($$),
+ classTexts = $$.classTexts.bind($$),
+ classFocus = $$.classFocus.bind($$),
+ mainTextUpdate = $$.main.select("." + _classes2.default.chartTexts).selectAll("." + _classes2.default.chartText).data(targets).attr("class", function (d) {
+ return classChartText(d) + classFocus(d);
+ }),
+ mainTextEnter = mainTextUpdate.enter().append("g").attr("class", classChartText).style("opacity", "0").style("pointer-events", "none");
+ mainTextEnter.append("g").attr("class", classTexts);
+ },
+
+
+ /**
+ * Update text
+ * @private
+ * @param {Number} Fade-out transition duration
+ */
+ updateText: function updateText(durationForExit) {
+ var _this = this,
+ $$ = this,
+ config = $$.config,
+ dataFn = $$.labelishData.bind($$),
+ classText = $$.classText.bind($$);
+
+ $$.mainText = $$.main.selectAll("." + _classes2.default.texts).selectAll("." + _classes2.default.text).data(function (d) {
+ return _this.isRadarType(d) ? d.values : dataFn(d);
+ }), $$.mainText.exit().transition().duration(durationForExit).style("fill-opacity", "0").remove(), $$.mainText = $$.mainText.enter().append("text").merge($$.mainText).attr("class", classText).attr("text-anchor", function (d) {
+ return config.axis_rotated ? d.value < 0 ? "end" : "start" : "middle";
+ }).style("stroke", "none").style("fill", function (d) {
+ return $$.color(d);
+ }).style("fill-opacity", "0").text(function (d, i, j) {
+ return $$.dataLabelFormat(d.id)(d.value, d.id, i, j);
+ });
+ },
+
+
+ /**
+ * Redraw chartText
+ * @private
+ * @param {Number} x Attribute
+ * @param {Number} y Attribute
+ * @param {Object} options.flow
+ * @param {Boolean} indicates transition is enabled
+ * @returns {Object} $$.mainText
+ */
+ redrawText: function redrawText(xForText, yForText, forFlow, withTransition) {
+ return [(withTransition ? this.mainText.transition() : this.mainText).attr("x", xForText).attr("y", yForText).style("fill", this.color).style("fill-opacity", forFlow ? 0 : this.opacityForText.bind(this))];
+ },
+
+
+ /**
+ * Gets the getBoundingClientRect value of the element
+ * @private
+ * @param {HTMLElement|d3.selection} textVal
+ * @param {String} className
+ * @param {HTMLElement|d3.selection} elementVal
+ * @returns {Object} value of element.getBoundingClientRect()
+ */
+ getTextRect: function getTextRect(textVal, className, elementVal) {
+ var text = (textVal.node ? textVal.node() : textVal).textContent,
+ element = elementVal.node ? elementVal.node() : elementVal,
+ dummy = (0, _d3Selection.select)("body").append("div").classed("bb", !0),
+ svg = dummy.append("svg").style("visibility", "hidden").style("position", "fixed").style("top", "0px").style("left", "0px"),
+ font = (0, _d3Selection.select)(element).style("font"),
+ rect = void 0;
+
+
+ return svg.selectAll(".dummy").data([text]).enter().append("text").classed(className, !!className).style("font", font).text(text).each(function () {
+ rect = this.getBoundingClientRect();
+ }), dummy.remove(), rect;
+ },
+
+
+ /**
+ * Gets the x or y coordinate of the text
+ * @private
+ * @param {Object} area Indices
+ * @param {Object} bar Indices
+ * @param {Object} line Indices
+ * @param {Boolean} whether or not to x
+ * @returns {Number} coordinates
+ */
+ generateXYForText: function generateXYForText(areaIndices, barIndices, lineIndices, forX) {
+ var $$ = this,
+ getAreaPoints = $$.generateGetAreaPoints(areaIndices, !1),
+ getBarPoints = $$.generateGetBarPoints(barIndices, !1),
+ getLinePoints = $$.generateGetLinePoints(lineIndices, !1),
+ getRadarPoints = $$.generateGetRadarPoints(),
+ getter = forX ? $$.getXForText : $$.getYForText;
+
+
+ return function (d, i) {
+ var getPoints = $$.isAreaType(d) && getAreaPoints || $$.isBarType(d) && getBarPoints || $$.isRadarType(d) && getRadarPoints || getLinePoints;
+
+ return getter.call($$, getPoints(d, i), d, this);
+ };
+ },
+
+
+ /**
+ * Gets the x coordinate of the text
+ * @private
+ * @param {Object} points
+ * @param {Object} data
+ * @param {HTMLElement} element
+ * @returns {Number} x coordinate
+ */
+ getXForText: function getXForText(points, d, textElement) {
+ var $$ = this,
+ config = $$.config,
+ xPos = void 0,
+ padding = void 0;
+
+
+ return config.axis_rotated ? (padding = $$.isBarType(d) ? 4 : 6, xPos = points[2][1] + padding * (d.value < 0 ? -1 : 1)) : xPos = $$.hasType("bar") ? (points[2][0] + points[0][0]) / 2 : points[0][0], d.value === null && (xPos > $$.width ? xPos = $$.width - textElement.getBoundingClientRect().width : xPos < 0 && (xPos = 4)), xPos + (config.data_labels_position.x || 0);
+ },
+
+
+ /**
+ * Gets the y coordinate of the text
+ * @private
+ * @param {Object} points
+ * @param {Object} data
+ * @param {HTMLElement} element
+ * @returns {Number} y coordinate
+ */
+ getYForText: function getYForText(points, d, textElement) {
+ var $$ = this,
+ config = $$.config,
+ r = config.point_r,
+ baseY = 3,
+ yPos = void 0;
+
+
+ if (config.axis_rotated) yPos = (points[0][0] + points[2][0] + textElement.getBoundingClientRect().height * .6) / 2;else if (yPos = points[2][1], (0, _util.isNumber)(r) && r > 5 && ($$.isLineType(d) || $$.isScatterType(d)) && (baseY += config.point_r / 2.3), d.value < 0 || d.value === 0 && !$$.hasPositiveValue) yPos += textElement.getBoundingClientRect().height, $$.isBarType(d) && $$.isSafari() ? yPos -= baseY : !$$.isBarType(d) && $$.isChrome() && (yPos += baseY);else {
+ var diff = -baseY * 2;
+
+ $$.isBarType(d) ? diff = -baseY : $$.isBubbleType(d) && (diff = baseY), yPos += diff;
+ }
+
+ // show labels regardless of the domain if value is null
+ if (d.value === null && !config.axis_rotated) {
+ var boxHeight = textElement.getBoundingClientRect().height;
+
+ yPos < boxHeight ? yPos = boxHeight : yPos > this.height && (yPos = this.height - 4);
+ }
+
+ return yPos + (config.data_labels_position.y || 0);
+ }
+});
+
+/***/ }),
+/* 40 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ setTargetType: function setTargetType(targetIds, type) {
+ var $$ = this,
+ config = $$.config;
+ $$.mapToTargetIds(targetIds).forEach(function (id) {
+ $$.withoutFadeIn[id] = type === config.data_types[id], config.data_types[id] = type;
+ }), targetIds || (config.data_type = type);
+ },
+ hasType: function hasType(type, targetsValue) {
+ var $$ = this,
+ types = $$.config.data_types,
+ targets = targetsValue || $$.data.targets,
+ has = !1;
+
+
+ return targets && targets.length ? targets.forEach(function (target) {
+ var t = types[target.id];
+
+ (t && t.indexOf(type) >= 0 || !t && type === "line") && (has = !0);
+ }) : Object.keys(types).length ? Object.keys(types).forEach(function (id) {
+ types[id] === type && (has = !0);
+ }) : has = $$.config.data_type === type, has;
+ },
+
+
+ /**
+ * Check if contains arc types chart
+ * @param {Object} targets
+ * @param {Array} exclude Excluded types
+ * @return {boolean}
+ * @private
+ */
+ hasArcType: function hasArcType(targets) {
+ var _this = this,
+ exclude = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [],
+ types = ["pie", "donut", "gauge", "radar"].filter(function (v) {
+ return exclude.indexOf(v) === -1;
+ });
+
+ return !types.every(function (v) {
+ return !_this.hasType(v, targets);
+ });
+ },
+ isLineType: function isLineType(d) {
+ var id = (0, _util.isString)(d) ? d : d.id;
+
+ return !this.config.data_types[id] || this.isTypeOf(id, ["line", "spline", "area", "area-spline", "area-spline-range", "area-line-range", "step", "area-step"]);
+ },
+ isTypeOf: function isTypeOf(d, type) {
+ var id = (0, _util.isString)(d) ? d : d.id,
+ dataType = this.config.data_types[id];
+
+
+ return (0, _util.isArray)(type) ? type.indexOf(dataType) >= 0 : dataType === type;
+ },
+ isStepType: function isStepType(d) {
+ return this.isTypeOf(d, ["step", "area-step"]);
+ },
+ isSplineType: function isSplineType(d) {
+ return this.isTypeOf(d, ["spline", "area-spline", "area-spline-range"]);
+ },
+ isAreaType: function isAreaType(d) {
+ return this.isTypeOf(d, ["area", "area-spline", "area-spline-range", "area-line-range", "area-step"]);
+ },
+ isAreaRangeType: function isAreaRangeType(d) {
+ return this.isTypeOf(d, ["area-spline-range", "area-line-range"]);
+ },
+ isBarType: function isBarType(d) {
+ return this.isTypeOf(d, "bar");
+ },
+ isBubbleType: function isBubbleType(d) {
+ return this.isTypeOf(d, "bubble");
+ },
+ isScatterType: function isScatterType(d) {
+ return this.isTypeOf(d, "scatter");
+ },
+ isPieType: function isPieType(d) {
+ return this.isTypeOf(d, "pie");
+ },
+ isGaugeType: function isGaugeType(d) {
+ return this.isTypeOf(d, "gauge");
+ },
+ isDonutType: function isDonutType(d) {
+ return this.isTypeOf(d, "donut");
+ },
+ isRadarType: function isRadarType(d) {
+ return this.isTypeOf(d, "radar");
+ },
+ isArcType: function isArcType(d) {
+ return this.isPieType(d) || this.isDonutType(d) || this.isGaugeType(d) || this.isRadarType(d);
+ },
+
+
+ // determine if is 'circle' data point
+ isCirclePoint: function isCirclePoint() {
+ var config = this.config,
+ pattern = config.point_pattern;
+
+
+ return config.point_type === "circle" && (!pattern || (0, _util.isArray)(pattern) && pattern.length === 0);
+ },
+ lineData: function lineData(d) {
+ return this.isLineType(d) ? [d] : [];
+ },
+ arcData: function arcData(d) {
+ return this.isArcType(d.data) ? [d] : [];
+ },
+ barData: function barData(d) {
+ return this.isBarType(d) ? d.values : [];
+ },
+
+
+ /**
+ * Get data adapt for data label showing
+ * @param {Object} d Data object
+ * @return {Array}
+ * @private
+ */
+ labelishData: function labelishData(d) {
+ return this.isBarType(d) || this.isLineType(d) || this.isScatterType(d) || this.isBubbleType(d) || this.isRadarType(d) ? d.values : [];
+ },
+ barLineBubbleData: function barLineBubbleData(d) {
+ return this.isBarType(d) || this.isLineType(d) || this.isBubbleType(d) ? d.values : [];
+ },
+
+
+ // https://github.com/d3/d3-shape#curves
+ isInterpolationType: function isInterpolationType(type) {
+ return ["basis", "basis-closed", "basis-open", "bundle", "cardinal", "cardinal-closed", "cardinal-open", "catmull-rom", "catmull-rom-closed", "catmull-rom-open", "linear", "linear-closed", "monotone-x", "monotone-y", "natural"].indexOf(type) >= 0;
+ }
+});
+
+/***/ }),
+/* 41 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Selection = __webpack_require__(5),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// Grid position and text anchor helpers
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+var getGridTextAnchor = function (d) {
+ return (0, _util.isValue)(d.position) || "end";
+},
+ getGridTextDx = function (d) {
+ return d.position === "start" ? 4 : d.position === "middle" ? 0 : -4;
+},
+ getGridTextX = function (isX, width, height) {
+ return function (d) {
+ var x = isX ? 0 : width;
+
+ return d.position === "start" ? x = isX ? -height : 0 : d.position === "middle" && (x = (isX ? -height : width) / 2), x;
+ };
+};
+
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ initGrid: function initGrid() {
+ var $$ = this,
+ config = $$.config;
+ $$.xgrid = (0, _d3Selection.selectAll)([]), config.grid_lines_front || $$.initGridLines(), config.grid_front || $$.initXYFocusGrid();
+ },
+ initGridLines: function initGridLines() {
+ var $$ = this;
+
+ $$.gridLines = $$.main.append("g").attr("clip-path", $$.clipPathForGrid).attr("class", _classes2.default.grid + " " + _classes2.default.gridLines), $$.gridLines.append("g").attr("class", _classes2.default.xgridLines), $$.gridLines.append("g").attr("class", _classes2.default.ygridLines), $$.xgridLines = (0, _d3Selection.selectAll)([]);
+ },
+ updateXGrid: function updateXGrid(withoutUpdate) {
+ var $$ = this,
+ config = $$.config,
+ isRotated = config.axis_rotated,
+ xgridData = $$.generateGridData(config.grid_x_type, $$.x),
+ tickOffset = $$.isCategorized() ? $$.xAxis.tickOffset() : 0;
+ $$.xgridAttr = isRotated ? {
+ "x1": 0,
+ "x2": $$.width,
+ "y1": function y1(d) {
+ return $$.x(d) - tickOffset;
+ },
+ "y2": function y2(d) {
+ return $$.x(d) - tickOffset;
+ }
+ } : {
+ "x1": function x1(d) {
+ return $$.x(d) + tickOffset;
+ },
+ "x2": function x2(d) {
+ return $$.x(d) + tickOffset;
+ },
+ "y1": 0,
+ "y2": $$.height
+ }, $$.xgrid = $$.main.select("." + _classes2.default.xgrids).selectAll("." + _classes2.default.xgrid).data(xgridData), $$.xgrid.exit().remove(), $$.xgrid = $$.xgrid.enter().append("line").attr("class", _classes2.default.xgrid).merge($$.xgrid), withoutUpdate || $$.xgrid.each(function () {
+ var grid = (0, _d3Selection.select)(this);
+
+ Object.keys($$.xgridAttr).forEach(function (id) {
+ grid.attr(id, $$.xgridAttr[id]).style("opacity", function () {
+ return grid.attr(isRotated ? "y1" : "x1") === (isRotated ? $$.height : 0) ? "0" : "1";
+ });
+ });
+ });
+ },
+ updateYGrid: function updateYGrid() {
+ var $$ = this,
+ config = $$.config,
+ isRotated = config.axis_rotated,
+ gridValues = $$.yAxis.tickValues() || $$.y.ticks(config.grid_y_ticks);
+ $$.ygrid = $$.main.select("." + _classes2.default.ygrids).selectAll("." + _classes2.default.ygrid).data(gridValues), $$.ygrid.exit().remove(), $$.ygrid = $$.ygrid.enter().append("line").attr("class", _classes2.default.ygrid).merge($$.ygrid), $$.ygrid.attr("x1", isRotated ? $$.y : 0).attr("x2", isRotated ? $$.y : $$.width).attr("y1", isRotated ? 0 : $$.y).attr("y2", isRotated ? $$.height : $$.y), $$.smoothLines($$.ygrid, "grid");
+ },
+ updateGrid: function updateGrid(duration) {
+ var $$ = this;
+
+ // hide if arc type
+ $$.grid.style("visibility", $$.hasArcType() ? "hidden" : "visible"), $$.main.select("line." + _classes2.default.xgridFocus).style("visibility", "hidden"), $$.updateXGridLines(duration), $$.updateYGridLines(duration);
+ },
+
+
+ /**
+ * Update X Grid lines
+ * @param {Number} duration
+ * @private
+ */
+ updateXGridLines: function updateXGridLines(duration) {
+ var $$ = this,
+ main = $$.main,
+ config = $$.config,
+ isRotated = config.axis_rotated;
+ config.grid_x_show && $$.updateXGrid(), $$.xgridLines = main.select("." + _classes2.default.xgridLines).selectAll("." + _classes2.default.xgridLine).data(config.grid_x_lines), $$.xgridLines.exit().transition().duration(duration).style("opacity", "0").remove();
+
+
+ // enter
+ var xgridLine = $$.xgridLines.enter().append("g");
+
+ xgridLine.append("line").style("opacity", "0"), xgridLine.append("text").attr("transform", isRotated ? "" : "rotate(-90)").attr("dy", -5).style("opacity", "0"), $$.xgridLines = xgridLine.merge($$.xgridLines), $$.xgridLines.attr("class", function (d) {
+ return (_classes2.default.xgridLine + " " + (d.class || "")).trim();
+ }).select("text").attr("text-anchor", getGridTextAnchor).attr("dx", getGridTextDx).transition().duration(duration).text(function (d) {
+ return d.text;
+ }).transition().style("opacity", "1");
+ },
+
+
+ /**
+ * Update Y Grid lines
+ * @param {Number} duration
+ * @private
+ */
+ updateYGridLines: function updateYGridLines(duration) {
+ var $$ = this,
+ main = $$.main,
+ config = $$.config,
+ isRotated = config.axis_rotated;
+ config.grid_y_show && $$.updateYGrid(), $$.ygridLines = main.select("." + _classes2.default.ygridLines).selectAll("." + _classes2.default.ygridLine).data(config.grid_y_lines), $$.ygridLines.exit().transition().duration(duration).style("opacity", "0").remove();
+
+
+ // enter
+ var ygridLine = $$.ygridLines.enter().append("g");
+
+ ygridLine.append("line").style("opacity", "0"), ygridLine.append("text").attr("transform", isRotated ? "rotate(-90)" : "").style("opacity", "0"), $$.ygridLines = ygridLine.merge($$.ygridLines);
+
+
+ // update
+ var yv = $$.yv.bind($$);
+
+ $$.ygridLines.attr("class", function (d) {
+ return (_classes2.default.ygridLine + " " + (d.class || "")).trim();
+ }).select("line").transition().duration(duration).attr("x1", isRotated ? yv : 0).attr("x2", isRotated ? yv : $$.width).attr("y1", isRotated ? 0 : yv).attr("y2", isRotated ? $$.height : yv).transition().style("opacity", "1"), $$.ygridLines.select("text").attr("text-anchor", getGridTextAnchor).attr("dx", getGridTextDx).transition().duration(duration).attr("dy", -5).attr("x", getGridTextX(isRotated, $$.width, $$.height)).attr("y", yv).text(function (d) {
+ return d.text;
+ }).transition().style("opacity", "1");
+ },
+ redrawGrid: function redrawGrid(withTransition) {
+ var $$ = this,
+ isRotated = $$.config.axis_rotated,
+ xv = $$.xv.bind($$),
+ lines = $$.xgridLines.select("line"),
+ texts = $$.xgridLines.select("text");
+
+
+ return lines = (withTransition ? lines.transition() : lines).attr("x1", isRotated ? 0 : xv).attr("x2", isRotated ? $$.width : xv).attr("y1", isRotated ? xv : 0).attr("y2", isRotated ? xv : $$.height), texts = (withTransition ? texts.transition() : texts).attr("x", getGridTextX(!isRotated, $$.width, $$.height)).attr("y", xv).text(function (d) {
+ return d.text;
+ }), [(withTransition ? lines.transition() : lines).style("opacity", "1"), (withTransition ? texts.transition() : texts).style("opacity", "1")];
+ },
+ initXYFocusGrid: function initXYFocusGrid() {
+ var $$ = this,
+ config = $$.config;
+ $$.grid = $$.main.append("g").attr("clip-path", $$.clipPathForGrid).attr("class", _classes2.default.grid), config.grid_x_show && $$.grid.append("g").attr("class", _classes2.default.xgrids), config.grid_y_show && $$.grid.append("g").attr("class", _classes2.default.ygrids), config.grid_focus_show && $$.grid.append("g").attr("class", _classes2.default.xgridFocus).append("line").attr("class", _classes2.default.xgridFocus);
+ },
+ showXGridFocus: function showXGridFocus(selectedData) {
+ var $$ = this,
+ config = $$.config,
+ isRotated = config.axis_rotated,
+ dataToShow = selectedData.filter(function (d) {
+ return d && (0, _util.isValue)($$.getBaseValue(d));
+ }),
+ focusEl = $$.main.selectAll("line." + _classes2.default.xgridFocus),
+ xx = $$.xx.bind($$);
+ !config.tooltip_show || $$.hasType("bubble") || $$.hasType("scatter") || $$.hasArcType() || (focusEl.style("visibility", "visible").data([dataToShow[0]]).attr(isRotated ? "y1" : "x1", xx).attr(isRotated ? "y2" : "x2", xx), $$.smoothLines(focusEl, "grid"));
+
+ // Hide when bubble/scatter plot exists
+ },
+ hideXGridFocus: function hideXGridFocus() {
+ this.main.select("line." + _classes2.default.xgridFocus).style("visibility", "hidden");
+ },
+ updateXgridFocus: function updateXgridFocus() {
+ var $$ = this,
+ isRotated = $$.config.axis_rotated;
+ $$.main.select("line." + _classes2.default.xgridFocus).attr("x1", isRotated ? 0 : -10).attr("x2", isRotated ? $$.width : -10).attr("y1", isRotated ? -10 : 0).attr("y2", isRotated ? -10 : $$.height);
+ },
+ generateGridData: function generateGridData(type, scale) {
+ var $$ = this,
+ tickNum = $$.main.select("." + _classes2.default.axisX).selectAll(".tick").size(),
+ gridData = [];
+
+
+ if (type === "year") {
+ var xDomain = $$.getXDomain(),
+ firstYear = xDomain[0].getFullYear(),
+ lastYear = xDomain[1].getFullYear();
+
+
+ for (var i = firstYear; i <= lastYear; i++) gridData.push(new Date(i + "-01-01 00:00:00"));
+ } else gridData = scale.ticks(10), gridData.length > tickNum && (gridData = gridData.filter(function (d) {
+ return (d + "").indexOf(".") < 0;
+ }));
+
+ return gridData;
+ },
+ getGridFilterToRemove: function getGridFilterToRemove(params) {
+ return params ? function (line) {
+ var found = !1;
+
+ return ((0, _util.isArray)(params) ? params.concat() : [params]).forEach(function (param) {
+ ("value" in param && line.value === param.value || "class" in param && line.class === param.class) && (found = !0);
+ }), found;
+ } : function () {
+ return !0;
+ };
+ },
+ removeGridLines: function removeGridLines(params, forX) {
+ var $$ = this,
+ config = $$.config,
+ toRemove = $$.getGridFilterToRemove(params),
+ classLines = forX ? _classes2.default.xgridLines : _classes2.default.ygridLines,
+ classLine = forX ? _classes2.default.xgridLine : _classes2.default.ygridLine;
+ $$.main.select("." + classLines).selectAll("." + classLine).filter(toRemove).transition().duration(config.transition_duration).style("opacity", "0").remove();
+
+
+ var gridLines = "grid_" + (forX ? "x" : "y") + "_lines";
+
+ config[gridLines] = config[gridLines].filter(function toShow(line) {
+ return !toRemove(line);
+ });
+ }
+});
+
+/***/ }),
+/* 42 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Selection = __webpack_require__(5),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ /**
+ * Initializes the tooltip
+ * @private
+ */
+ initTooltip: function initTooltip() {
+ var $$ = this,
+ config = $$.config;
+
+
+ // Show tooltip if needed
+ if ($$.tooltip = $$.selectChart.style("position", "relative").append("div").attr("class", _classes2.default.tooltipContainer).style("position", "absolute").style("pointer-events", "none").style("display", "none"), config.tooltip_init_show) {
+ if ($$.isTimeSeries() && (0, _util.isString)(config.tooltip_init_x)) {
+ var targets = $$.data.targets[0],
+ i = void 0,
+ val = void 0;
+
+
+ for (config.tooltip_init_x = $$.parseDate(config.tooltip_init_x), i = 0; (val = targets.values[i]) && val.x - config.tooltip_init_x !== 0; i++);
+
+ config.tooltip_init_x = i;
+ }
+
+ $$.tooltip.html(config.tooltip_contents.call($$, $$.data.targets.map(function (d) {
+ return $$.addName(d.values[config.tooltip_init_x]);
+ }), $$.axis.getXAxisTickFormat(), $$.getYFormat($$.hasArcType(null, ["radar"])), $$.color)), $$.tooltip.style("top", config.tooltip_init_position.top).style("left", config.tooltip_init_position.left).style("display", "block");
+ }
+ },
+
+
+ /**
+ * Returns the tooltip content(HTML string)
+ * @param {Object} d data
+ * @param {Function} defaultTitleFormat Default title format
+ * @param {Function} defaultValueFormat Default format for each data value in the tooltip.
+ * @param {Function} color Color function
+ * @returns {String} html
+ * @private
+ */
+ getTooltipContent: function getTooltipContent(d, defaultTitleFormat, defaultValueFormat, color) {
+ var $$ = this,
+ config = $$.config,
+ titleFormat = config.tooltip_format_title || defaultTitleFormat,
+ nameFormat = config.tooltip_format_name || function (name) {
+ return name;
+ },
+ valueFormat = config.tooltip_format_value || defaultValueFormat,
+ order = config.tooltip_order,
+ getRowValue = function (row) {
+ return $$.getBaseValue(row);
+ },
+ getBgColor = $$.levelColor ? function (row) {
+ return $$.levelColor(row.value);
+ } : function (row) {
+ return color(row.id);
+ };
+
+ if (order === null && config.data_groups.length) {
+ // for stacked data, order should aligned with the visually displayed data
+ var ids = $$.orderTargets($$.data.targets).map(function (i2) {
+ return i2.id;
+ }).reverse();
+
+ d.sort(function (a, b) {
+ var v1 = a ? a.value : null,
+ v2 = b ? b.value : null;
+
+
+ return v1 > 0 && v2 > 0 && (v1 = a.id ? ids.indexOf(a.id) : null, v2 = b.id ? ids.indexOf(b.id) : null), v1 - v2;
+ });
+ } else if (/^(asc|desc)$/.test(order)) {
+ d.sort(function (a, b) {
+ var v1 = a ? getRowValue(a) : null,
+ v2 = b ? getRowValue(b) : null;
+
+
+ return order === "asc" ? v1 - v2 : v2 - v1;
+ });
+ } else (0, _util.isFunction)(order) && d.sort(order);
+
+ var text = void 0,
+ row = void 0,
+ param = void 0,
+ value = void 0;
+
+
+ for (var i = 0, len = d.length; i < len; i++) if ((row = d[i]) && (getRowValue(row) || getRowValue(row) === 0)) {
+
+ if (!text) {
+ var title = (0, _util.sanitise)(titleFormat ? titleFormat(row.x) : row.x);
+
+ text = "<table class=\"" + $$.CLASS.tooltip + "\">" + ((0, _util.isValue)(title) ? "<tr><th colspan=\"2\">" + title + "</th></tr>" : "");
+ }
+
+ if (param = [row.ratio, row.id, row.index, d], $$.isAreaRangeType(row) ? (value = ["high", "low"].map(function (v) {
+ return (0, _util.sanitise)(valueFormat.apply(undefined, [$$.getAreaRangeData(row, v)].concat(param)));
+ }), value = "<b>Mid:</b> " + value + " <b>High:</b> " + value[0] + " <b>Low:</b> " + value[1]) : value = (0, _util.sanitise)(valueFormat.apply(undefined, [getRowValue(row)].concat(param))), value !== undefined) {
+ // Skip elements when their name is set to null
+ if (row.name === null) continue;
+
+ var name = (0, _util.sanitise)(nameFormat.apply(undefined, [row.name].concat(param))),
+ bgcolor = getBgColor(row);
+ text += "<tr class=\"" + $$.CLASS.tooltipName + $$.getTargetSelectorSuffix(row.id) + "\"><td class=\"name\">", text += $$.patterns ? "<svg><rect style=\"fill:" + bgcolor + "\" width=\"10\" height=\"10\"></rect></svg>" : "<span style=\"background-color:" + bgcolor + "\"></span>", text += name + "</td><td class=\"value\">" + value + "</td></tr>";
+ }
+ }
+
+ return text + "</table>";
+ },
+
+
+ /**
+ * Returns the position of the tooltip
+ * @param {Object} dataToShow data
+ * @param {String} tWidth Width value of tooltip element
+ * @param {String} tHeight Height value of tooltip element
+ * @param {HTMLElement} element
+ * @returns {Object} top, left value
+ * @private
+ */
+ tooltipPosition: function tooltipPosition(dataToShow, tWidth, tHeight, element) {
+ var $$ = this,
+ config = $$.config,
+ _d3Mouse = (0, _d3Selection.mouse)(element),
+ left = _d3Mouse[0],
+ top = _d3Mouse[1],
+ svgLeft = $$.getSvgLeft(!0),
+ chartRight = svgLeft + $$.currentWidth - $$.getCurrentPaddingRight();
+
+ // Determine tooltip position
+ if (top += 20, $$.hasArcType()) {
+ var raw = $$.inputType === "touch" || $$.hasType("radar");
+
+ raw || (top += $$.height / 2, left += ($$.width - ($$.isLegendRight ? $$.getLegendWidth() : 0)) / 2);
+ } else {
+ var dataScale = $$.x(dataToShow[0].x);
+
+ config.axis_rotated ? (top = dataScale + 20, left += svgLeft + 100, chartRight -= svgLeft) : (top -= 5, left = svgLeft + $$.getCurrentPaddingLeft(!0) + 20 + ($$.zoomScale ? left : dataScale));
+ }
+
+ var right = left + tWidth;
+
+ return right > chartRight && (left -= right - chartRight + 20), top + tHeight > $$.currentHeight && (top -= tHeight + 30), top < 0 && (top = 0), { top: top, left: left };
+ },
+
+
+ /**
+ * Show the tooltip
+ * @private
+ * @param {Object} selectedData
+ * @param {HTMLElement} element
+ */
+ showTooltip: function showTooltip(selectedData, element) {
+ var $$ = this,
+ config = $$.config,
+ forArc = $$.hasArcType(null, ["radar"]),
+ dataToShow = selectedData.filter(function (d) {
+ return d && (0, _util.isValue)($$.getBaseValue(d));
+ }),
+ positionFunction = config.tooltip_position || $$.tooltipPosition;
+
+
+ if (dataToShow.length !== 0 && config.tooltip_show) {
+ var datum = $$.tooltip.datum(),
+ width = datum && datum.width || 0,
+ height = datum && datum.height || 0;
+
+
+ if (!datum || datum.current !== JSON.stringify(selectedData)) {
+ var html = config.tooltip_contents.call($$, selectedData, $$.axis.getXAxisTickFormat(), $$.getYFormat(forArc), $$.color);
+
+ (0, _util.callFn)(config.tooltip_onshow, $$), $$.tooltip.html(html).style("display", "block").datum({
+ current: JSON.stringify(selectedData),
+ width: width = $$.tooltip.property("offsetWidth"),
+ height: height = $$.tooltip.property("offsetHeight")
+ }), (0, _util.callFn)(config.tooltip_onshown, $$), $$._handleLinkedCharts(!0, selectedData[0].index);
+ }
+
+ // Get tooltip dimensions
+ var position = positionFunction.call(this, dataToShow, width, height, element);
+
+ // Set tooltip position
+ $$.tooltip.style("top", position.top + "px").style("left", position.left + "px");
+ }
+ },
+
+
+ /**
+ * Hide the tooltip
+ * @private
+ */
+ hideTooltip: function hideTooltip() {
+ var $$ = this,
+ config = $$.config;
+ (0, _util.callFn)(config.tooltip_onhide, $$), this.tooltip.style("display", "none").datum(null), (0, _util.callFn)(config.tooltip_onhidden, $$), $$._handleLinkedCharts(!1);
+ },
+
+
+ /**
+ * Toggle display for linked chart instances
+ * @param {Boolean} show true: show, false: hide
+ * @param {Number} index x Axis index
+ * @private
+ */
+ _handleLinkedCharts: function _handleLinkedCharts(show, index) {
+ var $$ = this;
+
+ if ($$.config.tooltip_linked) {
+ var linkedName = $$.config.tooltip_linked_name;
+
+ $$.api.internal.charts.forEach(function (c) {
+ if (c !== $$.api) {
+ var internal = c.internal,
+ isLinked = internal.config.tooltip_linked,
+ name = internal.config.tooltip_linked_name,
+ isInDom = document.body.contains(c.element);
+
+
+ if (isLinked && linkedName === name && isInDom) {
+ var isShowing = internal.tooltip.style("display") === "block";
+
+ // prevent throwing error for non-paired linked indexes
+ try {
+ isShowing ^ show && c.tooltip[isShowing ? "hide" : "show"]({ index: index });
+ } catch (e) {}
+ }
+ }
+ });
+ }
+ }
+});
+
+/***/ }),
+/* 43 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Selection = __webpack_require__(5),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ /**
+ * Initialize the legend.
+ * @private
+ */
+ initLegend: function initLegend() {
+ var $$ = this,
+ config = $$.config;
+ $$.legendItemTextBox = {}, $$.legendHasRendered = !1, $$.legend = $$.svg.append("g"), config.legend_show ? config.legend_contents_bindto && config.legend_contents_template ? $$.updateLegendTemplate() : ($$.legend.attr("transform", $$.getTranslate("legend")), $$.updateLegendWithDefaults()) : ($$.legend.style("visibility", "hidden"), $$.hiddenLegendIds = $$.mapToIds($$.data.targets));
+ },
+
+
+ /**
+ * Update legend using template option
+ * @private
+ */
+ updateLegendTemplate: function updateLegendTemplate() {
+ var $$ = this,
+ config = $$.config,
+ wrapper = (0, _d3Selection.select)(config.legend_contents_bindto),
+ template = config.legend_contents_template;
+
+
+ if (!wrapper.empty()) {
+ var targets = $$.data.targets,
+ ids = [],
+ html = "";
+ $$.mapToIds(targets).forEach(function (v) {
+ var content = (0, _util.isFunction)(template) ? template.call($$, v, $$.color(v), $$.api.data(v)[0].values) : template.replace(/{=COLOR}/g, $$.color(v)).replace(/{=TITLE}/g, v);
+
+ content && (ids.push(v), html += content);
+ });
+
+
+ var legendItem = wrapper.html(html).selectAll(function () {
+ return this.childNodes;
+ }).data(ids);
+
+ $$.setLegendItem(legendItem);
+ }
+ },
+
+
+ /**
+ * Update the legend to its default value.
+ * @private
+ */
+ updateLegendWithDefaults: function updateLegendWithDefaults() {
+ var $$ = this;
+
+ $$.updateLegend($$.mapToIds($$.data.targets), {
+ withTransform: !1,
+ withTransitionForTransform: !1,
+ withTransition: !1
+ });
+ },
+
+
+ /**
+ * Update the size of the legend.
+ * @private
+ * @param {Number} height
+ * @param {Number} width
+ */
+ updateSizeForLegend: function updateSizeForLegend(legendHeight, legendWidth) {
+ var $$ = this,
+ config = $$.config,
+ insetLegendPosition = {
+ top: $$.isLegendTop ? $$.getCurrentPaddingTop() + config.legend_inset_y + 5.5 : $$.currentHeight - legendHeight - $$.getCurrentPaddingBottom() - config.legend_inset_y,
+ left: $$.isLegendLeft ? $$.getCurrentPaddingLeft() + config.legend_inset_x + .5 : $$.currentWidth - legendWidth - $$.getCurrentPaddingRight() - config.legend_inset_x + .5
+ };
+ $$.margin3 = {
+ top: $$.isLegendRight ? 0 : $$.isLegendInset ? insetLegendPosition.top : $$.currentHeight - legendHeight,
+ right: NaN,
+ bottom: 0,
+ left: $$.isLegendRight ? $$.currentWidth - legendWidth : $$.isLegendInset ? insetLegendPosition.left : 0
+ };
+ },
+
+
+ /**
+ * Transform Legend
+ * @private
+ * @param {Boolean} whether or not to transition.
+ */
+ transformLegend: function transformLegend(withTransition) {
+ var $$ = this;
+
+ (withTransition ? $$.legend.transition() : $$.legend).attr("transform", $$.getTranslate("legend"));
+ },
+
+
+ /**
+ * Update the legend step
+ * @private
+ * @param {Number} step
+ */
+ updateLegendStep: function updateLegendStep(step) {
+ this.legendStep = step;
+ },
+
+
+ /**
+ * Update legend item width
+ * @private
+ * @param {Number} width
+ */
+ updateLegendItemWidth: function updateLegendItemWidth(w) {
+ this.legendItemWidth = w;
+ },
+
+
+ /**
+ * Update legend item height
+ * @private
+ * @param {Number} height
+ */
+ updateLegendItemHeight: function updateLegendItemHeight(h) {
+ this.legendItemHeight = h;
+ },
+
+
+ /**
+ * Get the width of the legend
+ * @private
+ * @param {Number} width
+ */
+ getLegendWidth: function getLegendWidth() {
+ var $$ = this;
+
+ return $$.config.legend_show ? $$.isLegendRight || $$.isLegendInset ? $$.legendItemWidth * ($$.legendStep + 1) : $$.currentWidth : 0;
+ },
+
+
+ /**
+ * Get the height of the legend
+ * @private
+ * @param {Number} height
+ */
+ getLegendHeight: function getLegendHeight() {
+ var $$ = this,
+ h = 0;
+
+ return $$.config.legend_show && ($$.isLegendRight ? h = $$.currentHeight : h = Math.max(20, $$.legendItemHeight) * ($$.legendStep + 1)), h;
+ },
+
+
+ /**
+ * Get the opacity of the legend
+ * @private
+ * @param {Object} d3.Select
+ * @returns {Number} opacity
+ */
+ opacityForLegend: function opacityForLegend(legendItem) {
+ return legendItem.classed(_classes2.default.legendItemHidden) ? null : "1";
+ },
+
+
+ /**
+ * Get the opacity of the legend that is unfocused
+ * @private
+ * @param {Object} legendItem, d3.Select
+ * @returns {Number} opacity
+ */
+ opacityForUnfocusedLegend: function opacityForUnfocusedLegend(legendItem) {
+ return legendItem.classed(_classes2.default.legendItemHidden) ? null : "0.3";
+ },
+
+
+ /**
+ * Toggles the focus of the legend
+ * @private
+ * @param {Array} ID's of target
+ * @param {Boolean} whether or not to focus.
+ */
+ toggleFocusLegend: function toggleFocusLegend(targetIds, focus) {
+ var $$ = this,
+ targetIdz = $$.mapToTargetIds(targetIds);
+ $$.legend.selectAll("." + _classes2.default.legendItem).filter(function (id) {
+ return targetIdz.indexOf(id) >= 0;
+ }).classed(_classes2.default.legendItemFocused, focus).transition().duration(100).style("opacity", function () {
+ var opacity = focus ? $$.opacityForLegend : $$.opacityForUnfocusedLegend;
+
+ return opacity.call($$, (0, _d3Selection.select)(this));
+ });
+ },
+
+
+ /**
+ * Revert the legend to its default state
+ * @private
+ */
+ revertLegend: function revertLegend() {
+ var $$ = this;
+
+ $$.legend.selectAll("." + _classes2.default.legendItem).classed(_classes2.default.legendItemFocused, !1).transition().duration(100).style("opacity", function () {
+ return $$.opacityForLegend((0, _d3Selection.select)(this));
+ });
+ },
+
+
+ /**
+ * Shows the legend
+ * @private
+ * @param {Array} ID's of target
+ */
+ showLegend: function showLegend(targetIds) {
+ var $$ = this,
+ config = $$.config;
+ config.legend_show || (config.legend_show = !0, $$.legend.style("visibility", "visible"), !$$.legendHasRendered && $$.updateLegendWithDefaults()), $$.removeHiddenLegendIds(targetIds), $$.legend.selectAll($$.selectorLegends(targetIds)).style("visibility", "visible").transition().style("opacity", function () {
+ return $$.opacityForLegend((0, _d3Selection.select)(this));
+ });
+ },
+
+
+ /**
+ * Hide the legend
+ * @private
+ * @param {Array} ID's of target
+ */
+ hideLegend: function hideLegend(targetIds) {
+ var $$ = this,
+ config = $$.config;
+ config.legend_show && (0, _util.isEmpty)(targetIds) && (config.legend_show = !1, $$.legend.style("visibility", "hidden")), $$.addHiddenLegendIds(targetIds), $$.legend.selectAll($$.selectorLegends(targetIds)).style("opacity", "0").style("visibility", "hidden");
+ },
+
+
+ /**
+ * Clear the LegendItemTextBox cache.
+ * @private
+ */
+ clearLegendItemTextBoxCache: function clearLegendItemTextBoxCache() {
+ this.legendItemTextBox = {};
+ },
+
+
+ /**
+ * Set legend item style & bind events
+ * @private
+ * @param {d3.selection} item
+ */
+ setLegendItem: function setLegendItem(item) {
+ var $$ = this,
+ config = $$.config,
+ isTouch = $$.inputType === "touch";
+ item.attr("class", function (id) {
+ var node = (0, _d3Selection.select)(this),
+ itemClass = !node.empty() && node.attr("class") || "";
+
+
+ return itemClass + $$.generateClass(_classes2.default.legendItem, id);
+ }).style("visibility", function (id) {
+ return $$.isLegendToShow(id) ? "visible" : "hidden";
+ }).style("cursor", "pointer").on("click", function (id) {
+ (0, _util.callFn)(config.legend_item_onclick, $$, id) || (_d3Selection.event.altKey ? ($$.api.hide(), $$.api.show(id)) : ($$.api.toggle(id), !isTouch && $$.isTargetToShow(id) ? $$.api.focus(id) : $$.api.revert())), isTouch && $$.hideTooltip();
+ }), isTouch || item.on("mouseout", function (id) {
+ (0, _util.callFn)(config.legend_item_onout, $$, id) || ((0, _d3Selection.select)(this).classed(_classes2.default.legendItemFocused, !1), $$.api.revert());
+ }).on("mouseover", function (id) {
+ (0, _util.callFn)(config.legend_item_onover, $$, id) || ((0, _d3Selection.select)(this).classed(_classes2.default.legendItemFocused, !0), !$$.transiting && $$.isTargetToShow(id) && $$.api.focus(id));
+ });
+ },
+
+
+ /**
+ * Update the legend
+ * @private
+ * @param {Array} ID's of target
+ * @param {Object} withTransform : Whether to use the transform property / withTransitionForTransform: Whether transition is used when using the transform property / withTransition : whether or not to transition.
+ * @param {Object} the return value of the generateTransitions
+ */
+ updateLegend: function updateLegend(targetIds, options, transitions) {
+ var $$ = this,
+ config = $$.config,
+ tileWidth = config.legend_item_tile_width + 5,
+ maxWidth = 0,
+ maxHeight = 0,
+ xForLegend = void 0,
+ yForLegend = void 0,
+ totalLength = 0,
+ offsets = {},
+ widths = {},
+ heights = {},
+ margins = [0],
+ steps = {},
+ step = 0,
+ background = void 0,
+ isLegendRightOrInset = $$.isLegendRight || $$.isLegendInset,
+ targetIdz = targetIds.filter(function (id) {
+ return !(0, _util.isDefined)(config.data_names[id]) || config.data_names[id] !== null;
+ }),
+ optionz = options || {},
+ withTransition = (0, _util.getOption)(optionz, "withTransition", !0),
+ withTransitionForTransform = (0, _util.getOption)(optionz, "withTransitionForTransform", !0),
+ getTextBox = function (textElement, id) {
+
+ return $$.legendItemTextBox[id] || ($$.legendItemTextBox[id] = $$.getTextRect(textElement, _classes2.default.legendItem, textElement)), $$.legendItemTextBox[id];
+ },
+ updatePositions = function (textElement, id, index) {
+ var isLast = index === targetIdz.length - 1,
+ box = getTextBox(textElement, id),
+ itemWidth = box.width + tileWidth + (isLast && !isLegendRightOrInset ? 0 : 10) + config.legend_padding,
+ itemHeight = box.height + 4,
+ itemLength = isLegendRightOrInset ? itemHeight : itemWidth,
+ areaLength = isLegendRightOrInset ? $$.getLegendHeight() : $$.getLegendWidth(),
+ margin = void 0,
+ updateValues = function (id2, withoutStep) {
+ withoutStep || (margin = (areaLength - totalLength - itemLength) / 2, margin < 10 && (margin = (areaLength - itemLength) / 2, totalLength = 0, step++)), steps[id2] = step, margins[step] = $$.isLegendInset ? 10 : margin, offsets[id2] = totalLength, totalLength += itemLength;
+ };
+
+ // MEMO: care about condifion of step, totalLength
+
+
+ if (index === 0 && (totalLength = 0, step = 0, maxWidth = 0, maxHeight = 0), config.legend_show && !$$.isLegendToShow(id)) return widths[id] = 0, heights[id] = 0, steps[id] = 0, void (offsets[id] = 0);
+
+ widths[id] = itemWidth, heights[id] = itemHeight, (!maxWidth || itemWidth >= maxWidth) && (maxWidth = itemWidth), (!maxHeight || itemHeight >= maxHeight) && (maxHeight = itemHeight);
+
+
+ var maxLength = isLegendRightOrInset ? maxHeight : maxWidth;
+
+ config.legend_equally ? (Object.keys(widths).forEach(function (id2) {
+ return widths[id2] = maxWidth;
+ }), Object.keys(heights).forEach(function (id2) {
+ return heights[id2] = maxHeight;
+ }), margin = (areaLength - maxLength * targetIdz.length) / 2, margin < 10 ? (totalLength = 0, step = 0, targetIdz.forEach(function (id2) {
+ return updateValues(id2);
+ })) : updateValues(id, !0)) : updateValues(id);
+ };
+
+ // Skip elements when their name is set to null
+
+
+ $$.isLegendInset && (step = config.legend_inset_step ? config.legend_inset_step : targetIdz.length, $$.updateLegendStep(step)), $$.isLegendRight ? (xForLegend = function (id) {
+ return maxWidth * steps[id];
+ }, yForLegend = function (id) {
+ return margins[steps[id]] + offsets[id];
+ }) : $$.isLegendInset ? (xForLegend = function (id) {
+ return maxWidth * steps[id] + 10;
+ }, yForLegend = function (id) {
+ return margins[steps[id]] + offsets[id];
+ }) : (xForLegend = function (id) {
+ return margins[steps[id]] + offsets[id];
+ }, yForLegend = function (id) {
+ return maxHeight * steps[id];
+ });
+
+ var xForLegendText = function (id, i) {
+ return xForLegend(id, i) + 4 + config.legend_item_tile_width;
+ },
+ xForLegendRect = function (id, i) {
+ return xForLegend(id, i);
+ },
+ x1ForLegendTile = function (id, i) {
+ return xForLegend(id, i) - 2;
+ },
+ x2ForLegendTile = function (id, i) {
+ return xForLegend(id, i) - 2 + config.legend_item_tile_width;
+ },
+ yForLegendText = function (id, i) {
+ return yForLegend(id, i) + 9;
+ },
+ yForLegendRect = function (id, i) {
+ return yForLegend(id, i) - 5;
+ },
+ yForLegendTile = function (id, i) {
+ return yForLegend(id, i) + 4;
+ },
+ l = $$.legend.selectAll("." + _classes2.default.legendItem).data(targetIdz).enter().append("g");
+
+ // Define g for legend area
+
+
+ $$.setLegendItem(l), l.append("text").text(function (id) {
+ return (0, _util.isDefined)(config.data_names[id]) ? config.data_names[id] : id;
+ }).each(function (id, i) {
+ updatePositions(this, id, i);
+ }).style("pointer-events", "none").attr("x", isLegendRightOrInset ? xForLegendText : -200).attr("y", isLegendRightOrInset ? -200 : yForLegendText), l.append("rect").attr("class", _classes2.default.legendItemEvent).style("fill-opacity", "0").attr("x", isLegendRightOrInset ? xForLegendRect : -200).attr("y", isLegendRightOrInset ? -200 : yForLegendRect);
+
+
+ var usePoint = $$.config.legend_usePoint;
+
+ if (usePoint) {
+ var ids = [];
+
+ l.append(function (d) {
+ var pattern = (0, _util.notEmpty)(config.point_pattern) ? config.point_pattern : [config.point_type];
+
+ ids.indexOf(d) === -1 && ids.push(d);
+
+
+ var point = pattern[ids.indexOf(d) % pattern.length];
+
+ return point === "rectangle" && (point = "rect"), document.createElementNS(_d3Selection.namespaces.svg, $$.hasValidPointType(point) ? point : "use");
+ }).attr("class", _classes2.default.legendItemPoint).style("fill", function (d) {
+ return $$.color(d);
+ }).style("pointer-events", "none").attr("href", function (data, idx, selection) {
+ var node = selection[idx],
+ nodeName = node.nodeName.toLowerCase();
+
+
+ return nodeName === "use" ? "#" + $$.datetimeId + "-point-" + data : undefined;
+ });
+ } else l.append("line").attr("class", _classes2.default.legendItemTile).style("stroke", $$.color).style("pointer-events", "none").attr("x1", isLegendRightOrInset ? x1ForLegendTile : -200).attr("y1", isLegendRightOrInset ? -200 : yForLegendTile).attr("x2", isLegendRightOrInset ? x2ForLegendTile : -200).attr("y2", isLegendRightOrInset ? -200 : yForLegendTile).attr("stroke-width", config.legend_item_tile_height);
+
+ // Set background for inset legend
+ background = $$.legend.select("." + _classes2.default.legendBackground + " rect"), $$.isLegendInset && maxWidth > 0 && background.size() === 0 && (background = $$.legend.insert("g", "." + _classes2.default.legendItem).attr("class", _classes2.default.legendBackground).append("rect"));
+
+
+ var texts = $$.legend.selectAll("text").data(targetIdz).text(function (id) {
+ return (0, _util.isDefined)(config.data_names[id]) ? config.data_names[id] : id;
+ }) // MEMO: needed for update
+ .each(function (id, i) {
+ updatePositions(this, id, i);
+ });
+
+ (withTransition ? texts.transition() : texts).attr("x", xForLegendText).attr("y", yForLegendText);
+
+
+ var rects = $$.legend.selectAll("rect." + _classes2.default.legendItemEvent).data(targetIdz);
+
+ if ((withTransition ? rects.transition() : rects).attr("width", function (id) {
+ return widths[id];
+ }).attr("height", function (id) {
+ return heights[id];
+ }).attr("x", xForLegendRect).attr("y", yForLegendRect), usePoint) {
+ var tiles = $$.legend.selectAll("." + _classes2.default.legendItemPoint).data(targetIdz);
+
+ (withTransition ? tiles.transition() : tiles).each(function () {
+ var nodeName = this.nodeName.toLowerCase(),
+ pointR = $$.config.point_r,
+ x = "x",
+ y = "y",
+ xOffset = 2,
+ yOffset = 2.5,
+ radius = void 0,
+ width = void 0,
+ height = void 0;
+
+
+ if (nodeName === "circle") {
+ var size = pointR * .2;
+
+ x = "cx", y = "cy", radius = pointR + size, xOffset = pointR * 2, yOffset = -size;
+ } else if (nodeName === "rect") {
+ var _size = pointR * 2.5;
+
+ width = _size, height = _size, yOffset = 3;
+ }
+
+ (0, _d3Selection.select)(this).attr(x, function (d) {
+ return x1ForLegendTile(d) + xOffset;
+ }).attr(y, function (d) {
+ return yForLegendTile(d) - yOffset;
+ }).attr("r", radius).attr("width", width).attr("height", height);
+ });
+ } else {
+ var _tiles = $$.legend.selectAll("line." + _classes2.default.legendItemTile).data(targetIdz);
+
+ (withTransition ? _tiles.transition() : _tiles).style("stroke", $$.color).attr("x1", x1ForLegendTile).attr("y1", yForLegendTile).attr("x2", x2ForLegendTile).attr("y2", yForLegendTile);
+ }
+
+ background && (withTransition ? background.transition() : background).attr("height", $$.getLegendHeight() - 12).attr("width", maxWidth * (step + 1) + 10), $$.legend.selectAll("." + _classes2.default.legendItem).classed(_classes2.default.legendItemHidden, function (id) {
+ return !$$.isTargetToShow(id);
+ }), $$.updateLegendItemWidth(maxWidth), $$.updateLegendItemHeight(maxHeight), $$.updateLegendStep(step), $$.updateSizes(), $$.updateScales(!withTransition), $$.updateSvgSize(), $$.transformAll(withTransitionForTransform, transitions), $$.legendHasRendered = !0;
+ }
+});
+
+/***/ }),
+/* 44 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ /**
+ * Initializes the title
+ * @private
+ */
+ initTitle: function initTitle() {
+ var $$ = this;
+
+ $$.title = $$.svg.append("text").text($$.config.title_text).attr("class", $$.CLASS.title);
+ },
+
+
+ /**
+ * Redraw title
+ * @private
+ */
+ redrawTitle: function redrawTitle() {
+ var $$ = this;
+
+ $$.title.attr("x", $$.xForTitle.bind($$)).attr("y", $$.yForTitle.bind($$));
+ },
+
+
+ /**
+ * Returns the x attribute value of the title
+ * @private
+ * @returns {Number} x attribute value
+ */
+ xForTitle: function xForTitle() {
+ var $$ = this,
+ config = $$.config,
+ position = config.title_position || "left",
+ x = void 0;
+
+
+ return x = position.indexOf("right") >= 0 ? $$.currentWidth - $$.getTextRect($$.title, $$.CLASS.title, $$.title).width - config.title_padding.right : position.indexOf("center") >= 0 ? ($$.currentWidth - $$.getTextRect($$.title, $$.CLASS.title, $$.title).width) / 2 : config.title_padding.left, x;
+ },
+
+
+ /**
+ * Returns the y attribute value of the title
+ * @private
+ * @returns {Number} y attribute value
+ */
+ yForTitle: function yForTitle() {
+ var $$ = this;
+
+ return $$.config.title_padding.top + $$.getTextRect($$.title, $$.CLASS.title, $$.title).height;
+ },
+
+
+ /**
+ * Get title padding
+ * @private
+ * @returns {Number} padding value
+ */
+ getTitlePadding: function getTitlePadding() {
+ var $$ = this;
+
+ return $$.yForTitle() + $$.config.title_padding.bottom;
+ }
+});
+
+/***/ }),
+/* 45 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ getClipPath: function getClipPath(id) {
+ var $$ = this,
+ config = $$.config;
+
+
+ if (!config.clipPath && /-clip$/.test(id) || !config.axis_x_clipPath && /-clip-xaxis$/.test(id) || !config.axis_y_clipPath && /-clip-yaxis$/.test(id)) return null;
+
+ var isIE9 = window.navigator.appVersion.toLowerCase().indexOf("msie 9.") >= 0;
+
+ return "url(" + (isIE9 ? "" : document.URL.split("#")[0]) + "#" + id + ")";
+ },
+ appendClip: function appendClip(parent, id) {
+ return parent.append("clipPath").attr("id", id).append("rect");
+ },
+ getAxisClipX: function getAxisClipX(forHorizontal) {
+ // axis line width + padding for left
+ var left = Math.max(30, this.margin.left);
+
+ return forHorizontal ? -(1 + left) : -(left - 1);
+ },
+ getAxisClipY: function getAxisClipY(forHorizontal) {
+ return forHorizontal ? -20 : -this.margin.top;
+ },
+ getXAxisClipX: function getXAxisClipX() {
+ var $$ = this;
+
+ return $$.getAxisClipX(!$$.config.axis_rotated);
+ },
+ getXAxisClipY: function getXAxisClipY() {
+ var $$ = this;
+
+ return $$.getAxisClipY(!$$.config.axis_rotated);
+ },
+ getYAxisClipX: function getYAxisClipX() {
+ var $$ = this;
+
+ return $$.config.axis_y_inner ? -1 : $$.getAxisClipX($$.config.axis_rotated);
+ },
+ getYAxisClipY: function getYAxisClipY() {
+ var $$ = this;
+
+ return $$.getAxisClipY($$.config.axis_rotated);
+ },
+ getAxisClipWidth: function getAxisClipWidth(forHorizontal) {
+ var $$ = this,
+ left = Math.max(30, $$.margin.left),
+ right = Math.max(30, $$.margin.right);
+
+
+ // width + axis line width + padding for left/right
+ return forHorizontal ? $$.width + 2 + left + right : $$.margin.left + 20;
+ },
+ getAxisClipHeight: function getAxisClipHeight(forHorizontal) {
+ // less than 20 is not enough to show the axis label 'outer' without legend
+ return (forHorizontal ? this.margin.bottom : this.margin.top + this.height) + 20;
+ },
+ getXAxisClipWidth: function getXAxisClipWidth() {
+ var $$ = this;
+
+ return $$.getAxisClipWidth(!$$.config.axis_rotated);
+ },
+ getXAxisClipHeight: function getXAxisClipHeight() {
+ var $$ = this;
+
+ return $$.getAxisClipHeight(!$$.config.axis_rotated);
+ },
+ getYAxisClipWidth: function getYAxisClipWidth() {
+ var $$ = this;
+
+ return $$.getAxisClipWidth($$.config.axis_rotated) + ($$.config.axis_y_inner ? 20 : 0);
+ },
+ getYAxisClipHeight: function getYAxisClipHeight() {
+ var $$ = this;
+
+ return $$.getAxisClipHeight($$.config.axis_rotated);
+ }
+});
+
+/***/ }),
+/* 46 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Selection = __webpack_require__(5),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ initRegion: function initRegion() {
+ var $$ = this;
+
+ $$.region = $$.main.append("g").attr("clip-path", $$.clipPath).attr("class", _classes2.default.regions);
+ },
+ updateRegion: function updateRegion(duration) {
+ var $$ = this,
+ config = $$.config;
+
+
+ // hide if arc type
+ $$.region.style("visibility", $$.hasArcType() ? "hidden" : "visible"), $$.mainRegion = $$.main.select("." + _classes2.default.regions).selectAll("." + _classes2.default.region).data(config.regions), $$.mainRegion.exit().transition().duration(duration).style("opacity", "0").remove(), $$.mainRegion = $$.mainRegion.enter().append("g").merge($$.mainRegion).attr("class", $$.classRegion.bind($$)), $$.mainRegion.append("rect").style("fill-opacity", "0");
+ },
+ redrawRegion: function redrawRegion(withTransition) {
+ var $$ = this,
+ regions = $$.mainRegion.select("rect");
+
+
+ return regions = (withTransition ? regions.transition() : regions).attr("x", $$.regionX.bind($$)).attr("y", $$.regionY.bind($$)).attr("width", $$.regionWidth.bind($$)).attr("height", $$.regionHeight.bind($$)), [(withTransition ? regions.transition() : regions).style("fill-opacity", function (d) {
+ return (0, _util.isValue)(d.opacity) ? d.opacity : "0.1";
+ }).on("end", function () {
+ (0, _d3Selection.select)(this.parentNode).selectAll("rect:not([x])").remove();
+ })];
+ },
+ getRegionXY: function getRegionXY(type, d) {
+ var $$ = this,
+ config = $$.config,
+ isRotated = config.axis_rotated,
+ isX = type === "x",
+ key = "start",
+ scale = void 0,
+ pos = 0;
+
+
+ return d.axis === "y" || d.axis === "y2" ? (!isX && (key = "end"), (isX ? isRotated : !isRotated) && key in d && (scale = $$[d.axis], pos = scale(d[key]))) : (isX ? !isRotated : isRotated) && key in d && (scale = $$.zoomScale || $$.x, pos = scale($$.isTimeSeries() ? $$.parseDate(d[key]) : d[key])), pos;
+ },
+ regionX: function regionX(d) {
+ return this.getRegionXY("x", d);
+ },
+ regionY: function regionY(d) {
+ return this.getRegionXY("y", d);
+ },
+ getRegionSize: function getRegionSize(type, d) {
+ var $$ = this,
+ config = $$.config,
+ isRotated = config.axis_rotated,
+ isWidth = type === "width",
+ start = $$[isWidth ? "regionX" : "regionY"](d),
+ scale = void 0,
+ key = "end",
+ end = $$[type];
+
+
+ return d.axis === "y" || d.axis === "y2" ? (!isWidth && (key = "start"), (isWidth ? isRotated : !isRotated) && key in d && (scale = $$[d.axis], end = scale(d[key]))) : (isWidth ? !isRotated : isRotated) && key in d && (scale = $$.zoomScale || $$.x, end = scale($$.isTimeSeries() ? $$.parseDate(d[key]) : d[key])), end < start ? 0 : end - start;
+ },
+ regionWidth: function regionWidth(d) {
+ return this.getRegionSize("width", d);
+ },
+ regionHeight: function regionHeight(d) {
+ return this.getRegionSize("height", d);
+ },
+ isRegionOnX: function isRegionOnX(d) {
+ return !d.axis || d.axis === "x";
+ }
+}); // selection
+
+/***/ }),
+/* 47 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Selection = __webpack_require__(5),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ /**
+ * Called when dragging.
+ * Data points can be selected.
+ * @private
+ * @param {Object} mouse Object
+ */
+ drag: function drag(mouse) {
+ var $$ = this,
+ config = $$.config,
+ main = $$.main;
+
+
+ if (!$$.hasArcType() && config.data_selection_enabled && ( // do nothing if not selectable
+ !config.zoom_enabled || $$.zoom.altDomain) && config.data_selection_multiple // skip when single selection because drag is used for multiple selection
+ ) {
+ var _$$$dragStart = $$.dragStart,
+ sx = _$$$dragStart[0],
+ sy = _$$$dragStart[1],
+ mx = mouse[0],
+ my = mouse[1],
+ minX = Math.min(sx, mx),
+ maxX = Math.max(sx, mx),
+ minY = config.data_selection_grouped ? $$.margin.top : Math.min(sy, my),
+ maxY = config.data_selection_grouped ? $$.height : Math.max(sy, my);
+ main.select("." + _classes2.default.dragarea).attr("x", minX).attr("y", minY).attr("width", maxX - minX).attr("height", maxY - minY), main.selectAll("." + _classes2.default.shapes).selectAll("." + _classes2.default.shape).filter(function (d) {
+ return config.data_selection_isselectable(d);
+ }).each(function (d, i) {
+ var shape = (0, _d3Selection.select)(this),
+ isSelected = shape.classed(_classes2.default.SELECTED),
+ isIncluded = shape.classed(_classes2.default.INCLUDED),
+ _x = void 0,
+ _y = void 0,
+ _w = void 0,
+ _h = void 0,
+ toggle = void 0,
+ isWithin = !1,
+ box = void 0;
+
+ if (shape.classed(_classes2.default.circle)) _x = shape.attr("cx") * 1, _y = shape.attr("cy") * 1, toggle = $$.togglePoint, isWithin = minX < _x && _x < maxX && minY < _y && _y < maxY;else if (shape.classed(_classes2.default.bar)) box = (0, _util.getPathBox)(this), _x = box.x, _y = box.y, _w = box.width, _h = box.height, toggle = $$.togglePath, isWithin = !(maxX < _x || _x + _w < minX) && !(maxY < _y || _y + _h < minY);else
+ // line/area selection not supported yet
+ return;
+
+ isWithin ^ isIncluded && (shape.classed(_classes2.default.INCLUDED, !isIncluded), shape.classed(_classes2.default.SELECTED, !isSelected), toggle.call($$, !isSelected, shape, d, i));
+ });
+ }
+ },
+
+
+ /**
+ * Called when the drag starts.
+ * Adds and Shows the drag area.
+ * @private
+ * @param {Object} mouse Object
+ */
+ dragstart: function dragstart(mouse) {
+ var $$ = this,
+ config = $$.config;
+ $$.hasArcType() || !config.data_selection_enabled || ($$.dragStart = mouse, $$.main.select("." + _classes2.default.chart).append("rect").attr("class", _classes2.default.dragarea).style("opacity", "0.1"), $$.setDragStatus(!0));
+ },
+
+
+ /**
+ * Called when the drag finishes.
+ * Removes the drag area.
+ * @private
+ */
+ dragend: function dragend() {
+ var $$ = this,
+ config = $$.config;
+ $$.hasArcType() || !config.data_selection_enabled || ($$.main.select("." + _classes2.default.dragarea).transition().duration(100).style("opacity", "0").remove(), $$.main.selectAll("." + _classes2.default.shape).classed(_classes2.default.INCLUDED, !1), $$.setDragStatus(!1));
+ },
+ setDragStatus: function setDragStatus(isDragging) {
+ this.dragging = isDragging;
+ }
+});
+
+/***/ }),
+/* 48 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Selection = __webpack_require__(5),
+ _d3Color = __webpack_require__(49),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ /**
+ * Select a point
+ * @private
+ * @param {Object} target point
+ * @param {Object} data
+ * @param {Number} index
+ */
+ selectPoint: function selectPoint(target, d, i) {
+ var $$ = this,
+ config = $$.config,
+ isRotated = config.axis_rotated,
+ cx = (isRotated ? $$.circleY : $$.circleX).bind($$),
+ cy = (isRotated ? $$.circleX : $$.circleY).bind($$),
+ r = $$.pointSelectR.bind($$);
+ (0, _util.callFn)(config.data_onselected, $$.api, d, target.node()), $$.main.select("." + _classes2.default.selectedCircles + $$.getTargetSelectorSuffix(d.id)).selectAll("." + _classes2.default.selectedCircle + "-" + i).data([d]).enter().append("circle").attr("class", function () {
+ return $$.generateClass(_classes2.default.selectedCircle, i);
+ }).attr("cx", cx).attr("cy", cy).attr("stroke", function () {
+ return $$.color(d);
+ }).attr("r", function (d2) {
+ return $$.pointSelectR(d2) * 1.4;
+ }).transition().duration(100).attr("r", r);
+ },
+
+
+ /**
+ * Unelect a point
+ * @private
+ * @param {Object} target point
+ * @param {Object} data
+ * @param {Number} index
+ */
+ unselectPoint: function unselectPoint(target, d, i) {
+ var $$ = this;
+
+ (0, _util.callFn)($$.config.data_onunselected, $$.api, d, target.node()), $$.main.select("." + _classes2.default.selectedCircles + $$.getTargetSelectorSuffix(d.id)).selectAll("." + _classes2.default.selectedCircle + "-" + i).transition().duration(100).attr("r", 0).remove();
+ },
+
+
+ /**
+ * Toggles the selection of points
+ * @private
+ * @param {Boolean} whether or not to select.
+ * @param {Object} target point
+ * @param {Object} data
+ * @param {Number} index
+ */
+ togglePoint: function togglePoint(selected, target, d, i) {
+ var method = (selected ? "" : "un") + "selectPoint";
+
+ this[method](target, d, i);
+ },
+
+
+ /**
+ * Select a path
+ * @private
+ * @param {Object} target path
+ * @param {Object} data
+ */
+ selectPath: function selectPath(target, d) {
+ var $$ = this,
+ config = $$.config;
+ (0, _util.callFn)(config.data_onselected, $$, d, target.node()), config.interaction_brighten && target.transition().duration(100).style("fill", function () {
+ return (0, _d3Color.rgb)($$.color(d)).brighter(.75);
+ });
+ },
+
+
+ /**
+ * Unelect a path
+ * @private
+ * @param {Object} target path
+ * @param {Object} data
+ */
+ unselectPath: function unselectPath(target, d) {
+ var $$ = this,
+ config = $$.config;
+ (0, _util.callFn)(config.data_onunselected, $$, d, target.node()), config.interaction_brighten && target.transition().duration(100).style("fill", function () {
+ return $$.color(d);
+ });
+ },
+
+
+ /**
+ * Toggles the selection of lines
+ * @private
+ * @param {Boolean} whether or not to select.
+ * @param {Object} target shape
+ * @param {Object} data
+ * @param {Number} index
+ */
+ togglePath: function togglePath(selected, target, d, i) {
+ this[(selected ? "" : "un") + "selectPath"](target, d, i);
+ },
+
+
+ /**
+ * Returns the toggle method of the target
+ * @private
+ * @param {Object} target shape
+ * @param {Object} data
+ * @returns {Function} toggle method
+ */
+ getToggle: function getToggle(that, d) {
+ var $$ = this;
+
+ return that.nodeName === "path" ? $$.togglePath : $$.isStepType(d) ? function () {} : // circle is hidden in step chart, so treat as within the click area
+ $$.togglePoint;
+ },
+
+
+ /**
+ * Toggles the selection of shapes
+ * @private
+ * @param {Object} target shape
+ * @param {Object} data
+ * @param {Number} index
+ */
+ toggleShape: function toggleShape(that, d, i) {
+ var $$ = this,
+ config = $$.config,
+ shape = (0, _d3Selection.select)(that),
+ isSelected = shape.classed(_classes2.default.SELECTED),
+ toggle = $$.getToggle(that, d).bind($$),
+ toggledShape = void 0;
+
+
+ if (config.data_selection_enabled && config.data_selection_isselectable(d)) {
+ if (!config.data_selection_multiple) {
+ var selector = "." + _classes2.default.shapes;
+
+ config.data_selection_grouped && (selector += $$.getTargetSelectorSuffix(d.id)), $$.main.selectAll(selector).selectAll("." + _classes2.default.shape).each(function (d, i) {
+ var shape = (0, _d3Selection.select)(this);
+
+ shape.classed(_classes2.default.SELECTED) && (toggledShape = shape, toggle(!1, shape.classed(_classes2.default.SELECTED, !1), d, i));
+ });
+ }
+
+ toggledShape && toggledShape.node() === shape.node() || (shape.classed(_classes2.default.SELECTED, !isSelected), toggle(!isSelected, shape, d, i));
+ }
+ }
+}); /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+/***/ }),
+/* 49 */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE__49__;
+
+/***/ }),
+/* 50 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Selection = __webpack_require__(5),
+ _d3Brush = __webpack_require__(13),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ /**
+ * Initialize the brush.
+ * @private
+ */
+ initBrush: function initBrush() {
+ var $$ = this;
+
+ // set the brush
+ $$.brush = $$.config.axis_rotated ? (0, _d3Brush.brushY)() : (0, _d3Brush.brushX)();
+
+
+ // set "brush" event
+ var brushHandler = function () {
+ $$.redrawForBrush();
+ };
+
+ $$.brush.on("start", function () {
+ $$.inputType === "touch" && $$.hideTooltip(), brushHandler();
+ }).on("brush", brushHandler), $$.brush.update = function () {
+ var extent = this.extent()();
+
+ return extent[1].filter(function (v) {
+ return isNaN(v);
+ }).length === 0 && $$.context && $$.context.select("." + _classes2.default.brush).call(this), this;
+ }, $$.brush.scale = function (scale, height) {
+ var overlay = $$.svg.select(".bb-brush .overlay"),
+ extent = [[0, 0]];
+ scale.range ? extent.push([scale.range()[1], (height || !overlay.empty()) && ~~overlay.attr("height") || 60]) : scale.constructor === Array && extent.push(scale), $$.config.axis_rotated && extent.reverse(), this.extent($$.config.axis_x_extent || extent), this.update();
+ }, $$.brush.getSelection = function () {
+ return $$.context ? $$.context.select("." + _classes2.default.brush) : (0, _d3Selection.select)([]);
+ };
+ },
+
+
+ /**
+ * Initialize the subchart.
+ * @private
+ */
+ initSubchart: function initSubchart() {
+ var $$ = this,
+ config = $$.config,
+ visibility = config.subchart_show ? "visible" : "hidden";
+ $$.context = $$.svg.append("g").attr("transform", $$.getTranslate("context"));
+
+
+ var context = $$.context;
+
+ context.style("visibility", visibility), context.append("g").attr("clip-path", $$.clipPathForSubchart).attr("class", _classes2.default.chart), context.select("." + _classes2.default.chart).append("g").attr("class", _classes2.default.chartBars), context.select("." + _classes2.default.chart).append("g").attr("class", _classes2.default.chartLines), context.append("g").attr("clip-path", $$.clipPath).attr("class", _classes2.default.brush).call($$.brush), $$.axes.subx = context.append("g").attr("class", _classes2.default.axisX).attr("transform", $$.getTranslate("subx")).attr("clip-path", config.axis_rotated ? "" : $$.clipPathForXAxis).style("visibility", config.subchart_axis_x_show ? visibility : "hidden");
+ },
+
+
+ /**
+ * Update sub chart
+ * @private
+ * @param {Object} $$.data.targets
+ */
+ updateTargetsForSubchart: function updateTargetsForSubchart(targets) {
+ var $$ = this,
+ context = $$.context,
+ config = $$.config,
+ classChartBar = $$.classChartBar.bind($$),
+ classBars = $$.classBars.bind($$),
+ classChartLine = $$.classChartLine.bind($$),
+ classLines = $$.classLines.bind($$),
+ classAreas = $$.classAreas.bind($$);
+
+
+ if (config.subchart_show) {
+ // -- Bar --//
+ var contextBarUpdate = context.select("." + _classes2.default.chartBars).selectAll("." + _classes2.default.chartBar).data(targets).attr("class", classChartBar),
+ contextBarEnter = contextBarUpdate.enter().append("g").style("opacity", "0").attr("class", classChartBar).merge(contextBarUpdate);
+
+
+ // Bars for each data
+ contextBarEnter.append("g").attr("class", classBars);
+
+
+ // -- Line --//
+ var contextLineUpdate = context.select("." + _classes2.default.chartLines).selectAll("." + _classes2.default.chartLine).data(targets).attr("class", classChartLine),
+ contextLineEnter = contextLineUpdate.enter().append("g").style("opacity", "0").attr("class", classChartLine).merge(contextLineUpdate);
+
+
+ // Lines for each data
+ contextLineEnter.append("g").attr("class", classLines), contextLineEnter.append("g").attr("class", classAreas), context.selectAll("." + _classes2.default.brush + " rect").attr(config.axis_rotated ? "width" : "height", config.axis_rotated ? $$.width2 : $$.height2);
+ }
+ },
+
+
+ /**
+ * Update the bar of the sub chart
+ * @private
+ * @param {Object} durationForExit
+ */
+ updateBarForSubchart: function updateBarForSubchart(durationForExit) {
+ var $$ = this;
+
+ $$.contextBar = $$.context.selectAll("." + _classes2.default.bars).selectAll("." + _classes2.default.bar).data($$.barData.bind($$)), $$.contextBar.exit().transition().duration(durationForExit).style("opacity", "0").remove(), $$.contextBar = $$.contextBar.enter().append("path").attr("class", $$.classBar.bind($$)).style("stroke", "none").style("fill", $$.color).merge($$.contextBar).style("opacity", $$.initialOpacity.bind($$));
+ },
+
+
+ /**
+ * Redraw the bar of the subchart
+ * @private
+ * @param {String} path in subchart bar
+ * @param {Boolean} whether or not to transition.
+ * @param {Number} transition duration
+ */
+ redrawBarForSubchart: function redrawBarForSubchart(drawBarOnSub, withTransition, duration) {
+ var contextBar = void 0;
+
+ contextBar = withTransition ? this.contextBar.transition(Math.random().toString()).duration(duration) : this.contextBar, contextBar.attr("d", drawBarOnSub).style("opacity", "1");
+ },
+
+
+ /**
+ * Update the line of the sub chart
+ * @private
+ * @param {Number} Fade-out transition duration
+ */
+ updateLineForSubchart: function updateLineForSubchart(durationForExit) {
+ var $$ = this;
+
+ $$.contextLine = $$.context.selectAll("." + _classes2.default.lines).selectAll("." + _classes2.default.line).data($$.lineData.bind($$)), $$.contextLine.exit().transition().duration(durationForExit).style("opacity", "0").remove(), $$.contextLine = $$.contextLine.enter().append("path").attr("class", $$.classLine.bind($$)).style("stroke", $$.color).merge($$.contextLine).style("opacity", $$.initialOpacity.bind($$));
+ },
+
+
+ /**
+ * Redraw the line of the subchart
+ * @private
+ * @param {String} path in subchart line
+ * @param {Boolean} whether or not to transition
+ * @param {Number} transition duration
+ */
+ redrawLineForSubchart: function redrawLineForSubchart(drawLineOnSub, withTransition, duration) {
+ var contextLine = void 0;
+
+ contextLine = withTransition ? this.contextLine.transition(Math.random().toString()).duration(duration) : this.contextLine, contextLine.attr("d", drawLineOnSub).style("opacity", "1");
+ },
+
+
+ /**
+ * Update the area of the sub chart
+ * @private
+ * @param {Number} Fade-out transition duration
+ */
+ updateAreaForSubchart: function updateAreaForSubchart(durationForExit) {
+ var $$ = this;
+
+ $$.contextArea = $$.context.selectAll("." + _classes2.default.areas).selectAll("." + _classes2.default.area).data($$.lineData.bind($$)), $$.contextArea.exit().transition().duration(durationForExit).style("opacity", "0").remove(), $$.contextArea = $$.contextArea.enter().append("path").attr("class", $$.classArea.bind($$)).style("fill", $$.color).style("opacity", function () {
+ return $$.orgAreaOpacity = (0, _d3Selection.select)(this).style("opacity"), "0";
+ }).merge($$.contextArea).style("opacity", "0");
+ },
+
+ /**
+ * Redraw the area of the subchart
+ * @private
+ * @param {String} path in subchart line
+ * @param {Boolean} whether or not to transition
+ * @param {Number} transition duration
+ */
+ redrawAreaForSubchart: function redrawAreaForSubchart(drawAreaOnSub, withTransition, duration) {
+ var contextArea = void 0;
+
+ contextArea = withTransition ? this.contextArea.transition(Math.random().toString()).duration(duration) : this.contextArea, contextArea.attr("d", drawAreaOnSub).style("fill", this.color).style("opacity", this.orgAreaOpacity);
+ },
+
+
+ /**
+ * Redraw subchart.
+ * @private
+ * @param {Boolean} whether or not to show subchart
+ * @param Do not use.
+ * @param {Number} transition duration
+ * @param Do not use.
+ * @param {Object} area Indices
+ * @param {Object} bar Indices
+ * @param {Object} line Indices
+ */
+ redrawSubchart: function redrawSubchart(withSubchart, transitions, duration, durationForExit, areaIndices, barIndices, lineIndices) {
+ var $$ = this,
+ config = $$.config;
+
+
+ // subchart
+ if ($$.context.style("visibility", config.subchart_show ? "visible" : "hidden"), config.subchart_show && (_d3Selection.event && _d3Selection.event.type === "zoom" && $$.brush.update(), withSubchart))
+
+ // update subchart elements if needed
+ {
+ (0, _util.brushEmpty)($$) || $$.brush.update();
+
+
+ // setup drawer - MEMO: this must be called after axis updated
+ var drawAreaOnSub = $$.generateDrawArea(areaIndices, !0),
+ drawBarOnSub = $$.generateDrawBar(barIndices, !0),
+ drawLineOnSub = $$.generateDrawLine(lineIndices, !0);
+ $$.updateBarForSubchart(duration), $$.updateLineForSubchart(duration), $$.updateAreaForSubchart(duration), $$.redrawBarForSubchart(drawBarOnSub, duration, duration), $$.redrawLineForSubchart(drawLineOnSub, duration, duration), $$.redrawAreaForSubchart(drawAreaOnSub, duration, duration);
+ }
+ },
+
+ /**
+ * Redraw the brush.
+ * @private
+ */
+ redrawForBrush: function redrawForBrush() {
+ var $$ = this,
+ x = $$.x;
+ $$.redraw({
+ withTransition: !1,
+ withY: $$.config.zoom_rescale,
+ withSubchart: !1,
+ withUpdateXDomain: !0,
+ withDimension: !1
+ }), $$.config.subchart_onbrush.call($$.api, x.orgDomain());
+ },
+
+
+ /**
+ * Transform context
+ * @private
+ * @param {Boolean} indicates transition is enabled
+ * @param {Object} The return value of the generateTransitions method of Axis.
+ */
+ transformContext: function transformContext(withTransition, transitions) {
+ var $$ = this,
+ subXAxis = void 0;
+ transitions && transitions.axisSubX ? subXAxis = transitions.axisSubX : (subXAxis = $$.context.select("." + _classes2.default.axisX), withTransition && (subXAxis = subXAxis.transition())), $$.context.attr("transform", $$.getTranslate("context")), subXAxis.attr("transform", $$.getTranslate("subx"));
+ },
+
+
+ /**
+ * Get default extent
+ * @private
+ * @returns {Array} default extent
+ */
+ getDefaultExtent: function getDefaultExtent() {
+ var $$ = this,
+ config = $$.config,
+ extent = (0, _util.isFunction)(config.axis_x_extent) ? config.axis_x_extent($$.getXDomain($$.data.targets)) : config.axis_x_extent;
+
+
+ return $$.isTimeSeries() && (extent = [$$.parseDate(extent[0]), $$.parseDate(extent[1])]), extent;
+ }
+}); /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+/***/ }),
+/* 51 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Array = __webpack_require__(6),
+ _d3Selection = __webpack_require__(5),
+ _d3Drag = __webpack_require__(28),
+ _d3Zoom = __webpack_require__(52),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ /**
+ * Initialize zoom.
+ * @private
+ */
+ initZoom: function initZoom() {
+ var $$ = this;
+
+ $$.zoomScale = null, $$.generateZoom();
+ },
+
+
+ /**
+ * Bind zoom event
+ * @param {Boolean} bind Weather bind or unbound
+ * @private
+ */
+ bindZoomEvent: function bindZoomEvent() {
+ var bind = !(arguments.length > 0 && arguments[0] !== undefined) || arguments[0],
+ $$ = this,
+ zoomEnabled = $$.config.zoom_enabled;
+ $$.redrawEventRect(), zoomEnabled && bind ? zoomEnabled === !0 || zoomEnabled.type === "wheel" ? $$.bindZoomOnEventRect() : zoomEnabled.type === "drag" && $$.bindZoomOnDrag() : bind === !1 && ($$.api.unzoom(), $$.main.select("." + _classes2.default.eventRects).on(".zoom", null).on(".drag", null));
+ },
+
+
+ /**
+ * Generate zoom
+ * @private
+ */
+ generateZoom: function generateZoom() {
+ var $$ = this,
+ config = $$.config,
+ zoom = (0, _d3Zoom.zoom)().duration(0).on("start", $$.onZoomStart.bind($$)).on("zoom", $$.onZoom.bind($$)).on("end", $$.onZoomEnd.bind($$));
+
+
+ // get zoom extent
+ zoom.orgScaleExtent = function () {
+ var extent = config.zoom_extent || [1, 10];
+
+ return [extent[0], Math.max($$.getMaxDataCount() / extent[1], extent[1])];
+ }, zoom.updateScaleExtent = function () {
+ var ratio = (0, _util.diffDomain)($$.x.orgDomain()) / (0, _util.diffDomain)($$.getZoomDomain()),
+ extent = this.orgScaleExtent();
+
+
+ return this.scaleExtent([extent[0] * ratio, extent[1] * ratio]), this;
+ }, zoom.updateTransformScale = function (transform) {
+ // rescale from the original scale
+ var newScale = transform.rescaleX($$.subX.orgScale()),
+ domain = $$.trimXDomain(newScale.domain()),
+ rescale = config.zoom_rescale;
+ newScale.domain(domain, $$.orgXDomain), $$.zoomScale = $$.getCustomizedScale(newScale), $$.xAxis.scale($$.zoomScale), rescale && $$.x.domain($$.zoomScale.orgDomain());
+ }, $$.zoom = zoom;
+ },
+
+
+ /**
+ * 'start' event listener
+ * @private
+ */
+ onZoomStart: function onZoomStart() {
+ var $$ = this,
+ event = _d3Selection.event.sourceEvent;
+ $$.zoom.altDomain = event.altKey ? $$.x.orgDomain() : null, $$.zoom.startEvent = event, (0, _util.callFn)($$.config.zoom_onzoomstart, $$.api, event);
+ },
+
+
+ /**
+ * 'zoom' event listener
+ * @private
+ */
+ onZoom: function onZoom() {
+ var $$ = this,
+ config = $$.config,
+ event = _d3Selection.event;
+
+
+ if (config.zoom_enabled) {
+ var isMousemove = event.sourceEvent.type === "mousemove",
+ transform = event.transform;
+ return $$.zoom.updateTransformScale(transform), $$.filterTargetsToShow($$.data.targets).length === 0 ? void 0 : isMousemove && $$.zoom.altDomain ? ($$.x.domain($$.zoom.altDomain), void transform.scale($$.zoomScale).updateScaleExtent()) : void ($$.isCategorized() && $$.x.orgDomain()[0] === $$.orgXDomain[0] && $$.x.domain([$$.orgXDomain[0] - 1e-10, $$.x.orgDomain()[1]]), $$.redraw({
+ withTransition: !1,
+ withY: config.zoom_rescale,
+ withSubchart: !1,
+ withEventRect: !1,
+ withDimension: !1
+ }), $$.cancelClick = isMousemove, (0, _util.callFn)(config.zoom_onzoom, $$.api, $$.x.orgDomain()));
+ }
+ },
+
+
+ /**
+ * 'end' event listener
+ * @private
+ */
+ onZoomEnd: function onZoomEnd() {
+ var $$ = this,
+ startEvent = $$.zoom.startEvent;
+
+
+ // if click, do nothing. otherwise, click interaction will be canceled.
+ event && startEvent.clientX === event.clientX && startEvent.clientY === event.clientY || ($$.redrawEventRect(), $$.updateZoom(), (0, _util.callFn)($$.config.zoom_onzoomend, $$.api, $$.x.orgDomain()));
+ },
+
+
+ /**
+ * Get zoom domain
+ * @private
+ * @returns {Array} zoom domain
+ */
+ getZoomDomain: function getZoomDomain() {
+ var $$ = this,
+ config = $$.config,
+ min = (0, _d3Array.min)([$$.orgXDomain[0], config.zoom_x_min]),
+ max = (0, _d3Array.max)([$$.orgXDomain[1], config.zoom_x_max]);
+
+
+ return [min, max];
+ },
+
+
+ /**
+ * Update zoom
+ * @private
+ */
+ updateZoom: function updateZoom() {
+ var $$ = this;
+
+ if ($$.zoomScale) {
+ var zoomDomain = $$.zoomScale.domain(),
+ xDomain = $$.x.domain(),
+ delta = .015;
+ // arbitrary value
+
+ // check if the zoomed chart is fully shown, then reset scale when zoom is out as initial
+ (zoomDomain[0] <= xDomain[0] || zoomDomain[0] - delta <= xDomain[0]) && (xDomain[1] <= zoomDomain[1] || xDomain[1] <= zoomDomain[1] - delta) && ($$.xAxis.scale($$.x), $$.zoomScale = null);
+ }
+ },
+
+
+ /**
+ * Attach zoom event on <rect>
+ * @private
+ */
+ bindZoomOnEventRect: function bindZoomOnEventRect() {
+ var $$ = this;
+
+ $$.main.select("." + _classes2.default.eventRects).call($$.zoom).on("dblclick.zoom", null);
+ },
+
+
+ /**
+ * Initialize the drag behaviour used for zooming.
+ * @private
+ */
+ initZoomBehaviour: function initZoomBehaviour() {
+ var $$ = this,
+ config = $$.config,
+ isRotated = config.axis_rotated,
+ start = 0,
+ end = 0,
+ zoomRect = null;
+ $$.zoomBehaviour = (0, _d3Drag.drag)().on("start", function () {
+ $$.setDragStatus(!0), zoomRect || (zoomRect = $$.main.append("rect").attr("clip-path", $$.clipPath).attr("class", _classes2.default.zoomBrush).attr("width", isRotated ? $$.width : 0).attr("height", isRotated ? 0 : $$.height)), start = (0, _d3Selection.mouse)(this)[0], end = start, zoomRect.attr("x", start).attr("width", 0);
+ }).on("drag", function () {
+ end = (0, _d3Selection.mouse)(this)[0], zoomRect.attr("x", Math.min(start, end)).attr("width", Math.abs(end - start));
+ }).on("end", function () {
+ var _ref,
+ scale = $$.zoomScale || $$.x;
+
+ $$.setDragStatus(!1), zoomRect.attr("x", 0).attr("width", 0), start > end && (_ref = [end, start], start = _ref[0], end = _ref[1], _ref), start !== end && $$.api.zoom([start, end].map(function (v) {
+ return scale.invert(v);
+ }));
+ });
+ },
+
+
+ /**
+ * Enable zooming by dragging using the zoombehaviour.
+ * @private
+ */
+ bindZoomOnDrag: function bindZoomOnDrag() {
+ var $$ = this;
+
+ $$.main.select("." + _classes2.default.eventRects).call($$.zoomBehaviour);
+ },
+ setZoomResetButton: function setZoomResetButton() {
+ var $$ = this,
+ config = $$.config,
+ resetButton = config.zoom_resetButton;
+ resetButton && config.zoom_enabled.type === "drag" && ($$.zoom.resetBtn ? $$.zoom.resetBtn.style("display", null) : $$.zoom.resetBtn = $$.selectChart.append("div").classed(_classes2.default.button, !0).append("span").on("click", $$.api.unzoom.bind($$)).classed(_classes2.default.buttonZoomReset, !0).text(resetButton.text || "Reset Zoom"));
+ }
+}); /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+/***/ }),
+/* 52 */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE__52__;
+
+/***/ }),
+/* 53 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Selection = __webpack_require__(5),
+ _d3Scale = __webpack_require__(10),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Set pattern's background color
+ * (it adds a <rect> element to simulate bg-color)
+ * @param {SVGPatternElement} pattern SVG pattern element
+ * @param {String} color Color string
+ * @param {String} id ID to be set
+ * @return {{id: string, node: SVGPatternElement}}
+ * @private
+ */
+var colorizePattern = function (pattern, color, id) {
+ var node = (0, _d3Selection.select)(pattern.cloneNode(!0));
+
+ return node.attr("id", id).insert("rect", ":first-child").attr("width", node.attr("width")).attr("height", node.attr("height")).style("fill", color), {
+ id: id,
+ node: node.node()
+ };
+},
+ schemeCategory10 = ["#1f77b4", "#ff7f0e", "#2ca02c", "#d62728", "#9467bd", "#8c564b", "#e377c2", "#7f7f7f", "#bcbd22", "#17becf"];
+
+// Replacement of d3.schemeCategory10.
+// Contained differently depend on d3 version: v4(d3-scale), v5(d3-scale-chromatic)
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ /**
+ * Get color pattern from CSS file
+ * CSS should be defined as: background-image: url("#00c73c;#fa7171; ...");
+ * @return {Array}
+ * @private
+ */
+ getColorFromCss: function getColorFromCss() {
+ var body = document.body,
+ pattern = body["__colorPattern__"];
+
+
+ if (!pattern) {
+ var span = document.createElement("span");
+ span.className = _classes2.default.colorPattern, span.style.display = "none", body.appendChild(span);
+
+
+ var content = window.getComputedStyle(span).backgroundImage;
+
+ span.parentNode.removeChild(span), content.indexOf(";") > -1 && (pattern = content.replace(/url[^#]*|["'()]|(\s|%20)/g, "").split(";").map(function (v) {
+ return v.trim().replace(/[\"'\s]/g, "");
+ }).filter(Boolean), body["__colorPattern__"] = pattern);
+ }
+
+ return pattern;
+ },
+ generateColor: function generateColor() {
+ var $$ = this,
+ config = $$.config,
+ colors = config.data_colors,
+ callback = config.data_color,
+ ids = [],
+ pattern = (0, _util.notEmpty)(config.color_pattern) ? config.color_pattern : (0, _d3Scale.scaleOrdinal)($$.getColorFromCss() || schemeCategory10).range(),
+ originalColorPattern = pattern;
+
+
+ if ((0, _util.isFunction)(config.color_tiles)) {
+ var tiles = config.color_tiles(),
+ colorizedPatterns = pattern.map(function (p, index) {
+ var color = p.replace(/[#\(\)\s,]/g, ""),
+ id = $$.datetimeId + "-pattern-" + color + "-" + index;
+
+
+ return colorizePattern(tiles[index % tiles.length], p, id);
+ });
+
+ // Add background color to patterns
+
+ pattern = colorizedPatterns.map(function (p) {
+ return "url(#" + p.id + ")";
+ }), $$.patterns = colorizedPatterns;
+ }
+
+ return function (d) {
+ var id = d.id || d.data && d.data.id || d,
+ isLine = $$.isTypeOf(id, ["line", "spline", "step"]) || !$$.config.data_types[id],
+ color = void 0;
+
+ // if callback function is provided
+
+ return (0, _util.isFunction)(colors[id]) ? color = colors[id](d) : colors[id] ? color = colors[id] : (ids.indexOf(id) < 0 && ids.push(id), color = isLine ? originalColorPattern[ids.indexOf(id) % originalColorPattern.length] : pattern[ids.indexOf(id) % pattern.length], colors[id] = color), (0, _util.isFunction)(callback) ? callback(color, d) : color;
+ };
+ },
+ generateLevelColor: function generateLevelColor() {
+ var $$ = this,
+ config = $$.config,
+ colors = config.color_pattern,
+ threshold = config.color_threshold,
+ asValue = threshold.unit === "value",
+ max = threshold.max || 100,
+ values = threshold.values && threshold.values.length ? threshold.values : [];
+
+
+ return (0, _util.notEmpty)(threshold) ? function (value) {
+ var color = colors[colors.length - 1];
+
+ for (var v, i = 0; i < values.length; i++) if (v = asValue ? value : value * 100 / max, v < values[i]) {
+ color = colors[i];
+
+ break;
+ }
+
+ return color;
+ } : null;
+ }
+});
+
+/***/ }),
+/* 54 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+var getFormat = function ($$, typeValue, v) {
+ var config = $$.config,
+ type = "axis_" + typeValue + "_tick_format",
+ format = config[type] ? config[type] : $$.defaultValueFormat;
+
+
+ return format(v);
+};
+
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ getYFormat: function getYFormat(forArc) {
+ var $$ = this,
+ formatForY = $$.yFormat,
+ formatForY2 = $$.y2Format;
+
+
+ return forArc && !$$.hasType("gauge") && (formatForY = $$.defaultArcValueFormat, formatForY2 = $$.defaultArcValueFormat), function (v, ratio, id) {
+ var format = $$.axis.getId(id) === "y2" ? formatForY2 : formatForY;
+
+ return format.call($$, v, ratio);
+ };
+ },
+ yFormat: function yFormat(v) {
+ return getFormat(this, "y", v);
+ },
+ y2Format: function y2Format(v) {
+ return getFormat(this, "y2", v);
+ },
+ defaultValueFormat: function defaultValueFormat(v) {
+ return (0, _util.isValue)(v) ? +v : "";
+ },
+ defaultArcValueFormat: function defaultArcValueFormat(v, ratio) {
+ return (ratio * 100).toFixed(1) + "%";
+ },
+ dataLabelFormat: function dataLabelFormat(targetId) {
+ var $$ = this,
+ dataLabels = $$.config.data_labels,
+ defaultFormat = function (v) {
+ return (0, _util.isValue)(v) ? +v : "";
+ },
+ format = defaultFormat;
+
+ // find format according to axis id
+
+
+ return (0, _util.isFunction)(dataLabels.format) ? format = dataLabels.format : (0, _util.isObjectType)(dataLabels.format) && (dataLabels.format[targetId] ? format = dataLabels.format[targetId] === !0 ? defaultFormat : dataLabels.format[targetId] : format = function () {
+ return "";
+ }), format;
+ }
+});
+
+/***/ }),
+/* 55 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ hasCaches: function hasCaches(key) {
+ var isDataType = !!(arguments.length > 1 && arguments[1] !== undefined) && arguments[1];
+
+ if (isDataType) {
+ for (var i = 0, len = key.length; i < len; i++) if (!(key[i] in this.cache)) return !1;
+
+ return !0;
+ }
+
+ return key in this.cache;
+ },
+ addCache: function addCache(key, value) {
+ var isDataType = !!(arguments.length > 2 && arguments[2] !== undefined) && arguments[2];
+ this.cache[key] = isDataType ? this.cloneTarget(value) : value;
+ },
+ getCache: function getCache(key) {
+ var isDataType = !!(arguments.length > 1 && arguments[1] !== undefined) && arguments[1];
+
+ if (isDataType) {
+ var targets = [];
+
+ for (var id, i = 0; id = key[i]; i++) id in this.cache && targets.push(this.cloneTarget(this.cache[id]));
+
+ return targets;
+ }
+
+ return this.cache[key] || null;
+ },
+
+
+ /**
+ * reset cached data
+ * @param {Boolean} all true: reset all data, false: reset only '$' prefixed key data
+ * @private
+ */
+ resetCache: function resetCache(all) {
+ var $$ = this;
+
+ for (var x in $$.cache) (all || /^\$/.test(x)) && ($$.cache[x] = null);
+ }
+});
+
+/***/ }),
+/* 56 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ CLASS: _classes2.default,
+
+ generateClass: function generateClass(prefix, targetId) {
+ return " " + prefix + " " + (prefix + this.getTargetSelectorSuffix(targetId));
+ },
+ classText: function classText(d) {
+ return this.generateClass(_classes2.default.text, d.index);
+ },
+ classTexts: function classTexts(d) {
+ return this.generateClass(_classes2.default.texts, d.id);
+ },
+ classShape: function classShape(d) {
+ return this.generateClass(_classes2.default.shape, d.index);
+ },
+ classShapes: function classShapes(d) {
+ return this.generateClass(_classes2.default.shapes, d.id);
+ },
+ generateExtraLineClass: function generateExtraLineClass() {
+ var $$ = this,
+ classes = $$.config.line_classes || [],
+ ids = [];
+
+
+ return function (d) {
+ var id = d.id || d.data && d.data.id || d;
+
+ return ids.indexOf(id) < 0 && ids.push(id), classes[ids.indexOf(id) % classes.length];
+ };
+ },
+ classLine: function classLine(d) {
+ return this.classShape(d) + this.generateClass(_classes2.default.line, d.id);
+ },
+ classLines: function classLines(d) {
+ return this.classShapes(d) + this.generateClass(_classes2.default.lines, d.id);
+ },
+ classCircle: function classCircle(d) {
+ return this.classShape(d) + this.generateClass(_classes2.default.circle, d.index);
+ },
+ classCircles: function classCircles(d) {
+ return this.classShapes(d) + this.generateClass(_classes2.default.circles, d.id);
+ },
+ classBar: function classBar(d) {
+ return this.classShape(d) + this.generateClass(_classes2.default.bar, d.index);
+ },
+ classBars: function classBars(d) {
+ return this.classShapes(d) + this.generateClass(_classes2.default.bars, d.id);
+ },
+ classArc: function classArc(d) {
+ return this.classShape(d.data) + this.generateClass(_classes2.default.arc, d.data.id);
+ },
+ classArcs: function classArcs(d) {
+ return this.classShapes(d.data) + this.generateClass(_classes2.default.arcs, d.data.id);
+ },
+ classArea: function classArea(d) {
+ return this.classShape(d) + this.generateClass(_classes2.default.area, d.id);
+ },
+ classAreas: function classAreas(d) {
+ return this.classShapes(d) + this.generateClass(_classes2.default.areas, d.id);
+ },
+ classRegion: function classRegion(d, i) {
+ return this.generateClass(_classes2.default.region, i) + " " + ("class" in d ? d.class : "");
+ },
+ classEvent: function classEvent(d) {
+ return this.generateClass(_classes2.default.eventRect, d.index);
+ },
+ classTarget: function classTarget(id) {
+ var additionalClassSuffix = this.config.data_classes[id],
+ additionalClass = "";
+
+
+ return additionalClassSuffix && (additionalClass = " " + _classes2.default.target + "-" + additionalClassSuffix), this.generateClass(_classes2.default.target, id) + additionalClass;
+ },
+ classFocus: function classFocus(d) {
+ return this.classFocused(d) + this.classDefocused(d);
+ },
+ classFocused: function classFocused(d) {
+ return " " + (this.focusedTargetIds.indexOf(d.id) >= 0 ? _classes2.default.focused : "");
+ },
+ classDefocused: function classDefocused(d) {
+ return " " + (this.defocusedTargetIds.indexOf(d.id) >= 0 ? _classes2.default.defocused : "");
+ },
+ classChartText: function classChartText(d) {
+ return _classes2.default.chartText + this.classTarget(d.id);
+ },
+ classChartLine: function classChartLine(d) {
+ return _classes2.default.chartLine + this.classTarget(d.id);
+ },
+ classChartBar: function classChartBar(d) {
+ return _classes2.default.chartBar + this.classTarget(d.id);
+ },
+ classChartArc: function classChartArc(d) {
+ return _classes2.default.chartArc + this.classTarget(d.data.id);
+ },
+ classChartRadar: function classChartRadar(d) {
+ return _classes2.default.chartRadar + this.classTarget(d.id);
+ },
+ getTargetSelectorSuffix: function getTargetSelectorSuffix(targetId) {
+ return targetId || targetId === 0 ? ("-" + targetId).replace(/[\s?!@#$%^&*()_=+,.<>'":;\[\]\/|~`{}\\]/g, "-") : "";
+ },
+ selectorTarget: function selectorTarget(id, prefix) {
+ return (prefix || "") + "." + (_classes2.default.target + this.getTargetSelectorSuffix(id));
+ },
+ selectorTargets: function selectorTargets(idsValue, prefix) {
+ var $$ = this,
+ ids = idsValue || [];
+
+
+ return ids.length ? ids.map(function (id) {
+ return $$.selectorTarget(id, prefix);
+ }) : null;
+ },
+ selectorLegend: function selectorLegend(id) {
+ return "." + (_classes2.default.legendItem + this.getTargetSelectorSuffix(id));
+ },
+ selectorLegends: function selectorLegends(ids) {
+ var $$ = this;
+
+ return ids && ids.length ? ids.map(function (id) {
+ return $$.selectorLegend(id);
+ }) : null;
+ }
+}); /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+/***/ }),
+/* 57 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Selection = __webpack_require__(5),
+ _Chart = __webpack_require__(1),
+ _Chart2 = _interopRequireDefault(_Chart),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_Chart2.default.prototype, {
+ /**
+ * This API highlights specified targets and fade out the others.<br><br>
+ * You can specify multiple targets by giving an array that includes id as String. If no argument is given, all of targets will be highlighted.
+ * @method focus
+ * @instance
+ * @memberOf Chart
+ * @param {String|Array} targetIdsValue Target ids to be highlighted.
+ * @example
+ * // data1 will be highlighted and the others will be faded out
+ * chart.focus("data1");
+ *
+ * // data1 and data2 will be highlighted and the others will be faded out
+ * chart.focus(["data1", "data2"]);
+ *
+ * // all targets will be highlighted
+ * chart.focus();
+ */
+ focus: function focus(targetIdsValue) {
+ var $$ = this.internal,
+ targetIds = $$.mapToTargetIds(targetIdsValue),
+ candidates = $$.svg.selectAll($$.selectorTargets(targetIds.filter($$.isTargetToShow, $$)));
+ this.revert(), this.defocus(), candidates.classed(_classes2.default.focused, !0).classed(_classes2.default.defocused, !1), $$.hasArcType() && $$.expandArc(targetIds), $$.toggleFocusLegend(targetIds, !0), $$.focusedTargetIds = targetIds, $$.defocusedTargetIds = $$.defocusedTargetIds.filter(function (id) {
+ return targetIds.indexOf(id) < 0;
+ });
+ },
+
+
+ /**
+ * This API fades out specified targets and reverts the others.<br><br>
+ * You can specify multiple targets by giving an array that includes id as String. If no argument is given, all of targets will be faded out.
+ * @method defocus
+ * @instance
+ * @memberOf Chart
+ * @param {String|Array} Target ids to be faded out.
+ * @example
+ * // data1 will be faded out and the others will be reverted.
+ * chart.defocus("data1");
+ *
+ * // data1 and data2 will be faded out and the others will be reverted.
+ * chart.defocus(["data1", "data2"]);
+ *
+ * // all targets will be faded out.
+ * chart.defocus();
+ */
+ defocus: function defocus(targetIdsValue) {
+ var $$ = this.internal,
+ targetIds = $$.mapToTargetIds(targetIdsValue),
+ candidates = $$.svg.selectAll($$.selectorTargets(targetIds.filter($$.isTargetToShow, $$)));
+ candidates.classed(_classes2.default.focused, !1).classed(_classes2.default.defocused, !0), $$.hasArcType() && $$.unexpandArc(targetIds), $$.toggleFocusLegend(targetIds, !1), $$.focusedTargetIds = $$.focusedTargetIds.filter(function (id) {
+ return targetIds.indexOf(id) < 0;
+ }), $$.defocusedTargetIds = targetIds;
+ },
+
+
+ /**
+ * This API reverts specified targets.<br><br>
+ * You can specify multiple targets by giving an array that includes id as String. If no argument is given, all of targets will be reverted.
+ * @method revert
+ * @instance
+ * @memberOf Chart
+ * @param {String|Array} Target ids to be reverted
+ * @example
+ * // data1 will be reverted.
+ * chart.revert("data1");
+ *
+ * // data1 and data2 will be reverted.
+ * chart.revert(["data1", "data2"]);
+ *
+ * // all targets will be reverted.
+ * chart.revert();
+ */
+ revert: function revert(targetIdsValue) {
+ var $$ = this.internal,
+ targetIds = $$.mapToTargetIds(targetIdsValue),
+ candidates = $$.svg.selectAll($$.selectorTargets(targetIds));
+ // should be for all targets
+
+ candidates.classed(_classes2.default.focused, !1).classed(_classes2.default.defocused, !1), $$.hasArcType() && $$.unexpandArc(targetIds), $$.config.legend_show && ($$.showLegend(targetIds.filter($$.isLegendToShow.bind($$))), $$.legend.selectAll($$.selectorLegends(targetIds)).filter(function () {
+ return (0, _d3Selection.select)(this).classed(_classes2.default.legendItemFocused);
+ }).classed(_classes2.default.legendItemFocused, !1)), $$.focusedTargetIds = [], $$.defocusedTargetIds = [];
+ }
+});
+
+/***/ }),
+/* 58 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _Chart = __webpack_require__(1),
+ _Chart2 = _interopRequireDefault(_Chart),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_Chart2.default.prototype, {
+ /**
+ * Show data series on chart
+ * @method show
+ * @instance
+ * @memberOf Chart
+ * @param {String|Array} [targetIdsValue=all] The target id value.
+ * @param {Object} [options] The object can consist with following members:<br>
+ *
+ * | Key | Type | default | Description |
+ * | --- | --- | --- | --- |
+ * | withLegend | Boolean | false | whether or not display legend |
+ *
+ * @example
+ * // show 'data1'
+ * chart.show("data1");
+ *
+ * // show 'data1' and 'data3'
+ * chart.show(["data1", "data3"]);
+ */
+ show: function show(targetIdsValue) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},
+ $$ = this.internal,
+ targetIds = $$.mapToTargetIds(targetIdsValue);
+ $$.removeHiddenTargetIds(targetIds);
+
+ var targets = $$.svg.selectAll($$.selectorTargets(targetIds));
+
+ targets.transition().style("opacity", "1", "important").call($$.endall, function () {
+ targets.style("opacity", null).style("opacity", "1");
+ }), options.withLegend && $$.showLegend(targetIds), $$.redraw({
+ withUpdateOrgXDomain: !0,
+ withUpdateXDomain: !0,
+ withLegend: !0
+ });
+ },
+
+
+ /**
+ * Hide data series from chart
+ * @method hide
+ * @instance
+ * @memberOf Chart
+ * @param {String|Array} [targetIdsValue=all] The target id value.
+ * @param {Object} [options] The object can consist with following members:<br>
+ *
+ * | Key | Type | default | Description |
+ * | --- | --- | --- | --- |
+ * | withLegend | Boolean | false | whether or not display legend |
+ *
+ * @example
+ * // hide 'data1'
+ * chart.hide("data1");
+ *
+ * // hide 'data1' and 'data3'
+ * chart.hide(["data1", "data3"]);
+ */
+ hide: function hide(targetIdsValue) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},
+ $$ = this.internal,
+ targetIds = $$.mapToTargetIds(targetIdsValue);
+ $$.addHiddenTargetIds(targetIds);
+
+ var targets = $$.svg.selectAll($$.selectorTargets(targetIds));
+
+ targets.transition().style("opacity", "0", "important").call($$.endall, function () {
+ targets.style("opacity", null).style("opacity", "0");
+ }), options.withLegend && $$.hideLegend(targetIds), $$.redraw({
+ withUpdateOrgXDomain: !0,
+ withUpdateXDomain: !0,
+ withLegend: !0
+ });
+ },
+
+
+ /**
+ * Toggle data series on chart. When target data is hidden, it will show. If is shown, it will hide in vice versa.
+ * @method toggle
+ * @instance
+ * @memberOf Chart
+ * @param {String|Array} [targetIdsValue=all] The target id value.
+ * @param {Object} [options] The object can consist with following members:<br>
+ *
+ * | Key | Type | default | Description |
+ * | --- | --- | --- | --- |
+ * | withLegend | Boolean | false | whether or not display legend |
+ *
+ * @example
+ * // toggle 'data1'
+ * chart.toggle("data1");
+ *
+ * // toggle 'data1' and 'data3'
+ * chart.toggle(["data1", "data3"]);
+ */
+ toggle: function toggle(targetIds) {
+ var _this = this,
+ options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},
+ $$ = this.internal,
+ targets = { show: [], hide: [] };
+
+ // sort show & hide target ids
+ $$.mapToTargetIds(targetIds).forEach(function (id) {
+ return targets[$$.isTargetToShow(id) ? "hide" : "show"].push(id);
+ }), targets.show.length && this.show(targets.show, options), targets.hide.length && setTimeout(function () {
+ return _this.hide(targets.hide, options);
+ }, 0);
+ }
+});
+
+/***/ }),
+/* 59 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Array = __webpack_require__(6),
+ _d3Zoom = __webpack_require__(52),
+ _Chart = __webpack_require__(1),
+ _Chart2 = _interopRequireDefault(_Chart),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Zoom by giving x domain.
+ * @method zoom
+ * @instance
+ * @memberOf Chart
+ * @param {Array} domainValue If domain is given, the chart will be zoomed to the given domain. If no argument is given, the current zoomed domain will be returned.
+ * @return {Array} domain value in array
+ * @example
+ * // Zoom to specified domain
+ * chart.zoom([10, 20]);
+ *
+ * // Get the current zoomed domain
+ * chart.zoom();
+ */
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+var zoom = function (domainValue) {
+ var $$ = this.internal,
+ domain = domainValue,
+ resultDomain = void 0;
+
+
+ if ($$.config.zoom_enabled && domain) {
+ var isTimeSeries = $$.isTimeSeries();
+
+ if (isTimeSeries && (domain = domain.map(function (x) {
+ return $$.parseDate(x);
+ })), $$.config.subchart_show) {
+ var xScale = $$.zoomScale || $$.x;
+
+ $$.brush.getSelection().call($$.brush.move, [xScale(domain[0]), xScale(domain[1])]), resultDomain = domain;
+ } else {
+ var orgDomain = $$.subX.domain(),
+ k = (orgDomain[1] - orgDomain[0]) / (domain[1] - domain[0]),
+ gap = $$.isCategorized() ? $$.xAxis.tickOffset() : 0,
+ tx = isTimeSeries ? 0 - k * $$.x(domain[0].getTime()) : domain[0] - k * ($$.x(domain[0]) - gap);
+ $$.zoom.updateTransformScale(_d3Zoom.zoomIdentity.translate(tx, 0).scale(k)), resultDomain = $$.zoomScale.domain();
+ }
+
+ $$.redraw({
+ withTransition: !0,
+ withY: $$.config.zoom_rescale,
+ withDimension: !1
+ }), $$.setZoomResetButton(), (0, _util.callFn)($$.config.zoom_onzoom, this, $$.x.orgDomain());
+ } else resultDomain = $$.zoomScale ? $$.zoomScale.domain() : $$.x.orgDomain();
+
+ return resultDomain;
+};
+
+(0, _util.extend)(zoom, {
+ /**
+ * Enable and disable zooming.
+ * @method zoom․enable
+ * @instance
+ * @memberOf Chart
+ * @param {String|Boolean} enabled Possible string values are "wheel" or "drag". If enabled is true, "wheel" will be used. If false is given, zooming will be disabled.<br>When set to false, the current zooming status will be reset.
+ * @example
+ * // Enable zooming using the mouse wheel
+ * chart.zoom.enable(true);
+ * // Or
+ * chart.zoom.enable("wheel");
+ *
+ * // Enable zooming by dragging
+ * chart.zoom.enable("drag");
+ *
+ * // Disable zooming
+ * chart.zoom.enable(false);
+ */
+ enable: function enable() {
+ var enabled = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : "wheel",
+ $$ = this.internal,
+ config = $$.config,
+ enableType = enabled;
+ enabled && (enableType = (0, _util.isString)(enabled) && /^(drag|wheel)$/.test(enabled) ? { type: enabled } : enabled), config.zoom_enabled = enableType, $$.zoom ? enabled === !1 && $$.bindZoomEvent(!1) : ($$.initZoom(), $$.initZoomBehaviour(), $$.bindZoomEvent()), $$.updateAndRedraw();
+ },
+
+ /**
+ * Set or get x Axis maximum zoom range value
+ * @method zoom․max
+ * @instance
+ * @memberOf Chart
+ * @param {Number} [max] maximum value to set for zoom
+ * @return {Number} zoom max value
+ * @example
+ * // Set maximum range value
+ * chart.zoom.max(20);
+ */
+ max: function max(_max) {
+ var $$ = this.internal,
+ config = $$.config;
+
+
+ return (_max === 0 || _max) && (config.zoom_x_max = (0, _d3Array.max)([$$.orgXDomain[1], _max])), config.zoom_x_max;
+ },
+
+ /**
+ * Set or get x Axis minimum zoom range value
+ * @method zoom․min
+ * @instance
+ * @memberOf Chart
+ * @param {Number} [min] minimum value tp set for zoom
+ * @return {Number} zoom min value
+ * @example
+ * // Set minimum range value
+ * chart.zoom.min(-1);
+ */
+ min: function min(_min) {
+ var $$ = this.internal,
+ config = $$.config;
+
+
+ return (_min === 0 || _min) && (config.zoom_x_min = (0, _d3Array.min)([$$.orgXDomain[0], _min])), config.zoom_x_min;
+ },
+
+ /**
+ * Set zoom range
+ * @method zoom․range
+ * @instance
+ * @memberOf Chart
+ * @param {Object} [range]
+ * @return {Object} zoom range value
+ * {
+ * min: 0,
+ * max: 100
+ * }
+ * @example
+ * chart.zoom.range({
+ * min: 10,
+ * max: 100
+ * });
+ */
+ range: function range(_range) {
+ var zoom = this.zoom;
+
+ return (0, _util.isObject)(_range) && ((0, _util.isDefined)(_range.min) && zoom.min(_range.min), (0, _util.isDefined)(_range.max) && zoom.max(_range.max)), {
+ min: zoom.min(),
+ max: zoom.max()
+ };
+ }
+}), (0, _util.extend)(_Chart2.default.prototype, {
+ zoom: zoom,
+
+ /**
+ * Unzoom zoomed area
+ * @method unzoom
+ * @instance
+ * @memberOf Chart
+ * @example
+ * chart.unzoom();
+ */
+ unzoom: function unzoom() {
+ var $$ = this.internal,
+ config = $$.config;
+ $$.zoomScale && (config.subchart_show ? $$.brush.getSelection().call($$.brush.move, null) : $$.zoom.updateTransformScale(_d3Zoom.zoomIdentity), $$.updateZoom(), $$.zoom.resetBtn && $$.zoom.resetBtn.style("display", "none"), $$.redraw({
+ withTransition: !0,
+ withY: config.zoom_rescale
+ }));
+ }
+});
+
+/***/ }),
+/* 60 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _Chart = __webpack_require__(1),
+ _Chart2 = _interopRequireDefault(_Chart),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_Chart2.default.prototype, {
+ /**
+ * Load data to the chart.<br><br>
+ * You can specify multiple targets by giving an array that includes id as String. If no argument is given, all of targets will be toggles.
+ * - <b>Note:</b>
+ * unload should be used if some data needs to be unloaded simultaneously. If you call unload API soon after/before load instead of unload param, chart will not be rendered properly because of cancel of animation.<br>
+ * done will be called after data loaded, but it's not after rendering. It's because rendering will finish after some transition and there is some time lag between loading and rendering
+ * @method load
+ * @instance
+ * @memberOf Chart
+ * @param {Object} args The object can consist with following members:<br>
+ *
+ * | Key | Description |
+ * | --- | --- |
+ * | - url<br>- json<br>- rows<br>- columns | The data will be loaded. If data that has the same target id is given, the chart will be updated. Otherwise, new target will be added |
+ * | classes | The classes specified by data.classes will be updated. classes must be Object that has target id as keys. |
+ * | categories | The categories specified by axis.x.categories or data.x will be updated. categories must be Array. |
+ * | axes | The axes specified by data.axes will be updated. axes must be Object that has target id as keys. |
+ * | colors | The colors specified by data.colors will be updated. colors must be Object that has target id as keys. |
+ * | - type<br>- types | The type of targets will be updated. type must be String and types must be Object. |
+ * | unload | Specify the data will be unloaded before loading new data. If true given, all of data will be unloaded. If target ids given as String or Array, specified targets will be unloaded. If absent or false given, unload will not occur. |
+ * | done | The specified function will be called after data loaded.|
+ *
+ * @example
+ * // Load data1 and unload data2 and data3
+ * chart.load({
+ * columns: [
+ * ["data1", 100, 200, 150, ...],
+ * ...
+ * ],
+ * unload: ["data2", "data3"],
+ * url: "...",
+ * done: function() { ... }
+ * });
+ */
+ load: function load(args) {
+ var $$ = this.internal,
+ config = $$.config;
+
+ // update xs if specified
+
+ // use cache if exists
+ return args.xs && $$.addXs(args.xs), "names" in args && this.data.names(args.names), "classes" in args && Object.keys(args.classes).forEach(function (id) {
+ config.data_classes[id] = args.classes[id];
+ }), "categories" in args && $$.isCategorized() && (config.axis_x_categories = args.categories), "axes" in args && Object.keys(args.axes).forEach(function (id) {
+ config.data_axes[id] = args.axes[id];
+ }), "colors" in args && Object.keys(args.colors).forEach(function (id) {
+ config.data_colors[id] = args.colors[id];
+ }), "cacheIds" in args && $$.hasCaches(args.cacheIds, !0) ? void $$.load($$.getCache(args.cacheIds, !0), args.done) : void ("unload" in args && args.unload !== !1 ? $$.unload($$.mapToTargetIds(args.unload === !0 ? null : args.unload), function () {
+ return $$.loadFromArgs(args);
+ }) : $$.loadFromArgs(args));
+
+ // unload if needed
+ },
+
+
+ /**
+ * Unload data to the chart.<br><br>
+ * You can specify multiple targets by giving an array that includes id as String. If no argument is given, all of targets will be toggles.
+ * - <b>Note:</b>
+ * If you call load API soon after/before unload, unload param of load should be used. Otherwise chart will not be rendered properly because of cancel of animation.<br>
+ * `done` will be called after data loaded, but it's not after rendering. It's because rendering will finish after some transition and there is some time lag between loading and rendering.
+ * @method unload
+ * @instance
+ * @memberOf Chart
+ * @param {Object} args
+ * - If ids given, the data that has specified target id will be unloaded. ids should be String or Array. If ids is not specified, all data will be unloaded.
+ * - If done given, the specified function will be called after data loded.
+ * @example
+ * // Unload data2 and data3
+ * chart.unload({
+ * ids: ["data2", "data3"]
+ * });
+ */
+ unload: function unload(argsValue) {
+ var $$ = this.internal,
+ args = argsValue || {};
+ (0, _util.isArray)(args) ? args = { ids: args } : (0, _util.isString)(args) && (args = { ids: [args] }), $$.unload($$.mapToTargetIds(args.ids), function () {
+ $$.redraw({
+ withUpdateOrgXDomain: !0,
+ withUpdateXDomain: !0,
+ withLegend: !0
+ }), args.done && args.done();
+ });
+ }
+});
+
+/***/ }),
+/* 61 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Selection = __webpack_require__(5),
+ _d3Ease = __webpack_require__(62),
+ _d3Transition = __webpack_require__(7),
+ _Chart = __webpack_require__(1),
+ _Chart2 = _interopRequireDefault(_Chart),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _util = __webpack_require__(11),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+(0, _util.extend)(_Chart2.default.prototype, {
+ /**
+ * Flow data to the chart.<br><br>
+ * By this API, you can append new data points to the chart.
+ * @method flow
+ * @instance
+ * @memberOf Chart
+ * @param {Object} args The object can consist with following members:<br>
+ *
+ * | Key | Type | Description |
+ * | --- | --- | --- |
+ * | json | Object | Data as JSON format (@see [data․json](Options.html#.data%25E2%2580%25A4json)) |
+ * | rows | Array | Data in array as row format (@see [data․rows](Options.html#.data%25E2%2580%25A4json)) |
+ * | columns | Array | Data in array as column format (@see [data․columns](Options.html#.data%25E2%2580%25A4columns)) |
+ * | to | String | The lower x edge will move to that point. If not given, the lower x edge will move by the number of given data points |
+ * | length | Number | The lower x edge will move by the number of this argument |
+ * | duration | Number | The duration of the transition will be specified value. If not given, transition.duration will be used as default |
+ * | done | Function | The specified function will be called when flow ends |
+ *
+ * - **NOTE:**
+ * If json, rows and columns given, the data will be loaded.<br>
+ * If data that has the same target id is given, the chart will be appended.<br>
+ * Otherwise, new target will be added. One of these is required when calling.<br>
+ * If json specified, keys is required as well as data.json.
+ * @example
+ * // 2 data points will be apprended to the tail and popped from the head.
+ * // After that, 4 data points will be appended and no data points will be poppoed.
+ * chart.flow({
+ * columns: [
+ * ["x", "2018-01-11", "2018-01-21"],
+ * ["data1", 500, 200],
+ * ["data2", 100, 300],
+ * ["data3", 200, 120]
+ * ],
+ * to: "2013-01-11",
+ * done: function () {
+ * chart.flow({
+ * columns: [
+ * ["x", "2018-02-11", "2018-02-12", "2018-02-13", "2018-02-14"],
+ * ["data1", 200, 300, 100, 250],
+ * ["data2", 100, 90, 40, 120],
+ * ["data3", 100, 100, 300, 500]
+ * ],
+ * length: 2,
+ * duration: 1500
+ * });
+ * }
+ * });
+ */
+ flow: function flow(args) {
+ var $$ = this.internal,
+ notfoundIds = [],
+ orgDataCount = $$.getMaxDataCount(),
+ data = void 0,
+ domain = void 0,
+ length = 0,
+ tail = 0,
+ diff = void 0,
+ to = void 0;
+
+
+ if (args.json) data = $$.convertJsonToData(args.json, args.keys);else if (args.rows) data = $$.convertRowsToData(args.rows);else if (args.columns) data = $$.convertColumnsToData(args.columns);else return;
+
+ var targets = $$.convertDataToTargets(data, !0);
+
+ // Update/Add data
+ $$.data.targets.forEach(function (t) {
+ var found = !1;
+
+ for (var i = 0; i < targets.length; i++) if (t.id === targets[i].id) {
+ found = !0, t.values[t.values.length - 1] && (tail = t.values[t.values.length - 1].index + 1), length = targets[i].values.length;
+
+
+ for (var _j = 0; _j < length; _j++) targets[i].values[_j].index = tail + _j, $$.isTimeSeries() || (targets[i].values[_j].x = tail + _j);
+
+ t.values = t.values.concat(targets[i].values), targets.splice(i, 1);
+
+ break;
+ }
+
+ found || notfoundIds.push(t.id);
+ }), $$.data.targets.forEach(function (t) {
+ for (var i = 0; i < notfoundIds.length; i++) if (t.id === notfoundIds[i]) {
+ tail = t.values[t.values.length - 1].index + 1;
+
+
+ for (var _j2 = 0; _j2 < length; _j2++) t.values.push({
+ id: t.id,
+ index: tail + _j2,
+ x: $$.isTimeSeries() ? $$.getOtherTargetX(tail + _j2) : tail + _j2,
+ value: null
+ });
+ }
+ }), $$.data.targets.length && targets.forEach(function (t) {
+ var missing = [];
+
+ for (var i = $$.data.targets[0].values[0].index; i < tail; i++) missing.push({
+ id: t.id,
+ index: i,
+ x: $$.isTimeSeries() ? $$.getOtherTargetX(i) : i,
+ value: null
+ });
+
+ t.values.forEach(function (v) {
+ v.index += tail, $$.isTimeSeries() || (v.x += tail);
+ }), t.values = missing.concat(t.values);
+ }), $$.data.targets = $$.data.targets.concat(targets);
+ // add remained
+
+ // check data count because behavior needs to change when it"s only one
+ // const dataCount = $$.getMaxDataCount();
+ var baseTarget = $$.data.targets[0],
+ baseValue = baseTarget.values[0];
+
+
+ // Update length to flow if needed
+ (0, _util.isDefined)(args.to) ? (length = 0, to = $$.isTimeSeries() ? $$.parseDate(args.to) : args.to, baseTarget.values.forEach(function (v) {
+ v.x < to && length++;
+ })) : (0, _util.isDefined)(args.length) && (length = args.length), orgDataCount ? orgDataCount === 1 && $$.isTimeSeries() && (diff = (baseTarget.values[baseTarget.values.length - 1].x - baseValue.x) / 2, domain = [new Date(+baseValue.x - diff), new Date(+baseValue.x + diff)], $$.updateXDomain(null, !0, !0, !1, domain)) : (diff = $$.isTimeSeries() ? baseTarget.values.length > 1 ? baseTarget.values[baseTarget.values.length - 1].x - baseValue.x : baseValue.x - $$.getXDomain($$.data.targets)[0] : 1, domain = [baseValue.x - diff, baseValue.x], $$.updateXDomain(null, !0, !0, !1, domain)), $$.updateTargets($$.data.targets), $$.redraw({
+ flow: {
+ index: baseValue.index,
+ length: length,
+ duration: (0, _util.isValue)(args.duration) ? args.duration : $$.config.transition_duration,
+ done: args.done,
+ orgDataCount: orgDataCount
+ },
+ withLegend: !0,
+ withTransition: orgDataCount > 1,
+ withTrimXDomain: !1,
+ withUpdateXAxis: !0
+ });
+ }
+}), (0, _util.extend)(_ChartInternal2.default.prototype, {
+ /**
+ * Generate flow
+ * @memberOf ChartInternal
+ * @private
+ * @param {Object} args
+ * @return {Function}
+ */
+ generateFlow: function generateFlow(args) {
+ var $$ = this,
+ config = $$.config;
+
+
+ return function () {
+ var targets = args.targets,
+ flow = args.flow,
+ drawBar = args.drawBar,
+ drawLine = args.drawLine,
+ drawArea = args.drawArea,
+ cx = args.cx,
+ cy = args.cy,
+ xv = args.xv,
+ xForText = args.xForText,
+ yForText = args.yForText,
+ duration = args.duration,
+ translateX = void 0,
+ scaleX = 1,
+ flowIndex = flow.index,
+ flowLength = flow.length,
+ flowStart = $$.getValueOnIndex($$.data.targets[0].values, flowIndex),
+ flowEnd = $$.getValueOnIndex($$.data.targets[0].values, flowIndex + flowLength),
+ orgDomain = $$.x.domain(),
+ durationForFlow = flow.duration || duration,
+ done = flow.done || function () {},
+ wait = $$.generateWait(),
+ xgrid = $$.xgrid || (0, _d3Selection.selectAll)([]),
+ xgridLines = $$.xgridLines || (0, _d3Selection.selectAll)([]),
+ mainRegion = $$.mainRegion || (0, _d3Selection.selectAll)([]),
+ mainText = $$.mainText || (0, _d3Selection.selectAll)([]),
+ mainBar = $$.mainBar || (0, _d3Selection.selectAll)([]),
+ mainLine = $$.mainLine || (0, _d3Selection.selectAll)([]),
+ mainArea = $$.mainArea || (0, _d3Selection.selectAll)([]),
+ mainCircle = $$.mainCircle || (0, _d3Selection.selectAll)([]);
+
+ // set flag
+ $$.flowing = !0, $$.data.targets.forEach(function (d) {
+ d.values.splice(0, flowLength);
+ });
+
+
+ // update x domain to generate axis elements for flow
+ var domain = $$.updateXDomain(targets, !0, !0);
+
+ // update elements related to x scale
+ $$.updateXGrid && $$.updateXGrid(!0), flow.orgDataCount ? flow.orgDataCount === 1 || (flowStart && flowStart.x) === (flowEnd && flowEnd.x) ? translateX = $$.x(orgDomain[0]) - $$.x(domain[0]) : $$.isTimeSeries() ? translateX = $$.x(orgDomain[0]) - $$.x(domain[0]) : translateX = $$.x(flowStart.x) - $$.x(flowEnd.x) : $$.data.targets[0].values.length === 1 ? $$.isTimeSeries() ? (flowStart = $$.getValueOnIndex($$.data.targets[0].values, 0), flowEnd = $$.getValueOnIndex($$.data.targets[0].values, $$.data.targets[0].values.length - 1), translateX = $$.x(flowStart.x) - $$.x(flowEnd.x)) : translateX = (0, _util.diffDomain)(domain) / 2 : translateX = $$.x(orgDomain[0]) - $$.x(domain[0]), scaleX = (0, _util.diffDomain)(orgDomain) / (0, _util.diffDomain)(domain);
+
+ var transform = "translate(" + translateX + ",0) scale(" + scaleX + ",1)";
+
+ $$.hideXGridFocus();
+
+
+ var gt = (0, _d3Transition.transition)().ease(_d3Ease.easeLinear).duration(durationForFlow);
+
+ wait.add([$$.axes.x.transition(gt).call($$.xAxis.setTransition(gt)), mainBar.transition(gt).attr("transform", transform), mainLine.transition(gt).attr("transform", transform), mainArea.transition(gt).attr("transform", transform), mainCircle.transition(gt).attr("transform", transform), mainText.transition(gt).attr("transform", transform), mainRegion.filter($$.isRegionOnX).transition(gt).attr("transform", transform), xgrid.transition(gt).attr("transform", transform), xgridLines.transition(gt).attr("transform", transform)]), gt.call(wait, function () {
+ var shapes = [],
+ texts = [],
+ eventRects = [];
+
+
+ // remove flowed elements
+ if (flowLength) {
+ for (var index, i = 0; i < flowLength; i++) index = flowIndex + i, shapes.push("." + _classes2.default.shape + "-" + index), texts.push("." + _classes2.default.text + "-" + index), eventRects.push("." + _classes2.default.eventRect + "-" + index);
+
+ $$.svg.selectAll("." + _classes2.default.shapes).selectAll(shapes).remove(), $$.svg.selectAll("." + _classes2.default.texts).selectAll(texts).remove(), $$.svg.selectAll("." + _classes2.default.eventRects).selectAll(eventRects).remove(), $$.svg.select("." + _classes2.default.xgrid).remove();
+ }
+
+ // draw again for removing flowed elements and reverting attr
+
+
+ if (xgrid.size() && xgrid.attr("transform", null).attr($$.xgridAttr), xgridLines.attr("transform", null), xgridLines.select("line").attr("x1", config.axis_rotated ? 0 : xv).attr("x2", config.axis_rotated ? $$.width : xv), xgridLines.select("text").attr("x", config.axis_rotated ? $$.width : 0).attr("y", xv), mainBar.attr("transform", null).attr("d", drawBar), mainLine.attr("transform", null).attr("d", drawLine), mainArea.attr("transform", null).attr("d", drawArea), mainCircle.attr("transform", null), $$.isCirclePoint()) mainCircle.attr("cx", cx).attr("cy", cy);else {
+ var xFunc = function (d) {
+ return cx(d) - config.point_r;
+ },
+ yFunc = function (d) {
+ return cy(d) - config.point_r;
+ };
+
+ mainCircle.attr("x", xFunc).attr("y", yFunc).attr("cx", cx) // when pattern is used, it possibly contain 'circle' also.
+ .attr("cy", cy);
+ }
+
+ mainText.attr("transform", null).attr("x", xForText).attr("y", yForText).style("fill-opacity", $$.opacityForText.bind($$)), mainRegion.attr("transform", null), mainRegion.select("rect").filter($$.isRegionOnX).attr("x", $$.regionX.bind($$)).attr("width", $$.regionWidth.bind($$)), config.interaction_enabled && $$.redrawEventRect(), done(), $$.flowing = !1;
+ });
+ };
+ }
+}); /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+/***/ }),
+/* 62 */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE__62__;
+
+/***/ }),
+/* 63 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Selection = __webpack_require__(5),
+ _Chart = __webpack_require__(1),
+ _Chart2 = _interopRequireDefault(_Chart),
+ _util = __webpack_require__(11),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_Chart2.default.prototype, {
+ /**
+ * Get selected data points.<br><br>
+ * By this API, you can get selected data points information. To use this API, data.selection.enabled needs to be set true.
+ * @method selected
+ * @instance
+ * @memberOf Chart
+ * @param {String} [targetId] You can filter the result by giving target id that you want to get. If not given, all of data points will be returned.
+ * @return {Array} dataPoint Array of the data points.<br>ex.) `[{x: 1, value: 200, id: "data1", index: 1, name: "data1"}, ...]`
+ * @example
+ * // all selected data points will be returned.
+ * chart.selected();
+ * // --> ex.) [{x: 1, value: 200, id: "data1", index: 1, name: "data1"}, ... ]
+ *
+ * // all selected data points of data1 will be returned.
+ * chart.selected("data1");
+ */
+ selected: function selected(targetId) {
+ var $$ = this.internal,
+ dataPoint = [];
+
+
+ return $$.main.selectAll("." + (_classes2.default.shapes + $$.getTargetSelectorSuffix(targetId))).selectAll("." + _classes2.default.shape).filter(function () {
+ return (0, _d3Selection.select)(this).classed(_classes2.default.SELECTED);
+ }).each(function (d) {
+ return dataPoint.push(d);
+ }), dataPoint;
+ },
+
+
+ /**
+ * Set data points to be selected. (`[data.selection.enabled](Options.html#.data%25E2%2580%25A4selection%25E2%2580%25A4enabled) option should be set true to use this method)`
+ * @method select
+ * @instance
+ * @memberOf Chart
+ * @param {String|Array} [ids] id value to get selected.
+ * @param {Array} [indices] The index array of data points. If falsy value given, will select all data points.
+ * @param {Boolean} [resetOther] Unselect already selected.
+ * @example
+ * // select all data points
+ * chart.select();
+ *
+ * // select all from 'data2'
+ * chart.select("data2");
+ *
+ * // select all from 'data1' and 'data2'
+ * chart.select(["data1", "data2"]);
+ *
+ * // select from 'data1', indices 2 and unselect others selected
+ * chart.select("data1", [2], true);
+ *
+ * // select from 'data1', indices 0, 3 and 5
+ * chart.select("data1", [0, 3, 5]);
+ */
+ select: function select(ids, indices, resetOther) {
+ var $$ = this.internal,
+ config = $$.config;
+ config.data_selection_enabled && $$.main.selectAll("." + _classes2.default.shapes).selectAll("." + _classes2.default.shape).each(function (d, i) {
+ var shape = (0, _d3Selection.select)(this),
+ id = d.data ? d.data.id : d.id,
+ toggle = $$.getToggle(this, d).bind($$),
+ isTargetId = config.data_selection_grouped || !ids || ids.indexOf(id) >= 0,
+ isTargetIndex = !indices || indices.indexOf(i) >= 0,
+ isSelected = shape.classed(_classes2.default.SELECTED);
+
+
+ // line/area selection not supported yet
+ shape.classed(_classes2.default.line) || shape.classed(_classes2.default.area) || (isTargetId && isTargetIndex ? config.data_selection_isselectable(d) && !isSelected && toggle(!0, shape.classed(_classes2.default.SELECTED, !0), d, i) : (0, _util.isDefined)(resetOther) && resetOther && isSelected && toggle(!1, shape.classed(_classes2.default.SELECTED, !1), d, i));
+ });
+ },
+
+
+ /**
+ * Set data points to be un-selected.
+ * @method unselect
+ * @instance
+ * @memberOf Chart
+ * @param {String|Array} [ids] id value to be unselected.
+ * @param {Array} [indices] The index array of data points. If falsy value given, will select all data points.
+ * @example
+ * // unselect all data points
+ * chart.unselect();
+ *
+ * // unselect all from 'data1'
+ * chart.unselect("data1");
+ *
+ * // unselect from 'data1', indices 2
+ * chart.unselect("data1", [2]);
+ */
+ unselect: function unselect(ids, indices) {
+ var $$ = this.internal,
+ config = $$.config;
+ config.data_selection_enabled && $$.main.selectAll("." + _classes2.default.shapes).selectAll("." + _classes2.default.shape).each(function (d, i) {
+ var shape = (0, _d3Selection.select)(this),
+ id = d.data ? d.data.id : d.id,
+ toggle = $$.getToggle(this, d).bind($$),
+ isTargetId = config.data_selection_grouped || !ids || ids.indexOf(id) >= 0,
+ isTargetIndex = !indices || indices.indexOf(i) >= 0,
+ isSelected = shape.classed(_classes2.default.SELECTED);
+
+
+ // line/area selection not supported yet
+ shape.classed(_classes2.default.line) || shape.classed(_classes2.default.area) || isTargetId && isTargetIndex && config.data_selection_isselectable(d) && isSelected && toggle(!1, shape.classed(_classes2.default.SELECTED, !1), d, i);
+ });
+ }
+});
+
+/***/ }),
+/* 64 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _Chart = __webpack_require__(1),
+ _Chart2 = _interopRequireDefault(_Chart),
+ _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+(0, _util.extend)(_Chart2.default.prototype, {
+ /**
+ * Change the type of the chart.
+ * @method transform
+ * @instance
+ * @memberOf Chart
+ * @param {String} type Specify the type to be transformed. The types listed in data.type can be used.
+ * @param {String|Array} targetIds Specify targets to be transformed. If not given, all targets will be the candidate.
+ * @example
+ * // all targets will be bar chart.
+ * chart.transform("bar");
+ *
+ * // only data1 will be bar chart.
+ * chart.transform("bar", "data1");
+ *
+ * // only data1 and data2 will be bar chart.
+ * chart.transform("bar", ["data1", "data2"]);
+ */
+ transform: function transform(type, targetIds) {
+ var $$ = this.internal,
+ options = ["pie", "donut"].indexOf(type) >= 0 ? { withTransform: !0 } : null;
+ $$.transformTo(targetIds, type, options);
+ }
+}), (0, _util.extend)(_ChartInternal2.default.prototype, {
+ /**
+ * Change the type of the chart.
+ * @private
+ * @param {String|Array} targetIds
+ * @param {String} type
+ * @param {Object} optionsForRedraw
+ */
+ transformTo: function transformTo(targetIds, type, optionsForRedraw) {
+ var $$ = this,
+ withTransitionForAxis = !$$.hasArcType(),
+ options = optionsForRedraw || { withTransitionForAxis: withTransitionForAxis };
+ options.withTransitionForTransform = !1, $$.transiting = !1, $$.setTargetType(targetIds, type), $$.updateTargets($$.data.targets), $$.updateAndRedraw(options);
+ }
+}); /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+/***/ }),
+/* 65 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _Chart = __webpack_require__(1),
+ _Chart2 = _interopRequireDefault(_Chart),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_Chart2.default.prototype, {
+ /**
+ * Update groups for the targets.
+ * @method groups
+ * @instance
+ * @memberOf Chart
+ * @param {Array} groups This argument needs to be an Array that includes one or more Array that includes target ids to be grouped.
+ * @example
+ * // data1 and data2 will be a new group.
+ * chart.groups([
+ * ["data1", "data2"]
+ * ]);
+ */
+ groups: function groups(_groups) {
+ var $$ = this.internal,
+ config = $$.config;
+ return (0, _util.isUndefined)(_groups) ? config.data_groups : (config.data_groups = _groups, $$.redraw(), config.data_groups);
+ }
+});
+
+/***/ }),
+/* 66 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _Chart = __webpack_require__(1),
+ _Chart2 = _interopRequireDefault(_Chart),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Update x grid lines.
+ * @method xgrids
+ * @instance
+ * @memberOf Chart
+ * @param {Array} grids X grid lines will be replaced with this argument. The format of this argument is the same as grid.x.lines.
+ * @example
+ * // Show 2 x grid lines
+ * chart.xgrids([
+ * {value: 1, text: "Label 1"},
+ * {value: 4, text: "Label 4"}
+ * ]);
+ */
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+var xgrids = function (grids) {
+ var $$ = this.internal,
+ config = $$.config;
+ return grids ? (config.grid_x_lines = grids, $$.redrawWithoutRescale(), config.grid_x_lines) : config.grid_x_lines;
+};
+
+(0, _util.extend)(xgrids, {
+ /**
+ * Add x grid lines.<br>
+ * This API adds new x grid lines instead of replacing like xgrids.
+ * @method xgrids․add
+ * @instance
+ * @memberOf Chart
+ * @param {Array|Object} grids New x grid lines will be added. The format of this argument is the same as grid.x.lines and it's possible to give an Object if only one line will be added.
+ * @example
+ * // Add a new x grid line
+ * chart.xgrids.add(
+ * {value: 4, text: "Label 4"}
+ * );
+ *
+ * // Add new x grid lines
+ * chart.xgrids.add([
+ * {value: 2, text: "Label 2"},
+ * {value: 4, text: "Label 4"}
+ * ]);
+ */
+ add: function add(grids) {
+ return this.xgrids(this.internal.config.grid_x_lines.concat(grids || []));
+ },
+
+ /**
+ * Remove x grid lines.<br>
+ * This API removes x grid lines.
+ * @method xgrids․remove
+ * @instance
+ * @memberOf Chart
+ * @param {Object} params This argument should include value or class. If value is given, the x grid lines that have specified x value will be removed. If class is given, the x grid lines that have specified class will be removed. If args is not given, all of x grid lines will be removed.
+ * @example
+ * // x grid line on x = 2 will be removed
+ * chart.xgrids.remove({value: 2});
+ *
+ * // x grid lines that have 'grid-A' will be removed
+ * chart.xgrids.remove({
+ * class: "grid-A"
+ * });
+ *
+ * // all of x grid lines will be removed
+ * chart.xgrids.remove();
+ */
+ remove: function remove(params) {
+ this.internal.removeGridLines(params, !0);
+ }
+});
+
+
+/**
+ * Update y grid lines.
+ * @method ygrids
+ * @instance
+ * @memberOf Chart
+ * @param {Array} grids Y grid lines will be replaced with this argument. The format of this argument is the same as grid.y.lines.
+ * @example
+ * // Show 2 y grid lines
+ * chart.ygrids([
+ * {value: 100, text: "Label 1"},
+ * {value: 400, text: "Label 4"}
+ * ]);
+ */
+var ygrids = function (grids) {
+ var $$ = this.internal,
+ config = $$.config;
+ return grids ? (config.grid_y_lines = grids, $$.redrawWithoutRescale(), config.grid_y_lines) : config.grid_y_lines;
+};
+
+(0, _util.extend)(ygrids, {
+ /**
+ * Add y grid lines.<br>
+ * This API adds new y grid lines instead of replacing like ygrids.
+ * @method ygrids․add
+ * @instance
+ * @memberOf Chart
+ * @param {Array|Object} grids New y grid lines will be added. The format of this argument is the same as grid.y.lines and it's possible to give an Object if only one line will be added.
+ * @example
+ * // Add a new x grid line
+ * chart.ygrids.add(
+ * {value: 400, text: "Label 4"}
+ * );
+ *
+ * // Add new x grid lines
+ * chart.ygrids.add([
+ * {value: 200, text: "Label 2"},
+ * {value: 400, text: "Label 4"}
+ * ]);
+ */
+ add: function add(grids) {
+ return this.ygrids(this.internal.config.grid_y_lines.concat(grids || []));
+ },
+
+ /**
+ * Remove y grid lines.<br>
+ * This API removes x grid lines.
+ * @method ygrids․remove
+ * @instance
+ * @memberOf Chart
+ * @param {Object} params This argument should include value or class. If value is given, the y grid lines that have specified y value will be removed. If class is given, the y grid lines that have specified class will be removed. If args is not given, all of y grid lines will be removed.
+ * @example
+ * // y grid line on y = 200 will be removed
+ * chart.ygrids.remove({value: 200});
+ *
+ * // y grid lines that have 'grid-A' will be removed
+ * chart.ygrids.remove({
+ * class: "grid-A"
+ * });
+ *
+ * // all of y grid lines will be removed
+ * chart.ygrids.remove();
+ */
+ remove: function remove(params) {
+ this.internal.removeGridLines(params, !1);
+ }
+}), (0, _util.extend)(_Chart2.default.prototype, {
+ xgrids: xgrids,
+ ygrids: ygrids
+});
+
+/***/ }),
+/* 67 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _Chart = __webpack_require__(1),
+ _Chart2 = _interopRequireDefault(_Chart),
+ _classes = __webpack_require__(14),
+ _classes2 = _interopRequireDefault(_classes),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Update regions.
+ * @method regions
+ * @instance
+ * @memberOf Chart
+ * @param {Array} regions Regions will be replaced with this argument. The format of this argument is the same as regions.
+ * @return {Array} regions
+ * @example
+ * // Show 2 regions
+ * chart.regions([
+ * {axis: "x", start: 5, class: "regionX"},
+ * {axis: "y", end: 50, class: "regionY"}
+ * ]);
+ */
+var regions = function (_regions) {
+ var $$ = this.internal,
+ config = $$.config;
+ return _regions ? (config.regions = _regions, $$.redrawWithoutRescale(), config.regions) : config.regions;
+}; /**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(regions, {
+ /**
+ * Add new region.<br><br>
+ * This API adds new region instead of replacing like regions.
+ * @method regions․add
+ * @instance
+ * @memberOf Chart
+ * @param {Array|Object} regions New region will be added. The format of this argument is the same as regions and it's possible to give an Object if only one region will be added.
+ * @return {Array} regions
+ * @example
+ * // Add a new region
+ * chart.regions.add(
+ * {axis: "x", start: 5, class: "regionX"}
+ * );
+ *
+ * // Add new regions
+ * chart.regions.add([
+ * {axis: "x", start: 5, class: "regionX"},
+ * {axis: "y", end: 50, class: "regionY"}
+ *]);
+ */
+ add: function add(regions) {
+ var $$ = this.internal,
+ config = $$.config;
+ return regions ? (config.regions = config.regions.concat(regions), $$.redrawWithoutRescale(), config.regions) : config.regions;
+ },
+
+ /**
+ * Remove regions.<br><br>
+ * This API removes regions.
+ * @method regions․remove
+ * @instance
+ * @memberOf Chart
+ * @param {Object} regions This argument should include classes. If classes is given, the regions that have one of the specified classes will be removed. If args is not given, all of regions will be removed.
+ * @return {Array} regions
+ * @example
+ * // regions that have 'region-A' or 'region-B' will be removed.
+ * chart.regions.remove({
+ * classes: [
+ * "region-A", "region-B"
+ * ]
+ * });
+ *
+ * // all of regions will be removed.
+ * chart.regions.remove();
+ */
+ remove: function remove(optionsValue) {
+ var $$ = this.internal,
+ config = $$.config,
+ options = optionsValue || {},
+ duration = $$.getOption(options, "duration", config.transition_duration),
+ classes = $$.getOption(options, "classes", [_classes2.default.region]),
+ regions = $$.main.select("." + _classes2.default.regions).selectAll(classes.map(function (c) {
+ return "." + c;
+ }));
+
+
+ return (duration ? regions.transition().duration(duration) : regions).style("opacity", "0").remove(), config.regions = config.regions.filter(function (region) {
+ var found = !1;
+
+ return !region.class || (region.class.split(" ").forEach(function (c) {
+ classes.indexOf(c) >= 0 && (found = !0);
+ }), !found);
+ }), config.regions;
+ }
+}), (0, _util.extend)(_Chart2.default.prototype, { regions: regions });
+
+/***/ }),
+/* 68 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _Chart = __webpack_require__(1),
+ _Chart2 = _interopRequireDefault(_Chart),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Get data loaded in the chart.
+ * @method data
+ * @instance
+ * @memberOf Chart
+ * @param {String|Array} targetIds If this argument is given, this API returns the specified target data. If this argument is not given, all of data will be returned.
+ * @example
+ * // Get only data1 data
+ * chart.data("data1");
+ *
+ * // Get data1 and data2 data
+ * chart.data(["data1", "data2"]);
+ *
+ * // Get all data
+ * chart.data();
+ */
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+var data = function (targetIds) {
+ var targets = this.internal.data.targets;
+
+ return (0, _util.isUndefined)(targetIds) ? targets : targets.filter(function (t) {
+ return targetIds.indexOf(t.id) >= 0;
+ });
+};
+
+(0, _util.extend)(data, {
+ /**
+ * Get data shown in the chart.
+ * @method data․shown
+ * @instance
+ * @memberOf Chart
+ * @param {String|Array} targetIds If this argument is given, this API filters the data with specified target ids. If this argument is not given, all shown data will be returned.
+ * @example
+ * // Get shown data by filtering to include only data1 data
+ * chart.data.shown("data1");
+ *
+ * // Get shown data by filtering to include data1 and data2 data
+ * chart.data.shown(["data1", "data2"]);
+ *
+ * // Get all shown data
+ * chart.data.shown();
+ */
+ shown: function shown(targetIds) {
+ return this.internal.filterTargetsToShow(this.data(targetIds));
+ },
+
+ /**
+ * Get values of the data loaded in the chart.
+ * @method data․values
+ * @instance
+ * @memberOf Chart
+ * @param {String|Array} targetIds This API returns the values of specified target. If this argument is not given, null will be retruned
+ * @example
+ * // Get data1 values
+ * chart.data.values("data1");
+ */
+ values: function (targetId) {
+ var values = null;
+
+ if (targetId) {
+ var targets = this.data(targetId);
+
+ targets && (0, _util.isArray)(targets) && (values = [], targets.forEach(function (v) {
+ values = values.concat(v.values.map(function (d) {
+ return d.value;
+ }));
+ }));
+ }
+
+ return values;
+ },
+
+ /**
+ * Get and set names of the data loaded in the chart.
+ * @method data․names
+ * @instance
+ * @memberOf Chart
+ * @param {Object} names If this argument is given, the names of data will be updated. If not given, the current names will be returned. The format of this argument is the same as
+ * @example
+ * // Get current names
+ * chart.data.names();
+ *
+ * // Update names
+ * chart.data.names({
+ * data1: "New Name 1",
+ * data2: "New Name 2"
+ *});
+ */
+ names: function names(_names) {
+
+ return this.internal.clearLegendItemTextBoxCache(), this.internal.updateDataAttributes("names", _names);
+ },
+
+ /**
+ * Get and set colors of the data loaded in the chart.
+ * @method data․colors
+ * @instance
+ * @memberOf Chart
+ * @param {Object} colors If this argument is given, the colors of data will be updated. If not given, the current colors will be returned. The format of this argument is the same as
+ * @example
+ * // Get current colors
+ * chart.data.colors();
+ *
+ * // Update colors
+ * chart.data.colors({
+ * data1: "#FFFFFF",
+ * data2: "#000000"
+ * });
+ */
+ colors: function colors(_colors) {
+ return this.internal.updateDataAttributes("colors", _colors);
+ },
+
+ /**
+ * Get and set axes of the data loaded in the chart.
+ * @method data․axes
+ * @instance
+ * @memberOf Chart
+ * @param {Object} axes If this argument is given, the axes of data will be updated. If not given, the current axes will be returned. The format of this argument is the same as
+ * @example
+ * // Get current axes
+ * chart.data.axes();
+ *
+ * // Update axes
+ * chart.data.axes({
+ * data1: "y",
+ * data2: "y2"
+ * });
+ */
+ axes: function axes(_axes) {
+ return this.internal.updateDataAttributes("axes", _axes);
+ }
+}), (0, _util.extend)(_Chart2.default.prototype, { data: data });
+
+/***/ }),
+/* 69 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _Chart = __webpack_require__(1),
+ _Chart2 = _interopRequireDefault(_Chart),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_Chart2.default.prototype, {
+ /**
+ * Set specified category name on category axis.
+ * @method category
+ * @instance
+ * @memberOf Chart
+ * @param {Number} i index of category to be changed
+ * @param {String} category category value to be changed
+ * @example
+ * chart.category(2, "Category 3");
+ */
+ category: function category(i, _category) {
+ var $$ = this.internal,
+ config = $$.config;
+
+
+ return arguments.length > 1 && (config.axis_x_categories[i] = _category, $$.redraw()), config.axis_x_categories[i];
+ },
+
+
+ /**
+ * Set category names on category axis.
+ * @method categories
+ * @instance
+ * @memberOf Chart
+ * @param {Array} categories This must be an array that includes category names in string. If category names are included in the date by data.x option, this is not required.
+ * @example
+ * chart.categories([
+ * "Category 1", "Category 2", ...
+ * ]);
+ */
+ categories: function categories(_categories) {
+ var $$ = this.internal,
+ config = $$.config;
+ return arguments.length ? (config.axis_x_categories = _categories, $$.redraw(), config.axis_x_categories) : config.axis_x_categories;
+ }
+});
+
+/***/ }),
+/* 70 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _Chart = __webpack_require__(1),
+ _Chart2 = _interopRequireDefault(_Chart),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_Chart2.default.prototype, {
+ /**
+ * Get the color
+ * @method color
+ * @instance
+ * @memberOf Chart
+ * @param {String} id id to get the color
+ * @example
+ * chart.color("data1");
+ */
+ color: function color(id) {
+ return this.internal.color(id); // more patterns
+ }
+});
+
+/***/ }),
+/* 71 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _Chart = __webpack_require__(1),
+ _Chart2 = _interopRequireDefault(_Chart),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_Chart2.default.prototype, {
+ /**
+ * Get and set x values for the chart.
+ * @method x
+ * @instance
+ * @memberOf Chart
+ * @param {Array} x If x is given, x values of every target will be updated. If no argument is given, current x values will be returned as an Object whose keys are the target ids.
+ * @return {Object} xs
+ * @example
+ * // Get current x values
+ * chart.x();
+ *
+ * // Update x values for all targets
+ * chart.x([100, 200, 300, 400, ...]);
+ */
+ x: function x(_x) {
+ var $$ = this.internal;
+
+ return arguments.length && ($$.updateTargetX($$.data.targets, _x), $$.redraw({
+ withUpdateOrgXDomain: !0,
+ withUpdateXDomain: !0
+ })), $$.data.xs;
+ },
+
+
+ /**
+ * Get and set x values for the chart.
+ * @method xs
+ * @instance
+ * @memberOf Chart
+ * @param {Array} xs If xs is given, specified target's x values will be updated. If no argument is given, current x values will be returned as an Object whose keys are the target ids.
+ * @return {Object} xs
+ * @example
+ * // Get current x values
+ * chart.xs();
+ *
+ * // Update x values for all targets
+ * chart.xs({
+ * data1: [10, 20, 30, 40, ...],
+ * data2: [100, 200, 300, 400, ...]
+ * });
+ */
+ xs: function xs(_xs) {
+ var $$ = this.internal;
+
+ return arguments.length && ($$.updateTargetXs($$.data.targets, _xs), $$.redraw({
+ withUpdateOrgXDomain: !0,
+ withUpdateXDomain: !0
+ })), $$.data.xs;
+ }
+});
+
+/***/ }),
+/* 72 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _Chart = __webpack_require__(1),
+ _Chart2 = _interopRequireDefault(_Chart),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Set the min/max value
+ * @param {Chart} $$
+ * @param {String} type
+ * @param {Object} value
+ * @return {undefined}
+ * @private
+ */
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+var setMinMax = function ($$, type, value) {
+ var config = $$.config,
+ axisY = "axis_y_" + type,
+ axisY2 = "axis_y2_" + type;
+
+
+ return (0, _util.isDefined)(value) && ((0, _util.isObjectType)(value) ? ((0, _util.isValue)(value.x) && (config["axis_x_" + type] = value.x), (0, _util.isValue)(value.y) && (config[axisY] = value.y), (0, _util.isValue)(value.y2) && (config[axisY2] = value.y2)) : (config[axisY] = value, config[axisY2] = value), $$.redraw({
+ withUpdateOrgXDomain: !0,
+ withUpdateXDomain: !0
+ })), undefined;
+},
+ getMinMax = function ($$, type) {
+ var config = $$.config;
+
+
+ return {
+ x: config["axis_x_" + type],
+ y: config["axis_y_" + type],
+ y2: config["axis_y2_" + type]
+ };
+},
+ axis = (0, _util.extend)(function () {}, {
+ /**
+ * Get and set axis labels.
+ * @method axis․labels
+ * @instance
+ * @memberOf Chart
+ * @param {Object} labels specified axis' label to be updated.
+ * @example
+ * // Update axis' label
+ * chart.axis.labels({
+ * x: "New X Axis Label",
+ * y: "New Y Axis Label"
+ * });
+ */
+ labels: function labels(_labels) {
+ var $$ = this.internal;
+
+ arguments.length && (Object.keys(_labels).forEach(function (axisId) {
+ $$.axis.setLabelText(axisId, _labels[axisId]);
+ }), $$.axis.updateLabels());
+ },
+
+ /**
+ * Get and set axis min value.
+ * @method axis․min
+ * @instance
+ * @memberOf Chart
+ * @param {Object} min If min is given, specified axis' min value will be updated.<br>
+ * If no argument is given, the min values set on generating option for each axis will be returned.
+ * If not set any min values on generation, it will return `undefined`.
+ * @example
+ * // Update axis' min
+ * chart.axis.min({
+ * x: -10,
+ * y: 1000,
+ * y2: 100
+ * });
+ */
+ min: function min(_min) {
+ var $$ = this.internal;
+
+ return arguments.length ? setMinMax($$, "min", _min) : getMinMax($$, "min");
+ },
+
+ /**
+ * Get and set axis max value.
+ * @method axis․max
+ * @instance
+ * @memberOf Chart
+ * @param {Object} max If max is given, specified axis' max value will be updated.<br>
+ * If no argument is given, the max values set on generating option for each axis will be returned.
+ * If not set any max values on generation, it will return `undefined`.
+ * @example
+ * // Update axis' label
+ * chart.axis.max({
+ * x: 100,
+ * y: 1000,
+ * y2: 10000
+ * });
+ */
+ max: function max(_max) {
+ var $$ = this.internal;
+
+ return arguments.length ? setMinMax($$, "max", _max) : getMinMax($$, "max");
+ },
+
+ /**
+ * Get and set axis min and max value.
+ * @method axis․range
+ * @instance
+ * @memberOf Chart
+ * @param {Object} range If range is given, specified axis' min and max value will be updated. If no argument is given, the current min and max values for each axis will be returned.
+ * @example
+ * // Update axis' label
+ * chart.axis.range({
+ * min: {
+ * x: -10,
+ * y: -1000,
+ * y2: -10000
+ * },
+ * max: {
+ * x: 100,
+ * y: 1000,
+ * y2: 10000
+ * },
+ * });
+ */
+ range: function range(_range) {
+ var axis = this.axis;
+
+ if (arguments.length) (0, _util.isDefined)(_range.max) && axis.max(_range.max), (0, _util.isDefined)(_range.min) && axis.min(_range.min);else return {
+ max: axis.max(),
+ min: axis.min()
+ };
+
+ return undefined;
+ }
+});
+
+/**
+ * Get the min/max value
+ * @param {Chart} $$
+ * @param {String} type
+ * @return {{x, y, y2}}
+ * @private
+ */
+
+
+/**
+ * Define axis
+ * @ignore
+ */
+
+
+(0, _util.extend)(_Chart2.default.prototype, { axis: axis });
+
+/***/ }),
+/* 73 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _Chart = __webpack_require__(1),
+ _Chart2 = _interopRequireDefault(_Chart),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Define legend
+ * @ignore
+ */
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+var legend = (0, _util.extend)(function () {}, {
+ /**
+ * Show legend for each target.
+ * @method legend․show
+ * @instance
+ * @memberOf Chart
+ * @param {String|Array} targetIds
+ * - If targetIds is given, specified target's legend will be shown.
+ * - If only one target is the candidate, String can be passed.
+ * - If no argument is given, all of target's legend will be shown.
+ * @example
+ * // Show legend for data1.
+ * chart.legend.show("data1");
+ *
+ * // Show legend for data1 and data2.
+ * chart.legend.show(["data1", "data2"]);
+ *
+ * // Show all legend.
+ * chart.legend.show();
+ */
+ show: function show(targetIds) {
+ var $$ = this.internal;
+
+ $$.showLegend($$.mapToTargetIds(targetIds)), $$.updateAndRedraw({ withLegend: !0 });
+ },
+
+ /**
+ * Hide legend for each target.
+ * @method legend․hide
+ * @instance
+ * @memberOf Chart
+ * @param {String|Array} targetIds
+ * - If targetIds is given, specified target's legend will be hidden.
+ * - If only one target is the candidate, String can be passed.
+ * - If no argument is given, all of target's legend will be hidden.
+ * @example
+ * // Hide legend for data1.
+ * chart.legend.hide("data1");
+ *
+ * // Hide legend for data1 and data2.
+ * chart.legend.hide(["data1", "data2"]);
+ *
+ * // Hide all legend.
+ * chart.legend.hide();
+ */
+ hide: function hide(targetIds) {
+ var $$ = this.internal;
+
+ $$.hideLegend($$.mapToTargetIds(targetIds)), $$.updateAndRedraw({ withLegend: !0 });
+ }
+});
+
+(0, _util.extend)(_Chart2.default.prototype, { legend: legend });
+
+/***/ }),
+/* 74 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Selection = __webpack_require__(5),
+ _Chart = __webpack_require__(1),
+ _Chart2 = _interopRequireDefault(_Chart),
+ _browser = __webpack_require__(75),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+(0, _util.extend)(_Chart2.default.prototype, {
+ /**
+ * Resize the chart.
+ * @method resize
+ * @instance
+ * @memberOf Chart
+ * @param {Object} size This argument should include width and height in pixels.
+ * @example
+ * // Resize to 640x480
+ * chart.resize({
+ * width: 640,
+ * height: 480
+ * });
+ */
+ resize: function resize(size) {
+ var config = this.internal.config;
+
+ config.size_width = size ? size.width : null, config.size_height = size ? size.height : null, this.flush();
+ },
+
+
+ /**
+ * Force to redraw.
+ * @method flush
+ * @instance
+ * @memberOf Chart
+ * @param {Boolean} [soft] For soft redraw.
+ * @example
+ * chart.flush();
+ *
+ * // for soft redraw
+ * chart.flush(true);
+ */
+ flush: function flush(soft) {
+ var $$ = this.internal;
+
+ // reset possible zoom scale
+ $$.zoomScale = null, soft ? $$.redraw({
+ withTransform: !0,
+ withUpdateXDomain: !0,
+ withUpdateOrgXDomain: !0,
+ withLegend: !0
+ }) : $$.updateAndRedraw({
+ withLegend: !0,
+ withTransition: !1,
+ withTransitionForTransform: !1
+ });
+ },
+
+
+ /**
+ * Reset the chart object and remove element and events completely.
+ * @method destroy
+ * @instance
+ * @memberOf Chart
+ * @example
+ * chart.destroy();
+ */
+ destroy: function destroy() {
+ var _this = this,
+ $$ = this.internal;
+
+ return (0, _util.notEmpty)($$) && ($$.charts.splice($$.charts.indexOf(this), 1), (0, _util.isDefined)($$.resizeTimeout) && _browser.window.clearTimeout($$.resizeTimeout), (0, _d3Selection.select)(_browser.window).on("resize.bb", null), $$.selectChart.classed("bb", !1).html(""), Object.keys(this).forEach(function (key) {
+ key === "internal" && Object.keys($$).forEach(function (k) {
+ $$[k] = null;
+ }), _this[key] = null, delete _this[key];
+ })), null;
+ },
+
+
+ /**
+ * Get or set single config option value.
+ * @method config
+ * @instance
+ * @memberOf Chart
+ * @param {String} name The option key name.
+ * @param {*} [value] The value accepted for indicated option.
+ * @param {Boolean} [redraw] Set to redraw with the new option changes.
+ * - **NOTE:** Doesn't guarantee work in all circumstances. It can be applied for limited options only.
+ * @example
+ * // Getter
+ * chart.config("gauge.max");
+ *
+ * // Setter
+ * chart.config("gauge.max", 100);
+ *
+ * // Setter & redraw with the new option
+ * chart.config("gauge.max", 100, true);
+ */
+ config: function config(name, value, redraw) {
+ var $$ = this.internal,
+ key = name && name.replace(/\./g, "_"),
+ res = void 0;
+
+
+ return key in $$.config && ((0, _util.isDefined)(value) ? ($$.config[key] = value, res = value, redraw && this.flush(!0)) : res = $$.config[key]), res;
+ }
+});
+
+/***/ }),
+/* 75 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+exports.__esModule = !0;
+exports.document = exports.window = undefined;
+
+var _util = __webpack_require__(11),
+ win = (0, _util.isDefined)(window) && window.Math === Math ? window : (0, _util.isDefined)(self) && (self.Math === Math ? self : Function("return this")()),
+ doc = win.document;
+
+/**
+ * Window object
+ * @module
+ * @ignore
+ */
+/* eslint-disable no-new-func */
+
+
+/* eslint-enable no-new-func */
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+exports.window = win;
+exports.document = doc;
+
+/***/ }),
+/* 76 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _Chart = __webpack_require__(1),
+ _Chart2 = _interopRequireDefault(_Chart),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Define tooltip
+ * @ignore
+ */
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+var tooltip = (0, _util.extend)(function () {}, {
+ /**
+ * Show tooltip
+ * @method tooltip․show
+ * @instance
+ * @memberOf Chart
+ * @param {Object} args The object can consist with following members:<br>
+ *
+ * | Key | Type | Description |
+ * | --- | --- | --- |
+ * | index | Number | Determine focus by index |
+ * | x | Number | Date | Determine focus by x Axis index |
+ * | data | Object | Determine focus data with following keys: `x` or `index`.<br>When [data.xs](Options.html#.data%25E2%2580%25A4xs) option is set, the target is determined by mouse position and needs specify `x`, `id` and `value`. |
+ * | mouse | Array | Determine x and y coordinate value relative the targeted x Axis element.<br>It should be used along with `data`, `index` or `x` value. The default value is set as `[0,0]` |
+ *
+ * @example
+ * // show the 2nd x Axis coordinate tooltip
+ * chart.tooltip.show({
+ * index: 1
+ * });
+ *
+ * // show tooltip for the 3rd x Axis in x:50 and y:100 coordinate relative the x Axis element.
+ * chart.tooltip.show({
+ * data: {x: 2},
+ * mouse: [50, 100]
+ * });
+ *
+ * // show tooltip for timeseries x axis
+ * chart.tooltip.show({
+ * x: new Date("2018-01-02 00:00")
+ * });
+ */
+ show: function show() {
+ var args = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
+ $$ = this.internal,
+ index = void 0,
+ mouse = void 0;
+
+
+ // determine mouse position on the chart
+ args.mouse && (mouse = args.mouse), args.data ? $$.isMultipleX() ? (mouse = [$$.x(args.data.x), $$.getYScale(args.data.id)(args.data.value)], index = null) : index = (0, _util.isValue)(args.data.index) ? args.data.index : $$.getIndexByX(args.data.x) : (0, _util.isDefined)(args.x) ? index = $$.getIndexByX(args.x) : (0, _util.isDefined)(args.index) && (index = args.index), ($$.inputType === "mouse" ? ["mouseover", "mousemove"] : ["touchstart"]).forEach(function (eventName) {
+ $$.dispatchEvent(eventName, index, mouse);
+ });
+ },
+
+ /**
+ * Hide tooltip
+ * @method tooltip․hide
+ * @instance
+ * @memberOf Chart
+ */
+ hide: function hide() {
+ var $$ = this.internal;
+
+ $$.hideTooltip(), $$.hideXGridFocus(), $$.unexpandCircles(), $$.unexpandBars();
+ }
+});
+
+(0, _util.extend)(_Chart2.default.prototype, { tooltip: tooltip });
+
+/***/ }),
+/* 77 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _ChartInternal = __webpack_require__(3),
+ _ChartInternal2 = _interopRequireDefault(_ChartInternal),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+var ua = window.navigator.userAgent;
+
+(0, _util.extend)(_ChartInternal2.default.prototype, {
+ isSafari: function isSafari() {
+ return ua.indexOf("Safari") > -1 && !this.isChrome();
+ },
+ isChrome: function isChrome() {
+ return ua.indexOf("Chrome") > -1;
+ },
+ isMobile: function isMobile() {
+ // https://developer.mozilla.org/en-US/docs/Web/HTTP/Browser_detection_using_the_user_agent
+ return ua.indexOf("Mobi") > -1;
+ }
+});
+
+/***/ }),
+/* 78 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _d3Selection = __webpack_require__(5),
+ _Chart = __webpack_require__(1),
+ _Chart2 = _interopRequireDefault(_Chart),
+ _util = __webpack_require__(11);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Encode to base64
+ * @param {String} str
+ * @return {String}
+ * @private
+ * @see https://developer.mozilla.org/ko/docs/Web/API/WindowBase64/Base64_encoding_and_decoding
+ */
+var b64EncodeUnicode = function (str) {
+ return btoa(encodeURIComponent(str).replace(/%([0-9A-F]{2})/g, function (match, p) {
+ return String.fromCharCode("0x" + p);
+ }));
+},
+ nodeToSvgDataUrl = function (node) {
+ var bounds = node.getBoundingClientRect(),
+ clone = node.cloneNode(!0),
+ styleSheets = (0, _util.toArray)(document.styleSheets),
+ cssRules = (0, _util.getCssRules)(styleSheets),
+ cssText = cssRules.filter(function (r) {
+ return r.cssText;
+ }).map(function (r) {
+ return r.cssText;
+ });
+ clone.setAttribute("xmlns", _d3Selection.namespaces.xhtml);
+ var nodeXml = new XMLSerializer().serializeToString(clone),
+ dataStr = ("<svg xmlns=\"" + _d3Selection.namespaces.svg + "\" width=\"" + bounds.width + "\" height=\"" + bounds.height + "\">\n\t\t\t<foreignObject width=\"100%\" height=\"100%\">\n\t\t\t\t<style>" + cssText.join("\n") + "</style>\n\t\t\t\t" + nodeXml + "\n\t\t\t</foreignObject></svg>").replace(/#/g, "%23").replace("/\n/g", "%0A");
+
+ // foreignObject not supported in IE11 and below
+ // https://msdn.microsoft.com/en-us/library/hh834675(v=vs.85).aspx
+
+ return "data:image/svg+xml;base64," + b64EncodeUnicode(dataStr);
+};
+
+/**
+ * Convert svg node to data url
+ * @param {HTMLElement} node
+ * @return {String}
+ * @private
+ */
+/**
+ * Copyright (c) 2017 NAVER Corp.
+ * billboard.js project is licensed under the MIT license
+ */
+
+
+(0, _util.extend)(_Chart2.default.prototype, {
+ /**
+ * Export chart as an image.
+ * - **NOTE:**
+ * - IE11 and below not work properly due to the lack of the feature(<a href="https://msdn.microsoft.com/en-us/library/hh834675(v=vs.85).aspx">foreignObject</a>) support
+ * - The basic CSS file(ex. billboard.css) should be at same domain as API call context to get correct styled export image.
+ * @method export
+ * @instance
+ * @memberOf Chart
+ * @param {String} [mimeType=image/png] The desired output image format. (ex. 'image/png' for png, 'image/jpeg' for jpeg format)
+ * @param {Function} [callback] The callback to be invoked when export is ready.
+ * @return {String} dataURI
+ * @example
+ * chart.export();
+ * // --> "..."
+ *
+ * // Initialize the download automatically
+ * chart.export("image/png", dataUrl => {
+ * const link = document.createElement("a");
+ *
+ * link.download = `${Date.now()}.png`;
+ * link.href = dataUrl;
+ * link.innerHTML = "Download chart as image";
+ *
+ * document.body.appendChild(link);
+ * });
+ */
+ export: function _export() {
+ var mimeType = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : "image/png",
+ callback = arguments[1],
+ svgDataUrl = nodeToSvgDataUrl(this.element);
+
+
+ if ((0, _util.isFunction)(callback)) {
+ var img = new Image();
+
+ img.crosssOrigin = "Anonymous", img.onload = function () {
+ var canvas = document.createElement("canvas"),
+ ctx = canvas.getContext("2d");
+ canvas.width = img.width, canvas.height = img.height, ctx.drawImage(img, 0, 0), canvas.toBlob(function (blob) {
+ callback(window.URL.createObjectURL(blob));
+ }, mimeType);
+ }, img.src = svgDataUrl;
+ }
+
+ return svgDataUrl;
+ }
+});
+
+/***/ })
+/******/ ]);
+});
+//# sourceMappingURL=billboard.js.map
+
+