@antv/g2plot
Version:
An interactive and responsive charting library
171 lines • 6.13 kB
JavaScript
import { __assign, __spreadArrays } from "tslib";
import { get } from '@antv/util';
import { point } from '../../adaptor/geometries/point';
import { interaction as baseInteraction, animation, theme, legend, annotation, scale, pattern, } from '../../adaptor/common';
import { flow, deepAssign } from '../../utils';
import { getAdjustAppendPadding, resolveAllPadding } from '../../utils/padding';
import { transformData, resolvePaddingForCircle } from './utils';
import { RAW_FIELDS } from './constant';
/**
* 获取默认 option
* @param params
*/
function defaultOptions(params) {
var chart = params.chart;
var diameter = Math.min(chart.viewBBox.width, chart.viewBBox.height);
return deepAssign({
options: {
size: function (_a) {
var r = _a.r;
return r * diameter;
},
},
}, params);
}
/**
* padding 配置
* @param params
*/
function padding(params) {
var options = params.options, chart = params.chart;
// 通过改变 padding,修改 coordinate 的绘制区域
var containerSize = chart.viewBBox;
var padding = options.padding, appendPadding = options.appendPadding, drilldown = options.drilldown;
var tempAppendPadding = appendPadding;
if (drilldown === null || drilldown === void 0 ? void 0 : drilldown.enabled) {
var appendPaddingByDrilldown = getAdjustAppendPadding(chart.appendPadding, get(drilldown, ['breadCrumb', 'position']));
tempAppendPadding = resolveAllPadding([appendPaddingByDrilldown, appendPadding]);
}
var finalPadding = resolvePaddingForCircle(padding, tempAppendPadding, containerSize).finalPadding;
chart.padding = finalPadding;
chart.appendPadding = 0;
return params;
}
/**
* 字段
* @param params
*/
function geometry(params) {
var chart = params.chart, options = params.options;
var padding = chart.padding, appendPadding = chart.appendPadding;
var color = options.color, colorField = options.colorField, pointStyle = options.pointStyle, hierarchyConfig = options.hierarchyConfig, sizeField = options.sizeField, _a = options.rawFields, rawFields = _a === void 0 ? [] : _a, drilldown = options.drilldown;
var data = transformData({
data: options.data,
hierarchyConfig: hierarchyConfig,
enableDrillDown: drilldown === null || drilldown === void 0 ? void 0 : drilldown.enabled,
rawFields: rawFields,
});
chart.data(data);
var containerSize = chart.viewBBox;
var finalSize = resolvePaddingForCircle(padding, appendPadding, containerSize).finalSize;
// 有sizeField的时候,例如 value ,可以选择映射 size 函数,自己计算出映射的半径
var circleSize = function (_a) {
var r = _a.r;
return r * finalSize;
}; // 默认配置
if (sizeField) {
circleSize = function (d) { return d[sizeField] * finalSize; }; // 目前只有 r 通道映射效果会正常
}
// geometry
point(deepAssign({}, params, {
options: {
xField: 'x',
yField: 'y',
seriesField: colorField,
sizeField: sizeField,
rawFields: __spreadArrays(RAW_FIELDS, rawFields),
point: {
color: color,
style: pointStyle,
shape: 'circle',
size: circleSize,
},
},
}));
return params;
}
/**
* meta 配置
* @param params
*/
export function meta(params) {
return flow(scale({}, {
// 必须强制为 nice
x: { min: 0, max: 1, minLimit: 0, maxLimit: 1, nice: true },
y: { min: 0, max: 1, minLimit: 0, maxLimit: 1, nice: true },
}))(params);
}
/**
* tooltip 配置
* @param params
*/
function tooltip(params) {
var chart = params.chart, options = params.options;
var tooltip = options.tooltip;
if (tooltip === false) {
chart.tooltip(false);
}
else {
var tooltipOptions = tooltip;
// 设置了 fields,就不进行 customItems 了; 设置 formatter 时,需要搭配 fields
if (!get(tooltip, 'fields')) {
tooltipOptions = deepAssign({}, {
customItems: function (items) {
return items.map(function (item) {
var scales = get(chart.getOptions(), 'scales');
var nameFormatter = get(scales, ['name', 'formatter'], function (v) { return v; });
var valueFormatter = get(scales, ['value', 'formatter'], function (v) { return v; });
return __assign(__assign({}, item), { name: nameFormatter(item.data.name), value: valueFormatter(item.data.value) });
});
},
}, tooltipOptions);
}
chart.tooltip(tooltipOptions);
}
return params;
}
/**
* 坐标轴, 默认关闭
* @param params
*/
function axis(params) {
var chart = params.chart;
chart.axis(false);
return params;
}
function adaptorInteraction(options) {
var drilldown = options.drilldown, _a = options.interactions, interactions = _a === void 0 ? [] : _a;
if (drilldown === null || drilldown === void 0 ? void 0 : drilldown.enabled) {
return deepAssign({}, options, {
interactions: __spreadArrays(interactions, [
{
type: 'drill-down',
cfg: { drillDownConfig: drilldown, transformData: transformData, enableDrillDown: true },
},
]),
});
}
return options;
}
/**
* 交互配置
* @param params
* @returns
*/
function interaction(params) {
var chart = params.chart, options = params.options;
baseInteraction({
chart: chart,
options: adaptorInteraction(options),
});
return params;
}
/**
* 矩形树图
* @param chart
* @param options
*/
export function adaptor(params) {
return flow(pattern('pointStyle'), defaultOptions, padding, theme, meta, geometry, axis, legend, tooltip, interaction, animation, annotation())(params);
}
//# sourceMappingURL=adaptor.js.map