Permalink
Browse files

Added todos app example and 0.9.10 compat

  • Loading branch information...
1 parent 31fefb8 commit 3c12cf6e54f9d92c65a771894d806dfb766f4b3c @jeromegn committed Jan 27, 2013
Showing with 537 additions and 50 deletions.
  1. +1 −0 CNAME
  2. BIN destroy.png
  3. +82 −0 index.html
  4. +0 −50 spec/localStorage_spec.js
  5. +211 −0 todos.css
  6. +243 −0 todos.js
View
1 CNAME
@@ -0,0 +1 @@
+localtodos.com
View
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
View
@@ -0,0 +1,82 @@
+<!DOCTYPE html>
+<html lang="en">
+
+<head>
+ <meta charset="utf-8">
+ <title>Backbone.js Todos</title>
+ <link rel="stylesheet" href="todos.css"/>
+ <script type="text/javascript">
+
+ var _gaq = _gaq || [];
+ _gaq.push(['_setAccount', 'UA-5201171-9']);
+ _gaq.push(['_trackPageview']);
+
+ (function() {
+ var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
+ ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') +
+ '.google-analytics.com/ga.js';
+ var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
+ })();
+
+ </script>
+</head>
+
+<body>
+
+ <div id="todoapp">
+
+ <header>
+ <h1>Todos</h1>
+ <input id="new-todo" type="text" placeholder="What needs to be done?">
+ </header>
+
+ <section id="main">
+ <input id="toggle-all" type="checkbox">
+ <label for="toggle-all">Mark all as complete</label>
+ <ul id="todo-list"></ul>
+ </section>
+
+ <footer>
+ <a id="clear-completed">Clear completed</a>
+ <div id="todo-count"></div>
+ </footer>
+
+ </div>
+
+ <div id="instructions">
+ Double-click to edit a todo.
+ </div>
+
+ <div id="credits">
+ Created by
+ <br />
+ <a href="http://jgn.me/">J&eacute;r&ocirc;me Gravel-Niquet</a>.
+ <br />Rewritten by: <a href="http://addyosmani.github.com/todomvc">TodoMVC</a>.
+ </div>
+
+ <script src="spec/support/jquery.js"></script>
+ <script src="spec/support/underscore.js"></script>
+ <script src="spec/support/backbone.js"></script>
+ <script src="backbone.localStorage.js"></script>
+ <script src="todos.js"></script>
+
+ <!-- Templates -->
+
+ <script type="text/template" id="item-template">
+ <div class="view">
+ <input class="toggle" type="checkbox" <%= done ? 'checked="checked"' : '' %> />
+ <label><%- title %></label>
+ <a class="destroy"></a>
+ </div>
+ <input class="edit" type="text" value="<%- title %>" />
+ </script>
+
+ <script type="text/template" id="stats-template">
+ <% if (done) { %>
+ <a id="clear-completed">Clear <%= done %> completed <%= done == 1 ? 'item' : 'items' %></a>
+ <% } %>
+ <div class="todo-count"><b><%= remaining %></b> <%= remaining == 1 ? 'item' : 'items' %> left</div>
+ </script>
+
+ </body>
+</html>
View
@@ -308,56 +308,6 @@ describe("Without Backbone.localStorage", function(){
});
-describe("Backbone backwards compatibility", function(){
-
- describe("Should result in an exception when in backbone is 0.9.9", function(){
-
- var Model = Backbone.Model.extend();
-
- var Collection = Backbone.Collection.extend({
- model: Model,
- localStorage: new Backbone.LocalStorage("collectionStore")
- });
-
- var collection = new Collection();
- var cacheLocalSync = Backbone.localSync;
-
- before(function() {
- Backbone.VERSION = "0.9.9";
- })
-
- it("result in an exception if fetch is called", function() {
- assert.throw(collection.fetch, /(has no method \'sync\'|undefined)/ );
- })
-
- it("should call with one parameter if in 0.9.9", function() {
-
- Backbone.localSync = function(method, model, options) {
-
- options.success = function() {
- assert.equal(arguments.length,1, "Should only be called with one argument in backbone 0.9.9")
- }
-
- cacheLocalSync(method, model, options)
- }
-
- collection.fetch()
-
-
- })
-
- after(function() {
- Backbone.VERSION = "0.9.10";
- Backbone.localSync = cacheLocalSync;
- })
-
- });
-
-
-
-
-});
-
// For some reason this is not ran when viewed in a browser
// but it is ran when using `mocha-phantomjs`.
View
211 todos.css
@@ -0,0 +1,211 @@
+html,
+body {
+ margin: 0;
+ padding: 0;
+}
+
+body {
+ font: 14px "Helvetica Neue", Helvetica, Arial, sans-serif;
+ line-height: 1.4em;
+ background: #eeeeee;
+ color: #333333;
+ width: 520px;
+ margin: 0 auto;
+ -webkit-font-smoothing: antialiased;
+}
+
+#todoapp {
+ background: #fff;
+ padding: 20px;
+ margin-bottom: 40px;
+ -webkit-box-shadow: rgba(0, 0, 0, 0.2) 0 2px 6px 0;
+ -moz-box-shadow: rgba(0, 0, 0, 0.2) 0 2px 6px 0;
+ -ms-box-shadow: rgba(0, 0, 0, 0.2) 0 2px 6px 0;
+ -o-box-shadow: rgba(0, 0, 0, 0.2) 0 2px 6px 0;
+ box-shadow: rgba(0, 0, 0, 0.2) 0 2px 6px 0;
+ -webkit-border-radius: 0 0 5px 5px;
+ -moz-border-radius: 0 0 5px 5px;
+ -ms-border-radius: 0 0 5px 5px;
+ -o-border-radius: 0 0 5px 5px;
+ border-radius: 0 0 5px 5px;
+}
+
+#todoapp h1 {
+ font-size: 36px;
+ font-weight: bold;
+ text-align: center;
+ padding: 0 0 10px 0;
+}
+
+#todoapp input[type="text"] {
+ width: 466px;
+ font-size: 24px;
+ font-family: inherit;
+ line-height: 1.4em;
+ border: 0;
+ outline: none;
+ padding: 6px;
+ border: 1px solid #999999;
+ -webkit-box-shadow: rgba(0, 0, 0, 0.2) 0 1px 2px 0 inset;
+ -moz-box-shadow: rgba(0, 0, 0, 0.2) 0 1px 2px 0 inset;
+ -ms-box-shadow: rgba(0, 0, 0, 0.2) 0 1px 2px 0 inset;
+ -o-box-shadow: rgba(0, 0, 0, 0.2) 0 1px 2px 0 inset;
+ box-shadow: rgba(0, 0, 0, 0.2) 0 1px 2px 0 inset;
+}
+
+#todoapp input::-webkit-input-placeholder {
+ font-style: italic;
+}
+
+#main {
+ display: none;
+}
+
+#todo-list {
+ margin: 10px 0;
+ padding: 0;
+ list-style: none;
+}
+
+#todo-list li {
+ padding: 18px 20px 18px 0;
+ position: relative;
+ font-size: 24px;
+ border-bottom: 1px solid #cccccc;
+}
+
+#todo-list li:last-child {
+ border-bottom: none;
+}
+
+#todo-list li.done label {
+ color: #777777;
+ text-decoration: line-through;
+}
+
+#todo-list .destroy {
+ position: absolute;
+ right: 5px;
+ top: 20px;
+ display: none;
+ cursor: pointer;
+ width: 20px;
+ height: 20px;
+ background: url(destroy.png) no-repeat;
+}
+
+#todo-list li:hover .destroy {
+ display: block;
+}
+
+#todo-list .destroy:hover {
+ background-position: 0 -20px;
+}
+
+#todo-list li.editing {
+ border-bottom: none;
+ margin-top: -1px;
+ padding: 0;
+}
+
+#todo-list li.editing:last-child {
+ margin-bottom: -1px;
+}
+
+#todo-list li.editing .edit {
+ display: block;
+ width: 444px;
+ padding: 13px 15px 14px 20px;
+ margin: 0;
+}
+
+#todo-list li.editing .view {
+ display: none;
+}
+
+#todo-list li .view label {
+ word-break: break-word;
+}
+
+#todo-list li .edit {
+ display: none;
+}
+
+#todoapp footer {
+ display: none;
+ margin: 0 -20px -20px -20px;
+ overflow: hidden;
+ color: #555555;
+ background: #f4fce8;
+ border-top: 1px solid #ededed;
+ padding: 0 20px;
+ line-height: 37px;
+ -webkit-border-radius: 0 0 5px 5px;
+ -moz-border-radius: 0 0 5px 5px;
+ -ms-border-radius: 0 0 5px 5px;
+ -o-border-radius: 0 0 5px 5px;
+ border-radius: 0 0 5px 5px;
+}
+
+#clear-completed {
+ float: right;
+ line-height: 20px;
+ text-decoration: none;
+ background: rgba(0, 0, 0, 0.1);
+ color: #555555;
+ font-size: 11px;
+ margin-top: 8px;
+ margin-bottom: 8px;
+ padding: 0 10px 1px;
+ cursor: pointer;
+ -webkit-border-radius: 12px;
+ -moz-border-radius: 12px;
+ -ms-border-radius: 12px;
+ -o-border-radius: 12px;
+ border-radius: 12px;
+ -webkit-box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 0 0;
+ -moz-box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 0 0;
+ -ms-box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 0 0;
+ -o-box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 0 0;
+ box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 0 0;
+}
+
+#clear-completed:hover {
+ background: rgba(0, 0, 0, 0.15);
+ -webkit-box-shadow: rgba(0, 0, 0, 0.3) 0 -1px 0 0;
+ -moz-box-shadow: rgba(0, 0, 0, 0.3) 0 -1px 0 0;
+ -ms-box-shadow: rgba(0, 0, 0, 0.3) 0 -1px 0 0;
+ -o-box-shadow: rgba(0, 0, 0, 0.3) 0 -1px 0 0;
+ box-shadow: rgba(0, 0, 0, 0.3) 0 -1px 0 0;
+}
+
+#clear-completed:active {
+ position: relative;
+ top: 1px;
+}
+
+#todo-count span {
+ font-weight: bold;
+}
+
+#instructions {
+ margin: 10px auto;
+ color: #777777;
+ text-shadow: rgba(255, 255, 255, 0.8) 0 1px 0;
+ text-align: center;
+}
+
+#instructions a {
+ color: #336699;
+}
+
+#credits {
+ margin: 30px auto;
+ color: #999;
+ text-shadow: rgba(255, 255, 255, 0.8) 0 1px 0;
+ text-align: center;
+}
+
+#credits a {
+ color: #888;
+}
Oops, something went wrong.

0 comments on commit 3c12cf6

Please sign in to comment.