-
Notifications
You must be signed in to change notification settings - Fork 194
Expand file tree
/
Copy pathinput.js
More file actions
43 lines (40 loc) · 1.04 KB
/
input.js
File metadata and controls
43 lines (40 loc) · 1.04 KB
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
import {observe} from "./observe.js";
export function input(element) {
return observe((change) => {
const event = eventof(element);
let value = valueof(element);
const inputted = (event) => change(valueof(event.target));
element.addEventListener(event, inputted);
if (value !== undefined) change(value);
return () => element.removeEventListener(event, inputted);
});
}
function valueof(element) {
switch (element.type) {
case "range":
case "number":
return element.valueAsNumber;
case "date":
return element.valueAsDate;
case "checkbox":
return element.checked;
case "file":
return element.multiple ? element.files : element.files[0];
case "select-multiple":
return Array.from(element.selectedOptions, (o) => o.value);
default:
return element.value;
}
}
function eventof(element) {
switch (element.type) {
case "button":
case "submit":
case "checkbox":
return "click";
case "file":
return "change";
default:
return "input";
}
}