mirror of
https://gitee.com/dromara/go-view.git
synced 2026-04-23 00:00:12 +08:00
61 lines
1.6 KiB
TypeScript
61 lines
1.6 KiB
TypeScript
import { PublicConfigClass } from '@/packages/public'
|
|
import { VChartBarCommonConfig } from './index'
|
|
import { CreateComponentType } from '@/packages/index.d'
|
|
import { vChartOptionPrefixHandle } from '@/packages/public/vChart'
|
|
import data from './data.json'
|
|
import axisThemeJson from '@/settings/vchartThemes/axis.theme.json'
|
|
import { ChatCategoryEnum, IBarOption } from '../../index.d'
|
|
import { merge, cloneDeep } from 'lodash'
|
|
|
|
export const includes = ['legends', 'tooltip', 'label', 'bar']
|
|
export const option: IBarOption & { dataset?: any } = {
|
|
// 图表配置
|
|
type: 'bar',
|
|
dataset: data,
|
|
stack: true,
|
|
xField: ['year', 'type'],
|
|
yField: ['value'],
|
|
seriesField: 'type',
|
|
// 业务配置(后续会被转换为图表spec)
|
|
category: VChartBarCommonConfig.category as ChatCategoryEnum.BAR,
|
|
xAxis: {
|
|
name: 'x轴',
|
|
...(merge(cloneDeep(axisThemeJson), {
|
|
unit: {
|
|
style: {
|
|
dx: 10,
|
|
dy: 0
|
|
}
|
|
}
|
|
}) as any),
|
|
grid: {
|
|
...axisThemeJson.grid,
|
|
visible: false
|
|
}
|
|
},
|
|
yAxis: {
|
|
name: 'y轴',
|
|
...(merge(cloneDeep(axisThemeJson), {
|
|
unit: {
|
|
style: {
|
|
dx: 0,
|
|
dy: -10
|
|
}
|
|
}
|
|
}) as any),
|
|
grid: {
|
|
...axisThemeJson.grid,
|
|
style: {
|
|
...axisThemeJson.grid.style
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
export default class Config extends PublicConfigClass implements CreateComponentType {
|
|
public key = VChartBarCommonConfig.key
|
|
public chartConfig = cloneDeep(VChartBarCommonConfig)
|
|
// 图表配置项
|
|
public option = vChartOptionPrefixHandle(option, includes)
|
|
}
|