React Native routing system based on react router
-
2.5.7 : Small fix to render scene inspired by @zaynyatyi.
-
2.5.6 : Fix edge case with
transitionBack
. -
2.5.4 : Fix issue passing
routeProps
toIndexRoute
. -
2.5.3 : Fix issue passing
routeProps
. -
2.5.2 : Fix issue with
transitionBack
. -
2.5.1 : Fix for route with no component.
-
2.5.0 : Allow to pass props from router in routeProps params.
-
2.4.2 : Small code improvements.
-
2.4.0 : Improvements to how rendering is done.
-
2.3.0 : Add
routeWillFocus
androuteDidFocus
events that can be listened for.
npm i --save rn-router
'use strict';
var React = require('react-native');
var ReactRouter = require('rn-router');
var Home = require('./HomeView');
var Login = require('./LoginView');
var { Router, IndexRoute, Route, Transitions } = ReactRouter;
var Routes = React.createClass({
render: function() {
return (
<Router {...this.props} defaultTransition={Transitions.Fade}>
<IndexRoute name="login" component={Login} />
<Route name="home" component={Home} />
</Router>
);
}
});
module.exports = Routes;
'use strict';
var React = require('react-native');
var { AppRegistry } = React;
var Routes = require('./Routes');
var App = React.createClass({
render: function() {
return (
<Routes platform="ios" />
);
}
});
AppRegistry.registerComponent('App', () => App);
'use strict';
var React = require('react-native');
var { AppRegistry } = React;
var Routes = require('./Routes');
var App = React.createClass({
render: function() {
return (
<Routes platform="android" />
);
}
});
AppRegistry.registerComponent('App', () => App);
...
<Router {...this.props}>
<IndexRoute name="home" component={Home} />
<Route name="settings" component={SettingsLayout}>
<IndexRoute name="base" component={BaseSettings} />
<Route name="advanced" component={AdvancedSettings} />
</Route>
<Route name="users">
<IndexRoute name="listing" component={UsersListing} />
<Route name="profile" component={UsersProfile} />
</Route>
</Router>
...
this.context.transitionTo('settings'); // goes to 'settings/base'
this.context.transitionTo('settings/base');
this.context.transitionTo('settings/advanced');
this.context.transitionTo('users/profile', { id: 1 });
...
<Router {...this.props}>
<Route name="users">
<IndexRoute name="listing" component={UsersListing} />
<Route name=":userId" component={UsersProfile} />
</Route>
</Router>
...
this.context.transitionTo(`users/${id}`);
// UsersProfile
this.props.userId
var ReactRouter = require('rn-router');
var { Link, Transitions } = ReactRouter;
...
render() {
return (
<View>
<Link to='home'><Text>Home</Text></Link>
<Link to='login'><Text>Login</Text></Link>
<Link to='users/listing' props={{ page: 2 }}>
<Text>Listing Page 2</Text>
</Link>
<Link toBack={true}><Text>Back</Text></Link>
<Link to='login' transition={Transitions.FloatFromLeft}><Text>Login</Text></Link> // Default transition is None
<Link to='home' transition={Transitions.FloatFromBottom}><Text>Home</Text></Link>
<Link to='home' style={styles.linkButton}><Text>Home</Text></Link>
<Link to='home' activeLinkStyle={styles.highlight}><Text>Home</Text></Link> // Default active style is opacity: 0.5
<Link to='home'
props={{ id: 1 }}
linkStyle={styles.linkText}
activeLinkStyle={styles.highlight}>
<Text>Home</Text>
</Link>
</View>
);
}
- platform : the given platform value to Router or 'undefined'
- route : the route object ( name, component, props, sceneConfig )
- transitionTo : transition function params (name, props(optional), transitionFunction(optional))
- transitionBack : transition to last route
- events : event listener for
routeWillFocus
androuteDidFocus
events
var ReactRouter = require('rn-router');
...
contextTypes: {
events: React.PropTypes.object
},
...
this.context.events.on('routeWillFocus', (route) => {
this.setState({transitionStarted: true});
});
this.context.events.on('routeDidFocus', (route) => {
this.setState({fullyRouted: true});
});
var ReactRouter = require('rn-router');
var { Transitions } = ReactRouter;
...
contextTypes: {
transitionTo: React.PropTypes.func,
transitionBack: React.PropTypes.func
},
...
render() {
return (
<View>
<TouchableOpacity onPress={() => { this.context.transitionBack()}}>
<Text>
Back
</Text>
</TouchableOpacity>
<TouchableOpacity onPress={() => { this.context.transitionTo('home')}}>
<Text>
Home
</Text>
</TouchableOpacity>
</View>
);
}
The available transitions are as follows
var ReactRouter = require('rn-router');
var { Transitions } = ReactRouter;
Transitions.FloatFromRight
Transitions.FloatFromLeft
Transitions.FloatFromBottom
Transitions.FloatFromBottomAndroid
Transitions.FadeAndroid
Transitions.HorizontalSwipeJump
Transitions.HorizontalSwipeJumpFromRight
Transitions.VerticalUpSwipeJump
Transitions.VerticalDownSwipeJump
Transitions.None
Transitions.Fade
Transitions.NoGestures(Transitions.FloatFromBottom)