Move room locking to its own icon.
parent
ce76a28e0e
commit
5604ba20bb
|
|
@ -11,15 +11,17 @@ import PropTypes from 'prop-types';
|
||||||
import Dialog from '@material-ui/core/Dialog';
|
import Dialog from '@material-ui/core/Dialog';
|
||||||
import DialogTitle from '@material-ui/core/DialogTitle';
|
import DialogTitle from '@material-ui/core/DialogTitle';
|
||||||
import DialogActions from '@material-ui/core/DialogActions';
|
import DialogActions from '@material-ui/core/DialogActions';
|
||||||
|
import DialogContent from '@material-ui/core/DialogContent';
|
||||||
|
import DialogContentText from '@material-ui/core/DialogContentText';
|
||||||
import Button from '@material-ui/core/Button';
|
import Button from '@material-ui/core/Button';
|
||||||
import FormLabel from '@material-ui/core/FormLabel';
|
// import FormLabel from '@material-ui/core/FormLabel';
|
||||||
import FormControl from '@material-ui/core/FormControl';
|
// import FormControl from '@material-ui/core/FormControl';
|
||||||
import FormGroup from '@material-ui/core/FormGroup';
|
// import FormGroup from '@material-ui/core/FormGroup';
|
||||||
import FormControlLabel from '@material-ui/core/FormControlLabel';
|
// import FormControlLabel from '@material-ui/core/FormControlLabel';
|
||||||
// import Checkbox from '@material-ui/core/Checkbox';
|
// import Checkbox from '@material-ui/core/Checkbox';
|
||||||
// import InputLabel from '@material-ui/core/InputLabel';
|
// import InputLabel from '@material-ui/core/InputLabel';
|
||||||
// import OutlinedInput from '@material-ui/core/OutlinedInput';
|
// import OutlinedInput from '@material-ui/core/OutlinedInput';
|
||||||
import Switch from '@material-ui/core/Switch';
|
// import Switch from '@material-ui/core/Switch';
|
||||||
import List from '@material-ui/core/List';
|
import List from '@material-ui/core/List';
|
||||||
import ListSubheader from '@material-ui/core/ListSubheader';
|
import ListSubheader from '@material-ui/core/ListSubheader';
|
||||||
import ListLobbyPeer from './ListLobbyPeer';
|
import ListLobbyPeer from './ListLobbyPeer';
|
||||||
|
|
@ -56,7 +58,7 @@ const styles = (theme) =>
|
||||||
});
|
});
|
||||||
|
|
||||||
const LockDialog = ({
|
const LockDialog = ({
|
||||||
roomClient,
|
// roomClient,
|
||||||
room,
|
room,
|
||||||
handleCloseLockDialog,
|
handleCloseLockDialog,
|
||||||
// handleAccessCode,
|
// handleAccessCode,
|
||||||
|
|
@ -73,73 +75,78 @@ const LockDialog = ({
|
||||||
paper : classes.dialogPaper
|
paper : classes.dialogPaper
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
<DialogTitle id='form-dialog-title'>Room access control</DialogTitle>
|
<DialogTitle id='form-dialog-title'>Lobby administration</DialogTitle>
|
||||||
<form className={classes.lock} autoComplete='off'>
|
{/*
|
||||||
<FormControl component='fieldset' className={classes.formControl}>
|
<FormControl component='fieldset' className={classes.formControl}>
|
||||||
<FormLabel component='legend'>Room lock</FormLabel>
|
<FormLabel component='legend'>Room lock</FormLabel>
|
||||||
<FormGroup>
|
<FormGroup>
|
||||||
<FormControlLabel
|
<FormControlLabel
|
||||||
control={
|
control={
|
||||||
<Switch checked={room.locked} onChange={() =>
|
<Switch checked={room.locked} onChange={() =>
|
||||||
{
|
|
||||||
if (room.locked)
|
|
||||||
{
|
|
||||||
roomClient.unlockRoom();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
roomClient.lockRoom();
|
|
||||||
}
|
|
||||||
}}
|
|
||||||
/>}
|
|
||||||
label='Lock'
|
|
||||||
/>
|
|
||||||
{/* TODO: access code
|
|
||||||
<FormControlLabel disabled={ room.locked ? false : true }
|
|
||||||
control={
|
|
||||||
<Checkbox checked={room.joinByAccessCode}
|
|
||||||
onChange={
|
|
||||||
(event) => roomClient.setJoinByAccessCode(event.target.checked)
|
|
||||||
}
|
|
||||||
/>}
|
|
||||||
label='Join by Access code'
|
|
||||||
/>
|
|
||||||
<InputLabel htmlFor='access-code-input' />
|
|
||||||
<OutlinedInput
|
|
||||||
disabled={ room.locked ? false : true }
|
|
||||||
id='acces-code-input'
|
|
||||||
label='Access code'
|
|
||||||
labelWidth={0}
|
|
||||||
variant='outlined'
|
|
||||||
value={room.accessCode}
|
|
||||||
onChange={(event) => handleAccessCode(event.target.value)}
|
|
||||||
>
|
|
||||||
</OutlinedInput>
|
|
||||||
<Button onClick={() => roomClient.setAccessCode(room.accessCode)} color='primary'>
|
|
||||||
save
|
|
||||||
</Button>
|
|
||||||
*/}
|
|
||||||
</FormGroup>
|
|
||||||
</FormControl>
|
|
||||||
|
|
||||||
{ (lobbyPeers.length > 0) &&
|
|
||||||
<List
|
|
||||||
dense={true}
|
|
||||||
subheader={
|
|
||||||
<ListSubheader component='div'>
|
|
||||||
Participants in Lobby
|
|
||||||
</ListSubheader>
|
|
||||||
}
|
|
||||||
>
|
|
||||||
{
|
|
||||||
lobbyPeers.map((peerId) =>
|
|
||||||
{
|
{
|
||||||
return (<ListLobbyPeer key={peerId} id={peerId} />);
|
if (room.locked)
|
||||||
})
|
{
|
||||||
}
|
roomClient.unlockRoom();
|
||||||
</List>
|
}
|
||||||
}
|
else
|
||||||
</form>
|
{
|
||||||
|
roomClient.lockRoom();
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
/>}
|
||||||
|
label='Lock'
|
||||||
|
/>
|
||||||
|
TODO: access code
|
||||||
|
<FormControlLabel disabled={ room.locked ? false : true }
|
||||||
|
control={
|
||||||
|
<Checkbox checked={room.joinByAccessCode}
|
||||||
|
onChange={
|
||||||
|
(event) => roomClient.setJoinByAccessCode(event.target.checked)
|
||||||
|
}
|
||||||
|
/>}
|
||||||
|
label='Join by Access code'
|
||||||
|
/>
|
||||||
|
<InputLabel htmlFor='access-code-input' />
|
||||||
|
<OutlinedInput
|
||||||
|
disabled={ room.locked ? false : true }
|
||||||
|
id='acces-code-input'
|
||||||
|
label='Access code'
|
||||||
|
labelWidth={0}
|
||||||
|
variant='outlined'
|
||||||
|
value={room.accessCode}
|
||||||
|
onChange={(event) => handleAccessCode(event.target.value)}
|
||||||
|
>
|
||||||
|
</OutlinedInput>
|
||||||
|
<Button onClick={() => roomClient.setAccessCode(room.accessCode)} color='primary'>
|
||||||
|
save
|
||||||
|
</Button>
|
||||||
|
|
||||||
|
</FormGroup>
|
||||||
|
</FormControl>
|
||||||
|
*/}
|
||||||
|
{ lobbyPeers.length > 0 ?
|
||||||
|
<List
|
||||||
|
dense
|
||||||
|
subheader={
|
||||||
|
<ListSubheader component='div'>
|
||||||
|
Participants in Lobby
|
||||||
|
</ListSubheader>
|
||||||
|
}
|
||||||
|
>
|
||||||
|
{
|
||||||
|
lobbyPeers.map((peerId) =>
|
||||||
|
{
|
||||||
|
return (<ListLobbyPeer key={peerId} id={peerId} />);
|
||||||
|
})
|
||||||
|
}
|
||||||
|
</List>
|
||||||
|
:
|
||||||
|
<DialogContent>
|
||||||
|
<DialogContentText gutterBottom>
|
||||||
|
There are currently no one in the lobby.
|
||||||
|
</DialogContentText>
|
||||||
|
</DialogContent>
|
||||||
|
}
|
||||||
<DialogActions>
|
<DialogActions>
|
||||||
<Button onClick={() => handleCloseLockDialog({ lockDialogOpen: false })} color='primary'>
|
<Button onClick={() => handleCloseLockDialog({ lockDialogOpen: false })} color='primary'>
|
||||||
Close
|
Close
|
||||||
|
|
@ -151,7 +158,7 @@ const LockDialog = ({
|
||||||
|
|
||||||
LockDialog.propTypes =
|
LockDialog.propTypes =
|
||||||
{
|
{
|
||||||
roomClient : PropTypes.any.isRequired,
|
// roomClient : PropTypes.any.isRequired,
|
||||||
room : appPropTypes.Room.isRequired,
|
room : appPropTypes.Room.isRequired,
|
||||||
handleCloseLockDialog : PropTypes.func.isRequired,
|
handleCloseLockDialog : PropTypes.func.isRequired,
|
||||||
handleAccessCode : PropTypes.func.isRequired,
|
handleAccessCode : PropTypes.func.isRequired,
|
||||||
|
|
|
||||||
|
|
@ -325,18 +325,46 @@ class Room extends React.PureComponent
|
||||||
</Typography>
|
</Typography>
|
||||||
<div className={classes.grow} />
|
<div className={classes.grow} />
|
||||||
<div className={classes.actionButtons}>
|
<div className={classes.actionButtons}>
|
||||||
<IconButton
|
<Tooltip title={`${room.locked ? 'Unlock' : 'Lock'} room`}>
|
||||||
aria-label='Lock'
|
<IconButton
|
||||||
color='inherit'
|
aria-label='Lock room'
|
||||||
onClick={() => setLockDialogOpen(!room.lockDialogOpen)}
|
className={classes.actionButton}
|
||||||
>
|
color='inherit'
|
||||||
<PulsingBadge
|
onClick={() =>
|
||||||
color='secondary'
|
{
|
||||||
badgeContent={lobbyPeers.length}
|
if (room.locked)
|
||||||
|
{
|
||||||
|
roomClient.unlockRoom();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
roomClient.lockRoom();
|
||||||
|
}
|
||||||
|
}}
|
||||||
>
|
>
|
||||||
<SecurityIcon />
|
{ room.locked ?
|
||||||
</PulsingBadge>
|
<LockIcon />
|
||||||
</IconButton>
|
:
|
||||||
|
<LockOpenIcon />
|
||||||
|
}
|
||||||
|
</IconButton>
|
||||||
|
</Tooltip>
|
||||||
|
{ lobbyPeers.length > 0 &&
|
||||||
|
<Tooltip title='Show lobby'>
|
||||||
|
<IconButton
|
||||||
|
aria-label='Lobby'
|
||||||
|
color='inherit'
|
||||||
|
onClick={() => setLockDialogOpen(!room.lockDialogOpen)}
|
||||||
|
>
|
||||||
|
<PulsingBadge
|
||||||
|
color='secondary'
|
||||||
|
badgeContent={lobbyPeers.length}
|
||||||
|
>
|
||||||
|
<SecurityIcon />
|
||||||
|
</PulsingBadge>
|
||||||
|
</IconButton>
|
||||||
|
</Tooltip>
|
||||||
|
}
|
||||||
{ this.fullscreen.fullscreenEnabled &&
|
{ this.fullscreen.fullscreenEnabled &&
|
||||||
<IconButton
|
<IconButton
|
||||||
aria-label='Fullscreen'
|
aria-label='Fullscreen'
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue