Better retweet handling.
Fixes problems with liking + likes count.
This commit is contained in:
parent
8199c8e45d
commit
cc7f7a29cf
2 changed files with 43 additions and 4 deletions
|
@ -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])
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue