123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542 |
- import { __extends } from "tslib";
- import * as zrUtil from 'zrender/lib/core/util.js';
- import env from 'zrender/lib/core/env.js';
- import * as modelUtil from '../util/model.js';
- import ComponentModel from './Component.js';
- import { PaletteMixin } from './mixin/palette.js';
- import { DataFormatMixin } from '../model/mixin/dataFormat.js';
- import { getLayoutParams, mergeLayoutParam, fetchLayoutMode } from '../util/layout.js';
- import { createTask } from '../core/task.js';
- import { mountExtend } from '../util/clazz.js';
- import { SourceManager } from '../data/helper/sourceManager.js';
- import { defaultSeriesFormatTooltip } from '../component/tooltip/seriesFormatTooltip.js';
- var inner = modelUtil.makeInner();
- function getSelectionKey(data, dataIndex) {
- return data.getName(dataIndex) || data.getId(dataIndex);
- }
- export var SERIES_UNIVERSAL_TRANSITION_PROP = '__universalTransitionEnabled';
- var SeriesModel = function (_super) {
- __extends(SeriesModel, _super);
- function SeriesModel() {
-
-
-
-
-
-
-
-
-
- var _this = _super !== null && _super.apply(this, arguments) || this;
-
-
-
- _this._selectedDataIndicesMap = {};
- return _this;
- }
- SeriesModel.prototype.init = function (option, parentModel, ecModel) {
- this.seriesIndex = this.componentIndex;
- this.dataTask = createTask({
- count: dataTaskCount,
- reset: dataTaskReset
- });
- this.dataTask.context = {
- model: this
- };
- this.mergeDefaultAndTheme(option, ecModel);
- var sourceManager = inner(this).sourceManager = new SourceManager(this);
- sourceManager.prepareSource();
- var data = this.getInitialData(option, ecModel);
- wrapData(data, this);
- this.dataTask.context.data = data;
- if (process.env.NODE_ENV !== 'production') {
- zrUtil.assert(data, 'getInitialData returned invalid data.');
- }
- inner(this).dataBeforeProcessed = data;
-
-
-
-
-
-
-
-
-
-
- autoSeriesName(this);
- this._initSelectedMapFromData(data);
- };
-
- SeriesModel.prototype.mergeDefaultAndTheme = function (option, ecModel) {
- var layoutMode = fetchLayoutMode(this);
- var inputPositionParams = layoutMode ? getLayoutParams(option) : {};
-
-
-
-
- var themeSubType = this.subType;
- if (ComponentModel.hasClass(themeSubType)) {
- themeSubType += 'Series';
- }
- zrUtil.merge(option, ecModel.getTheme().get(this.subType));
- zrUtil.merge(option, this.getDefaultOption());
-
- modelUtil.defaultEmphasis(option, 'label', ['show']);
- this.fillDataTextStyle(option.data);
- if (layoutMode) {
- mergeLayoutParam(option, inputPositionParams, layoutMode);
- }
- };
- SeriesModel.prototype.mergeOption = function (newSeriesOption, ecModel) {
-
- newSeriesOption = zrUtil.merge(this.option, newSeriesOption, true);
- this.fillDataTextStyle(newSeriesOption.data);
- var layoutMode = fetchLayoutMode(this);
- if (layoutMode) {
- mergeLayoutParam(this.option, newSeriesOption, layoutMode);
- }
- var sourceManager = inner(this).sourceManager;
- sourceManager.dirty();
- sourceManager.prepareSource();
- var data = this.getInitialData(newSeriesOption, ecModel);
- wrapData(data, this);
- this.dataTask.dirty();
- this.dataTask.context.data = data;
- inner(this).dataBeforeProcessed = data;
- autoSeriesName(this);
- this._initSelectedMapFromData(data);
- };
- SeriesModel.prototype.fillDataTextStyle = function (data) {
-
-
-
- if (data && !zrUtil.isTypedArray(data)) {
- var props = ['show'];
- for (var i = 0; i < data.length; i++) {
- if (data[i] && data[i].label) {
- modelUtil.defaultEmphasis(data[i], 'label', props);
- }
- }
- }
- };
-
- SeriesModel.prototype.getInitialData = function (option, ecModel) {
- return;
- };
-
- SeriesModel.prototype.appendData = function (params) {
-
-
-
- var data = this.getRawData();
- data.appendData(params.data);
- };
-
- SeriesModel.prototype.getData = function (dataType) {
- var task = getCurrentTask(this);
- if (task) {
- var data = task.context.data;
- return dataType == null || !data.getLinkedData ? data : data.getLinkedData(dataType);
- } else {
-
-
-
-
- return inner(this).data;
- }
- };
- SeriesModel.prototype.getAllData = function () {
- var mainData = this.getData();
- return mainData && mainData.getLinkedDataAll ? mainData.getLinkedDataAll() : [{
- data: mainData
- }];
- };
- SeriesModel.prototype.setData = function (data) {
- var task = getCurrentTask(this);
- if (task) {
- var context = task.context;
-
-
-
-
-
- context.outputData = data;
-
-
-
-
-
-
-
-
- if (task !== this.dataTask) {
- context.data = data;
- }
- }
- inner(this).data = data;
- };
- SeriesModel.prototype.getEncode = function () {
- var encode = this.get('encode', true);
- if (encode) {
- return zrUtil.createHashMap(encode);
- }
- };
- SeriesModel.prototype.getSourceManager = function () {
- return inner(this).sourceManager;
- };
- SeriesModel.prototype.getSource = function () {
- return this.getSourceManager().getSource();
- };
-
- SeriesModel.prototype.getRawData = function () {
- return inner(this).dataBeforeProcessed;
- };
- SeriesModel.prototype.getColorBy = function () {
- var colorBy = this.get('colorBy');
- return colorBy || 'series';
- };
- SeriesModel.prototype.isColorBySeries = function () {
- return this.getColorBy() === 'series';
- };
-
- SeriesModel.prototype.getBaseAxis = function () {
- var coordSys = this.coordinateSystem;
-
- return coordSys && coordSys.getBaseAxis && coordSys.getBaseAxis();
- };
-
- SeriesModel.prototype.formatTooltip = function (dataIndex, multipleSeries, dataType) {
- return defaultSeriesFormatTooltip({
- series: this,
- dataIndex: dataIndex,
- multipleSeries: multipleSeries
- });
- };
- SeriesModel.prototype.isAnimationEnabled = function () {
- var ecModel = this.ecModel;
-
-
- if (env.node && !(ecModel && ecModel.ssr)) {
- return false;
- }
- var animationEnabled = this.getShallow('animation');
- if (animationEnabled) {
- if (this.getData().count() > this.getShallow('animationThreshold')) {
- animationEnabled = false;
- }
- }
- return !!animationEnabled;
- };
- SeriesModel.prototype.restoreData = function () {
- this.dataTask.dirty();
- };
- SeriesModel.prototype.getColorFromPalette = function (name, scope, requestColorNum) {
- var ecModel = this.ecModel;
-
- var color = PaletteMixin.prototype.getColorFromPalette.call(this, name, scope, requestColorNum);
- if (!color) {
- color = ecModel.getColorFromPalette(name, scope, requestColorNum);
- }
- return color;
- };
-
- SeriesModel.prototype.coordDimToDataDim = function (coordDim) {
- return this.getRawData().mapDimensionsAll(coordDim);
- };
-
- SeriesModel.prototype.getProgressive = function () {
- return this.get('progressive');
- };
-
- SeriesModel.prototype.getProgressiveThreshold = function () {
- return this.get('progressiveThreshold');
- };
-
- SeriesModel.prototype.select = function (innerDataIndices, dataType) {
- this._innerSelect(this.getData(dataType), innerDataIndices);
- };
- SeriesModel.prototype.unselect = function (innerDataIndices, dataType) {
- var selectedMap = this.option.selectedMap;
- if (!selectedMap) {
- return;
- }
- var selectedMode = this.option.selectedMode;
- var data = this.getData(dataType);
- if (selectedMode === 'series' || selectedMap === 'all') {
- this.option.selectedMap = {};
- this._selectedDataIndicesMap = {};
- return;
- }
- for (var i = 0; i < innerDataIndices.length; i++) {
- var dataIndex = innerDataIndices[i];
- var nameOrId = getSelectionKey(data, dataIndex);
- selectedMap[nameOrId] = false;
- this._selectedDataIndicesMap[nameOrId] = -1;
- }
- };
- SeriesModel.prototype.toggleSelect = function (innerDataIndices, dataType) {
- var tmpArr = [];
- for (var i = 0; i < innerDataIndices.length; i++) {
- tmpArr[0] = innerDataIndices[i];
- this.isSelected(innerDataIndices[i], dataType) ? this.unselect(tmpArr, dataType) : this.select(tmpArr, dataType);
- }
- };
- SeriesModel.prototype.getSelectedDataIndices = function () {
- if (this.option.selectedMap === 'all') {
- return [].slice.call(this.getData().getIndices());
- }
- var selectedDataIndicesMap = this._selectedDataIndicesMap;
- var nameOrIds = zrUtil.keys(selectedDataIndicesMap);
- var dataIndices = [];
- for (var i = 0; i < nameOrIds.length; i++) {
- var dataIndex = selectedDataIndicesMap[nameOrIds[i]];
- if (dataIndex >= 0) {
- dataIndices.push(dataIndex);
- }
- }
- return dataIndices;
- };
- SeriesModel.prototype.isSelected = function (dataIndex, dataType) {
- var selectedMap = this.option.selectedMap;
- if (!selectedMap) {
- return false;
- }
- var data = this.getData(dataType);
- return (selectedMap === 'all' || selectedMap[getSelectionKey(data, dataIndex)]) && !data.getItemModel(dataIndex).get(['select', 'disabled']);
- };
- SeriesModel.prototype.isUniversalTransitionEnabled = function () {
- if (this[SERIES_UNIVERSAL_TRANSITION_PROP]) {
- return true;
- }
- var universalTransitionOpt = this.option.universalTransition;
-
- if (!universalTransitionOpt) {
- return false;
- }
- if (universalTransitionOpt === true) {
- return true;
- }
-
- return universalTransitionOpt && universalTransitionOpt.enabled;
- };
- SeriesModel.prototype._innerSelect = function (data, innerDataIndices) {
- var _a, _b;
- var option = this.option;
- var selectedMode = option.selectedMode;
- var len = innerDataIndices.length;
- if (!selectedMode || !len) {
- return;
- }
- if (selectedMode === 'series') {
- option.selectedMap = 'all';
- } else if (selectedMode === 'multiple') {
- if (!zrUtil.isObject(option.selectedMap)) {
- option.selectedMap = {};
- }
- var selectedMap = option.selectedMap;
- for (var i = 0; i < len; i++) {
- var dataIndex = innerDataIndices[i];
-
- var nameOrId = getSelectionKey(data, dataIndex);
- selectedMap[nameOrId] = true;
- this._selectedDataIndicesMap[nameOrId] = data.getRawIndex(dataIndex);
- }
- } else if (selectedMode === 'single' || selectedMode === true) {
- var lastDataIndex = innerDataIndices[len - 1];
- var nameOrId = getSelectionKey(data, lastDataIndex);
- option.selectedMap = (_a = {}, _a[nameOrId] = true, _a);
- this._selectedDataIndicesMap = (_b = {}, _b[nameOrId] = data.getRawIndex(lastDataIndex), _b);
- }
- };
- SeriesModel.prototype._initSelectedMapFromData = function (data) {
-
-
- if (this.option.selectedMap) {
- return;
- }
- var dataIndices = [];
- if (data.hasItemOption) {
- data.each(function (idx) {
- var rawItem = data.getRawDataItem(idx);
- if (rawItem && rawItem.selected) {
- dataIndices.push(idx);
- }
- });
- }
- if (dataIndices.length > 0) {
- this._innerSelect(data, dataIndices);
- }
- };
-
-
-
-
- SeriesModel.registerClass = function (clz) {
- return ComponentModel.registerClass(clz);
- };
- SeriesModel.protoInitialize = function () {
- var proto = SeriesModel.prototype;
- proto.type = 'series.__base__';
- proto.seriesIndex = 0;
- proto.ignoreStyleOnData = false;
- proto.hasSymbolVisual = false;
- proto.defaultSymbol = 'circle';
-
- proto.visualStyleAccessPath = 'itemStyle';
- proto.visualDrawType = 'fill';
- }();
- return SeriesModel;
- }(ComponentModel);
- zrUtil.mixin(SeriesModel, DataFormatMixin);
- zrUtil.mixin(SeriesModel, PaletteMixin);
- mountExtend(SeriesModel, ComponentModel);
- function autoSeriesName(seriesModel) {
-
-
- var name = seriesModel.name;
- if (!modelUtil.isNameSpecified(seriesModel)) {
- seriesModel.name = getSeriesAutoName(seriesModel) || name;
- }
- }
- function getSeriesAutoName(seriesModel) {
- var data = seriesModel.getRawData();
- var dataDims = data.mapDimensionsAll('seriesName');
- var nameArr = [];
- zrUtil.each(dataDims, function (dataDim) {
- var dimInfo = data.getDimensionInfo(dataDim);
- dimInfo.displayName && nameArr.push(dimInfo.displayName);
- });
- return nameArr.join(' ');
- }
- function dataTaskCount(context) {
- return context.model.getRawData().count();
- }
- function dataTaskReset(context) {
- var seriesModel = context.model;
- seriesModel.setData(seriesModel.getRawData().cloneShallow());
- return dataTaskProgress;
- }
- function dataTaskProgress(param, context) {
-
- if (context.outputData && param.end > context.outputData.count()) {
- context.model.getRawData().cloneShallow(context.outputData);
- }
- }
- function wrapData(data, seriesModel) {
- zrUtil.each(zrUtil.concatArray(data.CHANGABLE_METHODS, data.DOWNSAMPLE_METHODS), function (methodName) {
- data.wrapMethod(methodName, zrUtil.curry(onDataChange, seriesModel));
- });
- }
- function onDataChange(seriesModel, newList) {
- var task = getCurrentTask(seriesModel);
- if (task) {
-
- task.setOutputEnd((newList || this).count());
- }
- return newList;
- }
- function getCurrentTask(seriesModel) {
- var scheduler = (seriesModel.ecModel || {}).scheduler;
- var pipeline = scheduler && scheduler.getPipeline(seriesModel.uid);
- if (pipeline) {
-
-
- var task = pipeline.currentTask;
- if (task) {
- var agentStubMap = task.agentStubMap;
- if (agentStubMap) {
- task = agentStubMap.get(seriesModel.uid);
- }
- }
- return task;
- }
- }
- export default SeriesModel;
|