Experiment
This is an experimental library and may have breaking changes in the future.
Goal
The goal of RNN Screens is to provide React Native developers with more simplified and predictable Navigation. It's built on top of React Native Navigation.
Quick start
Starters
-
starters-dev/rnn-with-expo - minimalistic starter with React Native Navigation, Expo Modules and RNN Screens.
-
rnn-starter - more advanced starter that is powered by cli-rn, React Native Navigation, Expo Modules, RNN Screens, RN UI lib, MMKV, Mobx, Reanimated 2, Dark Mode, Localization, Notifications, Permissions, and much more.
Bare RNN
React Native Navigation and RNN Screens
1. Install> yarn add react-native-navigation rnn-screens
> npx rnn-link
> npx pod-install
If you had problems installing RNN, please follow more detailed tutorial
2. Build screen components
import {generateRNNScreens, Root, BottomTabs, Screen, ScreenComponent} from 'rnn-screens';
// src/screens/main.tsx
export const Main: ScreenComponent = ({componentId}) => {
return <>...</>;
};
// src/screens/settings.tsx
type SettingsProps = {type: 'push' | 'show'};
export const Settings: ScreenComponent<SettingsProps> = ({componentId, type}) => {
return <>...</>;
};
3. Describe screens
// src/screens/index.tsx
import {generateRNNScreens} from 'rnn-screens';
import {Main} from './main';
import {Settings} from './settings';
export const screens = generateRNNScreens({
Main: {
component: Main,
options: {
topBar: {title: {text: 'Home'}},
},
},
Settings: {
component: Settings,
options: {
topBar: {title: {text: 'Settings'}},
},
},
});
4. Build root component
// App.tsx
// single screen app
export const App = () => Root(Screen(screens.get('Main')));
// tab based app
export const TabsApp = () =>
Root(
BottomTabs([
Screen(screens.get('Main')),
Screen(screens.get('Settings'))
])
);
index.js
5. Update // index.js
import {registerRootComponent} from 'rnn-screens';
import {App} from './App';
registerRootComponent(App);
6. Navigate with predictability
// navigate from any screen
// push screen
screens.push(componentId, 'Settings');
// show modal
screens.show('Settings');
// push screen with passProps
screens.push<SettingsProps>(componentId, 'Settings', {type: 'push'});
// use RNN Navigation instance
screens.N.dismissAllModals();
Enhancements
Feel free to open an issue for suggestions.
Credits
Thanks to the React Native Navigation team @ Wix!
License
This project is MIT licensed