254 lines
7.1 KiB
Vue
254 lines
7.1 KiB
Vue
|
<template>
|
|||
|
<view class="container">
|
|||
|
<VNavigationBar style="position: relative;z-index: 99;" backgroundColor="#fff" title-color="#000" title="消息中心" :showClear="showClear" @clearNoRead="clearNoReadFun"></VNavigationBar>
|
|||
|
<!-- <VNavigationBar background-color="#fff" title-color="#333" title="消息中心" :showClear="showClear" @clearNoRead="clearNoReadFun"></VNavigationBar>-->
|
|||
|
<view class="body">
|
|||
|
<view class="messageList">
|
|||
|
<scroll-view style="height: 100%;" scroll-y="true" class="itemContent" @scrolltolower="onReachBottomCus"
|
|||
|
refresher-enabled @refresherrefresh="onRefresherrefresh" :refresher-triggered="isTriggered">
|
|||
|
<view v-for="(item, index) in messageList" :key="index" class="messageItem" @click="readNotice(item)">
|
|||
|
<image class="messageIcon" src="../../static/icons/message-icon1.png" mode="aspectFit"></image>
|
|||
|
<view class="messageContent">
|
|||
|
<view :class="{'messageTitle':item.readStatus,'noReadTitle':!item.readStatus}" >系统通知</view>
|
|||
|
<view class="messageContent_content">{{item.templateContent}}</view>
|
|||
|
<view class="messageContent_content" style="text-align: right">{{formatTime(item.createTime)}}</view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
<view style="text-align: center" v-if="messageList.length==0">
|
|||
|
<image class="" src="@/static/images/nothing.png"></image>
|
|||
|
</view>
|
|||
|
</scroll-view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
<!-- 提示窗示例 -->
|
|||
|
<uni-popup ref="alertDialog" type="dialog">
|
|||
|
<uni-popup-dialog :type="msgType" cancelText="关闭" confirmText="我知道了" title="系统通知" :content="nowReadItem.templateContent" @confirm="dialogToggle"
|
|||
|
@close="dialogToggle"></uni-popup-dialog>
|
|||
|
</uni-popup>
|
|||
|
<!-- <!– 普通弹窗 –>-->
|
|||
|
<!-- <uni-popup ref="popup" background-color="#fff" >-->
|
|||
|
<!-- <view class="popup-content" :class="{ 'popup-height': type === 'left' || type === 'right' }">-->
|
|||
|
<!-- <text class="text popup-content-text">{{ nowReadItem.templateContent }}</text>-->
|
|||
|
<!-- <button class="button popup-info" @click="dialogToggle"><text-->
|
|||
|
<!-- class="button-text info-text">知道了</text></button>-->
|
|||
|
<!-- </view>-->
|
|||
|
<!-- </uni-popup>-->
|
|||
|
</view>
|
|||
|
</template>
|
|||
|
|
|||
|
<script>
|
|||
|
import VNavigationBar from '@/components/VNavigationBar.vue'
|
|||
|
import request from "@/utils/request";
|
|||
|
import {formatTimestamp} from "@/utils/utils";
|
|||
|
|
|||
|
export default {
|
|||
|
components: {
|
|||
|
VNavigationBar,
|
|||
|
},
|
|||
|
data() {
|
|||
|
return {
|
|||
|
msgType: 'success',
|
|||
|
messageList: [],
|
|||
|
pageNo: 1,
|
|||
|
pageSize: 15,
|
|||
|
total: 0,
|
|||
|
//下来刷新状态
|
|||
|
isTriggered:false,
|
|||
|
//是否显示一键清空
|
|||
|
showClear:true,
|
|||
|
nowReadItem:{},
|
|||
|
};
|
|||
|
},
|
|||
|
onLoad(){
|
|||
|
|
|||
|
},
|
|||
|
onShow(){
|
|||
|
this.getList()
|
|||
|
},
|
|||
|
methods:{
|
|||
|
/**
|
|||
|
* 点击阅读消息
|
|||
|
*/
|
|||
|
async readNotice(item) {
|
|||
|
this.nowReadItem = item
|
|||
|
// open 方法传入参数 等同在 uni-popup 组件上绑定 type属性
|
|||
|
this.$refs.alertDialog.open()
|
|||
|
//直接请求后台已读
|
|||
|
await request({
|
|||
|
url: "/admin-api/system/notify-message/update-read",
|
|||
|
method: "PUT",
|
|||
|
params:{ids:this.nowReadItem.id},
|
|||
|
tenantIdFlag:false
|
|||
|
}).then((res) => {
|
|||
|
if(res.code==200){
|
|||
|
this.onRefresherrefresh()
|
|||
|
}
|
|||
|
})
|
|||
|
},
|
|||
|
/**
|
|||
|
* 消息设置为已读
|
|||
|
*/
|
|||
|
dialogToggle(){
|
|||
|
|
|||
|
},
|
|||
|
/**
|
|||
|
* 一键清空未读消息
|
|||
|
*/
|
|||
|
async clearNoReadFun(){
|
|||
|
console.log("清空了")
|
|||
|
await request({
|
|||
|
url: "/admin-api/system/notify-message/update-all-read",
|
|||
|
method: "PUT",
|
|||
|
tenantIdFlag:false
|
|||
|
}).then((res) => {
|
|||
|
if(res.code==200){
|
|||
|
uni.showToast({
|
|||
|
title: '操作成功',
|
|||
|
icon: 'none'
|
|||
|
})
|
|||
|
setTimeout(()=>{
|
|||
|
this.onRefresherrefresh()
|
|||
|
},500)
|
|||
|
}
|
|||
|
})
|
|||
|
},
|
|||
|
formatTime(value){
|
|||
|
return formatTimestamp(value)
|
|||
|
},
|
|||
|
/**
|
|||
|
* 上滑加载数据
|
|||
|
*/
|
|||
|
onReachBottomCus() {
|
|||
|
//判断 如果页码*页容量大于等于总条数,提示该页数据加载完毕
|
|||
|
if (this.pageNo * this.pageSize >= this.total) {
|
|||
|
uni.$u.toast('没有更多数据了')
|
|||
|
return
|
|||
|
}
|
|||
|
//页码+1,调用获取数据的方法获取第二页数据
|
|||
|
this.pageNo++
|
|||
|
//此处调用自己获取数据列表的方法
|
|||
|
this.getList()
|
|||
|
},
|
|||
|
/**
|
|||
|
* 下拉刷新数据
|
|||
|
*/
|
|||
|
onRefresherrefresh(){
|
|||
|
this.isTriggered = true
|
|||
|
this.pageNo = 1
|
|||
|
this.total = 0
|
|||
|
this.messageList = []
|
|||
|
this.getList()
|
|||
|
},
|
|||
|
/**
|
|||
|
* 分页查询
|
|||
|
*/
|
|||
|
async getList(){
|
|||
|
await request({
|
|||
|
url: "/admin-api/system/notify-message/my-page",
|
|||
|
method: "GET",
|
|||
|
params:{
|
|||
|
pageNo:this.pageNo,
|
|||
|
pageSize:this.pageSize
|
|||
|
}
|
|||
|
}).then((res) => {
|
|||
|
//判断 如果获取的数据的页码不是第一页,就让之前赋值获取过的数组数据 concat连接 刚获取的第n页数据
|
|||
|
if (this.pageNo != 1) {
|
|||
|
this.messageList = this.messageList.concat(res.data.list)
|
|||
|
} else {
|
|||
|
this.messageList = res.data.list
|
|||
|
}
|
|||
|
//将获取的总条数赋值
|
|||
|
this.total = res.data.total
|
|||
|
this.isTriggered = false
|
|||
|
})
|
|||
|
},
|
|||
|
}
|
|||
|
}
|
|||
|
</script>
|
|||
|
|
|||
|
<style lang="less" scoped>
|
|||
|
.container {
|
|||
|
height: 100%;
|
|||
|
display: flex;
|
|||
|
flex-direction: column;
|
|||
|
.body {
|
|||
|
flex: 1;
|
|||
|
height: calc(100vh - env(safe-area-inset-top));
|
|||
|
overflow: auto;
|
|||
|
}
|
|||
|
.messageList {
|
|||
|
padding: 0 32rpx;
|
|||
|
height: 100%;
|
|||
|
}
|
|||
|
.messageItem {
|
|||
|
padding: 30rpx 0;
|
|||
|
display: flex;
|
|||
|
align-items: center;
|
|||
|
column-gap: 20rpx;
|
|||
|
border-bottom: 1rpx solid #EEEEEE;
|
|||
|
|
|||
|
.messageIcon {
|
|||
|
width: 80rpx;
|
|||
|
height: 80rpx;
|
|||
|
}
|
|||
|
.noReadTitle {
|
|||
|
font-weight: bold;
|
|||
|
font-size: 32rpx;
|
|||
|
color: #333333;
|
|||
|
}
|
|||
|
.noReadTitle:after{
|
|||
|
content: "*";
|
|||
|
color: red;
|
|||
|
display: block; /* 或者其他的块级显示类型,比如 inline-block, table 等 */
|
|||
|
position: absolute; /* 或者 absolute 或者 fixed,取决于你的布局需求 */
|
|||
|
z-index: 1; /* 确保它在元素的上方 */
|
|||
|
right: 0;
|
|||
|
}
|
|||
|
|
|||
|
.messageContent {
|
|||
|
flex: 1;
|
|||
|
width: 0;
|
|||
|
}
|
|||
|
.messageTitle {
|
|||
|
font-size: 32rpx;
|
|||
|
color: #333333;
|
|||
|
}
|
|||
|
.messageContent_content {
|
|||
|
font-weight: 500;
|
|||
|
font-size: 28rpx;
|
|||
|
color: #858BA0;
|
|||
|
|
|||
|
overflow: hidden;
|
|||
|
white-space: nowrap;
|
|||
|
text-overflow: ellipsis;
|
|||
|
}
|
|||
|
}
|
|||
|
.popup-content {
|
|||
|
padding: 15px;
|
|||
|
height: auto;
|
|||
|
margin: auto;
|
|||
|
width: 80%;
|
|||
|
background-color: #fff;
|
|||
|
}
|
|||
|
.popup-content-text {
|
|||
|
display: flex;
|
|||
|
align-items: center;
|
|||
|
justify-content: center;
|
|||
|
}
|
|||
|
|
|||
|
.text {
|
|||
|
color: #333;
|
|||
|
}
|
|||
|
|
|||
|
.popup-info {
|
|||
|
margin-top: 30rpx;
|
|||
|
color: #fff;
|
|||
|
background-color: #f2f6fc;
|
|||
|
}
|
|||
|
|
|||
|
.info-text {
|
|||
|
color: #909399;
|
|||
|
}
|
|||
|
}
|
|||
|
</style>
|