安全隐患整改审批流程处理
parent
411a84e564
commit
9a41479bec
|
@ -274,6 +274,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
|||
a.smark_url,
|
||||
a.isDel,
|
||||
CONCAT(c.nick_name,'【',c.phonenumber,'】') as createUser,
|
||||
a.createUser as updateUser,
|
||||
a.createTime,
|
||||
a.updateUser,
|
||||
a.updateTime,
|
||||
|
|
|
@ -114,7 +114,6 @@ function initMap(opt) {
|
|||
// 将地址解析结果显示在地图上,并调整地图视野
|
||||
myGeo.getPoint('经河新城', function (point) {
|
||||
if (point) {
|
||||
console.log("--->",point)
|
||||
map.value.centerAndZoom(point, 16);
|
||||
map.value.addOverlay(new BMapGL.Marker(point, { title: '经河新城' }))
|
||||
map.value.enableScrollWheelZoom(true);
|
||||
|
@ -151,6 +150,7 @@ defineExpose({
|
|||
.el-dialog__body {
|
||||
position: relative;
|
||||
padding: 0px;
|
||||
|
||||
.div-info {
|
||||
position: absolute;
|
||||
top: 0px;
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
<template>
|
||||
<div class="navbar">
|
||||
<hamburger id="hamburger-container" :is-active="appStore.sidebar.opened" class="hamburger-container" @toggleClick="toggleSideBar" />
|
||||
<hamburger id="hamburger-container" :is-active="appStore.sidebar.opened" class="hamburger-container"
|
||||
@toggleClick="toggleSideBar" />
|
||||
<breadcrumb id="breadcrumb-container" class="breadcrumb-container" v-if="!settingsStore.topNav" />
|
||||
<top-nav id="topmenu-container" class="topmenu-container" v-if="settingsStore.topNav" />
|
||||
|
||||
|
@ -96,7 +97,6 @@ function setLayout() {
|
|||
emits('setLayout');
|
||||
}
|
||||
data.comName = userStore.currentComName
|
||||
console.log("---->",userStore)
|
||||
</script>
|
||||
|
||||
<style lang='scss' scoped>
|
||||
|
@ -113,6 +113,7 @@ console.log("---->",userStore)
|
|||
height: 32px;
|
||||
line-height: 32px;
|
||||
}
|
||||
|
||||
.hamburger-container {
|
||||
line-height: 46px;
|
||||
height: 100%;
|
||||
|
|
|
@ -1,17 +1,15 @@
|
|||
import { login, logout, getInfo } from '@/api/login'
|
||||
import { findMyTasks } from '@/api/flowable/businessKey'
|
||||
import { getToken, setToken, removeToken } from '@/utils/auth'
|
||||
import defAva from '@/assets/images/profile.jpg'
|
||||
import { login, logout, getInfo } from "@/api/login";
|
||||
import { findMyTasks } from "@/api/flowable/businessKey";
|
||||
import { getToken, setToken, removeToken } from "@/utils/auth";
|
||||
import defAva from "@/assets/images/profile.jpg";
|
||||
|
||||
const useUserStore = defineStore(
|
||||
'user',
|
||||
{
|
||||
const useUserStore = defineStore("user", {
|
||||
state: () => ({
|
||||
token: getToken(),
|
||||
uid: '',
|
||||
name: '',
|
||||
nickName: '',
|
||||
avatar: '',
|
||||
uid: "",
|
||||
name: "",
|
||||
nickName: "",
|
||||
avatar: "",
|
||||
compInfo: {},
|
||||
roles: [],
|
||||
permissions: [],
|
||||
|
@ -19,37 +17,43 @@ const useUserStore = defineStore(
|
|||
currentComName: null,
|
||||
currentPrjId: null,
|
||||
currentProName: null,
|
||||
isAdmin: false,
|
||||
}),
|
||||
actions: {
|
||||
// 登录
|
||||
login(userInfo) {
|
||||
const username = userInfo.username.trim()
|
||||
const password = userInfo.password
|
||||
const code = userInfo.code
|
||||
const uuid = userInfo.uuid
|
||||
const username = userInfo.username.trim();
|
||||
const password = userInfo.password;
|
||||
const code = userInfo.code;
|
||||
const uuid = userInfo.uuid;
|
||||
return new Promise((resolve, reject) => {
|
||||
login(username, password, code, uuid).then(res => {
|
||||
let data = res.data
|
||||
setToken(data.access_token)
|
||||
this.token = data.access_token
|
||||
resolve()
|
||||
}).catch(error => {
|
||||
reject(error)
|
||||
})
|
||||
login(username, password, code, uuid)
|
||||
.then((res) => {
|
||||
let data = res.data;
|
||||
setToken(data.access_token);
|
||||
this.token = data.access_token;
|
||||
resolve();
|
||||
})
|
||||
.catch((error) => {
|
||||
reject(error);
|
||||
});
|
||||
});
|
||||
},
|
||||
// 获取用户信息
|
||||
getInfo() {
|
||||
return new Promise((resolve, reject) => {
|
||||
getInfo().then(res => {
|
||||
const user = res.user
|
||||
const avatar = (user.avatar == "" || user.avatar == null) ? defAva : user.avatar;
|
||||
getInfo()
|
||||
.then((res) => {
|
||||
const user = res.user;
|
||||
const avatar =
|
||||
user.avatar == "" || user.avatar == null ? defAva : user.avatar;
|
||||
|
||||
if (res.roles && res.roles.length > 0) { // 验证返回的roles是否是一个非空数组
|
||||
this.roles = res.roles
|
||||
this.permissions = res.permissions
|
||||
if (res.roles && res.roles.length > 0) {
|
||||
// 验证返回的roles是否是一个非空数组
|
||||
this.roles = res.roles;
|
||||
this.permissions = res.permissions;
|
||||
} else {
|
||||
this.roles = ['ROLE_DEFAULT']
|
||||
this.roles = ["ROLE_DEFAULT"];
|
||||
}
|
||||
this.uid = user.userId;
|
||||
this.name = user.userName;
|
||||
|
@ -60,20 +64,27 @@ const useUserStore = defineStore(
|
|||
this.currentComName = user.activeComName;
|
||||
this.currentPrjId = user.activeProjectId;
|
||||
this.currentProName = user.activeProjectName;
|
||||
resolve(res)
|
||||
}).catch(error => {
|
||||
reject(error)
|
||||
})
|
||||
this.isAdmin = user.roles.some(
|
||||
(item) =>
|
||||
item.roleKey.includes("admin") ||
|
||||
item.roleKey.includes("gsAdmin")
|
||||
);
|
||||
resolve(res);
|
||||
})
|
||||
.catch((error) => {
|
||||
reject(error);
|
||||
});
|
||||
});
|
||||
},
|
||||
// 获取用户代办
|
||||
getTasks() {
|
||||
return new Promise((resolve, reject) => {
|
||||
findMyTasks().then(response => {
|
||||
findMyTasks()
|
||||
.then((response) => {
|
||||
let todos = document.querySelectorAll(".tips_Todo");
|
||||
let tasks = document.querySelectorAll(".tips_Task");
|
||||
if (todos.length > 0) {
|
||||
todos.forEach(el => {
|
||||
todos.forEach((el) => {
|
||||
el.innerHTML = response.data.todo;
|
||||
if (response.data.todo > 0) {
|
||||
el.style.display = "inline";
|
||||
|
@ -83,7 +94,7 @@ const useUserStore = defineStore(
|
|||
});
|
||||
}
|
||||
if (tasks.length > 0) {
|
||||
tasks.forEach(el => {
|
||||
tasks.forEach((el) => {
|
||||
el.innerHTML = response.data.todo;
|
||||
if (response.data.todo > 0) {
|
||||
el.style.display = "inline";
|
||||
|
@ -92,27 +103,30 @@ const useUserStore = defineStore(
|
|||
}
|
||||
});
|
||||
}
|
||||
resolve(response)
|
||||
}).catch(error => {
|
||||
reject(error)
|
||||
})
|
||||
resolve(response);
|
||||
})
|
||||
.catch((error) => {
|
||||
reject(error);
|
||||
});
|
||||
});
|
||||
},
|
||||
// 退出系统
|
||||
logOut() {
|
||||
return new Promise((resolve, reject) => {
|
||||
logout(this.token).then(() => {
|
||||
this.token = ''
|
||||
this.roles = []
|
||||
this.permissions = []
|
||||
removeToken()
|
||||
resolve()
|
||||
}).catch(error => {
|
||||
reject(error)
|
||||
})
|
||||
})
|
||||
}
|
||||
}
|
||||
logout(this.token)
|
||||
.then(() => {
|
||||
this.token = "";
|
||||
this.roles = [];
|
||||
this.permissions = [];
|
||||
removeToken();
|
||||
resolve();
|
||||
})
|
||||
.catch((error) => {
|
||||
reject(error);
|
||||
});
|
||||
});
|
||||
},
|
||||
},
|
||||
});
|
||||
|
||||
export default useUserStore
|
||||
export default useUserStore;
|
||||
|
|
|
@ -6,10 +6,10 @@
|
|||
<el-steps style="max-width: 600px" :active="data.stepActive" finish-status="success" simple>
|
||||
<el-step title="待整改" />
|
||||
<el-step title="待复检" />
|
||||
<el-step title="复检驳回" />
|
||||
<el-step title="复检驳回" v-if="!data.simple" />
|
||||
<el-step title="复检通过" />
|
||||
</el-steps>
|
||||
|
||||
<div class="step-list">
|
||||
<div v-for="(it, idx) in data.auditinfoList" :key="idx">
|
||||
<div class="step-header" :class="data.row.checkState >= 0 ? 'is-active' : ''">
|
||||
<el-icon>
|
||||
|
@ -39,7 +39,8 @@
|
|||
</el-icon>整改图片</td>
|
||||
<td>
|
||||
<div class="step-img"><el-image :src="file.fileUrl"
|
||||
v-for="(file, index) in it.files" :key="index" :preview-teleported="true"
|
||||
v-for="(file, index) in it.files" :key="index"
|
||||
:preview-teleported="true"
|
||||
:preview-src-list="[file.fileUrl]"></el-image></div>
|
||||
</td>
|
||||
</tr>
|
||||
|
@ -72,13 +73,13 @@
|
|||
<Picture />
|
||||
</el-icon>隐患图片</td>
|
||||
<td>
|
||||
<el-image :src="data.row.smarkUrlPic" style="height:80px;" :preview-teleported="true"
|
||||
:preview-src-list="data.row.smarkUrlPics"></el-image>
|
||||
<el-image :src="data.row.smarkUrlPic" style="height:80px;"
|
||||
:preview-teleported="true" :preview-src-list="data.row.smarkUrlPics"></el-image>
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
</el-card>
|
||||
|
||||
</div>
|
||||
|
||||
</el-col>
|
||||
<el-col :span="14" class="detail-right" :class="'is-' + data.mode">
|
||||
|
@ -211,6 +212,7 @@
|
|||
<script setup name="Problemmodify">
|
||||
import useUserStore from '@/store/modules/user'
|
||||
import { listAuditinfo, addAuditinfo } from '@/api/trouble/auditinfo'
|
||||
import { fa } from 'element-plus/es/locales.mjs';
|
||||
const { proxy } = getCurrentInstance();
|
||||
const { ssp_proble_type, ssp_proble_sub_type } = proxy.useDict('ssp_proble_type', 'ssp_proble_sub_type');
|
||||
const formStep2Ref = ref();
|
||||
|
@ -218,6 +220,7 @@ const formStep3Ref = ref();
|
|||
const userStore = useUserStore()
|
||||
const emit = defineEmits(["success"]);
|
||||
let data = reactive({
|
||||
simple: false,
|
||||
mode: '',
|
||||
loading: false,
|
||||
visible: false,
|
||||
|
@ -264,6 +267,7 @@ function validateStep2Images(rule, value, callback) {
|
|||
function showDrawer(row, mode) {
|
||||
data.mode = mode;
|
||||
data.row = row;
|
||||
|
||||
step2Form.value.images = [];
|
||||
step2Form.value.opinion = "";
|
||||
step3Form.value.opinion = "";
|
||||
|
@ -288,6 +292,15 @@ function getListAuditinfo() {
|
|||
tmps[i].index = idx < 10 ? '0' + idx : idx;
|
||||
}
|
||||
data.auditinfoList = tmps;
|
||||
if (data.row.checkState == 3) {
|
||||
if (tmps.length == 2) {
|
||||
data.simple = true;
|
||||
data.stepActive = 3;
|
||||
} else {
|
||||
data.simple = false;
|
||||
data.stepActive = 4;
|
||||
}
|
||||
}
|
||||
})
|
||||
|
||||
}
|
||||
|
@ -394,6 +407,11 @@ defineExpose({
|
|||
}
|
||||
}
|
||||
|
||||
.step-list {
|
||||
overflow-y: auto;
|
||||
height: calc(100vh - 128px);
|
||||
}
|
||||
|
||||
.el-card__body {
|
||||
padding: 8px !important;
|
||||
}
|
||||
|
@ -427,7 +445,7 @@ defineExpose({
|
|||
|
||||
.step-img {
|
||||
.el-image {
|
||||
width: 95px;
|
||||
width: 90px;
|
||||
height: 80px;
|
||||
margin-left: 3px;
|
||||
}
|
||||
|
|
|
@ -180,6 +180,12 @@ function handleDetail(row) {
|
|||
detailDrawerRef.value.showDrawer(row, 'show');
|
||||
}
|
||||
function getIsVdel(row) {
|
||||
let isAdmin = userStore.isAdmin;
|
||||
if (isAdmin) {
|
||||
return true;
|
||||
} else if (row.updateUser == userStore.uid && row.checkState != 3) {
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
function getIsModify(row) {
|
||||
|
|
Loading…
Reference in New Issue