react-native-signin-with-google

1.0.1 • Public • Published

Google Easy SignIn tutorial for React Native

first of all Inatsll below Depandancy's

 npm install react-native-signin-with-google
   npm install @react-native-google-signin/google-signin

  npx react-native link @react-native-google-signin/google-signin

A straightforward approach of creating Google Sign In for a React Native app that works for both iOS and Android. ** Image here Go to https://console.cloud.google.com/ and create a New Project

The navigate to APIs & Services → Credentials

Click on CREATE CREDENTIALS → OAuth client ID

From the Application Type dropdown select iOS

Give this key a Name (convention is to have a name without any caps the screenshot below is just shared as an example)and Bundle ID (same as in your info.plist file of iOS project) and click CREATE.

You’ll now see the key in your credentials under OAuth 2.0 Client IDs

For iOS we also need to add a URL scheme. Click on the Name of the key you just created., in my case the name is DECIDER-RN-iOS-App-client and you’ll. be taken to a page like this:

Here copy the** iOS URL scheme** given on the right side and open your React Native iOS project in XCode.

Select your app from the TARGETS section, then select the Info tab, and expand the URL Types section. Click on. the + button and paste the copied** iOS URL scheme** here.

That’s it for iOS setup next we’ll create a key for android.

Click on CREATE CREDENTIALS → OAuth client ID and this time from Application type select Android.

Same as before giving it a name and copy the exact Package name as per your AndroidManifest.xml file.

A new thing here is it’s asking for an SHA-1 certificate fingerprint.

SHA-1 signing certificate fingerprint restricts usage to your Android apps.

SHA-1 signing certificate fingerprint restricts usage to your Android apps. Learn more

To create an SHA-1 fingerprint Open your React-Native Project and from its terminal first, do cd android and then run this command:

keytool -keystore app/debug.keystore -list -v

NOTE: The above command will give you a DEV key. To get an SHA-1 key for PROD use the above command but replace debug.keystore with your release.keystore and use that SHA-1. I suggest making two keys one for DEV and one for PROD.

If it asks you for the password, the password is android press enter and you’ll see

Copy the SHA1 (hidden with green) and paste the SHA-1 key in the Google Cloud Console ad click on CREATE.

Great now you have two client IDs one for iOS and one for Android.

Now Go to code Structure

Import this line in your project

import Google from 'react-native-signin-with-google';

import React from "react";
import { StyleSheet, Text, View, TouchableOpacity } from "react-native";
import Google from "react-native-signin-with-google";

const App = () => {
  return (
    <View style={{ flex: 1, justifyContent: "center", alignItems: "center" }}>
      <TouchableOpacity
        style={styles.btn}
        onPress={() => {
          Google(
            "androidClientId",
            "iosClientId",
            //login or logout
            "login"
            //You will get particular data Like
            // id,name,email,familyName,givenName,photo
            'id',
            'name',
            'email',
            'familyName',
            'givenName',
            'photo',

          ).then((i) => {
            console.log("====================================");
            console.log("my Data", JSON.stringify(i, null, 4));
            console.log("====================================");
          });

          // you can also get all data using 'all_data'
          Google(
            "androidClientId",
            "iosClientId",
            //login or logout
            "login"
            'all_data',

          ).then((i) => {
            console.log("====================================");
            console.log("my Data", JSON.stringify(i, null, 4));
            console.log("====================================");
          });


        }}
      >
        <Text style={styles.txt}>Login with Google</Text>
      </TouchableOpacity>
      <TouchableOpacity
        style={[styles.btn, { marginTop: 20 }]}
        onPress={() => {
          Google(
            "androidClientId",
            "iosClientId",
            //Login or Logout
            "logout"
          );
        }}
      >
        <Text style={styles.txt}>LOGOUT</Text>
      </TouchableOpacity>
    </View>
  );
};

export default App;

const styles = StyleSheet.create({
  btn: {
    justifyContent: "center",
    alignItems: "center",
    width: "95%",
    height: 70,
    borderRadius: 15,
    backgroundColor: "darkorange",
  },
  txt: {
    fontSize: 16,
    color: "red",
    fontWeight: "bold",
  },
});
Congrats 🙌 🎉! you have successfully implemented react-native-signin-with-google for your react native project.

Package Sidebar

Install

npm i react-native-signin-with-google

Weekly Downloads

1

Version

1.0.1

License

MIT

Unpacked Size

9.55 kB

Total Files

4

Last publish

Collaborators

  • invx_nixters