UNPKG

element-plus

Version:

A Component Library for Vue 3

164 lines (159 loc) 5.13 kB
'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var vue = require('vue'); var constants = require('./constants.js'); var form = require('./form.js'); var utils = require('./utils.js'); var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js'); var useFormCommonProps = require('./hooks/use-form-common-props.js'); var index = require('../../../hooks/use-namespace/index.js'); var error = require('../../../utils/error.js'); var shared = require('@vue/shared'); const COMPONENT_NAME = "ElForm"; const __default__ = vue.defineComponent({ name: COMPONENT_NAME }); const _sfc_main = /* @__PURE__ */ vue.defineComponent({ ...__default__, props: form.formProps, emits: form.formEmits, setup(__props, { expose, emit }) { const props = __props; const fields = []; const formSize = useFormCommonProps.useFormSize(); const ns = index.useNamespace("form"); const formClasses = vue.computed(() => { const { labelPosition, inline } = props; return [ ns.b(), ns.m(formSize.value || "default"), { [ns.m(`label-${labelPosition}`)]: labelPosition, [ns.m("inline")]: inline } ]; }); const getField = (prop) => { return fields.find((field) => field.prop === prop); }; const addField = (field) => { fields.push(field); }; const removeField = (field) => { if (field.prop) { fields.splice(fields.indexOf(field), 1); } }; const resetFields = (properties = []) => { if (!props.model) { error.debugWarn(COMPONENT_NAME, "model is required for resetFields to work."); return; } utils.filterFields(fields, properties).forEach((field) => field.resetField()); }; const clearValidate = (props2 = []) => { utils.filterFields(fields, props2).forEach((field) => field.clearValidate()); }; const isValidatable = vue.computed(() => { const hasModel = !!props.model; if (!hasModel) { error.debugWarn(COMPONENT_NAME, "model is required for validate to work."); } return hasModel; }); const obtainValidateFields = (props2) => { if (fields.length === 0) return []; const filteredFields = utils.filterFields(fields, props2); if (!filteredFields.length) { error.debugWarn(COMPONENT_NAME, "please pass correct props!"); return []; } return filteredFields; }; const validate = async (callback) => validateField(void 0, callback); const doValidateField = async (props2 = []) => { if (!isValidatable.value) return false; const fields2 = obtainValidateFields(props2); if (fields2.length === 0) return true; let validationErrors = {}; for (const field of fields2) { try { await field.validate(""); if (field.validateState === "error") field.resetField(); } catch (fields3) { validationErrors = { ...validationErrors, ...fields3 }; } } if (Object.keys(validationErrors).length === 0) return true; return Promise.reject(validationErrors); }; const validateField = async (modelProps = [], callback) => { const shouldThrow = !shared.isFunction(callback); try { const result = await doValidateField(modelProps); if (result === true) { await (callback == null ? void 0 : callback(result)); } return result; } catch (e) { if (e instanceof Error) throw e; const invalidFields = e; if (props.scrollToError) { scrollToField(Object.keys(invalidFields)[0]); } await (callback == null ? void 0 : callback(false, invalidFields)); return shouldThrow && Promise.reject(invalidFields); } }; const scrollToField = (prop) => { var _a; const field = utils.filterFields(fields, prop)[0]; if (field) { (_a = field.$el) == null ? void 0 : _a.scrollIntoView(props.scrollIntoViewOptions); } }; vue.watch(() => props.rules, () => { if (props.validateOnRuleChange) { validate().catch((err) => error.debugWarn(err)); } }, { deep: true, flush: "post" }); vue.provide(constants.formContextKey, vue.reactive({ ...vue.toRefs(props), emit, resetFields, clearValidate, validateField, getField, addField, removeField, ...utils.useFormLabelWidth() })); expose({ validate, validateField, resetFields, clearValidate, scrollToField, fields }); return (_ctx, _cache) => { return vue.openBlock(), vue.createElementBlock("form", { class: vue.normalizeClass(vue.unref(formClasses)) }, [ vue.renderSlot(_ctx.$slots, "default") ], 2); }; } }); var Form = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "form.vue"]]); exports["default"] = Form; //# sourceMappingURL=form2.js.map