Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(114)

Side by Side Diff: samples/third_party/todomvc/web/editable_label.dart

Issue 24149003: Port of github.com/polymer/polymer. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: rebase Created 7 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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 editable_label; 5 library todomvc.web.editable_label;
6 6
7 import 'dart:html'; 7 import 'dart:html';
8 import 'package:polymer/polymer.dart'; 8 import 'package:polymer/polymer.dart';
9 9
10 /** 10 /**
11 * Label whose [value] can be edited by double clicking. When editing, it 11 * Label whose [value] can be edited by double clicking. When editing, it
12 * displays a form and input element, otherwise it displays the label. 12 * displays a form and input element, otherwise it displays the label.
13 */ 13 */
14 class EditableLabel extends PolymerElement with ObservableMixin { 14 class EditableLabel extends PolymerElement {
15 @observable bool editing = false; 15 @observable bool editing = false;
16 @observable String value = ''; 16 @published String value = '';
17
17 bool get applyAuthorStyles => true; 18 bool get applyAuthorStyles => true;
18 19
19 InputElement get _editBox => getShadowRoot("editable-label").query('#edit'); 20 InputElement get _editBox => getShadowRoot("editable-label").query('#edit');
20 21
21 void edit() { 22 void edit() {
22 editing = true; 23 editing = true;
23 24
24 // This causes _editBox to be inserted. 25 // This causes _editBox to be inserted.
25 performMicrotaskCheckpoint(); 26 performMicrotaskCheckpoint();
26 27
(...skipping 12 matching lines...) Expand all
39 } 40 }
40 41
41 void maybeCancel(KeyboardEvent e) { 42 void maybeCancel(KeyboardEvent e) {
42 if (e.keyCode == KeyCode.ESC) { 43 if (e.keyCode == KeyCode.ESC) {
43 editing = false; 44 editing = false;
44 } 45 }
45 } 46 }
46 } 47 }
47 48
48 void main() { 49 void main() {
49 registerPolymerElement('editable-label', () => new EditableLabel()); 50 Polymer.register('editable-label', EditableLabel);
50 } 51 }
OLDNEW
« no previous file with comments | « samples/third_party/todomvc/web/app.dart ('k') | samples/third_party/todomvc/web/editable_label.html » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698