mirror of https://github.com/sualko/cloud_bbb
118 lines
4.1 KiB
TypeScript
118 lines
4.1 KiB
TypeScript
import React, { useState, useEffect } from 'react';
|
|
import { Access, Room, Permission, RoomShare, api } from './Api';
|
|
import Dialog from './Dialog';
|
|
import ShareWith from './ShareWith';
|
|
import { SubmitInput } from './SubmitInput';
|
|
|
|
const descriptions: { [key: string]: string } = {
|
|
name: t('bbb', 'Descriptive name of this room.'),
|
|
welcome: t('bbb', 'This message is shown to all users in the chat area after they joined.'),
|
|
maxParticipants: t('bbb', 'Sets a limit on the number of participants for this room. Zero means there is no limit.'),
|
|
recording: t('bbb', 'If enabled, the moderator is able to start the recording.'),
|
|
access: t('bbb', 'Public: Everyone knowing the link is able to join. Password: Guests have to provide a password. Waiting room: A moderator has to accept every guest before they can join. Internal: Only Nextcloud users can join.'),
|
|
};
|
|
|
|
type Props = {
|
|
room: Room;
|
|
updateProperty: (key: string, value: string | boolean | number) => Promise<void>;
|
|
open: boolean;
|
|
setOpen: (open: boolean) => void;
|
|
}
|
|
|
|
const EditRoomDialog: React.FC<Props> = ({ room, updateProperty, open, setOpen }) => {
|
|
const [shares, setShares] = useState<RoomShare[]>();
|
|
|
|
useEffect(() => {
|
|
if (!open) {
|
|
return;
|
|
}
|
|
|
|
api.getRoomShares(room.id).then(roomShares => {
|
|
console.log(room.name, roomShares);
|
|
setShares(roomShares);
|
|
}).catch(err => {
|
|
console.warn('Could not load room shares.', err);
|
|
|
|
setShares([]);
|
|
});
|
|
}, [room.id, open]);
|
|
|
|
function inputElement(label: string, field: string, type: 'text' | 'number' = 'text') {
|
|
return (
|
|
<div className="bbb-form-element">
|
|
<label htmlFor={`bbb-${field}`}>
|
|
<h3>{label}</h3>
|
|
</label>
|
|
|
|
<SubmitInput initialValue={room[field]} type={type} name={field} onSubmitValue={value => updateProperty(field, value)} />
|
|
{descriptions[field] && <em>{descriptions[field]}</em>}
|
|
</div>
|
|
);
|
|
}
|
|
|
|
function selectElement(label: string, field: string, value: string, options: { [key: string]: string }, onChange: (value: string) => void) {
|
|
return (
|
|
<div className="bbb-form-element">
|
|
<label htmlFor={`bbb-${field}`}>
|
|
<h3>{label}</h3>
|
|
</label>
|
|
|
|
<select name={field} value={value} onChange={(event) => onChange(event.target.value)}>
|
|
{Object.keys(options).map(key => {
|
|
const label = options[key];
|
|
|
|
return <option key={key} value={key}>{label}</option>;
|
|
})}
|
|
</select>
|
|
{(value === Access.Password && room.password) && <input type="text" readOnly={true} value={room.password} />}
|
|
{descriptions[field] && <em>{descriptions[field]}</em>}
|
|
</div>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<Dialog open={open} onClose={() => setOpen(false)} title={t('bbb', 'Edit "{room}"', { room: room.name })}>
|
|
{inputElement(t('bbb', 'Name'), 'name')}
|
|
{inputElement(t('bbb', 'Welcome'), 'welcome')}
|
|
{inputElement(t('bbb', 'Participant limit'), 'maxParticipants', 'number')}
|
|
|
|
{selectElement(t('bbb', 'Access'), 'access', room.access, {
|
|
[Access.Public]: t('bbb', 'Public'),
|
|
[Access.Password]: t('bbb', 'Internal + Password protection for guests'),
|
|
[Access.WaitingRoom]: t('bbb', 'Internal + Waiting room for guests'),
|
|
[Access.Internal]: t('bbb', 'Internal'),
|
|
[Access.InternalRestricted]: t('bbb', 'Internal restricted'),
|
|
}, (value) => {
|
|
console.log('access', value);
|
|
updateProperty('access', value);
|
|
})}
|
|
|
|
{room.access === Access.InternalRestricted && <div className="bbb-form-element bbb-form-shareWith">
|
|
<ShareWith permission={Permission.User} room={room} shares={shares} setShares={setShares} />
|
|
</div>}
|
|
|
|
<div className="bbb-form-element">
|
|
<label htmlFor={'bbb-moderator'}>
|
|
<h3>Moderator</h3>
|
|
</label>
|
|
|
|
<ShareWith permission={Permission.Moderator} room={room} shares={shares} setShares={setShares} />
|
|
</div>
|
|
|
|
<h3>{t('bbb', 'Miscellaneous')}</h3>
|
|
<div>
|
|
<div>
|
|
<input id={`bbb-record-${room.id}`}
|
|
type="checkbox"
|
|
className="checkbox"
|
|
checked={room.record}
|
|
onChange={(event) => updateProperty('record', event.target.checked)} />
|
|
<label htmlFor={`bbb-record-${room.id}`}>{t('bbb', 'Recording')}</label>
|
|
</div>
|
|
<em>{descriptions.recording}</em>
|
|
</div>
|
|
</Dialog>
|
|
);
|
|
};
|
|
|
|
export default EditRoomDialog; |