-
Notifications
You must be signed in to change notification settings - Fork 3
/
minimalisttodos.html
42 lines (40 loc) · 1.83 KB
/
minimalisttodos.html
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
<title>Minimalist TodoMVC App in S.js</title>
<script type="text/jsx">
var Todo = t => ({ // our Todo constructor
title: S.data(t.title), // properties are data signals
done: S.data(t.done)
}),
todos = SArray([]), // our array of todos
newTitle = S.data(""), // title for new todos
addTodo = () => { // push new title onto list
todos.push(Todo({ title: newTitle(), done: false }));
newTitle(""); // clear new title
},
view = // our declarative view
<div>
<h3>Minimalist ToDos in Surplus</h3>
<input type="text" placeholder="enter todo and click +" fn={data(newTitle)}/>
<a onClick={addTodo}> + </a>
{todos.map(todo =>
<div>
<input type="checkbox" fn={data(todo.done)}/>
<input type="text" fn={data(todo.title)}/>
<a onClick={() => todos.remove(todo)}> x</a>
</div>)}
</div>;
if (localStorage.todos) // load stored todos on start
todos(JSON.parse(localStorage.todos).map(Todo));
S(() => // store todos whenever they change
localStorage.todos = JSON.stringify(todos().map(t =>
({ title: t.title(), done: t.done() }))
));
document.body.appendChild(view); // add view to document
</script>
<script src="https://unpkg.com/surplus-toys"></script>
<script src="https://unpkg.com/surplus-mixin-data"></script>
<script src="https://unpkg.com/s-array"></script>
<script>
// since we're loading from <script> tags, pull out a few shorthand values
var data = SurplusDataMixin.default,
SArray = SArray.default;
</script>