/* YUI 3.17.2 (build 9c3c78e) Copyright 2014 Yahoo! Inc. All rights reserved. Licensed under the BSD License. http://yuilibrary.com/license/ */ YUI.add('series-base', function (Y, NAME) { /** * Provides functionality for creating a chart series. * * @module charts * @submodule series-base */ /** * An abstract class for creating series instances. * SeriesBase is used by the following classes: * * * @class SeriesBase * @extends Base * @uses Renderer * @constructor * @param {Object} config (optional) Configuration parameters. * @submodule series-base */ Y.SeriesBase = Y.Base.create("seriesBase", Y.Base, [Y.Renderer], { /** * @method render * @private */ render: function() { this._setCanvas(); this.addListeners(); this.validate(); }, /** * Creates a `Graphic` instance. * * @method _setCanvas * @protected */ _setCanvas: function() { var graph = this.get("graph"), graphic = graph.get("graphic"); this.set("graphic", graphic); }, /** * Returns a reference to the parent container to which all chart elements are contained. * When the series is bound to a `Chart` instance, the `Chart` instance is the reference. * If nothing is set as the `chart` attribute, the `_getChart` method will return a reference * to the `graphic` attribute. * * @method _getChart * @return {Object} * @private */ _getChart:function() { var chart, graph = this.get("graph"); if(graph) { chart = graph.get("chart"); } if(!chart) { chart = this.get("graphic"); } return chart; }, /** * Returns the sum of all values for the series. * * @method getTotalValues * @return Number */ getTotalValues: function() { var valueCoord = this.get("direction") === "vertical" ? "x" : "y", total = this.get(valueCoord + "Axis").getTotalByKey(this.get(valueCoord + "Key")); return total; }, /** * Gets the default value for the `styles` attribute. Overrides * base implementation. * * @method _getDefaultStyles * @return Object * @protected */ _getDefaultStyles: function() { return {padding:{ top: 0, left: 0, right: 0, bottom: 0 }}; }, /** * Shows/hides contents of the series. * * @method _handleVisibleChange * @param {Object} e Event object. * @protected */ _handleVisibleChange: function() { this._toggleVisible(this.get("visible")); }, /** * Destructor implementation for the CartesianSeries class. Calls destroy on all Graphic instances. * * @method destructor * @protected */ destructor: function() { var marker, markers = this.get("markers"); if(this.get("rendered")) { if(this._stylesChangeHandle) { this._stylesChangeHandle.detach(); } if(this._widthChangeHandle) { this._widthChangeHandle.detach(); } if(this._heightChangeHandle) { this._heightChangeHandle.detach(); } if(this._visibleChangeHandle) { this._visibleChangeHandle.detach(); } } while(markers && markers.length > 0) { marker = markers.shift(); if(marker && marker instanceof Y.Shape) { marker.destroy(); } } if(this._path) { this._path.destroy(); this._path = null; } if(this._lineGraphic) { this._lineGraphic.destroy(); this._lineGraphic = null; } if(this._groupMarker) { this._groupMarker.destroy(); this._groupMarker = null; } }, /** * Collection of default colors used for lines in a series when not specified by user. * * @property _defaultLineColors * @type Array * @protected */ _defaultLineColors:[ "#426ab3", "#d09b2c", "#000000", "#b82837", "#b384b5", "#ff7200", "#779de3", "#cbc8ba", "#7ed7a6", "#007a6c" ], /** * Collection of default colors used for marker fills in a series when not specified by user. * * @property _defaultFillColors * @type Array * @protected */ _defaultFillColors:[ "#6084d0", "#eeb647", "#6c6b5f", "#d6484f", "#ce9ed1", "#ff9f3b", "#93b7ff", "#e0ddd0", "#94ecba", "#309687" ], /** * Collection of default colors used for marker borders in a series when not specified by user. * * @property _defaultBorderColors * @type Array * @protected */ _defaultBorderColors:[ "#205096", "#b38206", "#000000", "#94001e", "#9d6fa0", "#e55b00", "#5e85c9", "#adab9e", "#6ac291", "#006457" ], /** * Collection of default colors used for area fills, histogram fills and pie fills in a series when not specified by user. * * @property _defaultSliceColors * @type Array * @protected */ _defaultSliceColors: [ "#66007f", "#a86f41", "#295454", "#996ab2", "#e8cdb7", "#90bdbd", "#000000", "#c3b8ca", "#968373", "#678585" ], /** * Parses a color based on a series order and type. * * @method _getDefaultColor * @param {Number} index Index indicating the series order. * @param {String} type Indicates which type of object needs the color. * @return String * @protected */ _getDefaultColor: function(index, type) { var colors = { line: this._defaultLineColors, fill: this._defaultFillColors, border: this._defaultBorderColors, slice: this._defaultSliceColors }, col = colors[type] || colors.fill, l = col.length; index = index || 0; if(index >= l) { index = index % l; } type = type || "fill"; return colors[type][index]; } }, { ATTRS: { /* * Returns the width of the parent graph * * @attribute width * @type Number */ width: { readOnly: true, getter: function() { return this.get("graphic").get("width"); } }, /** * Returns the height of the parent graph * * @attribute height * @type Number */ height: { readOnly: true, getter: function() { return this.get("graphic").get("height"); } }, /** * The graphic in which drawings will be rendered. * * @attribute graphic * @type Graphic */ graphic: { lazyAdd: false, setter: function(val) { //woraround for Attribute order of operations bug if(!this.get("rendered")) { this.set("rendered", true); } return val; } }, /** * Reference to the `Chart` application. If no `Chart` application is present, * a reference to the `Graphic` instance that the series is drawn into will be returned. * * @attribute chart * @type ChartBase */ chart: { getter: function() { var chart, graph = this.get("graph"); if(graph) { chart = graph.get("chart"); } return chart; } }, /** * Reference to the `Graph` in which the series is drawn into. * * @attribute graph * @type Graph */ graph: {}, /** * Indicates whether the Series has been through its initial set up. * * @attribute rendered * @type Boolean */ rendered: { value: false }, /** * Indicates whether to show the series * * @attribute visible * @type Boolean * @default true */ visible: { value: true }, /** * Indicates whether or not markers for a series will be grouped and rendered in a single complex shape instance. * * @attribute groupMarkers * @type Boolean */ groupMarkers: { getter: function() { var graph, groupMarkers = this._groupMarkers; if(!groupMarkers) { graph = this.get("graph"); if(graph) { groupMarkers = graph.get("groupMarkers"); } } return groupMarkers; }, setter: function(val) { this._groupMarkers = val; return val; } } } }); }, '3.17.2', {"requires": ["graphics", "axis-base"]});