config.vue 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. <template>
  2. <!-- Echarts 全局设置 -->
  3. <global-setting :optionData="optionData" in-chart> </global-setting>
  4. <!-- 漏斗图 -->
  5. <collapse-item v-for="(item, index) in seriesList" :key="index" :name="`漏斗图-${index + 1}`" expanded>
  6. <setting-item-box name="排序" alone>
  7. <setting-item>
  8. <n-select v-model:value="item.sort" :options="FunnelOrderEnumList" size="small" />
  9. </setting-item>
  10. </setting-item-box>
  11. <setting-item-box name="区块">
  12. <setting-item name="边框大小">
  13. <n-input-number v-model:value="item.itemStyle.borderWidth" :min="0" :max="10" size="small" />
  14. </setting-item>
  15. <setting-item name="边框颜色">
  16. <n-color-picker v-model:value="item.itemStyle.borderColor" :modes="['hex']" size="small" />
  17. </setting-item>
  18. <setting-item name="间隔">
  19. <n-input-number v-model:value="item.gap" :min="0" :max="20" size="small" />
  20. </setting-item>
  21. </setting-item-box>
  22. <setting-item-box name="标签">
  23. <setting-item name="是否显示">
  24. <n-checkbox v-model:checked="item.label.show" size="small">标签</n-checkbox>
  25. </setting-item>
  26. <setting-item name="位置">
  27. <n-select v-model:value="item.label.position" :options="FunnelLabelPositionEnumList" size="small" />
  28. </setting-item>
  29. <setting-item name="大小">
  30. <n-input-number v-model:value="item.label.fontSize" :min="0" size="small" />
  31. </setting-item>
  32. <setting-item name="悬停时大小">
  33. <n-input-number v-model:value="item.emphasis.label.fontSize" :min="0" size="small" />
  34. </setting-item>
  35. </setting-item-box>
  36. </collapse-item>
  37. </template>
  38. <script setup lang="ts">
  39. import { PropType, computed } from 'vue'
  40. import { GlobalSetting, CollapseItem, SettingItemBox, SettingItem } from '@/components/Pages/ChartItemSetting'
  41. import { GlobalThemeJsonType } from '@/settings/chartThemes/index'
  42. import { FunnelOrderEnumList, FunnelLabelPositionEnumList } from './config'
  43. const props = defineProps({
  44. optionData: {
  45. type: Object as PropType<GlobalThemeJsonType>,
  46. required: true
  47. }
  48. })
  49. const seriesList = computed(() => {
  50. return props.optionData.series
  51. })
  52. </script>