Skip to content
This repository was archived by the owner on Sep 11, 2024. It is now read-only.

Commit d3ba1f4

Browse files
authored
Merge pull request #1272 from matrix-org/t3chguy/hide_other_events
allow hiding of avatar/display name changes
2 parents 60c1ba4 + 5450d6b commit d3ba1f4

File tree

3 files changed

+30
-26
lines changed

3 files changed

+30
-26
lines changed

src/components/structures/UserSettings.js

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -85,6 +85,10 @@ const SETTINGS_LABELS = [
8585
id: 'hideJoinLeaves',
8686
label: 'Hide join/leave messages (invites/kicks/bans unaffected)',
8787
},
88+
{
89+
id: 'hideAvatarDisplaynameChanges',
90+
label: 'Hide avatar and display name changes',
91+
},
8892
{
8993
id: 'useCompactLayout',
9094
label: 'Use compact timeline layout',

src/i18n/strings/en_EN.json

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -346,6 +346,7 @@
346346
"Hangup": "Hangup",
347347
"Hide Apps": "Hide Apps",
348348
"Hide join/leave messages (invites/kicks/bans unaffected)": "Hide join/leave messages (invites/kicks/bans unaffected)",
349+
"Hide avatar and display name changes": "Hide avatar and display name changes",
349350
"Hide read receipts": "Hide read receipts",
350351
"Hide Text Formatting Toolbar": "Hide Text Formatting Toolbar",
351352
"Historical": "Historical",

src/shouldHideEvent.js

Lines changed: 25 additions & 26 deletions
Original file line numberDiff line numberDiff line change
@@ -14,38 +14,37 @@
1414
limitations under the License.
1515
*/
1616

17-
function _isLeaveOrJoin(ev) {
18-
const isMemberEvent = ev.getType() === 'm.room.member' && ev.getStateKey() !== undefined;
19-
if (!isMemberEvent) {
20-
return false; // bail early: all the checks below concern member events only
21-
}
17+
function memberEventDiff(ev) {
18+
const diff = {
19+
isMemberEvent: ev.getType() === 'm.room.member',
20+
};
2221

23-
// TODO: These checks are done to make sure we're dealing with membership transitions not avatar changes / dupe joins
24-
// These checks are also being done in TextForEvent and should really reside in the JS SDK as a helper function
25-
const membership = ev.getContent().membership;
26-
const prevMembership = ev.getPrevContent().membership;
27-
if (membership === prevMembership && membership === 'join') {
28-
// join -> join : This happens when display names change / avatars are set / genuine dupe joins with no changes.
29-
// Find out which we're dealing with.
30-
if (ev.getPrevContent().displayname !== ev.getContent().displayname) {
31-
return false; // display name changed
32-
}
33-
if (ev.getPrevContent().avatar_url !== ev.getContent().avatar_url) {
34-
return false; // avatar url changed
35-
}
36-
// dupe join event, fall through to hide rules
37-
}
22+
// If is not a Member Event then the other checks do not apply, so bail early.
23+
if (!diff.isMemberEvent) return diff;
3824

25+
const content = ev.getContent();
26+
const prevContent = ev.getPrevContent();
3927

40-
// this only applies to joins/invited joins/leaves not invites/kicks/bans
41-
const isJoin = membership === 'join' && prevMembership !== 'ban';
42-
const isLeave = membership === 'leave' && ev.getStateKey() === ev.getSender();
43-
return isJoin || isLeave;
28+
diff.isJoin = content.membership === 'join' && prevContent.membership !== 'ban';
29+
diff.isPart = content.membership === 'leave' && ev.getStateKey() === ev.getSender();
30+
31+
const isJoinToJoin = content.membership === prevContent.membership && content.membership === 'join';
32+
diff.isDisplaynameChange = isJoinToJoin && content.displayname !== prevContent.displayname;
33+
diff.isAvatarChange = isJoinToJoin && content.avatar_url !== prevContent.avatar_url;
34+
return diff;
4435
}
4536

46-
export default function(ev, syncedSettings) {
37+
export default function shouldHideEvent(ev, syncedSettings) {
4738
// Hide redacted events
4839
if (syncedSettings['hideRedactions'] && ev.isRedacted()) return true;
49-
if (syncedSettings['hideJoinLeaves'] && _isLeaveOrJoin(ev)) return true;
40+
41+
const eventDiff = memberEventDiff(ev);
42+
43+
if (eventDiff.isMemberEvent) {
44+
if (syncedSettings['hideJoinLeaves'] && (eventDiff.isJoin || eventDiff.isPart)) return true;
45+
const isMemberAvatarDisplaynameChange = eventDiff.isAvatarChange || eventDiff.isDisplaynameChange;
46+
if (syncedSettings['hideAvatarDisplaynameChanges'] && isMemberAvatarDisplaynameChange) return true;
47+
}
48+
5049
return false;
5150
}

0 commit comments

Comments
 (0)