OLD | NEW |
---|---|
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 import '../fn.dart'; | 5 import '../fn.dart'; |
6 | 6 |
7 abstract class ButtonBase extends Component { | 7 abstract class ButtonBase extends Component { |
8 bool highlight = false; | 8 bool highlight = false; |
9 | 9 |
10 ButtonBase({ Object key }) : super(key: key) { | 10 ButtonBase({ Object key }) : super(key: key); |
11 events.listen('pointerdown', _handlePointerDown); | 11 |
12 events.listen('pointerup', _handlePointerUp); | 12 Node buildContent(); |
rafaelw
2015/03/19 06:11:26
I'm tempted to feel like this is the wrong pattern
abarth-chromium
2015/03/19 14:19:59
Yeah.
| |
13 events.listen('pointercancel', _handlePointerCancel); | 13 |
14 Node build() { | |
15 return new EventTarget( | |
16 buildContent(), | |
17 onPointerDown: _handlePointerDown, | |
18 onPointerUp: _handlePointerUp, | |
19 onPointerCancel: _handlePointerCancel | |
20 ); | |
14 } | 21 } |
15 | 22 |
16 void _handlePointerDown(_) { | 23 void _handlePointerDown(_) { |
17 setState(() { | 24 setState(() { |
18 highlight = true; | 25 highlight = true; |
19 }); | 26 }); |
20 } | 27 } |
21 void _handlePointerUp(_) { | 28 void _handlePointerUp(_) { |
22 setState(() { | 29 setState(() { |
23 highlight = false; | 30 highlight = false; |
24 }); | 31 }); |
25 } | 32 } |
26 void _handlePointerCancel(_) { | 33 void _handlePointerCancel(_) { |
27 setState(() { | 34 setState(() { |
28 highlight = false; | 35 highlight = false; |
29 }); | 36 }); |
30 } | 37 } |
31 } | 38 } |
OLD | NEW |