2017-12-04 09:26:40 +02:00
|
|
|
import api, { getLinks } from 'flavours/glitch/util/api';
|
2016-09-13 03:24:40 +03:00
|
|
|
|
|
|
|
export const ACCOUNT_FETCH_REQUEST = 'ACCOUNT_FETCH_REQUEST';
|
|
|
|
export const ACCOUNT_FETCH_SUCCESS = 'ACCOUNT_FETCH_SUCCESS';
|
|
|
|
export const ACCOUNT_FETCH_FAIL = 'ACCOUNT_FETCH_FAIL';
|
|
|
|
|
2016-09-16 01:21:51 +03:00
|
|
|
export const ACCOUNT_FOLLOW_REQUEST = 'ACCOUNT_FOLLOW_REQUEST';
|
|
|
|
export const ACCOUNT_FOLLOW_SUCCESS = 'ACCOUNT_FOLLOW_SUCCESS';
|
|
|
|
export const ACCOUNT_FOLLOW_FAIL = 'ACCOUNT_FOLLOW_FAIL';
|
|
|
|
|
|
|
|
export const ACCOUNT_UNFOLLOW_REQUEST = 'ACCOUNT_UNFOLLOW_REQUEST';
|
|
|
|
export const ACCOUNT_UNFOLLOW_SUCCESS = 'ACCOUNT_UNFOLLOW_SUCCESS';
|
|
|
|
export const ACCOUNT_UNFOLLOW_FAIL = 'ACCOUNT_UNFOLLOW_FAIL';
|
|
|
|
|
2016-10-03 19:49:52 +03:00
|
|
|
export const ACCOUNT_BLOCK_REQUEST = 'ACCOUNT_BLOCK_REQUEST';
|
|
|
|
export const ACCOUNT_BLOCK_SUCCESS = 'ACCOUNT_BLOCK_SUCCESS';
|
|
|
|
export const ACCOUNT_BLOCK_FAIL = 'ACCOUNT_BLOCK_FAIL';
|
|
|
|
|
|
|
|
export const ACCOUNT_UNBLOCK_REQUEST = 'ACCOUNT_UNBLOCK_REQUEST';
|
|
|
|
export const ACCOUNT_UNBLOCK_SUCCESS = 'ACCOUNT_UNBLOCK_SUCCESS';
|
|
|
|
export const ACCOUNT_UNBLOCK_FAIL = 'ACCOUNT_UNBLOCK_FAIL';
|
|
|
|
|
2017-02-06 03:51:56 +02:00
|
|
|
export const ACCOUNT_MUTE_REQUEST = 'ACCOUNT_MUTE_REQUEST';
|
|
|
|
export const ACCOUNT_MUTE_SUCCESS = 'ACCOUNT_MUTE_SUCCESS';
|
|
|
|
export const ACCOUNT_MUTE_FAIL = 'ACCOUNT_MUTE_FAIL';
|
|
|
|
|
|
|
|
export const ACCOUNT_UNMUTE_REQUEST = 'ACCOUNT_UNMUTE_REQUEST';
|
|
|
|
export const ACCOUNT_UNMUTE_SUCCESS = 'ACCOUNT_UNMUTE_SUCCESS';
|
|
|
|
export const ACCOUNT_UNMUTE_FAIL = 'ACCOUNT_UNMUTE_FAIL';
|
|
|
|
|
2016-10-27 22:59:56 +03:00
|
|
|
export const FOLLOWERS_FETCH_REQUEST = 'FOLLOWERS_FETCH_REQUEST';
|
|
|
|
export const FOLLOWERS_FETCH_SUCCESS = 'FOLLOWERS_FETCH_SUCCESS';
|
|
|
|
export const FOLLOWERS_FETCH_FAIL = 'FOLLOWERS_FETCH_FAIL';
|
|
|
|
|
2016-11-13 21:42:54 +02:00
|
|
|
export const FOLLOWERS_EXPAND_REQUEST = 'FOLLOWERS_EXPAND_REQUEST';
|
|
|
|
export const FOLLOWERS_EXPAND_SUCCESS = 'FOLLOWERS_EXPAND_SUCCESS';
|
|
|
|
export const FOLLOWERS_EXPAND_FAIL = 'FOLLOWERS_EXPAND_FAIL';
|
|
|
|
|
2016-10-27 22:59:56 +03:00
|
|
|
export const FOLLOWING_FETCH_REQUEST = 'FOLLOWING_FETCH_REQUEST';
|
|
|
|
export const FOLLOWING_FETCH_SUCCESS = 'FOLLOWING_FETCH_SUCCESS';
|
|
|
|
export const FOLLOWING_FETCH_FAIL = 'FOLLOWING_FETCH_FAIL';
|
|
|
|
|
2016-11-13 21:42:54 +02:00
|
|
|
export const FOLLOWING_EXPAND_REQUEST = 'FOLLOWING_EXPAND_REQUEST';
|
|
|
|
export const FOLLOWING_EXPAND_SUCCESS = 'FOLLOWING_EXPAND_SUCCESS';
|
|
|
|
export const FOLLOWING_EXPAND_FAIL = 'FOLLOWING_EXPAND_FAIL';
|
|
|
|
|
2016-10-28 21:05:44 +03:00
|
|
|
export const RELATIONSHIPS_FETCH_REQUEST = 'RELATIONSHIPS_FETCH_REQUEST';
|
|
|
|
export const RELATIONSHIPS_FETCH_SUCCESS = 'RELATIONSHIPS_FETCH_SUCCESS';
|
|
|
|
export const RELATIONSHIPS_FETCH_FAIL = 'RELATIONSHIPS_FETCH_FAIL';
|
|
|
|
|
2016-12-26 22:33:51 +02:00
|
|
|
export const FOLLOW_REQUESTS_FETCH_REQUEST = 'FOLLOW_REQUESTS_FETCH_REQUEST';
|
|
|
|
export const FOLLOW_REQUESTS_FETCH_SUCCESS = 'FOLLOW_REQUESTS_FETCH_SUCCESS';
|
|
|
|
export const FOLLOW_REQUESTS_FETCH_FAIL = 'FOLLOW_REQUESTS_FETCH_FAIL';
|
|
|
|
|
|
|
|
export const FOLLOW_REQUESTS_EXPAND_REQUEST = 'FOLLOW_REQUESTS_EXPAND_REQUEST';
|
|
|
|
export const FOLLOW_REQUESTS_EXPAND_SUCCESS = 'FOLLOW_REQUESTS_EXPAND_SUCCESS';
|
|
|
|
export const FOLLOW_REQUESTS_EXPAND_FAIL = 'FOLLOW_REQUESTS_EXPAND_FAIL';
|
|
|
|
|
|
|
|
export const FOLLOW_REQUEST_AUTHORIZE_REQUEST = 'FOLLOW_REQUEST_AUTHORIZE_REQUEST';
|
|
|
|
export const FOLLOW_REQUEST_AUTHORIZE_SUCCESS = 'FOLLOW_REQUEST_AUTHORIZE_SUCCESS';
|
|
|
|
export const FOLLOW_REQUEST_AUTHORIZE_FAIL = 'FOLLOW_REQUEST_AUTHORIZE_FAIL';
|
|
|
|
|
|
|
|
export const FOLLOW_REQUEST_REJECT_REQUEST = 'FOLLOW_REQUEST_REJECT_REQUEST';
|
|
|
|
export const FOLLOW_REQUEST_REJECT_SUCCESS = 'FOLLOW_REQUEST_REJECT_SUCCESS';
|
|
|
|
export const FOLLOW_REQUEST_REJECT_FAIL = 'FOLLOW_REQUEST_REJECT_FAIL';
|
|
|
|
|
2016-09-13 03:24:40 +03:00
|
|
|
export function fetchAccount(id) {
|
|
|
|
return (dispatch, getState) => {
|
2017-03-04 23:17:10 +02:00
|
|
|
dispatch(fetchRelationships([id]));
|
|
|
|
|
|
|
|
if (getState().getIn(['accounts', id], null) !== null) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2016-09-13 03:24:40 +03:00
|
|
|
dispatch(fetchAccountRequest(id));
|
|
|
|
|
2016-10-30 16:06:43 +02:00
|
|
|
api(getState).get(`/api/v1/accounts/${id}`).then(response => {
|
|
|
|
dispatch(fetchAccountSuccess(response.data));
|
2016-09-13 03:24:40 +03:00
|
|
|
}).catch(error => {
|
|
|
|
dispatch(fetchAccountFail(id, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchAccountRequest(id) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_FETCH_REQUEST,
|
2017-05-20 18:31:47 +03:00
|
|
|
id,
|
2016-09-13 03:24:40 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-10-30 16:06:43 +02:00
|
|
|
export function fetchAccountSuccess(account) {
|
2016-09-13 03:24:40 +03:00
|
|
|
return {
|
|
|
|
type: ACCOUNT_FETCH_SUCCESS,
|
2017-05-20 18:31:47 +03:00
|
|
|
account,
|
2016-09-13 03:24:40 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchAccountFail(id, error) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_FETCH_FAIL,
|
2016-11-13 21:42:54 +02:00
|
|
|
id,
|
2017-02-27 00:06:27 +02:00
|
|
|
error,
|
2017-05-20 18:31:47 +03:00
|
|
|
skipAlert: true,
|
2016-09-13 03:24:40 +03:00
|
|
|
};
|
|
|
|
};
|
2016-09-16 01:21:51 +03:00
|
|
|
|
2017-11-09 16:41:10 +02:00
|
|
|
export function followAccount(id, reblogs = true) {
|
2016-09-16 01:21:51 +03:00
|
|
|
return (dispatch, getState) => {
|
2017-11-12 05:42:22 +02:00
|
|
|
const alreadyFollowing = getState().getIn(['relationships', id, 'following']);
|
2016-09-16 01:21:51 +03:00
|
|
|
dispatch(followAccountRequest(id));
|
|
|
|
|
2017-11-09 16:41:10 +02:00
|
|
|
api(getState).post(`/api/v1/accounts/${id}/follow`, { reblogs }).then(response => {
|
2017-11-12 05:42:22 +02:00
|
|
|
dispatch(followAccountSuccess(response.data, alreadyFollowing));
|
2016-09-16 01:21:51 +03:00
|
|
|
}).catch(error => {
|
|
|
|
dispatch(followAccountFail(error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function unfollowAccount(id) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(unfollowAccountRequest(id));
|
|
|
|
|
2016-09-27 17:58:23 +03:00
|
|
|
api(getState).post(`/api/v1/accounts/${id}/unfollow`).then(response => {
|
2017-10-13 17:44:02 +03:00
|
|
|
dispatch(unfollowAccountSuccess(response.data, getState().get('statuses')));
|
2016-09-16 01:21:51 +03:00
|
|
|
}).catch(error => {
|
|
|
|
dispatch(unfollowAccountFail(error));
|
|
|
|
});
|
2017-05-20 18:31:47 +03:00
|
|
|
};
|
2016-09-16 01:21:51 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
export function followAccountRequest(id) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_FOLLOW_REQUEST,
|
2017-05-20 18:31:47 +03:00
|
|
|
id,
|
2016-09-16 01:21:51 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2017-11-12 05:42:22 +02:00
|
|
|
export function followAccountSuccess(relationship, alreadyFollowing) {
|
2016-09-16 01:21:51 +03:00
|
|
|
return {
|
|
|
|
type: ACCOUNT_FOLLOW_SUCCESS,
|
2017-05-20 18:31:47 +03:00
|
|
|
relationship,
|
2017-11-12 05:42:22 +02:00
|
|
|
alreadyFollowing,
|
2016-09-16 01:21:51 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function followAccountFail(error) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_FOLLOW_FAIL,
|
2017-05-20 18:31:47 +03:00
|
|
|
error,
|
2016-09-16 01:21:51 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function unfollowAccountRequest(id) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_UNFOLLOW_REQUEST,
|
2017-05-20 18:31:47 +03:00
|
|
|
id,
|
2016-09-16 01:21:51 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2017-10-13 17:44:02 +03:00
|
|
|
export function unfollowAccountSuccess(relationship, statuses) {
|
2016-09-16 01:21:51 +03:00
|
|
|
return {
|
|
|
|
type: ACCOUNT_UNFOLLOW_SUCCESS,
|
2017-05-20 18:31:47 +03:00
|
|
|
relationship,
|
2017-10-13 17:44:02 +03:00
|
|
|
statuses,
|
2016-09-16 01:21:51 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function unfollowAccountFail(error) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_UNFOLLOW_FAIL,
|
2017-05-20 18:31:47 +03:00
|
|
|
error,
|
2016-09-16 01:21:51 +03:00
|
|
|
};
|
|
|
|
};
|
2016-09-18 19:18:46 +03:00
|
|
|
|
2016-10-03 19:49:52 +03:00
|
|
|
export function blockAccount(id) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(blockAccountRequest(id));
|
|
|
|
|
|
|
|
api(getState).post(`/api/v1/accounts/${id}/block`).then(response => {
|
2016-11-23 23:57:57 +02:00
|
|
|
// Pass in entire statuses map so we can use it to filter stuff in different parts of the reducers
|
|
|
|
dispatch(blockAccountSuccess(response.data, getState().get('statuses')));
|
2016-10-03 19:49:52 +03:00
|
|
|
}).catch(error => {
|
|
|
|
dispatch(blockAccountFail(id, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function unblockAccount(id) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(unblockAccountRequest(id));
|
|
|
|
|
|
|
|
api(getState).post(`/api/v1/accounts/${id}/unblock`).then(response => {
|
|
|
|
dispatch(unblockAccountSuccess(response.data));
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch(unblockAccountFail(id, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function blockAccountRequest(id) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_BLOCK_REQUEST,
|
2017-05-20 18:31:47 +03:00
|
|
|
id,
|
2016-10-03 19:49:52 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-11-23 23:57:57 +02:00
|
|
|
export function blockAccountSuccess(relationship, statuses) {
|
2016-10-03 19:49:52 +03:00
|
|
|
return {
|
|
|
|
type: ACCOUNT_BLOCK_SUCCESS,
|
2016-11-23 23:57:57 +02:00
|
|
|
relationship,
|
2017-05-20 18:31:47 +03:00
|
|
|
statuses,
|
2016-10-03 19:49:52 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function blockAccountFail(error) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_BLOCK_FAIL,
|
2017-05-20 18:31:47 +03:00
|
|
|
error,
|
2016-10-03 19:49:52 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function unblockAccountRequest(id) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_UNBLOCK_REQUEST,
|
2017-05-20 18:31:47 +03:00
|
|
|
id,
|
2016-10-03 19:49:52 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function unblockAccountSuccess(relationship) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_UNBLOCK_SUCCESS,
|
2017-05-20 18:31:47 +03:00
|
|
|
relationship,
|
2016-10-03 19:49:52 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function unblockAccountFail(error) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_UNBLOCK_FAIL,
|
2017-05-20 18:31:47 +03:00
|
|
|
error,
|
2016-10-03 19:49:52 +03:00
|
|
|
};
|
|
|
|
};
|
2016-10-27 22:59:56 +03:00
|
|
|
|
2017-02-06 03:51:56 +02:00
|
|
|
|
2017-08-07 01:36:04 +03:00
|
|
|
export function muteAccount(id, notifications) {
|
2017-02-06 03:51:56 +02:00
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(muteAccountRequest(id));
|
|
|
|
|
2017-08-07 01:36:04 +03:00
|
|
|
api(getState).post(`/api/v1/accounts/${id}/mute`, { notifications }).then(response => {
|
2017-02-06 03:51:56 +02:00
|
|
|
// Pass in entire statuses map so we can use it to filter stuff in different parts of the reducers
|
|
|
|
dispatch(muteAccountSuccess(response.data, getState().get('statuses')));
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch(muteAccountFail(id, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function unmuteAccount(id) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(unmuteAccountRequest(id));
|
|
|
|
|
|
|
|
api(getState).post(`/api/v1/accounts/${id}/unmute`).then(response => {
|
|
|
|
dispatch(unmuteAccountSuccess(response.data));
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch(unmuteAccountFail(id, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function muteAccountRequest(id) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_MUTE_REQUEST,
|
2017-05-20 18:31:47 +03:00
|
|
|
id,
|
2017-02-06 03:51:56 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function muteAccountSuccess(relationship, statuses) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_MUTE_SUCCESS,
|
|
|
|
relationship,
|
2017-05-20 18:31:47 +03:00
|
|
|
statuses,
|
2017-02-06 03:51:56 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function muteAccountFail(error) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_MUTE_FAIL,
|
2017-05-20 18:31:47 +03:00
|
|
|
error,
|
2017-02-06 03:51:56 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function unmuteAccountRequest(id) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_UNMUTE_REQUEST,
|
2017-05-20 18:31:47 +03:00
|
|
|
id,
|
2017-02-06 03:51:56 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function unmuteAccountSuccess(relationship) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_UNMUTE_SUCCESS,
|
2017-05-20 18:31:47 +03:00
|
|
|
relationship,
|
2017-02-06 03:51:56 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function unmuteAccountFail(error) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_UNMUTE_FAIL,
|
2017-05-20 18:31:47 +03:00
|
|
|
error,
|
2017-02-06 03:51:56 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2016-10-27 22:59:56 +03:00
|
|
|
export function fetchFollowers(id) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(fetchFollowersRequest(id));
|
|
|
|
|
|
|
|
api(getState).get(`/api/v1/accounts/${id}/followers`).then(response => {
|
2016-11-13 21:52:11 +02:00
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
2016-11-13 21:42:54 +02:00
|
|
|
|
2016-11-13 21:52:11 +02:00
|
|
|
dispatch(fetchFollowersSuccess(id, response.data, next ? next.uri : null));
|
2016-10-28 21:05:44 +03:00
|
|
|
dispatch(fetchRelationships(response.data.map(item => item.id)));
|
2016-10-27 22:59:56 +03:00
|
|
|
}).catch(error => {
|
|
|
|
dispatch(fetchFollowersFail(id, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchFollowersRequest(id) {
|
|
|
|
return {
|
|
|
|
type: FOLLOWERS_FETCH_REQUEST,
|
2017-05-20 18:31:47 +03:00
|
|
|
id,
|
2016-10-27 22:59:56 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-11-13 21:52:11 +02:00
|
|
|
export function fetchFollowersSuccess(id, accounts, next) {
|
2016-10-27 22:59:56 +03:00
|
|
|
return {
|
|
|
|
type: FOLLOWERS_FETCH_SUCCESS,
|
2016-11-13 21:42:54 +02:00
|
|
|
id,
|
|
|
|
accounts,
|
2017-05-20 18:31:47 +03:00
|
|
|
next,
|
2016-10-27 22:59:56 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchFollowersFail(id, error) {
|
|
|
|
return {
|
|
|
|
type: FOLLOWERS_FETCH_FAIL,
|
2016-11-13 21:42:54 +02:00
|
|
|
id,
|
2017-05-20 18:31:47 +03:00
|
|
|
error,
|
2016-11-13 21:42:54 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandFollowers(id) {
|
|
|
|
return (dispatch, getState) => {
|
2016-11-13 21:52:11 +02:00
|
|
|
const url = getState().getIn(['user_lists', 'followers', id, 'next']);
|
|
|
|
|
|
|
|
if (url === null) {
|
|
|
|
return;
|
|
|
|
}
|
2016-11-13 21:42:54 +02:00
|
|
|
|
|
|
|
dispatch(expandFollowersRequest(id));
|
|
|
|
|
|
|
|
api(getState).get(url).then(response => {
|
2016-11-13 21:52:11 +02:00
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
2016-11-13 21:42:54 +02:00
|
|
|
|
2016-11-13 21:52:11 +02:00
|
|
|
dispatch(expandFollowersSuccess(id, response.data, next ? next.uri : null));
|
2016-11-13 21:42:54 +02:00
|
|
|
dispatch(fetchRelationships(response.data.map(item => item.id)));
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch(expandFollowersFail(id, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandFollowersRequest(id) {
|
|
|
|
return {
|
|
|
|
type: FOLLOWERS_EXPAND_REQUEST,
|
2017-05-20 18:31:47 +03:00
|
|
|
id,
|
2016-11-13 21:42:54 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-11-13 21:52:11 +02:00
|
|
|
export function expandFollowersSuccess(id, accounts, next) {
|
2016-11-13 21:42:54 +02:00
|
|
|
return {
|
|
|
|
type: FOLLOWERS_EXPAND_SUCCESS,
|
|
|
|
id,
|
|
|
|
accounts,
|
2017-05-20 18:31:47 +03:00
|
|
|
next,
|
2016-11-13 21:42:54 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandFollowersFail(id, error) {
|
|
|
|
return {
|
|
|
|
type: FOLLOWERS_EXPAND_FAIL,
|
|
|
|
id,
|
2017-05-20 18:31:47 +03:00
|
|
|
error,
|
2016-10-27 22:59:56 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchFollowing(id) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(fetchFollowingRequest(id));
|
|
|
|
|
|
|
|
api(getState).get(`/api/v1/accounts/${id}/following`).then(response => {
|
2016-11-13 21:52:11 +02:00
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
|
|
|
|
|
|
|
dispatch(fetchFollowingSuccess(id, response.data, next ? next.uri : null));
|
2016-10-28 21:05:44 +03:00
|
|
|
dispatch(fetchRelationships(response.data.map(item => item.id)));
|
2016-10-27 22:59:56 +03:00
|
|
|
}).catch(error => {
|
|
|
|
dispatch(fetchFollowingFail(id, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchFollowingRequest(id) {
|
|
|
|
return {
|
|
|
|
type: FOLLOWING_FETCH_REQUEST,
|
2017-05-20 18:31:47 +03:00
|
|
|
id,
|
2016-10-27 22:59:56 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-11-13 22:02:10 +02:00
|
|
|
export function fetchFollowingSuccess(id, accounts, next) {
|
2016-10-27 22:59:56 +03:00
|
|
|
return {
|
|
|
|
type: FOLLOWING_FETCH_SUCCESS,
|
2016-11-13 21:42:54 +02:00
|
|
|
id,
|
2016-11-13 22:02:10 +02:00
|
|
|
accounts,
|
2017-05-20 18:31:47 +03:00
|
|
|
next,
|
2016-10-27 22:59:56 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchFollowingFail(id, error) {
|
|
|
|
return {
|
|
|
|
type: FOLLOWING_FETCH_FAIL,
|
2016-11-13 21:42:54 +02:00
|
|
|
id,
|
2017-05-20 18:31:47 +03:00
|
|
|
error,
|
2016-11-13 21:42:54 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandFollowing(id) {
|
|
|
|
return (dispatch, getState) => {
|
2016-11-13 21:52:11 +02:00
|
|
|
const url = getState().getIn(['user_lists', 'following', id, 'next']);
|
|
|
|
|
|
|
|
if (url === null) {
|
|
|
|
return;
|
|
|
|
}
|
2016-11-13 21:42:54 +02:00
|
|
|
|
|
|
|
dispatch(expandFollowingRequest(id));
|
|
|
|
|
|
|
|
api(getState).get(url).then(response => {
|
2016-11-13 21:52:11 +02:00
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
2016-11-13 21:42:54 +02:00
|
|
|
|
2016-11-13 21:52:11 +02:00
|
|
|
dispatch(expandFollowingSuccess(id, response.data, next ? next.uri : null));
|
2016-11-13 21:42:54 +02:00
|
|
|
dispatch(fetchRelationships(response.data.map(item => item.id)));
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch(expandFollowingFail(id, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandFollowingRequest(id) {
|
|
|
|
return {
|
|
|
|
type: FOLLOWING_EXPAND_REQUEST,
|
2017-05-20 18:31:47 +03:00
|
|
|
id,
|
2016-11-13 21:42:54 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-11-13 21:52:11 +02:00
|
|
|
export function expandFollowingSuccess(id, accounts, next) {
|
2016-11-13 21:42:54 +02:00
|
|
|
return {
|
|
|
|
type: FOLLOWING_EXPAND_SUCCESS,
|
|
|
|
id,
|
|
|
|
accounts,
|
2017-05-20 18:31:47 +03:00
|
|
|
next,
|
2016-11-13 21:42:54 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandFollowingFail(id, error) {
|
|
|
|
return {
|
|
|
|
type: FOLLOWING_EXPAND_FAIL,
|
|
|
|
id,
|
2017-05-20 18:31:47 +03:00
|
|
|
error,
|
2016-10-27 22:59:56 +03:00
|
|
|
};
|
|
|
|
};
|
2016-10-28 21:05:44 +03:00
|
|
|
|
2017-04-02 23:02:38 +03:00
|
|
|
export function fetchRelationships(accountIds) {
|
2016-10-28 21:05:44 +03:00
|
|
|
return (dispatch, getState) => {
|
2017-04-02 23:02:38 +03:00
|
|
|
const loadedRelationships = getState().get('relationships');
|
|
|
|
const newAccountIds = accountIds.filter(id => loadedRelationships.get(id, null) === null);
|
|
|
|
|
|
|
|
if (newAccountIds.length === 0) {
|
2017-01-15 15:41:49 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2017-04-02 23:02:38 +03:00
|
|
|
dispatch(fetchRelationshipsRequest(newAccountIds));
|
2016-10-28 21:05:44 +03:00
|
|
|
|
2017-04-02 23:02:38 +03:00
|
|
|
api(getState).get(`/api/v1/accounts/relationships?${newAccountIds.map(id => `id[]=${id}`).join('&')}`).then(response => {
|
2016-10-28 21:05:44 +03:00
|
|
|
dispatch(fetchRelationshipsSuccess(response.data));
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch(fetchRelationshipsFail(error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchRelationshipsRequest(ids) {
|
|
|
|
return {
|
|
|
|
type: RELATIONSHIPS_FETCH_REQUEST,
|
2017-01-19 12:23:24 +02:00
|
|
|
ids,
|
2017-05-20 18:31:47 +03:00
|
|
|
skipLoading: true,
|
2016-10-28 21:05:44 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchRelationshipsSuccess(relationships) {
|
|
|
|
return {
|
|
|
|
type: RELATIONSHIPS_FETCH_SUCCESS,
|
2017-01-19 12:23:24 +02:00
|
|
|
relationships,
|
2017-05-20 18:31:47 +03:00
|
|
|
skipLoading: true,
|
2016-10-28 21:05:44 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchRelationshipsFail(error) {
|
|
|
|
return {
|
|
|
|
type: RELATIONSHIPS_FETCH_FAIL,
|
2017-01-19 12:23:24 +02:00
|
|
|
error,
|
2017-05-20 18:31:47 +03:00
|
|
|
skipLoading: true,
|
2016-10-28 21:05:44 +03:00
|
|
|
};
|
|
|
|
};
|
2016-12-26 22:33:51 +02:00
|
|
|
|
|
|
|
export function fetchFollowRequests() {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(fetchFollowRequestsRequest());
|
|
|
|
|
|
|
|
api(getState).get('/api/v1/follow_requests').then(response => {
|
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
2017-05-20 18:31:47 +03:00
|
|
|
dispatch(fetchFollowRequestsSuccess(response.data, next ? next.uri : null));
|
2016-12-26 22:33:51 +02:00
|
|
|
}).catch(error => dispatch(fetchFollowRequestsFail(error)));
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchFollowRequestsRequest() {
|
|
|
|
return {
|
2017-05-20 18:31:47 +03:00
|
|
|
type: FOLLOW_REQUESTS_FETCH_REQUEST,
|
2016-12-26 22:33:51 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchFollowRequestsSuccess(accounts, next) {
|
|
|
|
return {
|
|
|
|
type: FOLLOW_REQUESTS_FETCH_SUCCESS,
|
|
|
|
accounts,
|
2017-05-20 18:31:47 +03:00
|
|
|
next,
|
2016-12-26 22:33:51 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchFollowRequestsFail(error) {
|
|
|
|
return {
|
|
|
|
type: FOLLOW_REQUESTS_FETCH_FAIL,
|
2017-05-20 18:31:47 +03:00
|
|
|
error,
|
2016-12-26 22:33:51 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandFollowRequests() {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
const url = getState().getIn(['user_lists', 'follow_requests', 'next']);
|
|
|
|
|
|
|
|
if (url === null) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
dispatch(expandFollowRequestsRequest());
|
|
|
|
|
|
|
|
api(getState).get(url).then(response => {
|
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
2017-05-20 18:31:47 +03:00
|
|
|
dispatch(expandFollowRequestsSuccess(response.data, next ? next.uri : null));
|
2016-12-26 22:33:51 +02:00
|
|
|
}).catch(error => dispatch(expandFollowRequestsFail(error)));
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandFollowRequestsRequest() {
|
|
|
|
return {
|
2017-05-20 18:31:47 +03:00
|
|
|
type: FOLLOW_REQUESTS_EXPAND_REQUEST,
|
2016-12-26 22:33:51 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandFollowRequestsSuccess(accounts, next) {
|
|
|
|
return {
|
|
|
|
type: FOLLOW_REQUESTS_EXPAND_SUCCESS,
|
|
|
|
accounts,
|
2017-05-20 18:31:47 +03:00
|
|
|
next,
|
2016-12-26 22:33:51 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandFollowRequestsFail(error) {
|
|
|
|
return {
|
|
|
|
type: FOLLOW_REQUESTS_EXPAND_FAIL,
|
2017-05-20 18:31:47 +03:00
|
|
|
error,
|
2016-12-26 22:33:51 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function authorizeFollowRequest(id) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(authorizeFollowRequestRequest(id));
|
|
|
|
|
|
|
|
api(getState)
|
|
|
|
.post(`/api/v1/follow_requests/${id}/authorize`)
|
2017-06-23 17:05:04 +03:00
|
|
|
.then(() => dispatch(authorizeFollowRequestSuccess(id)))
|
2016-12-26 22:33:51 +02:00
|
|
|
.catch(error => dispatch(authorizeFollowRequestFail(id, error)));
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function authorizeFollowRequestRequest(id) {
|
|
|
|
return {
|
|
|
|
type: FOLLOW_REQUEST_AUTHORIZE_REQUEST,
|
2017-05-20 18:31:47 +03:00
|
|
|
id,
|
2016-12-26 22:33:51 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function authorizeFollowRequestSuccess(id) {
|
|
|
|
return {
|
|
|
|
type: FOLLOW_REQUEST_AUTHORIZE_SUCCESS,
|
2017-05-20 18:31:47 +03:00
|
|
|
id,
|
2016-12-26 22:33:51 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function authorizeFollowRequestFail(id, error) {
|
|
|
|
return {
|
|
|
|
type: FOLLOW_REQUEST_AUTHORIZE_FAIL,
|
|
|
|
id,
|
2017-05-20 18:31:47 +03:00
|
|
|
error,
|
2016-12-26 22:33:51 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
export function rejectFollowRequest(id) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(rejectFollowRequestRequest(id));
|
|
|
|
|
|
|
|
api(getState)
|
|
|
|
.post(`/api/v1/follow_requests/${id}/reject`)
|
2017-06-23 17:05:04 +03:00
|
|
|
.then(() => dispatch(rejectFollowRequestSuccess(id)))
|
2016-12-26 22:33:51 +02:00
|
|
|
.catch(error => dispatch(rejectFollowRequestFail(id, error)));
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function rejectFollowRequestRequest(id) {
|
|
|
|
return {
|
|
|
|
type: FOLLOW_REQUEST_REJECT_REQUEST,
|
2017-05-20 18:31:47 +03:00
|
|
|
id,
|
2016-12-26 22:33:51 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function rejectFollowRequestSuccess(id) {
|
|
|
|
return {
|
|
|
|
type: FOLLOW_REQUEST_REJECT_SUCCESS,
|
2017-05-20 18:31:47 +03:00
|
|
|
id,
|
2016-12-26 22:33:51 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function rejectFollowRequestFail(id, error) {
|
|
|
|
return {
|
|
|
|
type: FOLLOW_REQUEST_REJECT_FAIL,
|
|
|
|
id,
|
2017-05-20 18:31:47 +03:00
|
|
|
error,
|
2016-12-26 22:33:51 +02:00
|
|
|
};
|
|
|
|
};
|