2017-05-20 11:31:47 -04:00
|
|
|
import api, { getLinks } from '../api';
|
2016-10-16 19:23:41 -04:00
|
|
|
import Immutable from 'immutable';
|
2016-09-12 20:24:40 -04: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-15 18:21:51 -04: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 12:49:52 -04: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-05 20:51:56 -05: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-09-18 12:18:46 -04:00
|
|
|
export const ACCOUNT_TIMELINE_FETCH_REQUEST = 'ACCOUNT_TIMELINE_FETCH_REQUEST';
|
|
|
|
export const ACCOUNT_TIMELINE_FETCH_SUCCESS = 'ACCOUNT_TIMELINE_FETCH_SUCCESS';
|
|
|
|
export const ACCOUNT_TIMELINE_FETCH_FAIL = 'ACCOUNT_TIMELINE_FETCH_FAIL';
|
|
|
|
|
2016-09-22 14:58:35 -04:00
|
|
|
export const ACCOUNT_TIMELINE_EXPAND_REQUEST = 'ACCOUNT_TIMELINE_EXPAND_REQUEST';
|
|
|
|
export const ACCOUNT_TIMELINE_EXPAND_SUCCESS = 'ACCOUNT_TIMELINE_EXPAND_SUCCESS';
|
|
|
|
export const ACCOUNT_TIMELINE_EXPAND_FAIL = 'ACCOUNT_TIMELINE_EXPAND_FAIL';
|
|
|
|
|
2017-05-19 19:28:25 -04:00
|
|
|
export const ACCOUNT_MEDIA_TIMELINE_FETCH_REQUEST = 'ACCOUNT_MEDIA_TIMELINE_FETCH_REQUEST';
|
|
|
|
export const ACCOUNT_MEDIA_TIMELINE_FETCH_SUCCESS = 'ACCOUNT_MEDIA_TIMELINE_FETCH_SUCCESS';
|
|
|
|
export const ACCOUNT_MEDIA_TIMELINE_FETCH_FAIL = 'ACCOUNT_MEDIA_TIMELINE_FETCH_FAIL';
|
|
|
|
|
|
|
|
export const ACCOUNT_MEDIA_TIMELINE_EXPAND_REQUEST = 'ACCOUNT_MEDIA_TIMELINE_EXPAND_REQUEST';
|
|
|
|
export const ACCOUNT_MEDIA_TIMELINE_EXPAND_SUCCESS = 'ACCOUNT_MEDIA_TIMELINE_EXPAND_SUCCESS';
|
|
|
|
export const ACCOUNT_MEDIA_TIMELINE_EXPAND_FAIL = 'ACCOUNT_MEDIA_TIMELINE_EXPAND_FAIL';
|
|
|
|
|
2016-10-27 15:59:56 -04: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 14:42:54 -05: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 15:59:56 -04: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 14:42:54 -05: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 14:05:44 -04: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 15:33:51 -05: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-12 20:24:40 -04:00
|
|
|
export function fetchAccount(id) {
|
|
|
|
return (dispatch, getState) => {
|
2017-03-04 16:17:10 -05:00
|
|
|
dispatch(fetchRelationships([id]));
|
|
|
|
|
|
|
|
if (getState().getIn(['accounts', id], null) !== null) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2016-09-12 20:24:40 -04:00
|
|
|
dispatch(fetchAccountRequest(id));
|
|
|
|
|
2016-10-30 10:06:43 -04:00
|
|
|
api(getState).get(`/api/v1/accounts/${id}`).then(response => {
|
|
|
|
dispatch(fetchAccountSuccess(response.data));
|
2016-09-12 20:24:40 -04:00
|
|
|
}).catch(error => {
|
|
|
|
dispatch(fetchAccountFail(id, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-10-19 12:20:19 -04:00
|
|
|
export function fetchAccountTimeline(id, replace = false) {
|
2016-09-18 12:18:46 -04:00
|
|
|
return (dispatch, getState) => {
|
2017-01-23 22:12:10 -05:00
|
|
|
const ids = getState().getIn(['timelines', 'accounts_timelines', id, 'items'], Immutable.List());
|
2016-10-18 17:06:28 -04:00
|
|
|
const newestId = ids.size > 0 ? ids.first() : null;
|
|
|
|
|
2017-05-19 19:28:25 -04:00
|
|
|
let params = {};
|
2017-01-19 05:01:01 -05:00
|
|
|
let skipLoading = false;
|
2016-10-18 17:06:28 -04:00
|
|
|
|
2016-10-19 12:20:19 -04:00
|
|
|
if (newestId !== null && !replace) {
|
2017-05-19 19:28:25 -04:00
|
|
|
params.since_id = newestId;
|
2017-01-19 05:01:01 -05:00
|
|
|
skipLoading = true;
|
2016-10-18 17:06:28 -04:00
|
|
|
}
|
|
|
|
|
2017-01-19 05:01:01 -05:00
|
|
|
dispatch(fetchAccountTimelineRequest(id, skipLoading));
|
|
|
|
|
2017-05-19 19:28:25 -04:00
|
|
|
api(getState).get(`/api/v1/accounts/${id}/statuses`, { params }).then(response => {
|
2017-05-25 11:09:13 -04:00
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
|
|
|
dispatch(fetchAccountTimelineSuccess(id, response.data, replace, skipLoading, next));
|
2016-09-18 12:18:46 -04:00
|
|
|
}).catch(error => {
|
2017-01-19 05:01:01 -05:00
|
|
|
dispatch(fetchAccountTimelineFail(id, error, skipLoading));
|
2016-09-18 12:18:46 -04:00
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2017-05-19 19:28:25 -04:00
|
|
|
export function fetchAccountMediaTimeline(id, replace = false) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
const ids = getState().getIn(['timelines', 'accounts_media_timelines', id, 'items'], Immutable.List());
|
|
|
|
const newestId = ids.size > 0 ? ids.first() : null;
|
|
|
|
|
|
|
|
let params = { only_media: 'true', limit: 12 };
|
|
|
|
let skipLoading = false;
|
|
|
|
|
|
|
|
if (newestId !== null && !replace) {
|
|
|
|
params.since_id = newestId;
|
|
|
|
skipLoading = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
dispatch(fetchAccountMediaTimelineRequest(id, skipLoading));
|
|
|
|
|
|
|
|
api(getState).get(`/api/v1/accounts/${id}/statuses`, { params }).then(response => {
|
2017-05-25 11:09:13 -04:00
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
|
|
|
dispatch(fetchAccountMediaTimelineSuccess(id, response.data, replace, skipLoading, next));
|
2017-05-19 19:28:25 -04:00
|
|
|
}).catch(error => {
|
|
|
|
dispatch(fetchAccountMediaTimelineFail(id, error, skipLoading));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-09-22 14:58:35 -04:00
|
|
|
export function expandAccountTimeline(id) {
|
|
|
|
return (dispatch, getState) => {
|
2017-01-23 22:12:10 -05:00
|
|
|
const lastId = getState().getIn(['timelines', 'accounts_timelines', id, 'items'], Immutable.List()).last();
|
2016-09-22 14:58:35 -04:00
|
|
|
|
|
|
|
dispatch(expandAccountTimelineRequest(id));
|
|
|
|
|
2017-01-23 22:12:10 -05:00
|
|
|
api(getState).get(`/api/v1/accounts/${id}/statuses`, {
|
|
|
|
params: {
|
|
|
|
limit: 10,
|
2017-05-20 11:31:47 -04:00
|
|
|
max_id: lastId,
|
|
|
|
},
|
2017-01-23 22:12:10 -05:00
|
|
|
}).then(response => {
|
2017-04-18 07:10:49 -04:00
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
|
|
|
dispatch(expandAccountTimelineSuccess(id, response.data, next));
|
2016-09-22 14:58:35 -04:00
|
|
|
}).catch(error => {
|
|
|
|
dispatch(expandAccountTimelineFail(id, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2017-05-19 19:28:25 -04:00
|
|
|
export function expandAccountMediaTimeline(id) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
const lastId = getState().getIn(['timelines', 'accounts_media_timelines', id, 'items'], Immutable.List()).last();
|
|
|
|
|
|
|
|
dispatch(expandAccountMediaTimelineRequest(id));
|
|
|
|
|
|
|
|
api(getState).get(`/api/v1/accounts/${id}/statuses`, {
|
|
|
|
params: {
|
|
|
|
limit: 12,
|
|
|
|
only_media: 'true',
|
2017-05-20 11:31:47 -04:00
|
|
|
max_id: lastId,
|
|
|
|
},
|
2017-05-19 19:28:25 -04:00
|
|
|
}).then(response => {
|
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
|
|
|
dispatch(expandAccountMediaTimelineSuccess(id, response.data, next));
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch(expandAccountMediaTimelineFail(id, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-09-12 20:24:40 -04:00
|
|
|
export function fetchAccountRequest(id) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_FETCH_REQUEST,
|
2017-05-20 11:31:47 -04:00
|
|
|
id,
|
2016-09-12 20:24:40 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-10-30 10:06:43 -04:00
|
|
|
export function fetchAccountSuccess(account) {
|
2016-09-12 20:24:40 -04:00
|
|
|
return {
|
|
|
|
type: ACCOUNT_FETCH_SUCCESS,
|
2017-05-20 11:31:47 -04:00
|
|
|
account,
|
2016-09-12 20:24:40 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchAccountFail(id, error) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_FETCH_FAIL,
|
2016-11-13 14:42:54 -05:00
|
|
|
id,
|
2017-02-26 17:06:27 -05:00
|
|
|
error,
|
2017-05-20 11:31:47 -04:00
|
|
|
skipAlert: true,
|
2016-09-12 20:24:40 -04:00
|
|
|
};
|
|
|
|
};
|
2016-09-15 18:21:51 -04:00
|
|
|
|
|
|
|
export function followAccount(id) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(followAccountRequest(id));
|
|
|
|
|
2016-09-27 10:58:23 -04:00
|
|
|
api(getState).post(`/api/v1/accounts/${id}/follow`).then(response => {
|
2016-09-15 18:21:51 -04:00
|
|
|
dispatch(followAccountSuccess(response.data));
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch(followAccountFail(error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function unfollowAccount(id) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(unfollowAccountRequest(id));
|
|
|
|
|
2016-09-27 10:58:23 -04:00
|
|
|
api(getState).post(`/api/v1/accounts/${id}/unfollow`).then(response => {
|
2016-09-15 18:21:51 -04:00
|
|
|
dispatch(unfollowAccountSuccess(response.data));
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch(unfollowAccountFail(error));
|
|
|
|
});
|
2017-05-20 11:31:47 -04:00
|
|
|
};
|
2016-09-15 18:21:51 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
export function followAccountRequest(id) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_FOLLOW_REQUEST,
|
2017-05-20 11:31:47 -04:00
|
|
|
id,
|
2016-09-15 18:21:51 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-09-23 14:23:26 -04:00
|
|
|
export function followAccountSuccess(relationship) {
|
2016-09-15 18:21:51 -04:00
|
|
|
return {
|
|
|
|
type: ACCOUNT_FOLLOW_SUCCESS,
|
2017-05-20 11:31:47 -04:00
|
|
|
relationship,
|
2016-09-15 18:21:51 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function followAccountFail(error) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_FOLLOW_FAIL,
|
2017-05-20 11:31:47 -04:00
|
|
|
error,
|
2016-09-15 18:21:51 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function unfollowAccountRequest(id) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_UNFOLLOW_REQUEST,
|
2017-05-20 11:31:47 -04:00
|
|
|
id,
|
2016-09-15 18:21:51 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-09-23 14:23:26 -04:00
|
|
|
export function unfollowAccountSuccess(relationship) {
|
2016-09-15 18:21:51 -04:00
|
|
|
return {
|
|
|
|
type: ACCOUNT_UNFOLLOW_SUCCESS,
|
2017-05-20 11:31:47 -04:00
|
|
|
relationship,
|
2016-09-15 18:21:51 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function unfollowAccountFail(error) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_UNFOLLOW_FAIL,
|
2017-05-20 11:31:47 -04:00
|
|
|
error,
|
2016-09-15 18:21:51 -04:00
|
|
|
};
|
|
|
|
};
|
2016-09-18 12:18:46 -04:00
|
|
|
|
2017-01-19 05:01:01 -05:00
|
|
|
export function fetchAccountTimelineRequest(id, skipLoading) {
|
2016-09-18 12:18:46 -04:00
|
|
|
return {
|
|
|
|
type: ACCOUNT_TIMELINE_FETCH_REQUEST,
|
2017-01-19 05:01:01 -05:00
|
|
|
id,
|
2017-05-20 11:31:47 -04:00
|
|
|
skipLoading,
|
2016-09-18 12:18:46 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2017-05-25 11:09:13 -04:00
|
|
|
export function fetchAccountTimelineSuccess(id, statuses, replace, skipLoading, next) {
|
2016-09-18 12:18:46 -04:00
|
|
|
return {
|
|
|
|
type: ACCOUNT_TIMELINE_FETCH_SUCCESS,
|
2016-11-13 14:42:54 -05:00
|
|
|
id,
|
|
|
|
statuses,
|
2017-01-19 05:01:01 -05:00
|
|
|
replace,
|
2017-05-20 11:31:47 -04:00
|
|
|
skipLoading,
|
2017-05-25 11:09:13 -04:00
|
|
|
next,
|
2016-09-18 12:18:46 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2017-01-19 05:01:01 -05:00
|
|
|
export function fetchAccountTimelineFail(id, error, skipLoading) {
|
2016-09-18 12:18:46 -04:00
|
|
|
return {
|
|
|
|
type: ACCOUNT_TIMELINE_FETCH_FAIL,
|
2016-11-13 14:42:54 -05:00
|
|
|
id,
|
2017-01-19 05:01:01 -05:00
|
|
|
error,
|
2017-02-26 17:06:27 -05:00
|
|
|
skipLoading,
|
2017-05-20 11:31:47 -04:00
|
|
|
skipAlert: error.response.status === 404,
|
2016-09-18 12:18:46 -04:00
|
|
|
};
|
|
|
|
};
|
2016-09-22 14:58:35 -04:00
|
|
|
|
2017-05-19 19:28:25 -04:00
|
|
|
export function fetchAccountMediaTimelineRequest(id, skipLoading) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_MEDIA_TIMELINE_FETCH_REQUEST,
|
|
|
|
id,
|
2017-05-20 11:31:47 -04:00
|
|
|
skipLoading,
|
2017-05-19 19:28:25 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2017-05-25 11:09:13 -04:00
|
|
|
export function fetchAccountMediaTimelineSuccess(id, statuses, replace, skipLoading, next) {
|
2017-05-19 19:28:25 -04:00
|
|
|
return {
|
|
|
|
type: ACCOUNT_MEDIA_TIMELINE_FETCH_SUCCESS,
|
|
|
|
id,
|
|
|
|
statuses,
|
|
|
|
replace,
|
2017-05-20 11:31:47 -04:00
|
|
|
skipLoading,
|
2017-05-25 11:09:13 -04:00
|
|
|
next,
|
2017-05-19 19:28:25 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchAccountMediaTimelineFail(id, error, skipLoading) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_MEDIA_TIMELINE_FETCH_FAIL,
|
|
|
|
id,
|
|
|
|
error,
|
|
|
|
skipLoading,
|
2017-05-20 11:31:47 -04:00
|
|
|
skipAlert: error.response.status === 404,
|
2017-05-19 19:28:25 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-09-22 14:58:35 -04:00
|
|
|
export function expandAccountTimelineRequest(id) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_TIMELINE_EXPAND_REQUEST,
|
2017-05-20 11:31:47 -04:00
|
|
|
id,
|
2016-09-22 14:58:35 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2017-04-18 07:10:49 -04:00
|
|
|
export function expandAccountTimelineSuccess(id, statuses, next) {
|
2016-09-22 14:58:35 -04:00
|
|
|
return {
|
|
|
|
type: ACCOUNT_TIMELINE_EXPAND_SUCCESS,
|
2016-11-13 14:42:54 -05:00
|
|
|
id,
|
2017-04-18 07:10:49 -04:00
|
|
|
statuses,
|
2017-05-20 11:31:47 -04:00
|
|
|
next,
|
2016-09-22 14:58:35 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandAccountTimelineFail(id, error) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_TIMELINE_EXPAND_FAIL,
|
2016-11-13 14:42:54 -05:00
|
|
|
id,
|
2017-05-20 11:31:47 -04:00
|
|
|
error,
|
2016-09-22 14:58:35 -04:00
|
|
|
};
|
|
|
|
};
|
2016-10-03 12:49:52 -04:00
|
|
|
|
2017-05-19 19:28:25 -04:00
|
|
|
export function expandAccountMediaTimelineRequest(id) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_MEDIA_TIMELINE_EXPAND_REQUEST,
|
2017-05-20 11:31:47 -04:00
|
|
|
id,
|
2017-05-19 19:28:25 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandAccountMediaTimelineSuccess(id, statuses, next) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_MEDIA_TIMELINE_EXPAND_SUCCESS,
|
|
|
|
id,
|
|
|
|
statuses,
|
2017-05-20 11:31:47 -04:00
|
|
|
next,
|
2017-05-19 19:28:25 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandAccountMediaTimelineFail(id, error) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_MEDIA_TIMELINE_EXPAND_FAIL,
|
|
|
|
id,
|
2017-05-20 11:31:47 -04:00
|
|
|
error,
|
2017-05-19 19:28:25 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-10-03 12:49:52 -04:00
|
|
|
export function blockAccount(id) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(blockAccountRequest(id));
|
|
|
|
|
|
|
|
api(getState).post(`/api/v1/accounts/${id}/block`).then(response => {
|
2016-11-23 16:57:57 -05: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 12:49:52 -04: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 11:31:47 -04:00
|
|
|
id,
|
2016-10-03 12:49:52 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-11-23 16:57:57 -05:00
|
|
|
export function blockAccountSuccess(relationship, statuses) {
|
2016-10-03 12:49:52 -04:00
|
|
|
return {
|
|
|
|
type: ACCOUNT_BLOCK_SUCCESS,
|
2016-11-23 16:57:57 -05:00
|
|
|
relationship,
|
2017-05-20 11:31:47 -04:00
|
|
|
statuses,
|
2016-10-03 12:49:52 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function blockAccountFail(error) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_BLOCK_FAIL,
|
2017-05-20 11:31:47 -04:00
|
|
|
error,
|
2016-10-03 12:49:52 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function unblockAccountRequest(id) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_UNBLOCK_REQUEST,
|
2017-05-20 11:31:47 -04:00
|
|
|
id,
|
2016-10-03 12:49:52 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function unblockAccountSuccess(relationship) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_UNBLOCK_SUCCESS,
|
2017-05-20 11:31:47 -04:00
|
|
|
relationship,
|
2016-10-03 12:49:52 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function unblockAccountFail(error) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_UNBLOCK_FAIL,
|
2017-05-20 11:31:47 -04:00
|
|
|
error,
|
2016-10-03 12:49:52 -04:00
|
|
|
};
|
|
|
|
};
|
2016-10-27 15:59:56 -04:00
|
|
|
|
2017-02-05 20:51:56 -05:00
|
|
|
|
|
|
|
export function muteAccount(id) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(muteAccountRequest(id));
|
|
|
|
|
|
|
|
api(getState).post(`/api/v1/accounts/${id}/mute`).then(response => {
|
|
|
|
// 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 11:31:47 -04:00
|
|
|
id,
|
2017-02-05 20:51:56 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function muteAccountSuccess(relationship, statuses) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_MUTE_SUCCESS,
|
|
|
|
relationship,
|
2017-05-20 11:31:47 -04:00
|
|
|
statuses,
|
2017-02-05 20:51:56 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function muteAccountFail(error) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_MUTE_FAIL,
|
2017-05-20 11:31:47 -04:00
|
|
|
error,
|
2017-02-05 20:51:56 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function unmuteAccountRequest(id) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_UNMUTE_REQUEST,
|
2017-05-20 11:31:47 -04:00
|
|
|
id,
|
2017-02-05 20:51:56 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function unmuteAccountSuccess(relationship) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_UNMUTE_SUCCESS,
|
2017-05-20 11:31:47 -04:00
|
|
|
relationship,
|
2017-02-05 20:51:56 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function unmuteAccountFail(error) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_UNMUTE_FAIL,
|
2017-05-20 11:31:47 -04:00
|
|
|
error,
|
2017-02-05 20:51:56 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2016-10-27 15:59:56 -04:00
|
|
|
export function fetchFollowers(id) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(fetchFollowersRequest(id));
|
|
|
|
|
|
|
|
api(getState).get(`/api/v1/accounts/${id}/followers`).then(response => {
|
2016-11-13 14:52:11 -05:00
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
2016-11-13 14:42:54 -05:00
|
|
|
|
2016-11-13 14:52:11 -05:00
|
|
|
dispatch(fetchFollowersSuccess(id, response.data, next ? next.uri : null));
|
2016-10-28 14:05:44 -04:00
|
|
|
dispatch(fetchRelationships(response.data.map(item => item.id)));
|
2016-10-27 15:59:56 -04:00
|
|
|
}).catch(error => {
|
|
|
|
dispatch(fetchFollowersFail(id, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchFollowersRequest(id) {
|
|
|
|
return {
|
|
|
|
type: FOLLOWERS_FETCH_REQUEST,
|
2017-05-20 11:31:47 -04:00
|
|
|
id,
|
2016-10-27 15:59:56 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-11-13 14:52:11 -05:00
|
|
|
export function fetchFollowersSuccess(id, accounts, next) {
|
2016-10-27 15:59:56 -04:00
|
|
|
return {
|
|
|
|
type: FOLLOWERS_FETCH_SUCCESS,
|
2016-11-13 14:42:54 -05:00
|
|
|
id,
|
|
|
|
accounts,
|
2017-05-20 11:31:47 -04:00
|
|
|
next,
|
2016-10-27 15:59:56 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchFollowersFail(id, error) {
|
|
|
|
return {
|
|
|
|
type: FOLLOWERS_FETCH_FAIL,
|
2016-11-13 14:42:54 -05:00
|
|
|
id,
|
2017-05-20 11:31:47 -04:00
|
|
|
error,
|
2016-11-13 14:42:54 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandFollowers(id) {
|
|
|
|
return (dispatch, getState) => {
|
2016-11-13 14:52:11 -05:00
|
|
|
const url = getState().getIn(['user_lists', 'followers', id, 'next']);
|
|
|
|
|
|
|
|
if (url === null) {
|
|
|
|
return;
|
|
|
|
}
|
2016-11-13 14:42:54 -05:00
|
|
|
|
|
|
|
dispatch(expandFollowersRequest(id));
|
|
|
|
|
|
|
|
api(getState).get(url).then(response => {
|
2016-11-13 14:52:11 -05:00
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
2016-11-13 14:42:54 -05:00
|
|
|
|
2016-11-13 14:52:11 -05:00
|
|
|
dispatch(expandFollowersSuccess(id, response.data, next ? next.uri : null));
|
2016-11-13 14:42:54 -05: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 11:31:47 -04:00
|
|
|
id,
|
2016-11-13 14:42:54 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-11-13 14:52:11 -05:00
|
|
|
export function expandFollowersSuccess(id, accounts, next) {
|
2016-11-13 14:42:54 -05:00
|
|
|
return {
|
|
|
|
type: FOLLOWERS_EXPAND_SUCCESS,
|
|
|
|
id,
|
|
|
|
accounts,
|
2017-05-20 11:31:47 -04:00
|
|
|
next,
|
2016-11-13 14:42:54 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandFollowersFail(id, error) {
|
|
|
|
return {
|
|
|
|
type: FOLLOWERS_EXPAND_FAIL,
|
|
|
|
id,
|
2017-05-20 11:31:47 -04:00
|
|
|
error,
|
2016-10-27 15:59:56 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchFollowing(id) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(fetchFollowingRequest(id));
|
|
|
|
|
|
|
|
api(getState).get(`/api/v1/accounts/${id}/following`).then(response => {
|
2016-11-13 14:52:11 -05:00
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
|
|
|
|
|
|
|
dispatch(fetchFollowingSuccess(id, response.data, next ? next.uri : null));
|
2016-10-28 14:05:44 -04:00
|
|
|
dispatch(fetchRelationships(response.data.map(item => item.id)));
|
2016-10-27 15:59:56 -04:00
|
|
|
}).catch(error => {
|
|
|
|
dispatch(fetchFollowingFail(id, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchFollowingRequest(id) {
|
|
|
|
return {
|
|
|
|
type: FOLLOWING_FETCH_REQUEST,
|
2017-05-20 11:31:47 -04:00
|
|
|
id,
|
2016-10-27 15:59:56 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-11-13 15:02:10 -05:00
|
|
|
export function fetchFollowingSuccess(id, accounts, next) {
|
2016-10-27 15:59:56 -04:00
|
|
|
return {
|
|
|
|
type: FOLLOWING_FETCH_SUCCESS,
|
2016-11-13 14:42:54 -05:00
|
|
|
id,
|
2016-11-13 15:02:10 -05:00
|
|
|
accounts,
|
2017-05-20 11:31:47 -04:00
|
|
|
next,
|
2016-10-27 15:59:56 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchFollowingFail(id, error) {
|
|
|
|
return {
|
|
|
|
type: FOLLOWING_FETCH_FAIL,
|
2016-11-13 14:42:54 -05:00
|
|
|
id,
|
2017-05-20 11:31:47 -04:00
|
|
|
error,
|
2016-11-13 14:42:54 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandFollowing(id) {
|
|
|
|
return (dispatch, getState) => {
|
2016-11-13 14:52:11 -05:00
|
|
|
const url = getState().getIn(['user_lists', 'following', id, 'next']);
|
|
|
|
|
|
|
|
if (url === null) {
|
|
|
|
return;
|
|
|
|
}
|
2016-11-13 14:42:54 -05:00
|
|
|
|
|
|
|
dispatch(expandFollowingRequest(id));
|
|
|
|
|
|
|
|
api(getState).get(url).then(response => {
|
2016-11-13 14:52:11 -05:00
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
2016-11-13 14:42:54 -05:00
|
|
|
|
2016-11-13 14:52:11 -05:00
|
|
|
dispatch(expandFollowingSuccess(id, response.data, next ? next.uri : null));
|
2016-11-13 14:42:54 -05: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 11:31:47 -04:00
|
|
|
id,
|
2016-11-13 14:42:54 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-11-13 14:52:11 -05:00
|
|
|
export function expandFollowingSuccess(id, accounts, next) {
|
2016-11-13 14:42:54 -05:00
|
|
|
return {
|
|
|
|
type: FOLLOWING_EXPAND_SUCCESS,
|
|
|
|
id,
|
|
|
|
accounts,
|
2017-05-20 11:31:47 -04:00
|
|
|
next,
|
2016-11-13 14:42:54 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandFollowingFail(id, error) {
|
|
|
|
return {
|
|
|
|
type: FOLLOWING_EXPAND_FAIL,
|
|
|
|
id,
|
2017-05-20 11:31:47 -04:00
|
|
|
error,
|
2016-10-27 15:59:56 -04:00
|
|
|
};
|
|
|
|
};
|
2016-10-28 14:05:44 -04:00
|
|
|
|
2017-04-02 16:02:38 -04:00
|
|
|
export function fetchRelationships(accountIds) {
|
2016-10-28 14:05:44 -04:00
|
|
|
return (dispatch, getState) => {
|
2017-04-02 16:02:38 -04:00
|
|
|
const loadedRelationships = getState().get('relationships');
|
|
|
|
const newAccountIds = accountIds.filter(id => loadedRelationships.get(id, null) === null);
|
|
|
|
|
|
|
|
if (newAccountIds.length === 0) {
|
2017-01-15 08:41:49 -05:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2017-04-02 16:02:38 -04:00
|
|
|
dispatch(fetchRelationshipsRequest(newAccountIds));
|
2016-10-28 14:05:44 -04:00
|
|
|
|
2017-04-02 16:02:38 -04:00
|
|
|
api(getState).get(`/api/v1/accounts/relationships?${newAccountIds.map(id => `id[]=${id}`).join('&')}`).then(response => {
|
2016-10-28 14:05:44 -04:00
|
|
|
dispatch(fetchRelationshipsSuccess(response.data));
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch(fetchRelationshipsFail(error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchRelationshipsRequest(ids) {
|
|
|
|
return {
|
|
|
|
type: RELATIONSHIPS_FETCH_REQUEST,
|
2017-01-19 05:23:24 -05:00
|
|
|
ids,
|
2017-05-20 11:31:47 -04:00
|
|
|
skipLoading: true,
|
2016-10-28 14:05:44 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchRelationshipsSuccess(relationships) {
|
|
|
|
return {
|
|
|
|
type: RELATIONSHIPS_FETCH_SUCCESS,
|
2017-01-19 05:23:24 -05:00
|
|
|
relationships,
|
2017-05-20 11:31:47 -04:00
|
|
|
skipLoading: true,
|
2016-10-28 14:05:44 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchRelationshipsFail(error) {
|
|
|
|
return {
|
|
|
|
type: RELATIONSHIPS_FETCH_FAIL,
|
2017-01-19 05:23:24 -05:00
|
|
|
error,
|
2017-05-20 11:31:47 -04:00
|
|
|
skipLoading: true,
|
2016-10-28 14:05:44 -04:00
|
|
|
};
|
|
|
|
};
|
2016-12-26 15:33:51 -05: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 11:31:47 -04:00
|
|
|
dispatch(fetchFollowRequestsSuccess(response.data, next ? next.uri : null));
|
2016-12-26 15:33:51 -05:00
|
|
|
}).catch(error => dispatch(fetchFollowRequestsFail(error)));
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchFollowRequestsRequest() {
|
|
|
|
return {
|
2017-05-20 11:31:47 -04:00
|
|
|
type: FOLLOW_REQUESTS_FETCH_REQUEST,
|
2016-12-26 15:33:51 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchFollowRequestsSuccess(accounts, next) {
|
|
|
|
return {
|
|
|
|
type: FOLLOW_REQUESTS_FETCH_SUCCESS,
|
|
|
|
accounts,
|
2017-05-20 11:31:47 -04:00
|
|
|
next,
|
2016-12-26 15:33:51 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchFollowRequestsFail(error) {
|
|
|
|
return {
|
|
|
|
type: FOLLOW_REQUESTS_FETCH_FAIL,
|
2017-05-20 11:31:47 -04:00
|
|
|
error,
|
2016-12-26 15:33:51 -05: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 11:31:47 -04:00
|
|
|
dispatch(expandFollowRequestsSuccess(response.data, next ? next.uri : null));
|
2016-12-26 15:33:51 -05:00
|
|
|
}).catch(error => dispatch(expandFollowRequestsFail(error)));
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandFollowRequestsRequest() {
|
|
|
|
return {
|
2017-05-20 11:31:47 -04:00
|
|
|
type: FOLLOW_REQUESTS_EXPAND_REQUEST,
|
2016-12-26 15:33:51 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandFollowRequestsSuccess(accounts, next) {
|
|
|
|
return {
|
|
|
|
type: FOLLOW_REQUESTS_EXPAND_SUCCESS,
|
|
|
|
accounts,
|
2017-05-20 11:31:47 -04:00
|
|
|
next,
|
2016-12-26 15:33:51 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandFollowRequestsFail(error) {
|
|
|
|
return {
|
|
|
|
type: FOLLOW_REQUESTS_EXPAND_FAIL,
|
2017-05-20 11:31:47 -04:00
|
|
|
error,
|
2016-12-26 15:33:51 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function authorizeFollowRequest(id) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(authorizeFollowRequestRequest(id));
|
|
|
|
|
|
|
|
api(getState)
|
|
|
|
.post(`/api/v1/follow_requests/${id}/authorize`)
|
|
|
|
.then(response => dispatch(authorizeFollowRequestSuccess(id)))
|
|
|
|
.catch(error => dispatch(authorizeFollowRequestFail(id, error)));
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function authorizeFollowRequestRequest(id) {
|
|
|
|
return {
|
|
|
|
type: FOLLOW_REQUEST_AUTHORIZE_REQUEST,
|
2017-05-20 11:31:47 -04:00
|
|
|
id,
|
2016-12-26 15:33:51 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function authorizeFollowRequestSuccess(id) {
|
|
|
|
return {
|
|
|
|
type: FOLLOW_REQUEST_AUTHORIZE_SUCCESS,
|
2017-05-20 11:31:47 -04:00
|
|
|
id,
|
2016-12-26 15:33:51 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function authorizeFollowRequestFail(id, error) {
|
|
|
|
return {
|
|
|
|
type: FOLLOW_REQUEST_AUTHORIZE_FAIL,
|
|
|
|
id,
|
2017-05-20 11:31:47 -04:00
|
|
|
error,
|
2016-12-26 15:33:51 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
export function rejectFollowRequest(id) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(rejectFollowRequestRequest(id));
|
|
|
|
|
|
|
|
api(getState)
|
|
|
|
.post(`/api/v1/follow_requests/${id}/reject`)
|
|
|
|
.then(response => dispatch(rejectFollowRequestSuccess(id)))
|
|
|
|
.catch(error => dispatch(rejectFollowRequestFail(id, error)));
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function rejectFollowRequestRequest(id) {
|
|
|
|
return {
|
|
|
|
type: FOLLOW_REQUEST_REJECT_REQUEST,
|
2017-05-20 11:31:47 -04:00
|
|
|
id,
|
2016-12-26 15:33:51 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function rejectFollowRequestSuccess(id) {
|
|
|
|
return {
|
|
|
|
type: FOLLOW_REQUEST_REJECT_SUCCESS,
|
2017-05-20 11:31:47 -04:00
|
|
|
id,
|
2016-12-26 15:33:51 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function rejectFollowRequestFail(id, error) {
|
|
|
|
return {
|
|
|
|
type: FOLLOW_REQUEST_REJECT_FAIL,
|
|
|
|
id,
|
2017-05-20 11:31:47 -04:00
|
|
|
error,
|
2016-12-26 15:33:51 -05:00
|
|
|
};
|
|
|
|
};
|