React Native Router flux action.key () не работает - PullRequest
0 голосов
/ 04 декабря 2018

Я строю проект на React Native, я новичок в React Native.Но, к сожалению, Actions.key () не работает.Вот мои данные кода

App.js

import React, { Component } from 'react';
import { AsyncStorage, ActivityIndicator } from 'react-native';
import { Provider } from 'react-redux';
import { createStore, applyMiddleware } from 'redux';
import ReduxThunk from 'redux-thunk';
import { PersistGate } from 'redux-persist/integration/react'
import Spinner from './components/common/Spinner'; 
import reducers from './reducers';
import Router from './Router';
import { persistStore, persistReducer } from 'redux-persist'

class App extends Component {

  render() {
    renderLoading = () =>
{
 <Spinner size="large" />;  
}
    const persistConfig = {
      key: 'root2',
      storage: AsyncStorage  
    }
    const persistedReducer = persistReducer(persistConfig, reducers) 
    const store = createStore(persistedReducer, {}, applyMiddleware(ReduxThunk));
    const persistor = persistStore(store);
    return (

      <Provider store={store}>
      <PersistGate loading={null} persistor={persistor}>
        <Router />
        </PersistGate>
      </Provider>
    );
  }
}

export default App;


LoginForm.js



import React, { Component } from 'react';
import { Text } from 'react-native';
import { connect } from 'react-redux';
import { emailChanged, passwordChanged, loginUser, loginUserSuccess1 } from '../actions';
import { Card, CardSection, Input, Button, Spinner } from './common';
import { Actions } from 'react-native-router-flux';
import NameEnter from './NameEnter';
import Router from '../Router';

class LoginForm extends Component {
  componentDidMount()
  {

    console.log (this.props.userDetails); 
    if(this.props.userDetails != null) 
    {
    if (this.props.userDetails.success !== false) {
      console.log (this.props.userDetails.success);
      this.props.loginUserSuccess1(this.props.userDetails);    

    }   
  }     
    //Actions.screen1();   

  }
  onEmailChange(text) {

    this.props.emailChanged(text);
  }

  onPasswordChange(text) {
    this.props.passwordChanged(text);
  }

  onButtonPress() {
    const { email, password } = this.props;

    this.props.loginUser({ email, password });
  }

  renderButton() {
    // if (this.props.loading) {
    //   return <Spinner size="large" />;
    // }

    return (
      <Button onPress={this.onButtonPress.bind(this)}>
        Login
      </Button>
    );
  }


  render() {

    return (
      <Card>

        <CardSection>
          <Input
            label="Email"
            placeholder="email@gmail.com"
            onChangeText={this.onEmailChange.bind(this)}
            value={this.props.email}
          />
        </CardSection>

        <CardSection>
          <Input
            secureTextEntry
            label="Password"
            placeholder="password"
            onChangeText={this.onPasswordChange.bind(this)}
            value={this.props.password}
          />
        </CardSection>

        <Text style={styles.errorTextStyle}>
          {this.props.error}
        </Text>

        <CardSection>
          {this.renderButton()}
        </CardSection>
      </Card>
    );
  }
}

const styles = {
  errorTextStyle: {
    fontSize: 20,
    alignSelf: 'center',
    color: 'red'
  }
};

const mapStateToProps = ({ auth }) => {
  const { email, password, error, loading , userDetails } = auth;

  return { email, password, error, loading , userDetails };
};

export default connect(mapStateToProps, {
  emailChanged, passwordChanged, loginUser, loginUserSuccess1
})(LoginForm);

AuthActions.js

 import { Actions } from 'react-native-router-flux';
    import axios from 'react-native-axios';


    import {
      EMAIL_CHANGED,
      PASSWORD_CHANGED,
      LOGIN_USER_SUCCESS,
      LOGIN_USER_FAIL,
      LOGIN_USER,
      URL
    } from './types';

    export const emailChanged = (text) => {

      return {
        type: EMAIL_CHANGED,
        payload: text
      };

    };

    export const passwordChanged = (text) => {
      return {
        type: PASSWORD_CHANGED,
        payload: text
      };
    };

    export const loginUser = ({ email, password }) => {
      return (dispatch) => {
        dispatch({ type: LOGIN_USER });

      axios.post(URL + '/hostLogin', {
          email: email,
          password: password
        })
        .then((user) => {
          console.log(user.data);
          loginUserSuccess(dispatch, user);
        })
        .catch((error) => {
          loginUserFail(dispatch);
        });
        // firebase.auth().signInWithEmailAndPassword(email, password)
        //   .then(user => loginUserSuccess(dispatch, user))
        //   .catch((error) => {
        //     console.log(error);

        //     firebase.auth().createUserWithEmailAndPassword(email, password)
        //       .then(user => loginUserSuccess(dispatch, user))
        //       .catch(() => loginUserFail(dispatch));
        //   });
      };
    };

    const loginUserFail = (dispatch) => {
      dispatch({ type: LOGIN_USER_FAIL });
    };

    const loginUserSuccess = (dispatch, user) => {

      dispatch({
        type: LOGIN_USER_SUCCESS,
        payload: user.data
      });

      Actions.main();
    };
    export const loginUserSuccess1 = (user) => {
      console.log(1);
      return {
        type: 'Navigate',
        payload: 'Success'
      };


    };

AuthReducer.js

import {
  EMAIL_CHANGED,
  PASSWORD_CHANGED,
  LOGIN_USER_SUCCESS,
  LOGIN_USER_FAIL,
  LOGIN_USER
} from '../actions/types';
import { Actions } from 'react-native-router-flux';

const INITIAL_STATE = {
  email: '',
  password: '',
   userDetails: null,
  error: '',
  loading: false
};

export default (state = INITIAL_STATE, action) => {
  switch (action.type) {
    case EMAIL_CHANGED:
      return { ...state, email: action.payload };
    case PASSWORD_CHANGED:
      return { ...state, password: action.payload };
    case LOGIN_USER:
      return { ...state, loading: true, error: '' };
    case LOGIN_USER_SUCCESS:
    console.log(action.payload );
      return { ...state, userDetails: action.payload }; 
    case LOGIN_USER_FAIL:
      return { ...state, error: 'Authentication Failed.', password: '', loading: false };
      case 'Navigate':
      console.log(2);
      Actions.main();  
       default: 
      return state;
  }
}; 

Это маршрутизатор.js

import React from 'react';
import { Scene, Router, Actions } from 'react-native-router-flux';
import LoginForm from './components/LoginForm';
import NameEnter from './components/NameEnter';


const RouterComponent = () => {
  return (
    <Router>
    <Scene key="root" hideNavBar>
      <Scene key="auth" >
        <Scene key="login" component={LoginForm} title="Please Login" />
      </Scene>
      <Scene key="main">
        <Scene key="screen1" component={NameEnter} title="Please Enter Your Name " />
      </Scene>
      </Scene>
    </Router> 
  );
};

export default RouterComponent;

Теперь в Authreducer.js я использую Actions.main () для перехода к основному.Но это не работает.Что-то не так с настройками роутера.Пожалуйста, помогите

Ответы [ 2 ]

0 голосов
/ 04 декабря 2018

Из избыточной документации :

"При тех же аргументах он [ redurs ] должен вычислить следующее состояние и вернуть его. Никаких сюрпризов. Никаких побочных эффектов. Никаких вызовов API. Никаких мутаций. Просто расчет. "

Редукторы всегда должны оставаться чистыми.Это antipattern для выполнения маршрутизации переходов внутри редуктора.

Кроме этого: У меня была такая же проблема с реагирует на родные 0.57.0 и response-native-router-flux v4 , чтона основе React Navigation v2.x.Все методы, кроме .key () работали, поэтому мне пришлось вернуться к версии rnrf 4.0.0-beta.32 .Похоже, что это не ошибка, и скорее всего она вызвана несоответствием версий зависимостей (например, реагировать и реагировать на изменения).Я углублюсь в эту проблему и, надеюсь, найду способ использовать более новые версии.

0 голосов
/ 04 декабря 2018

Это не работает, потому что вы смешали собственные команды с избыточным.Что я заметил, так это то, что redux всегда загружается в первую очередь, прежде чем реагируют нативные библиотеки и т. Д., Поэтому он не будет работать, вы должны разделить их, чтобы они работали.

Вы можете разделить их, вернув true (также удалите Actions.main () из операторов переключения файлов избыточности), и вы прочитаете этот ответ из другого файла (этот файл будет реагировать на собственный компонент), где вы можете использовать Actions.main (), и тогда он будет работать.

...