import { Event, VIEW_LIFE_CIRCLE } from '@antv/g2'; import { Adaptor } from '../../core/adaptor'; import { Plot } from '../../core/plot'; import { processIllegalData } from '../../utils'; import { adaptor, pieAnnotation } from './adaptor'; import { DEFAULT_OPTIONS } from './contants'; import './interactions'; import { PieOptions } from './types'; import { isAllZero } from './utils'; export type { PieOptions }; export class Pie extends Plot { /** * 获取 饼图 默认配置项 * 供外部使用 */ static getDefaultOptions(): Partial { return DEFAULT_OPTIONS; } /** 图表类型 */ public type: string = 'pie'; /** * 更新数据 * @param data */ public changeData(data: PieOptions['data']) { this.chart.emit( VIEW_LIFE_CIRCLE.BEFORE_CHANGE_DATA, Event.fromData(this.chart, VIEW_LIFE_CIRCLE.BEFORE_CHANGE_DATA, null) ); const prevOptions = this.options; const { angleField } = this.options; const prevData = processIllegalData(prevOptions.data, angleField); const curData = processIllegalData(data, angleField); // 如果上一次或当前数据全为 0,则重新渲染 if (isAllZero(prevData, angleField) || isAllZero(curData, angleField)) { this.update({ data }); } else { this.updateOption({ data }); this.chart.data(curData); // todo 后续让 G2 层在 afterrender 之后,来重绘 annotations pieAnnotation({ chart: this.chart, options: this.options }); this.chart.render(true); } this.chart.emit( VIEW_LIFE_CIRCLE.AFTER_CHANGE_DATA, Event.fromData(this.chart, VIEW_LIFE_CIRCLE.AFTER_CHANGE_DATA, null) ); } /** * 获取 饼图 默认配置项, 供 base 获取 */ protected getDefaultOptions(): Partial { return Pie.getDefaultOptions(); } /** * 获取 饼图 的适配器 */ protected getSchemaAdaptor(): Adaptor { return adaptor; } }