-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtodo.tag
43 lines (33 loc) · 789 Bytes
/
todo.tag
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
<todo>
<h3>{ opts.title }</h3>
<ul>
<li each={ items.filter(filter) }>
<label class={ completed: done }>
<input type="checkbox" checked={ done } onclick={ parent.toggle }> { title }
</label>
</li>
</ul>
<form onsubmit={ add }>
<input name="input" onkeyup={ edit }>
<button disabled={ !text }>Add #{ items.filter(filter).length + 1 }</button>
</form>
this.items = opts.items
edit(e) {
this.text = e.target.value
}
add(e) {
if (this.text) {
this.items.push({ title: this.text })
this.text = this.input.value = ''
}
}
// an example how to filter items on the list
filter(item) {
return !item.hidden
}
toggle(e) {
var item = e.item
item.done = !item.done
return true
}
</todo>