/* eslint-disable @typescript-eslint/ban-ts-comment */ import React, { useEffect } from 'react'; import { PopupContainer, PopupContents } from './styles'; import { GET_WELCOME_MESSAGE, WelcomeMsgsResponse } from './queries'; import { useQuery } from '@apollo/client'; import PopupContent from './popup-content/component'; import { layoutSelect } from '../../../layout/context'; import { Layout } from '../../../layout/layoutTypes'; import { ChatCommands } from '/imports/ui/core/enums/chat'; interface ChatPopupProps { welcomeMessage: string | null; welcomeMsgForModerators: string | null; } const WELCOME_MSG_KEY = 'welcomeMsg'; const WELCOME_MSG_FOR_MODERATORS_KEY = 'welcomeMsgForModerators'; // @ts-ignore - temporary, while meteor exists in the project const CHAT_CONFIG = window.meetingClientSettings.public.chat; const PUBLIC_GROUP_CHAT_KEY = CHAT_CONFIG.public_group_id; const setWelcomeMsgsOnSession = (key: string, value: boolean) => { sessionStorage.setItem(key, String(value)); }; const isBoolean = (v: unknown): boolean => { if (v === 'true') { return true; } if (v === 'false') { return false; } // if v is not defined it shouldn't be considered on comparison, so it returns true return true; }; const ChatPopup: React.FC = ({ welcomeMessage, welcomeMsgForModerators, }) => { const [showWelcomeMessage, setShowWelcomeMessage] = React.useState( welcomeMessage && isBoolean(sessionStorage.getItem(WELCOME_MSG_KEY)), ); const [showWelcomeMessageForModerators, setShowWelcomeMessageForModerators] = React.useState( welcomeMsgForModerators && isBoolean(sessionStorage.getItem(WELCOME_MSG_FOR_MODERATORS_KEY)), ); useEffect(() => { const eventCallback = () => { if (welcomeMessage) { setShowWelcomeMessage(true); setWelcomeMsgsOnSession(WELCOME_MSG_KEY, true); } if (welcomeMsgForModerators) { setShowWelcomeMessageForModerators(true); setWelcomeMsgsOnSession(WELCOME_MSG_FOR_MODERATORS_KEY, true); } }; window.addEventListener(ChatCommands.RESTORE_WELCOME_MESSAGES, eventCallback); return () => { // eslint-disable-next-line no-restricted-globals removeEventListener(ChatCommands.RESTORE_WELCOME_MESSAGES, eventCallback); }; }, []); if (!showWelcomeMessage && !showWelcomeMessageForModerators) return null; return ( {showWelcomeMessage && welcomeMessage && ( { setShowWelcomeMessage(false); setWelcomeMsgsOnSession(WELCOME_MSG_KEY, false); }} /> )} {showWelcomeMessageForModerators && welcomeMsgForModerators && ( { setShowWelcomeMessageForModerators(false); setWelcomeMsgsOnSession(WELCOME_MSG_FOR_MODERATORS_KEY, false); }} /> )} ); }; const ChatPopupContainer: React.FC = () => { const { data: welcomeData, loading: welcomeLoading, error: welcomeError, } = useQuery(GET_WELCOME_MESSAGE); const idChatOpen = layoutSelect((i: Layout) => i.idChatOpen); if (idChatOpen !== PUBLIC_GROUP_CHAT_KEY) return null; if (welcomeLoading) return null; if (welcomeError) return
{JSON.stringify(welcomeError)}
; if (!welcomeData) return null; return ( ); }; export default ChatPopupContainer;