diff options
| author | Roger Braun <roger@rogerbraun.net> | 2016-11-07 18:36:11 +0100 |
|---|---|---|
| committer | Roger Braun <roger@rogerbraun.net> | 2016-11-07 18:36:11 +0100 |
| commit | cc7f7a29cf8435cc2486122976504c38ffe75c33 (patch) | |
| tree | 492a77b79faf58d5b4f39025592e727b978974cc /src | |
| parent | 8199c8e45d5dee07b358e07c13419c0cf3bb9e6d (diff) | |
Better retweet handling.
Fixes problems with liking + likes count.
Diffstat (limited to 'src')
| -rw-r--r-- | src/modules/statuses.js | 25 |
1 files changed, 23 insertions, 2 deletions
diff --git a/src/modules/statuses.js b/src/modules/statuses.js index 38cba185..2f5238ee 100644 --- a/src/modules/statuses.js +++ b/src/modules/statuses.js @@ -1,4 +1,4 @@ -import { map, slice, last, intersectionBy, sortBy, unionBy, toInteger, groupBy, differenceBy, each, find } from 'lodash' +import { flatten, map, slice, last, intersectionBy, sortBy, unionBy, toInteger, groupBy, differenceBy, each, find } from 'lodash' import moment from 'moment' import apiService from '../services/api/api.service.js' @@ -55,8 +55,16 @@ const addStatusesToTimeline = (addedStatuses, showImmediately, { statuses, visib addedStatuses = statusesAndFaves['status'] || [] + const splitRetweets = (status) => { + if (status.retweeted_status) { + return [status, status.retweeted_status] + } else { + return status + } + } + // Add some html and nsfw to the statuses. - each(addedStatuses, (status) => { + addedStatuses = map(addedStatuses, (status) => { const statusoid = status.retweeted_status || status statusoid.created_at_parsed = statusoid.created_at @@ -70,8 +78,12 @@ const addStatusesToTimeline = (addedStatuses, showImmediately, { statuses, visib const nsfwRegex = /#nsfw/i statusoid.nsfw = statusoid.text.match(nsfwRegex) } + + return splitRetweets(status) }) + addedStatuses = flatten(addedStatuses) + const newStatuses = sortBy( unionBy(addedStatuses, statuses, 'id'), ({id}) => -id @@ -114,6 +126,15 @@ export const mutations = { addNewStatuses (state, { statuses, showImmediately = false, timeline }) { state.timelines[timeline] = addStatusesToTimeline(statuses, showImmediately, state.timelines[timeline]) state.allStatuses = unionBy(state.timelines[timeline].statuses, state.allStatuses.id) + + // Set up retweets with most current status + + each(state.allStatuses, (status) => { + if (status.retweeted_status) { + const retweetedStatus = find(state.allStatuses, { id: status.retweeted_status.id }) + status.retweeted_status = retweetedStatus + } + }) }, showNewStatuses (state, { timeline }) { const oldTimeline = (state.timelines[timeline]) |
