summaryrefslogtreecommitdiffstats
path: root/src/store
diff options
context:
space:
mode:
authorJulius Härtl <jus@bitgrid.net>2018-11-21 18:27:33 +0100
committerJulius Härtl <jus@bitgrid.net>2018-11-21 18:27:33 +0100
commit67b78f8e8adf39a76ef374be0d99cc76f180927a (patch)
tree4ae1a6cfa46697ce1cbf9b477360013710fcfb6a /src/store
parent873d91d7c39c05f2f2d34c9a8098e3f9e74b79d3 (diff)
Refresh timeline when posting
Signed-off-by: Julius Härtl <jus@bitgrid.net>
Diffstat (limited to 'src/store')
-rw-r--r--src/store/timeline.js18
1 files changed, 13 insertions, 5 deletions
diff --git a/src/store/timeline.js b/src/store/timeline.js
index a5f0d4a5..9afd148d 100644
--- a/src/store/timeline.js
+++ b/src/store/timeline.js
@@ -21,16 +21,17 @@
*/
import axios from 'nextcloud-axios'
+import Vue from 'vue'
const state = {
- timeline: [],
+ timeline: {},
since: new Date()
}
const mutations = {
addToTimeline(state, data) {
for (let item in data) {
state.since = data[item].published
- state.timeline.push(data[item])
+ Vue.set(state.timeline, data[item].id, data[item])
}
},
addPost(state, data) {
@@ -40,7 +41,9 @@ const mutations = {
}
const getters = {
getTimeline(state) {
- return state.timeline
+ return Object.values(state.timeline).sort(function(a, b) {
+ return b.publishedTime - a.publishedTime
+ })
}
}
const actions = {
@@ -52,8 +55,13 @@ const actions = {
console.error('Failed to create a post', error)
})
},
- fetchTimeline(context, account) {
- const sinceTimestamp = Date.parse(state.since) / 1000
+ refreshTimeline(context, account) {
+ return this.dispatch('fetchTimeline', { account: account, sinceTimestamp: Math.floor(Date.now() / 1000) + 1 })
+ },
+ fetchTimeline(context, { account, sinceTimestamp }) {
+ if (typeof sinceTimestamp === 'undefined') {
+ sinceTimestamp = Date.parse(state.since) / 1000
+ }
return axios.get(OC.generateUrl('apps/social/api/v1/timeline?limit=5&since=' + sinceTimestamp)).then((response) => {
if (response.status === -1) {
throw response.message