Commit 69f9e3b2 authored by Hans Muller's avatar Hans Muller

Added ListItem dividers

parent f3561d80
...@@ -21,9 +21,10 @@ class ListDemoState extends State<ListDemo> { ...@@ -21,9 +21,10 @@ class ListDemoState extends State<ListDemo> {
ScaffoldFeatureController _bottomSheet; ScaffoldFeatureController _bottomSheet;
ListDemoItemSize _itemSize = ListDemoItemSize.threeLine; ListDemoItemSize _itemSize = ListDemoItemSize.threeLine;
bool _dense = true; bool _dense = false;
bool _showAvatar = true; bool _showAvatars = true;
bool _showIcon = false; bool _showIcons = false;
bool _showDividers = false;
bool _reverseSort = false; bool _reverseSort = false;
List<String> items = <String>[ List<String> items = <String>[
'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N' 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N'
...@@ -77,10 +78,10 @@ class ListDemoState extends State<ListDemo> { ...@@ -77,10 +78,10 @@ class ListDemoState extends State<ListDemo> {
dense: true, dense: true,
primary: new Text('Show Avatar'), primary: new Text('Show Avatar'),
right: new Checkbox( right: new Checkbox(
value: _showAvatar, value: _showAvatars,
onChanged: (bool value) { onChanged: (bool value) {
setState(() { setState(() {
_showAvatar = value; _showAvatars = value;
}); });
_bottomSheet?.setState(() { }); _bottomSheet?.setState(() { });
} }
...@@ -90,10 +91,23 @@ class ListDemoState extends State<ListDemo> { ...@@ -90,10 +91,23 @@ class ListDemoState extends State<ListDemo> {
dense: true, dense: true,
primary: new Text('Show Icon'), primary: new Text('Show Icon'),
right: new Checkbox( right: new Checkbox(
value: _showIcon, value: _showIcons,
onChanged: (bool value) { onChanged: (bool value) {
setState(() { setState(() {
_showIcon = value; _showIcons = value;
});
_bottomSheet?.setState(() { });
}
)
),
new ListItem(
dense: true,
primary: new Text('Show Dividers'),
right: new Checkbox(
value: _showDividers,
onChanged: (bool value) {
setState(() {
_showDividers = value;
}); });
_bottomSheet?.setState(() { }); _bottomSheet?.setState(() { });
} }
...@@ -132,10 +146,10 @@ class ListDemoState extends State<ListDemo> { ...@@ -132,10 +146,10 @@ class ListDemoState extends State<ListDemo> {
return new ListItem( return new ListItem(
isThreeLine: _itemSize == ListDemoItemSize.threeLine, isThreeLine: _itemSize == ListDemoItemSize.threeLine,
dense: _dense, dense: _dense,
left: _showAvatar ? new CircleAvatar(child: new Text(item)) : null, left: _showAvatars ? new CircleAvatar(child: new Text(item)) : null,
primary: new Text('This item represents $item'), primary: new Text('This item represents $item'),
secondary: secondary, secondary: secondary,
right: _showIcon ? new Icon(icon: 'action/info', color: Theme.of(context).disabledColor) : null right: _showIcons ? new Icon(icon: 'action/info', color: Theme.of(context).disabledColor) : null
); );
} }
...@@ -153,6 +167,11 @@ class ListDemoState extends State<ListDemo> { ...@@ -153,6 +167,11 @@ class ListDemoState extends State<ListDemo> {
itemSizeText = 'Three-Line'; itemSizeText = 'Three-Line';
break; break;
} }
Iterable<Widget> listItems = items.map((String item) => buildListItem(context, item));
if (_showDividers)
listItems = ListItem.divideItems(context: context, items: listItems);
return new Scaffold( return new Scaffold(
key: scaffoldKey, key: scaffoldKey,
toolBar: new ToolBar( toolBar: new ToolBar(
...@@ -177,7 +196,7 @@ class ListDemoState extends State<ListDemo> { ...@@ -177,7 +196,7 @@ class ListDemoState extends State<ListDemo> {
), ),
body: new Block( body: new Block(
padding: new EdgeDims.all(_dense ? 4.0 : 8.0), padding: new EdgeDims.all(_dense ? 4.0 : 8.0),
children: items.map((String item) => buildListItem(context, item)).toList() children: listItems.toList()
) )
); );
} }
......
...@@ -41,6 +41,32 @@ class ListItem extends StatelessComponent { ...@@ -41,6 +41,32 @@ class ListItem extends StatelessComponent {
final GestureTapCallback onTap; final GestureTapCallback onTap;
final GestureLongPressCallback onLongPress; final GestureLongPressCallback onLongPress;
/// Add a one pixel border in between each item. If color isn't specified the
/// dividerColor of the context's theme is used.
static Iterable<Widget> divideItems({ BuildContext context, Iterable<Widget> items, Color color }) sync* {
assert(items != null);
assert(color != null || context != null);
final Color dividerColor = color ?? Theme.of(context).dividerColor;
final Iterator<Widget> iterator = items.iterator;
final bool isNotEmpty = iterator.moveNext();
Widget item = iterator.current;
while(iterator.moveNext()) {
yield new DecoratedBox(
decoration: new BoxDecoration(
border: new Border(
bottom: new BorderSide(color: dividerColor)
)
),
child: item
);
item = iterator.current;
}
if (isNotEmpty)
yield item;
}
TextStyle primaryTextStyle(BuildContext context) { TextStyle primaryTextStyle(BuildContext context) {
final ThemeData theme = Theme.of(context); final ThemeData theme = Theme.of(context);
final TextStyle style = theme.text.subhead; final TextStyle style = theme.text.subhead;
......
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