|
|
@ -129,12 +129,14 @@ export function fetchAccountFail(id, error) { |
|
|
|
export function followAccount(id, reblogs = true) { |
|
|
|
export function followAccount(id, reblogs = true) { |
|
|
|
return (dispatch, getState) => { |
|
|
|
return (dispatch, getState) => { |
|
|
|
const alreadyFollowing = getState().getIn(['relationships', id, 'following']); |
|
|
|
const alreadyFollowing = getState().getIn(['relationships', id, 'following']); |
|
|
|
dispatch(followAccountRequest(id)); |
|
|
|
const locked = getState().getIn(['accounts', id, 'locked'], false); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
dispatch(followAccountRequest(id, locked)); |
|
|
|
|
|
|
|
|
|
|
|
api(getState).post(`/api/v1/accounts/${id}/follow`, { reblogs }).then(response => { |
|
|
|
api(getState).post(`/api/v1/accounts/${id}/follow`, { reblogs }).then(response => { |
|
|
|
dispatch(followAccountSuccess(response.data, alreadyFollowing)); |
|
|
|
dispatch(followAccountSuccess(response.data, alreadyFollowing)); |
|
|
|
}).catch(error => { |
|
|
|
}).catch(error => { |
|
|
|
dispatch(followAccountFail(error)); |
|
|
|
dispatch(followAccountFail(error, locked)); |
|
|
|
}); |
|
|
|
}); |
|
|
|
}; |
|
|
|
}; |
|
|
|
}; |
|
|
|
}; |
|
|
@ -151,10 +153,12 @@ export function unfollowAccount(id) { |
|
|
|
}; |
|
|
|
}; |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
export function followAccountRequest(id) { |
|
|
|
export function followAccountRequest(id, locked) { |
|
|
|
return { |
|
|
|
return { |
|
|
|
type: ACCOUNT_FOLLOW_REQUEST, |
|
|
|
type: ACCOUNT_FOLLOW_REQUEST, |
|
|
|
id, |
|
|
|
id, |
|
|
|
|
|
|
|
locked, |
|
|
|
|
|
|
|
skipLoading: true, |
|
|
|
}; |
|
|
|
}; |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
@ -163,13 +167,16 @@ export function followAccountSuccess(relationship, alreadyFollowing) { |
|
|
|
type: ACCOUNT_FOLLOW_SUCCESS, |
|
|
|
type: ACCOUNT_FOLLOW_SUCCESS, |
|
|
|
relationship, |
|
|
|
relationship, |
|
|
|
alreadyFollowing, |
|
|
|
alreadyFollowing, |
|
|
|
|
|
|
|
skipLoading: true, |
|
|
|
}; |
|
|
|
}; |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
export function followAccountFail(error) { |
|
|
|
export function followAccountFail(error, locked) { |
|
|
|
return { |
|
|
|
return { |
|
|
|
type: ACCOUNT_FOLLOW_FAIL, |
|
|
|
type: ACCOUNT_FOLLOW_FAIL, |
|
|
|
error, |
|
|
|
error, |
|
|
|
|
|
|
|
locked, |
|
|
|
|
|
|
|
skipLoading: true, |
|
|
|
}; |
|
|
|
}; |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
@ -177,6 +184,7 @@ export function unfollowAccountRequest(id) { |
|
|
|
return { |
|
|
|
return { |
|
|
|
type: ACCOUNT_UNFOLLOW_REQUEST, |
|
|
|
type: ACCOUNT_UNFOLLOW_REQUEST, |
|
|
|
id, |
|
|
|
id, |
|
|
|
|
|
|
|
skipLoading: true, |
|
|
|
}; |
|
|
|
}; |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
@ -185,6 +193,7 @@ export function unfollowAccountSuccess(relationship, statuses) { |
|
|
|
type: ACCOUNT_UNFOLLOW_SUCCESS, |
|
|
|
type: ACCOUNT_UNFOLLOW_SUCCESS, |
|
|
|
relationship, |
|
|
|
relationship, |
|
|
|
statuses, |
|
|
|
statuses, |
|
|
|
|
|
|
|
skipLoading: true, |
|
|
|
}; |
|
|
|
}; |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
@ -192,6 +201,7 @@ export function unfollowAccountFail(error) { |
|
|
|
return { |
|
|
|
return { |
|
|
|
type: ACCOUNT_UNFOLLOW_FAIL, |
|
|
|
type: ACCOUNT_UNFOLLOW_FAIL, |
|
|
|
error, |
|
|
|
error, |
|
|
|
|
|
|
|
skipLoading: true, |
|
|
|
}; |
|
|
|
}; |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|