-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtoggleInput.ts
80 lines (67 loc) · 2.58 KB
/
toggleInput.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
import { randomId } from "@sv443-network/userutils";
import { setInnerHtml, t } from "../utils/index.js";
import "./toggleInput.css";
export interface ToggleInputProps {
/** Callback function that is called when the toggle is changed */
onChange: (value: boolean) => void;
/** Initial value of the toggle - defaults to false */
initialValue?: boolean;
/** If unspecified, a random ID is generated */
id?: string;
/** Toggle label off or change position of the label relative to the toggle */
labelPos?: "off" | "left" | "right";
}
/** Creates a simple toggle element */
export async function createToggleInput({
onChange,
initialValue = false,
id = randomId(6, 36),
labelPos = "left",
}: ToggleInputProps) {
const wrapperEl = document.createElement("div");
wrapperEl.classList.add("bytm-toggle-input-wrapper", "bytm-no-select");
wrapperEl.role = "switch";
wrapperEl.tabIndex = 0;
const labelEl = labelPos !== "off" && document.createElement("label");
if(labelEl) {
labelEl.classList.add("bytm-toggle-input-label");
labelEl.textContent = t(`toggled_${initialValue ? "on" : "off"}`);
if(id)
labelEl.htmlFor = `bytm-toggle-input-${id}`;
}
const toggleWrapperEl = document.createElement("div");
toggleWrapperEl.classList.add("bytm-toggle-input");
toggleWrapperEl.tabIndex = -1;
const toggleEl = document.createElement("input");
toggleEl.type = "checkbox";
toggleEl.checked = initialValue;
toggleEl.dataset.toggled = String(Boolean(initialValue));
toggleEl.tabIndex = -1;
if(id)
toggleEl.id = `bytm-toggle-input-${id}`;
const toggleKnobEl = document.createElement("div");
toggleKnobEl.classList.add("bytm-toggle-input-knob");
setInnerHtml(toggleKnobEl, " ");
const toggleElClicked = (e: Event) => {
e.preventDefault();
e.stopPropagation();
onChange(toggleEl.checked);
toggleEl.dataset.toggled = String(Boolean(toggleEl.checked));
if(labelEl)
labelEl.textContent = t(`toggled_${toggleEl.checked ? "on" : "off"}`);
wrapperEl.ariaValueText = t(`toggled_${toggleEl.checked ? "on" : "off"}`);
};
toggleEl.addEventListener("change", toggleElClicked);
wrapperEl.addEventListener("keydown", (e) => {
if(["Space", " ", "Enter"].includes(e.code)) {
toggleEl.checked = !toggleEl.checked;
toggleElClicked(e);
}
});
toggleEl.appendChild(toggleKnobEl);
toggleWrapperEl.appendChild(toggleEl);
labelEl && labelPos === "left" && wrapperEl.appendChild(labelEl);
wrapperEl.appendChild(toggleWrapperEl);
labelEl && labelPos === "right" && wrapperEl.appendChild(labelEl);
return wrapperEl;
}