config.vue 3.36 KB
<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>