Commit 13e7c017 authored by Hans Muller's avatar Hans Muller

Merge pull request #2372 from HansMuller/menu_item

Add type parameters to uses of PopupMenuItem
parents 8af3dde3 f1659e4f
...@@ -138,16 +138,16 @@ class GridListDemoState extends State<GridListDemo> { ...@@ -138,16 +138,16 @@ class GridListDemoState extends State<GridListDemo> {
GridDemoTileStyle tileStyle = GridDemoTileStyle.twoLine; GridDemoTileStyle tileStyle = GridDemoTileStyle.twoLine;
void showTileStyleMenu(BuildContext context) { void showTileStyleMenu(BuildContext context) {
final List<PopupMenuItem> items = <PopupMenuItem>[ final List<PopupMenuItem> items = <PopupMenuItem<GridDemoTileStyle>>[
new PopupMenuItem( new PopupMenuItem<GridDemoTileStyle>(
value: GridDemoTileStyle.imageOnly, value: GridDemoTileStyle.imageOnly,
child: new Text('Image only') child: new Text('Image only')
), ),
new PopupMenuItem( new PopupMenuItem<GridDemoTileStyle>(
value: GridDemoTileStyle.oneLine, value: GridDemoTileStyle.oneLine,
child: new Text('One line') child: new Text('One line')
), ),
new PopupMenuItem( new PopupMenuItem<GridDemoTileStyle>(
value: GridDemoTileStyle.twoLine, value: GridDemoTileStyle.twoLine,
child: new Text('Two line') child: new Text('Two line')
) )
......
...@@ -61,16 +61,16 @@ class MenuDemoState extends State<MenuDemo> { ...@@ -61,16 +61,16 @@ class MenuDemoState extends State<MenuDemo> {
right: <Widget>[ right: <Widget>[
new PopupMenuButton<String>( new PopupMenuButton<String>(
onSelected: showMenuSelection, onSelected: showMenuSelection,
items: <PopupMenuItem>[ items: <PopupMenuItem<String>>[
new PopupMenuItem( new PopupMenuItem<String>(
value: 'ToolBar Menu', value: 'ToolBar Menu',
child: new Text('ToolBar Menu') child: new Text('ToolBar Menu')
), ),
new PopupMenuItem( new PopupMenuItem<String>(
value: 'Right Here', value: 'Right Here',
child: new Text('Right Here') child: new Text('Right Here')
), ),
new PopupMenuItem( new PopupMenuItem<String>(
value: 'Hooray!', value: 'Hooray!',
child: new Text('Hooray!') child: new Text('Hooray!')
), ),
...@@ -88,16 +88,16 @@ class MenuDemoState extends State<MenuDemo> { ...@@ -88,16 +88,16 @@ class MenuDemoState extends State<MenuDemo> {
primary: new Text('An item with a context menu button'), primary: new Text('An item with a context menu button'),
right: new PopupMenuButton<String>( right: new PopupMenuButton<String>(
onSelected: showMenuSelection, onSelected: showMenuSelection,
items: <PopupMenuItem>[ items: <PopupMenuItem<String>>[
new PopupMenuItem( new PopupMenuItem<String>(
value: _simpleValue1, value: _simpleValue1,
child: new Text('Context menu item one') child: new Text('Context menu item one')
), ),
new PopupMenuItem( new PopupMenuItem<String>(
enabled: false, enabled: false,
child: new Text('A disabled menu item') child: new Text('A disabled menu item')
), ),
new PopupMenuItem( new PopupMenuItem<String>(
value: _simpleValue3, value: _simpleValue3,
child: new Text('Context menu item three') child: new Text('Context menu item three')
), ),
...@@ -112,21 +112,21 @@ class MenuDemoState extends State<MenuDemo> { ...@@ -112,21 +112,21 @@ class MenuDemoState extends State<MenuDemo> {
right: new PopupMenuButton<String>( right: new PopupMenuButton<String>(
onSelected: showMenuSelection, onSelected: showMenuSelection,
items: <PopupMenuEntry<String>>[ items: <PopupMenuEntry<String>>[
new PopupMenuItem( new PopupMenuItem<String>(
value: 'Preview', value: 'Preview',
child: new ListItem( child: new ListItem(
left: new Icon(icon: Icons.visibility), left: new Icon(icon: Icons.visibility),
primary: new Text('Preview') primary: new Text('Preview')
) )
), ),
new PopupMenuItem( new PopupMenuItem<String>(
value: 'Share', value: 'Share',
child: new ListItem( child: new ListItem(
left: new Icon(icon: Icons.person_add), left: new Icon(icon: Icons.person_add),
primary: new Text('Share') primary: new Text('Share')
) )
), ),
new PopupMenuItem( new PopupMenuItem<String>(
value: 'Get Link', value: 'Get Link',
child: new ListItem( child: new ListItem(
left: new Icon(icon: Icons.link), left: new Icon(icon: Icons.link),
...@@ -134,7 +134,7 @@ class MenuDemoState extends State<MenuDemo> { ...@@ -134,7 +134,7 @@ class MenuDemoState extends State<MenuDemo> {
) )
), ),
new PopupMenuDivider(), new PopupMenuDivider(),
new PopupMenuItem( new PopupMenuItem<String>(
value: 'Remove', value: 'Remove',
child: new ListItem( child: new ListItem(
left: new Icon(icon: Icons.delete), left: new Icon(icon: Icons.delete),
...@@ -154,16 +154,16 @@ class MenuDemoState extends State<MenuDemo> { ...@@ -154,16 +154,16 @@ class MenuDemoState extends State<MenuDemo> {
primary: new Text('An item with a simple menu'), primary: new Text('An item with a simple menu'),
secondary: new Text(_simpleValue) secondary: new Text(_simpleValue)
), ),
items: <PopupMenuItem>[ items: <PopupMenuItem<String>>[
new PopupMenuItem( new PopupMenuItem<String>(
value: _simpleValue1, value: _simpleValue1,
child: new Text(_simpleValue1) child: new Text(_simpleValue1)
), ),
new PopupMenuItem( new PopupMenuItem<String>(
value: _simpleValue2, value: _simpleValue2,
child: new Text(_simpleValue2) child: new Text(_simpleValue2)
), ),
new PopupMenuItem( new PopupMenuItem<String>(
value: _simpleValue3, value: _simpleValue3,
child: new Text(_simpleValue3) child: new Text(_simpleValue3)
) )
...@@ -175,23 +175,24 @@ class MenuDemoState extends State<MenuDemo> { ...@@ -175,23 +175,24 @@ class MenuDemoState extends State<MenuDemo> {
primary: new Text('An item with a checklist menu'), primary: new Text('An item with a checklist menu'),
right: new PopupMenuButton<String>( right: new PopupMenuButton<String>(
onSelected: showCheckedMenuSelections, onSelected: showCheckedMenuSelections,
items: <PopupMenuItem>[ items: <PopupMenuItem<String>>[
new CheckedPopupMenuItem( new CheckedPopupMenuItem(
value: _checkedValue1, value: _checkedValue1,
checked: isChecked(_checkedValue1), checked: isChecked(_checkedValue1),
child: new Text(_checkedValue1) child: new Text(_checkedValue1)
), ),
new CheckedPopupMenuItem( new CheckedPopupMenuItem<String>(
value: _checkedValue2,
enabled: false, enabled: false,
checked: isChecked(_checkedValue2), checked: isChecked(_checkedValue2),
child: new Text(_checkedValue2) child: new Text(_checkedValue2)
), ),
new CheckedPopupMenuItem( new CheckedPopupMenuItem<String>(
value: _checkedValue3, value: _checkedValue3,
checked: isChecked(_checkedValue3), checked: isChecked(_checkedValue3),
child: new Text(_checkedValue3) child: new Text(_checkedValue3)
), ),
new CheckedPopupMenuItem( new CheckedPopupMenuItem<String>(
value: _checkedValue4, value: _checkedValue4,
checked: isChecked(_checkedValue4), checked: isChecked(_checkedValue4),
child: new Text(_checkedValue4) child: new Text(_checkedValue4)
......
...@@ -218,21 +218,21 @@ class StockHomeState extends State<StockHome> { ...@@ -218,21 +218,21 @@ class StockHomeState extends State<StockHome> {
), ),
new PopupMenuButton<_StockMenuItem>( new PopupMenuButton<_StockMenuItem>(
onSelected: (_StockMenuItem value) { _handleStockMenu(context, value); }, onSelected: (_StockMenuItem value) { _handleStockMenu(context, value); },
items: <PopupMenuItem>[ items: <PopupMenuItem<_StockMenuItem>>[
new CheckedPopupMenuItem( new CheckedPopupMenuItem<_StockMenuItem>(
value: _StockMenuItem.autorefresh, value: _StockMenuItem.autorefresh,
checked: _autorefresh, checked: _autorefresh,
child: new Text('Autorefresh') child: new Text('Autorefresh')
), ),
new PopupMenuItem( new PopupMenuItem<_StockMenuItem>(
value: _StockMenuItem.refresh, value: _StockMenuItem.refresh,
child: new Text('Refresh') child: new Text('Refresh')
), ),
new PopupMenuItem( new PopupMenuItem<_StockMenuItem>(
value: _StockMenuItem.speedUp, value: _StockMenuItem.speedUp,
child: new Text('Increase animation speed') child: new Text('Increase animation speed')
), ),
new PopupMenuItem( new PopupMenuItem<_StockMenuItem>(
value: _StockMenuItem.speedDown, value: _StockMenuItem.speedDown,
child: new Text('Decrease animation speed') child: new Text('Decrease animation speed')
) )
......
...@@ -19,18 +19,22 @@ class IndexedStackDemoState extends State<IndexedStackDemo> { ...@@ -19,18 +19,22 @@ class IndexedStackDemoState extends State<IndexedStackDemo> {
}); });
} }
List<PopupMenuItem> _buildMenu() { List<PopupMenuItem<int>> _buildMenu() {
TextStyle style = const TextStyle(fontSize: 18.0, fontWeight: FontWeight.bold); TextStyle style = const TextStyle(fontSize: 18.0, fontWeight: FontWeight.bold);
String pad = ''; String pad = '';
return new List<PopupMenuItem>.generate(_itemCount, (int i) { return new List<PopupMenuItem>.generate(_itemCount, (int i) {
pad += '-'; pad += '-';
return new PopupMenuItem(value: i, child: new Text('$pad Hello World $i $pad', style: style)); return new PopupMenuItem<int>(value: i, child: new Text('$pad Hello World $i $pad', style: style));
}); });
} }
Widget build(BuildContext context) { Widget build(BuildContext context) {
List<PopupMenuItem> items = _buildMenu(); List<PopupMenuItem<int>> items = _buildMenu();
IndexedStack indexedStack = new IndexedStack(children: items, index: _itemIndex, alignment: const FractionalOffset(0.5, 0.0)); IndexedStack indexedStack = new IndexedStack(
children: items,
index: _itemIndex,
alignment: const FractionalOffset(0.5, 0.0)
);
return new Scaffold( return new Scaffold(
toolBar: new ToolBar(center: new Text('IndexedStackDemo Demo')), toolBar: new ToolBar(center: new Text('IndexedStackDemo Demo')),
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment