cinny/src/app/organisms/emoji-board/EmojiBoardOpener.jsx

80 lines
2.1 KiB
React
Raw Normal View History

2021-08-14 06:49:29 +02:00
import React, { useEffect, useRef } from 'react';
import cons from '../../../client/state/cons';
import navigation from '../../../client/state/navigation';
import ContextMenu from '../../atoms/context-menu/ContextMenu';
import EmojiBoard from './EmojiBoard';
let requestCallback = null;
2021-08-14 06:59:28 +02:00
let isEmojiBoardVisible = false;
2021-08-14 06:49:29 +02:00
function EmojiBoardOpener() {
const openerRef = useRef(null);
function openEmojiBoard(cords, requestEmojiCallback) {
2021-08-14 06:59:28 +02:00
if (requestCallback !== null || isEmojiBoardVisible) {
2021-08-14 06:49:29 +02:00
requestCallback = null;
if (cords.detail === 0) openerRef.current.click();
return;
}
const x = typeof cords.x === 'string' ? cords.x : `${cords.x}px`;
const y = typeof cords.y === 'string' ? cords.y : `${cords.y}px`;
openerRef.current.style.left = cords.isReverse ? 'unset' : x;
openerRef.current.style.top = cords.isReverse ? 'unset' : y;
openerRef.current.style.right = cords.isReverse ? x : 'unset';
openerRef.current.style.bottom = cords.isReverse ? y : 'unset';
requestCallback = requestEmojiCallback;
openerRef.current.click();
}
function afterEmojiBoardToggle(isVisible) {
2021-08-14 06:59:28 +02:00
isEmojiBoardVisible = isVisible;
2021-08-14 06:49:29 +02:00
if (!isVisible) {
setTimeout(() => {
2021-08-14 06:59:28 +02:00
if (!isEmojiBoardVisible) requestCallback = null;
2021-08-14 06:49:29 +02:00
}, 500);
}
}
function addEmoji(emoji) {
requestCallback(emoji);
}
useEffect(() => {
navigation.on(cons.events.navigation.EMOJIBOARD_OPENED, openEmojiBoard);
return () => {
navigation.removeListener(cons.events.navigation.EMOJIBOARD_OPENED, openEmojiBoard);
};
}, []);
return (
<ContextMenu
content={(
<EmojiBoard onSelect={addEmoji} />
)}
afterToggle={afterEmojiBoardToggle}
2021-08-14 06:59:28 +02:00
render={(toggleMenu) => (
2021-08-14 06:49:29 +02:00
<input
ref={openerRef}
onClick={toggleMenu}
type="button"
style={{
width: '0',
height: '0',
position: 'absolute',
top: 0,
left: 0,
padding: 0,
border: 'none',
visibility: 'hidden',
}}
/>
)}
/>
);
}
export default EmojiBoardOpener;