// import classNames from 'classnames'; import React from 'react'; import { HotKeys } from 'react-hotkeys'; import ImmutablePureComponent from 'react-immutable-pure-component'; import { connect } from 'react-redux'; import { getSoapboxConfig } from 'soapbox/actions/soapbox'; import { EmojiSelector as RealEmojiSelector } from 'soapbox/components/ui'; import type { List as ImmutableList } from 'immutable'; import type { RootState } from 'soapbox/store'; const mapStateToProps = (state: RootState) => ({ allowedEmoji: getSoapboxConfig(state).allowedEmoji, }); interface IEmojiSelector { allowedEmoji: ImmutableList, onReact: (emoji: string) => void, onUnfocus: () => void, visible: boolean, focused?: boolean, } class EmojiSelector extends ImmutablePureComponent { static defaultProps: Partial = { onReact: () => { }, onUnfocus: () => { }, visible: false, } node?: HTMLDivElement = undefined; handleBlur: React.FocusEventHandler = e => { const { focused, onUnfocus } = this.props; if (focused && (!e.currentTarget || !e.currentTarget.classList.contains('emoji-react-selector__emoji'))) { onUnfocus(); } } _selectPreviousEmoji = (i: number): void => { if (!this.node) return; if (i !== 0) { const button: HTMLButtonElement | null = this.node.querySelector(`.emoji-react-selector__emoji:nth-child(${i})`); button?.focus(); } else { const button: HTMLButtonElement | null = this.node.querySelector('.emoji-react-selector__emoji:last-child'); button?.focus(); } }; _selectNextEmoji = (i: number) => { if (!this.node) return; if (i !== this.props.allowedEmoji.size - 1) { const button: HTMLButtonElement | null = this.node.querySelector(`.emoji-react-selector__emoji:nth-child(${i + 2})`); button?.focus(); } else { const button: HTMLButtonElement | null = this.node.querySelector('.emoji-react-selector__emoji:first-child'); button?.focus(); } }; handleKeyDown = (i: number): React.KeyboardEventHandler => e => { const { onUnfocus } = this.props; switch (e.key) { case 'Tab': e.preventDefault(); if (e.shiftKey) this._selectPreviousEmoji(i); else this._selectNextEmoji(i); break; case 'Left': case 'ArrowLeft': this._selectPreviousEmoji(i); break; case 'Right': case 'ArrowRight': this._selectNextEmoji(i); break; case 'Escape': onUnfocus(); break; } } handleReact = (emoji: string) => (): void => { const { onReact, focused, onUnfocus } = this.props; onReact(emoji); if (focused) { onUnfocus(); } } handlers = { open: () => { }, }; setRef = (c: HTMLDivElement): void => { this.node = c; } render() { const { visible, focused, allowedEmoji, onReact } = this.props; return ( {/*
{allowedEmoji.map((emoji, i) => ( ))}
*/}
); } } export default connect(mapStateToProps)(EmojiSelector);