|   | 
| /* | 
| * Licensed to the Apache Software Foundation (ASF) under one | 
| * or more contributor license agreements.  See the NOTICE file | 
| * distributed with this work for additional information | 
| * regarding copyright ownership.  The ASF licenses this file | 
| * to you under the Apache License, Version 2.0 (the | 
| * "License"); you may not use this file except in compliance | 
| * with the License.  You may obtain a copy of the License at | 
| * | 
| *   http://www.apache.org/licenses/LICENSE-2.0 | 
| * | 
| * Unless required by applicable law or agreed to in writing, | 
| * software distributed under the License is distributed on an | 
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY | 
| * KIND, either express or implied.  See the License for the | 
| * specific language governing permissions and limitations | 
| * under the License. | 
| */ | 
|   | 
|   | 
| /** | 
|  * AUTO-GENERATED FILE. DO NOT MODIFY. | 
|  */ | 
|   | 
| /* | 
| * Licensed to the Apache Software Foundation (ASF) under one | 
| * or more contributor license agreements.  See the NOTICE file | 
| * distributed with this work for additional information | 
| * regarding copyright ownership.  The ASF licenses this file | 
| * to you under the Apache License, Version 2.0 (the | 
| * "License"); you may not use this file except in compliance | 
| * with the License.  You may obtain a copy of the License at | 
| * | 
| *   http://www.apache.org/licenses/LICENSE-2.0 | 
| * | 
| * Unless required by applicable law or agreed to in writing, | 
| * software distributed under the License is distributed on an | 
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY | 
| * KIND, either express or implied.  See the License for the | 
| * specific language governing permissions and limitations | 
| * under the License. | 
| */ | 
| /* global Int32Array */ | 
| import * as zrUtil from 'zrender/lib/core/util.js'; | 
| import Model from '../model/Model.js'; | 
| import DataDiffer from './DataDiffer.js'; | 
| import { DefaultDataProvider } from './helper/dataProvider.js'; | 
| import { summarizeDimensions } from './helper/dimensionHelper.js'; | 
| import SeriesDimensionDefine from './SeriesDimensionDefine.js'; | 
| import { SOURCE_FORMAT_TYPED_ARRAY, SOURCE_FORMAT_ORIGINAL } from '../util/types.js'; | 
| import { convertOptionIdName, isDataItemOption } from '../util/model.js'; | 
| import { setCommonECData } from '../util/innerStore.js'; | 
| import { isSourceInstance } from './Source.js'; | 
| import DataStore from './DataStore.js'; | 
| import { isSeriesDataSchema } from './helper/SeriesDataSchema.js'; | 
| var isObject = zrUtil.isObject; | 
| var map = zrUtil.map; | 
| var CtorInt32Array = typeof Int32Array === 'undefined' ? Array : Int32Array; | 
| // Use prefix to avoid index to be the same as otherIdList[idx], | 
| // which will cause weird update animation. | 
| var ID_PREFIX = 'e\0\0'; | 
| var INDEX_NOT_FOUND = -1; | 
| // type SeriesDimensionIndex = DimensionIndex; | 
| var TRANSFERABLE_PROPERTIES = ['hasItemOption', '_nameList', '_idList', '_invertedIndicesMap', '_dimSummary', 'userOutput', '_rawData', '_dimValueGetter', '_nameDimIdx', '_idDimIdx', '_nameRepeatCount']; | 
| var CLONE_PROPERTIES = ['_approximateExtent']; | 
| // ----------------------------- | 
| // Internal method declarations: | 
| // ----------------------------- | 
| var prepareInvertedIndex; | 
| var getId; | 
| var getIdNameFromStore; | 
| var normalizeDimensions; | 
| var transferProperties; | 
| var cloneListForMapAndSample; | 
| var makeIdFromName; | 
| var SeriesData = /** @class */function () { | 
|   /** | 
|    * @param dimensionsInput.dimensions | 
|    *        For example, ['someDimName', {name: 'someDimName', type: 'someDimType'}, ...]. | 
|    *        Dimensions should be concrete names like x, y, z, lng, lat, angle, radius | 
|    */ | 
|   function SeriesData(dimensionsInput, hostModel) { | 
|     this.type = 'list'; | 
|     this._dimOmitted = false; | 
|     this._nameList = []; | 
|     this._idList = []; | 
|     // Models of data option is stored sparse for optimizing memory cost | 
|     // Never used yet (not used yet). | 
|     // private _optionModels: Model[] = []; | 
|     // Global visual properties after visual coding | 
|     this._visual = {}; | 
|     // Global layout properties. | 
|     this._layout = {}; | 
|     // Item visual properties after visual coding | 
|     this._itemVisuals = []; | 
|     // Item layout properties after layout | 
|     this._itemLayouts = []; | 
|     // Graphic elements | 
|     this._graphicEls = []; | 
|     // key: dim, value: extent | 
|     this._approximateExtent = {}; | 
|     this._calculationInfo = {}; | 
|     // Having detected that there is data item is non primitive type | 
|     // (in type `OptionDataItemObject`). | 
|     // Like `data: [ { value: xx, itemStyle: {...} }, ...]` | 
|     // At present it only happen in `SOURCE_FORMAT_ORIGINAL`. | 
|     this.hasItemOption = false; | 
|     // Methods that create a new list based on this list should be listed here. | 
|     // Notice that those method should `RETURN` the new list. | 
|     this.TRANSFERABLE_METHODS = ['cloneShallow', 'downSample', 'minmaxDownSample', 'lttbDownSample', 'map']; | 
|     // Methods that change indices of this list should be listed here. | 
|     this.CHANGABLE_METHODS = ['filterSelf', 'selectRange']; | 
|     this.DOWNSAMPLE_METHODS = ['downSample', 'minmaxDownSample', 'lttbDownSample']; | 
|     var dimensions; | 
|     var assignStoreDimIdx = false; | 
|     if (isSeriesDataSchema(dimensionsInput)) { | 
|       dimensions = dimensionsInput.dimensions; | 
|       this._dimOmitted = dimensionsInput.isDimensionOmitted(); | 
|       this._schema = dimensionsInput; | 
|     } else { | 
|       assignStoreDimIdx = true; | 
|       dimensions = dimensionsInput; | 
|     } | 
|     dimensions = dimensions || ['x', 'y']; | 
|     var dimensionInfos = {}; | 
|     var dimensionNames = []; | 
|     var invertedIndicesMap = {}; | 
|     var needsHasOwn = false; | 
|     var emptyObj = {}; | 
|     for (var i = 0; i < dimensions.length; i++) { | 
|       // Use the original dimensions[i], where other flag props may exists. | 
|       var dimInfoInput = dimensions[i]; | 
|       var dimensionInfo = zrUtil.isString(dimInfoInput) ? new SeriesDimensionDefine({ | 
|         name: dimInfoInput | 
|       }) : !(dimInfoInput instanceof SeriesDimensionDefine) ? new SeriesDimensionDefine(dimInfoInput) : dimInfoInput; | 
|       var dimensionName = dimensionInfo.name; | 
|       dimensionInfo.type = dimensionInfo.type || 'float'; | 
|       if (!dimensionInfo.coordDim) { | 
|         dimensionInfo.coordDim = dimensionName; | 
|         dimensionInfo.coordDimIndex = 0; | 
|       } | 
|       var otherDims = dimensionInfo.otherDims = dimensionInfo.otherDims || {}; | 
|       dimensionNames.push(dimensionName); | 
|       dimensionInfos[dimensionName] = dimensionInfo; | 
|       if (emptyObj[dimensionName] != null) { | 
|         needsHasOwn = true; | 
|       } | 
|       if (dimensionInfo.createInvertedIndices) { | 
|         invertedIndicesMap[dimensionName] = []; | 
|       } | 
|       if (otherDims.itemName === 0) { | 
|         this._nameDimIdx = i; | 
|       } | 
|       if (otherDims.itemId === 0) { | 
|         this._idDimIdx = i; | 
|       } | 
|       if (process.env.NODE_ENV !== 'production') { | 
|         zrUtil.assert(assignStoreDimIdx || dimensionInfo.storeDimIndex >= 0); | 
|       } | 
|       if (assignStoreDimIdx) { | 
|         dimensionInfo.storeDimIndex = i; | 
|       } | 
|     } | 
|     this.dimensions = dimensionNames; | 
|     this._dimInfos = dimensionInfos; | 
|     this._initGetDimensionInfo(needsHasOwn); | 
|     this.hostModel = hostModel; | 
|     this._invertedIndicesMap = invertedIndicesMap; | 
|     if (this._dimOmitted) { | 
|       var dimIdxToName_1 = this._dimIdxToName = zrUtil.createHashMap(); | 
|       zrUtil.each(dimensionNames, function (dimName) { | 
|         dimIdxToName_1.set(dimensionInfos[dimName].storeDimIndex, dimName); | 
|       }); | 
|     } | 
|   } | 
|   /** | 
|    * | 
|    * Get concrete dimension name by dimension name or dimension index. | 
|    * If input a dimension name, do not validate whether the dimension name exits. | 
|    * | 
|    * @caution | 
|    * @param dim Must make sure the dimension is `SeriesDimensionLoose`. | 
|    * Because only those dimensions will have auto-generated dimension names if not | 
|    * have a user-specified name, and other dimensions will get a return of null/undefined. | 
|    * | 
|    * @notice Because of this reason, should better use `getDimensionIndex` instead, for examples: | 
|    * ```js | 
|    * const val = data.getStore().get(data.getDimensionIndex(dim), dataIdx); | 
|    * ``` | 
|    * | 
|    * @return Concrete dim name. | 
|    */ | 
|   SeriesData.prototype.getDimension = function (dim) { | 
|     var dimIdx = this._recognizeDimIndex(dim); | 
|     if (dimIdx == null) { | 
|       return dim; | 
|     } | 
|     dimIdx = dim; | 
|     if (!this._dimOmitted) { | 
|       return this.dimensions[dimIdx]; | 
|     } | 
|     // Retrieve from series dimension definition because it probably contains | 
|     // generated dimension name (like 'x', 'y'). | 
|     var dimName = this._dimIdxToName.get(dimIdx); | 
|     if (dimName != null) { | 
|       return dimName; | 
|     } | 
|     var sourceDimDef = this._schema.getSourceDimension(dimIdx); | 
|     if (sourceDimDef) { | 
|       return sourceDimDef.name; | 
|     } | 
|   }; | 
|   /** | 
|    * Get dimension index in data store. Return -1 if not found. | 
|    * Can be used to index value from getRawValue. | 
|    */ | 
|   SeriesData.prototype.getDimensionIndex = function (dim) { | 
|     var dimIdx = this._recognizeDimIndex(dim); | 
|     if (dimIdx != null) { | 
|       return dimIdx; | 
|     } | 
|     if (dim == null) { | 
|       return -1; | 
|     } | 
|     var dimInfo = this._getDimInfo(dim); | 
|     return dimInfo ? dimInfo.storeDimIndex : this._dimOmitted ? this._schema.getSourceDimensionIndex(dim) : -1; | 
|   }; | 
|   /** | 
|    * The meanings of the input parameter `dim`: | 
|    * | 
|    * + If dim is a number (e.g., `1`), it means the index of the dimension. | 
|    *   For example, `getDimension(0)` will return 'x' or 'lng' or 'radius'. | 
|    * + If dim is a number-like string (e.g., `"1"`): | 
|    *     + If there is the same concrete dim name defined in `series.dimensions` or `dataset.dimensions`, | 
|    *        it means that concrete name. | 
|    *     + If not, it will be converted to a number, which means the index of the dimension. | 
|    *        (why? because of the backward compatibility. We have been tolerating number-like string in | 
|    *        dimension setting, although now it seems that it is not a good idea.) | 
|    *     For example, `visualMap[i].dimension: "1"` is the same meaning as `visualMap[i].dimension: 1`, | 
|    *     if no dimension name is defined as `"1"`. | 
|    * + If dim is a not-number-like string, it means the concrete dim name. | 
|    *   For example, it can be be default name `"x"`, `"y"`, `"z"`, `"lng"`, `"lat"`, `"angle"`, `"radius"`, | 
|    *   or customized in `dimensions` property of option like `"age"`. | 
|    * | 
|    * @return recognized `DimensionIndex`. Otherwise return null/undefined (means that dim is `DimensionName`). | 
|    */ | 
|   SeriesData.prototype._recognizeDimIndex = function (dim) { | 
|     if (zrUtil.isNumber(dim) | 
|     // If being a number-like string but not being defined as a dimension name. | 
|     || dim != null && !isNaN(dim) && !this._getDimInfo(dim) && (!this._dimOmitted || this._schema.getSourceDimensionIndex(dim) < 0)) { | 
|       return +dim; | 
|     } | 
|   }; | 
|   SeriesData.prototype._getStoreDimIndex = function (dim) { | 
|     var dimIdx = this.getDimensionIndex(dim); | 
|     if (process.env.NODE_ENV !== 'production') { | 
|       if (dimIdx == null) { | 
|         throw new Error('Unknown dimension ' + dim); | 
|       } | 
|     } | 
|     return dimIdx; | 
|   }; | 
|   /** | 
|    * Get type and calculation info of particular dimension | 
|    * @param dim | 
|    *        Dimension can be concrete names like x, y, z, lng, lat, angle, radius | 
|    *        Or a ordinal number. For example getDimensionInfo(0) will return 'x' or 'lng' or 'radius' | 
|    */ | 
|   SeriesData.prototype.getDimensionInfo = function (dim) { | 
|     // Do not clone, because there may be categories in dimInfo. | 
|     return this._getDimInfo(this.getDimension(dim)); | 
|   }; | 
|   SeriesData.prototype._initGetDimensionInfo = function (needsHasOwn) { | 
|     var dimensionInfos = this._dimInfos; | 
|     this._getDimInfo = needsHasOwn ? function (dimName) { | 
|       return dimensionInfos.hasOwnProperty(dimName) ? dimensionInfos[dimName] : undefined; | 
|     } : function (dimName) { | 
|       return dimensionInfos[dimName]; | 
|     }; | 
|   }; | 
|   /** | 
|    * concrete dimension name list on coord. | 
|    */ | 
|   SeriesData.prototype.getDimensionsOnCoord = function () { | 
|     return this._dimSummary.dataDimsOnCoord.slice(); | 
|   }; | 
|   SeriesData.prototype.mapDimension = function (coordDim, idx) { | 
|     var dimensionsSummary = this._dimSummary; | 
|     if (idx == null) { | 
|       return dimensionsSummary.encodeFirstDimNotExtra[coordDim]; | 
|     } | 
|     var dims = dimensionsSummary.encode[coordDim]; | 
|     return dims ? dims[idx] : null; | 
|   }; | 
|   SeriesData.prototype.mapDimensionsAll = function (coordDim) { | 
|     var dimensionsSummary = this._dimSummary; | 
|     var dims = dimensionsSummary.encode[coordDim]; | 
|     return (dims || []).slice(); | 
|   }; | 
|   SeriesData.prototype.getStore = function () { | 
|     return this._store; | 
|   }; | 
|   /** | 
|    * Initialize from data | 
|    * @param data source or data or data store. | 
|    * @param nameList The name of a datum is used on data diff and | 
|    *        default label/tooltip. | 
|    *        A name can be specified in encode.itemName, | 
|    *        or dataItem.name (only for series option data), | 
|    *        or provided in nameList from outside. | 
|    */ | 
|   SeriesData.prototype.initData = function (data, nameList, dimValueGetter) { | 
|     var _this = this; | 
|     var store; | 
|     if (data instanceof DataStore) { | 
|       store = data; | 
|     } | 
|     if (!store) { | 
|       var dimensions = this.dimensions; | 
|       var provider = isSourceInstance(data) || zrUtil.isArrayLike(data) ? new DefaultDataProvider(data, dimensions.length) : data; | 
|       store = new DataStore(); | 
|       var dimensionInfos = map(dimensions, function (dimName) { | 
|         return { | 
|           type: _this._dimInfos[dimName].type, | 
|           property: dimName | 
|         }; | 
|       }); | 
|       store.initData(provider, dimensionInfos, dimValueGetter); | 
|     } | 
|     this._store = store; | 
|     // Reset | 
|     this._nameList = (nameList || []).slice(); | 
|     this._idList = []; | 
|     this._nameRepeatCount = {}; | 
|     this._doInit(0, store.count()); | 
|     // Cache summary info for fast visit. See "dimensionHelper". | 
|     // Needs to be initialized after store is prepared. | 
|     this._dimSummary = summarizeDimensions(this, this._schema); | 
|     this.userOutput = this._dimSummary.userOutput; | 
|   }; | 
|   /** | 
|    * Caution: Can be only called on raw data (before `this._indices` created). | 
|    */ | 
|   SeriesData.prototype.appendData = function (data) { | 
|     var range = this._store.appendData(data); | 
|     this._doInit(range[0], range[1]); | 
|   }; | 
|   /** | 
|    * Caution: Can be only called on raw data (before `this._indices` created). | 
|    * This method does not modify `rawData` (`dataProvider`), but only | 
|    * add values to store. | 
|    * | 
|    * The final count will be increased by `Math.max(values.length, names.length)`. | 
|    * | 
|    * @param values That is the SourceType: 'arrayRows', like | 
|    *        [ | 
|    *            [12, 33, 44], | 
|    *            [NaN, 43, 1], | 
|    *            ['-', 'asdf', 0] | 
|    *        ] | 
|    *        Each item is exactly corresponding to a dimension. | 
|    */ | 
|   SeriesData.prototype.appendValues = function (values, names) { | 
|     var _a = this._store.appendValues(values, names && names.length), | 
|       start = _a.start, | 
|       end = _a.end; | 
|     var shouldMakeIdFromName = this._shouldMakeIdFromName(); | 
|     this._updateOrdinalMeta(); | 
|     if (names) { | 
|       for (var idx = start; idx < end; idx++) { | 
|         var sourceIdx = idx - start; | 
|         this._nameList[idx] = names[sourceIdx]; | 
|         if (shouldMakeIdFromName) { | 
|           makeIdFromName(this, idx); | 
|         } | 
|       } | 
|     } | 
|   }; | 
|   SeriesData.prototype._updateOrdinalMeta = function () { | 
|     var store = this._store; | 
|     var dimensions = this.dimensions; | 
|     for (var i = 0; i < dimensions.length; i++) { | 
|       var dimInfo = this._dimInfos[dimensions[i]]; | 
|       if (dimInfo.ordinalMeta) { | 
|         store.collectOrdinalMeta(dimInfo.storeDimIndex, dimInfo.ordinalMeta); | 
|       } | 
|     } | 
|   }; | 
|   SeriesData.prototype._shouldMakeIdFromName = function () { | 
|     var provider = this._store.getProvider(); | 
|     return this._idDimIdx == null && provider.getSource().sourceFormat !== SOURCE_FORMAT_TYPED_ARRAY && !provider.fillStorage; | 
|   }; | 
|   SeriesData.prototype._doInit = function (start, end) { | 
|     if (start >= end) { | 
|       return; | 
|     } | 
|     var store = this._store; | 
|     var provider = store.getProvider(); | 
|     this._updateOrdinalMeta(); | 
|     var nameList = this._nameList; | 
|     var idList = this._idList; | 
|     var sourceFormat = provider.getSource().sourceFormat; | 
|     var isFormatOriginal = sourceFormat === SOURCE_FORMAT_ORIGINAL; | 
|     // Each data item is value | 
|     // [1, 2] | 
|     // 2 | 
|     // Bar chart, line chart which uses category axis | 
|     // only gives the 'y' value. 'x' value is the indices of category | 
|     // Use a tempValue to normalize the value to be a (x, y) value | 
|     // If dataItem is {name: ...} or {id: ...}, it has highest priority. | 
|     // This kind of ids and names are always stored `_nameList` and `_idList`. | 
|     if (isFormatOriginal && !provider.pure) { | 
|       var sharedDataItem = []; | 
|       for (var idx = start; idx < end; idx++) { | 
|         // NOTICE: Try not to write things into dataItem | 
|         var dataItem = provider.getItem(idx, sharedDataItem); | 
|         if (!this.hasItemOption && isDataItemOption(dataItem)) { | 
|           this.hasItemOption = true; | 
|         } | 
|         if (dataItem) { | 
|           var itemName = dataItem.name; | 
|           if (nameList[idx] == null && itemName != null) { | 
|             nameList[idx] = convertOptionIdName(itemName, null); | 
|           } | 
|           var itemId = dataItem.id; | 
|           if (idList[idx] == null && itemId != null) { | 
|             idList[idx] = convertOptionIdName(itemId, null); | 
|           } | 
|         } | 
|       } | 
|     } | 
|     if (this._shouldMakeIdFromName()) { | 
|       for (var idx = start; idx < end; idx++) { | 
|         makeIdFromName(this, idx); | 
|       } | 
|     } | 
|     prepareInvertedIndex(this); | 
|   }; | 
|   /** | 
|    * PENDING: In fact currently this function is only used to short-circuit | 
|    * the calling of `scale.unionExtentFromData` when data have been filtered by modules | 
|    * like "dataZoom". `scale.unionExtentFromData` is used to calculate data extent for series on | 
|    * an axis, but if a "axis related data filter module" is used, the extent of the axis have | 
|    * been fixed and no need to calling `scale.unionExtentFromData` actually. | 
|    * But if we add "custom data filter" in future, which is not "axis related", this method may | 
|    * be still needed. | 
|    * | 
|    * Optimize for the scenario that data is filtered by a given extent. | 
|    * Consider that if data amount is more than hundreds of thousand, | 
|    * extent calculation will cost more than 10ms and the cache will | 
|    * be erased because of the filtering. | 
|    */ | 
|   SeriesData.prototype.getApproximateExtent = function (dim) { | 
|     return this._approximateExtent[dim] || this._store.getDataExtent(this._getStoreDimIndex(dim)); | 
|   }; | 
|   /** | 
|    * Calculate extent on a filtered data might be time consuming. | 
|    * Approximate extent is only used for: calculate extent of filtered data outside. | 
|    */ | 
|   SeriesData.prototype.setApproximateExtent = function (extent, dim) { | 
|     dim = this.getDimension(dim); | 
|     this._approximateExtent[dim] = extent.slice(); | 
|   }; | 
|   SeriesData.prototype.getCalculationInfo = function (key) { | 
|     return this._calculationInfo[key]; | 
|   }; | 
|   SeriesData.prototype.setCalculationInfo = function (key, value) { | 
|     isObject(key) ? zrUtil.extend(this._calculationInfo, key) : this._calculationInfo[key] = value; | 
|   }; | 
|   /** | 
|    * @return Never be null/undefined. `number` will be converted to string. Because: | 
|    * In most cases, name is used in display, where returning a string is more convenient. | 
|    * In other cases, name is used in query (see `indexOfName`), where we can keep the | 
|    * rule that name `2` equals to name `'2'`. | 
|    */ | 
|   SeriesData.prototype.getName = function (idx) { | 
|     var rawIndex = this.getRawIndex(idx); | 
|     var name = this._nameList[rawIndex]; | 
|     if (name == null && this._nameDimIdx != null) { | 
|       name = getIdNameFromStore(this, this._nameDimIdx, rawIndex); | 
|     } | 
|     if (name == null) { | 
|       name = ''; | 
|     } | 
|     return name; | 
|   }; | 
|   SeriesData.prototype._getCategory = function (dimIdx, idx) { | 
|     var ordinal = this._store.get(dimIdx, idx); | 
|     var ordinalMeta = this._store.getOrdinalMeta(dimIdx); | 
|     if (ordinalMeta) { | 
|       return ordinalMeta.categories[ordinal]; | 
|     } | 
|     return ordinal; | 
|   }; | 
|   /** | 
|    * @return Never null/undefined. `number` will be converted to string. Because: | 
|    * In all cases having encountered at present, id is used in making diff comparison, which | 
|    * are usually based on hash map. We can keep the rule that the internal id are always string | 
|    * (treat `2` is the same as `'2'`) to make the related logic simple. | 
|    */ | 
|   SeriesData.prototype.getId = function (idx) { | 
|     return getId(this, this.getRawIndex(idx)); | 
|   }; | 
|   SeriesData.prototype.count = function () { | 
|     return this._store.count(); | 
|   }; | 
|   /** | 
|    * Get value. Return NaN if idx is out of range. | 
|    * | 
|    * @notice Should better to use `data.getStore().get(dimIndex, dataIdx)` instead. | 
|    */ | 
|   SeriesData.prototype.get = function (dim, idx) { | 
|     var store = this._store; | 
|     var dimInfo = this._dimInfos[dim]; | 
|     if (dimInfo) { | 
|       return store.get(dimInfo.storeDimIndex, idx); | 
|     } | 
|   }; | 
|   /** | 
|    * @notice Should better to use `data.getStore().getByRawIndex(dimIndex, dataIdx)` instead. | 
|    */ | 
|   SeriesData.prototype.getByRawIndex = function (dim, rawIdx) { | 
|     var store = this._store; | 
|     var dimInfo = this._dimInfos[dim]; | 
|     if (dimInfo) { | 
|       return store.getByRawIndex(dimInfo.storeDimIndex, rawIdx); | 
|     } | 
|   }; | 
|   SeriesData.prototype.getIndices = function () { | 
|     return this._store.getIndices(); | 
|   }; | 
|   SeriesData.prototype.getDataExtent = function (dim) { | 
|     return this._store.getDataExtent(this._getStoreDimIndex(dim)); | 
|   }; | 
|   SeriesData.prototype.getSum = function (dim) { | 
|     return this._store.getSum(this._getStoreDimIndex(dim)); | 
|   }; | 
|   SeriesData.prototype.getMedian = function (dim) { | 
|     return this._store.getMedian(this._getStoreDimIndex(dim)); | 
|   }; | 
|   SeriesData.prototype.getValues = function (dimensions, idx) { | 
|     var _this = this; | 
|     var store = this._store; | 
|     return zrUtil.isArray(dimensions) ? store.getValues(map(dimensions, function (dim) { | 
|       return _this._getStoreDimIndex(dim); | 
|     }), idx) : store.getValues(dimensions); | 
|   }; | 
|   /** | 
|    * If value is NaN. Including '-' | 
|    * Only check the coord dimensions. | 
|    */ | 
|   SeriesData.prototype.hasValue = function (idx) { | 
|     var dataDimIndicesOnCoord = this._dimSummary.dataDimIndicesOnCoord; | 
|     for (var i = 0, len = dataDimIndicesOnCoord.length; i < len; i++) { | 
|       // Ordinal type originally can be string or number. | 
|       // But when an ordinal type is used on coord, it can | 
|       // not be string but only number. So we can also use isNaN. | 
|       if (isNaN(this._store.get(dataDimIndicesOnCoord[i], idx))) { | 
|         return false; | 
|       } | 
|     } | 
|     return true; | 
|   }; | 
|   /** | 
|    * Retrieve the index with given name | 
|    */ | 
|   SeriesData.prototype.indexOfName = function (name) { | 
|     for (var i = 0, len = this._store.count(); i < len; i++) { | 
|       if (this.getName(i) === name) { | 
|         return i; | 
|       } | 
|     } | 
|     return -1; | 
|   }; | 
|   SeriesData.prototype.getRawIndex = function (idx) { | 
|     return this._store.getRawIndex(idx); | 
|   }; | 
|   SeriesData.prototype.indexOfRawIndex = function (rawIndex) { | 
|     return this._store.indexOfRawIndex(rawIndex); | 
|   }; | 
|   /** | 
|    * Only support the dimension which inverted index created. | 
|    * Do not support other cases until required. | 
|    * @param dim concrete dim | 
|    * @param value ordinal index | 
|    * @return rawIndex | 
|    */ | 
|   SeriesData.prototype.rawIndexOf = function (dim, value) { | 
|     var invertedIndices = dim && this._invertedIndicesMap[dim]; | 
|     if (process.env.NODE_ENV !== 'production') { | 
|       if (!invertedIndices) { | 
|         throw new Error('Do not supported yet'); | 
|       } | 
|     } | 
|     var rawIndex = invertedIndices && invertedIndices[value]; | 
|     if (rawIndex == null || isNaN(rawIndex)) { | 
|       return INDEX_NOT_FOUND; | 
|     } | 
|     return rawIndex; | 
|   }; | 
|   /** | 
|    * Retrieve the index of nearest value | 
|    * @param dim | 
|    * @param value | 
|    * @param [maxDistance=Infinity] | 
|    * @return If and only if multiple indices has | 
|    *         the same value, they are put to the result. | 
|    */ | 
|   SeriesData.prototype.indicesOfNearest = function (dim, value, maxDistance) { | 
|     return this._store.indicesOfNearest(this._getStoreDimIndex(dim), value, maxDistance); | 
|   }; | 
|   SeriesData.prototype.each = function (dims, cb, ctx) { | 
|     'use strict'; | 
|   | 
|     if (zrUtil.isFunction(dims)) { | 
|       ctx = cb; | 
|       cb = dims; | 
|       dims = []; | 
|     } | 
|     // ctxCompat just for compat echarts3 | 
|     var fCtx = ctx || this; | 
|     var dimIndices = map(normalizeDimensions(dims), this._getStoreDimIndex, this); | 
|     this._store.each(dimIndices, fCtx ? zrUtil.bind(cb, fCtx) : cb); | 
|   }; | 
|   SeriesData.prototype.filterSelf = function (dims, cb, ctx) { | 
|     'use strict'; | 
|   | 
|     if (zrUtil.isFunction(dims)) { | 
|       ctx = cb; | 
|       cb = dims; | 
|       dims = []; | 
|     } | 
|     // ctxCompat just for compat echarts3 | 
|     var fCtx = ctx || this; | 
|     var dimIndices = map(normalizeDimensions(dims), this._getStoreDimIndex, this); | 
|     this._store = this._store.filter(dimIndices, fCtx ? zrUtil.bind(cb, fCtx) : cb); | 
|     return this; | 
|   }; | 
|   /** | 
|    * Select data in range. (For optimization of filter) | 
|    * (Manually inline code, support 5 million data filtering in data zoom.) | 
|    */ | 
|   SeriesData.prototype.selectRange = function (range) { | 
|     'use strict'; | 
|   | 
|     var _this = this; | 
|     var innerRange = {}; | 
|     var dims = zrUtil.keys(range); | 
|     var dimIndices = []; | 
|     zrUtil.each(dims, function (dim) { | 
|       var dimIdx = _this._getStoreDimIndex(dim); | 
|       innerRange[dimIdx] = range[dim]; | 
|       dimIndices.push(dimIdx); | 
|     }); | 
|     this._store = this._store.selectRange(innerRange); | 
|     return this; | 
|   }; | 
|   /* eslint-enable max-len */ | 
|   SeriesData.prototype.mapArray = function (dims, cb, ctx) { | 
|     'use strict'; | 
|   | 
|     if (zrUtil.isFunction(dims)) { | 
|       ctx = cb; | 
|       cb = dims; | 
|       dims = []; | 
|     } | 
|     // ctxCompat just for compat echarts3 | 
|     ctx = ctx || this; | 
|     var result = []; | 
|     this.each(dims, function () { | 
|       result.push(cb && cb.apply(this, arguments)); | 
|     }, ctx); | 
|     return result; | 
|   }; | 
|   SeriesData.prototype.map = function (dims, cb, ctx, ctxCompat) { | 
|     'use strict'; | 
|   | 
|     // ctxCompat just for compat echarts3 | 
|     var fCtx = ctx || ctxCompat || this; | 
|     var dimIndices = map(normalizeDimensions(dims), this._getStoreDimIndex, this); | 
|     var list = cloneListForMapAndSample(this); | 
|     list._store = this._store.map(dimIndices, fCtx ? zrUtil.bind(cb, fCtx) : cb); | 
|     return list; | 
|   }; | 
|   SeriesData.prototype.modify = function (dims, cb, ctx, ctxCompat) { | 
|     var _this = this; | 
|     // ctxCompat just for compat echarts3 | 
|     var fCtx = ctx || ctxCompat || this; | 
|     if (process.env.NODE_ENV !== 'production') { | 
|       zrUtil.each(normalizeDimensions(dims), function (dim) { | 
|         var dimInfo = _this.getDimensionInfo(dim); | 
|         if (!dimInfo.isCalculationCoord) { | 
|           console.error('Danger: only stack dimension can be modified'); | 
|         } | 
|       }); | 
|     } | 
|     var dimIndices = map(normalizeDimensions(dims), this._getStoreDimIndex, this); | 
|     // If do shallow clone here, if there are too many stacked series, | 
|     // it still cost lots of memory, because `_store.dimensions` are not shared. | 
|     // We should consider there probably be shallow clone happen in each series | 
|     // in consequent filter/map. | 
|     this._store.modify(dimIndices, fCtx ? zrUtil.bind(cb, fCtx) : cb); | 
|   }; | 
|   /** | 
|    * Large data down sampling on given dimension | 
|    * @param sampleIndex Sample index for name and id | 
|    */ | 
|   SeriesData.prototype.downSample = function (dimension, rate, sampleValue, sampleIndex) { | 
|     var list = cloneListForMapAndSample(this); | 
|     list._store = this._store.downSample(this._getStoreDimIndex(dimension), rate, sampleValue, sampleIndex); | 
|     return list; | 
|   }; | 
|   /** | 
|    * Large data down sampling using min-max | 
|    * @param {string} valueDimension | 
|    * @param {number} rate | 
|    */ | 
|   SeriesData.prototype.minmaxDownSample = function (valueDimension, rate) { | 
|     var list = cloneListForMapAndSample(this); | 
|     list._store = this._store.minmaxDownSample(this._getStoreDimIndex(valueDimension), rate); | 
|     return list; | 
|   }; | 
|   /** | 
|    * Large data down sampling using largest-triangle-three-buckets | 
|    * @param {string} valueDimension | 
|    * @param {number} targetCount | 
|    */ | 
|   SeriesData.prototype.lttbDownSample = function (valueDimension, rate) { | 
|     var list = cloneListForMapAndSample(this); | 
|     list._store = this._store.lttbDownSample(this._getStoreDimIndex(valueDimension), rate); | 
|     return list; | 
|   }; | 
|   SeriesData.prototype.getRawDataItem = function (idx) { | 
|     return this._store.getRawDataItem(idx); | 
|   }; | 
|   /** | 
|    * Get model of one data item. | 
|    */ | 
|   // TODO: Type of data item | 
|   SeriesData.prototype.getItemModel = function (idx) { | 
|     var hostModel = this.hostModel; | 
|     var dataItem = this.getRawDataItem(idx); | 
|     return new Model(dataItem, hostModel, hostModel && hostModel.ecModel); | 
|   }; | 
|   /** | 
|    * Create a data differ | 
|    */ | 
|   SeriesData.prototype.diff = function (otherList) { | 
|     var thisList = this; | 
|     return new DataDiffer(otherList ? otherList.getStore().getIndices() : [], this.getStore().getIndices(), function (idx) { | 
|       return getId(otherList, idx); | 
|     }, function (idx) { | 
|       return getId(thisList, idx); | 
|     }); | 
|   }; | 
|   /** | 
|    * Get visual property. | 
|    */ | 
|   SeriesData.prototype.getVisual = function (key) { | 
|     var visual = this._visual; | 
|     return visual && visual[key]; | 
|   }; | 
|   SeriesData.prototype.setVisual = function (kvObj, val) { | 
|     this._visual = this._visual || {}; | 
|     if (isObject(kvObj)) { | 
|       zrUtil.extend(this._visual, kvObj); | 
|     } else { | 
|       this._visual[kvObj] = val; | 
|     } | 
|   }; | 
|   /** | 
|    * Get visual property of single data item | 
|    */ | 
|   // eslint-disable-next-line | 
|   SeriesData.prototype.getItemVisual = function (idx, key) { | 
|     var itemVisual = this._itemVisuals[idx]; | 
|     var val = itemVisual && itemVisual[key]; | 
|     if (val == null) { | 
|       // Use global visual property | 
|       return this.getVisual(key); | 
|     } | 
|     return val; | 
|   }; | 
|   /** | 
|    * If exists visual property of single data item | 
|    */ | 
|   SeriesData.prototype.hasItemVisual = function () { | 
|     return this._itemVisuals.length > 0; | 
|   }; | 
|   /** | 
|    * Make sure itemVisual property is unique | 
|    */ | 
|   // TODO: use key to save visual to reduce memory. | 
|   SeriesData.prototype.ensureUniqueItemVisual = function (idx, key) { | 
|     var itemVisuals = this._itemVisuals; | 
|     var itemVisual = itemVisuals[idx]; | 
|     if (!itemVisual) { | 
|       itemVisual = itemVisuals[idx] = {}; | 
|     } | 
|     var val = itemVisual[key]; | 
|     if (val == null) { | 
|       val = this.getVisual(key); | 
|       // TODO Performance? | 
|       if (zrUtil.isArray(val)) { | 
|         val = val.slice(); | 
|       } else if (isObject(val)) { | 
|         val = zrUtil.extend({}, val); | 
|       } | 
|       itemVisual[key] = val; | 
|     } | 
|     return val; | 
|   }; | 
|   // eslint-disable-next-line | 
|   SeriesData.prototype.setItemVisual = function (idx, key, value) { | 
|     var itemVisual = this._itemVisuals[idx] || {}; | 
|     this._itemVisuals[idx] = itemVisual; | 
|     if (isObject(key)) { | 
|       zrUtil.extend(itemVisual, key); | 
|     } else { | 
|       itemVisual[key] = value; | 
|     } | 
|   }; | 
|   /** | 
|    * Clear itemVisuals and list visual. | 
|    */ | 
|   SeriesData.prototype.clearAllVisual = function () { | 
|     this._visual = {}; | 
|     this._itemVisuals = []; | 
|   }; | 
|   SeriesData.prototype.setLayout = function (key, val) { | 
|     isObject(key) ? zrUtil.extend(this._layout, key) : this._layout[key] = val; | 
|   }; | 
|   /** | 
|    * Get layout property. | 
|    */ | 
|   SeriesData.prototype.getLayout = function (key) { | 
|     return this._layout[key]; | 
|   }; | 
|   /** | 
|    * Get layout of single data item | 
|    */ | 
|   SeriesData.prototype.getItemLayout = function (idx) { | 
|     return this._itemLayouts[idx]; | 
|   }; | 
|   /** | 
|    * Set layout of single data item | 
|    */ | 
|   SeriesData.prototype.setItemLayout = function (idx, layout, merge) { | 
|     this._itemLayouts[idx] = merge ? zrUtil.extend(this._itemLayouts[idx] || {}, layout) : layout; | 
|   }; | 
|   /** | 
|    * Clear all layout of single data item | 
|    */ | 
|   SeriesData.prototype.clearItemLayouts = function () { | 
|     this._itemLayouts.length = 0; | 
|   }; | 
|   /** | 
|    * Set graphic element relative to data. It can be set as null | 
|    */ | 
|   SeriesData.prototype.setItemGraphicEl = function (idx, el) { | 
|     var seriesIndex = this.hostModel && this.hostModel.seriesIndex; | 
|     setCommonECData(seriesIndex, this.dataType, idx, el); | 
|     this._graphicEls[idx] = el; | 
|   }; | 
|   SeriesData.prototype.getItemGraphicEl = function (idx) { | 
|     return this._graphicEls[idx]; | 
|   }; | 
|   SeriesData.prototype.eachItemGraphicEl = function (cb, context) { | 
|     zrUtil.each(this._graphicEls, function (el, idx) { | 
|       if (el) { | 
|         cb && cb.call(context, el, idx); | 
|       } | 
|     }); | 
|   }; | 
|   /** | 
|    * Shallow clone a new list except visual and layout properties, and graph elements. | 
|    * New list only change the indices. | 
|    */ | 
|   SeriesData.prototype.cloneShallow = function (list) { | 
|     if (!list) { | 
|       list = new SeriesData(this._schema ? this._schema : map(this.dimensions, this._getDimInfo, this), this.hostModel); | 
|     } | 
|     transferProperties(list, this); | 
|     list._store = this._store; | 
|     return list; | 
|   }; | 
|   /** | 
|    * Wrap some method to add more feature | 
|    */ | 
|   SeriesData.prototype.wrapMethod = function (methodName, injectFunction) { | 
|     var originalMethod = this[methodName]; | 
|     if (!zrUtil.isFunction(originalMethod)) { | 
|       return; | 
|     } | 
|     this.__wrappedMethods = this.__wrappedMethods || []; | 
|     this.__wrappedMethods.push(methodName); | 
|     this[methodName] = function () { | 
|       var res = originalMethod.apply(this, arguments); | 
|       return injectFunction.apply(this, [res].concat(zrUtil.slice(arguments))); | 
|     }; | 
|   }; | 
|   // ---------------------------------------------------------- | 
|   // A work around for internal method visiting private member. | 
|   // ---------------------------------------------------------- | 
|   SeriesData.internalField = function () { | 
|     prepareInvertedIndex = function (data) { | 
|       var invertedIndicesMap = data._invertedIndicesMap; | 
|       zrUtil.each(invertedIndicesMap, function (invertedIndices, dim) { | 
|         var dimInfo = data._dimInfos[dim]; | 
|         // Currently, only dimensions that has ordinalMeta can create inverted indices. | 
|         var ordinalMeta = dimInfo.ordinalMeta; | 
|         var store = data._store; | 
|         if (ordinalMeta) { | 
|           invertedIndices = invertedIndicesMap[dim] = new CtorInt32Array(ordinalMeta.categories.length); | 
|           // The default value of TypedArray is 0. To avoid miss | 
|           // mapping to 0, we should set it as INDEX_NOT_FOUND. | 
|           for (var i = 0; i < invertedIndices.length; i++) { | 
|             invertedIndices[i] = INDEX_NOT_FOUND; | 
|           } | 
|           for (var i = 0; i < store.count(); i++) { | 
|             // Only support the case that all values are distinct. | 
|             invertedIndices[store.get(dimInfo.storeDimIndex, i)] = i; | 
|           } | 
|         } | 
|       }); | 
|     }; | 
|     getIdNameFromStore = function (data, dimIdx, idx) { | 
|       return convertOptionIdName(data._getCategory(dimIdx, idx), null); | 
|     }; | 
|     /** | 
|      * @see the comment of `List['getId']`. | 
|      */ | 
|     getId = function (data, rawIndex) { | 
|       var id = data._idList[rawIndex]; | 
|       if (id == null && data._idDimIdx != null) { | 
|         id = getIdNameFromStore(data, data._idDimIdx, rawIndex); | 
|       } | 
|       if (id == null) { | 
|         id = ID_PREFIX + rawIndex; | 
|       } | 
|       return id; | 
|     }; | 
|     normalizeDimensions = function (dimensions) { | 
|       if (!zrUtil.isArray(dimensions)) { | 
|         dimensions = dimensions != null ? [dimensions] : []; | 
|       } | 
|       return dimensions; | 
|     }; | 
|     /** | 
|      * Data in excludeDimensions is copied, otherwise transferred. | 
|      */ | 
|     cloneListForMapAndSample = function (original) { | 
|       var list = new SeriesData(original._schema ? original._schema : map(original.dimensions, original._getDimInfo, original), original.hostModel); | 
|       // FIXME If needs stackedOn, value may already been stacked | 
|       transferProperties(list, original); | 
|       return list; | 
|     }; | 
|     transferProperties = function (target, source) { | 
|       zrUtil.each(TRANSFERABLE_PROPERTIES.concat(source.__wrappedMethods || []), function (propName) { | 
|         if (source.hasOwnProperty(propName)) { | 
|           target[propName] = source[propName]; | 
|         } | 
|       }); | 
|       target.__wrappedMethods = source.__wrappedMethods; | 
|       zrUtil.each(CLONE_PROPERTIES, function (propName) { | 
|         target[propName] = zrUtil.clone(source[propName]); | 
|       }); | 
|       target._calculationInfo = zrUtil.extend({}, source._calculationInfo); | 
|     }; | 
|     makeIdFromName = function (data, idx) { | 
|       var nameList = data._nameList; | 
|       var idList = data._idList; | 
|       var nameDimIdx = data._nameDimIdx; | 
|       var idDimIdx = data._idDimIdx; | 
|       var name = nameList[idx]; | 
|       var id = idList[idx]; | 
|       if (name == null && nameDimIdx != null) { | 
|         nameList[idx] = name = getIdNameFromStore(data, nameDimIdx, idx); | 
|       } | 
|       if (id == null && idDimIdx != null) { | 
|         idList[idx] = id = getIdNameFromStore(data, idDimIdx, idx); | 
|       } | 
|       if (id == null && name != null) { | 
|         var nameRepeatCount = data._nameRepeatCount; | 
|         var nmCnt = nameRepeatCount[name] = (nameRepeatCount[name] || 0) + 1; | 
|         id = name; | 
|         if (nmCnt > 1) { | 
|           id += '__ec__' + nmCnt; | 
|         } | 
|         idList[idx] = id; | 
|       } | 
|     }; | 
|   }(); | 
|   return SeriesData; | 
| }(); | 
| export default SeriesData; |