Commit 7cb4d0e7 authored by Sindre Sorhus's avatar Sindre Sorhus

index.html - head/body indentation

parent 39a16fa4
<!doctype html> <!doctype html>
<html lang="en" data-framework="canjs"> <html lang="en" data-framework="canjs">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>CanJS • TodoMVC</title> <title>CanJS • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
</section> </section>
<footer id="info"> <footer id="info">
<p>Double-click to edit a todo</p> <p>Double-click to edit a todo</p>
<p>Written by <a href="http://bitovi.com">Bitovi</a></p> <p>Written by <a href="http://bitovi.com">Bitovi</a></p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</footer> </footer>
<script src="bower_components/jquery/jquery.js"></script> <script src="bower_components/jquery/jquery.js"></script>
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<script src="bower_components/canjs/can.jquery.js"></script> <script src="bower_components/canjs/can.jquery.js"></script>
<script src="bower_components/canjs-localstorage/can.localstorage.js"></script> <script src="bower_components/canjs-localstorage/can.localstorage.js"></script>
<script src="js/lib/can.mustache.min.js"></script> <script src="js/lib/can.mustache.min.js"></script>
<script src="js/models/todo.js"></script> <script src="js/models/todo.js"></script>
<script src="js/todos/todos.js"></script> <script src="js/todos/todos.js"></script>
<script src="js/app.js"></script> <script src="js/app.js"></script>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="closure"> <html lang="en" data-framework="closure">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Closure • TodoMVC</title> <title>Closure • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" placeholder="What needs to be done?" autofocus> <input id="new-todo" placeholder="What needs to be done?" autofocus>
</header> </header>
<section id="main"> <section id="main">
<input id="toggle-all" type="checkbox"> <input id="toggle-all" type="checkbox">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list"> <ul id="todo-list">
</ul> </ul>
</section>
<footer id="footer">
<ul id="filters">
<li>
<a class="selected" href="#/">All</a>
</li>
<li>
<a href="#/active">Active</a>
</li>
<li>
<a href="#/completed">Completed</a>
</li>
</ul>
</footer>
</section> </section>
<footer id="footer"> <footer id="info">
<ul id="filters"> <p>Double-click to edit a todo</p>
<li> <p>Created by <a href="http://www.scottlogic.co.uk/blog/chris/">Chris Price</a></p>
<a class="selected" href="#/">All</a> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</li>
<li>
<a href="#/active">Active</a>
</li>
<li>
<a href="#/completed">Completed</a>
</li>
</ul>
</footer> </footer>
</section> <script src="bower_components/todomvc-common/base.js"></script>
<footer id="info"> <!-- The compiled version (to update run java -jar build/plovr.jar build plovr.json > js/compiled.js) -->
<p>Double-click to edit a todo</p> <script type="text/javascript" src="js/compiled.js"></script>
<p>Created by <a href="http://www.scottlogic.co.uk/blog/chris/">Chris Price</a></p> <!-- The RAW development version (to serve the files run java -jar build/plovr.jar serve plovr.json) -->
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <!-- <script type="text/javascript" src="http://localhost:9810/compile?id=todomvc&mode=RAW"></script> -->
</footer> <!-- The COMPILED development version (to serve the files run java -jar build/plovr.jar serve plovr.json) -->
<script src="bower_components/todomvc-common/base.js"></script> <!-- <script type="text/javascript" src="http://localhost:9810/compile?id=todomvc&mode=ADVANCED"></script> -->
<!-- The compiled version (to update run java -jar build/plovr.jar build plovr.json > js/compiled.js) --> </body>
<script type="text/javascript" src="js/compiled.js"></script>
<!-- The RAW development version (to serve the files run java -jar build/plovr.jar serve plovr.json) -->
<!-- <script type="text/javascript" src="http://localhost:9810/compile?id=todomvc&mode=RAW"></script> -->
<!-- The COMPILED development version (to serve the files run java -jar build/plovr.jar serve plovr.json) -->
<!-- <script type="text/javascript" src="http://localhost:9810/compile?id=todomvc&mode=ADVANCED"></script> -->
</body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="dart"> <html lang="en" data-framework="dart">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Dart • TodoMVC</title> <title>Dart • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" placeholder="What needs to be done?" autofocus> <input id="new-todo" placeholder="What needs to be done?" autofocus>
</header> </header>
<section id="main"> <section id="main">
<input id="toggle-all" type="checkbox"> <input id="toggle-all" type="checkbox">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list"></ul> <ul id="todo-list"></ul>
</section>
<footer id="footer">
<span id="todo-count"><strong>0</strong> item left</span>
<ul id="filters">
<li>
<a class="selected" href="#/">All</a>
</li>
<li>
<a href="#/active">Active</a>
</li>
<li>
<a href="#/completed">Completed</a>
</li>
</ul>
<button id="clear-completed">Clear completed</button>
</footer>
</section> </section>
<footer id="footer"> <footer id="info">
<span id="todo-count"><strong>0</strong> item left</span> <p>Double-click to edit a todo</p>
<ul id="filters"> <p>Created by <a href="http://mlorber.net">Mathieu Lorber</a></p>
<li> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
<a class="selected" href="#/">All</a>
</li>
<li>
<a href="#/active">Active</a>
</li>
<li>
<a href="#/completed">Completed</a>
</li>
</ul>
<button id="clear-completed">Clear completed</button>
</footer> </footer>
</section> <script src="bower_components/todomvc-common/base.js"></script>
<footer id="info"> <script type="application/dart" src="dart/app.dart"></script>
<p>Double-click to edit a todo</p> <script src="sdk/dart.js"></script>
<p>Created by <a href="http://mlorber.net">Mathieu Lorber</a></p> </body>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</footer>
<script src="bower_components/todomvc-common/base.js"></script>
<script type="application/dart" src="dart/app.dart"></script>
<script src="sdk/dart.js"></script>
</body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="dojo"> <html lang="en" data-framework="dojo">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Dojo • TodoMVC</title> <title>Dojo • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
<link rel="stylesheet" href="css/app.css"> <link rel="stylesheet" href="css/app.css">
</head> </head>
<body> <body>
<section id="todoapp" data-dojo-type="todo/app18"></section> <section id="todoapp" data-dojo-type="todo/app18"></section>
<footer id="info"> <footer id="info">
<p>Double-click to edit a todo</p> <p>Double-click to edit a todo</p>
<p>Created by <a href="http://jamesthom.as/">James Thomas</a> and <a href="https://github.com/edchat">Ed Chatelain</a></p> <p>Created by <a href="http://jamesthom.as/">James Thomas</a> and <a href="https://github.com/edchat">Ed Chatelain</a></p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</footer> </footer>
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<script> <script>
require = { require = {
async: true, async: true,
parseOnLoad: true, parseOnLoad: true,
locale: 'en', locale: 'en',
paths: { paths: {
dijit: '../dijit-1.8' dijit: '../dijit-1.8'
}, },
deps: ['dojo/parser', 'dojo/domReady!'], deps: ['dojo/parser', 'dojo/domReady!'],
mvc: { debugBindings: true } mvc: { debugBindings: true }
}; };
</script> </script>
<script src="js/lib/dojo-1.8/dojo.js"></script> <script src="js/lib/dojo-1.8/dojo.js"></script>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="emberjs"> <html lang="en" data-framework="emberjs">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>ember.js • TodoMVC</title> <title>ember.js • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<script type="text/x-handlebars" data-template-name="todos"> <script type="text/x-handlebars" data-template-name="todos">
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
{{view Ember.TextField id="new-todo" placeholder="What needs to be done?" {{view Ember.TextField id="new-todo" placeholder="What needs to be done?"
valueBinding="newTitle" action="createTodo"}} valueBinding="newTitle" action="createTodo"}}
</header> </header>
{{#if length}} {{#if length}}
<section id="main"> <section id="main">
<ul id="todo-list"> <ul id="todo-list">
{{#each filteredTodos itemController="todo"}} {{#each filteredTodos itemController="todo"}}
<li {{bindAttr class="isCompleted:completed isEditing:editing"}}> <li {{bindAttr class="isCompleted:completed isEditing:editing"}}>
{{#if isEditing}} {{#if isEditing}}
{{view Todos.EditTodoView todoBinding="this"}} {{view Todos.EditTodoView todoBinding="this"}}
{{else}} {{else}}
{{view Ember.Checkbox checkedBinding="isCompleted" class="toggle"}} {{view Ember.Checkbox checkedBinding="isCompleted" class="toggle"}}
<label {{action "editTodo" on="doubleClick"}}>{{title}}</label> <label {{action "editTodo" on="doubleClick"}}>{{title}}</label>
<button {{action "removeTodo"}} class="destroy"></button> <button {{action "removeTodo"}} class="destroy"></button>
{{/if}} {{/if}}
</li> </li>
{{/each}} {{/each}}
</ul> </ul>
{{view Ember.Checkbox id="toggle-all" checkedBinding="allAreDone"}} {{view Ember.Checkbox id="toggle-all" checkedBinding="allAreDone"}}
</section> </section>
<footer id="footer"> <footer id="footer">
<span id="todo-count">{{{remainingFormatted}}}</span> <span id="todo-count">{{{remainingFormatted}}}</span>
<ul id="filters"> <ul id="filters">
<li> <li>
{{#linkTo todos.index activeClass="selected"}}All{{/linkTo}} {{#linkTo todos.index activeClass="selected"}}All{{/linkTo}}
</li> </li>
<li> <li>
{{#linkTo todos.active activeClass="selected"}}Active{{/linkTo}} {{#linkTo todos.active activeClass="selected"}}Active{{/linkTo}}
</li> </li>
<li> <li>
{{#linkTo todos.completed activeClass="selected"}}Completed{{/linkTo}} {{#linkTo todos.completed activeClass="selected"}}Completed{{/linkTo}}
</li> </li>
</ul> </ul>
{{#if hasCompleted}} {{#if hasCompleted}}
<button id="clear-completed" {{action "clearCompleted"}} {{bindAttr class="buttonClass:hidden"}}> <button id="clear-completed" {{action "clearCompleted"}} {{bindAttr class="buttonClass:hidden"}}>
Clear completed ({{completed}}) Clear completed ({{completed}})
</button> </button>
{{/if}} {{/if}}
</footer> </footer>
{{/if}} {{/if}}
</section> </section>
<footer id="info"> <footer id="info">
<p>Double-click to edit a todo</p> <p>Double-click to edit a todo</p>
<p> <p>
Created by Created by
<a href="http://github.com/tomdale">Tom Dale</a>, <a href="http://github.com/tomdale">Tom Dale</a>,
<a href="http://github.com/addyosmani">Addy Osmani</a> <a href="http://github.com/addyosmani">Addy Osmani</a>
</p> </p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</footer> </footer>
</script> </script>
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<script src="bower_components/jquery/jquery.js"></script> <script src="bower_components/jquery/jquery.js"></script>
<script src="bower_components/handlebars/handlebars.js"></script> <script src="bower_components/handlebars/handlebars.js"></script>
<script src="bower_components/ember/ember.js"></script> <script src="bower_components/ember/ember.js"></script>
<!-- TODO: change out with a component when a built one is available on Bower --> <!-- TODO: change out with a component when a built one is available on Bower -->
<script src="js/libs/ember-data.js"></script> <script src="js/libs/ember-data.js"></script>
<script src="bower_components/ember-localstorage-adapter/localstorage_adapter.js"></script> <script src="bower_components/ember-localstorage-adapter/localstorage_adapter.js"></script>
<script src="js/app.js"></script> <script src="js/app.js"></script>
<script src="js/router.js"></script> <script src="js/router.js"></script>
<script src="js/models/todo.js"></script> <script src="js/models/todo.js"></script>
<script src="js/models/store.js"></script> <script src="js/models/store.js"></script>
<script src="js/controllers/todos_controller.js"></script> <script src="js/controllers/todos_controller.js"></script>
<script src="js/controllers/todo_controller.js"></script> <script src="js/controllers/todo_controller.js"></script>
<script src="js/views/edit_todo_view.js"></script> <script src="js/views/edit_todo_view.js"></script>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="gwt"> <html lang="en" data-framework="gwt">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Google Web Toolkit • TodoMVC</title> <title>Google Web Toolkit • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
<link rel="stylesheet" href="css/app.css"> <link rel="stylesheet" href="css/app.css">
</head> </head>
<body> <body>
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<script src="gwttodo/gwttodo.nocache.js"></script> <script src="gwttodo/gwttodo.nocache.js"></script>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="jquery"> <html lang="en" data-framework="jquery">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>jQuery • TodoMVC</title> <title>jQuery • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
<link rel="stylesheet" href="css/app.css"> <link rel="stylesheet" href="css/app.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" placeholder="What needs to be done?" autofocus> <input id="new-todo" placeholder="What needs to be done?" autofocus>
</header> </header>
<section id="main"> <section id="main">
<input id="toggle-all" type="checkbox"> <input id="toggle-all" type="checkbox">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list"></ul> <ul id="todo-list"></ul>
</section>
<footer id="footer">
<span id="todo-count"><strong>0</strong> item left</span>
<button id="clear-completed">Clear completed</button>
</footer>
</section> </section>
<footer id="footer"> <footer id="info">
<span id="todo-count"><strong>0</strong> item left</span> <p>Double-click to edit a todo</p>
<button id="clear-completed">Clear completed</button> <p>Created by <a href="http://github.com/sindresorhus">Sindre Sorhus</a></p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</footer> </footer>
</section> <script id="todo-template" type="text/x-handlebars-template">
<footer id="info"> {{#this}}
<p>Double-click to edit a todo</p> <li {{#if completed}}class="completed"{{/if}} data-id="{{id}}">
<p>Created by <a href="http://github.com/sindresorhus">Sindre Sorhus</a></p> <div class="view">
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <input class="toggle" type="checkbox" {{#if completed}}checked{{/if}}>
</footer> <label>{{title}}</label>
<script id="todo-template" type="text/x-handlebars-template"> <button class="destroy"></button>
{{#this}} </div>
<li {{#if completed}}class="completed"{{/if}} data-id="{{id}}"> <input class="edit" value="{{title}}">
<div class="view"> </li>
<input class="toggle" type="checkbox" {{#if completed}}checked{{/if}}> {{/this}}
<label>{{title}}</label> </script>
<button class="destroy"></button> <script id="footer-template" type="text/x-handlebars-template">
</div> <span id="todo-count"><strong>{{activeTodoCount}}</strong> {{activeTodoWord}} left</span>
<input class="edit" value="{{title}}"> {{#if completedTodos}}<button id="clear-completed">Clear completed ({{completedTodos}})</button>{{/if}}
</li> </script>
{{/this}} <script src="bower_components/todomvc-common/base.js"></script>
</script> <script src="bower_components/jquery/jquery.js"></script>
<script id="footer-template" type="text/x-handlebars-template"> <script src="bower_components/handlebars/handlebars.js"></script>
<span id="todo-count"><strong>{{activeTodoCount}}</strong> {{activeTodoWord}} left</span> <script src="js/app.js"></script>
{{#if completedTodos}}<button id="clear-completed">Clear completed ({{completedTodos}})</button>{{/if}} </body>
</script>
<script src="bower_components/todomvc-common/base.js"></script>
<script src="bower_components/jquery/jquery.js"></script>
<script src="bower_components/handlebars/handlebars.js"></script>
<script src="js/app.js"></script>
</body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="knockback"> <html lang="en" data-framework="knockback">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Knockback.js • TodoMVC</title> <title>Knockback.js • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<section id="todoapp" kb-inject="AppViewModel"> <section id="todoapp" kb-inject="AppViewModel">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" type="text" data-bind="value: title, valueUpdate: 'afterkeydown', event: {keyup: onAddTodo}" placeholder="What needs to be done?" autofocus> <input id="new-todo" type="text" data-bind="value: title, valueUpdate: 'afterkeydown', event: {keyup: onAddTodo}" placeholder="What needs to be done?" autofocus>
</header> </header>
<section id="main" data-bind="block: tasks_exist"> <section id="main" data-bind="block: tasks_exist">
<input id="toggle-all" type="checkbox" data-bind="checked: all_completed"> <input id="toggle-all" type="checkbox" data-bind="checked: all_completed">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list" data-bind="foreach: todos"> <ul id="todo-list" data-bind="foreach: todos">
<li data-bind="css: {completed: completed, editing: editing}"> <li data-bind="css: {completed: completed, editing: editing}">
<div class="view" data-bind="event: {dblclick: onCheckEditBegin}"> <div class="view" data-bind="event: {dblclick: onCheckEditBegin}">
<input class="toggle" type="checkbox" data-bind="checked: completed" checked> <input class="toggle" type="checkbox" data-bind="checked: completed" checked>
<label data-bind="text: title"></label> <label data-bind="text: title"></label>
<button class="destroy" data-bind="click: onDestroyTodo"></button> <button class="destroy" data-bind="click: onDestroyTodo"></button>
</div> </div>
<input class="edit" type="text" data-bind="value: title, selectAndFocus: editing, event: {blur: onCheckEditEnd, keyup: onCheckEditEnd}"> <input class="edit" type="text" data-bind="value: title, selectAndFocus: editing, event: {blur: onCheckEditEnd, keyup: onCheckEditEnd}">
</li> </li>
</ul> </ul>
</section>
<footer id="footer" data-bind="block: tasks_exist">
<span id="todo-count" data-bind="html: loc.remaining_message"></span>
<ul id="filters">
<li>
<a href="#/" data-bind="css: {selected: list_filter_mode()==''}">All</a>
</li>
<li>
<a href="#/active" data-bind="css: {selected: list_filter_mode()=='active'}">Active</a>
</li>
<li>
<a href="#/completed" data-bind="css: {selected: list_filter_mode()=='completed'}">Completed</a>
</li>
</ul>
<button id="clear-completed" data-bind="text: loc.clear_message, block: loc.clear_message, click: onDestroyCompleted"></button>
</footer>
</section> </section>
<footer id="footer" data-bind="block: tasks_exist"> <footer id="info">
<span id="todo-count" data-bind="html: loc.remaining_message"></span> <p>Double-click to edit a todo</p>
<ul id="filters"> <p>Created by <a href="https://github.com/kmalakoff">Kevin Malakoff</a>. <br/>
<li> Please try out the <a href="http://kmalakoff.github.com/knockback-todos-app/">enhanced version</a> <br/>
<a href="#/" data-bind="css: {selected: list_filter_mode()==''}">All</a> with localization, priority colors, and lazy loading <br/>
</li> to see just how dynamic <a href="https://github.com/kmalakoff/knockback">Knockback.js</a> can be!</p>
<li> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
<a href="#/active" data-bind="css: {selected: list_filter_mode()=='active'}">Active</a>
</li>
<li>
<a href="#/completed" data-bind="css: {selected: list_filter_mode()=='completed'}">Completed</a>
</li>
</ul>
<button id="clear-completed" data-bind="text: loc.clear_message, block: loc.clear_message, click: onDestroyCompleted"></button>
</footer> </footer>
</section>
<footer id="info">
<p>Double-click to edit a todo</p>
<p>Created by <a href="https://github.com/kmalakoff">Kevin Malakoff</a>. <br/>
Please try out the <a href="http://kmalakoff.github.com/knockback-todos-app/">enhanced version</a> <br/>
with localization, priority colors, and lazy loading <br/>
to see just how dynamic <a href="https://github.com/kmalakoff/knockback">Knockback.js</a> can be!</p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</footer>
<!-- App Dependencies --> <!-- App Dependencies -->
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<script src="bower_components/jquery/jquery.js"></script> <script src="bower_components/jquery/jquery.js"></script>
<script src="js/lib/knockback-full-stack-0.16.9.min.js"></script> <script src="js/lib/knockback-full-stack-0.16.9.min.js"></script>
<script src="bower_components/Backbone.localStorage/backbone.localStorage.js"></script> <script src="bower_components/Backbone.localStorage/backbone.localStorage.js"></script>
<!-- App and Components --> <!-- App and Components -->
<script src="js/lib/knockout-extended-bindings.js"></script> <script src="js/lib/knockout-extended-bindings.js"></script>
<script src="js/models/todo.js"></script> <script src="js/models/todo.js"></script>
<script src="js/models/todo_collection.js"></script> <script src="js/models/todo_collection.js"></script>
<script src="js/viewmodels/todo.js"></script> <script src="js/viewmodels/todo.js"></script>
<script src="js/viewmodels/app.js"></script> <script src="js/viewmodels/app.js"></script>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="knockoutjs"> <html lang="en" data-framework="knockoutjs">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta content="IE=edge,chrome=1" http-equiv="X-UA-Compatible"> <meta content="IE=edge,chrome=1" http-equiv="X-UA-Compatible">
<title>Knockout.js • TodoMVC</title> <title>Knockout.js • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" data-bind="value: current, valueUpdate: 'afterkeydown', enterKey: add" placeholder="What needs to be done?" autofocus> <input id="new-todo" data-bind="value: current, valueUpdate: 'afterkeydown', enterKey: add" placeholder="What needs to be done?" autofocus>
</header> </header>
<section id="main" data-bind="visible: todos().length"> <section id="main" data-bind="visible: todos().length">
<input id="toggle-all" data-bind="checked: allCompleted" type="checkbox"> <input id="toggle-all" data-bind="checked: allCompleted" type="checkbox">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list" data-bind="foreach: filteredTodos"> <ul id="todo-list" data-bind="foreach: filteredTodos">
<li data-bind="css: { completed: completed, editing: editing }"> <li data-bind="css: { completed: completed, editing: editing }">
<div class="view"> <div class="view">
<input class="toggle" data-bind="checked: completed" type="checkbox"> <input class="toggle" data-bind="checked: completed" type="checkbox">
<label data-bind="text: title, event: { dblclick: $root.editItem }"></label> <label data-bind="text: title, event: { dblclick: $root.editItem }"></label>
<button class="destroy" data-bind="click: $root.remove"></button> <button class="destroy" data-bind="click: $root.remove"></button>
</div> </div>
<input class="edit" data-bind="value: title, valueUpdate: 'afterkeydown', enterKey: $root.stopEditing, selectAndFocus: editing, event: { blur: $root.stopEditing }"> <input class="edit" data-bind="value: title, valueUpdate: 'afterkeydown', enterKey: $root.stopEditing, selectAndFocus: editing, event: { blur: $root.stopEditing }">
</li> </li>
</ul> </ul>
</section>
<footer id="footer" data-bind="visible: completedCount() || remainingCount()">
<span id="todo-count">
<strong data-bind="text: remainingCount">0</strong>
<span data-bind="text: getLabel( remainingCount )"></span> left
</span>
<ul id="filters">
<li>
<a data-bind="css: { selected: showMode() == 'all' }" href="#/all">All</a>
</li>
<li>
<a data-bind="css: { selected: showMode() == 'active' }" href="#/active">Active</a>
</li>
<li>
<a data-bind="css: { selected: showMode() == 'completed' }" href="#/completed">Completed</a>
</li>
</ul>
<button id="clear-completed" data-bind="visible: completedCount, click: removeCompleted">
Clear completed (<span data-bind="text: completedCount"></span>)
</button>
</footer>
</section> </section>
<footer id="footer" data-bind="visible: completedCount() || remainingCount()"> <footer id="info">
<span id="todo-count"> <p>Double-click to edit a todo</p>
<strong data-bind="text: remainingCount">0</strong> <p>Original Knockout version from <a href="https://github.com/ashish01/knockoutjs-todos">Ashish Sharma</a></p>
<span data-bind="text: getLabel( remainingCount )"></span> left <p>Rewritten to use Knockout 2.0 and standard template by <a href="http://knockmeout.net">Ryan Niemeyer</a></p>
</span> <p>Patches/fixes for cross-browser compat: <a href="http://twitter.com/addyosmani">Addy Osmani</a></p>
<ul id="filters"> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
<li>
<a data-bind="css: { selected: showMode() == 'all' }" href="#/all">All</a>
</li>
<li>
<a data-bind="css: { selected: showMode() == 'active' }" href="#/active">Active</a>
</li>
<li>
<a data-bind="css: { selected: showMode() == 'completed' }" href="#/completed">Completed</a>
</li>
</ul>
<button id="clear-completed" data-bind="visible: completedCount, click: removeCompleted">
Clear completed (<span data-bind="text: completedCount"></span>)
</button>
</footer> </footer>
</section> <script src="bower_components/todomvc-common/base.js"></script>
<footer id="info"> <script src="bower_components/knockout.js/knockout.js"></script>
<p>Double-click to edit a todo</p> <script src="bower_components/director/build/director.js"></script>
<p>Original Knockout version from <a href="https://github.com/ashish01/knockoutjs-todos">Ashish Sharma</a></p> <script src="js/app.js"></script>
<p>Rewritten to use Knockout 2.0 and standard template by <a href="http://knockmeout.net">Ryan Niemeyer</a></p> </body>
<p>Patches/fixes for cross-browser compat: <a href="http://twitter.com/addyosmani">Addy Osmani</a></p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</footer>
<script src="bower_components/todomvc-common/base.js"></script>
<script src="bower_components/knockout.js/knockout.js"></script>
<script src="bower_components/director/build/director.js"></script>
<script src="js/app.js"></script>
</body>
</html> </html>
<!DOCTYPE html> <!doctype html>
<html data-framework="maria"> <html data-framework="maria">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<title>Maria • TodoMVC</title> <title>Maria • TodoMVC</title>
<link href="bower_components/todomvc-common/base.css" rel="stylesheet"> <link href="bower_components/todomvc-common/base.css" rel="stylesheet">
<link href="css/app.css" rel="stylesheet"> <link href="css/app.css" rel="stylesheet">
</head> </head>
<body> <body>
<footer id="info"> <footer id="info">
<p>Double-click to edit a todo</p> <p>Double-click to edit a todo</p>
<p>Created by <a href="http://github.com/petermichaux">Peter Michaux</a></p> <p>Created by <a href="http://github.com/petermichaux">Peter Michaux</a></p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</footer> </footer>
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<script src="bower_components/director/build/director.js"></script> <script src="bower_components/director/build/director.js"></script>
<script src="bower_components/maria-bower/maria.js"></script> <script src="bower_components/maria-bower/maria.js"></script>
<script src="bower_components/aristocrat-bower/aristocrat.js"></script> <script src="bower_components/aristocrat-bower/aristocrat.js"></script>
<script src="js/namespace.js"></script> <script src="js/namespace.js"></script>
<script src="js/util.js"></script> <script src="js/util.js"></script>
<script src="js/models/TodoModel.js"></script> <script src="js/models/TodoModel.js"></script>
<script src="js/models/TodosModel.js"></script> <script src="js/models/TodosModel.js"></script>
<script src="js/templates/TodosTemplate.js"></script> <script src="js/templates/TodosTemplate.js"></script>
<script src="js/views/TodosView.js"></script> <script src="js/views/TodosView.js"></script>
<script src="js/controllers/TodosController.js"></script> <script src="js/controllers/TodosController.js"></script>
<script src="js/templates/TodoTemplate.js"></script> <script src="js/templates/TodoTemplate.js"></script>
<script src="js/views/TodoView.js"></script> <script src="js/views/TodoView.js"></script>
<script src="js/controllers/TodoController.js"></script> <script src="js/controllers/TodoController.js"></script>
<script src="js/bootstrap.js"></script> <script src="js/bootstrap.js"></script>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="spine"> <html lang="en" data-framework="spine">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Spine.js • TodoMVC</title> <title>Spine.js • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" placeholder="What needs to be done?" autofocus> <input id="new-todo" placeholder="What needs to be done?" autofocus>
</header> </header>
<section id="main"> <section id="main">
<input id="toggle-all" type="checkbox"> <input id="toggle-all" type="checkbox">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list"></ul> <ul id="todo-list"></ul>
</section>
<footer id="footer">
<span id="todo-count"><strong>0</strong> items left</span>
<ul id="filters">
<li>
<a class="selected" href="#/">All</a>
</li>
<li>
<a href="#/active">Active</a>
</li>
<li>
<a href="#/completed">Completed</a>
</li>
</ul>
<button id="clear-completed">Clear completed</button>
</footer>
</section> </section>
<footer id="footer"> <footer id="info">
<span id="todo-count"><strong>0</strong> items left</span> <p>Double-click to edit a todo</p>
<ul id="filters"> <p>Inspired by the official <a href="https://github.com/maccman/spine.todos">Spine.Todos</a></p>
<li> <p>Created by <a href="http://github.com/sindresorhus">Sindre Sorhus</a></p>
<a class="selected" href="#/">All</a> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</li>
<li>
<a href="#/active">Active</a>
</li>
<li>
<a href="#/completed">Completed</a>
</li>
</ul>
<button id="clear-completed">Clear completed</button>
</footer> </footer>
</section> <script type="text/x-handlebars-template" id="todo-template">
<footer id="info"> {{#this}}
<p>Double-click to edit a todo</p> <li {{#if completed}}class="completed"{{/if}}>
<p>Inspired by the official <a href="https://github.com/maccman/spine.todos">Spine.Todos</a></p> <div class="view">
<p>Created by <a href="http://github.com/sindresorhus">Sindre Sorhus</a></p> <input class="toggle" type="checkbox" {{#if completed}}checked{{/if}}>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <label>{{title}}</label>
</footer> <button class="destroy"></button>
<script type="text/x-handlebars-template" id="todo-template"> </div>
{{#this}} <input class="edit" value="{{title}}">
<li {{#if completed}}class="completed"{{/if}}> </li>
<div class="view"> {{/this}}
<input class="toggle" type="checkbox" {{#if completed}}checked{{/if}}> </script>
<label>{{title}}</label> <script src="bower_components/todomvc-common/base.js"></script>
<button class="destroy"></button> <script src="bower_components/jquery/jquery.js"></script>
</div> <script src="bower_components/handlebars/handlebars.js"></script>
<input class="edit" value="{{title}}"> <script src="bower_components/spine/lib/spine.js"></script>
</li> <script src="bower_components/spine/lib/route.js"></script>
{{/this}} <script src="bower_components/spine/lib/local.js"></script>
</script>
<script src="bower_components/todomvc-common/base.js"></script>
<script src="bower_components/jquery/jquery.js"></script>
<script src="bower_components/handlebars/handlebars.js"></script>
<script src="bower_components/spine/lib/spine.js"></script>
<script src="bower_components/spine/lib/route.js"></script>
<script src="bower_components/spine/lib/local.js"></script>
<script src="js/controllers/todos.js"></script> <script src="js/controllers/todos.js"></script>
<script src="js/models/todo.js"></script> <script src="js/models/todo.js"></script>
<script src="js/app.js"></script> <script src="js/app.js"></script>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="yui"> <html lang="en" data-framework="yui">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>YUI • TodoMVC</title> <title>YUI • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" placeholder="What needs to be done?" autofocus> <input id="new-todo" placeholder="What needs to be done?" autofocus>
</header> </header>
<section id="main"> <section id="main">
<input id="toggle-all" type="checkbox"> <input id="toggle-all" type="checkbox">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list"></ul> <ul id="todo-list"></ul>
</section>
<footer id="footer"></footer>
</section> </section>
<footer id="footer"></footer> <footer id="info">
</section> <p>Double-click to edit a todo</p>
<footer id="info"> <p>Created by
<p>Double-click to edit a todo</p> <a href="https://github.com/clarle">Clarence Leung</a> and
<p>Created by <a href="https://twitter.com/ericf">Eric Ferraiuolo</a>
<a href="https://github.com/clarle">Clarence Leung</a> and </p>
<a href="https://twitter.com/ericf">Eric Ferraiuolo</a> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</p> </footer>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <script src="bower_components/todomvc-common/base.js"></script>
</footer> <script type="text/x-handlebars-template" id="item-template">
<script src="bower_components/todomvc-common/base.js"></script> <div class="view">
<script type="text/x-handlebars-template" id="item-template"> <input class="toggle" type="checkbox" {{#if completed}}checked{{/if}}>
<div class="view"> <label>{{title}}</label>
<input class="toggle" type="checkbox" {{#if completed}}checked{{/if}}> <button class="destroy"></button>
<label>{{title}}</label> </div>
<button class="destroy"></button> <input class="edit" value="{{title}}">
</div> </script>
<input class="edit" value="{{title}}"> <script type="text/x-handlebars-template" id="stats-template">
</script> <span id="todo-count"><strong>{{remaining}}</strong> {{pluralize remaining "item"}} left</span>
<script type="text/x-handlebars-template" id="stats-template"> <ul id="filters">
<span id="todo-count"><strong>{{remaining}}</strong> {{pluralize remaining "item"}} left</span> <li>
<ul id="filters"> <a class="selected" href="#/">All</a>
<li> </li>
<a class="selected" href="#/">All</a> <li>
</li> <a href="#/active">Active</a>
<li> </li>
<a href="#/active">Active</a> <li>
</li> <a href="#/completed">Completed</a>
<li> </li>
<a href="#/completed">Completed</a> </ul>
</li> {{#if completed}}
</ul> <button id="clear-completed">Clear completed ({{completed}})</button>
{{#if completed}} {{/if}}
<button id="clear-completed">Clear completed ({{completed}})</button> </script>
{{/if}} <script src="../../assets/base.js"></script>
</script> <script src="http://yui.yahooapis.com/3.11.0/build/yui/yui-min.js"></script>
<script src="../../assets/base.js"></script> <script>
<script src="http://yui.yahooapis.com/3.11.0/build/yui/yui-min.js"></script> YUI({
<script> groups: {
YUI({ 'todo-mvc': {
groups: { base: './js/',
'todo-mvc': { modules: {
base: './js/', 'todo': {
modules: { path: 'models/todo.js'
'todo': { },
path: 'models/todo.js' 'todo-list': {
}, path: 'models/todolist.js'
'todo-list': { },
path: 'models/todolist.js' 'todo-view': {
}, path: 'views/todoview.js'
'todo-view': { },
path: 'views/todoview.js' 'todo-app': {
}, path: 'app.js'
'todo-app': { }
path: 'app.js'
} }
} }
} }
} }).use('todo-app', function (Y) {
}).use('todo-app', function (Y) { new Y.TodoMVC.TodoApp();
new Y.TodoMVC.TodoApp(); });
}); </script>
</script> </body>
</body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="backbonejs"> <html lang="en" data-framework="backbonejs">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Backbone.js + RequireJS • TodoMVC</title> <title>Backbone.js + RequireJS • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" placeholder="What needs to be done?" autofocus> <input id="new-todo" placeholder="What needs to be done?" autofocus>
</header> </header>
<section id="main"> <section id="main">
<input id="toggle-all" type="checkbox"> <input id="toggle-all" type="checkbox">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list"></ul> <ul id="todo-list"></ul>
</section>
<footer id="footer"></footer>
</section> </section>
<footer id="footer"></footer> <footer id="info">
</section> <p>Double-click to edit a todo</p>
<footer id="info"> <p>Written by <a href="http://addyosmani.github.com/todomvc/">Addy Osmani</a></p>
<p>Double-click to edit a todo</p> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
<p>Written by <a href="http://addyosmani.github.com/todomvc/">Addy Osmani</a></p> </footer>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <script data-main="js/main" src="bower_components/requirejs/require.js"></script>
</footer> </body>
<script data-main="js/main" src="bower_components/requirejs/require.js"></script>
</body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="flight"> <html lang="en" data-framework="flight">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Flight • Todo</title> <title>Flight • Todo</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" placeholder="What needs to be done?" autofocus> <input id="new-todo" placeholder="What needs to be done?" autofocus>
</header> </header>
<section id="main"> <section id="main">
<input id="toggle-all" type="checkbox"> <input id="toggle-all" type="checkbox">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list"></ul> <ul id="todo-list"></ul>
</section>
<footer id="footer"></footer>
</section> </section>
<footer id="footer"></footer> <footer id="info">
</section> <p>Double-click to edit a todo</p>
<footer id="info"> <p>Created by <a href="http://github.com/mkuklis">Michal Kuklis</a></p>
<p>Double-click to edit a todo</p> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
<p>Created by <a href="http://github.com/mkuklis">Michal Kuklis</a></p> </footer>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <script src="bower_components/todomvc-common/base.js"></script>
</footer> <script data-main="app/js/main" src="bower_components/requirejs/requirejs.js"></script>
<script src="bower_components/todomvc-common/base.js"></script> </body>
<script data-main="app/js/main" src="bower_components/requirejs/requirejs.js"></script>
</body>
</html> </html>
This diff is collapsed.
<!doctype html> <!doctype html>
<html lang="en" data-framework="ariatemplates"> <html lang="en" data-framework="ariatemplates">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Aria Templates • TodoMVC</title> <title>Aria Templates • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
<link rel="stylesheet" href="css/app.css"> <link rel="stylesheet" href="css/app.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
</section> </section>
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<script src="js/lib/aria/ariatemplates-1.3.5.js"></script> <script src="js/lib/aria/ariatemplates-1.3.5.js"></script>
<script> <script>
// Update the path to the Todo module here when necessary // Update the path to the Todo module here when necessary
aria.core.DownloadMgr.updateRootMap({ aria.core.DownloadMgr.updateRootMap({
js: { js: {
'*': './' '*': './'
} }
}); });
// Here be todos // Here be todos
Aria.loadTemplate({ Aria.loadTemplate({
div: 'todoapp', div: 'todoapp',
classpath: 'js.view.Todo', classpath: 'js.view.Todo',
moduleCtrl: { moduleCtrl: {
classpath: 'js.TodoCtrl' classpath: 'js.TodoCtrl'
} }
}); });
</script> </script>
<footer id="info"> <footer id="info">
<p>Double-click to edit a todo</p> <p>Double-click to edit a todo</p>
<p>Written by <a href="http://ariatemplates.com">Olaf Kappes</a></p> <p>Written by <a href="http://ariatemplates.com">Olaf Kappes</a></p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</footer> </footer>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="backbonejs"> <html lang="en" data-framework="backbonejs">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Backbone.js • TodoMVC</title> <title>Backbone.js • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" placeholder="What needs to be done?" autofocus> <input id="new-todo" placeholder="What needs to be done?" autofocus>
</header> </header>
<section id="main"> <section id="main">
<input id="toggle-all" type="checkbox"> <input id="toggle-all" type="checkbox">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list"></ul> <ul id="todo-list"></ul>
</section>
<footer id="footer"></footer>
</section> </section>
<footer id="footer"></footer> <footer id="info">
</section> <p>Double-click to edit a todo</p>
<footer id="info"> <p>Written by <a href="https://github.com/addyosmani">Addy Osmani</a></p>
<p>Double-click to edit a todo</p> <p>Adapted for
<p>Written by <a href="https://github.com/addyosmani">Addy Osmani</a></p> <a href="https://github.com/ggozad/Backbone.xmpp">Backbone.xmpp</a>
<p>Adapted for by <a href="https://github.com/ggozad">Yiorgis Gozadinos</a></p>
<a href="https://github.com/ggozad/Backbone.xmpp">Backbone.xmpp</a> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
by <a href="https://github.com/ggozad">Yiorgis Gozadinos</a></p> </footer>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <script type="text/template" id="item-template">
</footer> <div class="view">
<script type="text/template" id="item-template"> <input class="toggle" type="checkbox" <%= completed ? 'checked' : '' %>>
<div class="view"> <label><%- title %></label>
<input class="toggle" type="checkbox" <%= completed ? 'checked' : '' %>> <button class="destroy"></button>
<label><%- title %></label> </div>
<button class="destroy"></button> <input class="edit" value="<%- title %>">
</div> </script>
<input class="edit" value="<%- title %>"> <script type="text/template" id="stats-template">
</script> <span id="todo-count"><strong><%= remaining %></strong> <%= remaining === 1 ? 'item' : 'items' %> left</span>
<script type="text/template" id="stats-template"> <ul id="filters">
<span id="todo-count"><strong><%= remaining %></strong> <%= remaining === 1 ? 'item' : 'items' %> left</span> <li>
<ul id="filters"> <a class="selected" href="#/">All</a>
<li> </li>
<a class="selected" href="#/">All</a> <li>
</li> <a href="#/active">Active</a>
<li> </li>
<a href="#/active">Active</a> <li>
</li> <a href="#/completed">Completed</a>
<li> </li>
<a href="#/completed">Completed</a> </ul>
</li> <% if (completed) { %>
</ul> <button id="clear-completed">Clear completed (<%= completed %>)</button>
<% if (completed) { %> <% } %>
<button id="clear-completed">Clear completed (<%= completed %>)</button> </script>
<% } %> <script src="bower_components/todomvc-common/base.js"></script>
</script> <script src="bower_components/jquery/jquery.js"></script>
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/lodash/lodash.js"></script>
<script src="bower_components/jquery/jquery.js"></script> <script src="bower_components/backbone/backbone.js"></script>
<script src="bower_components/lodash/lodash.js"></script> <script src="bower_components/Strophe.js/strophe.js"></script>
<script src="bower_components/backbone/backbone.js"></script> <script src="js/lib/strophe.forms.js"></script>
<script src="bower_components/Strophe.js/strophe.js"></script> <script src="js/lib/strophe.pubsub.js"></script>
<script src="js/lib/strophe.forms.js"></script> <script src="js/lib/backbone.xmpp.storage.js"></script>
<script src="js/lib/strophe.pubsub.js"></script> <script src="js/lib/backbone.xmpp.node.js"></script>
<script src="js/lib/backbone.xmpp.storage.js"></script> <script src="js/models/todo.js"></script>
<script src="js/lib/backbone.xmpp.node.js"></script> <script src="js/collections/todos.js"></script>
<script src="js/models/todo.js"></script> <script src="js/views/todos.js"></script>
<script src="js/collections/todos.js"></script> <script src="js/views/app.js"></script>
<script src="js/views/todos.js"></script> <script src="js/routers/router.js"></script>
<script src="js/views/app.js"></script> <script src="js/app.js"></script>
<script src="js/routers/router.js"></script> </body>
<script src="js/app.js"></script>
</body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="marionettejs"> <html lang="en" data-framework="marionettejs">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Marionette • TodoMVC</title> <title>Marionette • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
<link rel="stylesheet" href="css/app.css"> <link rel="stylesheet" href="css/app.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"></header> <header id="header"></header>
<section id="main"></section> <section id="main"></section>
<footer id="footer"></footer> <footer id="footer"></footer>
</section> </section>
<footer id="info"> <footer id="info">
<p>Double-click to edit a todo</p> <p>Double-click to edit a todo</p>
<p> <p>
Created by <a href="http://github.com/jsoverson">Jarrod Overson</a> Created by <a href="http://github.com/jsoverson">Jarrod Overson</a>
and <a href="http://github.com/derickbailey">Derick Bailey</a> and <a href="http://github.com/derickbailey">Derick Bailey</a>
using <a href="http://marionettejs.com">Backbone.Marionette</a> using <a href="http://marionettejs.com">Backbone.Marionette</a>
</p> </p>
<p>Further variations on the Backbone.Marionette app are also <a href="https://github.com/marionettejs/backbone.marionette/wiki/Projects-and-websites-using-marionette">available</a>.</p> <p>Further variations on the Backbone.Marionette app are also <a href="https://github.com/marionettejs/backbone.marionette/wiki/Projects-and-websites-using-marionette">available</a>.</p>
</footer> </footer>
<script type="text/html" id="template-footer"> <script type="text/html" id="template-footer">
<span id="todo-count"> <span id="todo-count">
<strong><%= activeCount %></strong> <%= activeCountLabel() %> <strong><%= activeCount %></strong> <%= activeCountLabel() %>
</span> </span>
<ul id="filters"> <ul id="filters">
<li> <li>
<a href="#">All</a> <a href="#">All</a>
</li> </li>
<li> <li>
<a href="#active">Active</a> <a href="#active">Active</a>
</li> </li>
<li> <li>
<a href="#completed">Completed</a> <a href="#completed">Completed</a>
</li> </li>
</ul> </ul>
<button id="clear-completed" <% if (!completedCount) { %>class="hidden"<% } %>> <button id="clear-completed" <% if (!completedCount) { %>class="hidden"<% } %>>
Clear completed (<%= completedCount %>) Clear completed (<%= completedCount %>)
</button> </button>
</script> </script>
<script type="text/html" id="template-header"> <script type="text/html" id="template-header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" placeholder="What needs to be done?" autofocus> <input id="new-todo" placeholder="What needs to be done?" autofocus>
</script> </script>
<script type="text/html" id="template-todoItemView"> <script type="text/html" id="template-todoItemView">
<div class="view"> <div class="view">
<input class="toggle" type="checkbox" <% if (completed) { %>checked<% } %>> <input class="toggle" type="checkbox" <% if (completed) { %>checked<% } %>>
<label><%- title %></label> <label><%- title %></label>
<button class="destroy"></button> <button class="destroy"></button>
</div> </div>
<input class="edit" value="<%- title %>"> <input class="edit" value="<%- title %>">
</script> </script>
<script type="text/html" id="template-todoListCompositeView"> <script type="text/html" id="template-todoListCompositeView">
<input id="toggle-all" type="checkbox"> <input id="toggle-all" type="checkbox">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list"></ul> <ul id="todo-list"></ul>
</script> </script>
<!-- vendor libraries --> <!-- vendor libraries -->
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<script src="bower_components/jquery/jquery.js"></script> <script src="bower_components/jquery/jquery.js"></script>
<script src="bower_components/underscore/underscore.js"></script> <script src="bower_components/underscore/underscore.js"></script>
<script src="bower_components/backbone/backbone.js"></script> <script src="bower_components/backbone/backbone.js"></script>
<script src="bower_components/backbone.localStorage/backbone.localStorage.js"></script> <script src="bower_components/backbone.localStorage/backbone.localStorage.js"></script>
<script src="bower_components/backbone.marionette/lib/backbone.marionette.js"></script> <script src="bower_components/backbone.marionette/lib/backbone.marionette.js"></script>
<!-- application --> <!-- application -->
<script src="js/TodoMVC.js"></script> <script src="js/TodoMVC.js"></script>
<script src="js/TodoMVC.Todos.js"></script> <script src="js/TodoMVC.Todos.js"></script>
<script src="js/TodoMVC.Layout.js"></script> <script src="js/TodoMVC.Layout.js"></script>
<script src="js/TodoMVC.TodoList.Views.js"></script> <script src="js/TodoMVC.TodoList.Views.js"></script>
<script src="js/TodoMVC.TodoList.js"></script> <script src="js/TodoMVC.TodoList.js"></script>
<script> <script>
$(function () { $(function () {
// start the TodoMVC app (defined in js/TodoMVC.js) // start the TodoMVC app (defined in js/TodoMVC.js)
TodoMVC.start(); TodoMVC.start();
}); });
</script> </script>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="batman"> <html lang="en" data-framework="batman">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Batman • TodoMVC</title> <title>Batman • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<div data-yield="main"></div> <div data-yield="main"></div>
<div data-defineview="todos/all"> <div data-defineview="todos/all">
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<form data-formfor-todo="newTodo" data-event-submit="createTodo"> <form data-formfor-todo="newTodo" data-event-submit="createTodo">
<input id="new-todo" type="text" placeholder="What needs to be completed?" autofocus data-bind="todo.title"> <input id="new-todo" type="text" placeholder="What needs to be completed?" autofocus data-bind="todo.title">
</form> </form>
</header> </header>
<section id="main" class="hidden" data-removeclass-hidden="Todo.all.length"> <section id="main" class="hidden" data-removeclass-hidden="Todo.all.length">
<input id="toggle-all" type="checkbox" data-event-change="toggleAll" data-source="Todo.completed.length | equals Todo.all.length"> <input id="toggle-all" type="checkbox" data-event-change="toggleAll" data-source="Todo.completed.length | equals Todo.all.length">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list"> <ul id="todo-list">
<li data-foreach-todo="currentTodos" <li data-foreach-todo="currentTodos"
data-addclass-completed="todo.completed" data-addclass-completed="todo.completed"
data-addclass-editing="todo.editing" > data-addclass-editing="todo.editing" >
<div class="view" data-hideif="todo.editing"> <div class="view" data-hideif="todo.editing">
<input class="toggle" type="checkbox" data-bind="todo.completed" data-event-change="todoDoneChanged"> <input class="toggle" type="checkbox" data-bind="todo.completed" data-event-change="todoDoneChanged">
<label data-bind="todo.title" data-event-doubleclick="toggleEditing"></label> <label data-bind="todo.title" data-event-doubleclick="toggleEditing"></label>
<button class="destroy" data-event-click="destroyTodo"></button> <button class="destroy" data-event-click="destroyTodo"></button>
</div> </div>
<input class="edit" type="text" <input class="edit" type="text"
data-bind="todo.title" data-bind="todo.title"
data-bind-id="'todo-input-' | append todo.id" data-bind-id="'todo-input-' | append todo.id"
data-event-blur="toggleEditing" data-event-blur="toggleEditing"
data-event-keypress="disableEditingUponSubmit"> data-event-keypress="disableEditingUponSubmit">
</li> </li>
</ul> </ul>
</section>
<footer id="footer" class="hidden" data-removeclass-hidden="Todo.all.length">
<span id="todo-count">
<strong data-bind="Todo.active.length"></strong>
<span data-bind="'item' | pluralize Todo.active.length, false"></span> left
</span>
<ul id="filters">
<li>
<a data-addclass-selected="currentRoute.action | equals 'all'" data-route="'/'">All</a>
</li>
<li>
<a data-addclass-selected="currentRoute.action | equals 'active'" data-route="'/active'">Active</a>
</li>
<li>
<a data-addclass-selected="currentRoute.action | equals 'completed'" data-route="'/completed'">Completed</a>
</li>
</ul>
<button id="clear-completed" data-event-click="clearCompleted" data-showif="Todo.completed.length">
Clear completed (<span data-bind="Todo.completed.length"></span>)
</button>
</footer>
</section> </section>
<footer id="footer" class="hidden" data-removeclass-hidden="Todo.all.length"> <footer id="info">
<span id="todo-count"> <p>Double-click to edit a todo</p>
<strong data-bind="Todo.active.length"></strong> <p>Created by <a href="http://batmanjs.org">Harry Brundage</a></p>
<span data-bind="'item' | pluralize Todo.active.length, false"></span> left <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</span>
<ul id="filters">
<li>
<a data-addclass-selected="currentRoute.action | equals 'all'" data-route="'/'">All</a>
</li>
<li>
<a data-addclass-selected="currentRoute.action | equals 'active'" data-route="'/active'">Active</a>
</li>
<li>
<a data-addclass-selected="currentRoute.action | equals 'completed'" data-route="'/completed'">Completed</a>
</li>
</ul>
<button id="clear-completed" data-event-click="clearCompleted" data-showif="Todo.completed.length">
Clear completed (<span data-bind="Todo.completed.length"></span>)
</button>
</footer> </footer>
</section> </div>
<footer id="info"> <script src="bower_components/todomvc-common/base.js"></script>
<p>Double-click to edit a todo</p> <script src="bower_components/batman/lib/dist/batman.js"></script>
<p>Created by <a href="http://batmanjs.org">Harry Brundage</a></p> <script src="app.js"></script>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> </body>
</footer>
</div>
<script src="bower_components/todomvc-common/base.js"></script>
<script src="bower_components/batman/lib/dist/batman.js"></script>
<script src="app.js"></script>
</body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="cujo"> <html lang="en" data-framework="cujo">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>cujo • TodoMVC</title> <title>cujo • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<section id="todoapp"></section> <section id="todoapp"></section>
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<script data-curl-run="app/run" src="bower_components/curl/src/curl.js"></script> <script data-curl-run="app/run" src="bower_components/curl/src/curl.js"></script>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="dermis"> <html lang="en" data-framework="dermis">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Dermis • TodoMVC</title> <title>Dermis • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" placeholder="What needs to be done?" autofocus> <input id="new-todo" placeholder="What needs to be done?" autofocus>
</header> </header>
<div id="content"> <div id="content">
<section id="main" data-show=". | length | overZero"> <section id="main" data-show=". | length | overZero">
<input id="toggle-all" type="checkbox" data-on-click=":toggle" data-checked=":allCompleted < . .child" data-show=":all < . | length | overZero"> <input id="toggle-all" type="checkbox" data-on-click=":toggle" data-checked=":allCompleted < . .child" data-show=":all < . | length | overZero">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list"> <ul id="todo-list">
<li data-each-todo=":todos < . .mode" data-class-completed="todo.completed" data-class-editing="todo.editable"> <li data-each-todo=":todos < . .mode" data-class-completed="todo.completed" data-class-editing="todo.editable">
<div class="view"> <div class="view">
<input class="toggle" type="checkbox" data-checked="todo.completed"> <input class="toggle" type="checkbox" data-checked="todo.completed">
<label data-text="todo.title" data-on-dblclick="todo:setEditable"></label> <label data-text="todo.title" data-on-dblclick="todo:setEditable"></label>
<button class="destroy" data-on-click="todo:destroy"></button> <button class="destroy" data-on-click="todo:destroy"></button>
</div> </div>
<input class="edit" data-value="todo.title" data-on-blur="todo:save" data-on-change="todo:save"> <input class="edit" data-value="todo.title" data-on-blur="todo:save" data-on-change="todo:save">
</li> </li>
</ul> </ul>
</section>
<footer id="footer" data-show=":all < . .child | length | overZero">
<span id="todo-count">
<strong data-text=":active < . .child | length"></strong>
item<span data-show=":active < . .child | length | plural">s</span> left
</span>
<ul id="filters">
<li>
<a href="#/">All</a>
</li>
<li>
<a href="#/active">Active</a>
</li>
<li>
<a href="#/completed">Completed</a>
</li>
</ul>
<button id="clear-completed" data-on-click=":clear" data-show=":completed < . .child | length | overZero">Clear completed (<span data-text=":completed < . .child | length"></span>)
</button>
</footer>
</section> </section>
<footer id="footer" data-show=":all < . .child | length | overZero"> </div>
<span id="todo-count"> <footer id="info">
<strong data-text=":active < . .child | length"></strong> <p>Double-click to edit a todo</p>
item<span data-show=":active < . .child | length | plural">s</span> left <p>Created by <a href="http://github.com/Contra">Contra</a></p>
</span> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
<ul id="filters"> </footer>
<li>
<a href="#/">All</a>
</li>
<li>
<a href="#/active">Active</a>
</li>
<li>
<a href="#/completed">Completed</a>
</li>
</ul>
<button id="clear-completed" data-on-click=":clear" data-show=":completed < . .child | length | overZero">Clear completed (<span data-text=":completed < . .child | length"></span>)
</button>
</footer>
</section>
</div>
<footer id="info">
<p>Double-click to edit a todo</p>
<p>Created by <a href="http://github.com/Contra">Contra</a></p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</footer>
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<script src="bower_components/jquery/jquery.js"></script> <script src="bower_components/jquery/jquery.js"></script>
<script src="bower_components/requirejs/require.js"></script> <script src="bower_components/requirejs/require.js"></script>
<script src="js/lib/dermis.js"></script> <script src="js/lib/dermis.js"></script>
<script src="js/app.js"></script> <script src="js/app.js"></script>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="dijon"> <html lang="en" data-framework="dijon">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Dijon • TodoMVC</title> <title>Dijon • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" placeholder="What needs to be done?" autofocus> <input id="new-todo" placeholder="What needs to be done?" autofocus>
</header> </header>
<section id="main"> <section id="main">
<input id="toggle-all" type="checkbox"> <input id="toggle-all" type="checkbox">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list"></ul> <ul id="todo-list"></ul>
</section>
<footer id="footer">
<span id="todo-count"><strong>0</strong> item left</span>
<button id="clear-completed">Clear completed</button>
</footer>
</section> </section>
<footer id="footer"> <footer id="info">
<span id="todo-count"><strong>0</strong> item left</span> <p>Double-click to edit a todo</p>
<button id="clear-completed">Clear completed</button> <p>Based on app by <a href="http://github.com/sindresorhus">Sindre Sorhus</a></p>
<p>Created by <a href="http://www.creynders.be">Camille Reynders</a></p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</footer> </footer>
</section> <script type="text/x-handlebars-template" id="todo-template">
<footer id="info"> {{#this}}
<p>Double-click to edit a todo</p> <li {{#if completed}}class="completed"{{/if}} data-id="{{id}}">
<p>Based on app by <a href="http://github.com/sindresorhus">Sindre Sorhus</a></p> <div class="view">
<p>Created by <a href="http://www.creynders.be">Camille Reynders</a></p> <input class="toggle" type="checkbox" {{#if completed}}checked{{/if}}>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <label>{{title}}</label>
</footer> <button class="destroy"></button>
<script type="text/x-handlebars-template" id="todo-template"> </div>
{{#this}} <input class="edit" value="{{title}}">
<li {{#if completed}}class="completed"{{/if}} data-id="{{id}}"> </li>
<div class="view"> {{/this}}
<input class="toggle" type="checkbox" {{#if completed}}checked{{/if}}> </script>
<label>{{title}}</label> <script src="bower_components/todomvc-common/base.js"></script>
<button class="destroy"></button> <script src="bower_components/jquery/jquery.js"></script>
</div> <script src="bower_components/handlebars.js/handlebars.js"></script>
<input class="edit" value="{{title}}"> <script src="js/lib/dijon-0.5.3.min.js"></script>
</li> <script src="js/config.js"></script>
{{/this}} <script src="js/models/TodosModel.js"></script>
</script> <script src="js/services/LocalStorageService.js"></script>
<script src="bower_components/todomvc-common/base.js"></script> <script src="js/utils/Utils.js"></script>
<script src="bower_components/jquery/jquery.js"></script> <script src="js/views/FooterView.js"></script>
<script src="bower_components/handlebars.js/handlebars.js"></script> <script src="js/views/TodoFormView.js"></script>
<script src="js/lib/dijon-0.5.3.min.js"></script> <script src="js/views/TodoListView.js"></script>
<script src="js/config.js"></script> <script src="js/app.js"></script>
<script src="js/models/TodosModel.js"></script> </body>
<script src="js/services/LocalStorageService.js"></script>
<script src="js/utils/Utils.js"></script>
<script src="js/views/FooterView.js"></script>
<script src="js/views/TodoFormView.js"></script>
<script src="js/views/TodoListView.js"></script>
<script src="js/app.js"></script>
</body>
</html> </html>
<!DOCTYPE html> <!DOCTYPE html>
<html lang="en" data-framework="duel"> <html lang="en" data-framework="duel">
<head> <head>
<meta charset="utf-8" /> <meta charset="utf-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" /> <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
<title>DUEL &#x2022; TodoMVC</title> <title>DUEL &#x2022; TodoMVC</title>
<link rel="stylesheet" href="./cdn/d764469b1882372019d07f8c1174b1d64507e56d.css" /> <link rel="stylesheet" href="./cdn/d764469b1882372019d07f8c1174b1d64507e56d.css" />
</head> </head>
<body> <body>
<footer id="info"> <footer id="info">
<p>Double-click to edit a todo</p> <p>Double-click to edit a todo</p>
<p>Ported to <a href="http://duelengine.org">DUEL</a> by <a href="http://mck.me">Stephen McKamey</a></p> <p>Ported to <a href="http://duelengine.org">DUEL</a> by <a href="http://mck.me">Stephen McKamey</a></p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</footer> </footer>
<script src="./cdn/4340176df828f72a94b201a48c223860b95908dc.js"></script> <script src="./cdn/4340176df828f72a94b201a48c223860b95908dc.js"></script>
</body>
</body> </html>
</html>
\ No newline at end of file
<!doctype html> <!doctype html>
<html lang="en" data-framework="epitome"> <html lang="en" data-framework="epitome">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Epitome • TodoMVC</title> <title>Epitome • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" placeholder="What needs to be done?" autofocus> <input id="new-todo" placeholder="What needs to be done?" autofocus>
</header> </header>
<section id="main"> <section id="main">
<input id="toggle-all" type="checkbox"> <input id="toggle-all" type="checkbox">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list"></ul> <ul id="todo-list"></ul>
</section>
<footer id="footer"></footer>
</section> </section>
<footer id="footer"></footer> <footer id="info">
</section> <p>Double-click to edit a todo</p>
<footer id="info"> <p>Created by <a href="https://github.com/DimitarChristoff/">Dimitar Christoff</a></p>
<p>Double-click to edit a todo</p> <p>Powered by <a href="http://epitome-mvc.github.io/Epitome">Epitome for MooTools</a></p>
<p>Created by <a href="https://github.com/DimitarChristoff/">Dimitar Christoff</a></p> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
<p>Powered by <a href="http://epitome-mvc.github.io/Epitome">Epitome for MooTools</a></p> </footer>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <script type="text/template" id="item-template">
</footer> <div class="view">
<script type="text/template" id="item-template"> <input class="toggle" type="checkbox" <%=completedCheckbox%>>
<div class="view"> <label><%-title%></label>
<input class="toggle" type="checkbox" <%=completedCheckbox%>> <button class="destroy"></button>
<label><%-title%></label> </div>
<button class="destroy"></button> <input class="edit" value="<%=title%>">
</div> </script>
<input class="edit" value="<%=title%>"> <script type="text/template" id="stats-template">
</script> <span id="todo-count">
<script type="text/template" id="stats-template"> <strong><%=remaining%></strong> item<% if (obj.remaining !== 1) { %>s<% } %> left
<span id="todo-count"> </span>
<strong><%=remaining%></strong> item<% if (obj.remaining !== 1) { %>s<% } %> left <ul id="filters">
</span> <li>
<ul id="filters"> <a class="selected" href="#!/">All</a>
<li> </li>
<a class="selected" href="#!/">All</a> <li>
</li> <a href="#!/active">Active</a>
<li> </li>
<a href="#!/active">Active</a> <li>
</li> <a href="#!/completed">Completed</a>
<li> </li>
<a href="#!/completed">Completed</a> </ul>
</li> <% if (completed) { %>
</ul> <button id="clear-completed">Clear completed (<%=completed%>)</button>
<% if (completed) { %> <% } %>
<button id="clear-completed">Clear completed (<%=completed%>)</button> </script>
<% } %> <script src="bower_components/todomvc-common/base.js"></script>
</script> <!-- mootools -->
<script src="bower_components/todomvc-common/base.js"></script> <script src="js/lib/mootools-yui-compressed.js"></script>
<!-- mootools --> <!-- epitome pre-compiled -->
<script src="js/lib/mootools-yui-compressed.js"></script> <script src="bower_components/Epitome/Epitome-min.js"></script>
<!-- epitome pre-compiled --> <!-- todo app -->
<script src="bower_components/Epitome/Epitome-min.js"></script> <script src="js/models/todo-model.js"></script>
<!-- todo app --> <script src="js/collections/todo-collection.js"></script>
<script src="js/models/todo-model.js"></script> <script src="js/views/todo-list.js"></script>
<script src="js/collections/todo-collection.js"></script> <script src="js/views/todo-main.js"></script>
<script src="js/views/todo-list.js"></script> <script src="js/controllers/todo-router.js"></script>
<script src="js/views/todo-main.js"></script> <script src="js/app.js"></script>
<script src="js/controllers/todo-router.js"></script> </body>
<script src="js/app.js"></script>
</body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en"> <html lang="en">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>ExtJS • TodoMVC</title> <title>ExtJS • TodoMVC</title>
<!-- <link rel="stylesheet" href="bower_components/todomvc-common/base.css"> --> <!-- <link rel="stylesheet" href="bower_components/todomvc-common/base.css"> -->
<link rel="stylesheet" href="css/app.css"> <link rel="stylesheet" href="css/app.css">
</head> </head>
<body> <body>
<div id="todoapp"> <div id="todoapp">
<header> <header>
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" type="text" placeholder="What needs to be done?"> <input id="new-todo" type="text" placeholder="What needs to be done?">
</header> </header>
<section id="main"></section> <section id="main"></section>
</div> </div>
<div id="instructions"> <div id="instructions">
Double-click to edit a todo Double-click to edit a todo
</div> </div>
<div id="credits"> <div id="credits">
Created by <a href="http://revolunet.com/">Revolunet</a><br /> Created by <a href="http://revolunet.com/">Revolunet</a><br />
Updates by <a href="http://github.com/boushley">Aaron Boushley</a> Updates by <a href="http://github.com/boushley">Aaron Boushley</a>
</div> </div>
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<script src="http://cdn.sencha.com/ext-4.1.1-gpl/bootstrap.js"></script> <script src="http://cdn.sencha.com/ext-4.1.1-gpl/bootstrap.js"></script>
<script src="js/app.js"></script> <script src="js/app.js"></script>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="deftjs"> <html lang="en" data-framework="deftjs">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>ExtJS with DeftJS • TodoMVC</title> <title>ExtJS with DeftJS • TodoMVC</title>
<!-- CSS --> <!-- CSS -->
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
<link rel="stylesheet" href="css/app.css"> <link rel="stylesheet" href="css/app.css">
</head> </head>
<body> <body>
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<!-- ExtJS --> <!-- ExtJS -->
<script src="lib/extjs/ext-all.js"></script> <script src="lib/extjs/ext-all.js"></script>
<!-- Application --> <!-- Application -->
<script src="js/app-loader.js"></script> <script src="js/app-loader.js"></script>
<script src="lib/deft/deft.js"></script> <script src="lib/deft/deft.js"></script>
<script src="js/app.js"></script> <script src="js/app.js"></script>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="kendo"> <html lang="en" data-framework="kendo">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Kendo UI • TodoMVC</title> <title>Kendo UI • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" data-bind="enter: saveTodo" <input id="new-todo" data-bind="enter: saveTodo"
placeholder="What needs to be done?" autofocus> placeholder="What needs to be done?" autofocus>
</header> </header>
<section id="main" data-bind="visible: isVisible"> <section id="main" data-bind="visible: isVisible">
<input id="toggle-all" type="checkbox" data-bind="click: toggleAll, checked: allCompleted"> <input id="toggle-all" type="checkbox" data-bind="click: toggleAll, checked: allCompleted">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list" data-role="listview" data-template="item-template" data-bind="source: todos"></ul> <ul id="todo-list" data-role="listview" data-template="item-template" data-bind="source: todos"></ul>
</section>
<footer id="footer" data-bind="visible: isVisible">
<span id="todo-count">
<strong data-bind="text: activeCount"></strong>
<span data-bind="text: activeCountText"></span> left
</span>
<ul id="filters">
<li>
<a href="#/" data-bind="attr: { class: allFilterClass }">All</a>
</li>
<li>
<a href="#/active" data-bind="attr: { class: activeFilterClass }">Active</a>
</li>
<li>
<a href="#/completed" data-bind="attr: { class: completedFilterClass }">Completed</a>
</li>
</ul>
<button id="clear-completed"
data-bind="click: destroyCompleted,
visible: completedCount,
text: clearCompletedText">
</button>
</footer>
</section> </section>
<footer id="footer" data-bind="visible: isVisible"> <div id="info">
<span id="todo-count"> <p>Double-click to edit a todo</p>
<strong data-bind="text: activeCount"></strong> <p>Credits <a href="https://github.com/bsatrom">Brandon Satrom</a>, <a href="https://github.com/burkeholland">Burke Holland</a> &amp; <a href="https://github.com/akorchev">Atanas Korchev</a></p>
<span data-bind="text: activeCountText"></span> left <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</span> </div>
<ul id="filters"> <script type="text/template" id="item-template">
<li> <li data-bind="attr: { class: todoItemClass }">
<a href="#/" data-bind="attr: { class: allFilterClass }">All</a> <div class="view">
<input class="toggle" type="checkbox" data-bind="checked: completed, events: { change: sync }">
<label data-bind="text: title, events: { dblclick: startEdit } "></label>
<button class="destroy" data-bind="click: destroy">
</button>
</div>
<input class="edit" data-bind="value: title, events: { change: endEdit, blur: endEdit }, enter: endEdit">
</li> </li>
<li> </script>
<a href="#/active" data-bind="attr: { class: activeFilterClass }">Active</a> <script src="bower_components/todomvc-common/base.js"></script>
</li> <script src="bower_components/jquery/jquery.js"></script>
<li> <script src="js/lib/kendo.web.js"></script>
<a href="#/completed" data-bind="attr: { class: completedFilterClass }">Completed</a> <script src="js/lib/kendo.bindings.custom.js"></script>
</li> <script src="js/lib/kendo.data.localstoragedatasource.js"></script>
</ul> <script src="js/app.js"></script>
<button id="clear-completed" </body>
data-bind="click: destroyCompleted,
visible: completedCount,
text: clearCompletedText">
</button>
</footer>
</section>
<div id="info">
<p>Double-click to edit a todo</p>
<p>Credits <a href="https://github.com/bsatrom">Brandon Satrom</a>, <a href="https://github.com/burkeholland">Burke Holland</a> &amp; <a href="https://github.com/akorchev">Atanas Korchev</a></p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</div>
<script type="text/template" id="item-template">
<li data-bind="attr: { class: todoItemClass }">
<div class="view">
<input class="toggle" type="checkbox" data-bind="checked: completed, events: { change: sync }">
<label data-bind="text: title, events: { dblclick: startEdit } "></label>
<button class="destroy" data-bind="click: destroy">
</button>
</div>
<input class="edit" data-bind="value: title, events: { change: endEdit, blur: endEdit }, enter: endEdit">
</li>
</script>
<script src="bower_components/todomvc-common/base.js"></script>
<script src="bower_components/jquery/jquery.js"></script>
<script src="js/lib/kendo.web.js"></script>
<script src="js/lib/kendo.bindings.custom.js"></script>
<script src="js/lib/kendo.data.localstoragedatasource.js"></script>
<script src="js/app.js"></script>
</body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="knockoutjs"> <html lang="en" data-framework="knockoutjs">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta content="IE=edge,chrome=1" http-equiv="X-UA-Compatible"> <meta content="IE=edge,chrome=1" http-equiv="X-UA-Compatible">
<title>Knockout.js • TodoMVC</title> <title>Knockout.js • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" data-class="todos.new" placeholder="What needs to be done?" autofocus> <input id="new-todo" data-class="todos.new" placeholder="What needs to be done?" autofocus>
</header> </header>
<section id="main" data-class="todos.listVisible"> <section id="main" data-class="todos.listVisible">
<input id="toggle-all" data-class="todos.allCompleted" type="checkbox"> <input id="toggle-all" data-class="todos.allCompleted" type="checkbox">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list" data-class="todos.foreach"> <ul id="todo-list" data-class="todos.foreach">
<li data-class="todos.todo.item"> <li data-class="todos.todo.item">
<div class="view"> <div class="view">
<input class="toggle" data-class="todos.todo.completed" type="checkbox"> <input class="toggle" data-class="todos.todo.completed" type="checkbox">
<label data-class="todos.todo.readOnlyValue"></label> <label data-class="todos.todo.readOnlyValue"></label>
<button class="destroy" data-class="todos.todo.destroy"></button> <button class="destroy" data-class="todos.todo.destroy"></button>
</div> </div>
<input class="edit" data-class="todos.todo.editingValue"> <input class="edit" data-class="todos.todo.editingValue">
</li> </li>
</ul> </ul>
</section>
<footer id="footer" data-class="footer.isVisible">
<span id="todo-count">
<strong data-class="footer.remainingCount">0</strong>
<span data-class="footer.remainingCountText"></span> left
</span>
<ul id="filters">
<li>
<a data-class="footer.filters.all" href="#/all">All</a>
</li>
<li>
<a data-class="footer.filters.active" href="#/active">Active</a>
</li>
<li>
<a data-class="footer.filters.completed" href="#/completed">Completed</a>
</li>
</ul>
<button id="clear-completed" data-class="footer.clearCompleted">
Clear completed (<span data-class="footer.completedCount"></span>)
</button>
</footer>
</section> </section>
<footer id="footer" data-class="footer.isVisible"> <footer id="info">
<span id="todo-count"> <p>Double-click to edit a todo</p>
<strong data-class="footer.remainingCount">0</strong> <p>Original Knockout version from <a href="https://github.com/ashish01/knockoutjs-todos" target="_blank">Ashish Sharma</a></p>
<span data-class="footer.remainingCountText"></span> left <p>Rewritten to use Knockout 2.0 and standard template by <a href="http://knockmeout.net" target="_blank">Ryan Niemeyer</a></p>
</span> <p>Patches/fixes for cross-browser compat: <a href="http://twitter.com/addyosmani" target="_blank">Addy Osmani</a></p>
<ul id="filters"> <p>Implemented Knockout classBindingProvider: <a href="http://github.com/mberkom" target="_blank">Michael Berkompas</a></p>
<li>
<a data-class="footer.filters.all" href="#/all">All</a>
</li>
<li>
<a data-class="footer.filters.active" href="#/active">Active</a>
</li>
<li>
<a data-class="footer.filters.completed" href="#/completed">Completed</a>
</li>
</ul>
<button id="clear-completed" data-class="footer.clearCompleted">
Clear completed (<span data-class="footer.completedCount"></span>)
</button>
</footer> </footer>
</section> <script src="bower_components/todomvc-common/base.js"></script>
<footer id="info"> <script src="bower_components/director/build/director.js"></script>
<p>Double-click to edit a todo</p> <script src="bower_components/knockout.js/knockout.js"></script>
<p>Original Knockout version from <a href="https://github.com/ashish01/knockoutjs-todos" target="_blank">Ashish Sharma</a></p> <script src="js/lib/knockout-classBindingProvider.min.js"></script>
<p>Rewritten to use Knockout 2.0 and standard template by <a href="http://knockmeout.net" target="_blank">Ryan Niemeyer</a></p> <script src="js/app.js"></script>
<p>Patches/fixes for cross-browser compat: <a href="http://twitter.com/addyosmani" target="_blank">Addy Osmani</a></p> </body>
<p>Implemented Knockout classBindingProvider: <a href="http://github.com/mberkom" target="_blank">Michael Berkompas</a></p>
</footer>
<script src="bower_components/todomvc-common/base.js"></script>
<script src="bower_components/director/build/director.js"></script>
<script src="bower_components/knockout.js/knockout.js"></script>
<script src="js/lib/knockout-classBindingProvider.min.js"></script>
<script src="js/app.js"></script>
</body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="montage" id="montage-todomvc"> <html lang="en" data-framework="montage" id="montage-todomvc">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Montage • TodoMVC</title> <title>Montage • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
<link rel="stylesheet" href="assets/app.css"> <link rel="stylesheet" href="assets/app.css">
</head> </head>
<body> <body>
<div id="todo-container"></div> <div id="todo-container"></div>
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<script src="bundle-0-d67ccde.js" <script src="bundle-0-d67ccde.js"
data-montage="packages/montage@4763f06/" data-montage="packages/montage@4763f06/"
data-montage-hash="4763f06" data-montage-hash="4763f06"
data-application-hash="1156f40"></script> data-application-hash="1156f40"></script>
<script type="text/montage-serialization"> <script type="text/montage-serialization">
{ {
"owner": { "owner": {
"prototype": "montage/ui/loader.reel", "prototype": "montage/ui/loader.reel",
"properties": { "properties": {
"element": { "element": {
"#": "todo-container" "#": "todo-container"
}
} }
} }
} }
} </script>
</script> </body>
</body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="funnyfacejs"> <html lang="en" data-framework="funnyfacejs">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>o_O • TodoMVC</title> <title>o_O • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" data-bind="value: current; enterKey: add" placeholder="What needs to be done?" autofocus> <input id="new-todo" data-bind="value: current; enterKey: add" placeholder="What needs to be done?" autofocus>
</header> </header>
<section id="main" data-bind="visible: todos.count"> <section id="main" data-bind="visible: todos.count">
<div> <div>
<input id="toggle-all" type="checkbox" data-bind="value: allCompleted;"> <input id="toggle-all" type="checkbox" data-bind="value: allCompleted;">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
</div> </div>
<ul id="todo-list" data-bind="foreach: todos"> <ul id="todo-list" data-bind="foreach: todos">
<li data-bind="class: klass; visible"> <li data-bind="class: klass; visible">
<div class="view"> <div class="view">
<input class="toggle" type="checkbox" data-bind="value: completed"> <input class="toggle" type="checkbox" data-bind="value: completed">
<label data-bind="text: title; dblclick: startEditing"></label> <label data-bind="text: title; dblclick: startEditing"></label>
<button class="destroy" data-bind="click: remove"></button> <button class="destroy" data-bind="click: remove"></button>
</div> </div>
<input class="edit" data-bind="value: title; enterKey: stopEditing; blur: stopEditing"> <input class="edit" data-bind="value: title; enterKey: stopEditing; blur: stopEditing">
</li> </li>
</ul> </ul>
</section>
<footer id="footer" data-bind="visible: todos.count">
<span id="todo-count">
<strong data-bind="text: remainingCount"></strong>
<span class="word" data-bind="text: pluralize('item', remainingCount())"></span> left
</span>
<ul id="filters" >
<li><a href="#/">All</a></li>
<li><a href="#/active">Active</a></li>
<li><a href="#/completed">Completed</a></li>
</ul>
<button id="clear-completed" data-bind="click: removeCompleted; visible: completedCount">
Clear completed (<span data-bind='text: completedCount'></span>)
</button>
</footer>
</section> </section>
<footer id="footer" data-bind="visible: todos.count"> <footer id="info">
<span id="todo-count"> <p>Double-click to edit a todo</p>
<strong data-bind="text: remainingCount"></strong> <p>Created by <a href="http://weepy.github.com">weepy (Jonah Fox)</a></p>
<span class="word" data-bind="text: pluralize('item', remainingCount())"></span> left <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</span>
<ul id="filters" >
<li><a href="#/">All</a></li>
<li><a href="#/active">Active</a></li>
<li><a href="#/completed">Completed</a></li>
</ul>
<button id="clear-completed" data-bind="click: removeCompleted; visible: completedCount">
Clear completed (<span data-bind='text: completedCount'></span>)
</button>
</footer> </footer>
</section> <script src="bower_components/todomvc-common/base.js"></script>
<footer id="info"> <script src="bower_components/jquery/jquery.js"></script>
<p>Double-click to edit a todo</p> <script src="js/lib/o_O.js" ></script>
<p>Created by <a href="http://weepy.github.com">weepy (Jonah Fox)</a></p> <script src="js/lib/o_O.router.js"></script>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <script src="js/app.js"></script>
</footer> </body>
<script src="bower_components/todomvc-common/base.js"></script>
<script src="bower_components/jquery/jquery.js"></script>
<script src="js/lib/o_O.js" ></script>
<script src="js/lib/o_O.router.js"></script>
<script src="js/app.js"></script>
</body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="olives"> <html lang="en" data-framework="olives">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Olives • TodoMVC</title> <title>Olives • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
<link rel="stylesheet" href="css/app.css"> <link rel="stylesheet" href="css/app.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" placeholder="What needs to be done?" autofocus data-event="listen:keydown,addTask"> <input id="new-todo" placeholder="What needs to be done?" autofocus data-event="listen:keydown,addTask">
</header> </header>
<section id="main" data-stats="bind:toggleClass,nbItems,show"> <section id="main" data-stats="bind:toggleClass,nbItems,show">
<input id="toggle-all" type="checkbox" data-event="listen:click,toggleAll" data-stats="bind:toggleCheck,nbCompleted"> <input id="toggle-all" type="checkbox" data-event="listen:click,toggleAll" data-stats="bind:toggleCheck,nbCompleted">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list" data-model="foreach"> <ul id="todo-list" data-model="foreach">
<li data-model="bind:toggleClass,completed,completed;"> <li data-model="bind:toggleClass,completed,completed;">
<div class="view"> <div class="view">
<input class="toggle" type="checkbox" data-model="bind:checked,completed"> <input class="toggle" type="checkbox" data-model="bind:checked,completed">
<label data-model="bind:textContent,title" data-event="listen:dblclick,startEdit"></label> <label data-model="bind:textContent,title" data-event="listen:dblclick,startEdit"></label>
<button class="destroy" data-event="listen:click,remove"></button> <button class="destroy" data-event="listen:click,remove"></button>
</div> </div>
<input class="edit" data-model="bind:value,title" data-event="listen:keydown,stopEdit; listen:blur,stopEdit"> <input class="edit" data-model="bind:value,title" data-event="listen:keydown,stopEdit; listen:blur,stopEdit">
</li> </li>
</ul> </ul>
</section>
<footer id="footer" data-stats="bind:toggleClass,nbItems,show">
<span id="todo-count"><strong data-stats="bind:innerHTML,nbLeft">0</strong> <span data-stats="bind:innerHTML,plural"></span> left</span>
<button id="clear-completed" data-event="listen:click,delAll" data-stats="bind:toggleClass,nbCompleted,show">
Clear completed (<span data-stats="bind:innerHTML,nbCompleted"></span>)
</button>
</footer>
</section> </section>
<footer id="footer" data-stats="bind:toggleClass,nbItems,show"> <footer id="info">
<span id="todo-count"><strong data-stats="bind:innerHTML,nbLeft">0</strong> <span data-stats="bind:innerHTML,plural"></span> left</span> <p>Double-click to edit a todo</p>
<button id="clear-completed" data-event="listen:click,delAll" data-stats="bind:toggleClass,nbCompleted,show"> <p>Created by <a href="http://github.com/podefr">Olivier Scherrer</a></p>
Clear completed (<span data-stats="bind:innerHTML,nbCompleted"></span>) <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</button>
</footer> </footer>
</section> <script src="bower_components/todomvc-common/base.js"></script>
<footer id="info"> <script src="bower_components/requirejs/require.js"></script>
<p>Double-click to edit a todo</p> <script src="bower_components/emily/build/Emily.js"></script>
<p>Created by <a href="http://github.com/podefr">Olivier Scherrer</a></p> <script src="bower_components/olives/build/Olives.js"></script>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <script src="js/lib/Tools.js"></script>
</footer> <script src="js/uis/Input.js"></script>
<script src="bower_components/todomvc-common/base.js"></script> <script src="js/uis/List.js"></script>
<script src="bower_components/requirejs/require.js"></script> <script src="js/uis/Controls.js"></script>
<script src="bower_components/emily/build/Emily.js"></script> <script src="js/app.js"></script>
<script src="bower_components/olives/build/Olives.js"></script> </body>
<script src="js/lib/Tools.js"></script>
<script src="js/uis/Input.js"></script>
<script src="js/uis/List.js"></script>
<script src="js/uis/Controls.js"></script>
<script src="js/app.js"></script>
</body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="plastronjs"> <html lang="en" data-framework="plastronjs">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>PlastronJS • TodoMVC</title> <title>PlastronJS • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
<style> <style>
#filters.none li.none, #filters.none li.none,
#filters.active li.active, #filters.active li.active,
#filters.completed li.completed { #filters.completed li.completed {
font-weight: bold; font-weight: bold;
} }
</style> </style>
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" class="todo-entry" placeholder="What needs to be done?" autofocus> <input id="new-todo" class="todo-entry" placeholder="What needs to be done?" autofocus>
</header> </header>
<section id="main"> <section id="main">
<input id="toggle-all" class="toggle-all" type="checkbox"> <input id="toggle-all" class="toggle-all" type="checkbox">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list"></ul> <ul id="todo-list"></ul>
</section>
<footer id="footer">
<span id="todo-count"><strong>0</strong> item left</span>
<ul id="filters" class="none">
<li class="none">
<a href="#/">All</a>
</li>
<li class="active">
<a href="#/active">Active</a>
</li>
<li class="completed">
<a href="#/completed">Completed</a>
</li>
</ul>
<button id="clear-completed" class="clear-completed">Clear completed</button>
</footer>
</section> </section>
<footer id="footer"> <footer id="info">
<span id="todo-count"><strong>0</strong> item left</span> <p>Double-click to edit a todo</p>
<ul id="filters" class="none"> <p>Created by <a href="http://rhysbrettbowen.com">Rhys Brett-Bowen</a> (<a href="https://twitter.com/RhysBB">RhysBB</a>)</p>
<li class="none"> <p>Using <a href="https://github.com/rhysbrettbowen/PlastronJS">PlastronJS</a> and <a href="https://developers.google.com/closure/">Closure Tools</a></p>
<a href="#/">All</a> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</li>
<li class="active">
<a href="#/active">Active</a>
</li>
<li class="completed">
<a href="#/completed">Completed</a>
</li>
</ul>
<button id="clear-completed" class="clear-completed">Clear completed</button>
</footer> </footer>
</section> <script src="bower_components/todomvc-common/base.js"></script>
<footer id="info"> <!-- <script src="http://localhost:9810/compile?id=todomvc&mode=raw"></script> -->
<p>Double-click to edit a todo</p> <script src="js/compiled.js"></script>
<p>Created by <a href="http://rhysbrettbowen.com">Rhys Brett-Bowen</a> (<a href="https://twitter.com/RhysBB">RhysBB</a>)</p> </body>
<p>Using <a href="https://github.com/rhysbrettbowen/PlastronJS">PlastronJS</a> and <a href="https://developers.google.com/closure/">Closure Tools</a></p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</footer>
<script src="bower_components/todomvc-common/base.js"></script>
<!-- <script src="http://localhost:9810/compile?id=todomvc&mode=raw"></script> -->
<script src="js/compiled.js"></script>
</body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="puremvc"> <html lang="en" data-framework="puremvc">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>PureMVC • TodoMVC</title> <title>PureMVC • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" placeholder="What needs to be done?" autofocus> <input id="new-todo" placeholder="What needs to be done?" autofocus>
</header> </header>
<section id="main"> <section id="main">
<input id="toggle-all" type="checkbox"> <input id="toggle-all" type="checkbox">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list"> <ul id="todo-list">
</ul> </ul>
</section>
<footer id="footer">
<span id="todo-count"><strong>1</strong> item left</span>
<ul id="filters">
<li>
<a id="filterAll" class="selected" href="#/">All</a>
</li>
<li>
<a id="filterActive" href="#/active">Active</a>
</li>
<li>
<a id="filterCompleted" href="#/completed">Completed</a>
</li>
</ul>
<button id="clear-completed">Clear completed (1)</button>
</footer>
</section> </section>
<footer id="footer"> <footer id="info">
<span id="todo-count"><strong>1</strong> item left</span> <p>Double-click to edit a todo</p>
<ul id="filters"> <p>Created by <a href="http://puremvc.org">Mike Britton and Cliff Hall for the PureMVC Project</a></p>
<li> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
<a id="filterAll" class="selected" href="#/">All</a>
</li>
<li>
<a id="filterActive" href="#/active">Active</a>
</li>
<li>
<a id="filterCompleted" href="#/completed">Completed</a>
</li>
</ul>
<button id="clear-completed">Clear completed (1)</button>
</footer> </footer>
</section>
<footer id="info">
<p>Double-click to edit a todo</p>
<p>Created by <a href="http://puremvc.org">Mike Britton and Cliff Hall for the PureMVC Project</a></p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</footer>
<!-- TODOMVC PROJECT BASE --> <!-- TODOMVC PROJECT BASE -->
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<!-- FLATIRION DIRECTOR ROUTING LIBRARY --> <!-- FLATIRION DIRECTOR ROUTING LIBRARY -->
<script src="bower_components/director/director.js"></script> <script src="bower_components/director/director.js"></script>
<!-- PUREMVC LIBRARY --> <!-- PUREMVC LIBRARY -->
<script src="bower_components/puremvc/puremvc-1.0.1.js"></script> <script src="bower_components/puremvc/puremvc-1.0.1.js"></script>
<!-- APPLICATION CONSTANTS --> <!-- APPLICATION CONSTANTS -->
<script src="js/AppConstants.js"></script> <script src="js/AppConstants.js"></script>
<!-- PROXIES --> <!-- PROXIES -->
<script src="js/model/proxy/TodoProxy.js"></script> <script src="js/model/proxy/TodoProxy.js"></script>
<!-- EVENTS --> <!-- EVENTS -->
<script src="js/view/event/AppEvents.js"></script> <script src="js/view/event/AppEvents.js"></script>
<!-- VIEW COMPONENTS --> <!-- VIEW COMPONENTS -->
<script src="js/view/component/TodoForm.js"></script> <script src="js/view/component/TodoForm.js"></script>
<!-- MEDIATORS --> <!-- MEDIATORS -->
<script src="js/view/mediator/RoutesMediator.js"></script> <script src="js/view/mediator/RoutesMediator.js"></script>
<script src="js/view/mediator/TodoFormMediator.js"></script> <script src="js/view/mediator/TodoFormMediator.js"></script>
<!-- COMMANDS --> <!-- COMMANDS -->
<script src="js/controller/command/StartupCommand.js"></script> <script src="js/controller/command/StartupCommand.js"></script>
<script src="js/controller/command/PrepControllerCommand.js"></script> <script src="js/controller/command/PrepControllerCommand.js"></script>
<script src="js/controller/command/PrepModelCommand.js"></script> <script src="js/controller/command/PrepModelCommand.js"></script>
<script src="js/controller/command/PrepViewCommand.js"></script> <script src="js/controller/command/PrepViewCommand.js"></script>
<script src="js/controller/command/TodoCommand.js"></script> <script src="js/controller/command/TodoCommand.js"></script>
<!-- APPLICATION --> <!-- APPLICATION -->
<script src="js/app.js"></script> <script src="js/app.js"></script>
<!-- START THE APPLICATION --> <!-- START THE APPLICATION -->
<script> <script>
document.addEventListener('DOMContentLoaded', function() { document.addEventListener('DOMContentLoaded', function() {
var app = new todomvc.Application(); var app = new todomvc.Application();
}); });
</script> </script>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="rappidjs"> <html lang="en" data-framework="rappidjs">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>rAppid.js • TodoMVC</title> <title>rAppid.js • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
<style> <style>
.hide { .hide {
display: none; display: none;
}
</style>
</head>
<body>
<script src="bower_components/todomvc-common/base.js"></script>
<script src="app/lib/rappidjs.min.js"></script>
<script>
rAppid.bootStrap('app/Todo.xml', 'config.json', function (err, systemManager, application) {
if (!err) {
application.start(null, function () {
application.render(document.body);
});
} else {
console.warn(err);
} }
}); </style>
</script> </head>
</body> <body>
<script src="bower_components/todomvc-common/base.js"></script>
<script src="app/lib/rappidjs.min.js"></script>
<script>
rAppid.bootStrap('app/Todo.xml', 'config.json', function (err, systemManager, application) {
if (!err) {
application.start(null, function () {
application.render(document.body);
});
} else {
console.warn(err);
}
});
</script>
</body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="serenadejs"> <html lang="en" data-framework="serenadejs">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Serenade.js • TodoMVC</title> <title>Serenade.js • TodoMVC</title>
<link href="bower_components/todomvc-common/base.css" rel="stylesheet"> <link href="bower_components/todomvc-common/base.css" rel="stylesheet">
</head> </head>
<body> <body>
<script id="app" type="text/serenade"> <script id="app" type="text/serenade">
section#todoapp section#todoapp
header#header header#header
form[event:submit=newTodo!] form[event:submit=newTodo!]
h1 "todos" h1 "todos"
input#new-todo[binding:change=@newTitle placeholder="What needs to be done?" autofocus="autofocus"] input#new-todo[binding:change=@newTitle placeholder="What needs to be done?" autofocus="autofocus"]
- if @allCount - if @allCount
section#main section#main
input#toggle-all[type="checkbox" binding:change=@allCompleted] input#toggle-all[type="checkbox" binding:change=@allCompleted]
label[for="toggle-all"] "Mark all as complete" label[for="toggle-all"] "Mark all as complete"
ul#todo-list ul#todo-list
- collection @filtered - collection @filtered
- view "todo" - view "todo"
footer#footer footer#footer
span#todo-count span#todo-count
strong @activeCount strong @activeCount
" " " "
@label @label
ul#filters ul#filters
li li
a.all[class:selected=@filterAll href="#/"] "All" a.all[class:selected=@filterAll href="#/"] "All"
li li
a.active[class:selected=@filterActive href="#/active"] "Active" a.active[class:selected=@filterActive href="#/active"] "Active"
li li
a.completed[class:selected=@filterCompleted href="#/completed"] "Completed" a.completed[class:selected=@filterCompleted href="#/completed"] "Completed"
- if @completedCount - if @completedCount
button#clear-completed[event:click=clearCompleted] button#clear-completed[event:click=clearCompleted]
"Clear completed (" @completedCount ")" "Clear completed (" @completedCount ")"
</script> </script>
<script id="todo" type="text/serenade"> <script id="todo" type="text/serenade">
li[class:editing=@edit class:completed=@completed] li[class:editing=@edit class:completed=@completed]
form[event:submit=edited!] form[event:submit=edited!]
input.edit[on:load=loadField event:blur=edited! binding:change=@title] input.edit[on:load=loadField event:blur=edited! binding:change=@title]
- unless @edit - unless @edit
input.toggle[type="checkbox" binding:change=@completed] input.toggle[type="checkbox" binding:change=@completed]
label[event:dblclick=edit] @title label[event:dblclick=edit] @title
button.destroy[event:click=removeTodo] button.destroy[event:click=removeTodo]
</script> </script>
<footer id="info"> <footer id="info">
<p>Double-click to edit a todo</p> <p>Double-click to edit a todo</p>
<p>Created by <a href="http://elabs.se">Elabs</a></p> <p>Created by <a href="http://elabs.se">Elabs</a></p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</footer> </footer>
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<script src="bower_components/director/build/director.js"></script> <script src="bower_components/director/build/director.js"></script>
<script src="js/lib/serenade.js"></script> <script src="js/lib/serenade.js"></script>
<script src="js/app.js"></script> <script src="js/app.js"></script>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="somajs"> <html lang="en" data-framework="somajs">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>soma.js • TodoMVC</title> <title>soma.js • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
<link rel="stylesheet" href="css/app.css"> <link rel="stylesheet" href="css/app.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<!-- HEADER VIEW, template: /views/header.js (todo.HeaderView) --> <!-- HEADER VIEW, template: /views/header.js (todo.HeaderView) -->
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" placeholder="What needs to be done?" autofocus data-keypress="add()" data-blur="clear()"> <input id="new-todo" placeholder="What needs to be done?" autofocus data-keypress="add()" data-blur="clear()">
</header> </header>
<!-- MAIN VIEW, template: /views/main.js (todo.MainView) --> <!-- MAIN VIEW, template: /views/main.js (todo.MainView) -->
<section id="main" data-show="{{isVisible}}"> <section id="main" data-show="{{isVisible}}">
<input id="toggle-all" type="checkbox" data-click="toggleAll()" data-checked="{{allCompleted}}"> <input id="toggle-all" type="checkbox" data-click="toggleAll()" data-checked="{{allCompleted}}">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list" class="data-cloak"> <ul id="todo-list" class="data-cloak">
<li data-repeat="todo in items" class="{{completedClass(todo.completed)}} {{todo.editing}}"> <li data-repeat="todo in items" class="{{completedClass(todo.completed)}} {{todo.editing}}">
<div class="view"> <div class="view">
<input class="toggle" type="checkbox" data-checked="{{todo.completed}}" data-click="toggle(todo)"> <input class="toggle" type="checkbox" data-checked="{{todo.completed}}" data-click="toggle(todo)">
<label data-dblclick="edit(todo)">{{todo.title}}</label> <label data-dblclick="edit(todo)">{{todo.title}}</label>
<button class="destroy" data-click="remove(todo)"></button> <button class="destroy" data-click="remove(todo)"></button>
</div> </div>
<input class="edit" value="{{todo.title}}" data-keypress="update(todo)" data-blur="update(todo)"> <input class="edit" value="{{todo.title}}" data-keypress="update(todo)" data-blur="update(todo)">
</li> </li>
</ul> </ul>
</section> </section>
<!-- FOOTER VIEW, template: /views/footer.js (todo.FooterView) --> <!-- FOOTER VIEW, template: /views/footer.js (todo.FooterView) -->
<footer id="footer" class="data-cloak" data-show="{{footerVisible}}"> <footer id="footer" class="data-cloak" data-show="{{footerVisible}}">
<span id="todo-count"><strong>{{active}}</strong> {{itemLabel}} left</span> <span id="todo-count"><strong>{{active}}</strong> {{itemLabel}} left</span>
<ul id="filters"> <ul id="filters">
<li> <li>
<a class="{{highlightFilter('')}}" href="#/">All</a> <a class="{{highlightFilter('')}}" href="#/">All</a>
</li> </li>
<li> <li>
<a class="{{highlightFilter('active')}}" href="#/active">Active</a> <a class="{{highlightFilter('active')}}" href="#/active">Active</a>
</li> </li>
<li> <li>
<a class="{{highlightFilter('completed')}}" href="#/completed">Completed</a> <a class="{{highlightFilter('completed')}}" href="#/completed">Completed</a>
</li> </li>
</ul> </ul>
<button id="clear-completed" data-show="{{clearCompletedVisible()}}" data-click="clearCompleted()">Clear completed ({{completed}})</button> <button id="clear-completed" data-show="{{clearCompletedVisible()}}" data-click="clearCompleted()">Clear completed ({{completed}})</button>
</footer> </footer>
</section> </section>
<footer id="info"> <footer id="info">
<p>Double-click to edit a todo</p> <p>Double-click to edit a todo</p>
<p>Created by <a href="http://soundstep.com">Romuald Quantin</a> (<a href="http://somajs.github.io/somajs/">soma.js</a>)</p> <p>Created by <a href="http://soundstep.com">Romuald Quantin</a> (<a href="http://somajs.github.io/somajs/">soma.js</a>)</p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</footer> </footer>
<!-- LIBRARIES --> <!-- LIBRARIES -->
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<script src="bower_components/director/build/director.js"></script> <script src="bower_components/director/build/director.js"></script>
<script src="bower_components/soma.js/build/soma.js"></script> <script src="bower_components/soma.js/build/soma.js"></script>
<script src="bower_components/soma-template/build/soma-template.js"></script> <script src="bower_components/soma-template/build/soma-template.js"></script>
<!-- TODO APP --> <!-- TODO APP -->
<script src="js/models/todos.js"></script> <script src="js/models/todos.js"></script>
<script src="js/models/router.js"></script> <script src="js/models/router.js"></script>
<script src="js/views/header.js"></script> <script src="js/views/header.js"></script>
<script src="js/views/main.js"></script> <script src="js/views/main.js"></script>
<script src="js/views/footer.js"></script> <script src="js/views/footer.js"></script>
<script src="js/app.js"></script> <script src="js/app.js"></script>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="stapes"> <html lang="en" data-framework="stapes">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Stapes.js • TodoMVC</title> <title>Stapes.js • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" placeholder="What needs to be done?" autofocus> <input id="new-todo" placeholder="What needs to be done?" autofocus>
</header> </header>
<section id="main"> <section id="main">
<input id="toggle-all" type="checkbox"> <input id="toggle-all" type="checkbox">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list"></ul> <ul id="todo-list"></ul>
</section>
<footer id="footer">
<span id="todo-count"><strong>0</strong> item left</span>
<ul id="filters">
<li>
<a class="selected" href="#/">All</a>
</li>
<li>
<a href="#/active">Active</a>
</li>
<li>
<a href="#/completed">Completed</a>
</li>
</ul>
<button id="clear-completed">Clear completed (1)</button>
</footer>
</section> </section>
<footer id="footer"> <footer id="info">
<span id="todo-count"><strong>0</strong> item left</span> <p>Double-click to edit a todo</p>
<ul id="filters"> <p>Created by <a href="http://github.com/hay/stapes/">Hay Kranen</a>.</p>
<li>
<a class="selected" href="#/">All</a>
</li>
<li>
<a href="#/active">Active</a>
</li>
<li>
<a href="#/completed">Completed</a>
</li>
</ul>
<button id="clear-completed">Clear completed (1)</button>
</footer> </footer>
</section>
<footer id="info">
<p>Double-click to edit a todo</p>
<p>Created by <a href="http://github.com/hay/stapes/">Hay Kranen</a>.</p>
</footer>
<script id="todo-template" type="text/x-handlebars-template"> <script id="todo-template" type="text/x-handlebars-template">
{{#todos}} {{#todos}}
<li class="{{#completed}}completed{{/completed}}" data-id="{{id}}"> <li class="{{#completed}}completed{{/completed}}" data-id="{{id}}">
<div class="view"> <div class="view">
<input class="toggle" type="checkbox" {{#completed}}checked="checked"{{/completed}}> <input class="toggle" type="checkbox" {{#completed}}checked="checked"{{/completed}}>
<label>{{title}}</label> <label>{{title}}</label>
<button class="destroy"></button> <button class="destroy"></button>
</div> </div>
<input class="edit" value="{{title}}"> <input class="edit" value="{{title}}">
</li> </li>
{{/todos}} {{/todos}}
</script> </script>
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<script src="bower_components/jquery/jquery.js"></script> <script src="bower_components/jquery/jquery.js"></script>
<script src="bower_components/handlebars.js/handlebars.js"></script> <script src="bower_components/handlebars.js/handlebars.js"></script>
<script src="bower_components/stapes/stapes.js"></script> <script src="bower_components/stapes/stapes.js"></script>
<script src="js/controllers/todoController.js"></script> <script src="js/controllers/todoController.js"></script>
<script src="js/models/todoModel.js"></script> <script src="js/models/todoModel.js"></script>
<script src="js/views/todoView.js"></script> <script src="js/views/todoView.js"></script>
<script src="js/stores/todoStore.js"></script> <script src="js/stores/todoStore.js"></script>
<script> <script>
TodoController.init(); TodoController.init();
</script> </script>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="thorax"> <html lang="en" data-framework="thorax">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Thorax • TodoMVC</title> <title>Thorax • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<script type="text/template" data-template-name="app"> <script type="text/template" data-template-name="app">
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<input id="new-todo" placeholder="What needs to be done?" autofocus> <input id="new-todo" placeholder="What needs to be done?" autofocus>
</header> </header>
{{^empty collection}} {{^empty collection}}
<section id="main"> <section id="main">
<input id="toggle-all" type="checkbox"> <input id="toggle-all" type="checkbox">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
{{#collection item-view="todo-item" tag="ul" id="todo-list"}} {{#collection item-view="todo-item" tag="ul" id="todo-list"}}
<div class="view"> <div class="view">
<input class="toggle" type="checkbox" {{#if completed}}checked="checked"{{/if}}> <input class="toggle" type="checkbox" {{#if completed}}checked="checked"{{/if}}>
<label>{{title}}</label> <label>{{title}}</label>
<button class="destroy"></button> <button class="destroy"></button>
</div> </div>
<input class="edit" value="{{title}}"> <input class="edit" value="{{title}}">
{{/collection}} {{/collection}}
</section> </section>
{{view "stats" tag="footer" id="footer"}} {{view "stats" tag="footer" id="footer"}}
{{/empty}} {{/empty}}
</section> </section>
<div id="info"> <div id="info">
<p>Double-click to edit a todo</p> <p>Double-click to edit a todo</p>
<p>Written by <a href="https://github.com/addyosmani">Addy Osmani</a> &amp; <a href="https://github.com/eastridge">Ryan Eastridge</a></p> <p>Written by <a href="https://github.com/addyosmani">Addy Osmani</a> &amp; <a href="https://github.com/eastridge">Ryan Eastridge</a></p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</div> </div>
</script> </script>
<script type="text/template" data-template-name="stats"> <script type="text/template" data-template-name="stats">
<span id="todo-count"><strong>{{remaining}}</strong> {{itemText}} left</span> <span id="todo-count"><strong>{{remaining}}</strong> {{itemText}} left</span>
<ul id="filters"> <ul id="filters">
<li> <li>
{{#link "/" class="selected"}}All{{/link}} {{#link "/" class="selected"}}All{{/link}}
</li> </li>
<li> <li>
{{#link "/active"}}Active{{/link}} {{#link "/active"}}Active{{/link}}
</li> </li>
<li> <li>
{{#link "/completed"}}Completed{{/link}} {{#link "/completed"}}Completed{{/link}}
</li> </li>
</ul> </ul>
{{#if completed}} {{#if completed}}
<button id="clear-completed">Clear completed ({{completed}})</button> <button id="clear-completed">Clear completed ({{completed}})</button>
{{/if}} {{/if}}
</script> </script>
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<script src="bower_components/jquery/jquery.js"></script> <script src="bower_components/jquery/jquery.js"></script>
<script src="bower_components/handlebars.js/handlebars.js"></script> <script src="bower_components/handlebars.js/handlebars.js"></script>
<script src="bower_components/underscore/underscore.js"></script> <script src="bower_components/underscore/underscore.js"></script>
<script src="bower_components/backbone/backbone.js"></script> <script src="bower_components/backbone/backbone.js"></script>
<script src="bower_components/thorax/thorax.js"></script> <script src="bower_components/thorax/thorax.js"></script>
<script src="js/lib/backbone-localstorage.js"></script> <script src="js/lib/backbone-localstorage.js"></script>
<script> <script>
// Grab the text from the templates we created above // Grab the text from the templates we created above
Thorax.templates = { Thorax.templates = {
app: Handlebars.compile($('script[data-template-name="app"]').html()), app: Handlebars.compile($('script[data-template-name="app"]').html()),
stats: Handlebars.compile($('script[data-template-name="stats"]').html()) stats: Handlebars.compile($('script[data-template-name="stats"]').html())
}; };
// Initialize the app object // Initialize the app object
window.app = {}; window.app = {};
</script> </script>
<script src="js/models/todo.js"></script> <script src="js/models/todo.js"></script>
<script src="js/collections/todos.js"></script> <script src="js/collections/todos.js"></script>
<script src="js/views/todo-item.js"></script> <script src="js/views/todo-item.js"></script>
<script src="js/views/stats.js"></script> <script src="js/views/stats.js"></script>
<script src="js/views/app.js"></script> <script src="js/views/app.js"></script>
<script src="js/routers/router.js"></script> <script src="js/routers/router.js"></script>
<script src="js/app.js"></script> <script src="js/app.js"></script>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" ng-app="todomvc" data-framework="typescript"> <html lang="en" ng-app="todomvc" data-framework="typescript">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Typescript & AngularJS • TodoMVC</title> <title>Typescript & AngularJS • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
<style>[ng-cloak] { display: none; }</style> <style>[ng-cloak] { display: none; }</style>
</head> </head>
<body> <body>
<section id="todoapp" ng-controller="todoCtrl"> <section id="todoapp" ng-controller="todoCtrl">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<form id="todo-form" ng-submit="addTodo()"> <form id="todo-form" ng-submit="addTodo()">
<input id="new-todo" placeholder="What needs to be done?" ng-model="newTodo" autofocus> <input id="new-todo" placeholder="What needs to be done?" ng-model="newTodo" autofocus>
</form> </form>
</header> </header>
<section id="main" ng-show="todos.length" ng-cloak> <section id="main" ng-show="todos.length" ng-cloak>
<input id="toggle-all" type="checkbox" ng-model="allChecked" ng-click="markAll(allChecked)"> <input id="toggle-all" type="checkbox" ng-model="allChecked" ng-click="markAll(allChecked)">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list"> <ul id="todo-list">
<li ng-repeat="todo in todos | filter:statusFilter" ng-class="{completed: todo.completed, editing: todo == editedTodo}"> <li ng-repeat="todo in todos | filter:statusFilter" ng-class="{completed: todo.completed, editing: todo == editedTodo}">
<div class="view"> <div class="view">
<input class="toggle" type="checkbox" ng-model="todo.completed"> <input class="toggle" type="checkbox" ng-model="todo.completed">
<label ng-dblclick="editTodo(todo)">{{todo.title}}</label> <label ng-dblclick="editTodo(todo)">{{todo.title}}</label>
<button class="destroy" ng-click="removeTodo(todo)"></button> <button class="destroy" ng-click="removeTodo(todo)"></button>
</div> </div>
<form ng-submit="doneEditing(todo)"> <form ng-submit="doneEditing(todo)">
<input class="edit" ng-model="todo.title" todo-blur="doneEditing(todo)" todo-focus="todo == editedTodo"> <input class="edit" ng-model="todo.title" todo-blur="doneEditing(todo)" todo-focus="todo == editedTodo">
</form> </form>
</li> </li>
</ul> </ul>
</section> </section>
<footer id="footer" ng-show="todos.length" ng-cloak> <footer id="footer" ng-show="todos.length" ng-cloak>
<span id="todo-count"><strong>{{remainingCount}}</strong> <span id="todo-count"><strong>{{remainingCount}}</strong>
<ng-pluralize count="remainingCount" when="{ one: 'item left', other: 'items left' }"></ng-pluralize> <ng-pluralize count="remainingCount" when="{ one: 'item left', other: 'items left' }"></ng-pluralize>
</span> </span>
<ul id="filters"> <ul id="filters">
<li> <li>
<a ng-class="{selected: location.path() == '/'} " href="#/">All</a> <a ng-class="{selected: location.path() == '/'} " href="#/">All</a>
</li> </li>
<li> <li>
<a ng-class="{selected: location.path() == '/active'}" href="#/active">Active</a> <a ng-class="{selected: location.path() == '/active'}" href="#/active">Active</a>
</li> </li>
<li> <li>
<a ng-class="{selected: location.path() == '/completed'}" href="#/completed">Completed</a> <a ng-class="{selected: location.path() == '/completed'}" href="#/completed">Completed</a>
</li> </li>
</ul> </ul>
<button id="clear-completed" ng-click="clearDoneTodos()" ng-show="doneCount">Clear completed ({{doneCount}})</button> <button id="clear-completed" ng-click="clearDoneTodos()" ng-show="doneCount">Clear completed ({{doneCount}})</button>
</footer> </footer>
</section> </section>
<footer id="info"> <footer id="info">
<p>Double-click to edit a todo</p> <p>Double-click to edit a todo</p>
<p>Credits: <p>Credits:
<a href="http://twitter.com/cburgdorf">Christoph Burgdorf</a>, <a href="http://twitter.com/cburgdorf">Christoph Burgdorf</a>,
<a href="http://ericbidelman.com">Eric Bidelman</a>, <a href="http://ericbidelman.com">Eric Bidelman</a>,
<a href="http://jacobmumm.com">Jacob Mumm</a> <a href="http://jacobmumm.com">Jacob Mumm</a>
<a href="http://igorminar.com">Igor Minar</a> and <a href="http://igorminar.com">Igor Minar</a> and
<a href="http://zamboch.blogspot.com">Pavel Savara</a> <a href="http://zamboch.blogspot.com">Pavel Savara</a>
</p> </p>
</footer> </footer>
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<script src="bower_components/angular/angular.js"></script> <script src="bower_components/angular/angular.js"></script>
<script src="js/models/TodoItem.js"></script> <script src="js/models/TodoItem.js"></script>
<script src="js/controllers/TodoCtrl.js"></script> <script src="js/controllers/TodoCtrl.js"></script>
<script src="js/services/TodoStorage.js"></script> <script src="js/services/TodoStorage.js"></script>
<script src="js/directives/TodoFocus.js"></script> <script src="js/directives/TodoFocus.js"></script>
<script src="js/directives/TodoBlur.js"></script> <script src="js/directives/TodoBlur.js"></script>
<script src="js/Application.js"></script> <script src="js/Application.js"></script>
</body> </body>
</html> </html>
...@@ -44,70 +44,70 @@ https://github.com/documentcloud/backbone/blob/master/examples/todos/index.html ...@@ -44,70 +44,70 @@ https://github.com/documentcloud/backbone/blob/master/examples/todos/index.html
<!doctype html> <!doctype html>
<html lang="en" data-framework="typescript"> <html lang="en" data-framework="typescript">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>TypeScript & Backbone.js • TodoMVC</title> <title>TypeScript & Backbone.js • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<div id="create-todo"> <div id="create-todo">
<input id="new-todo" placeholder="What needs to be done?" autofocus> <input id="new-todo" placeholder="What needs to be done?" autofocus>
</div> </div>
</header> </header>
<section id="main"> <section id="main">
<input class="check mark-all-done" id="toggle-all" type="checkbox"> <input class="check mark-all-done" id="toggle-all" type="checkbox">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list"></ul> <ul id="todo-list"></ul>
</section> </section>
<footer id="footer"> <footer id="footer">
<div id="todo-stats"></div> <div id="todo-stats"></div>
</footer> </footer>
</section> </section>
<footer id="info"> <footer id="info">
<p>Double-click to edit a todo</p> <p>Double-click to edit a todo</p>
<p>TypeScript version by <a href="http://blogs.msdn.com/lukeh">Luke Hoban</a></p> <p>TypeScript version by <a href="http://blogs.msdn.com/lukeh">Luke Hoban</a></p>
<p>Cleanup, edits: <a href="http://addyosmani.com">Addy Osmani</a></p> <p>Cleanup, edits: <a href="http://addyosmani.com">Addy Osmani</a></p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</footer> </footer>
<!-- Templates --> <!-- Templates -->
<script type="text/template" id="item-template"> <script type="text/template" id="item-template">
<div class="todo <%= done ? 'done' : '' %>"> <div class="todo <%= done ? 'done' : '' %>">
<div class="view display"> <div class="view display">
<input class="toggle check" type="checkbox" <%= done ? 'checked' : '' %>> <input class="toggle check" type="checkbox" <%= done ? 'checked' : '' %>>
<label class="todo-content"><%= content %></label> <label class="todo-content"><%= content %></label>
<button class="destroy"></button> <button class="destroy"></button>
</div>
<input class="edit todo-input" value="<%= content %>">
</div> </div>
<input class="edit todo-input" value="<%= content %>"> </script>
</div>
</script>
<script type="text/template" id="stats-template"> <script type="text/template" id="stats-template">
<% if (total) { %> <% if (total) { %>
<span id="todo-count"> <span id="todo-count">
<strong class="number"><%= remaining %></strong> <strong class="number"><%= remaining %></strong>
<span class="word"><%= remaining == 1 ? 'item' : 'items' %></span> left <span class="word"><%= remaining == 1 ? 'item' : 'items' %></span> left
</span> </span>
<% } %> <% } %>
<% if (done) { %> <% if (done) { %>
<span class="todo-clear"> <span class="todo-clear">
<button id="clear-completed"> <button id="clear-completed">
Clear completed (<span class="number-done"><%= done %></span>) Clear completed (<span class="number-done"><%= done %></span>)
</button> </button>
</span> </span>
<% } %> <% } %>
</script> </script>
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<script src="bower_components/jquery/jquery.js"></script> <script src="bower_components/jquery/jquery.js"></script>
<script src="bower_components/lodash/lodash.js"></script> <script src="bower_components/lodash/lodash.js"></script>
<script src="bower_components/backbone/backbone.js"></script> <script src="bower_components/backbone/backbone.js"></script>
<script src="js/libs/backbone/backbone.localStorage.js"></script> <script src="js/libs/backbone/backbone.localStorage.js"></script>
<script src="js/app.js"></script> <script src="js/app.js"></script>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="angularjs"> <html lang="en" data-framework="angularjs">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>AngularJS & RequireJS • TodoMVC</title> <title>AngularJS & RequireJS • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
<style>[ng-cloak] { display: none; }</style> <style>[ng-cloak] { display: none; }</style>
<script> <script>
// Include angular-loader to allow modules to be loaded in any order. // Include angular-loader to allow modules to be loaded in any order.
/* /*
AngularJS v1.0.2 AngularJS v1.0.2
(c) 2010-2012 Google, Inc. http://angularjs.org (c) 2010-2012 Google, Inc. http://angularjs.org
License: MIT License: MIT
*/ */
(function(i){'use strict';function d(c,b,e){return c[b]||(c[b]=e())}return d(d(i,"angular",Object),"module",function(){var c={};return function(b,e,f){e&&c.hasOwnProperty(b)&&(c[b]=null);return d(c,b,function(){function a(a,b,d){return function(){c[d||"push"]([a,b,arguments]);return g}}if(!e)throw Error("No module: "+b);var c=[],d=[],h=a("$injector","invoke"),g={_invokeQueue:c,_runBlocks:d,requires:e,name:b,provider:a("$provide","provider"),factory:a("$provide","factory"),service:a("$provide","service"), value:a("$provide","value"),constant:a("$provide","constant","unshift"),filter:a("$filterProvider","register"),controller:a("$controllerProvider","register"),directive:a("$compileProvider","directive"),config:h,run:function(a){d.push(a);return this}};f&&h(f);return g})}})})(window); (function(i){'use strict';function d(c,b,e){return c[b]||(c[b]=e())}return d(d(i,"angular",Object),"module",function(){var c={};return function(b,e,f){e&&c.hasOwnProperty(b)&&(c[b]=null);return d(c,b,function(){function a(a,b,d){return function(){c[d||"push"]([a,b,arguments]);return g}}if(!e)throw Error("No module: "+b);var c=[],d=[],h=a("$injector","invoke"),g={_invokeQueue:c,_runBlocks:d,requires:e,name:b,provider:a("$provide","provider"),factory:a("$provide","factory"),service:a("$provide","service"), value:a("$provide","value"),constant:a("$provide","constant","unshift"),filter:a("$filterProvider","register"),controller:a("$controllerProvider","register"),directive:a("$compileProvider","directive"),config:h,run:function(a){d.push(a);return this}};f&&h(f);return g})}})})(window);
</script> </script>
</head> </head>
<body> <body>
<section id="todoapp" ng-controller="TodoController"> <section id="todoapp" ng-controller="TodoController">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<form id="todo-form" ng-submit="addTodo()"> <form id="todo-form" ng-submit="addTodo()">
<input id="new-todo" placeholder="What needs to be done?" ng-model="newTodo" autofocus> <input id="new-todo" placeholder="What needs to be done?" ng-model="newTodo" autofocus>
</form> </form>
</header> </header>
<section id="main" ng-show="todos.length" ng-cloak> <section id="main" ng-show="todos.length" ng-cloak>
<input id="toggle-all" type="checkbox" ng-model="allChecked" ng-click="markAll(allChecked)"> <input id="toggle-all" type="checkbox" ng-model="allChecked" ng-click="markAll(allChecked)">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list"> <ul id="todo-list">
<li ng-repeat="todo in todos | filter:statusFilter" ng-class="{completed: todo.completed, editing: todo == editedTodo}"> <li ng-repeat="todo in todos | filter:statusFilter" ng-class="{completed: todo.completed, editing: todo == editedTodo}">
<div class="view"> <div class="view">
<input class="toggle" type="checkbox" ng-model="todo.completed"> <input class="toggle" type="checkbox" ng-model="todo.completed">
<label ng-dblclick="editTodo(todo)">{{todo.title}}</label> <label ng-dblclick="editTodo(todo)">{{todo.title}}</label>
<button class="destroy" ng-click="removeTodo(todo)"></button> <button class="destroy" ng-click="removeTodo(todo)"></button>
</div> </div>
<form ng-submit="doneEditing(todo)"> <form ng-submit="doneEditing(todo)">
<input class="edit" ng-model="todo.title" todo-blur="doneEditing(todo)" todo-focus="todo == editedTodo"> <input class="edit" ng-model="todo.title" todo-blur="doneEditing(todo)" todo-focus="todo == editedTodo">
</form> </form>
</li> </li>
</ul> </ul>
</section>
<footer id="footer" ng-show="todos.length" ng-cloak>
<span id="todo-count"><strong>{{remainingCount}}</strong>
<ng-pluralize count="remainingCount" when="{ one: 'item left', other: 'items left' }"></ng-pluralize>
</span>
<ul id="filters">
<li>
<a ng-class="{selected: location.path() == '/'} " href="#/">All</a>
</li>
<li>
<a ng-class="{selected: location.path() == '/active'}" href="#/active">Active</a>
</li>
<li>
<a ng-class="{selected: location.path() == '/completed'}" href="#/completed">Completed</a>
</li>
</ul>
<button id="clear-completed" ng-click="clearDoneTodos()" ng-show="remainingCount < todos.length">Clear completed ({{todos.length - remainingCount}})</button>
</footer>
</section> </section>
<footer id="footer" ng-show="todos.length" ng-cloak> <footer id="info">
<span id="todo-count"><strong>{{remainingCount}}</strong> <p>Double-click to edit a todo</p>
<ng-pluralize count="remainingCount" when="{ one: 'item left', other: 'items left' }"></ng-pluralize> <p>Credits:
</span> <a href="http://twitter.com/cburgdorf">Christoph Burgdorf</a>,
<ul id="filters"> <a href="http://ericbidelman.com">Eric Bidelman</a>,
<li> <a href="http://jacobmumm.com">Jacob Mumm</a>,
<a ng-class="{selected: location.path() == '/'} " href="#/">All</a> <a href="http://igorminar.com">Igor Minar</a> and
</li> <a href="http://twitter.com/passy">Pascal Hartig</a>
<li> </p>
<a ng-class="{selected: location.path() == '/active'}" href="#/active">Active</a> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</li>
<li>
<a ng-class="{selected: location.path() == '/completed'}" href="#/completed">Completed</a>
</li>
</ul>
<button id="clear-completed" ng-click="clearDoneTodos()" ng-show="remainingCount < todos.length">Clear completed ({{todos.length - remainingCount}})</button>
</footer> </footer>
</section> <script src="bower_components/todomvc-common/base.js"></script>
<footer id="info"> <script data-main="js/main" src="bower_components/requirejs/require.js"></script>
<p>Double-click to edit a todo</p> </body>
<p>Credits:
<a href="http://twitter.com/cburgdorf">Christoph Burgdorf</a>,
<a href="http://ericbidelman.com">Eric Bidelman</a>,
<a href="http://jacobmumm.com">Jacob Mumm</a>,
<a href="http://igorminar.com">Igor Minar</a> and
<a href="http://twitter.com/passy">Pascal Hartig</a>
</p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</footer>
<script src="bower_components/todomvc-common/base.js"></script>
<script data-main="js/main" src="bower_components/requirejs/require.js"></script>
</body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="marionettejs"> <html lang="en" data-framework="marionettejs">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Backbone.Marionette & Requirejs • TodoMVC</title> <title>Backbone.Marionette & Requirejs • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
<link rel="stylesheet" href="css/custom.css"> <link rel="stylesheet" href="css/custom.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"> <header id="header">
</header> </header>
<section id="main"> <section id="main">
</section>
<footer id="footer">
</footer>
</section> </section>
<footer id="footer"> <footer id="info">
<p>Double-click to edit a todo</p>
<p>Created by <a href="http://github.com/jsoverson">Jarrod Overson</a></p>
</footer> </footer>
</section> <script src="bower_components/todomvc-common/base.js"></script>
<footer id="info"> <script data-main="js/main" src="bower_components/requirejs/require.js"></script>
<p>Double-click to edit a todo</p> </body>
<p>Created by <a href="http://github.com/jsoverson">Jarrod Overson</a></p>
</footer>
<script src="bower_components/todomvc-common/base.js"></script>
<script data-main="js/main" src="bower_components/requirejs/require.js"></script>
</body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="canjs"> <html lang="en" data-framework="canjs">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>CanJS + RequireJS • TodoMVC</title> <title>CanJS + RequireJS • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
</section> </section>
<div id="info"> <div id="info">
<p>Double-click to edit a todo</p> <p>Double-click to edit a todo</p>
<p>Written by <a href="http://bitovi.com">Bitovi</a></p> <p>Written by <a href="http://bitovi.com">Bitovi</a></p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</div> </div>
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<script data-main="js/app" src="bower_components/requirejs/require.js"></script> <script data-main="js/app" src="bower_components/requirejs/require.js"></script>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html class="no-js" lang="en" data-framework="chaplin"> <html class="no-js" lang="en" data-framework="chaplin">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Chaplin &amp; Brunch • TodoMVC</title> <title>Chaplin &amp; Brunch • TodoMVC</title>
<link rel="stylesheet" href="../bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="../bower_components/todomvc-common/base.css">
<link rel="stylesheet" href="../bower_components/todomvc-common/base.js"> <link rel="stylesheet" href="../bower_components/todomvc-common/base.js">
<!--[if IE]> <!--[if IE]>
<script src="../../../assets/ie.js"></script> <script src="../../../assets/ie.js"></script>
<![endif]--> <![endif]-->
<script src="app.js"></script> <script src="app.js"></script>
<script>require('initialize');</script> <script>require('initialize');</script>
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"></header> <header id="header"></header>
<section id="main"></section> <section id="main"></section>
<footer id="footer"></footer> <footer id="footer"></footer>
</section> </section>
<footer id="info"> <footer id="info">
<p>Double-click to edit a todo</p> <p>Double-click to edit a todo</p>
<p>Created by <a href="http://paulmillr.com">Paul Miller</a></p> <p>Created by <a href="http://paulmillr.com">Paul Miller</a></p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</footer> </footer>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html class="no-js" lang="en" data-framework="chaplin"> <html class="no-js" lang="en" data-framework="chaplin">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Chaplin &amp; Brunch • TodoMVC</title> <title>Chaplin &amp; Brunch • TodoMVC</title>
<link rel="stylesheet" href="../bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="../bower_components/todomvc-common/base.css">
<link rel="stylesheet" href="../bower_components/todomvc-common/base.js"> <link rel="stylesheet" href="../bower_components/todomvc-common/base.js">
<!--[if IE]> <!--[if IE]>
<script src="../../../assets/ie.js"></script> <script src="../../../assets/ie.js"></script>
<![endif]--> <![endif]-->
<script src="app.js"></script> <script src="app.js"></script>
<script>require('initialize');</script> <script>require('initialize');</script>
</head> </head>
<body> <body>
<section id="todoapp"> <section id="todoapp">
<header id="header"></header> <header id="header"></header>
<section id="main"></section> <section id="main"></section>
<footer id="footer"></footer> <footer id="footer"></footer>
</section> </section>
<footer id="info"> <footer id="info">
<p>Double-click to edit a todo</p> <p>Double-click to edit a todo</p>
<p>Created by <a href="http://paulmillr.com">Paul Miller</a></p> <p>Created by <a href="http://paulmillr.com">Paul Miller</a></p>
<p>Part of <a href="http://todomvc.com">TodoMVC</a></p> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p>
</footer> </footer>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="enyo"> <html lang="en" data-framework="enyo">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Enyo & Backbone.js • TodoMVC</title> <title>Enyo & Backbone.js • TodoMVC</title>
<link rel="stylesheet" href="bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<div id="todo-container" class="enyo-unselectable"> <div id="todo-container" class="enyo-unselectable">
<!-- Enyo comes with a build and deploy process that will minify and concatenate your files into 2 js files. One for enyo, and one for app code. For the purpose of demonstration, I used the debug loading library to handle the dependency management. The loader nagivates directories for package.js files and injects files they list into the DOM. --> <!-- Enyo comes with a build and deploy process that will minify and concatenate your files into 2 js files. One for enyo, and one for app code. For the purpose of demonstration, I used the debug loading library to handle the dependency management. The loader nagivates directories for package.js files and injects files they list into the DOM. -->
<script src="bower_components/todomvc-common/base.js"></script> <script src="bower_components/todomvc-common/base.js"></script>
<script src="enyo/enyo.js"></script> <script src="enyo/enyo.js"></script>
<script src="js/package.js"></script> <script src="js/package.js"></script>
</div> </div>
</body> </body>
</html> </html>
<!doctype html> <!doctype html>
<html lang="en" data-framework="thorax"> <html lang="en" data-framework="thorax">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Thorax & Lumbar • TodoMVC</title> <title>Thorax & Lumbar • TodoMVC</title>
<link rel="stylesheet" href="../bower_components/todomvc-common/base.css"> <link rel="stylesheet" href="../bower_components/todomvc-common/base.css">
</head> </head>
<body> <body>
<script src="base.js"></script> <script src="base.js"></script>
</body> </body>
</html> </html>
This diff is collapsed.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment