config.vue
3.19 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
<template>
<CollapseItem name="配置" :expanded="true">
<SettingItemBox :name="`颜色-${index + 1}`" v-for="(item, index) in optionData.animat.colors" :key="index">
<SettingItem name="颜色">
<n-color-picker size="small" :modes="['hex']" v-model:value="optionData.animat.colors[index]"></n-color-picker>
</SettingItem>
<SettingItem>
<n-button size="small" @click="optionData.animat.colors[index] = optionData.animat.colors[index]">
恢复默认
</n-button>
</SettingItem>
</SettingItemBox>
<SettingItemBox name="大小">
<SettingItem name="宽度">
<n-input-number size="small" v-model:value="optionData.animat.w"></n-input-number>
</SettingItem>
<SettingItem name="高度">
<n-input-number size="small" v-model:value="optionData.animat.h"></n-input-number>
</SettingItem>
</SettingItemBox>
<SettingItemBox name="间距">
<SettingItem name="左间距">
<n-input-number size="small" v-model:value="optionData.animat.x"></n-input-number>
</SettingItem>
<SettingItem name="上间距">
<n-input-number size="small" v-model:value="optionData.animat.y"></n-input-number>
</SettingItem>
</SettingItemBox>
</CollapseItem>
<collapse-item name="信息" :expanded="true">
<setting-item-box name="文字" :alone="true">
<setting-item>
<n-input v-model:value="optionData.animat.text" size="small"></n-input>
</setting-item>
</setting-item-box>
</collapse-item>
<collapse-item name="样式" :expanded="true">
<setting-item-box name="文字">
<setting-item name="字体大小">
<n-input-number v-model:value="optionData.animat.size" size="small" placeholder="字体大小"></n-input-number>
</setting-item>
</setting-item-box>
<setting-item-box name="渐变色参数">
<setting-item name="起始值">
<n-color-picker size="small" :modes="['hex']" v-model:value="optionData.animat.gradient.from"></n-color-picker>
</setting-item>
<setting-item name="结束值">
<n-color-picker size="small" :modes="['hex']" v-model:value="optionData.animat.gradient.to"></n-color-picker>
</setting-item>
<setting-item name="偏移角度">
<n-input-number
v-model:value="optionData.animat.gradient.deg"
size="small"
placeholder="颜色旋转"
></n-input-number>
</setting-item>
</setting-item-box>
<setting-item-box name="间距">
<setting-item name="字体左间距">
<n-input-number v-model:value="optionData.animat.textPos.x" size="small" placeholder="间距"></n-input-number>
</setting-item>
<setting-item name="字体上间距">
<n-input-number v-model:value="optionData.animat.textPos.y" size="small" placeholder="间距"></n-input-number>
</setting-item>
</setting-item-box>
</collapse-item>
</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>