Commit d868044e authored by Mehmet Fidanboylu's avatar Mehmet Fidanboylu Committed by GitHub

Selectively apply margin between middle and leading (#11964)

* Selectively apply margin between middle and leading

If ToolbarLayout does not have a leading widget, we should not put a margin between leading and middle areas since it ends up being blank space that looks odd. Fixes https://github.com/flutter/flutter/issues/11963

* Fix the failing test which is a good test case for missing leading widget
parent 60c4ff93
...@@ -141,7 +141,7 @@ class _ToolbarLayout extends MultiChildLayoutDelegate { ...@@ -141,7 +141,7 @@ class _ToolbarLayout extends MultiChildLayoutDelegate {
final BoxConstraints constraints = new BoxConstraints.loose(size).copyWith(maxWidth: maxWidth); final BoxConstraints constraints = new BoxConstraints.loose(size).copyWith(maxWidth: maxWidth);
final Size middleSize = layoutChild(_ToolbarSlot.middle, constraints); final Size middleSize = layoutChild(_ToolbarSlot.middle, constraints);
final double middleStartMargin = leadingWidth + _kMiddleMargin; final double middleStartMargin = hasChild(_ToolbarSlot.leading) ? leadingWidth + _kMiddleMargin : 0.0;
double middleStart = middleStartMargin; double middleStart = middleStartMargin;
final double middleY = (size.height - middleSize.height) / 2.0; final double middleY = (size.height - middleSize.height) / 2.0;
// If the centered middle will not fit between the leading and trailing // If the centered middle will not fit between the leading and trailing
......
...@@ -157,7 +157,7 @@ void main() { ...@@ -157,7 +157,7 @@ void main() {
expect(center.dx, lessThan(400 + size.width / 2.0)); expect(center.dx, lessThan(400 + size.width / 2.0));
}); });
testWidgets('AppBar centerTitle:false title start edge is 16.0 (LTR)', (WidgetTester tester) async { testWidgets('AppBar centerTitle:false title start edge is 0.0 (LTR)', (WidgetTester tester) async {
await tester.pumpWidget( await tester.pumpWidget(
new MaterialApp( new MaterialApp(
home: new Scaffold( home: new Scaffold(
...@@ -169,10 +169,10 @@ void main() { ...@@ -169,10 +169,10 @@ void main() {
), ),
); );
expect(tester.getTopLeft(find.text('X')).dx, 16.0); expect(tester.getTopLeft(find.text('X')).dx, 0.0);
}); });
testWidgets('AppBar centerTitle:false title start edge is 16.0 (RTL)', (WidgetTester tester) async { testWidgets('AppBar centerTitle:false title start edge is 0.0 (RTL)', (WidgetTester tester) async {
await tester.pumpWidget( await tester.pumpWidget(
new MaterialApp( new MaterialApp(
home: new Directionality( home: new Directionality(
...@@ -187,7 +187,7 @@ void main() { ...@@ -187,7 +187,7 @@ void main() {
), ),
); );
expect(tester.getTopRight(find.text('X')).dx, 800.0 - 16.0); expect(tester.getTopRight(find.text('X')).dx, 800.0);
}); });
testWidgets( testWidgets(
......
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