mirror of
https://github.com/IT4Change/Ocelot-Social.git
synced 2026-01-18 19:01:24 +00:00
add apollo messages query
This commit is contained in:
parent
01ce770b2d
commit
932ad7037f
16
webapp/graphql/Messages.js
Normal file
16
webapp/graphql/Messages.js
Normal file
@ -0,0 +1,16 @@
|
||||
import gql from 'graphql-tag'
|
||||
|
||||
export const messageQuery = () => {
|
||||
return gql`
|
||||
query($roomId: ID!) {
|
||||
Message(roomId: $roomId) {
|
||||
id
|
||||
content
|
||||
author {
|
||||
id
|
||||
}
|
||||
}
|
||||
}
|
||||
`
|
||||
}
|
||||
|
||||
@ -1,6 +1,6 @@
|
||||
import gql from 'graphql-tag'
|
||||
|
||||
export const RoomQuery = () => gql`
|
||||
export const roomQuery = () => gql`
|
||||
query {
|
||||
Room {
|
||||
id
|
||||
|
||||
@ -36,7 +36,8 @@ register()
|
||||
import links from '~/constants/links.js'
|
||||
import { internalPageMixins } from '~/mixins/internalPageMixins'
|
||||
import BaseButton from '../components/_new/generic/BaseButton/BaseButton.vue'
|
||||
import { RoomQuery } from '~/graphql/Rooms'
|
||||
import { roomQuery } from '~/graphql/Rooms'
|
||||
import { messageQuery } from '~/graphql/Messages'
|
||||
|
||||
export default {
|
||||
components: { BaseButton },
|
||||
@ -132,19 +133,36 @@ export default {
|
||||
},
|
||||
|
||||
methods: {
|
||||
fetchMessages({ options = {} }) {
|
||||
setTimeout(() => {
|
||||
fetchMessages({ room, options = {} }) {
|
||||
console.log(room, options)
|
||||
this.messagesLoaded = false
|
||||
setTimeout(async () => {
|
||||
if (options.reset) {
|
||||
this.messages = this.addMessages(true)
|
||||
console.log('reset messages')
|
||||
this.messages = [] // this.addMessages(true)
|
||||
} else {
|
||||
this.messages = [...this.addMessages(), ...this.messages]
|
||||
this.messagesLoaded = true
|
||||
try {
|
||||
const {
|
||||
data: { Message },
|
||||
} = await this.$apollo.query({
|
||||
query: messageQuery(),
|
||||
variables: {
|
||||
roomId: room.id,
|
||||
}
|
||||
})
|
||||
console.log('Messages', Message)
|
||||
this.messages = Message
|
||||
} catch (error) {
|
||||
console.log('Error', error)
|
||||
this.messages = [] //this.addMessages(true)
|
||||
this.$toast.error(error.message)
|
||||
}
|
||||
}
|
||||
// this.addNewMessage()
|
||||
this.messagesLoaded = true
|
||||
})
|
||||
},
|
||||
|
||||
addMessages(reset) {
|
||||
/* addMessages(reset) {
|
||||
const messages = []
|
||||
|
||||
for (let i = 0; i < 30; i++) {
|
||||
@ -167,7 +185,7 @@ export default {
|
||||
})
|
||||
|
||||
return messages
|
||||
},
|
||||
}, */
|
||||
|
||||
sendMessage(message) {
|
||||
this.messages = [
|
||||
@ -200,7 +218,7 @@ export default {
|
||||
apollo: {
|
||||
Rooms: {
|
||||
query() {
|
||||
return RoomQuery()
|
||||
return roomQuery()
|
||||
},
|
||||
update({ Room }) {
|
||||
console.log('Rooms', Room)
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user