{"remainingRequest":"/Users/shuguang/Desktop/毕设/CodeMaster/CodeMaster/node_modules/babel-loader/lib/index.js!/Users/shuguang/Desktop/毕设/CodeMaster/CodeMaster/node_modules/cache-loader/dist/cjs.js??ref--1-0!/Users/shuguang/Desktop/毕设/CodeMaster/CodeMaster/node_modules/vue-loader/lib/index.js??vue-loader-options!/Users/shuguang/Desktop/毕设/CodeMaster/CodeMaster/src/tool/form/ConfigForm.vue?vue&type=script&lang=js","dependencies":[{"path":"/Users/shuguang/Desktop/毕设/CodeMaster/CodeMaster/src/tool/form/ConfigForm.vue","mtime":1742646402774},{"path":"/Users/shuguang/Desktop/毕设/CodeMaster/CodeMaster/babel.config.js","mtime":1742646402652},{"path":"/Users/shuguang/Desktop/毕设/CodeMaster/CodeMaster/node_modules/cache-loader/dist/cjs.js","mtime":1743264595665},{"path":"/Users/shuguang/Desktop/毕设/CodeMaster/CodeMaster/node_modules/babel-loader/lib/index.js","mtime":1743264596348},{"path":"/Users/shuguang/Desktop/毕设/CodeMaster/CodeMaster/node_modules/cache-loader/dist/cjs.js","mtime":1743264595665},{"path":"/Users/shuguang/Desktop/毕设/CodeMaster/CodeMaster/node_modules/vue-loader/lib/index.js","mtime":1743264596512}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:import "core-js/modules/es.array.reduce.js";
import FormItemLabel from './label';
import FormItemContent from './content';
import AsyncValidator from 'async-validator';
import { isFunction, isPlainObject, cloneDeep, isString, omit, noop, has } from 'lodash-es';
import { getDefaultValue, getInjectedEvents, getFilterData, notEmpty } from './helpers';
export default {
  name: 'ConfigForm',
  components: {
    FormItemLabel,
    FormItemContent
  },
  props: {
    /**
     * 组件核心配置项
     */
    options: {
      type: Array,
      default: () => []
    },
    /**
     * 用于匹配组件，用户可以根据接收到的组件名称返回想要的组件，返回结果将作为createElement的第一个参数
     */
    matcher: {
      type: Function,
      default: noop
    },
    /**
     * 简单的i18n处理函数
     */
    locale: {
      type: Function,
      default: key => key
    },
    /**
     * 为校验失败项添加的默认类名，外部可根据这个类名去定义/修改组件样式
     */
    errorClass: {
      type: String,
      default: 'form-item-error'
    }
  },
  data() {
    return {
      formData: {},
      flatOptions: {},
      // 按key将原始选项存储
      validator: null,
      errors: {}
    };
  },
  computed: {
    result() {
      const result = {};
      const {
        formData,
        flatOptions
      } = this;
      for (const [key, value] of Object.entries(flatOptions)) {
        const {
          mapper
        } = value;

        // mapper为false代表当前key值不需要加入最终结果
        if (mapper === false) continue;

        // mapper没有返回值的话默认使用当前值 formData[key] 兜底
        const mapperValue = isFunction(mapper) ? mapper(formData) : formData[key];
        // 空值过滤
        if (isPlainObject(mapperValue)) {
          Object.assign(result, getFilterData(mapperValue));
        } else if (notEmpty(mapperValue)) {
          result[key] = mapperValue;
        }
      }
      return result;
    }
  },
  watch: {
    options: {
      deep: true,
      immediate: true,
      handler() {
        this.initFormData();
      }
    },
    formData: {
      deep: true,
      handler(val) {
        this.$emit('change', val);
      }
    }
  },
  methods: {
    match(name) {
      var _this$matcher;
      // 匹配组件
      return (_this$matcher = this.matcher(name)) !== null && _this$matcher !== void 0 ? _this$matcher : name;
    },
    initFormData() {
      const formData = {};
      const flatOptions = {};
      const descriptor = {};
      for (const item of this.options) {
        var _this$$route;
        const {
          label,
          key,
          rules
        } = item;
        flatOptions[key] = item;
        if (rules) {
          // rules为函数时视为validator选项
          descriptor[key] = isFunction(rules) ? {
            validator: rules
          } : rules;
        }

        // 设置默认值，考虑项目可能没有引入VueRouter
        Object.assign(formData, getDefaultValue(item, (_this$$route = this.$route) === null || _this$$route === void 0 ? void 0 : _this$$route.query));

        // 处理label
        if (isPlainObject(label)) {
          flatOptions[label.key] = label;
        }
      }
      Object.assign(this, {
        flatOptions,
        formData,
        validator: new AsyncValidator(descriptor)
      });
    },
    getProps(key, options) {
      const {
        formData
      } = this;
      const {
        props = {},
        attrs = {},
        on: event = {},
        nativeOn: nativeEvent = {},
        ...otherOptions
      } = options;

      /**
       * 为事件处理函数注入setState参数
       */
      const on = getInjectedEvents(event, this.setState.bind(this));
      const nativeOn = getInjectedEvents(nativeEvent, this.setState.bind(this));
      const update = newVal => {
        this.$set(this.errors, key, null); // 清除错误状态
        this.setState({
          [key]: newVal
        });
      };
      const allAttrs = Object.assign(attrs, props);
      return {
        ...otherOptions,
        // 其他选项直接原样传递，保证拓展性
        formOption: this.flatOptions[key],
        // 基本信息，便于用户使用matcher自定义组件
        key,
        nativeOn,
        on: Object.assign({}, on, {
          input: isFunction(on.input) ? newVal => {
            on.input(newVal);
            update(newVal);
          } : update
        }),
        /**
         * 合并attrs/props，统一传给attrs
         * Vue内部解析属性时，会将对应组件的`props从所有的attrs中提取出来
         * 并将props传递给组件的props，剩下的attrs放进`$attrs`，所以默认传给attrs没有问题
         * 但是如果默认传给props将可能会导致某些自定义组件无法正确解析得到`$attrs`
         * 比如一些透传属性，组件中如果没有声明对应的props，没有被组件接搜的props属性将不会进入`$attrs`
         * 从而导致内部使用到`$attrs`变量的地方出现问题
         */
        attrs: Object.assign({}, allAttrs, {
          // 优先采用 value
          value: has(allAttrs, 'value') ? allAttrs.value : formData[key]
        })
      };
    },
    createComponent(options) {
      const h = this.$createElement;
      const {
        component,
        key,
        ...otherOptions
      } = options;
      if (!key) {
        console.error('Missing required prop \'key\'');
      }

      // component 要么是string要么是function
      if (isString(component)) {
        return h(this.match(component), this.getProps(key, otherOptions));
      }
      if (isFunction(component)) {
        const result = component(h, this.formData, this.setState);
        if (result instanceof this.$vnode.constructor) {
          return result;
        }
        // 不是VNode就认为是对象，包含component、props、attrs、on等属性
        return h(this.match(result.component), this.getProps(key, omit(result, 'component')));
      }
      console.warn('\'component\' must be string or function');
    },
    /**
     * 下列函数外部可调用
     */
    getResult() {
      return cloneDeep(this.result);
    },
    getFormData() {
      return cloneDeep(this.formData);
    },
    setState(callback) {
      const data = isFunction(callback) ? callback(this.formData) : callback;
      if (isPlainObject(data)) {
        Object.assign(this.formData, data);
      }
    },
    reset() {
      const formData = {};
      for (const [key, value] of Object.entries(this.flatOptions)) {
        const {
          default: defaultValue
        } = value;
        formData[key] = isFunction(defaultValue) ? defaultValue({}) // 外部可能解构，传入空对象防报错
        : defaultValue;
      }
      this.formData = formData;
      this.errors = {};
    },
    toQuery() {
      const query = {};
      for (const key of Object.keys(this.flatOptions)) {
        const {
          toQuery,
          mapper
        } = this.flatOptions[key];
        let value;
        if (toQuery === true && isFunction(mapper)) {
          var _mapper;
          value = (_mapper = mapper(this.formData)) !== null && _mapper !== void 0 ? _mapper : this.formData[key];
        } else if (isFunction(toQuery)) {
          value = toQuery(this.formData);
        }
        // 空值过滤, value不为 undefined 或 null 或 ''
        if (notEmpty(value)) {
          if (isPlainObject(value)) {
            Object.assign(query, getFilterData(value));
          } else {
            query[key] = value;
          }
        }
      }
      return query;
    },
    validate(options = {}) {
      var _this$validator;
      return (_this$validator = this.validator) === null || _this$validator === void 0 ? void 0 : _this$validator.validate(this.formData, options).then(() => {
        this.errors = {};
        return this.getResult();
      }).catch(e => {
        const {
          errors
        } = e;
        if (Array.isArray(errors)) {
          this.errors = errors.reduce((result, item) => {
            result[item.field] = item.message;
            return result;
          }, {});
        }
        throw e;
      });
    }
  }
};"},{"version":3,"names":["FormItemLabel","FormItemContent","AsyncValidator","isFunction","isPlainObject","cloneDeep","isString","omit","noop","has","getDefaultValue","getInjectedEvents","getFilterData","notEmpty","name","components","props","options","type","Array","default","matcher","Function","locale","key","errorClass","String","data","formData","flatOptions","validator","errors","computed","result","value","Object","entries","mapper","mapperValue","assign","watch","deep","immediate","handler","initFormData","val","$emit","methods","match","_this$matcher","descriptor","item","_this$$route","label","rules","$route","query","getProps","attrs","on","event","nativeOn","nativeEvent","otherOptions","setState","bind","update","newVal","$set","allAttrs","formOption","input","createComponent","h","$createElement","component","console","error","$vnode","constructor","warn","getResult","getFormData","callback","reset","defaultValue","toQuery","keys","_mapper","validate","_this$validator","then","catch","e","isArray","reduce","field","message"],"sources":["src/tool/form/ConfigForm.vue"],"sourcesContent":["e\n\n\n\n\n"],"mappings":"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","ignoreList":[]}]}