diff options
author | tpart <tpart120@proton.me> | 2023-06-24 22:22:33 +0200 |
---|---|---|
committer | tpart <tpart120@proton.me> | 2023-06-24 22:22:33 +0200 |
commit | 466aee544b95a866305731df4642927583d4eb90 (patch) | |
tree | e150ec304e65ed8d90cdb5b8e1fdce85df41137c /client-web/source/menu.ts | |
parent | ea501df4775cb2686ef5f2e2bbee1d5c69d00941 (diff) | |
parent | e3d056a8807d52f95b7df9537ce931925b00d98f (diff) | |
download | keks-meet-466aee544b95a866305731df4642927583d4eb90.tar keks-meet-466aee544b95a866305731df4642927583d4eb90.tar.bz2 keks-meet-466aee544b95a866305731df4642927583d4eb90.tar.zst |
Merge branch 'master' of codeberg.org:metamuffin/keks-meet
Diffstat (limited to 'client-web/source/menu.ts')
-rw-r--r-- | client-web/source/menu.ts | 96 |
1 files changed, 43 insertions, 53 deletions
diff --git a/client-web/source/menu.ts b/client-web/source/menu.ts index 0df50d8..1b159ec 100644 --- a/client-web/source/menu.ts +++ b/client-web/source/menu.ts @@ -5,68 +5,58 @@ */ /// <reference lib="dom" /> -import { ebutton, ediv, efooter, enav, ep, OverlayUi } from "./helper.ts" +import { ebutton, ediv, efooter, einput, elabel, enav, ep } from "./helper.ts" import { VERSION } from "./index.ts" -import { PrefUi } from "./preferences/ui.ts" +import { ui_preferences } from "./preferences/ui.ts" import { create_file_res } from "./resource/file.ts"; import { create_camera_res, create_mic_res, create_screencast_res } from "./resource/track.ts"; import { Room } from "./room.ts" -export class MenuBr extends OverlayUi { - constructor() { - const item = (name: string, cb: (() => void) | string) => { - const p = document.createElement("p") - const a = document.createElement("a") - a.classList.add("menu-item") - a.target = "_blank" // dont unload this meeting - a.textContent = name - if (typeof cb == "string") a.href = cb - else a.addEventListener("click", cb), a.href = "#" - p.append(a) - return p - } - - super(efooter({ class: "menu-br" }, - ep(`keks-meet ${VERSION}`, { class: "version" }), - item("License", "https://codeberg.org/metamuffin/keks-meet/raw/branch/master/COPYING"), - item("Source code", "https://codeberg.org/metamuffin/keks-meet"), - item("Documentation", "https://codeberg.org/metamuffin/keks-meet/src/branch/master/readme.md"), - ), true) +export function info_br() { + const item = (name: string, cb: (() => void) | string) => { + const p = document.createElement("p") + const a = document.createElement("a") + a.classList.add("menu-item") + a.target = "_blank" // dont unload this meeting + a.textContent = name + if (typeof cb == "string") a.href = cb + else a.addEventListener("click", cb), a.href = "#" + p.append(a) + return p } + + return efooter({ class: "info-br" }, + ep(`keks-meet ${VERSION}`, { class: "version" }), + item("License", "https://codeberg.org/metamuffin/keks-meet/raw/branch/master/COPYING"), + item("Source code", "https://codeberg.org/metamuffin/keks-meet"), + item("Documentation", "https://codeberg.org/metamuffin/keks-meet/src/branch/master/readme.md"), + ) } -export class BottomMenu extends OverlayUi { - constructor(room: Room) { - // TODO this should ideally be a checkbox - const chat_toggle = document.createElement("input") - chat_toggle.type = "button" - chat_toggle.value = "Chat" - chat_toggle.ariaHasPopup = "menu" - chat_toggle.onclick = () => { - room.chat.shown = !room.chat.shown - if (room.chat.shown) chat_toggle.classList.add("active") - else chat_toggle.classList.remove("active") - } - const prefs_button = document.createElement("input") - prefs_button.type = "button" - prefs_button.value = "Settings" - prefs_button.ariaHasPopup = "menu" +export function control_bar(room: Room, side_ui_container: HTMLElement): HTMLElement { + const chat = side_ui(side_ui_container, room.chat.element, "Chat") + const prefs = side_ui(side_ui_container, ui_preferences(), "Settings") + const local_controls = ediv({ class: "local-controls", aria_label: "local resources" }, + ebutton("Microphone", { onclick: () => room.local_user.await_add_resource(create_mic_res()) }), + ebutton("Camera", { onclick: () => room.local_user.await_add_resource(create_camera_res()) }), + ebutton("Screen", { onclick: () => room.local_user.await_add_resource(create_screencast_res()) }), + ebutton("File", { onclick: () => room.local_user.await_add_resource(create_file_res()) }), + ) + return enav({ class: "control-bar" }, chat.el, prefs.el, local_controls) +} - const prefs = new PrefUi() - prefs_button.onclick = () => { - prefs.shown = !prefs.shown - if (prefs.shown) prefs_button.classList.add("active") - else prefs_button.classList.remove("active") +export interface SideUI { el: HTMLElement, set_state: (s: boolean) => void } +export function side_ui(container: HTMLElement, content: HTMLElement, label: string): SideUI { + // TODO: close other side uis + const checkbox = einput("checkbox", { + onchange: () => { + if (checkbox.checked) container.appendChild(content) + else container.removeChild(content) } - - const local_controls = ediv({ class: "local-controls", aria_label: "local resources" }, - ebutton("Microphone", { onclick: () => room.local_user.await_add_resource(create_mic_res()) }), - ebutton("Camera", { onclick: () => room.local_user.await_add_resource(create_camera_res()) }), - ebutton("Screen", { onclick: () => room.local_user.await_add_resource(create_screencast_res()) }), - ebutton("File", { onclick: () => room.local_user.await_add_resource(create_file_res()) }), - ) - - super(enav({ class: "bottom-menu" }, chat_toggle, prefs_button, local_controls), true) + }) + return { + el: elabel(label, { class: "side-ui-control" }, checkbox), + set_state(s) { checkbox.checked = s } } -} +}
\ No newline at end of file |