stream-chat-angular 2.9.0 → 2.12.1
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.
- package/assets/i18n/en.d.ts +2 -0
- package/assets/version.d.ts +1 -1
- package/bundles/stream-chat-angular.umd.js +718 -343
- package/bundles/stream-chat-angular.umd.js.map +1 -1
- package/esm2015/assets/i18n/en.js +3 -1
- package/esm2015/assets/version.js +2 -2
- package/esm2015/lib/channel/channel.component.js +3 -2
- package/esm2015/lib/channel.service.js +175 -40
- package/esm2015/lib/chat-client.service.js +6 -1
- package/esm2015/lib/icon/icon.component.js +2 -2
- package/esm2015/lib/message/message.component.js +67 -42
- package/esm2015/lib/message-actions-box/message-actions-box.component.js +20 -9
- package/esm2015/lib/message-input/message-input.component.js +61 -13
- package/esm2015/lib/message-list/message-list.component.js +124 -55
- package/esm2015/lib/message-preview.js +4 -2
- package/esm2015/lib/stream-chat.module.js +8 -3
- package/esm2015/lib/thread/thread.component.js +37 -0
- package/esm2015/public-api.js +2 -1
- package/fesm2015/stream-chat-angular.js +583 -252
- package/fesm2015/stream-chat-angular.js.map +1 -1
- package/lib/channel/channel.component.d.ts +2 -1
- package/lib/channel.service.d.ts +22 -7
- package/lib/chat-client.service.d.ts +1 -0
- package/lib/icon/icon.component.d.ts +1 -1
- package/lib/message/message.component.d.ts +26 -8
- package/lib/message-actions-box/message-actions-box.component.d.ts +4 -1
- package/lib/message-input/message-input.component.d.ts +7 -1
- package/lib/message-list/message-list.component.d.ts +21 -7
- package/lib/message-preview.d.ts +1 -1
- package/lib/stream-chat.module.d.ts +5 -4
- package/lib/thread/thread.component.d.ts +18 -0
- package/package.json +2 -11
- package/public-api.d.ts +1 -0
- package/src/assets/i18n/en.ts +4 -0
- package/src/assets/version.ts +1 -1
|
@@ -7,35 +7,43 @@ import * as i2 from "../chat-client.service";
|
|
|
7
7
|
import * as i3 from "./image-load.service";
|
|
8
8
|
import * as i4 from "../message/message.component";
|
|
9
9
|
import * as i5 from "@angular/common";
|
|
10
|
+
import * as i6 from "@ngx-translate/core";
|
|
10
11
|
export class MessageListComponent {
|
|
11
12
|
constructor(channelService, chatClientService, imageLoadService) {
|
|
12
13
|
this.channelService = channelService;
|
|
13
14
|
this.chatClientService = chatClientService;
|
|
14
15
|
this.imageLoadService = imageLoadService;
|
|
15
|
-
|
|
16
|
+
/**
|
|
17
|
+
* @deprecated https://getstream.io/chat/docs/sdk/angular/components/message_list/#caution-arereactionsenabled-deprecated
|
|
18
|
+
*/
|
|
19
|
+
this.areReactionsEnabled = undefined;
|
|
20
|
+
/**
|
|
21
|
+
* @deprecated https://getstream.io/chat/docs/sdk/angular/components/message_list/#caution-enabledmessageactions-deprecated
|
|
22
|
+
*/
|
|
16
23
|
/* eslint-disable-next-line @angular-eslint/no-input-rename */
|
|
17
|
-
this.enabledMessageActionsInput =
|
|
24
|
+
this.enabledMessageActionsInput = undefined;
|
|
25
|
+
this.mode = 'main';
|
|
18
26
|
this.enabledMessageActions = [];
|
|
19
27
|
this.class = 'str-chat-angular__main-panel-inner str-chat-angular__message-list-host';
|
|
20
28
|
this.unreadMessageCount = 0;
|
|
21
29
|
this.groupStyles = [];
|
|
22
30
|
this.authorizedMessageActions = ['flag'];
|
|
23
31
|
this.isUserScrolledUpThreshold = 300;
|
|
24
|
-
this.
|
|
32
|
+
this.subscriptions = [];
|
|
33
|
+
this.subscriptions.push(this.channelService.activeChannel$.subscribe((channel) => {
|
|
25
34
|
var _a;
|
|
26
|
-
this.
|
|
27
|
-
this.hasNewMessages = true;
|
|
28
|
-
this.isUserScrolledUp = false;
|
|
29
|
-
this.containerHeight = undefined;
|
|
30
|
-
this.olderMassagesLoaded = false;
|
|
31
|
-
this.oldestMessageDate = undefined;
|
|
32
|
-
this.unreadMessageCount = 0;
|
|
33
|
-
this.isNewMessageSentByUser = undefined;
|
|
35
|
+
this.resetScrollState();
|
|
34
36
|
const capabilites = (_a = channel === null || channel === void 0 ? void 0 : channel.data) === null || _a === void 0 ? void 0 : _a.own_capabilities;
|
|
35
37
|
if (capabilites) {
|
|
36
38
|
this.canReactToMessage = capabilites.indexOf('send-reaction') !== -1;
|
|
37
39
|
this.canReceiveReadEvents = capabilites.indexOf('read-events') !== -1;
|
|
38
40
|
this.authorizedMessageActions = [];
|
|
41
|
+
if (this.canReactToMessage) {
|
|
42
|
+
this.authorizedMessageActions.push('send-reaction');
|
|
43
|
+
}
|
|
44
|
+
if (this.canReceiveReadEvents) {
|
|
45
|
+
this.authorizedMessageActions.push('read-events');
|
|
46
|
+
}
|
|
39
47
|
if (capabilites.indexOf('flag-message') !== -1) {
|
|
40
48
|
this.authorizedMessageActions.push('flag');
|
|
41
49
|
}
|
|
@@ -53,47 +61,16 @@ export class MessageListComponent {
|
|
|
53
61
|
this.authorizedMessageActions.push('delete');
|
|
54
62
|
this.authorizedMessageActions.push('delete-any');
|
|
55
63
|
}
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
});
|
|
59
|
-
this.messages$ = this.channelService.activeChannelMessages$.pipe(tap((messages) => {
|
|
60
|
-
var _a, _b, _c, _d, _e;
|
|
61
|
-
if (messages.length === 0) {
|
|
62
|
-
return;
|
|
63
|
-
}
|
|
64
|
-
const currentLatestMessageDate = messages[messages.length - 1].created_at;
|
|
65
|
-
if (!this.latestMessageDate ||
|
|
66
|
-
((_a = this.latestMessageDate) === null || _a === void 0 ? void 0 : _a.getTime()) < currentLatestMessageDate.getTime()) {
|
|
67
|
-
this.latestMessageDate = currentLatestMessageDate;
|
|
68
|
-
this.hasNewMessages = true;
|
|
69
|
-
this.isNewMessageSentByUser =
|
|
70
|
-
((_b = messages[messages.length - 1].user) === null || _b === void 0 ? void 0 : _b.id) ===
|
|
71
|
-
((_d = (_c = this.chatClientService.chatClient) === null || _c === void 0 ? void 0 : _c.user) === null || _d === void 0 ? void 0 : _d.id);
|
|
72
|
-
if (this.isUserScrolledUp) {
|
|
73
|
-
this.unreadMessageCount++;
|
|
64
|
+
if (capabilites.indexOf('send-reply') !== -1) {
|
|
65
|
+
this.authorizedMessageActions.push('send-reply');
|
|
74
66
|
}
|
|
67
|
+
if (capabilites.indexOf('quote-message') !== -1) {
|
|
68
|
+
this.authorizedMessageActions.push('quote-message');
|
|
69
|
+
}
|
|
70
|
+
this.setEnabledActions();
|
|
75
71
|
}
|
|
76
|
-
const currentOldestMessageDate = messages[0].created_at;
|
|
77
|
-
if (!this.oldestMessageDate) {
|
|
78
|
-
this.oldestMessageDate = currentOldestMessageDate;
|
|
79
|
-
}
|
|
80
|
-
else if (((_e = this.oldestMessageDate) === null || _e === void 0 ? void 0 : _e.getTime()) > currentOldestMessageDate.getTime()) {
|
|
81
|
-
this.oldestMessageDate = currentOldestMessageDate;
|
|
82
|
-
this.olderMassagesLoaded = true;
|
|
83
|
-
}
|
|
84
|
-
}), tap((messages) => {
|
|
85
|
-
this.groupStyles = messages.map((m, i) => getGroupStyles(m, messages[i - 1], messages[i + 1]));
|
|
86
|
-
}), tap((messages) => {
|
|
87
|
-
var _a;
|
|
88
|
-
return (this.lastSentMessageId = (_a = [...messages]
|
|
89
|
-
.reverse()
|
|
90
|
-
.find((m) => {
|
|
91
|
-
var _a, _b, _c;
|
|
92
|
-
return ((_a = m.user) === null || _a === void 0 ? void 0 : _a.id) === ((_c = (_b = this.chatClientService.chatClient) === null || _b === void 0 ? void 0 : _b.user) === null || _c === void 0 ? void 0 : _c.id) &&
|
|
93
|
-
m.status !== 'sending';
|
|
94
|
-
})) === null || _a === void 0 ? void 0 : _a.id);
|
|
95
72
|
}));
|
|
96
|
-
this.imageLoadService.imageLoad$.subscribe(() => {
|
|
73
|
+
this.subscriptions.push(this.imageLoadService.imageLoad$.subscribe(() => {
|
|
97
74
|
if (!this.isUserScrolledUp) {
|
|
98
75
|
this.scrollToBottom();
|
|
99
76
|
// Hacky and unreliable workaround to scroll down after loaded images move the scrollbar
|
|
@@ -101,12 +78,27 @@ export class MessageListComponent {
|
|
|
101
78
|
this.scrollToBottom();
|
|
102
79
|
}, 300);
|
|
103
80
|
}
|
|
104
|
-
});
|
|
81
|
+
}));
|
|
82
|
+
this.subscriptions.push(this.channelService.activeParentMessage$.subscribe((message) => {
|
|
83
|
+
if (message &&
|
|
84
|
+
this.parentMessage &&
|
|
85
|
+
message.id !== this.parentMessage.id &&
|
|
86
|
+
this.mode === 'thread') {
|
|
87
|
+
this.resetScrollState();
|
|
88
|
+
}
|
|
89
|
+
this.parentMessage = message;
|
|
90
|
+
}));
|
|
91
|
+
}
|
|
92
|
+
ngOnInit() {
|
|
93
|
+
this.setMessages$();
|
|
105
94
|
}
|
|
106
95
|
ngOnChanges(changes) {
|
|
107
96
|
if (changes.enabledMessageActionsInput) {
|
|
108
97
|
this.setEnabledActions();
|
|
109
98
|
}
|
|
99
|
+
if (changes.mode) {
|
|
100
|
+
this.setMessages$();
|
|
101
|
+
}
|
|
110
102
|
}
|
|
111
103
|
ngAfterViewChecked() {
|
|
112
104
|
if (this.hasNewMessages) {
|
|
@@ -132,6 +124,9 @@ export class MessageListComponent {
|
|
|
132
124
|
this.containerHeight = this.scrollContainer.nativeElement.scrollHeight;
|
|
133
125
|
}
|
|
134
126
|
}
|
|
127
|
+
ngOnDestroy() {
|
|
128
|
+
this.subscriptions.forEach((s) => s.unsubscribe());
|
|
129
|
+
}
|
|
135
130
|
trackByMessageId(index, item) {
|
|
136
131
|
return item.id;
|
|
137
132
|
}
|
|
@@ -140,6 +135,7 @@ export class MessageListComponent {
|
|
|
140
135
|
this.scrollContainer.nativeElement.scrollHeight;
|
|
141
136
|
}
|
|
142
137
|
scrolled() {
|
|
138
|
+
var _a, _b;
|
|
143
139
|
this.isUserScrolledUp =
|
|
144
140
|
this.scrollContainer.nativeElement.scrollHeight -
|
|
145
141
|
(this.scrollContainer.nativeElement.scrollTop +
|
|
@@ -148,20 +144,36 @@ export class MessageListComponent {
|
|
|
148
144
|
if (!this.isUserScrolledUp) {
|
|
149
145
|
this.unreadMessageCount = 0;
|
|
150
146
|
}
|
|
151
|
-
if (this.scrollContainer.nativeElement.scrollTop
|
|
147
|
+
if (this.scrollContainer.nativeElement.scrollTop <=
|
|
148
|
+
(((_a = this.parentMessageElement) === null || _a === void 0 ? void 0 : _a.nativeElement.clientHeight) || 0) &&
|
|
149
|
+
(this.prevScrollTop === undefined ||
|
|
150
|
+
this.prevScrollTop >
|
|
151
|
+
(((_b = this.parentMessageElement) === null || _b === void 0 ? void 0 : _b.nativeElement.clientHeight) || 0))) {
|
|
152
152
|
this.containerHeight = this.scrollContainer.nativeElement.scrollHeight;
|
|
153
|
-
|
|
153
|
+
this.mode === 'main'
|
|
154
|
+
? void this.channelService.loadMoreMessages()
|
|
155
|
+
: void this.channelService.loadMoreThreadReplies();
|
|
154
156
|
}
|
|
157
|
+
this.prevScrollTop = this.scrollContainer.nativeElement.scrollTop;
|
|
155
158
|
}
|
|
156
159
|
preserveScrollbarPosition() {
|
|
157
160
|
this.scrollContainer.nativeElement.scrollTop =
|
|
158
|
-
this.
|
|
161
|
+
(this.prevScrollTop || 0) +
|
|
162
|
+
(this.scrollContainer.nativeElement.scrollHeight - this.containerHeight);
|
|
159
163
|
}
|
|
160
164
|
setEnabledActions() {
|
|
161
165
|
this.enabledMessageActions = [];
|
|
162
166
|
if (!this.enabledMessageActionsInput) {
|
|
167
|
+
this.enabledMessageActions = this.authorizedMessageActions;
|
|
163
168
|
return;
|
|
164
169
|
}
|
|
170
|
+
this.enabledMessageActionsInput = [
|
|
171
|
+
...this.enabledMessageActionsInput,
|
|
172
|
+
'send-reaction',
|
|
173
|
+
'read-events',
|
|
174
|
+
'send-reply',
|
|
175
|
+
'quote-message',
|
|
176
|
+
];
|
|
165
177
|
this.enabledMessageActionsInput.forEach((action) => {
|
|
166
178
|
const isAuthorized = this.authorizedMessageActions.indexOf(action) !== -1;
|
|
167
179
|
if (isAuthorized) {
|
|
@@ -169,9 +181,61 @@ export class MessageListComponent {
|
|
|
169
181
|
}
|
|
170
182
|
});
|
|
171
183
|
}
|
|
184
|
+
setMessages$() {
|
|
185
|
+
this.messages$ = (this.mode === 'main'
|
|
186
|
+
? this.channelService.activeChannelMessages$
|
|
187
|
+
: this.channelService.activeThreadMessages$).pipe(tap((messages) => {
|
|
188
|
+
var _a, _b, _c, _d, _e;
|
|
189
|
+
if (messages.length === 0) {
|
|
190
|
+
return;
|
|
191
|
+
}
|
|
192
|
+
const currentLatestMessageDate = messages[messages.length - 1].created_at;
|
|
193
|
+
if (!this.latestMessageDate ||
|
|
194
|
+
((_a = this.latestMessageDate) === null || _a === void 0 ? void 0 : _a.getTime()) < currentLatestMessageDate.getTime()) {
|
|
195
|
+
this.latestMessageDate = currentLatestMessageDate;
|
|
196
|
+
this.hasNewMessages = true;
|
|
197
|
+
this.isNewMessageSentByUser =
|
|
198
|
+
((_b = messages[messages.length - 1].user) === null || _b === void 0 ? void 0 : _b.id) ===
|
|
199
|
+
((_d = (_c = this.chatClientService.chatClient) === null || _c === void 0 ? void 0 : _c.user) === null || _d === void 0 ? void 0 : _d.id);
|
|
200
|
+
if (this.isUserScrolledUp) {
|
|
201
|
+
this.unreadMessageCount++;
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
const currentOldestMessageDate = messages[0].created_at;
|
|
205
|
+
if (!this.oldestMessageDate) {
|
|
206
|
+
this.oldestMessageDate = currentOldestMessageDate;
|
|
207
|
+
}
|
|
208
|
+
else if (((_e = this.oldestMessageDate) === null || _e === void 0 ? void 0 : _e.getTime()) > currentOldestMessageDate.getTime()) {
|
|
209
|
+
this.oldestMessageDate = currentOldestMessageDate;
|
|
210
|
+
this.olderMassagesLoaded = true;
|
|
211
|
+
}
|
|
212
|
+
}), tap((messages) => {
|
|
213
|
+
this.groupStyles = messages.map((m, i) => getGroupStyles(m, messages[i - 1], messages[i + 1]));
|
|
214
|
+
}), tap((messages) => {
|
|
215
|
+
var _a;
|
|
216
|
+
return (this.lastSentMessageId = (_a = [...messages]
|
|
217
|
+
.reverse()
|
|
218
|
+
.find((m) => {
|
|
219
|
+
var _a, _b, _c;
|
|
220
|
+
return ((_a = m.user) === null || _a === void 0 ? void 0 : _a.id) === ((_c = (_b = this.chatClientService.chatClient) === null || _b === void 0 ? void 0 : _b.user) === null || _c === void 0 ? void 0 : _c.id) &&
|
|
221
|
+
m.status !== 'sending';
|
|
222
|
+
})) === null || _a === void 0 ? void 0 : _a.id);
|
|
223
|
+
}));
|
|
224
|
+
}
|
|
225
|
+
resetScrollState() {
|
|
226
|
+
this.latestMessageDate = undefined;
|
|
227
|
+
this.hasNewMessages = true;
|
|
228
|
+
this.isUserScrolledUp = false;
|
|
229
|
+
this.containerHeight = undefined;
|
|
230
|
+
this.olderMassagesLoaded = false;
|
|
231
|
+
this.oldestMessageDate = undefined;
|
|
232
|
+
this.unreadMessageCount = 0;
|
|
233
|
+
this.prevScrollTop = undefined;
|
|
234
|
+
this.isNewMessageSentByUser = undefined;
|
|
235
|
+
}
|
|
172
236
|
}
|
|
173
237
|
MessageListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: MessageListComponent, deps: [{ token: i1.ChannelService }, { token: i2.ChatClientService }, { token: i3.ImageLoadService }], target: i0.ɵɵFactoryTarget.Component });
|
|
174
|
-
MessageListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.5", type: MessageListComponent, selector: "stream-message-list", inputs: { messageTemplate: "messageTemplate", messageInputTemplate: "messageInputTemplate", mentionTemplate: "mentionTemplate", areReactionsEnabled: "areReactionsEnabled", enabledMessageActionsInput: ["enabledMessageActions", "enabledMessageActionsInput"] }, host: { properties: { "class": "this.class" } }, viewQueries: [{ propertyName: "scrollContainer", first: true, predicate: ["scrollContainer"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div\n #scrollContainer\n data-testid=\"scroll-container\"\n class=\"str-chat__list\"\n (scroll)=\"scrolled()\"\n>\n <div class=\"str-chat__reverse-infinite-scroll\">\n <ul class=\"str-chat__ul\">\n <li\n data-testclass=\"message\"\n *ngFor=\"\n let message of messages$ | async;\n let i = index;\n trackBy: trackByMessageId\n \"\n class=\"str-chat__li str-chat__li--{{ groupStyles[i] }}\"\n >\n <ng-container
|
|
238
|
+
MessageListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.5", type: MessageListComponent, selector: "stream-message-list", inputs: { messageTemplate: "messageTemplate", messageInputTemplate: "messageInputTemplate", mentionTemplate: "mentionTemplate", areReactionsEnabled: "areReactionsEnabled", enabledMessageActionsInput: ["enabledMessageActions", "enabledMessageActionsInput"], mode: "mode" }, host: { properties: { "class": "this.class" } }, viewQueries: [{ propertyName: "scrollContainer", first: true, predicate: ["scrollContainer"], descendants: true }, { propertyName: "parentMessageElement", first: true, predicate: ["parentMessageElement"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div\n #scrollContainer\n data-testid=\"scroll-container\"\n class=\"str-chat__list\"\n (scroll)=\"scrolled()\"\n>\n <div class=\"str-chat__reverse-infinite-scroll\">\n <ul class=\"str-chat__ul\">\n <li\n #parentMessageElement\n *ngIf=\"mode === 'thread'\"\n data-testid=\"parent-message\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n messageTemplateContainer;\n context: { message: parentMessage }\n \"\n ></ng-container>\n <div class=\"str-chat__thread-start\" translate>\n streamChat.Start of a new thread\n </div>\n </li>\n <li\n data-testclass=\"message\"\n *ngFor=\"\n let message of messages$ | async;\n let i = index;\n trackBy: trackByMessageId\n \"\n class=\"str-chat__li str-chat__li--{{ groupStyles[i] }}\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n messageTemplateContainer;\n context: { message: message }\n \"\n ></ng-container>\n </li>\n </ul>\n </div>\n</div>\n<div class=\"str-chat__list-notifications\">\n <button\n data-testid=\"scroll-to-bottom\"\n *ngIf=\"isUserScrolledUp\"\n class=\"\n str-chat__message-notification\n str-chat__message-notification-right\n str-chat__message-notification-scroll-down\n \"\n (keyup.enter)=\"scrollToBottom()\"\n (click)=\"scrollToBottom()\"\n >\n <div\n *ngIf=\"unreadMessageCount > 0\"\n class=\"\n str-chat__message-notification\n str-chat__message-notification-scroll-down-unread-count\n \"\n >\n {{ unreadMessageCount }}\n </div>\n </button>\n</div>\n\n<ng-template #messageTemplateContainer let-message=\"message\">\n <ng-container *ngIf=\"messageTemplate; else defaultMessageTemplate\">\n <ng-container\n *ngTemplateOutlet=\"\n messageTemplate;\n context: {\n message: message,\n areReactionsEnabled: areReactionsEnabled,\n canReactToMessage: canReactToMessage,\n lastSentMessageId: !!(\n lastSentMessageId && message?.id === lastSentMessageId\n ),\n canReceiveReadEvents: canReceiveReadEvents,\n messageInputTemplate: messageInputTemplate,\n mentionTemplate: mentionTemplate,\n mode: mode\n }\n \"\n ></ng-container>\n </ng-container>\n <ng-template #defaultMessageTemplate>\n <stream-message\n [message]=\"message\"\n [areReactionsEnabled]=\"areReactionsEnabled\"\n [canReactToMessage]=\"canReactToMessage\"\n [isLastSentMessage]=\"\n !!(lastSentMessageId && message?.id === lastSentMessageId)\n \"\n [enabledMessageActions]=\"enabledMessageActions\"\n [canReceiveReadEvents]=\"canReceiveReadEvents\"\n [messageInputTemplate]=\"messageInputTemplate\"\n [mentionTemplate]=\"mentionTemplate\"\n [mode]=\"mode\"\n ></stream-message>\n </ng-template>\n</ng-template>\n", components: [{ type: i4.MessageComponent, selector: "stream-message", inputs: ["messageInputTemplate", "mentionTemplate", "message", "enabledMessageActions", "areReactionsEnabled", "canReactToMessage", "isLastSentMessage", "canReceiveReadEvents", "mode"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i6.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i5.AsyncPipe } });
|
|
175
239
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: MessageListComponent, decorators: [{
|
|
176
240
|
type: Component,
|
|
177
241
|
args: [{
|
|
@@ -190,11 +254,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
|
|
|
190
254
|
}], enabledMessageActionsInput: [{
|
|
191
255
|
type: Input,
|
|
192
256
|
args: ['enabledMessageActions']
|
|
257
|
+
}], mode: [{
|
|
258
|
+
type: Input
|
|
193
259
|
}], class: [{
|
|
194
260
|
type: HostBinding,
|
|
195
261
|
args: ['class']
|
|
196
262
|
}], scrollContainer: [{
|
|
197
263
|
type: ViewChild,
|
|
198
264
|
args: ['scrollContainer']
|
|
265
|
+
}], parentMessageElement: [{
|
|
266
|
+
type: ViewChild,
|
|
267
|
+
args: ['parentMessageElement']
|
|
199
268
|
}] } });
|
|
200
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"message-list.component.js","sourceRoot":"","sources":["../../../../../projects/stream-chat-angular/src/lib/message-list/message-list.component.ts","../../../../../projects/stream-chat-angular/src/lib/message-list/message-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewChecked,\n  Component,\n  ElementRef,\n  HostBinding,\n  Input,\n  OnChanges,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { ChannelService } from '../channel.service';\nimport { Observable } from 'rxjs';\nimport { tap } from 'rxjs/operators';\nimport { StreamMessage } from '../types';\nimport { ChatClientService } from '../chat-client.service';\nimport { getGroupStyles, GroupStyle } from './group-styles';\nimport { ImageLoadService } from './image-load.service';\nimport { MessageActions } from '../message-actions-box/message-actions-box.component';\n@Component({\n  selector: 'stream-message-list',\n  templateUrl: './message-list.component.html',\n  styles: [],\n})\nexport class MessageListComponent implements AfterViewChecked, OnChanges {\n  @Input() messageTemplate: TemplateRef<any> | undefined;\n  @Input() messageInputTemplate: TemplateRef<any> | undefined;\n  @Input() mentionTemplate: TemplateRef<any> | undefined;\n  @Input() areReactionsEnabled = true;\n  /* eslint-disable-next-line @angular-eslint/no-input-rename */\n  @Input('enabledMessageActions') enabledMessageActionsInput: MessageActions[] =\n    ['flag', 'edit', 'edit-any', 'delete', 'delete-any'];\n  messages$!: Observable<StreamMessage[]>;\n  canReactToMessage: boolean | undefined;\n  canReceiveReadEvents: boolean | undefined;\n  enabledMessageActions: MessageActions[] = [];\n  @HostBinding('class') private class =\n    'str-chat-angular__main-panel-inner str-chat-angular__message-list-host';\n  unreadMessageCount = 0;\n  isUserScrolledUp: boolean | undefined;\n  groupStyles: GroupStyle[] = [];\n  lastSentMessageId: string | undefined;\n  @ViewChild('scrollContainer')\n  private scrollContainer!: ElementRef<HTMLElement>;\n  private latestMessageDate: Date | undefined;\n  private hasNewMessages: boolean | undefined;\n  private containerHeight: number | undefined;\n  private oldestMessageDate: Date | undefined;\n  private olderMassagesLoaded: boolean | undefined;\n  private isNewMessageSentByUser: boolean | undefined;\n  private authorizedMessageActions: MessageActions[] = ['flag'];\n  private readonly isUserScrolledUpThreshold = 300;\n\n  constructor(\n    private channelService: ChannelService,\n    private chatClientService: ChatClientService,\n    private imageLoadService: ImageLoadService\n  ) {\n    this.channelService.activeChannel$.subscribe((channel) => {\n      this.latestMessageDate = undefined;\n      this.hasNewMessages = true;\n      this.isUserScrolledUp = false;\n      this.containerHeight = undefined;\n      this.olderMassagesLoaded = false;\n      this.oldestMessageDate = undefined;\n      this.unreadMessageCount = 0;\n      this.isNewMessageSentByUser = undefined;\n      const capabilites = channel?.data?.own_capabilities as string[];\n      if (capabilites) {\n        this.canReactToMessage = capabilites.indexOf('send-reaction') !== -1;\n        this.canReceiveReadEvents = capabilites.indexOf('read-events') !== -1;\n        this.authorizedMessageActions = [];\n        if (capabilites.indexOf('flag-message') !== -1) {\n          this.authorizedMessageActions.push('flag');\n        }\n        if (capabilites.indexOf('update-own-message') !== -1) {\n          this.authorizedMessageActions.push('edit');\n        }\n        if (capabilites.indexOf('update-any-message') !== -1) {\n          this.authorizedMessageActions.push('edit');\n          this.authorizedMessageActions.push('edit-any');\n        }\n        if (capabilites.indexOf('delete-own-message') !== -1) {\n          this.authorizedMessageActions.push('delete');\n        }\n        if (capabilites.indexOf('delete-any-message') !== -1) {\n          this.authorizedMessageActions.push('delete');\n          this.authorizedMessageActions.push('delete-any');\n        }\n        this.setEnabledActions();\n      }\n    });\n    this.messages$ = this.channelService.activeChannelMessages$.pipe(\n      tap((messages) => {\n        if (messages.length === 0) {\n          return;\n        }\n        const currentLatestMessageDate =\n          messages[messages.length - 1].created_at;\n        if (\n          !this.latestMessageDate ||\n          this.latestMessageDate?.getTime() < currentLatestMessageDate.getTime()\n        ) {\n          this.latestMessageDate = currentLatestMessageDate;\n          this.hasNewMessages = true;\n          this.isNewMessageSentByUser =\n            messages[messages.length - 1].user?.id ===\n            this.chatClientService.chatClient?.user?.id;\n          if (this.isUserScrolledUp) {\n            this.unreadMessageCount++;\n          }\n        }\n        const currentOldestMessageDate = messages[0].created_at;\n        if (!this.oldestMessageDate) {\n          this.oldestMessageDate = currentOldestMessageDate;\n        } else if (\n          this.oldestMessageDate?.getTime() > currentOldestMessageDate.getTime()\n        ) {\n          this.oldestMessageDate = currentOldestMessageDate;\n          this.olderMassagesLoaded = true;\n        }\n      }),\n      tap((messages) => {\n        this.groupStyles = messages.map((m, i) =>\n          getGroupStyles(m, messages[i - 1], messages[i + 1])\n        );\n      }),\n      tap(\n        (messages) =>\n          (this.lastSentMessageId = [...messages]\n            .reverse()\n            .find(\n              (m) =>\n                m.user?.id === this.chatClientService.chatClient?.user?.id &&\n                m.status !== 'sending'\n            )?.id)\n      )\n    );\n    this.imageLoadService.imageLoad$.subscribe(() => {\n      if (!this.isUserScrolledUp) {\n        this.scrollToBottom();\n        // Hacky and unreliable workaround to scroll down after loaded images move the scrollbar\n        setTimeout(() => {\n          this.scrollToBottom();\n        }, 300);\n      }\n    });\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.enabledMessageActionsInput) {\n      this.setEnabledActions();\n    }\n  }\n\n  ngAfterViewChecked() {\n    if (this.hasNewMessages) {\n      if (!this.isUserScrolledUp || this.isNewMessageSentByUser) {\n        this.scrollToBottom();\n        // Hacky and unreliable workaround to scroll down after loaded images move the scrollbar\n        setTimeout(() => {\n          this.scrollToBottom();\n        }, 300);\n      }\n      this.hasNewMessages = false;\n      this.containerHeight = this.scrollContainer.nativeElement.scrollHeight;\n    } else if (this.olderMassagesLoaded) {\n      this.preserveScrollbarPosition();\n      this.containerHeight = this.scrollContainer.nativeElement.scrollHeight;\n      this.olderMassagesLoaded = false;\n    } else if (\n      this.containerHeight !== undefined &&\n      this.containerHeight < this.scrollContainer.nativeElement.scrollHeight &&\n      !this.isUserScrolledUp\n    ) {\n      this.scrollToBottom();\n      this.containerHeight = this.scrollContainer.nativeElement.scrollHeight;\n    }\n  }\n\n  trackByMessageId(index: number, item: StreamMessage) {\n    return item.id;\n  }\n\n  scrollToBottom(): void {\n    this.scrollContainer.nativeElement.scrollTop =\n      this.scrollContainer.nativeElement.scrollHeight;\n  }\n\n  scrolled() {\n    this.isUserScrolledUp =\n      this.scrollContainer.nativeElement.scrollHeight -\n        (this.scrollContainer.nativeElement.scrollTop +\n          this.scrollContainer.nativeElement.clientHeight) >\n      this.isUserScrolledUpThreshold;\n    if (!this.isUserScrolledUp) {\n      this.unreadMessageCount = 0;\n    }\n    if (this.scrollContainer.nativeElement.scrollTop === 0) {\n      this.containerHeight = this.scrollContainer.nativeElement.scrollHeight;\n      void this.channelService.loadMoreMessages();\n    }\n  }\n\n  private preserveScrollbarPosition() {\n    this.scrollContainer.nativeElement.scrollTop =\n      this.scrollContainer.nativeElement.scrollHeight - this.containerHeight!;\n  }\n\n  private setEnabledActions() {\n    this.enabledMessageActions = [];\n    if (!this.enabledMessageActionsInput) {\n      return;\n    }\n    this.enabledMessageActionsInput.forEach((action) => {\n      const isAuthorized = this.authorizedMessageActions.indexOf(action) !== -1;\n      if (isAuthorized) {\n        this.enabledMessageActions.push(action);\n      }\n    });\n  }\n}\n","<div\n  #scrollContainer\n  data-testid=\"scroll-container\"\n  class=\"str-chat__list\"\n  (scroll)=\"scrolled()\"\n>\n  <div class=\"str-chat__reverse-infinite-scroll\">\n    <ul class=\"str-chat__ul\">\n      <li\n        data-testclass=\"message\"\n        *ngFor=\"\n          let message of messages$ | async;\n          let i = index;\n          trackBy: trackByMessageId\n        \"\n        class=\"str-chat__li str-chat__li--{{ groupStyles[i] }}\"\n      >\n        <ng-container *ngIf=\"messageTemplate; else defaultMessageTemplate\">\n          <ng-container\n            *ngTemplateOutlet=\"\n              messageTemplate;\n              context: {\n                message: message,\n                areReactionsEnabled: areReactionsEnabled,\n                canReactToMessage: canReactToMessage,\n                lastSentMessageId: !!(\n                  lastSentMessageId && message?.id === lastSentMessageId\n                ),\n                canReceiveReadEvents: canReceiveReadEvents,\n                messageInputTemplate: messageInputTemplate,\n                mentionTemplate: mentionTemplate\n              }\n            \"\n          ></ng-container>\n        </ng-container>\n        <ng-template #defaultMessageTemplate>\n          <stream-message\n            [message]=\"message\"\n            [areReactionsEnabled]=\"areReactionsEnabled\"\n            [canReactToMessage]=\"canReactToMessage\"\n            [isLastSentMessage]=\"\n              !!(lastSentMessageId && message?.id === lastSentMessageId)\n            \"\n            [enabledMessageActions]=\"enabledMessageActions\"\n            [canReceiveReadEvents]=\"canReceiveReadEvents\"\n            [messageInputTemplate]=\"messageInputTemplate\"\n            [mentionTemplate]=\"mentionTemplate\"\n          ></stream-message>\n        </ng-template>\n      </li>\n    </ul>\n  </div>\n</div>\n<div class=\"str-chat__list-notifications\">\n  <button\n    data-testid=\"scroll-to-bottom\"\n    *ngIf=\"isUserScrolledUp\"\n    class=\"\n      str-chat__message-notification\n      str-chat__message-notification-right\n      str-chat__message-notification-scroll-down\n    \"\n    (keyup.enter)=\"scrollToBottom()\"\n    (click)=\"scrollToBottom()\"\n  >\n    <div\n      *ngIf=\"unreadMessageCount > 0\"\n      class=\"\n        str-chat__message-notification\n        str-chat__message-notification-scroll-down-unread-count\n      \"\n    >\n      {{ unreadMessageCount }}\n    </div>\n  </button>\n</div>\n"]}
|
|
269
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"message-list.component.js","sourceRoot":"","sources":["../../../../../projects/stream-chat-angular/src/lib/message-list/message-list.component.ts","../../../../../projects/stream-chat-angular/src/lib/message-list/message-list.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,WAAW,EACX,KAAK,EAML,SAAS,GACV,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAGrC,OAAO,EAAE,cAAc,EAAc,MAAM,gBAAgB,CAAC;;;;;;;;AAQ5D,MAAM,OAAO,oBAAoB;IA4C/B,YACU,cAA8B,EAC9B,iBAAoC,EACpC,gBAAkC;QAFlC,mBAAc,GAAd,cAAc,CAAgB;QAC9B,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAzC5C;;WAEG;QACM,wBAAmB,GAAwB,SAAS,CAAC;QAC9D;;WAEG;QACH,8DAA8D;QAC9B,+BAA0B,GAE1C,SAAS,CAAC;QACjB,SAAI,GAAsB,MAAM,CAAC;QAI1C,0BAAqB,GAAa,EAAE,CAAC;QACP,UAAK,GACjC,wEAAwE,CAAC;QAC3E,uBAAkB,GAAG,CAAC,CAAC;QAEvB,gBAAW,GAAiB,EAAE,CAAC;QAavB,6BAAwB,GAAa,CAAC,MAAM,CAAC,CAAC;QACrC,8BAAyB,GAAG,GAAG,CAAC;QACzC,kBAAa,GAAmB,EAAE,CAAC;QAQzC,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE;;YACvD,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,MAAM,WAAW,GAAG,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,IAAI,0CAAE,gBAA4B,CAAC;YAChE,IAAI,WAAW,EAAE;gBACf,IAAI,CAAC,iBAAiB,GAAG,WAAW,CAAC,OAAO,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC;gBACrE,IAAI,CAAC,oBAAoB,GAAG,WAAW,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC;gBACtE,IAAI,CAAC,wBAAwB,GAAG,EAAE,CAAC;gBACnC,IAAI,IAAI,CAAC,iBAAiB,EAAE;oBAC1B,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;iBACrD;gBACD,IAAI,IAAI,CAAC,oBAAoB,EAAE;oBAC7B,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;iBACnD;gBACD,IAAI,WAAW,CAAC,OAAO,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,EAAE;oBAC9C,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;iBAC5C;gBACD,IAAI,WAAW,CAAC,OAAO,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC,EAAE;oBACpD,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;iBAC5C;gBACD,IAAI,WAAW,CAAC,OAAO,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC,EAAE;oBACpD,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBAC3C,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;iBAChD;gBACD,IAAI,WAAW,CAAC,OAAO,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC,EAAE;oBACpD,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;iBAC9C;gBACD,IAAI,WAAW,CAAC,OAAO,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC,EAAE;oBACpD,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;oBAC7C,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;iBAClD;gBACD,IAAI,WAAW,CAAC,OAAO,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE;oBAC5C,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;iBAClD;gBACD,IAAI,WAAW,CAAC,OAAO,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,EAAE;oBAC/C,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;iBACrD;gBACD,IAAI,CAAC,iBAAiB,EAAE,CAAC;aAC1B;QACH,CAAC,CAAC,CACH,CAAC;QACF,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAC,SAAS,CAAC,GAAG,EAAE;YAC9C,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;gBAC1B,IAAI,CAAC,cAAc,EAAE,CAAC;gBACtB,wFAAwF;gBACxF,UAAU,CAAC,GAAG,EAAE;oBACd,IAAI,CAAC,cAAc,EAAE,CAAC;gBACxB,CAAC,EAAE,GAAG,CAAC,CAAC;aACT;QACH,CAAC,CAAC,CACH,CAAC;QACF,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,cAAc,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE;YAC7D,IACE,OAAO;gBACP,IAAI,CAAC,aAAa;gBAClB,OAAO,CAAC,EAAE,KAAK,IAAI,CAAC,aAAa,CAAC,EAAE;gBACpC,IAAI,CAAC,IAAI,KAAK,QAAQ,EACtB;gBACA,IAAI,CAAC,gBAAgB,EAAE,CAAC;aACzB;YACD,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC;QAC/B,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,0BAA0B,EAAE;YACtC,IAAI,CAAC,iBAAiB,EAAE,CAAC;SAC1B;QACD,IAAI,OAAO,CAAC,IAAI,EAAE;YAChB,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;IACH,CAAC;IAED,kBAAkB;QAChB,IAAI,IAAI,CAAC,cAAc,EAAE;YACvB,IAAI,CAAC,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,sBAAsB,EAAE;gBACzD,IAAI,CAAC,cAAc,EAAE,CAAC;gBACtB,wFAAwF;gBACxF,UAAU,CAAC,GAAG,EAAE;oBACd,IAAI,CAAC,cAAc,EAAE,CAAC;gBACxB,CAAC,EAAE,GAAG,CAAC,CAAC;aACT;YACD,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;YAC5B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,YAAY,CAAC;SACxE;aAAM,IAAI,IAAI,CAAC,mBAAmB,EAAE;YACnC,IAAI,CAAC,yBAAyB,EAAE,CAAC;YACjC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,YAAY,CAAC;YACvE,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;SAClC;aAAM,IACL,IAAI,CAAC,eAAe,KAAK,SAAS;YAClC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,YAAY;YACtE,CAAC,IAAI,CAAC,gBAAgB,EACtB;YACA,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,YAAY,CAAC;SACxE;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;IACrD,CAAC;IAED,gBAAgB,CAAC,KAAa,EAAE,IAAmB;QACjD,OAAO,IAAI,CAAC,EAAE,CAAC;IACjB,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,SAAS;YAC1C,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,YAAY,CAAC;IACpD,CAAC;IAED,QAAQ;;QACN,IAAI,CAAC,gBAAgB;YACnB,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,YAAY;gBAC7C,CAAC,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,SAAS;oBAC3C,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,YAAY,CAAC;gBACpD,IAAI,CAAC,yBAAyB,CAAC;QACjC,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;YAC1B,IAAI,CAAC,kBAAkB,GAAG,CAAC,CAAC;SAC7B;QACD,IACE,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,SAAS;YAC1C,CAAC,CAAA,MAAA,IAAI,CAAC,oBAAoB,0CAAE,aAAa,CAAC,YAAY,KAAI,CAAC,CAAC;YAC9D,CAAC,IAAI,CAAC,aAAa,KAAK,SAAS;gBAC/B,IAAI,CAAC,aAAa;oBAChB,CAAC,CAAA,MAAA,IAAI,CAAC,oBAAoB,0CAAE,aAAa,CAAC,YAAY,KAAI,CAAC,CAAC,CAAC,EACjE;YACA,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,YAAY,CAAC;YACvE,IAAI,CAAC,IAAI,KAAK,MAAM;gBAClB,CAAC,CAAC,KAAK,IAAI,CAAC,cAAc,CAAC,gBAAgB,EAAE;gBAC7C,CAAC,CAAC,KAAK,IAAI,CAAC,cAAc,CAAC,qBAAqB,EAAE,CAAC;SACtD;QACD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,SAAS,CAAC;IACpE,CAAC;IAEO,yBAAyB;QAC/B,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,SAAS;YAC1C,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,CAAC;gBACzB,CAAC,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,YAAY,GAAG,IAAI,CAAC,eAAgB,CAAC,CAAC;IAC9E,CAAC;IAEO,iBAAiB;QACvB,IAAI,CAAC,qBAAqB,GAAG,EAAE,CAAC;QAChC,IAAI,CAAC,IAAI,CAAC,0BAA0B,EAAE;YACpC,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,wBAAwB,CAAC;YAC3D,OAAO;SACR;QACD,IAAI,CAAC,0BAA0B,GAAG;YAChC,GAAG,IAAI,CAAC,0BAA0B;YAClC,eAAe;YACf,aAAa;YACb,YAAY;YACZ,eAAe;SAChB,CAAC;QACF,IAAI,CAAC,0BAA0B,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;YACjD,MAAM,YAAY,GAAG,IAAI,CAAC,wBAAwB,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;YAC1E,IAAI,YAAY,EAAE;gBAChB,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;aACzC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,YAAY;QAClB,IAAI,CAAC,SAAS,GAAG,CACf,IAAI,CAAC,IAAI,KAAK,MAAM;YAClB,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,sBAAsB;YAC5C,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,qBAAqB,CAC9C,CAAC,IAAI,CACJ,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE;;YACf,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;gBACzB,OAAO;aACR;YACD,MAAM,wBAAwB,GAC5B,QAAQ,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,UAAU,CAAC;YAC3C,IACE,CAAC,IAAI,CAAC,iBAAiB;gBACvB,CAAA,MAAA,IAAI,CAAC,iBAAiB,0CAAE,OAAO,EAAE,IAAG,wBAAwB,CAAC,OAAO,EAAE,EACtE;gBACA,IAAI,CAAC,iBAAiB,GAAG,wBAAwB,CAAC;gBAClD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;gBAC3B,IAAI,CAAC,sBAAsB;oBACzB,CAAA,MAAA,QAAQ,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,IAAI,0CAAE,EAAE;yBACtC,MAAA,MAAA,IAAI,CAAC,iBAAiB,CAAC,UAAU,0CAAE,IAAI,0CAAE,EAAE,CAAA,CAAC;gBAC9C,IAAI,IAAI,CAAC,gBAAgB,EAAE;oBACzB,IAAI,CAAC,kBAAkB,EAAE,CAAC;iBAC3B;aACF;YACD,MAAM,wBAAwB,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC;YACxD,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE;gBAC3B,IAAI,CAAC,iBAAiB,GAAG,wBAAwB,CAAC;aACnD;iBAAM,IACL,CAAA,MAAA,IAAI,CAAC,iBAAiB,0CAAE,OAAO,EAAE,IAAG,wBAAwB,CAAC,OAAO,EAAE,EACtE;gBACA,IAAI,CAAC,iBAAiB,GAAG,wBAAwB,CAAC;gBAClD,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;aACjC;QACH,CAAC,CAAC,EACF,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE;YACf,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CACvC,cAAc,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CACpD,CAAC;QACJ,CAAC,CAAC,EACF,GAAG,CACD,CAAC,QAAQ,EAAE,EAAE;;YACX,OAAA,CAAC,IAAI,CAAC,iBAAiB,GAAG,MAAA,CAAC,GAAG,QAAQ,CAAC;iBACpC,OAAO,EAAE;iBACT,IAAI,CACH,CAAC,CAAC,EAAE,EAAE;;gBACJ,OAAA,CAAA,MAAA,CAAC,CAAC,IAAI,0CAAE,EAAE,OAAK,MAAA,MAAA,IAAI,CAAC,iBAAiB,CAAC,UAAU,0CAAE,IAAI,0CAAE,EAAE,CAAA;oBAC1D,CAAC,CAAC,MAAM,KAAK,SAAS,CAAA;aAAA,CACzB,0CAAE,EAAE,CAAC,CAAA;SAAA,CACX,CACF,CAAC;IACJ,CAAC;IAEO,gBAAgB;QACtB,IAAI,CAAC,iBAAiB,GAAG,SAAS,CAAC;QACnC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;QAC9B,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC;QACjC,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;QACjC,IAAI,CAAC,iBAAiB,GAAG,SAAS,CAAC;QACnC,IAAI,CAAC,kBAAkB,GAAG,CAAC,CAAC;QAC5B,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC;QAC/B,IAAI,CAAC,sBAAsB,GAAG,SAAS,CAAC;IAC1C,CAAC;;iHAzRU,oBAAoB;qGAApB,oBAAoB,qnBC1BjC,i/FAsGA;2FD5Ea,oBAAoB;kBALhC,SAAS;mBAAC;oBACT,QAAQ,EAAE,qBAAqB;oBAC/B,WAAW,EAAE,+BAA+B;oBAC5C,MAAM,EAAE,EAAE;iBACX;oKAIU,eAAe;sBAAvB,KAAK;gBACG,oBAAoB;sBAA5B,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBAIG,mBAAmB;sBAA3B,KAAK;gBAK0B,0BAA0B;sBAAzD,KAAK;uBAAC,uBAAuB;gBAGrB,IAAI;sBAAZ,KAAK;gBAKwB,KAAK;sBAAlC,WAAW;uBAAC,OAAO;gBAQZ,eAAe;sBADtB,SAAS;uBAAC,iBAAiB;gBAGpB,oBAAoB;sBAD3B,SAAS;uBAAC,sBAAsB","sourcesContent":["import {\n  AfterViewChecked,\n  Component,\n  ElementRef,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { ChannelService } from '../channel.service';\nimport { Observable, Subscription } from 'rxjs';\nimport { tap } from 'rxjs/operators';\nimport { StreamMessage } from '../types';\nimport { ChatClientService } from '../chat-client.service';\nimport { getGroupStyles, GroupStyle } from './group-styles';\nimport { ImageLoadService } from './image-load.service';\n\n@Component({\n  selector: 'stream-message-list',\n  templateUrl: './message-list.component.html',\n  styles: [],\n})\nexport class MessageListComponent\n  implements AfterViewChecked, OnChanges, OnInit, OnDestroy\n{\n  @Input() messageTemplate: TemplateRef<any> | undefined;\n  @Input() messageInputTemplate: TemplateRef<any> | undefined;\n  @Input() mentionTemplate: TemplateRef<any> | undefined;\n  /**\n   * @deprecated https://getstream.io/chat/docs/sdk/angular/components/message_list/#caution-arereactionsenabled-deprecated\n   */\n  @Input() areReactionsEnabled: boolean | undefined = undefined;\n  /**\n   * @deprecated https://getstream.io/chat/docs/sdk/angular/components/message_list/#caution-enabledmessageactions-deprecated\n   */\n  /* eslint-disable-next-line @angular-eslint/no-input-rename */\n  @Input('enabledMessageActions') enabledMessageActionsInput:\n    | string[]\n    | undefined = undefined;\n  @Input() mode: 'main' | 'thread' = 'main';\n  messages$!: Observable<StreamMessage[]>;\n  canReactToMessage: boolean | undefined;\n  canReceiveReadEvents: boolean | undefined;\n  enabledMessageActions: string[] = [];\n  @HostBinding('class') private class =\n    'str-chat-angular__main-panel-inner str-chat-angular__message-list-host';\n  unreadMessageCount = 0;\n  isUserScrolledUp: boolean | undefined;\n  groupStyles: GroupStyle[] = [];\n  lastSentMessageId: string | undefined;\n  parentMessage: StreamMessage | undefined;\n  @ViewChild('scrollContainer')\n  private scrollContainer!: ElementRef<HTMLElement>;\n  @ViewChild('parentMessageElement')\n  private parentMessageElement!: ElementRef<HTMLElement>;\n  private latestMessageDate: Date | undefined;\n  private hasNewMessages: boolean | undefined;\n  private containerHeight: number | undefined;\n  private oldestMessageDate: Date | undefined;\n  private olderMassagesLoaded: boolean | undefined;\n  private isNewMessageSentByUser: boolean | undefined;\n  private authorizedMessageActions: string[] = ['flag'];\n  private readonly isUserScrolledUpThreshold = 300;\n  private subscriptions: Subscription[] = [];\n  private prevScrollTop: number | undefined;\n\n  constructor(\n    private channelService: ChannelService,\n    private chatClientService: ChatClientService,\n    private imageLoadService: ImageLoadService\n  ) {\n    this.subscriptions.push(\n      this.channelService.activeChannel$.subscribe((channel) => {\n        this.resetScrollState();\n        const capabilites = channel?.data?.own_capabilities as string[];\n        if (capabilites) {\n          this.canReactToMessage = capabilites.indexOf('send-reaction') !== -1;\n          this.canReceiveReadEvents = capabilites.indexOf('read-events') !== -1;\n          this.authorizedMessageActions = [];\n          if (this.canReactToMessage) {\n            this.authorizedMessageActions.push('send-reaction');\n          }\n          if (this.canReceiveReadEvents) {\n            this.authorizedMessageActions.push('read-events');\n          }\n          if (capabilites.indexOf('flag-message') !== -1) {\n            this.authorizedMessageActions.push('flag');\n          }\n          if (capabilites.indexOf('update-own-message') !== -1) {\n            this.authorizedMessageActions.push('edit');\n          }\n          if (capabilites.indexOf('update-any-message') !== -1) {\n            this.authorizedMessageActions.push('edit');\n            this.authorizedMessageActions.push('edit-any');\n          }\n          if (capabilites.indexOf('delete-own-message') !== -1) {\n            this.authorizedMessageActions.push('delete');\n          }\n          if (capabilites.indexOf('delete-any-message') !== -1) {\n            this.authorizedMessageActions.push('delete');\n            this.authorizedMessageActions.push('delete-any');\n          }\n          if (capabilites.indexOf('send-reply') !== -1) {\n            this.authorizedMessageActions.push('send-reply');\n          }\n          if (capabilites.indexOf('quote-message') !== -1) {\n            this.authorizedMessageActions.push('quote-message');\n          }\n          this.setEnabledActions();\n        }\n      })\n    );\n    this.subscriptions.push(\n      this.imageLoadService.imageLoad$.subscribe(() => {\n        if (!this.isUserScrolledUp) {\n          this.scrollToBottom();\n          // Hacky and unreliable workaround to scroll down after loaded images move the scrollbar\n          setTimeout(() => {\n            this.scrollToBottom();\n          }, 300);\n        }\n      })\n    );\n    this.subscriptions.push(\n      this.channelService.activeParentMessage$.subscribe((message) => {\n        if (\n          message &&\n          this.parentMessage &&\n          message.id !== this.parentMessage.id &&\n          this.mode === 'thread'\n        ) {\n          this.resetScrollState();\n        }\n        this.parentMessage = message;\n      })\n    );\n  }\n\n  ngOnInit(): void {\n    this.setMessages$();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.enabledMessageActionsInput) {\n      this.setEnabledActions();\n    }\n    if (changes.mode) {\n      this.setMessages$();\n    }\n  }\n\n  ngAfterViewChecked() {\n    if (this.hasNewMessages) {\n      if (!this.isUserScrolledUp || this.isNewMessageSentByUser) {\n        this.scrollToBottom();\n        // Hacky and unreliable workaround to scroll down after loaded images move the scrollbar\n        setTimeout(() => {\n          this.scrollToBottom();\n        }, 300);\n      }\n      this.hasNewMessages = false;\n      this.containerHeight = this.scrollContainer.nativeElement.scrollHeight;\n    } else if (this.olderMassagesLoaded) {\n      this.preserveScrollbarPosition();\n      this.containerHeight = this.scrollContainer.nativeElement.scrollHeight;\n      this.olderMassagesLoaded = false;\n    } else if (\n      this.containerHeight !== undefined &&\n      this.containerHeight < this.scrollContainer.nativeElement.scrollHeight &&\n      !this.isUserScrolledUp\n    ) {\n      this.scrollToBottom();\n      this.containerHeight = this.scrollContainer.nativeElement.scrollHeight;\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach((s) => s.unsubscribe());\n  }\n\n  trackByMessageId(index: number, item: StreamMessage) {\n    return item.id;\n  }\n\n  scrollToBottom(): void {\n    this.scrollContainer.nativeElement.scrollTop =\n      this.scrollContainer.nativeElement.scrollHeight;\n  }\n\n  scrolled() {\n    this.isUserScrolledUp =\n      this.scrollContainer.nativeElement.scrollHeight -\n        (this.scrollContainer.nativeElement.scrollTop +\n          this.scrollContainer.nativeElement.clientHeight) >\n      this.isUserScrolledUpThreshold;\n    if (!this.isUserScrolledUp) {\n      this.unreadMessageCount = 0;\n    }\n    if (\n      this.scrollContainer.nativeElement.scrollTop <=\n        (this.parentMessageElement?.nativeElement.clientHeight || 0) &&\n      (this.prevScrollTop === undefined ||\n        this.prevScrollTop >\n          (this.parentMessageElement?.nativeElement.clientHeight || 0))\n    ) {\n      this.containerHeight = this.scrollContainer.nativeElement.scrollHeight;\n      this.mode === 'main'\n        ? void this.channelService.loadMoreMessages()\n        : void this.channelService.loadMoreThreadReplies();\n    }\n    this.prevScrollTop = this.scrollContainer.nativeElement.scrollTop;\n  }\n\n  private preserveScrollbarPosition() {\n    this.scrollContainer.nativeElement.scrollTop =\n      (this.prevScrollTop || 0) +\n      (this.scrollContainer.nativeElement.scrollHeight - this.containerHeight!);\n  }\n\n  private setEnabledActions() {\n    this.enabledMessageActions = [];\n    if (!this.enabledMessageActionsInput) {\n      this.enabledMessageActions = this.authorizedMessageActions;\n      return;\n    }\n    this.enabledMessageActionsInput = [\n      ...this.enabledMessageActionsInput,\n      'send-reaction',\n      'read-events',\n      'send-reply',\n      'quote-message',\n    ];\n    this.enabledMessageActionsInput.forEach((action) => {\n      const isAuthorized = this.authorizedMessageActions.indexOf(action) !== -1;\n      if (isAuthorized) {\n        this.enabledMessageActions.push(action);\n      }\n    });\n  }\n\n  private setMessages$() {\n    this.messages$ = (\n      this.mode === 'main'\n        ? this.channelService.activeChannelMessages$\n        : this.channelService.activeThreadMessages$\n    ).pipe(\n      tap((messages) => {\n        if (messages.length === 0) {\n          return;\n        }\n        const currentLatestMessageDate =\n          messages[messages.length - 1].created_at;\n        if (\n          !this.latestMessageDate ||\n          this.latestMessageDate?.getTime() < currentLatestMessageDate.getTime()\n        ) {\n          this.latestMessageDate = currentLatestMessageDate;\n          this.hasNewMessages = true;\n          this.isNewMessageSentByUser =\n            messages[messages.length - 1].user?.id ===\n            this.chatClientService.chatClient?.user?.id;\n          if (this.isUserScrolledUp) {\n            this.unreadMessageCount++;\n          }\n        }\n        const currentOldestMessageDate = messages[0].created_at;\n        if (!this.oldestMessageDate) {\n          this.oldestMessageDate = currentOldestMessageDate;\n        } else if (\n          this.oldestMessageDate?.getTime() > currentOldestMessageDate.getTime()\n        ) {\n          this.oldestMessageDate = currentOldestMessageDate;\n          this.olderMassagesLoaded = true;\n        }\n      }),\n      tap((messages) => {\n        this.groupStyles = messages.map((m, i) =>\n          getGroupStyles(m, messages[i - 1], messages[i + 1])\n        );\n      }),\n      tap(\n        (messages) =>\n          (this.lastSentMessageId = [...messages]\n            .reverse()\n            .find(\n              (m) =>\n                m.user?.id === this.chatClientService.chatClient?.user?.id &&\n                m.status !== 'sending'\n            )?.id)\n      )\n    );\n  }\n\n  private resetScrollState() {\n    this.latestMessageDate = undefined;\n    this.hasNewMessages = true;\n    this.isUserScrolledUp = false;\n    this.containerHeight = undefined;\n    this.olderMassagesLoaded = false;\n    this.oldestMessageDate = undefined;\n    this.unreadMessageCount = 0;\n    this.prevScrollTop = undefined;\n    this.isNewMessageSentByUser = undefined;\n  }\n}\n","<div\n  #scrollContainer\n  data-testid=\"scroll-container\"\n  class=\"str-chat__list\"\n  (scroll)=\"scrolled()\"\n>\n  <div class=\"str-chat__reverse-infinite-scroll\">\n    <ul class=\"str-chat__ul\">\n      <li\n        #parentMessageElement\n        *ngIf=\"mode === 'thread'\"\n        data-testid=\"parent-message\"\n      >\n        <ng-container\n          *ngTemplateOutlet=\"\n            messageTemplateContainer;\n            context: { message: parentMessage }\n          \"\n        ></ng-container>\n        <div class=\"str-chat__thread-start\" translate>\n          streamChat.Start of a new thread\n        </div>\n      </li>\n      <li\n        data-testclass=\"message\"\n        *ngFor=\"\n          let message of messages$ | async;\n          let i = index;\n          trackBy: trackByMessageId\n        \"\n        class=\"str-chat__li str-chat__li--{{ groupStyles[i] }}\"\n      >\n        <ng-container\n          *ngTemplateOutlet=\"\n            messageTemplateContainer;\n            context: { message: message }\n          \"\n        ></ng-container>\n      </li>\n    </ul>\n  </div>\n</div>\n<div class=\"str-chat__list-notifications\">\n  <button\n    data-testid=\"scroll-to-bottom\"\n    *ngIf=\"isUserScrolledUp\"\n    class=\"\n      str-chat__message-notification\n      str-chat__message-notification-right\n      str-chat__message-notification-scroll-down\n    \"\n    (keyup.enter)=\"scrollToBottom()\"\n    (click)=\"scrollToBottom()\"\n  >\n    <div\n      *ngIf=\"unreadMessageCount > 0\"\n      class=\"\n        str-chat__message-notification\n        str-chat__message-notification-scroll-down-unread-count\n      \"\n    >\n      {{ unreadMessageCount }}\n    </div>\n  </button>\n</div>\n\n<ng-template #messageTemplateContainer let-message=\"message\">\n  <ng-container *ngIf=\"messageTemplate; else defaultMessageTemplate\">\n    <ng-container\n      *ngTemplateOutlet=\"\n        messageTemplate;\n        context: {\n          message: message,\n          areReactionsEnabled: areReactionsEnabled,\n          canReactToMessage: canReactToMessage,\n          lastSentMessageId: !!(\n            lastSentMessageId && message?.id === lastSentMessageId\n          ),\n          canReceiveReadEvents: canReceiveReadEvents,\n          messageInputTemplate: messageInputTemplate,\n          mentionTemplate: mentionTemplate,\n          mode: mode\n        }\n      \"\n    ></ng-container>\n  </ng-container>\n  <ng-template #defaultMessageTemplate>\n    <stream-message\n      [message]=\"message\"\n      [areReactionsEnabled]=\"areReactionsEnabled\"\n      [canReactToMessage]=\"canReactToMessage\"\n      [isLastSentMessage]=\"\n        !!(lastSentMessageId && message?.id === lastSentMessageId)\n      \"\n      [enabledMessageActions]=\"enabledMessageActions\"\n      [canReceiveReadEvents]=\"canReceiveReadEvents\"\n      [messageInputTemplate]=\"messageInputTemplate\"\n      [mentionTemplate]=\"mentionTemplate\"\n      [mode]=\"mode\"\n    ></stream-message>\n  </ng-template>\n</ng-template>\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { v4 as uuidv4 } from 'uuid';
|
|
2
|
-
export const createMessagePreview = (user, text, attachments, mentionedUsers) => {
|
|
2
|
+
export const createMessagePreview = (user, text, attachments = [], mentionedUsers = [], parentId = undefined, quotedMessageId = undefined) => {
|
|
3
3
|
const clientSideId = `${user.id}-${uuidv4()}`;
|
|
4
4
|
return {
|
|
5
5
|
__html: text,
|
|
@@ -13,6 +13,8 @@ export const createMessagePreview = (user, text, attachments, mentionedUsers) =>
|
|
|
13
13
|
user,
|
|
14
14
|
attachments,
|
|
15
15
|
mentioned_users: mentionedUsers,
|
|
16
|
+
parent_id: parentId,
|
|
17
|
+
quoted_message_id: quotedMessageId,
|
|
16
18
|
};
|
|
17
19
|
};
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVzc2FnZS1wcmV2aWV3LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvc3RyZWFtLWNoYXQtYW5ndWxhci9zcmMvbGliL21lc3NhZ2UtcHJldmlldy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsRUFBRSxJQUFJLE1BQU0sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUVwQyxNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxDQUNsQyxJQUFrQixFQUNsQixJQUFZLEVBQ1osY0FBNEIsRUFBRSxFQUM5QixpQkFBaUMsRUFBRSxFQUNuQyxXQUErQixTQUFTLEVBQ3hDLGtCQUFzQyxTQUFTLEVBQy9DLEVBQUU7SUFDRixNQUFNLFlBQVksR0FBRyxHQUFHLElBQUksQ0FBQyxFQUFFLElBQUksTUFBTSxFQUFFLEVBQUUsQ0FBQztJQUU5QyxPQUFPO1FBQ0wsTUFBTSxFQUFFLElBQUk7UUFDWixVQUFVLEVBQUUsSUFBSSxJQUFJLEVBQUU7UUFDdEIsSUFBSSxFQUFFLElBQUk7UUFDVixFQUFFLEVBQUUsWUFBWTtRQUNoQixTQUFTLEVBQUUsRUFBRTtRQUNiLE1BQU0sRUFBRSxTQUFTO1FBQ2pCLElBQUk7UUFDSixJQUFJLEVBQUUsU0FBUztRQUNmLElBQUk7UUFDSixXQUFXO1FBQ1gsZUFBZSxFQUFFLGNBQWM7UUFDL0IsU0FBUyxFQUFFLFFBQVE7UUFDbkIsaUJBQWlCLEVBQUUsZUFBZTtLQUNMLENBQUM7QUFDbEMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQXR0YWNobWVudCwgTWVzc2FnZVJlc3BvbnNlLCBVc2VyUmVzcG9uc2UgfSBmcm9tICdzdHJlYW0tY2hhdCc7XG5pbXBvcnQgeyB2NCBhcyB1dWlkdjQgfSBmcm9tICd1dWlkJztcblxuZXhwb3J0IGNvbnN0IGNyZWF0ZU1lc3NhZ2VQcmV2aWV3ID0gKFxuICB1c2VyOiBVc2VyUmVzcG9uc2UsXG4gIHRleHQ6IHN0cmluZyxcbiAgYXR0YWNobWVudHM6IEF0dGFjaG1lbnRbXSA9IFtdLFxuICBtZW50aW9uZWRVc2VyczogVXNlclJlc3BvbnNlW10gPSBbXSxcbiAgcGFyZW50SWQ6IHVuZGVmaW5lZCB8IHN0cmluZyA9IHVuZGVmaW5lZCxcbiAgcXVvdGVkTWVzc2FnZUlkOiB1bmRlZmluZWQgfCBzdHJpbmcgPSB1bmRlZmluZWRcbikgPT4ge1xuICBjb25zdCBjbGllbnRTaWRlSWQgPSBgJHt1c2VyLmlkfS0ke3V1aWR2NCgpfWA7XG5cbiAgcmV0dXJuIHtcbiAgICBfX2h0bWw6IHRleHQsXG4gICAgY3JlYXRlZF9hdDogbmV3IERhdGUoKSxcbiAgICBodG1sOiB0ZXh0LFxuICAgIGlkOiBjbGllbnRTaWRlSWQsXG4gICAgcmVhY3Rpb25zOiBbXSxcbiAgICBzdGF0dXM6ICdzZW5kaW5nJyxcbiAgICB0ZXh0LFxuICAgIHR5cGU6ICdyZWd1bGFyJyxcbiAgICB1c2VyLFxuICAgIGF0dGFjaG1lbnRzLFxuICAgIG1lbnRpb25lZF91c2VyczogbWVudGlvbmVkVXNlcnMsXG4gICAgcGFyZW50X2lkOiBwYXJlbnRJZCxcbiAgICBxdW90ZWRfbWVzc2FnZV9pZDogcXVvdGVkTWVzc2FnZUlkLFxuICB9IGFzIHVua25vd24gYXMgTWVzc2FnZVJlc3BvbnNlO1xufTtcbiJdfQ==
|
|
@@ -19,6 +19,7 @@ import { AttachmentPreviewListComponent } from './attachment-preview-list/attach
|
|
|
19
19
|
import { ModalComponent } from './modal/modal.component';
|
|
20
20
|
import { TextareaDirective } from './message-input/textarea.directive';
|
|
21
21
|
import { StreamAvatarModule } from './stream-avatar.module';
|
|
22
|
+
import { ThreadComponent } from './thread/thread.component';
|
|
22
23
|
import * as i0 from "@angular/core";
|
|
23
24
|
export class StreamChatModule {
|
|
24
25
|
}
|
|
@@ -39,7 +40,8 @@ StreamChatModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", versio
|
|
|
39
40
|
NotificationListComponent,
|
|
40
41
|
AttachmentPreviewListComponent,
|
|
41
42
|
ModalComponent,
|
|
42
|
-
TextareaDirective
|
|
43
|
+
TextareaDirective,
|
|
44
|
+
ThreadComponent], imports: [CommonModule, TranslateModule, StreamAvatarModule], exports: [ChannelComponent,
|
|
43
45
|
ChannelHeaderComponent,
|
|
44
46
|
ChannelListComponent,
|
|
45
47
|
ChannelPreviewComponent,
|
|
@@ -55,7 +57,8 @@ StreamChatModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", versio
|
|
|
55
57
|
NotificationListComponent,
|
|
56
58
|
AttachmentPreviewListComponent,
|
|
57
59
|
ModalComponent,
|
|
58
|
-
StreamAvatarModule
|
|
60
|
+
StreamAvatarModule,
|
|
61
|
+
ThreadComponent] });
|
|
59
62
|
StreamChatModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: StreamChatModule, imports: [[CommonModule, TranslateModule, StreamAvatarModule], StreamAvatarModule] });
|
|
60
63
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: StreamChatModule, decorators: [{
|
|
61
64
|
type: NgModule,
|
|
@@ -78,6 +81,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
|
|
|
78
81
|
AttachmentPreviewListComponent,
|
|
79
82
|
ModalComponent,
|
|
80
83
|
TextareaDirective,
|
|
84
|
+
ThreadComponent,
|
|
81
85
|
],
|
|
82
86
|
imports: [CommonModule, TranslateModule, StreamAvatarModule],
|
|
83
87
|
exports: [
|
|
@@ -98,7 +102,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
|
|
|
98
102
|
AttachmentPreviewListComponent,
|
|
99
103
|
ModalComponent,
|
|
100
104
|
StreamAvatarModule,
|
|
105
|
+
ThreadComponent,
|
|
101
106
|
],
|
|
102
107
|
}]
|
|
103
108
|
}] });
|
|
104
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
109
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RyZWFtLWNoYXQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvc3RyZWFtLWNoYXQtYW5ndWxhci9zcmMvbGliL3N0cmVhbS1jaGF0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQy9ELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQzdFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDZDQUE2QyxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQy9ELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQ2hGLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxpREFBaUQsQ0FBQztBQUM1RixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDdEQsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0scURBQXFELENBQUM7QUFDakcsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFDdEYsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0saURBQWlELENBQUM7QUFDNUYsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDOUUsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0saURBQWlELENBQUM7QUFDNUYsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3RELE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLDZEQUE2RCxDQUFDO0FBQzdHLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUN2RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUM1RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7O0FBNkM1RCxNQUFNLE9BQU8sZ0JBQWdCOzs2R0FBaEIsZ0JBQWdCOzhHQUFoQixnQkFBZ0IsaUJBekN6QixnQkFBZ0I7UUFDaEIsc0JBQXNCO1FBQ3RCLG9CQUFvQjtRQUNwQix1QkFBdUI7UUFDdkIsZ0JBQWdCO1FBQ2hCLHFCQUFxQjtRQUNyQixvQkFBb0I7UUFDcEIseUJBQXlCO1FBQ3pCLGFBQWE7UUFDYiwwQkFBMEI7UUFDMUIsdUJBQXVCO1FBQ3ZCLHlCQUF5QjtRQUN6QixxQkFBcUI7UUFDckIseUJBQXlCO1FBQ3pCLDhCQUE4QjtRQUM5QixjQUFjO1FBQ2QsaUJBQWlCO1FBQ2pCLGVBQWUsYUFFUCxZQUFZLEVBQUUsZUFBZSxFQUFFLGtCQUFrQixhQUV6RCxnQkFBZ0I7UUFDaEIsc0JBQXNCO1FBQ3RCLG9CQUFvQjtRQUNwQix1QkFBdUI7UUFDdkIsZ0JBQWdCO1FBQ2hCLHFCQUFxQjtRQUNyQixvQkFBb0I7UUFDcEIseUJBQXlCO1FBQ3pCLGFBQWE7UUFDYiwwQkFBMEI7UUFDMUIsdUJBQXVCO1FBQ3ZCLHlCQUF5QjtRQUN6QixxQkFBcUI7UUFDckIseUJBQXlCO1FBQ3pCLDhCQUE4QjtRQUM5QixjQUFjO1FBQ2Qsa0JBQWtCO1FBQ2xCLGVBQWU7OEdBR04sZ0JBQWdCLFlBdEJsQixDQUFDLFlBQVksRUFBRSxlQUFlLEVBQUUsa0JBQWtCLENBQUMsRUFrQjFELGtCQUFrQjsyRkFJVCxnQkFBZ0I7a0JBM0M1QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWixnQkFBZ0I7d0JBQ2hCLHNCQUFzQjt3QkFDdEIsb0JBQW9CO3dCQUNwQix1QkFBdUI7d0JBQ3ZCLGdCQUFnQjt3QkFDaEIscUJBQXFCO3dCQUNyQixvQkFBb0I7d0JBQ3BCLHlCQUF5Qjt3QkFDekIsYUFBYTt3QkFDYiwwQkFBMEI7d0JBQzFCLHVCQUF1Qjt3QkFDdkIseUJBQXlCO3dCQUN6QixxQkFBcUI7d0JBQ3JCLHlCQUF5Qjt3QkFDekIsOEJBQThCO3dCQUM5QixjQUFjO3dCQUNkLGlCQUFpQjt3QkFDakIsZUFBZTtxQkFDaEI7b0JBQ0QsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLGVBQWUsRUFBRSxrQkFBa0IsQ0FBQztvQkFDNUQsT0FBTyxFQUFFO3dCQUNQLGdCQUFnQjt3QkFDaEIsc0JBQXNCO3dCQUN0QixvQkFBb0I7d0JBQ3BCLHVCQUF1Qjt3QkFDdkIsZ0JBQWdCO3dCQUNoQixxQkFBcUI7d0JBQ3JCLG9CQUFvQjt3QkFDcEIseUJBQXlCO3dCQUN6QixhQUFhO3dCQUNiLDBCQUEwQjt3QkFDMUIsdUJBQXVCO3dCQUN2Qix5QkFBeUI7d0JBQ3pCLHFCQUFxQjt3QkFDckIseUJBQXlCO3dCQUN6Qiw4QkFBOEI7d0JBQzlCLGNBQWM7d0JBQ2Qsa0JBQWtCO3dCQUNsQixlQUFlO3FCQUNoQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDaGFubmVsQ29tcG9uZW50IH0gZnJvbSAnLi9jaGFubmVsL2NoYW5uZWwuY29tcG9uZW50JztcbmltcG9ydCB7IENoYW5uZWxIZWFkZXJDb21wb25lbnQgfSBmcm9tICcuL2NoYW5uZWwtaGVhZGVyL2NoYW5uZWwtaGVhZGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDaGFubmVsTGlzdENvbXBvbmVudCB9IGZyb20gJy4vY2hhbm5lbC1saXN0L2NoYW5uZWwtbGlzdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ2hhbm5lbFByZXZpZXdDb21wb25lbnQgfSBmcm9tICcuL2NoYW5uZWwtcHJldmlldy9jaGFubmVsLXByZXZpZXcuY29tcG9uZW50JztcbmltcG9ydCB7IE1lc3NhZ2VDb21wb25lbnQgfSBmcm9tICcuL21lc3NhZ2UvbWVzc2FnZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgTWVzc2FnZUlucHV0Q29tcG9uZW50IH0gZnJvbSAnLi9tZXNzYWdlLWlucHV0L21lc3NhZ2UtaW5wdXQuY29tcG9uZW50JztcbmltcG9ydCB7IE1lc3NhZ2VMaXN0Q29tcG9uZW50IH0gZnJvbSAnLi9tZXNzYWdlLWxpc3QvbWVzc2FnZS1saXN0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTG9hZGluZ0luZGljYXRvckNvbXBvbmVudCB9IGZyb20gJy4vbG9hZGluZy1pbmRpY2F0b3IvbG9hZGluZy1pbmRpY2F0b3IuY29tcG9uZW50JztcbmltcG9ydCB7IEljb25Db21wb25lbnQgfSBmcm9tICcuL2ljb24vaWNvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgTWVzc2FnZUFjdGlvbnNCb3hDb21wb25lbnQgfSBmcm9tICcuL21lc3NhZ2UtYWN0aW9ucy1ib3gvbWVzc2FnZS1hY3Rpb25zLWJveC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQXR0YWNobWVudExpc3RDb21wb25lbnQgfSBmcm9tICcuL2F0dGFjaG1lbnQtbGlzdC9hdHRhY2htZW50LWxpc3QuY29tcG9uZW50JztcbmltcG9ydCB7IE1lc3NhZ2VSZWFjdGlvbnNDb21wb25lbnQgfSBmcm9tICcuL21lc3NhZ2UtcmVhY3Rpb25zL21lc3NhZ2UtcmVhY3Rpb25zLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBOb3RpZmljYXRpb25Db21wb25lbnQgfSBmcm9tICcuL25vdGlmaWNhdGlvbi9ub3RpZmljYXRpb24uY29tcG9uZW50JztcbmltcG9ydCB7IE5vdGlmaWNhdGlvbkxpc3RDb21wb25lbnQgfSBmcm9tICcuL25vdGlmaWNhdGlvbi1saXN0L25vdGlmaWNhdGlvbi1saXN0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcbmltcG9ydCB7IEF0dGFjaG1lbnRQcmV2aWV3TGlzdENvbXBvbmVudCB9IGZyb20gJy4vYXR0YWNobWVudC1wcmV2aWV3LWxpc3QvYXR0YWNobWVudC1wcmV2aWV3LWxpc3QuY29tcG9uZW50JztcbmltcG9ydCB7IE1vZGFsQ29tcG9uZW50IH0gZnJvbSAnLi9tb2RhbC9tb2RhbC5jb21wb25lbnQnO1xuaW1wb3J0IHsgVGV4dGFyZWFEaXJlY3RpdmUgfSBmcm9tICcuL21lc3NhZ2UtaW5wdXQvdGV4dGFyZWEuZGlyZWN0aXZlJztcbmltcG9ydCB7IFN0cmVhbUF2YXRhck1vZHVsZSB9IGZyb20gJy4vc3RyZWFtLWF2YXRhci5tb2R1bGUnO1xuaW1wb3J0IHsgVGhyZWFkQ29tcG9uZW50IH0gZnJvbSAnLi90aHJlYWQvdGhyZWFkLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1xuICAgIENoYW5uZWxDb21wb25lbnQsXG4gICAgQ2hhbm5lbEhlYWRlckNvbXBvbmVudCxcbiAgICBDaGFubmVsTGlzdENvbXBvbmVudCxcbiAgICBDaGFubmVsUHJldmlld0NvbXBvbmVudCxcbiAgICBNZXNzYWdlQ29tcG9uZW50LFxuICAgIE1lc3NhZ2VJbnB1dENvbXBvbmVudCxcbiAgICBNZXNzYWdlTGlzdENvbXBvbmVudCxcbiAgICBMb2FkaW5nSW5kaWNhdG9yQ29tcG9uZW50LFxuICAgIEljb25Db21wb25lbnQsXG4gICAgTWVzc2FnZUFjdGlvbnNCb3hDb21wb25lbnQsXG4gICAgQXR0YWNobWVudExpc3RDb21wb25lbnQsXG4gICAgTWVzc2FnZVJlYWN0aW9uc0NvbXBvbmVudCxcbiAgICBOb3RpZmljYXRpb25Db21wb25lbnQsXG4gICAgTm90aWZpY2F0aW9uTGlzdENvbXBvbmVudCxcbiAgICBBdHRhY2htZW50UHJldmlld0xpc3RDb21wb25lbnQsXG4gICAgTW9kYWxDb21wb25lbnQsXG4gICAgVGV4dGFyZWFEaXJlY3RpdmUsXG4gICAgVGhyZWFkQ29tcG9uZW50LFxuICBdLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBUcmFuc2xhdGVNb2R1bGUsIFN0cmVhbUF2YXRhck1vZHVsZV0sXG4gIGV4cG9ydHM6IFtcbiAgICBDaGFubmVsQ29tcG9uZW50LFxuICAgIENoYW5uZWxIZWFkZXJDb21wb25lbnQsXG4gICAgQ2hhbm5lbExpc3RDb21wb25lbnQsXG4gICAgQ2hhbm5lbFByZXZpZXdDb21wb25lbnQsXG4gICAgTWVzc2FnZUNvbXBvbmVudCxcbiAgICBNZXNzYWdlSW5wdXRDb21wb25lbnQsXG4gICAgTWVzc2FnZUxpc3RDb21wb25lbnQsXG4gICAgTG9hZGluZ0luZGljYXRvckNvbXBvbmVudCxcbiAgICBJY29uQ29tcG9uZW50LFxuICAgIE1lc3NhZ2VBY3Rpb25zQm94Q29tcG9uZW50LFxuICAgIEF0dGFjaG1lbnRMaXN0Q29tcG9uZW50LFxuICAgIE1lc3NhZ2VSZWFjdGlvbnNDb21wb25lbnQsXG4gICAgTm90aWZpY2F0aW9uQ29tcG9uZW50LFxuICAgIE5vdGlmaWNhdGlvbkxpc3RDb21wb25lbnQsXG4gICAgQXR0YWNobWVudFByZXZpZXdMaXN0Q29tcG9uZW50LFxuICAgIE1vZGFsQ29tcG9uZW50LFxuICAgIFN0cmVhbUF2YXRhck1vZHVsZSxcbiAgICBUaHJlYWRDb21wb25lbnQsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIFN0cmVhbUNoYXRNb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { Component, HostBinding } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../channel.service";
|
|
4
|
+
import * as i2 from "../icon/icon.component";
|
|
5
|
+
import * as i3 from "@ngx-translate/core";
|
|
6
|
+
export class ThreadComponent {
|
|
7
|
+
constructor(channelService) {
|
|
8
|
+
this.channelService = channelService;
|
|
9
|
+
this.class = 'str-chat__thread';
|
|
10
|
+
this.subscriptions = [];
|
|
11
|
+
this.subscriptions.push(this.channelService.activeParentMessage$.subscribe((parentMessage) => (this.parentMessage = parentMessage)));
|
|
12
|
+
}
|
|
13
|
+
ngOnDestroy() {
|
|
14
|
+
this.subscriptions.forEach((s) => s.unsubscribe());
|
|
15
|
+
}
|
|
16
|
+
get replyCountParam() {
|
|
17
|
+
var _a;
|
|
18
|
+
return { replyCount: (_a = this.parentMessage) === null || _a === void 0 ? void 0 : _a.reply_count };
|
|
19
|
+
}
|
|
20
|
+
closeThread() {
|
|
21
|
+
void this.channelService.setAsActiveParentMessage(undefined);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
ThreadComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: ThreadComponent, deps: [{ token: i1.ChannelService }], target: i0.ɵɵFactoryTarget.Component });
|
|
25
|
+
ThreadComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.5", type: ThreadComponent, selector: "stream-thread", host: { properties: { "class": "this.class" } }, ngImport: i0, template: "<div class=\"str-chat__thread-header\">\n <div class=\"str-chat__thread-header-details\">\n <strong translate>streamChat.Thread</strong>\n <small data-testid=\"reply-count\">\n {{parentMessage?.reply_count === 1 ? ('streamChat.1 reply' | translate) : ('streamChat.{{ replyCount }}\n replies' | translate:replyCountParam)}}\n </small>\n </div>\n <button\n class=\"str-chat__square-button\"\n data-testid=\"close-button\"\n (click)=\"closeThread()\"\n >\n <stream-icon icon=\"close-no-outline\"></stream-icon>\n </button>\n</div>\n<ng-content select='[name=\"thread-message-list\"]'></ng-content>\n<div class=\"str-chat__small-message-input__wrapper\">\n <ng-content select='[name=\"thread-message-input\"]'></ng-content>\n</div>\n", components: [{ type: i2.IconComponent, selector: "stream-icon", inputs: ["icon", "size"] }], directives: [{ type: i3.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], pipes: { "translate": i3.TranslatePipe } });
|
|
26
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: ThreadComponent, decorators: [{
|
|
27
|
+
type: Component,
|
|
28
|
+
args: [{
|
|
29
|
+
selector: 'stream-thread',
|
|
30
|
+
templateUrl: './thread.component.html',
|
|
31
|
+
styles: [],
|
|
32
|
+
}]
|
|
33
|
+
}], ctorParameters: function () { return [{ type: i1.ChannelService }]; }, propDecorators: { class: [{
|
|
34
|
+
type: HostBinding,
|
|
35
|
+
args: ['class']
|
|
36
|
+
}] } });
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhyZWFkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi90aHJlYWQvdGhyZWFkLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi90aHJlYWQvdGhyZWFkLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFhLE1BQU0sZUFBZSxDQUFDOzs7OztBQVVsRSxNQUFNLE9BQU8sZUFBZTtJQUsxQixZQUFvQixjQUE4QjtRQUE5QixtQkFBYyxHQUFkLGNBQWMsQ0FBZ0I7UUFKcEIsVUFBSyxHQUFHLGtCQUFrQixDQUFDO1FBRWpELGtCQUFhLEdBQW1CLEVBQUUsQ0FBQztRQUd6QyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FDckIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxvQkFBb0IsQ0FBQyxTQUFTLENBQ2hELENBQUMsYUFBYSxFQUFFLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxhQUFhLEdBQUcsYUFBYSxDQUFDLENBQ3hELENBQ0YsQ0FBQztJQUNKLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDO0lBQ3JELENBQUM7SUFFRCxJQUFJLGVBQWU7O1FBQ2pCLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBQSxJQUFJLENBQUMsYUFBYSwwQ0FBRSxXQUFXLEVBQUUsQ0FBQztJQUN6RCxDQUFDO0lBRUQsV0FBVztRQUNULEtBQUssSUFBSSxDQUFDLGNBQWMsQ0FBQyx3QkFBd0IsQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUMvRCxDQUFDOzs0R0F2QlUsZUFBZTtnR0FBZixlQUFlLHNHQ1Y1Qixnd0JBb0JBOzJGRFZhLGVBQWU7a0JBTDNCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGVBQWU7b0JBQ3pCLFdBQVcsRUFBRSx5QkFBeUI7b0JBQ3RDLE1BQU0sRUFBRSxFQUFFO2lCQUNYO3FHQUUrQixLQUFLO3NCQUFsQyxXQUFXO3VCQUFDLE9BQU8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBPbkRlc3Ryb3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgQ2hhbm5lbFNlcnZpY2UgfSBmcm9tICcuLi9jaGFubmVsLnNlcnZpY2UnO1xuaW1wb3J0IHsgU3RyZWFtTWVzc2FnZSB9IGZyb20gJy4uL3R5cGVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnc3RyZWFtLXRocmVhZCcsXG4gIHRlbXBsYXRlVXJsOiAnLi90aHJlYWQuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZXM6IFtdLFxufSlcbmV4cG9ydCBjbGFzcyBUaHJlYWRDb21wb25lbnQgaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xuICBASG9zdEJpbmRpbmcoJ2NsYXNzJykgcHJpdmF0ZSBjbGFzcyA9ICdzdHItY2hhdF9fdGhyZWFkJztcbiAgcGFyZW50TWVzc2FnZTogU3RyZWFtTWVzc2FnZSB8IHVuZGVmaW5lZDtcbiAgcHJpdmF0ZSBzdWJzY3JpcHRpb25zOiBTdWJzY3JpcHRpb25bXSA9IFtdO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgY2hhbm5lbFNlcnZpY2U6IENoYW5uZWxTZXJ2aWNlKSB7XG4gICAgdGhpcy5zdWJzY3JpcHRpb25zLnB1c2goXG4gICAgICB0aGlzLmNoYW5uZWxTZXJ2aWNlLmFjdGl2ZVBhcmVudE1lc3NhZ2UkLnN1YnNjcmliZShcbiAgICAgICAgKHBhcmVudE1lc3NhZ2UpID0+ICh0aGlzLnBhcmVudE1lc3NhZ2UgPSBwYXJlbnRNZXNzYWdlKVxuICAgICAgKVxuICAgICk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLnN1YnNjcmlwdGlvbnMuZm9yRWFjaCgocykgPT4gcy51bnN1YnNjcmliZSgpKTtcbiAgfVxuXG4gIGdldCByZXBseUNvdW50UGFyYW0oKSB7XG4gICAgcmV0dXJuIHsgcmVwbHlDb3VudDogdGhpcy5wYXJlbnRNZXNzYWdlPy5yZXBseV9jb3VudCB9O1xuICB9XG5cbiAgY2xvc2VUaHJlYWQoKSB7XG4gICAgdm9pZCB0aGlzLmNoYW5uZWxTZXJ2aWNlLnNldEFzQWN0aXZlUGFyZW50TWVzc2FnZSh1bmRlZmluZWQpO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwic3RyLWNoYXRfX3RocmVhZC1oZWFkZXJcIj5cbiAgPGRpdiBjbGFzcz1cInN0ci1jaGF0X190aHJlYWQtaGVhZGVyLWRldGFpbHNcIj5cbiAgICA8c3Ryb25nIHRyYW5zbGF0ZT5zdHJlYW1DaGF0LlRocmVhZDwvc3Ryb25nPlxuICAgIDxzbWFsbCBkYXRhLXRlc3RpZD1cInJlcGx5LWNvdW50XCI+XG4gICAgICB7e3BhcmVudE1lc3NhZ2U/LnJlcGx5X2NvdW50ID09PSAxID8gKCdzdHJlYW1DaGF0LjEgcmVwbHknIHwgdHJhbnNsYXRlKSA6ICgnc3RyZWFtQ2hhdC57eyByZXBseUNvdW50IH19XG4gICAgICByZXBsaWVzJyB8IHRyYW5zbGF0ZTpyZXBseUNvdW50UGFyYW0pfX1cbiAgICA8L3NtYWxsPlxuICA8L2Rpdj5cbiAgPGJ1dHRvblxuICAgIGNsYXNzPVwic3RyLWNoYXRfX3NxdWFyZS1idXR0b25cIlxuICAgIGRhdGEtdGVzdGlkPVwiY2xvc2UtYnV0dG9uXCJcbiAgICAoY2xpY2spPVwiY2xvc2VUaHJlYWQoKVwiXG4gID5cbiAgICA8c3RyZWFtLWljb24gaWNvbj1cImNsb3NlLW5vLW91dGxpbmVcIj48L3N0cmVhbS1pY29uPlxuICA8L2J1dHRvbj5cbjwvZGl2PlxuPG5nLWNvbnRlbnQgc2VsZWN0PSdbbmFtZT1cInRocmVhZC1tZXNzYWdlLWxpc3RcIl0nPjwvbmctY29udGVudD5cbjxkaXYgY2xhc3M9XCJzdHItY2hhdF9fc21hbGwtbWVzc2FnZS1pbnB1dF9fd3JhcHBlclwiPlxuICA8bmctY29udGVudCBzZWxlY3Q9J1tuYW1lPVwidGhyZWFkLW1lc3NhZ2UtaW5wdXRcIl0nPjwvbmctY29udGVudD5cbjwvZGl2PlxuIl19
|
package/esm2015/public-api.js
CHANGED
|
@@ -32,6 +32,7 @@ export * from './lib/attachment-preview-list/attachment-preview-list.component';
|
|
|
32
32
|
export * from './lib/message-reactions/message-reactions.component';
|
|
33
33
|
export * from './lib/notification/notification.component';
|
|
34
34
|
export * from './lib/notification-list/notification-list.component';
|
|
35
|
+
export * from './lib/thread/thread.component';
|
|
35
36
|
export * from './lib/modal/modal.component';
|
|
36
37
|
export * from './lib/read-by';
|
|
37
38
|
export * from './lib/is-image-attachment';
|
|
@@ -46,4 +47,4 @@ export * from './lib/stream-autocomplete-textarea.module';
|
|
|
46
47
|
export * from './lib/stream-textarea.module';
|
|
47
48
|
export * from './lib/injection-tokens';
|
|
48
49
|
export * from './lib/types';
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYyx5REFBeUQsQ0FBQztBQUN4RSxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsMkVBQTJFLENBQUM7QUFDMUYsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLHdDQUF3QyxDQUFDO0FBQ3ZELGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLGlFQUFpRSxDQUFDO0FBQ2hGLGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLHFEQUFxRCxDQUFDO0FBQ3BFLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIHN0cmVhbS1jaGF0LWFuZ3VsYXJcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGF0LWNsaWVudC5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoYW5uZWwuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90aGVtZS5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2F0dGFjaG1lbnQuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zdHJlYW0taTE4bi5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2F2YXRhci9hdmF0YXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ljb24vaWNvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbG9hZGluZy1pbmRpY2F0b3IvbG9hZGluZy1pbmRpY2F0b3IuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lc3NhZ2UtYWN0aW9ucy1ib3gvbWVzc2FnZS1hY3Rpb25zLWJveC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hhbm5lbC9jaGFubmVsLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGFubmVsLWhlYWRlci9jaGFubmVsLWhlYWRlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hhbm5lbC1wcmV2aWV3L2NoYW5uZWwtcHJldmlldy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hhbm5lbC1saXN0L2NoYW5uZWwtbGlzdC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hhbm5lbC1saXN0L2NoYW5uZWwtbGlzdC10b2dnbGUuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZXNzYWdlL21lc3NhZ2UuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lc3NhZ2UvcGFyc2UtZGF0ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZXNzYWdlL3JlYWQtYnktdGV4dCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZXNzYWdlLWlucHV0L21lc3NhZ2UtaW5wdXQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lc3NhZ2UtaW5wdXQvdGV4dGFyZWEvdGV4dGFyZWEuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lc3NhZ2UtaW5wdXQvYXV0b2NvbXBsZXRlLXRleHRhcmVhL2F1dG9jb21wbGV0ZS10ZXh0YXJlYS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWVzc2FnZS1pbnB1dC9tZXNzYWdlLWlucHV0LWNvbmZpZy5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lc3NhZ2UtaW5wdXQvdGV4dGFyZWEuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lc3NhZ2UtaW5wdXQvdGV4dGFyZWEuaW50ZXJmYWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lc3NhZ2UtbGlzdC9tZXNzYWdlLWxpc3QuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lc3NhZ2UtbGlzdC9pbWFnZS1sb2FkLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWVzc2FnZS1saXN0L2dyb3VwLXN0eWxlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdHRhY2htZW50LWxpc3QvYXR0YWNobWVudC1saXN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdHRhY2htZW50LXByZXZpZXctbGlzdC9hdHRhY2htZW50LXByZXZpZXctbGlzdC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWVzc2FnZS1yZWFjdGlvbnMvbWVzc2FnZS1yZWFjdGlvbnMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL25vdGlmaWNhdGlvbi9ub3RpZmljYXRpb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL25vdGlmaWNhdGlvbi1saXN0L25vdGlmaWNhdGlvbi1saXN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90aHJlYWQvdGhyZWFkLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RhbC9tb2RhbC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcmVhZC1ieSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9pcy1pbWFnZS1hdHRhY2htZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2lzLWltYWdlLWZpbGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGV2aWNlLXdpZHRoJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lc3NhZ2UtcHJldmlldyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9ub3RpZmljYXRpb24uc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90cmFuc2xpdGVyYXRpb24uc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zdHJlYW0tY2hhdC5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc3RyZWFtLWF2YXRhci5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc3RyZWFtLWF1dG9jb21wbGV0ZS10ZXh0YXJlYS5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc3RyZWFtLXRleHRhcmVhLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbmplY3Rpb24tdG9rZW5zJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3R5cGVzJztcbiJdfQ==
|