pleroma-fe/src/services/follow_manipulate/follow_manipulate.js

53 lines
1.9 KiB
JavaScript
Raw Normal View History

2020-04-21 20:27:51 +00:00
const fetchRelationship = (attempt, user, store) => new Promise((resolve, reject) => {
setTimeout(() => {
2020-04-21 20:27:51 +00:00
store.state.api.backendInteractor.fetchUserRelationship({ id: user.id })
.then((relationship) => {
store.commit('updateUserRelationship', [relationship])
return relationship
})
.then((relationship) => resolve([relationship.following, relationship.requested, user.locked, attempt]))
.catch((e) => reject(e))
}, 500)
}).then(([following, sent, locked, attempt]) => {
if (!following && !(locked && sent) && attempt <= 3) {
// If we BE reports that we still not following that user - retry,
// increment attempts by one
2020-04-21 20:27:51 +00:00
fetchRelationship(++attempt, user, store)
}
})
export const requestFollow = (user, store) => new Promise((resolve, reject) => {
store.state.api.backendInteractor.followUser({ id: user.id })
.then((updated) => {
store.commit('updateUserRelationship', [updated])
if (updated.following || (user.locked && user.requested)) {
// If we get result immediately or the account is locked, just stop.
resolve()
return
}
// But usually we don't get result immediately, so we ask server
// for updated user profile to confirm if we are following them
// Sometimes it takes several tries. Sometimes we end up not following
// user anyway, probably because they locked themselves and we
// don't know that yet.
// Recursive Promise, it will call itself up to 3 times.
2020-04-21 20:27:51 +00:00
return fetchRelationship(1, user, store)
.then(() => {
resolve()
})
})
})
export const requestUnfollow = (user, store) => new Promise((resolve, reject) => {
store.state.api.backendInteractor.unfollowUser({ id: user.id })
.then((updated) => {
store.commit('updateUserRelationship', [updated])
resolve({
updated
})
})
})