Skip to content

Routing + Navigation Bar + Left Panel for react native apps

Notifications You must be signed in to change notification settings

anubhav756/router-react-native

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

32 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Install

npm i router-react-native

Usage

import Router from 'router-react-native';

export default class MyApp extends Component {
  render() {
    return (
      <Router
        routes={[
            { index: Index },
            { login: Login },
            { users: Users },
                ...
            { defaultRouteName: DefaultRouteComponent }
        ]}
        defaultRoute='defaultRouteName'
        initialRoute='index'
        navBar={<NavBarComponent />}
        leftPanel={<LeftPanelComponent />}
        onOpen={() => { alert('Left panel opened!') }}
        onClose={() => { alert('Left panel closed!') }}
        leftPanelOffset={100}
        />
    );
  }
}

AppRegistry.registerComponent('MyApp', () => MyApp);

Change routes

import { pushRoute, popRoute } from 'router-react-native';

handleNextClick() {
    const hideNavBar = true;
    const routeParameters = { ... };
        ...

    pushRoute('routeName', routeParameters, hideNavBar);
}

handleBackClick() {
    popRoute();
}

Props

  • routes: An array to map route ids with route's component
  • initialRoute: id of the initial route
  • defaultRoute: id of the default route (in case no matching route id is found)
  • navBar: Component which will be rendered as the top navigation bar
  • leftPanel: Component which will be rendered as the left panel
  • onOpen: Event handler for left panel open
  • onClose: Event handler for left panel close
  • leftPanelOffset: Space to be left empty while opening left panel (default 100)

Exports

  • currentRoute: Information about the current route
    • currentRoute.id: Unique route id
    • currentRoute.params: Route parameters
    • currentRoute.index: Index in the routing stack
  • pushRoute (id, params, hideNavBar): To go to a new route
    • id: The route's id
    • params: Optional routing parameters
    • hideNavBar: true for hiding the navigation bar for this new route
  • popRoute (n): Go back n routes (1 by default). 0 to clear history, and go to initial route
  • updateLayoutData (Object): Update the layoutData prop of navBar/leftPanel components

Props for navBar & leftPanel

  • toggleLeftPanel(): Toggle left panel
  • showingLeftPanel: Whether left panel is visible or not (true/false)
  • layoutData: Any data which needs to be sent to the layout components (navBar/leftPanel)

router-react-native NPM module

About

Routing + Navigation Bar + Left Panel for react native apps

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published