事件上报
@@ -1,165 +0,0 @@
|
|||||||
<template>
|
|
||||||
<div class="AppPointsReview">
|
|
||||||
<AiTopFixed>
|
|
||||||
<div class="top-search">
|
|
||||||
<div class="left">
|
|
||||||
<u-search v-model="keyword" :clearabled="true" placeholder="请输入申请人,审批人" :show-action="false" bg-color="#F5F5F5"
|
|
||||||
search-icon-color="#999" color="#999" height="58" @search="getListInit" @clear="getListInit">
|
|
||||||
</u-search>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="top-select">
|
|
||||||
<div class="item">
|
|
||||||
<span style="color:#999;">日期筛选</span>
|
|
||||||
<!-- <span v-else>{{ $dict.getLabel('EP_handleType', handleType) }}</span> -->
|
|
||||||
<u-icon name="arrow-down" color="#666" size="28" style="margin-left: 4px" />
|
|
||||||
</div>
|
|
||||||
<div class="item">
|
|
||||||
<span style="color:#999;">事件类型</span>
|
|
||||||
<!-- <span v-else>{{ $dict.getLabel('EP_handleType', handleType) }}</span> -->
|
|
||||||
<u-icon name="arrow-down" color="#666" size="28" style="margin-left: 4px" />
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</AiTopFixed>
|
|
||||||
<div class="list-content">
|
|
||||||
<div class="item">
|
|
||||||
<div class="title-flex">
|
|
||||||
<p class="title">事件类型事件类型事件类型事件类型事件类型事件类型</p>
|
|
||||||
<div class="btn">
|
|
||||||
<div>推送精选</div>
|
|
||||||
<p>已推送</p>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="user-name">李进放<span>积分+5</span></div>
|
|
||||||
<div class="time-flex">
|
|
||||||
<span>审核通过</span>
|
|
||||||
<span>2023-03-30 09:09</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="item">
|
|
||||||
<div class="title-flex">
|
|
||||||
<p class="title">事件类型事件类型事件类型事件类型事件类型事件类型事件类型事件类型型事件类型事件类型事件类型</p>
|
|
||||||
</div>
|
|
||||||
<div class="user-name">李进放<span>积分+5</span></div>
|
|
||||||
<div class="time-flex">
|
|
||||||
<span>审核通过</span>
|
|
||||||
<span>2023-03-30 09:09</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script>
|
|
||||||
export default {
|
|
||||||
name: "AppPointsReview",
|
|
||||||
appName: "积分审核",
|
|
||||||
data() {
|
|
||||||
return {
|
|
||||||
keyword: '',
|
|
||||||
areaId: '',
|
|
||||||
areaName: '',
|
|
||||||
};
|
|
||||||
},
|
|
||||||
onShow() {
|
|
||||||
|
|
||||||
},
|
|
||||||
methods: {
|
|
||||||
getListInit() {
|
|
||||||
|
|
||||||
},
|
|
||||||
areaSelect(e) {
|
|
||||||
this.areaId = e
|
|
||||||
this.getListInit()
|
|
||||||
this.getTotal()
|
|
||||||
},
|
|
||||||
},
|
|
||||||
};
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
|
||||||
.AppPointsReview {
|
|
||||||
height: 100%;
|
|
||||||
::v-deep .AiTopFixed {
|
|
||||||
.placeholder {
|
|
||||||
.content {
|
|
||||||
padding: 0 !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
.fixed {
|
|
||||||
margin: 0 !important;
|
|
||||||
.content {
|
|
||||||
padding: 0 !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
.top-search {
|
|
||||||
padding: 20px 32px;
|
|
||||||
display: flex;
|
|
||||||
.left {
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
.top-select {
|
|
||||||
display: flex;
|
|
||||||
padding: 28px 0;
|
|
||||||
.item {
|
|
||||||
flex: 1;
|
|
||||||
padding: 0 8px;
|
|
||||||
text-align: center;
|
|
||||||
span {
|
|
||||||
display: inline-block;
|
|
||||||
font-family: PingFangSC-Medium;
|
|
||||||
font-weight: 500;
|
|
||||||
font-size: 28px;
|
|
||||||
color: #666;
|
|
||||||
line-height: 40px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
.list-content {
|
|
||||||
padding: 32px;
|
|
||||||
.item {
|
|
||||||
border-radius: 8px;
|
|
||||||
padding: 32px;
|
|
||||||
background-color: #fff;
|
|
||||||
margin-bottom: 32px;
|
|
||||||
.title-flex {
|
|
||||||
display: flex;
|
|
||||||
.title {
|
|
||||||
word-break: break-all;
|
|
||||||
font-size: 30px;
|
|
||||||
font-weight: 500;
|
|
||||||
color: #333;
|
|
||||||
line-height: 34px;
|
|
||||||
text-overflow: -o-ellipsis-lastline;
|
|
||||||
overflow: hidden;
|
|
||||||
text-overflow: ellipsis;
|
|
||||||
display: -webkit-box;
|
|
||||||
-webkit-line-clamp: 2;
|
|
||||||
line-clamp: 2;
|
|
||||||
-webkit-box-orient: vertical;
|
|
||||||
}
|
|
||||||
.btn {
|
|
||||||
text-align: right;
|
|
||||||
padding-left: 32px;
|
|
||||||
div {
|
|
||||||
width: 150px;
|
|
||||||
text-align: center;
|
|
||||||
border-radius: 4px;
|
|
||||||
line-height: 56px;
|
|
||||||
background: #1365DD;
|
|
||||||
color: #fff;
|
|
||||||
font-size: 28px;
|
|
||||||
}
|
|
||||||
p {
|
|
||||||
margin-top: 8px;
|
|
||||||
font-size: 28px;
|
|
||||||
color: #666;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
@@ -1,30 +0,0 @@
|
|||||||
<template>
|
|
||||||
<div class="detail">
|
|
||||||
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script>
|
|
||||||
export default {
|
|
||||||
name: "detail",
|
|
||||||
data() {
|
|
||||||
return {
|
|
||||||
keyword: '',
|
|
||||||
areaId: '',
|
|
||||||
areaName: '',
|
|
||||||
};
|
|
||||||
},
|
|
||||||
onShow() {
|
|
||||||
|
|
||||||
},
|
|
||||||
methods: {
|
|
||||||
},
|
|
||||||
};
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
|
||||||
.detail {
|
|
||||||
height: 100%;
|
|
||||||
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
@@ -1,154 +0,0 @@
|
|||||||
<template>
|
|
||||||
<section class="AppVote">
|
|
||||||
<AiGroup noBorder description class="mar-b32">
|
|
||||||
<u-parse :html="detail.preface"/>
|
|
||||||
</AiGroup>
|
|
||||||
<div class="voteItem" flex @click="handleDetail(row.id)" v-for="row in list" :key="row.id">
|
|
||||||
<div class="fill">
|
|
||||||
<b class="mar-b16" v-text="row.videoName"/>
|
|
||||||
<div class="color-999 line3" v-text="row.videoIntroduction"/>
|
|
||||||
</div>
|
|
||||||
<div class="thumb">
|
|
||||||
<img :src="row.imageFileUrl"/>
|
|
||||||
<span v-text="`${row.voteNumber}票`"/>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<AiGroup noBorder description>
|
|
||||||
<u-parse :html="detail.ending"/>
|
|
||||||
</AiGroup>
|
|
||||||
<u-gap height="160"/>
|
|
||||||
<weixin-login :autoShow="!user.token" :visible.sync="wxLogin" content="投票需要您授权您的微信信息" @login="getList"/>
|
|
||||||
</section>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script>
|
|
||||||
import {mapState} from "vuex"
|
|
||||||
import WeixinLogin from "./component/weixinLogin";
|
|
||||||
|
|
||||||
export default {
|
|
||||||
name: "AppVote",
|
|
||||||
components: {WeixinLogin},
|
|
||||||
appName: "“微视频”大赛",
|
|
||||||
data() {
|
|
||||||
return {
|
|
||||||
detail: {},
|
|
||||||
list: [],
|
|
||||||
wxLogin: 0,
|
|
||||||
current: 1,
|
|
||||||
total: 0
|
|
||||||
}
|
|
||||||
},
|
|
||||||
computed: {
|
|
||||||
...mapState(['user']),
|
|
||||||
},
|
|
||||||
methods: {
|
|
||||||
getDetail(retry = false) {
|
|
||||||
this.$http.post("/app/appvideovoteconfig/queryDetailByCorpId", null, {
|
|
||||||
withoutToken: !this.user.token || retry
|
|
||||||
}).then(res => {
|
|
||||||
if (res?.data) {
|
|
||||||
this.detail = res.data
|
|
||||||
}
|
|
||||||
}).catch(() => !retry && this.getList(true))
|
|
||||||
},
|
|
||||||
getList() {
|
|
||||||
const {current, total, list} = this
|
|
||||||
if (current == 1 || list.length < total) {
|
|
||||||
current == 1 && (this.list = [])
|
|
||||||
this.$http.post("/app/appvideoinfo/list", null, {
|
|
||||||
withoutToken: true,
|
|
||||||
params: {current}
|
|
||||||
}).then(res => {
|
|
||||||
if (res?.data) {
|
|
||||||
this.list = [this.list, res.data.records].flat().filter(Boolean)
|
|
||||||
this.total = res.data.total
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
},
|
|
||||||
handleDetail(id) {
|
|
||||||
if (!this.user.token) this.wxLogin++
|
|
||||||
else uni.navigateTo({url: './voteDetail?id=' + id})
|
|
||||||
}
|
|
||||||
},
|
|
||||||
onShow() {
|
|
||||||
this.current = 1
|
|
||||||
this.getDetail()
|
|
||||||
this.getList()
|
|
||||||
},
|
|
||||||
onReachBottom() {
|
|
||||||
this.current++
|
|
||||||
this.getList()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
|
||||||
.AppVote {
|
|
||||||
min-height: 100vh;
|
|
||||||
background: #fff;
|
|
||||||
|
|
||||||
.AiGroup {
|
|
||||||
width: 100%;
|
|
||||||
padding-right: 32px;
|
|
||||||
box-sizing: border-box;
|
|
||||||
}
|
|
||||||
|
|
||||||
.voteItem {
|
|
||||||
height: 240px;
|
|
||||||
border: 1px solid #CCCCCC;
|
|
||||||
border-radius: 16px;
|
|
||||||
margin: 0 32px 24px;
|
|
||||||
padding: 24px;
|
|
||||||
box-sizing: border-box;
|
|
||||||
font-family: PingFangSC;
|
|
||||||
align-items: flex-start;
|
|
||||||
|
|
||||||
b {
|
|
||||||
font-size: 34px;
|
|
||||||
color: #333333;
|
|
||||||
display: block;
|
|
||||||
line-height: 48px;
|
|
||||||
text-overflow: ellipsis;
|
|
||||||
overflow: hidden;
|
|
||||||
white-space: nowrap;
|
|
||||||
}
|
|
||||||
|
|
||||||
.line3 {
|
|
||||||
display: -webkit-box;
|
|
||||||
overflow: hidden;
|
|
||||||
-webkit-line-clamp: 3;
|
|
||||||
-webkit-box-orient: vertical;
|
|
||||||
}
|
|
||||||
|
|
||||||
.thumb {
|
|
||||||
position: relative;
|
|
||||||
flex-shrink: 0;
|
|
||||||
margin-left: 24px;
|
|
||||||
width: 192px;
|
|
||||||
height: 192px;
|
|
||||||
border-radius: 8px;
|
|
||||||
overflow: hidden;
|
|
||||||
background-repeat: no-repeat;
|
|
||||||
background-size: 100%;
|
|
||||||
background-color: #eee;
|
|
||||||
|
|
||||||
& > span {
|
|
||||||
position: absolute;
|
|
||||||
right: 0;
|
|
||||||
top: 0;
|
|
||||||
padding: 0 8px;
|
|
||||||
line-height: 44px;
|
|
||||||
background: #FF883C;
|
|
||||||
color: #fff;
|
|
||||||
z-index: 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
& > img {
|
|
||||||
width: 100%;
|
|
||||||
height: 100%;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
@@ -1,72 +0,0 @@
|
|||||||
<template>
|
|
||||||
<section class="weixinLogin">
|
|
||||||
<u-modal v-model="show" :content="content" confirm-text="去授权" cancel-text="仅浏览" show-cancel-button :show-title="false"
|
|
||||||
@confirm="handleConfirm" @cancel="handleCancel"/>
|
|
||||||
</section>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script>
|
|
||||||
import {mapActions, mapState} from "vuex"
|
|
||||||
|
|
||||||
export default {
|
|
||||||
name: "weixinLogin",
|
|
||||||
props: {
|
|
||||||
content: {default: "是否要进行微信授权?"},
|
|
||||||
autoShow: Boolean,
|
|
||||||
visible: {default: ""}
|
|
||||||
},
|
|
||||||
computed: {
|
|
||||||
...mapState(['user']),
|
|
||||||
wxCode: v => v.$route.query.code,
|
|
||||||
},
|
|
||||||
data() {
|
|
||||||
return {
|
|
||||||
show: false
|
|
||||||
}
|
|
||||||
},
|
|
||||||
methods: {
|
|
||||||
...mapActions(['getWechatToken', 'getCode']),
|
|
||||||
handleConfirm() {
|
|
||||||
this.$http.get("/app/appdvcpconfig/getMpAppid", {withoutToken: true}).then(res => {
|
|
||||||
if (res?.code == 0 && res?.data) {
|
|
||||||
this.getCode({scope: "snsapi_userinfo", appid: res.data})
|
|
||||||
}
|
|
||||||
})
|
|
||||||
},
|
|
||||||
handleCancel() {
|
|
||||||
this.show = false
|
|
||||||
},
|
|
||||||
autoLogin() {
|
|
||||||
if (!this.user.token) this.getWechatToken({code: this.wxCode}).then(() => this.$emit("login")).catch(() => {
|
|
||||||
setTimeout(() => uni.showModal({
|
|
||||||
content: "是否要重新加载页面?",
|
|
||||||
success: res => {
|
|
||||||
if (!!res?.confirm) {
|
|
||||||
const redirect = this.$qs.parseUrl(location.href)
|
|
||||||
delete redirect.query.code
|
|
||||||
delete redirect.query.state
|
|
||||||
location.replace(this.$qs.stringifyUrl(redirect))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}), 500)
|
|
||||||
})
|
|
||||||
},
|
|
||||||
},
|
|
||||||
watch: {
|
|
||||||
autoShow: {
|
|
||||||
immediate: true,
|
|
||||||
handler(v) {
|
|
||||||
this.wxCode ? this.autoLogin() : this.show = !!v
|
|
||||||
}
|
|
||||||
},
|
|
||||||
visible(v) {
|
|
||||||
this.show = !!v
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
|
||||||
.weixinLogin {
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
@@ -1,79 +0,0 @@
|
|||||||
<template>
|
|
||||||
<section class="voteDetail">
|
|
||||||
<AiItem top-label :label="detail.videoName" :border="false" labelBold>
|
|
||||||
<u-parse class="mar-b8" :html="detail.videoIntroduction"/>
|
|
||||||
<video :src="detail.videoFileUrl" :poster="detail.imageFileUrl"/>
|
|
||||||
</AiItem>
|
|
||||||
<AiBottomBtn background="#fff">
|
|
||||||
<div flex class="pad-l32 pad-r16 pad-b16 pad-t16">
|
|
||||||
<AiHighlight class="fill color-999" content="当前票数:@v" :value="detail.voteNumber" color="#FF6900"/>
|
|
||||||
<div class="text circle mar-l16" :class="{disabled:canotVote}" @click="handleVote">投票</div>
|
|
||||||
</div>
|
|
||||||
</AiBottomBtn>
|
|
||||||
</section>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script>
|
|
||||||
import {mapState} from "vuex"
|
|
||||||
|
|
||||||
export default {
|
|
||||||
name: "voteDetail",
|
|
||||||
appName: "投票详情",
|
|
||||||
computed: {
|
|
||||||
...mapState(['user']),
|
|
||||||
canotVote: v => !!v.user.token && v.detail.isVote == '0'
|
|
||||||
},
|
|
||||||
data() {
|
|
||||||
return {
|
|
||||||
detail: {},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
methods: {
|
|
||||||
getDetail() {
|
|
||||||
const {id} = this.$route.query
|
|
||||||
this.$http.post("/app/appvideoinfo/queryDetailById", null, {params: {id}, withoutToken: !this.user.token}).then(res => {
|
|
||||||
if (res?.data) {
|
|
||||||
this.detail = res.data
|
|
||||||
document.title = this.detail.videoName
|
|
||||||
}
|
|
||||||
})
|
|
||||||
},
|
|
||||||
handleVote() {
|
|
||||||
if (!this.canotVote) {
|
|
||||||
const {id} = this.$route.query
|
|
||||||
this.$http.post("/app/appvideovoteinfo/voteByVideoId", null, {
|
|
||||||
throttle: 1000,
|
|
||||||
params: {id}
|
|
||||||
}).then(res => {
|
|
||||||
if (res?.code == 0) {
|
|
||||||
this.$u.toast("投票成功!")
|
|
||||||
this.getDetail()
|
|
||||||
}
|
|
||||||
}).catch(err => this.$u.toast(err || "投票失败!"))
|
|
||||||
}
|
|
||||||
},
|
|
||||||
},
|
|
||||||
onShow() {
|
|
||||||
this.getDetail()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
|
||||||
.voteDetail {
|
|
||||||
background: #F3F6F9;
|
|
||||||
min-height: 100vh;
|
|
||||||
|
|
||||||
::v-deep.disabled {
|
|
||||||
filter: grayscale(100%);
|
|
||||||
}
|
|
||||||
|
|
||||||
::v-deep video {
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
::v-deep.topLabel {
|
|
||||||
padding-right: 20px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
@@ -27,12 +27,12 @@
|
|||||||
<img src="./img/fail-icon.png" alt="" class="fail-img">
|
<img src="./img/fail-icon.png" alt="" class="fail-img">
|
||||||
</div>
|
</div>
|
||||||
<div class="item item-right" v-else>
|
<div class="item item-right" v-else>
|
||||||
<div class="content">
|
<div class="content">
|
||||||
<span></span>
|
<span></span>
|
||||||
<p>{{item.content}}</p>
|
<p>{{item.content}}</p>
|
||||||
|
</div>
|
||||||
|
<img src="./img/user-img.png" alt="" class="user-img">
|
||||||
</div>
|
</div>
|
||||||
<img src="./img/user-img.png" alt="" class="user-img">
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
202
src/project/wuxi/AppHandSnapshot/Add.vue
Normal file
@@ -0,0 +1,202 @@
|
|||||||
|
<template>
|
||||||
|
<div class="Add">
|
||||||
|
<div class="contents">
|
||||||
|
<u-form :model="forms" ref="uForm" label-width="auto" :border-bottom="false">
|
||||||
|
<u-form-item label="事件类型" prop="groupName" required :border-bottom="false" right-icon="arrow-right">
|
||||||
|
<span @click="show = true" class="right-span" :style="forms.groupName ? '' : 'color:#999;'">{{ forms.groupName || '请选择事件类型' }}</span>
|
||||||
|
<u-select v-model="show" :list="myList" value-name="id" label-name="groupName" @confirm="selectStatus"></u-select>
|
||||||
|
</u-form-item>
|
||||||
|
<u-form-item label="事件描述" prop="content" required :border-bottom="false" label-position="top" class="contents">
|
||||||
|
<u-input v-model="forms.content" placeholder="请输入事件描述..." type="textarea" auto-height height="100" maxlength="500"/>
|
||||||
|
</u-form-item>
|
||||||
|
|
||||||
|
<div class="line"></div>
|
||||||
|
<u-form-item label="上报位置" prop="mapInfo" required :border-bottom="false" right-icon="arrow-right" class="border">
|
||||||
|
<span @click="show = true" class="right-span" :style="forms.mapInfo.name ? '' : 'color:#999;'">{{ forms.mapInfo.name || '请选择上报位置' }}</span>
|
||||||
|
</u-form-item>
|
||||||
|
<u-form-item label="所属网格" prop="girdName" required :border-bottom="false">
|
||||||
|
<AiPagePicker type="gird" v-model="forms.girdId" @change="confirmGird" valueObj nodeKey="id" formType="2" class="right-span">
|
||||||
|
<AiMore v-model="forms.girdName" placeholder="请选择所属网格"/>
|
||||||
|
</AiPagePicker>
|
||||||
|
</u-form-item>
|
||||||
|
|
||||||
|
<div class="line"></div>
|
||||||
|
<u-form-item label="图片上传(最多9张)" prop="files" :border-bottom="false" class="avatars" label-position="top">
|
||||||
|
<AiUploader :def.sync="forms.files" multiple placeholder="上传图片" :limit="9" action="/admin/file/add2"></AiUploader>
|
||||||
|
</u-form-item>
|
||||||
|
|
||||||
|
<div class="line"></div>
|
||||||
|
<u-form-item label="姓名" prop="name" required :border-bottom="false" class="border">
|
||||||
|
<u-input v-model="forms.name" placeholder="请输入姓名" />
|
||||||
|
</u-form-item>
|
||||||
|
<u-form-item label="联系方式" prop="phone" required :border-bottom="false" >
|
||||||
|
<u-input v-model="forms.phone" placeholder="请输入联系方式" />
|
||||||
|
</u-form-item>
|
||||||
|
|
||||||
|
<div class="line"></div>
|
||||||
|
|
||||||
|
</u-form>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="btn" @click="confirm">
|
||||||
|
<span>提交</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
export default {
|
||||||
|
name: 'Add',
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
forms: {
|
||||||
|
groupName: '',
|
||||||
|
groupId: '',
|
||||||
|
content: '',
|
||||||
|
mapInfo: {},
|
||||||
|
girdId: '',
|
||||||
|
girdName: '',
|
||||||
|
files: [],
|
||||||
|
name: '',
|
||||||
|
phone: ''
|
||||||
|
},
|
||||||
|
flag: false,
|
||||||
|
show: false,
|
||||||
|
myList: []
|
||||||
|
}
|
||||||
|
},
|
||||||
|
onLoad() {
|
||||||
|
this.typeList()
|
||||||
|
},
|
||||||
|
onShow() {
|
||||||
|
document.title = '事件添加'
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
typeList() {
|
||||||
|
this.$http.post(`/app/appclapeventgroup/list`, null, {
|
||||||
|
params: {
|
||||||
|
size: 9999,
|
||||||
|
},
|
||||||
|
}).then((res) => {
|
||||||
|
if (res.code == 0) {
|
||||||
|
this.myList = res.data.records
|
||||||
|
this.$forceUpdate()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
},
|
||||||
|
selectStatus(e) {
|
||||||
|
this.forms.groupName = e[0].label
|
||||||
|
this.forms.groupId = e[0].value
|
||||||
|
},
|
||||||
|
confirmGird(v) {
|
||||||
|
this.forms.girdId = v.id
|
||||||
|
this.forms.girdName = v.girdName
|
||||||
|
},
|
||||||
|
|
||||||
|
confirm() {
|
||||||
|
// if (this.status == 1 && !this.forms.name) {
|
||||||
|
// //return this.$u.toast('请选择转交对象')
|
||||||
|
// }
|
||||||
|
|
||||||
|
},
|
||||||
|
|
||||||
|
},
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped lang="scss">
|
||||||
|
.Add {
|
||||||
|
height: 100%;
|
||||||
|
|
||||||
|
.contents {
|
||||||
|
padding-bottom: 140px;
|
||||||
|
|
||||||
|
::v-deep .u-form {
|
||||||
|
.u-form-item {
|
||||||
|
padding: 0 45px !important;
|
||||||
|
|
||||||
|
.u-form-item__body {
|
||||||
|
.u-form-item--right__content__slot {
|
||||||
|
padding-bottom: 0;
|
||||||
|
|
||||||
|
.u-input {
|
||||||
|
text-align: right !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.u-form-item:first-child {
|
||||||
|
.u-form-item__body {
|
||||||
|
border-bottom: 1px solid #ddd;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.line {
|
||||||
|
height: 24px;
|
||||||
|
background: #f3f6f9;
|
||||||
|
}
|
||||||
|
|
||||||
|
.contents {
|
||||||
|
padding-bottom: 20px !important;
|
||||||
|
|
||||||
|
.u-form-item__body {
|
||||||
|
.u-form-item--right__content__slot {
|
||||||
|
.u-input {
|
||||||
|
text-align: left !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.avatars {
|
||||||
|
padding-bottom: 20px !important;
|
||||||
|
|
||||||
|
.u-form-item__body {
|
||||||
|
.default {
|
||||||
|
width: 160px;
|
||||||
|
height: 160px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.border {
|
||||||
|
::v-deep .u-form-item__body {
|
||||||
|
border-bottom: 1px solid #ddd;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.btn {
|
||||||
|
position: fixed;
|
||||||
|
bottom: 0;
|
||||||
|
width: 100%;
|
||||||
|
box-sizing: border-box;
|
||||||
|
background: #3975c6;
|
||||||
|
padding: 34px 0;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 32px;
|
||||||
|
font-weight: 500;
|
||||||
|
color: #ffffff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.right-span {
|
||||||
|
display: inline-block;
|
||||||
|
width: 100%;
|
||||||
|
text-align: right;
|
||||||
|
|
||||||
|
::v-deep .u-icon__label {
|
||||||
|
font-size: 28px!important;
|
||||||
|
}
|
||||||
|
|
||||||
|
::v-deep .uicon-arrow-right{
|
||||||
|
color: #c0c4cc!important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
::v-deep .uni-input-placeholder {
|
||||||
|
color: #999!important;
|
||||||
|
font-size: 28px!important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
147
src/project/wuxi/AppHandSnapshot/AppHandSnapshot.vue
Normal file
@@ -0,0 +1,147 @@
|
|||||||
|
<template>
|
||||||
|
<div class="AppHandSnapshot">
|
||||||
|
<component v-if="refresh && isGridMember" :is="component" @change="onChange" :params="params"/>
|
||||||
|
<div class="tabs" v-if="isTab && isGridMember">
|
||||||
|
<div class="item" @click="tabClick(index, item.component)" v-for="(item, index) in tabs" :key="index">
|
||||||
|
<img :src="tabIndex == index ? item.activeImg : item.img" alt=""/>
|
||||||
|
<p :class="tabIndex == index ? 'color-3267F0' : ''">{{ item.text }}</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div v-if="!isGridMember" class="empty">
|
||||||
|
<img src="./components/img/no-admin.png" alt="">
|
||||||
|
<p>没有网格员权限<br/>无法查看事件上报信息哦~</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import List from './List.vue'
|
||||||
|
import Statistics from './Statistics.vue'
|
||||||
|
import {mapState} from 'vuex'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
name: 'AppHandSnapshot',
|
||||||
|
appName: '事件上报',
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
component: 'List',
|
||||||
|
params: {},
|
||||||
|
refresh: true,
|
||||||
|
tabIndex: 0,
|
||||||
|
tabs: [
|
||||||
|
{
|
||||||
|
img: require('./components/img/handle-icon.png'),
|
||||||
|
activeImg: require('./components/img/handle-icon-active.png'),
|
||||||
|
text: '办理',
|
||||||
|
component: 'List',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
img: require('./components/img/statistics-icon.png'),
|
||||||
|
activeImg: require('./components/img/statistics-icon-active.png'),
|
||||||
|
text: '统计',
|
||||||
|
component: 'Statistics',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
isTab: true,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
...mapState(['user']),
|
||||||
|
isGridMember() {
|
||||||
|
return this.user.girdCheckType > 0
|
||||||
|
}
|
||||||
|
},
|
||||||
|
components: {
|
||||||
|
List,
|
||||||
|
Statistics,
|
||||||
|
Set,
|
||||||
|
},
|
||||||
|
|
||||||
|
methods: {
|
||||||
|
onChange(e) {
|
||||||
|
this.params = e.params
|
||||||
|
this.component = e.type
|
||||||
|
},
|
||||||
|
tabClick(index, component) {
|
||||||
|
this.tabIndex = index
|
||||||
|
this.component = component
|
||||||
|
this.refresh = false
|
||||||
|
this.$nextTick(() => {
|
||||||
|
this.refresh = true
|
||||||
|
})
|
||||||
|
}
|
||||||
|
},
|
||||||
|
onShow() {
|
||||||
|
document.title = '事件上报'
|
||||||
|
uni.$on('hideTab', () => {
|
||||||
|
this.isTab = false
|
||||||
|
})
|
||||||
|
uni.$on('showTab', () => {
|
||||||
|
this.isTab = true
|
||||||
|
})
|
||||||
|
|
||||||
|
},
|
||||||
|
onReachBottom() {
|
||||||
|
if (!this.tabIndex) {
|
||||||
|
uni.$emit('nextList')
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style lang="scss" scoped>
|
||||||
|
.AppHandSnapshot {
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tabs {
|
||||||
|
width: 100%;
|
||||||
|
height: 98px;
|
||||||
|
background: #fff;
|
||||||
|
border-top: 1px solid #ddd;
|
||||||
|
position: fixed;
|
||||||
|
bottom: 0;
|
||||||
|
left: 0;
|
||||||
|
display: flex;
|
||||||
|
|
||||||
|
.item {
|
||||||
|
flex: 1;
|
||||||
|
text-align: center;
|
||||||
|
|
||||||
|
img {
|
||||||
|
width: 56px;
|
||||||
|
height: 56px;
|
||||||
|
margin-top: 8px;
|
||||||
|
}
|
||||||
|
|
||||||
|
p {
|
||||||
|
font-size: 22px;
|
||||||
|
font-family: PingFangSC-Medium, PingFang SC;
|
||||||
|
font-weight: 500;
|
||||||
|
color: #c4cad4;
|
||||||
|
line-height: 8px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.color-3267F0 {
|
||||||
|
color: #3267f0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.empty {
|
||||||
|
text-align: center;
|
||||||
|
|
||||||
|
img {
|
||||||
|
width: 282px;
|
||||||
|
height: 306px;
|
||||||
|
margin: 136px auto 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
p {
|
||||||
|
font-size: 28px;
|
||||||
|
font-family: PingFangSC-Regular, PingFang SC;
|
||||||
|
color: #999;
|
||||||
|
line-height: 40px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
242
src/project/wuxi/AppHandSnapshot/Content.vue
Normal file
@@ -0,0 +1,242 @@
|
|||||||
|
<template>
|
||||||
|
<div class="Transfer">
|
||||||
|
<div class="contents">
|
||||||
|
<u-form :model="forms" ref="uForm" label-width="auto" :border-bottom="false">
|
||||||
|
<u-form-item label="转交给" prop="status" required :border-bottom="false" right-icon="arrow-right" class="first-form" v-if="status == 1">
|
||||||
|
<u-input v-model="forms.name" placeholder="请选择转交对象" @click="toSelectUser" disabled/>
|
||||||
|
</u-form-item>
|
||||||
|
<u-form-item label="事件分类" prop="groupName" required :border-bottom="false" right-icon="arrow-right" v-if="status != 1">
|
||||||
|
<!-- <u-input v-model="forms.groupName" placeholder="请选择事件分类" /> -->
|
||||||
|
<span @click="show = true" class="right-span" :style="forms.groupName ? '' : 'color:#999;'">{{ forms.groupName || '请选择事件分类' }}</span>
|
||||||
|
|
||||||
|
<u-select v-model="show" :list="myList" value-name="id" label-name="groupName" @confirm="selectStatus"></u-select>
|
||||||
|
</u-form-item>
|
||||||
|
|
||||||
|
<u-form-item :label="status == 3 ? '办结意见' : status == 2 ? '拒绝受理意见' : '办理意见'" prop="content" required :border-bottom="false" label-position="top"
|
||||||
|
class="contents">
|
||||||
|
<u-input v-model="forms.content" :placeholder="status == 2 ? '请写下拒绝受理意见…' : '请写下你的办结意见...'" type="textarea" auto-height height="100" maxlength="500"/>
|
||||||
|
</u-form-item>
|
||||||
|
|
||||||
|
<div class="line"></div>
|
||||||
|
|
||||||
|
<u-form-item label="图片上传(最多9张)" prop="files" :border-bottom="false" class="avatars" label-position="top">
|
||||||
|
<AiUploader :def.sync="forms.files" multiple placeholder="上传图片" :limit="9" action="/admin/file/add2"></AiUploader>
|
||||||
|
</u-form-item>
|
||||||
|
|
||||||
|
</u-form>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="btn" v-if="this.status == 1" @click="confirm">
|
||||||
|
<span>转交事件</span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="btn" v-if="this.status == 2" @click="confirm">
|
||||||
|
<span>拒绝受理</span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="btn" v-if="this.status == 3" @click="confirm">
|
||||||
|
<span>我已办结</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
export default {
|
||||||
|
name: 'Content',
|
||||||
|
components: {},
|
||||||
|
props: {},
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
forms: {
|
||||||
|
groupName: '',
|
||||||
|
groupId: '',
|
||||||
|
content: '',
|
||||||
|
files: [],
|
||||||
|
name: ''
|
||||||
|
},
|
||||||
|
flag: false,
|
||||||
|
show: false,
|
||||||
|
status: '', //1转交 2拒绝受理 3我已办结
|
||||||
|
myList: [],
|
||||||
|
id: '',
|
||||||
|
selectUser: {},
|
||||||
|
titleList: ['', '转交事件', '拒绝受理', '我已办结']
|
||||||
|
}
|
||||||
|
},
|
||||||
|
onLoad(option) {
|
||||||
|
this.status = option.status
|
||||||
|
this.id = option.id
|
||||||
|
this.forms.groupId = option.groupId
|
||||||
|
this.forms.groupName = option.groupName
|
||||||
|
this.typeList()
|
||||||
|
uni.$on('pagePicker:custom', (res) => {
|
||||||
|
this.selectUser = res
|
||||||
|
if (res.name) {
|
||||||
|
this.forms.name = res.name
|
||||||
|
} else {
|
||||||
|
this.forms.name = res.girdName
|
||||||
|
}
|
||||||
|
})
|
||||||
|
},
|
||||||
|
onShow() {
|
||||||
|
document.title = this.titleList[this.status]
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
|
||||||
|
typeList() {
|
||||||
|
this.$http.post(`/app/appclapeventgroup/list`, null, {
|
||||||
|
params: {
|
||||||
|
size: 9999,
|
||||||
|
},
|
||||||
|
})
|
||||||
|
.then((res) => {
|
||||||
|
if (res.code == 0) {
|
||||||
|
this.myList = res.data.records
|
||||||
|
this.$forceUpdate()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
},
|
||||||
|
|
||||||
|
confirm() {
|
||||||
|
if (this.status == 1 && !this.forms.name) {
|
||||||
|
return this.$u.toast('请选择转交对象')
|
||||||
|
}
|
||||||
|
if (this.status != 1 && !this.forms.groupName) {
|
||||||
|
return this.$u.toast('请选择分类')
|
||||||
|
}
|
||||||
|
if (this.status != 1 && !this.forms.content) {
|
||||||
|
return this.$u.toast('请输入意见')
|
||||||
|
}
|
||||||
|
this.submit()
|
||||||
|
},
|
||||||
|
submit() { //status 1转交 2拒绝受理 3我已办结
|
||||||
|
var url = '', successText = '', params = ''
|
||||||
|
if (this.status == 1) {
|
||||||
|
url = `/app/appclapeventinfo/transfer`
|
||||||
|
successText = '转交成功'
|
||||||
|
params = {
|
||||||
|
...this.forms,
|
||||||
|
girdId: this.selectUser.id,
|
||||||
|
girdName: this.selectUser.girdName,
|
||||||
|
}
|
||||||
|
if (this.selectUser.name) { //选择的网格员
|
||||||
|
params.girdId = this.selectUser.girdId
|
||||||
|
params.girdMemberId = this.selectUser.id
|
||||||
|
params.girdMemberName = this.selectUser.name
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (this.status == 2) {
|
||||||
|
url = `/app/appclapeventinfo/refuse`
|
||||||
|
successText = '拒绝成功'
|
||||||
|
params = {...this.forms}
|
||||||
|
}
|
||||||
|
if (this.status == 3) {
|
||||||
|
url = `/app/appclapeventinfo/finishByGirdMember`
|
||||||
|
successText = '办结成功'
|
||||||
|
params = {...this.forms}
|
||||||
|
}
|
||||||
|
params.id = this.id
|
||||||
|
this.$http.post(url, params).then((res) => {
|
||||||
|
if (res.code == 0) {
|
||||||
|
this.$u.toast(successText)
|
||||||
|
uni.$emit('updateDeatil')
|
||||||
|
uni.$emit('getListInit')
|
||||||
|
setTimeout(() => {
|
||||||
|
if (this.status == 1) {
|
||||||
|
uni.navigateBack({delta: 2})
|
||||||
|
} else {
|
||||||
|
uni.navigateBack()
|
||||||
|
}
|
||||||
|
}, 600)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
},
|
||||||
|
selectStatus(e) {
|
||||||
|
this.forms.groupName = e[0].label
|
||||||
|
this.forms.groupId = e[0].value
|
||||||
|
},
|
||||||
|
toSelectUser() {
|
||||||
|
uni.navigateTo({url: '../AppGridManagement/selectGridMember'})
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped lang="scss">
|
||||||
|
.Transfer {
|
||||||
|
height: 100%;
|
||||||
|
|
||||||
|
.contents {
|
||||||
|
padding-bottom: 140px;
|
||||||
|
|
||||||
|
::v-deep .u-form {
|
||||||
|
.u-form-item {
|
||||||
|
padding: 0 45px !important;
|
||||||
|
|
||||||
|
.u-form-item__body {
|
||||||
|
.u-form-item--right__content__slot {
|
||||||
|
padding-bottom: 0;
|
||||||
|
|
||||||
|
.u-input {
|
||||||
|
text-align: right !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.u-form-item:first-child {
|
||||||
|
.u-form-item__body {
|
||||||
|
border-bottom: 1px solid #ddd;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.line {
|
||||||
|
height: 24px;
|
||||||
|
background: #f3f6f9;
|
||||||
|
}
|
||||||
|
|
||||||
|
.contents {
|
||||||
|
padding-bottom: 20px !important;
|
||||||
|
|
||||||
|
.u-form-item__body {
|
||||||
|
.u-form-item--right__content__slot {
|
||||||
|
.u-input {
|
||||||
|
text-align: left !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.avatars {
|
||||||
|
padding-bottom: 20px !important;
|
||||||
|
|
||||||
|
.u-form-item__body {
|
||||||
|
.default {
|
||||||
|
width: 160px;
|
||||||
|
height: 160px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.btn {
|
||||||
|
position: fixed;
|
||||||
|
bottom: 0;
|
||||||
|
width: 100%;
|
||||||
|
box-sizing: border-box;
|
||||||
|
background: #3975c6;
|
||||||
|
padding: 34px 0;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 32px;
|
||||||
|
font-weight: 500;
|
||||||
|
color: #ffffff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.right-span {
|
||||||
|
display: inline-block;
|
||||||
|
width: 100%;
|
||||||
|
text-align: right;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
499
src/project/wuxi/AppHandSnapshot/Detail.vue
Normal file
@@ -0,0 +1,499 @@
|
|||||||
|
<template>
|
||||||
|
<div class="Detail">
|
||||||
|
<div class="header-top">
|
||||||
|
<div class="avatars" v-if="data.name">{{ data.name.substring(data.name.length, data.name.length - 2) }}</div>
|
||||||
|
|
||||||
|
<div class="right">
|
||||||
|
<div class="names">{{ data.name }}的上报</div>
|
||||||
|
|
||||||
|
<div class="times">{{ data.createTime }}</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="header-middle">
|
||||||
|
<div class="titles">{{ data.content }}</div>
|
||||||
|
|
||||||
|
<span class="status status0" :class="detailStatus.cls" v-if="data.eventStatus"> {{ detailStatus.label }}</span>
|
||||||
|
|
||||||
|
<div class="card">
|
||||||
|
<span class="card-left">事件来源</span>
|
||||||
|
<span class="card-right">{{ data.groupName }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="card">
|
||||||
|
<span class="card-left">事件类型</span>
|
||||||
|
<span class="card-right">{{ data.groupName }}</span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="card">
|
||||||
|
<span class="card-left">所属网格</span>
|
||||||
|
<span class="card-right">{{ data.girdName }}</span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="card">
|
||||||
|
<span class="card-left">联系方式</span>
|
||||||
|
<span class="card-right">
|
||||||
|
<span> {{ data.phone }}</span>
|
||||||
|
<u-icon name="phone-fill" color="#3D94FB" @click="callPhone(data.phone)"></u-icon>
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="card">
|
||||||
|
<span class="card-left">上报地址</span>
|
||||||
|
<span class="card-right">
|
||||||
|
<span>{{ data.address }}</span>
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- 暂时先去掉 -->
|
||||||
|
|
||||||
|
<!-- <div class="card">
|
||||||
|
<span class="card-left">上报来源</span>
|
||||||
|
<span class="card-right">三角湖居民社群 李毅 小程序填报三角湖居民社群 李毅 小程序填报三角湖居民社群 李毅 小程序填报</span>
|
||||||
|
</div> -->
|
||||||
|
|
||||||
|
<div class="cards">
|
||||||
|
<span class="card-left" style="color:#999">照片</span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<img :src="item.url" alt="" v-for="(item, i) in data.files" :key="i" @click="previewImage(data.files, item.url)"/>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="header-bottom">
|
||||||
|
<div class="line"></div>
|
||||||
|
|
||||||
|
<div class="plan">
|
||||||
|
<div class="nav">
|
||||||
|
<span>办理进度</span>
|
||||||
|
<span> ({{ detailStatus.label }})</span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="cards" v-for="(item, index) in process" :key="index">
|
||||||
|
<div class="cardss">
|
||||||
|
<div class="cardss-left">
|
||||||
|
<span v-text="item.avatar"/>
|
||||||
|
</div>
|
||||||
|
<div class="cardss-right">
|
||||||
|
<div class="cardsss-right-left">
|
||||||
|
<div class="cardssss-right-left-top">
|
||||||
|
<span v-text="item.systemExplain"/>
|
||||||
|
<div style="color: #2ea222; font-size: 16px; margin-top: 5px" v-text="item.statusLabel"/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="cardees-right-right">{{ item.doTime }}</div>
|
||||||
|
</div>
|
||||||
|
<div class="lines"/>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="cardes-msg-top" v-if="item.doExplain">{{ item.doExplain }}</div>
|
||||||
|
|
||||||
|
<div class="imgs">
|
||||||
|
<img :src="e.url" alt="" v-for="(e, index) in item.files" :key="index" @click="previewImage(item.files, e.url)"/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="fixedBtn">
|
||||||
|
<div class="status00" v-if="data.eventStatus == 0">
|
||||||
|
<div class="columns border-r" @click="toContent(1)">
|
||||||
|
<!-- <img src="./components/img/zhuanjiao.png" alt="" /> -->
|
||||||
|
<span class="hint">转交事件</span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="columns" @click="toContent(2)">
|
||||||
|
<!-- <img src="./components/img/jujue.png" alt="" /> -->
|
||||||
|
<span class="hint">拒绝受理</span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="doIt" @click="doItShow = true">我来受理</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="endDoIt" v-if="data.eventStatus == 1 && data.rightType == 0" @click="toContent(3)">前往办理</div>
|
||||||
|
</div>
|
||||||
|
<AiEvaluation v-show="false" v-model="evaluation" :bid="data.id"/>
|
||||||
|
<u-modal v-model="doItShow" :mask-close-able="true" z-index="99" content="确定受理该事件?" :show-cancel-button="true" @confirm="doThings"></u-modal>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import {mapState} from 'vuex'
|
||||||
|
export default {
|
||||||
|
name: 'Detail',
|
||||||
|
props: {},
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
data: {},
|
||||||
|
id: '',
|
||||||
|
doItShow: false,
|
||||||
|
evaluation: {}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
...mapState(['user']),
|
||||||
|
detailStatus: v => {
|
||||||
|
const status = !v.evaluation.id ? v.data.eventStatus : 'evaluation'
|
||||||
|
return {
|
||||||
|
cls: 'status' + status,
|
||||||
|
label: !v.evaluation.id ? v.$dict.getLabel('clapEventStatus', v.data.eventStatus) : "已评价"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
process() {
|
||||||
|
const getAvatar = str => str?.substring(str?.length, str?.length - 2)
|
||||||
|
const list = this.data.processList.map(e => ({
|
||||||
|
...e,
|
||||||
|
avatar: getAvatar(e.girdMemberName),
|
||||||
|
statusLabel: this.$dict.getLabel('clapDoStatus', e.doStatus)
|
||||||
|
}))
|
||||||
|
if (this.evaluation.id) {
|
||||||
|
const {id, createUserName, score, createTime: doTime, content: doExplain} = this.evaluation
|
||||||
|
list.splice(0, 0, {
|
||||||
|
id, doTime, doExplain,
|
||||||
|
statusLabel: `${score}星评价`,
|
||||||
|
avatar: getAvatar(createUserName),
|
||||||
|
systemExplain: `${createUserName}完成评价`
|
||||||
|
})
|
||||||
|
}
|
||||||
|
return list
|
||||||
|
}
|
||||||
|
},
|
||||||
|
watch: {},
|
||||||
|
onLoad(o) {
|
||||||
|
this.id = o.id
|
||||||
|
this.$dict.load('realityStatus', 'clapDoStatus').then(() => {
|
||||||
|
this.getDetail()
|
||||||
|
})
|
||||||
|
|
||||||
|
uni.$on('updateDeatil', () => {
|
||||||
|
this.getDetail()
|
||||||
|
})
|
||||||
|
},
|
||||||
|
onShow() {
|
||||||
|
document.title = this.user.corpId == 'wpytYEDgAACQq2uZ5x54MvlJ9fgvSPXQ' ? '微心愿' : '随手拍'
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
getDetail() {
|
||||||
|
this.$http.post(`/app/appclapeventinfo/queryDetailById?id=${this.id}`).then((res) => {
|
||||||
|
if (res?.data) {
|
||||||
|
this.data = res.data
|
||||||
|
}
|
||||||
|
})
|
||||||
|
},
|
||||||
|
|
||||||
|
callPhone(phone) {
|
||||||
|
uni.makePhoneCall({phoneNumber: phone})
|
||||||
|
},
|
||||||
|
|
||||||
|
doThings() {
|
||||||
|
this.$http.post(`/app/appclapeventinfo/acceptance?id=${this.id}`).then((res) => {
|
||||||
|
if (res.code == 0) {
|
||||||
|
this.getDetail()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
},
|
||||||
|
|
||||||
|
toContent(status) {
|
||||||
|
uni.navigateTo({url: `./Content?status=${status}&groupId=${this.data.groupId}&groupName=${this.data.groupName}&id=${this.id}`})
|
||||||
|
},
|
||||||
|
previewImage(images, img) {
|
||||||
|
uni.previewImage({
|
||||||
|
urls: images.map(v => v.url),
|
||||||
|
current: img
|
||||||
|
})
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped lang="scss">
|
||||||
|
uni-page-body {
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.Detail {
|
||||||
|
height: 100%;
|
||||||
|
background: #fff;
|
||||||
|
|
||||||
|
.header-top {
|
||||||
|
display: flex;
|
||||||
|
margin: 26px 0 14px 0;
|
||||||
|
padding: 0 32px;
|
||||||
|
|
||||||
|
.avatars {
|
||||||
|
width: 80px;
|
||||||
|
height: 80px;
|
||||||
|
line-height: 80px;
|
||||||
|
background: #3975c6;
|
||||||
|
border-radius: 50%;
|
||||||
|
color: #fff;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 28px;
|
||||||
|
font-weight: 500;
|
||||||
|
margin-right: 16px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.right {
|
||||||
|
.names {
|
||||||
|
font-size: 32px;
|
||||||
|
font-weight: 500;
|
||||||
|
}
|
||||||
|
|
||||||
|
.times {
|
||||||
|
margin-top: 10px;
|
||||||
|
font-size: 28px;
|
||||||
|
color: #999999;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.header-middle {
|
||||||
|
padding: 0 32px 10px 32px;
|
||||||
|
|
||||||
|
.titles {
|
||||||
|
margin: 32px 0;
|
||||||
|
line-height: 1.4;
|
||||||
|
word-break: break-all;
|
||||||
|
font-size: 40px;
|
||||||
|
font-weight: 600;
|
||||||
|
}
|
||||||
|
|
||||||
|
.status {
|
||||||
|
display: inline-block;
|
||||||
|
margin-bottom: 14px;
|
||||||
|
padding: 4px 8px;
|
||||||
|
font-size: 26px;
|
||||||
|
color: #ffffff;
|
||||||
|
border-radius: 8px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.status0 {
|
||||||
|
background: #ff883c;
|
||||||
|
}
|
||||||
|
|
||||||
|
.status1, .statusevaluation {
|
||||||
|
background: #1aaaff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.status2 {
|
||||||
|
background: #42d784;
|
||||||
|
}
|
||||||
|
|
||||||
|
.status3 {
|
||||||
|
background: #ff4466;
|
||||||
|
}
|
||||||
|
|
||||||
|
.card {
|
||||||
|
display: flex;
|
||||||
|
justify-content: space-between;
|
||||||
|
padding: 34px 0;
|
||||||
|
border-bottom: 1px solid #ddd;
|
||||||
|
|
||||||
|
.card-left {
|
||||||
|
width: 46%;
|
||||||
|
font-size: 32px;
|
||||||
|
color: #999999;
|
||||||
|
}
|
||||||
|
|
||||||
|
.card-right {
|
||||||
|
font-size: 32px;
|
||||||
|
|
||||||
|
.u-icon {
|
||||||
|
margin-left: 8px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// .card:last-child {
|
||||||
|
// border-bottom: none;
|
||||||
|
// }
|
||||||
|
|
||||||
|
.cards {
|
||||||
|
padding: 34px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
img {
|
||||||
|
width: 225px;
|
||||||
|
height: 226px;
|
||||||
|
margin-right: 8px;
|
||||||
|
}
|
||||||
|
|
||||||
|
img:nth-child(3n) {
|
||||||
|
margin-right: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.header-bottom {
|
||||||
|
padding-bottom: 80px;
|
||||||
|
|
||||||
|
.line {
|
||||||
|
height: 16px;
|
||||||
|
background: #f3f6f9;
|
||||||
|
}
|
||||||
|
|
||||||
|
.plan {
|
||||||
|
padding: 0 32px;
|
||||||
|
|
||||||
|
.nav {
|
||||||
|
padding: 26px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cards {
|
||||||
|
position: relative;
|
||||||
|
padding-bottom: 80px;
|
||||||
|
|
||||||
|
.cardss {
|
||||||
|
display: flex;
|
||||||
|
justify-content: space-between;
|
||||||
|
|
||||||
|
.cardss-left {
|
||||||
|
position: relative;
|
||||||
|
width: 80px;
|
||||||
|
height: 80px;
|
||||||
|
text-align: center;
|
||||||
|
line-height: 80px;
|
||||||
|
color: #fff;
|
||||||
|
background: #197df0;
|
||||||
|
border: 1px solid #dddddd;
|
||||||
|
border-radius: 50%;
|
||||||
|
font-size: 28px;
|
||||||
|
z-index: 9;
|
||||||
|
// img {
|
||||||
|
// width: 100%;
|
||||||
|
// height: 100%;
|
||||||
|
// border-radius: 50%;
|
||||||
|
// }
|
||||||
|
.avatarIcon {
|
||||||
|
position: absolute;
|
||||||
|
bottom: 0;
|
||||||
|
right: 0;
|
||||||
|
width: 38px;
|
||||||
|
height: 38px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.cardss-right {
|
||||||
|
width: calc(100% - 110px);
|
||||||
|
display: flex;
|
||||||
|
justify-content: space-between;
|
||||||
|
|
||||||
|
.cardsss-right-left {
|
||||||
|
.cardssss-right-left-top {
|
||||||
|
width: 300px;
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
font-size: 32px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cardssss-right-left-bottom {
|
||||||
|
margin-top: 10px;
|
||||||
|
font-size: 28px;
|
||||||
|
color: #666666;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.cardees-right-right {
|
||||||
|
font-size: 28px;
|
||||||
|
color: #999999;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.lines {
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
left: 40px;
|
||||||
|
width: 4px;
|
||||||
|
height: 100%;
|
||||||
|
background: #eeeeee;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.cardes-msg-top {
|
||||||
|
font-size: 28px;
|
||||||
|
color: #343d65;
|
||||||
|
margin-top: 10px;
|
||||||
|
margin-left: 110px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.imgs {
|
||||||
|
margin-top: 10px;
|
||||||
|
margin-left: 110px;
|
||||||
|
|
||||||
|
img {
|
||||||
|
width: 136px;
|
||||||
|
height: 136px;
|
||||||
|
border-radius: 4px;
|
||||||
|
margin-right: 12px;
|
||||||
|
}
|
||||||
|
|
||||||
|
img:nth-child(4n) {
|
||||||
|
margin-right: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.cards:last-child {
|
||||||
|
.lines {
|
||||||
|
width: 0;
|
||||||
|
height: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixedBtn {
|
||||||
|
background: #fff;
|
||||||
|
position: fixed;
|
||||||
|
bottom: 0;
|
||||||
|
width: 100%;
|
||||||
|
box-sizing: border-box;
|
||||||
|
z-index: 999;
|
||||||
|
|
||||||
|
.status00 {
|
||||||
|
display: flex;
|
||||||
|
|
||||||
|
.columns {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
align-items: center;
|
||||||
|
width: 22%;
|
||||||
|
padding: 16px 0;
|
||||||
|
border-top: 1px solid #ddd;
|
||||||
|
|
||||||
|
img {
|
||||||
|
width: 44px;
|
||||||
|
height: 42px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hint {
|
||||||
|
margin-top: 4px;
|
||||||
|
font-size: 28px;
|
||||||
|
color: #666666;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.border-r {
|
||||||
|
border-right: 1px solid #ddd;
|
||||||
|
}
|
||||||
|
|
||||||
|
.doIt {
|
||||||
|
width: 56%;
|
||||||
|
background: #3975c6;
|
||||||
|
text-align: center;
|
||||||
|
line-height: 112px;
|
||||||
|
font-size: 36px;
|
||||||
|
font-weight: 500;
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.endDoIt {
|
||||||
|
background: #3975c6;
|
||||||
|
text-align: center;
|
||||||
|
padding: 34px 0;
|
||||||
|
|
||||||
|
font-size: 32px;
|
||||||
|
font-weight: 500;
|
||||||
|
color: #ffffff;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
280
src/project/wuxi/AppHandSnapshot/List.vue
Normal file
@@ -0,0 +1,280 @@
|
|||||||
|
<template>
|
||||||
|
<div class="list-content">
|
||||||
|
<AiTopFixed>
|
||||||
|
<u-tabs :list="tabList" :is-scroll="false" :current="currentTabs" height="96" bg-color="#3975C6" inactive-color="#fff" active-color="#fff"
|
||||||
|
@change="change"></u-tabs>
|
||||||
|
<div class="select-top">
|
||||||
|
<div class="tab-item">
|
||||||
|
<AiPagePicker type="gird" v-model="searchGrid" @change="confirm" valueObj nodeKey="id" formType="2">
|
||||||
|
<AiMore v-model="searchGrid.girdName" icon="arrow-down" placeholder="所属网格"/>
|
||||||
|
</AiPagePicker>
|
||||||
|
</div>
|
||||||
|
<div class="tab-item" @click="showType = true">
|
||||||
|
<AiMore v-model="eventStatusText" icon="arrow-down" placeholder="办件状态"/>
|
||||||
|
</div>
|
||||||
|
<u-select v-model="showType" :list="listType" value-name="dictValue" label-name="dictName" @confirm="confirm"></u-select>
|
||||||
|
</div>
|
||||||
|
</AiTopFixed>
|
||||||
|
<template>
|
||||||
|
<AiCard v-for="(item, i) in datas" :key="i" @click.native="goDetail(item, 1)">
|
||||||
|
<template #custom>
|
||||||
|
<div class="card-top">
|
||||||
|
<div class="titles">{{ item.content }}</div>
|
||||||
|
|
||||||
|
<div class="types">
|
||||||
|
<span>事件类型</span>
|
||||||
|
<span class="types-right">{{ item.groupName }}</span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="gards">
|
||||||
|
<span>所属网格</span>
|
||||||
|
<span class="gards-right">{{ item.girdName }}</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="status" :class="item.eventStatus == 0 ? 'status0' : item.eventStatus == 1 ? 'status1' : item.eventStatus == 2 ? 'status2' : 'status3'"
|
||||||
|
v-if="item.eventStatus">
|
||||||
|
<span class="icon"></span>
|
||||||
|
<span>
|
||||||
|
{{ $dict.getLabel('clapEventStatus', item.eventStatus) }}
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</AiCard>
|
||||||
|
<AiEmpty v-if="!datas.length"></AiEmpty>
|
||||||
|
</template>
|
||||||
|
<div class="pad-b120" v-if="datas.length"></div>
|
||||||
|
<AiAdd @add="add"/>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import {mapState} from 'vuex'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
props: {},
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
datas: [],
|
||||||
|
tabList: [
|
||||||
|
{
|
||||||
|
name: '全部待办',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: '办件历史',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
currentTabs: 0,
|
||||||
|
current: 1,
|
||||||
|
pages: 0,
|
||||||
|
searchGrid: {},
|
||||||
|
showType: false,
|
||||||
|
eventStatus: '',
|
||||||
|
eventStatusText: '',
|
||||||
|
}
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
...mapState(['user']),
|
||||||
|
listType() {
|
||||||
|
return this.$dict.getDict(this.currentTabs == 0 ? 'clapEventStatusAll' : 'clapEventStatusHistory')
|
||||||
|
}
|
||||||
|
},
|
||||||
|
onLoad() {
|
||||||
|
uni.$on('nextList', () => {
|
||||||
|
this.current++
|
||||||
|
this.getList()
|
||||||
|
})
|
||||||
|
uni.$on('getListInit', () => {
|
||||||
|
this.current = 1
|
||||||
|
this.getList()
|
||||||
|
})
|
||||||
|
|
||||||
|
},
|
||||||
|
onShow() {
|
||||||
|
document.title = this.user.corpId == 'wpytYEDgAACQq2uZ5x54MvlJ9fgvSPXQ' ? '微心愿' : '随手拍'
|
||||||
|
},
|
||||||
|
created() {
|
||||||
|
this.$dict.load('clapEventStatus', 'clapEventStatusAll', 'clapEventStatusHistory').then(() => {
|
||||||
|
this.getList()
|
||||||
|
})
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
getList() {
|
||||||
|
let {current, eventStatus, searchGrid: {id: girdId}} = this
|
||||||
|
this.$http.post(`/app/appclapeventinfo/listByGirdMember`, null, {
|
||||||
|
params: {
|
||||||
|
size: 10,
|
||||||
|
current, searchType: this.currentTabs == 1 ? '1' : '0',
|
||||||
|
eventStatus, girdId
|
||||||
|
},
|
||||||
|
})
|
||||||
|
.then((res) => {
|
||||||
|
if (res.code == 0) {
|
||||||
|
this.datas = this.current > 1 ? [...this.datas, ...res.data.records] : res.data.records
|
||||||
|
this.pages = res.data.pages
|
||||||
|
this.$forceUpdate()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
},
|
||||||
|
|
||||||
|
confirm(e) {
|
||||||
|
if (this.showType) {
|
||||||
|
this.eventStatus = e[0].value
|
||||||
|
this.eventStatusText = e[0].label
|
||||||
|
}
|
||||||
|
this.current = 1
|
||||||
|
this.getList()
|
||||||
|
},
|
||||||
|
|
||||||
|
goDetail(item) {
|
||||||
|
uni.navigateTo({url: `./Detail?id=${item.id}`})
|
||||||
|
},
|
||||||
|
|
||||||
|
change(index) {
|
||||||
|
this.current = 1
|
||||||
|
this.datas = []
|
||||||
|
this.eventStatus = ''
|
||||||
|
this.currentTabs = index
|
||||||
|
this.getList()
|
||||||
|
},
|
||||||
|
|
||||||
|
linkTo(url) {
|
||||||
|
uni.navigateTo({url})
|
||||||
|
},
|
||||||
|
add() {
|
||||||
|
uni.navigateTo({url: './Add'})
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped lang="scss">
|
||||||
|
.list-content {
|
||||||
|
height: 100%;
|
||||||
|
padding: 0;
|
||||||
|
width: 100vw;
|
||||||
|
|
||||||
|
.select-top {
|
||||||
|
background: #fff;
|
||||||
|
display: flex;
|
||||||
|
padding: 24px 0;
|
||||||
|
|
||||||
|
.tab-item {
|
||||||
|
flex: 1;
|
||||||
|
text-align: center;
|
||||||
|
line-height: 48px;
|
||||||
|
font-size: 26px;
|
||||||
|
font-family: PingFangSC-Regular, PingFang SC;
|
||||||
|
color: #666;
|
||||||
|
|
||||||
|
img {
|
||||||
|
width: 32px;
|
||||||
|
height: 32px;
|
||||||
|
margin-left: 8px;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.tab-item:nth-of-type(1) {
|
||||||
|
border-right: 1px solid #eee;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
::v-deep .AiTopFixed .content {
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
::v-deep .AiCard {
|
||||||
|
background: #f3f6f9;
|
||||||
|
padding: 24px 40px 0 32px;
|
||||||
|
|
||||||
|
.start {
|
||||||
|
background: #fff;
|
||||||
|
border-radius: 16px;
|
||||||
|
|
||||||
|
.card-top {
|
||||||
|
padding: 32px;
|
||||||
|
|
||||||
|
.titles {
|
||||||
|
margin-bottom: 34px;
|
||||||
|
font-size: 32px;
|
||||||
|
font-weight: 500;
|
||||||
|
color: #333333;
|
||||||
|
line-height: 1.4;
|
||||||
|
word-break: break-all;
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
display: -webkit-box;
|
||||||
|
-webkit-line-clamp: 2;
|
||||||
|
-webkit-box-orient: vertical;
|
||||||
|
}
|
||||||
|
|
||||||
|
.types,
|
||||||
|
.gards {
|
||||||
|
margin-top: 8px;
|
||||||
|
font-size: 26px;
|
||||||
|
|
||||||
|
.types-right,
|
||||||
|
.gards-right {
|
||||||
|
margin-left: 32px;
|
||||||
|
color: #333333;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.status {
|
||||||
|
padding: 32px;
|
||||||
|
border-top: 1px solid #dddddd;
|
||||||
|
|
||||||
|
.icon {
|
||||||
|
display: inline-block;
|
||||||
|
width: 8px;
|
||||||
|
height: 8px;
|
||||||
|
vertical-align: middle;
|
||||||
|
margin-right: 8px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.status0 {
|
||||||
|
color: #ff883c;
|
||||||
|
|
||||||
|
.icon {
|
||||||
|
background: #ff883c;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.status1 {
|
||||||
|
color: #1aaaff;
|
||||||
|
|
||||||
|
.icon {
|
||||||
|
background: #1aaaff;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.status2 {
|
||||||
|
color: #42d784;
|
||||||
|
|
||||||
|
.icon {
|
||||||
|
background: #42d784;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.status3 {
|
||||||
|
color: #ff4466;
|
||||||
|
|
||||||
|
.icon {
|
||||||
|
background: #ff4466;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// ::v-deep .AiCard:last-child {
|
||||||
|
// padding-bottom: 24px;
|
||||||
|
// }
|
||||||
|
.pad-b120 {
|
||||||
|
background-color: #f3f6f9;
|
||||||
|
padding-bottom: 120px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
339
src/project/wuxi/AppHandSnapshot/SelectUser.vue
Normal file
@@ -0,0 +1,339 @@
|
|||||||
|
<template>
|
||||||
|
<div class="SelectUser">
|
||||||
|
<div class="header-middle">
|
||||||
|
<div class="hint">
|
||||||
|
<span v-for="(item, index) in slectList" :key="index"><span v-if="index" style="margin:0 4px;">/</span><span style="color:#3F8DF5" @click="girdNameClick(item, index)">{{item.girdName}}</span></span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="showTypes" v-if="!userList.length">
|
||||||
|
<div v-if="treeList.length > 0">
|
||||||
|
<div class="cards" v-for="(item, index) in treeList" :key="index" @click="itemClick(item)">
|
||||||
|
<div class="imges">
|
||||||
|
<span v-if="item.girdLevel == 2">
|
||||||
|
<img src="./components/img/xzh.png" alt="" class="imgselect" v-if="item.isChecked" @click.stop="girdClick(item, index)" />
|
||||||
|
<img src="./components/img/xz.png" alt="" class="imgselect" v-else @click.stop="girdClick(item, index)" />
|
||||||
|
</span>
|
||||||
|
<img src="./components/img/gird--select-icon.png" alt="" class="avatras" />
|
||||||
|
</div>
|
||||||
|
<div class="rightes">
|
||||||
|
<div class="applicationNames">{{ item.girdName }}</div>
|
||||||
|
<img src="./components/img/right-icon.png" alt="" class="imgs" />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<AiEmpty description="暂无数据" class="emptyWrap" v-else></AiEmpty>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="showUsers" v-else>
|
||||||
|
<div v-if="userList.length > 0">
|
||||||
|
<div class="cards" v-for="(e, index) in userList" :key="index">
|
||||||
|
<div class="imges">
|
||||||
|
<img src="./components/img/xzh.png" alt="" class="imgselect" v-if="e.isChecked" @click="userClick(e, index)" />
|
||||||
|
<img src="./components/img/xz.png" alt="" class="imgselect" v-else @click="userClick(e, index)" />
|
||||||
|
|
||||||
|
<img src="./components/img/tx@2x.png" alt="" class="avatras" />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="rights">
|
||||||
|
<div class="applicationNames">{{ e.name }}</div>
|
||||||
|
<div class="idNumbers">{{ e.phone }}</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<AiEmpty description="暂无数据" class="emptyWrap" v-else></AiEmpty>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="subBtn" @click="submit">
|
||||||
|
<div>确定选择</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
export default {
|
||||||
|
name: 'SelectUser',
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
selectUser: {},
|
||||||
|
allData: null,
|
||||||
|
treeList: [],
|
||||||
|
slectList: [],
|
||||||
|
userList: [],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
onLoad() {
|
||||||
|
this.getTree()
|
||||||
|
},
|
||||||
|
onShow() {
|
||||||
|
document.title = '选择人员'
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
getTree() {
|
||||||
|
this.slectList = []
|
||||||
|
this.$http.post('/app/appgirdinfo/listAllByTop').then((res) => {
|
||||||
|
if (res?.data) {
|
||||||
|
this.allData = res.data
|
||||||
|
this.treeInit()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
},
|
||||||
|
|
||||||
|
treeInit() {
|
||||||
|
if(this.allData[0].girdLevel == 2) {
|
||||||
|
if(this.allData[0].girdMemberList && this.allData[0].girdMemberList.length) {
|
||||||
|
this.userList = this.allData[0].girdMemberList
|
||||||
|
this.userList.map((item) => {
|
||||||
|
item.isChecked = false
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}else {
|
||||||
|
this.treeList = this.allData[0].girdList
|
||||||
|
}
|
||||||
|
var obj = {
|
||||||
|
girdName: this.allData[0].girdName,
|
||||||
|
id: this.allData[0].id,
|
||||||
|
girdLevel: this.allData[0].girdLevel
|
||||||
|
}
|
||||||
|
this.slectList.push(obj)
|
||||||
|
},
|
||||||
|
|
||||||
|
itemClick(row) {
|
||||||
|
console.log(row)
|
||||||
|
var obj = {
|
||||||
|
girdName: row.girdName,
|
||||||
|
id: row.id,
|
||||||
|
girdLevel: row.girdLevel
|
||||||
|
}
|
||||||
|
this.slectList.push(obj)
|
||||||
|
this.searckGird(row)
|
||||||
|
},
|
||||||
|
|
||||||
|
searckGird(row) {
|
||||||
|
this.treeList = []
|
||||||
|
if(row.girdLevel != 2) { //查网格
|
||||||
|
this.$http.post(`/app/appgirdinfo/list?parentGirdId=${row.id}&size=999`).then((res) => {
|
||||||
|
if (res?.data) {
|
||||||
|
this.treeList = res.data.records
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}else { //查网格员
|
||||||
|
this.userList = []
|
||||||
|
this.$http.post(`/app/appgirdmemberinfo/listByGirdIdByThree?girdId=${row.id}`).then((res) => {
|
||||||
|
if (res?.data) {
|
||||||
|
this.userList = res.data
|
||||||
|
this.userList.map((item) => {
|
||||||
|
item.isChecked = false
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
girdNameClick(row, index) {
|
||||||
|
this.userList = []
|
||||||
|
if(!index) { //第一级别
|
||||||
|
this.slectList = []
|
||||||
|
this.treeInit()
|
||||||
|
}else {
|
||||||
|
var list = []
|
||||||
|
this.slectList.map((item, i) => {
|
||||||
|
if(i <= index) {
|
||||||
|
list.push(item)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
this.slectList = list
|
||||||
|
this.searckGird(row)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
|
||||||
|
girdClick(row, index) {
|
||||||
|
if (this.treeList[index].isChecked) {//取消
|
||||||
|
this.treeList[index].isChecked = false
|
||||||
|
this.selectUser = {}
|
||||||
|
} else {
|
||||||
|
this.treeList.map((item) => {
|
||||||
|
item.isChecked = false
|
||||||
|
})
|
||||||
|
this.treeList[index].isChecked = true
|
||||||
|
this.selectUser = row
|
||||||
|
}
|
||||||
|
this.$forceUpdate()
|
||||||
|
},
|
||||||
|
|
||||||
|
userClick(row, index) {
|
||||||
|
if (this.userList[index].isChecked) {//取消
|
||||||
|
this.userList[index].isChecked = false
|
||||||
|
this.selectUser = {}
|
||||||
|
} else {
|
||||||
|
this.userList.map((item) => {
|
||||||
|
item.isChecked = false
|
||||||
|
})
|
||||||
|
this.userList[index].isChecked = true
|
||||||
|
this.selectUser = row
|
||||||
|
}
|
||||||
|
this.$forceUpdate()
|
||||||
|
},
|
||||||
|
|
||||||
|
submit() {
|
||||||
|
if (this.selectUser.id != null) {
|
||||||
|
uni.$emit('goback', this.selectUser)
|
||||||
|
uni.navigateBack()
|
||||||
|
} else {
|
||||||
|
return this.$u.toast('请选择网格或网格员')
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped lang="scss">
|
||||||
|
.SelectUser {
|
||||||
|
height: 100%;
|
||||||
|
background: #fff;
|
||||||
|
.header-top {
|
||||||
|
background: #fff;
|
||||||
|
padding: 20px 32px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.header-middle {
|
||||||
|
padding-bottom: 140px;
|
||||||
|
.hint {
|
||||||
|
padding: 28px 20px 28px 32px;
|
||||||
|
line-height: 56px;
|
||||||
|
box-shadow: 0px 1px 0px 0px #e4e5e6;
|
||||||
|
font-size: 30px;
|
||||||
|
font-weight: 500;
|
||||||
|
word-break: break-all;
|
||||||
|
}
|
||||||
|
|
||||||
|
.showTypes {
|
||||||
|
.empty-div {
|
||||||
|
height: 16px;
|
||||||
|
background: #f5f5f5;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cards {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
height: 120px;
|
||||||
|
line-height: 120px;
|
||||||
|
// background: pink;
|
||||||
|
padding: 0 0 0 32px;
|
||||||
|
|
||||||
|
.imges {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
// width: 200px;
|
||||||
|
.imgselect {
|
||||||
|
width: 48px;
|
||||||
|
height: 48px;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
|
||||||
|
.avatras {
|
||||||
|
width: 74px;
|
||||||
|
height: 74px;
|
||||||
|
border-radius: 8px;
|
||||||
|
margin-left: 36px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
img {
|
||||||
|
width: 74px;
|
||||||
|
height: 74px;
|
||||||
|
border-radius: 8px;
|
||||||
|
}
|
||||||
|
.rightes {
|
||||||
|
width: 100%;
|
||||||
|
display: flex;
|
||||||
|
justify-content: space-between;
|
||||||
|
align-items: center;
|
||||||
|
margin-left: 32px;
|
||||||
|
border-bottom: 1px solid #e4e5e6;
|
||||||
|
.applicationNames {
|
||||||
|
font-size: 36px;
|
||||||
|
font-weight: 500;
|
||||||
|
color: #333333;
|
||||||
|
}
|
||||||
|
.imgs {
|
||||||
|
width: 40px;
|
||||||
|
height: 40px;
|
||||||
|
margin-right: 20px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.showUsers {
|
||||||
|
.cards {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
height: 120px;
|
||||||
|
line-height: 120px;
|
||||||
|
// background: pink;
|
||||||
|
padding: 0 0 0 32px;
|
||||||
|
|
||||||
|
.imges {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
width: 200px;
|
||||||
|
.imgselect {
|
||||||
|
width: 48px;
|
||||||
|
height: 48px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.avatras {
|
||||||
|
width: 74px;
|
||||||
|
height: 74px;
|
||||||
|
border-radius: 8px;
|
||||||
|
margin-left: 36px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.rights {
|
||||||
|
width: 100%;
|
||||||
|
display: flex;
|
||||||
|
justify-content: space-between;
|
||||||
|
align-items: center;
|
||||||
|
margin-left: 32px;
|
||||||
|
border-bottom: 1px solid #e4e5e6;
|
||||||
|
padding-right: 40px;
|
||||||
|
.applicationNames {
|
||||||
|
font-size: 36px;
|
||||||
|
font-weight: 500;
|
||||||
|
color: #333333;
|
||||||
|
}
|
||||||
|
.idNumbers {
|
||||||
|
color: #666;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.subBtn {
|
||||||
|
position: fixed;
|
||||||
|
bottom: 0;
|
||||||
|
left: 0;
|
||||||
|
width: 100%;
|
||||||
|
height: 118px;
|
||||||
|
background: #f4f8fb;
|
||||||
|
div {
|
||||||
|
width: 192px;
|
||||||
|
height: 80px;
|
||||||
|
line-height: 80px;
|
||||||
|
text-align: center;
|
||||||
|
background: #1365dd;
|
||||||
|
border-radius: 4px;
|
||||||
|
font-size: 32px;
|
||||||
|
color: #fff;
|
||||||
|
margin: 20px 34px 0 0;
|
||||||
|
float: right;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
346
src/project/wuxi/AppHandSnapshot/Statistics.vue
Normal file
@@ -0,0 +1,346 @@
|
|||||||
|
<template>
|
||||||
|
<div class="statistics" v-if="pageShow">
|
||||||
|
<div class="info-content">
|
||||||
|
<div class="title">今日概况</div>
|
||||||
|
<div class="el-row">
|
||||||
|
<div class="item" v-for="(item, index) in todayList" :key="index">
|
||||||
|
<h2>{{item.value}}</h2>
|
||||||
|
<p>{{item.label}}</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="info-content">
|
||||||
|
<div class="title">业务透视</div>
|
||||||
|
<div class="business">
|
||||||
|
<div class="left">
|
||||||
|
<div class="item">
|
||||||
|
<p>受理率</p>
|
||||||
|
<h2>{{info.businessCountMap['受理率'] || '0'}}%</h2>
|
||||||
|
</div>
|
||||||
|
<div class="item">
|
||||||
|
<p>办结率</p>
|
||||||
|
<h2>{{info.businessCountMap['办结率'] || '0'}}%</h2>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="right">
|
||||||
|
<div class="img">
|
||||||
|
<img src="./components/img/line-img.png" alt="">
|
||||||
|
<img src="./components/img/line-img.png" alt="">
|
||||||
|
</div>
|
||||||
|
<div class="num">
|
||||||
|
<div class="item bg1">
|
||||||
|
<h2>累计反馈</h2>
|
||||||
|
<p>{{info.businessCountMap['累计反馈'] || '0'}}</p>
|
||||||
|
</div>
|
||||||
|
<div class="item bg2">
|
||||||
|
<h2>累计受理</h2>
|
||||||
|
<p>{{info.businessCountMap['累计受理'] || '0'}}</p>
|
||||||
|
</div>
|
||||||
|
<div class="item bg3">
|
||||||
|
<h2>累计办理</h2>
|
||||||
|
<p>{{info.businessCountMap['累计办结'] || '0'}}</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="info-content">
|
||||||
|
<div class="title" @click="toPercentageDetail">分类统计
|
||||||
|
<!-- <img src="./components/img/right-icon.png" alt=""> -->
|
||||||
|
</div>
|
||||||
|
<div class="percentage">
|
||||||
|
<div class="item" v-for="(item, index) in info.groupList" :key="index">
|
||||||
|
<div class="mini-title">{{item.groupName}}</div>
|
||||||
|
<div class="info">
|
||||||
|
<div class="line-bg" :style="`width:${item.width}%`" ><div class="active-bg" :style="`width:${item.percentage*100}%`"></div></div>共{{item.totalNum}}条 | 已办结{{item.finishNum}}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!-- <div class="info-content" @click="toUserList">
|
||||||
|
<div class="title">成员明细
|
||||||
|
<img src="./components/img/right-icon.png" alt="">
|
||||||
|
</div>
|
||||||
|
</div> -->
|
||||||
|
<div class="pad-b120"></div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
export default {
|
||||||
|
props: {},
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
todayList: [],
|
||||||
|
info: {},
|
||||||
|
pageShow: false,
|
||||||
|
showSelect: false,
|
||||||
|
myGirdList: [],
|
||||||
|
girdName: '全部网格'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
mounted() {
|
||||||
|
this.girdList()
|
||||||
|
this.getStatistics()
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
getStatistics() {
|
||||||
|
this.$http.post('/app/appclapeventinfo/countByGirdMember').then((res) => {
|
||||||
|
if (res.code == 0) {
|
||||||
|
if(res.data.businessCountMap['受理率']) {
|
||||||
|
res.data.businessCountMap['受理率'] = Number(res.data.businessCountMap['受理率'] * 100).toFixed(1)
|
||||||
|
}
|
||||||
|
if(res.data.businessCountMap['办结率']) {
|
||||||
|
res.data.businessCountMap['办结率'] = Number(res.data.businessCountMap['办结率'] * 100).toFixed(1)
|
||||||
|
}
|
||||||
|
this.info = res.data
|
||||||
|
|
||||||
|
Object.keys(res.data.todayCountMap).forEach((key) => {
|
||||||
|
var info = {
|
||||||
|
label: key,
|
||||||
|
value: res.data.todayCountMap[key]
|
||||||
|
}
|
||||||
|
this.todayList.push(info)
|
||||||
|
})
|
||||||
|
if(this.info.groupList.length) {
|
||||||
|
this.info.groupList.map((item, index) => {
|
||||||
|
if(item.finishNum) {
|
||||||
|
item.percentage = (item.finishNum/item.totalNum).toFixed(2)
|
||||||
|
}else {
|
||||||
|
item.percentage = 0
|
||||||
|
}
|
||||||
|
item.width = 56-(index*10)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.pageShow = true
|
||||||
|
})
|
||||||
|
},
|
||||||
|
|
||||||
|
goDetail(item) {
|
||||||
|
uni.navigateTo({ url: `./Detail?id=${item.id}` })
|
||||||
|
},
|
||||||
|
|
||||||
|
change(index) {
|
||||||
|
this.currentTabs = index
|
||||||
|
this.getList()
|
||||||
|
},
|
||||||
|
|
||||||
|
toPercentageDetail() {
|
||||||
|
// uni.navigateTo({url: './PercentageDetail'})
|
||||||
|
},
|
||||||
|
toUserList() {
|
||||||
|
uni.navigateTo({url: './UserList'})
|
||||||
|
},
|
||||||
|
|
||||||
|
girdList() {
|
||||||
|
this.$http.post(`/app/appgirdmemberinfo/queryMyGirdList`, null, {
|
||||||
|
params: {
|
||||||
|
size: 9999,
|
||||||
|
},
|
||||||
|
})
|
||||||
|
.then((res) => {
|
||||||
|
if (res.code == 0) {
|
||||||
|
this.myGirdList = res.data
|
||||||
|
var all = {
|
||||||
|
id: '',
|
||||||
|
girdName: '全部'
|
||||||
|
}
|
||||||
|
this.myGirdList.unshift(all)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
},
|
||||||
|
confirm(e) {
|
||||||
|
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped lang="scss">
|
||||||
|
.statistics {
|
||||||
|
background-color: #F3F7F8;
|
||||||
|
padding: 30px 30px 0;
|
||||||
|
.gird-select{
|
||||||
|
width: 100%;
|
||||||
|
background: #FFF;
|
||||||
|
border-radius: 16px;
|
||||||
|
margin: 0 0 24px;
|
||||||
|
text-align: center;
|
||||||
|
padding: 24px 0;
|
||||||
|
img{
|
||||||
|
width: 32px;
|
||||||
|
height: 32px;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
span{
|
||||||
|
display: inline-block;
|
||||||
|
font-size: 34px;
|
||||||
|
font-family: PingFangSC-Medium, PingFang SC;
|
||||||
|
font-weight: 500;
|
||||||
|
color: #333;
|
||||||
|
line-height: 48px;
|
||||||
|
margin: 0 10px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.info-content{
|
||||||
|
width: 100%;
|
||||||
|
background: #FFF;
|
||||||
|
border-radius: 16px;
|
||||||
|
margin-bottom: 24px;
|
||||||
|
.title{
|
||||||
|
font-size: 32px;
|
||||||
|
font-family: PingFangSC-Regular, PingFang SC;
|
||||||
|
font-weight: 400;
|
||||||
|
color: #333;
|
||||||
|
line-height: 48px;
|
||||||
|
padding: 24px 16px 24px 24px;
|
||||||
|
img{
|
||||||
|
float: right;
|
||||||
|
width: 40px;
|
||||||
|
height: 40px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.el-row{
|
||||||
|
display: flex;
|
||||||
|
padding: 32px 0 60px 0;
|
||||||
|
.item{
|
||||||
|
flex: 1;
|
||||||
|
text-align: center;
|
||||||
|
h2{
|
||||||
|
font-size: 64px;
|
||||||
|
font-family: DINAlternate-Bold, DINAlternate;
|
||||||
|
font-weight: bold;
|
||||||
|
color: #3B424A;
|
||||||
|
line-height: 64px;
|
||||||
|
margin-bottom: 8px;
|
||||||
|
}
|
||||||
|
p{
|
||||||
|
font-size: 28px;
|
||||||
|
font-family: PingFangSC-Regular, PingFang SC;
|
||||||
|
color: #999;
|
||||||
|
line-height: 40px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.business{
|
||||||
|
display: flex;
|
||||||
|
padding: 40px 0 30px 0;
|
||||||
|
.left{
|
||||||
|
width: 220px;
|
||||||
|
padding: 20px 0 78px 50px;
|
||||||
|
.item{
|
||||||
|
margin-bottom: 58px;
|
||||||
|
}
|
||||||
|
h2{
|
||||||
|
font-size: 58px;
|
||||||
|
font-family: DINAlternate-Bold, DINAlternate;
|
||||||
|
font-weight: bold;
|
||||||
|
color: #3B424A;
|
||||||
|
line-height: 64px;
|
||||||
|
letter-spacing: -4px;
|
||||||
|
}
|
||||||
|
p{
|
||||||
|
font-size: 28px;
|
||||||
|
font-family: PingFangSC-Regular, PingFang SC;
|
||||||
|
color: #666;
|
||||||
|
line-height: 48px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.right{
|
||||||
|
width: calc(100% - 220px);
|
||||||
|
display: flex;
|
||||||
|
.img{
|
||||||
|
width: 140px;
|
||||||
|
margin-top: 42px;
|
||||||
|
img{
|
||||||
|
width: 140px;
|
||||||
|
height: 144px;
|
||||||
|
margin-bottom: 20px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.num{
|
||||||
|
width: calc(100% - 140px);
|
||||||
|
text-align: center;
|
||||||
|
.item{
|
||||||
|
height: 130px;
|
||||||
|
border-radius: 6px;
|
||||||
|
background-size: 100% 100%;
|
||||||
|
margin-bottom: 4px;
|
||||||
|
color: #2F7EE5;
|
||||||
|
h2{
|
||||||
|
font-size: 26px;
|
||||||
|
font-family: PingFangSC-Medium, PingFang SC;
|
||||||
|
font-weight: 500;
|
||||||
|
line-height: 48px;
|
||||||
|
padding-top: 20px;
|
||||||
|
}
|
||||||
|
p{
|
||||||
|
font-size: 40px;
|
||||||
|
font-family: DINAlternate-Bold, DINAlternate;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.bg1{
|
||||||
|
width: 272px;
|
||||||
|
background-image: url('./components/img/bg-1.png');
|
||||||
|
}
|
||||||
|
.bg2{
|
||||||
|
width: 234px;
|
||||||
|
background-image: url('./components/img/bg-2.png');
|
||||||
|
margin-left: 16px;
|
||||||
|
}
|
||||||
|
.bg3{
|
||||||
|
width: 208px;
|
||||||
|
background-image: url('./components/img/bg-3.png');
|
||||||
|
margin-left: 32px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.percentage{
|
||||||
|
padding: 16px 0 0 26px;
|
||||||
|
.item{
|
||||||
|
width: 100%;
|
||||||
|
padding-bottom: 32px;
|
||||||
|
.mini-title{
|
||||||
|
font-size: 30px;
|
||||||
|
font-family: PingFangSC-Regular, PingFang SC;
|
||||||
|
color: #333;
|
||||||
|
line-height: 48px;
|
||||||
|
margin-bottom: 14px;
|
||||||
|
}
|
||||||
|
.info{
|
||||||
|
width: 100%;
|
||||||
|
font-size: 28px;
|
||||||
|
font-family: PingFangSC-Regular, PingFang SC;
|
||||||
|
color: #999;
|
||||||
|
line-height: 48px;
|
||||||
|
.line-bg{
|
||||||
|
display: inline-block;
|
||||||
|
height: 14px;
|
||||||
|
background: #D7D8D9;
|
||||||
|
border-radius: 8px;
|
||||||
|
margin-right: 12px;
|
||||||
|
.active-bg{
|
||||||
|
height: 100%;
|
||||||
|
background: #257FF1;
|
||||||
|
border-radius: 8px;
|
||||||
|
min-width: 1%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
img{
|
||||||
|
width: 32px;
|
||||||
|
height: 32px;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.pad-b120{
|
||||||
|
background-color: #F3F7F8;
|
||||||
|
padding-bottom: 120px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
BIN
src/project/wuxi/AppHandSnapshot/components/1.png
Normal file
|
After Width: | Height: | Size: 623 B |
BIN
src/project/wuxi/AppHandSnapshot/components/22.png
Normal file
|
After Width: | Height: | Size: 810 B |
BIN
src/project/wuxi/AppHandSnapshot/components/img/add-icon.png
Normal file
|
After Width: | Height: | Size: 815 B |
BIN
src/project/wuxi/AppHandSnapshot/components/img/bg-1.png
Normal file
|
After Width: | Height: | Size: 3.2 KiB |
BIN
src/project/wuxi/AppHandSnapshot/components/img/bg-2.png
Normal file
|
After Width: | Height: | Size: 2.7 KiB |
BIN
src/project/wuxi/AppHandSnapshot/components/img/bg-3.png
Normal file
|
After Width: | Height: | Size: 2.6 KiB |
BIN
src/project/wuxi/AppHandSnapshot/components/img/down-icon.png
Normal file
|
After Width: | Height: | Size: 314 B |
|
After Width: | Height: | Size: 1.2 KiB |
BIN
src/project/wuxi/AppHandSnapshot/components/img/gird-icon.png
Normal file
|
After Width: | Height: | Size: 1.1 KiB |
|
After Width: | Height: | Size: 1.5 KiB |
BIN
src/project/wuxi/AppHandSnapshot/components/img/handle-icon.png
Normal file
|
After Width: | Height: | Size: 1.5 KiB |
BIN
src/project/wuxi/AppHandSnapshot/components/img/jujue.png
Normal file
|
After Width: | Height: | Size: 1.5 KiB |
BIN
src/project/wuxi/AppHandSnapshot/components/img/line-img.png
Normal file
|
After Width: | Height: | Size: 1.6 KiB |
BIN
src/project/wuxi/AppHandSnapshot/components/img/local-icon.png
Normal file
|
After Width: | Height: | Size: 1.1 KiB |
BIN
src/project/wuxi/AppHandSnapshot/components/img/no-admin.png
Normal file
|
After Width: | Height: | Size: 21 KiB |
BIN
src/project/wuxi/AppHandSnapshot/components/img/remove-icon.png
Normal file
|
After Width: | Height: | Size: 803 B |
BIN
src/project/wuxi/AppHandSnapshot/components/img/right-icon.png
Normal file
|
After Width: | Height: | Size: 373 B |
BIN
src/project/wuxi/AppHandSnapshot/components/img/search-icon.png
Normal file
|
After Width: | Height: | Size: 766 B |
|
After Width: | Height: | Size: 1.6 KiB |
BIN
src/project/wuxi/AppHandSnapshot/components/img/set-icon.png
Normal file
|
After Width: | Height: | Size: 1.6 KiB |
BIN
src/project/wuxi/AppHandSnapshot/components/img/setting-icon.png
Normal file
|
After Width: | Height: | Size: 1.3 KiB |
|
After Width: | Height: | Size: 1.7 KiB |
|
After Width: | Height: | Size: 1.7 KiB |
BIN
src/project/wuxi/AppHandSnapshot/components/img/tx@2x.png
Normal file
|
After Width: | Height: | Size: 1.4 KiB |
BIN
src/project/wuxi/AppHandSnapshot/components/img/user-img.png
Normal file
|
After Width: | Height: | Size: 2.7 KiB |
BIN
src/project/wuxi/AppHandSnapshot/components/img/xz.png
Normal file
|
After Width: | Height: | Size: 1.5 KiB |
BIN
src/project/wuxi/AppHandSnapshot/components/img/xzh.png
Normal file
|
After Width: | Height: | Size: 1.7 KiB |
BIN
src/project/wuxi/AppHandSnapshot/components/img/zhuanjiao.png
Normal file
|
After Width: | Height: | Size: 1.6 KiB |
BIN
src/project/wuxi/AppHandSnapshot/components/yan.jpg
Normal file
|
After Width: | Height: | Size: 88 KiB |