|
|
|
@ -129,12 +129,14 @@ export function fetchAccountFail(id, error) {
|
|
|
|
|
export function followAccount(id, reblogs = true) {
|
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
|
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 => {
|
|
|
|
|
dispatch(followAccountSuccess(response.data, alreadyFollowing));
|
|
|
|
|
}).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 {
|
|
|
|
|
type: ACCOUNT_FOLLOW_REQUEST,
|
|
|
|
|
id,
|
|
|
|
|
locked,
|
|
|
|
|
skipLoading: true,
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
@ -163,13 +167,16 @@ export function followAccountSuccess(relationship, alreadyFollowing) {
|
|
|
|
|
type: ACCOUNT_FOLLOW_SUCCESS,
|
|
|
|
|
relationship,
|
|
|
|
|
alreadyFollowing,
|
|
|
|
|
skipLoading: true,
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export function followAccountFail(error) {
|
|
|
|
|
export function followAccountFail(error, locked) {
|
|
|
|
|
return {
|
|
|
|
|
type: ACCOUNT_FOLLOW_FAIL,
|
|
|
|
|
error,
|
|
|
|
|
locked,
|
|
|
|
|
skipLoading: true,
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
@ -177,6 +184,7 @@ export function unfollowAccountRequest(id) {
|
|
|
|
|
return {
|
|
|
|
|
type: ACCOUNT_UNFOLLOW_REQUEST,
|
|
|
|
|
id,
|
|
|
|
|
skipLoading: true,
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
@ -185,6 +193,7 @@ export function unfollowAccountSuccess(relationship, statuses) {
|
|
|
|
|
type: ACCOUNT_UNFOLLOW_SUCCESS,
|
|
|
|
|
relationship,
|
|
|
|
|
statuses,
|
|
|
|
|
skipLoading: true,
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
@ -192,6 +201,7 @@ export function unfollowAccountFail(error) {
|
|
|
|
|
return {
|
|
|
|
|
type: ACCOUNT_UNFOLLOW_FAIL,
|
|
|
|
|
error,
|
|
|
|
|
skipLoading: true,
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|