| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246 | <template>  <basic-container>    <avue-crud :option="option"               :table-loading="loading"               :data="data"               :page.sync="page"               :permission="permissionList"               :before-open="beforeOpen"               v-model="form"               ref="crud"               @row-update="rowUpdate"               @row-save="rowSave"               @row-del="rowDel"               @search-change="searchChange"               @search-reset="searchReset"               @selection-change="selectionChange"               @current-change="currentChange"               @size-change="sizeChange"               @refresh-change="refreshChange"               @on-load="onLoad">      <template slot="menuLeft">        <el-button type="danger"                   size="small"                   icon="el-icon-delete"                   plain                   v-if="permission.wbsinfo_delete"                   @click="handleDelete">删 除        </el-button>      </template>      <template slot-scope="{row,index}" slot="menu">        <el-button type="text" icon="el-icon-edit" size="mini" v-if="permission.wbsinfo_tree_edit" @click="toEdit(row,index)">编辑wbs库</el-button>      </template>    </avue-crud>  </basic-container></template><script>  import {getList, getDetail, add, update, remove} from "@/api/manager/wbsinfo";  import {mapGetters} from "vuex";  export default {    data() {      return {        form: {},        query: {},        loading: true,        page: {          pageSize: 20,          currentPage: 1,          total: 0        },        selectionList: [],        option: {          menuWidth:300,          height:'auto',          calcHeight: 30,          tip: false,          searchShow: true,          searchMenuSpan: 6,          border: true,          index: true,          viewBtn: true,          selection: true,          dialogClickModal: false,          column: [            {              label: "创建时间",              prop: "createTime",              rules: [{                required: true,                message: "请输入创建时间",                trigger: "blur"              }]            },            {              label: "wsb名称",              prop: "wbsName",              rules: [{                required: true,                message: "请输入wsb名称",                trigger: "blur"              }]            },            {              label: "wsb属性",              prop: "wbsType",              hide:true,              rules: [{                required: true,                message: "请输入wsb属性",                trigger: "blur"              }]            },            {              label: "是否启用",              prop: "status",              rules: [{                required: true,                message: "是否启用",                trigger: "blur"              }]            },          ]        },        data: []      };    },    computed: {      ...mapGetters(["permission"]),      permissionList() {        return {          addBtn: this.vaildData(this.permission.wbsinfo_add, false),          viewBtn: this.vaildData(this.permission.wbsinfo_view, false),          delBtn: this.vaildData(this.permission.wbsinfo_delete, false),          editBtn: this.vaildData(this.permission.wbsinfo_edit, false)        };      },      ids() {        let ids = [];        this.selectionList.forEach(ele => {          ids.push(ele.id);        });        return ids.join(",");      }    },    methods: {      rowSave(row, done, loading) {        add(row).then(() => {          this.onLoad(this.page);          this.$message({            type: "success",            message: "操作成功!"          });          done();        }, error => {          loading();          window.console.log(error);        });      },      rowUpdate(row, index, done, loading) {        update(row).then(() => {          this.onLoad(this.page);          this.$message({            type: "success",            message: "操作成功!"          });          done();        }, error => {          loading();          console.log(error);        });      },      rowDel(row) {        this.$confirm("确定将选择数据删除?", {          confirmButtonText: "确定",          cancelButtonText: "取消",          type: "warning"        })          .then(() => {            return remove(row.id);          })          .then(() => {            this.onLoad(this.page);            this.$message({              type: "success",              message: "操作成功!"            });          });      },      handleDelete() {        if (this.selectionList.length === 0) {          this.$message.warning("请选择至少一条数据");          return;        }        this.$confirm("确定将选择数据删除?", {          confirmButtonText: "确定",          cancelButtonText: "取消",          type: "warning"        })          .then(() => {            return remove(this.ids);          })          .then(() => {            this.onLoad(this.page);            this.$message({              type: "success",              message: "操作成功!"            });            this.$refs.crud.toggleSelection();          });      },      beforeOpen(done, type) {        if (["edit", "view"].includes(type)) {          getDetail(this.form.id).then(res => {            this.form = res.data.data;          });        }        done();      },      searchReset() {        this.query = {};        this.onLoad(this.page);      },      searchChange(params, done) {        this.query = params;        this.page.currentPage = 1;        this.onLoad(this.page, params);        done();      },      selectionChange(list) {        this.selectionList = list;      },      selectionClear() {        this.selectionList = [];        this.$refs.crud.toggleSelection();      },      currentChange(currentPage){        this.page.currentPage = currentPage;      },      sizeChange(pageSize){        this.page.pageSize = pageSize;      },      refreshChange() {        this.onLoad(this.page, this.query);      },      onLoad(page, params = {}) {        this.loading = true;        getList(page.currentPage, page.pageSize, Object.assign(params, this.query)).then(res => {          const data = res.data.data;          this.page.total = data.total;          this.data = data.records;          this.loading = false;          this.selectionClear();        });      },      toEdit(row){        //console.log(row,index);        this.$router.push('/wbs/edit/'+row.id);      }    }  };</script><style></style>
 |