router.js 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. import React from 'react';
  2. import {
  3. ToastAndroid,
  4. BackHandler,
  5. DeviceEventEmitter,
  6. Platform
  7. } from 'react-native';
  8. import {connect} from 'react-redux';
  9. import {
  10. createReduxContainer,
  11. createReactNavigationReduxMiddleware,
  12. createNavigationReducer,
  13. } from 'react-navigation-redux-helpers';
  14. import {
  15. NavigationActions,
  16. } from 'react-navigation';
  17. import RootStack from './root'
  18. export const routerReducer = createNavigationReducer(RootStack);
  19. export const routerMiddleware = createReactNavigationReduxMiddleware(
  20. Platform.OS === 'ios' ? (state) => state.router : state => state.nav,
  21. );
  22. const AppStack = createReduxContainer(RootStack, 'root');
  23. let lastBackPressed = 0;
  24. function getActiveRouteName(navigationState) {
  25. if (!navigationState) {
  26. return null;
  27. }
  28. const route = navigationState.routes[navigationState.index];
  29. if (route.routes) {
  30. return getActiveRouteName(route);
  31. }
  32. return route.routeName;
  33. }
  34. @connect(({app, router}) => ({app, router}))
  35. class Router extends React.PureComponent {
  36. componentDidMount() {
  37. BackHandler.addEventListener('hardwareBackPress', this.backHandle);
  38. }
  39. componentWillUnmount() {
  40. BackHandler.removeEventListener('hardwareBackPress', this.backHandle);
  41. }
  42. backHandle = () => {
  43. const currentScreen = getActiveRouteName(this.props.router);
  44. if (currentScreen === 'Main') {
  45. return true;
  46. }
  47. const MainRouteNames = ['DesktopHome',];
  48. if (MainRouteNames.indexOf(currentScreen) === -1) {
  49. this.props.dispatch(NavigationActions.back());
  50. return true;
  51. } else {
  52. if (lastBackPressed && lastBackPressed + 2000 >= Date.now()) {
  53. //最近2秒内按过back键,可以退出应用。
  54. return false;
  55. }
  56. lastBackPressed = Date.now();
  57. ToastAndroid.show('再按一次退出应用', ToastAndroid.SHORT);
  58. return true;
  59. }
  60. };
  61. render() {
  62. const {dispatch, router} = this.props;
  63. return <AppStack
  64. dispatch={dispatch}
  65. state={router}
  66. />;
  67. }
  68. }
  69. export default Router;