1 |
- {"remainingRequest":"E:\\boman-framwork\\ruoyi-ui\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!E:\\boman-framwork\\ruoyi-ui\\src\\views\\tool\\gen\\editTable.vue?vue&type=script&lang=js&","dependencies":[{"path":"E:\\boman-framwork\\ruoyi-ui\\src\\views\\tool\\gen\\editTable.vue","mtime":1621578953096},{"path":"E:\\boman-framwork\\ruoyi-ui\\node_modules\\babel-loader\\lib\\index.js","mtime":315532800000},{"path":"E:\\boman-framwork\\ruoyi-ui\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"E:\\boman-framwork\\ruoyi-ui\\node_modules\\vue-loader\\lib\\index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64://
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//

import {
  getGenTable,
  updateGenTable,
  delPost,
  tabList,
  listTable,
  addGenTable,
  setGenTable,
  delGenTable,
  listAllColumnsByTableId,
  genTableColumnList,
  tableSql,
  zxImplement,
  getReload,
  addGenTableColumn,
  delGenTableColumn,
  setGenTableColumn,
  getGenTableColumn,
  getByIdWithForeignKey,
  listIndexfou,
  tableQuery,
  qurGenTable
} from "@/api/tool/gen";
import {
  optionselect as getDictOptionselect
} from "@/api/system/dict/type";
import {
  listMenu as getMenuTreeselect
} from "@/api/system/menu";
import basicInfoForm from "./basicInfoForm";
import genInfoForm from "./genInfoForm";
import Sortable from 'sortablejs'

let _this = ''
export default {
  name: "GenEdit",
  components: {
    basicInfoForm,
    genInfoForm
  },
  data() {
    _this = this
    return {
      ForeName: '',
      totalquery:0,
      // 多行查询
      titleopenquery:'快速查询',
      // 获取输入框的参数
      queryLisr:{
        table:'gen_table_column'
      },
      aliemg:{
        table:'gen_table_column',
        orderBy:'create_time desc',
        pageNo:1,
        pageSize:10,
        fixedData:{
          condition:''
        }
      },
      postListquery:{},
      queryData: {},
      openquery:false,
      formquery:{},
      // 字段信息
      tableSqlData: [],
      columList: [],
      columHRList: [],
      foreignKey: [],
      openZd: false,
      formZd: {
      },
      rulesZd: {
        columnName: [{
          required: true,
          message: "请输入字段名",
          trigger: "blur"
        }],
        columnComment: [{
          required: true,
          message: "请输入字段描述",
          trigger: "blur"
        }],
        columnType: [{
          required: true,
          message: "请输入物理类型",
          trigger: "blur"
        }],
        mask: [{
          required: true,
          message: "请输入字段显示规则",
          trigger: "blur"
        }],
        sort: [{
          required: true,
          message: "请输入序号",
          trigger: "blur"
        }],
      },
      loadingZd: '',
      // 关联表
      title: "",
      loading: false,
      open: false,
      form: {},
      rules: {
        relationParentId: [{
          required: true,
          message: "请选择关联表",
          trigger: "blur"
        }],
        relationChildId: [{
          required: true,
          message: "请选择字段",
          trigger: "blur"
        }],
        relationType: [{
          required: true,
          message: "请选择关联条件",
          trigger: "blur"
        }],
      },
      postList: [],
      total: 1,
      tableList: {},
      // 关联方式

      // 内嵌编辑
      genList: [],
      glbParams: {
        pageNum: 1,
        pageSize: 10000000,
      },
      // 关联表查询参数
      queryParams: {
        relationParentId: this.$route.params && this.$route.params.tableId,
        pageNum: 1,
        pageSize: 10,
      },
      // 选中选项卡的 name
      activeName: "basic",
      // 表格的高度
      tableHeight: document.documentElement.scrollHeight - 245 + "px",
      // 表信息
      tables: [],
      // 表列信息
      cloumns: [],
      // 字典信息
      dictOptions: [],
      // 菜单信息
      menus: [],
      // 表详细信息
      info: {},
      // 选中数组
      ids: [],
      ids1: [],
      // 非单个禁用
      single: true,
      single1: true,
      // 非多个禁用
      multiple: true,
      multiple1: true,
      // 关联方式
      relationType: [],
      // 内嵌编辑
      embedEdit: [],
    };
  },
  filters: {
    zdFn(data) {
      let is = ''
      for (let item of _this.columList) {
        if (item.columnId == data) {
          is = item.columnName
        }
      }
      return is
    },
    relationTypeFn(data) {
      let is = ''
      for (let item of _this.relationType) {
        if (item.dictValue == data) {
          is = item.dictLabel
        }
      }
      return is
    },
    embedEditFn(data) {
      let is = ''
      for (let item of _this.embedEdit) {
        if (item.dictValue == data) {
          is = item.dictLabel
        }
      }
      return is
    },
  },
  created() {
    const tableId = this.$route.params && this.$route.params.tableId;
    if (tableId) {
      // 获取表详细信息
      getGenTable(tableId).then(res => {
        this.cloumns = res.data.rows;
        this.info = res.data.info;
        console.log(this.info,33456)
        this.tables = res.data.tables;
      });
      //查询数据库sql
      tableSql(tableId).then(res => {
        if (res.data) {
          this.tableSqlData = res.data
        }
      })
      /** 查询字典下拉列表 */
      getDictOptionselect().then(response => {
        this.dictOptions = response.data;
      });
      // 关联HR字段
      genTableColumnList({
        tableId,
        htmlType: 'HR'
      }).then(response => {
        this.columHRList = response.rows;
      });
      // 关联字段
      listAllColumnsByTableId({
        id:tableId
      }).then(response => {
        this.columList = response.data;
      });
      // 关联表数据
      listTable(this.glbParams).then(response => {
        this.tableList = response;
      });
      /** 查询菜单下拉列表 */
      // getMenuTreeselect().then(response => {
      //   this.menus = this.handleTree(response.data, "menuId");
      // });
      // 关联方式
      this.getDicts("relation_type").then(response => {
        this.relationType = response.data;
      });
      // 内嵌编辑
      this.getDicts("embed_edit").then(response => {
        this.embedEdit = response.data;
      });
    }
    this.tabList()

  },
  methods: {
    tableBtn(row){
      this.openquery = false
      this.ForeName = row.column_name
      this.formZd.foreignKey = row.id
    },
    fkzdFn() {
      this.queryedit()
      this.getLisail()
      this.openquery = true
    },
    changeFn(obj) {
      console.log(obj)
      for(let key in obj){
        this.formquery.fixedData[key] = obj[key]
      }
    },
    // 快速查询
    queryedit(){
      this.loading = true;
      tableQuery(this.queryLisr).then(response => {
         let data = response.data
         this.queryData = data
          this.loading = false;
        })
    },
    handleQuery(){
      for(let item of this.queryData.queryList){
        if(item.htmlType == 'checkbox' || item.htmlType == 'imageUpload' || item.htmlType == 'fileUpload'){
          this.formquery[item.columnName] = this.$refs[item.columnName][0].config
        } else{
          this.formquery[item.columnName] = this.$refs[item.columnName][0].config[item.columnName]
        }
      }
     this.aliemg.fixedData.condition = this.formquery
     this.getLisail()
    },
    // 快速查询列表
    getLisail() {
      this.loading = true;
      listIndexfou(this.aliemg).then(response => {
          if(response.data){
            // this.tableDataalid = response.data.tableHeadList;
            this.postListquery = response.data
            this.postListquery.rows.filter(route => {
              if(route.table_id){
                 route.table_id = route.table_id.name
              }
            })
            this.totalquery = response.data.total;
          }
          this.loading = false;
        }
      );
    },
    submitFormZd() {
      this.$refs["formZd"].validate(valid => {
        if (valid) {
          const tableId = this.$route.params && this.$route.params.tableId;
          this.formZd.tableId = tableId
          if (this.formZd.id != undefined) {
            setGenTableColumn(this.formZd).then(response => {
              this.msgSuccess("修改成功");
              this.openZd = false;
              // 获取表详细信息
              getGenTable(tableId).then(res => {
                this.cloumns = res.data.rows;
                this.info = res.data.info;
                this.tables = res.data.tables;
              });
            });
          } else {
            addGenTableColumn(this.formZd).then(response => {
              this.msgSuccess("新增成功");
              this.openZd = false;
              // 获取表详细信息
              getGenTable(tableId).then(res => {
                this.cloumns = res.data.rows;
                this.info = res.data.info;
                this.tables = res.data.tables;
              });
            });
          }

        }
      });
    },
    sxCreaBtn() {
      const tableId = this.$route.params && this.$route.params.tableId
      getReload({
        tableId,
        createSql: this.tableSqlData.createSql,
        createLog: this.tableSqlData.createLog,
        id: this.tableSqlData.id
      }).then(res => {
        this.msgSuccess('刷新成功')
        //查询数据库sql
        tableSql(tableId).then(res => {
          if (res.data) {
            this.tableSqlData = res.data
          }
        })
      })
    },
    zxCreaBtn() {
      const _this = this
      this.$confirm('是否确认执行创建语句?', "警告", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning"
      }).then(function() {
        return zxImplement({
          tableId: _this.$route.params && _this.$route.params.tableId,
          createSql: _this.tableSqlData.createSql,
          createLog: _this.tableSqlData.createLog,
          id: _this.tableSqlData.id
        })
      }).then(res => {
        _this.msgSuccess('执行成功')
      })
    },
    dbSelectedZd(row) {
      this.reset();
      const id = row.id
      getByIdWithForeignKey(id).then(response => {
        let data = response.data
        data.foreignKey = data.foreignKey ? data.foreignKey - 0 : ''
        this.formZd = data;
        if(data.fkInfo){
          this.ForeName = data.fkInfo.value
        }
        this.openZd = true;
        this.title = "修改字段信息";
      });
    },
    dbSelected(row) {
      this.reset();
      const id = row.id
      qurGenTable(id).then(response => {
        let data = response.data
        data.relationType = data.relationType + ""
        data.embedEdit = data.embedEdit?(data.embedEdit + ""): data.embedEdit
        getGenTable(data.relationParentId).then(res => {
          this.genList = res.data.rows;
          this.form = data;
          this.open = true;
          this.title = "修改关联表";
        });
      });
    },
    addGlfn() {
      this.$refs["form"].validate(valid => {
        if (valid) {
          let datas = JSON.parse(JSON.stringify(this.form))
          datas.relationParentId = this.info.id
          console.log(datas,this.info.id,9998)
          if (this.form.id != undefined) {
            setGenTable(datas).then(response => {
              this.msgSuccess("修改成功");
              this.open = false;
              this.tabList();
            });
          } else {
            addGenTable(datas).then(response => {
              this.msgSuccess("新增成功");
              this.open = false;
              this.tabList();
            });
          }
        }
      });
    },
    relationFn(data) {
      getGenTable(data).then(res => {
        this.genList = res.data.rows;
      });
    },
    loadMore() {
      const _this = this
      let num = _this.tableList.total % 10 == 0 ? _this.tableList.total / 10 : ((_this.tableList.total - _this.tableList
        .total % 10) / 10 + 1)
      console.log(num, 1)
      if (this.glbParams.pageNum < num) {
        this.glbParams.pageNum++
        // 关联表数据
        listTable(this.glbParams).then(response => {
          let data = response
          data.rows = _this.tableList.rows.concat(data.rows)
          _this.tableList = data;
        });
      }
    },
    // 取消按钮
    cancel() {
      this.open = false;
      this.reset();
      this.openZd = false;
      this.resetZd();
    },
    // 关联表数据
    tabList() {
      this.loading = true;
      tabList(this.queryParams).then(response => {
        this.postList = response.rows;
        this.total = response.total;
        this.loading = false;
      });
    },
    /** 新增按钮操作 */
    handleAdd_gl() {
      this.reset();
      this.open = true;
      console.log(this.form)
      this.title = "新增关联表";
    },
    handleDel_gl(row) {
      const ids = row.id || this.ids1;
      this.$confirm('是否确认删除id为"' + ids + '"的数据项?', "警告", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning"
      }).then(function() {
        return delGenTable(ids);
      }).then(() => {
        this.tabList();
        this.msgSuccess("删除成功");
      })
    },
    // 表单重置
    reset() {
      this.form = {
        isDel: 'N'
      };
      this.resetForm("form");
    },
    resetZd() {
      this.formZd = {
      };
      this.resetForm("formZd");
    },
    /** 提交按钮 */
    submitForm() {
      let isInFlag = 0
      let isOutFlag = 0

      for(let item of this.cloumns){
        if(item.isIn=='Y'){
          isInFlag++
        }
        if(item.isOut=='Y'){
          isOutFlag++
        }
      }
      if(isInFlag>1){
        this.msgError('"输入字段"最多只能选择一个!')
        return
      }
      if(isOutFlag>1){
        this.msgError('"显示字段"最多只能选择一个!')
        return
      }
      const basicForm = this.$refs.basicInfo.$refs.basicInfoForm;
      const tabnum = Object.assign({}, basicForm.model)
      console.log(tabnum.tableColumn,234)
      if(tabnum.tableColumn >4 ){
         this.msgError('列数最大只能输入4')
         return
      }
      if( tabnum.tableColumn <1){
        this.msgError('最小只能输入1')
        return
      }


      // const genForm = this.$refs.genInfo.$refs.genInfoForm;
      Promise.all([basicForm].map(this.getFormPromise)).then(res => {
        const validateResult = res.every(item => !!item);
        if (validateResult) {
          const genTable = Object.assign({}, basicForm.model);
          genTable.columns = this.cloumns;
          // genTable.params = {
          //   treeCode: genTable.treeCode,
          //   treeName: genTable.treeName,
          //   treeParentCode: genTable.treeParentCode,
          //   parentMenuId: genTable.parentMenuId
          // };
          console.log(genTable)
          if(this.activeName=='basic'){
            genTable.updateType ='1'
          }
          if(this.activeName=='cloum'){
            genTable.updateType ='2'
          }
          updateGenTable(genTable).then(res => {
            this.msgSuccess(res.msg);
            if (res.code === 200) {
              this.close();
            }
          });
        } else {
          this.msgError("表单校验未通过，请重新检查提交内容");
        }
      });
    },
    getFormPromise(form) {
      return new Promise(resolve => {
        form.validate(res => {
          resolve(res);
        });
      });
    },
    /** 关闭按钮 */
    close() {
      this.$store.dispatch("tagsView/delView", this.$route);
      this.$router.push({
        path: "/tool/gen",
        query: {
          t: Date.now()
        }
      })
    },
    // 多选框选中数据
    handleSelectionChange(selection) {
      this.ids = selection.map(item => item.id)
      this.single = selection.length != 1
      this.multiple = !selection.length
    },
    // 多选框选中数据
    handleSelectionChange1(selection) {
      this.ids1 = selection.map(item => item.id)
      this.single1 = selection.length != 1
      this.multiple1 = !selection.length
    },
    /** 删除按钮操作 */
    handleDelete(row) {
      const ids = row.id || this.ids;
      const tableId = this.$route.params && this.$route.params.tableId;
      this.$confirm('是否确认删除字段编号为"' + ids + '"的数据项?', "警告", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning"
      }).then(function() {
        return delGenTableColumn(ids);
      }).then(() => {
        // 获取表详细信息
        getGenTable(tableId).then(res => {
          this.cloumns = res.data.rows;
          this.info = res.data.info;
          this.tables = res.data.tables;
        });
        this.msgSuccess("删除成功");
      })
    },
    handleAdd() {
      this.resetZd();
      this.openZd = true;
      this.title = "新增字段信息";
    }
  },
  mounted() {
    const el = this.$refs.dragTable.$el.querySelectorAll(".el-table__body-wrapper > table > tbody")[0];
    const sortable = Sortable.create(el, {
      handle: ".allowDrag",
      onEnd: evt => {
        const targetRow = this.cloumns.splice(evt.oldIndex, 1)[0];
        this.cloumns.splice(evt.newIndex, 0, targetRow);
        for (let index in this.cloumns) {
          this.cloumns[index].sort = parseInt(index) + 1;
        }
      }
    });
  }
};
"},null]}
|