|  |  | @ -334,8 +334,8 @@ export class ConversationModel extends Backbone.Model<ConversationAttributes> { | 
			
		
	
		
		
			
				
					
					|  |  |  |     const expireTimer = this.get('expireTimer'); |  |  |  |     const expireTimer = this.get('expireTimer'); | 
			
		
	
		
		
			
				
					
					|  |  |  |     const currentNotificationSetting = this.get('triggerNotificationsFor'); |  |  |  |     const currentNotificationSetting = this.get('triggerNotificationsFor'); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     // to reduce the redux store size, only set fields which cannot be undefined
 |  |  |  |     // To reduce the redux store size, only set fields which cannot be undefined.
 | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     // for instance, a boolean can usually be not set if false, etc
 |  |  |  |     // For instance, a boolean can usually be not set if false, etc
 | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     const toRet: ReduxConversationType = { |  |  |  |     const toRet: ReduxConversationType = { | 
			
		
	
		
		
			
				
					
					|  |  |  |       id: this.id as string, |  |  |  |       id: this.id as string, | 
			
		
	
		
		
			
				
					
					|  |  |  |       activeAt: this.get('active_at'), |  |  |  |       activeAt: this.get('active_at'), | 
			
		
	
	
		
		
			
				
					|  |  | @ -394,6 +394,7 @@ export class ConversationModel extends Backbone.Model<ConversationAttributes> { | 
			
		
	
		
		
			
				
					
					|  |  |  |     if (hasNickname) { |  |  |  |     if (hasNickname) { | 
			
		
	
		
		
			
				
					
					|  |  |  |       toRet.hasNickname = hasNickname; |  |  |  |       toRet.hasNickname = hasNickname; | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     if (isKickedFromGroup) { |  |  |  |     if (isKickedFromGroup) { | 
			
		
	
		
		
			
				
					
					|  |  |  |       toRet.isKickedFromGroup = isKickedFromGroup; |  |  |  |       toRet.isKickedFromGroup = isKickedFromGroup; | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
	
		
		
			
				
					|  |  | @ -1027,14 +1028,25 @@ export class ConversationModel extends Backbone.Model<ConversationAttributes> { | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   // LOKI PROFILES
 |  |  |  |   public async setNickname(nickname?: string) { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |   public async setNickname(nickname: string) { |  |  |  |     if (!this.isPrivate()) { | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       window.log.info('cannot setNickname to a non private conversation.'); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       return; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |     const trimmed = nickname && nickname.trim(); |  |  |  |     const trimmed = nickname && nickname.trim(); | 
			
		
	
		
		
			
				
					
					|  |  |  |     if (this.get('nickname') === trimmed) { |  |  |  |     if (this.get('nickname') === trimmed) { | 
			
		
	
		
		
			
				
					
					|  |  |  |       return; |  |  |  |       return; | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     // make sure to save the lokiDisplayName as name in the db. so a search of conversation returns it.
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     // (we look for matches in name too)
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     const realUserName = this.getLokiProfile()?.displayName; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     if (!trimmed || !trimmed.length) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       this.set({ nickname: undefined, name: realUserName }); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     } else { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       this.set({ nickname: trimmed, name: realUserName }); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     this.set({ nickname: trimmed }); |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     await this.commit(); |  |  |  |     await this.commit(); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     await this.updateProfileName(); |  |  |  |     await this.updateProfileName(); | 
			
		
	
	
		
		
			
				
					|  |  | @ -1060,8 +1072,7 @@ export class ConversationModel extends Backbone.Model<ConversationAttributes> { | 
			
		
	
		
		
			
				
					
					|  |  |  |   public async updateProfileName() { |  |  |  |   public async updateProfileName() { | 
			
		
	
		
		
			
				
					
					|  |  |  |     // Prioritise nickname over the profile display name
 |  |  |  |     // Prioritise nickname over the profile display name
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     const nickname = this.getNickname(); |  |  |  |     const nickname = this.getNickname(); | 
			
		
	
		
		
			
				
					
					|  |  |  |     const profile = this.getLokiProfile(); |  |  |  |     const displayName = this.getLokiProfile()?.displayName; | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     const displayName = profile && profile.displayName; |  |  |  |  | 
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     const profileName = nickname || displayName || null; |  |  |  |     const profileName = nickname || displayName || null; | 
			
		
	
		
		
			
				
					
					|  |  |  |     await this.setProfileName(profileName); |  |  |  |     await this.setProfileName(profileName); | 
			
		
	
	
		
		
			
				
					|  |  | @ -1270,7 +1281,7 @@ export class ConversationModel extends Backbone.Model<ConversationAttributes> { | 
			
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   public getProfileName() { |  |  |  |   public getProfileName() { | 
			
		
	
		
		
			
				
					
					|  |  |  |     if (this.isPrivate() && !this.get('name')) { |  |  |  |     if (this.isPrivate()) { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |       return this.get('profileName'); |  |  |  |       return this.get('profileName'); | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |     return undefined; |  |  |  |     return undefined; | 
			
		
	
	
		
		
			
				
					|  |  | 
 |