115 lines
3.0 KiB
JavaScript
115 lines
3.0 KiB
JavaScript
import { delay } from 'redux-saga';
|
|
import { takeLatest, put, call } from 'redux-saga/effects';
|
|
import { Navigation } from 'react-native-navigation';
|
|
|
|
import { MESSAGES } from '../actions/actionsTypes';
|
|
import {
|
|
messagesSuccess,
|
|
messagesFailure,
|
|
deleteSuccess,
|
|
deleteFailure,
|
|
editSuccess,
|
|
editFailure,
|
|
toggleStarSuccess,
|
|
toggleStarFailure,
|
|
togglePinSuccess,
|
|
togglePinFailure,
|
|
replyInit
|
|
} from '../actions/messages';
|
|
import RocketChat from '../lib/rocketchat';
|
|
import database from '../lib/realm';
|
|
import log from '../utils/log';
|
|
|
|
const deleteMessage = message => RocketChat.deleteMessage(message);
|
|
const editMessage = message => RocketChat.editMessage(message);
|
|
const toggleStarMessage = message => RocketChat.toggleStarMessage(message);
|
|
const togglePinMessage = message => RocketChat.togglePinMessage(message);
|
|
|
|
const get = function* get({ room }) {
|
|
try {
|
|
if (room.lastOpen) {
|
|
yield RocketChat.loadMissedMessages(room);
|
|
} else {
|
|
yield RocketChat.loadMessagesForRoom(room);
|
|
}
|
|
yield put(messagesSuccess());
|
|
} catch (err) {
|
|
yield put(messagesFailure(err));
|
|
}
|
|
};
|
|
|
|
const handleDeleteRequest = function* handleDeleteRequest({ message }) {
|
|
try {
|
|
yield call(deleteMessage, message);
|
|
yield put(deleteSuccess());
|
|
} catch (error) {
|
|
yield put(deleteFailure());
|
|
}
|
|
};
|
|
|
|
const handleEditRequest = function* handleEditRequest({ message }) {
|
|
try {
|
|
yield call(editMessage, message);
|
|
yield put(editSuccess());
|
|
} catch (error) {
|
|
yield put(editFailure());
|
|
}
|
|
};
|
|
|
|
const handleToggleStarRequest = function* handleToggleStarRequest({ message }) {
|
|
try {
|
|
yield call(toggleStarMessage, message);
|
|
yield put(toggleStarSuccess());
|
|
} catch (error) {
|
|
yield put(toggleStarFailure());
|
|
}
|
|
};
|
|
|
|
const handleTogglePinRequest = function* handleTogglePinRequest({ message }) {
|
|
try {
|
|
yield call(togglePinMessage, message);
|
|
yield put(togglePinSuccess());
|
|
} catch (error) {
|
|
yield put(togglePinFailure(error));
|
|
}
|
|
};
|
|
|
|
const goRoom = function* goRoom({ rid }) {
|
|
yield Navigation.popToRoot('RoomsListView');
|
|
Navigation.push('RoomsListView', {
|
|
component: {
|
|
name: 'RoomView',
|
|
passProps: {
|
|
rid
|
|
}
|
|
}
|
|
});
|
|
};
|
|
|
|
const handleReplyBroadcast = function* handleReplyBroadcast({ message }) {
|
|
try {
|
|
const { username } = message.u;
|
|
const subscriptions = database.objects('subscriptions').filtered('name = $0', username);
|
|
if (subscriptions.length) {
|
|
yield goRoom({ rid: subscriptions[0].rid });
|
|
} else {
|
|
const room = yield RocketChat.createDirectMessage(username);
|
|
yield goRoom({ rid: room.rid });
|
|
}
|
|
yield delay(500);
|
|
yield put(replyInit(message, false));
|
|
} catch (e) {
|
|
log('handleReplyBroadcast', e);
|
|
}
|
|
};
|
|
|
|
const root = function* root() {
|
|
yield takeLatest(MESSAGES.REQUEST, get);
|
|
yield takeLatest(MESSAGES.DELETE_REQUEST, handleDeleteRequest);
|
|
yield takeLatest(MESSAGES.EDIT_REQUEST, handleEditRequest);
|
|
yield takeLatest(MESSAGES.TOGGLE_STAR_REQUEST, handleToggleStarRequest);
|
|
yield takeLatest(MESSAGES.TOGGLE_PIN_REQUEST, handleTogglePinRequest);
|
|
yield takeLatest(MESSAGES.REPLY_BROADCAST, handleReplyBroadcast);
|
|
};
|
|
export default root;
|