Browse Source

路由

master
jingbowen 2 years ago
parent
commit
86ab2671e4
  1. 27
      components/index/jiuyuanzhan.vue
  2. 115
      components/tabbar.vue
  3. 2
      config.js
  4. 98
      pages.json
  5. 2
      pages/dadui/index/index.vue
  6. 8
      pages/index/index.vue
  7. 726
      pages/rescue/index.vue
  8. 0
      pages/rescue/task_implement/details.vue
  9. 0
      pages/rescue/task_implement/implement.vue
  10. 853
      pages/rescue/taskapply.vue
  11. 887
      pages/rescue/taskreceive.vue
  12. 7
      pages/task/taskapply.vue
  13. 10
      pages/task/taskreceive.vue
  14. 15
      pages/user/user.vue
  15. 885
      pages/zhidui/index.vue
  16. 2
      unpackage/dist/dev/.sourcemap/mp-weixin/common/runtime.js.map
  17. 2
      unpackage/dist/dev/.sourcemap/mp-weixin/common/vendor.js.map
  18. 2
      unpackage/dist/dev/.sourcemap/mp-weixin/pages/dadui/index/index.js.map
  19. 2
      unpackage/dist/dev/.sourcemap/mp-weixin/pages/index/index.js.map
  20. 2
      unpackage/dist/dev/.sourcemap/mp-weixin/pages/task/details.js.map
  21. 2
      unpackage/dist/dev/.sourcemap/mp-weixin/pages/task/taskapply.js.map
  22. 2
      unpackage/dist/dev/.sourcemap/mp-weixin/pages/task/taskreceive.js.map
  23. 2
      unpackage/dist/dev/.sourcemap/mp-weixin/pages/user/changePassword/changePassword.js.map
  24. 2
      unpackage/dist/dev/.sourcemap/mp-weixin/pages/user/user.js.map
  25. 48
      unpackage/dist/dev/mp-weixin/app.json
  26. 2
      unpackage/dist/dev/mp-weixin/common/runtime.js
  27. 6
      unpackage/dist/dev/mp-weixin/common/vendor.js
  28. 2
      unpackage/dist/dev/mp-weixin/pages/index/index.js
  29. 6
      unpackage/dist/dev/mp-weixin/pages/index/index.json
  30. 1
      unpackage/dist/dev/mp-weixin/pages/task/details.js
  31. 2
      unpackage/dist/dev/mp-weixin/pages/task/taskapply.js
  32. 3
      unpackage/dist/dev/mp-weixin/pages/task/taskapply.json
  33. 2
      unpackage/dist/dev/mp-weixin/pages/task/taskapply.wxml
  34. 2
      unpackage/dist/dev/mp-weixin/pages/task/taskreceive.js
  35. 3
      unpackage/dist/dev/mp-weixin/pages/task/taskreceive.json
  36. 2
      unpackage/dist/dev/mp-weixin/pages/task/taskreceive.wxml
  37. 1
      unpackage/dist/dev/mp-weixin/pages/user/changePassword/changePassword.js
  38. 2
      unpackage/dist/dev/mp-weixin/pages/user/user.js
  39. 4
      unpackage/dist/dev/mp-weixin/pages/user/user.json
  40. 2
      unpackage/dist/dev/mp-weixin/pages/user/user.wxml
  41. 4
      unpackage/dist/dev/mp-weixin/project.config.json

27
components/index/jiuyuanzhan.vue

@ -10,7 +10,8 @@
<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="">
<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="">
@ -18,8 +19,8 @@
</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)">
<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>
@ -137,11 +138,18 @@
</view>
</view>
</view>
<tabbar :selected="0"></tabbar>
</view>
</template>
<script>
import tabbar from '../tabbar.vue'
export default {
components: {
tabbar
},
data() {
return {
title: 'Hello',
@ -211,11 +219,9 @@
}
}
},
user: [
{
user: [{
tasknub: 0
}
],
}],
isSupervisor: false,
list: [],
month: 0,
@ -232,9 +238,6 @@
this.dates.year = date.getFullYear()
this.dates.day = date.getDate()
this.getOrganizations()
},
onReady() {
@ -412,9 +415,11 @@
background-color: #317AFF;
color: #fff;
}
.month_color2 {
color: #B5B5B5;
}
.calendar {
z-index: 1;
position: relative;
@ -704,10 +709,12 @@
height: 100%;
padding-top: 20rpx;
}
img {
width: 100rpx;
height: 100rpx;
}
// button {
// float: right;
// width: 80rpx;

115
components/tabbar.vue

@ -0,0 +1,115 @@
<template>
<view class="tab-bar">
<view v-for="(item,index) in list" :key="index" class="tab-bar-item" @click="switchTab(item, index)">
<image class="tab_img" :src="selected === index ? item.selectedIconPath : item.iconPath"></image>
<view class="tab_text" :style="{color: selected === index ? selectedColor : color}">{{item.text}}</view>
</view>
</view>
</template>
<script>
export default {
name: "tabbar",
props: {
// 使:pagePath='pagePath',
pagePath: String,
selected: { // tab index
type: Number,
default: 0
},
},
data() {
return {
isSupervisor: false,
shenfen: '',
color: "#333333",
selectedColor: "#333333",
list: []
}
},
created() {
let roles = uni.getStorageSync("user").roles
let isSupervisor = roles.find(item => {
return item.name.indexOf('检查') != -1
})
isSupervisor ? this.isSupervisor = true : this.isSupervisor = false
this.shenfen = uni.getStorageSync("user").organizationLevel
},
mounted() {
//
if (this.shenfen == 'squadron' || (this.shenfen == 'battalion' && this.isSupervisor)) {
this.list = [{
"pagePath": "/pages/index/index",
"iconPath": "/static/tab/43251.png",
"selectedIconPath": "/static/tab/4325.png",
"text": "工作任务"
},
{
"pagePath": "/pages/task/taskapply",
"iconPath": "/static/tab/43281.png",
"selectedIconPath": "/static/tab/4328.png",
"text": "申请"
},
{
"pagePath": "/pages/task/taskreceive",
"iconPath": "/static/tab/43281.png",
"selectedIconPath": "/static/tab/4328.png",
"text": "领取"
},
{
"pagePath": "/pages/user/user",
"iconPath": "/static/tab/user.png",
"selectedIconPath": "/static/tab/user1.png",
"text": "我的"
}
]
}
},
methods: {
switchTab(item, index) {
console.log("item", item)
console.log("index", index)
let url = item.pagePath;
uni.switchTab({
url
})
}
}
}
</script>
<style lang="scss">
.tab-bar {
position: fixed;
bottom: 0;
left: 0;
right: 0;
height: 100rpx;
background: white;
display: flex;
justify-content: center;
align-items: center;
padding-bottom: env(safe-area-inset-bottom); // iphoneX
.tab-bar-item {
flex: 1;
text-align: center;
display: flex;
justify-content: center;
align-items: center;
flex-direction: column;
.tab_img {
width: 37rpx;
height: 41rpx;
}
.tab_text {
font-size: 20rpx;
margin-top: 9rpx;
}
}
}
</style>

2
config.js

@ -4,7 +4,7 @@ const domain = 'https://fx.anxincloud.cn';
const devApi = 'https://121.36.37.70:8204';
const devDomain = 'https://121.36.37.70:8204';
const online = true; //是否线上模式
const online = false; //是否线上模式
export default {
domain: online ? domain : devDomain,

98
pages.json

@ -10,34 +10,35 @@
}
},
{
"path": "pages/index/index",
"path": "pages/rescue/task_implement/implement",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#57B5FF",
"navigationBarBackgroundColor": "#317AFF",
"navigationBarTitleText": "消防一体化综合治理平台",
"navigationBarTextStyle": "white"
}
},
{
"path": "pages/user/user",
"path": "pages/changePassword/changePassword",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#317AFF",
"navigationBarTitleText": "",
"navigationBarTitleText": "消防一体化综合治理平台",
"navigationBarTextStyle": "white"
}
},
{
"path": "pages/task/taskreceive",
"path": "pages/demo/demo",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#57B5FF",
"navigationBarBackgroundColor": "#317AFF",
"navigationBarTitleText": "消防一体化综合治理平台",
"navigationBarTextStyle": "white"
}
},
{
"path": "pages/task/taskapply",
"path": "pages/rescue/task_implement/details",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#57B5FF",
@ -45,20 +46,17 @@
"navigationBarTextStyle": "white"
}
},
{
"path": "pages/demo/demo",
"path": "pages/task/taskreceive",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#317AFF",
"navigationBarBackgroundColor": "#57B5FF",
"navigationBarTitleText": "消防一体化综合治理平台",
"navigationBarTextStyle": "white"
}
},
{
"path": "pages/dadui/jiancha/jiancha",
"path": "pages/index/index",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#57B5FF",
@ -66,50 +64,44 @@
"navigationBarTextStyle": "white"
}
},
// {
// "path": "pages/dadui/index/index",
// "style": {
// "backgroundTextStyle": "light",
// "navigationBarBackgroundColor": "#57B5FF",
// "navigationBarTitleText": "消防一体化综合治理平台",
// "navigationBarTextStyle": "white"
// }
// },
{
"path": "pages/dadui/jiuyuan/jiuyuan",
"path": "pages/user/user",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#57B5FF",
"navigationBarTitleText": "消防一体化综合治理平台",
"navigationBarBackgroundColor": "#317AFF",
"navigationBarTitleText": "",
"navigationBarTextStyle": "white"
}
}
],
"subPackages":[
{
"root": "pages/changePassword",
"pages": [
},
{
"path": "changePassword",
"path": "pages/dadui/jiancha/jiancha",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#57B5FF",
"navigationBarTitleText": "消防一体化综合治理平台",
"navigationBarTextStyle": "white"
}
}
]
},
{
"root": "pages/task_jian",
"pages": [
{
"path": "implement",
"path": "pages/dadui/jiuyuan/jiuyuan",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#57B5FF",
"navigationBarTitleText": "消防一体化综合治理平台",
"navigationBarTextStyle": "white"
}
}
]
},
{
"root": "pages/task_jian",
"pages": [
{
"path": "details",
"path": "pages/task/taskapply",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#57B5FF",
@ -117,8 +109,6 @@
"navigationBarTextStyle": "white"
}
}
]
}
],
"globalStyle": {
"navigationBarTextStyle": "black",
@ -127,33 +117,33 @@
"backgroundColor": "#F8F8F8"
},
"tabBar": {
"custom": true,
"color": "#353535",
"selectedColor": "#5187FF",
"list": [{
"pagePath": "pages/index/index",
"iconPath": "static/tab/43251.png",
"selectedIconPath": "static/tab/4325.png",
"text": "工作任务"
"pagePath": "pages/index/index"
// "iconPath": "static/tab/43251.png",
// "selectedIconPath": "static/tab/4325.png",
// "text": "工作任务"
},
{
"pagePath": "pages/task/taskapply",
"iconPath": "static/tab/43281.png",
"selectedIconPath": "static/tab/4328.png",
"text": "申请"
"pagePath": "pages/task/taskapply"
// "iconPath": "static/tab/43281.png",
// "selectedIconPath": "static/tab/4328.png",
// "text": "申请"
},
{
"pagePath": "pages/task/taskreceive",
"iconPath": "static/tab/43281.png",
"selectedIconPath": "static/tab/4328.png",
"text": "领取"
"pagePath": "pages/task/taskreceive"
// "iconPath": "static/tab/43281.png",
// "selectedIconPath": "static/tab/4328.png",
// "text": "领取"
},
{
"pagePath": "pages/user/user",
"iconPath": "static/tab/user.png",
"selectedIconPath": "static/tab/user1.png",
"text": "我的"
"pagePath": "pages/user/user"
// "iconPath": "static/tab/user.png",
// "selectedIconPath": "static/tab/user1.png",
// "text": "我的"
}
]
}
}

2
pages/dadui/index/index.vue

@ -423,7 +423,7 @@
months: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]
}
},
onLoad() {
created() {
let a = uni.getStorageSync("user");
let date = new Date()
this.dates.month = date.getMonth() + 1

8
pages/index/index.vue

@ -2,12 +2,14 @@
<Dindex v-if="shenfen=='battalion'&&!isSupervisor"></Dindex>
<Zindex v-else-if="shenfen=='brigade'"></Zindex>
<Jindex v-else></Jindex>
</template>
<script>
import Dindex from "../../components/index/dadui.vue"
import Jindex from "../../components/index/jiuyuanzhan.vue"
import Zindex from "../../components/index/zhidui.vue"
import Dindex from "@/pages/dadui/index/index.vue"
import Jindex from "@/pages/rescue/index.vue"
import Zindex from "@/pages/zhidui/index.vue"
export default {
components: {
Dindex,

726
pages/rescue/index.vue

@ -0,0 +1,726 @@
<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" v-for="(item,key) in user" :key="key">
<view class="top">
<view class="left">
<img src="@/static/4412.png" alt="">
<view class="">
<text>{{item.name}}任务总数</text><text>{{nub}}</text>
</view>
</view>
<view class="right">
<view v-if="nub" style="margin-right: 10rpx;">完成</view>
<view class="">
<text v-if="nub">{{item.tasknub+'/'+nub}}</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>
</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">
{{item.approvalStatus}}
</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 class="implement">
<button>执行</button>
</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="item.approvalStatus=='待检查'">
<button @tap="start(item)">执行</button>
</view>
<img v-else-if="item.inspectionResult=='未发现违法违规情况'" src="@/static/zeren/4508.png" alt="">
<img v-else-if="item.inspectionResult=='责令限期改正'" src="@/static/zeren/4511.png" alt="">
<view v-else class="">
{{item.inspectionResult}}
</view>
</view>
</view>
</view>
</view>
<tabbar :selected="0"></tabbar>
</view>
</template>
<script>
import tabbar from '@/components/tabbar.vue'
export default {
components: {
tabbar
},
data() {
return {
title: 'Hello',
identity: 0,
progressNub: 60,
chartData: {
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"
}
}
},
user: [{
tasknub: 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()
},
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) => {
console.log(uni.getStorageSync("user").roles, 8800);
let userName = uni.getStorageSync("user").name;
// console.log(uni.getStorageSync("user").roles);
for (let i = 0; i < res.length; i++) {
if (res[i].name = userName) {
this.user = [res[i]]
console.log(this.user, 8070);
for (let i = 0; i < this.user.length; i++) {
this.user[i]["tasknub"] = 0
this.user[i]["rate"] = 0
}
}
}
})
},
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();
})
},
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)
}
}
}
this.identity = 1
},
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) {
console.log(item);
// return
uni.navigateTo({
url: '/pages/task/details?id=' + item.company.id + '&uid=' + item.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>

0
pages/task_jian/details.vue → pages/rescue/task_implement/details.vue

0
pages/task_jian/implement.vue → pages/rescue/task_implement/implement.vue

853
pages/rescue/taskapply.vue

@ -0,0 +1,853 @@
<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}" 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" v-for="(item,key) in user" :key="key">
<view class="top">
<view class="left">
<img src="@/static/4412.png" alt="">
<view class="">
<text>{{item.name}}</text>
</view>
</view>
<view class="right">
</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 style="width: 100rpx; margin-top: 10rpx;">
<button @tap="index=true">新增</button>
</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 v-if="item.approvalStatus=='通过'||item.approvalStatus=='驳回'" class="jiancha"
:class="{jiancha_color:item.approvalStatus=='通过'}">
{{item.approvalStatus}}
</view>
<view v-else class="jiancha" style="color: #FFBA19;">
{{item.approvalStatus}}
</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 class="implement">
<button>执行</button>
</view> -->
</view>
<view class="staffbox">
<view class="staff">
<view>申请时间:</view>
<view>{{item.creationTime}}</view>
<view class="" @tap="chakan(item)">
查看
</view>
</view>
<!-- -->
</view>
</view>
<view class="implement">
<!-- <view class="button">
<button @tap="start(item)">执行</button>
</view> -->
</view>
</view>
</view>
</view>
<view class="taskadd" v-if="index">
<view class="itembox">
<view class="item_top">
<view class="">
任务申领
</view>
<view class="" @tap="indexs()">
x
</view>
</view>
<view class="item_content" v-if="index">
<TaskAdd @apply="apply"></TaskAdd>
</view>
<view class="item_content" v-if="index2">
<TaskDet @apply="apply"></TaskDet>
</view>
</view>
</view>
<view class="taskadd" v-if="index2">
<view class="itembox2">
<view class="item_top">
<view class="">
详情
</view>
<view class="" @tap="indexs()">
x
</view>
</view>
<view class="item_content" v-if="index2">
<TaskDet :cid="Cid"></TaskDet>
</view>
</view>
</view>
<tabbar :selected="1"></tabbar>
</view>
</template>
<script>
import TaskAdd from "@/components/task/add.vue"
import TaskDet from "@/components/task/details.vue"
import tabbar from '@/components/tabbar.vue'
export default {
components: {
TaskAdd,
TaskDet,
tabbar
},
data() {
return {
title: 'Hello',
identity: 0,
progressNub: 60,
chartData: {
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"
}
}
},
user: [{
tasknub: 0
}],
isSupervisor: false,
list: [],
nub: 0,
index: false,
index2: false,
Cid: "",
xuanchuan: false,
months: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]
}
},
onLoad() {
let a = uni.getStorageSync("user");
let date = new Date()
this.dates.month = date.getMonth() + 1
this.today.month = date.getMonth() + 1
this.dates.year = date.getFullYear()
this.dates.day = date.getDate()
// this.getOrganizations()
},
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) => {
console.log(res);
let userName = uni.getStorageSync("user").roles[0].name;
// console.log(uni.getStorageSync("user").roles);
for (let i = 0; i < res.length; i++) {
if (res[i].userName = userName) {
this.user = [res[i]]
// console.log(this.user,8070);
for (let i = 0; i < this.user.length; i++) {
this.user[i]["tasknub"] = 0
this.user[i]["rate"] = 0
}
}
}
})
},
getTaskListOfStation(item) {
console.log(item);
let organizationId = uni.getStorageSync("user").organizationId
const that = this
let selectedTime = this.dates.year + '-' + this.dates.month + '-' + '01'
let params = {
Month: selectedTime,
// SupervisorId: item,
OrganizationId: organizationId,
CreatorId: item,
PageNumber: 1,
approvalStatus: '通过',
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++) {
for (let k = 0; k < that.list[i].supervisors.length; k++) {
// that.list[i].supervisors[k].name=that.list[i].supervisors[k].name.slice(0,3)+"..."
}
if (that.list[i].creationTime) {
let text = that.list[i].creationTime.substring(0, 10)
that.list[i].creationTime = text
}
if (that.list[i].inspectionResult != '待检查') {
this.user[e].tasknub += 1
}
}
}
console.log(this.list);
this.getServerData();
})
},
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++) {
if (this.list[i].approvalStatus == "待处理") {
this.chartData.series[0].data[1].value += 1
this.nub += 1
} else if (this.list[i].approvalStatus == "驳回") {
this.chartData.series[0].data[2].value += 1
this.nub += 1
} else {
this.chartData.series[0].data[0].value += 1
this.nub += 1
}
}
this.opts.subtitle.name = this.nub
this.identity = 1
},
dateYear(e) {
console.log(e);
this.dates.year = e.detail.value
this.getOrganizations()
},
dateMonth(e) {
this.dates.month = e
this.getOrganizations()
},
apply() {
let that = this;
this.index = false
this.getOrganizations()
},
indexs() {
this.index = false
this.index2 = false
},
chakan(e) {
this.Cid = e
this.index2 = true
},
start(item) {
uni.navigateTo({
url: '/pages/task/details?id=' + item.company.id,
})
}
}
}
</script>
<style lang="scss">
.top {
position: relative;
top: 0;
left: 0;
}
.taskadd {
width: 100vw;
height: 100vh;
position: fixed;
left: 0;
top: 0;
background: rgba(49, 49, 51, 0.2);
z-index: 10;
.itembox {
// background: #fff;
position: absolute;
bottom: 0;
left: 0;
width: 100%;
height: 800rpx;
.item_top {
height: 60rpx;
background: #F5F7FA;
border-radius: 40rpx 40rpx 0 0;
padding: 10rpx 40rpx 0 40rpx;
display: flex;
view:nth-child(1) {
flex: 1;
}
}
.item_content {
background-color: #fff;
height: 100%;
}
}
.itembox2 {
// background: #fff;
position: absolute;
bottom: 0;
left: 0;
width: 100%;
height: 400rpx;
.item_top {
height: 60rpx;
background: #F5F7FA;
border-radius: 40rpx 40rpx 0 0;
padding: 10rpx 40rpx 0 40rpx;
display: flex;
view:nth-child(1) {
flex: 1;
}
}
.item_content {
background-color: #fff;
height: 100%;
}
}
}
.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;
}
.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: 94%;
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;
white-space: nowrap;
/*内容超宽后禁止换行显示*/
overflow: hidden;
/*超出部分隐藏*/
text-overflow: ellipsis;
/*文字超出部分以省略号显示*/
}
.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;
font-size: 18rpx;
}
}
}
}
.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 {
margin-right: 10rpx;
}
.jiancha_color {
color: #14B488;
}
}
.implement {
margin-bottom: 10rpx;
.button {
width: 100%;
height: 100%;
padding-top: 20rpx;
}
// button {
// float: right;
// width: 80rpx;
// height: 40rpx;
// line-height: 40rpx;
// margin-top: 20rpx;
// }
}
</style>

887
pages/rescue/taskreceive.vue

@ -0,0 +1,887 @@
<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}" 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" v-for="(item,key) in user" :key="key">
<view class="top">
<view class="left">
<img src="@/static/4412.png" alt="">
<view class="">
<text>{{item.name}}</text>
</view>
</view>
<view class="right">
</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 style="width: 100rpx; margin-top: 10rpx;">
<button @tap="index=true">新增</button>
</view> -->
</view>
</view>
<view class="listbox">
<view class="item" v-for="(item,key) in list" :key="key">
<view class="typebox">
<view
style="width: 80rpx; height: 40rpx; line-height: 40rpx; border-radius: 4rpx; font-size: 26rpx; text-align: center; margin-top: 6rpx; background: #E63434; color: #fff;">
派发
</view>
<view class="type">
{{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="namebox">
<view class="name">
<view
style="width: 12rpx; height: 34rpx; margin-top: 14rpx; background-color: #9D80FF; color: #9D80FF ;">
</view>
<view class="type">
{{item.taskType}}
</view>
</view>
</view>
<view class="staffbox">
<view class="staff" style="flex: 1;">
<view>申请人:</view>
<view class="zhu">{{item.organization.name}}</view>
</view>
<view v-if="item.approvalStatus!='已检查'" class="jiancha"
style="color: #FFBA19; display: flex; margin-top: -10rpx;">
<button @tap="tongguo(item)">同意</button>
<button type="default" @tap="bohui(item)">驳回</button>
</view>
<view v-else class="jiancha" style="color: #FFBA19;">
{{item.approvalStatus}}
</view>
</view>
<view style="display: flex;">
<view style="flex:1">
<view class="staffbox">
<view class="staff">
<view>申请时间:</view>
<view>{{item.creationTime}}</view>
<view class="" @tap="chakan(item)">
查看
</view>
</view>
<view v-if="item.approvalStatus=='通过'||item.approvalStatus=='驳回'" class="jiancha"
:class="{jiancha_color:item.approvalStatus=='通过'}">
{{item.approvalStatus}}
</view>
<!-- <view v-else class="jiancha"
style="color: #FFBA19;">
{{item.approvalStatus}}
</view> -->
</view>
</view>
<view class="implement">
</view>
</view>
</view>
</view>
<view class="taskadd" v-if="index">
<view class="itembox">
<view class="item_top">
<view class="">
任务申领
</view>
<view class="" @tap="indexs()">
x
</view>
</view>
<view class="item_content" v-if="index">
<TaskAdd @apply="apply"></TaskAdd>
</view>
<view class="item_content" v-if="index2">
<TaskDet @apply="apply"></TaskDet>
</view>
</view>
</view>
<view class="taskadd" v-if="index2">
<view class="itembox2">
<view class="item_top">
<view class="">
详情
</view>
<view class="" @tap="indexs()">
x
</view>
</view>
<view class="item_content" v-if="index2">
<TaskDet :cid="Cid"></TaskDet>
</view>
</view>
</view>
<tabbar :selected="2"></tabbar>
</view>
</template>
<script>
import TaskAdd from "@/components/task/add.vue"
import TaskDet from "@/components/task/details.vue"
import tabbar from '@/components/tabbar.vue'
export default {
components: {
TaskAdd,
TaskDet,
tabbar
},
data() {
return {
title: 'Hello',
identity: 0,
progressNub: 60,
chartData: {
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"
}
}
},
user: [{
tasknub: 0
}],
isSupervisor: false,
list: [],
nub: 0,
index: false,
index2: false,
OrganizationId: "",
userId: "",
Cid: "",
xuanchuan: false,
months: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]
}
},
onLoad() {
let a = uni.getStorageSync("user");
let date = new Date()
this.dates.month = date.getMonth() + 1
this.today.month = date.getMonth() + 1
this.dates.year = date.getFullYear()
this.dates.day = date.getDate()
// this.getOrganizations()
},
onReady() {
this.getOrganizations()
this.OrganizationId = uni.getStorageSync("user").organizationId
this.userId = uni.getStorageSync("user").id
},
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) => {
console.log(res);
let userName = uni.getStorageSync("user").roles[0].name;
// console.log(uni.getStorageSync("user").roles);
for (let i = 0; i < res.length; i++) {
if (res[i].userName = userName) {
this.user = [res[i]]
// console.log(this.user,8070);
for (let i = 0; i < this.user.length; i++) {
this.user[i]["tasknub"] = 0
this.user[i]["rate"] = 0
}
}
}
})
},
getTaskListOfStation(item) {
console.log(item);
let organizationId = uni.getStorageSync("user").organizationId
const that = this
let selectedTime = this.dates.year + '-' + this.dates.month + '-' + '01'
let params = {
Month: selectedTime,
SupervisorId: this.isSupervisor ? this.userId : null,
assistantOrganizationId: this.isSupervisor ? null : this.OrganizationId,
PageNumber: 1,
PageSize: 9999,
approvalStatuses: ['待处理', '通过', '驳回', '待检查', '已检查']
}
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++) {
for (let k = 0; k < that.list[i].supervisors.length; k++) {
// that.list[i].supervisors[k].name=that.list[i].supervisors[k].name.slice(0,3)+"..."
}
if (that.list[i].creationTime) {
let text = that.list[i].creationTime.substring(0, 10)
that.list[i].creationTime = text
}
if (that.list[i].inspectionResult != '待检查') {
this.user[e].tasknub += 1
}
}
}
console.log(this.list);
this.getServerData();
})
},
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++) {
if (this.list[i].approvalStatus == "待处理") {
this.chartData.series[0].data[1].value += 1
this.nub += 1
} else if (this.list[i].approvalStatus == "驳回") {
this.chartData.series[0].data[2].value += 1
this.nub += 1
} else {
this.chartData.series[0].data[0].value += 1
this.nub += 1
}
}
this.opts.subtitle.name = this.nub
this.identity = 1
},
dateYear(e) {
console.log(e);
this.dates.year = e.detail.value
this.getOrganizations()
},
dateMonth(e) {
this.dates.month = e
this.getOrganizations()
},
apply() {
let that = this;
this.index = false
this.getOrganizations()
},
indexs() {
this.index = false
this.index2 = false
},
chakan(e) {
this.Cid = e
this.index2 = true
},
tongguo(item) {
// console.log(item);
let params = {
approvalStatus: '通过'
}
this.$request.post('/api/PlanTasks/Approval/' + item.id + '?approvalStatus=' + '通过', null, (data, res) => {
console.log(res);
this.getOrganizations()
})
},
bohui(item) {
this.$request.post('/api/PlanTasks/Approval/' + item.id + '?approvalStatus=' + '驳回', null, (data, res) => {
console.log(res);
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;
}
.taskadd {
width: 100vw;
height: 100vh;
position: fixed;
left: 0;
top: 0;
background: rgba(49, 49, 51, 0.2);
z-index: 10;
.itembox {
// background: #fff;
position: absolute;
bottom: 0;
left: 0;
width: 100%;
height: 600rpx;
.item_top {
height: 60rpx;
background: #F5F7FA;
border-radius: 40rpx 40rpx 0 0;
padding: 10rpx 40rpx 0 40rpx;
display: flex;
view:nth-child(1) {
flex: 1;
}
}
.item_content {
background-color: #fff;
height: 100%;
}
}
.itembox2 {
// background: #fff;
position: absolute;
bottom: 0;
left: 0;
width: 100%;
height: 400rpx;
.item_top {
height: 60rpx;
background: #F5F7FA;
border-radius: 40rpx 40rpx 0 0;
padding: 10rpx 40rpx 0 40rpx;
display: flex;
view:nth-child(1) {
flex: 1;
}
}
.item_content {
background-color: #fff;
height: 100%;
}
}
}
.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;
}
.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;
}
button::after {
border: none;
}
.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: 94%;
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;
white-space: nowrap;
/*内容超宽后禁止换行显示*/
overflow: hidden;
/*超出部分隐藏*/
text-overflow: ellipsis;
/*文字超出部分以省略号显示*/
display: flex;
.type {
width: 50%;
// border-left: #327AFE 6rpx solid;
font-size: 32rpx;
font-weight: 600;
padding-left: 10rpx;
}
}
}
}
}
.typebox {
display: flex;
margin: 14rpx 0;
.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;
font-size: 18rpx;
}
.type {
flex: 1;
// 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);
flex: 1;
.zhu {
color: #100F19;
}
view {
margin-right: 20rpx;
}
img {
width: 40rpx;
height: 40rpx;
min-width: 40rpx;
min-height: 40rpx;
}
}
.jiancha {
margin-right: 10rpx;
}
.jiancha_color {
color: #14B488;
}
}
.implement {
margin-bottom: 10rpx;
.button {
width: 100%;
height: 100%;
padding-top: 20rpx;
}
// button {
// float: right;
// width: 80rpx;
// height: 40rpx;
// line-height: 40rpx;
// margin-top: 20rpx;
// }
}
</style>

7
pages/task/taskapply.vue

@ -175,6 +175,9 @@
</view>
</view>
</view>
<tabbar :selected="1"></tabbar>
</view>
</template>
@ -182,10 +185,12 @@
<script>
import TaskAdd from "../../components/task/add.vue"
import TaskDet from "../../components/task/details.vue"
import tabbar from '../../components/tabbar.vue'
export default {
components: {
TaskAdd,
TaskDet
TaskDet,
tabbar
},
data() {
return {

10
pages/task/taskreceive.vue

@ -99,7 +99,8 @@
</view>
<view v-if="item.approvalStatus!='已检查'" class="jiancha" style="color: #FFBA19; display: flex; margin-top: -10rpx;">
<view v-if="item.approvalStatus!='已检查'" class="jiancha"
style="color: #FFBA19; display: flex; margin-top: -10rpx;">
<button @tap="tongguo(item)">同意</button>
<button type="default" @tap="bohui(item)">驳回</button>
</view>
@ -173,6 +174,8 @@
</view>
</view>
</view>
<tabbar :selected="2"></tabbar>
</view>
</template>
@ -180,10 +183,12 @@
<script>
import TaskAdd from "../../components/task/add.vue"
import TaskDet from "../../components/task/details.vue"
import tabbar from '../../components/tabbar.vue'
export default {
components: {
TaskAdd,
TaskDet
TaskDet,
tabbar
},
data() {
return {
@ -832,6 +837,7 @@
display: flex;
color: rgba(16, 15, 25, 0.48);
flex: 1;
.zhu {
color: #100F19;

15
pages/user/user.vue

@ -26,11 +26,16 @@
<view @tap="tuichu()" class="tuichudenglu">
退出登录
</view>
<tabbar :selected="3"></tabbar>
</view>
</template>
<script>
import tabbar from '../../components/tabbar.vue'
export default {
components: {
tabbar
},
data() {
return {
list: {}
@ -61,29 +66,35 @@
background: linear-gradient(180deg, #317AFF 0%, #ACD1FF 100%);
height: 300rpx;
padding: 20rpx 40rpx;
.box {
display: flex;
.portrait {
width: 150rpx;
height: 150rpx;
border-radius: 150rpx;
border: 6rpx solid #fff;
img {
width: 100%;
height: 100%;
border-radius: 150rpx;
}
}
.information {
color: #fff;
margin: 30rpx 20rpx;
font-size: 36rpx;
.name {
margin-bottom: 20rpx;
}
}
}
}
.items {
width: 100%;
margin-top: -40rpx;
@ -97,6 +108,7 @@
line-height: 80rpx;
border-radius: 10rpx;
padding-left: 20rpx;
img {
height: 40rpx;
margin-top: 20rpx;
@ -105,6 +117,7 @@
}
}
.tuichudenglu {
width: 100%;
color: #acacac;
@ -112,6 +125,4 @@
text-align: center;
}
}
</style>

885
pages/zhidui/index.vue

@ -0,0 +1,885 @@
<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>{{nub}}</text>
</view>
</view>
<view class="right">
<view v-if="nub" style="margin-right: 10rpx;">完成</view>
<view class="">
<text v-if="nub">{{num}}/{{nub}}</text>
<text v-else>暂无任务</text>
</view>
</view>
</view>
<view class="charts-box" style="display: flex;">
<!-- <img src="@/static/dadui/10.png" alt=""> -->
<view style="width: 40%;">
<qiun-data-charts v-if="identity" type="ring" :opts="opts" :chartData="chartData" />
</view>
<view style=" width: 60%; display: flex;flex-wrap:wrap">
<view class="tagbox" style="width: 50%;" v-for="(item,key) in chartData.series[0].data"
:key="key">
<view class="tag" :style="'background:'+opts.color[key]+';'">
</view>
<text style="font-size: 24rpx;">{{item.name}}</text>
<view style="font-size: 28rpx; flex:1;text-align: right;padding-right: 10rpx;">
{{item.value}}
</view>
</view>
</view>
</view>
<view class="itembox">
<view class="top">
<view class="left">
<img src="@/static/4412.png" alt="">
<view class="">
<text>指派任务任务总数</text><text>{{nub2}}</text>
</view>
</view>
<view class="right">
<view v-if="nub2" style="margin-right: 10rpx;">完成</view>
<view class="">
<text v-if="nub">{{num2}}/{{nub2}}</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: 40%;">
<qiun-data-charts type="ring" :opts="opts2" :chartData="chartData2" />
</view>
<view
style="width: 60%; 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:'+opts2.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">
<view class="title" style="display: flex;">
<view class="">
</view>
<view class="">
救援站主负责发起
</view>
</view>
<!-- <img src="@/static/dadui/10.png" alt=""> -->
<view class="" style="display: flex; ">
<view v-if="identity" style="width: 40%;">
<qiun-data-charts type="ring" :opts="opts3" :chartData="chartData3" />
</view>
<view
style="width: 60%; 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 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: 40%;">
<qiun-data-charts type="ring" :opts="opts3" :chartData="chartData3" />
</view>
<view
style="width: 60%; 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>
</view>
</view>
</view>
</template>
<script>
import tabbar from '@/components/tabbar.vue'
export default {
components: {
tabbar
},
data() {
return {
title: 'Hello',
identity: 0,
progressNub: 60,
chartData: {
series: [{
data: [{
name: "熟悉演练",
value: 0
}, {
name: "联络指导",
value: 0
}, {
name: "消防宣传",
value: 0
}, {
name: "投诉举报",
value: 0
}, {
name: "双随机",
value: 0
}, {
name: "行政许可",
value: 0
}, {
name: "火灾调查",
value: 0
}, ]
}]
},
chartData2: {
series: [{
data: [{
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: ["#FEA364", "#977AC8", "#6AD9AC", "#6A7A96", "#F5C044", "#E7745E", "#79C9EA"],
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: 50,
borderWidth: 3,
borderColor: "#FFFFFF",
centerColor: "#57B5FF",
linearType: "none"
}
}
},
opts2: {
rotate: false,
rotateLock: false,
color: ["#5074F9", "#FFBA19"],
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: 50,
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: 50,
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: [],
list2: [],
list3: [],
list4: [],
month: 0,
nub: 0,
nub2: 0,
num: 0,
num2: 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.getTaskListOfStation('投诉举报')
this.getTaskListOfStation('双随机')
this.getTaskListOfStation('熟悉演练')
this.getTaskListOfStation('行政许可')
this.getCountStat()
},
onReady() {
this.identity = 1
// this.getOrganizations()
},
methods: {
getTaskListOfStation(item) {
const that = this
let OrganizationId = uni.getStorageSync("user").organizationId
let selectedTime = this.dates.year + '-' + this.dates.month + '-' + '01'
let params = {
Month: selectedTime,
OrganizationId: OrganizationId,
TaskType: item,
PageNumber: 1,
PageSize: 99999
}
this.$request.get("/api/PlanTasks", params, (data, res) => {
console.log(res);
if (item == "投诉举报") {
this.list = res.items
this.chartData.series[0].data[3].value = res.items.length
this.chartData2.series[0].data[0].value = res.items.length
this.nub += res.items.length
this.nub2 += res.items.length
for (let a = 0; a < res.items.length; a++) {
if (res.items[a].approvalStatus == "已检查") {
this.num++
this.num2++
}
}
}
if (item == "双随机") {
this.list2 = res.items
this.chartData.series[0].data[2].value = res.items.length
this.nub += res.items.length
for (let a = 0; a < res.items.length; a++) {
if (res.items[a].approvalStatus == "已检查") {
this.num++
}
}
}
if (item == "熟悉演练") {
this.list3 = res.items
this.chartData.series[0].data[0].value = res.items.length
this.nub += res.items.length
for (let a = 0; a < res.items.length; a++) {
if (res.items[a].approvalStatus == "已检查") {
this.num++
}
}
}
if (item == "行政许可") {
this.list4 = res.items
this.chartData.series[0].data[5].value = res.items.length
this.chartData2.series[0].data[1].value = res.items.length
this.nub += res.items.length
this.nub2 += res.items.length
for (let a = 0; a < res.items.length; a++) {
if (res.items[a].approvalStatus == "已检查") {
this.num++
this.num2++
}
}
}
this.opts.subtitle.name = this.nub
this.opts2.subtitle.name = this.nub2
// this.getCountStat()
})
},
getCountStat() {
},
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 {
box-shadow: 0px 0px 10px 1px #C1D7FF;
// background-color: #5687fd;
height: 250rpx;
position: relative;
img {
width: 100%;
height: 100%;
position: absolute;
top: 0;
left: 0;
z-index: -1;
}
.tagbox {
color: #100F19;
display: flex;
justify-content: center;
align-items: center;
margin: 10rpx 0;
font-size: 32rpx;
.tag {
width: 20rpx;
height: 20rpx;
border-radius: 20rpx;
margin-right: 10rpx;
}
}
}
.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>

2
unpackage/dist/dev/.sourcemap/mp-weixin/common/runtime.js.map vendored

File diff suppressed because one or more lines are too long

2
unpackage/dist/dev/.sourcemap/mp-weixin/common/vendor.js.map vendored

File diff suppressed because one or more lines are too long

2
unpackage/dist/dev/.sourcemap/mp-weixin/pages/dadui/index/index.js.map vendored

File diff suppressed because one or more lines are too long

2
unpackage/dist/dev/.sourcemap/mp-weixin/pages/index/index.js.map vendored

File diff suppressed because one or more lines are too long

2
unpackage/dist/dev/.sourcemap/mp-weixin/pages/task/details.js.map vendored

@ -1 +1 @@
{"version":3,"sources":["uni-app:///main.js"],"names":["wx","__webpack_require_UNI_MP_PLUGIN__","__webpack_require__","createPage","Page"],"mappings":"+HAAA,KAGA,YACA,W,mDAFAA,GAAGC,kCAAoCC,EAGvCC,EAAWC,a","file":"pages/task/details.js","sourcesContent":["import 'uni-pages';\n// @ts-ignore\nwx.__webpack_require_UNI_MP_PLUGIN__ = __webpack_require__;\nimport Vue from 'vue'\nimport Page from './pages/task/details.vue'\ncreatePage(Page)"],"sourceRoot":""}
{"version":3,"sources":["uni-app:///main.js"],"names":["wx","__webpack_require_UNI_MP_PLUGIN__","__webpack_require__","createPage","Page"],"mappings":"gIAAA,KAGA,YACA,0H,mDAFAA,GAAGC,kCAAoCC,EAGvCC,EAAWC,a","file":"pages/task/details.js","sourcesContent":["import 'uni-pages';\n// @ts-ignore\nwx.__webpack_require_UNI_MP_PLUGIN__ = __webpack_require__;\nimport Vue from 'vue'\nimport Page from './pages/task/details.vue'\ncreatePage(Page)"],"sourceRoot":""}

2
unpackage/dist/dev/.sourcemap/mp-weixin/pages/task/taskapply.js.map vendored

File diff suppressed because one or more lines are too long

2
unpackage/dist/dev/.sourcemap/mp-weixin/pages/task/taskreceive.js.map vendored

File diff suppressed because one or more lines are too long

2
unpackage/dist/dev/.sourcemap/mp-weixin/pages/user/changePassword/changePassword.js.map vendored

@ -1 +1 @@
{"version":3,"sources":["uni-app:///main.js"],"names":["wx","__webpack_require_UNI_MP_PLUGIN__","__webpack_require__","createPage","Page"],"mappings":"qJAAA,KAGA,YACA,W,mDAFAA,GAAGC,kCAAoCC,EAGvCC,EAAWC,a","file":"pages/user/changePassword/changePassword.js","sourcesContent":["import 'uni-pages';\n// @ts-ignore\nwx.__webpack_require_UNI_MP_PLUGIN__ = __webpack_require__;\nimport Vue from 'vue'\nimport Page from './pages/user/changePassword/changePassword.vue'\ncreatePage(Page)"],"sourceRoot":""}
{"version":3,"sources":["uni-app:///main.js"],"names":["wx","__webpack_require_UNI_MP_PLUGIN__","__webpack_require__","createPage","Page"],"mappings":"sJAAA,KAGA,YACA,gJ,mDAFAA,GAAGC,kCAAoCC,EAGvCC,EAAWC,a","file":"pages/user/changePassword/changePassword.js","sourcesContent":["import 'uni-pages';\n// @ts-ignore\nwx.__webpack_require_UNI_MP_PLUGIN__ = __webpack_require__;\nimport Vue from 'vue'\nimport Page from './pages/user/changePassword/changePassword.vue'\ncreatePage(Page)"],"sourceRoot":""}

2
unpackage/dist/dev/.sourcemap/mp-weixin/pages/user/user.js.map vendored

File diff suppressed because one or more lines are too long

48
unpackage/dist/dev/mp-weixin/app.json vendored

@ -1,29 +1,18 @@
{
"pages": [
"pages/login/login",
"pages/rescue/task_implement/implement",
"pages/changePassword/changePassword",
"pages/demo/demo",
"pages/rescue/task_implement/details",
"pages/task/taskreceive",
"pages/index/index",
"pages/user/user",
"pages/task/taskreceive",
"pages/task/taskapply",
"pages/demo/demo",
"pages/dadui/jiancha/jiancha",
"pages/dadui/jiuyuan/jiuyuan"
],
"subPackages": [
{
"root": "pages/changePassword",
"pages": [
"changePassword"
]
},
{
"root": "pages/task_jian",
"pages": [
"implement",
"details"
]
}
"pages/dadui/jiuyuan/jiuyuan",
"pages/task/taskapply"
],
"subPackages": [],
"window": {
"navigationBarTextStyle": "black",
"navigationBarTitleText": "uni-app",
@ -31,32 +20,21 @@
"backgroundColor": "#F8F8F8"
},
"tabBar": {
"custom": true,
"color": "#353535",
"selectedColor": "#5187FF",
"list": [
{
"pagePath": "pages/index/index",
"iconPath": "static/tab/43251.png",
"selectedIconPath": "static/tab/4325.png",
"text": "工作任务"
"pagePath": "pages/index/index"
},
{
"pagePath": "pages/task/taskapply",
"iconPath": "static/tab/43281.png",
"selectedIconPath": "static/tab/4328.png",
"text": "申请"
"pagePath": "pages/task/taskapply"
},
{
"pagePath": "pages/task/taskreceive",
"iconPath": "static/tab/43281.png",
"selectedIconPath": "static/tab/4328.png",
"text": "领取"
"pagePath": "pages/task/taskreceive"
},
{
"pagePath": "pages/user/user",
"iconPath": "static/tab/user.png",
"selectedIconPath": "static/tab/user1.png",
"text": "我的"
"pagePath": "pages/user/user"
}
]
},

2
unpackage/dist/dev/mp-weixin/common/runtime.js vendored

File diff suppressed because one or more lines are too long

6
unpackage/dist/dev/mp-weixin/common/vendor.js vendored

File diff suppressed because one or more lines are too long

2
unpackage/dist/dev/mp-weixin/pages/index/index.js vendored

@ -1,2 +1,2 @@
(global["webpackJsonp"]=global["webpackJsonp"]||[]).push([["pages/index/index"],{37:function(n,e,t){"use strict";(function(n){t(5);r(t(4));var e=r(t(38));function r(n){return n&&n.__esModule?n:{default:n}}wx.__webpack_require_UNI_MP_PLUGIN__=t,n(e.default)}).call(this,t(1)["createPage"])},38:function(n,e,t){"use strict";t.r(e);var r=t(39),o=t(41);for(var u in o)"default"!==u&&function(n){t.d(e,n,(function(){return o[n]}))}(u);t(43);var i,c=t(11),a=Object(c["default"])(o["default"],r["render"],r["staticRenderFns"],!1,null,null,null,!1,r["components"],i);a.options.__file="pages/index/index.vue",e["default"]=a.exports},39:function(n,e,t){"use strict";t.r(e);var r=t(40);t.d(e,"render",(function(){return r["render"]})),t.d(e,"staticRenderFns",(function(){return r["staticRenderFns"]})),t.d(e,"recyclableRender",(function(){return r["recyclableRender"]})),t.d(e,"components",(function(){return r["components"]}))},40:function(n,e,t){"use strict";var r;t.r(e),t.d(e,"render",(function(){return o})),t.d(e,"staticRenderFns",(function(){return i})),t.d(e,"recyclableRender",(function(){return u})),t.d(e,"components",(function(){return r}));var o=function(){var n=this,e=n.$createElement;n._self._c},u=!1,i=[];o._withStripped=!0},41:function(n,e,t){"use strict";t.r(e);var r=t(42),o=t.n(r);for(var u in r)"default"!==u&&function(n){t.d(e,n,(function(){return r[n]}))}(u);e["default"]=o.a},42:function(n,e,t){"use strict";(function(n){Object.defineProperty(e,"__esModule",{value:!0}),e.default=void 0;var r=function(){Promise.all([t.e("common/vendor"),t.e("components/index/dadui")]).then(function(){return resolve(t(127))}.bind(null,t)).catch(t.oe)},o=function(){Promise.all([t.e("common/vendor"),t.e("components/index/jiuyuanzhan")]).then(function(){return resolve(t(134))}.bind(null,t)).catch(t.oe)},u=function(){Promise.all([t.e("common/vendor"),t.e("components/index/zhidui")]).then(function(){return resolve(t(141))}.bind(null,t)).catch(t.oe)},i={components:{Dindex:r,Jindex:o,Zindex:u},data:function(){return{shenfen:"",isSupervisor:!1}},onLoad:function(){var e=n.getStorageSync("user").roles,t=e.find((function(n){return-1!=n.name.indexOf("检查")}));this.isSupervisor=!!t,this.shenfen=n.getStorageSync("user").organizationLevel},onReady:function(){},methods:{}};e.default=i}).call(this,t(1)["default"])},43:function(n,e,t){"use strict";t.r(e);var r=t(44),o=t.n(r);for(var u in r)"default"!==u&&function(n){t.d(e,n,(function(){return r[n]}))}(u);e["default"]=o.a},44:function(n,e,t){}},[[37,"common/runtime","common/vendor"]]]);
(global["webpackJsonp"]=global["webpackJsonp"]||[]).push([["pages/index/index"],{37:function(n,e,t){"use strict";(function(n){t(5);r(t(4));var e=r(t(38));function r(n){return n&&n.__esModule?n:{default:n}}wx.__webpack_require_UNI_MP_PLUGIN__=t,n(e.default)}).call(this,t(1)["createPage"])},38:function(n,e,t){"use strict";t.r(e);var r=t(39),o=t(41);for(var u in o)"default"!==u&&function(n){t.d(e,n,(function(){return o[n]}))}(u);t(43);var i,c=t(11),a=Object(c["default"])(o["default"],r["render"],r["staticRenderFns"],!1,null,null,null,!1,r["components"],i);a.options.__file="pages/index/index.vue",e["default"]=a.exports},39:function(n,e,t){"use strict";t.r(e);var r=t(40);t.d(e,"render",(function(){return r["render"]})),t.d(e,"staticRenderFns",(function(){return r["staticRenderFns"]})),t.d(e,"recyclableRender",(function(){return r["recyclableRender"]})),t.d(e,"components",(function(){return r["components"]}))},40:function(n,e,t){"use strict";var r;t.r(e),t.d(e,"render",(function(){return o})),t.d(e,"staticRenderFns",(function(){return i})),t.d(e,"recyclableRender",(function(){return u})),t.d(e,"components",(function(){return r}));var o=function(){var n=this,e=n.$createElement;n._self._c},u=!1,i=[];o._withStripped=!0},41:function(n,e,t){"use strict";t.r(e);var r=t(42),o=t.n(r);for(var u in r)"default"!==u&&function(n){t.d(e,n,(function(){return r[n]}))}(u);e["default"]=o.a},42:function(n,e,t){"use strict";(function(n){Object.defineProperty(e,"__esModule",{value:!0}),e.default=void 0;var r=function(){Promise.all([t.e("common/vendor"),t.e("pages/dadui/index/index")]).then(function(){return resolve(t(127))}.bind(null,t)).catch(t.oe)},o=function(){Promise.all([t.e("common/vendor"),t.e("pages/rescue/index")]).then(function(){return resolve(t(262))}.bind(null,t)).catch(t.oe)},u=function(){Promise.all([t.e("common/vendor"),t.e("pages/zhidui/index")]).then(function(){return resolve(t(134))}.bind(null,t)).catch(t.oe)},i={components:{Dindex:r,Jindex:o,Zindex:u},data:function(){return{shenfen:"",isSupervisor:!1}},onLoad:function(){var e=n.getStorageSync("user").roles,t=e.find((function(n){return-1!=n.name.indexOf("检查")}));this.isSupervisor=!!t,this.shenfen=n.getStorageSync("user").organizationLevel},onReady:function(){},methods:{}};e.default=i}).call(this,t(1)["default"])},43:function(n,e,t){"use strict";t.r(e);var r=t(44),o=t.n(r);for(var u in r)"default"!==u&&function(n){t.d(e,n,(function(){return r[n]}))}(u);e["default"]=o.a},44:function(n,e,t){}},[[37,"common/runtime","common/vendor"]]]);
//# sourceMappingURL=../../../.sourcemap/mp-weixin/pages/index/index.js.map

6
unpackage/dist/dev/mp-weixin/pages/index/index.json vendored

@ -4,8 +4,8 @@
"navigationBarTitleText": "消防一体化综合治理平台",
"navigationBarTextStyle": "white",
"usingComponents": {
"dindex": "/components/index/dadui",
"jindex": "/components/index/jiuyuanzhan",
"zindex": "/components/index/zhidui"
"dindex": "/pages/dadui/index/index",
"jindex": "/pages/rescue/index",
"zindex": "/pages/zhidui/index"
}
}

1
unpackage/dist/dev/mp-weixin/pages/task/details.js vendored

@ -0,0 +1 @@
Component({})

2
unpackage/dist/dev/mp-weixin/pages/task/taskapply.js vendored

File diff suppressed because one or more lines are too long

3
unpackage/dist/dev/mp-weixin/pages/task/taskapply.json vendored

@ -6,6 +6,7 @@
"usingComponents": {
"qiun-data-charts": "/uni_modules/qiun-data-charts/components/qiun-data-charts/qiun-data-charts",
"task-add": "/components/task/add",
"task-det": "/components/task/details"
"task-det": "/components/task/details",
"tabbar": "/components/tabbar"
}
}

2
unpackage/dist/dev/mp-weixin/pages/task/taskapply.wxml vendored

File diff suppressed because one or more lines are too long

2
unpackage/dist/dev/mp-weixin/pages/task/taskreceive.js vendored

File diff suppressed because one or more lines are too long

3
unpackage/dist/dev/mp-weixin/pages/task/taskreceive.json vendored

@ -6,6 +6,7 @@
"usingComponents": {
"qiun-data-charts": "/uni_modules/qiun-data-charts/components/qiun-data-charts/qiun-data-charts",
"task-add": "/components/task/add",
"task-det": "/components/task/details"
"task-det": "/components/task/details",
"tabbar": "/components/tabbar"
}
}

2
unpackage/dist/dev/mp-weixin/pages/task/taskreceive.wxml vendored

@ -1 +1 @@
<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" data-event-opts="{{[['change',[['dateYear',['$event']]]]]}}" bindchange="__e"><view>{{dates.year}}</view></picker><image style="width:30rpx;height:30rpx;margin:10rpx 0 0 10rpx;" src="{{$root.m0}}" alt class="_img"></image></view><view style="margin:0 10rpx;">|</view><view>{{''+today.month+"."+dates.day+''}}</view></view><view class="monthbox"><block wx:for="{{months}}" wx:for-item="item" wx:for-index="key" wx:key="key"><view data-event-opts="{{[['tap',[['dateMonth',['$0'],[[['months','',key]]]]]]]}}" class="{{['month_class',(item==dates.month)?'month_color':'']}}" bindtap="__e"><text>{{item}}</text></view></block></view></view></view><view class="taskbox"><block wx:for="{{user}}" wx:for-item="item" wx:for-index="key" wx:key="key"><view class="itembox"><view class="top"><view class="left"><image src="{{$root.m1}}" alt class="_img"></image><view><text>{{item.name}}</text></view></view><view class="right"></view></view><view class="charts-box" style="display:flex;"><image src="{{$root.m2}}" alt class="_img"></image><block wx:if="{{identity}}"><view style="width:50%;"><qiun-data-charts vue-id="{{'e720980e-1-'+key}}" type="ring" opts="{{opts}}" chartData="{{chartData}}" bind:__l="__l"></qiun-data-charts></view></block><view style="width:50%;display:flex;justify-content:center;align-items:center;flex-direction:column;"><block wx:for="{{chartData.series[0].data}}" wx:for-item="item" wx:for-index="key" wx:key="key"><view class="tagbox"><view class="tag" style="{{('background:'+opts.color[key]+';')}}"></view><text>{{item.name+"-------"+item.value+"个"}}</text></view></block></view></view></view></block></view><view class="listbox"><block wx:for="{{list}}" wx:for-item="item" wx:for-index="key" wx:key="key"><view class="item"><view class="typebox"><view style="width:80rpx;height:40rpx;line-height:40rpx;border-radius:4rpx;font-size:26rpx;text-align:center;margin-top:6rpx;background:#E63434;color:#fff;">派发</view><view class="type">{{''+item.company.companyName+''}}</view><view style="width:30%;padding-left:20rpx;"><block wx:if="{{item.company.useNature=='重点单位'}}"><view class="tag">{{''+item.company.useNature+''}}</view></block><block wx:else><view class="tag2">{{''+item.company.useNature+''}}</view></block></view></view><view class="namebox"><view class="name"><view style="width:12rpx;height:34rpx;margin-top:14rpx;background-color:#9D80FF;color:#9D80FF;"></view><view class="type">{{''+item.taskType+''}}</view></view></view><view class="staffbox"><view class="staff" style="flex:1;"><view>申请人:</view><view class="zhu">{{item.organization.name}}</view></view><block wx:if="{{item.approvalStatus!='已检查'}}"><view class="jiancha" style="color:#FFBA19;display:flex;margin-top:-10rpx;"><button data-event-opts="{{[['tap',[['tongguo',['$0'],[[['list','',key]]]]]]]}}" bindtap="__e">同意</button><button type="default" data-event-opts="{{[['tap',[['bohui',['$0'],[[['list','',key]]]]]]]}}" bindtap="__e">驳回</button></view></block><block wx:else><view class="jiancha" style="color:#FFBA19;">{{''+item.approvalStatus+''}}</view></block></view><view style="display:flex;"><view style="flex:1;"><view class="staffbox"><view class="staff"><view>申请时间:</view><view>{{item.creationTime}}</view><view data-event-opts="{{[['tap',[['chakan',['$0'],[[['list','',key]]]]]]]}}" bindtap="__e">查看</view></view><block wx:if="{{item.approvalStatus=='通过'||item.approvalStatus=='驳回'}}"><view class="{{['jiancha',(item.approvalStatus=='通过')?'jiancha_color':'']}}">{{'已'+item.approvalStatus+''}}</view></block></view></view><view class="implement"></view></view></view></block></view><block wx:if="{{index}}"><view class="taskadd"><view class="itembox"><view class="item_top"><view>任务申领</view><view data-event-opts="{{[['tap',[['indexs']]]]}}" bindtap="__e">x</view></view><block wx:if="{{index}}"><view class="item_content"><task-add bind:apply="__e" vue-id="e720980e-2" data-event-opts="{{[['^apply',[['apply']]]]}}" bind:__l="__l"></task-add></view></block><block wx:if="{{index2}}"><view class="item_content"><task-det bind:apply="__e" vue-id="e720980e-3" data-event-opts="{{[['^apply',[['apply']]]]}}" bind:__l="__l"></task-det></view></block></view></view></block><block wx:if="{{index2}}"><view class="taskadd"><view class="itembox2"><view class="item_top"><view>详情</view><view data-event-opts="{{[['tap',[['indexs']]]]}}" bindtap="__e">x</view></view><block wx:if="{{index2}}"><view class="item_content"><task-det vue-id="e720980e-4" cid="{{Cid}}" bind:__l="__l"></task-det></view></block></view></view></block></view>
<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" data-event-opts="{{[['change',[['dateYear',['$event']]]]]}}" bindchange="__e"><view>{{dates.year}}</view></picker><image style="width:30rpx;height:30rpx;margin:10rpx 0 0 10rpx;" src="{{$root.m0}}" alt class="_img"></image></view><view style="margin:0 10rpx;">|</view><view>{{''+today.month+"."+dates.day+''}}</view></view><view class="monthbox"><block wx:for="{{months}}" wx:for-item="item" wx:for-index="key" wx:key="key"><view data-event-opts="{{[['tap',[['dateMonth',['$0'],[[['months','',key]]]]]]]}}" class="{{['month_class',(item==dates.month)?'month_color':'']}}" bindtap="__e"><text>{{item}}</text></view></block></view></view></view><view class="taskbox"><block wx:for="{{user}}" wx:for-item="item" wx:for-index="key" wx:key="key"><view class="itembox"><view class="top"><view class="left"><image src="{{$root.m1}}" alt class="_img"></image><view><text>{{item.name}}</text></view></view><view class="right"></view></view><view class="charts-box" style="display:flex;"><image src="{{$root.m2}}" alt class="_img"></image><block wx:if="{{identity}}"><view style="width:50%;"><qiun-data-charts vue-id="{{'e720980e-1-'+key}}" type="ring" opts="{{opts}}" chartData="{{chartData}}" bind:__l="__l"></qiun-data-charts></view></block><view style="width:50%;display:flex;justify-content:center;align-items:center;flex-direction:column;"><block wx:for="{{chartData.series[0].data}}" wx:for-item="item" wx:for-index="key" wx:key="key"><view class="tagbox"><view class="tag" style="{{('background:'+opts.color[key]+';')}}"></view><text>{{item.name+"-------"+item.value+"个"}}</text></view></block></view></view></view></block></view><view class="listbox"><block wx:for="{{list}}" wx:for-item="item" wx:for-index="key" wx:key="key"><view class="item"><view class="typebox"><view style="width:80rpx;height:40rpx;line-height:40rpx;border-radius:4rpx;font-size:26rpx;text-align:center;margin-top:6rpx;background:#E63434;color:#fff;">派发</view><view class="type">{{''+item.company.companyName+''}}</view><view style="width:30%;padding-left:20rpx;"><block wx:if="{{item.company.useNature=='重点单位'}}"><view class="tag">{{''+item.company.useNature+''}}</view></block><block wx:else><view class="tag2">{{''+item.company.useNature+''}}</view></block></view></view><view class="namebox"><view class="name"><view style="width:12rpx;height:34rpx;margin-top:14rpx;background-color:#9D80FF;color:#9D80FF;"></view><view class="type">{{''+item.taskType+''}}</view></view></view><view class="staffbox"><view class="staff" style="flex:1;"><view>申请人:</view><view class="zhu">{{item.organization.name}}</view></view><block wx:if="{{item.approvalStatus!='已检查'}}"><view class="jiancha" style="color:#FFBA19;display:flex;margin-top:-10rpx;"><button data-event-opts="{{[['tap',[['tongguo',['$0'],[[['list','',key]]]]]]]}}" bindtap="__e">同意</button><button type="default" data-event-opts="{{[['tap',[['bohui',['$0'],[[['list','',key]]]]]]]}}" bindtap="__e">驳回</button></view></block><block wx:else><view class="jiancha" style="color:#FFBA19;">{{''+item.approvalStatus+''}}</view></block></view><view style="display:flex;"><view style="flex:1;"><view class="staffbox"><view class="staff"><view>申请时间:</view><view>{{item.creationTime}}</view><view data-event-opts="{{[['tap',[['chakan',['$0'],[[['list','',key]]]]]]]}}" bindtap="__e">查看</view></view><block wx:if="{{item.approvalStatus=='通过'||item.approvalStatus=='驳回'}}"><view class="{{['jiancha',(item.approvalStatus=='通过')?'jiancha_color':'']}}">{{'已'+item.approvalStatus+''}}</view></block></view></view><view class="implement"></view></view></view></block></view><block wx:if="{{index}}"><view class="taskadd"><view class="itembox"><view class="item_top"><view>任务申领</view><view data-event-opts="{{[['tap',[['indexs']]]]}}" bindtap="__e">x</view></view><block wx:if="{{index}}"><view class="item_content"><task-add bind:apply="__e" vue-id="e720980e-2" data-event-opts="{{[['^apply',[['apply']]]]}}" bind:__l="__l"></task-add></view></block><block wx:if="{{index2}}"><view class="item_content"><task-det bind:apply="__e" vue-id="e720980e-3" data-event-opts="{{[['^apply',[['apply']]]]}}" bind:__l="__l"></task-det></view></block></view></view></block><block wx:if="{{index2}}"><view class="taskadd"><view class="itembox2"><view class="item_top"><view>详情</view><view data-event-opts="{{[['tap',[['indexs']]]]}}" bindtap="__e">x</view></view><block wx:if="{{index2}}"><view class="item_content"><task-det vue-id="e720980e-4" cid="{{Cid}}" bind:__l="__l"></task-det></view></block></view></view></block><tabbar vue-id="e720980e-5" selected="{{2}}" bind:__l="__l"></tabbar></view>

1
unpackage/dist/dev/mp-weixin/pages/user/changePassword/changePassword.js vendored

@ -0,0 +1 @@
Component({})

2
unpackage/dist/dev/mp-weixin/pages/user/user.js vendored

@ -1,2 +1,2 @@
(global["webpackJsonp"]=global["webpackJsonp"]||[]).push([["pages/user/user"],{45:function(n,t,e){"use strict";(function(n){e(5);r(e(4));var t=r(e(46));function r(n){return n&&n.__esModule?n:{default:n}}wx.__webpack_require_UNI_MP_PLUGIN__=e,n(t.default)}).call(this,e(1)["createPage"])},46:function(n,t,e){"use strict";e.r(t);var r=e(47),u=e(51);for(var o in u)"default"!==o&&function(n){e.d(t,n,(function(){return u[n]}))}(o);e(53);var c,a=e(11),i=Object(a["default"])(u["default"],r["render"],r["staticRenderFns"],!1,null,null,null,!1,r["components"],c);i.options.__file="pages/user/user.vue",t["default"]=i.exports},47:function(n,t,e){"use strict";e.r(t);var r=e(48);e.d(t,"render",(function(){return r["render"]})),e.d(t,"staticRenderFns",(function(){return r["staticRenderFns"]})),e.d(t,"recyclableRender",(function(){return r["recyclableRender"]})),e.d(t,"components",(function(){return r["components"]}))},48:function(n,t,e){"use strict";var r;e.r(t),e.d(t,"render",(function(){return u})),e.d(t,"staticRenderFns",(function(){return c})),e.d(t,"recyclableRender",(function(){return o})),e.d(t,"components",(function(){return r}));var u=function(){var n=this,t=n.$createElement,r=(n._self._c,e(49)),u=e(50);n.$mp.data=Object.assign({},{$root:{m0:r,m1:u}})},o=!1,c=[];u._withStripped=!0},51:function(n,t,e){"use strict";e.r(t);var r=e(52),u=e.n(r);for(var o in r)"default"!==o&&function(n){e.d(t,n,(function(){return r[n]}))}(o);t["default"]=u.a},52:function(n,t,e){"use strict";(function(n){Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var e={data:function(){return{list:{}}},onLoad:function(){this.list=n.getStorageSync("user"),console.log(this.list)},methods:{changePassword:function(){n.navigateTo({url:"/pages/changePassword/changePassword"})},tuichu:function(){this.$auth.logout()}}};t.default=e}).call(this,e(1)["default"])},53:function(n,t,e){"use strict";e.r(t);var r=e(54),u=e.n(r);for(var o in r)"default"!==o&&function(n){e.d(t,n,(function(){return r[n]}))}(o);t["default"]=u.a},54:function(n,t,e){}},[[45,"common/runtime","common/vendor"]]]);
(global["webpackJsonp"]=global["webpackJsonp"]||[]).push([["pages/user/user"],{45:function(n,t,e){"use strict";(function(n){e(5);r(e(4));var t=r(e(46));function r(n){return n&&n.__esModule?n:{default:n}}wx.__webpack_require_UNI_MP_PLUGIN__=e,n(t.default)}).call(this,e(1)["createPage"])},46:function(n,t,e){"use strict";e.r(t);var r=e(47),u=e(51);for(var o in u)"default"!==o&&function(n){e.d(t,n,(function(){return u[n]}))}(o);e(53);var c,a=e(11),i=Object(a["default"])(u["default"],r["render"],r["staticRenderFns"],!1,null,null,null,!1,r["components"],c);i.options.__file="pages/user/user.vue",t["default"]=i.exports},47:function(n,t,e){"use strict";e.r(t);var r=e(48);e.d(t,"render",(function(){return r["render"]})),e.d(t,"staticRenderFns",(function(){return r["staticRenderFns"]})),e.d(t,"recyclableRender",(function(){return r["recyclableRender"]})),e.d(t,"components",(function(){return r["components"]}))},48:function(n,t,e){"use strict";var r;e.r(t),e.d(t,"render",(function(){return u})),e.d(t,"staticRenderFns",(function(){return c})),e.d(t,"recyclableRender",(function(){return o})),e.d(t,"components",(function(){return r}));var u=function(){var n=this,t=n.$createElement,r=(n._self._c,e(49)),u=e(50);n.$mp.data=Object.assign({},{$root:{m0:r,m1:u}})},o=!1,c=[];u._withStripped=!0},51:function(n,t,e){"use strict";e.r(t);var r=e(52),u=e.n(r);for(var o in r)"default"!==o&&function(n){e.d(t,n,(function(){return r[n]}))}(o);t["default"]=u.a},52:function(n,t,e){"use strict";(function(n){Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var r=function(){e.e("components/tabbar").then(function(){return resolve(e(141))}.bind(null,e)).catch(e.oe)},u={components:{tabbar:r},data:function(){return{list:{}}},onLoad:function(){this.list=n.getStorageSync("user"),console.log(this.list)},methods:{changePassword:function(){n.navigateTo({url:"/pages/changePassword/changePassword"})},tuichu:function(){this.$auth.logout()}}};t.default=u}).call(this,e(1)["default"])},53:function(n,t,e){"use strict";e.r(t);var r=e(54),u=e.n(r);for(var o in r)"default"!==o&&function(n){e.d(t,n,(function(){return r[n]}))}(o);t["default"]=u.a},54:function(n,t,e){}},[[45,"common/runtime","common/vendor"]]]);
//# sourceMappingURL=../../../.sourcemap/mp-weixin/pages/user/user.js.map

4
unpackage/dist/dev/mp-weixin/pages/user/user.json vendored

@ -3,5 +3,7 @@
"navigationBarBackgroundColor": "#317AFF",
"navigationBarTitleText": "",
"navigationBarTextStyle": "white",
"usingComponents": {}
"usingComponents": {
"tabbar": "/components/tabbar"
}
}

2
unpackage/dist/dev/mp-weixin/pages/user/user.wxml vendored

@ -1 +1 @@
<view class="page"><view class="top"><view class="box"><view class="portrait"><image src="{{$root.m0}}" alt class="_img"></image></view><view class="information"><view class="name">{{''+list.name+''}}</view><view class="organization">{{''+list.organizationName+''}}</view></view></view></view><view class="items"><view class="item"><view data-event-opts="{{[['tap',[['changePassword']]]]}}" class="text" style="flex:1;" bindtap="__e">修改密码</view><image src="{{$root.m1}}" alt class="_img"></image></view></view><view data-event-opts="{{[['tap',[['tuichu']]]]}}" class="tuichudenglu" bindtap="__e">退出登录</view></view>
<view class="page"><view class="top"><view class="box"><view class="portrait"><image src="{{$root.m0}}" alt class="_img"></image></view><view class="information"><view class="name">{{''+list.name+''}}</view><view class="organization">{{''+list.organizationName+''}}</view></view></view></view><view class="items"><view class="item"><view data-event-opts="{{[['tap',[['changePassword']]]]}}" class="text" style="flex:1;" bindtap="__e">修改密码</view><image src="{{$root.m1}}" alt class="_img"></image></view></view><view data-event-opts="{{[['tap',[['tuichu']]]]}}" class="tuichudenglu" bindtap="__e">退出登录</view><tabbar vue-id="380011e0-1" selected="{{3}}" bind:__l="__l"></tabbar></view>

4
unpackage/dist/dev/mp-weixin/project.config.json vendored

@ -13,12 +13,12 @@
}
},
"compileType": "miniprogram",
"libVersion": "2.25.2",
"libVersion": "2.26.0",
"appid": "wx762e3ccf09854482",
"projectname": "Jinan_app",
"condition": {},
"editorSetting": {
"tabIndent": "insertSpaces",
"tabSize": 2
"tabSize": 4
}
}
Loading…
Cancel
Save