You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
202 lines
7.4 KiB
202 lines
7.4 KiB
|
|
/*
|
|
* 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 * as zrUtil from 'zrender/lib/core/util.js';
|
|
import { retrieveRawValue } from '../../data/helper/dataProvider.js';
|
|
import { formatTpl } from '../../util/format.js';
|
|
import { error, makePrintable } from '../../util/log.js';
|
|
var DIMENSION_LABEL_REG = /\{@(.+?)\}/g;
|
|
var DataFormatMixin = /** @class */function () {
|
|
function DataFormatMixin() {}
|
|
/**
|
|
* Get params for formatter
|
|
*/
|
|
DataFormatMixin.prototype.getDataParams = function (dataIndex, dataType) {
|
|
var data = this.getData(dataType);
|
|
var rawValue = this.getRawValue(dataIndex, dataType);
|
|
var rawDataIndex = data.getRawIndex(dataIndex);
|
|
var name = data.getName(dataIndex);
|
|
var itemOpt = data.getRawDataItem(dataIndex);
|
|
var style = data.getItemVisual(dataIndex, 'style');
|
|
var color = style && style[data.getItemVisual(dataIndex, 'drawType') || 'fill'];
|
|
var borderColor = style && style.stroke;
|
|
var mainType = this.mainType;
|
|
var isSeries = mainType === 'series';
|
|
var userOutput = data.userOutput && data.userOutput.get();
|
|
return {
|
|
componentType: mainType,
|
|
componentSubType: this.subType,
|
|
componentIndex: this.componentIndex,
|
|
seriesType: isSeries ? this.subType : null,
|
|
seriesIndex: this.seriesIndex,
|
|
seriesId: isSeries ? this.id : null,
|
|
seriesName: isSeries ? this.name : null,
|
|
name: name,
|
|
dataIndex: rawDataIndex,
|
|
data: itemOpt,
|
|
dataType: dataType,
|
|
value: rawValue,
|
|
color: color,
|
|
borderColor: borderColor,
|
|
dimensionNames: userOutput ? userOutput.fullDimensions : null,
|
|
encode: userOutput ? userOutput.encode : null,
|
|
// Param name list for mapping `a`, `b`, `c`, `d`, `e`
|
|
$vars: ['seriesName', 'name', 'value']
|
|
};
|
|
};
|
|
/**
|
|
* Format label
|
|
* @param dataIndex
|
|
* @param status 'normal' by default
|
|
* @param dataType
|
|
* @param labelDimIndex Only used in some chart that
|
|
* use formatter in different dimensions, like radar.
|
|
* @param formatter Formatter given outside.
|
|
* @return return null/undefined if no formatter
|
|
*/
|
|
DataFormatMixin.prototype.getFormattedLabel = function (dataIndex, status, dataType, labelDimIndex, formatter, extendParams) {
|
|
status = status || 'normal';
|
|
var data = this.getData(dataType);
|
|
var params = this.getDataParams(dataIndex, dataType);
|
|
if (extendParams) {
|
|
params.value = extendParams.interpolatedValue;
|
|
}
|
|
if (labelDimIndex != null && zrUtil.isArray(params.value)) {
|
|
params.value = params.value[labelDimIndex];
|
|
}
|
|
if (!formatter) {
|
|
var itemModel = data.getItemModel(dataIndex);
|
|
// @ts-ignore
|
|
formatter = itemModel.get(status === 'normal' ? ['label', 'formatter'] : [status, 'label', 'formatter']);
|
|
}
|
|
if (zrUtil.isFunction(formatter)) {
|
|
params.status = status;
|
|
params.dimensionIndex = labelDimIndex;
|
|
return formatter(params);
|
|
} else if (zrUtil.isString(formatter)) {
|
|
var str = formatTpl(formatter, params);
|
|
// Support 'aaa{@[3]}bbb{@product}ccc'.
|
|
// Do not support '}' in dim name util have to.
|
|
return str.replace(DIMENSION_LABEL_REG, function (origin, dimStr) {
|
|
var len = dimStr.length;
|
|
var dimLoose = dimStr;
|
|
if (dimLoose.charAt(0) === '[' && dimLoose.charAt(len - 1) === ']') {
|
|
dimLoose = +dimLoose.slice(1, len - 1); // Also support: '[]' => 0
|
|
if (process.env.NODE_ENV !== 'production') {
|
|
if (isNaN(dimLoose)) {
|
|
error("Invalide label formatter: @" + dimStr + ", only support @[0], @[1], @[2], ...");
|
|
}
|
|
}
|
|
}
|
|
var val = retrieveRawValue(data, dataIndex, dimLoose);
|
|
if (extendParams && zrUtil.isArray(extendParams.interpolatedValue)) {
|
|
var dimIndex = data.getDimensionIndex(dimLoose);
|
|
if (dimIndex >= 0) {
|
|
val = extendParams.interpolatedValue[dimIndex];
|
|
}
|
|
}
|
|
return val != null ? val + '' : '';
|
|
});
|
|
}
|
|
};
|
|
/**
|
|
* Get raw value in option
|
|
*/
|
|
DataFormatMixin.prototype.getRawValue = function (idx, dataType) {
|
|
return retrieveRawValue(this.getData(dataType), idx);
|
|
};
|
|
/**
|
|
* Should be implemented.
|
|
* @param {number} dataIndex
|
|
* @param {boolean} [multipleSeries=false]
|
|
* @param {string} [dataType]
|
|
*/
|
|
DataFormatMixin.prototype.formatTooltip = function (dataIndex, multipleSeries, dataType) {
|
|
// Empty function
|
|
return;
|
|
};
|
|
return DataFormatMixin;
|
|
}();
|
|
export { DataFormatMixin };
|
|
;
|
|
// PENDING: previously we accept this type when calling `formatTooltip`,
|
|
// but guess little chance has been used outside. Do we need to backward
|
|
// compat it?
|
|
// type TooltipFormatResultLegacyObject = {
|
|
// // `html` means the markup language text, either in 'html' or 'richText'.
|
|
// // The name `html` is not appropriate because in 'richText' it is not a HTML
|
|
// // string. But still support it for backward compatibility.
|
|
// html: string;
|
|
// markers: Dictionary<ColorString>;
|
|
// };
|
|
/**
|
|
* For backward compat, normalize the return from `formatTooltip`.
|
|
*/
|
|
export function normalizeTooltipFormatResult(result) {
|
|
var markupText;
|
|
// let markers: Dictionary<ColorString>;
|
|
var markupFragment;
|
|
if (zrUtil.isObject(result)) {
|
|
if (result.type) {
|
|
markupFragment = result;
|
|
} else {
|
|
if (process.env.NODE_ENV !== 'production') {
|
|
console.warn('The return type of `formatTooltip` is not supported: ' + makePrintable(result));
|
|
}
|
|
}
|
|
// else {
|
|
// markupText = (result as TooltipFormatResultLegacyObject).html;
|
|
// markers = (result as TooltipFormatResultLegacyObject).markers;
|
|
// if (markersExisting) {
|
|
// markers = zrUtil.merge(markersExisting, markers);
|
|
// }
|
|
// }
|
|
} else {
|
|
markupText = result;
|
|
}
|
|
return {
|
|
text: markupText,
|
|
// markers: markers || markersExisting,
|
|
frag: markupFragment
|
|
};
|
|
} |