refactor error handling of pinStatus

This commit is contained in:
taehoon 2019-04-24 16:19:27 -04:00
parent ce1d19136d
commit 1229622fed
3 changed files with 8 additions and 17 deletions

View File

@ -24,11 +24,8 @@ const ExtraButtons = {
}, },
pinStatus () { pinStatus () {
this.refreshPopper() this.refreshPopper()
this.$store.dispatch('pinStatus', this.status.id).then((status) => { this.$store.dispatch('pinStatus', this.status.id)
if (status.error) { .catch(err => this.$emit('onError', err.error.error))
this.$emit('onError', status.error)
}
})
}, },
unpinStatus () { unpinStatus () {
this.refreshPopper() this.refreshPopper()

View File

@ -546,12 +546,8 @@ const statuses = {
.then(statuses => dispatch('addNewStatuses', { statuses, timeline: 'user', userId })) .then(statuses => dispatch('addNewStatuses', { statuses, timeline: 'user', userId }))
}, },
pinStatus ({ rootState, commit }, statusId) { pinStatus ({ rootState, commit }, statusId) {
return rootState.api.backendInteractor.pinOwnStatus(statusId).then((status) => { return rootState.api.backendInteractor.pinOwnStatus(statusId)
if (!status.error) { .then((status) => commit('setPinned', { status }))
commit('setPinned', { status })
}
return status
})
}, },
unpinStatus ({ rootState, commit }, statusId) { unpinStatus ({ rootState, commit }, statusId) {
rootState.api.backendInteractor.unpinOwnStatus(statusId) rootState.api.backendInteractor.unpinOwnStatus(statusId)

View File

@ -213,19 +213,17 @@ const unfollowUser = ({id, credentials}) => {
} }
const pinOwnStatus = ({ id, credentials }) => { const pinOwnStatus = ({ id, credentials }) => {
let url = MASTODON_PIN_OWN_STATUS(id) return promisedRequest(MASTODON_PIN_OWN_STATUS(id), {
return fetch(url, {
headers: authHeaders(credentials), headers: authHeaders(credentials),
method: 'POST' method: 'POST'
}).then((data) => data.json()) })
} }
const unpinOwnStatus = ({ id, credentials }) => { const unpinOwnStatus = ({ id, credentials }) => {
let url = MASTODON_UNPIN_OWN_STATUS(id) return promisedRequest(MASTODON_UNPIN_OWN_STATUS(id), {
return fetch(url, {
headers: authHeaders(credentials), headers: authHeaders(credentials),
method: 'POST' method: 'POST'
}).then((data) => data.json()) })
} }
const blockUser = ({id, credentials}) => { const blockUser = ({id, credentials}) => {