import { PropType, h, inject } from 'vue' import { defineVxeComponent } from '../../ui/src/comp' import { VxeUI, getI18n } from '@vxe-ui/core' import { WidgetInputFormObjVO } from './input-data' import { useWidgetName } from '../../form-design/src/use' import type { VxeGlobalRendererHandles, VxeFormViewConstructor, VxeFormViewPrivateMethods } from '../../../types' export const WidgetInputViewComponent = defineVxeComponent({ props: { renderOpts: { type: Object as PropType, default: () => ({}) }, renderParams: { type: Object as PropType>, default: () => ({}) } }, emits: [], setup (props) { const VxeUIFormItemComponent = VxeUI.getComponent('vxe-form-item') const $xeFormView = inject<(VxeFormViewConstructor & VxeFormViewPrivateMethods) | null>('$xeFormView', null) const { computeKebabCaseName } = useWidgetName(props) const changeEvent = () => { const { renderParams } = props const { widget } = renderParams if ($xeFormView) { const itemValue = $xeFormView ? $xeFormView.getItemValue(widget) : null $xeFormView.updateWidgetStatus(widget, itemValue) } } return () => { const { renderParams } = props const { widget } = renderParams const { options } = widget const kebabCaseName = computeKebabCaseName.value return h(VxeUIFormItemComponent, { class: ['vxe-form-design--widget-render-form-item', `widget-${kebabCaseName}`], field: widget.field, title: widget.title, itemRender: {} }, { default () { return h('input', { class: 'vxe-default-input', type: 'text', placeholder: options.placeholder || getI18n('vxe.base.pleaseInput'), value: $xeFormView ? $xeFormView.getItemValue(widget) : null, onChange: changeEvent, onInput (evnt: InputEvent & { target: HTMLInputElement }) { if ($xeFormView) { $xeFormView.setItemValue(widget, evnt.target.value) } } }) } }) } } })