JinZHouXiYiJi_DaPin2/resource/Text/SubText/config.ts

103 lines
2.2 KiB
TypeScript
Raw Permalink Normal View History

2023-12-05 13:23:01 +08:00
import type { MetaContainerItem } from 'open-data-v/base'
import { ComponentGroup, CustomComponent, FormType } from 'open-data-v/base'
import { h } from 'vue'
export const componentName = 'SubText'
class SubTextComponent extends CustomComponent {
constructor(id?: string, name?: string, icon?: string) {
super({
component: componentName,
group: ComponentGroup.TEXT,
name: name ? name : '数据订阅文本',
id,
width: 100,
height: 30,
icon
})
}
_prop: MetaContainerItem[] = [
{
label: '基础配置',
prop: 'base',
children: [
{
prop: 'tag',
label: '数据标签',
type: FormType.TEXT,
props: {
defaultValue: ''
}
},
{
prop: 'url',
label: '获取数据API',
type: FormType.TEXT,
props: {
defaultValue: ''
}
},
{
prop: 'label',
label: 'Label',
type: FormType.TEXT,
props: {
defaultValue: ''
}
},
{
prop: 'unit',
label: '单位',
type: FormType.TEXT,
props: {
defaultValue: ''
}
}
]
}
]
_style: MetaContainerItem[] = [
{
label: '字体设置',
prop: 'font',
children: [
{
prop: 'color',
label: '颜色',
type: FormType.COLOR,
props: {
defaultValue: '#1E90FF'
}
},
{
prop: 'fontSize',
label: '字体大小',
type: FormType.NUMBER,
props: {
defaultValue: 20,
suffix: () => h('span', {}, 'px')
}
},
{
prop: 'fontWeight',
label: '字体宽度',
type: FormType.FONT_WEIGHT,
props: {
defaultValue: 200
}
},
{
prop: 'fontFamily',
label: '字体',
type: FormType.FONT_STYLE,
props: {
defaultValue: 'Arial'
}
}
]
}
]
}
export default SubTextComponent