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 'package:sky/theme/colors.dart' as colors; | 5 import 'package:sky/theme/colors.dart' as colors; |
6 import 'package:sky/widgets/basic.dart'; | 6 import 'package:sky/widgets/basic.dart'; |
7 import 'package:sky/widgets/checkbox.dart'; | 7 import 'package:sky/widgets/checkbox.dart'; |
8 import 'package:sky/widgets/icon_button.dart'; | 8 import 'package:sky/widgets/icon_button.dart'; |
9 import 'package:sky/widgets/menu_item.dart'; | 9 import 'package:sky/widgets/menu_item.dart'; |
10 import 'package:sky/widgets/navigator.dart'; | 10 import 'package:sky/widgets/navigator.dart'; |
11 import 'package:sky/widgets/scaffold.dart'; | 11 import 'package:sky/widgets/scaffold.dart'; |
12 import 'package:sky/widgets/theme.dart'; | 12 import 'package:sky/widgets/theme.dart'; |
13 import 'package:sky/widgets/tool_bar.dart'; | 13 import 'package:sky/widgets/tool_bar.dart'; |
14 | 14 |
15 import 'stock_home.dart'; | |
jackson
2015/06/23 00:44:03
I don't think the settings page should need to kno
| |
16 | |
17 typedef void SettingsUpdater({StockMode mode}); | |
18 | |
15 class StockSettings extends Component { | 19 class StockSettings extends Component { |
16 | 20 |
17 StockSettings(this._navigator); | 21 StockSettings(this.navigator, this.stockMode, this.updater) : super(stateful: true); |
18 | 22 |
19 Navigator _navigator; | 23 Navigator navigator; |
24 StockMode stockMode; | |
25 SettingsUpdater updater; | |
20 | 26 |
21 bool _awesome = false; | 27 void syncFields(StockSettings source) { |
28 navigator = source.navigator; | |
29 stockMode = source.stockMode; | |
30 updater = source.updater; | |
31 } | |
32 | |
22 void _handleAwesomeChanged(bool value) { | 33 void _handleAwesomeChanged(bool value) { |
jackson
2015/06/23 00:44:03
might want to rename this _handleModeChanged
| |
23 setState(() { | 34 setState(() { |
24 _awesome = value; | 35 stockMode = value ? StockMode.optimistic : StockMode.pessimistic; |
25 }); | 36 }); |
37 sendUpdates(); | |
38 } | |
39 | |
40 void sendUpdates() { | |
41 if (updater != null) | |
42 updater( | |
43 mode: stockMode | |
44 ); | |
26 } | 45 } |
27 | 46 |
28 Widget buildToolBar() { | 47 Widget buildToolBar() { |
29 return new ToolBar( | 48 return new ToolBar( |
30 left: new IconButton( | 49 left: new IconButton( |
31 icon: 'navigation/arrow_back_white', | 50 icon: 'navigation/arrow_back_white', |
32 onPressed: _navigator.pop), | 51 onPressed: navigator.pop), |
33 center: new Text('Settings', style: Theme.of(this).text.title) | 52 center: new Text('Settings', style: Theme.of(this).text.title) |
34 ); | 53 ); |
35 } | 54 } |
36 | 55 |
37 Widget buildSettingsPane() { | 56 Widget buildSettingsPane() { |
38 return new Container( | 57 return new Container( |
39 padding: const EdgeDims.symmetric(vertical: 20.0), | 58 padding: const EdgeDims.symmetric(vertical: 20.0), |
40 decoration: new BoxDecoration(backgroundColor: colors.Grey[50]), | 59 decoration: new BoxDecoration(backgroundColor: colors.Grey[50]), |
41 child: new Block([ | 60 child: new Block([ |
42 new MenuItem( | 61 new MenuItem( |
43 icon: 'action/thumb_up', | 62 icon: 'action/thumb_up', |
44 onPressed: () => _handleAwesomeChanged(!_awesome), | 63 onPressed: () => _handleAwesomeChanged(stockMode == StockMode.optimist ic ? false : true), |
45 children: [ | 64 children: [ |
46 new Flexible(child: new Text('Everything is awesome')), | 65 new Flexible(child: new Text('Everything is awesome')), |
47 new Checkbox(value: _awesome, onChanged: _handleAwesomeChanged) | 66 new Checkbox(value: stockMode == StockMode.optimistic, onChanged: _h andleAwesomeChanged) |
48 ] | 67 ] |
49 ), | 68 ), |
50 ]) | 69 ]) |
51 ); | 70 ); |
52 } | 71 } |
53 | 72 |
54 Widget build() { | 73 Widget build() { |
55 return new Scaffold( | 74 return new Scaffold( |
56 toolbar: buildToolBar(), | 75 toolbar: buildToolBar(), |
57 body: buildSettingsPane() | 76 body: buildSettingsPane() |
58 ); | 77 ); |
59 } | 78 } |
60 } | 79 } |
OLD | NEW |