2021-07-28 22:15:52 +09:00
|
|
|
import EventEmitter from 'events';
|
|
|
|
import appDispatcher from '../dispatcher';
|
|
|
|
import cons from './cons';
|
|
|
|
|
|
|
|
class Navigation extends EventEmitter {
|
|
|
|
constructor() {
|
|
|
|
super();
|
|
|
|
|
2021-09-05 22:26:34 +09:00
|
|
|
this.selectedTab = cons.tabs.HOME;
|
2021-09-03 21:28:01 +09:00
|
|
|
this.selectedSpaceId = null;
|
2021-09-05 22:26:34 +09:00
|
|
|
this.selectedSpacePath = [cons.tabs.HOME];
|
|
|
|
|
2021-09-03 21:28:01 +09:00
|
|
|
this.selectedRoomId = null;
|
2021-12-22 23:48:32 +09:00
|
|
|
this.isRoomSettings = false;
|
2021-12-11 13:25:38 +09:00
|
|
|
this.recentRooms = [];
|
2021-12-11 14:20:34 +09:00
|
|
|
|
|
|
|
this.isRawModalVisible = false;
|
2021-07-28 22:15:52 +09:00
|
|
|
}
|
|
|
|
|
2021-09-03 21:28:01 +09:00
|
|
|
_setSpacePath(roomId) {
|
2021-09-05 22:26:34 +09:00
|
|
|
if (roomId === null || roomId === cons.tabs.HOME) {
|
|
|
|
this.selectedSpacePath = [cons.tabs.HOME];
|
2021-09-03 21:28:01 +09:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (this.selectedSpacePath.includes(roomId)) {
|
|
|
|
const spIndex = this.selectedSpacePath.indexOf(roomId);
|
|
|
|
this.selectedSpacePath = this.selectedSpacePath.slice(0, spIndex + 1);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
this.selectedSpacePath.push(roomId);
|
2021-07-28 22:15:52 +09:00
|
|
|
}
|
|
|
|
|
2021-12-11 13:25:38 +09:00
|
|
|
removeRecentRoom(roomId) {
|
|
|
|
if (typeof roomId !== 'string') return;
|
|
|
|
const roomIdIndex = this.recentRooms.indexOf(roomId);
|
|
|
|
if (roomIdIndex >= 0) {
|
|
|
|
this.recentRooms.splice(roomIdIndex, 1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
addRecentRoom(roomId) {
|
|
|
|
if (typeof roomId !== 'string') return;
|
|
|
|
|
|
|
|
this.recentRooms.push(roomId);
|
|
|
|
if (this.recentRooms.length > 10) {
|
|
|
|
this.recentRooms.splice(0, 1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-12-11 14:20:34 +09:00
|
|
|
setIsRawModalVisible(visible) {
|
|
|
|
this.isRawModalVisible = visible;
|
|
|
|
}
|
|
|
|
|
2021-07-28 22:15:52 +09:00
|
|
|
navigate(action) {
|
|
|
|
const actions = {
|
2021-09-05 22:26:34 +09:00
|
|
|
[cons.actions.navigation.SELECT_TAB]: () => {
|
2021-09-03 21:28:01 +09:00
|
|
|
this.selectedTab = action.tabId;
|
2021-09-05 22:26:34 +09:00
|
|
|
if (this.selectedTab !== cons.tabs.DIRECTS) {
|
|
|
|
if (this.selectedTab === cons.tabs.HOME) {
|
|
|
|
this.selectedSpacePath = [cons.tabs.HOME];
|
|
|
|
this.selectedSpaceId = null;
|
|
|
|
} else {
|
|
|
|
this.selectedSpacePath = [this.selectedTab];
|
|
|
|
this.selectedSpaceId = this.selectedTab;
|
|
|
|
}
|
|
|
|
this.emit(cons.events.navigation.SPACE_SELECTED, this.selectedSpaceId);
|
|
|
|
} else this.selectedSpaceId = null;
|
|
|
|
this.emit(cons.events.navigation.TAB_SELECTED, this.selectedTab);
|
2021-09-03 21:28:01 +09:00
|
|
|
},
|
|
|
|
[cons.actions.navigation.SELECT_SPACE]: () => {
|
|
|
|
this._setSpacePath(action.roomId);
|
|
|
|
this.selectedSpaceId = action.roomId;
|
2021-09-05 22:26:34 +09:00
|
|
|
this.emit(cons.events.navigation.SPACE_SELECTED, this.selectedSpaceId);
|
2021-07-28 22:15:52 +09:00
|
|
|
},
|
|
|
|
[cons.actions.navigation.SELECT_ROOM]: () => {
|
2022-01-09 13:59:06 +09:00
|
|
|
if (this.selectedRoomId === action.roomId) return;
|
|
|
|
|
2021-09-03 21:28:01 +09:00
|
|
|
const prevSelectedRoomId = this.selectedRoomId;
|
|
|
|
this.selectedRoomId = action.roomId;
|
2021-12-11 14:20:34 +09:00
|
|
|
this.removeRecentRoom(prevSelectedRoomId);
|
2021-12-11 13:25:38 +09:00
|
|
|
this.addRecentRoom(prevSelectedRoomId);
|
|
|
|
this.removeRecentRoom(this.selectedRoomId);
|
2021-12-26 19:04:20 +09:00
|
|
|
if (this.isRoomSettings && typeof this.selectedRoomId === 'string') {
|
2021-12-22 23:48:32 +09:00
|
|
|
this.isRoomSettings = !this.isRoomSettings;
|
|
|
|
this.emit(cons.events.navigation.ROOM_SETTINGS_TOGGLED, this.isRoomSettings);
|
|
|
|
}
|
2021-12-03 22:02:10 +09:00
|
|
|
this.emit(
|
|
|
|
cons.events.navigation.ROOM_SELECTED,
|
|
|
|
this.selectedRoomId,
|
|
|
|
prevSelectedRoomId,
|
|
|
|
action.eventId,
|
|
|
|
);
|
2021-07-28 22:15:52 +09:00
|
|
|
},
|
2021-12-22 23:48:32 +09:00
|
|
|
[cons.actions.navigation.TOGGLE_ROOM_SETTINGS]: () => {
|
|
|
|
this.isRoomSettings = !this.isRoomSettings;
|
|
|
|
this.emit(cons.events.navigation.ROOM_SETTINGS_TOGGLED, this.isRoomSettings);
|
|
|
|
},
|
2021-07-28 22:15:52 +09:00
|
|
|
[cons.actions.navigation.OPEN_INVITE_LIST]: () => {
|
|
|
|
this.emit(cons.events.navigation.INVITE_LIST_OPENED);
|
|
|
|
},
|
2021-08-31 22:13:31 +09:00
|
|
|
[cons.actions.navigation.OPEN_PUBLIC_ROOMS]: () => {
|
|
|
|
this.emit(cons.events.navigation.PUBLIC_ROOMS_OPENED, action.searchTerm);
|
2021-07-28 22:15:52 +09:00
|
|
|
},
|
2021-08-31 22:13:31 +09:00
|
|
|
[cons.actions.navigation.OPEN_CREATE_ROOM]: () => {
|
|
|
|
this.emit(cons.events.navigation.CREATE_ROOM_OPENED);
|
2021-07-28 22:15:52 +09:00
|
|
|
},
|
|
|
|
[cons.actions.navigation.OPEN_INVITE_USER]: () => {
|
2021-08-08 13:53:26 +09:00
|
|
|
this.emit(cons.events.navigation.INVITE_USER_OPENED, action.roomId, action.searchTerm);
|
2021-07-28 22:15:52 +09:00
|
|
|
},
|
2021-10-19 00:25:52 +09:00
|
|
|
[cons.actions.navigation.OPEN_PROFILE_VIEWER]: () => {
|
|
|
|
this.emit(cons.events.navigation.PROFILE_VIEWER_OPENED, action.userId, action.roomId);
|
|
|
|
},
|
2021-07-28 22:15:52 +09:00
|
|
|
[cons.actions.navigation.OPEN_SETTINGS]: () => {
|
|
|
|
this.emit(cons.events.navigation.SETTINGS_OPENED);
|
|
|
|
},
|
2021-08-14 13:49:29 +09:00
|
|
|
[cons.actions.navigation.OPEN_EMOJIBOARD]: () => {
|
|
|
|
this.emit(
|
|
|
|
cons.events.navigation.EMOJIBOARD_OPENED,
|
|
|
|
action.cords, action.requestEmojiCallback,
|
|
|
|
);
|
|
|
|
},
|
2021-08-16 21:07:29 +09:00
|
|
|
[cons.actions.navigation.OPEN_READRECEIPTS]: () => {
|
|
|
|
this.emit(
|
|
|
|
cons.events.navigation.READRECEIPTS_OPENED,
|
|
|
|
action.roomId,
|
2021-12-03 22:02:10 +09:00
|
|
|
action.userIds,
|
2021-08-16 21:07:29 +09:00
|
|
|
);
|
|
|
|
},
|
2021-11-20 16:59:32 +09:00
|
|
|
[cons.actions.navigation.CLICK_REPLY_TO]: () => {
|
|
|
|
this.emit(
|
|
|
|
cons.events.navigation.REPLY_TO_CLICKED,
|
|
|
|
action.userId,
|
|
|
|
action.eventId,
|
|
|
|
action.body,
|
|
|
|
);
|
|
|
|
},
|
2021-12-10 20:52:53 +09:00
|
|
|
[cons.actions.navigation.OPEN_SEARCH]: () => {
|
|
|
|
this.emit(
|
|
|
|
cons.events.navigation.SEARCH_OPENED,
|
|
|
|
action.term,
|
|
|
|
);
|
|
|
|
},
|
2022-01-12 00:16:41 +09:00
|
|
|
[cons.actions.navigation.OPEN_REUSABLE_CONTEXT_MENU]: () => {
|
|
|
|
this.emit(
|
|
|
|
cons.events.navigation.REUSABLE_CONTEXT_MENU_OPENED,
|
|
|
|
action.placement,
|
|
|
|
action.cords,
|
|
|
|
action.render,
|
|
|
|
);
|
|
|
|
},
|
2021-07-28 22:15:52 +09:00
|
|
|
};
|
|
|
|
actions[action.type]?.();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const navigation = new Navigation();
|
|
|
|
appDispatcher.register(navigation.navigate.bind(navigation));
|
|
|
|
|
|
|
|
export default navigation;
|