{"remainingRequest":"D:\\jenkins\\workspace\\dataShare-fvue\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!D:\\jenkins\\workspace\\dataShare-fvue\\src\\components\\eipControl\\EipSubDialog.vue?vue&type=script&lang=js","dependencies":[{"path":"D:\\jenkins\\workspace\\dataShare-fvue\\src\\components\\eipControl\\EipSubDialog.vue","mtime":1733309211891},{"path":"D:\\jenkins\\workspace\\dataShare-fvue\\node_modules\\@vue\\cli-plugin-babel\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\jenkins\\workspace\\dataShare-fvue\\node_modules\\@vue\\cli-plugin-babel\\node_modules\\thread-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\jenkins\\workspace\\dataShare-fvue\\node_modules\\babel-loader\\lib\\index.js","mtime":456789000000},{"path":"D:\\jenkins\\workspace\\dataShare-fvue\\node_modules\\@vue\\cli-plugin-babel\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\jenkins\\workspace\\dataShare-fvue\\node_modules\\vue-loader\\lib\\index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64://
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//

import { mapState } from "vuex";
import utils from "@/utils.js";
import hotentUiUtils from "@/hotent-ui-util.js";
import { Message } from "element-ui";
import req from "@/request.js";
import sub_pio_mixin from "@/sub-permission-mixin.js";
import EipTag from "@/components/eipControl/EipTag.vue";
import EipSelectDia from "@/components/eipControl/EipSelectDia.vue";
export default {
  components: { EipTag, EipSelectDia },
  name: "eip-dialog",
  props: [
    "validate",
    "value",
    "name",
    "permission",
    "atter",
    "single",
    "selectorconfig",
    "custdialog",
    "placeholder",
    "tooltipplacement",
    'initFillData',
    'initFillDataType',
    'relation',
    'maxRow'
  ],
  mixins: [sub_pio_mixin], //混入方式引入表单组件中公共属性，处理子表、孙表行内联动（切面修改permission_sub）
  data() {
    return {
      data: {
        qxdd: {},
      },
      inputSuffixWidth: 0,
      placeholderBo: "",
      quickSearch: "", //填写提示
      conditionBind: [], //参数查询字段
      nodeKey: "ID_", //树形数据父Id
      customDialogShowList: false,
      customDialogShowTree: false,
      selectOrgProps: {
        label: "name",
      },
      style: "", //对话框宽高
      selectOrgs: null,
      inputSuffixHeight: 33,
      config: null,
      updating: false,
      displayfield: [], //显示字段
      customDialog: {},
      queryParam: "", //查询条件输入的值
      props1: [],
      showData: [],
      checkBoxDataAll: [], //选中对象的集合
      defaultProps: {
        children: "children",
        label: "label",
      },
      propsData: [],
      querysShow: false, //是否显示搜索框
      undefineda: "",
      isCurrentChange: false, //是否不执行 orgTableSelection方法
      pagination: {
        page: 1,
        pageSize: 20,
        total: 0,
      },
      param: [], //绑定的表单字段
      treeList: [],
      displayField: {},
      queryParams: [],
      placeholders: [],
      oldselectOrgs: [],
      combinationTreeData: [],
      combiTreeDisplayField: [],
      combinationTreeQuerys: [],
      combinationRule: {},
      toggleBtn: "el-icon-arrow-left",
      treeShow: true,
      transtionWidth: "25%",
      leftTreeTitle: "",
      writeable: true,
      isShow: true,
    };
  },
  watch: {
    props1: function (newVal, oldVal) {
      //树形
      if (this.showData != undefined && this.showData.length > 0) {
        const this_ = this;
        let data = [];
        for (let i = 0; i < this.showData.length; i++) {
          data.push(this.showData[i]);
        }
        setTimeout(() => {
          for (let i = 0; i < data.length; i++) {
            this_.$refs.tree.setChecked(data[i], true);
            this_.checkNode(data[i], this_);
          }
        }, 200);
      }
    },
  },
  mounted() {
    let requestType = window.location.href.split('?')[0].split('/')
    let isDoneList = window.location.href.split('/')
    if (
      requestType[requestType.length - 1] == 'get' ||
      requestType[requestType.length - 2] == 'get' ||
      isDoneList[isDoneList.length - 1] == 'doneList'
    ) {
      this.isShow = false
    }else{
      if(this.initFillData=='true'){
        this.initTemplateData();
      }
    }
  },
  computed: mapState({
    total: (state) => state.dialog.total,
    dialogData: (state) => {
      return state.dialog.rows;
    },
    inputVal: function () {
      if (!this.value || this.value == "||[]") {
        this.checkBoxDataAll = [];
        // this.showData = [];
        return null;
      } else {
        let nameAry = this.value.split(",");
        if (this.value.indexOf("||") > 0) {
          nameAry = this.value.split("||")[0].split(",");
          // this.showData=JSON.parse(this.value.split("||")[1]);
        }
        //  this.showData =this.selectOrgs;
        let idAry = null;
        let accountAry = null;
        let result = [];
        nameAry.forEach((m, i) => {
          let n = { value: m };
          result.push(n);
        });
        return result;
      }
    },
    inputWriteable: function () {
      return this.writeable
        ? utils.getWriteable(this.permission_sub)
        : this.writeable;
    },
    inputValidate: function () {
      var validateObj = this.$store.state.index.validate;
      return utils.addRequiredOrNot(
        this.permission_sub,
        this.validate,
        validateObj,
        this
      );
    },
    inputName: function () {
      let labeldesc = "";
      if (
        this.$slots &&
        this.$slots.labeldesc &&
        this.$slots.labeldesc[0].children &&
        this.$slots.labeldesc[0].children[0].text
      ) {
        labeldesc = this.$slots.labeldesc[0].children[0].text;
        return this.name ? this.name : utils.getName() + "-" + labeldesc;
      } else {
        return this.name ? this.name : utils.getName();
      }
    },
    // 是否有回填设置
    bindSet: function () {
      return this.selectorconfig ? this.selectorconfig.bind : null;
    },
  }),
  created() {
    if (!this.placeholder) {
      this.placeholderBo = "请选择内容";
    } else {
      this.placeholderBo = this.placeholder;
    }
    this.$validator = this.$root.$validator;
  },
  methods: {
    selectAll(selection) {
      if (this.oldselectOrgs != null && selection.length > 0) {
        for (let x = 0; x < selection.length; x++) {
          if (this.indexArray(this.oldselectOrgs, selection[x]) === -1) {
            this.oldselectOrgs.push(selection[x]);
          }
        }
        this.selectOrgs = _.cloneDeep(this.oldselectOrgs);
      } else {
        this.selectOrgs = _.cloneDeep(selection);
      }
    },
    checkNode(data, this_, pnode) {
      if (data.Pid) {
        let node = this_.$refs.tree.getNode(data.Pid);
        node.indeterminate = true;
        if (node.data.Pid) {
          this_.$refs.tree.getNode(node.data.Pid).indeterminate = true;
          this.checkNode(
            this_.$refs.tree.getNode(node.data.Pid).data,
            this_,
            this_.$refs.tree.getNode(node.data.Pid)
          );
        }
        if (!node.indeterminate) {
          node.indeterminate = true;
        }
      } else if (pnode && !pnode.indeterminate) {
        pnode.indeterminate = true;
      }
    },
    //回车查询
    searchEnterFun: function (e) {
      var keyCode = window.event ? e.keyCode : e.which;
      if (keyCode == 13) {
        this.search();
      }
    },
    handleSizeChange: function (size) {
      this.isCurrentChange = true;
      //每页下拉显示数据
      this.pagination.pageSize = size;
      this.search();
    },
    handleCurrentChange: function (currentPage) {
      const this_ = this;
      if (this.selectOrgs != undefined && this.selectOrgs.length > 0) {
        this.selectOrgs.forEach((row) => {
          let res = this_.indexArray(this_.checkBoxDataAll, row);
          if (res == -1) {
            this_.checkBoxDataAll.push(row);
          }
        });
      }
      this.isCurrentChange = true;
      //点击第几页
      this.pagination.page = currentPage;
      this.search();
    },
    checkList() {
      const this_ = this;
      setTimeout(() => {
        //列表
        if (
          this_.checkBoxDataAll != undefined &&
          this_.checkBoxDataAll.length > 0
        ) {
          this_.checkBoxDataAll.forEach((row) => {
            let res = this_.indexArray(this_.dialogData, row);
            this_.undefineda = res;
            if (res != -1) {
              this_.isCurrentChange = true;
              this_.toggleRowSelection(res, true);
            }
          });
        }
      }, 300);
    },
    toggleRowSelection(res, val) {
      this.$refs.orgTable.toggleRowSelection(this.dialogData[res], val);
    },
    showDialog(item) {
      const this_ = this;
      //第二次点击子表回填对话框 第一次选中的数据不是选中状态
      if(this_.selectOrgs){
        this_.selectOrgs.empty();
        this_.checkBoxDataAll.empty();
      }
      var alias = this.custdialog.custDialog.alias
      this.$store.dispatch('form/getByAlias', alias).then(customDialog => {
        if (!customDialog || !customDialog.alias) {
          Message.error('对话框别名【' + alias + '】不存在！')
          return
        }
        if (customDialog.style == 1) {
          var displaylist = JSON.parse(customDialog.displayfield)
          this_.nodeKey = displaylist.id
        }
        //对话框按表单字段查询（参数传入的）
        let bindList = this_.custdialog.custDialog.conditions
        this_.param = [] //绑定的表单字段
        if (bindList.length > 0) {
          bindList.forEach(ele => {
            //绑定表单字段
            if (ele.defaultType == '3' && ele.bind) {
              let obj = {}
              obj.field = ele.field
              obj.bind = ele.bind
              this_.param.push(obj)
            }
          })
        }
        //判断对话框查询是否有条件
        let userInputList = JSON.parse(customDialog.conditionfield)
        this_.quickSearch = '' //填写提示 placeholder
        this_.conditionBind = []
        let queryParams = []
        let placeholders = []
        if (userInputList.length > 0) {
          userInputList.forEach(ele => {
            var obj = {}
            //条件查询参数（用户输入的） 文本框输入
            if (ele.defaultType == '1') {
              obj[ele.field] = ''
              queryParams.push(obj)
              this_.conditionBind.push(ele)
              placeholders.push('请输入' + ele.comment)
            }
          })
          this.$set(this, 'queryParams', queryParams)
          this.$set(this, 'placeholders', placeholders)
        }
        //判断是否显示条件查询输入框
        if (this_.quickSearch != '') {
          this_.querysShow = true
        } else {
          this_.querysShow = true
        }
        this_.quickSearch = '请输入' + this.quickSearch + '查询'
        this_.style = 'height:' + customDialog.height + 'px'
        if (window.screen.height && window.screen.height <= 900) {
          this.style = 'height:440px'
        }
        if (customDialog.style == 0 || customDialog.style == 2) {
          //列表
          this_.customDialogShow({alias: alias, customDialog: customDialog})
        } else if (customDialog.style == 1) {
          //树形
          this_.pageParam = { alias: alias,customDialog: customDialog };
          this_.customDialog = customDialog;
          let param = {};
          this_.conditionfieldTree = [];
          //判断是否存在条件
          if(customDialog.conditionfield){
            this_.conditionfieldTree = JSON.parse(customDialog.conditionfield);
            if (this_.conditionfieldTree.length > 0) {
              for (let i = this_.conditionfieldTree.length - 1; i >= 0; i--) {
                //判断条件字段是否是动态传入（defaultType：4：动态传入，2：固定值 ）
                if (this_.conditionfieldTree[i].defaultType == "4") {
                  param[this_.conditionfieldTree[i].field] = this_.conditionfieldTree[i].comment;
                }
              }
            }
          }
          //有动态传入的字段
          if (JSON.stringify(param) != "{}") {
            this_.dialogVisible = true;
          }else{
            //无动态传入的字段
            this_.customDialogTreeShow(this_.pageParam);
          }
        }
      })
    },
    //判断数据是否包含某个对象，并返回数据包含对象的下标
    indexArray(array, item) {
      if (array.length == 0) {
        return -1;
      }
      for (let i = 0; i < array.length; i++) {
        if (JSON.stringify(array[i]) == JSON.stringify(item)) {
          return i;
        }
      }
      return -1;
    },
    //点击列表某一个复选框时触发
    onTableSelect(rows, row) {
      this.isCurrentChange = false;
      //判断点击列表数据时复选框是否勾选  selected：true不勾选，false勾选
      let selected =
        this.selectOrgs &&
        this.selectOrgs.length > 0 &&
        this.indexArray(this.selectOrgs, row) !== -1;
      if (selected) {
        this.isCurrentChange = true;
        let res = this.indexArray(this.selectOrgs, row);
        this.selectOrgs.splice(res, 1);
      }
    },
    //点击列表某一条数据时触发
    orgRowClick(row, column, event) {
      if (this.customDialog.selectNum === 1) {
        $(event.currentTarget.children[0].children[0].children[0]).trigger(
          "click"
        );
        this.selectOrgs = [];
        this.selectOrgs.push(row);
      } else if (this.customDialog.selectNum != 1) {
        this.isCurrentChange = false;
        //判断点击列表数据时复选框是否勾选  selected：true不勾选，false勾选
        let selected =
          this.selectOrgs &&
          this.selectOrgs.length > 0 &&
          this.indexArray(this.selectOrgs, row) !== -1;
        if (selected) {
          this.isCurrentChange = true;
          let res = this.indexArray(this.selectOrgs, row);
          this.selectOrgs.splice(res, 1);
        }
        this.$refs.orgTable.toggleRowSelection(row);
      }
    },
    //列表复选框有改变时触发
    orgTableSelection(selection) {
      //全选的情况特殊处理(为了与原本功能逻辑不冲突,先复制一份旧的选中数据.然后拿到全选事件中去计算)
      this.oldselectOrgs = _.cloneDeep(this.selectOrgs);
      //多选
      if (this.customDialog.selectNum != 1 && !this.isCurrentChange) {
        if (selection && selection.length > 0) {
          if (
            selection.length == 1 &&
            (!this.selectOrgs || this.selectOrgs.length == 0)
          ) {
            this.selectOrgs = selection;
          } else if (
            (!this.selectOrgs || this.selectOrgs.length == 0) &&
            selection.length > 1
          ) {
            if (!this.selectOrgs) {
              this.selectOrgs = [];
            }
            for (let i = selection.length - 1; i >= 0; i--) {
              this.selectOrgs.push(selection[i]);
            }
          } else if (this.isCurrentChange && selection.length >= 10) {
            if (!this.selectOrgs) {
              this.selectOrgs = [];
            } else {
              for (let u = this.selectOrgs.length - 1; u >= 0; u--) {
                let res = this.indexArray(selection, this.selectOrgs[u]);
                if (res != -1) {
                  this.selectOrgs.splice(res, 1);
                }
              }
            }
            for (let i = 0; i < selection.length; i++) {
              this.selectOrgs.push(selection[i]);
            }
          } else {
            for (let i = selection.length - 1; i >= 0; i--) {
              this.selectOrgs.push(selection[i]);
              break;
            }
          }
        }
      }
    },
    dialogConfirm() {
      if(!this.selectOrgs || this.selectOrgs.length==0){
        this.$message.error("请选择数据回填");
        return;
      }
      this.queryParam = "";
      this.customDialogShowList = false;
      this.calacInputSuffixHeight();
      this.syncInputValue();
    },
    //重置
    reset() {
      this.queryParams.forEach((paramObj) => {
        for (let key in paramObj) {
          this.queryParams[key] = "";
        }
      });
      //组合树重置
      if(this.$refs.combinationTree){
        let nodes = this.$refs.combinationTree.store.nodesMap;
        for (let key in nodes) {
          nodes[key].expanded = false;
        }
      }
      this.combinationTreeQuerys.splice(0);
      this.search(true);
    },
    //查询
    search(resetPagintion) {
      let querys = []; //查询条件
      let queryFilter = {};
      if (JSON.stringify(this.pagination) == "{}") {
        this.pagination = { page: 1, pageSize: 20, showTotal: "true" };
      }
      let pageBean = { pageBean: this.pagination };
      if (resetPagintion) {
        pageBean.pageBean = { page: 1, pageSize: 20, showTotal: "true" };
      }
      //用户输入的
      if (this.queryParams.length != 0 && this.queryParams[0] != "") {
        this.conditionBind.forEach((item, index) => {
          querys.push({
            property: item.field,
            value: this.queryParams[item.field],
            group: "main",
            operation: "LIKE",
            relation: "AND",
          });
        });
      }
      //参数传入的查询拼接
      if (this.param) {
        const pInst = utils.getOnlineFormInstance(this);
        this.param.forEach((item) => {
          querys.push({
            property: item.field,
            value: utils.getValueByPath(pInst, item.bind),
            group: "main",
            operation: "LIKE",
            relation: "AND",
          });
        });
      }
      //来自组合对话框的
      if (
        this.combinationTreeQuerys &&
        this.combinationTreeQuerys.length != 0
      ) {
        for (let i = 0; i < this.combinationTreeQuerys.length; i++) {
          querys.push(this.combinationTreeQuerys[i]);
        }
      }

      if (querys.length > 0) {
        queryFilter = { pageBean: pageBean.pageBean, querys };
        this.customDialog.pageBean = queryFilter;
        this.$store
          .dispatch("dialog/getlistJson", this.customDialog)
          .then(() => {
            this.checkList();
          });
      } else {
        this.customDialog.pageBean = pageBean;
        this.$store
          .dispatch("dialog/getlistJson", this.customDialog)
          .then(() => {
            this.checkList();
          });
      }
    },
    async doQuery(param) {
      let paramLoadData = [];
      const pInst = utils.getOnlineFormInstance(this);
      //获取关联查询绑定的表单参数
      for (let i = 0; i < param.conditionfield.length; i++) {
        if (param.conditionfield[i].fieldPath != "") {
          let bindVal = utils.getValueByPath(
            pInst,
            param.conditionfield[i].fieldPath,
            null
          );
          let obj = { key: param.conditionfield[i].field, value: bindVal };
          paramLoadData.push(obj);
        }
      }

      let queryUrl =
        param.dsType == "dataSource"
          ? "${form}/form/customQuery/v1/doQuery?alias=" +
            param.alias +
            "&page=1"
          : param.url;
      let requestMethod = "POST";
      //如果关联数据列表查询数据不是数据源则请求方法为restful配置的请求方式
      if (param.dsType != "dataSource") {
        requestMethod = param.requestType;
      }
      //查询数据
      req
        .request({ url: queryUrl, method: requestMethod, data: paramLoadData })
        .then((res) => {
          //判断是否有关联查询数据返回
          if (res.data.rows.length > 0) {
            //获取关联查询返回的表单参数
            for (let io = 0; io < param.resultfield.length; io++) {
              if (param.resultfield[io].fieldPath != "") {
                let val = "";
                for (let j = 0; j < res.data.rows.length; j++) {
                  if (res.data.rows[j][param.resultfield[io].field]) {
                    val =
                      val + res.data.rows[j][param.resultfield[io].field] + ",";
                  }
                }
                val = val.substring(0, val.length - 1);
                let pathArr = param.resultfield[io].fieldPath.split(".");
                if (pathArr.length == 3) {
                  //主表
                  utils.setValueByPath(
                    pInst,
                    param.resultfield[io].fieldPath,
                    val,
                    null
                  );
                } else if (pathArr.length == 4) {
                  //子表
                  let subData = pInst.data[pathArr[1]][pathArr[2]];
                  if (subData.length == 0) {
                    //子表没数据的情况
                    let subTabName = pathArr[2].replace("sub_", "");
                    //得到子表的所有字段
                    let subInitData =
                      pInst.data[pathArr[1]].initData[subTabName] || {};
                    //把数组里面的值为 null 转换为空字符串
                    let str = JSON.stringify(subInitData).replace(
                      /null/g,
                      '""'
                    );
                    let subData = JSON.parse(str);
                    for (var key in subData) {
                      //点添加时判断要新增子表记录中的孙表是否有值
                      if (key.indexOf("sub_") == 0 && subData[key].length > 0) {
                        subData[key] = []; //有则清空
                      }
                      //点添加时判断要新增子表记录中的字段是否有值
                      if (subData[key]) {
                        subData[key] = ""; //有则清空
                      }
                    }
                    //新增一条数据
                    pInst.data[pathArr[1]][pathArr[2]].push(subData);
                    //对话框关联查询返回的值赋值给绑定的字段
                    utils.setValueByPath(
                      pInst,
                      param.resultfield[io].fieldPath,
                      val,
                      0
                    );
                  } else {
                    //子表有数据的情况
                    for (let p = 0; p < subData.length; p++) {
                      //对话框关联查询返回的值赋值给绑定的字段
                      utils.setValueByPath(
                        pInst,
                        param.resultfield[io].fieldPath,
                        val,
                        p
                      );
                    }
                  }
                }
              }
            }
          } else {
            //没有返回的值则清空
            //获取关联查询返回的表单参数
            for (let iop = 0; iop < param.resultfield.length; iop++) {
              if (param.resultfield[iop].fieldPath != "") {
                let pathArr = param.resultfield[iop].fieldPath.split(".");
                if (pathArr.length == 3) {
                  //主表
                  //赋值给绑定的字段
                  utils.setValueByPath(
                    pInst,
                    param.resultfield[iop].fieldPath,
                    "",
                    null
                  );
                } else if (pathArr.length == 4) {
                  //子表
                  let subData = pInst.data[pathArr[1]][pathArr[2]];
                  for (let p = 0; p < subData.length; p++) {
                    //对话框关联查询返回的值赋值给绑定的字段
                    utils.setValueByPath(
                      pInst,
                      param.resultfield[iop].fieldPath,
                      "",
                      p
                    );
                  }
                }
              }
            }
          }
        });
    },
    // 同步选择结果
    syncInputValue() {
      var returnStr = JSON.parse(this.customDialog.resultfield)
      //拿到返回的字段
      var field = new Array([returnStr.length])
      var comment = new Array([returnStr.length])
      var str = []
      var ids = []
      for (var i = 0; i < returnStr.length; i++) {
        field[i] =
          this.customDialog.dsType == 'dataSource'
            ? returnStr[i].field.toLowerCase()
            : returnStr[i].field
        comment[i] =
          this.customDialog.dsType == 'dataSource'
            ? returnStr[i].comment.toLowerCase()
            : returnStr[i].comment
      }
      const this_ = this
      this.selectOrgs.forEach(row => {
        if (this_.checkBoxDataAll || this_.checkBoxDataAll.length < 1) {
          this_.checkBoxDataAll.push(row)
        } else if (
          JSON.stringify(this_.indexArray).indexOf(JSON.stringify(row)) == -1
        ) {
          this_.checkBoxDataAll.push(row)
        }
      })
      var s = this.selectOrgs

      if (this.customDialog.selectNum === 1) {
        var temp = ''
        for (var i = 0; i < comment.length; i++) {
          let encodeStr = encodeURIComponent(s[0][field[i]])
          temp += '"' + comment[i] + '":"' + encodeStr + '",'
        }
        if (temp != '') {
          temp = '{' + temp.substring(0, temp.length - 1) + '}'
        }
        str.push(utils.parseToJson(temp))
        ids.push(s[0].id)
      } else {
        for (var i = 0; i < s.length; i++) {
          var temp = ''
          for (var j = 0; j < comment.length; j++) {
            let encodeStr = encodeURIComponent(s[i][field[j]])
            temp += '"' + comment[j] + '":"' + encodeStr + '",'
          }
          if (temp != '') {
            temp = '{' + temp.substring(0, temp.length - 1) + '}'
          }
          str.push(utils.parseToJson(temp))
          ids.push(s[i].id)
        }
      }
      const returnData = str
      const _this = this
      const formInst = utils.getOnlineFormInstance(this)
      //处理自动回填配置
      this.instId = formInst.$parent.instId;
      let custDialog = this.custdialog;
      let fillOrg = {};
      if(custDialog.orgConfig && custDialog.orgConfig.name && this.fillOrg.id){
        const namePath = custDialog.orgConfig.name.split('.');
        const orgNameField = namePath[namePath.length-1];
        fillOrg[orgNameField] = this.fillOrg.name;
        if(custDialog.orgConfig.id){
          const idPath = custDialog.orgConfig.id.split('.');
          const orgIdField = idPath[idPath.length-1];
          fillOrg[orgIdField] = this.fillOrg.id;
        }
        if(custDialog.orgConfig.code){
          const codePath = custDialog.orgConfig.code.split('.');
          const orgCodeField = codePath[codePath.length-1];
          fillOrg[orgCodeField] = this.fillOrg.code;
        }
      }
      if(custDialog.orgConfig.instId){
        const instIdPath = custDialog.orgConfig.instId.split('.');
        const instIdField = instIdPath[instIdPath.length-1];
        fillOrg[instIdField] = this.instId;
      }
      try{
        let returnSize = returnData.length;
        //判断是否是一对一子表
        if (_this.relation && _this.relation == 'onetoone') {
          if(returnSize>1){
            this_.$message.error("一对一子表只能选择一条数据");
            this_.customDialogShowList = true;
            return;
          }
        }
        returnData.forEach(row => {
          var targetArray = null
          var subLineData = {}
          this.custdialog.custDialog.mappingConf.forEach(con => {
            if (con.target[0]) {
              targetArray = con.target[0].split('.')
              var from = ''
              if (_this.customDialog.dsType == 'restful') {
                from = con.from
              } else {
                from = con.from.toLowerCase()
              }
              if (row[from] == undefined) {
                from = from.toUpperCase()
              }
              subLineData[
                targetArray[targetArray.length - 1]
              ] = decodeURIComponent(row[from])
            }
          })
          if (targetArray) {
            var subBo = formInst['data'][targetArray[0]][targetArray[1]]
            //判断是否大于子表数据最大行数
            if(this_.maxRow !=0 && (subBo.length + returnSize)>this_.maxRow){
              this_.$message.error("子表数据已超过最大行数【"+this_.maxRow+"】");
              this_.customDialogShowList = true;
              throw new Error("EndIterative");
            }

            //子表中的孙表实体（可能存在多个）
            let sunBos = utils.getSomeAttributeFromParentElement(
              _this.$el,
              'sunBos'
            )
            //如果存在孙表实体则手动添加空孙表数组对象
            if (sunBos) {
              let arrayBo = sunBos.split(',')
              for (let i = 0; i < arrayBo.length; i++) {
                let key = 'sub_' + arrayBo[i]
                let value = new Array()
                subLineData[key] = value
              }
            }
            //判断是否是一对一子表
            if (_this.relation && _this.relation == 'onetoone') {
              subBo.empty()
            }
            if(fillOrg && JSON.stringify(fillOrg)!='{}'){
              subLineData = {...subLineData,...fillOrg};
            }
            subBo.push(subLineData)
            returnSize--
          }
        })
      }catch(e) {
        if(e.message!="EndIterative") throw e;
      };
    },
    //取消按钮
    dialogCancel() {
      const this_ = this;
      this_.queryParam = "";
      this_.$store.dispatch("dialog/setDialogData", []).then(() => {
        this_.customDialogShowList = false;
        //判断是否是点击了确认再点击取消的  inputVal没有值则表示直接点击的取消
        if (!this_.inputVal) {
          this_.selectOrgs = [];
        } else {
          this_.selectOrgs = [...this_.showData];
          this.checkBoxDataAll = [...this_.selectOrgs];
        }
      });
    },
    dialogTreeConfirm() {
      const this_ = this
      if(this_.propsData.length==0){
        this_.$message.error("请选择数据回填");
        return;
      }
      this.$store.dispatch('dialog/setDialogData', [])
      var returnStr = JSON.parse(this.customDialog.resultfield)
      var field = new Array([returnStr.length])
      var comment = new Array([returnStr.length])
      var str = []
      for (var i = 0; i < returnStr.length; i++) {
        field[i] = returnStr[i].field
        comment[i] = returnStr[i].comment
      }
      if (this.customDialog.selectNum === 1) {
        var nodes = this.propsData[0]
        var temp = ''
        for (var i = 0; i < comment.length; i++) {
          temp += '"' + comment[i] + '":"' + nodes[field[i]] + '",'
        }
        if (temp != '') {
          temp = '{' + temp.substring(0, temp.length - 1) + '}'
        }
        str.push(utils.parseToJson(temp))
      } else {
        var nodes = this.propsData
        nodes.forEach((item, k) => {
          var temp = ''
          for (var i = 0; i < comment.length; i++) {
            temp += '"' + comment[i] + '":"' + nodes[field[i]] + '",'
            temp += '"' + comment[i] + '":"' + nodes[k][field[i]] + '",'
          }
          if (temp != '') {
            temp = '{' + temp.substring(0, temp.length - 1) + '}'
          }
          str.push(utils.parseToJson(temp))
        })
      }
      const returnData = str
      const formInst = utils.getOnlineFormInstance(this)
      try{
        let returnSize = returnData.length;
        //判断是否是一对一子表
        if (this_.relation && this_.relation == 'onetoone') {
          if(returnSize>1){
            this_.$message.error("一对一子表只能选择一条数据");
            this_.customDialogShowTree = true;
            return;
          }
        }
        returnData.forEach(row => {
          var targetArray = null
          var subLineData = {}
          this.custdialog.custDialog.mappingConf.forEach(con => {
            if (con.target[0]) {
              targetArray = con.target[0].split('.')
              var from = ''
              if (this_.customDialog.dsType == 'restful') {
                from = con.from
              } else {
                from = con.from.toLowerCase()
              }
              if (row[from] == undefined) {
                from = from.toUpperCase()
              }
              subLineData[
                targetArray[targetArray.length - 1]
              ] = decodeURIComponent(row[from])
            }
          })
          if (targetArray) {
            var subBo = formInst['data'][targetArray[0]][targetArray[1]]
            //判断是否大于子表数据最大行数
            if(this_.maxRow !=0 && (subBo.length + returnSize)>this_.maxRow){
              this_.$message.error("子表数据已超过最大行数【"+this_.maxRow+"】");
              this_.customDialogShowTree = true;
              throw new Error("EndIterative");
            }

            //子表中的孙表实体（可能存在多个）
            let sunBos = utils.getSomeAttributeFromParentElement(
              this_.$el,
              'sunBos'
            )
            //如果存在孙表实体则手动添加空孙表数组对象
            if (sunBos) {
              let arrayBo = sunBos.split(',')
              for (let i = 0; i < arrayBo.length; i++) {
                let key = 'sub_' + arrayBo[i]
                let value = new Array()
                subLineData[key] = value
              }
            }
            //判断是否是一对一子表
            if (this_.relation && this_.relation == 'onetoone') {
              subBo.empty()
            }
            subBo.push(subLineData)
            returnSize--
          }
        })
        this.customDialogShowTree = false;
      }catch(e) {
        if(e.message!="EndIterative") throw e;
      };

    },
    dialogCancelTree() {
      this.$store.dispatch("dialog/setDialogData", []);
      this.customDialogShowTree = false;
    },
    getChecked(data, checked, indeterminate) {
      if (this.customDialog.selectNum === 1) {
        this.propsData = [];
        this.propsData.push(data);
      } else {
        this.propsData = this.$refs.tree.getCheckedNodes();
      }
    },
    treeClick(data, n, i) {
      if (this.customDialog.selectNum === 1) {
        this.propsData = [];
        this.propsData.push(data);
      }
    },
    clearAllSelectOrgs() {
      this.selectOrgs = null;
      this.$refs.orgTable.clearSelection();
    },
    removeSelectOrg(item) {
      if (this.customDialog.selectNum === 1) {
        this.$emit("input", "");
        this.selectOrgs.splice(item, 1);
        this.showData.splice(item, 1);
      } else {
        this.inputVal.splice(item, 1);
        // let removeId = this.showData[item];
        //树形
        if (this.propsData.length > 0) {
          this.propsData.splice(item, 1);
        }
        if (this.showData.length > 0) {
          this.showData.splice(item, 1);
        }
        //列表
        if (this.selectOrgs != null) {
          this.selectOrgs.splice(item, 1);
          this.checkBoxDataAll.splice(item, 1);
          this.selectOrgs.forEach((row) => {
            // if(item.id ==removeId ){
            this.isCurrentChange = true;
            this.toggleRowSelection(row, false);
            // }
          });
        }
        this.calacInputSuffixHeight();
        let value = "";
        this.inputVal.forEach((val) => {
          value += val.value + ",";
        });
        if (value.length > 0) {
          value = value.substring(0, value.length - 1);
        }
        if (value != "") {
          value = value + "||" + JSON.stringify(this.showData);
        }
        this.$emit("input", value);
      }
      this.syncInputValue();
    },
    calacInputSuffixHeight() {
      setTimeout(() => {
        if (!this.$refs.tagSpans) return;
        if (this.$refs.tagSpans.offsetHeight) {
          this.inputSuffixHeight = this.$refs.tagSpans.offsetHeight + 5;
        } else {
          this.inputSuffixHeight = 30;
        }
        // 触发验证
        this.$validator.validate();
      }, 0);
    },
    customDialogShow(pageParam) {
      this.customDialogShowList = true;
      this.customDialog = pageParam.customDialog;
      this.customDialog.queryUrl =
        this.customDialog.dsType == "dataSource"
          ? "${form}/form/customDialog/v1/getListData?alias=" +
            this.customDialog.alias +
            "&mapParam=" +
            (this.customDialog.mapParam ? this.customDialog.mapParam : "")
          : this.customDialog.url;
      if (this.dialogData.length < 1) {
        this.pagination = { page: 1, pageSize: 20, showTotal: "true" };
        this.search();
        this.displayfield = JSON.parse(pageParam.customDialog.displayfield);
        if (this.customDialog.dsType == "dataSource") {
          for (var i = 0; i < this.displayfield.length; i++) {
            this.displayfield[i].field = this.displayfield[
              i
            ].field.toLowerCase();
          }
        }
      } else if (this.dialogData.length > 1) {
        this.search();
      }
      if (this.dialogData.length > 0 && this.displayfield.length == 0) {
        this.search();
        this.displayfield = JSON.parse(pageParam.customDialog.displayfield);
        if (this.customDialog.dsType == "dataSource") {
          for (var i = 0; i < this.displayfield.length; i++) {
            this.displayfield[i].field = this.displayfield[
              i
            ].field.toLowerCase();
          }
        }
      }
    },
    customDialogTreeShow(pageParam) {
      this.customDialog = pageParam.customDialog;
      var customDialog = this.customDialog;
      var mapParam = "";
      if (pageParam.param != undefined) {
        mapParam = JSON.stringify(pageParam.param);
        mapParam = mapParam.substring(1, mapParam.length - 1);
      }
      var requestType =
        customDialog.dsType == "dataSource"
          ? "GET"
          : customDialog.requestType
          ? customDialog.requestType
          : "POST";
      var url =
        "${form}/form/customDialog/v1/getTreeData?alias=" +
        pageParam.alias +
        "&mapParam=" +
        mapParam;
      var paramsObj = {};
      if (customDialog.dsType != "dataSource") {
        url = customDialog.url;
        var templatePa = customDialog.dataParam;
        if (customDialog.conditionfield) {
          var conditions = JSON.parse(customDialog.conditionfield);
          for (var i = 0; i < conditions.length; i++) {
            var con = conditions[i];
            if (requestType == "POST") {
              if (templatePa) {
                templatePa = templatePa.replace(
                  new RegExp("\\{" + con.field + "\\}", "g"),
                  con.defaultValue
                );
              } else {
                paramsObj[con.field] = con.defaultValue;
              }
            } else {
              var ljChar = url.indexOf("?") == -1 ? "?" : "&";
              url = url + ljChar + con.field + "=" + con.defaultValue;
            }
          }
          if (templatePa) {
            paramsObj = JSON.parse(templatePa);
          }
        }
      }
      var requestParams = {};
      requestParams.requestType = requestType;
      requestParams.url = url;
      requestParams.paramsObj = paramsObj;
      this.searchTree(requestParams);
      this.customDialogShowTree = true;
    },
    //树形查询
    searchTree(requestParams) {
      const this_ = this;
      let query =
        requestParams.requestType == "POST"
          ? req.post(requestParams.url, requestParams.paramsObj)
          : req.get(requestParams.url);
      query.then(function (response) {
        //显示字段配置
        let displayfield = JSON.parse(this_.customDialog.displayfield);
        this_.displayField = displayfield;
        //把对话框配置的显示字段显示名称赋值给树形的显示值
        this_.defaultProps.label = displayfield.displayName;
        this_.treeList = response.data;
        //得到要加载树的信息
        this_.props1 = this_.toTreeData(
          response.data,
          displayfield.id,
          displayfield.pid,
          displayfield.displayName,
          displayfield.pvalue ? displayfield.pvalue : 0
        );
      });
    },
    //加载树的信息
    toTreeData(data, id, pid, name, pvalue) {
      // 建立个树形结构,需要定义个最顶层的父节点，pvalue是0
      return this.translateDataToTree(data, pid, id, name, pvalue);
    },
    translateDataToTree(data, pid, id, name, pvalue) {
      //把树数据有子节点的数据全部过滤掉（只留父节点的数据）
      let parents = data.filter(
        (value) =>
          value[id] == value[pid] || value[pid] == null || value[pid] == pvalue
      );
      if (!parents) {
        parents = data.filter(
          (value) =>
            value[pid] !== "undefined" &&
            value[pid] != null &&
            value[id] != value[pid]
        );
      }
      return parents;
    },
    loadTree(node, resolve) {
      if (node) {
        let this_ = this;
        let displayField =
          this_.customDialog.style == 2
            ? this_.combiTreeDisplayField
            : this_.displayField;
        resolve(
          this.treeList.filter(
            (value) => value[displayField.pid] === node.data[displayField.id]
          )
        );
        if (this.showData && this.showData.length > 0) {
          setTimeout(() => {
            this.showData.forEach((v) => {
              if (v.Pid == node.key) {
                this_.$refs.tree.setChecked(v, true);
              } else {
                this_.checkNode(v, this_);
              }
            });
          }, 400);
        }
      }
    },

    afterOpen() {
      //打开对话框之后加载树
      this.loadCombinationTree();
    },
    loadCombinationTree() {
      if (this.customDialog.style != 2) {
        return;
      }
      let combinationRule = JSON.parse(this.customDialog.combinationRule);
      this.combinationRule = combinationRule;
      let treeAlias = combinationRule.leftTree;
      //获取对话框数据
      req
        .get("${form}/form/customDialog/v1/getByAlias?alias=" + treeAlias)
        .then((resp) => {
          let treeDialog = resp.data;
          this.leftTreeTitle = treeDialog.name;
          let reqParam = {};
          let requestType =
            treeDialog.dsType == "dataSource"
              ? "GET"
              : treeDialog.requestType
              ? treeDialog.requestType
              : "POST";
          let url =
            "${form}/form/customDialog/v1/getTreeData?alias=" +
            treeAlias +
            "&mapParam=";
          let paramsObj = {};
          if (treeDialog.dsType != "dataSource") {
            url = treeDialog.url;
            let templatePa = treeDialog.dataParam;
            if (treeDialog.conditionfield) {
              let conditions = JSON.parse(treeDialog.conditionfield);
              for (let i = 0; i < conditions.length; i++) {
                let con = conditions[i];
                if (requestType == "POST") {
                  if (templatePa) {
                    templatePa = templatePa.replace(
                      new RegExp("\\{" + con.field + "\\}", "g"),
                      con.defaultValue
                    );
                  } else {
                    paramsObj[con.field] = con.defaultValue;
                  }
                } else {
                  let ljChar = url.indexOf("?") == -1 ? "?" : "&";
                  url = url + ljChar + con.field + "=" + con.defaultValue;
                }
              }
              if (templatePa) {
                paramsObj = JSON.parse(templatePa);
              }
            }
          }
          let requestParams = {};
          requestParams.requestType = requestType;
          requestParams.url = url;
          requestParams.paramsObj = paramsObj;
          this.$store
            .dispatch("dialog/getTreeData", requestParams)
            .then((resp) => {
              if (treeDialog.displayfield && treeDialog.resultfield) {
                let displayField = JSON.parse(treeDialog.displayfield);
                let resultfield = JSON.parse(treeDialog.resultfield);
                this.defaultProps.label = displayField.displayName;
                this.treeList = resp;
                this.combiTreeDisplayField = displayField;
                this.combinationTreeData = this.toTreeData(
                  resp,
                  displayField.id,
                  displayField.pid,
                  displayField.displayName,
                  displayField.pvalue ? displayField.pvalue : "0",
                  resultfield
                );
              }
            });
        });
    },
    combiTreeClick(paramObj, node, nodeComponent) {
      //组合对话框点击左树
      //清空旧的
      this.combinationTreeQuerys.splice(0);
      let combinationRule = JSON.parse(this.customDialog.combinationRule);
      if (!combinationRule.rules || combinationRule.rules.length == 0) {
        return;
      }
      let rules = combinationRule.rules;
      for (let i = 0; i < rules.length; i++) {
        let value = paramObj[rules[i].treeField];
        let property = rules[i].listField;
        this.combinationTreeQuerys.push({
          property: property,
          value: value,
          group: "treeGroup",
          operation: this.getOperation(rules[i].condition),
          relation: "AND",
        });
      }
      this.search();
    },
    //获取运算符号
    getOperation(old) {
      if (!old) {
        return "";
      }
      if (old == "EQ") {
        return "EQUAL";
      }
      if (old == "LK") {
        return "LIKE";
      }
      if (old == "LFK") {
        return "LIKE";
      }
      if (old == "IN") {
        return "IN";
      }
    },
    toggleTree() {
      if (this.treeShow) {
        this.treeShow = false;
        this.transtionWidth = "0%";
        this.toggleBtn = "el-icon-arrow-right";
      } else {
        this.treeShow = true;
        this.transtionWidth = "25%";
        this.toggleBtn = "el-icon-arrow-left";
      }
    },
    initTemplateData(){
        let _this = this;
        const custdialog = this.custdialog.custDialog;
        if(!custdialog || !custdialog.mappingConf || custdialog.mappingConf.length<1){
          return ;
        }
        const targetPath = this.getTargetPath(custdialog.mappingConf);
        const paths = targetPath.split('.');
        const formInst = utils.getOnlineFormInstance(this);
        if(!formInst.initFillData){
          return ;
        }
        //如果已有数据则不需要再次初始化
        const curData = formInst['data'][paths[0]][paths[1]];
        let initType = this.initFillDataType;
        if((!initType || initType=='empty') && curData.length>0 && !(curData.length==1 && JSON.stringify(curData[0])=='[]')){
          return ;
        }else if(initType=='cover'){
          formInst['data'][paths[0]][paths[1]] = [];
        }
        const loading = this.$loading({
          lock: true,
          text: '正在初始化填报模板...',
          spinner: 'el-icon-loading',
          background: 'rgba(0, 0, 0, 0.7)'
        });
        let myCustomDialog = null;
        this.$http.get('${form}/form/customDialog/v1/getByAlias?alias='+custdialog.alias).then(resp => {
            myCustomDialog = resp.data;
            _this.customDialog = resp.data;
        }, error => {
            _this.closeLoading(loading);
            _this.$message({
              message: "获取自定义对话框失败！",
              type: "error"
            });
        }).then(function () {
              const currentUser = JSON.parse(sessionStorage.getItem("currentUser"));
             if(!_this.custdialog.orgConfig.code && !_this.custdialog.orgConfig.name && !_this.custdialog.orgConfig.id){
                _this.closeLoading(loading);
                _this.toFillInitData(_this,myCustomDialog.dsType,formInst['data']);
              }else if (localStorage.getItem("curFillOrg_"+currentUser.account)) {
               _this.closeLoading(loading);
               _this.fillOrg = JSON.parse(localStorage.getItem("curFillOrg_"+currentUser.account));
               _this.toFillInitData(_this,myCustomDialog.dsType,formInst['data']);
             }else{
               _this.$http.get('${uc}/api/org/v1/org/getFillOrg').then(resp => {
                   _this.closeLoading(loading);
                    const rep = resp.data;
                    if(rep.state){
                      _this.fillOrg = rep.value;
                      localStorage.setItem("curFillOrg_"+currentUser.account,JSON.stringify(rep.value))
                      _this.toFillInitData(_this,myCustomDialog.dsType,formInst['data']);
                    }else{
                      _this.$message({
                        message: rep.message,
                        type: "warning"
                      });
                    }
                }, error => {
                    _this.closeLoading(loading);
                    _this.$message({
                      message: "获取当前用户填制单位失败！",
                      type: "warning"
                    });
                })
             }
        });
    },
    closeLoading(loading){
      setTimeout(function(){
        loading.close();
      },2000);
    },
    getTargetPath(mappingConf){
      let target = '';
      if(mappingConf && mappingConf.length>0){
        mappingConf.forEach(map =>{
          if(map['target'] && map['target'].length==1 && map['target'][0]){
            target = map['target'][0];
            return target;
          }
        });
      }
      return target;
    },
    toFillInitData(_this,dsType,curData){
      const custdialog = this.custdialog.custDialog;
      let params = [];//绑定的表单字段
      if(custdialog.conditions){
        //对话框按表单字段查询（参数传入的）
        let bindList = custdialog.conditions;
        if(bindList.length>0){
          bindList.forEach(ele => {
            //绑定表单字段
            if (ele.defaultType == "3" && ele.bind) {
              let obj = {};
              obj.field = ele.field;
              const bindArray = ele.bind.split('.');
              if(bindArray.length==3){
                obj.bind = curData[bindArray[1]][bindArray[2]];
                params.push(obj);
              }

            }
          });
        }
      }
      let url = '${form}/form/customDialog/v1/getListData?alias='+custdialog.alias;
      if(params.length>0){
        let paStr = '';
        params.forEach(pa =>{
          if(paStr){
            paStr += ',';
          }
          paStr = paStr + '"'+pa.field +'":"'+pa.bind+'"';
        });
        url = url+'&mapParam='+paStr;
      }else{
        url = url+'&mapParam=';
      }
      const param = {pageBean: {page: 1, pageSize: 1000, showTotal: true}};
      _this.$http.post(url, param).then(resp => {
          const response = resp.data;
          if(response.rows){
            _this.syncInitTableValue(response.rows,dsType);
          }
      }, error => {
          _this.$message({
            message: "获取初始化数据失败！",
            type: "error"
          });
      });
    },
    syncInitTableValue(s,dsType) {
      let custDialog = this.custdialog;
      var returnStr = JSON.parse(this.customDialog.resultfield);
      //拿到返回的字段
      var field = new Array([returnStr.length]);
      var comment = new Array([returnStr.length]);
      var str = [];
      var ids = [];
      for (var i = 0; i < returnStr.length; i++) {
        field[i] =
          dsType == "dataSource"
            ? returnStr[i].field.toLowerCase()
            : returnStr[i].field;
        comment[i] =
          dsType == "dataSource"
            ? returnStr[i].comment.toLowerCase()
            : returnStr[i].comment;
      }
      if (this.customDialog.selectNum === 1) {
        var temp = "";
        for (var i = 0; i < comment.length; i++) {
          const va = s[0][field[i]];
          va = typeof(va)=='undefined'?'':va;
          temp += '"' + comment[i] + '":"' + va + '",';
        }
        if (temp != "") {
          temp = "{" + temp.substring(0, temp.length - 1) + "}";
        }
        str.push(utils.parseToJson(temp));
        ids.push(s[0].id);
      } else {
        for (var i = 0; i < s.length; i++) {
          var temp = "";
          for (var j = 0; j < comment.length; j++) {
            const va = s[i][field[j]];
            va = typeof(va)=='undefined'?'':va;
            temp += '"' + comment[j] + '":"' + va + '",';
          }
          if (temp != "") {
            temp = "{" + temp.substring(0, temp.length - 1) + "}";
          }
          str.push(utils.parseToJson(temp));
          ids.push(s[i].id);
        }
      }
      const formInst = utils.getOnlineFormInstance(this);
      this.instId = formInst.$parent.instId;
      //处理填制部门
      let fillOrg = {};
      if(custDialog.orgConfig && custDialog.orgConfig.name && this.fillOrg.id){
        const namePath = custDialog.orgConfig.name.split('.');
        const orgNameField = namePath[namePath.length-1];
        fillOrg[orgNameField] = this.fillOrg.name;
        if(custDialog.orgConfig.id){
          const idPath = custDialog.orgConfig.id.split('.');
          const orgIdField = idPath[idPath.length-1];
          fillOrg[orgIdField] = this.fillOrg.id;
        }
        if(custDialog.orgConfig.code){
          const codePath = custDialog.orgConfig.code.split('.');
          const orgCodeField = codePath[codePath.length-1];
          fillOrg[orgCodeField] = this.fillOrg.code;
        }
      }
      if(custDialog.orgConfig.instId){
        const instIdPath = custDialog.orgConfig.instId.split('.');
        const instIdField = instIdPath[instIdPath.length-1];
        fillOrg[instIdField] = this.instId;
      }
      const returnData = str;
      const _this = this;

      returnData.forEach(row => {
        var subLineData = {};
        var targetArray = null;
        custDialog.custDialog.mappingConf.forEach(con => {
          if (con.target[0]) {
            targetArray = con.target[0].split(".");
            var from = "";
            if (_this.customDialog.dsType == "restful") {
              from = con.from;
            } else {
              from = con.from.toLowerCase();
            }
            subLineData[targetArray[targetArray.length - 1]] = row[from];
          }
        });
        if(fillOrg && JSON.stringify(fillOrg)!='{}'){
          subLineData = {...subLineData,...fillOrg};
        }
        formInst['data'][targetArray[0]][targetArray[1]].push(subLineData);
      });
    },
  },
};
"},null]}