config.vue
3.36 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
<template>
<!-- Echarts 全局设置 -->
<global-setting :optionData="optionData"> </global-setting>
<!-- 漏斗图 -->
<collapse-item v-for="(item, index) in seriesList" :key="index" :name="`${t('charts.chart.funnelPlot')}`" expanded>
<setting-item-box :name="t('common.sortText')" alone>
<setting-item>
<n-select v-model:value="item.sort" :options="FunnelOrderEnumList" size="small" />
</setting-item>
</setting-item-box>
<SettingItemBox :name="t('common.rangeText')" :alone="true">
<setting-item :name="`${t('charts.chart.topDistance')}${item.top}px`">
<n-slider v-model:value="item.top" :min="0" :max="300" :format-tooltip="sliderFormatTooltip"></n-slider>
</setting-item>
</SettingItemBox>
<setting-item-box :name="t('charts.chart.block')">
<setting-item :name="t('charts.chart.borderSize')">
<n-input-number v-model:value="item.itemStyle.borderWidth" :min="0" :max="10" size="small" />
</setting-item>
<setting-item :name="t('charts.chart.borderColor')">
<n-color-picker v-model:value="item.itemStyle.borderColor" :modes="['hex']" size="small" />
</setting-item>
<setting-item :name="t('common.intervalText')">
<n-input-number v-model:value="item.gap" :min="0" :max="20" size="small" />
</setting-item>
</setting-item-box>
<setting-item-box :name="t('common.labelText')">
<setting-item :name="t('common.isDisplayText')">
<n-checkbox v-model:checked="item.label.show" size="small">{{ t('common.labbelText') }}</n-checkbox>
</setting-item>
<setting-item :name="t('common.positionText')">
<n-select v-model:value="item.label.position" :options="FunnelLabelPositionEnumList" size="small" />
</setting-item>
<setting-item :name="t('charts.chart.sizeText')">
<n-input-number v-model:value="item.label.fontSize" :min="0" size="small" />
</setting-item>
<setting-item :name="t('charts.chart.hoverSize')">
<n-input-number v-model:value="item.emphasis.label.fontSize" :min="0" size="small" />
</setting-item>
</setting-item-box>
</collapse-item>
</template>
<script setup lang="ts">
import { PropType, computed } from 'vue'
import { GlobalSetting, CollapseItem, SettingItemBox, SettingItem } from '@/components/Pages/ChartItemSetting'
import { GlobalThemeJsonType } from '@/settings/chartThemes/index'
// import { option, FunnelOrderEnumList, FunnelLabelPositionEnumList } from './config'
import { option } from './config'
const props = defineProps({
optionData: {
type: Object as PropType<typeof option & GlobalThemeJsonType>,
required: true
}
})
const t = window['$t']
const seriesList = computed(() => {
return props.optionData.series
})
const sliderFormatTooltip = (v: number) => {
return `${v}px`
}
// 排序枚举
const FunnelOrderEnumList = [
{ label: t('common.symbolEnumList.descending'), value: 'descending' },
{ label: t('common.symbolEnumList.ascending'), value: 'ascending' }
]
// 标签位置枚举
const FunnelLabelPositionEnumList = [
{ label: t('common.funnelLabelPositionEnumList.inside'), value: 'inside' },
{ label: t('common.funnelLabelPositionEnumList.outside'), value: 'outside' },
{ label: t('common.funnelLabelPositionEnumList.insideLeft'), value: 'insideLeft' },
{ label: t('common.funnelLabelPositionEnumList.insideRight'), value: 'insideRight' }
]
</script>