mirror of https://github.com/vector-im/riot-web
Trigger room-specific watchers whenever a higher level change happens
Otherwise the room list badges end up having to listen to `null` for a room ID, meaning they have to filter. The notification badge count setting is the first ever setting to watch based on a room ID, so there are no compatibility concerns with this change.pull/21833/head
parent
13282bddad
commit
241e0c12f0
|
@ -51,8 +51,17 @@ export class WatchManager {
|
||||||
const roomWatchers = this._watchers[settingName];
|
const roomWatchers = this._watchers[settingName];
|
||||||
const callbacks = [];
|
const callbacks = [];
|
||||||
|
|
||||||
if (inRoomId !== null && roomWatchers[inRoomId]) callbacks.push(...roomWatchers[inRoomId]);
|
if (inRoomId !== null && roomWatchers[inRoomId]) {
|
||||||
if (roomWatchers[null]) callbacks.push(...roomWatchers[null]);
|
callbacks.push(...roomWatchers[inRoomId]);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!inRoomId) {
|
||||||
|
// Fire updates to all the individual room watchers too, as they probably
|
||||||
|
// care about the change higher up.
|
||||||
|
callbacks.push(...Object.values(roomWatchers).reduce((r, a) => [...r, ...a], []));
|
||||||
|
} else if (roomWatchers[null]) {
|
||||||
|
callbacks.push(...roomWatchers[null]);
|
||||||
|
}
|
||||||
|
|
||||||
for (const callback of callbacks) {
|
for (const callback of callbacks) {
|
||||||
callback(inRoomId, atLevel, newValueAtLevel);
|
callback(inRoomId, atLevel, newValueAtLevel);
|
||||||
|
|
Loading…
Reference in New Issue