<template> <div class="page-data"> <!--搜素框--> <div class="page-filter"> <page-filter :query.sync="projectFilterInfo.query" :filter-list="projectFilterInfo.list" @handleClick="handleClick" /> </div> <div class="page-content"> <!--表格--> <div class="h-100"> <page-table tabIndex pagination :api-url="projectTableInfo.url" :refresh="projectTableInfo.refresh" :data.sync="projectTableInfo.data" :query="projectFilterInfo.query" :page-query="projectTableInfo.pageQuery" :list-type-info="listTypeInfo" :init-curpage="projectTableInfo.initCurpage" :field-list="projectTableInfo.fieldList" :handle="projectTableInfo.handle" @handleClick="handleClick" > <template v-slot:col-status="scope"> <el-button type="text" size="small" :class="[scope.row.status === 1 ? '' : 'red']"> {{ scope.row.status === 1 ? "管理中" : "未管理" }} </el-button> </template> </page-table> </div> </div> <!--弹窗--> <el-dialog :width="dialogInfo.width" append-to-body :title="dialogInfo.title[dialogInfo.type]" :visible.sync="dialogInfo.visible" :before-close="handleClose" > <!--项目关联站点--> <template v-if="dialogInfo.type === 'relate'"> <div class="page-filter"> <el-form :inline="true" :model="siteQuery" ref="siteQuery" size="medium"> <el-form-item label=""> <el-input v-model="siteQuery.searchStr" placeholder="请输入站点编号/名称"></el-input> </el-form-item> <el-form-item> <el-button type="primary" icon="el-icon-search" size="medium" @click="handleClick('siteSearch')">查询</el-button> </el-form-item> </el-form> </div> <div class="page-content"> <el-row :gutter="20" class="h-100"> <el-col :span="10" class="h-100"> <page-table tabIndex checkBox pagination type="unRelate" :api-url="siteTableInfo.url" :refresh="siteTableInfo.refresh" :data.sync="UnRelateSiteTableInfo.data" :query="UnRelateSiteTableInfo.query" :init-curpage="siteTableInfo.initCurpage" :field-list="siteTableInfo.fieldList" @handleClick="handleClick" @handleEvent="handleEvent" /> </el-col> <el-col :span="4" class="h-100"> <div class="btn-group"> <el-button type="primary" size="small" icon="el-icon-d-arrow-right" :disabled="isCanInsertSite" @click="handleClick('insert')" >添加</el-button > <el-button type="primary" size="small" icon="el-icon-d-arrow-left" :disabled="isCanRemoveSite" @click="handleClick('remove')" >移除</el-button > </div> </el-col> <el-col :span="10" class="h-100"> <page-table tabIndex checkBox pagination type="isRelate" :api-url="siteTableInfo.url" :refresh="siteTableInfo.refresh" :data.sync="RelatedSiteTableInfo.data" :query="RelatedSiteTableInfo.query" :init-curpage="siteTableInfo.initCurpage" :field-list="siteTableInfo.fieldList" @handleClick="handleClick" @handleEvent="handleEvent" /> </el-col> </el-row> </div> </template> <!--修改项目--> <template v-if="dialogInfo.type === 'update'"> <div class="page-form"> <page-form :ref-obj.sync="projectFormInfo.ref" :data="projectFormInfo.data" :field-list="projectFormInfo.fieldList" :rules="projectFormInfo.rules" :list-type-info="listTypeInfo" :need-clear-nodes="projectFormInfo.needClearNodes" :cascader-options="projectFormInfo.cascaderOptions" @handleClick="handleClick" /> </div> </template> <!--分配权限--> <template v-if="dialogInfo.type === 'permission'"> <div class="page-filter"> <page-filter :query.sync="permissionFilterInfo.query" :filter-list="permissionFilterInfo.list" @handleClick="handleClick" /> </div> <div class="page-content"> <page-table tabIndex checkBox pagination :api-url="permissionTableInfo.url" :refresh="permissionTableInfo.refresh" :data.sync="permissionTableInfo.data" :query="permissionFilterInfo.query" :init-curpage="permissionTableInfo.initCurpage" :field-list="permissionTableInfo.fieldList" :handle="permissionTableInfo.handle" @handleClick="handleClick" @handleEvent="handleEvent" /> </div> </template> <div class="dialot-footer" slot="footer"> <template v-if="dialogInfo.type !== 'relate'"> <el-button type="primary" size="medium" @click="handleClick('submit')">保存</el-button> </template> <el-button size="medium" @click="handleClick('close')">取消</el-button> </div> </el-dialog> <el-dialog class="userDialog" append-to-body width="500px" :title="userDialogInfo.title[userDialogInfo.type]" :visible.sync="userDialogInfo.visible" :before-close="handleUserClose" > <!--添加用户--> <template v-if="userDialogInfo.type === 'addUser'"> <div class="page-form"> <page-form :ref-obj.sync="userFormInfo.ref" size="medium" :data="userFormInfo.data" :field-list="userFormInfo.fieldList" :rules="userFormInfo.rules" :list-type-info="listTypeInfo" @handleClick="handleClick" /> </div> </template> <!--添加用户组--> <template v-else> <div class="page-form"> <page-form :ref-obj.sync="groupFormInfo.ref" :data="groupFormInfo.data" :field-list="groupFormInfo.fieldList" :rules="groupFormInfo.rules" @handleClick="handleClick" /> </div> </template> <div slot="footer"> <el-button size="small" type="primary" @click="handleClick('save')">提交</el-button> <el-button size="small" @click="handleClick('closeUserDialog')">取消</el-button> </div> </el-dialog> </div> </template> <script> import { mapGetters } from "vuex"; export default { data() { // 验证电话 let checkPhone = (rule, value, callback) => { let check = this.$validate({ label: "电话", value, rules: ["moblie"] }); if (!check.result) { callback(new Error(check.message)); } else { callback(); } }; return { //项目搜索相关 projectFilterInfo: { query: { searchStr: "", startDate: "", endDate: "" }, list: [ {type: "input", label: "项目名称/编号", value: "searchStr", hideLabel: true }, {type: "date", label: "开始时间", value: "startDate", dateType: "date", datePickerOptions: "pickerOptionsStart", hideLabel: true}, {type: "date", label: "结束时间", value: "endDate", dateType: "date", datePickerOptions: "pickerOptionsEnd", hideLabel: true}, {type: "button", label: "查询", btType: "primary", icon: "", event: "searchProject", show: true} ] }, //项目表格相关 projectTableInfo: { url: this.nozzle.sysPlatformList, //接口地址 refresh: 1, initCurpage: 1, data: [], fieldList: [ { label: "项目编号", value: "platformCode", width: 100 }, { label: "项目名称", value: "name", minWidth: 150, tooltip: true }, { label: "项目添加时间", value: "createTime", minWidth: 150, tooltip: true }, { label: "操作人", value: "operator", width: 120 }, { label: "状态", value: "status", width: 100, type: "slot" }, { label: "项目类型", value: "sysGroup", minWidth: 100, tooltip: true, list: "xmlxList" } ], handle: { fixed: "right", label: "操作", width: "240", btList: [ { label: "分配权限", size: "small", type: "text", event: "permission", show: true, has: 'm11-1-1' }, { label: "项目关联站点", size: "small", type: "text", event: "relate", show: true, has: 'm11-1-2' }, { label: "修改", size: "small", type: "text", event: "update", show: true, has: 'm11-1-3' } ] } }, //分配权限表格相关 permissionTableInfo: { url: this.nozzle.userGroupList, //接口地址 refresh: 1, initCurpage: 1, data: [], fieldList: [ { label: "分组名称", value: "groupName", minWidth: 150, tooltip: true }, { label: "分组描述", value: "description", minWidth: 150, tooltip: true } ], handle: { fixed: "right", label: "操作", width: "120", btList: [ { label: "添加用户", size: "small", type: "text", event: "addUser", show: true } ] } }, //分配权限过滤相关 permissionFilterInfo: { query: { searchStr: "" }, list: [ { type: "input", label: "分组名称", value: "searchStr", hideLabel: true }, { type: "button", label: "查询", btType: "primary", icon: "el-icon-search", event: "searchPermission", show: true }, { type: "button", label: "添加用户组", btType: "primary", icon: "el-icon-plus", event: "addGroup", show: true } ] }, //分配权限选中表格数据 permissionSelectData: [], //需要进行绑定操作的项目ID needHandleProjectId: "", //弹窗相关 dialogInfo: { title: { update: "编辑" }, type: "", visible: false, width: "80%" }, //列表相关 listTypeInfo: { xmlxList: [{ key: "合同项目", value: "0" }, { key: "临时项目", value: "1" }], groupList: [], deptTree: [], roleTree: [], userType: [{ key: "普通用户", value: 0 }, { key: "超级管理员", value: 1 }], statusList: [{ key: "未管理", value: 0 }, { key: "管理中", value: 1 }] }, //用户弹窗相关 userDialogInfo: { title: { addUser: "添加用户", addGroup: "添加用户组" }, type: "", visible: false }, //用户表单相关 userFormInfo: { ref: null, data: { id: undefined, login: "", realName: "", pwd: "", userType: "", orgId: undefined, groupId: undefined, groupName: "", roleId: undefined, mobile: "" }, fieldList: [ { label: "用户名", value: "login", type: "input", required: true }, { label: "姓名", value: "realName", type: "input", required: true }, { label: "密码", value: "pwd", type: "password", required: true }, { label: "电话", value: "mobile", type: "input", validator: checkPhone }, { label: "用户类型", value: "userType", type: "select", list: "userType", required: true }, { label: "所属部门", value: "orgId", type: "treeselect", list: "deptTree", required: true }, { label: "所属分组", value: "groupName", type: "input", disabled: true }, { label: "所属角色", value: "roleId", type: "treeselect", list: "roleTree", required: true } ], rules: {}, treeOptions: [] }, //用户组表单相关 groupFormInfo: { ref: null, data: { id: undefined, groupName: "", description: "" }, fieldList: [ { label: "用户组名称", value: "groupName", type: "input", required: true }, { label: "用户组描述", value: "description", type: "textarea", limit: true } ], rules: {} }, //站点表格相关 siteTableInfo: { url: this.nozzle.sysStationBaseList, //接口地址 refresh: 1, initCurpage: 1, fieldList: [ { label: "站点编号", value: "stCode", minWidth: 150, tooltip: true }, { label: "站点名称", value: "stName", minWidth: 150, tooltip: true } ] }, //已关联站点表格相关 RelatedSiteTableInfo: { data: [], query: { sign: "" }, selectList: [] }, //未关联站点表格相关 UnRelateSiteTableInfo: { data: [], query: { sign: "unbound" }, selectList: [] }, //站点过滤相关 siteQuery: { searchStr: "", platformCode: "" }, //项目表单相关 projectFormInfo: { ref: null, data: { id: undefined, name: "", sysGroup: "", operator: "", area: "", platformCode: "", status: undefined }, fieldList: [ { label: "项目名称", value: "name", type: "input", required: true }, { label: "项目类型", value: "sysGroup", type: "select", list: "xmlxList", required: true }, { label: "项目编号", value: "platformCode", type: "input", disabled: true }, { label: "项目状态", value: "status", type: "select", list: "statusList", required: true }, { label: "操作人", value: "operator", type: "input", disabled: true }, { label: "所属区域", value: "area", type: "cascader", required: true } ], rules: {}, cascaderOptions: [], //区域级联数据源 needClearNodes: false //是否清除级联上次数据高亮 } }; }, watch: { "dialogInfo.visible"(val) { if (!val) { this.permissionTableInfo.data = []; this.RelatedSiteTableInfo.data = []; this.UnRelateSiteTableInfo.data = []; this.siteQuery = { searchStr: "" }; if (this.projectFormInfo.ref) { this.projectFormInfo.ref.resetFields(); } const type = this.dialogInfo.type; this.projectFormInfo.needClearNodes = true; this.resetForm(type); } }, "dialogInfo.type"(val) { if (val === "update") { this.dialogInfo.width = "500px"; return; } this.dialogInfo.width = "80%"; }, "userDialogInfo.visible"(val) { if (!val) { if (this.groupFormInfo.ref) { this.groupFormInfo.ref.resetFields(); } if (this.userFormInfo.ref) { this.userFormInfo.ref.resetFields(); } const type = this.userDialogInfo.type; this.resetForm(type); } }, "siteQuery.searchStr"(val) { Object.assign(this.RelatedSiteTableInfo.query, this.siteQuery); Object.assign(this.UnRelateSiteTableInfo.query, this.siteQuery); } }, computed: { //移除按钮是否可点击 isCanRemoveSite() { return this.RelatedSiteTableInfo.selectList.length ? false : true; }, //添加按钮是否可点击 isCanInsertSite() { return this.UnRelateSiteTableInfo.selectList.length ? false : true; }, ...mapGetters(["allDept", "allRole", "allCity"]) }, mounted() { this.initRules(); this.projectTableInfo.refresh = Math.random(); }, methods: { // 初始化验证 initRules() { const userFormInfo = this.userFormInfo; const groupFormInfo = this.groupFormInfo; const projectFormInfo = this.projectFormInfo; userFormInfo.rules = this.$initRules(userFormInfo.fieldList); groupFormInfo.rules = this.$initRules(groupFormInfo.fieldList); projectFormInfo.rules = this.$initRules(projectFormInfo.fieldList); }, //点击事件 handleClick(event, data) { switch (event) { //项目搜索 case "searchProject": this.projectTableInfo.initCurpage = Math.random(); this.projectTableInfo.refresh = Math.random(); break; //项目关联站点按钮 case "relate": this.dialogInfo.type = event; this.siteQuery.platformCode = data.platformCode; this.dialogInfo.visible = true; setTimeout(() => { Object.assign(this.RelatedSiteTableInfo.query, this.siteQuery); Object.assign(this.UnRelateSiteTableInfo.query, this.siteQuery); this.siteTableInfo.refresh = Math.random(); }, 0); break; //分配权限按钮 case "permission": this.dialogInfo.visible = true; this.dialogInfo.type = event; this.listTypeInfo.deptTree = this.allDept; this.listTypeInfo.roleTree = this.allRole; this.needHandleProjectId = data.platformCode; setTimeout(() => { this.permissionTableInfo.refresh = Math.random(); }, 0); break; //站点搜索 case "siteSearch": this.siteTableInfo.initCurpage = Math.random(); this.siteTableInfo.refresh = Math.random(); break; //分配权限搜索 case "searchPermission": this.permissionTableInfo.initCurpage = Math.random(); this.permissionTableInfo.refresh = Math.random(); break; //添加用户按钮 case "addUser": this.userDialogInfo.type = event; this.userFormInfo.data["groupName"] = data.groupName; this.userFormInfo.data["groupId"] = data.id; this.userDialogInfo.visible = true; break; //添加用户组按钮 case "addGroup": this.userDialogInfo.type = event; this.userDialogInfo.visible = true; break; //提交数据 case "submit": let submitType = this.dialogInfo.type; let submitApi, submitParams; if (submitType === "permission") { if (this.permissionSelectData.length) { if (this.permissionSelectData.length > 1) { this.$message({ message: "仅能绑定一个用户组到项目", type: "warning", showClose: true }); return; } else { const groupIds = this.permissionSelectData.map(item => item.id); submitApi = this.nozzle.addGroupToProject; submitParams = { data: { groupIds: groupIds, platfromCode: this.needHandleProjectId } }; this.handleAjax(submitApi, submitParams); } } else { this.$message({ message: "请选择需要绑定的用户组", type: "warning", showClose: true }); return; } } else if (submitType === "update") { //更新项目 this.projectFormInfo.ref.validate(valid => { if (valid) { submitApi = this.nozzle.sysPlatformUpdate; submitParams = { data: this.projectFormInfo.data }; this.handleAjax(submitApi, submitParams); } }); } else { return; } break; //添加站点到项目 case "insert": if (this.UnRelateSiteTableInfo.selectList.length) { const siteIdArr = this.UnRelateSiteTableInfo.selectList.map( item => item.id); const insertData = { platCode: this.RelatedSiteTableInfo.query.platformCode, siteList: siteIdArr }; this.$http.post(this.nozzle.sysStationBaseUpdate, { data: insertData }).then(res => { if (res.data.code === 1) { this.siteQuery.searchStr = ""; this.siteTableInfo.refresh = Math.random(); this.siteTableInfo.initCurpage = Math.random(); } this.$message({ message: res.data.msg, type: res.data.code === 1 ? "success" : "error", showClose: true }); }); } else { this.$message({ message: "请选择需要绑定的站点", type: "warning", showClose: true }); } break; //从项目中移除站点 case "remove": if (this.RelatedSiteTableInfo.selectList.length) { const siteIdArr = this.RelatedSiteTableInfo.selectList.map(item => item.id); const removeData = { platCode: this.RelatedSiteTableInfo.query.platformCode, siteList: siteIdArr }; this.$http.post(this.nozzle.sysStationBaseRemove, { data: removeData }).then(res => { if (res.data.code === 1) { this.siteQuery.searchStr = ""; this.siteTableInfo.refresh = Math.random(); this.siteTableInfo.initCurpage = Math.random(); } this.$message({ message: res.data.msg, type: res.data.code === 1 ? "success" : "error", showClose: true }); }); } else { this.$message({ message: "请选择需要移除的站点", type: "warning", showClose: true }); } break; //编辑项目按钮 case "update": this.dialogInfo.type = event; this.dialogInfo.visible = true; this.projectFormInfo.needClearNodes = false; this.projectFormInfo.cascaderOptions = this.removeEmptyChild(this.allCity); for (let key in data) { if (key in this.projectFormInfo.data) { this.projectFormInfo.data[key] = data[key]; this.projectFormInfo.data["operator"] = this.$fn.getLocalStore("USERNO"); } } break; //关闭 case "close": this.dialogInfo.visible = false; break; case "closeUserDialog": this.userDialogInfo.visible = false; break; //保存用户组/用户 case "save": const type = this.userDialogInfo.type; const formName = type === "addUser" ? this.userFormInfo : this.groupFormInfo; let params, api; formName.ref.validate(valid => { if (valid) { if (type === "addUser") { //添加用户绑定到用户组 api = this.nozzle.addUserToGroup; params = this.userFormInfo.data; } if (type === "addGroup") { //添加保存用户组 api = this.nozzle.userGroupAdd; params = { data: this.groupFormInfo.data }; } this.$http.post(api, params).then(res => { if (res.data.code === 1 || res.data.code === 200) { this.userDialogInfo.visible = false; this.permissionTableInfo.refresh = Math.random(); } this.$message({ message: res.data.msg, type: res.data.code === 1 ? "success" : "error", showClose: true }); }) .catch(e => { console.log(e); }); } }); break; } }, //关闭弹窗 handleClose() { this.dialogInfo.visible = false; }, handleUserClose() { this.userDialogInfo.visible = false; }, //表格checkbox选择事件 handleEvent(event, data) { switch (event) { case "all": this.permissionSelectData = data; break; case "isRelate": this.RelatedSiteTableInfo.selectList = data; break; case "unRelate": this.UnRelateSiteTableInfo.selectList = data; break; } }, //重置表单 resetForm(type) { switch (type) { case "addUser": this.userFormInfo.data = { id: undefined, login: "", realName: "", pwd: "", userType: "", orgId: undefined, groupId: undefined, groupName: "", roleId: undefined, mobile: "" }; break; case "addGroup": this.groupFormInfo.data = { id: undefined, groupName: "", description: "" }; break; case "update": this.projectFormInfo.data = { id: undefined, name: "", sysGroup: "", operator: "", area: "", platformCode: "", status: undefined }; break; } }, //请求接口处理结果 handleAjax(url, params) { this.$http .post(url, params) .then(res => { if (res.data.code === 1 || res.data.code === 200) { this.dialogInfo.visible = false; this.projectTableInfo.refresh = Math.random(); } this.$message({ message: res.data.msg, type: res.data.code === 1 ? "success" : "error", showClose: true }); }) .catch(e => { console.log(e); }); }, //将空的children置为undefined,避免在没有下一级数据的情况下显示暂无数据 removeEmptyChild(arr) { arr.forEach(item => { if (!item.children || item.children.length < 1) { item.children = undefined; } else { this.removeEmptyChild(item.children); } }); return arr; } } }; </script> <style lang="scss" scoped> .page-data { @include fd(); } .page-filter { text-align: left; } .page-content { flex: 1; overflow: hidden; .page-table { height: 100%; } .red { color: red; } } .btn-group { height: 100%; @include fdaj(center, center); /deep/ .el-button + .el-button { margin-left: 0; margin-top: 10px; } } /deep/ .el-dialog { @include fd(); @include wh(80%, 60%); max-height: 60%; margin-top: 10vh !important; .el-dialog__body { @include fd(); flex: 1; padding: 20px; overflow-y: auto; } .el-pagination__sizes, .el-pagination__total, .el-pagination__jump { display: none; } } .userDialog { /deep/ .el-form-item { .el-form-item__label { width: 120px; padding-right: 15px; } } } </style>