|
@@ -16,7 +16,7 @@
|
|
|
<div class="status1"><span class="icon"></span>API接口</div>
|
|
|
<div class="status2"><span class="icon"></span>数据读写</div>
|
|
|
</div>
|
|
|
- <Search @getSearchData="getSearchData" :isTitle="false" @clearSearchData="clearSearchData" />
|
|
|
+ <!-- <Search @getSearchData="getSearchData" :isTitle="false" @clearSearchData="clearSearchData" /> -->
|
|
|
</div>
|
|
|
<!--权限树-->
|
|
|
<!-- <div class="authority-content">
|
|
@@ -29,79 +29,12 @@
|
|
|
<div class="grid-content">
|
|
|
<div class="manageTitle">权限树</div>
|
|
|
<div class="contentTree">
|
|
|
- <el-tree ref="tree" :data="dataListTree" :props="defaultProps" node-key="AuthId" :filter-node-method="filterNode" highlight-current :default-expanded-keys="[currentKey]" @node-click="handleNodeClick">
|
|
|
+ <el-tree ref="tree" :data="dataListTree" :props="defaultProps" node-key="auth_id" :filter-node-method="filterNode" highlight-current :default-expanded-keys="[currentKey]" @node-click="handleNodeClick">
|
|
|
</el-tree>
|
|
|
</div>
|
|
|
</div>
|
|
|
</el-col>
|
|
|
<el-col :span="18" class="bodyPart">
|
|
|
- <!-- <div class="grid-contentTop">
|
|
|
- <div class="manageTitle">当前</div>
|
|
|
- <div class="content">
|
|
|
- <template v-if="currDataArr.length">
|
|
|
- <el-row>
|
|
|
- <el-col :span="6" v-for="(data, index) in currDataArr" :key="data.AuthId">
|
|
|
- <div class="account-left-content-teams">
|
|
|
- <div class="team">
|
|
|
- <div class="bg" :class="
|
|
|
- data.Type == 1 || data.Type == 0
|
|
|
- ? 'status1'
|
|
|
- : 'status2'
|
|
|
- "></div>
|
|
|
- <div class="list" :class="data.QueryTarget == 1 ? 'activeStatus' : ''">
|
|
|
- <div class="flex info">
|
|
|
- <div :title="data.AuthName" class="name">
|
|
|
- {{ data.AuthName }}
|
|
|
- </div>
|
|
|
- <div class="icon">
|
|
|
- <el-tooltip effect="dark" content="新增应用" placement="bottom">
|
|
|
- <span v-if="data.Type === 0" title="新增应用" @click="renderAdd()" class="cap cap-plus"></span>
|
|
|
- </el-tooltip>
|
|
|
- <el-tooltip effect="dark" content="修改应用" placement="bottom">
|
|
|
- <span v-if="data.Type === 1" title="修改应用" @click="renderEdit(data)" class="cap cap-edit"></span>
|
|
|
- </el-tooltip>
|
|
|
- <el-tooltip v-is="['authtree_btn_add_auth']" effect="dark" content="新增权限项" placement="bottom">
|
|
|
- <span v-if="data.Type === 2" title="新增权限项" @click="renderSub(data)" class="cap cap-sub"></span>
|
|
|
- </el-tooltip>
|
|
|
- <el-tooltip v-is="['authtree_btn_update_auth']" effect="dark" content="编辑权限项" placement="bottom">
|
|
|
- <span v-if="data.Type > 2" title="编辑权限项" @click="renderEdit(data)" class="cap cap-edit"></span>
|
|
|
- </el-tooltip>
|
|
|
- <el-tooltip v-is="['authtree_btn_add_auth']" effect="dark" content="新增权限项" placement="bottom">
|
|
|
- <span v-if="data.Type > 2" title="新增权限项" @click="renderSub(data)" class="cap cap-sub"></span>
|
|
|
- </el-tooltip>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- <div v-if="data.Type > 0" class="flex details">
|
|
|
- <div class="details-msg">
|
|
|
- 状态:<span :class="data.Status === 1 ? 'success' : 'error'">{{ data.Status === 1 ? "启用" : "禁用" }}</span>
|
|
|
- </div>
|
|
|
- <div v-is="['authtree_btn_state_swatch']" class="details-info">
|
|
|
- <el-switch v-model="data.flag" @change="renderChange(data, index)" active-color="#2D67E3">
|
|
|
- </el-switch>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- <div v-is="['authtree_btn_del_auth']">
|
|
|
- <div v-if="data.Type !== 0 && data.Type !== 2" @click.stop="onNodeClick(data)" class="info-close">
|
|
|
- <i class="icon el-icon-close" :class="
|
|
|
- data.Type === 1
|
|
|
- ? 'close1'
|
|
|
- : data.Type > 2
|
|
|
- ? 'close2'
|
|
|
- : ''
|
|
|
- "></i>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- </el-col>
|
|
|
- </el-row>
|
|
|
- </template>
|
|
|
- <template v-else>
|
|
|
- <NoData :imageWidth="180" :imageHeight="130" />
|
|
|
- </template>
|
|
|
- </div>
|
|
|
- </div> -->
|
|
|
<div class="grid-contentBottom">
|
|
|
<div class="capTitle flex">
|
|
|
<div class="manageTitle">下级权限</div>
|
|
@@ -112,42 +45,28 @@
|
|
|
<div class="content">
|
|
|
<template v-if="childrenData.length">
|
|
|
<el-row :gutter="24">
|
|
|
- <el-col :span="6" v-for="(data, index) in childrenData" :key="data.AuthId">
|
|
|
+ <el-col :span="6" v-for="data in childrenData" :key="data.auth_id">
|
|
|
<div @click.stop="childrenClick(data)" class="account-left-content-teams">
|
|
|
<div class="team">
|
|
|
- <div class="bg" :class="data.Type == 1 ? 'status0' : data.Type == 2 ? 'status1' : 'status2'"></div>
|
|
|
+ <div class="bg" :class="data.auth_type == 1 ? 'status0' : data.auth_type == 2 ? 'status1' : 'status2'"></div>
|
|
|
<div class="list" :class="data.QueryTarget == 1 ? 'activeStatus' : ''">
|
|
|
<div class="flex info">
|
|
|
- <div :title="data.AuthName" class="name">
|
|
|
- {{ data.AuthName }}
|
|
|
+ <div :title="data.auth_name" class="name">
|
|
|
+ {{ data.auth_name }}
|
|
|
</div>
|
|
|
- <div class="icon">
|
|
|
- <el-tooltip effect="dark" content="新增应用" placement="bottom">
|
|
|
- <span v-if="data.Type === 0" title="新增应用" @click="renderAdd()" class="cap cap-plus"></span>
|
|
|
- </el-tooltip>
|
|
|
+ <div v-if="data.auth_type > 0" class="icon">
|
|
|
<el-tooltip effect="dark" content="修改应用" placement="bottom">
|
|
|
- <span v-if="data.Type === 1" title="修改应用" @click="renderEdit(data)" class="cap cap-edit"></span>
|
|
|
- </el-tooltip>
|
|
|
- <!-- <el-tooltip v-is="['authtree_btn_add_auth']" effect="dark" content="新增权限项" placement="bottom">
|
|
|
- <span v-if="data.Type === 2" title="新增权限项" @click="renderSub(data)" class="cap cap-sub"></span>
|
|
|
- </el-tooltip> -->
|
|
|
- <el-tooltip v-is="['authtree_btn_add_auth']" effect="dark" content="编辑权限项" placement="bottom">
|
|
|
- <span v-if="data.Type === 2" title="编辑权限项" @click="renderEdit(data)" class="cap cap-edit"></span>
|
|
|
- </el-tooltip>
|
|
|
- <el-tooltip v-is="['authtree_btn_update_auth']" effect="dark" content="编辑权限项" placement="bottom">
|
|
|
- <span v-if="data.Type > 2" title="编辑权限项" @click="renderEdit(data)" class="cap cap-edit"></span>
|
|
|
+ <span title="修改应用" @click="renderEdit(data)" class="cap cap-edit"></span>
|
|
|
</el-tooltip>
|
|
|
- <!-- <el-tooltip v-is="['authtree_btn_add_auth']" effect="dark" content="新增权限项" placement="bottom">
|
|
|
- <span v-if="data.Type > 2" title="新增权限项" @click="renderSub(data)" class="cap cap-sub"></span>
|
|
|
- </el-tooltip> -->
|
|
|
</div>
|
|
|
</div>
|
|
|
- <div v-if="data.Type > 0" class="flex details">
|
|
|
+ <div v-if="data.auth_type > 0" class="flex details">
|
|
|
<div class="details-msg">
|
|
|
- 状态:<span :class="data.Status === 1 ? 'success' : 'error'">{{ data.Status === 1 ? "启用" : "禁用" }}</span>
|
|
|
+ 状态:<span :class="data.auth_status ? 'success' : 'error'">{{ data.auth_status ? "启用" : "禁用" }}</span>
|
|
|
</div>
|
|
|
- <div v-is="['authtree_btn_state_swatch']" class="details-info">
|
|
|
- <el-switch v-model="data.flag" @click.stop.native @change="renderChange(data, index)" active-color="#2D67E3">
|
|
|
+ <!-- v-is="['authtree_btn_state_swatch']" -->
|
|
|
+ <div class="details-info">
|
|
|
+ <el-switch v-model="data.auth_status" @click.stop.native @change="renderChange(data)" active-color="#2D67E3">
|
|
|
</el-switch>
|
|
|
</div>
|
|
|
</div>
|
|
@@ -156,12 +75,13 @@
|
|
|
<!-- <div v-if="data.Type !== 0 && data.Type !== 2" @click.stop="onNodeClick(data)" class="info-close">
|
|
|
<i class="icon el-icon-close" :class="data.Type === 1 ? 'close1' : data.Type > 2 ? 'close2' : ''"></i>
|
|
|
</div> -->
|
|
|
- <div v-is="['authtree_btn_del_auth']">
|
|
|
- <div v-if="data.Type !== 0 && data.Type !== 2" @click.stop="onNodeClick(data)" class="info-close">
|
|
|
+ <!-- v-is="['authtree_btn_del_auth']" -->
|
|
|
+ <div>
|
|
|
+ <div v-if="data.auth_type !== 0" @click.stop="onNodeClick(data)" class="info-close">
|
|
|
<i class="icon el-icon-close" :class="
|
|
|
- data.Type === 1
|
|
|
+ data.auth_type === 1
|
|
|
? 'close1'
|
|
|
- : data.Type > 2
|
|
|
+ : data.auth_type > 2
|
|
|
? 'close2'
|
|
|
: ''
|
|
|
"></i>
|
|
@@ -182,7 +102,7 @@
|
|
|
<!--删除弹框-->
|
|
|
<Dialog :flag="flag">
|
|
|
<div class="airportInfoDialog">
|
|
|
- <div class="title del-title">删除{{ title }}</div>
|
|
|
+ <div class="title del-title">删除权限</div>
|
|
|
<div class="content del-content">
|
|
|
<span class="el-icon-error error r10"></span>是否确认删除<span class="error l10">{{ title }}</span>?
|
|
|
</div>
|
|
@@ -198,42 +118,36 @@
|
|
|
<div class="title">{{ editDialogTitle }}</div>
|
|
|
<div class="content">
|
|
|
<el-form ref="ruleForm" :model="ruleForm" :rules="rules" label-width="110px" class="demo-ruleForm">
|
|
|
- <el-form-item label="权限名称" prop="authName">
|
|
|
- <el-input v-model="ruleForm.authName" size="medium" placeholder="请输入权限名称" />
|
|
|
+ <el-form-item label="权限名称" prop="auth_name">
|
|
|
+ <el-input v-model="ruleForm.auth_name" size="medium" placeholder="请输入权限名称" />
|
|
|
</el-form-item>
|
|
|
<div class="flex">
|
|
|
- <el-form-item label="权限类型" prop="authType">
|
|
|
- <el-select size="medium" v-model="ruleForm.authType" placeholder="请选择">
|
|
|
- <el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value">
|
|
|
+ <el-form-item label="权限类型" prop="auth_type">
|
|
|
+ <el-select size="medium" v-model="ruleForm.auth_type" placeholder="请选择">
|
|
|
+ <el-option v-for="(item,index) in optionsType" :key="index" :label="item.label" :value="item.value">
|
|
|
</el-option>
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
<el-form-item label="父级权限" prop="authParent">
|
|
|
- <el-select size="medium" v-model="ruleForm.authParent" placeholder="请选择">
|
|
|
- <el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value">
|
|
|
+ <el-select size="medium" v-model="ruleForm.auth_id" placeholder="请选择">
|
|
|
+ <el-option v-for="(item,index) in optionsParent" :key="index" :label="item.label" :value="item.value">
|
|
|
</el-option>
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
</div>
|
|
|
- <div class="flex">
|
|
|
- <el-form-item label="数据来源类型" prop="authData">
|
|
|
- <el-select size="medium" v-model="ruleForm.authData" placeholder="请选择">
|
|
|
- <el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value">
|
|
|
- </el-option>
|
|
|
- </el-select>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item label="所属应用" prop="authApp">
|
|
|
- <el-select size="medium" v-model="ruleForm.authApp" placeholder="请选择">
|
|
|
- <el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value">
|
|
|
+ <div class="flex-wrap">
|
|
|
+ <el-form-item class="flex1" label="所属应用" prop="app_name">
|
|
|
+ <el-select style="display:block;" size="medium" v-model="ruleForm.app_name" placeholder="请选择">
|
|
|
+ <el-option v-for="(item,index) in optionsApp" :key="index" :label="item.label" :value="item.value">
|
|
|
</el-option>
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
</div>
|
|
|
- <el-form-item label="权限标识符" prop="authPoint">
|
|
|
- <el-input v-model="ruleForm.authPoint" size="medium" type="textarea" :rows="3" placeholder="请输入权限标识符" />
|
|
|
+ <el-form-item label="权限标识符" prop="auth_ident">
|
|
|
+ <el-input v-model="ruleForm.auth_ident" size="medium" type="textarea" :rows="3" placeholder="请输入权限标识符" />
|
|
|
</el-form-item>
|
|
|
- <el-form-item label="数据项描述" prop="authDesc">
|
|
|
- <el-input v-model="ruleForm.authDesc" size="medium" type="textarea" :rows="3" placeholder="请输入数据项描述" />
|
|
|
+ <el-form-item label="数据项描述" prop="auth_comment">
|
|
|
+ <el-input v-model="ruleForm.auth_comment" size="medium" type="textarea" :rows="3" placeholder="请输入数据项描述" />
|
|
|
</el-form-item>
|
|
|
</el-form>
|
|
|
</div>
|
|
@@ -257,6 +171,7 @@ import {
|
|
|
DeleteApp,
|
|
|
DeleteAuth,
|
|
|
} from "@/api/apiAuthority";
|
|
|
+import { GeneralDataReception } from '@/api/dataIntegration'
|
|
|
import treeData from "../minixs/treeData";
|
|
|
export default {
|
|
|
name: "Authority",
|
|
@@ -271,7 +186,7 @@ export default {
|
|
|
title: "", //弹框title
|
|
|
flag: false, //弹框开关
|
|
|
dataId: null, //tree数据id
|
|
|
- currData:null,
|
|
|
+ currData: null,
|
|
|
currDataArr: [],
|
|
|
currDataArrId: 0,
|
|
|
childrenData: [],
|
|
@@ -279,28 +194,47 @@ export default {
|
|
|
currentKey: -1,
|
|
|
defaultProps: {
|
|
|
children: "children",
|
|
|
- label: "AuthName",
|
|
|
+ label: "auth_name",
|
|
|
},
|
|
|
options: [],
|
|
|
editDialogVisible: false,
|
|
|
editDialogTitle: '新增下级权限',
|
|
|
editType: 'add',
|
|
|
+ delObj: {},
|
|
|
ruleForm: {
|
|
|
// 协议信息表单
|
|
|
- authName: "",
|
|
|
- authType: "",
|
|
|
- authDesc: "",
|
|
|
- authPoint: "",
|
|
|
- authApp: "",
|
|
|
- authParent: "",
|
|
|
- authData: ""
|
|
|
+ auth_name: "",
|
|
|
+ auth_type: "",
|
|
|
+ auth_comment: "",
|
|
|
+ app_name: "",
|
|
|
+ auth_ident: "",
|
|
|
+ auth_type: "",
|
|
|
+ app_name: "",
|
|
|
+ app_id: "",
|
|
|
+ auth_status: true
|
|
|
},
|
|
|
rules: {
|
|
|
// 协议信息表单验证
|
|
|
- authName: [
|
|
|
+ auth_name: [
|
|
|
{ required: true, message: "请输入权限名称", trigger: "blur" },
|
|
|
],
|
|
|
},
|
|
|
+ optionsType: [
|
|
|
+ {
|
|
|
+ label: '前端权限',
|
|
|
+ value: 1
|
|
|
+ },
|
|
|
+ {
|
|
|
+ label: 'API权限',
|
|
|
+ value: 2
|
|
|
+ },
|
|
|
+ {
|
|
|
+ label: '数据权限',
|
|
|
+ value: 3
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ optionsApp: [],
|
|
|
+ optionsParent: []
|
|
|
};
|
|
|
},
|
|
|
created: function () {
|
|
@@ -322,17 +256,42 @@ export default {
|
|
|
methods: {
|
|
|
// 新增
|
|
|
addAuth () {
|
|
|
- // this.editDialogTitle = '新增下级权限'
|
|
|
- // this.editDialogVisible = true
|
|
|
- // this.editType = 'add'
|
|
|
- this.$router.push({
|
|
|
- path: "/authority/addPower",
|
|
|
- query: {
|
|
|
- AuthId: this.currData.AuthId,
|
|
|
- Status: this.currData.Status,
|
|
|
- UpAuthId: this.currData.UpAuthId,
|
|
|
- },
|
|
|
- });
|
|
|
+ if (!this.currData) {
|
|
|
+ this.$message.error('请选择权限后再操作')
|
|
|
+ return false
|
|
|
+ }
|
|
|
+ this.ruleForm = {}
|
|
|
+ this.optionsApp = []
|
|
|
+ this.optionsParent = []
|
|
|
+ this.editDialogTitle = '新增下级权限'
|
|
|
+ this.editDialogVisible = true
|
|
|
+ this.editType = 'add'
|
|
|
+ this.optionsApp.push({
|
|
|
+ label: this.currData.app_name,
|
|
|
+ value: this.currData.app_id
|
|
|
+ })
|
|
|
+ this.optionsParent.push({
|
|
|
+ label: this.currData.auth_name,
|
|
|
+ value: this.currData.auth_id
|
|
|
+ })
|
|
|
+ },
|
|
|
+ //增删改
|
|
|
+ async changeAuth (obj, type) {
|
|
|
+ const { code, message } = await GeneralDataReception({
|
|
|
+ serviceId: SERVICE_ID.authScId,
|
|
|
+ dataContent: JSON.stringify(obj)
|
|
|
+ })
|
|
|
+ if (code == 0) {
|
|
|
+ this.$message.success(message)
|
|
|
+ this.getAuthTree()
|
|
|
+ } else {
|
|
|
+ this.$message.error(message)
|
|
|
+ }
|
|
|
+ if (type == 'form') {
|
|
|
+ this.resetForm('ruleForm')
|
|
|
+ } else if (type == 'del') {
|
|
|
+ this.flag = false
|
|
|
+ }
|
|
|
},
|
|
|
// 重置
|
|
|
resetForm (formName) {
|
|
@@ -344,9 +303,18 @@ export default {
|
|
|
this.$refs["ruleForm"].validate((valid) => {
|
|
|
if (valid) {
|
|
|
if (this.editType == 'add') {
|
|
|
- // console.log('新增')
|
|
|
+ this.ruleForm.app_id = this.ruleForm.app_name
|
|
|
+ this.ruleForm.app_name = this.currData.app_name
|
|
|
+ this.ruleForm.auth_status = true
|
|
|
+ this.ruleForm.event = 1
|
|
|
+ if (this.ruleForm.auth_id) {
|
|
|
+ this.ruleForm.up_auth_id = this.ruleForm.auth_id
|
|
|
+ delete this.ruleForm.auth_id
|
|
|
+ }
|
|
|
+ this.changeAuth(this.ruleForm, 'form')
|
|
|
} else {
|
|
|
- // console.log('编辑')
|
|
|
+ this.ruleForm.event = 2
|
|
|
+ this.changeAuth(this.ruleForm, 'form')
|
|
|
}
|
|
|
} else {
|
|
|
return false
|
|
@@ -355,39 +323,39 @@ export default {
|
|
|
},
|
|
|
//树点击
|
|
|
handleNodeClick (data) {
|
|
|
+ console.log(data)
|
|
|
const dataNew = _.cloneDeep(data);
|
|
|
this.currData = dataNew;
|
|
|
- this.currDataArrId = dataNew.AuthId;
|
|
|
+ this.currDataArrId = dataNew.auth_id;
|
|
|
this.currDataArr = [];
|
|
|
this.childrenData = [];
|
|
|
- this.currDataArr = this.decompose(this.dataArr, "AuthId", dataNew.AuthId);
|
|
|
+ this.currDataArr = this.decompose(this.dataArr, "auth_id", dataNew.auth_id);
|
|
|
this.childrenData = this.decompose(
|
|
|
this.dataArr,
|
|
|
- "UpAuthId",
|
|
|
- dataNew.AuthId
|
|
|
+ "up_auth_id",
|
|
|
+ dataNew.auth_id
|
|
|
);
|
|
|
},
|
|
|
//下级卡片点击
|
|
|
childrenClick (data) {
|
|
|
const dataNew = _.cloneDeep(data);
|
|
|
this.currData = dataNew;
|
|
|
- this.currDataArrId = dataNew.AuthId;
|
|
|
+ this.currDataArrId = dataNew.auth_id;
|
|
|
this.currDataArr = [];
|
|
|
this.childrenData = [];
|
|
|
- this.currDataArr = this.decompose(this.dataArr, "AuthId", dataNew.AuthId);
|
|
|
+ this.currDataArr = this.decompose(this.dataArr, "auth_id", dataNew.auth_id);
|
|
|
this.childrenData = this.decompose(
|
|
|
this.dataArr,
|
|
|
- "UpAuthId",
|
|
|
- dataNew.AuthId
|
|
|
+ "up_auth_id",
|
|
|
+ dataNew.auth_id
|
|
|
);
|
|
|
- this.$refs.tree.setCurrentKey(dataNew.AuthId);
|
|
|
- this.currentKey = dataNew.AuthId;
|
|
|
+ console.log(this.childrenData);
|
|
|
+ this.$refs.tree.setCurrentKey(dataNew.auth_id);
|
|
|
+ this.currentKey = dataNew.auth_id;
|
|
|
},
|
|
|
//下级关闭
|
|
|
- childrenRenderChange (data, index) {
|
|
|
+ childrenRenderChange (data) {
|
|
|
try {
|
|
|
- const { OrganId, flag } = data;
|
|
|
- const Status = flag ? 1 : 0;
|
|
|
tissueTreeStart({
|
|
|
OrganId: OrganId,
|
|
|
Status: Status,
|
|
@@ -416,53 +384,42 @@ export default {
|
|
|
},
|
|
|
// 修改权限
|
|
|
renderEdit (data) {
|
|
|
- // this.editDialogVisible = true;
|
|
|
- // this.editDialogTitle = '编辑下级权限';
|
|
|
- // this.editType = 'edit';
|
|
|
- if (data.Type === 1) {
|
|
|
- this.$router.push({
|
|
|
- path: "/authority/appEdit",
|
|
|
- query: {
|
|
|
- AuthId: data.AuthId,
|
|
|
- Status: data.Status,
|
|
|
- UpAuthId: data.UpAuthId,
|
|
|
- },
|
|
|
- });
|
|
|
- } else if (data.Type > 2) {
|
|
|
- this.$router.push({
|
|
|
- path: "/authority/editPower",
|
|
|
- query: {
|
|
|
- AuthId: data.AuthId,
|
|
|
- Status: data.Status,
|
|
|
- UpAuthId: data.UpAuthId,
|
|
|
- },
|
|
|
- });
|
|
|
- }
|
|
|
+ this.optionsApp = []
|
|
|
+ this.optionsParent = []
|
|
|
+ this.editDialogVisible = true;
|
|
|
+ this.editDialogTitle = '编辑下级权限';
|
|
|
+ this.editType = 'edit';
|
|
|
+ this.ruleForm = data;
|
|
|
+ this.optionsApp.push({
|
|
|
+ label: data.app_name,
|
|
|
+ value: data.app_id
|
|
|
+ })
|
|
|
+ this.optionsParent.push({
|
|
|
+ label: this.currData.auth_name,
|
|
|
+ value: data.auth_id
|
|
|
+ })
|
|
|
},
|
|
|
// 权限树
|
|
|
renderSub (data) {
|
|
|
this.$router.push({
|
|
|
path: "/authority/addPower",
|
|
|
query: {
|
|
|
- AuthId: data.AuthId,
|
|
|
- Status: data.Status,
|
|
|
- UpAuthId: data.UpAuthId,
|
|
|
+ AuthId: data.auth_id,
|
|
|
+ Status: data.auth_status,
|
|
|
+ UpAuthId: data.up_auth_id,
|
|
|
},
|
|
|
});
|
|
|
},
|
|
|
// 关闭开启
|
|
|
- renderChange (data, index) {
|
|
|
- const { AuthId, flag, Type } = data;
|
|
|
- const Status = flag ? 1 : 0;
|
|
|
- this.handleChange(AuthId, Status, Type, index);
|
|
|
+ renderChange (data) {
|
|
|
+ data.event = 2;
|
|
|
+ this.changeAuth(data);
|
|
|
},
|
|
|
//删除
|
|
|
remove () {
|
|
|
- if (this.type === 1) {
|
|
|
- this.deleteApp(this.dataId);
|
|
|
- } else {
|
|
|
- this.deleteAuth(this.dataId);
|
|
|
- }
|
|
|
+ this.delObj.event = 3
|
|
|
+ this.changeAuth(this.delObj, 'del')
|
|
|
+ this.childrenClick(this.delObj)
|
|
|
},
|
|
|
//查询
|
|
|
getSearchData (val) {
|
|
@@ -476,9 +433,8 @@ export default {
|
|
|
//节点关闭按钮点击
|
|
|
onNodeClick (data) {
|
|
|
this.flag = true;
|
|
|
- this.dataId = data.AuthId;
|
|
|
- this.title = data.AuthName;
|
|
|
- this.type = data.Type;
|
|
|
+ this.title = data.auth_name;
|
|
|
+ this.delObj = data;
|
|
|
},
|
|
|
//获取指定数据
|
|
|
decompose (value, key, id) {
|
|
@@ -491,79 +447,9 @@ export default {
|
|
|
}
|
|
|
return arr;
|
|
|
},
|
|
|
- //渲染节点
|
|
|
- renderContent (h, data) {
|
|
|
- return (
|
|
|
- <div class="account-left-content-teams">
|
|
|
- <div class="team">
|
|
|
- <div class={[data.Type <= 1 ? "status1" : "status2", "bg"]}></div>
|
|
|
- <div class={[data.QueryTarget == 1 ? "activeStatus" : "", "list"]}>
|
|
|
- <div class="flex info">
|
|
|
- <div class="name">{data.AuthName}</div>
|
|
|
- <div class="icon">
|
|
|
- <span
|
|
|
- v-show={data.Type === 0}
|
|
|
- onClick={() => this.renderAdd()}
|
|
|
- class="cap cap-plus"
|
|
|
- ></span>
|
|
|
- <span
|
|
|
- v-show={data.Type === 1}
|
|
|
- onClick={() => this.renderEdit(data)}
|
|
|
- class="cap cap-edit"
|
|
|
- ></span>
|
|
|
- <span
|
|
|
- v-show={data.Type === 2}
|
|
|
- onClick={() => this.renderSub(data)}
|
|
|
- class="cap cap-sub"
|
|
|
- ></span>
|
|
|
- <span
|
|
|
- v-show={data.Type > 2}
|
|
|
- onClick={() => this.renderEdit(data)}
|
|
|
- class="cap cap-edit"
|
|
|
- ></span>
|
|
|
- <span
|
|
|
- v-show={data.Type > 2}
|
|
|
- onClick={() => this.renderSub(data)}
|
|
|
- class="cap cap-sub"
|
|
|
- ></span>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- <div v-show={data.Type > 0} class="flex details">
|
|
|
- <div class="details-msg">
|
|
|
- 状态:
|
|
|
- <span class={[data.Status === 1 ? "success" : "error"]}>
|
|
|
- {data.Status === 1 ? "启用" : "禁用"}
|
|
|
- </span>
|
|
|
- </div>
|
|
|
- <div class="details-info">
|
|
|
- <el-switch
|
|
|
- v-model={data.flag}
|
|
|
- onChange={() => this.renderChange(data)}
|
|
|
- active-color="#6F81BC"
|
|
|
- ></el-switch>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- <div
|
|
|
- v-show={data.Type !== 0 && data.Type !== 2}
|
|
|
- onClick={() => this.onNodeClick(data)}
|
|
|
- class="info-close"
|
|
|
- >
|
|
|
- <i
|
|
|
- class={[
|
|
|
- data.Type === 1 ? "close1" : data.Type > 2 ? "close2" : "",
|
|
|
- "icon",
|
|
|
- "el-icon-close",
|
|
|
- ]}
|
|
|
- ></i>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- );
|
|
|
- },
|
|
|
//-----------获取数据------------
|
|
|
//应用状态变更
|
|
|
- async handleChange (id, val, type, index) {
|
|
|
+ async handleChange (data) {
|
|
|
try {
|
|
|
let res = null;
|
|
|
if (type === 1) {
|