2017-05-20 18:31:47 +03:00
|
|
|
import api, { getLinks } from '../api';
|
2016-10-17 02:23:41 +03:00
|
|
|
import Immutable from 'immutable';
|
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-09-18 19:18:46 +03: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 21:58:35 +03: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-20 02:28:25 +03: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 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));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-10-19 19:20:19 +03:00
|
|
|
export function fetchAccountTimeline(id, replace = false) {
|
2016-09-18 19:18:46 +03:00
|
|
|
return (dispatch, getState) => {
|
2017-01-24 05:12:10 +02:00
|
|
|
const ids = getState().getIn(['timelines', 'accounts_timelines', id, 'items'], Immutable.List());
|
2016-10-19 00:06:28 +03:00
|
|
|
const newestId = ids.size > 0 ? ids.first() : null;
|
|
|
|
|
2017-05-20 02:28:25 +03:00
|
|
|
let params = {};
|
2017-01-19 12:01:01 +02:00
|
|
|
let skipLoading = false;
|
2016-10-19 00:06:28 +03:00
|
|
|
|
2017-05-31 16:30:26 +03:00
|
|
|
replace = replace || newestId === null;
|
|
|
|
|
|
|
|
if (!replace) {
|
2017-05-20 02:28:25 +03:00
|
|
|
params.since_id = newestId;
|
2017-01-19 12:01:01 +02:00
|
|
|
skipLoading = true;
|
2016-10-19 00:06:28 +03:00
|
|
|
}
|
|
|
|
|
2017-01-19 12:01:01 +02:00
|
|
|
dispatch(fetchAccountTimelineRequest(id, skipLoading));
|
|
|
|
|
2017-05-20 02:28:25 +03:00
|
|
|
api(getState).get(`/api/v1/accounts/${id}/statuses`, { params }).then(response => {
|
2017-05-25 18:09:13 +03:00
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
|
|
|
dispatch(fetchAccountTimelineSuccess(id, response.data, replace, skipLoading, next));
|
2016-09-18 19:18:46 +03:00
|
|
|
}).catch(error => {
|
2017-01-19 12:01:01 +02:00
|
|
|
dispatch(fetchAccountTimelineFail(id, error, skipLoading));
|
2016-09-18 19:18:46 +03:00
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2017-05-20 02:28:25 +03: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;
|
|
|
|
|
2017-05-31 16:30:26 +03:00
|
|
|
replace = replace || newestId === null;
|
|
|
|
|
|
|
|
if (!replace) {
|
2017-05-20 02:28:25 +03:00
|
|
|
params.since_id = newestId;
|
|
|
|
skipLoading = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
dispatch(fetchAccountMediaTimelineRequest(id, skipLoading));
|
|
|
|
|
|
|
|
api(getState).get(`/api/v1/accounts/${id}/statuses`, { params }).then(response => {
|
2017-05-25 18:09:13 +03:00
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
|
|
|
dispatch(fetchAccountMediaTimelineSuccess(id, response.data, replace, skipLoading, next));
|
2017-05-20 02:28:25 +03:00
|
|
|
}).catch(error => {
|
|
|
|
dispatch(fetchAccountMediaTimelineFail(id, error, skipLoading));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-09-22 21:58:35 +03:00
|
|
|
export function expandAccountTimeline(id) {
|
|
|
|
return (dispatch, getState) => {
|
2017-01-24 05:12:10 +02:00
|
|
|
const lastId = getState().getIn(['timelines', 'accounts_timelines', id, 'items'], Immutable.List()).last();
|
2016-09-22 21:58:35 +03:00
|
|
|
|
|
|
|
dispatch(expandAccountTimelineRequest(id));
|
|
|
|
|
2017-01-24 05:12:10 +02:00
|
|
|
api(getState).get(`/api/v1/accounts/${id}/statuses`, {
|
|
|
|
params: {
|
|
|
|
limit: 10,
|
2017-05-20 18:31:47 +03:00
|
|
|
max_id: lastId,
|
|
|
|
},
|
2017-01-24 05:12:10 +02:00
|
|
|
}).then(response => {
|
2017-04-18 14:10:49 +03:00
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
|
|
|
dispatch(expandAccountTimelineSuccess(id, response.data, next));
|
2016-09-22 21:58:35 +03:00
|
|
|
}).catch(error => {
|
|
|
|
dispatch(expandAccountTimelineFail(id, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2017-05-20 02:28:25 +03: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 18:31:47 +03:00
|
|
|
max_id: lastId,
|
|
|
|
},
|
2017-05-20 02:28:25 +03: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-13 03:24:40 +03:00
|
|
|
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
|
|
|
|
|
|
|
export function followAccount(id) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(followAccountRequest(id));
|
|
|
|
|
2016-09-27 17:58:23 +03:00
|
|
|
api(getState).post(`/api/v1/accounts/${id}/follow`).then(response => {
|
2016-09-16 01:21:51 +03:00
|
|
|
dispatch(followAccountSuccess(response.data));
|
|
|
|
}).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 => {
|
2016-09-16 01:21:51 +03:00
|
|
|
dispatch(unfollowAccountSuccess(response.data));
|
|
|
|
}).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
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-09-23 21:23:26 +03:00
|
|
|
export function followAccountSuccess(relationship) {
|
2016-09-16 01:21:51 +03:00
|
|
|
return {
|
|
|
|
type: ACCOUNT_FOLLOW_SUCCESS,
|
2017-05-20 18:31:47 +03:00
|
|
|
relationship,
|
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
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-09-23 21:23:26 +03:00
|
|
|
export function unfollowAccountSuccess(relationship) {
|
2016-09-16 01:21:51 +03:00
|
|
|
return {
|
|
|
|
type: ACCOUNT_UNFOLLOW_SUCCESS,
|
2017-05-20 18:31:47 +03:00
|
|
|
relationship,
|
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
|
|
|
|
2017-01-19 12:01:01 +02:00
|
|
|
export function fetchAccountTimelineRequest(id, skipLoading) {
|
2016-09-18 19:18:46 +03:00
|
|
|
return {
|
|
|
|
type: ACCOUNT_TIMELINE_FETCH_REQUEST,
|
2017-01-19 12:01:01 +02:00
|
|
|
id,
|
2017-05-20 18:31:47 +03:00
|
|
|
skipLoading,
|
2016-09-18 19:18:46 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2017-05-25 18:09:13 +03:00
|
|
|
export function fetchAccountTimelineSuccess(id, statuses, replace, skipLoading, next) {
|
2016-09-18 19:18:46 +03:00
|
|
|
return {
|
|
|
|
type: ACCOUNT_TIMELINE_FETCH_SUCCESS,
|
2016-11-13 21:42:54 +02:00
|
|
|
id,
|
|
|
|
statuses,
|
2017-01-19 12:01:01 +02:00
|
|
|
replace,
|
2017-05-20 18:31:47 +03:00
|
|
|
skipLoading,
|
2017-05-25 18:09:13 +03:00
|
|
|
next,
|
2016-09-18 19:18:46 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2017-01-19 12:01:01 +02:00
|
|
|
export function fetchAccountTimelineFail(id, error, skipLoading) {
|
2016-09-18 19:18:46 +03:00
|
|
|
return {
|
|
|
|
type: ACCOUNT_TIMELINE_FETCH_FAIL,
|
2016-11-13 21:42:54 +02:00
|
|
|
id,
|
2017-01-19 12:01:01 +02:00
|
|
|
error,
|
2017-02-27 00:06:27 +02:00
|
|
|
skipLoading,
|
2017-05-20 18:31:47 +03:00
|
|
|
skipAlert: error.response.status === 404,
|
2016-09-18 19:18:46 +03:00
|
|
|
};
|
|
|
|
};
|
2016-09-22 21:58:35 +03:00
|
|
|
|
2017-05-20 02:28:25 +03:00
|
|
|
export function fetchAccountMediaTimelineRequest(id, skipLoading) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_MEDIA_TIMELINE_FETCH_REQUEST,
|
|
|
|
id,
|
2017-05-20 18:31:47 +03:00
|
|
|
skipLoading,
|
2017-05-20 02:28:25 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2017-05-25 18:09:13 +03:00
|
|
|
export function fetchAccountMediaTimelineSuccess(id, statuses, replace, skipLoading, next) {
|
2017-05-20 02:28:25 +03:00
|
|
|
return {
|
|
|
|
type: ACCOUNT_MEDIA_TIMELINE_FETCH_SUCCESS,
|
|
|
|
id,
|
|
|
|
statuses,
|
|
|
|
replace,
|
2017-05-20 18:31:47 +03:00
|
|
|
skipLoading,
|
2017-05-25 18:09:13 +03:00
|
|
|
next,
|
2017-05-20 02:28:25 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function fetchAccountMediaTimelineFail(id, error, skipLoading) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_MEDIA_TIMELINE_FETCH_FAIL,
|
|
|
|
id,
|
|
|
|
error,
|
|
|
|
skipLoading,
|
2017-05-20 18:31:47 +03:00
|
|
|
skipAlert: error.response.status === 404,
|
2017-05-20 02:28:25 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-09-22 21:58:35 +03:00
|
|
|
export function expandAccountTimelineRequest(id) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_TIMELINE_EXPAND_REQUEST,
|
2017-05-20 18:31:47 +03:00
|
|
|
id,
|
2016-09-22 21:58:35 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2017-04-18 14:10:49 +03:00
|
|
|
export function expandAccountTimelineSuccess(id, statuses, next) {
|
2016-09-22 21:58:35 +03:00
|
|
|
return {
|
|
|
|
type: ACCOUNT_TIMELINE_EXPAND_SUCCESS,
|
2016-11-13 21:42:54 +02:00
|
|
|
id,
|
2017-04-18 14:10:49 +03:00
|
|
|
statuses,
|
2017-05-20 18:31:47 +03:00
|
|
|
next,
|
2016-09-22 21:58:35 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandAccountTimelineFail(id, error) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_TIMELINE_EXPAND_FAIL,
|
2016-11-13 21:42:54 +02:00
|
|
|
id,
|
2017-05-20 18:31:47 +03:00
|
|
|
error,
|
2016-09-22 21:58:35 +03:00
|
|
|
};
|
|
|
|
};
|
2016-10-03 19:49:52 +03:00
|
|
|
|
2017-05-20 02:28:25 +03:00
|
|
|
export function expandAccountMediaTimelineRequest(id) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_MEDIA_TIMELINE_EXPAND_REQUEST,
|
2017-05-20 18:31:47 +03:00
|
|
|
id,
|
2017-05-20 02:28:25 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandAccountMediaTimelineSuccess(id, statuses, next) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_MEDIA_TIMELINE_EXPAND_SUCCESS,
|
|
|
|
id,
|
|
|
|
statuses,
|
2017-05-20 18:31:47 +03:00
|
|
|
next,
|
2017-05-20 02:28:25 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export function expandAccountMediaTimelineFail(id, error) {
|
|
|
|
return {
|
|
|
|
type: ACCOUNT_MEDIA_TIMELINE_EXPAND_FAIL,
|
|
|
|
id,
|
2017-05-20 18:31:47 +03:00
|
|
|
error,
|
2017-05-20 02:28:25 +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
|
|
|
|
|
|
|
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 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`)
|
|
|
|
.then(response => dispatch(authorizeFollowRequestSuccess(id)))
|
|
|
|
.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`)
|
|
|
|
.then(response => dispatch(rejectFollowRequestSuccess(id)))
|
|
|
|
.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
|
|
|
};
|
|
|
|
};
|