Merge pull request #6611 from Ocelot-Social-Community/fix-chat-behaviour

fix(webapp): fix chat behaviour
This commit is contained in:
Ulf Gebhardt 2023-07-19 12:31:25 +02:00 committed by GitHub
commit b1e39585b1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -35,7 +35,7 @@
<div slot="room-header-avatar"> <div slot="room-header-avatar">
<div <div
v-if="selectedRoom && selectedRoom.avatar && selectedRoom.avatar !== 'default-avatar'" v-if="selectedRoom && selectedRoom.avatar"
class="vac-avatar" class="vac-avatar"
:style="{ 'background-image': `url('${selectedRoom.avatar}')` }" :style="{ 'background-image': `url('${selectedRoom.avatar}')` }"
/> />
@ -46,7 +46,7 @@
<div v-for="room in rooms" :slot="'room-list-avatar_' + room.id" :key="room.id"> <div v-for="room in rooms" :slot="'room-list-avatar_' + room.id" :key="room.id">
<div <div
v-if="room.avatar && room.avatar !== 'default-avatar'" v-if="room.avatar"
class="vac-avatar" class="vac-avatar"
:style="{ 'background-image': `url('${room.avatar}')` }" :style="{ 'background-image': `url('${room.avatar}')` }"
/> />
@ -222,9 +222,9 @@ export default {
...mapMutations({ ...mapMutations({
commitUnreadRoomCount: 'chat/UPDATE_ROOM_COUNT', commitUnreadRoomCount: 'chat/UPDATE_ROOM_COUNT',
}), }),
async fetchRooms({ room } = {}) { async fetchRooms({ room, options = {} } = {}) {
this.roomsLoaded = false this.roomsLoaded = options.refetch ? this.roomsLoaded : false
const offset = this.roomPage * this.roomPageSize const offset = (options.refetch ? 0 : this.roomPage) * this.roomPageSize
try { try {
const { const {
data: { Room }, data: { Room },
@ -238,16 +238,25 @@ export default {
fetchPolicy: 'no-cache', fetchPolicy: 'no-cache',
}) })
const newRooms = Room.map((r) => { const rms = []
return { const rmsIds = []
...r, ;[...Room, ...this.rooms].forEach((r) => {
users: r.users.map((u) => { if (!rmsIds.find((v) => v === r.id)) {
return { ...u, username: u.name, avatar: u.avatar?.url } rms.push({
}), ...r,
index: r.lastMessage?.date,
lastMessage: {
...r.lastMessage,
content: r.lastMessage?.content.trim().substring(0, 30),
},
users: r.users.map((u) => {
return { ...u, username: u.name, avatar: u.avatar?.url }
}),
})
rmsIds.push(r.id)
} }
}) })
this.rooms = rms
this.rooms = [...this.rooms, ...newRooms]
if (Room.length < this.roomPageSize) { if (Room.length < this.roomPageSize) {
this.roomsLoaded = true this.roomsLoaded = true
@ -282,8 +291,14 @@ export default {
fetchPolicy: 'no-cache', fetchPolicy: 'no-cache',
}) })
const newMsgIds = Message.filter((m) => m.seen === false).map((m) => m.id) const newMsgIds = Message.filter(
(m) => m.seen === false && m.senderId !== this.currentUser.id,
).map((m) => m.id)
if (newMsgIds.length) { if (newMsgIds.length) {
const roomIndex = this.rooms.findIndex((r) => r.id === room.id)
const changedRoom = { ...this.rooms[roomIndex] }
changedRoom.unreadCount = changedRoom.unreadCount - newMsgIds.length
this.rooms[roomIndex] = changedRoom
this.$apollo this.$apollo
.mutate({ .mutate({
mutation: markMessagesAsSeen(), mutation: markMessagesAsSeen(),
@ -322,14 +337,17 @@ export default {
}, },
async chatMessageAdded({ data }) { async chatMessageAdded({ data }) {
const roomIndex = this.rooms.findIndex((r) => r.id === data.chatMessageAdded.room.id)
const changedRoom = { ...this.rooms[roomIndex] }
changedRoom.lastMessage = data.chatMessageAdded
changedRoom.lastMessage.content = changedRoom.lastMessage.content.trim().substring(0, 30)
changedRoom.lastMessageAt = data.chatMessageAdded.date
changedRoom.unreadCount++
this.rooms[roomIndex] = changedRoom
if (data.chatMessageAdded.room.id === this.selectedRoom?.id) { if (data.chatMessageAdded.room.id === this.selectedRoom?.id) {
this.fetchMessages({ room: this.selectedRoom, options: { refetch: true } }) this.fetchMessages({ room: this.selectedRoom, options: { refetch: true } })
} else { } else {
// TODO this might be optimized selectively (first page vs rest) this.fetchRooms({ options: { refetch: true } })
this.rooms = []
this.roomPage = 0
this.roomsLoaded = false
this.fetchRooms()
} }
}, },
@ -348,6 +366,11 @@ export default {
content: message.content, content: message.content,
}, },
}) })
const roomIndex = this.rooms.findIndex((r) => r.id === message.roomId)
const changedRoom = { ...this.rooms[roomIndex] }
changedRoom.lastMessage = message
changedRoom.lastMessage.content = changedRoom.lastMessage.content.trim().substring(0, 30)
this.rooms[roomIndex] = changedRoom
} catch (error) { } catch (error) {
this.$toast.error(error.message) this.$toast.error(error.message)
} }