vxe-pc-ui
Version:
A vue based PC component library
75 lines (74 loc) • 2.14 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.WidgetInputViewComponent = void 0;
var _vue = require("vue");
var _core = require("@vxe-ui/core");
var _use = require("../../form-design/src/use");
var _formItem = _interopRequireDefault(require("../../form/src/form-item"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
const WidgetInputViewComponent = exports.WidgetInputViewComponent = (0, _vue.defineComponent)({
props: {
renderOpts: {
type: Object,
default: () => ({})
},
renderParams: {
type: Object,
default: () => ({})
}
},
emits: [],
setup(props) {
const $xeFormView = (0, _vue.inject)('$xeFormView', null);
const {
computeKebabCaseName
} = (0, _use.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 (0, _vue.h)(_formItem.default, {
class: ['vxe-form-design--widget-render-form-item', `widget-${kebabCaseName}`],
field: widget.field,
title: widget.title,
itemRender: {}
}, {
default() {
return (0, _vue.h)('input', {
class: 'vxe-default-input',
type: 'text',
placeholder: options.placeholder || (0, _core.getI18n)('vxe.base.pleaseInput'),
value: $xeFormView ? $xeFormView.getItemValue(widget) : null,
onChange: changeEvent,
onInput(evnt) {
if ($xeFormView) {
$xeFormView.setItemValue(widget, evnt.target.value);
}
}
});
}
});
};
}
});