resizeable sidebar and meeting names on startpage
All checks were successful
continuous-integration/drone/push Build is passing

This commit is contained in:
qvalentin 2023-07-04 20:05:58 +02:00
parent eedc21fb8e
commit f3e6699ca5
4 changed files with 40 additions and 2 deletions

View file

@ -20,6 +20,7 @@ function App() {
conferenceData={conferenceData} conferenceData={conferenceData}
setConferenceData={setConferenceData} setConferenceData={setConferenceData}
userInfo={userInfo} userInfo={userInfo}
usersData={roomData}
/> />
</div> </div>
) )

View file

@ -0,0 +1,4 @@
.meeting-quickjoin {
text-align: center
}

View file

@ -1,19 +1,26 @@
import { ConferenceData } from '../../background/jitsi/eventListeners' import { ConferenceData } from '../../background/jitsi/eventListeners'
import { UsersData } from '../../background/types/roomData'
import useMeetingStarted from '../../hooks/useMeetingStarted' import useMeetingStarted from '../../hooks/useMeetingStarted'
import { useRoomName } from '../../hooks/useRoomName' import { useRoomName } from '../../hooks/useRoomName'
import JitsiEntrypoint from '../jitsi/JitsiEntrypoint' import JitsiEntrypoint from '../jitsi/JitsiEntrypoint'
import { UserInfo } from '../jitsi/types' import { UserInfo } from '../jitsi/types'
import MeetingNameInput from './MeetingNameInput' import MeetingNameInput from './MeetingNameInput'
import './Meeting.css'
interface Props { interface Props {
conferenceData: ConferenceData | undefined conferenceData: ConferenceData | undefined
setConferenceData: (newData: ConferenceData) => void setConferenceData: (newData: ConferenceData) => void
userInfo: UserInfo userInfo: UserInfo
usersData: UsersData
} }
function Meeting({ conferenceData, setConferenceData, userInfo }: Props) { function Meeting(props: Props) {
const { conferenceData, setConferenceData, userInfo, usersData } = props
console.log("[Rooms] meeting usersData", props)
const [meetingStarted] = useMeetingStarted() const [meetingStarted] = useMeetingStarted()
const { roomName } = useRoomName() const { roomName } = useRoomName()
const [_, setMeetingStarted] = useMeetingStarted()
const { updateAndSubmitRoomName: updateAndSubmitRoomName } = useRoomName()
if (meetingStarted) { if (meetingStarted) {
return ( return (
@ -26,7 +33,32 @@ function Meeting({ conferenceData, setConferenceData, userInfo }: Props) {
) )
} }
return <MeetingNameInput roomName={roomName} currentUser={userInfo.displayName} /> return (
<div>
<MeetingNameInput roomName={roomName} currentUser={userInfo.displayName} />
<div className="meeting-quickjoin">
{usersData?.roomsData.map((roomData) => {
return (
<>
<h3>
<a
href="#"
onClick={() => {
updateAndSubmitRoomName(roomData.roomName)
setMeetingStarted(true)
}}
>
{roomData.roomName}
</a>
</h3>
{roomData.participants.map((participant) => (
<div key={participant.jid}> {participant.displayName} </div>
))}
</>
)
})}
</div>
</div>)
} }
export default Meeting export default Meeting

View file

@ -1,4 +1,5 @@
.sidebar { .sidebar {
resize: horizontal;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
white-space: nowrap; white-space: nowrap;