| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166 |
- '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 formRef = vue.ref();
- const fields = vue.reactive([]);
- 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 utils.filterFields(fields, [prop])[0];
- };
- const addField = (field) => {
- fields.push(field);
- };
- const removeField = (field) => {
- if (field.prop) {
- fields.splice(fields.indexOf(field), 1);
- }
- };
- const resetFields = (properties = []) => {
- if (!props.model) {
- 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;
- return hasModel;
- });
- const obtainValidateFields = (props2) => {
- if (fields.length === 0)
- return [];
- const filteredFields = utils.filterFields(fields, props2);
- if (!filteredFields.length) {
- 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.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) => {
- let result = false;
- const shouldThrow = !shared.isFunction(callback);
- try {
- 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) {
- if (formRef.value) {
- const formItem = formRef.value.querySelector(`.${ns.b()}-item.is-error`);
- formItem == null ? void 0 : formItem.scrollIntoView(props.scrollIntoViewOptions);
- }
- }
- !result && await (callback == null ? void 0 : callback(false, invalidFields));
- return shouldThrow && Promise.reject(invalidFields);
- }
- };
- const scrollToField = (prop) => {
- var _a;
- const field = getField(prop);
- if (field) {
- (_a = field.$el) == null ? void 0 : _a.scrollIntoView(props.scrollIntoViewOptions);
- }
- };
- vue.watch(() => props.rules, () => {
- if (props.validateOnRuleChange) {
- validate().catch((err) => error.debugWarn());
- }
- }, { 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,
- getField,
- fields
- });
- return (_ctx, _cache) => {
- return vue.openBlock(), vue.createElementBlock("form", {
- ref_key: "formRef",
- ref: formRef,
- 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
|