0b81f7e5e174073c8621c7cbc743d04759cc87fa678bf1d713d396f4344021a213e56963adffbbf2f0271f253e06fe101748aaa36b39d1452f8ef56b33ecd0 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. 'use strict';
  2. Object.defineProperty(exports, '__esModule', { value: true });
  3. var vue = require('vue');
  4. var constants = require('./constants.js');
  5. var form = require('./form.js');
  6. var utils = require('./utils.js');
  7. var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
  8. var useFormCommonProps = require('./hooks/use-form-common-props.js');
  9. var index = require('../../../hooks/use-namespace/index.js');
  10. var error = require('../../../utils/error.js');
  11. var shared = require('@vue/shared');
  12. const COMPONENT_NAME = "ElForm";
  13. const __default__ = vue.defineComponent({
  14. name: COMPONENT_NAME
  15. });
  16. const _sfc_main = /* @__PURE__ */ vue.defineComponent({
  17. ...__default__,
  18. props: form.formProps,
  19. emits: form.formEmits,
  20. setup(__props, { expose, emit }) {
  21. const props = __props;
  22. const formRef = vue.ref();
  23. const fields = vue.reactive([]);
  24. const formSize = useFormCommonProps.useFormSize();
  25. const ns = index.useNamespace("form");
  26. const formClasses = vue.computed(() => {
  27. const { labelPosition, inline } = props;
  28. return [
  29. ns.b(),
  30. ns.m(formSize.value || "default"),
  31. {
  32. [ns.m(`label-${labelPosition}`)]: labelPosition,
  33. [ns.m("inline")]: inline
  34. }
  35. ];
  36. });
  37. const getField = (prop) => {
  38. return utils.filterFields(fields, [prop])[0];
  39. };
  40. const addField = (field) => {
  41. fields.push(field);
  42. };
  43. const removeField = (field) => {
  44. if (field.prop) {
  45. fields.splice(fields.indexOf(field), 1);
  46. }
  47. };
  48. const resetFields = (properties = []) => {
  49. if (!props.model) {
  50. return;
  51. }
  52. utils.filterFields(fields, properties).forEach((field) => field.resetField());
  53. };
  54. const clearValidate = (props2 = []) => {
  55. utils.filterFields(fields, props2).forEach((field) => field.clearValidate());
  56. };
  57. const isValidatable = vue.computed(() => {
  58. const hasModel = !!props.model;
  59. return hasModel;
  60. });
  61. const obtainValidateFields = (props2) => {
  62. if (fields.length === 0)
  63. return [];
  64. const filteredFields = utils.filterFields(fields, props2);
  65. if (!filteredFields.length) {
  66. return [];
  67. }
  68. return filteredFields;
  69. };
  70. const validate = async (callback) => validateField(void 0, callback);
  71. const doValidateField = async (props2 = []) => {
  72. if (!isValidatable.value)
  73. return false;
  74. const fields2 = obtainValidateFields(props2);
  75. if (fields2.length === 0)
  76. return true;
  77. let validationErrors = {};
  78. for (const field of fields2) {
  79. try {
  80. await field.validate("");
  81. if (field.validateState === "error" && !field.error)
  82. field.resetField();
  83. } catch (fields3) {
  84. validationErrors = {
  85. ...validationErrors,
  86. ...fields3
  87. };
  88. }
  89. }
  90. if (Object.keys(validationErrors).length === 0)
  91. return true;
  92. return Promise.reject(validationErrors);
  93. };
  94. const validateField = async (modelProps = [], callback) => {
  95. let result = false;
  96. const shouldThrow = !shared.isFunction(callback);
  97. try {
  98. result = await doValidateField(modelProps);
  99. if (result === true) {
  100. await (callback == null ? void 0 : callback(result));
  101. }
  102. return result;
  103. } catch (e) {
  104. if (e instanceof Error)
  105. throw e;
  106. const invalidFields = e;
  107. if (props.scrollToError) {
  108. if (formRef.value) {
  109. const formItem = formRef.value.querySelector(`.${ns.b()}-item.is-error`);
  110. formItem == null ? void 0 : formItem.scrollIntoView(props.scrollIntoViewOptions);
  111. }
  112. }
  113. !result && await (callback == null ? void 0 : callback(false, invalidFields));
  114. return shouldThrow && Promise.reject(invalidFields);
  115. }
  116. };
  117. const scrollToField = (prop) => {
  118. var _a;
  119. const field = getField(prop);
  120. if (field) {
  121. (_a = field.$el) == null ? void 0 : _a.scrollIntoView(props.scrollIntoViewOptions);
  122. }
  123. };
  124. vue.watch(() => props.rules, () => {
  125. if (props.validateOnRuleChange) {
  126. validate().catch((err) => error.debugWarn());
  127. }
  128. }, { deep: true, flush: "post" });
  129. vue.provide(constants.formContextKey, vue.reactive({
  130. ...vue.toRefs(props),
  131. emit,
  132. resetFields,
  133. clearValidate,
  134. validateField,
  135. getField,
  136. addField,
  137. removeField,
  138. ...utils.useFormLabelWidth()
  139. }));
  140. expose({
  141. validate,
  142. validateField,
  143. resetFields,
  144. clearValidate,
  145. scrollToField,
  146. getField,
  147. fields
  148. });
  149. return (_ctx, _cache) => {
  150. return vue.openBlock(), vue.createElementBlock("form", {
  151. ref_key: "formRef",
  152. ref: formRef,
  153. class: vue.normalizeClass(vue.unref(formClasses))
  154. }, [
  155. vue.renderSlot(_ctx.$slots, "default")
  156. ], 2);
  157. };
  158. }
  159. });
  160. var Form = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "form.vue"]]);
  161. exports["default"] = Form;
  162. //# sourceMappingURL=form2.js.map