UNPKG

vxe-pc-ui

Version:
566 lines (565 loc) 16.1 kB
"use strict"; var _vue = require("vue"); var _xeUtils = _interopRequireDefault(require("xe-utils")); var _ui = require("../../ui"); var _vn = require("../../ui/src/vn"); var _log = require("../../ui/src/log"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } const componentDefaultModelProp = 'modelValue'; /** * 已废弃 * @deprecated */ function getOldComponentName(name) { return `vxe-${name.replace('$', '')}`; } function getDefaultComponent({ name }) { return (0, _ui.getComponent)(name) || (0, _vue.resolveComponent)(name); } /** * 已废弃 * @deprecated */ function getOldComponent({ name }) { return (0, _vue.resolveComponent)(getOldComponentName(name)); } function getNativeAttrs(renderOpts) { let { name, attrs } = renderOpts; if (name === 'input') { attrs = Object.assign({ type: 'text' }, attrs); } return attrs; } function getComponentFormItemProps(renderOpts, params, value, defaultProps) { return _xeUtils.default.assign({}, defaultProps, renderOpts.props, { [componentDefaultModelProp]: value }); } /** * 原生事件处理 * @param renderOpts * @param params * @param modelFunc * @param changeFunc */ function getNativeElementOns(renderOpts, params, modelFunc, changeFunc) { const { events } = renderOpts; const modelEvent = (0, _vn.getModelEvent)(renderOpts.name); const changeEvent = (0, _vn.getChangeEvent)(renderOpts.name); const isSameEvent = changeEvent === modelEvent; const ons = {}; if (events) { _xeUtils.default.objectEach(events, (func, key) => { ons[(0, _vn.getOnName)(key)] = function (...args) { func(params, ...args); }; }); } if (modelFunc) { ons[(0, _vn.getOnName)(modelEvent)] = function (targetEvnt) { modelFunc(targetEvnt); if (isSameEvent && changeFunc) { changeFunc(targetEvnt); } if (events && events[modelEvent]) { events[modelEvent](params, targetEvnt); } }; } if (!isSameEvent && changeFunc) { ons[(0, _vn.getOnName)(changeEvent)] = function (...args) { changeFunc(...args); if (events && events[changeEvent]) { events[changeEvent](params, ...args); } }; } return ons; } /** * 组件事件处理 * @param renderOpts * @param params * @param modelFunc * @param changeFunc */ function getComponentOns(renderOpts, params, modelFunc, changeFunc) { const { events } = renderOpts; const modelEvent = (0, _vn.getModelEvent)(renderOpts.name); const changeEvent = (0, _vn.getChangeEvent)(renderOpts.name); const ons = {}; _xeUtils.default.objectEach(events, (func, key) => { ons[(0, _vn.getOnName)(key)] = function (...args) { if (process.env.NODE_ENV === 'development') { if (!_xeUtils.default.isFunction(func)) { (0, _log.errLog)('vxe.error.errFunc', [func]); } } func(params, ...args); }; }); if (modelFunc) { ons[(0, _vn.getOnName)(modelEvent)] = function (targetEvnt) { modelFunc(targetEvnt); if (events && events[modelEvent]) { events[modelEvent](params, targetEvnt); } }; } if (changeFunc) { ons[(0, _vn.getOnName)(changeEvent)] = function (...args) { changeFunc(...args); if (events && events[changeEvent]) { events[changeEvent](params, ...args); } }; } return ons; } function getItemOns(renderOpts, params) { const { $form, data, field } = params; return getComponentOns(renderOpts, params, value => { // 处理 model 值双向绑定 _xeUtils.default.set(data, field, value); }, () => { // 处理 change 事件相关逻辑 $form.updateStatus(params); }); } function getNativeItemOns(renderOpts, params) { const { $form, data, field } = params; return getNativeElementOns(renderOpts, params, evnt => { // 处理 model 值双向绑定 const itemValue = evnt.target.value; _xeUtils.default.set(data, field, itemValue); }, () => { // 处理 change 事件相关逻辑 $form.updateStatus(params); }); } function renderNativeOptgroup(renderOpts, params, renderOptionsMethods) { const { optionGroups, optionGroupProps = {} } = renderOpts; const groupOptions = optionGroupProps.options || 'options'; const groupLabel = optionGroupProps.label || 'label'; return optionGroups.map((group, gIndex) => { return (0, _vue.h)('optgroup', { key: gIndex, label: group[groupLabel] }, renderOptionsMethods(group[groupOptions], renderOpts, params)); }); } /** * 渲染表单-项 * 用于渲染原生的标签 */ function nativeItemRender(renderOpts, params) { const { data, field } = params; const { name } = renderOpts; const attrs = getNativeAttrs(renderOpts); const itemValue = _xeUtils.default.get(data, field); return [(0, _vue.h)(name, Object.assign(Object.assign(Object.assign({ class: `vxe-default-${name}` }, attrs), { value: attrs && name === 'input' && (attrs.type === 'submit' || attrs.type === 'reset') ? null : itemValue }), getNativeItemOns(renderOpts, params)))]; } function defaultItemRender(renderOpts, params) { const { data, field } = params; const itemValue = _xeUtils.default.get(data, field); return [(0, _vue.h)(getDefaultComponent(renderOpts), Object.assign(Object.assign({}, getComponentFormItemProps(renderOpts, params, itemValue)), getItemOns(renderOpts, params)))]; } /** * 已废弃 * @deprecated */ function oldItemRender(renderOpts, params) { const { data, field } = params; const itemValue = _xeUtils.default.get(data, field); return [(0, _vue.h)(getOldComponent(renderOpts), Object.assign(Object.assign({}, getComponentFormItemProps(renderOpts, params, itemValue)), getItemOns(renderOpts, params)))]; } /** * 已废弃 * @deprecated */ function oldButtonItemRender(renderOpts, params) { return [(0, _vue.h)((0, _vue.resolveComponent)('vxe-button'), Object.assign(Object.assign({}, getComponentFormItemProps(renderOpts, params, null)), getComponentOns(renderOpts, params)))]; } /** * 已废弃 * @deprecated */ function oldButtonsItemRender(renderOpts, params) { return renderOpts.children.map(childRenderOpts => oldButtonItemRender(childRenderOpts, params)[0]); } /** * 渲染原生的 select 标签 */ function renderNativeFormOptions(options, renderOpts, params) { const { data, field } = params; const { optionProps = {} } = renderOpts; const labelProp = optionProps.label || 'label'; const valueProp = optionProps.value || 'value'; const disabledProp = optionProps.disabled || 'disabled'; const cellValue = _xeUtils.default.get(data, field); return options.map((item, oIndex) => { return (0, _vue.h)('option', { key: oIndex, value: item[valueProp], disabled: item[disabledProp], /* eslint-disable eqeqeq */ selected: item[valueProp] == cellValue }, item[labelProp]); }); } /** * 渲染表单-项 */ function defaultFormItemRender(renderOpts, params) { const { data, field } = params; const itemValue = _xeUtils.default.get(data, field); return [(0, _vue.h)(getDefaultComponent(renderOpts), Object.assign(Object.assign({}, getComponentFormItemProps(renderOpts, params, itemValue)), getItemOns(renderOpts, params)))]; } function formItemRadioAndCheckboxRender(renderOpts, params) { const { options, optionProps } = renderOpts; const { data, field } = params; const itemValue = _xeUtils.default.get(data, field); return [(0, _vue.h)(getDefaultComponent(renderOpts), Object.assign(Object.assign({ options, optionProps }, getComponentFormItemProps(renderOpts, params, itemValue)), getItemOns(renderOpts, params)))]; } /** * 已废弃 * @deprecated */ function oldFormItemRadioAndCheckboxRender(renderOpts, params) { const { name, options, optionProps = {} } = renderOpts; const { data, field } = params; const labelProp = optionProps.label || 'label'; const valueProp = optionProps.value || 'value'; const disabledProp = optionProps.disabled || 'disabled'; const itemValue = _xeUtils.default.get(data, field); const compName = getOldComponentName(name); // 如果是分组 if (options) { return [(0, _vue.h)((0, _vue.resolveComponent)(`${compName}-group`), Object.assign(Object.assign({}, getComponentFormItemProps(renderOpts, params, itemValue)), getItemOns(renderOpts, params)), { default: () => { return options.map((item, index) => { return (0, _vue.h)((0, _vue.resolveComponent)(compName), { key: index, label: item[valueProp], content: item[labelProp], disabled: item[disabledProp] }); }); } })]; } return [(0, _vue.h)((0, _vue.resolveComponent)(compName), Object.assign(Object.assign({}, getComponentFormItemProps(renderOpts, params, itemValue)), getItemOns(renderOpts, params)))]; } /** * 表单 - 渲染器 */ _ui.renderer.mixin({ input: { formItemAutoFocus: 'input', renderFormItemContent: nativeItemRender }, textarea: { formItemAutoFocus: 'textarea', renderFormItemContent: nativeItemRender }, select: { formItemAutoFocus: 'input', renderFormItemContent(renderOpts, params) { return [(0, _vue.h)('select', Object.assign(Object.assign({ class: 'vxe-default-select' }, getNativeAttrs(renderOpts)), getNativeItemOns(renderOpts, params)), renderOpts.optionGroups ? renderNativeOptgroup(renderOpts, params, renderNativeFormOptions) : renderNativeFormOptions(renderOpts.options, renderOpts, params))]; } }, VxeInput: { formItemAutoFocus: 'input', renderFormItemContent: defaultItemRender }, VxeNumberInput: { formItemAutoFocus: 'input', renderFormItemContent: defaultItemRender }, VxePasswordInput: { formItemAutoFocus: 'input', renderFormItemContent: defaultItemRender }, VxeTextarea: { formItemAutoFocus: 'textarea', renderFormItemContent: defaultItemRender }, VxeDatePicker: { formItemAutoFocus: 'input', renderFormItemContent: defaultItemRender }, VxeButton: { renderFormItemContent: defaultFormItemRender }, VxeButtonGroup: { renderFormItemContent(renderOpts, params) { const { options } = renderOpts; const { data, field } = params; const itemValue = _xeUtils.default.get(data, field); return [(0, _vue.h)(getDefaultComponent(renderOpts), Object.assign(Object.assign({ options }, getComponentFormItemProps(renderOpts, params, itemValue)), getItemOns(renderOpts, params)))]; } }, VxeSelect: { formItemAutoFocus: 'input', renderFormItemContent(renderOpts, params) { const { data, field } = params; const { options, optionProps, optionGroups, optionGroupProps } = renderOpts; const itemValue = _xeUtils.default.get(data, field); return [(0, _vue.h)(getDefaultComponent(renderOpts), Object.assign(Object.assign({}, getComponentFormItemProps(renderOpts, params, itemValue, { options, optionProps, optionGroups, optionGroupProps })), getItemOns(renderOpts, params)))]; } }, VxeTreeSelect: { formItemAutoFocus: 'input', renderFormItemContent(renderOpts, params) { const { data, field } = params; const { options, optionProps } = renderOpts; const itemValue = _xeUtils.default.get(data, field); return [(0, _vue.h)(getDefaultComponent(renderOpts), Object.assign(Object.assign({}, getComponentFormItemProps(renderOpts, params, itemValue, { options, optionProps })), getItemOns(renderOpts, params)))]; } }, VxeTableSelect: { formItemAutoFocus: 'input', renderFormItemContent(renderOpts, params) { const { data, field } = params; const { options, optionProps } = renderOpts; const itemValue = _xeUtils.default.get(data, field); return [(0, _vue.h)(getDefaultComponent(renderOpts), Object.assign(Object.assign({}, getComponentFormItemProps(renderOpts, params, itemValue, { options, optionProps })), getItemOns(renderOpts, params)))]; } }, VxeColorPicker: { formItemAutoFocus: 'input', renderFormItemContent(renderOpts, params) { const { data, field } = params; const { options } = renderOpts; const itemValue = _xeUtils.default.get(data, field); return [(0, _vue.h)(getDefaultComponent(renderOpts), Object.assign(Object.assign({}, getComponentFormItemProps(renderOpts, params, itemValue, { colors: options })), getItemOns(renderOpts, params)))]; } }, VxeIconPicker: { formItemAutoFocus: 'input', renderFormItemContent(renderOpts, params) { const { data, field } = params; const { options } = renderOpts; const itemValue = _xeUtils.default.get(data, field); return [(0, _vue.h)(getDefaultComponent(renderOpts), Object.assign(Object.assign({}, getComponentFormItemProps(renderOpts, params, itemValue, { icons: options })), getItemOns(renderOpts, params)))]; } }, VxeRadio: { renderFormItemContent: defaultFormItemRender }, VxeRadioGroup: { renderFormItemContent: formItemRadioAndCheckboxRender }, VxeCheckbox: { renderFormItemContent: defaultFormItemRender }, VxeCheckboxGroup: { renderFormItemContent: formItemRadioAndCheckboxRender }, VxeSwitch: { renderFormItemContent: defaultItemRender }, VxeRate: { renderFormItemContent: defaultItemRender }, VxeSlider: { renderFormItemContent: defaultItemRender }, VxeImage: { renderFormItemContent(renderOpts, params) { const { data, field } = params; const { props } = renderOpts; const itemValue = _xeUtils.default.get(data, field); return [(0, _vue.h)(getDefaultComponent(renderOpts), Object.assign(Object.assign(Object.assign({}, props), { src: itemValue }), getItemOns(renderOpts, params)))]; } }, VxeImageGroup: { renderFormItemContent(renderOpts, params) { const { data, field } = params; const { props } = renderOpts; const itemValue = _xeUtils.default.get(data, field); return [(0, _vue.h)(getDefaultComponent(renderOpts), Object.assign(Object.assign(Object.assign({}, props), { urlList: itemValue }), getItemOns(renderOpts, params)))]; } }, VxeUpload: { renderFormItemContent: defaultItemRender }, // 以下已废弃 $input: { formItemAutoFocus: 'input', renderFormItemContent: oldItemRender }, $textarea: { formItemAutoFocus: 'textarea', renderFormItemContent: oldItemRender }, $button: { renderFormItemContent: oldButtonItemRender }, $buttons: { renderFormItemContent: oldButtonsItemRender }, $select: { formItemAutoFocus: 'input', renderFormItemContent(renderOpts, params) { const { data, field } = params; const { options, optionProps, optionGroups, optionGroupProps } = renderOpts; const itemValue = _xeUtils.default.get(data, field); return [(0, _vue.h)(getOldComponent(renderOpts), Object.assign(Object.assign({}, getComponentFormItemProps(renderOpts, params, itemValue, { options, optionProps, optionGroups, optionGroupProps })), getItemOns(renderOpts, params)))]; } }, $radio: { renderFormItemContent: oldFormItemRadioAndCheckboxRender }, $checkbox: { renderFormItemContent: oldFormItemRadioAndCheckboxRender }, $switch: { renderFormItemContent: oldItemRender } // 以上已废弃 });