-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.js
61 lines (52 loc) · 1.12 KB
/
index.js
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
'use strict';
let {
map
} = require('bolzano');
let {
n, view
} = require('kabanery');
/**
* @readme-quick-run
*
* ## test tar=js r_c=Select env=browser
*
* let {mount} = require('kabanery');
*
* let view = Select({
* options: [['a', 'option a'], ['b', 'option b']],
* selected: 'a',
* onchange: (selectItem) => {
* }
* });
*
* mount(view, document.body);
*
* console.log(document.body.innerHTML);
*/
/**
* {
*
* options: [[name, description]],
*
* selected
* }
*/
module.exports = view((data) => {
data.selected = data.selected || data.options[0][0];
let onchange = data.onchange;
return n('select', {
onchange: (e) => {
data.selected = e.target.value;
onchange && onchange(data.selected);
}
}, map(data.options, ([name, description]) => {
let selectStr = '';
if (data.selected === name) {
selectStr = 'selected="selected"';
}
if (description === undefined) {
description = name;
}
return n(`option value=${name} ${selectStr}`, description);
}));
});