@fesjs/fes-design
Version:
fes-design for PC
165 lines (153 loc) • 6.76 kB
JavaScript
import _defineProperty from '@babel/runtime/helpers/esm/defineProperty';
import { defineComponent, computed, provide, toRefs, openBlock, createElementBlock, normalizeClass, normalizeStyle, renderSlot } from 'vue';
import { pxfy } from '../_util/utils';
import getPrefixCls from '../_util/getPrefixCls';
import { useTheme } from '../_theme/useTheme';
import { FORM_NAME, FORM_LAYOUT, provideKey, TRIGGER_TYPE_DEFAULT } from './const';
import { allPromiseFinish } from './utils';
import { formProps } from './interface';
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
const prefixCls = getPrefixCls('form');
var script = defineComponent({
name: FORM_NAME,
props: formProps,
emits: ['submit'],
setup(props, _ref) {
let {
emit
} = _ref;
useTheme();
const formFields = {};
const formClass = computed(() => [prefixCls, `${prefixCls}-${props.layout}`, props.disabled && `${prefixCls}-disabled` // disabled
]);
const formStyle = computed(() => {
const tempColStyle = props.layout === FORM_LAYOUT.INLINE && props.inlineItemWidth && {
'grid-template-columns': `repeat(auto-fit, ${pxfy(props.inlineItemWidth)})`
};
const gapStyle = props.layout === FORM_LAYOUT.INLINE && props.inlineItemGap && {
'grid-gap': `${pxfy(props.inlineItemGap)}`
};
return _objectSpread(_objectSpread({}, tempColStyle), gapStyle);
});
const addField = (formItemProp, formItemContext) => {
if (formItemProp) {
formFields[formItemProp] = formItemContext;
}
};
const removeField = formItemProp => {
delete formFields[formItemProp];
};
const validateFields = async function (fieldProps) {
let trigger = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : TRIGGER_TYPE_DEFAULT;
if (!props.model) {
return Promise.reject('Form `model` is required for resetFields to work.');
}
// 是否指定prop: 【部分】表单字段校验调用会指定; 【整个】表单校验调用则不会指定
const specifyPropsFlag = Boolean(fieldProps.length);
const promiseList = []; // 原始校验结果
Object.values(formFields).forEach(formField => {
// Skip if Specify prop but not include
if (specifyPropsFlag && !fieldProps.includes(formField.prop)) {
return;
}
const promise = formField.validateRules(trigger);
promiseList.push(promise.then(() => ({
name: formField.prop,
errors: []
})).catch(errors => Promise.reject({
name: formField.prop,
errors
})));
});
try {
return await allPromiseFinish(promiseList); // 汇总校验结果;
} catch (results) {
const errorList = [];
const errorNameList = [];
results === null || results === void 0 || results.forEach(result => {
var _result$errors;
if (result !== null && result !== void 0 && (_result$errors = result.errors) !== null && _result$errors !== void 0 && _result$errors.length) {
errorList.push(result);
errorNameList.push(result === null || result === void 0 ? void 0 : result.name);
}
});
return Promise.reject({
valid: false,
values: errorNameList,
errorFields: errorList
});
}
};
/**
* 表单校验
* fieldProps { string[] } 指定校验字段的 props 数组
* return { Promise } 校验结果
*/
const validate = function () {
let fieldProps = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
return validateFields(fieldProps);
};
/** 移除表单项的校验结果 */
const clearValidate = function () {
let fieldProps = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
if (!props.model) {
return Promise.reject('Form `model` is required for resetFields to work.');
}
// 是否指定prop: 【部分】表单字段校验调用会指定; 【整个】表单校验调用则不会指定
const specifyPropsFlag = Boolean(fieldProps.length);
Object.values(formFields).forEach(formField => {
// Skip if Specify prop but not include
if (specifyPropsFlag && !fieldProps.includes(formField.prop)) {
return;
}
formField.clearValidate();
});
};
/** 对整个表单进行重置,将所有字段值重置为初始值并移除校验结果 */
const resetFields = function () {
let fieldProps = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
if (!props.model) {
return Promise.reject('Form `model` is required for resetFields to work.');
}
// 是否指定prop: 【部分】表单字段校验调用会指定; 【整个】表单校验调用则不会指定
const specifyPropsFlag = Boolean(fieldProps.length);
Object.values(formFields).forEach(formField => {
// Skip if Specify prop but not include
if (specifyPropsFlag && !fieldProps.includes(formField.prop)) {
return;
}
formField.resetField();
});
};
provide(provideKey, _objectSpread(_objectSpread({}, toRefs(props)), {}, {
addField,
removeField
}));
const handleSubmit = e => {
e.preventDefault();
e.stopPropagation();
emit('submit', e);
};
return {
formClass,
formStyle,
validate,
clearValidate,
resetFields,
handleSubmit
};
}
});
function render(_ctx, _cache, $props, $setup, $data, $options) {
return openBlock(), createElementBlock("form", {
class: normalizeClass(_ctx.formClass),
style: normalizeStyle(_ctx.formStyle),
onSubmit: _cache[0] || (_cache[0] = function () {
return _ctx.handleSubmit && _ctx.handleSubmit(...arguments);
})
}, [renderSlot(_ctx.$slots, "default")], 38 /* CLASS, STYLE, NEED_HYDRATION */);
}
script.render = render;
script.__file = "components/form/form.vue";
export { script as default };