import _ from 'lodash'; import React, { useEffect, useState } from 'react'; import { defineMessages, injectIntl } from 'react-intl'; import injectWbResizeEvent from '/imports/ui/components/presentation/resize-wrapper/component'; import UserAvatar from '/imports/ui/components/user-avatar/component'; import TextInput from '/imports/ui/components/text-input/component'; import Button from '/imports/ui/components/button/component'; import { styles } from './styles'; import { PANELS, ACTIONS } from '../layout/enums'; const intlMessages = defineMessages({ waitingUsersTitle: { id: 'app.userList.guest.waitingUsersTitle', description: 'Title for the notes list', }, title: { id: 'app.userList.guest.waitingUsers', description: 'Label for the waiting users', }, optionTitle: { id: 'app.userList.guest.optionTitle', description: 'Label above the options', }, allowAllAuthenticated: { id: 'app.userList.guest.allowAllAuthenticated', description: 'Title for the waiting users', }, allowAllGuests: { id: 'app.userList.guest.allowAllGuests', description: 'Title for the waiting users', }, allowEveryone: { id: 'app.userList.guest.allowEveryone', description: 'Title for the waiting users', }, denyEveryone: { id: 'app.userList.guest.denyEveryone', description: 'Title for the waiting users', }, pendingUsers: { id: 'app.userList.guest.pendingUsers', description: 'Title for the waiting users', }, pendingGuestUsers: { id: 'app.userList.guest.pendingGuestUsers', description: 'Title for the waiting users', }, rememberChoice: { id: 'app.userList.guest.rememberChoice', description: 'Remember label for checkbox', }, emptyMessage: { id: 'app.userList.guest.emptyMessage', description: 'Empty guest lobby message label', }, inputPlaceholder: { id: 'app.userList.guest.inputPlaceholder', description: 'Placeholder to guest lobby message input', }, accept: { id: 'app.userList.guest.acceptLabel', description: 'Accept guest button label', }, deny: { id: 'app.userList.guest.denyLabel', description: 'Deny guest button label', }, }); const ALLOW_STATUS = 'ALLOW'; const DENY_STATUS = 'DENY'; const getNameInitials = (name) => { const nameInitials = name.slice(0, 2); return nameInitials.replace(/^\w/, (c) => c.toUpperCase()); }; const renderGuestUserItem = ( name, color, handleAccept, handleDeny, role, sequence, userId, avatar, intl, ) => (
{getNameInitials(name)}

{sequence} {name}

); const renderPendingUsers = (message, usersArray, action, intl) => { if (!usersArray.length) return null; return (

{message}

{usersArray.map((user, idx) => renderGuestUserItem( user.name, user.color, () => action([user], ALLOW_STATUS), () => action([user], DENY_STATUS), user.role, idx + 1, user.intId, user.avatar, intl, ))}
); }; const WaitingUsers = (props) => { const [rememberChoice, setRememberChoice] = useState(false); useEffect(() => { const { authenticatedUsers, guestUsers, layoutContextDispatch, } = props; if (!authenticatedUsers.length && !guestUsers.length) { layoutContextDispatch({ type: ACTIONS.SET_SIDEBAR_CONTENT_IS_OPEN, value: false, }); layoutContextDispatch({ type: ACTIONS.SET_SIDEBAR_CONTENT_PANEL, value: PANELS.NONE, }); } }); const { intl, authenticatedUsers, guestUsers, guestUsersCall, changeGuestPolicy, isGuestLobbyMessageEnabled, setGuestLobbyMessage, guestLobbyMessage, authenticatedGuest, layoutContextDispatch, allowRememberChoice, } = props; const onCheckBoxChange = (e) => { const { checked } = e.target; setRememberChoice(checked); }; const changePolicy = (shouldExecutePolicy, policyRule, cb) => () => { if (shouldExecutePolicy) { changeGuestPolicy(policyRule); } return cb(); }; const renderButton = (message, { key, policy, action }) => (