Fix interactions with rebloged statuses

Signed-off-by: Louis Chemineau <louis@chmn.me>
pull/1744/head
Louis Chemineau 2023-04-20 11:18:09 +02:00
rodzic 84fae8f634
commit 51b3ef24cd
2 zmienionych plików z 34 dodań i 25 usunięć

Wyświetl plik

@ -90,7 +90,8 @@ export default {
if (this.isNotification) { if (this.isNotification) {
return this.notification.status return this.notification.status
} else if (this.isBoost) { } else if (this.isBoost) {
return this.status.reblog // We use the object stored in the store so that actions on it are reflected.
return this.$store.getters.getStatus(this.item.reblog.id)
} else { } else {
return this.item return this.item
} }

Wyświetl plik

@ -69,6 +69,18 @@ const state = {
composerDisplayStatus: false, composerDisplayStatus: false,
} }
/**
*
* @param {typeof state} state
* @param {import ('../types/Mastodon.js').Status} status
*/
function addToStatuses(state, status) {
Vue.set(state.statuses, status.id, status)
if (status.reblog !== undefined && status.reblog !== null) {
Vue.set(state.statuses, status.reblog.id, status.reblog)
}
}
/** @type {import('vuex').MutationTree<state>} */ /** @type {import('vuex').MutationTree<state>} */
const mutations = { const mutations = {
/** /**
@ -76,7 +88,7 @@ const mutations = {
* @param {import ('../types/Mastodon.js').Status} status * @param {import ('../types/Mastodon.js').Status} status
*/ */
addToStatuses(state, status) { addToStatuses(state, status) {
Vue.set(state.statuses, status.id, status) addToStatuses(state, status)
}, },
/** /**
* @param state * @param state
@ -84,13 +96,13 @@ const mutations = {
*/ */
addToTimeline(state, data) { addToTimeline(state, data) {
if (Array.isArray(data)) { if (Array.isArray(data)) {
data.forEach(status => Vue.set(state.statuses, status.id, status)) data.forEach(status => addToStatuses(state, status))
data data
.filter(status => state.timeline.indexOf(status.id) === -1) .filter(status => state.timeline.indexOf(status.id) === -1)
.forEach(status => state.timeline.push(status.id)) .forEach(status => state.timeline.push(status.id))
} else { } else {
data.descendants.forEach(status => Vue.set(state.statuses, status.id, status)) data.descendants.forEach(status => addToStatuses(state, status))
data.ancestors.forEach(status => Vue.set(state.statuses, status.id, status)) data.ancestors.forEach(status => addToStatuses(state, status))
data.descendants data.descendants
.filter(status => state.timeline.indexOf(status.id) === -1) .filter(status => state.timeline.indexOf(status.id) === -1)
@ -100,22 +112,11 @@ const mutations = {
.forEach(status => state.parentsTimeline.push(status.id)) .forEach(status => state.parentsTimeline.push(status.id))
} }
}, },
/**
* @param state
* @param {import ('../types/Mastodon.js').Status[]} data
*/
updateInTimelines(state, data) {
data.forEach((status) => {
if (state.statuses[status.id] !== undefined) {
Vue.set(state.statuses, status.id, status)
}
})
},
/** /**
* @param state * @param state
* @param {import('../types/Mastodon.js').Status} status * @param {import('../types/Mastodon.js').Status} status
*/ */
removeStatusf(state, status) { removeStatus(state, status) {
const timelineIndex = state.timeline.indexOf(status.id) const timelineIndex = state.timeline.indexOf(status.id)
if (timelineIndex !== -1) { if (timelineIndex !== -1) {
state.timeline.splice(timelineIndex, 1) state.timeline.splice(timelineIndex, 1)
@ -161,6 +162,7 @@ const mutations = {
likeStatus(state, { status }) { likeStatus(state, { status }) {
if (state.statuses[status.id] !== undefined) { if (state.statuses[status.id] !== undefined) {
Vue.set(state.statuses[status.id], 'favourited', true) Vue.set(state.statuses[status.id], 'favourited', true)
state.statuses[status.id].favourites_count++
} }
}, },
/** /**
@ -171,6 +173,7 @@ const mutations = {
unlikeStatus(state, { status }) { unlikeStatus(state, { status }) {
if (state.statuses[status.id] !== undefined) { if (state.statuses[status.id] !== undefined) {
Vue.set(state.statuses[status.id], 'favourited', false) Vue.set(state.statuses[status.id], 'favourited', false)
state.statuses[status.id].favourites_count--
} }
}, },
/** /**
@ -181,6 +184,7 @@ const mutations = {
boostStatus(state, { status }) { boostStatus(state, { status }) {
if (state.statuses[status.id] !== undefined) { if (state.statuses[status.id] !== undefined) {
Vue.set(state.statuses[status.id], 'reblogged', true) Vue.set(state.statuses[status.id], 'reblogged', true)
state.statuses[status.id].reblogs_count++
} }
}, },
/** /**
@ -191,6 +195,7 @@ const mutations = {
unboostStatus(state, { status }) { unboostStatus(state, { status }) {
if (state.statuses[status.id] !== undefined) { if (state.statuses[status.id] !== undefined) {
Vue.set(state.statuses[status.id], 'reblogged', false) Vue.set(state.statuses[status.id], 'reblogged', false)
state.statuses[status.id].reblogs_count--
} }
}, },
} }
@ -210,11 +215,14 @@ const getters = {
.map(statusId => state.statuses[statusId]) .map(statusId => state.statuses[statusId])
.sort((a, b) => new Date(b.created_at).getTime() - new Date(a.created_at).getTime()) .sort((a, b) => new Date(b.created_at).getTime() - new Date(a.created_at).getTime())
}, },
getStatus(state) {
return (statusId) => state.statuses[statusId]
},
getSinglePost(state) { getSinglePost(state) {
return state.statuses[state.params.singlePost] return state.statuses[state.params.singlePost]
}, },
getPostFromTimeline(state) { getPostFromTimeline(state) {
return (/** @type {string} */ statusId) => { return (statusId) => {
if (state.statuses[statusId] !== undefined) { if (state.statuses[statusId] !== undefined) {
return state.statuses[statusId] return state.statuses[statusId]
} else { } else {
@ -280,11 +288,11 @@ const actions = {
*/ */
async postDelete(context, status) { async postDelete(context, status) {
try { try {
context.commit('removeStatusf', status) context.commit('removeStatus', status)
const response = await axios.delete(generateUrl(`apps/social/api/v1/post?id=${status.uri}`)) const response = await axios.delete(generateUrl(`apps/social/api/v1/post?id=${status.uri}`))
logger.info('Post deleted with token ' + response.data.result.token) logger.info('Post deleted with token ' + response.data.result.token)
} catch (error) { } catch (error) {
context.commit('updateInTimelines', [status]) context.commit('addToStatuses', status)
showError('Failed to delete the status') showError('Failed to delete the status')
logger.error('Failed to delete the status', { error }) logger.error('Failed to delete the status', { error })
} }
@ -299,7 +307,7 @@ const actions = {
context.commit('likeStatus', { status }) context.commit('likeStatus', { status })
const response = await axios.post(generateUrl(`apps/social/api/v1/statuses/${status.id}/favourite`)) const response = await axios.post(generateUrl(`apps/social/api/v1/statuses/${status.id}/favourite`))
logger.info('Post liked') logger.info('Post liked')
context.commit('updateInTimelines', [response.data]) context.commit('addToStatuses', response.data)
return response return response
} catch (error) { } catch (error) {
context.commit('unlikeStatus', { status }) context.commit('unlikeStatus', { status })
@ -316,12 +324,12 @@ const actions = {
try { try {
// Remove status from list if we are in the 'liked' timeline // Remove status from list if we are in the 'liked' timeline
if (state.type === 'liked') { if (state.type === 'liked') {
context.commit('removeStatusf', status) context.commit('removeStatus', status)
} }
context.commit('unlikeStatus', { status }) context.commit('unlikeStatus', { status })
const response = await axios.post(generateUrl(`apps/social/api/v1/statuses/${status.id}/unfavourite`)) const response = await axios.post(generateUrl(`apps/social/api/v1/statuses/${status.id}/unfavourite`))
logger.info('Post unliked') logger.info('Post unliked')
context.commit('updateInTimelines', [response.data]) context.commit('addToStatuses', response.data)
return response return response
} catch (error) { } catch (error) {
// Readd status from list if we are in the 'liked' timeline // Readd status from list if we are in the 'liked' timeline
@ -343,7 +351,7 @@ const actions = {
context.commit('boostStatus', { status }) context.commit('boostStatus', { status })
const response = await axios.post(generateUrl(`apps/social/api/v1/statuses/${status.id}/reblog`)) const response = await axios.post(generateUrl(`apps/social/api/v1/statuses/${status.id}/reblog`))
logger.info('Post boosted') logger.info('Post boosted')
context.commit('updateInTimelines', [response.data]) context.commit('addToStatuses', response.data)
return response return response
} catch (error) { } catch (error) {
context.commit('unboostStatus', { status }) context.commit('unboostStatus', { status })
@ -361,7 +369,7 @@ const actions = {
context.commit('unboostStatus', { status }) context.commit('unboostStatus', { status })
const response = await axios.post(generateUrl(`apps/social/api/v1/statuses/${status.id}/unreblog`)) const response = await axios.post(generateUrl(`apps/social/api/v1/statuses/${status.id}/unreblog`))
logger.info('Boost deleted') logger.info('Boost deleted')
context.commit('updateInTimelines', [response.data]) context.commit('addToStatuses', response.data)
return response return response
} catch (error) { } catch (error) {
context.commit('boostStatus', { status }) context.commit('boostStatus', { status })