<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 class="page-data-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 flex flex-d"> <div class="table-title">未关联站点列表</div> <page-table class="flex-1" 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 flex flex-d"> <div class="table-title">已关联站点列表</div> <page-table class="flex-1" 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' || dialogInfo.type === 'create' "> <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" :limit-time="projectFormInfo.limitTime" :label-width="projectFormInfo.labelWidth" :need-clear-nodes="projectFormInfo.needClearNodes" :cascader-options="projectFormInfo.cascaderOptions" @currentAreaJwd="currentAreaJwd" @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 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' && dialogInfo.type !== 'permission'"> <el-button type="primary" size="small" @click="handleClick('submit')" :loading="btnLoading">保存</el-button> </template> <el-button size="small" @click="handleClick('close')">关闭</el-button> </div> </el-dialog> <el-dialog class="userDialog" append-to-body :width="userDialogInfo.width" :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-if="userDialogInfo.type === 'addGroup'"> <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> <!--查看用户--> <template v-else> <!-- <div class="h-100"> <page-table tabIndex pagination :api-url="groupUserTableInfo.url" :refresh="groupUserTableInfo.refresh" :data.sync="groupUserTableInfo.data" :query="groupUserFilterInfo.query" :init-curpage="groupUserTableInfo.initCurpage" :field-list="groupUserTableInfo.fieldList" :handle="groupUserTableInfo.handle" @handleClick="handleClick" @handleEvent="handleEvent" /> </div> --> <div class="page-filter"> <el-form :inline="true" :model="userQuery" ref="userQuery" size="medium"> <el-form-item label=""> <el-input v-model="userQuery.searchStr" placeholder="请输入用户名"></el-input> </el-form-item> <el-form-item> <el-button type="primary" icon="el-icon-search" size="medium" @click="handleClick('userSearch')">查询</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 flex flex-d"> <div class="table-title">未关联用户列表</div> <page-table class="flex-1" checkBox pagination type="unUserRelate" :api-url="userTableInfo.url" :refresh="userTableInfo.refresh" :data.sync="UnRelateUserTableInfo.data" :query="UnRelateUserTableInfo.query" :init-curpage="userTableInfo.initCurpage" :field-list="userTableInfo.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="isCanInsertUser" @click="handleClick('insertUser')" >添加</el-button > <el-button type="primary" size="small" icon="el-icon-d-arrow-left" :disabled="isCanRemoveUser" @click="handleClick('removeUser')" >移除</el-button > </div> </el-col> <el-col :span="10" class="h-100 flex flex-d"> <div class="table-title">已关联用户列表</div> <page-table class="flex-1" checkBox pagination type="isUserRelate" :api-url="userTableInfo.url" :refresh="userTableInfo.refresh" :data.sync="RelatedUserTableInfo.data" :query="RelatedUserTableInfo.query" :init-curpage="userTableInfo.initCurpage" :field-list="userTableInfo.fieldList" @handleClick="handleClick" @handleEvent="handleEvent" /> </el-col> </el-row> </div> </template> <div slot="footer"> <el-button size="small" type="primary" v-if="userDialogInfo.type !== 'detail'" @click="handleClick('save')" :loading="btnLoading">提交</el-button> <el-button size="small" @click="handleClick('closeUserDialog')">关闭</el-button> </div> </el-dialog> </div> </template> <script> import { mapGetters } from "vuex"; import { message } from "./../../util/item"; export default { data() { // 验证电话 let checkPhone = (rule, value, callback) => { let check = this.$validate({ label: "手机号", value, rules: ["phone"] }); 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: "el-icon-search", event: "searchProject", show: true}, {type: "button", label: "添加项目", btType: "primary", icon: "el-icon-circle-plus-outline", event: "create", show: true, has: "m11-1-4"} ] }, //项目表格相关 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: "onlineTime", minWidth: 150, tooltip: true }, { label: "操作人", value: "realName", 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' }, { label: "删除", size: "small", type: "text", event: "delete", show: true, has: 'm11-1-5' } ] } }, //分配权限表格相关 permissionTableInfo: { url: this.nozzle.userGroupList, //接口地址 refresh: 1, initCurpage: 1, data: [], fieldList: [ { label: "分组名称", value: "groupName", minWidth: 120, tooltip: true }, { label: "分组描述", value: "description", minWidth: 120, tooltip: true } ], handle: { fixed: "right", label: "操作", width: "240", btList: [ { label: "添加用户", size: "small", type: "text", event: "addUser", show: true }, { label: "关联用户", size: "small", type: "text", event: "detail", show: true }, { label: "删除用户组", size: "small", type: "text", event: "delGroup", show: true } ] } }, //分配权限过滤相关 permissionFilterInfo: { query: { searchStr: "", platformCode: "" }, 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 } ] }, //需要进行绑定操作的项目ID needHandleProjectId: "", //按钮loading btnLoading: false, //弹窗相关 dialogInfo: { title: { update: "编辑项目", create: "添加项目" }, type: "", visible: false, width: "80%" }, //列表相关 listTypeInfo: { xmlxList: [{ key: "合同项目", value: "0" }, { key: "临测项目", value: "1" }], groupList: [], deptTree: [], userType: [{ key: "普通用户", value: 0 }, { key: "超级管理员", value: 1 }], statusList: [{ key: "未管理", value: 0 }, { key: "管理中", value: 1 }], roleList: [], }, //用户弹窗相关 userDialogInfo: { title: { addUser: "添加用户", addGroup: "添加用户组", detail: "" }, width: "80%", type: "", visible: false }, //用户表单相关 userFormInfo: { ref: null, data: { id: undefined, login: "", realName: "", userType: 0, orgId: undefined, groupId: undefined, groupName: "", roleId: undefined, mobile: "", roleType: 0, }, fieldList: [ { label: "用户名", value: "login", type: "input", required: true }, { label: "姓名", value: "realName", type: "input", required: true }, { label: "手机号", value: "mobile", type: "input", required: true, validator: checkPhone }, { label: "用户类型", value: "userType", type: "select", list: "userType", disabled: true }, { label: "所属部门", value: "orgId", type: "treeselect", list: "deptTree", required: true }, { label: "所属分组", value: "groupName", type: "input", disabled: true }, { label: "所属角色", value: "roleId", type: "select", list: "roleList", 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: {} }, //用户组下用户过滤相关 // groupUserFilterInfo: { // query: { // id: undefined // }, // }, //用户组下用户表格相关 // groupUserTableInfo: { // url: this.nozzle.userGroupUserList, //接口地址 // refresh: 1, // initCurpage: 1, // data: [], // fieldList: [ // { label: "用户名", value: "login", minWidth: 120, tooltip: true }, // { label: "姓名", value: "realName", minWidth: 100, tooltip: true }, // { label: "电话", value: "mobile", minWidth: 120, tooltip: true }, // ], // handle: { // fixed: "right", // label: "操作", // width: "80", // btList: [ // { label: "删除", size: "small", type: "text", event: "delUser", show: true } // ] // } // }, //用户表格通用相关 userTableInfo: { url: this.nozzle.userGroupUserList, //接口地址 refresh: 1, initCurpage: 1, fieldList: [ { label: "用户名", value: "login", minWidth: 120, tooltip: true }, { label: "姓名", value: "realName", minWidth: 100, tooltip: true }, { label: "电话", value: "mobile", minWidth: 120, tooltip: true } ] }, //已关联用户表格相关 RelatedUserTableInfo: { data: [], query: { sign: "" }, selectList: [] }, //未关联用户表格相关 UnRelateUserTableInfo: { data: [], query: { sign: "unbound" }, selectList: [] }, //用户表格搜索相关 userQuery: { searchStr: "", groupId: "" }, //站点表格通用相关 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: "", realName: "", area: "", platformCode: "", status: undefined, startTime: "", endTime: "", onlineTime: "" }, fieldList: [ { label: "项目名称", value: "name", type: "input", required: true }, { label: "项目类型", value: "sysGroup", type: "select", list: "xmlxList", required: true }, { label: "临测开始时间", value: "startTime", type: "date", dateType: "date", datePickerOptions: "pickerOptionsStart", required: true, show: false }, { label: "临测结束时间", value: "endTime", type: "date", dateType: "date", datePickerOptions: "pickerOptionsEnd", required: true, show: false }, { label: "上线时间", value: "onlineTime", type: "date", dateType: "date", required: true }, { label: "项目编号", value: "platformCode", type: "input", disabled: true }, { label: "项目状态", value: "status", type: "select", list: "statusList", required: true }, { label: "用户名称", value: "realName", type: "input", disabled: true }, { label: "所属区域", value: "area", type: "cascader", required: true } ], rules: {}, labelWidth: "110px", cascaderOptions: [], //区域级联数据源 needClearNodes: false, //是否清除级联上次数据高亮 limitTime: true, //是否开启选择时间区段限制 }, //保存当前选中城市信息以便获取经纬度 currentCity: {}, }; }, 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(); this.projectFormInfo.ref.clearValidate(); } const type = this.dialogInfo.type; this.projectFormInfo.needClearNodes = true; this.resetForm(type); } }, "dialogInfo.type"(val) { const projectFormInfo = this.projectFormInfo; switch(val) { case "update": for(let item of projectFormInfo.fieldList) { if(item.value === "platformCode") { item.show = true; } } this.dialogInfo.width = "500px"; break; case "create": for(let item of projectFormInfo.fieldList) { if(item.value === "platformCode") { item.show = false; } } this.dialogInfo.width = "500px"; break; default: this.dialogInfo.width = "60%"; break; } }, "userDialogInfo.visible"(val) { if (!val) { if (this.groupFormInfo.ref) { this.groupFormInfo.ref.resetFields(); } if (this.userFormInfo.ref) { this.userFormInfo.ref.resetFields(); } this.RelatedUserTableInfo.data = []; this.UnRelateUserTableInfo.data = []; this.userQuery = { searchStr: "" }; const type = this.userDialogInfo.type; this.resetForm(type); } }, "userDialogInfo.type"(val) { if(val === "addUser" || val === "addGroup") { this.userDialogInfo.width = "500px"; }else{ this.userDialogInfo.width = "80%"; } }, "siteQuery.searchStr"(val) { Object.assign(this.RelatedSiteTableInfo.query, this.siteQuery); Object.assign(this.UnRelateSiteTableInfo.query, this.siteQuery); }, "userQuery.searchStr"(val) { Object.assign(this.RelatedUserTableInfo.query, this.userQuery); Object.assign(this.UnRelateUserTableInfo.query, this.userQuery); }, "projectFormInfo.data.sysGroup"(val) { if(val) { if(val === "1") {//临测项目 for(let item of this.projectFormInfo.fieldList) { if(item.value === "endTime" || item.value === "startTime") { item.show = true; } } }else{//合同项目 for(let item of this.projectFormInfo.fieldList) { if(item.value === "endTime" || item.value === "startTime") { item.show = false; } } } this.projectFormInfo.rules = this.$initRules(this.projectFormInfo.fieldList); setTimeout(() => { this.projectFormInfo.ref.clearValidate(); }, 0); }else{ this.resetForm(this.dialogInfo.type); if(this.projectFormInfo.ref) { this.projectFormInfo.ref.resetFields(); } for(let item of this.projectFormInfo.fieldList) { if(item.value === "endTime" || item.value === "startTime") { item.show = false; } } } } }, computed: { //移除按钮是否可点击 isCanRemoveSite() { return this.RelatedSiteTableInfo.selectList.length ? false : true; }, //添加按钮是否可点击 isCanInsertSite() { return this.UnRelateSiteTableInfo.selectList.length ? false : true; }, //移除按钮是否可点击 isCanRemoveUser() { return this.RelatedUserTableInfo.selectList.length ? false : true; }, //添加按钮是否可点击 isCanInsertUser() { return this.UnRelateUserTableInfo.selectList.length ? false : true; }, ...mapGetters(["allDept", "allRole", "allCity"]) }, mounted() { this.initRules(); this.projectTableInfo.refresh = Math.random(); this.initRoles(); }, 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); }, // 初始化角色 initRoles() { this.$http.post(this.nozzle.roleGetRoles, { current: 0, size: 0, data: { searchStr: "", type: 0 } }).then(res => { if(res.data.code === 1) { this.listTypeInfo.roleList = res.data.data.map(item => { return{ key: item.roleName, value: item.roleId } }) } }) }, //点击事件 handleClick(event, data) { switch (event) { //项目搜索 case "searchProject": this.projectTableInfo.initCurpage = Math.random(); this.projectTableInfo.refresh = Math.random(); break; //项目添加按钮 case "create": this.dialogInfo.type = event; this.dialogInfo.visible = true; this.projectFormInfo.needClearNodes = false; this.projectFormInfo.cascaderOptions = this.removeEmptyChild(this.allCity); this.projectFormInfo.data["operator"] = this.$fn.getLocalStore("USERNO"); this.projectFormInfo.data["realName"] = this.$fn.getLocalStore("USERName"); 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.rules = this.$initRules(this.projectFormInfo.fieldList); } } setTimeout(() => { this.initRules(); }, 0); break; //提交数据 case "submit": let submitType = this.dialogInfo.type; let submitApi, submitParams; const { lat, lon } = this.currentCity; this.projectFormInfo.data.longitude = lon; this.projectFormInfo.data.latitude = lat; if(submitType === "update" || submitType === "create") { this.projectFormInfo.rules = this.$initRules(this.projectFormInfo.fieldList); this.projectFormInfo.ref.validate(valid => { if (valid) { this.btnLoading = true; submitApi = this.nozzle.sysPlatformAddOrUpdate; submitParams = { data: this.projectFormInfo.data }; this.handleAjax(submitApi, submitParams); }else{ return false; } }); } break; //项目删除按钮 case "delete": this.$confirm("此操作将永久删除该数据, 是否继续?", "提示", { confirmButtonText: "确定", cancelButtonText: "取消", type: "warning" }).then(res =>{ this.$http.post(this.nozzle.sysPlatformDelete,{data:{platformCode:data.platformCode}}).then(res =>{ if(res.data.code === 1 || res.data.code === 200) { this.projectTableInfo.refresh = Math.random(); this.projectTableInfo.initCurpage = Math.random(); } this.$message({ message: res.data.msg, type: res.data.code === 1 ? 'success' : 'error', showClose: true, }) }).catch(e =>{ message(e); }) }).catch(() =>{}) 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.needHandleProjectId = data.platformCode; this.permissionFilterInfo.query.platformCode = 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 "detail": this.userDialogInfo.type = event; this.userDialogInfo.visible = true; this.userQuery.groupId = data.id; setTimeout(() => { Object.assign(this.RelatedUserTableInfo.query, this.userQuery); Object.assign(this.UnRelateUserTableInfo.query, this.userQuery); this.userTableInfo.refresh = Math.random(); }, 0); break; //用户搜索 case "userSearch": this.userTableInfo.initCurpage = Math.random(); this.userTableInfo.refresh = Math.random(); break; //绑定用户到用户组 case "insertUser": const userIdInsertArr = this.UnRelateUserTableInfo.selectList.map( item => item.id); const insertUserData = { groupId: this.UnRelateUserTableInfo.query.groupId, userIds: userIdInsertArr }; this.$http.post(this.nozzle.bindUserToGroup, { data: insertUserData }).then(res => { if (res.data.code === 1) { this.userQuery.searchStr = ""; this.userTableInfo.refresh = Math.random(); this.userTableInfo.initCurpage = Math.random(); } this.$message({ message: res.data.msg, type: res.data.code === 1 ? "success" : "error", showClose: true }); }) break; //从用户组中解绑用户 case "removeUser": const userIdRemoveArr = this.RelatedUserTableInfo.selectList.map(item => item.id); const removeUserData = { groupId: this.RelatedUserTableInfo.query.groupId, userIds: userIdRemoveArr }; this.$http.post(this.nozzle.removeUserFromGroup, { data: removeUserData }).then(res => { if (res.data.code === 1) { this.userQuery.searchStr = ""; this.userTableInfo.refresh = Math.random(); this.userTableInfo.initCurpage = Math.random(); } this.$message({ message: res.data.msg, type: res.data.code === 1 ? "success" : "error", showClose: true }); }); break; //删除用户组按钮 case "delGroup": this.$confirm("此操作将永久删除该数据, 是否继续?", "提示", { confirmButtonText: "确定", cancelButtonText: "取消", type: "warning" }).then(res =>{ this.$http.post(this.nozzle.userGroupDelete,{data:{id:data.id}}).then(res =>{ if(res.data.code === 1 || res.data.code === 200) { this.permissionTableInfo.refresh = Math.random(); this.permissionTableInfo.initCurpage = Math.random(); } this.$message({ message: res.data.msg, type: res.data.code === 1 ? 'success' : 'error', showClose: true, }) }).catch(e =>{ message(e); }) }).catch(() =>{}) break; //从用户组中删除用户 // case "delUser": // this.$confirm("此操作将永久删除该数据, 是否继续?", "提示", { // confirmButtonText: "确定", // cancelButtonText: "取消", // type: "warning" // }).then(res =>{ // this.$http.post(this.nozzle.userGroupRemoveUser,{data:{userIds:[data.id]}}).then(res =>{ // if(res.data.code === 1 || res.data.code === 200) { // this.groupUserTableInfo.refresh = Math.random(); // this.groupUserTableInfo.initCurpage = Math.random(); // } // this.$message({ // message: res.data.msg, // type: res.data.code === 1 ? 'success' : 'error', // showClose: true, // }) // }).catch(e =>{ // message(e); // }) // }).catch(() =>{}) // 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 "close": this.resetForm(this.dialogInfo.type); if(this.projectFormInfo.ref) { this.projectFormInfo.ref.resetFields(); this.projectFormInfo.ref.clearValidate(); } setTimeout(() => { this.dialogInfo.visible = false; }, 0); 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) { this.btnLoading = true; if (type === "addUser") { //添加用户绑定到用户组 api = this.nozzle.addUserToGroup; const data = {...this.userFormInfo.data, ...{platformCode:this.needHandleProjectId}}; params = data; } if (type === "addGroup") { //添加保存用户组 api = this.nozzle.userGroupAdd; const data = {...this.groupFormInfo.data, ...{platformCode:this.needHandleProjectId}}; params = { data: 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 }); this.btnLoading = false; }) .catch(e => { console.log(e); this.btnLoading = false; }); } }); break; } }, //关闭弹窗 handleClose() { this.dialogInfo.visible = false; }, handleUserClose() { this.userDialogInfo.visible = false; }, //表格checkbox选择事件 handleEvent(event, data) { switch (event) { //站点关联 case "isRelate": this.RelatedSiteTableInfo.selectList = data; break; //站点未关联 case "unRelate": this.UnRelateSiteTableInfo.selectList = data; break; //用户关联 case "isUserRelate": this.RelatedUserTableInfo.selectList = data; break; //用户未关联 case "unUserRelate": this.UnRelateUserTableInfo.selectList = data; break; } }, //重置表单 resetForm(type) { switch (type) { case "addUser": this.userFormInfo.data = { id: undefined, login: "", realName: "", userType: 0, orgId: undefined, groupId: undefined, groupName: "", roleId: undefined, mobile: "" }; break; case "addGroup": this.groupFormInfo.data = { id: undefined, groupName: "", description: "" }; break; case "update": case "create": this.projectFormInfo.data = { id: undefined, name: "", sysGroup: "", operator: "", realName: "", area: "", platformCode: "", status: undefined, startTime: "", endTime: "", onlineTime: "" }; 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.$store.dispatch("common/getAllPlatSite").then(()=>{}) } this.$message({ message: res.data.msg, type: res.data.code === 1 ? "success" : "error", showClose: true }); this.btnLoading = false; }) .catch(e => { console.log(e); this.btnLoading = false; }); }, //将空的children置为undefined,避免在没有下一级数据的情况下显示暂无数据 removeEmptyChild(arr) { arr.forEach(item => { if (!item.children || item.children.length < 1) { item.children = undefined; } else { this.removeEmptyChild(item.children); } }); return arr; }, //获取子组件传来的所选城市节点 currentAreaJwd(data) { this.currentCity = data.data; } } }; </script> <style lang="scss" scoped> .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-bottom: 0; overflow-y: auto; } } .table-title{ @include hl(30px,30px); color: #409EFF; text-align: center; font-size: 16px; margin-bottom: 10px; } .userDialog { /deep/ .el-form-item { .el-form-item__label { width: 120px; padding-right: 15px; } } } </style>