Work in progress
Create lists of views that map to an array of data.
component install ripplejs/list
First create a child view for the items in the list:
var Todo = ripple('<li>{{name}}</li>');
Then create your main view:
var TodoList = ripple(template)
.attr('todos', { required: true, type: 'array' })
.attr('items', { map: 'todos', view: Todo })
.use(list());
Add list
as a plugin and you'll be able to use map
and view
within attributes. This maps the items
property to the todos
property and will create a new Todo
view for each item in the array.
The template might look like this:
<div class="TodoList">
<ul class="Todos">{{items}}</ul>
</div>
The items
value will be a view with an el
property so it will render the list's element within the ul
.
Then you can create your view as normal, passing in todos:
var todolist = new TodoList({
todos: [{
name: "Buy Milk"
}]
});
Then you can manipulate the array itself to add, remove and sort items:
todos.push({
name: "Feed cat"
});
todos.sort();
todos.pop();