You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

990 lines
22 KiB

<template>
<view class="page">
<view class="top">
<view class="pure_top">
</view>
<view class="calendar">
<view class="date_year">
<view style="display: flex;">
<picker :value="dates.year" mode="date" fields="year" @change="dateYear($event)">
<view>{{dates.year}}</view>
</picker>
<img src="@/static/down.png" style="width: 30rpx;height: 30rpx; margin:10rpx 0 0 10rpx;" alt="">
</view>
<view style="margin: 0 10rpx;">|</view>
<view class="">
{{today.month}}.{{dates.day}}
</view>
</view>
<view class="monthbox">
<view :class="{month_color : item==dates.month,month_color2 : item>month}" class="month_class"
v-for="(item,key) in months" :key="key" @tap="dateMonth(item)">
<text>{{item}}</text>
</view>
</view>
</view>
</view>
<view class="taskbox">
<view class="itembox">
<view class="top">
<view class="left">
<img src="@/static/4412.png" alt="">
<view class="">
<text>任务总数</text><text>{{countStat.statistics1.num}}</text>
</view>
</view>
<view class="right">
<view v-if="countStat.statistics1.percentageComplete" style="margin-right: 10rpx;">完成率:</view>
<view class="">
<text v-if="countStat.statistics1.percentageComplete">{{countStat.statistics1.percentageComplete}}%</text>
<text v-else>暂无任务</text>
</view>
</view>
</view>
<view class="charts-box" style="display: flex;">
<img src="@/static/dadui/10.png" alt="">
<view v-if="identity" style="width: 50%;">
<qiun-data-charts type="ring" :opts="opts" :chartData="chartData" />
</view>
<view
style="width: 50%; display: flex;justify-content: center;align-items: center;flex-direction: column;">
<view class="tagbox" v-for="(item,key) in chartData.series[0].data" :key="key">
<view class="tag" :style="'background:'+opts.color[key]+';'">
</view>
<text>{{item.name}}-------{{item.value}}个</text>
</view>
</view>
</view>
<view class="itembox">
<view class="top">
<view class="left">
<img src="@/static/4412.png" alt="">
<view class="">
<text>救援站任务总数</text><text>{{countStat.statistics2.num}}</text>
</view>
</view>
<view class="right">
<view v-if="countStat.statistics2.percentageComplete" style="margin-right: 10rpx;">完成率:</view>
<view class="">
<text v-if="countStat.statistics2.percentageComplete">{{countStat.statistics2.percentageComplete}}%</text>
<text v-else>暂无任务</text>
</view>
</view>
</view>
<view class="charts-box" style="display: flex;">
<img src="@/static/dadui/10.png" alt="">
<view v-if="identity" style="width: 50%;">
<qiun-data-charts type="ring" :opts="opts2" :chartData="chartData2" />
</view>
<view
style="width: 50%; display: flex;justify-content: center;align-items: center;flex-direction: column;">
<view class="tagbox" v-for="(item,key) in chartData2.series[0].data" :key="key">
<view class="tag" :style="'background:'+opts.color[key]+';'">
</view>
<text>{{item.name}}-------{{item.value}}个</text>
</view>
</view>
</view>
<view class="itembox">
<view class="top">
<view class="left">
<img src="@/static/4412.png" alt="">
<view class="">
<text>检察员任务总数</text><text>{{countStat.statistics3.num}}</text>
</view>
</view>
<view class="right">
<view v-if="countStat.statistics3.percentageComplete" style="margin-right: 10rpx;">完成率:</view>
<view class="">
<text v-if="countStat.statistics3.percentageComplete">{{countStat.statistics3.percentageComplete}}%</text>
<text v-else>暂无任务</text>
</view>
</view>
</view>
<view class="charts-box" style="display: flex;">
<img src="@/static/dadui/10.png" alt="">
<view v-if="identity" style="width: 50%;">
<qiun-data-charts type="ring" :opts="opts3" :chartData="chartData3" />
</view>
<view
style="width: 50%; display: flex;justify-content: center;align-items: center;flex-direction: column;">
<view class="tagbox" v-for="(item,key) in chartData3.series[0].data" :key="key">
<view class="tag" :style="'background:'+opts.color[key]+';'">
</view>
<text>{{item.name}}-------{{item.value}}个</text>
</view>
</view>
</view>
</view>
</view>
<!-- <view class="listbox">
<view class="item" v-for="(item,key) in list" :key="key">
<view class="typebox">
<view
style="width: 12rpx; height: 34rpx; margin-top: 6rpx; background-color: #9D80FF; color: #9D80FF ;">
1
</view>
<view class="type">
{{item.taskType}}
</view>
</view>
<view class="namebox">
<view class="name">
{{item.company.companyName}}
</view>
<view style=" width: 30%; padding-left:20rpx;">
<view v-if="item.company.useNature=='重点单位'" class="tag" style="">
{{item.company.useNature}}
</view>
<view v-else class="tag2">
{{item.company.useNature}}
</view>
</view>
</view>
<view class="staffbox">
<view class="staff" style="flex: 1;">
<view>主负责人:</view>
<view class="zhu">{{item.organization.name}}</view>
</view>
<view class="jiancha">
待检查
</view>
</view>
<view style="display: flex;">
<view style="flex:1">
<view class="staffbox">
<view class="staff">
<view>协助人员:</view>
<view v-for="(i,k) in item.supervisors" :key="k"
style="display: flex;justify-content: center;align-items: center;">
<img v-if="i.posts && i.posts[0] == '主查人员'" src="@/static/447.png" alt="">
<img v-if="i.posts && i.posts[0] == '协查人员'" src="@/static/446.png" alt="">
{{i.name}}
</view>
</view>
</view>
<view class="staffbox">
<view class="staff">
<view>检查时间:</view>
<view>{{item.checkTime}}</view>
</view>
</view>
</view>
<view class="implement">
<view class="button" v-if="">
<button @tap="start(item)">执行</button>
</view>
<img src="@/static/zeren/4508.png" alt="">
</view>
</view>
</view> -->
</view>
</view>
<!-- <view class="login-box" v-if="!identity">
<view class="login-text">
登录平台,在线处理业务
</view>
<view class="login-button" >
<button @tap="login()">登录</button>
</view>
</view> -->
</view>
</template>
<script>
export default {
data() {
return {
title: 'Hello',
identity: 0,
progressNub: 60,
chartData: {
series: [{
data: [{
name: "上级指派",
value: 0
}, {
name: "自主任务",
value: 0
}, {
name: "申领任务",
value: 0
}, ]
}]
},
chartData2: {
series: [{
data: [{
name: "上级指派",
value: 0
}, {
name: "自主任务",
value: 0
}, {
name: "申领任务",
value: 0
}, ]
}]
},
chartData3: {
series: [{
data: [{
name: "上级指派",
value: 0
}, {
name: "自主任务",
value: 0
}, {
name: "申领任务",
value: 0
}, ]
}]
},
dates: {
year: 2022,
month: 8,
day: 0,
},
today: {
month: 8,
},
opts: {
rotate: false,
rotateLock: false,
color: ["#FACE15", "#04F1C9", "#3990F1"],
padding: [5, 5, 5, 5],
dataLabel: false,
legend: {
show: false,
fontColor: "#fff",
position: "right",
lineHeight: 20
},
title: {
name: "任务总数",
fontSize: 15,
color: "#fff"
},
subtitle: {
name: "0",
fontSize: 25,
color: "#fff"
},
extra: {
ring: {
width: 50,
height: 50,
ringWidth: 10,
activeOpacity: 0.5,
activeRadius: 10,
offsetAngle: 0,
labelWidth: 15,
border: false,
customRadius: 60,
borderWidth: 3,
borderColor: "#FFFFFF",
centerColor: "#57B5FF",
linearType: "none"
}
}
},
opts2: {
rotate: false,
rotateLock: false,
color: ["#FACE15", "#04F1C9", "#3990F1"],
padding: [5, 5, 5, 5],
dataLabel: false,
legend: {
show: false,
fontColor: "#fff",
position: "right",
lineHeight: 20
},
title: {
name: "任务总数",
fontSize: 15,
color: "#fff"
},
subtitle: {
name: "0",
fontSize: 25,
color: "#fff"
},
extra: {
ring: {
width: 50,
height: 50,
ringWidth: 10,
activeOpacity: 0.5,
activeRadius: 10,
offsetAngle: 0,
labelWidth: 15,
border: false,
customRadius: 60,
borderWidth: 3,
borderColor: "#FFFFFF",
centerColor: "#57B5FF",
linearType: "none"
}
}
},
opts3: {
rotate: false,
rotateLock: false,
color: ["#FACE15", "#04F1C9", "#3990F1"],
padding: [5, 5, 5, 5],
dataLabel: false,
legend: {
show: false,
fontColor: "#fff",
position: "right",
lineHeight: 20
},
title: {
name: "任务总数",
fontSize: 15,
color: "#fff"
},
subtitle: {
name: "0",
fontSize: 25,
color: "#fff"
},
extra: {
ring: {
width: 50,
height: 50,
ringWidth: 10,
activeOpacity: 0.5,
activeRadius: 10,
offsetAngle: 0,
labelWidth: 15,
border: false,
customRadius: 60,
borderWidth: 3,
borderColor: "#FFFFFF",
centerColor: "#57B5FF",
linearType: "none"
}
}
},
user: [{
tasknub: 0
}],
countStat: {
statistics1: {
num: 0,
percentageComplete: 0,
item1: 0,
item2: 0,
item3: 0
},
statistics2: {
num: 0,
percentageComplete: 0,
item1: 0,
item2: 0,
item3: 0
},
statistics3: {
num: 0,
percentageComplete: 0,
item1: 0,
item2: 0,
item3: 0
}
},
isSupervisor: false,
list: [],
month: 0,
nub: 0,
months: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]
}
},
created() {
let a = uni.getStorageSync("user");
let date = new Date()
this.dates.month = date.getMonth() + 1
this.today.month = date.getMonth() + 1
this.month = date.getMonth() + 1
this.dates.year = date.getFullYear()
this.dates.day = date.getDate()
this.getOrganizations()
this.getSupervisor()
this.getCountStat()
},
onReady() {
// this.getOrganizations()
},
methods: {
getOrganizations() {
const that = this
let selectedTime = this.dates.year + '-' + this.dates.month + '-' + '01'
let userId = uni.getStorageSync("user").id
let roles = uni.getStorageSync("user").roles
console.log(uni.getStorageSync("user"));
let isSupervisor = roles.find(item => {
return item.name.indexOf('检查') != -1
})
isSupervisor ? this.isSupervisor = true : this.isSupervisor = false
let params = {
ContainsChildren: true,
pageSize: 9999
}
this.$request.get("/api/Organizations", params, (data, res) => {
console.log(res);
if (!this.isSupervisor) {
this.user = res.items
for (let i = 0; i < this.user.length; i++) {
this.user[i]["tasknub"] = 0
this.user[i]["rate"] = 0
}
} else {
this.getSupervisor()
}
this.getTaskListOfStation(userId)
})
},
getSupervisor() {
this.$request.get("/api/Users/Inspectors", {}, (data, res) => {
this.list = []
let userOrganizationId = uni.getStorageSync("user").organizationId;
// console.log(uni.getStorageSync("user"),5500);
for (let i = 0; i < res.length; i++) {
if (res[i].organizationId = userOrganizationId) {
this.list.push(res[i])
}
}
console.log(this.list);
})
},
getTaskListOfStation(item) {
console.log(item);
const that = this
let OrganizationId = uni.getStorageSync("user").organizationId
let selectedTime = this.dates.year + '-' + this.dates.month + '-' + '01'
let params = {
Month: selectedTime,
SupervisorId: this.isSupervisor ? item : null,
AssitantOrganizationId: this.isSupervisor ? null : OrganizationId,
PageNumber: 1,
approvalStatuses: ['待检查', '已检查'],
PageSize: 9999
}
this.$request.get("/api/PlanTasks", params, (data, res) => {
console.log(res);
this.list = res.items
this.list["tasknub"] = 0
for (let e = 0; e < this.user.length; e++) {
for (let i = 0; i < that.list.length; i++) {
if (that.list[i].checkTime) {
let text = that.list[i].checkTime.substring(0, 10)
that.list[i].checkTime = text
}
if (that.list[i].inspectionResult != '待检查') {
this.user[e].tasknub += 1
}
}
}
console.log(this.list);
// this.getServerData();
this.getCountStat()
})
},
getCountStat(){
let selectedMonth = this.dates.month < 10 ? "0" + this.dates.month : this.dates.month;
let selectedTime = this.dates.year + '-' + this.dates.month + '-' + '01';
function integer(num) {
return Math.round(num * 100) || 0
}
let params= {
month: selectedTime
}
this.$request.get('/api/PlanTasks/GetCountStat',params,(data,res)=>{
console.log(res);
this.chartData= {
series: [{
data: [{
name: "上级指派",
value: res['任务总数']['上级指派']
}, {
name: "自主任务",
value: res['任务总数']['自主任务']
}, {
name: "申领任务",
value: res['任务总数']['申领任务']
}, ]
}]
}
this.chartData2= {
series: [{
data: [{
name: "上级指派",
value: res['消防救援任务总数']['上级指派']
}, {
name: "自主任务",
value: res['消防救援任务总数']['自主任务']
}, {
name: "申领任务",
value: res['消防救援任务总数']['申领任务']
}, ]
}]
}
this.chartData3= {
series: [{
data: [{
name: "上级指派",
value: res['检查员任务总数']['上级指派']
}, {
name: "自主任务",
value: res['检查员任务总数']['自主任务']
}, {
name: "申领任务",
value: res['检查员任务总数']['申领任务']
}, ]
}]
}
this.opts.subtitle.name=res['任务总数']['总数']||"0"
this.opts2.subtitle.name=res['消防救援任务总数']['总数']||"0"
this.opts3.subtitle.name=res['检查员任务总数']['总数']||"0"
this.countStat = {
statistics1: {
num: res['任务总数']['总数'], percentageComplete: integer(res['任务总数']['已完成'] / res['任务总数']['总数']), item1: integer(res['任务总数']['上级指派'] / res['任务总数']['总数']), item2: integer(res['任务总数']['自主任务'] / res['任务总数']['总数']), item3: integer(res['任务总数']['申领任务'] / res['任务总数']['总数'])
},
statistics2: {
num: res['消防救援任务总数']['总数'], percentageComplete: integer(res['消防救援任务总数']['已完成'] / res['消防救援任务总数']['总数']), item1: integer(res['消防救援任务总数']['上级指派'] / res['消防救援任务总数']['总数']), item2: integer(res['消防救援任务总数']['自主任务'] / res['消防救援任务总数']['总数']), item3: integer(res['消防救援任务总数']['申领任务'] / res['消防救援任务总数']['总数'])
},
statistics3: {
num: res['检查员任务总数']['总数'], percentageComplete: integer(res['检查员任务总数']['已完成'] / res['检查员任务总数']['总数']), item1: integer(res['检查员任务总数']['上级指派'] / res['检查员任务总数']['总数']), item2: integer(res['检查员任务总数']['自主任务'] / res['检查员任务总数']['总数']), item3: integer(res['检查员任务总数']['申领任务'] / res['检查员任务总数']['总数'])
}
}
this.identity = 1
// console.log(this.countStat);
})
},
getServerData() {
//模拟从服务器获取数据时的延时
this.nub = 0
this.chartData = {
series: [{
data: [{
name: "上级指派",
value: 0
}, {
name: "自主任务",
value: 0
}, {
name: "申领任务",
value: 0
}, ]
}]
}
for (let i = 0; i < this.list.length; i++) {
for (let e = 0; e < this.chartData.series[0].data.length; e++) {
if (this.chartData.series[0].data[e].name == this.list[i].creationType) {
this.chartData.series[0].data[e].value += 1
this.nub = this.nub + 1
this.opts.subtitle.name = JSON.stringify(this.nub)
}
}
}
},
dateYear(e) {
console.log(e);
this.dates.year = e.detail.value
this.getOrganizations()
},
dateMonth(e) {
if (e > this.month) {
return
}
this.dates.month = e
this.getOrganizations()
},
start(item) {
uni.navigateTo({
url: '/pages/task/details?id=' + item.company.id,
})
}
}
}
</script>
<style lang="scss">
.top {
position: relative;
top: 0;
left: 0;
}
.pure_top {
width: 100%;
height: 220rpx;
position: absolute;
z-index: 0;
overflow: hidden;
}
.pure_top::after {
content: "";
width: 100%;
height: 220rpx;
position: absolute;
left: 0;
top: 0;
z-index: -1;
border-radius: 0 0 100% 100%;
background: linear-gradient(180deg, #57B5FF 0%, #616DFD 100%);
}
.month_color {
border-radius: 48rpx;
background-color: #317AFF;
color: #fff;
}
.month_color2 {
color: #B5B5B5;
}
.calendar {
z-index: 1;
position: relative;
left: 74rpx;
top: 20rpx;
width: 80%;
height: 120rpx;
border-radius: 10rpx;
box-shadow: 0px 0px 20px 1px #C1D7FF;
background: #fff;
view {
height: 60rpx;
}
.date_year {
box-sizing: border-box;
display: flex;
background-color: #fff;
padding: 10rpx 0 0 10rpx;
}
.monthbox {
display: flex;
justify-content: center;
align-items: center;
flex-direction: row;
.month_class {
width: 48rpx;
height: 48rpx;
text-align: center;
}
}
}
// button {
// width: 140rpx;
// height: 70rpx;
// color: #fff;
// border-radius: 34rpx;
// line-height: 70rpx;
// font-size: 30rpx;
// background-color: #327AFE;
// }
.taskbox {
width: 90%;
margin: 40rpx auto;
border-radius: 20rpx;
background-color: #fff;
padding: 20rpx;
position: relative;
left: 0;
z-index: 10;
.itembox {
.top {
margin-top: 30rpx;
height: 60rpx;
display: flex;
.left {
display: flex;
flex: 1;
img {
width: 50rpx;
height: 50rpx;
}
text {
margin-right: 10rpx;
}
}
.right {
color: #909090;
display: flex;
.progress {
margin-top: 6rpx;
margin-right: 10rpx;
height: 34rpx;
flex: 1;
background: #E4E7EC;
.color {
height: 100%;
background-color: #14B389;
}
}
}
}
}
}
.charts-box {
// background-color: #5687fd;
height: 250rpx;
position: relative;
img {
width: 100%;
height: 100%;
position: absolute;
top: 0;
left: 0;
z-index: -1;
}
display: flex;
justify-content: center;
align-items: center;
.tagbox {
color: #FFFFFF;
display: flex;
justify-content: center;
align-items: center;
margin: 10rpx 0;
font-size: 32rpx;
.tag {
width: 20rpx;
height: 20rpx;
border-radius: 20rpx;
}
}
}
.logo {
height: 200rpx;
width: 200rpx;
margin-top: 200rpx;
margin-left: auto;
margin-right: auto;
margin-bottom: 50rpx;
}
.text-area {
display: flex;
justify-content: center;
}
.title {
font-size: 36rpx;
color: #8f8f94;
}
.login-box {
display: flex;
background: #8f8f94;
width: 100%;
height: 120rpx;
position: fixed;
bottom: 0;
left: 0;
.login-text {
color: #fff;
width: 60%;
display: flex;
font-size: 36rpx;
padding-left: 40rpx;
align-items: center;
}
.login-button {
flex: 1;
text-align: center;
margin-top: 20rpx;
}
}
.listbox {
width: 90%;
margin: -10rpx auto 0 auto;
.item {
background-color: #fff;
margin: 20rpx 0;
padding: 20rpx;
.namebox {
display: flex;
margin-bottom: 10rpx;
.name {
font-weight: 600;
font-size: 36rpx;
width: 70%;
height: 60rpx;
line-height: 60rpx;
}
.tag {
text-align: center;
width: 180rpx;
height: 60rpx;
line-height: 60rpx;
color: #FF6F51;
border: 1px solid #FF6F51;
background: rgba(255, 111, 81, 0.2400);
border-radius: 40rpx 40rpx 40rpx 40rpx;
}
.tag2 {
text-align: center;
width: 180rpx;
height: 60rpx;
line-height: 60rpx;
color: #14B488;
border: 1px solid rgba(30, 232, 177, 0.8);
background: rgba(30, 232, 177, 0.24);
border-radius: 40rpx 40rpx 40rpx 40rpx;
}
}
}
}
.typebox {
display: flex;
margin: 14rpx 0;
.type {
width: 50%;
// border-left: #327AFE 6rpx solid;
font-size: 32rpx;
font-weight: 600;
padding-left: 10rpx;
}
.result {
width: 50%;
text-align: right;
color: #FF6F51;
}
}
.staffbox {
display: flex;
margin: 6rpx 0;
font-size: 30rpx;
.staff {
display: flex;
color: rgba(16, 15, 25, 0.48);
.zhu {
color: #100F19;
}
view {
margin-right: 20rpx;
}
img {
width: 40rpx;
height: 40rpx;
min-width: 40rpx;
min-height: 40rpx;
}
}
.jiancha {
color: #FFBA19;
margin-right: 10rpx;
}
}
.implement {
margin-bottom: 10rpx;
.button {
width: 100%;
height: 100%;
padding-top: 20rpx;
}
img {
width: 100rpx;
height: 100rpx;
}
// button {
// float: right;
// width: 80rpx;
// height: 40rpx;
// line-height: 40rpx;
// margin-top: 20rpx;
// }
}
</style>