✨消息新增红点、已读功能
This commit is contained in:
parent
c1bfaabcb2
commit
d48866b248
@ -2,15 +2,16 @@
|
|||||||
<div>
|
<div>
|
||||||
<el-popover placement="bottom" trigger="click" width="400px" popper-class="el-popover-pupop-user-news">
|
<el-popover placement="bottom" trigger="click" width="400px" popper-class="el-popover-pupop-user-news">
|
||||||
<template #reference>
|
<template #reference>
|
||||||
<el-badge :is-dot="noticeDot" style="line-height: 18px">
|
<el-badge :hidden="noticeDot <= 0" :value="noticeDot" style="line-height: 18px">
|
||||||
<el-icon><bell /></el-icon>
|
<el-icon><bell /></el-icon>
|
||||||
</el-badge>
|
</el-badge>
|
||||||
</template>
|
</template>
|
||||||
<div class="layout-navbars-breadcrumb-user-news">
|
<div class="layout-navbars-breadcrumb-user-news">
|
||||||
|
<div class="read" @click="onAllReadClick">全部已读</div>
|
||||||
<el-tabs v-model="noticeType">
|
<el-tabs v-model="noticeType">
|
||||||
<el-tab-pane name="0">
|
<el-tab-pane name="0">
|
||||||
<template #label>
|
<template #label>
|
||||||
<el-badge :is-dot="newsDot" class="item"> 通知 </el-badge>
|
<el-badge :is-dot="newsDot" class="new-item"> 通知 </el-badge>
|
||||||
</template>
|
</template>
|
||||||
<div class="content-box">
|
<div class="content-box">
|
||||||
<div class="content-box-item" v-for="item in noticeList" @click="handleDetails(item, 0)">
|
<div class="content-box-item" v-for="item in noticeList" @click="handleDetails(item, 0)">
|
||||||
@ -20,12 +21,14 @@
|
|||||||
<div class="content-box-time">{{ dayjs(item.create_time).format('YYYY-MM-DD') }}</div>
|
<div class="content-box-time">{{ dayjs(item.create_time).format('YYYY-MM-DD') }}</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<el-empty v-if="noticeList.length <= 0" :image-size="60" description="暂无公告"></el-empty>
|
||||||
</div>
|
</div>
|
||||||
</el-tab-pane>
|
</el-tab-pane>
|
||||||
|
|
||||||
<el-tab-pane name="1">
|
<el-tab-pane name="1">
|
||||||
<template #label>
|
<template #label>
|
||||||
<el-badge :value="chatList.length"> 私信 </el-badge>
|
<el-badge :hidden="chatDotNum <= 0" :value="chatDotNum" class="new-item"> 私信 </el-badge>
|
||||||
</template>
|
</template>
|
||||||
<div class="content-box">
|
<div class="content-box">
|
||||||
<div class="content-box-item" v-for="item in chatList" @click="handleDetails(item, 1)">
|
<div class="content-box-item" v-for="item in chatList" @click="handleDetails(item, 1)">
|
||||||
@ -38,13 +41,13 @@
|
|||||||
<div class="content-box-time">{{ formatTime(item.chatTime) }}</div>
|
<div class="content-box-time">{{ formatTime(item.chatTime) }}</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<el-empty v-if="chatList.length <= 0" :image-size="60" description="暂无私信"></el-empty>
|
||||||
</div>
|
</div>
|
||||||
</el-tab-pane>
|
</el-tab-pane>
|
||||||
</el-tabs>
|
</el-tabs>
|
||||||
|
|
||||||
<div class="foot-box">
|
<div class="foot-box">
|
||||||
<div @click="onGoToGiteeClick" v-if="noticeList.length > 0">前往通知中心</div>
|
<div @click="onGoToGiteeClick" v-if="noticeList.length > 0">前往通知中心</div>
|
||||||
<div>全部已读</div>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</el-popover>
|
</el-popover>
|
||||||
@ -52,10 +55,13 @@
|
|||||||
<el-dialog draggable v-model="show" append-to-body>
|
<el-dialog draggable v-model="show" append-to-body>
|
||||||
<template #header> {{ info.title }} </template>
|
<template #header> {{ info.title }} </template>
|
||||||
<template v-if="info">
|
<template v-if="info">
|
||||||
<div v-if="info.type == 0">
|
<template v-if="noticeType == 0">
|
||||||
<div v-html="info.item.noticeContent"></div>
|
<div v-html="info.item.noticeContent"></div>
|
||||||
</div>
|
|
||||||
<msgList v-if="info.type == 1" v-model="info.userId"> </msgList>
|
<div class="n_right">{{ info.item.create_by }}</div>
|
||||||
|
<div class="n_right">{{ dayjs(info.item.create_time).format('YYYY-MM-DD HH:mm') }}</div>
|
||||||
|
</template>
|
||||||
|
<msgList v-if="noticeType == 1" v-model="info.userId"> </msgList>
|
||||||
</template>
|
</template>
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
</div>
|
</div>
|
||||||
@ -76,11 +82,14 @@ const noticeList = computed(() => {
|
|||||||
return useSocketStore().noticeList
|
return useSocketStore().noticeList
|
||||||
})
|
})
|
||||||
const noticeDot = computed(() => {
|
const noticeDot = computed(() => {
|
||||||
return useSocketStore().noticeDot
|
return useSocketStore().getAllDotNum()
|
||||||
})
|
})
|
||||||
const chatList = computed(() => {
|
const chatList = computed(() => {
|
||||||
return useSocketStore().getSessionList(useUserStore().userId)
|
return useSocketStore().getSessionList(useUserStore().userId)
|
||||||
})
|
})
|
||||||
|
const chatDotNum = computed(() => {
|
||||||
|
return useSocketStore().newChat
|
||||||
|
})
|
||||||
const info = ref({})
|
const info = ref({})
|
||||||
function handleDetails(item, type) {
|
function handleDetails(item, type) {
|
||||||
show.value = true
|
show.value = true
|
||||||
@ -93,7 +102,11 @@ function handleDetails(item, type) {
|
|||||||
// 全部已读点击
|
// 全部已读点击
|
||||||
function onAllReadClick() {
|
function onAllReadClick() {
|
||||||
newsDot.value = false
|
newsDot.value = false
|
||||||
proxy.$modal.msg('请自行实现!!!')
|
if (noticeType.value == 1) {
|
||||||
|
useSocketStore().readAll()
|
||||||
|
} else {
|
||||||
|
proxy.$modal.msg('请自行实现!!!')
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// 前往通知中心点击
|
// 前往通知中心点击
|
||||||
function onGoToGiteeClick() {
|
function onGoToGiteeClick() {
|
||||||
@ -102,29 +115,11 @@ function onGoToGiteeClick() {
|
|||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
// .head-box {
|
|
||||||
// display: flex;
|
|
||||||
// border-bottom: 1px solid #ebeef5;
|
|
||||||
// box-sizing: border-box;
|
|
||||||
// color: #333333;
|
|
||||||
// justify-content: space-between;
|
|
||||||
// height: 35px;
|
|
||||||
// align-items: center;
|
|
||||||
// .head-box-btn {
|
|
||||||
// color: #1890ff;
|
|
||||||
// font-size: 13px;
|
|
||||||
// cursor: pointer;
|
|
||||||
// opacity: 0.8;
|
|
||||||
// &:hover {
|
|
||||||
// opacity: 1;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
.content-box {
|
.content-box {
|
||||||
font-size: 13px;
|
font-size: 13px;
|
||||||
min-height: 60px;
|
min-height: 160px;
|
||||||
max-height: 200px;
|
max-height: 230px;
|
||||||
overflow-y: scroll;
|
overflow: auto;
|
||||||
|
|
||||||
.content-box-item {
|
.content-box-item {
|
||||||
display: flex;
|
display: flex;
|
||||||
@ -154,17 +149,6 @@ function onGoToGiteeClick() {
|
|||||||
margin-top: 3px;
|
margin-top: 3px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.content-box-empty {
|
|
||||||
height: 260px;
|
|
||||||
display: flex;
|
|
||||||
.content-box-empty-margin {
|
|
||||||
margin: auto;
|
|
||||||
text-align: center;
|
|
||||||
i {
|
|
||||||
font-size: 60px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
.foot-box {
|
.foot-box {
|
||||||
height: 35px;
|
height: 35px;
|
||||||
@ -186,4 +170,26 @@ function onGoToGiteeClick() {
|
|||||||
.head-box-title {
|
.head-box-title {
|
||||||
color: var(--base-color-white);
|
color: var(--base-color-white);
|
||||||
}
|
}
|
||||||
|
.layout-navbars-breadcrumb-user-news {
|
||||||
|
position: relative;
|
||||||
|
.read {
|
||||||
|
position: absolute;
|
||||||
|
top: 5px;
|
||||||
|
right: 0;
|
||||||
|
color: #1890ff;
|
||||||
|
cursor: pointer;
|
||||||
|
z-index: 2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.n_right {
|
||||||
|
text-align: right;
|
||||||
|
margin: 10px;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
<style>
|
||||||
|
.new-item {
|
||||||
|
.is-fixed {
|
||||||
|
right: -3px !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|||||||
@ -2,7 +2,7 @@ import useUserStore from './user'
|
|||||||
import signalR from '@/signalr/signalr'
|
import signalR from '@/signalr/signalr'
|
||||||
const useSocketStore = defineStore('socket', {
|
const useSocketStore = defineStore('socket', {
|
||||||
persist: {
|
persist: {
|
||||||
paths: ['chatMessage', 'chatList', 'sessionList'] //存储指定key
|
paths: ['chatMessage', 'chatList', 'sessionList', 'newChat'] //存储指定key
|
||||||
},
|
},
|
||||||
state: () => ({
|
state: () => ({
|
||||||
onlineNum: 0,
|
onlineNum: 0,
|
||||||
@ -28,6 +28,9 @@ const useSocketStore = defineStore('socket', {
|
|||||||
},
|
},
|
||||||
getSessionList(state) {
|
getSessionList(state) {
|
||||||
return (userid) => state.sessionList[userid] || []
|
return (userid) => state.sessionList[userid] || []
|
||||||
|
},
|
||||||
|
getAllDotNum(state) {
|
||||||
|
return () => state.newChat
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
actions: {
|
actions: {
|
||||||
@ -70,6 +73,7 @@ const useSocketStore = defineStore('socket', {
|
|||||||
data.self = data.userId == selfUserId
|
data.self = data.userId == selfUserId
|
||||||
this.chatList[sessionId].push(data)
|
this.chatList[sessionId].push(data)
|
||||||
if (selfUserId == data.userId) return
|
if (selfUserId == data.userId) return
|
||||||
|
this.newChat++
|
||||||
|
|
||||||
if (this.sessionList[selfUserId] == undefined) {
|
if (this.sessionList[selfUserId] == undefined) {
|
||||||
this.sessionList[selfUserId] = []
|
this.sessionList[selfUserId] = []
|
||||||
@ -90,6 +94,9 @@ const useSocketStore = defineStore('socket', {
|
|||||||
console.error(err.toString())
|
console.error(err.toString())
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
},
|
||||||
|
readAll() {
|
||||||
|
this.newChat = 0
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user