2018-01-30 19:48:26 +00:00
|
|
|
import React from 'react';
|
2022-07-14 13:50:41 +00:00
|
|
|
import { Text, TouchableOpacity } from 'react-native';
|
|
|
|
import { BottomSheetFlatList } from '@gorhom/bottom-sheet';
|
|
|
|
import { FlatList as GHFlatList } from 'react-native-gesture-handler';
|
2019-01-29 19:52:56 +00:00
|
|
|
|
2022-06-06 14:17:51 +00:00
|
|
|
import shortnameToUnicode from '../../lib/methods/helpers/shortnameToUnicode';
|
2018-01-30 19:48:26 +00:00
|
|
|
import styles from './styles';
|
|
|
|
import CustomEmoji from './CustomEmoji';
|
2022-06-06 14:17:51 +00:00
|
|
|
import scrollPersistTaps from '../../lib/methods/helpers/scrollPersistTaps';
|
2022-02-17 15:27:01 +00:00
|
|
|
import { IEmoji, IEmojiCategory } from '../../definitions/IEmoji';
|
2018-01-30 19:48:26 +00:00
|
|
|
|
2022-06-24 20:51:19 +00:00
|
|
|
const MAX_EMOJI_SIZE = 50;
|
2018-01-30 19:48:26 +00:00
|
|
|
|
2021-09-13 20:41:05 +00:00
|
|
|
const renderEmoji = (emoji: IEmoji, size: number, baseUrl: string) => {
|
2022-07-14 13:50:41 +00:00
|
|
|
if (emoji?.isCustom || emoji?.name) {
|
2021-09-13 20:41:05 +00:00
|
|
|
return (
|
|
|
|
<CustomEmoji
|
|
|
|
style={[styles.customCategoryEmoji, { height: size - 16, width: size - 16 }]}
|
|
|
|
emoji={emoji}
|
|
|
|
baseUrl={baseUrl}
|
|
|
|
/>
|
|
|
|
);
|
2018-01-30 19:48:26 +00:00
|
|
|
}
|
|
|
|
return (
|
|
|
|
<Text style={[styles.categoryEmoji, { height: size, width: size, fontSize: size - 14 }]}>
|
2021-09-13 20:41:05 +00:00
|
|
|
{shortnameToUnicode(`:${emoji}:`)}
|
2018-01-30 19:48:26 +00:00
|
|
|
</Text>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2022-07-14 13:50:41 +00:00
|
|
|
const EmojiCategory = React.memo(
|
|
|
|
({ baseUrl, onEmojiSelected, emojis, width, tabsCount, isBottomSheet, ...props }: IEmojiCategory) => {
|
|
|
|
const emojiSize = width ? Math.min(width / tabsCount, MAX_EMOJI_SIZE) : MAX_EMOJI_SIZE;
|
|
|
|
const numColumns = Math.trunc(width ? width / emojiSize : tabsCount);
|
2019-11-25 20:01:17 +00:00
|
|
|
|
2022-07-14 13:50:41 +00:00
|
|
|
const FlatList = isBottomSheet ? BottomSheetFlatList : GHFlatList;
|
2019-11-25 20:01:17 +00:00
|
|
|
|
2022-07-14 13:50:41 +00:00
|
|
|
const renderItem = (emoji: IEmoji) => (
|
|
|
|
<TouchableOpacity
|
|
|
|
activeOpacity={0.7}
|
|
|
|
// @ts-ignore
|
|
|
|
key={emoji && emoji.isCustom ? emoji.content : emoji}
|
|
|
|
onPress={() => onEmojiSelected(emoji)}
|
|
|
|
testID={`reaction-picker-${emoji && emoji.isCustom ? emoji.content : emoji}`}
|
|
|
|
>
|
|
|
|
{renderEmoji(emoji, emojiSize, baseUrl)}
|
|
|
|
</TouchableOpacity>
|
|
|
|
);
|
|
|
|
|
|
|
|
if (!width) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<FlatList
|
|
|
|
// rerender FlatList in case of width changes
|
|
|
|
key={`emoji-category-${width}`}
|
|
|
|
// @ts-ignore
|
|
|
|
keyExtractor={item => (item && item.isCustom && item.content) || item}
|
|
|
|
data={emojis}
|
|
|
|
extraData={{ baseUrl, onEmojiSelected, width, ...props }}
|
|
|
|
renderItem={({ item }) => renderItem(item)}
|
|
|
|
numColumns={numColumns}
|
|
|
|
initialNumToRender={45}
|
|
|
|
removeClippedSubviews
|
|
|
|
{...scrollPersistTaps}
|
|
|
|
keyboardDismissMode={'none'}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
);
|
2019-08-07 13:51:34 +00:00
|
|
|
|
2020-06-17 17:35:58 +00:00
|
|
|
export default EmojiCategory;
|