Как использовать StackNavigator в React Native

Я пытаюсь заставить мое приложение, использующее свои реакции, использовать stackNavigator, поэтому, когда люди нажимают кнопку "Назад" на телефоне с Android, они переходят на HomeScreen.

Я хочу, чтобы все экраны из bottomNavigator возвращались на HomeScreen при первом нажатии кнопки "Назад". Также я создал новый экран (TravelCPHAirportScreen), который не должен быть включен в bottomNavigationbar, и теперь, когда я к нему перехожу, я не могу вернуться снова, потому что кнопка "Назад" выходит из приложения.

Я попробовал несколько вещей, но не могу понять, правильно ли я разместил новый TravelCPHAirportScreen и как сделать stackNavigator, как описано.

import React, {Component} from 'react';
import { createStackNavigator, createBottomTabNavigator } from 'react-navigation';
import { Ionicons } from '@expo/vector-icons';

import AuthScreen from './AuthScreen';

import HomeScreen from './HomeScreen';
import MeetingScreen from './MeetingScreen';
import TripScreen from './TripScreen';
import RateTripScreen from './RateTripScreen';
import ProfileScreen from './ProfileScreen';

import TravelCPHAirportScreen from './TravelCPHAirportScreen';

let AuthStack = createStackNavigator({ AuthScreen }, {
    headerMode: 'none',
    navigationOptions: {
        headerStyle: {
            backgroundColor: '#202020',
        },
        headerTintColor: '#fff',
        headerTitleStyle: {
            fontWeight: 'bold',
        },
    },
});

AuthStack.navigationOptions = {
    tabBarLabel: 'Login',
    tabBarVisible: false,
};


let HomeStack = createStackNavigator({ HomeScreen }, {
    title: 'Home  ',
    titleStyle: {
      color: '#f0ca6d',
      fontWeight: '300',
      justifyContent: 'space-between',
    },
    navigationOptions: {
        headerStyle: {
            backgroundColor: '#303030',
        },
        headerTintColor: '#f0ca6d',
        headerTitleStyle: {
            fontWeight: 'bold',
        },
    },
});

HomeStack.navigationOptions = {
    tabBarLabel: 'Home',
    tabBarVisible: true,
};

let MeetingStack = createStackNavigator({ MeetingScreen }, {
    navigationOptions: {
        title: 'Meeting',
        titleStyle: {
          color: '#f0ca6d',
          fontWeight: '300',
          justifyContent: 'space-between',
          textAlign: 'center'
        },
        headerStyle: {
            backgroundColor: '#303030',
        },
        headerTintColor: '#f0ca6d',
        headerTitleStyle: {
            fontWeight: 'bold',
        },
    },
});

MeetingStack.navigationOptions = {
    tabBarLabel: 'Meeting Point',
    tabBarVisible: true,
};

let TripStack = createStackNavigator({ TripScreen }, {
    navigationOptions: {
        title: 'Trip',
        titleStyle: {
          color: '#f0ca6d',
          fontWeight: '300',
          justifyContent: 'space-between'
        },
        headerStyle: {
            backgroundColor: '#303030',
        },
        headerTintColor: '#f0ca6d',
        headerTitleStyle: {
            fontWeight: 'bold',
        },
    },
});

TripStack.navigationOptions = {
    tabBarLabel: 'Trip',
    tabBarVisible: true,
};


let RateStack = createStackNavigator({ RateTripScreen }, {
    navigationOptions: {
        title: 'Rate Trip',
        titleStyle: {
          color: '#f0ca6d',
          fontWeight: '300',
          justifyContent: 'space-between'
        },
        headerStyle: {
            backgroundColor: '#303030',
        },
        headerTintColor: '#fff',
        headerTitleStyle: {
            fontWeight: 'bold',
        },
    },
});

RateStack.navigationOptions = {
    tabBarLabel: 'Rate Trip',
    tabBarVisible: true,
};


let ProfileStack = createStackNavigator({ ProfileScreen }, {
    navigationOptions: {
        title: 'Profile',
        titleStyle: {
          color: '#f0ca6d',
          fontWeight: '300',
          justifyContent: 'space-between',
          textAlign: 'center'
        },
        headerStyle: {
            backgroundColor: '#303030',
        },
        headerTintColor: '#f0ca6d',
        headerTitleStyle: {
            fontWeight: 'bold',
        },
    },
});

ProfileStack.navigationOptions = {
    tabBarLabel: 'Profile',
    tabBarVisible: true,
};



let TravelCPHAirportStack = createStackNavigator({ TravelCPHAirportScreen }, { headerMode: 'none',
    navigationOptions: {
        headerStyle: {
            backgroundColor: '#202020',
        },
        headerTintColor: '#fff',
        headerTitleStyle: {
            fontWeight: 'bold',
        },
    },
});

TravelCPHAirportStack.navigationOptions = {
    tabBarLabel: 'CPH Airport',
    tabBarVisible: false,
};



let MainTab = createBottomTabNavigator(
    {
        HomeStack,
        MeetingStack,
        TripStack,
        RateStack,
        ProfileStack,
    },
    {
        navigationOptions: ({ navigation }) => ({
            tabBarIcon: ({ focused, tintColor }) => {

                const { routeName } = navigation.state;

                let iconName;

                switch (routeName) {
                  case 'HomeStack':
                      // const iconName = Platform.OS === 'android' ? 'android-icon': 'ios-icon';
                      iconName = `ios-home${focused ? '' : '-outline'}`;
                      break;
                  case 'MeetingStack':
                      iconName = `ios-git-network${focused ? '' : '-outline'}`;
                      break;
                  case 'TripStack':
                      iconName = `ios-map${focused ? '' : '-outline'}`;
                      break;
                  case 'RateStack':
                      // const iconName = Platform.OS === 'android' ? 'android-icon': 'ios-icon';
                      iconName = `ios-star${focused ? '' : '-outline'}`;
                      break;
                  case 'ProfileStack':
                      // const iconName = Platform.OS === 'android' ? 'android-icon': 'ios-icon';
                      iconName = `ios-person${focused ? '' : '-outline'}`;
                      break;
                }

                return <Ionicons name={iconName} size={30} color={tintColor} />;

            },
        }),
        headerMode: 'none',
        tabBarOptions: {
            style: {
              backgroundColor: '#202020'
            },
            activeTintColor: '#f0ca6d',
            inactiveTintColor: 'white',
            labelStyle: { fontSize: 12 }
        },
        tabBarPosition: 'bottom'
    }
);

MainTab.navigationOptions = {
    tabBarLabel: 'Main',
    tabBarVisible: false,
};

let RootTab = createBottomTabNavigator(
    {
        AuthStack,
        MainTab,
    },{
        navigationOptions: ({ navigation }) => ({
            tabBarIcon: ({ focused, tintColor }) => {

                const { routeName } = navigation.state;
                let iconName;

                switch (routeName) {
                    case 'AuthStack':
                        iconName = `ios-log-in${focused ? '' : '-outline'}`;
                        break;
                }
                return <Ionicons name={iconName} size={30} color={tintColor} />;
            },
        }),
        headerMode: 'none',
        tabBarOptions: {
            activeTintColor: 'tomato',
            inactiveTintColor: 'gray',
            labelStyle: { fontSize: 12 }
        },
        tabBarPosition: 'bottom'
    }
);

const Root = createStackNavigator(
    {
        root: RootTab,
    },
    { headerMode: 'none', }
);

class Navigation extends Component {
    render() {
        return (
           <Root/>
        );
    }
}
export default Navigation;

0 ответов

Другие вопросы по тегам