|
|
|
<template>
|
|
|
|
<cs-page :selected="4" isTab title="个人中心">
|
|
|
|
<scroll-view class="owner-container" scroll-y>
|
|
|
|
<view
|
|
|
|
class="section wd-flex wd-flex-row wd-justify-between wd-items-center"
|
|
|
|
@tap="edit"
|
|
|
|
>
|
|
|
|
<view class="wd-flex wd-flex-col" style="gap: 12rpx">
|
|
|
|
<view
|
|
|
|
class="wd-flex wd-flex-row"
|
|
|
|
style="gap: 16rpx; align-items: center"
|
|
|
|
>
|
|
|
|
<text
|
|
|
|
class="wd-font-800"
|
|
|
|
style="font-size: 40rpx; color: #252f4a"
|
|
|
|
>
|
|
|
|
{{ user.realName }}
|
|
|
|
</text>
|
|
|
|
|
|
|
|
<text class="dept">{{ user.dept.name }}</text>
|
|
|
|
</view>
|
|
|
|
<view class="moblie">{{ user.mobile }}</view>
|
|
|
|
</view>
|
|
|
|
<view class="wd-flex wd-flex-row" style="gap: 16rpx">
|
|
|
|
<u-avatar :src="user.avatar" size="126rpx"></u-avatar>
|
|
|
|
<u-icon name="arrow-right" color="#C4CADA"></u-icon>
|
|
|
|
</view>
|
|
|
|
</view>
|
|
|
|
<view
|
|
|
|
class="section wd-flex wd-flex-row wd-justify-between"
|
|
|
|
@click="openSubMessage"
|
|
|
|
>
|
|
|
|
<view class="wd-flex wd-flex-row" style="gap: 8rpx">
|
|
|
|
<u--image
|
|
|
|
src="/static/images/owner/message.png"
|
|
|
|
width="40rpx"
|
|
|
|
height="40rpx"
|
|
|
|
mode="aspectFill"
|
|
|
|
></u--image>
|
|
|
|
<text style="color: #252f4a">消息通知</text>
|
|
|
|
</view>
|
|
|
|
<!-- <view class="wd-flex wd-flex-row wd-items-center" style="gap: 8px">
|
|
|
|
<u-count-to
|
|
|
|
:startVal="30"
|
|
|
|
:endVal="500"
|
|
|
|
fontSize="14px"
|
|
|
|
separator=","
|
|
|
|
></u-count-to>
|
|
|
|
<u-icon name="arrow-right"></u-icon>
|
|
|
|
</view> -->
|
|
|
|
<view class="row">
|
|
|
|
<view class="notice-wrapper">
|
|
|
|
<u-count-to
|
|
|
|
:startVal="0"
|
|
|
|
:endVal="policyTotal"
|
|
|
|
fontSize="14px"
|
|
|
|
separator=","
|
|
|
|
color="#fff"
|
|
|
|
></u-count-to>
|
|
|
|
</view>
|
|
|
|
|
|
|
|
<u-icon name="arrow-right" color="#C4CADA"></u-icon>
|
|
|
|
</view>
|
|
|
|
</view>
|
|
|
|
<!-- <view class="section wd-flex wd-flex-row wd-justify-between">
|
|
|
|
<view class="wd-flex wd-flex-row" style="gap: 8px">
|
|
|
|
<u--image
|
|
|
|
src="/static/images/owner/edit.png"
|
|
|
|
width="20px"
|
|
|
|
height="20px"
|
|
|
|
mode="aspectFit"
|
|
|
|
></u--image>
|
|
|
|
<text class="wd-font-800">执法记录</text>
|
|
|
|
</view>
|
|
|
|
<view class="wd-flex wd-flex-row wd-items-center" style="gap: 8px">
|
|
|
|
<u-count-to
|
|
|
|
:startVal="30"
|
|
|
|
:endVal="500"
|
|
|
|
fontSize="14px"
|
|
|
|
separator=","
|
|
|
|
></u-count-to>
|
|
|
|
<u-icon name="arrow-right"></u-icon>
|
|
|
|
</view>
|
|
|
|
</view> -->
|
|
|
|
<button
|
|
|
|
class="section wd-flex wd-flex-row wd-justify-between"
|
|
|
|
@click="btnPolicy"
|
|
|
|
>
|
|
|
|
<view class="wd-flex wd-flex-row" style="gap: 8rpx">
|
|
|
|
<u--image
|
|
|
|
src="/static/images/owner/list.png"
|
|
|
|
width="40rpx"
|
|
|
|
height="40rpx"
|
|
|
|
mode="aspectFill"
|
|
|
|
></u--image>
|
|
|
|
<text style="color: #252f4a">政策法规</text>
|
|
|
|
</view>
|
|
|
|
<view class="row">
|
|
|
|
<u-icon name="arrow-right" color="#C4CADA"></u-icon>
|
|
|
|
</view>
|
|
|
|
</button>
|
|
|
|
<button
|
|
|
|
class="section wd-flex wd-flex-row wd-justify-between"
|
|
|
|
open-type="share"
|
|
|
|
@click="invite"
|
|
|
|
>
|
|
|
|
<view class="wd-flex wd-flex-row" style="gap: 8rpx">
|
|
|
|
<u--image
|
|
|
|
src="/static/images/owner/edit.png"
|
|
|
|
width="40rpx"
|
|
|
|
height="40rpx"
|
|
|
|
mode="aspectFill"
|
|
|
|
></u--image>
|
|
|
|
<text style="color: #252f4a">企业入驻</text>
|
|
|
|
</view>
|
|
|
|
<view class="row">
|
|
|
|
<u-icon name="arrow-right" color="#C4CADA"></u-icon>
|
|
|
|
</view>
|
|
|
|
</button>
|
|
|
|
<view
|
|
|
|
class="section wd-flex wd-flex-row wd-justify-between"
|
|
|
|
@click="callPhone"
|
|
|
|
>
|
|
|
|
<view class="wd-flex wd-flex-row" style="gap: 8rpx">
|
|
|
|
<u--image
|
|
|
|
src="/static/images/owner/phone.png"
|
|
|
|
width="40rpx"
|
|
|
|
height="40rpx"
|
|
|
|
mode="aspectFill"
|
|
|
|
></u--image>
|
|
|
|
<text style="color: #252f4a">内部专线</text>
|
|
|
|
</view>
|
|
|
|
<view class="row">
|
|
|
|
<view style="color: #78829d; line-height: 120%">点击拨打</view>
|
|
|
|
<u-icon name="arrow-right" color="#C4CADA"></u-icon>
|
|
|
|
</view>
|
|
|
|
</view>
|
|
|
|
<button
|
|
|
|
class="section wd-flex wd-flex-row wd-justify-between"
|
|
|
|
@click="btnJobInfo"
|
|
|
|
>
|
|
|
|
<view class="wd-flex wd-flex-row" style="gap: 8rpx">
|
|
|
|
<u--image
|
|
|
|
src="/static/images/owner/bill.png"
|
|
|
|
width="40rpx"
|
|
|
|
height="40rpx"
|
|
|
|
mode="aspectFill"
|
|
|
|
></u--image>
|
|
|
|
<text style="color: #252f4a">工作汇报</text>
|
|
|
|
</view>
|
|
|
|
<view class="row">
|
|
|
|
<u-count-to
|
|
|
|
:startVal="0"
|
|
|
|
:endVal="jobCount"
|
|
|
|
fontSize="28rpx"
|
|
|
|
separator=","
|
|
|
|
color="#17C653"
|
|
|
|
></u-count-to>
|
|
|
|
<u-icon name="arrow-right" color="#C4CADA"></u-icon>
|
|
|
|
</view>
|
|
|
|
</button>
|
|
|
|
</scroll-view>
|
|
|
|
</cs-page>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
import { mapGetters } from 'vuex'
|
|
|
|
import { getUserProfile } from '@/api/system/user.js'
|
|
|
|
import { PolicyApi, formatPolicyContext } from '@/api/policy/index.js'
|
|
|
|
import { JobInfoApi } from '@/api/jobinfo/index.js'
|
|
|
|
import { NoticApi } from '@/api/common/notic.js'
|
|
|
|
export default {
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
user: {},
|
|
|
|
policyTotal: 0,
|
|
|
|
jobCount: 0,
|
|
|
|
share: {}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
computed: {},
|
|
|
|
onShow() {
|
|
|
|
this.init()
|
|
|
|
},
|
|
|
|
onShareAppMessage() {
|
|
|
|
return this.share
|
|
|
|
},
|
|
|
|
onShareTimeline() {
|
|
|
|
return this.share
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
btnPolicy() {
|
|
|
|
uni.navigateTo({
|
|
|
|
url: '/sub/owner/policy'
|
|
|
|
})
|
|
|
|
},
|
|
|
|
btnJobInfo() {
|
|
|
|
uni.navigateTo({
|
|
|
|
url: '/sub/owner/jobInfo'
|
|
|
|
})
|
|
|
|
},
|
|
|
|
|
|
|
|
async init() {
|
|
|
|
getUserProfile().then(res => {
|
|
|
|
this.user = res.data
|
|
|
|
})
|
|
|
|
const notic = await NoticApi.getListData({ readStatus: false })
|
|
|
|
this.policyTotal = notic.data.total
|
|
|
|
const job = await JobInfoApi.getJobInfoPage()
|
|
|
|
this.jobCount = job.data.total
|
|
|
|
},
|
|
|
|
openSubMessage() {
|
|
|
|
uni.requestSubscribeMessage({
|
|
|
|
//此处填写刚才申请模板的模板ID
|
|
|
|
tmplIds: [
|
|
|
|
'2Mfm2TRKwEP4jF_wRaQQ6EfuhHO5c1CQhKiWAl-cm9g',
|
|
|
|
'DcXH1Zo78EoG25771zxR0JcsUj8TTbG-Go3yT8YAszM',
|
|
|
|
'E8RK91cPLMios6ZHoKx6FJOV4H2kodx6yPWYp7jpLJY'
|
|
|
|
],
|
|
|
|
complete(res) {
|
|
|
|
uni.navigateTo({
|
|
|
|
url: '/sub/owner/notic'
|
|
|
|
})
|
|
|
|
}
|
|
|
|
})
|
|
|
|
},
|
|
|
|
edit() {
|
|
|
|
uni.navigateTo({
|
|
|
|
url: '/sub/owner/edit'
|
|
|
|
})
|
|
|
|
},
|
|
|
|
|
|
|
|
invite() {
|
|
|
|
this.share = {
|
|
|
|
title: '邀请企业入驻', // 标题
|
|
|
|
path: `/pages/login?inviteId=${this.$store.getters.userId}`,
|
|
|
|
imageUrl: 'https://hb.jzce.com/fx_qyrz.png'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
callPhone() {
|
|
|
|
uni.makePhoneCall({
|
|
|
|
phoneNumber: '04167230123'
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style lang="scss" scoped>
|
|
|
|
.header {
|
|
|
|
display: flex;
|
|
|
|
flex-flow: row nowrap;
|
|
|
|
gap: 20rpx;
|
|
|
|
align-items: center;
|
|
|
|
.title {
|
|
|
|
font-size: 32rpx;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.owner-container {
|
|
|
|
padding: 32rpx;
|
|
|
|
height: 100%;
|
|
|
|
.dept {
|
|
|
|
font-size: 24rpx;
|
|
|
|
background-color: #17c653;
|
|
|
|
color: #fff;
|
|
|
|
padding: 4rpx 16rpx;
|
|
|
|
border-radius: 240rpx;
|
|
|
|
}
|
|
|
|
.section {
|
|
|
|
border-radius: 16rpx;
|
|
|
|
background: #fff;
|
|
|
|
margin-bottom: 32rpx;
|
|
|
|
padding: 48rpx;
|
|
|
|
font-size: 28rpx;
|
|
|
|
}
|
|
|
|
.moblie {
|
|
|
|
color: $uni-text-color-grey;
|
|
|
|
}
|
|
|
|
.notice-wrapper {
|
|
|
|
height: 45rpx;
|
|
|
|
width: 45rpx;
|
|
|
|
background-color: #17c653;
|
|
|
|
border-radius: 50%;
|
|
|
|
display: flex;
|
|
|
|
justify-content: center;
|
|
|
|
align-items: center;
|
|
|
|
}
|
|
|
|
.row {
|
|
|
|
display: flex;
|
|
|
|
flex-flow: row nowrap;
|
|
|
|
align-items: center;
|
|
|
|
gap: 8rpx;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
::v-deep .u-tag--mini {
|
|
|
|
padding: 4rpx 16rpx;
|
|
|
|
}
|
|
|
|
</style>
|