2020-03-27 13:59:38 -07:00
|
|
|
import { emojiIndex } from 'emoji-mart';
|
2022-06-16 12:32:17 -07:00
|
|
|
import pick from 'lodash/pick';
|
2022-01-10 14:25:06 -08:00
|
|
|
|
2020-03-27 13:59:38 -07:00
|
|
|
import { search } from '../emoji_mart_search_light';
|
|
|
|
|
|
|
|
const trimEmojis = emoji => pick(emoji, ['id', 'unified', 'native', 'custom']);
|
|
|
|
|
|
|
|
describe('emoji_index', () => {
|
|
|
|
it('should give same result for emoji_index_light and emoji-mart', () => {
|
|
|
|
const expected = [
|
|
|
|
{
|
|
|
|
id: 'pineapple',
|
|
|
|
unified: '1f34d',
|
|
|
|
native: '🍍',
|
|
|
|
},
|
|
|
|
];
|
|
|
|
expect(search('pineapple').map(trimEmojis)).toEqual(expected);
|
|
|
|
expect(emojiIndex.search('pineapple').map(trimEmojis)).toEqual(expected);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('orders search results correctly', () => {
|
|
|
|
const expected = [
|
|
|
|
{
|
|
|
|
id: 'apple',
|
|
|
|
unified: '1f34e',
|
|
|
|
native: '🍎',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
id: 'pineapple',
|
|
|
|
unified: '1f34d',
|
|
|
|
native: '🍍',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
id: 'green_apple',
|
|
|
|
unified: '1f34f',
|
|
|
|
native: '🍏',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
id: 'iphone',
|
|
|
|
unified: '1f4f1',
|
|
|
|
native: '📱',
|
|
|
|
},
|
|
|
|
];
|
|
|
|
expect(search('apple').map(trimEmojis)).toEqual(expected);
|
|
|
|
expect(emojiIndex.search('apple').map(trimEmojis)).toEqual(expected);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('can include/exclude categories', () => {
|
|
|
|
expect(search('flag', { include: ['people'] })).toEqual([]);
|
|
|
|
expect(emojiIndex.search('flag', { include: ['people'] })).toEqual([]);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('(different behavior from emoji-mart) do not erases custom emoji if not passed again', () => {
|
|
|
|
const custom = [
|
|
|
|
{
|
2021-07-09 23:59:37 -07:00
|
|
|
id: 'mastodon',
|
|
|
|
name: 'mastodon',
|
|
|
|
short_names: ['mastodon'],
|
2020-03-27 13:59:38 -07:00
|
|
|
text: '',
|
|
|
|
emoticons: [],
|
2021-07-09 23:59:37 -07:00
|
|
|
keywords: ['mastodon'],
|
2020-03-27 13:59:38 -07:00
|
|
|
imageUrl: 'http://example.com',
|
|
|
|
custom: true,
|
|
|
|
},
|
|
|
|
];
|
|
|
|
search('', { custom });
|
|
|
|
emojiIndex.search('', { custom });
|
|
|
|
const expected = [];
|
|
|
|
const lightExpected = [
|
|
|
|
{
|
2021-07-09 23:59:37 -07:00
|
|
|
id: 'mastodon',
|
2020-03-27 13:59:38 -07:00
|
|
|
custom: true,
|
|
|
|
},
|
|
|
|
];
|
2021-07-09 23:59:37 -07:00
|
|
|
expect(search('masto').map(trimEmojis)).toEqual(lightExpected);
|
|
|
|
expect(emojiIndex.search('masto').map(trimEmojis)).toEqual(expected);
|
2020-03-27 13:59:38 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
it('(different behavior from emoji-mart) erases custom emoji if another is passed', () => {
|
|
|
|
const custom = [
|
|
|
|
{
|
2021-07-09 23:59:37 -07:00
|
|
|
id: 'mastodon',
|
|
|
|
name: 'mastodon',
|
|
|
|
short_names: ['mastodon'],
|
2020-03-27 13:59:38 -07:00
|
|
|
text: '',
|
|
|
|
emoticons: [],
|
2021-07-09 23:59:37 -07:00
|
|
|
keywords: ['mastodon'],
|
2020-03-27 13:59:38 -07:00
|
|
|
imageUrl: 'http://example.com',
|
|
|
|
custom: true,
|
|
|
|
},
|
|
|
|
];
|
|
|
|
search('', { custom });
|
|
|
|
emojiIndex.search('', { custom });
|
|
|
|
const expected = [];
|
2021-07-09 23:59:37 -07:00
|
|
|
expect(search('masto', { custom: [] }).map(trimEmojis)).toEqual(expected);
|
|
|
|
expect(emojiIndex.search('masto').map(trimEmojis)).toEqual(expected);
|
2020-03-27 13:59:38 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
it('handles custom emoji', () => {
|
|
|
|
const custom = [
|
|
|
|
{
|
2021-07-09 23:59:37 -07:00
|
|
|
id: 'mastodon',
|
|
|
|
name: 'mastodon',
|
|
|
|
short_names: ['mastodon'],
|
2020-03-27 13:59:38 -07:00
|
|
|
text: '',
|
|
|
|
emoticons: [],
|
2021-07-09 23:59:37 -07:00
|
|
|
keywords: ['mastodon'],
|
2020-03-27 13:59:38 -07:00
|
|
|
imageUrl: 'http://example.com',
|
|
|
|
custom: true,
|
|
|
|
},
|
|
|
|
];
|
|
|
|
search('', { custom });
|
|
|
|
emojiIndex.search('', { custom });
|
|
|
|
const expected = [
|
|
|
|
{
|
2021-07-09 23:59:37 -07:00
|
|
|
id: 'mastodon',
|
2020-03-27 13:59:38 -07:00
|
|
|
custom: true,
|
|
|
|
},
|
|
|
|
];
|
2021-07-09 23:59:37 -07:00
|
|
|
expect(search('masto', { custom }).map(trimEmojis)).toEqual(expected);
|
|
|
|
expect(emojiIndex.search('masto', { custom }).map(trimEmojis)).toEqual(expected);
|
2020-03-27 13:59:38 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should filter only emojis we care about, exclude pineapple', () => {
|
|
|
|
const emojisToShowFilter = emoji => emoji.unified !== '1F34D';
|
|
|
|
expect(search('apple', { emojisToShowFilter }).map((obj) => obj.id))
|
|
|
|
.not.toContain('pineapple');
|
|
|
|
expect(emojiIndex.search('apple', { emojisToShowFilter }).map((obj) => obj.id))
|
|
|
|
.not.toContain('pineapple');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('does an emoji whose unified name is irregular', () => {
|
|
|
|
const expected = [
|
|
|
|
{
|
|
|
|
'id': 'water_polo',
|
|
|
|
'unified': '1f93d',
|
|
|
|
'native': '🤽',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'id': 'man-playing-water-polo',
|
|
|
|
'unified': '1f93d-200d-2642-fe0f',
|
|
|
|
'native': '🤽♂️',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'id': 'woman-playing-water-polo',
|
|
|
|
'unified': '1f93d-200d-2640-fe0f',
|
|
|
|
'native': '🤽♀️',
|
|
|
|
},
|
|
|
|
];
|
|
|
|
expect(search('polo').map(trimEmojis)).toEqual(expected);
|
|
|
|
expect(emojiIndex.search('polo').map(trimEmojis)).toEqual(expected);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('can search for thinking_face', () => {
|
|
|
|
const expected = [
|
|
|
|
{
|
|
|
|
id: 'thinking_face',
|
|
|
|
unified: '1f914',
|
|
|
|
native: '🤔',
|
|
|
|
},
|
|
|
|
];
|
|
|
|
expect(search('thinking_fac').map(trimEmojis)).toEqual(expected);
|
|
|
|
expect(emojiIndex.search('thinking_fac').map(trimEmojis)).toEqual(expected);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('can search for woman-facepalming', () => {
|
|
|
|
const expected = [
|
|
|
|
{
|
|
|
|
id: 'woman-facepalming',
|
|
|
|
unified: '1f926-200d-2640-fe0f',
|
|
|
|
native: '🤦♀️',
|
|
|
|
},
|
|
|
|
];
|
|
|
|
expect(search('woman-facep').map(trimEmojis)).toEqual(expected);
|
|
|
|
expect(emojiIndex.search('woman-facep').map(trimEmojis)).toEqual(expected);
|
|
|
|
});
|
|
|
|
});
|