config.vue 2.21 KB
<template>
  <CollapseItem name="配置" :expanded="true">
    <SettingItemBox name="标题">
      <SettingItem name="内容">
        <n-input v-model:value="optionData.dataset" />
      </SettingItem>
      <SettingItem name="大小">
        <n-input-number v-model:value="optionData.attribute.fontSize" />
      </SettingItem>
      <SettingItem name="x轴位置">
        <n-input-number v-model:value="optionData.attribute.fontPos.x" />
      </SettingItem>
      <SettingItem name="y轴位置">
        <n-input-number v-model:value="optionData.attribute.fontPos.y" />
      </SettingItem>
      <SettingItem name="颜色">
        <n-color-picker size="small" :modes="['hex']" v-model:value="optionData.attribute.fontColor"></n-color-picker>
      </SettingItem>
      <SettingItem>
        <n-button size="small" @click="optionData.attribute.fontColor = '#2AFFFF'"> 恢复默认 </n-button>
      </SettingItem>
    </SettingItemBox>
    <SettingItemBox
      :name="`装饰颜色-${index + 1}`"
      v-for="(item, index) in optionData.attribute.linearColors"
      :key="index"
    >
      <SettingItem name="颜色">
        <n-color-picker
          size="small"
          :modes="['hex']"
          v-model:value="optionData.attribute.linearColors[index]"
        ></n-color-picker>
      </SettingItem>
      <SettingItem>
        <n-button size="small" @click="optionData.attribute.linearColors[index] = option.attribute.linearColors[index]">
          恢复默认
        </n-button>
      </SettingItem>
    </SettingItemBox>
    <SettingItemBox :name="`装饰颜色8`">
      <SettingItem name="颜色">
        <n-color-picker size="small" :modes="['hex']" v-model:value="optionData.attribute.lineColor"></n-color-picker>
      </SettingItem>
      <SettingItem>
        <n-button size="small" @click="optionData.attribute.lineColor = '#2AFFFF'"> 恢复默认 </n-button>
      </SettingItem>
    </SettingItemBox>
  </CollapseItem>
</template>

<script setup lang="ts">
import { PropType } from 'vue'
import { option } from './config'
import { CollapseItem, SettingItemBox, SettingItem } from '@/components/Pages/ChartItemSetting'

defineProps({
  optionData: {
    type: Object as PropType<typeof option>,
    required: true
  }
})
</script>