Skip to content
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

Remove explicit React Native entry point #7138

Merged
merged 2 commits into from
Jul 5, 2023
Merged

Remove explicit React Native entry point #7138

merged 2 commits into from
Jul 5, 2023

Conversation

hsubox76
Copy link
Contributor

@hsubox76 hsubox76 commented Mar 20, 2023

DO NOT MERGE until 6/20. This is a breaking change and must be released with a major version. It is expected to release with the next major version of the SDK in June 2023.

Remove firebase/auth/react-native entry point. The React Native bundle should be automatically picked up by React Native build tools which recognize the react-native fields in package.json (at the top level and in exports). Firestore already does this.

The result is that users will not need to remember to use a special path when importing auth in React Native.

Test: I've tested this with an Expo project and it works. One caveat is there's a common pattern where users override Metro's default resolver and spread the old defaultResolver, not realizing that this removes the react-native field from resolverMainFields as Metro's default config is platform agnostic. See facebook/metro#807

If users run into this issue we need to remind them that this kind of Metro config modification:

exports.resolver = {
  ...defaultResolver,
  sourceExts: [
    ...defaultResolver.sourceExts,
    "cjs",
  ],
};

has unexpected results and what they really want to do is:

exports.resolver = {
  sourceExts: [
    ...defaultResolver.sourceExts,
    "cjs",
  ],
};

as their custom metro config will automatically extend existing defaults without the user having to include them explicitly.

The result of doing it the wrong way (the first example) is that Metro will grab the browser bundle instead of the one specified in the package.json react-native field. See #7115 for an example of a Firestore user having an issue with this (Firestore is currently the only other product with a specific react native bundle).

@changeset-bot
Copy link

changeset-bot bot commented Mar 20, 2023

🦋 Changeset detected

Latest commit: 5fbc371

The changes in this PR will be included in the next version bump.

This PR includes changesets to release 4 packages
Name Type
firebase Major
@firebase/auth Major
@firebase/rules-unit-testing Major
@firebase/auth-compat Patch

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

@hsubox76 hsubox76 added this to the v10 milestone May 23, 2023
@hsubox76 hsubox76 marked this pull request as ready for review July 2, 2023 18:35
@hsubox76 hsubox76 changed the title DO NOT MERGE: Remove explicit React Native entry point Jul 2, 2023
Copy link
Contributor

@dwyfrequency dwyfrequency left a comment

Choose a reason for hiding this comment

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

LGTM

@hsubox76 hsubox76 merged commit c2686ed into master Jul 5, 2023
@hsubox76 hsubox76 deleted the ch-auth-rn branch July 5, 2023 20:59
@google-oss-bot google-oss-bot mentioned this pull request Jul 6, 2023
@firebase firebase locked and limited conversation to collaborators Aug 5, 2023
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
4 participants