react-router-firebase-auth-guard
TypeScript icon, indicating that this package has built-in type declarations

1.1.0 • Public • Published

react-router-firebase-auth-guard

A Package For Managing React-Router Firebase Auth Guard

Installing Required Packages

npm install --save firebase react-router-dom

OR

yarn add firebase react-router-dom

Installing Package

npm install --save react-router-firebase-auth-guard

OR

yarn add react-router-firebase-auth-guard

Usage


import { initializeApp } from 'firebase';
import React from 'react';
import ReactDOM from 'react-dom';
import { FirebaseAuthGuardRouter, FirebaseAuthGuardRoute } from 'react-router-firebase-auth-guard';
import {
    Link
} from 'react-router-dom'
 
// COPIED FROM YOUR FIREBASE PROJECT
var config = {
    apiKey: "<API_KEY>",
    authDomain: "<AUTH_DOMAIN>",
    databaseURL: "BASE_URL",
    projectId: "PROJECT_ID"
};
 
initializeApp(config);
 
const NavBar = ({ auth }) => (
    <div>
        react-router-firebase-auth-guard
        {auth ?
            <ul style={{ display: 'flex' }}>
                <li><Link to="/">Nutral</Link></li>
                <li><Link to="/auth">Auth Required</Link></li>
            </ul>
            :
            <ul style={{ display: 'flex' }}>
                <li><Link to="/">Nutral</Link></li>
                <li><Link to="/noauth">noAuth Required</Link></li>
            </ul>
        }
    </div>
)
ReactDOM.render(
    <div>
        <FirebaseAuthGuardRouter loading={<span>loading...</span>} navBar={NavBar}>
            <FirebaseAuthGuardRoute exact path="/" component={() => <h1>Nutral</h1>} />
            <FirebaseAuthGuardRoute noAuthOnly exact redirectPath="/noauth" path="/auth" component={() => <h1>auth</h1>} />
            <FirebaseAuthGuardRoute authOnly redirectPath="/auth" path="/noauth" component={() => <h1>no auth</h1>} />
        </FirebaseAuthGuardRouter>
    </div>,
    document.getElementById('root') // ROOT IS MY ID PASTE HERE YOURS
);

Package Sidebar

Install

npm i react-router-firebase-auth-guard

Weekly Downloads

1

Version

1.1.0

License

MIT

Last publish

Collaborators

  • ghulammustafaraza