config.vue 5.22 KB
<template>
  <CollapseItem name="头部左侧配置" :expanded="true">
    <SettingItemBox :name="`颜色-${index + 1}`" v-for="(item, index) in optionData.colorLefts" :key="index">
      <SettingItem name="颜色">
        <n-color-picker size="small" :modes="['hex']" v-model:value="optionData.colorLefts[index]"></n-color-picker>
      </SettingItem>
      <SettingItem>
        <n-button size="small" @click="optionData.colorLefts[index] = option.colorLefts[index]"> 恢复默认 </n-button>
      </SettingItem>
    </SettingItemBox>
    <SettingItemBox name="大小">
      <SettingItem name="宽度">
        <n-input-number size="small" v-model:value="optionData.headLeftInfo.w"></n-input-number>
      </SettingItem>
      <SettingItem name="高度">
        <n-input-number size="small" v-model:value="optionData.headLeftInfo.h"></n-input-number>
      </SettingItem>
    </SettingItemBox>
    <SettingItemBox name="间距">
      <SettingItem name="左间距">
        <n-input-number size="small" v-model:value="optionData.headLeftInfo.ml"></n-input-number>
      </SettingItem>
      <SettingItem name="上间距">
        <n-input-number size="small" v-model:value="optionData.headLeftInfo.mt"></n-input-number>
      </SettingItem>
    </SettingItemBox>
    <SettingItemBox name="方向">
      <SettingItem>
        <n-space>
          <n-switch v-model:value="optionData.headLeftInfo.headLeftReverse" size="small" />
          <n-text>开启反向</n-text>
        </n-space>
      </SettingItem>
    </SettingItemBox>
  </CollapseItem>
  <CollapseItem name="头部中间配置" :expanded="true">
    <SettingItemBox :name="`颜色-${index + 1}`" v-for="(item, index) in optionData.colorTexts" :key="index">
      <SettingItem name="颜色">
        <n-color-picker size="small" :modes="['hex']" v-model:value="optionData.colorTexts[index]"></n-color-picker>
      </SettingItem>
      <SettingItem>
        <n-button size="small" @click="optionData.colorTexts[index] = option.colorTexts[index]"> 恢复默认 </n-button>
      </SettingItem>
    </SettingItemBox>
    <SettingItemBox name="文字" alone>
      <SettingItem>
        <n-input v-model:value="optionData.headCenterInfo.dataset" size="small"></n-input>
      </SettingItem>
    </SettingItemBox>
    <SettingItemBox name="样式">
      <SettingItem name="颜色">
        <n-color-picker
          size="small"
          :modes="['hex']"
          v-model:value="optionData.headCenterInfo.textColor"
        ></n-color-picker>
      </SettingItem>
      <SettingItem name="大小">
        <n-input-number v-model:value="optionData.headCenterInfo.textSize" size="small" :min="12"></n-input-number>
      </SettingItem>
    </SettingItemBox>
    <SettingItemBox name="大小">
      <SettingItem name="宽度">
        <n-input-number size="small" v-model:value="optionData.headCenterInfo.w"></n-input-number>
      </SettingItem>
      <SettingItem name="高度">
        <n-input-number size="small" v-model:value="optionData.headCenterInfo.h"></n-input-number>
      </SettingItem>
    </SettingItemBox>
    <SettingItemBox name="间距">
      <SettingItem name="左间距">
        <n-input-number size="small" v-model:value="optionData.headCenterInfo.ml"></n-input-number>
      </SettingItem>
      <SettingItem name="上间距">
        <n-input-number size="small" v-model:value="optionData.headCenterInfo.mt"></n-input-number>
      </SettingItem>
    </SettingItemBox>
  </CollapseItem>
  <CollapseItem name="头部右侧配置" :expanded="true">
    <SettingItemBox :name="`颜色-${index + 1}`" v-for="(item, index) in optionData.colorRights" :key="index">
      <SettingItem name="颜色">
        <n-color-picker size="small" :modes="['hex']" v-model:value="optionData.colorRights[index]"></n-color-picker>
      </SettingItem>
      <SettingItem>
        <n-button size="small" @click="optionData.colorRights[index] = option.colorRights[index]"> 恢复默认 </n-button>
      </SettingItem>
    </SettingItemBox>
    <SettingItemBox name="大小">
      <SettingItem name="宽度">
        <n-input-number size="small" v-model:value="optionData.headRightInfo.w"></n-input-number>
      </SettingItem>
      <SettingItem name="高度">
        <n-input-number size="small" v-model:value="optionData.headRightInfo.h"></n-input-number>
      </SettingItem>
    </SettingItemBox>
    <SettingItemBox name="间距">
      <SettingItem name="左间距">
        <n-input-number size="small" v-model:value="optionData.headRightInfo.ml"></n-input-number>
      </SettingItem>
      <SettingItem name="上间距">
        <n-input-number size="small" v-model:value="optionData.headRightInfo.mt"></n-input-number>
      </SettingItem>
    </SettingItemBox>
    <SettingItemBox name="方向">
      <SettingItem>
        <n-space>
          <n-switch v-model:value="optionData.headRightInfo.headRightReverse" size="small" />
          <n-text>开启反向</n-text>
        </n-space>
      </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 any as PropType<typeof option>,
    required: true
  }
})
</script>