import classNames from 'classnames'; import React, { useState, useRef } from 'react'; import { usePopper } from 'react-popper'; import { useDispatch } from 'react-redux'; import { simpleEmojiReact } from 'soapbox/actions/emoji_reacts'; import { openModal } from 'soapbox/actions/modals'; import EmojiSelector from 'soapbox/components/ui/emoji-selector/emoji-selector'; import { useAppSelector, useOwnAccount, useSoapboxConfig } from 'soapbox/hooks'; import { isUserTouching } from 'soapbox/is_mobile'; import { getReactForStatus } from 'soapbox/utils/emoji_reacts'; interface IEmojiButtonWrapper { statusId: string, children: JSX.Element, } /** Provides emoji reaction functionality to the underlying button component */ const EmojiButtonWrapper: React.FC = ({ statusId, children }): JSX.Element | null => { const dispatch = useDispatch(); const ownAccount = useOwnAccount(); const status = useAppSelector(state => state.statuses.get(statusId)); const soapboxConfig = useSoapboxConfig(); const [visible, setVisible] = useState(false); // const [focused, setFocused] = useState(false); const ref = useRef(null); const popperRef = useRef(null); const { styles, attributes } = usePopper(ref.current, popperRef.current, { placement: 'top-start', strategy: 'fixed', modifiers: [ { name: 'offset', options: { offset: [-10, 0], }, }, ], }); if (!status) return null; const handleMouseEnter = () => { setVisible(true); }; const handleMouseLeave = () => { setVisible(false); }; const handleReact = (emoji: string): void => { if (ownAccount) { dispatch(simpleEmojiReact(status, emoji)); } else { dispatch(openModal('UNAUTHORIZED', { action: 'FAVOURITE', ap_id: status.url, })); } setVisible(false); }; const handleClick: React.EventHandler = e => { const meEmojiReact = getReactForStatus(status, soapboxConfig.allowedEmoji) || '👍'; if (isUserTouching()) { if (visible) { handleReact(meEmojiReact); } else { setVisible(true); } } else { handleReact(meEmojiReact); } e.stopPropagation(); }; // const handleUnfocus: React.EventHandler = () => { // setFocused(false); // }; const selector = (
); return (
{React.cloneElement(children, { onClick: handleClick, ref, })} {selector}
); }; export default EmojiButtonWrapper;