forked from observablehq/inputs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathselect.js
21 lines (20 loc) · 929 Bytes
/
select.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
import {html} from "htl";
import {createChooser} from "./chooser.js";
import {maybeWidth} from "./css.js";
import {stringify} from "./format.js";
import {maybeLabel} from "./label.js";
export const select = createChooser({
render(data, index, selected, disabled, {format, multiple, size, label, width}) {
const select = html`<select class=__ns__-input disabled=${disabled === true} multiple=${multiple} size=${size} name=input>
${index.map(i => html`<option value=${i} disabled=${typeof disabled === "function" ? disabled(i) : false} selected=${selected(i)}>${stringify(format(data[i], i, data))}`)}
</select>`;
const form = html`<form class=__ns__ style=${maybeWidth(width)}>${maybeLabel(label, select)}${select}`;
return [form, select];
},
selectedIndexes(input) {
return Array.from(input.selectedOptions, i => +i.value);
},
select(input, selected) {
input.selected = selected;
}
});