|
|
|
@ -33,13 +33,9 @@ export const STATUS_HIDE = 'STATUS_HIDE';
|
|
|
|
|
|
|
|
|
|
export const REDRAFT = 'REDRAFT';
|
|
|
|
|
|
|
|
|
|
export function fetchStatusRequest(id, skipLoading) {
|
|
|
|
|
return {
|
|
|
|
|
type: STATUS_FETCH_REQUEST,
|
|
|
|
|
id,
|
|
|
|
|
skipLoading,
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
const statusExists = (getState, statusId) => {
|
|
|
|
|
return getState().getIn(['statuses', statusId], null) !== null;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export function createStatus(params, idempotencyKey) {
|
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
@ -60,43 +56,20 @@ export function createStatus(params, idempotencyKey) {
|
|
|
|
|
|
|
|
|
|
export function fetchStatus(id) {
|
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
|
const skipLoading = getState().getIn(['statuses', id], null) !== null;
|
|
|
|
|
const skipLoading = statusExists(getState, id);
|
|
|
|
|
|
|
|
|
|
dispatch(fetchContext(id));
|
|
|
|
|
|
|
|
|
|
if (skipLoading) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
dispatch({ type: STATUS_FETCH_REQUEST, id, skipLoading });
|
|
|
|
|
|
|
|
|
|
dispatch(fetchStatusRequest(id, skipLoading));
|
|
|
|
|
|
|
|
|
|
api(getState).get(`/api/v1/statuses/${id}`).then(response => {
|
|
|
|
|
dispatch(importFetchedStatus(response.data));
|
|
|
|
|
dispatch(fetchStatusSuccess(response.data, skipLoading));
|
|
|
|
|
return api(getState).get(`/api/v1/statuses/${id}`).then(({ data: status }) => {
|
|
|
|
|
dispatch(importFetchedStatus(status));
|
|
|
|
|
dispatch({ type: STATUS_FETCH_SUCCESS, status, skipLoading });
|
|
|
|
|
return status;
|
|
|
|
|
}).catch(error => {
|
|
|
|
|
dispatch(fetchStatusFail(id, error, skipLoading));
|
|
|
|
|
dispatch({ type: STATUS_FETCH_FAIL, id, error, skipLoading, skipAlert: true });
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function fetchStatusSuccess(status, skipLoading) {
|
|
|
|
|
return {
|
|
|
|
|
type: STATUS_FETCH_SUCCESS,
|
|
|
|
|
status,
|
|
|
|
|
skipLoading,
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function fetchStatusFail(id, error, skipLoading) {
|
|
|
|
|
return {
|
|
|
|
|
type: STATUS_FETCH_FAIL,
|
|
|
|
|
id,
|
|
|
|
|
error,
|
|
|
|
|
skipLoading,
|
|
|
|
|
skipAlert: true,
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function redraft(status, raw_text) {
|
|
|
|
|
return {
|
|
|
|
|
type: REDRAFT,
|
|
|
|
@ -115,10 +88,10 @@ export function deleteStatus(id, routerHistory, withRedraft = false) {
|
|
|
|
|
status = status.set('poll', getState().getIn(['polls', status.get('poll')]));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
dispatch(deleteStatusRequest(id));
|
|
|
|
|
dispatch({ type: STATUS_DELETE_REQUEST, id });
|
|
|
|
|
|
|
|
|
|
api(getState).delete(`/api/v1/statuses/${id}`).then(response => {
|
|
|
|
|
dispatch(deleteStatusSuccess(id));
|
|
|
|
|
dispatch({ type: STATUS_DELETE_SUCCESS, id });
|
|
|
|
|
dispatch(deleteFromTimelines(id));
|
|
|
|
|
|
|
|
|
|
if (withRedraft) {
|
|
|
|
@ -126,73 +99,37 @@ export function deleteStatus(id, routerHistory, withRedraft = false) {
|
|
|
|
|
dispatch(openModal('COMPOSE'));
|
|
|
|
|
}
|
|
|
|
|
}).catch(error => {
|
|
|
|
|
dispatch(deleteStatusFail(id, error));
|
|
|
|
|
dispatch({ type: STATUS_DELETE_FAIL, id, error });
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function deleteStatusRequest(id) {
|
|
|
|
|
return {
|
|
|
|
|
type: STATUS_DELETE_REQUEST,
|
|
|
|
|
id: id,
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function deleteStatusSuccess(id) {
|
|
|
|
|
return {
|
|
|
|
|
type: STATUS_DELETE_SUCCESS,
|
|
|
|
|
id: id,
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function deleteStatusFail(id, error) {
|
|
|
|
|
return {
|
|
|
|
|
type: STATUS_DELETE_FAIL,
|
|
|
|
|
id: id,
|
|
|
|
|
error: error,
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function fetchContext(id) {
|
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
|
dispatch(fetchContextRequest(id));
|
|
|
|
|
|
|
|
|
|
api(getState).get(`/api/v1/statuses/${id}/context`).then(response => {
|
|
|
|
|
dispatch(importFetchedStatuses(response.data.ancestors.concat(response.data.descendants)));
|
|
|
|
|
dispatch(fetchContextSuccess(id, response.data.ancestors, response.data.descendants));
|
|
|
|
|
|
|
|
|
|
dispatch({ type: CONTEXT_FETCH_REQUEST, id });
|
|
|
|
|
|
|
|
|
|
return api(getState).get(`/api/v1/statuses/${id}/context`).then(({ data: context }) => {
|
|
|
|
|
const { ancestors, descendants } = context;
|
|
|
|
|
const statuses = ancestors.concat(descendants);
|
|
|
|
|
dispatch(importFetchedStatuses(statuses));
|
|
|
|
|
dispatch({ type: CONTEXT_FETCH_SUCCESS, id, ancestors, descendants });
|
|
|
|
|
return context;
|
|
|
|
|
}).catch(error => {
|
|
|
|
|
if (error.response && error.response.status === 404) {
|
|
|
|
|
dispatch(deleteFromTimelines(id));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
dispatch(fetchContextFail(id, error));
|
|
|
|
|
dispatch({ type: CONTEXT_FETCH_FAIL, id, error, skipAlert: true });
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function fetchContextRequest(id) {
|
|
|
|
|
return {
|
|
|
|
|
type: CONTEXT_FETCH_REQUEST,
|
|
|
|
|
id,
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function fetchContextSuccess(id, ancestors, descendants) {
|
|
|
|
|
return {
|
|
|
|
|
type: CONTEXT_FETCH_SUCCESS,
|
|
|
|
|
id,
|
|
|
|
|
ancestors,
|
|
|
|
|
descendants,
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function fetchContextFail(id, error) {
|
|
|
|
|
return {
|
|
|
|
|
type: CONTEXT_FETCH_FAIL,
|
|
|
|
|
id,
|
|
|
|
|
error,
|
|
|
|
|
skipAlert: true,
|
|
|
|
|
export function fetchStatusWithContext(id) {
|
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
|
return Promise.all([
|
|
|
|
|
dispatch(fetchContext(id)),
|
|
|
|
|
dispatch(fetchStatus(id)),
|
|
|
|
|
]);
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -200,74 +137,28 @@ export function muteStatus(id) {
|
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
|
if (!isLoggedIn(getState)) return;
|
|
|
|
|
|
|
|
|
|
dispatch(muteStatusRequest(id));
|
|
|
|
|
|
|
|
|
|
dispatch({ type: STATUS_MUTE_REQUEST, id });
|
|
|
|
|
api(getState).post(`/api/v1/statuses/${id}/mute`).then(() => {
|
|
|
|
|
dispatch(muteStatusSuccess(id));
|
|
|
|
|
dispatch({ type: STATUS_MUTE_SUCCESS, id });
|
|
|
|
|
}).catch(error => {
|
|
|
|
|
dispatch(muteStatusFail(id, error));
|
|
|
|
|
dispatch({ type: STATUS_MUTE_FAIL, id, error });
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function muteStatusRequest(id) {
|
|
|
|
|
return {
|
|
|
|
|
type: STATUS_MUTE_REQUEST,
|
|
|
|
|
id,
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function muteStatusSuccess(id) {
|
|
|
|
|
return {
|
|
|
|
|
type: STATUS_MUTE_SUCCESS,
|
|
|
|
|
id,
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function muteStatusFail(id, error) {
|
|
|
|
|
return {
|
|
|
|
|
type: STATUS_MUTE_FAIL,
|
|
|
|
|
id,
|
|
|
|
|
error,
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function unmuteStatus(id) {
|
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
|
if (!isLoggedIn(getState)) return;
|
|
|
|
|
|
|
|
|
|
dispatch(unmuteStatusRequest(id));
|
|
|
|
|
|
|
|
|
|
dispatch({ type: STATUS_UNMUTE_REQUEST, id });
|
|
|
|
|
api(getState).post(`/api/v1/statuses/${id}/unmute`).then(() => {
|
|
|
|
|
dispatch(unmuteStatusSuccess(id));
|
|
|
|
|
dispatch({ type: STATUS_UNMUTE_SUCCESS, id });
|
|
|
|
|
}).catch(error => {
|
|
|
|
|
dispatch(unmuteStatusFail(id, error));
|
|
|
|
|
dispatch({ type: STATUS_UNMUTE_FAIL, id, error });
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function unmuteStatusRequest(id) {
|
|
|
|
|
return {
|
|
|
|
|
type: STATUS_UNMUTE_REQUEST,
|
|
|
|
|
id,
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function unmuteStatusSuccess(id) {
|
|
|
|
|
return {
|
|
|
|
|
type: STATUS_UNMUTE_SUCCESS,
|
|
|
|
|
id,
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function unmuteStatusFail(id, error) {
|
|
|
|
|
return {
|
|
|
|
|
type: STATUS_UNMUTE_FAIL,
|
|
|
|
|
id,
|
|
|
|
|
error,
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function hideStatus(ids) {
|
|
|
|
|
if (!Array.isArray(ids)) {
|
|
|
|
|
ids = [ids];
|
|
|
|
|