fujunling
2023-06-20 ff182ac475ea169057956ab182d38236d7ee87a1
Source/UBCS-WEB/src/components/FormTemplate/FormTempalte.vue
@@ -27,6 +27,11 @@
        <vciWebRefer
          v-if="item.type == 'refer'"
          :referConfig="item.referConfig || {}"
          :value="form[item.referConfig.field] || item.value"
          :text="form[item.referConfig.showField]"
          :disabled="item.disabled"
          :display="item.display"
          @setReferValue="setReferValue"
        ></vciWebRefer>
      </template>
    </avue-form>
@@ -512,6 +517,7 @@
            collapse: true,
            column: [],
          });
          return
        }
        if (
          formItem.type === "combox" &&
@@ -555,13 +561,11 @@
          maxlength: formItem.maxlength,
          filterable: true,
          referConfig:formItem.type=='refer'?{
            title:formItem.text,
            title:formItem.text ,
            showField:formItem.showField || formItem.field,
            field: formItem.field,
            placeholder: formItem.inputTip,
            options:formItem.referConfig,
            value:'',
            text:''
            options:formItem.referConfig
          }:{},
          span: formItem.type === "textarea" ? 24 : this.trendsSpan,
          rules: [
@@ -593,7 +597,9 @@
      this.$set(this.option, "column", column);
      this.$set(this.option, "group", group);
      this.formIndex++;
      this.loading = false;
      if (this.type === 'add' || this.type === 'preview') {
        this.loading = false;
      }
      this.geDictData(dictKeys);
      this.getFormDetail();
    },
@@ -647,11 +653,11 @@
      if (type === "truefalse") {
        return [
          {
            key: false,
            key: 'false',
            value: "否",
          },
          {
            key: true,
            key: 'true',
            value: "是",
          },
        ];
@@ -683,8 +689,7 @@
    // 表单校验
    validate() {
      return new Promise((resolve) => {
        this.$refs.form.validate((valid, done, msg) => {
          console.error(msg, valid);
        this.$refs.form.validate((valid, done) => {
          if (valid) {
            done();
            resolve(true);
@@ -696,14 +701,21 @@
    },
    // 获取表单详情数据
    getFormDetail() {
      if (this.type === 'add') return
      if (this.type === 'add' || this.type === 'preview') return
      getFormDetail({ templateOid: this.templateOid, oid: this.rowOid }).then(
        (res) => {
          this.form = Object.assign(this.form, res.obj)
          console.log(res, "res");
          this.form = Object.assign(this.form, res.data.data[0])
          this.loading = false;
        }
      );
    },
    setReferValue(data){
      if(data.field){
        this.form[data.field]=data.value || '';
        this.form[data.showField]=data.text || '';
        this.$emit("referConfigDataUpdate", data);
      }
    }
  },
  watch: {
    // 表单数据修改反馈到父组件