Skip to content

benjaminnoufel/react-router

Repository files navigation

react-router

This a React Router componant for initialize a router.

Code Style CI Package Package npmjs

Requirements

Installation

$ npm install --save @benjaminnoufel/react-router
$ yarn add @benjaminnoufel/react-router

Environment setup

$ cp .env.example .env
$ $EDITOR .env

Where $EDITOR is your favorite text editor's command line interface.

Usage

Use ReactRouter with only connected routes

import ReactRouter from "@benjaminnoufel/react-router"
import React, {FC as FunctionalComponent, LazyExoticComponent, lazy} from "react";

const App = () => {
    const HomePage: LazyExoticComponent<FunctionalComponent> = lazy(() => import("@Pages/HomePage"));
    const Logout: LazyExoticComponent<FunctionalComponent> = lazy(() => import("@Pages/Logout"));
    const NotFoundPage: LazyExoticComponent<FunctionalComponent> = lazy(() => import("@Pages/404"));

    const isConnectedRoutes = [
        {
            exact: true,
            path: "/home",
            component: HomePage
        },
        {
            exact: true,
            path: "/logout",
            component: Logout
        }
    ];


    return (
        <>
            <ReactRouter
                isConnectedRoutes={isConnectedRoutes}
                isDisconnectRoutes={[]}
                globalRoutes={[]}
                notFoundPage={NotFoundPage}
                isConnected={true}

            />
        </>
    );   
}

Use ReactRouter with connected, disconnected and global routes

import ReactRouter from "@benjaminnoufel/react-router"
import React, {FC as FunctionalComponent, LazyExoticComponent, lazy} from "react";

const App = () => {
    const HomePage: LazyExoticComponent<FunctionalComponent> = lazy(() => import("@Pages/HomePage"));
    const Logout: LazyExoticComponent<FunctionalComponent> = lazy(() => import("@Pages/Logout"));
    const Login: LazyExoticComponent<FunctionalComponent> = lazy(() => import("@Pages/Login"));
    const Information: LazyExoticComponent<FunctionalComponent> = lazy(() => import("@Pages/Information"));

    const isConnectedRoutes = [
        {
            exact: true,
            path: "/home",
            component: HomePage
        },
        {
            exact: true,
            path: "/logout",
            component: Logout
        }
    ];

    const isDisconnectRoutes = [
        {
            exact: true,
            path: "/login",
            component: Login
        }
    ];

    const globalRoutes = [
        {
            exact: true,
            path: "/",
            component: Information
        }
    ];

    return (
        <>
            <ReactRouter
                isConnectedRoutes={isConnectedRoutes}
                isDisconnectRoutes={isDisconnectRoutes}
                globalRoutes={globalRoutes}
                notFoundPage={NotFoundPage}
                isConnected={true}
            />
        </>
    );   
}

API

import {RouteProps} from "react-router-dom";
interface IRouterItems extends RouteProps {}

interface IRouter {
    isConnectedRoutes: IRouterItems[];
    isDisconnectRoutes: IRouterItems[];
    globalRoutes: IRouterItems[];
    notFoundPage: LazyExoticComponent<FunctionalComponent>;
    isConnected: boolean;
}