|
|
|
|
@ -12,11 +12,14 @@ import Overlay from 'react-overlays/Overlay';
|
|
|
|
|
|
|
|
|
|
import MoodIcon from '@/material-icons/400-20px/mood.svg?react';
|
|
|
|
|
import { IconButton } from 'mastodon/components/icon_button';
|
|
|
|
|
import emojiCompressed from 'mastodon/features/emoji/emoji_compressed';
|
|
|
|
|
import { assetHost } from 'mastodon/utils/config';
|
|
|
|
|
|
|
|
|
|
import { buildCustomEmojis, categoriesFromEmojis } from '../../emoji/emoji';
|
|
|
|
|
import { EmojiPicker as EmojiPickerAsync } from '../../ui/util/async-components';
|
|
|
|
|
|
|
|
|
|
const nimblePickerData = emojiCompressed[5];
|
|
|
|
|
|
|
|
|
|
const messages = defineMessages({
|
|
|
|
|
emoji: { id: 'emoji_button.label', defaultMessage: 'Insert emoji' },
|
|
|
|
|
emoji_search: { id: 'emoji_button.search', defaultMessage: 'Search...' },
|
|
|
|
|
@ -37,15 +40,18 @@ let EmojiPicker, Emoji; // load asynchronously
|
|
|
|
|
|
|
|
|
|
const listenerOptions = supportsPassiveEvents ? { passive: true, capture: true } : true;
|
|
|
|
|
|
|
|
|
|
const backgroundImageFn = () => `${assetHost}/emoji/sheet_13.png`;
|
|
|
|
|
const backgroundImageFn = () => `${assetHost}/emoji/sheet_15.png`;
|
|
|
|
|
|
|
|
|
|
const notFoundFn = () => (
|
|
|
|
|
<div className='emoji-mart-no-results'>
|
|
|
|
|
<Emoji
|
|
|
|
|
data={nimblePickerData}
|
|
|
|
|
emoji='sleuth_or_spy'
|
|
|
|
|
set='twitter'
|
|
|
|
|
size={32}
|
|
|
|
|
sheetSize={32}
|
|
|
|
|
sheetColumns={62}
|
|
|
|
|
sheetRows={62}
|
|
|
|
|
backgroundImageFn={backgroundImageFn}
|
|
|
|
|
/>
|
|
|
|
|
|
|
|
|
|
@ -67,7 +73,7 @@ class ModifierPickerMenu extends PureComponent {
|
|
|
|
|
this.props.onSelect(e.currentTarget.getAttribute('data-index') * 1);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
UNSAFE_componentWillReceiveProps (nextProps) {
|
|
|
|
|
UNSAFE_componentWillReceiveProps(nextProps) {
|
|
|
|
|
if (nextProps.active) {
|
|
|
|
|
this.attachListeners();
|
|
|
|
|
} else {
|
|
|
|
|
@ -75,7 +81,7 @@ class ModifierPickerMenu extends PureComponent {
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
componentWillUnmount () {
|
|
|
|
|
componentWillUnmount() {
|
|
|
|
|
this.removeListeners();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@ -85,12 +91,12 @@ class ModifierPickerMenu extends PureComponent {
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
attachListeners () {
|
|
|
|
|
attachListeners() {
|
|
|
|
|
document.addEventListener('click', this.handleDocumentClick, { capture: true });
|
|
|
|
|
document.addEventListener('touchend', this.handleDocumentClick, listenerOptions);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
removeListeners () {
|
|
|
|
|
removeListeners() {
|
|
|
|
|
document.removeEventListener('click', this.handleDocumentClick, { capture: true });
|
|
|
|
|
document.removeEventListener('touchend', this.handleDocumentClick, listenerOptions);
|
|
|
|
|
}
|
|
|
|
|
@ -99,17 +105,17 @@ class ModifierPickerMenu extends PureComponent {
|
|
|
|
|
this.node = c;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
render () {
|
|
|
|
|
render() {
|
|
|
|
|
const { active } = this.props;
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
<div className='emoji-picker-dropdown__modifiers__menu' style={{ display: active ? 'block' : 'none' }} ref={this.setRef}>
|
|
|
|
|
<button type='button' onClick={this.handleClick} data-index={1}><Emoji emoji='fist' set='twitter' size={22} sheetSize={32} skin={1} backgroundImageFn={backgroundImageFn} /></button>
|
|
|
|
|
<button type='button' onClick={this.handleClick} data-index={2}><Emoji emoji='fist' set='twitter' size={22} sheetSize={32} skin={2} backgroundImageFn={backgroundImageFn} /></button>
|
|
|
|
|
<button type='button' onClick={this.handleClick} data-index={3}><Emoji emoji='fist' set='twitter' size={22} sheetSize={32} skin={3} backgroundImageFn={backgroundImageFn} /></button>
|
|
|
|
|
<button type='button' onClick={this.handleClick} data-index={4}><Emoji emoji='fist' set='twitter' size={22} sheetSize={32} skin={4} backgroundImageFn={backgroundImageFn} /></button>
|
|
|
|
|
<button type='button' onClick={this.handleClick} data-index={5}><Emoji emoji='fist' set='twitter' size={22} sheetSize={32} skin={5} backgroundImageFn={backgroundImageFn} /></button>
|
|
|
|
|
<button type='button' onClick={this.handleClick} data-index={6}><Emoji emoji='fist' set='twitter' size={22} sheetSize={32} skin={6} backgroundImageFn={backgroundImageFn} /></button>
|
|
|
|
|
<button type='button' onClick={this.handleClick} data-index={1}><Emoji data={nimblePickerData} sheetColumns={62} sheetRows={62} emoji='fist' set='twitter' size={22} sheetSize={32} skin={1} backgroundImageFn={backgroundImageFn} /></button>
|
|
|
|
|
<button type='button' onClick={this.handleClick} data-index={2}><Emoji data={nimblePickerData} sheetColumns={62} sheetRows={62} emoji='fist' set='twitter' size={22} sheetSize={32} skin={2} backgroundImageFn={backgroundImageFn} /></button>
|
|
|
|
|
<button type='button' onClick={this.handleClick} data-index={3}><Emoji data={nimblePickerData} sheetColumns={62} sheetRows={62} emoji='fist' set='twitter' size={22} sheetSize={32} skin={3} backgroundImageFn={backgroundImageFn} /></button>
|
|
|
|
|
<button type='button' onClick={this.handleClick} data-index={4}><Emoji data={nimblePickerData} sheetColumns={62} sheetRows={62} emoji='fist' set='twitter' size={22} sheetSize={32} skin={4} backgroundImageFn={backgroundImageFn} /></button>
|
|
|
|
|
<button type='button' onClick={this.handleClick} data-index={5}><Emoji data={nimblePickerData} sheetColumns={62} sheetRows={62} emoji='fist' set='twitter' size={22} sheetSize={32} skin={5} backgroundImageFn={backgroundImageFn} /></button>
|
|
|
|
|
<button type='button' onClick={this.handleClick} data-index={6}><Emoji data={nimblePickerData} sheetColumns={62} sheetRows={62} emoji='fist' set='twitter' size={22} sheetSize={32} skin={6} backgroundImageFn={backgroundImageFn} /></button>
|
|
|
|
|
</div>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
@ -139,12 +145,12 @@ class ModifierPicker extends PureComponent {
|
|
|
|
|
this.props.onClose();
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
render () {
|
|
|
|
|
render() {
|
|
|
|
|
const { active, modifier } = this.props;
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
<div className='emoji-picker-dropdown__modifiers'>
|
|
|
|
|
<Emoji emoji='fist' set='twitter' size={22} sheetSize={32} skin={modifier} onClick={this.handleClick} backgroundImageFn={backgroundImageFn} />
|
|
|
|
|
<Emoji data={nimblePickerData} sheetColumns={62} sheetRows={62} emoji='fist' set='twitter' size={22} sheetSize={32} skin={modifier} onClick={this.handleClick} backgroundImageFn={backgroundImageFn} />
|
|
|
|
|
<ModifierPickerMenu active={active} onSelect={this.handleSelect} onClose={this.props.onClose} />
|
|
|
|
|
</div>
|
|
|
|
|
);
|
|
|
|
|
@ -184,7 +190,7 @@ class EmojiPickerMenuImpl extends PureComponent {
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
componentDidMount () {
|
|
|
|
|
componentDidMount() {
|
|
|
|
|
document.addEventListener('click', this.handleDocumentClick, { capture: true });
|
|
|
|
|
document.addEventListener('touchend', this.handleDocumentClick, listenerOptions);
|
|
|
|
|
|
|
|
|
|
@ -199,7 +205,7 @@ class EmojiPickerMenuImpl extends PureComponent {
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
componentWillUnmount () {
|
|
|
|
|
componentWillUnmount() {
|
|
|
|
|
document.removeEventListener('click', this.handleDocumentClick, { capture: true });
|
|
|
|
|
document.removeEventListener('touchend', this.handleDocumentClick, listenerOptions);
|
|
|
|
|
}
|
|
|
|
|
@ -252,7 +258,7 @@ class EmojiPickerMenuImpl extends PureComponent {
|
|
|
|
|
this.props.onSkinTone(modifier);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
render () {
|
|
|
|
|
render() {
|
|
|
|
|
const { loading, style, intl, custom_emojis, skinTone, frequentlyUsedEmojis } = this.props;
|
|
|
|
|
|
|
|
|
|
if (loading) {
|
|
|
|
|
@ -280,6 +286,9 @@ class EmojiPickerMenuImpl extends PureComponent {
|
|
|
|
|
return (
|
|
|
|
|
<div className={classNames('emoji-picker-dropdown__menu', { selecting: modifierOpen })} style={style} ref={this.setRef}>
|
|
|
|
|
<EmojiPicker
|
|
|
|
|
data={nimblePickerData}
|
|
|
|
|
sheetColumns={62}
|
|
|
|
|
sheetRows={62}
|
|
|
|
|
perLine={8}
|
|
|
|
|
emojiSize={22}
|
|
|
|
|
sheetSize={32}
|
|
|
|
|
@ -345,7 +354,7 @@ class EmojiPickerDropdown extends PureComponent {
|
|
|
|
|
|
|
|
|
|
EmojiPickerAsync().then(EmojiMart => {
|
|
|
|
|
EmojiPicker = EmojiMart.Picker;
|
|
|
|
|
Emoji = EmojiMart.Emoji;
|
|
|
|
|
Emoji = EmojiMart.Emoji;
|
|
|
|
|
|
|
|
|
|
this.setState({ loading: false });
|
|
|
|
|
}).catch(() => {
|
|
|
|
|
@ -386,7 +395,7 @@ class EmojiPickerDropdown extends PureComponent {
|
|
|
|
|
this.setState({ placement: state.placement });
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
render () {
|
|
|
|
|
render() {
|
|
|
|
|
const { intl, onPickEmoji, onSkinTone, skinTone, frequentlyUsedEmojis } = this.props;
|
|
|
|
|
const title = intl.formatMessage(messages.emoji);
|
|
|
|
|
const { active, loading, placement } = this.state;
|
|
|
|
|
@ -403,7 +412,7 @@ class EmojiPickerDropdown extends PureComponent {
|
|
|
|
|
/>
|
|
|
|
|
|
|
|
|
|
<Overlay show={active} placement={placement} flip target={this.findTarget} popperConfig={{ strategy: 'fixed', onFirstUpdate: this.handleOverlayEnter }}>
|
|
|
|
|
{({ props, placement })=> (
|
|
|
|
|
{({ props, placement }) => (
|
|
|
|
|
<div {...props} style={{ ...props.style }}>
|
|
|
|
|
<div className={`dropdown-animation ${placement}`}>
|
|
|
|
|
<EmojiPickerMenu
|
|
|
|
|
|