Изменение состояния на другой вкладке навигатора из вызова функции - PullRequest
0 голосов
/ 12 июня 2019

У меня есть встроенное приложение, где я использую навигатор по табуляциям с react-navigation. Здесь я использую функцию для изменения состояния другого компонента навигатора вкладок для изменения языка с помощью AsyncStorage. Вот код, где я выполняю функцию:

export class Settings extends Component {
    constructor(props) {
        super(props);
        this.state = {
            toggle: false
        };
    }
    funcCallen = async () => {
        try {
            await AsyncStorage.setItem('toggle', JSON.stringify(false))
            this.setState({ toggle: false})
        } catch (e) {
            console.log(e)
        }
        console.log('en:', this.state.toggle)
    }
    funcCallch = async () => {
        try {
            await AsyncStorage.setItem('toggle', JSON.stringify(true))
            this.setState({ toggle: true})
        } catch (e) {
            console.log(e)
        }
        console.log('ch:', this.state.toggle)
    }
    render() {

        return (
            <Container>
                <Header>
                    <Body style={{ marginLeft: 20 }}>
                        <Title >Settings</Title>
                    </Body>
                </Header>
                <Content>
                    <View style={{ flexDirection: 'row', paddingVertical: 20, paddingHorizontal: 20 }}>
                        <Icon name='lock' style={{ color: '#bde814', marginRight: 10 }} />
                        <Text style={{ fontSize: 20, fontWeight: '400', color: '#42a6ed' }}>{this.state.toggle ? "登入" : "Sign In"}</Text>
                    </View>
                    <Separator bordered>
                        <Text style={{ fontSize: 20, fontWeight: '400' }}>Language</Text>
                    </Separator>
                    <TouchableOpacity onPress={() => this.funcCallen()}>
                        <ListItem>
                            <Text>English</Text>
                        </ListItem>
                    </TouchableOpacity>
                    <TouchableOpacity onPress={() => { this.funcCallch() }}>
                        <ListItem last>
                            <Text>Chinese</Text>
                        </ListItem>
                    </TouchableOpacity>
                    <Separator bordered>
                    </Separator>
                </Content>
            </Container>
        )
    }
}

export default Settings

А вот другой компонент навигатора вкладок, где я хочу изменить состояние от выполнения предыдущих функций компонента funcCallen и funcCallch:

class Toolbox1 extends Component{
   
  constructor(props) {
    super(props);
    this.state = {
      toggle: false
    }
  }
 
  componentWillMount() {
    const { navigation } = this.props;
    this.focusListener = navigation.addListener("didFocus", () => {
       try {
        const value =  AsyncStorage.getItem('toggle')
         this.setState({ toggle: JSON.parse(value) })
         console.log('mate:', this.state.toggle)
      } catch(e) {
        // error reading value
      }
    });
  }

  render() {
    console.log('new:', this.state.toggle)
    return (
        <Container>
        <Header>
            <Body style={{marginLeft:20}}>
              <Title>Toolbox</Title>
            </Body>
          </Header>
        <Content>
          <ListItem onPress={()=> this.props.navigation.navigate('Toolbox')}>
          <Icon name='stats' style={{color:'blue'}}/>
            <Body>
              <Text style={styles.text}>4D Number Stats & Detail</Text>
            </Body>
          </ListItem>
          <ListItem onPress={()=> this.props.navigation.navigate('LuckySpin')}>
          <Icon name='planet' style={{color:'blue'}}/>
            <Body>
              <Text style={styles.text}>{this.state.toggle ? "旋转我的运气" : "Spin My Luck"}</Text>
            </Body>
          </ListItem>
        </Content>
      </Container>
    );
  }
}
export default withNavigation(Toolbox1)

Теперь он не меняет состояние в Toolbox1. Как я могу это сделать?

...