import { put, takeLatest } from 'redux-saga/effects'; import { AsyncStorage, Alert } 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 { serverFailure, selectServerRequest, selectServerSuccess } from '../actions/server'; import { setRoles } from '../actions/roles'; import { setUser } from '../actions/login'; import RocketChat from '../lib/rocketchat'; import database from '../lib/realm'; import log from '../utils/log'; import store from '../lib/createStore'; import I18n from '../i18n'; let LoginSignupView = null; let LoginView = null; const handleSelectServer = function* handleSelectServer({ server }) { try { yield AsyncStorage.setItem('currentServer', server); const userStringified = yield AsyncStorage.getItem(`${ RocketChat.TOKEN_KEY }-${ server }`); if (userStringified) { const user = JSON.parse(userStringified); RocketChat.connect({ server, user }); yield put(setUser(user)); yield put(actions.appStart('inside')); } else { RocketChat.connect({ server }); } const settings = database.objects('settings'); yield put(actions.setAllSettings(RocketChat.parseSettings(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(selectServerSuccess(server)); } catch (e) { log('handleSelectServer', e); } }; const handleServerRequest = function* handleServerRequest({ server }) { try { const result = yield RocketChat.testServer(server); if (!result.success) { Alert.alert(I18n.t('Oops'), I18n.t(result.message, result.messageOptions)); yield put(serverFailure()); return; } 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;