Skip to content

Commit

Permalink
fix: don't display read count in read by tootltip if channel has more…
Browse files Browse the repository at this point in the history
… than 100 members
  • Loading branch information
szuperaz committed Nov 20, 2024
1 parent 11cfe6f commit 5c65dae
Show file tree
Hide file tree
Showing 5 changed files with 71 additions and 6 deletions.
1 change: 1 addition & 0 deletions projects/stream-chat-angular/src/assets/i18n/en.ts
Original file line number Diff line number Diff line change
Expand Up @@ -130,5 +130,6 @@ export const en = {
"You can't uplod more than {{max}} attachments",
'You currently have {{count}} attachments, the maximum is {{max}}':
'You currently have {{count}} attachments, the maximum is {{max}}',
'and others': 'and others',
},
};
15 changes: 15 additions & 0 deletions projects/stream-chat-angular/src/lib/list-users.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -48,4 +48,19 @@ describe('listUsers', () => {

expect(listUsers(readBy)).toBe('Bob, Sophie, Jack, Rose, John +1');
});

it(`shouldn't display number if #displayRestCount is set to false`, () => {
const readBy = [
{ id: 'id1', name: 'Bob' },
{ id: 'id2', name: 'Sophie' },
{ id: 'id3', name: 'Jack' },
{ id: 'id4', name: 'Rose' },
{ id: 'id5', name: 'John' },
{ id: 'id6', name: 'Adam' },
];

expect(listUsers(readBy, false, 'and more')).toBe(
'Bob, Sophie, Jack, Rose, John and more'
);
});
});
8 changes: 6 additions & 2 deletions projects/stream-chat-angular/src/lib/list-users.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
import { UserResponse } from 'stream-chat';

export const listUsers = (users: UserResponse[]) => {
export const listUsers = (
users: UserResponse[],
displayRestCount = true,
othersText = ''
) => {
let outStr = '';

const slicedArr = users.map((item) => item.name || item.id).slice(0, 5);
Expand All @@ -9,7 +13,7 @@ export const listUsers = (users: UserResponse[]) => {
const commaSeparatedUsers = slicedArr.join(', ');
outStr = commaSeparatedUsers;
if (restLength > 0) {
outStr += ` +${restLength}`;
outStr += displayRestCount ? ` +${restLength}` : ` ${othersText}`;
}

return outStr;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,12 @@ describe('MessageComponent', () => {
let setAsActiveParentMessageSpy: jasmine.Spy;
let jumpToMessageSpy: jasmine.Spy;
let bouncedMessage$: BehaviorSubject<StreamMessage | undefined>;
const mockChannel = {
cid: 'messaging:general',
data: {
member_count: 5,
},
};

beforeEach(() => {
resendMessageSpy = jasmine.createSpy('resendMessage');
Expand Down Expand Up @@ -91,6 +97,13 @@ describe('MessageComponent', () => {
{
provide: ChannelService,
useValue: {
_activeChannel$: of(mockChannel),
get activeChannel$() {
return this._activeChannel$;
},
set activeChannel$(value) {
this._activeChannel$ = value;
},
resendMessage: resendMessageSpy,
setAsActiveParentMessage: setAsActiveParentMessageSpy,
jumpToMessage: jumpToMessageSpy,
Expand Down Expand Up @@ -129,6 +142,7 @@ describe('MessageComponent', () => {
queryMessageOptionsButton = () =>
nativeElement.querySelector('[data-testid="message-options-button"]');
message = mockMessage();
message.cid = mockChannel.cid;
component.message = message;
component.ngOnChanges({ message: {} as SimpleChange });
component.ngAfterViewInit();
Expand Down
39 changes: 35 additions & 4 deletions projects/stream-chat-angular/src/lib/message/message.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,7 @@ import {
NgxFloatUiContentComponent,
NgxFloatUiLooseDirective,
} from 'ngx-float-ui';
import { TranslateService } from '@ngx-translate/core';

type MessagePart = {
content: string;
Expand Down Expand Up @@ -125,6 +126,7 @@ export class MessageComponent
private showMessageMenuTimeout?: ReturnType<typeof setTimeout>;
private shouldPreventMessageMenuClose = false;
private _visibleMessageActionsCount = 0;
private channelMemberCount?: number;

constructor(
private chatClientService: ChatClientService,
Expand All @@ -134,7 +136,8 @@ export class MessageComponent
private dateParser: DateParserService,
private messageService: MessageService,
public messageActionsService: MessageActionsService,
private ngZone: NgZone
private ngZone: NgZone,
private translateService: TranslateService
) {
this.displayAs = this.messageService.displayAs;
}
Expand Down Expand Up @@ -180,6 +183,26 @@ export class MessageComponent
}
})
);
this.subscriptions.push(
this.channelService.activeChannel$.subscribe((activeChannel) => {
const newChannelMemberCount = activeChannel?.data?.member_count;
if (newChannelMemberCount !== this.channelMemberCount) {
const shouldUpdateText =
this.channelMemberCount !== undefined &&
newChannelMemberCount != undefined &&
((this.channelMemberCount <= 1000 && newChannelMemberCount > 100) ||
(this.channelMemberCount > 100 && newChannelMemberCount <= 100));
this.channelMemberCount = activeChannel?.data?.member_count;
if (
this.message &&
this.message.cid === activeChannel?.cid &&
shouldUpdateText
) {
this.updateReadByText();
}
}
})
);
}

ngOnChanges(changes: SimpleChanges): void {
Expand All @@ -194,9 +217,7 @@ export class MessageComponent
: [];
this.setIsSentByCurrentUser();
this.setLastReadUser();
this.readByText = this.message?.readBy
? listUsers(this.message.readBy)
: '';
this.updateReadByText();
this.isOnlyReadByMe = !!(
this.message &&
this.message.readBy &&
Expand Down Expand Up @@ -567,6 +588,16 @@ export class MessageComponent
return content;
}

private updateReadByText() {
const others = this.translateService.instant(
'streamChat.and others'
) as string;
const hasMoreThan100Members = (this.channelMemberCount ?? 0) > 100;
this.readByText = this.message?.readBy
? listUsers(this.message.readBy, !hasMoreThan100Members, others)
: '';
}

private setIsSentByCurrentUser() {
this.isSentByCurrentUser = this.message?.user?.id === this.userId;
}
Expand Down

0 comments on commit 5c65dae

Please sign in to comment.