| OLD | NEW |
| 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
| 3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
| 4 | 4 |
| 5 library todomvc.web.app; | 5 library todomvc.web.app; |
| 6 | 6 |
| 7 import 'dart:html'; | 7 import 'dart:html'; |
| 8 import 'package:polymer/polymer.dart'; | 8 import 'package:polymer/polymer.dart'; |
| 9 import 'model.dart'; | 9 import 'model.dart'; |
| 10 | 10 |
| 11 @CustomTag('todo-app') | 11 @CustomTag('todo-app') |
| 12 class TodoApp extends PolymerElement { | 12 class TodoApp extends PolymerElement { |
| 13 @observable AppModel app; | 13 @observable AppModel app; |
| 14 bool get applyAuthorStyles => true; | 14 bool get applyAuthorStyles => true; |
| 15 | 15 |
| 16 factory TodoApp() => new Element.tag('TodoApp'); | 16 factory TodoApp() => new Element.tag('TodoApp'); |
| 17 | 17 |
| 18 TodoApp.created() : super.created() { | 18 TodoApp.created() : super.created() { |
| 19 app = appModel; | 19 app = appModel; |
| 20 } | 20 } |
| 21 | 21 |
| 22 void addTodo(Event e) { | 22 void addTodo(Event e) { |
| 23 e.preventDefault(); // don't submit the form | 23 e.preventDefault(); // don't submit the form |
| 24 InputElement input = getShadowRoot('todo-app').query('#new-todo'); | 24 InputElement input = getShadowRoot('todo-app').querySelector('#new-todo'); |
| 25 if (input.value == '') return; | 25 if (input.value == '') return; |
| 26 app.todos.add(new Todo(input.value)); | 26 app.todos.add(new Todo(input.value)); |
| 27 input.value = ''; | 27 input.value = ''; |
| 28 } | 28 } |
| 29 | 29 |
| 30 void clear() => app.clearDone(); | 30 void clear() => app.clearDone(); |
| 31 } | 31 } |
| OLD | NEW |