-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtodo.tag
executable file
·97 lines (82 loc) · 2.28 KB
/
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
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
<todo>
<h3>{ title } <a href={ url }>{ url }</a></h3>
<ul>
<li title={ json } each={ items.filter(whatShow) }>
<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(whatShow).length + 1 }</button>
<button disabled={ items.filter(onlyDone).length == 0 } onclick={ removeAllDone }>
X{ items.filter(onlyDone).length } </button>
</form>
<!-- this script tag is optional -->
<script>
var items = []
var title = ''
var jumpInto = function(array, current) {
for(i in array) {
if(array[i].type == 'LayerGroup') {
jumpInto(array[i].entries, current + '/' + array[i].title)
} else {
items.push({title : current + '/' + array[i].title, json : JSON.stringify(array[i])})
}
}
}
var request = new XMLHttpRequest()
request.open('GET', opts.url, false)
request.onload = function() {
if (request.status >= 200 && request.status < 400) {
var r = JSON.parse(request.responseText)
title = r.layers[0].title
jumpInto(r.layers, '');
}
}
request.send()
this.url = opts.url;
this.items = items
this.title = title
edit(e) {
this.text = e.target.value
}
add(e) {
if (this.text) {
this.items.push({ title: this.text })
this.text = this.input.value = ''
}
}
removeAllDone(e) {
this.items = this.items.filter(function(item) {
return !item.done
})
}
// an two example how to filter items on the list
whatShow(item) {
return !item.hidden
}
onlyDone(item) {
return item.done
}
toggle(e) {
var item = e.item
item.done = !item.done
return true
}
load() {
console.log('hello');
var request = new XMLHttpRequest()
request.open('GET', opts.url, true)
request.onload = function() {
if (request.status >= 200 && request.status < 400) {
var r = JSON.parse(request.responseText)
console.log(r)
console.log(e)
}
}
request.send()
}
</script>
</todo>