bigbuffet-rw/app/soapbox/actions/emoji_reacts.js

180 lines
4.7 KiB
JavaScript
Raw Normal View History

2020-05-19 19:42:23 -07:00
import api from '../api';
import { importFetchedAccounts, importFetchedStatus } from './importer';
import { favourite, unfavourite } from './interactions';
2021-03-25 10:25:45 -07:00
import { isLoggedIn } from 'soapbox/utils/auth';
import { List as ImmutableList } from 'immutable';
2020-05-19 19:42:23 -07:00
export const EMOJI_REACT_REQUEST = 'EMOJI_REACT_REQUEST';
export const EMOJI_REACT_SUCCESS = 'EMOJI_REACT_SUCCESS';
export const EMOJI_REACT_FAIL = 'EMOJI_REACT_FAIL';
export const UNEMOJI_REACT_REQUEST = 'UNEMOJI_REACT_REQUEST';
export const UNEMOJI_REACT_SUCCESS = 'UNEMOJI_REACT_SUCCESS';
export const UNEMOJI_REACT_FAIL = 'UNEMOJI_REACT_FAIL';
export const EMOJI_REACTS_FETCH_REQUEST = 'EMOJI_REACTS_FETCH_REQUEST';
export const EMOJI_REACTS_FETCH_SUCCESS = 'EMOJI_REACTS_FETCH_SUCCESS';
export const EMOJI_REACTS_FETCH_FAIL = 'EMOJI_REACTS_FETCH_FAIL';
2020-05-22 16:44:24 -07:00
const noOp = () => () => new Promise(f => f());
export const simpleEmojiReact = (status, emoji) => {
return (dispatch, getState) => {
const emojiReacts = status.getIn(['pleroma', 'emoji_reactions'], ImmutableList());
if (emoji === '👍' && status.get('favourited')) return dispatch(unfavourite(status));
const undo = emojiReacts.filter(e => e.get('me') === true && e.get('name') === emoji).count() > 0;
if (undo) return dispatch(unEmojiReact(status, emoji));
return Promise.all(
emojiReacts
.filter(emojiReact => emojiReact.get('me') === true)
.map(emojiReact => dispatch(unEmojiReact(status, emojiReact.get('name')))),
status.get('favourited') && dispatch(unfavourite(status)),
).then(() => {
if (emoji === '👍') {
dispatch(favourite(status));
} else {
dispatch(emojiReact(status, emoji));
}
}).catch(err => {
console.error(err);
});
};
};
2020-05-19 19:42:23 -07:00
export function fetchEmojiReacts(id, emoji) {
return (dispatch, getState) => {
2021-03-24 09:52:12 -07:00
if (!isLoggedIn(getState)) return dispatch(noOp());
2020-05-19 19:42:23 -07:00
dispatch(fetchEmojiReactsRequest(id, emoji));
const url = emoji
? `/api/v1/pleroma/statuses/${id}/reactions/${emoji}`
: `/api/v1/pleroma/statuses/${id}/reactions`;
2020-05-22 16:44:24 -07:00
return api(getState).get(url).then(response => {
2020-05-19 19:42:23 -07:00
response.data.forEach(emojiReact => {
dispatch(importFetchedAccounts(emojiReact.accounts));
});
dispatch(fetchEmojiReactsSuccess(id, response.data));
}).catch(error => {
dispatch(fetchEmojiReactsFail(id, error));
});
};
2021-08-03 12:22:51 -07:00
}
2020-05-19 19:42:23 -07:00
export function emojiReact(status, emoji) {
return function(dispatch, getState) {
2021-03-24 09:52:12 -07:00
if (!isLoggedIn(getState)) return dispatch(noOp());
2020-05-19 19:42:23 -07:00
dispatch(emojiReactRequest(status, emoji));
2020-05-22 16:44:24 -07:00
return api(getState)
2020-05-19 19:42:23 -07:00
.put(`/api/v1/pleroma/statuses/${status.get('id')}/reactions/${emoji}`)
.then(function(response) {
dispatch(importFetchedStatus(response.data));
dispatch(emojiReactSuccess(status, emoji));
}).catch(function(error) {
dispatch(emojiReactFail(status, emoji, error));
});
};
2021-08-03 12:22:51 -07:00
}
2020-05-19 19:42:23 -07:00
export function unEmojiReact(status, emoji) {
return (dispatch, getState) => {
2021-03-24 09:52:12 -07:00
if (!isLoggedIn(getState)) return dispatch(noOp());
2020-05-19 19:42:23 -07:00
dispatch(unEmojiReactRequest(status, emoji));
2020-05-22 16:44:24 -07:00
return api(getState)
2020-05-19 19:42:23 -07:00
.delete(`/api/v1/pleroma/statuses/${status.get('id')}/reactions/${emoji}`)
.then(response => {
dispatch(importFetchedStatus(response.data));
dispatch(unEmojiReactSuccess(status, emoji));
}).catch(error => {
dispatch(unEmojiReactFail(status, emoji, error));
});
};
2021-08-03 12:22:51 -07:00
}
2020-05-19 19:42:23 -07:00
export function fetchEmojiReactsRequest(id, emoji) {
return {
type: EMOJI_REACTS_FETCH_REQUEST,
id,
emoji,
};
2021-08-03 12:22:51 -07:00
}
2020-05-19 19:42:23 -07:00
export function fetchEmojiReactsSuccess(id, emojiReacts) {
return {
type: EMOJI_REACTS_FETCH_SUCCESS,
id,
emojiReacts,
};
2021-08-03 12:22:51 -07:00
}
2020-05-19 19:42:23 -07:00
export function fetchEmojiReactsFail(id, error) {
return {
type: EMOJI_REACTS_FETCH_FAIL,
error,
};
2021-08-03 12:22:51 -07:00
}
2020-05-19 19:42:23 -07:00
export function emojiReactRequest(status, emoji) {
return {
type: EMOJI_REACT_REQUEST,
status,
emoji,
skipLoading: true,
};
2021-08-03 12:22:51 -07:00
}
2020-05-19 19:42:23 -07:00
export function emojiReactSuccess(status, emoji) {
return {
type: EMOJI_REACT_SUCCESS,
status,
emoji,
skipLoading: true,
};
2021-08-03 12:22:51 -07:00
}
2020-05-19 19:42:23 -07:00
export function emojiReactFail(status, emoji, error) {
return {
type: EMOJI_REACT_FAIL,
status,
emoji,
error,
skipLoading: true,
};
2021-08-03 12:22:51 -07:00
}
2020-05-19 19:42:23 -07:00
export function unEmojiReactRequest(status, emoji) {
return {
type: UNEMOJI_REACT_REQUEST,
status,
emoji,
skipLoading: true,
};
2021-08-03 12:22:51 -07:00
}
2020-05-19 19:42:23 -07:00
export function unEmojiReactSuccess(status, emoji) {
return {
type: UNEMOJI_REACT_SUCCESS,
status,
emoji,
skipLoading: true,
};
2021-08-03 12:22:51 -07:00
}
2020-05-19 19:42:23 -07:00
export function unEmojiReactFail(status, emoji, error) {
return {
type: UNEMOJI_REACT_FAIL,
status,
emoji,
error,
skipLoading: true,
};
2021-08-03 12:22:51 -07:00
}