diff options
author | Emmanuel ROHEE <erohee@amdocs.com> | 2014-09-04 13:57:27 +0200 |
---|---|---|
committer | Emmanuel ROHEE <erohee@amdocs.com> | 2014-09-04 13:57:27 +0200 |
commit | 3983bae160b63554e657c92450fcb2e1fbaba0c7 (patch) | |
tree | 19ea77ae79cdfd4d32290ff8ebbaa0022e60ff20 /webclient/components | |
parent | Moved mRoomName filter into matrix-filter.js, a place for all generic filters... (diff) | |
download | synapse-3983bae160b63554e657c92450fcb2e1fbaba0c7.tar.xz |
Added mUserDisplayName, a filter to resolve a user display name from a user_id
Diffstat (limited to 'webclient/components')
-rw-r--r-- | webclient/components/matrix/matrix-filter.js | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/webclient/components/matrix/matrix-filter.js b/webclient/components/matrix/matrix-filter.js index a9bdbf66d9..0922684e3b 100644 --- a/webclient/components/matrix/matrix-filter.js +++ b/webclient/components/matrix/matrix-filter.js @@ -97,4 +97,37 @@ angular.module('matrixFilter', []) return roomName; }; +}]) + +// Compute the user display name in a room according to the data already downloaded +.filter('mUserDisplayName', ['$rootScope', function($rootScope) { + return function(user_id, room_id) { + var displayName; + + // Try to find the user name among presence data + // Warning: that means we have received before a presence event for this + // user which cannot be guaranted. + // However, if we get the info by this way, we are sure this is the latest user display name + // See FIXME comment below + if (user_id in $rootScope.presence) { + displayName = $rootScope.presence[user_id].content.displayname; + } + + // FIXME: Would like to use the display name as defined in room members of the room. + // But this information is the display name of the user when he has joined the room. + // It does not take into account user display name update + if (room_id) { + var room = $rootScope.events.rooms[room_id]; + if (room && (user_id in room.members)) { + var member = room.members[user_id]; + displayName = member.content.displayname; + } + } + + if (undefined === displayName) { + // By default, use the user ID + displayName = user_id; + } + return displayName; + }; }]); |