166 lines
5.8 KiB
JavaScript
166 lines
5.8 KiB
JavaScript
|
|
/*
|
|
* 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.
|
|
*/
|
|
import { __extends } from "tslib";
|
|
import * as zrUtil from 'zrender/lib/core/util.js';
|
|
import env from 'zrender/lib/core/env.js';
|
|
import { DataFormatMixin } from '../../model/mixin/dataFormat.js';
|
|
import ComponentModel from '../../model/Component.js';
|
|
import { makeInner, defaultEmphasis } from '../../util/model.js';
|
|
import { createTooltipMarkup } from '../tooltip/tooltipMarkup.js';
|
|
function fillLabel(opt) {
|
|
defaultEmphasis(opt, 'label', ['show']);
|
|
}
|
|
// { [componentType]: MarkerModel }
|
|
var inner = makeInner();
|
|
var MarkerModel = /** @class */function (_super) {
|
|
__extends(MarkerModel, _super);
|
|
function MarkerModel() {
|
|
var _this = _super !== null && _super.apply(this, arguments) || this;
|
|
_this.type = MarkerModel.type;
|
|
/**
|
|
* If marker model is created by self from series
|
|
*/
|
|
_this.createdBySelf = false;
|
|
return _this;
|
|
}
|
|
/**
|
|
* @overrite
|
|
*/
|
|
MarkerModel.prototype.init = function (option, parentModel, ecModel) {
|
|
if (process.env.NODE_ENV !== 'production') {
|
|
if (this.type === 'marker') {
|
|
throw new Error('Marker component is abstract component. Use markLine, markPoint, markArea instead.');
|
|
}
|
|
}
|
|
this.mergeDefaultAndTheme(option, ecModel);
|
|
this._mergeOption(option, ecModel, false, true);
|
|
};
|
|
MarkerModel.prototype.isAnimationEnabled = function () {
|
|
if (env.node) {
|
|
return false;
|
|
}
|
|
var hostSeries = this.__hostSeries;
|
|
return this.getShallow('animation') && hostSeries && hostSeries.isAnimationEnabled();
|
|
};
|
|
/**
|
|
* @overrite
|
|
*/
|
|
MarkerModel.prototype.mergeOption = function (newOpt, ecModel) {
|
|
this._mergeOption(newOpt, ecModel, false, false);
|
|
};
|
|
MarkerModel.prototype._mergeOption = function (newOpt, ecModel, createdBySelf, isInit) {
|
|
var componentType = this.mainType;
|
|
if (!createdBySelf) {
|
|
ecModel.eachSeries(function (seriesModel) {
|
|
// mainType can be markPoint, markLine, markArea
|
|
var markerOpt = seriesModel.get(this.mainType, true);
|
|
var markerModel = inner(seriesModel)[componentType];
|
|
if (!markerOpt || !markerOpt.data) {
|
|
inner(seriesModel)[componentType] = null;
|
|
return;
|
|
}
|
|
if (!markerModel) {
|
|
if (isInit) {
|
|
// Default label emphasis `position` and `show`
|
|
fillLabel(markerOpt);
|
|
}
|
|
zrUtil.each(markerOpt.data, function (item) {
|
|
// FIXME Overwrite fillLabel method ?
|
|
if (item instanceof Array) {
|
|
fillLabel(item[0]);
|
|
fillLabel(item[1]);
|
|
} else {
|
|
fillLabel(item);
|
|
}
|
|
});
|
|
markerModel = this.createMarkerModelFromSeries(markerOpt, this, ecModel);
|
|
// markerModel = new ImplementedMarkerModel(
|
|
// markerOpt, this, ecModel
|
|
// );
|
|
zrUtil.extend(markerModel, {
|
|
mainType: this.mainType,
|
|
// Use the same series index and name
|
|
seriesIndex: seriesModel.seriesIndex,
|
|
name: seriesModel.name,
|
|
createdBySelf: true
|
|
});
|
|
markerModel.__hostSeries = seriesModel;
|
|
} else {
|
|
markerModel._mergeOption(markerOpt, ecModel, true);
|
|
}
|
|
inner(seriesModel)[componentType] = markerModel;
|
|
}, this);
|
|
}
|
|
};
|
|
MarkerModel.prototype.formatTooltip = function (dataIndex, multipleSeries, dataType) {
|
|
var data = this.getData();
|
|
var value = this.getRawValue(dataIndex);
|
|
var itemName = data.getName(dataIndex);
|
|
return createTooltipMarkup('section', {
|
|
header: this.name,
|
|
blocks: [createTooltipMarkup('nameValue', {
|
|
name: itemName,
|
|
value: value,
|
|
noName: !itemName,
|
|
noValue: value == null
|
|
})]
|
|
});
|
|
};
|
|
MarkerModel.prototype.getData = function () {
|
|
return this._data;
|
|
};
|
|
MarkerModel.prototype.setData = function (data) {
|
|
this._data = data;
|
|
};
|
|
MarkerModel.getMarkerModelFromSeries = function (seriesModel,
|
|
// Support three types of markers. Strict check.
|
|
componentType) {
|
|
return inner(seriesModel)[componentType];
|
|
};
|
|
MarkerModel.type = 'marker';
|
|
MarkerModel.dependencies = ['series', 'grid', 'polar', 'geo'];
|
|
return MarkerModel;
|
|
}(ComponentModel);
|
|
zrUtil.mixin(MarkerModel, DataFormatMixin.prototype);
|
|
export default MarkerModel; |