mirror of https://github.com/vector-im/riot-web
Also move effects handling from `event` to `Room.timeline` to wake up less
parent
923d68a0fa
commit
1437188282
|
@ -253,7 +253,6 @@ export default class RoomView extends React.Component<IProps, IState> {
|
||||||
this.context.on("userTrustStatusChanged", this.onUserVerificationChanged);
|
this.context.on("userTrustStatusChanged", this.onUserVerificationChanged);
|
||||||
this.context.on("crossSigning.keysChanged", this.onCrossSigningKeysChanged);
|
this.context.on("crossSigning.keysChanged", this.onCrossSigningKeysChanged);
|
||||||
this.context.on("Event.decrypted", this.onEventDecrypted);
|
this.context.on("Event.decrypted", this.onEventDecrypted);
|
||||||
this.context.on("event", this.onEvent);
|
|
||||||
// Start listening for RoomViewStore updates
|
// Start listening for RoomViewStore updates
|
||||||
this.roomStoreToken = RoomViewStore.addListener(this.onRoomViewStoreUpdate);
|
this.roomStoreToken = RoomViewStore.addListener(this.onRoomViewStoreUpdate);
|
||||||
this.rightPanelStoreToken = RightPanelStore.getSharedInstance().addListener(this.onRightPanelStoreUpdate);
|
this.rightPanelStoreToken = RightPanelStore.getSharedInstance().addListener(this.onRightPanelStoreUpdate);
|
||||||
|
@ -637,7 +636,6 @@ export default class RoomView extends React.Component<IProps, IState> {
|
||||||
this.context.removeListener("userTrustStatusChanged", this.onUserVerificationChanged);
|
this.context.removeListener("userTrustStatusChanged", this.onUserVerificationChanged);
|
||||||
this.context.removeListener("crossSigning.keysChanged", this.onCrossSigningKeysChanged);
|
this.context.removeListener("crossSigning.keysChanged", this.onCrossSigningKeysChanged);
|
||||||
this.context.removeListener("Event.decrypted", this.onEventDecrypted);
|
this.context.removeListener("Event.decrypted", this.onEventDecrypted);
|
||||||
this.context.removeListener("event", this.onEvent);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
window.removeEventListener('beforeunload', this.onPageUnload);
|
window.removeEventListener('beforeunload', this.onPageUnload);
|
||||||
|
@ -837,8 +835,7 @@ export default class RoomView extends React.Component<IProps, IState> {
|
||||||
if (this.unmounted) return;
|
if (this.unmounted) return;
|
||||||
|
|
||||||
// ignore events for other rooms
|
// ignore events for other rooms
|
||||||
if (!room) return;
|
if (!room || room.roomId !== this.state.room?.roomId) return;
|
||||||
if (!this.state.room || room.roomId != this.state.room.roomId) return;
|
|
||||||
|
|
||||||
// ignore events from filtered timelines
|
// ignore events from filtered timelines
|
||||||
if (data.timeline.getTimelineSet() !== room.getUnfilteredTimelineSet()) return;
|
if (data.timeline.getTimelineSet() !== room.getUnfilteredTimelineSet()) return;
|
||||||
|
@ -859,6 +856,10 @@ export default class RoomView extends React.Component<IProps, IState> {
|
||||||
// we'll only be showing a spinner.
|
// we'll only be showing a spinner.
|
||||||
if (this.state.joining) return;
|
if (this.state.joining) return;
|
||||||
|
|
||||||
|
if (!ev.isBeingDecrypted() && !ev.isDecryptionFailure()) {
|
||||||
|
this.handleEffects(ev);
|
||||||
|
}
|
||||||
|
|
||||||
if (ev.getSender() !== this.context.credentials.userId) {
|
if (ev.getSender() !== this.context.credentials.userId) {
|
||||||
// update unread count when scrolled up
|
// update unread count when scrolled up
|
||||||
if (!this.state.searchResults && this.state.atEndOfLiveTimeline) {
|
if (!this.state.searchResults && this.state.atEndOfLiveTimeline) {
|
||||||
|
@ -871,20 +872,14 @@ export default class RoomView extends React.Component<IProps, IState> {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
private onEventDecrypted = (ev) => {
|
private onEventDecrypted = (ev: MatrixEvent) => {
|
||||||
|
if (!this.state.room || !this.state.matrixClientIsReady) return; // not ready at all
|
||||||
|
if (ev.getRoomId() !== this.state.room.roomId) return; // not for us
|
||||||
if (ev.isDecryptionFailure()) return;
|
if (ev.isDecryptionFailure()) return;
|
||||||
this.handleEffects(ev);
|
this.handleEffects(ev);
|
||||||
};
|
};
|
||||||
|
|
||||||
private onEvent = (ev) => {
|
private handleEffects = (ev: MatrixEvent) => {
|
||||||
if (ev.isBeingDecrypted() || ev.isDecryptionFailure()) return;
|
|
||||||
this.handleEffects(ev);
|
|
||||||
};
|
|
||||||
|
|
||||||
private handleEffects = (ev) => {
|
|
||||||
if (!this.state.room || !this.state.matrixClientIsReady) return; // not ready at all
|
|
||||||
if (ev.getRoomId() !== this.state.room.roomId) return; // not for us
|
|
||||||
|
|
||||||
const notifState = RoomNotificationStateStore.instance.getRoomState(this.state.room);
|
const notifState = RoomNotificationStateStore.instance.getRoomState(this.state.room);
|
||||||
if (!notifState.isUnread) return;
|
if (!notifState.isUnread) return;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue