91 lines
3.0 KiB
JavaScript
91 lines
3.0 KiB
JavaScript
import { put, 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 { 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';
|
|
|
|
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);
|
|
yield put(setUser(user));
|
|
yield put(actions.appStart('inside'));
|
|
RocketChat.connect({ server, user });
|
|
} 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 {
|
|
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;
|