Commit f202e7ab authored by Adam Barth's avatar Adam Barth

_ModalScope has local copies of route state

Now we just use the state from the Route.

Fixes #744
parent 0fe72b17
...@@ -258,45 +258,35 @@ abstract class LocalHistoryRoute<T> extends Route<T> { ...@@ -258,45 +258,35 @@ abstract class LocalHistoryRoute<T> extends Route<T> {
class _ModalScopeStatus extends InheritedWidget { class _ModalScopeStatus extends InheritedWidget {
_ModalScopeStatus({ _ModalScopeStatus({
Key key, Key key,
this.current, this.isCurrent,
this.route, this.route,
Widget child Widget child
}) : super(key: key, child: child) { }) : super(key: key, child: child) {
assert(current != null); assert(isCurrent != null);
assert(route != null); assert(route != null);
assert(child != null); assert(child != null);
} }
final bool current; final bool isCurrent;
final Route route; final Route route;
bool updateShouldNotify(_ModalScopeStatus old) { bool updateShouldNotify(_ModalScopeStatus old) {
return current != old.current || return isCurrent != old.isCurrent ||
route != old.route; route != old.route;
} }
void debugFillDescription(List<String> description) { void debugFillDescription(List<String> description) {
super.debugFillDescription(description); super.debugFillDescription(description);
description.add('${current ? "active" : "inactive"}'); description.add('${isCurrent ? "active" : "inactive"}');
} }
} }
class _ModalScope extends StatefulComponent { class _ModalScope extends StatefulComponent {
_ModalScope({ _ModalScope({
Key key, Key key,
this.subtreeKey,
this.storageBucket,
this.performance,
this.forwardPerformance,
this.current,
this.route this.route
}) : super(key: key); }) : super(key: key);
final GlobalKey subtreeKey;
final PageStorageBucket storageBucket;
final PerformanceView performance;
final PerformanceView forwardPerformance;
final bool current;
final ModalRoute route; final ModalRoute route;
_ModalScopeState createState() => new _ModalScopeState(); _ModalScopeState createState() => new _ModalScopeState();
...@@ -305,24 +295,17 @@ class _ModalScope extends StatefulComponent { ...@@ -305,24 +295,17 @@ class _ModalScope extends StatefulComponent {
class _ModalScopeState extends State<_ModalScope> { class _ModalScopeState extends State<_ModalScope> {
void initState() { void initState() {
super.initState(); super.initState();
config.performance?.addStatusListener(_performanceStatusChanged); config.route.performance?.addStatusListener(_performanceStatusChanged);
config.forwardPerformance?.addStatusListener(_performanceStatusChanged); config.route.forwardPerformance?.addStatusListener(_performanceStatusChanged);
} }
void didUpdateConfig(_ModalScope oldConfig) { void didUpdateConfig(_ModalScope oldConfig) {
if (config.performance != oldConfig.performance) { assert(config.route == oldConfig.route);
oldConfig.performance?.removeStatusListener(_performanceStatusChanged);
config.performance?.addStatusListener(_performanceStatusChanged);
}
if (config.forwardPerformance != oldConfig.forwardPerformance) {
oldConfig.forwardPerformance?.removeStatusListener(_performanceStatusChanged);
config.forwardPerformance?.addStatusListener(_performanceStatusChanged);
}
} }
void dispose() { void dispose() {
config.performance?.removeStatusListener(_performanceStatusChanged); config.route.performance?.removeStatusListener(_performanceStatusChanged);
config.forwardPerformance?.removeStatusListener(_performanceStatusChanged); config.route.forwardPerformance?.removeStatusListener(_performanceStatusChanged);
super.dispose(); super.dispose();
} }
...@@ -334,12 +317,12 @@ class _ModalScopeState extends State<_ModalScope> { ...@@ -334,12 +317,12 @@ class _ModalScopeState extends State<_ModalScope> {
Widget build(BuildContext context) { Widget build(BuildContext context) {
Widget contents = new PageStorage( Widget contents = new PageStorage(
key: config.subtreeKey, key: config.route._subtreeKey,
bucket: config.storageBucket, bucket: config.route._storageBucket,
child: new _ModalScopeStatus( child: new _ModalScopeStatus(
current: config.current,
route: config.route, route: config.route,
child: config.route.buildPage(context, config.performance, config.forwardPerformance) isCurrent: config.route.isCurrent,
child: config.route.buildPage(context, config.route.performance, config.route.forwardPerformance)
) )
); );
if (config.route.offstage) { if (config.route.offstage) {
...@@ -348,11 +331,11 @@ class _ModalScopeState extends State<_ModalScope> { ...@@ -348,11 +331,11 @@ class _ModalScopeState extends State<_ModalScope> {
contents = new Focus( contents = new Focus(
key: new GlobalObjectKey(config.route), key: new GlobalObjectKey(config.route),
child: new IgnorePointer( child: new IgnorePointer(
ignoring: config.performance?.status == PerformanceStatus.reverse, ignoring: config.route.performance?.status == PerformanceStatus.reverse,
child: config.route.buildTransitions( child: config.route.buildTransitions(
context, context,
config.performance, config.route.performance,
config.forwardPerformance, config.route.forwardPerformance,
contents contents
) )
) )
...@@ -457,11 +440,6 @@ abstract class ModalRoute<T> extends TransitionRoute<T> with LocalHistoryRoute<T ...@@ -457,11 +440,6 @@ abstract class ModalRoute<T> extends TransitionRoute<T> with LocalHistoryRoute<T
Widget _buildModalScope(BuildContext context) { Widget _buildModalScope(BuildContext context) {
return new _ModalScope( return new _ModalScope(
key: _scopeKey, key: _scopeKey,
subtreeKey: _subtreeKey,
storageBucket: _storageBucket,
performance: performance,
forwardPerformance: forwardPerformance,
current: isCurrent,
route: this route: this
// calls buildTransitions() and buildPage(), defined above // calls buildTransitions() and buildPage(), defined above
); );
......
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