这是indexloc提供的服务,不要输入任何密码
Skip to content

enable Navigator.of to accept a navigator element and return its stat… #58259

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 3 commits into from
Jun 8, 2020

Conversation

chunhtai
Copy link
Contributor

…e directly

Description

Navigator.of uses context.findAncestorStateOfType which does not handle the case where the context is a navigator element. this pr fixes it.

Related Issues

Fixes #34105

Tests

I added the following tests:

See files

Checklist

Before you create this PR confirm that it meets all requirements listed below by checking the relevant checkboxes ([x]). This will ensure a smooth and quick review process.

  • I read the Contributor Guide and followed the process outlined there for submitting PRs.
  • I signed the CLA.
  • I read and followed the Flutter Style Guide, including Features we expect every widget to implement.
  • I read the Tree Hygiene wiki page, which explains my responsibilities.
  • I updated/added relevant documentation (doc comments with ///).
  • All existing and new tests are passing.
  • The analyzer (flutter analyze --flutter-repo) does not report any problems on my PR.
  • I am willing to follow-up on review comments in a timely manner.

Breaking Change

Did any tests fail when you ran them? Please read Handling breaking changes.

@fluttergithubbot fluttergithubbot added f: material design flutter/packages/flutter/material repository. framework flutter/packages/flutter repository. See also f: labels. labels May 29, 2020
@chunhtai chunhtai removed the f: material design flutter/packages/flutter/material repository. label May 29, 2020
final NavigatorState navigator = rootNavigator
? context.findRootAncestorStateOfType<NavigatorState>()
: context.findAncestorStateOfType<NavigatorState>();
// Handles the case where the input context is a navigator element.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

/cc @gspencergoog I seem to remember that you recently also ran into the problem that "self" is not included when you look up ancestors. How did we solve the problem there again?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I created _getAncestor to fetch the parent so that I can start searching using getElementForInheritedWidgetOfExactType from the parent element, which avoids returning itself just by starting the search with the parent element.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

And my problem was the opposite: getElementForInheritedWidgetOfExactType can return self, and I didn't want it to.

Comment on lines 2136 to 2137
if (context is StatefulElement) {
if (context.state is NavigatorState)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I believe these two ifs can be combined into one.

Copy link
Member

@goderbauer goderbauer left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@fluttergithubbot fluttergithubbot merged commit 333eb9d into flutter:master Jun 8, 2020
mono0926 added a commit to mono0926/flutter_mono_kit that referenced this pull request Jul 31, 2020
mono0926 added a commit to mono0926/flutter_mono_kit that referenced this pull request Aug 7, 2020
mingwandroid pushed a commit to mingwandroid/flutter that referenced this pull request Sep 6, 2020
@github-actions github-actions bot locked as resolved and limited conversation to collaborators Jul 30, 2021
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
framework flutter/packages/flutter repository. See also f: labels.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Create a builder that builds a widget that a wraps routes of Navigator.
5 participants