2016-04-01 1 views
0

Я использую методы сокращения и NetInfo для обнаружения соединения менеджера во время запуска и любых действий, в которых важно подключение.Отчеты NetInfo, связанные при запуске и те же действия

import createOneShotMiddleware from 'redux-middleware-oneshot'; 
import { NetInfo } from 'react-native'; 
import { checkConnection } from '../actions/networkActions'; 

export const middleware = createOneShotMiddleware((dispatch) => { 
    const handle = (isConnected) => dispatch(checkConnection(isConnected)); 
    NetInfo.isConnected.fetch().done(handle); 
    NetInfo.isConnected.addEventListener('change', handle); 
}); 

Действия

import * as types from './actionTypes'; 

export function checkConnection(isConnected) { 
    return { 
    type: types.CHECK_CONNECTION, 
    isConnected: isConnected 
    }; 
} 

Редукторы

import { CHECK_CONNECTION } from '../actions/actionTypes'; 

const initialState = { 
    isConnected: false, 
}; 


export default function network(state = initialState, action = {}) { 
    switch (action.type) { 
     case CHECK_CONNECTION: 
      return Object.assign({}, state, {isConnected: action.isConnected}) 
     default: 
      return state; 
    } 
} 

App.js

import React, { Component } from 'react-native'; 
import { createStore, applyMiddleware, combineReducers } from 'redux'; 
import { middleware as netInfo } from './Middleware/redux-middleware-react-native-netinfo'; 
import { Provider } from 'react-redux'; 
import thunk from 'redux-thunk'; 
import createLogger from 'redux-logger' 

import * as reducers from './reducers'; 

import NavigationScreen from './Containers/NavigationScreen'; 

const logger = createLogger() 
const createStoreWithMiddleware = applyMiddleware(thunk, logger, netInfo)(createStore) 
const reducer = combineReducers(reducers); 
const store = createStoreWithMiddleware(reducer) 

export default class App extends Component { 
    render() { 
    return (
     <Provider store={store}> 
     <NavigationScreen /> 
     </Provider> 
    ); 
    } 
} 

Это не работает и не обновлять состояние, любые предложения?

ответ

0

Это старый, но для тех, кто приезжает сюда в будущем это, как я это сделал я, как правило, сделать это на моих действиях создателей:

export function networkCheck(){ 
    return (dispatch) => { 
    const dispatchNetworkState = (isConnected) => dispatch({ 
     type: types.NETWORK_STATE, 
     state: isConnected 
    }) 
    const handle =() => NetInfo.isConnected.fetch().done(dispatchNetworkState) 
    NetInfo.isConnected.addEventListener('change', handle); 
    } 
} 

isue на код перед тем, что не является следуя цепочке eventlistener -> testNetwork -> результат отправки