This API is relevant when in a screen component context - it allows a screen to push other screens, pop screens, change its navigator style, etc. Access to this API is available through the navigator
object that is passed to your component through props
.
Push a new screen into this screen’s navigation stack.
this.props.navigator.push({
screen: 'example.ScreenThree', // unique ID registered with Navigation.registerScreen
title: undefined, // navigation bar title of the pushed screen (optional)
subtitle: undefined, // navigation bar subtitle of the pushed screen (optional)
titleImage: require('../../img/my_image.png'), // iOS only. navigation bar title image instead of the title text of the pushed screen (optional)
passProps: {}, // Object that will be passed as props to the pushed screen (optional)
animated: true, // does the push have transition animation or does it happen immediately (optional)
animationType: 'fade', // 'fade' (for both) / 'slide-horizontal' (for android) does the push have different transition animation (optional)
backButtonTitle: undefined, // override the back button title (optional)
backButtonHidden: false, // hide the back button altogether (optional)
navigatorStyle: {}, // override the navigator style for the pushed screen (optional)
navigatorButtons: {}, // override the nav buttons for the pushed screen (optional)
// enable peek and pop - commited screen will have `isPreview` prop set as true.
previewView: undefined, // react ref or node id (optional)
previewHeight: undefined, // set preview height, defaults to full height (optional)
previewCommit: true, // commit to push preview controller to the navigation stack (optional)
previewActions: [{ // action presses can be detected with the `PreviewActionPress` event on the commited screen.
id: '', // action id (required)
title: '', // action title (required)
style: undefined, // 'selected' or 'destructive' (optional)
actions: [], // list of sub-actions
}],
});
Pop the top screen from this screen’s navigation stack.
this.props.navigator.pop({
animated: true, // does the pop have transition animation or does it happen immediately (optional)
animationType: 'fade', // 'fade' (for both) / 'slide-horizontal' (for android) does the pop have different transition animation (optional)
});
Pop all the screens until the root from this screen’s navigation stack.
this.props.navigator.popToRoot({
animated: true, // does the popToRoot have transition animation or does it happen immediately (optional)
animationType: 'fade', // 'fade' (for both) / 'slide-horizontal' (for android) does the popToRoot have different transition animation (optional)
});
Reset the screen’s navigation stack to a new screen (the stack root is changed).
this.props.navigator.resetTo({
screen: 'example.ScreenThree', // unique ID registered with Navigation.registerScreen
title: undefined, // navigation bar title of the pushed screen (optional)
passProps: {}, // simple serializable object that will pass as props to the pushed screen (optional)
animated: true, // does the resetTo have transition animation or does it happen immediately (optional)
animationType: 'fade', // 'fade' (for both) / 'slide-horizontal' (for android) does the resetTo have different transition animation (optional)
navigatorStyle: {}, // override the navigator style for the pushed screen (optional)
navigatorButtons: {} // override the nav buttons for the pushed screen (optional)
});
Show a screen as a modal.
this.props.navigator.showModal({
screen: "example.ModalScreen", // unique ID registered with Navigation.registerScreen
title: "Modal", // title of the screen as appears in the nav bar (optional)
passProps: {}, // simple serializable object that will pass as props to the modal (optional)
navigatorStyle: {}, // override the navigator style for the screen, see "Styling the navigator" below (optional)
animationType: 'slide-up' // 'none' / 'slide-up' , appear animation for the modal (optional, default 'slide-up')
});
Dismiss the current modal.
this.props.navigator.dismissModal({
animationType: 'slide-down' // 'none' / 'slide-down' , dismiss animation for the modal (optional, default 'slide-down')
});
Dismiss all the current modals at the same time.
this.props.navigator.dismissAllModals({
animationType: 'slide-down' // 'none' / 'slide-down' , dismiss animation for the modal (optional, default 'slide-down')
});
Show a screen as a lightbox.
this.props.navigator.showLightBox({
screen: "example.LightBoxScreen", // unique ID registered with Navigation.registerScreen
passProps: {}, // simple serializable object that will pass as props to the lightbox (optional)
style: {
backgroundBlur: "dark", // 'dark' / 'light' / 'xlight' / 'none' - the type of blur on the background
backgroundColor: "#ff000080" // tint color for the background, you can specify alpha here (optional)
},
adjustSoftInput: "resize", // android only, adjust soft input, modes: 'nothing', 'pan', 'resize', 'unspecified' (optional, default 'unspecified')
});
Dismiss the current lightbox.
this.props.navigator.dismissLightBox();
Show in-app notification. This generally looks like a pop-up window that can appear at the top of the screen.
this.props.navigator.showInAppNotification({
screen: "example.InAppNotification", // unique ID registered with Navigation.registerScreen
passProps: {}, // simple serializable object that will pass as props to the in-app notification (optional)
autoDismissTimerSec: 1 // auto dismiss notification in seconds
});
Trigger a deep link within the app. See deep links for more details about how screens can listen for deep link events.
this.props.navigator.handleDeepLink({
link: "chats/2349823023" // the link string (required)
});
handleDeepLink
can also be called statically:
import {Navigation} from 'react-native-navigation'; Navigation.handleDeepLink(...);
Set buttons dynamically on the navigator. If your buttons don’t change during runtime, see “Adding buttons to the navigator” below to add them using static navigatorButtons = {...};
.
this.props.navigator.setButtons({
leftButtons: [], // see "Adding buttons to the navigator" below for format (optional)
rightButtons: [], // see "Adding buttons to the navigator" below for format (optional)
animated: true // does the change have transition animation or does it happen immediately (optional)
});
Set the nav bar title dynamically. If your title doesn’t change during runtime, set it when the screen is defined / pushed.
this.props.navigator.setTitle({
title: "Dynamic Title" // the new title of the screen as appears in the nav bar
});
Set the nav bar subtitle dynamically. If your subtitle doesn’t change during runtime, set it when the screen is defined / pushed.
this.props.navigator.setSubTitle({
subtitle: "Connecting..."
});
Toggle the side menu drawer assuming you have one in your app.
this.props.navigator.toggleDrawer({
side: 'left', // the side of the drawer since you can have two, 'left' / 'right'
animated: true, // does the toggle have transition animation or does it happen immediately (optional)
to: 'open' // optional, 'open' = open the drawer, 'closed' = close it, missing = the opposite of current state
});
Enables or disables the side menu drawer assuming you have one in your app. Both drawers are enabled by default.
this.props.navigator.setDrawerEnabled({
side: 'left', // the side of the drawer since you can have two, 'left' / 'right'
enabled: false // should the drawer be enabled or disabled (locked closed)
});
Toggle whether the tabs are displayed or not (only in tab-based apps).
this.props.navigator.toggleTabs({
to: 'hidden', // required, 'hidden' = hide tab bar, 'shown' = show tab bar
animated: true // does the toggle have transition animation or does it happen immediately (optional)
});
Set the badge on a tab (any string or numeric value).
this.props.navigator.setTabBadge({
tabIndex: 0, // (optional) if missing, the badge will be added to this screen's tab
badge: 17, // badge value, null to remove badge
badgeColor: '#006400', // (optional) if missing, the badge will use the default color
});
Change the tab icon on a bottom tab.
this.props.navigator.setTabButton({
tabIndex: 0, // (optional) if missing, the icon will be added to this screen's tab
icon: require('../img/one.png'), // local image asset for the tab icon unselected state (optional)
selectedIcon: require('../img/one_selected.png'), // local image asset for the tab icon selected state (optional, iOS only)
label: 'New Label' // tab label that appears under the icon (optional)
});
Switch to a tab (sets it as the currently selected tab).
this.props.navigator.switchToTab({
tabIndex: 0 // (optional) if missing, this screen's tab will become selected
});
Toggle whether the navigation bar is displayed or not.
this.props.navigator.toggleNavBar({
to: 'hidden', // required, 'hidden' = hide navigation bar, 'shown' = show navigation bar
animated: true // does the toggle have transition animation or does it happen immediately (optional). By default animated: true
});
Set a handler for navigator events (like nav button press). This would normally go in your component constructor.
Can not be used in conjuction with addOnNavigatorEvent
.
// this.onNavigatorEvent will be our handler
this.props.navigator.setOnNavigatorEvent(this.onNavigatorEvent.bind(this));
Add a handler for navigator events (like nav button press). This would normally go in your component constructor.
If you choose to use addOnNavigatorEvent
instead of setOnNavigatorEvent
you will be able to add multiple handlers.
Bear in mind that you can’t use both addOnNavigatorEvent
and setOnNavigatorEvent
.
addOnNavigatorEvent
returns a function, that once called will remove the registered handler.
const isVisible = await this.props.navigator.screenIsCurrentlyVisible()
export default class ExampleScreen extends Component {
constructor(props) {
super(props);
this.props.navigator.setOnNavigatorEvent(this.onNavigatorEvent.bind(this));
}
onNavigatorEvent(event) {
switch(event.id) {
case 'willAppear':
break;
case 'didAppear':
break;
case 'willDisappear':
break;
case 'didDisappear':
break;
case 'willCommitPreview':
break;
}
}
}
import {ScreenVisibilityListener as RNNScreenVisibilityListener} from 'react-native-navigation';
export class ScreenVisibilityListener {
constructor() {
this.listener = new RNNScreenVisibilityListener({
didAppear: ({screen, startTime, endTime, commandType}) => {
console.log('screenVisibility', `Screen ${screen} displayed in ${endTime - startTime} millis after [${commandType}]`);
}
});
}
register() {
this.listener.register();
}
unregister() {
if (this.listener) {
this.listener.unregister();
this.listener = null;
}
}
}
In order to listen to bottomTabSelected
event, set an onNavigatorEventListener
on screens that are pushed to BottomTab. The event is dispatched to the top most screen pushed to the selected tab’s stack.
export default class ExampleScreen extends Component {
constructor(props) {
super(props);
this.props.navigator.setOnNavigatorEvent(this.onNavigatorEvent.bind(this));
}
onNavigatorEvent(event) {
if (event.id === 'bottomTabSelected') {
console.log('Tab selected!');
}
if (event.id === 'bottomTabReselected') {
console.log('Tab reselected!');
}
}
}
react-native-navigation supports the Peek and pop feature by setting a react view reference as a previewView
parameter when doing a push, more options are available in the push
section.
You can define actions and listen for interactions on the pushed screen with the PreviewActionPress
event.
Previewed screens will have the prop isPreview
that can be used to render different things when the screen is in the “Peek” state and will then recieve a navigator event of willCommitPreview
when in the “Pop” state.