2020-05-21 21:52:10 -07:00
|
|
|
import {
|
|
|
|
Map as ImmutableMap,
|
|
|
|
List as ImmutableList,
|
|
|
|
} from 'immutable';
|
2020-05-20 09:46:49 -07:00
|
|
|
|
|
|
|
// https://emojipedia.org/facebook/
|
|
|
|
export const ALLOWED_EMOJI = [
|
|
|
|
'👍',
|
2020-05-20 13:52:28 -07:00
|
|
|
'❤',
|
2020-05-20 09:46:49 -07:00
|
|
|
'😂',
|
|
|
|
'😯',
|
|
|
|
'😢',
|
|
|
|
'😡',
|
|
|
|
];
|
|
|
|
|
|
|
|
export const sortEmoji = emojiReacts => (
|
|
|
|
emojiReacts.sortBy(emojiReact => -emojiReact.get('count'))
|
|
|
|
);
|
|
|
|
|
|
|
|
export const mergeEmoji = emojiReacts => (
|
|
|
|
emojiReacts // TODO: Merge similar emoji
|
|
|
|
);
|
|
|
|
|
2020-05-22 15:45:18 -07:00
|
|
|
export const mergeEmojiFavourites = (emojiReacts, favouritesCount, favourited) => {
|
2020-05-20 09:55:30 -07:00
|
|
|
if (!favouritesCount) return emojiReacts;
|
2020-05-22 15:45:18 -07:00
|
|
|
const likeIndex = emojiReacts.findIndex(emojiReact => emojiReact.get('name') === '👍');
|
2020-05-20 09:46:49 -07:00
|
|
|
if (likeIndex > -1) {
|
|
|
|
const likeCount = emojiReacts.getIn([likeIndex, 'count']);
|
2020-05-22 15:45:18 -07:00
|
|
|
favourited = favourited || emojiReacts.getIn([likeIndex, 'me'], false);
|
|
|
|
return emojiReacts
|
|
|
|
.setIn([likeIndex, 'count'], likeCount + favouritesCount)
|
|
|
|
.setIn([likeIndex, 'me'], favourited);
|
2020-05-20 09:46:49 -07:00
|
|
|
} else {
|
2020-05-22 15:45:18 -07:00
|
|
|
return emojiReacts.push(ImmutableMap({ count: favouritesCount, me: favourited, name: '👍' }));
|
2020-05-20 09:46:49 -07:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2020-05-22 12:08:38 -07:00
|
|
|
const hasMultiReactions = (emojiReacts, account) => (
|
|
|
|
emojiReacts.filter(
|
|
|
|
e => e.get('accounts').filter(
|
|
|
|
a => a.get('id') === account.get('id')
|
|
|
|
).count() > 0
|
|
|
|
).count() > 1
|
|
|
|
);
|
|
|
|
|
|
|
|
const inAccounts = (accounts, id) => (
|
|
|
|
accounts.filter(a => a.get('id') === id).count() > 0
|
|
|
|
);
|
|
|
|
|
|
|
|
export const oneEmojiPerAccount = (emojiReacts, me) => {
|
2020-05-21 21:52:10 -07:00
|
|
|
emojiReacts = emojiReacts.reverse();
|
2020-05-22 12:08:38 -07:00
|
|
|
|
|
|
|
return emojiReacts.reduce((acc, cur, idx) => {
|
|
|
|
const accounts = cur.get('accounts', ImmutableList())
|
|
|
|
.filter(a => !hasMultiReactions(acc, a));
|
|
|
|
|
|
|
|
return acc.set(idx, cur.merge({
|
|
|
|
accounts: accounts,
|
|
|
|
count: accounts.count(),
|
2020-05-22 13:42:57 -07:00
|
|
|
me: me ? inAccounts(accounts, me) : false,
|
2020-05-22 12:08:38 -07:00
|
|
|
}));
|
|
|
|
}, emojiReacts)
|
|
|
|
.filter(e => e.get('count') > 0)
|
|
|
|
.reverse();
|
2020-05-21 21:17:11 -07:00
|
|
|
};
|
|
|
|
|
2020-05-20 09:46:49 -07:00
|
|
|
export const filterEmoji = emojiReacts => (
|
|
|
|
emojiReacts.filter(emojiReact => (
|
|
|
|
ALLOWED_EMOJI.includes(emojiReact.get('name'))
|
|
|
|
)));
|
|
|
|
|
2020-05-22 15:45:18 -07:00
|
|
|
export const reduceEmoji = (emojiReacts, favouritesCount, favourited) => (
|
2020-05-22 15:02:56 -07:00
|
|
|
filterEmoji(sortEmoji(mergeEmoji(mergeEmojiFavourites(
|
2020-05-22 15:45:18 -07:00
|
|
|
emojiReacts, favouritesCount, favourited
|
2020-05-22 15:02:56 -07:00
|
|
|
)))));
|
2020-05-21 21:17:11 -07:00
|
|
|
|
|
|
|
export const getReactForStatus = status => {
|
2020-05-22 15:45:18 -07:00
|
|
|
return reduceEmoji(
|
|
|
|
status.getIn(['pleroma', 'emoji_reactions'], ImmutableList()),
|
|
|
|
status.get('favourites_count'),
|
|
|
|
status.get('favourited')
|
|
|
|
).filter(e => e.get('me'))
|
|
|
|
.first(ImmutableMap())
|
|
|
|
.get('name');
|
2020-05-21 21:17:11 -07:00
|
|
|
};
|