Unverified Commit fb2cffb0 authored by LongCatIsLooong's avatar LongCatIsLooong Committed by GitHub

[Hero] toHero flightShuttleBuilder overrides fromHero flightShuttleBuilder (#77733)

parent 7b1aec70
...@@ -996,8 +996,8 @@ class HeroController extends NavigatorObserver { ...@@ -996,8 +996,8 @@ class HeroController extends NavigatorObserver {
fromHero: fromHero, fromHero: fromHero,
toHero: toHero, toHero: toHero,
createRectTween: createRectTween, createRectTween: createRectTween,
shuttleBuilder: fromHero.widget.flightShuttleBuilder shuttleBuilder: toHero.widget.flightShuttleBuilder
?? toHero.widget.flightShuttleBuilder ?? fromHero.widget.flightShuttleBuilder
?? _defaultHeroFlightShuttleBuilder, ?? _defaultHeroFlightShuttleBuilder,
isUserGestureTransition: isUserGestureTransition, isUserGestureTransition: isUserGestureTransition,
isDiverted: existingFlight != null, isDiverted: existingFlight != null,
......
...@@ -1612,7 +1612,7 @@ Future<void> main() async { ...@@ -1612,7 +1612,7 @@ Future<void> main() async {
expect(tester.getTopLeft(find.byKey(firstKey)).dx, x0); expect(tester.getTopLeft(find.byKey(firstKey)).dx, x0);
}); });
testWidgets('Can override flight shuttle', (WidgetTester tester) async { testWidgets('Can override flight shuttle in to hero', (WidgetTester tester) async {
await tester.pumpWidget(MaterialApp( await tester.pumpWidget(MaterialApp(
home: Material( home: Material(
child: ListView( child: ListView(
...@@ -1656,6 +1656,102 @@ Future<void> main() async { ...@@ -1656,6 +1656,102 @@ Future<void> main() async {
expect(find.text('baz'), findsOneWidget); expect(find.text('baz'), findsOneWidget);
}); });
testWidgets('Can override flight shuttle in from hero', (WidgetTester tester) async {
await tester.pumpWidget(MaterialApp(
home: Material(
child: ListView(
children: <Widget>[
Hero(
tag: 'a',
child: const Text('foo'),
flightShuttleBuilder: (
BuildContext flightContext,
Animation<double> animation,
HeroFlightDirection flightDirection,
BuildContext fromHeroContext,
BuildContext toHeroContext,
) { return const Text('baz'); },
),
Builder(builder: (BuildContext context) {
return TextButton(
child: const Text('two'),
onPressed: () => Navigator.push<void>(context, MaterialPageRoute<void>(
builder: (BuildContext context) {
return const Material(
child: Hero(tag: 'a', child: Text('bar')),
);
},
)),
);
}),
],
),
),
));
await tester.tap(find.text('two'));
await tester.pump();
await tester.pump(const Duration(milliseconds: 10));
expect(find.text('foo'), findsNothing);
expect(find.text('bar'), findsNothing);
expect(find.text('baz'), findsOneWidget);
});
// Regression test for https://github.com/flutter/flutter/issues/77720.
testWidgets("toHero's shuttle builder over fromHero's shuttle builder", (WidgetTester tester) async {
await tester.pumpWidget(MaterialApp(
home: Material(
child: ListView(
children: <Widget>[
Hero(
tag: 'a',
child: const Text('foo'),
flightShuttleBuilder: (
BuildContext flightContext,
Animation<double> animation,
HeroFlightDirection flightDirection,
BuildContext fromHeroContext,
BuildContext toHeroContext,
) { return const Text('fromHero text'); },
),
Builder(builder: (BuildContext context) {
return TextButton(
child: const Text('two'),
onPressed: () => Navigator.push<void>(context, MaterialPageRoute<void>(
builder: (BuildContext context) {
return Material(
child: Hero(
tag: 'a',
child: const Text('bar'),
flightShuttleBuilder: (
BuildContext flightContext,
Animation<double> animation,
HeroFlightDirection flightDirection,
BuildContext fromHeroContext,
BuildContext toHeroContext,
) { return const Text('toHero text'); },
),
);
},
)),
);
}),
],
),
),
));
await tester.tap(find.text('two'));
await tester.pump();
await tester.pump(const Duration(milliseconds: 10));
expect(find.text('foo'), findsNothing);
expect(find.text('bar'), findsNothing);
expect(find.text('fromHero text'), findsNothing);
expect(find.text('toHero text'), findsOneWidget);
});
testWidgets('Can override flight launch pads', (WidgetTester tester) async { testWidgets('Can override flight launch pads', (WidgetTester tester) async {
await tester.pumpWidget(MaterialApp( await tester.pumpWidget(MaterialApp(
home: Material( home: Material(
......
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