Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
T
todomvc
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Eugene Shen
todomvc
Commits
f0c582c3
Commit
f0c582c3
authored
Feb 19, 2013
by
Sindre Sorhus
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #462 from passy/style-update
Style update for Backbone and Ember
parents
879f666c
ad8a026c
Changes
14
Hide whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
112 additions
and
82 deletions
+112
-82
architecture-examples/backbone/js/app.js
architecture-examples/backbone/js/app.js
+4
-1
architecture-examples/backbone/js/collections/todos.js
architecture-examples/backbone/js/collections/todos.js
+9
-8
architecture-examples/backbone/js/models/todo.js
architecture-examples/backbone/js/models/todo.js
+3
-2
architecture-examples/backbone/js/routers/router.js
architecture-examples/backbone/js/routers/router.js
+4
-3
architecture-examples/backbone/js/views/app.js
architecture-examples/backbone/js/views/app.js
+19
-18
architecture-examples/backbone/js/views/todos.js
architecture-examples/backbone/js/views/todos.js
+20
-19
architecture-examples/emberjs/js/app.js
architecture-examples/emberjs/js/app.js
+1
-0
architecture-examples/emberjs/js/controllers/todo_controller.js
...ecture-examples/emberjs/js/controllers/todo_controller.js
+5
-2
architecture-examples/emberjs/js/controllers/todos_controller.js
...cture-examples/emberjs/js/controllers/todos_controller.js
+17
-14
architecture-examples/emberjs/js/models/store.js
architecture-examples/emberjs/js/models/store.js
+3
-0
architecture-examples/emberjs/js/models/todo.js
architecture-examples/emberjs/js/models/todo.js
+5
-2
architecture-examples/emberjs/js/router.js
architecture-examples/emberjs/js/router.js
+11
-8
architecture-examples/emberjs/js/views/edit_todo_view.js
architecture-examples/emberjs/js/views/edit_todo_view.js
+7
-4
architecture-examples/emberjs/js/views/todo_view.js
architecture-examples/emberjs/js/views/todo_view.js
+4
-1
No files found.
architecture-examples/backbone/js/app.js
View file @
f0c582c3
/*global $*/
/*jshint unused:false*/
var
app
=
app
||
{};
var
app
=
app
||
{};
var
ENTER_KEY
=
13
;
var
ENTER_KEY
=
13
;
$
(
function
()
{
$
(
function
()
{
'
use strict
'
;
// Kick things off by creating the **App**.
// Kick things off by creating the **App**.
new
app
.
AppView
();
new
app
.
AppView
();
...
...
architecture-examples/backbone/js/collections/todos.js
View file @
f0c582c3
/*global Backbone Store*/
var
app
=
app
||
{};
var
app
=
app
||
{};
(
function
()
{
(
function
()
{
'
use strict
'
;
'
use strict
'
;
// Todo Collection
// Todo Collection
...
@@ -17,28 +18,28 @@ var app = app || {};
...
@@ -17,28 +18,28 @@ var app = app || {};
localStorage
:
new
Store
(
'
todos-backbone
'
),
localStorage
:
new
Store
(
'
todos-backbone
'
),
// Filter down the list of all todo items that are finished.
// Filter down the list of all todo items that are finished.
completed
:
function
()
{
completed
:
function
()
{
return
this
.
filter
(
function
(
todo
)
{
return
this
.
filter
(
function
(
todo
)
{
return
todo
.
get
(
'
completed
'
);
return
todo
.
get
(
'
completed
'
);
});
});
},
},
// Filter down the list to only todo items that are still not finished.
// Filter down the list to only todo items that are still not finished.
remaining
:
function
()
{
remaining
:
function
()
{
return
this
.
without
.
apply
(
this
,
this
.
completed
()
);
return
this
.
without
.
apply
(
this
,
this
.
completed
()
);
},
},
// We keep the Todos in sequential order, despite being saved by unordered
// We keep the Todos in sequential order, despite being saved by unordered
// GUID in the database. This generates the next order number for new items.
// GUID in the database. This generates the next order number for new items.
nextOrder
:
function
()
{
nextOrder
:
function
()
{
if
(
!
this
.
length
)
{
if
(
!
this
.
length
)
{
return
1
;
return
1
;
}
}
return
this
.
last
().
get
(
'
order
'
)
+
1
;
return
this
.
last
().
get
(
'
order
'
)
+
1
;
},
},
// Todos are sorted by their original insertion order.
// Todos are sorted by their original insertion order.
comparator
:
function
(
todo
)
{
comparator
:
function
(
todo
)
{
return
todo
.
get
(
'
order
'
);
return
todo
.
get
(
'
order
'
);
}
}
});
});
...
...
architecture-examples/backbone/js/models/todo.js
View file @
f0c582c3
/*global Backbone*/
var
app
=
app
||
{};
var
app
=
app
||
{};
(
function
()
{
(
function
()
{
'
use strict
'
;
'
use strict
'
;
// Todo Model
// Todo Model
...
@@ -17,7 +18,7 @@ var app = app || {};
...
@@ -17,7 +18,7 @@ var app = app || {};
},
},
// Toggle the `completed` state of this todo item.
// Toggle the `completed` state of this todo item.
toggle
:
function
()
{
toggle
:
function
()
{
this
.
save
({
this
.
save
({
completed
:
!
this
.
get
(
'
completed
'
)
completed
:
!
this
.
get
(
'
completed
'
)
});
});
...
...
architecture-examples/backbone/js/routers/router.js
View file @
f0c582c3
/*global Backbone*/
var
app
=
app
||
{};
var
app
=
app
||
{};
(
function
()
{
(
function
()
{
'
use strict
'
;
'
use strict
'
;
// Todo Router
// Todo Router
// ----------
// ----------
var
Workspace
=
Backbone
.
Router
.
extend
({
var
Workspace
=
Backbone
.
Router
.
extend
({
routes
:{
routes
:
{
'
*filter
'
:
'
setFilter
'
'
*filter
'
:
'
setFilter
'
},
},
setFilter
:
function
(
param
)
{
setFilter
:
function
(
param
)
{
// Set the current filter to be used
// Set the current filter to be used
app
.
TodoFilter
=
param
.
trim
()
||
''
;
app
.
TodoFilter
=
param
.
trim
()
||
''
;
...
...
architecture-examples/backbone/js/views/app.js
View file @
f0c582c3
/*global Backbone _ $ ENTER_KEY*/
var
app
=
app
||
{};
var
app
=
app
||
{};
$
(
function
(
$
)
{
$
(
function
(
$
)
{
'
use strict
'
;
'
use strict
'
;
// The Application
// The Application
...
@@ -14,7 +15,7 @@ $(function( $ ) {
...
@@ -14,7 +15,7 @@ $(function( $ ) {
el
:
'
#todoapp
'
,
el
:
'
#todoapp
'
,
// Our template for the line of statistics at the bottom of the app.
// Our template for the line of statistics at the bottom of the app.
statsTemplate
:
_
.
template
(
$
(
'
#stats-template
'
).
html
()
),
statsTemplate
:
_
.
template
(
$
(
'
#stats-template
'
).
html
()
),
// Delegated events for creating new items, and clearing completed ones.
// Delegated events for creating new items, and clearing completed ones.
events
:
{
events
:
{
...
@@ -26,7 +27,7 @@ $(function( $ ) {
...
@@ -26,7 +27,7 @@ $(function( $ ) {
// At initialization we bind to the relevant events on the `Todos`
// At initialization we bind to the relevant events on the `Todos`
// collection, when items are added or changed. Kick things off by
// collection, when items are added or changed. Kick things off by
// loading any preexisting todos that might be saved in *localStorage*.
// loading any preexisting todos that might be saved in *localStorage*.
initialize
:
function
()
{
initialize
:
function
()
{
this
.
allCheckbox
=
this
.
$
(
'
#toggle-all
'
)[
0
];
this
.
allCheckbox
=
this
.
$
(
'
#toggle-all
'
)[
0
];
this
.
$input
=
this
.
$
(
'
#new-todo
'
);
this
.
$input
=
this
.
$
(
'
#new-todo
'
);
this
.
$footer
=
this
.
$
(
'
#footer
'
);
this
.
$footer
=
this
.
$
(
'
#footer
'
);
...
@@ -43,11 +44,11 @@ $(function( $ ) {
...
@@ -43,11 +44,11 @@ $(function( $ ) {
// Re-rendering the App just means refreshing the statistics -- the rest
// Re-rendering the App just means refreshing the statistics -- the rest
// of the app doesn't change.
// of the app doesn't change.
render
:
function
()
{
render
:
function
()
{
var
completed
=
app
.
Todos
.
completed
().
length
;
var
completed
=
app
.
Todos
.
completed
().
length
;
var
remaining
=
app
.
Todos
.
remaining
().
length
;
var
remaining
=
app
.
Todos
.
remaining
().
length
;
if
(
app
.
Todos
.
length
)
{
if
(
app
.
Todos
.
length
)
{
this
.
$main
.
show
();
this
.
$main
.
show
();
this
.
$footer
.
show
();
this
.
$footer
.
show
();
...
@@ -58,7 +59,7 @@ $(function( $ ) {
...
@@ -58,7 +59,7 @@ $(function( $ ) {
this
.
$
(
'
#filters li a
'
)
this
.
$
(
'
#filters li a
'
)
.
removeClass
(
'
selected
'
)
.
removeClass
(
'
selected
'
)
.
filter
(
'
[href="#/
'
+
(
app
.
TodoFilter
||
''
)
+
'
"]
'
)
.
filter
(
'
[href="#/
'
+
(
app
.
TodoFilter
||
''
)
+
'
"]
'
)
.
addClass
(
'
selected
'
);
.
addClass
(
'
selected
'
);
}
else
{
}
else
{
this
.
$main
.
hide
();
this
.
$main
.
hide
();
...
@@ -70,27 +71,27 @@ $(function( $ ) {
...
@@ -70,27 +71,27 @@ $(function( $ ) {
// Add a single todo item to the list by creating a view for it, and
// Add a single todo item to the list by creating a view for it, and
// appending its element to the `<ul>`.
// appending its element to the `<ul>`.
addOne
:
function
(
todo
)
{
addOne
:
function
(
todo
)
{
var
view
=
new
app
.
TodoView
({
model
:
todo
});
var
view
=
new
app
.
TodoView
({
model
:
todo
});
$
(
'
#todo-list
'
).
append
(
view
.
render
().
el
);
$
(
'
#todo-list
'
).
append
(
view
.
render
().
el
);
},
},
// Add all items in the **Todos** collection at once.
// Add all items in the **Todos** collection at once.
addAll
:
function
()
{
addAll
:
function
()
{
this
.
$
(
'
#todo-list
'
).
html
(
''
);
this
.
$
(
'
#todo-list
'
).
html
(
''
);
app
.
Todos
.
each
(
this
.
addOne
,
this
);
app
.
Todos
.
each
(
this
.
addOne
,
this
);
},
},
filterOne
:
function
(
todo
)
{
filterOne
:
function
(
todo
)
{
todo
.
trigger
(
'
visible
'
);
todo
.
trigger
(
'
visible
'
);
},
},
filterAll
:
function
()
{
filterAll
:
function
()
{
app
.
Todos
.
each
(
this
.
filterOne
,
this
);
app
.
Todos
.
each
(
this
.
filterOne
,
this
);
},
},
// Generate the attributes for a new Todo item.
// Generate the attributes for a new Todo item.
newAttributes
:
function
()
{
newAttributes
:
function
()
{
return
{
return
{
title
:
this
.
$input
.
val
().
trim
(),
title
:
this
.
$input
.
val
().
trim
(),
order
:
app
.
Todos
.
nextOrder
(),
order
:
app
.
Todos
.
nextOrder
(),
...
@@ -100,25 +101,25 @@ $(function( $ ) {
...
@@ -100,25 +101,25 @@ $(function( $ ) {
// If you hit return in the main input field, create new **Todo** model,
// If you hit return in the main input field, create new **Todo** model,
// persisting it to *localStorage*.
// persisting it to *localStorage*.
createOnEnter
:
function
(
e
)
{
createOnEnter
:
function
(
e
)
{
if
(
e
.
which
!==
ENTER_KEY
||
!
this
.
$input
.
val
().
trim
()
)
{
if
(
e
.
which
!==
ENTER_KEY
||
!
this
.
$input
.
val
().
trim
()
)
{
return
;
return
;
}
}
app
.
Todos
.
create
(
this
.
newAttributes
()
);
app
.
Todos
.
create
(
this
.
newAttributes
()
);
this
.
$input
.
val
(
''
);
this
.
$input
.
val
(
''
);
},
},
// Clear all completed todo items, destroying their models.
// Clear all completed todo items, destroying their models.
clearCompleted
:
function
()
{
clearCompleted
:
function
()
{
_
.
invoke
(
app
.
Todos
.
completed
(),
'
destroy
'
);
_
.
invoke
(
app
.
Todos
.
completed
(),
'
destroy
'
);
return
false
;
return
false
;
},
},
toggleAllComplete
:
function
()
{
toggleAllComplete
:
function
()
{
var
completed
=
this
.
allCheckbox
.
checked
;
var
completed
=
this
.
allCheckbox
.
checked
;
app
.
Todos
.
each
(
function
(
todo
)
{
app
.
Todos
.
each
(
function
(
todo
)
{
todo
.
save
({
todo
.
save
({
'
completed
'
:
completed
'
completed
'
:
completed
});
});
...
...
architecture-examples/backbone/js/views/todos.js
View file @
f0c582c3
/*global Backbone _ $ ENTER_KEY*/
var
app
=
app
||
{};
var
app
=
app
||
{};
$
(
function
()
{
$
(
function
()
{
'
use strict
'
;
'
use strict
'
;
// Todo Item View
// Todo Item View
...
@@ -13,7 +14,7 @@ $(function() {
...
@@ -13,7 +14,7 @@ $(function() {
tagName
:
'
li
'
,
tagName
:
'
li
'
,
// Cache the template function for a single item.
// Cache the template function for a single item.
template
:
_
.
template
(
$
(
'
#item-template
'
).
html
()
),
template
:
_
.
template
(
$
(
'
#item-template
'
).
html
()
),
// The DOM events specific to an item.
// The DOM events specific to an item.
events
:
{
events
:
{
...
@@ -27,50 +28,50 @@ $(function() {
...
@@ -27,50 +28,50 @@ $(function() {
// The TodoView listens for changes to its model, re-rendering. Since there's
// The TodoView listens for changes to its model, re-rendering. Since there's
// a one-to-one correspondence between a **Todo** and a **TodoView** in this
// a one-to-one correspondence between a **Todo** and a **TodoView** in this
// app, we set a direct reference on the model for convenience.
// app, we set a direct reference on the model for convenience.
initialize
:
function
()
{
initialize
:
function
()
{
this
.
listenTo
(
this
.
model
,
'
change
'
,
this
.
render
);
this
.
listenTo
(
this
.
model
,
'
change
'
,
this
.
render
);
this
.
listenTo
(
this
.
model
,
'
destroy
'
,
this
.
remove
);
this
.
listenTo
(
this
.
model
,
'
destroy
'
,
this
.
remove
);
this
.
listenTo
(
this
.
model
,
'
visible
'
,
this
.
toggleVisible
);
this
.
listenTo
(
this
.
model
,
'
visible
'
,
this
.
toggleVisible
);
},
},
// Re-render the titles of the todo item.
// Re-render the titles of the todo item.
render
:
function
()
{
render
:
function
()
{
this
.
$el
.
html
(
this
.
template
(
this
.
model
.
toJSON
()
)
);
this
.
$el
.
html
(
this
.
template
(
this
.
model
.
toJSON
())
);
this
.
$el
.
toggleClass
(
'
completed
'
,
this
.
model
.
get
(
'
completed
'
)
);
this
.
$el
.
toggleClass
(
'
completed
'
,
this
.
model
.
get
(
'
completed
'
)
);
this
.
toggleVisible
();
this
.
toggleVisible
();
this
.
$input
=
this
.
$
(
'
.edit
'
);
this
.
$input
=
this
.
$
(
'
.edit
'
);
return
this
;
return
this
;
},
},
toggleVisible
:
function
()
{
toggleVisible
:
function
()
{
this
.
$el
.
toggleClass
(
'
hidden
'
,
this
.
isHidden
());
this
.
$el
.
toggleClass
(
'
hidden
'
,
this
.
isHidden
());
},
},
isHidden
:
function
()
{
isHidden
:
function
()
{
var
isCompleted
=
this
.
model
.
get
(
'
completed
'
);
var
isCompleted
=
this
.
model
.
get
(
'
completed
'
);
return
(
// hidden cases only
return
(
// hidden cases only
(
!
isCompleted
&&
app
.
TodoFilter
===
'
completed
'
)
(
!
isCompleted
&&
app
.
TodoFilter
===
'
completed
'
)
||
||
(
isCompleted
&&
app
.
TodoFilter
===
'
active
'
)
(
isCompleted
&&
app
.
TodoFilter
===
'
active
'
)
);
);
},
},
// Toggle the `"completed"` state of the model.
// Toggle the `"completed"` state of the model.
toggleCompleted
:
function
()
{
toggleCompleted
:
function
()
{
this
.
model
.
toggle
();
this
.
model
.
toggle
();
},
},
// Switch this view into `"editing"` mode, displaying the input field.
// Switch this view into `"editing"` mode, displaying the input field.
edit
:
function
()
{
edit
:
function
()
{
this
.
$el
.
addClass
(
'
editing
'
);
this
.
$el
.
addClass
(
'
editing
'
);
this
.
$input
.
focus
();
this
.
$input
.
focus
();
},
},
// Close the `"editing"` mode, saving changes to the todo.
// Close the `"editing"` mode, saving changes to the todo.
close
:
function
()
{
close
:
function
()
{
var
value
=
this
.
$input
.
val
().
trim
();
var
value
=
this
.
$input
.
val
().
trim
();
if
(
value
)
{
if
(
value
)
{
this
.
model
.
save
({
title
:
value
});
this
.
model
.
save
({
title
:
value
});
}
else
{
}
else
{
this
.
clear
();
this
.
clear
();
...
@@ -80,14 +81,14 @@ $(function() {
...
@@ -80,14 +81,14 @@ $(function() {
},
},
// If you hit `enter`, we're through editing the item.
// If you hit `enter`, we're through editing the item.
updateOnEnter
:
function
(
e
)
{
updateOnEnter
:
function
(
e
)
{
if
(
e
.
which
===
ENTER_KEY
)
{
if
(
e
.
which
===
ENTER_KEY
)
{
this
.
close
();
this
.
close
();
}
}
},
},
// Remove the item, destroy the model from *localStorage* and delete its view.
// Remove the item, destroy the model from *localStorage* and delete its view.
clear
:
function
()
{
clear
:
function
()
{
this
.
model
.
destroy
();
this
.
model
.
destroy
();
}
}
});
});
...
...
architecture-examples/emberjs/js/app.js
View file @
f0c582c3
/*global Ember*/
window
.
Todos
=
Ember
.
Application
.
create
();
window
.
Todos
=
Ember
.
Application
.
create
();
architecture-examples/emberjs/js/controllers/todo_controller.js
View file @
f0c582c3
/*global Todos Ember*/
'
use strict
'
;
Todos
.
TodoController
=
Ember
.
ObjectController
.
extend
({
Todos
.
TodoController
=
Ember
.
ObjectController
.
extend
({
isEditing
:
false
,
isEditing
:
false
,
editTodo
:
function
()
{
editTodo
:
function
()
{
this
.
set
(
'
isEditing
'
,
true
);
this
.
set
(
'
isEditing
'
,
true
);
},
},
removeTodo
:
function
()
{
removeTodo
:
function
()
{
var
todo
=
this
.
get
(
'
model
'
);
var
todo
=
this
.
get
(
'
model
'
);
todo
.
deleteRecord
();
todo
.
deleteRecord
();
...
...
architecture-examples/emberjs/js/controllers/todos_controller.js
View file @
f0c582c3
/*global Todos Ember*/
'
use strict
'
;
Todos
.
TodosController
=
Ember
.
ArrayController
.
extend
({
Todos
.
TodosController
=
Ember
.
ArrayController
.
extend
({
createTodo
:
function
()
{
createTodo
:
function
()
{
// Get the todo title set by the "New Todo" text field
// Get the todo title set by the "New Todo" text field
var
title
=
this
.
get
(
'
newTitle
'
);
var
title
=
this
.
get
(
'
newTitle
'
);
if
(
!
title
.
trim
())
{
return
;
}
if
(
!
title
.
trim
())
{
return
;
}
...
@@ -17,38 +20,38 @@ Todos.TodosController = Ember.ArrayController.extend({
...
@@ -17,38 +20,38 @@ Todos.TodosController = Ember.ArrayController.extend({
this
.
get
(
'
store
'
).
commit
();
this
.
get
(
'
store
'
).
commit
();
},
},
clearCompleted
:
function
()
{
clearCompleted
:
function
()
{
var
completed
=
this
.
filterProperty
(
'
isCompleted
'
,
true
);
var
completed
=
this
.
filterProperty
(
'
isCompleted
'
,
true
);
completed
.
invoke
(
'
deleteRecord
'
);
completed
.
invoke
(
'
deleteRecord
'
);
this
.
get
(
'
store
'
).
commit
();
this
.
get
(
'
store
'
).
commit
();
},
},
remaining
:
function
()
{
remaining
:
function
()
{
return
this
.
filterProperty
(
'
isCompleted
'
,
false
).
get
(
'
length
'
);
return
this
.
filterProperty
(
'
isCompleted
'
,
false
).
get
(
'
length
'
);
}.
property
(
'
@each.isCompleted
'
),
}.
property
(
'
@each.isCompleted
'
),
remainingFormatted
:
function
()
{
remainingFormatted
:
function
()
{
var
remaining
=
this
.
get
(
'
remaining
'
);
var
remaining
=
this
.
get
(
'
remaining
'
);
var
plural
=
remaining
===
1
?
'
item
'
:
'
items
'
;
var
plural
=
remaining
===
1
?
'
item
'
:
'
items
'
;
return
'
<strong>%@</strong> %@ left
'
.
fmt
(
remaining
,
plural
);
return
'
<strong>%@</strong> %@ left
'
.
fmt
(
remaining
,
plural
);
}.
property
(
'
remaining
'
),
}.
property
(
'
remaining
'
),
completed
:
function
()
{
completed
:
function
()
{
return
this
.
filterProperty
(
'
isCompleted
'
,
true
).
get
(
'
length
'
);
return
this
.
filterProperty
(
'
isCompleted
'
,
true
).
get
(
'
length
'
);
}.
property
(
'
@each.isCompleted
'
),
}.
property
(
'
@each.isCompleted
'
),
hasCompleted
:
function
()
{
hasCompleted
:
function
()
{
return
this
.
get
(
'
completed
'
)
>
0
;
return
this
.
get
(
'
completed
'
)
>
0
;
}.
property
(
'
completed
'
),
}.
property
(
'
completed
'
),
allAreDone
:
function
(
key
,
value
)
{
allAreDone
:
function
(
key
,
value
)
{
if
(
value
!==
undefined
)
{
if
(
value
!==
undefined
)
{
this
.
setEach
(
'
isCompleted
'
,
value
);
this
.
setEach
(
'
isCompleted
'
,
value
);
return
value
;
return
value
;
}
else
{
}
else
{
return
!!
this
.
get
(
'
length
'
)
&&
return
!!
this
.
get
(
'
length
'
)
&&
this
.
everyProperty
(
'
isCompleted
'
,
true
);
this
.
everyProperty
(
'
isCompleted
'
,
true
);
}
}
}.
property
(
'
@each.isCompleted
'
)
}.
property
(
'
@each.isCompleted
'
)
});
});
architecture-examples/emberjs/js/models/store.js
View file @
f0c582c3
/*global Todos DS*/
'
use strict
'
;
Todos
.
Store
=
DS
.
Store
.
extend
({
Todos
.
Store
=
DS
.
Store
.
extend
({
revision
:
11
,
revision
:
11
,
adapter
:
'
Todos.LSAdapter
'
adapter
:
'
Todos.LSAdapter
'
...
...
architecture-examples/emberjs/js/models/todo.js
View file @
f0c582c3
/*global Todos DS Ember*/
'
use strict
'
;
Todos
.
Todo
=
DS
.
Model
.
extend
({
Todos
.
Todo
=
DS
.
Model
.
extend
({
title
:
DS
.
attr
(
'
string
'
),
title
:
DS
.
attr
(
'
string
'
),
isCompleted
:
DS
.
attr
(
'
boolean
'
),
isCompleted
:
DS
.
attr
(
'
boolean
'
),
todoDidChange
:
function
()
{
todoDidChange
:
function
()
{
Ember
.
run
.
once
(
this
,
function
()
{
Ember
.
run
.
once
(
this
,
function
()
{
this
.
get
(
'
store
'
).
commit
();
this
.
get
(
'
store
'
).
commit
();
});
});
}.
observes
(
'
isCompleted
'
,
'
title
'
)
}.
observes
(
'
isCompleted
'
,
'
title
'
)
...
...
architecture-examples/emberjs/js/router.js
View file @
f0c582c3
Todos
.
Router
.
map
(
function
()
{
/*global Todos Ember*/
this
.
resource
(
'
todos
'
,
{
path
:
'
/
'
},
function
()
{
'
use strict
'
;
Todos
.
Router
.
map
(
function
()
{
this
.
resource
(
'
todos
'
,
{
path
:
'
/
'
},
function
()
{
this
.
route
(
'
active
'
);
this
.
route
(
'
active
'
);
this
.
route
(
'
completed
'
);
this
.
route
(
'
completed
'
);
});
});
});
});
Todos
.
TodosRoute
=
Ember
.
Route
.
extend
({
Todos
.
TodosRoute
=
Ember
.
Route
.
extend
({
model
:
function
()
{
model
:
function
()
{
return
Todos
.
Todo
.
find
();
return
Todos
.
Todo
.
find
();
}
}
});
});
Todos
.
TodosIndexRoute
=
Ember
.
Route
.
extend
({
Todos
.
TodosIndexRoute
=
Ember
.
Route
.
extend
({
setupController
:
function
()
{
setupController
:
function
()
{
var
todos
=
Todos
.
Todo
.
find
();
var
todos
=
Todos
.
Todo
.
find
();
this
.
controllerFor
(
'
todos
'
).
set
(
'
filteredTodos
'
,
todos
);
this
.
controllerFor
(
'
todos
'
).
set
(
'
filteredTodos
'
,
todos
);
}
}
});
});
Todos
.
TodosActiveRoute
=
Ember
.
Route
.
extend
({
Todos
.
TodosActiveRoute
=
Ember
.
Route
.
extend
({
setupController
:
function
()
{
setupController
:
function
()
{
var
todos
=
Todos
.
Todo
.
filter
(
function
(
todo
)
{
var
todos
=
Todos
.
Todo
.
filter
(
function
(
todo
)
{
if
(
!
todo
.
get
(
'
isCompleted
'
))
{
return
true
;
}
if
(
!
todo
.
get
(
'
isCompleted
'
))
{
return
true
;
}
});
});
...
@@ -29,8 +32,8 @@ Todos.TodosActiveRoute = Ember.Route.extend({
...
@@ -29,8 +32,8 @@ Todos.TodosActiveRoute = Ember.Route.extend({
});
});
Todos
.
TodosCompletedRoute
=
Ember
.
Route
.
extend
({
Todos
.
TodosCompletedRoute
=
Ember
.
Route
.
extend
({
setupController
:
function
()
{
setupController
:
function
()
{
var
todos
=
Todos
.
Todo
.
filter
(
function
(
todo
)
{
var
todos
=
Todos
.
Todo
.
filter
(
function
(
todo
)
{
if
(
todo
.
get
(
'
isCompleted
'
))
{
return
true
;
}
if
(
todo
.
get
(
'
isCompleted
'
))
{
return
true
;
}
});
});
...
...
architecture-examples/emberjs/js/views/edit_todo_view.js
View file @
f0c582c3
/*global Todos Ember*/
'
use strict
'
;
Todos
.
EditTodoView
=
Ember
.
TextField
.
extend
({
Todos
.
EditTodoView
=
Ember
.
TextField
.
extend
({
classNames
:
[
'
edit
'
],
classNames
:
[
'
edit
'
],
valueBinding
:
'
todo.title
'
,
valueBinding
:
'
todo.title
'
,
change
:
function
()
{
change
:
function
()
{
var
value
=
this
.
get
(
'
value
'
);
var
value
=
this
.
get
(
'
value
'
);
if
(
Ember
.
isEmpty
(
value
))
{
if
(
Ember
.
isEmpty
(
value
))
{
...
@@ -11,15 +14,15 @@ Todos.EditTodoView = Ember.TextField.extend({
...
@@ -11,15 +14,15 @@ Todos.EditTodoView = Ember.TextField.extend({
}
}
},
},
focusOut
:
function
()
{
focusOut
:
function
()
{
this
.
set
(
'
controller.isEditing
'
,
false
);
this
.
set
(
'
controller.isEditing
'
,
false
);
},
},
insertNewline
:
function
()
{
insertNewline
:
function
()
{
this
.
set
(
'
controller.isEditing
'
,
false
);
this
.
set
(
'
controller.isEditing
'
,
false
);
},
},
didInsertElement
:
function
()
{
didInsertElement
:
function
()
{
this
.
$
().
focus
();
this
.
$
().
focus
();
}
}
});
});
architecture-examples/emberjs/js/views/todo_view.js
View file @
f0c582c3
/*global Todos Ember*/
'
use strict
'
;
Todos
.
TodoView
=
Ember
.
View
.
extend
({
Todos
.
TodoView
=
Ember
.
View
.
extend
({
tagName
:
'
li
'
,
tagName
:
'
li
'
,
classNameBindings
:
[
'
todo.isCompleted:completed
'
,
'
isEditing:editing
'
],
classNameBindings
:
[
'
todo.isCompleted:completed
'
,
'
isEditing:editing
'
],
doubleClick
:
function
(
event
)
{
doubleClick
:
function
(
)
{
this
.
set
(
'
isEditing
'
,
true
);
this
.
set
(
'
isEditing
'
,
true
);
}
}
});
});
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment