2023-10-29 15:00:48 -07:00
|
|
|
import { List as ImmutableList } from 'immutable';
|
2022-06-19 11:38:51 -07:00
|
|
|
|
|
|
|
import { isLoggedIn } from 'soapbox/utils/auth';
|
|
|
|
|
|
|
|
import api from '../api';
|
|
|
|
|
|
|
|
import { importFetchedAccounts, importFetchedStatus } from './importer';
|
|
|
|
import { favourite, unfavourite } from './interactions';
|
|
|
|
|
|
|
|
import type { AppDispatch, RootState } from 'soapbox/store';
|
2023-10-29 15:00:48 -07:00
|
|
|
import type { APIEntity, EmojiReaction, Status } from 'soapbox/types/entities';
|
2022-06-19 11:38:51 -07:00
|
|
|
|
|
|
|
const EMOJI_REACT_REQUEST = 'EMOJI_REACT_REQUEST';
|
|
|
|
const EMOJI_REACT_SUCCESS = 'EMOJI_REACT_SUCCESS';
|
|
|
|
const EMOJI_REACT_FAIL = 'EMOJI_REACT_FAIL';
|
|
|
|
|
|
|
|
const UNEMOJI_REACT_REQUEST = 'UNEMOJI_REACT_REQUEST';
|
|
|
|
const UNEMOJI_REACT_SUCCESS = 'UNEMOJI_REACT_SUCCESS';
|
|
|
|
const UNEMOJI_REACT_FAIL = 'UNEMOJI_REACT_FAIL';
|
|
|
|
|
|
|
|
const EMOJI_REACTS_FETCH_REQUEST = 'EMOJI_REACTS_FETCH_REQUEST';
|
|
|
|
const EMOJI_REACTS_FETCH_SUCCESS = 'EMOJI_REACTS_FETCH_SUCCESS';
|
|
|
|
const EMOJI_REACTS_FETCH_FAIL = 'EMOJI_REACTS_FETCH_FAIL';
|
|
|
|
|
|
|
|
const noOp = () => () => new Promise(f => f(undefined));
|
|
|
|
|
2023-03-17 16:07:18 -07:00
|
|
|
const simpleEmojiReact = (status: Status, emoji: string, custom?: string) =>
|
2022-06-19 11:38:51 -07:00
|
|
|
(dispatch: AppDispatch) => {
|
2023-10-29 15:00:48 -07:00
|
|
|
const emojiReacts: ImmutableList<EmojiReaction> = status.reactions || ImmutableList();
|
2022-06-19 11:38:51 -07:00
|
|
|
|
|
|
|
if (emoji === '👍' && status.favourited) return dispatch(unfavourite(status));
|
|
|
|
|
2023-10-29 15:00:48 -07:00
|
|
|
const undo = emojiReacts.filter(e => e.me === true && e.name === emoji).count() > 0;
|
2022-06-19 11:38:51 -07:00
|
|
|
if (undo) return dispatch(unEmojiReact(status, emoji));
|
|
|
|
|
|
|
|
return Promise.all([
|
|
|
|
...emojiReacts
|
2023-10-29 15:00:48 -07:00
|
|
|
.filter((emojiReact) => emojiReact.me === true)
|
|
|
|
.map(emojiReact => dispatch(unEmojiReact(status, emojiReact.name))).toArray(),
|
2022-06-19 11:38:51 -07:00
|
|
|
status.favourited && dispatch(unfavourite(status)),
|
|
|
|
]).then(() => {
|
|
|
|
if (emoji === '👍') {
|
|
|
|
dispatch(favourite(status));
|
|
|
|
} else {
|
2023-03-17 16:07:18 -07:00
|
|
|
dispatch(emojiReact(status, emoji, custom));
|
2022-06-19 11:38:51 -07:00
|
|
|
}
|
|
|
|
}).catch(err => {
|
|
|
|
console.error(err);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
const fetchEmojiReacts = (id: string, emoji: string) =>
|
|
|
|
(dispatch: AppDispatch, getState: () => RootState) => {
|
|
|
|
if (!isLoggedIn(getState)) return dispatch(noOp());
|
|
|
|
|
|
|
|
dispatch(fetchEmojiReactsRequest(id, emoji));
|
|
|
|
|
|
|
|
const url = emoji
|
|
|
|
? `/api/v1/pleroma/statuses/${id}/reactions/${emoji}`
|
|
|
|
: `/api/v1/pleroma/statuses/${id}/reactions`;
|
|
|
|
|
|
|
|
return api(getState).get(url).then(response => {
|
|
|
|
response.data.forEach((emojiReact: APIEntity) => {
|
|
|
|
dispatch(importFetchedAccounts(emojiReact.accounts));
|
|
|
|
});
|
|
|
|
dispatch(fetchEmojiReactsSuccess(id, response.data));
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch(fetchEmojiReactsFail(id, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2023-03-17 16:07:18 -07:00
|
|
|
const emojiReact = (status: Status, emoji: string, custom?: string) =>
|
2022-06-19 11:38:51 -07:00
|
|
|
(dispatch: AppDispatch, getState: () => RootState) => {
|
|
|
|
if (!isLoggedIn(getState)) return dispatch(noOp());
|
|
|
|
|
2023-03-17 16:07:18 -07:00
|
|
|
dispatch(emojiReactRequest(status, emoji, custom));
|
2022-06-19 11:38:51 -07:00
|
|
|
|
|
|
|
return api(getState)
|
2023-06-28 14:22:22 -07:00
|
|
|
.put(`/api/v1/pleroma/statuses/${status.id}/reactions/${emoji}`)
|
2022-06-19 11:38:51 -07:00
|
|
|
.then(function(response) {
|
|
|
|
dispatch(importFetchedStatus(response.data));
|
|
|
|
dispatch(emojiReactSuccess(status, emoji));
|
|
|
|
}).catch(function(error) {
|
|
|
|
dispatch(emojiReactFail(status, emoji, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
const unEmojiReact = (status: Status, emoji: string) =>
|
|
|
|
(dispatch: AppDispatch, getState: () => RootState) => {
|
|
|
|
if (!isLoggedIn(getState)) return dispatch(noOp());
|
|
|
|
|
|
|
|
dispatch(unEmojiReactRequest(status, emoji));
|
|
|
|
|
|
|
|
return api(getState)
|
2023-06-28 14:22:22 -07:00
|
|
|
.delete(`/api/v1/pleroma/statuses/${status.id}/reactions/${emoji}`)
|
2022-06-19 11:38:51 -07:00
|
|
|
.then(response => {
|
|
|
|
dispatch(importFetchedStatus(response.data));
|
|
|
|
dispatch(unEmojiReactSuccess(status, emoji));
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch(unEmojiReactFail(status, emoji, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
const fetchEmojiReactsRequest = (id: string, emoji: string) => ({
|
|
|
|
type: EMOJI_REACTS_FETCH_REQUEST,
|
|
|
|
id,
|
|
|
|
emoji,
|
|
|
|
});
|
|
|
|
|
|
|
|
const fetchEmojiReactsSuccess = (id: string, emojiReacts: APIEntity[]) => ({
|
|
|
|
type: EMOJI_REACTS_FETCH_SUCCESS,
|
|
|
|
id,
|
|
|
|
emojiReacts,
|
|
|
|
});
|
|
|
|
|
2023-10-23 15:22:10 -07:00
|
|
|
const fetchEmojiReactsFail = (id: string, error: unknown) => ({
|
2022-06-19 11:38:51 -07:00
|
|
|
type: EMOJI_REACTS_FETCH_FAIL,
|
|
|
|
id,
|
|
|
|
error,
|
|
|
|
});
|
|
|
|
|
2023-03-17 16:07:18 -07:00
|
|
|
const emojiReactRequest = (status: Status, emoji: string, custom?: string) => ({
|
2022-06-19 11:38:51 -07:00
|
|
|
type: EMOJI_REACT_REQUEST,
|
|
|
|
status,
|
|
|
|
emoji,
|
2023-03-17 16:07:18 -07:00
|
|
|
custom,
|
2022-06-19 11:38:51 -07:00
|
|
|
skipLoading: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
const emojiReactSuccess = (status: Status, emoji: string) => ({
|
|
|
|
type: EMOJI_REACT_SUCCESS,
|
|
|
|
status,
|
|
|
|
emoji,
|
|
|
|
skipLoading: true,
|
|
|
|
});
|
|
|
|
|
2023-10-23 15:22:10 -07:00
|
|
|
const emojiReactFail = (status: Status, emoji: string, error: unknown) => ({
|
2022-06-19 11:38:51 -07:00
|
|
|
type: EMOJI_REACT_FAIL,
|
|
|
|
status,
|
|
|
|
emoji,
|
|
|
|
error,
|
|
|
|
skipLoading: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
const unEmojiReactRequest = (status: Status, emoji: string) => ({
|
|
|
|
type: UNEMOJI_REACT_REQUEST,
|
|
|
|
status,
|
|
|
|
emoji,
|
|
|
|
skipLoading: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
const unEmojiReactSuccess = (status: Status, emoji: string) => ({
|
|
|
|
type: UNEMOJI_REACT_SUCCESS,
|
|
|
|
status,
|
|
|
|
emoji,
|
|
|
|
skipLoading: true,
|
|
|
|
});
|
|
|
|
|
2023-10-23 15:22:10 -07:00
|
|
|
const unEmojiReactFail = (status: Status, emoji: string, error: unknown) => ({
|
2022-06-19 11:38:51 -07:00
|
|
|
type: UNEMOJI_REACT_FAIL,
|
|
|
|
status,
|
|
|
|
emoji,
|
|
|
|
error,
|
|
|
|
skipLoading: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
export {
|
|
|
|
EMOJI_REACT_REQUEST,
|
|
|
|
EMOJI_REACT_SUCCESS,
|
|
|
|
EMOJI_REACT_FAIL,
|
|
|
|
UNEMOJI_REACT_REQUEST,
|
|
|
|
UNEMOJI_REACT_SUCCESS,
|
|
|
|
UNEMOJI_REACT_FAIL,
|
|
|
|
EMOJI_REACTS_FETCH_REQUEST,
|
|
|
|
EMOJI_REACTS_FETCH_SUCCESS,
|
|
|
|
EMOJI_REACTS_FETCH_FAIL,
|
|
|
|
simpleEmojiReact,
|
|
|
|
fetchEmojiReacts,
|
|
|
|
emojiReact,
|
|
|
|
unEmojiReact,
|
|
|
|
fetchEmojiReactsRequest,
|
|
|
|
fetchEmojiReactsSuccess,
|
|
|
|
fetchEmojiReactsFail,
|
|
|
|
emojiReactRequest,
|
|
|
|
emojiReactSuccess,
|
|
|
|
emojiReactFail,
|
|
|
|
unEmojiReactRequest,
|
|
|
|
unEmojiReactSuccess,
|
|
|
|
unEmojiReactFail,
|
|
|
|
};
|