UNPKG

@antv/f2

Version:

Charts for mobile visualization.

65 lines 2.36 kB
import { __assign, __extends } from "tslib"; import { flatten, map, isArray, groupBy, mapValues, get } from '@antv/util'; import Adjust from './adjust'; var Symmetric = /** @class */function (_super) { __extends(Symmetric, _super); function Symmetric() { return _super !== null && _super.apply(this, arguments) || this; } Symmetric.prototype.process = function (groupDataArray) { var mergeData = flatten(groupDataArray); var _a = this, xField = _a.xField, yField = _a.yField; // 每个 x 值对应的 最大值 var cache = this.getXValuesMaxMap(mergeData); // 所有数据的最大的值 var max = Math.max.apply(Math, Object.keys(cache).map(function (key) { return cache[key]; })); return map(groupDataArray, function (dataArray) { return map(dataArray, function (data) { var _a, _b; var yValue = data[yField]; var xValue = data[xField]; // 数组处理逻辑 if (isArray(yValue)) { var off_1 = (max - cache[xValue]) / 2; return __assign(__assign({}, data), (_a = {}, _a[yField] = map(yValue, function (y) { return off_1 + y; }), _a)); } // 非数组处理逻辑 var offset = (max - yValue) / 2; return __assign(__assign({}, data), (_b = {}, _b[yField] = [offset, yValue + offset], _b)); }); }); }; // 获取每个 x 对应的最大的值 Symmetric.prototype.getXValuesMaxMap = function (mergeData) { var _this = this; var _a = this, xField = _a.xField, yField = _a.yField; // 根据 xField 的值进行分组 var groupDataArray = groupBy(mergeData, function (data) { return data[xField]; }); // 获取每个 xField 值中的最大值 return mapValues(groupDataArray, function (dataArray) { return _this.getDimMaxValue(dataArray, yField); }); }; Symmetric.prototype.getDimMaxValue = function (mergeData, dim) { // 所有的 value 值 var dimValues = map(mergeData, function (data) { return get(data, dim, []); }); // 将数组打平(dim value 有可能是数组,比如 stack 之后的) var flattenValues = flatten(dimValues); // 求出数组的最大值 return Math.max.apply(Math, flattenValues); }; return Symmetric; }(Adjust); export default Symmetric;