vxe-pc-ui
Version:
A vue based PC component library
71 lines (70 loc) • 2.79 kB
JavaScript
import { defineComponent, h } from 'vue';
import { getI18n } from '@vxe-ui/core';
import VxeFormComponent from '../../form/src/form';
import VxeFormItemComponent from '../../form/src/form-item';
import VxeInputComponent from '../../input/src/input';
import VxeSwitchComponent from '../../switch/src/switch';
import { useWidgetName } from '../../form-design/src/use';
export const WidgetInputFormComponent = defineComponent({
props: {
renderOpts: {
type: Object,
default: () => ({})
},
renderParams: {
type: Object,
default: () => ({})
}
},
emits: [],
setup(props) {
const { computeKebabCaseName } = useWidgetName(props);
return () => {
const { renderParams } = props;
const { widget } = renderParams;
const kebabCaseName = computeKebabCaseName.value;
return h(VxeFormComponent, {
class: ['vxe-form-design--widget-render-form-wrapper', `widget-${kebabCaseName}`],
vertical: true,
span: 24,
titleBold: true,
titleOverflow: true,
data: widget.options
}, {
default() {
return [
h(VxeFormItemComponent, {
title: getI18n('vxe.formDesign.widgetProp.name')
}, {
default() {
return h(VxeInputComponent, {
modelValue: widget.title,
'onUpdate:modelValue'(val) {
widget.title = val;
}
});
}
}),
h(VxeFormItemComponent, {
title: getI18n('vxe.formDesign.widgetProp.placeholder'),
field: 'placeholder',
itemRender: { name: 'VxeInput' }
}),
h(VxeFormItemComponent, {
title: getI18n('vxe.formDesign.widgetProp.required')
}, {
default() {
return h(VxeSwitchComponent, {
modelValue: widget.required,
'onUpdate:modelValue'(val) {
widget.required = val;
}
});
}
})
];
}
});
};
}
});