2022-06-04 00:22:36 -07:00
|
|
|
import { List as ImmutableList, Map as ImmutableMap, fromJS } from 'immutable';
|
|
|
|
|
|
|
|
import { normalizeStatus } from 'soapbox/normalizers';
|
2022-01-10 14:25:06 -08:00
|
|
|
|
2020-05-20 09:46:49 -07:00
|
|
|
import {
|
|
|
|
sortEmoji,
|
|
|
|
mergeEmojiFavourites,
|
2020-05-21 21:17:11 -07:00
|
|
|
oneEmojiPerAccount,
|
2020-05-20 09:46:49 -07:00
|
|
|
reduceEmoji,
|
2020-05-21 21:17:11 -07:00
|
|
|
getReactForStatus,
|
2020-05-23 18:29:25 -07:00
|
|
|
simulateEmojiReact,
|
2020-09-27 15:24:55 -07:00
|
|
|
simulateUnEmojiReact,
|
2022-11-15 12:46:23 -08:00
|
|
|
} from '../emoji-reacts';
|
2020-05-20 09:46:49 -07:00
|
|
|
|
2022-06-04 00:22:36 -07:00
|
|
|
const ALLOWED_EMOJI = ImmutableList([
|
2020-05-23 09:54:26 -07:00
|
|
|
'👍',
|
|
|
|
'❤',
|
|
|
|
'😂',
|
|
|
|
'😯',
|
|
|
|
'😢',
|
|
|
|
'😡',
|
2022-04-02 19:40:47 -07:00
|
|
|
]);
|
2020-05-23 09:54:26 -07:00
|
|
|
|
2020-05-20 09:46:49 -07:00
|
|
|
describe('sortEmoji', () => {
|
|
|
|
describe('with an unsorted list of emoji', () => {
|
|
|
|
const emojiReacts = fromJS([
|
2023-02-08 18:59:26 -08:00
|
|
|
{ 'count': 7, 'me': true, 'name': '😃' },
|
2020-05-20 09:46:49 -07:00
|
|
|
{ 'count': 7, 'me': true, 'name': '😯' },
|
|
|
|
{ 'count': 3, 'me': true, 'name': '😢' },
|
|
|
|
{ 'count': 1, 'me': true, 'name': '😡' },
|
|
|
|
{ 'count': 20, 'me': true, 'name': '👍' },
|
|
|
|
{ 'count': 7, 'me': true, 'name': '😂' },
|
2020-05-20 14:08:29 -07:00
|
|
|
{ 'count': 15, 'me': true, 'name': '❤' },
|
2022-06-04 00:22:36 -07:00
|
|
|
]) as ImmutableList<ImmutableMap<string, any>>;
|
2020-05-20 09:46:49 -07:00
|
|
|
it('sorts the emoji by count', () => {
|
2023-02-08 18:59:26 -08:00
|
|
|
expect(sortEmoji(emojiReacts, ALLOWED_EMOJI)).toEqual(fromJS([
|
2020-05-20 09:46:49 -07:00
|
|
|
{ 'count': 20, 'me': true, 'name': '👍' },
|
2020-05-20 14:08:29 -07:00
|
|
|
{ 'count': 15, 'me': true, 'name': '❤' },
|
2020-05-20 09:46:49 -07:00
|
|
|
{ 'count': 7, 'me': true, 'name': '😯' },
|
|
|
|
{ 'count': 7, 'me': true, 'name': '😂' },
|
2023-02-08 18:59:26 -08:00
|
|
|
{ 'count': 7, 'me': true, 'name': '😃' },
|
2020-05-20 09:46:49 -07:00
|
|
|
{ 'count': 3, 'me': true, 'name': '😢' },
|
|
|
|
{ 'count': 1, 'me': true, 'name': '😡' },
|
|
|
|
]));
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('mergeEmojiFavourites', () => {
|
|
|
|
const favouritesCount = 12;
|
2020-05-22 15:45:18 -07:00
|
|
|
const favourited = true;
|
2020-05-20 09:46:49 -07:00
|
|
|
|
|
|
|
describe('with existing 👍 reacts', () => {
|
|
|
|
const emojiReacts = fromJS([
|
2023-03-18 05:27:27 -07:00
|
|
|
{ 'count': 20, 'me': false, 'name': '👍', 'url': undefined },
|
|
|
|
{ 'count': 15, 'me': false, 'name': '❤', 'url': undefined },
|
|
|
|
{ 'count': 7, 'me': false, 'name': '😯', 'url': undefined },
|
2022-06-04 00:22:36 -07:00
|
|
|
]) as ImmutableList<ImmutableMap<string, any>>;
|
2020-05-20 09:46:49 -07:00
|
|
|
it('combines 👍 reacts with favourites', () => {
|
2020-05-22 15:45:18 -07:00
|
|
|
expect(mergeEmojiFavourites(emojiReacts, favouritesCount, favourited)).toEqual(fromJS([
|
2023-03-18 05:27:27 -07:00
|
|
|
{ 'count': 32, 'me': true, 'name': '👍', 'url': undefined },
|
|
|
|
{ 'count': 15, 'me': false, 'name': '❤', 'url': undefined },
|
|
|
|
{ 'count': 7, 'me': false, 'name': '😯', 'url': undefined },
|
2020-05-20 09:46:49 -07:00
|
|
|
]));
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('without existing 👍 reacts', () => {
|
|
|
|
const emojiReacts = fromJS([
|
2020-05-22 15:45:18 -07:00
|
|
|
{ 'count': 15, 'me': false, 'name': '❤' },
|
|
|
|
{ 'count': 7, 'me': false, 'name': '😯' },
|
2022-06-04 00:22:36 -07:00
|
|
|
]) as ImmutableList<ImmutableMap<string, any>>;
|
2020-05-20 09:46:49 -07:00
|
|
|
it('adds 👍 reacts to the map equaling favourite count', () => {
|
2020-05-22 15:45:18 -07:00
|
|
|
expect(mergeEmojiFavourites(emojiReacts, favouritesCount, favourited)).toEqual(fromJS([
|
|
|
|
{ 'count': 15, 'me': false, 'name': '❤' },
|
|
|
|
{ 'count': 7, 'me': false, 'name': '😯' },
|
|
|
|
{ 'count': 12, 'me': true, 'name': '👍' },
|
2020-05-20 09:46:49 -07:00
|
|
|
]));
|
|
|
|
});
|
2020-05-20 09:55:30 -07:00
|
|
|
it('does not add 👍 reacts when there are no favourites', () => {
|
2020-05-22 15:45:18 -07:00
|
|
|
expect(mergeEmojiFavourites(emojiReacts, 0, false)).toEqual(fromJS([
|
|
|
|
{ 'count': 15, 'me': false, 'name': '❤' },
|
|
|
|
{ 'count': 7, 'me': false, 'name': '😯' },
|
2020-05-20 09:55:30 -07:00
|
|
|
]));
|
|
|
|
});
|
2020-05-20 09:46:49 -07:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('reduceEmoji', () => {
|
|
|
|
describe('with a clusterfuck of emoji', () => {
|
|
|
|
const emojiReacts = fromJS([
|
2020-05-22 15:02:56 -07:00
|
|
|
{ 'count': 1, 'me': false, 'name': '😡' },
|
|
|
|
{ 'count': 1, 'me': true, 'name': '🔪' },
|
|
|
|
{ 'count': 7, 'me': true, 'name': '😯' },
|
|
|
|
{ 'count': 3, 'me': false, 'name': '😢' },
|
|
|
|
{ 'count': 1, 'me': true, 'name': '🌵' },
|
|
|
|
{ 'count': 20, 'me': true, 'name': '👍' },
|
|
|
|
{ 'count': 7, 'me': false, 'name': '😂' },
|
|
|
|
{ 'count': 15, 'me': true, 'name': '❤' },
|
|
|
|
{ 'count': 1, 'me': false, 'name': '👀' },
|
|
|
|
{ 'count': 1, 'me': false, 'name': '🍩' },
|
2022-06-04 00:22:36 -07:00
|
|
|
]) as ImmutableList<ImmutableMap<string, any>>;
|
2020-05-20 09:46:49 -07:00
|
|
|
it('sorts, filters, and combines emoji and favourites', () => {
|
2020-05-23 09:54:26 -07:00
|
|
|
expect(reduceEmoji(emojiReacts, 7, true, ALLOWED_EMOJI)).toEqual(fromJS([
|
2020-05-22 15:02:56 -07:00
|
|
|
{ 'count': 27, 'me': true, 'name': '👍' },
|
|
|
|
{ 'count': 15, 'me': true, 'name': '❤' },
|
|
|
|
{ 'count': 7, 'me': true, 'name': '😯' },
|
|
|
|
{ 'count': 7, 'me': false, 'name': '😂' },
|
|
|
|
{ 'count': 3, 'me': false, 'name': '😢' },
|
|
|
|
{ 'count': 1, 'me': false, 'name': '😡' },
|
2023-02-08 18:59:26 -08:00
|
|
|
{ 'count': 1, 'me': true, 'name': '🔪' },
|
|
|
|
{ 'count': 1, 'me': true, 'name': '🌵' },
|
|
|
|
{ 'count': 1, 'me': false, 'name': '👀' },
|
|
|
|
{ 'count': 1, 'me': false, 'name': '🍩' },
|
2020-05-20 09:46:49 -07:00
|
|
|
]));
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2020-05-21 21:17:11 -07:00
|
|
|
|
|
|
|
describe('oneEmojiPerAccount', () => {
|
|
|
|
it('reduces to one react per account', () => {
|
|
|
|
const emojiReacts = fromJS([
|
|
|
|
// Sorted
|
2020-05-21 21:52:10 -07:00
|
|
|
{ 'count': 2, 'me': true, 'name': '👍', accounts: [{ id: '1' }, { id: '2' }] },
|
|
|
|
{ 'count': 2, 'me': true, 'name': '❤', accounts: [{ id: '1' }, { id: '2' }] },
|
2020-05-22 12:08:38 -07:00
|
|
|
{ 'count': 1, 'me': true, 'name': '😯', accounts: [{ id: '1' }] },
|
|
|
|
{ 'count': 1, 'me': false, 'name': '😂', accounts: [{ id: '3' }] },
|
2022-06-04 00:22:36 -07:00
|
|
|
]) as ImmutableList<ImmutableMap<string, any>>;
|
2020-05-22 12:08:38 -07:00
|
|
|
expect(oneEmojiPerAccount(emojiReacts, '1')).toEqual(fromJS([
|
2020-05-21 21:52:10 -07:00
|
|
|
{ 'count': 2, 'me': true, 'name': '👍', accounts: [{ id: '1' }, { id: '2' }] },
|
2020-05-22 12:08:38 -07:00
|
|
|
{ 'count': 1, 'me': false, 'name': '😂', accounts: [{ id: '3' }] },
|
2020-05-21 21:17:11 -07:00
|
|
|
]));
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('getReactForStatus', () => {
|
|
|
|
it('returns a single owned react (including favourite) for the status', () => {
|
2022-06-04 00:22:36 -07:00
|
|
|
const status = normalizeStatus(fromJS({
|
2020-05-21 21:17:11 -07:00
|
|
|
favourited: false,
|
|
|
|
pleroma: {
|
|
|
|
emoji_reactions: [
|
|
|
|
{ 'count': 20, 'me': false, 'name': '👍' },
|
|
|
|
{ 'count': 15, 'me': true, 'name': '❤' },
|
|
|
|
{ 'count': 7, 'me': true, 'name': '😯' },
|
|
|
|
{ 'count': 7, 'me': false, 'name': '😂' },
|
|
|
|
],
|
|
|
|
},
|
2022-06-04 00:22:36 -07:00
|
|
|
}));
|
2023-03-18 05:27:27 -07:00
|
|
|
expect(getReactForStatus(status, ALLOWED_EMOJI)?.get('name')).toEqual('❤');
|
2020-05-21 21:17:11 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
it('returns a thumbs-up for a favourite', () => {
|
2022-06-04 00:22:36 -07:00
|
|
|
const status = normalizeStatus(fromJS({ favourites_count: 1, favourited: true }));
|
2023-03-18 05:27:27 -07:00
|
|
|
expect(getReactForStatus(status)?.get('name')).toEqual('👍');
|
2020-05-21 21:17:11 -07:00
|
|
|
});
|
2020-05-22 16:44:24 -07:00
|
|
|
|
|
|
|
it('returns undefined when a status has no reacts (or favourites)', () => {
|
2022-06-04 00:22:36 -07:00
|
|
|
const status = normalizeStatus(fromJS({}));
|
2020-05-22 16:44:24 -07:00
|
|
|
expect(getReactForStatus(status)).toEqual(undefined);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('returns undefined when a status has no valid reacts (or favourites)', () => {
|
2022-06-04 00:22:36 -07:00
|
|
|
const status = normalizeStatus(fromJS([
|
2020-05-22 16:44:24 -07:00
|
|
|
{ 'count': 1, 'me': true, 'name': '🔪' },
|
|
|
|
{ 'count': 1, 'me': true, 'name': '🌵' },
|
|
|
|
{ 'count': 1, 'me': false, 'name': '👀' },
|
|
|
|
{ 'count': 1, 'me': false, 'name': '🍩' },
|
2022-06-04 00:22:36 -07:00
|
|
|
]));
|
2020-05-22 16:44:24 -07:00
|
|
|
expect(getReactForStatus(status)).toEqual(undefined);
|
|
|
|
});
|
2020-05-21 21:17:11 -07:00
|
|
|
});
|
2020-05-23 18:29:25 -07:00
|
|
|
|
|
|
|
describe('simulateEmojiReact', () => {
|
|
|
|
it('adds the emoji to the list', () => {
|
|
|
|
const emojiReacts = fromJS([
|
2023-03-18 05:27:27 -07:00
|
|
|
{ 'count': 2, 'me': false, 'name': '👍', 'url': undefined },
|
|
|
|
{ 'count': 2, 'me': false, 'name': '❤', 'url': undefined },
|
2022-06-04 00:22:36 -07:00
|
|
|
]) as ImmutableList<ImmutableMap<string, any>>;
|
2020-05-23 18:29:25 -07:00
|
|
|
expect(simulateEmojiReact(emojiReacts, '❤')).toEqual(fromJS([
|
2023-03-18 05:27:27 -07:00
|
|
|
{ 'count': 2, 'me': false, 'name': '👍', 'url': undefined },
|
|
|
|
{ 'count': 3, 'me': true, 'name': '❤', 'url': undefined },
|
2020-05-23 18:29:25 -07:00
|
|
|
]));
|
|
|
|
});
|
|
|
|
|
|
|
|
it('creates the emoji if it didn\'t already exist', () => {
|
|
|
|
const emojiReacts = fromJS([
|
2023-03-18 05:27:27 -07:00
|
|
|
{ 'count': 2, 'me': false, 'name': '👍', 'url': undefined },
|
|
|
|
{ 'count': 2, 'me': false, 'name': '❤', 'url': undefined },
|
2022-06-04 00:22:36 -07:00
|
|
|
]) as ImmutableList<ImmutableMap<string, any>>;
|
2020-05-23 18:29:25 -07:00
|
|
|
expect(simulateEmojiReact(emojiReacts, '😯')).toEqual(fromJS([
|
2023-03-18 05:27:27 -07:00
|
|
|
{ 'count': 2, 'me': false, 'name': '👍', 'url': undefined },
|
|
|
|
{ 'count': 2, 'me': false, 'name': '❤', 'url': undefined },
|
|
|
|
{ 'count': 1, 'me': true, 'name': '😯', 'url': undefined },
|
2020-05-23 18:29:25 -07:00
|
|
|
]));
|
|
|
|
});
|
2023-03-18 12:49:13 -07:00
|
|
|
|
|
|
|
it('adds a custom emoji to the list', () => {
|
|
|
|
const emojiReacts = fromJS([
|
|
|
|
{ 'count': 2, 'me': false, 'name': '👍', 'url': undefined },
|
|
|
|
{ 'count': 2, 'me': false, 'name': '❤', 'url': undefined },
|
|
|
|
]) as ImmutableList<ImmutableMap<string, any>>;
|
|
|
|
expect(simulateEmojiReact(emojiReacts, 'soapbox', 'https://gleasonator.com/emoji/Gleasonator/soapbox.png')).toEqual(fromJS([
|
|
|
|
{ 'count': 2, 'me': false, 'name': '👍', 'url': undefined },
|
|
|
|
{ 'count': 2, 'me': false, 'name': '❤', 'url': undefined },
|
|
|
|
{ 'count': 1, 'me': true, 'name': 'soapbox', 'url': 'https://gleasonator.com/emoji/Gleasonator/soapbox.png' },
|
|
|
|
]));
|
|
|
|
});
|
2020-05-23 18:29:25 -07:00
|
|
|
});
|
2020-09-27 15:24:55 -07:00
|
|
|
|
|
|
|
describe('simulateUnEmojiReact', () => {
|
|
|
|
it('removes the emoji from the list', () => {
|
|
|
|
const emojiReacts = fromJS([
|
|
|
|
{ 'count': 2, 'me': false, 'name': '👍' },
|
|
|
|
{ 'count': 3, 'me': true, 'name': '❤' },
|
2022-06-04 00:22:36 -07:00
|
|
|
]) as ImmutableList<ImmutableMap<string, any>>;
|
2020-09-27 15:24:55 -07:00
|
|
|
expect(simulateUnEmojiReact(emojiReacts, '❤')).toEqual(fromJS([
|
|
|
|
{ 'count': 2, 'me': false, 'name': '👍' },
|
|
|
|
{ 'count': 2, 'me': false, 'name': '❤' },
|
|
|
|
]));
|
|
|
|
});
|
|
|
|
|
|
|
|
it('removes the emoji if it\'s the last one in the list', () => {
|
|
|
|
const emojiReacts = fromJS([
|
|
|
|
{ 'count': 2, 'me': false, 'name': '👍' },
|
|
|
|
{ 'count': 2, 'me': false, 'name': '❤' },
|
|
|
|
{ 'count': 1, 'me': true, 'name': '😯' },
|
2022-06-04 00:22:36 -07:00
|
|
|
]) as ImmutableList<ImmutableMap<string, any>>;
|
2020-09-27 15:24:55 -07:00
|
|
|
expect(simulateUnEmojiReact(emojiReacts, '😯')).toEqual(fromJS([
|
|
|
|
{ 'count': 2, 'me': false, 'name': '👍' },
|
|
|
|
{ 'count': 2, 'me': false, 'name': '❤' },
|
|
|
|
]));
|
|
|
|
});
|
2023-03-18 12:49:13 -07:00
|
|
|
|
|
|
|
it ('removes custom emoji from the list', () => {
|
|
|
|
const emojiReacts = fromJS([
|
|
|
|
{ 'count': 2, 'me': false, 'name': '👍' },
|
|
|
|
{ 'count': 2, 'me': false, 'name': '❤' },
|
|
|
|
{ 'count': 1, 'me': true, 'name': 'soapbox', 'url': 'https://gleasonator.com/emoji/Gleasonator/soapbox.png' },
|
|
|
|
]) as ImmutableList<ImmutableMap<string, any>>;
|
|
|
|
expect(simulateUnEmojiReact(emojiReacts, 'soapbox')).toEqual(fromJS([
|
|
|
|
{ 'count': 2, 'me': false, 'name': '👍' },
|
|
|
|
{ 'count': 2, 'me': false, 'name': '❤' },
|
|
|
|
]));
|
|
|
|
});
|
2020-09-27 15:24:55 -07:00
|
|
|
});
|