stream-chat-angular 5.13.0 → 6.0.0-beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (165) hide show
  1. package/assets/i18n/en.d.ts +1 -0
  2. package/assets/version.d.ts +1 -1
  3. package/{esm2020 → esm2022}/assets/i18n/en.mjs +2 -1
  4. package/{esm2020 → esm2022}/assets/version.mjs +2 -2
  5. package/{esm2020 → esm2022}/lib/attachment-configuration.service.mjs +4 -4
  6. package/esm2022/lib/attachment-list/attachment-list.component.mjs +212 -0
  7. package/esm2022/lib/attachment-preview-list/attachment-preview-list.component.mjs +55 -0
  8. package/{esm2020 → esm2022}/lib/attachment.service.mjs +5 -5
  9. package/esm2022/lib/avatar/avatar.component.mjs +157 -0
  10. package/{esm2020 → esm2022}/lib/avatar-placeholder/avatar-placeholder.component.mjs +6 -6
  11. package/esm2022/lib/channel/channel.component.mjs +45 -0
  12. package/esm2022/lib/channel-header/channel-header.component.mjs +72 -0
  13. package/esm2022/lib/channel-list/channel-list.component.mjs +50 -0
  14. package/esm2022/lib/channel-preview/channel-preview.component.mjs +150 -0
  15. package/esm2022/lib/channel.service.mjs +1389 -0
  16. package/esm2022/lib/chat-client.service.mjs +227 -0
  17. package/{esm2020 → esm2022}/lib/custom-templates.service.mjs +5 -5
  18. package/{esm2020 → esm2022}/lib/date-parser.service.mjs +5 -5
  19. package/esm2022/lib/file-utils.mjs +35 -0
  20. package/{esm2020 → esm2022}/lib/get-channel-display-text.mjs +1 -1
  21. package/{esm2020 → esm2022}/lib/get-message-translation.mjs +1 -1
  22. package/{esm2020 → esm2022}/lib/icon/icon-placeholder/icon-placeholder.component.mjs +6 -6
  23. package/{esm2020 → esm2022}/lib/icon/icon.component.mjs +5 -5
  24. package/{esm2020 → esm2022}/lib/icon/icon.module.mjs +11 -11
  25. package/{esm2020 → esm2022}/lib/icon/loading-indicator/loading-indicator.component.mjs +5 -5
  26. package/{esm2020 → esm2022}/lib/icon/loading-indicator-placeholder/loading-indicator-placeholder.component.mjs +6 -6
  27. package/{esm2020 → esm2022}/lib/list-users.mjs +1 -1
  28. package/esm2022/lib/message/message.component.mjs +486 -0
  29. package/esm2022/lib/message-actions-box/message-actions-box.component.mjs +120 -0
  30. package/{esm2020 → esm2022}/lib/message-actions.service.mjs +5 -5
  31. package/esm2022/lib/message-bounce-prompt/message-bounce-prompt.component.mjs +71 -0
  32. package/{esm2020 → esm2022}/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.mjs +6 -6
  33. package/{esm2020 → esm2022}/lib/message-input/emoji-input.service.mjs +5 -5
  34. package/{esm2020 → esm2022}/lib/message-input/message-input-config.service.mjs +5 -5
  35. package/esm2022/lib/message-input/message-input.component.mjs +507 -0
  36. package/{esm2020 → esm2022}/lib/message-input/textarea/textarea.component.mjs +5 -5
  37. package/{esm2020 → esm2022}/lib/message-input/textarea.directive.mjs +5 -5
  38. package/{esm2020 → esm2022}/lib/message-input/voice-recorder.service.mjs +5 -5
  39. package/{esm2020 → esm2022}/lib/message-list/group-styles.mjs +1 -1
  40. package/esm2022/lib/message-list/message-list.component.mjs +715 -0
  41. package/{esm2020 → esm2022}/lib/message-preview.mjs +1 -1
  42. package/esm2022/lib/message-reactions/message-reactions.component.mjs +165 -0
  43. package/esm2022/lib/message-reactions-selector/message-reactions-selector.component.mjs +57 -0
  44. package/{esm2020 → esm2022}/lib/message-reactions.service.mjs +5 -5
  45. package/{esm2020 → esm2022}/lib/message-text/message-text.component.mjs +6 -6
  46. package/esm2022/lib/message.service.mjs +43 -0
  47. package/{esm2020 → esm2022}/lib/modal/modal.component.mjs +6 -6
  48. package/{esm2020 → esm2022}/lib/notification/notification.component.mjs +6 -6
  49. package/esm2022/lib/notification-list/notification-list.component.mjs +33 -0
  50. package/{esm2020 → esm2022}/lib/notification.service.mjs +5 -5
  51. package/esm2022/lib/paginated-list/paginated-list.component.mjs +94 -0
  52. package/{esm2020 → esm2022}/lib/parse-date.mjs +1 -1
  53. package/{esm2020 → esm2022}/lib/read-by.mjs +1 -1
  54. package/esm2022/lib/stream-autocomplete-textarea.module.mjs +33 -0
  55. package/{esm2020 → esm2022}/lib/stream-avatar.module.mjs +5 -5
  56. package/{esm2020 → esm2022}/lib/stream-chat.module.mjs +59 -59
  57. package/{esm2020 → esm2022}/lib/stream-i18n.service.mjs +5 -5
  58. package/esm2022/lib/stream-textarea.module.mjs +31 -0
  59. package/{esm2020 → esm2022}/lib/theme.service.mjs +5 -5
  60. package/{esm2020 → esm2022}/lib/thread/thread.component.mjs +6 -6
  61. package/{esm2020 → esm2022}/lib/transliteration.service.mjs +5 -5
  62. package/esm2022/lib/types.mjs +2 -0
  63. package/{esm2020 → esm2022}/lib/user-list/user-list.component.mjs +5 -5
  64. package/esm2022/lib/virtualized-list.service.mjs +273 -0
  65. package/{esm2020 → esm2022}/lib/virtualized-message-list.service.mjs +1 -1
  66. package/{esm2020 → esm2022}/lib/voice-recorder/amplitude-recorder.service.mjs +5 -5
  67. package/{esm2020 → esm2022}/lib/voice-recorder/audio-recorder.service.mjs +5 -5
  68. package/{esm2020 → esm2022}/lib/voice-recorder/media-recorder.mjs +1 -1
  69. package/esm2022/lib/voice-recorder/mp3-transcoder.mjs +61 -0
  70. package/esm2022/lib/voice-recorder/transcoder.service.mjs +121 -0
  71. package/esm2022/lib/voice-recorder/voice-recorder-wavebar/voice-recorder-wavebar.component.mjs +32 -0
  72. package/esm2022/lib/voice-recorder/voice-recorder.component.mjs +80 -0
  73. package/{esm2020 → esm2022}/lib/voice-recorder/voice-recorder.module.mjs +9 -9
  74. package/esm2022/lib/voice-recording/voice-recording-wavebar/voice-recording-wavebar.component.mjs +112 -0
  75. package/esm2022/lib/voice-recording/voice-recording.component.mjs +91 -0
  76. package/{esm2020 → esm2022}/lib/voice-recording/voice-recording.module.mjs +5 -5
  77. package/{esm2020 → esm2022}/lib/wave-form-sampler.mjs +1 -1
  78. package/esm2022/public-api.mjs +82 -0
  79. package/{fesm2020 → fesm2022}/stream-chat-angular.mjs +865 -1140
  80. package/fesm2022/stream-chat-angular.mjs.map +1 -0
  81. package/lib/attachment-list/attachment-list.component.d.ts +2 -5
  82. package/lib/attachment-preview-list/attachment-preview-list.component.d.ts +2 -2
  83. package/lib/attachment.service.d.ts +1 -1
  84. package/lib/avatar/avatar.component.d.ts +4 -4
  85. package/lib/avatar-placeholder/avatar-placeholder.component.d.ts +1 -1
  86. package/lib/channel-list/channel-list.component.d.ts +1 -0
  87. package/lib/channel-preview/channel-preview.component.d.ts +3 -4
  88. package/lib/channel.service.d.ts +40 -106
  89. package/lib/chat-client.service.d.ts +1 -4
  90. package/lib/custom-templates.service.d.ts +10 -10
  91. package/lib/icon/icon-placeholder/icon-placeholder.component.d.ts +1 -1
  92. package/lib/icon/icon.component.d.ts +2 -2
  93. package/lib/message/message.component.d.ts +2 -2
  94. package/lib/message-actions-box/message-actions-box.component.d.ts +2 -3
  95. package/lib/message-actions.service.d.ts +1 -1
  96. package/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.d.ts +2 -2
  97. package/lib/message-input/message-input.component.d.ts +2 -2
  98. package/lib/message-input/textarea/textarea.component.d.ts +1 -1
  99. package/lib/message-input/textarea.directive.d.ts +2 -2
  100. package/lib/message-list/group-styles.d.ts +1 -1
  101. package/lib/message-list/message-list.component.d.ts +2 -3
  102. package/lib/message-reactions/message-reactions.component.d.ts +2 -3
  103. package/lib/message-reactions-selector/message-reactions-selector.component.d.ts +1 -2
  104. package/lib/message-text/message-text.component.d.ts +2 -2
  105. package/lib/modal/modal.component.d.ts +1 -1
  106. package/lib/notification/notification.component.d.ts +1 -1
  107. package/lib/notification-list/notification-list.component.d.ts +0 -1
  108. package/lib/paginated-list/paginated-list.component.d.ts +5 -2
  109. package/lib/read-by.d.ts +1 -1
  110. package/lib/types.d.ts +98 -84
  111. package/lib/user-list/user-list.component.d.ts +1 -1
  112. package/lib/voice-recorder/amplitude-recorder.service.d.ts +2 -2
  113. package/lib/voice-recorder/media-recorder.d.ts +2 -2
  114. package/lib/voice-recorder/transcoder.service.d.ts +4 -4
  115. package/lib/voice-recorder/voice-recorder-wavebar/voice-recorder-wavebar.component.d.ts +0 -1
  116. package/lib/voice-recorder/voice-recorder.component.d.ts +2 -2
  117. package/lib/voice-recording/voice-recording-wavebar/voice-recording-wavebar.component.d.ts +3 -3
  118. package/lib/voice-recording/voice-recording.component.d.ts +1 -1
  119. package/package.json +15 -21
  120. package/public-api.d.ts +0 -1
  121. package/src/assets/i18n/en.ts +1 -0
  122. package/src/assets/version.ts +1 -1
  123. package/esm2020/lib/attachment-list/attachment-list.component.mjs +0 -224
  124. package/esm2020/lib/attachment-preview-list/attachment-preview-list.component.mjs +0 -55
  125. package/esm2020/lib/avatar/avatar.component.mjs +0 -160
  126. package/esm2020/lib/channel/channel.component.mjs +0 -45
  127. package/esm2020/lib/channel-header/channel-header.component.mjs +0 -72
  128. package/esm2020/lib/channel-list/channel-list.component.mjs +0 -47
  129. package/esm2020/lib/channel-preview/channel-preview.component.mjs +0 -155
  130. package/esm2020/lib/channel-query.mjs +0 -77
  131. package/esm2020/lib/channel.service.mjs +0 -1546
  132. package/esm2020/lib/chat-client.service.mjs +0 -238
  133. package/esm2020/lib/file-utils.mjs +0 -35
  134. package/esm2020/lib/message/message.component.mjs +0 -486
  135. package/esm2020/lib/message-actions-box/message-actions-box.component.mjs +0 -123
  136. package/esm2020/lib/message-bounce-prompt/message-bounce-prompt.component.mjs +0 -71
  137. package/esm2020/lib/message-input/message-input.component.mjs +0 -507
  138. package/esm2020/lib/message-list/message-list.component.mjs +0 -717
  139. package/esm2020/lib/message-reactions/message-reactions.component.mjs +0 -168
  140. package/esm2020/lib/message-reactions-selector/message-reactions-selector.component.mjs +0 -61
  141. package/esm2020/lib/message.service.mjs +0 -43
  142. package/esm2020/lib/notification-list/notification-list.component.mjs +0 -36
  143. package/esm2020/lib/paginated-list/paginated-list.component.mjs +0 -94
  144. package/esm2020/lib/stream-autocomplete-textarea.module.mjs +0 -33
  145. package/esm2020/lib/stream-textarea.module.mjs +0 -31
  146. package/esm2020/lib/types.mjs +0 -2
  147. package/esm2020/lib/virtualized-list.service.mjs +0 -271
  148. package/esm2020/lib/voice-recorder/mp3-transcoder.mjs +0 -61
  149. package/esm2020/lib/voice-recorder/transcoder.service.mjs +0 -121
  150. package/esm2020/lib/voice-recorder/voice-recorder-wavebar/voice-recorder-wavebar.component.mjs +0 -35
  151. package/esm2020/lib/voice-recorder/voice-recorder.component.mjs +0 -80
  152. package/esm2020/lib/voice-recording/voice-recording-wavebar/voice-recording-wavebar.component.mjs +0 -112
  153. package/esm2020/lib/voice-recording/voice-recording.component.mjs +0 -91
  154. package/esm2020/public-api.mjs +0 -83
  155. package/fesm2015/stream-chat-angular.mjs +0 -9152
  156. package/fesm2015/stream-chat-angular.mjs.map +0 -1
  157. package/fesm2020/stream-chat-angular.mjs.map +0 -1
  158. package/lib/channel-query.d.ts +0 -26
  159. /package/{esm2020 → esm2022}/lib/format-duration.mjs +0 -0
  160. /package/{esm2020 → esm2022}/lib/injection-tokens.mjs +0 -0
  161. /package/{esm2020 → esm2022}/lib/is-image-attachment.mjs +0 -0
  162. /package/{esm2020 → esm2022}/lib/is-on-separate-date.mjs +0 -0
  163. /package/{esm2020 → esm2022}/lib/is-safari.mjs +0 -0
  164. /package/{esm2020 → esm2022}/lib/message-input/textarea.interface.mjs +0 -0
  165. /package/{esm2020 → esm2022}/stream-chat-angular.mjs +0 -0
@@ -1,155 +0,0 @@
1
- import { Component, Input } from '@angular/core';
2
- import { filter } from 'rxjs/operators';
3
- import { getChannelDisplayText } from '../get-channel-display-text';
4
- import { getMessageTranslation } from '../get-message-translation';
5
- import { getReadBy } from '../read-by';
6
- import { isOnSeparateDate } from '../is-on-separate-date';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "../channel.service";
9
- import * as i2 from "../chat-client.service";
10
- import * as i3 from "../message.service";
11
- import * as i4 from "../custom-templates.service";
12
- import * as i5 from "../date-parser.service";
13
- import * as i6 from "@angular/common";
14
- import * as i7 from "../avatar-placeholder/avatar-placeholder.component";
15
- import * as i8 from "../icon/icon-placeholder/icon-placeholder.component";
16
- import * as i9 from "@ngx-translate/core";
17
- /**
18
- * The `ChannelPreview` component displays a channel preview in the channel list, it consists of the image, name and latest message of the channel.
19
- */
20
- export class ChannelPreviewComponent {
21
- constructor(channelService, ngZone, chatClientService, messageService, customTemplatesService, dateParser) {
22
- this.channelService = channelService;
23
- this.ngZone = ngZone;
24
- this.chatClientService = chatClientService;
25
- this.customTemplatesService = customTemplatesService;
26
- this.dateParser = dateParser;
27
- this.isActive = false;
28
- this.isUnreadMessageWasCalled = false;
29
- this.isUnread = false;
30
- this.latestMessageText = 'streamChat.Nothing yet...';
31
- this.subscriptions = [];
32
- this.canSendReadEvents = true;
33
- this.displayAs = messageService.displayAs;
34
- }
35
- ngOnInit() {
36
- this.subscriptions.push(this.chatClientService.user$.subscribe((user) => {
37
- if (user?.id !== this.userId) {
38
- this.userId = user?.id;
39
- }
40
- }));
41
- this.subscriptions.push(this.channelService.activeChannel$.subscribe((activeChannel) => (this.isActive = activeChannel?.id === this.channel?.id)));
42
- const messages = this.channel?.state?.latestMessages;
43
- if (messages && messages.length > 0) {
44
- this.setLatestMessage(messages[messages.length - 1]);
45
- }
46
- this.updateUnreadState();
47
- const capabilities = this.channel?.data?.own_capabilities || [];
48
- this.canSendReadEvents = capabilities.indexOf('read-events') !== -1;
49
- this.subscriptions.push(this.channel.on('message.new', this.handleMessageEvent.bind(this)));
50
- this.subscriptions.push(this.channel.on('message.updated', this.handleMessageEvent.bind(this)));
51
- this.subscriptions.push(this.channel.on('message.deleted', this.handleMessageEvent.bind(this)));
52
- this.subscriptions.push(this.channel.on('channel.truncated', this.handleMessageEvent.bind(this)));
53
- this.subscriptions.push(this.channel.on('message.read', () => this.ngZone.run(() => {
54
- this.isUnreadMessageWasCalled = false;
55
- this.updateUnreadState();
56
- })));
57
- this.subscriptions.push(this.chatClientService.events$
58
- .pipe(filter((e) => e.eventType === 'notification.mark_unread' &&
59
- this.channel.id === e.event?.channel_id))
60
- .subscribe(() => {
61
- this.ngZone.run(() => {
62
- this.isUnreadMessageWasCalled = true;
63
- this.updateUnreadState();
64
- });
65
- }));
66
- }
67
- ngOnDestroy() {
68
- this.subscriptions.forEach((s) => s.unsubscribe());
69
- }
70
- get avatarImage() {
71
- return this.channel?.data?.image;
72
- }
73
- get avatarName() {
74
- return this.channel?.data?.name;
75
- }
76
- get title() {
77
- if (!this.channel) {
78
- return '';
79
- }
80
- return getChannelDisplayText(this.channel, this.chatClientService.chatClient.user);
81
- }
82
- setAsActiveChannel() {
83
- void this.channelService.setAsActiveChannel(this.channel);
84
- }
85
- handleMessageEvent(event) {
86
- this.ngZone.run(() => {
87
- if (this.channel?.state.latestMessages.length === 0) {
88
- this.latestMessage = undefined;
89
- this.latestMessageStatus = undefined;
90
- this.latestMessageText = 'streamChat.Nothing yet...';
91
- this.latestMessageTime = undefined;
92
- return;
93
- }
94
- const latestMessage = this.channel?.state.latestMessages[this.channel?.state.latestMessages.length - 1];
95
- if (!event.message || latestMessage?.id !== event.message.id) {
96
- return;
97
- }
98
- this.setLatestMessage(latestMessage);
99
- this.updateUnreadState();
100
- });
101
- }
102
- setLatestMessage(message) {
103
- this.latestMessage = message;
104
- if (message?.deleted_at) {
105
- this.latestMessageText = 'streamChat.Message deleted';
106
- }
107
- else if (message?.text) {
108
- this.latestMessageText =
109
- getMessageTranslation(message, this.channel, this.chatClientService.chatClient.user) || message.text;
110
- }
111
- else if (message?.attachments && message.attachments.length) {
112
- this.latestMessageText = 'streamChat.🏙 Attachment...';
113
- }
114
- if (this.latestMessage && this.latestMessage.type === 'regular') {
115
- this.latestMessageTime = isOnSeparateDate(new Date(), this.latestMessage.created_at)
116
- ? this.dateParser.parseDate(this.latestMessage.created_at)
117
- : this.dateParser.parseTime(this.latestMessage.created_at);
118
- }
119
- else {
120
- this.latestMessageTime = undefined;
121
- }
122
- }
123
- updateUnreadState() {
124
- if (this.channel &&
125
- this.latestMessage &&
126
- this.latestMessage.user?.id === this.userId &&
127
- this.latestMessage.status === 'received' &&
128
- this.latestMessage.type === 'regular') {
129
- this.latestMessageStatus =
130
- getReadBy(this.latestMessage, this.channel).length > 0
131
- ? 'read'
132
- : 'delivered';
133
- }
134
- else {
135
- this.latestMessageStatus = undefined;
136
- }
137
- if ((this.isActive && !this.isUnreadMessageWasCalled) ||
138
- !this.canSendReadEvents) {
139
- this.unreadCount = 0;
140
- this.isUnread = false;
141
- return;
142
- }
143
- this.unreadCount = this.channel.countUnread();
144
- this.isUnread = !!this.unreadCount;
145
- }
146
- }
147
- ChannelPreviewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: ChannelPreviewComponent, deps: [{ token: i1.ChannelService }, { token: i0.NgZone }, { token: i2.ChatClientService }, { token: i3.MessageService }, { token: i4.CustomTemplatesService }, { token: i5.DateParserService }], target: i0.ɵɵFactoryTarget.Component });
148
- ChannelPreviewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: ChannelPreviewComponent, selector: "stream-channel-preview", inputs: { channel: "channel" }, ngImport: i0, template: "<button\n class=\"str-chat__channel-preview-messenger str-chat__channel-preview\"\n data-testid=\"channel-preview-container\"\n [class.str-chat__channel-preview-messenger--active]=\"isActive\"\n [class.str-chat__channel-preview--active]=\"isActive\"\n [class.str-chat__channel-preview-messenger--unread]=\"isUnread\"\n (click)=\"setAsActiveChannel()\"\n>\n <div class=\"str-chat__channel-preview-messenger--left\">\n <stream-avatar-placeholder\n type=\"channel\"\n location=\"channel-preview\"\n name=\"{{ avatarName }}\"\n imageUrl=\"{{ avatarImage }}\"\n [channel]=\"channel\"\n ></stream-avatar-placeholder>\n </div>\n <div\n class=\"str-chat__channel-preview-messenger--right str-chat__channel-preview-end\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n (customTemplatesService.channelPreviewInfoTemplate$ | async) ||\n defaultChannelInfo;\n context: {\n channelDisplayTitle: title,\n channel: channel,\n unreadCount: unreadCount,\n latestMessageText: latestMessageText,\n latestMessageStatus: latestMessageStatus,\n latestMessageTime: latestMessageTime,\n latestMessage: latestMessage\n }\n \"\n ></ng-container>\n <ng-template\n #defaultChannelInfo\n let-channelDisplayTitle=\"channelDisplayTitle\"\n let-unreadCount=\"unreadCount\"\n let-latestMessageText=\"latestMessageText\"\n let-latestMessageStatus=\"latestMessageStatus\"\n let-latestMessageTime=\"latestMessageTime\"\n >\n <div class=\"str-chat__channel-preview-end-first-row\">\n <div class=\"str-chat__channel-preview-messenger--name\">\n <span data-testid=\"channel-preview-title\">{{\n channelDisplayTitle\n }}</span>\n </div>\n <div\n *ngIf=\"unreadCount\"\n data-testid=\"unread-badge\"\n class=\"str-chat__channel-preview-unread-badge\"\n >\n {{ unreadCount }}\n </div>\n </div>\n <div class=\"str-chat__channel-preview-end-second-row\">\n <div\n data-testid=\"latest-message\"\n class=\"str-chat__channel-preview-messenger--last-message\"\n >\n <ng-container *ngIf=\"displayAs === 'text'; else asHTML\">\n {{ latestMessageText | translate }}\n </ng-container>\n <ng-template #asHTML>\n <span\n data-testid=\"html-content\"\n [innerHTML]=\"latestMessageText | translate\"\n ></span>\n </ng-template>\n </div>\n <div\n *ngIf=\"latestMessageStatus\"\n data-testid=\"latest-message-status\"\n class=\"str-chat__channel-preview-messenger--status str-chat__channel-preview-messenger--status-{{\n latestMessageStatus\n }}\"\n >\n <stream-icon-placeholder\n [icon]=\"latestMessageStatus === 'delivered' ? 'delivered' : 'read'\"\n ></stream-icon-placeholder>\n </div>\n <div\n *ngIf=\"latestMessageTime\"\n data-testid=\"latest-message-time\"\n class=\"str-chat__channel-preview-messenger--time\"\n >\n {{ latestMessageTime }}\n </div>\n </div>\n </ng-template>\n </div>\n</button>\n", dependencies: [{ kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i7.AvatarPlaceholderComponent, selector: "stream-avatar-placeholder", inputs: ["name", "imageUrl", "location", "channel", "user", "type", "initialsType", "showOnlineIndicator"] }, { kind: "component", type: i8.IconPlaceholderComponent, selector: "stream-icon-placeholder", inputs: ["icon"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i9.TranslatePipe, name: "translate" }] });
149
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: ChannelPreviewComponent, decorators: [{
150
- type: Component,
151
- args: [{ selector: 'stream-channel-preview', template: "<button\n class=\"str-chat__channel-preview-messenger str-chat__channel-preview\"\n data-testid=\"channel-preview-container\"\n [class.str-chat__channel-preview-messenger--active]=\"isActive\"\n [class.str-chat__channel-preview--active]=\"isActive\"\n [class.str-chat__channel-preview-messenger--unread]=\"isUnread\"\n (click)=\"setAsActiveChannel()\"\n>\n <div class=\"str-chat__channel-preview-messenger--left\">\n <stream-avatar-placeholder\n type=\"channel\"\n location=\"channel-preview\"\n name=\"{{ avatarName }}\"\n imageUrl=\"{{ avatarImage }}\"\n [channel]=\"channel\"\n ></stream-avatar-placeholder>\n </div>\n <div\n class=\"str-chat__channel-preview-messenger--right str-chat__channel-preview-end\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n (customTemplatesService.channelPreviewInfoTemplate$ | async) ||\n defaultChannelInfo;\n context: {\n channelDisplayTitle: title,\n channel: channel,\n unreadCount: unreadCount,\n latestMessageText: latestMessageText,\n latestMessageStatus: latestMessageStatus,\n latestMessageTime: latestMessageTime,\n latestMessage: latestMessage\n }\n \"\n ></ng-container>\n <ng-template\n #defaultChannelInfo\n let-channelDisplayTitle=\"channelDisplayTitle\"\n let-unreadCount=\"unreadCount\"\n let-latestMessageText=\"latestMessageText\"\n let-latestMessageStatus=\"latestMessageStatus\"\n let-latestMessageTime=\"latestMessageTime\"\n >\n <div class=\"str-chat__channel-preview-end-first-row\">\n <div class=\"str-chat__channel-preview-messenger--name\">\n <span data-testid=\"channel-preview-title\">{{\n channelDisplayTitle\n }}</span>\n </div>\n <div\n *ngIf=\"unreadCount\"\n data-testid=\"unread-badge\"\n class=\"str-chat__channel-preview-unread-badge\"\n >\n {{ unreadCount }}\n </div>\n </div>\n <div class=\"str-chat__channel-preview-end-second-row\">\n <div\n data-testid=\"latest-message\"\n class=\"str-chat__channel-preview-messenger--last-message\"\n >\n <ng-container *ngIf=\"displayAs === 'text'; else asHTML\">\n {{ latestMessageText | translate }}\n </ng-container>\n <ng-template #asHTML>\n <span\n data-testid=\"html-content\"\n [innerHTML]=\"latestMessageText | translate\"\n ></span>\n </ng-template>\n </div>\n <div\n *ngIf=\"latestMessageStatus\"\n data-testid=\"latest-message-status\"\n class=\"str-chat__channel-preview-messenger--status str-chat__channel-preview-messenger--status-{{\n latestMessageStatus\n }}\"\n >\n <stream-icon-placeholder\n [icon]=\"latestMessageStatus === 'delivered' ? 'delivered' : 'read'\"\n ></stream-icon-placeholder>\n </div>\n <div\n *ngIf=\"latestMessageTime\"\n data-testid=\"latest-message-time\"\n class=\"str-chat__channel-preview-messenger--time\"\n >\n {{ latestMessageTime }}\n </div>\n </div>\n </ng-template>\n </div>\n</button>\n" }]
152
- }], ctorParameters: function () { return [{ type: i1.ChannelService }, { type: i0.NgZone }, { type: i2.ChatClientService }, { type: i3.MessageService }, { type: i4.CustomTemplatesService }, { type: i5.DateParserService }]; }, propDecorators: { channel: [{
153
- type: Input
154
- }] } });
155
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"channel-preview.component.js","sourceRoot":"","sources":["../../../../../projects/stream-chat-angular/src/lib/channel-preview/channel-preview.component.ts","../../../../../projects/stream-chat-angular/src/lib/channel-preview/channel-preview.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, NgZone, OnDestroy, OnInit } from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { filter } from 'rxjs/operators';\nimport { Channel, Event, FormatMessageResponse } from 'stream-chat';\nimport { ChannelService } from '../channel.service';\nimport { getChannelDisplayText } from '../get-channel-display-text';\nimport { DefaultStreamChatGenerics } from '../types';\nimport { ChatClientService } from '../chat-client.service';\nimport { getMessageTranslation } from '../get-message-translation';\nimport { MessageService } from '../message.service';\nimport { CustomTemplatesService } from '../custom-templates.service';\nimport { getReadBy } from '../read-by';\nimport { isOnSeparateDate } from '../is-on-separate-date';\nimport { DateParserService } from '../date-parser.service';\n\n/**\n * The `ChannelPreview` component displays a channel preview in the channel list, it consists of the image, name and latest message of the channel.\n */\n@Component({\n  selector: 'stream-channel-preview',\n  templateUrl: './channel-preview.component.html',\n  styles: [],\n})\nexport class ChannelPreviewComponent implements OnInit, OnDestroy {\n  /**\n   * The channel to be displayed\n   */\n  @Input() channel: Channel<DefaultStreamChatGenerics> | undefined;\n  isActive = false;\n  isUnreadMessageWasCalled = false;\n  isUnread = false;\n  unreadCount: number | undefined;\n  latestMessageText: string = 'streamChat.Nothing yet...';\n  latestMessageStatus?: 'delivered' | 'read';\n  latestMessageTime?: string;\n  latestMessage?: FormatMessageResponse<DefaultStreamChatGenerics>;\n  displayAs: 'text' | 'html';\n  userId?: string;\n  private subscriptions: (Subscription | { unsubscribe: () => void })[] = [];\n  private canSendReadEvents = true;\n\n  constructor(\n    private channelService: ChannelService,\n    private ngZone: NgZone,\n    private chatClientService: ChatClientService,\n    messageService: MessageService,\n    public customTemplatesService: CustomTemplatesService,\n    private dateParser: DateParserService\n  ) {\n    this.displayAs = messageService.displayAs;\n  }\n\n  ngOnInit(): void {\n    this.subscriptions.push(\n      this.chatClientService.user$.subscribe((user) => {\n        if (user?.id !== this.userId) {\n          this.userId = user?.id;\n        }\n      })\n    );\n    this.subscriptions.push(\n      this.channelService.activeChannel$.subscribe(\n        (activeChannel) =>\n          (this.isActive = activeChannel?.id === this.channel?.id)\n      )\n    );\n    const messages = this.channel?.state?.latestMessages;\n    if (messages && messages.length > 0) {\n      this.setLatestMessage(messages[messages.length - 1]);\n    }\n    this.updateUnreadState();\n    const capabilities =\n      (this.channel?.data?.own_capabilities as string[]) || [];\n    this.canSendReadEvents = capabilities.indexOf('read-events') !== -1;\n    this.subscriptions.push(\n      this.channel!.on('message.new', this.handleMessageEvent.bind(this))\n    );\n    this.subscriptions.push(\n      this.channel!.on('message.updated', this.handleMessageEvent.bind(this))\n    );\n    this.subscriptions.push(\n      this.channel!.on('message.deleted', this.handleMessageEvent.bind(this))\n    );\n    this.subscriptions.push(\n      this.channel!.on('channel.truncated', this.handleMessageEvent.bind(this))\n    );\n    this.subscriptions.push(\n      this.channel!.on('message.read', () =>\n        this.ngZone.run(() => {\n          this.isUnreadMessageWasCalled = false;\n          this.updateUnreadState();\n        })\n      )\n    );\n    this.subscriptions.push(\n      this.chatClientService.events$\n        .pipe(\n          filter(\n            (e) =>\n              e.eventType === 'notification.mark_unread' &&\n              this.channel!.id === e.event?.channel_id\n          )\n        )\n        .subscribe(() => {\n          this.ngZone.run(() => {\n            this.isUnreadMessageWasCalled = true;\n            this.updateUnreadState();\n          });\n        })\n    );\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach((s) => s.unsubscribe());\n  }\n\n  get avatarImage() {\n    return this.channel?.data?.image;\n  }\n\n  get avatarName() {\n    return this.channel?.data?.name;\n  }\n\n  get title() {\n    if (!this.channel) {\n      return '';\n    }\n    return getChannelDisplayText(\n      this.channel,\n      this.chatClientService.chatClient.user!\n    );\n  }\n\n  setAsActiveChannel(): void {\n    void this.channelService.setAsActiveChannel(this.channel!);\n  }\n\n  private handleMessageEvent(event: Event) {\n    this.ngZone.run(() => {\n      if (this.channel?.state.latestMessages.length === 0) {\n        this.latestMessage = undefined;\n        this.latestMessageStatus = undefined;\n        this.latestMessageText = 'streamChat.Nothing yet...';\n        this.latestMessageTime = undefined;\n        return;\n      }\n      const latestMessage =\n        this.channel?.state.latestMessages[\n          this.channel?.state.latestMessages.length - 1\n        ];\n      if (!event.message || latestMessage?.id !== event.message.id) {\n        return;\n      }\n      this.setLatestMessage(latestMessage);\n      this.updateUnreadState();\n    });\n  }\n\n  private setLatestMessage(\n    message?: FormatMessageResponse<DefaultStreamChatGenerics>\n  ) {\n    this.latestMessage = message;\n    if (message?.deleted_at) {\n      this.latestMessageText = 'streamChat.Message deleted';\n    } else if (message?.text) {\n      this.latestMessageText =\n        getMessageTranslation(\n          message,\n          this.channel,\n          this.chatClientService.chatClient.user\n        ) || message.text;\n    } else if (message?.attachments && message.attachments.length) {\n      this.latestMessageText = 'streamChat.🏙 Attachment...';\n    }\n    if (this.latestMessage && this.latestMessage.type === 'regular') {\n      this.latestMessageTime = isOnSeparateDate(\n        new Date(),\n        this.latestMessage.created_at\n      )\n        ? this.dateParser.parseDate(this.latestMessage.created_at)\n        : this.dateParser.parseTime(this.latestMessage.created_at);\n    } else {\n      this.latestMessageTime = undefined;\n    }\n  }\n\n  private updateUnreadState() {\n    if (\n      this.channel &&\n      this.latestMessage &&\n      this.latestMessage.user?.id === this.userId &&\n      this.latestMessage.status === 'received' &&\n      this.latestMessage.type === 'regular'\n    ) {\n      this.latestMessageStatus =\n        getReadBy(this.latestMessage, this.channel).length > 0\n          ? 'read'\n          : 'delivered';\n    } else {\n      this.latestMessageStatus = undefined;\n    }\n    if (\n      (this.isActive && !this.isUnreadMessageWasCalled) ||\n      !this.canSendReadEvents\n    ) {\n      this.unreadCount = 0;\n      this.isUnread = false;\n      return;\n    }\n    this.unreadCount = this.channel!.countUnread();\n    this.isUnread = !!this.unreadCount;\n  }\n}\n","<button\n  class=\"str-chat__channel-preview-messenger str-chat__channel-preview\"\n  data-testid=\"channel-preview-container\"\n  [class.str-chat__channel-preview-messenger--active]=\"isActive\"\n  [class.str-chat__channel-preview--active]=\"isActive\"\n  [class.str-chat__channel-preview-messenger--unread]=\"isUnread\"\n  (click)=\"setAsActiveChannel()\"\n>\n  <div class=\"str-chat__channel-preview-messenger--left\">\n    <stream-avatar-placeholder\n      type=\"channel\"\n      location=\"channel-preview\"\n      name=\"{{ avatarName }}\"\n      imageUrl=\"{{ avatarImage }}\"\n      [channel]=\"channel\"\n    ></stream-avatar-placeholder>\n  </div>\n  <div\n    class=\"str-chat__channel-preview-messenger--right str-chat__channel-preview-end\"\n  >\n    <ng-container\n      *ngTemplateOutlet=\"\n        (customTemplatesService.channelPreviewInfoTemplate$ | async) ||\n          defaultChannelInfo;\n        context: {\n          channelDisplayTitle: title,\n          channel: channel,\n          unreadCount: unreadCount,\n          latestMessageText: latestMessageText,\n          latestMessageStatus: latestMessageStatus,\n          latestMessageTime: latestMessageTime,\n          latestMessage: latestMessage\n        }\n      \"\n    ></ng-container>\n    <ng-template\n      #defaultChannelInfo\n      let-channelDisplayTitle=\"channelDisplayTitle\"\n      let-unreadCount=\"unreadCount\"\n      let-latestMessageText=\"latestMessageText\"\n      let-latestMessageStatus=\"latestMessageStatus\"\n      let-latestMessageTime=\"latestMessageTime\"\n    >\n      <div class=\"str-chat__channel-preview-end-first-row\">\n        <div class=\"str-chat__channel-preview-messenger--name\">\n          <span data-testid=\"channel-preview-title\">{{\n            channelDisplayTitle\n          }}</span>\n        </div>\n        <div\n          *ngIf=\"unreadCount\"\n          data-testid=\"unread-badge\"\n          class=\"str-chat__channel-preview-unread-badge\"\n        >\n          {{ unreadCount }}\n        </div>\n      </div>\n      <div class=\"str-chat__channel-preview-end-second-row\">\n        <div\n          data-testid=\"latest-message\"\n          class=\"str-chat__channel-preview-messenger--last-message\"\n        >\n          <ng-container *ngIf=\"displayAs === 'text'; else asHTML\">\n            {{ latestMessageText | translate }}\n          </ng-container>\n          <ng-template #asHTML>\n            <span\n              data-testid=\"html-content\"\n              [innerHTML]=\"latestMessageText | translate\"\n            ></span>\n          </ng-template>\n        </div>\n        <div\n          *ngIf=\"latestMessageStatus\"\n          data-testid=\"latest-message-status\"\n          class=\"str-chat__channel-preview-messenger--status str-chat__channel-preview-messenger--status-{{\n            latestMessageStatus\n          }}\"\n        >\n          <stream-icon-placeholder\n            [icon]=\"latestMessageStatus === 'delivered' ? 'delivered' : 'read'\"\n          ></stream-icon-placeholder>\n        </div>\n        <div\n          *ngIf=\"latestMessageTime\"\n          data-testid=\"latest-message-time\"\n          class=\"str-chat__channel-preview-messenger--time\"\n        >\n          {{ latestMessageTime }}\n        </div>\n      </div>\n    </ng-template>\n  </div>\n</button>\n"]}
@@ -1,77 +0,0 @@
1
- /**
2
- * This class allows you to make paginated channel query requests.
3
- */
4
- export class ChannelQuery {
5
- constructor(chatService, channelService, filters, sort = { last_message_at: -1 }, options = {
6
- limit: 25,
7
- state: true,
8
- presence: true,
9
- watch: true,
10
- }) {
11
- this.chatService = chatService;
12
- this.channelService = channelService;
13
- this.filters = filters;
14
- this.sort = sort;
15
- this.options = options;
16
- }
17
- async query(queryType) {
18
- if (queryType === 'first-page' || queryType === 'recover-state') {
19
- this.nextPageConfiguration = undefined;
20
- }
21
- const prevChannels = queryType === 'recover-state' ? [] : this.channelService.channels;
22
- let filters;
23
- let options;
24
- if (this.nextPageConfiguration) {
25
- if (this.nextPageConfiguration.type === 'filter') {
26
- filters = {
27
- ...this.filters,
28
- ...this.nextPageConfiguration.paginationFilter,
29
- };
30
- options = this.options;
31
- }
32
- else {
33
- options = {
34
- ...this.options,
35
- offset: this.nextPageConfiguration.offset,
36
- };
37
- filters = this.filters;
38
- }
39
- }
40
- else {
41
- filters = this.filters;
42
- options = this.options;
43
- }
44
- const channels = await this.chatService.chatClient.queryChannels(filters, this.sort || {}, options);
45
- this.setNextPageConfiguration(channels);
46
- const currentActiveChannel = this.channelService.activeChannel;
47
- if (queryType === 'recover-state' &&
48
- currentActiveChannel &&
49
- !channels.find((c) => c.cid === currentActiveChannel?.cid)) {
50
- try {
51
- await currentActiveChannel.watch();
52
- channels.unshift(currentActiveChannel);
53
- }
54
- catch (error) {
55
- this.chatService.chatClient.logger('warn', 'Unable to refetch active channel after state recover', error);
56
- }
57
- }
58
- return {
59
- channels: [...prevChannels, ...channels],
60
- hasMorePage: channels.length >= this.options.limit,
61
- };
62
- }
63
- setNextPageConfiguration(channelQueryResult) {
64
- if (this.customPaginator) {
65
- this.nextPageConfiguration = this.customPaginator(channelQueryResult);
66
- }
67
- else {
68
- this.nextPageConfiguration = {
69
- type: 'offset',
70
- offset: (this.nextPageConfiguration?.type === 'offset'
71
- ? this.nextPageConfiguration.offset
72
- : 0) + channelQueryResult.length,
73
- };
74
- }
75
- }
76
- }
77
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"channel-query.js","sourceRoot":"","sources":["../../../../projects/stream-chat-angular/src/lib/channel-query.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Channel,\n  ChannelFilters,\n  ChannelOptions,\n  ChannelSort,\n} from 'stream-chat';\nimport { ChannelService } from './channel.service';\nimport {\n  ChannelQueryResult,\n  ChannelQueryType,\n  DefaultStreamChatGenerics,\n  NextPageConfiguration,\n} from './types';\nimport { ChatClientService } from './chat-client.service';\n\n/**\n * This class allows you to make paginated channel query requests.\n */\nexport class ChannelQuery<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> {\n  /**\n   * By default the SDK uses an offset based pagination, you can change/extend this by providing your own custom paginator method.\n   *\n   * The method will be called with the result of the latest channel query.\n   *\n   * You can return either an offset, or a filter using the [`$lte`/`$gte` operator](/chat/docs/javascript/query_syntax_operators/). If you return a filter, it will be merged with the filter provided for the `init` method.\n   */\n  customPaginator?: (channelQueryResult: Channel<T>[]) => NextPageConfiguration;\n  private nextPageConfiguration?: NextPageConfiguration;\n\n  constructor(\n    private chatService: ChatClientService<T>,\n    private channelService: ChannelService<T>,\n    private filters: ChannelFilters<T>,\n    private sort: ChannelSort<T> = { last_message_at: -1 },\n    private options: ChannelOptions = {\n      limit: 25,\n      state: true,\n      presence: true,\n      watch: true,\n    }\n  ) {}\n\n  async query(queryType: ChannelQueryType): Promise<ChannelQueryResult<T>> {\n    if (queryType === 'first-page' || queryType === 'recover-state') {\n      this.nextPageConfiguration = undefined;\n    }\n    const prevChannels =\n      queryType === 'recover-state' ? [] : this.channelService.channels;\n    let filters: ChannelFilters<T>;\n    let options: ChannelOptions;\n    if (this.nextPageConfiguration) {\n      if (this.nextPageConfiguration.type === 'filter') {\n        filters = {\n          ...this.filters,\n          ...this.nextPageConfiguration.paginationFilter,\n        };\n        options = this.options;\n      } else {\n        options = {\n          ...this.options,\n          offset: this.nextPageConfiguration.offset,\n        };\n        filters = this.filters;\n      }\n    } else {\n      filters = this.filters;\n      options = this.options;\n    }\n    const channels = await this.chatService.chatClient.queryChannels(\n      filters,\n      this.sort || {},\n      options\n    );\n    this.setNextPageConfiguration(channels);\n\n    const currentActiveChannel = this.channelService.activeChannel;\n    if (\n      queryType === 'recover-state' &&\n      currentActiveChannel &&\n      !channels.find((c) => c.cid === currentActiveChannel?.cid)\n    ) {\n      try {\n        await currentActiveChannel.watch();\n        channels.unshift(currentActiveChannel);\n      } catch (error) {\n        this.chatService.chatClient.logger(\n          'warn',\n          'Unable to refetch active channel after state recover',\n          error as Record<string, unknown>\n        );\n      }\n    }\n\n    return {\n      channels: [...prevChannels, ...channels],\n      hasMorePage: channels.length >= this.options.limit!,\n    };\n  }\n\n  setNextPageConfiguration(channelQueryResult: Channel<T>[]) {\n    if (this.customPaginator) {\n      this.nextPageConfiguration = this.customPaginator(channelQueryResult);\n    } else {\n      this.nextPageConfiguration = {\n        type: 'offset',\n        offset:\n          (this.nextPageConfiguration?.type === 'offset'\n            ? this.nextPageConfiguration.offset\n            : 0) + channelQueryResult.length,\n      };\n    }\n  }\n}\n"]}