// @flow
// $FlowFixMe
import { Global } from '@emotion/react';
import { Menu, MenuButton, MenuList, MenuItem } from '@reach/menu-button';
import { useHistory } from 'react-router-dom';
import usePersistedState from 'effects/use-persisted-state';
import * as ICONS from 'constants/icons';
import Icon from 'component/common/icon';
import React from 'react';
type Props = {
isPopoutWindow?: boolean,
superchatsHidden?: boolean,
noSuperchats?: boolean,
isMobile?: boolean,
hideChat?: () => void,
setPopoutWindow?: (any) => void,
toggleSuperchats?: () => void,
};
export default function LivestreamMenu(props: Props) {
const {
isPopoutWindow,
superchatsHidden,
noSuperchats,
isMobile,
hideChat,
setPopoutWindow,
toggleSuperchats,
} = props;
const {
location: { pathname },
} = useHistory();
const initialPopoutUnload = React.useRef(false);
const [showTimestamps, setShowTimestamps] = usePersistedState('live-timestamps', false);
function handlePopout() {
if (setPopoutWindow) {
const popoutWindow = window.open('/$/popout' + pathname, 'Popout Chat', 'height=700,width=400');
// Adds function to popoutWindow when unloaded and verify if it was closed
const handleUnload = (e) => {
if (!initialPopoutUnload.current) {
initialPopoutUnload.current = true;
} else {
const timer = setInterval((a, b) => {
if (popoutWindow.closed) {
clearInterval(timer);
setPopoutWindow(undefined);
}
}, 300);
}
};
popoutWindow.onunload = handleUnload;
if (window.focus) popoutWindow.focus();
setPopoutWindow(popoutWindow);
}
}
return (
<>