aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/modules/statuses.js17
1 files changed, 15 insertions, 2 deletions
diff --git a/src/modules/statuses.js b/src/modules/statuses.js
index d7607bf1..7fa8a7b2 100644
--- a/src/modules/statuses.js
+++ b/src/modules/statuses.js
@@ -1,4 +1,4 @@
-import { reduce, map, slice, last, intersectionBy, sortBy, unionBy, toInteger, groupBy, differenceBy, each, find, flatten, maxBy } from 'lodash'
+import { reduce, map, slice, last, intersectionBy, sortBy, unionBy, toInteger, groupBy, differenceBy, each, find, flatten, maxBy, merge } from 'lodash'
import moment from 'moment'
import apiService from '../services/api/api.service.js'
// import parse from '../services/status_parser/status_parser.js'
@@ -54,6 +54,19 @@ export const prepareStatus = (status) => {
return status
}
+// Merges old and new status collections.
+const mergeStatuses = (oldStatuses, newStatuses) => {
+ each(newStatuses, (status) => {
+ let oldStatus = find(oldStatuses, { id: status.id })
+ if (oldStatus) {
+ merge(oldStatus, status)
+ } else {
+ oldStatuses.push(status)
+ }
+ })
+ return oldStatuses
+}
+
const addStatusesToTimeline = (addedStatuses, showImmediately, { statuses, visibleStatuses, newStatusCount, faves, loading, maxId }) => {
const statusesAndFaves = groupBy(addedStatuses, statusType)
const addedFaves = statusesAndFaves['fave'] || []
@@ -150,7 +163,7 @@ export const mutations = {
// const statusesByType = groupStatusesByType(statuses)
state.timelines[timeline] = addStatusesToTimeline(statuses, showImmediately, state.timelines[timeline])
- state.allStatuses = unionBy(state.timelines[timeline].statuses, state.allStatuses, 'id')
+ mergeStatuses(state.allStatuses, state.timelines[timeline].statuses)
// Set up retweets with most current status
const getRetweets = (result, status) => {