告警规则

This commit is contained in:
熊丽君
2020-12-09 08:54:01 +08:00
parent 311b128a26
commit caba87f9b1
4 changed files with 243 additions and 56 deletions

26
src/api/fault/warning.js Normal file
View File

@ -0,0 +1,26 @@
import request from "@/utils/request";
// 获取全部告警规则
export function select(params) {
return request({
url: "/system/warningRule/select",
params
});
}
// 获取全部告警类型
export function type(params) {
return request({
url: "/system/signal/fault/select",
params
});
}
// 保存信号量告警规则
export function update(data) {
return request({
url: "/system/warningRule/save",
method: "POST",
data
});
}

View File

@ -7,9 +7,10 @@ const getters = {
token: state => state.user.token, token: state => state.user.token,
avatar: state => state.user.avatar, avatar: state => state.user.avatar,
name: state => state.user.name, name: state => state.user.name,
userId: state => state.user.userId,
introduction: state => state.user.introduction, introduction: state => state.user.introduction,
roles: state => state.user.roles, roles: state => state.user.roles,
permissions: state => state.user.permissions, permissions: state => state.user.permissions,
permission_routes: state => state.permission.routes permission_routes: state => state.permission.routes
} };
export default getters export default getters;

View File

@ -1,96 +1,112 @@
import { login, logout, getInfo } from '@/api/login' import { login, logout, getInfo } from "@/api/login";
import { getToken, setToken, removeToken } from '@/utils/auth' import { getToken, setToken, removeToken } from "@/utils/auth";
const user = { const user = {
state: { state: {
token: getToken(), token: getToken(),
name: '', name: "",
avatar: '', userId: "",
avatar: "",
roles: [], roles: [],
permissions: [] permissions: []
}, },
mutations: { mutations: {
SET_TOKEN: (state, token) => { SET_TOKEN: (state, token) => {
state.token = token state.token = token;
}, },
SET_NAME: (state, name) => { SET_NAME: (state, name) => {
state.name = name state.name = name;
},
SET_USERID: (state, userId) => {
state.userId = userId;
}, },
SET_AVATAR: (state, avatar) => { SET_AVATAR: (state, avatar) => {
state.avatar = avatar state.avatar = avatar;
}, },
SET_ROLES: (state, roles) => { SET_ROLES: (state, roles) => {
state.roles = roles state.roles = roles;
}, },
SET_PERMISSIONS: (state, permissions) => { SET_PERMISSIONS: (state, permissions) => {
state.permissions = permissions state.permissions = permissions;
} }
}, },
actions: { actions: {
// 登录 // 登录
Login({ commit }, userInfo) { Login({ commit }, userInfo) {
const username = userInfo.username.trim() const username = userInfo.username.trim();
const password = userInfo.password const password = userInfo.password;
const code = userInfo.code const code = userInfo.code;
const uuid = userInfo.uuid const uuid = userInfo.uuid;
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
login(username, password, code, uuid).then(res => { login(username, password, code, uuid)
setToken(res.token) .then(res => {
commit('SET_TOKEN', res.token) setToken(res.token);
resolve() commit("SET_TOKEN", res.token);
}).catch(error => { resolve();
reject(error) })
}) .catch(error => {
}) reject(error);
});
});
}, },
// 获取用户信息 // 获取用户信息
GetInfo({ commit, state }) { GetInfo({ commit, state }) {
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
getInfo(state.token).then(res => { getInfo(state.token)
const user = res.user .then(res => {
const avatar = user.avatar == "" ? require("@/assets/image/profile.jpg") : process.env.VUE_APP_BASE_API + user.avatar; const user = res.user;
if (res.roles && res.roles.length > 0) { // 验证返回的roles是否是一个非空数组 const avatar =
commit('SET_ROLES', res.roles) user.avatar == ""
commit('SET_PERMISSIONS', res.permissions) ? require("@/assets/image/profile.jpg")
} else { : process.env.VUE_APP_BASE_API + user.avatar;
commit('SET_ROLES', ['ROLE_DEFAULT']) if (res.roles && res.roles.length > 0) {
} // 验证返回的roles是否是一个非空数组
commit('SET_NAME', user.userName) commit("SET_ROLES", res.roles);
commit('SET_AVATAR', avatar) commit("SET_PERMISSIONS", res.permissions);
resolve(res) } else {
}).catch(error => { commit("SET_ROLES", ["ROLE_DEFAULT"]);
reject(error) }
}) commit("SET_NAME", user.userName);
}) commit("SET_USERID", user.userId);
commit("SET_AVATAR", avatar);
resolve(res);
})
.catch(error => {
reject(error);
});
});
}, },
// 退出系统 // 退出系统
LogOut({ commit, state }) { LogOut({ commit, state }) {
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
logout(state.token).then(() => { logout(state.token)
commit('SET_TOKEN', '') .then(() => {
commit('SET_ROLES', []) commit("SET_TOKEN", "");
commit('SET_PERMISSIONS', []) commit("SET_ROLES", []);
removeToken() commit("SET_PERMISSIONS", []);
resolve() removeToken();
}).catch(error => { resolve();
reject(error) })
}) .catch(error => {
}) reject(error);
});
});
}, },
// 前端 登出 // 前端 登出
FedLogOut({ commit }) { FedLogOut({ commit }) {
return new Promise(resolve => { return new Promise(resolve => {
commit('SET_TOKEN', '') commit("SET_TOKEN", "");
removeToken() removeToken();
resolve() resolve();
}) });
} }
} }
} };
export default user export default user;

View File

@ -0,0 +1,144 @@
<template>
<section class="app-container">
<el-form v-loading="loading">
<el-form-item v-for="item1 in formTitle" :key="item1.id">
<section v-if="item1.signalCode">
<div class="tab">
{{ item1.signalName }}
</div>
<el-row :gutter="20">
<el-col :span="6" v-for="item2 in formList" :key="item2.id">
<el-form-item
class="row"
:label="
item2.optValName
? item2.optValName
: (item2.optValName = item2.warningName)
"
label-width="200px"
v-if="item1.signalCode === item2.signalCode"
>
<el-select v-model="item2.signalLevel">
<el-option
v-for="item in signalLevelList"
:key="item.value"
:label="item.label"
:value="item.value"
>
</el-option>
</el-select>
</el-form-item>
</el-col>
</el-row>
</section>
<section v-else>
<div class="tab">
{{ item1.signalName }}
</div>
<el-row :gutter="20">
<el-col :span="6" v-for="item2 in otherList" :key="item2.id">
<el-form-item
class="row"
:label="
item2.optValName
? item2.optValName
: (item2.optValName = item2.warningName)
"
label-width="200px"
>
<el-select v-model="item2.signalLevel">
<el-option
v-for="item in signalLevelList"
:key="item.value"
:label="item.label"
:value="item.value"
>
</el-option>
</el-select>
</el-form-item>
</el-col>
</el-row>
</section>
</el-form-item>
<!-- 表单操作 -->
<el-form-item class="right">
<el-button type="primary" @click="submitForm">提交</el-button>
</el-form-item>
</el-form>
</section>
</template>
<script>
import { select, type, update } from "@/api/fault/warning";
export default {
name: "warning",
data() {
return {
formTitle: [],
formList: [],
value: "",
signalLevelList: [
{ label: "一级", value: "1" },
{ label: "二级", value: "2" },
{ label: "三级", value: "3" },
{ label: "四级", value: "4" }
],
loading: true
};
},
methods: {
// 获取 title 的类型
async getTitle() {
const { select: data } = await type();
this.formTitle = data;
const { select: res } = await select({
userId: this.$store.getters.userId
});
this.formList = res;
this.loading = false;
},
async submitForm() {
const array = JSON.parse(
JSON.stringify(this.formList).replace(/optValName/g, "warningName")
);
this.loading = true;
const { code } = await update({
userId: this.$store.getters.userId,
signalList: array
});
this.loading = false;
if (code !== 200) {
return this.$message.error("更新错误,请稍后重试");
}
this.$message.success("更新成功");
}
},
computed: {
otherList() {
let signalCodes = this.formTitle.map(v => v.signalCode).filter(v => !!v);
return this.formList.filter(v => {
return signalCodes.indexOf(v.signalCode) == -1;
});
}
},
watch: {},
created() {
this.getTitle();
}
};
</script>
<style lang="scss" scoped>
.app-container {
.tab {
font-weight: 700;
}
.row {
margin-bottom: 10px;
}
.right {
float: right;
}
.el-select {
width: 150px;
}
}
</style>