aboutsummaryrefslogtreecommitdiff
path: root/client-web/source/menu.ts
diff options
context:
space:
mode:
Diffstat (limited to 'client-web/source/menu.ts')
-rw-r--r--client-web/source/menu.ts96
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