import { put, call, takeLatest } from 'redux-saga/effects'; import { AsyncStorage } from 'react-native'; import { Navigation } from 'react-native-navigation'; import { Provider } from 'react-redux'; import { gestureHandlerRootHOC } from 'react-native-gesture-handler'; import { SERVER } from '../actions/actionsTypes'; import * as actions from '../actions'; import { connectRequest } from '../actions/connect'; import { serverFailure, selectServerRequest, selectServerSuccess } from '../actions/server'; import { setRoles } from '../actions/roles'; import RocketChat from '../lib/rocketchat'; import database from '../lib/realm'; import log from '../utils/log'; import store from '../lib/createStore'; let LoginSignupView = null; let LoginView = null; const handleSelectServer = function* handleSelectServer({ server }) { try { yield database.setActiveDB(server); yield call([AsyncStorage, 'setItem'], 'currentServer', server); const token = yield AsyncStorage.getItem(`${ RocketChat.TOKEN_KEY }-${ server }`); if (token) { yield put(actions.appStart('inside')); } const settings = database.objects('settings'); yield put(actions.setAllSettings(RocketChat.parseSettings(RocketChat._filterSettings(settings.slice(0, settings.length))))); const emojis = database.objects('customEmojis'); yield put(actions.setCustomEmojis(RocketChat.parseEmojis(emojis.slice(0, emojis.length)))); const roles = database.objects('roles'); yield put(setRoles(roles.reduce((result, role) => { result[role._id] = role.description; return result; }, {}))); yield put(connectRequest()); yield put(selectServerSuccess(server)); } catch (e) { log('handleSelectServer', e); } }; const handleServerRequest = function* handleServerRequest({ server }) { try { yield RocketChat.testServer(server); const loginServicesLength = yield RocketChat.getLoginServices(server); if (loginServicesLength === 0) { if (LoginView == null) { LoginView = require('../views/LoginView').default; Navigation.registerComponentWithRedux('LoginView', () => gestureHandlerRootHOC(LoginView), Provider, store); } yield Navigation.push('NewServerView', { component: { name: 'LoginView' } }); } else { if (LoginSignupView == null) { LoginSignupView = require('../views/LoginSignupView').default; Navigation.registerComponentWithRedux('LoginSignupView', () => gestureHandlerRootHOC(LoginSignupView), Provider, store); } yield Navigation.push('NewServerView', { component: { name: 'LoginSignupView' } }); } database.databases.serversDB.write(() => { database.databases.serversDB.create('servers', { id: server }, true); }); yield put(selectServerRequest(server)); } catch (e) { yield put(serverFailure()); log('handleServerRequest', e); } }; const root = function* root() { yield takeLatest(SERVER.SELECT_REQUEST, handleSelectServer); yield takeLatest(SERVER.REQUEST, handleServerRequest); }; export default root;