| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104 |
- <template>
- <!-- Echarts 全局设置 -->
- <global-setting :optionData="optionData"></global-setting>
- <CollapseItem name="饼图配置" :expanded="true">
- <SettingItemBox name="类型">
- <SettingItem>
- <n-select v-model:value="optionData.type" size="small" :options="fontWeightOptions" />
- </SettingItem>
- </SettingItemBox>
- <SettingItemBox name="动画" :alone="true">
- <SettingItem>
- <n-space>
- <n-switch v-model:value="optionData.isCarousel" size="small"></n-switch>
- <n-text>开启<n-text :depth="3">(将自动隐藏图例)</n-text></n-text>
- </n-space>
- </SettingItem>
- <SettingItem>
- <n-text :depth="3">无鼠标点击图例场景时,可强行打开图例</n-text>
- </SettingItem>
- </SettingItemBox>
- <SettingItemBox name="标签">
- <SettingItem>
- <n-space>
- <n-switch v-model:value="optionData.series[0].label.show" size="small"></n-switch>
- <n-text>展示标签</n-text>
- </n-space>
- </SettingItem>
- <setting-item>
- <n-space>
- <n-switch v-model:value="optionData.series[0].labelLine.show" size="small"></n-switch>
- <n-text>引导线</n-text>
- </n-space>
- </setting-item>
- <SettingItem name="位置">
- <n-select v-model:value="optionData.series[0].label.position" size="small" :options="labelConfig.position" />
- </SettingItem>
- <setting-item name="展示类型">
- <n-select v-model:value="optionData.series[0].label.formatter" size="small" :options="labelFormatterOptions" />
- </setting-item>
- <setting-item name="标签颜色">
- <n-color-picker size="small" :modes="['hex']" v-model:value="optionData.series[0].label.color"></n-color-picker>
- </setting-item>
- </SettingItemBox>
- <setting-item-box name="圆角">
- <setting-item>
- <n-space>
- <n-input-number
- v-model:value="optionData.series[0].itemStyle.borderRadius"
- size="small"
- :min="0"
- ></n-input-number>
- <n-text>圆角大小</n-text>
- </n-space>
- </setting-item>
- <setting-item>
- <n-space>
- <n-input-number
- v-model:value="optionData.series[0].itemStyle.borderWidth"
- size="small"
- :min="0"
- ></n-input-number>
- <n-text>线条宽度</n-text>
- </n-space>
- </setting-item>
- </setting-item-box>
- </CollapseItem>
- </template>
- <script setup lang="ts">
- import { PropType, watch } from 'vue'
- import { GlobalThemeJsonType } from '@/settings/chartThemes/index'
- import { GlobalSetting, CollapseItem, SettingItemBox, SettingItem } from '@/components/Pages/ChartItemSetting'
- import { PieTypeObject, PieTypeEnum } from './config'
- import { labelConfig } from '@/packages/chartConfiguration/echarts'
- const props = defineProps({
- optionData: {
- type: Object as PropType<GlobalThemeJsonType>,
- required: true
- }
- })
- const fontWeightOptions = [
- {
- label: PieTypeEnum.NORMAL,
- value: PieTypeObject[PieTypeEnum.NORMAL]
- },
- {
- label: PieTypeEnum.RING,
- value: PieTypeObject[PieTypeEnum.RING]
- },
- {
- label: PieTypeEnum.ROSE,
- value: PieTypeObject[PieTypeEnum.ROSE]
- }
- ]
- const labelFormatterOptions = [
- { label: '数据名', value: '{b}' },
- { label: '百分比', value: '{d}' },
- { label: '列名:百分比', value: '{b}:{d}%' },
- { label: '列名:数据值(data1)', value: '{b}:{@data1}' },
- { label: '数据值(data1)', value: '{@data1}' }
- ]
- </script>
|