stream-chat-angular 2.3.0 → 2.5.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/version.d.ts +1 -1
- package/bundles/stream-chat-angular.umd.js +105 -58
- package/bundles/stream-chat-angular.umd.js.map +1 -1
- package/esm2015/assets/version.js +2 -2
- package/esm2015/lib/message/message.component.js +52 -5
- package/esm2015/lib/message-actions-box/message-actions-box.component.js +9 -7
- package/esm2015/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.js +8 -2
- package/esm2015/lib/message-input/message-input.component.js +16 -14
- package/esm2015/lib/message-input/textarea.directive.js +12 -2
- package/esm2015/lib/message-list/message-list.component.js +6 -2
- package/esm2015/lib/stream-chat.module.js +5 -8
- package/esm2015/public-api.js +2 -2
- package/fesm2015/stream-chat-angular.js +103 -54
- package/fesm2015/stream-chat-angular.js.map +1 -1
- package/lib/message/message.component.d.ts +11 -2
- package/lib/message-actions-box/message-actions-box.component.d.ts +4 -3
- package/lib/message-input/message-input.component.d.ts +2 -3
- package/lib/message-input/textarea.directive.d.ts +1 -0
- package/lib/message-list/message-list.component.d.ts +3 -1
- package/lib/stream-chat.module.d.ts +4 -5
- package/package.json +1 -1
- package/public-api.d.ts +1 -1
- package/src/assets/version.ts +1 -1
- package/esm2015/lib/message/highlight-mentions.pipe.js +0 -23
- package/lib/message/highlight-mentions.pipe.d.ts +0 -8
package/assets/version.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export declare const version = "2.
|
|
1
|
+
export declare const version = "2.5.1";
|
|
@@ -353,7 +353,7 @@
|
|
|
353
353
|
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
354
354
|
}
|
|
355
355
|
|
|
356
|
-
var version = '2.
|
|
356
|
+
var version = '2.5.1';
|
|
357
357
|
|
|
358
358
|
var NotificationService = /** @class */ (function () {
|
|
359
359
|
function NotificationService() {
|
|
@@ -1731,9 +1731,11 @@
|
|
|
1731
1731
|
this.send = new i0.EventEmitter();
|
|
1732
1732
|
this.userMentions = new i0.EventEmitter();
|
|
1733
1733
|
this.subscriptions = [];
|
|
1734
|
+
this.unpropagatedChanges = [];
|
|
1734
1735
|
}
|
|
1735
1736
|
TextareaDirective.prototype.ngOnChanges = function (changes) {
|
|
1736
1737
|
var _this = this;
|
|
1738
|
+
this.unpropagatedChanges.push(changes);
|
|
1737
1739
|
if (!this.componentRef) {
|
|
1738
1740
|
return;
|
|
1739
1741
|
}
|
|
@@ -1745,6 +1747,11 @@
|
|
|
1745
1747
|
if (this.componentRef.instance.userMentions) {
|
|
1746
1748
|
this.subscriptions.push(this.componentRef.instance.userMentions.subscribe(function (value) { return _this.userMentions.next(value); }));
|
|
1747
1749
|
}
|
|
1750
|
+
this.componentRef.instance.areMentionsEnabled = this.areMentionsEnabled;
|
|
1751
|
+
this.componentRef.instance.mentionAutocompleteItemTemplate =
|
|
1752
|
+
this.mentionAutocompleteItemTemplate;
|
|
1753
|
+
this.componentRef.instance.mentionScope = this.mentionScope;
|
|
1754
|
+
this.componentRef.instance.value = this.value;
|
|
1748
1755
|
}
|
|
1749
1756
|
}
|
|
1750
1757
|
if (changes.areMentionsEnabled) {
|
|
@@ -1761,8 +1768,11 @@
|
|
|
1761
1768
|
this.componentRef.instance.value = this.value;
|
|
1762
1769
|
}
|
|
1763
1770
|
// ngOnChanges not called for dynamic components since we don't use template binding
|
|
1771
|
+
var changesToPropagate = {};
|
|
1772
|
+
this.unpropagatedChanges.forEach(function (c) { return (changesToPropagate = Object.assign(Object.assign({}, changesToPropagate), c)); });
|
|
1764
1773
|
// eslint-disable-next-line @angular-eslint/no-lifecycle-call
|
|
1765
|
-
this.componentRef.instance.ngOnChanges(
|
|
1774
|
+
this.componentRef.instance.ngOnChanges(changesToPropagate);
|
|
1775
|
+
this.unpropagatedChanges = [];
|
|
1766
1776
|
};
|
|
1767
1777
|
return TextareaDirective;
|
|
1768
1778
|
}());
|
|
@@ -1868,24 +1878,13 @@
|
|
|
1868
1878
|
this.textareaValue = '';
|
|
1869
1879
|
this.mentionedUsers = [];
|
|
1870
1880
|
this.subscriptions = [];
|
|
1881
|
+
this.isViewInited = false;
|
|
1871
1882
|
this.subscriptions.push(this.attachmentService.attachmentUploadInProgressCounter$.subscribe(function (counter) {
|
|
1872
1883
|
if (counter === 0 && _this.hideNotification) {
|
|
1873
1884
|
_this.hideNotification();
|
|
1874
1885
|
_this.hideNotification = undefined;
|
|
1875
1886
|
}
|
|
1876
1887
|
}));
|
|
1877
|
-
this.attachmentUploads$ = this.attachmentService.attachmentUploads$;
|
|
1878
|
-
this.isFileUploadEnabled = this.configService.isFileUploadEnabled;
|
|
1879
|
-
this.acceptedFileTypes = this.configService.acceptedFileTypes;
|
|
1880
|
-
this.isMultipleFileUploadEnabled =
|
|
1881
|
-
this.configService.isMultipleFileUploadEnabled;
|
|
1882
|
-
this.areMentionsEnabled = this.configService.areMentionsEnabled;
|
|
1883
|
-
this.mentionAutocompleteItemTemplate =
|
|
1884
|
-
this.configService.mentionAutocompleteItemTemplate;
|
|
1885
|
-
this.mentionScope = this.configService.mentionScope;
|
|
1886
|
-
}
|
|
1887
|
-
MessageInputComponent.prototype.ngOnInit = function () {
|
|
1888
|
-
var _this = this;
|
|
1889
1888
|
this.subscriptions.push(this.channelService.activeChannel$.subscribe(function (channel) {
|
|
1890
1889
|
var _a;
|
|
1891
1890
|
_this.textareaValue = '';
|
|
@@ -1896,12 +1895,24 @@
|
|
|
1896
1895
|
capabilities.indexOf('upload-file') !== -1;
|
|
1897
1896
|
_this.canSendLinks = capabilities.indexOf('send-links') !== -1;
|
|
1898
1897
|
_this.canSendMessages = capabilities.indexOf('send-message') !== -1;
|
|
1899
|
-
_this.
|
|
1900
|
-
|
|
1898
|
+
if (_this.isViewInited) {
|
|
1899
|
+
_this.cdRef.detectChanges();
|
|
1900
|
+
_this.initTextarea();
|
|
1901
|
+
}
|
|
1901
1902
|
}
|
|
1902
1903
|
}));
|
|
1903
|
-
|
|
1904
|
+
this.attachmentUploads$ = this.attachmentService.attachmentUploads$;
|
|
1905
|
+
this.isFileUploadEnabled = this.configService.isFileUploadEnabled;
|
|
1906
|
+
this.acceptedFileTypes = this.configService.acceptedFileTypes;
|
|
1907
|
+
this.isMultipleFileUploadEnabled =
|
|
1908
|
+
this.configService.isMultipleFileUploadEnabled;
|
|
1909
|
+
this.areMentionsEnabled = this.configService.areMentionsEnabled;
|
|
1910
|
+
this.mentionAutocompleteItemTemplate =
|
|
1911
|
+
this.configService.mentionAutocompleteItemTemplate;
|
|
1912
|
+
this.mentionScope = this.configService.mentionScope;
|
|
1913
|
+
}
|
|
1904
1914
|
MessageInputComponent.prototype.ngAfterViewInit = function () {
|
|
1915
|
+
this.isViewInited = true;
|
|
1905
1916
|
this.initTextarea();
|
|
1906
1917
|
};
|
|
1907
1918
|
MessageInputComponent.prototype.ngOnChanges = function (changes) {
|
|
@@ -2179,6 +2190,7 @@
|
|
|
2179
2190
|
|
|
2180
2191
|
var MessageActionsBoxComponent = /** @class */ (function () {
|
|
2181
2192
|
function MessageActionsBoxComponent(chatClientService, notificationService, channelService) {
|
|
2193
|
+
var _this = this;
|
|
2182
2194
|
this.chatClientService = chatClientService;
|
|
2183
2195
|
this.notificationService = notificationService;
|
|
2184
2196
|
this.channelService = channelService;
|
|
@@ -2188,6 +2200,10 @@
|
|
|
2188
2200
|
this.displayedActionsCount = new i0.EventEmitter();
|
|
2189
2201
|
this.isEditing = new i0.EventEmitter();
|
|
2190
2202
|
this.isEditModalOpen = false;
|
|
2203
|
+
this.modalClosed = function () {
|
|
2204
|
+
_this.isEditModalOpen = false;
|
|
2205
|
+
_this.isEditing.emit(false);
|
|
2206
|
+
};
|
|
2191
2207
|
}
|
|
2192
2208
|
MessageActionsBoxComponent.prototype.ngOnChanges = function (changes) {
|
|
2193
2209
|
if (changes.isMine || changes.enabledActions) {
|
|
@@ -2295,10 +2311,6 @@
|
|
|
2295
2311
|
var _a;
|
|
2296
2312
|
(_a = this.messageInput) === null || _a === void 0 ? void 0 : _a.messageSent();
|
|
2297
2313
|
};
|
|
2298
|
-
MessageActionsBoxComponent.prototype.modalClosed = function () {
|
|
2299
|
-
this.isEditModalOpen = false;
|
|
2300
|
-
this.isEditing.emit(false);
|
|
2301
|
-
};
|
|
2302
2314
|
MessageActionsBoxComponent.prototype.deleteClicked = function () {
|
|
2303
2315
|
return __awaiter(this, void 0, void 0, function () {
|
|
2304
2316
|
var error_1;
|
|
@@ -2322,7 +2334,7 @@
|
|
|
2322
2334
|
return MessageActionsBoxComponent;
|
|
2323
2335
|
}());
|
|
2324
2336
|
MessageActionsBoxComponent.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0__namespace, type: MessageActionsBoxComponent, deps: [{ token: ChatClientService }, { token: NotificationService }, { token: ChannelService }], target: i0__namespace.ɵɵFactoryTarget.Component });
|
|
2325
|
-
MessageActionsBoxComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.5", type: MessageActionsBoxComponent, selector: "stream-message-actions-box", inputs: { isOpen: "isOpen", isMine: "isMine", message: "message", enabledActions: "enabledActions" }, outputs: { displayedActionsCount: "displayedActionsCount", isEditing: "isEditing" }, viewQueries: [{ propertyName: "messageInput", first: true, predicate: MessageInputComponent, descendants: true }], usesOnChanges: true, ngImport: i0__namespace, template: "<div\n data-testid=\"action-box\"\n class=\"str-chat__message-actions-box\"\n [class.str-chat__message-actions-box--open]=\"isOpen\"\n [class.str-chat__message-actions-box--mine]=\"isMine\"\n>\n <ul class=\"str-chat__message-actions-list\">\n <button\n data-testid=\"quote-action\"\n *ngIf=\"isQuoteVisible\"\n (click)=\"quoteClicked()\"\n >\n <li class=\"str-chat__message-actions-list-item\">\n {{ \"streamChat.Reply\" | translate }}\n </li>\n </button>\n <button\n data-testid=\"pin-action\"\n *ngIf=\"isPinVisible\"\n (click)=\"pinClicked()\"\n >\n <li class=\"str-chat__message-actions-list-item\">\n {{\n (message?.pinned ? \"streamChat.Unpin\" : \"streamChat.Pin\") | translate\n }}\n </li>\n </button>\n <button\n data-testid=\"flag-action\"\n *ngIf=\"isFlagVisible\"\n (click)=\"flagClicked()\"\n >\n <li class=\"str-chat__message-actions-list-item\">\n {{ \"streamChat.Flag\" | translate }}\n </li>\n </button>\n <button\n data-testid=\"mute-action\"\n *ngIf=\"isMuteVisible\"\n (click)=\"muteClicked()\"\n >\n <li class=\"str-chat__message-actions-list-item\">\n {{ \"streamChat.Mute\" | translate }}\n </li>\n </button>\n <button\n data-testid=\"edit-action\"\n *ngIf=\"isEditVisible\"\n (click)=\"editClicked()\"\n >\n <li class=\"str-chat__message-actions-list-item\">\n {{ \"streamChat.Edit Message\" | translate }}\n </li>\n </button>\n <button\n data-testid=\"delete-action\"\n *ngIf=\"isDeleteVisible\"\n (click)=\"deleteClicked()\"\n >\n <li class=\"str-chat__message-actions-list-item\">\n {{ \"streamChat.Delete\" | translate }}\n </li>\n </button>\n </ul>\n</div>\n\n<stream-modal\n [isOpen]=\"isEditModalOpen\"\n (isOpenChange)=\"\n isEditModalOpen = $event; isEditModalOpen ? '' : modalClosed()\n \"\n>\n <div class=\"str-chat__edit-message-form\" *ngIf=\"isEditModalOpen\">\n <stream-message-input\n
|
|
2337
|
+
MessageActionsBoxComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.5", type: MessageActionsBoxComponent, selector: "stream-message-actions-box", inputs: { messageInputTemplate: "messageInputTemplate", isOpen: "isOpen", isMine: "isMine", message: "message", enabledActions: "enabledActions" }, outputs: { displayedActionsCount: "displayedActionsCount", isEditing: "isEditing" }, viewQueries: [{ propertyName: "messageInput", first: true, predicate: MessageInputComponent, descendants: true }], usesOnChanges: true, ngImport: i0__namespace, template: "<div\n data-testid=\"action-box\"\n class=\"str-chat__message-actions-box\"\n [class.str-chat__message-actions-box--open]=\"isOpen\"\n [class.str-chat__message-actions-box--mine]=\"isMine\"\n>\n <ul class=\"str-chat__message-actions-list\">\n <button\n data-testid=\"quote-action\"\n *ngIf=\"isQuoteVisible\"\n (click)=\"quoteClicked()\"\n >\n <li class=\"str-chat__message-actions-list-item\">\n {{ \"streamChat.Reply\" | translate }}\n </li>\n </button>\n <button\n data-testid=\"pin-action\"\n *ngIf=\"isPinVisible\"\n (click)=\"pinClicked()\"\n >\n <li class=\"str-chat__message-actions-list-item\">\n {{\n (message?.pinned ? \"streamChat.Unpin\" : \"streamChat.Pin\") | translate\n }}\n </li>\n </button>\n <button\n data-testid=\"flag-action\"\n *ngIf=\"isFlagVisible\"\n (click)=\"flagClicked()\"\n >\n <li class=\"str-chat__message-actions-list-item\">\n {{ \"streamChat.Flag\" | translate }}\n </li>\n </button>\n <button\n data-testid=\"mute-action\"\n *ngIf=\"isMuteVisible\"\n (click)=\"muteClicked()\"\n >\n <li class=\"str-chat__message-actions-list-item\">\n {{ \"streamChat.Mute\" | translate }}\n </li>\n </button>\n <button\n data-testid=\"edit-action\"\n *ngIf=\"isEditVisible\"\n (click)=\"editClicked()\"\n >\n <li class=\"str-chat__message-actions-list-item\">\n {{ \"streamChat.Edit Message\" | translate }}\n </li>\n </button>\n <button\n data-testid=\"delete-action\"\n *ngIf=\"isDeleteVisible\"\n (click)=\"deleteClicked()\"\n >\n <li class=\"str-chat__message-actions-list-item\">\n {{ \"streamChat.Delete\" | translate }}\n </li>\n </button>\n </ul>\n</div>\n\n<stream-modal\n [isOpen]=\"isEditModalOpen\"\n (isOpenChange)=\"\n isEditModalOpen = $event; isEditModalOpen ? '' : modalClosed()\n \"\n>\n <div class=\"str-chat__edit-message-form\" *ngIf=\"isEditModalOpen\">\n <ng-container *ngIf=\"messageInputTemplate; else defaultInput\">\n <ng-container\n *ngTemplateOutlet=\"\n messageInputTemplate;\n context: {\n message: message,\n messageUpdateHandler: modalClosed\n }\n \"\n ></ng-container>\n </ng-container>\n <ng-template #defaultInput>\n <stream-message-input\n [message]=\"message\"\n (messageUpdate)=\"modalClosed()\"\n ></stream-message-input>\n </ng-template>\n <stream-notification-list></stream-notification-list>\n <div class=\"str-chat__message-team-form-footer\">\n <div></div>\n <div>\n <button translate data-testid=\"cancel-button\" (click)=\"modalClosed()\">\n streamChat.Cancel\n </button>\n <button\n type=\"submit\"\n translate\n data-testid=\"send-button\"\n (click)=\"sendClicked()\"\n (keyup.enter)=\"sendClicked()\"\n >\n streamChat.Send\n </button>\n </div>\n </div>\n </div>\n</stream-modal>\n", components: [{ type: ModalComponent, selector: "stream-modal", inputs: ["isOpen"], outputs: ["isOpenChange"] }, { type: MessageInputComponent, selector: "stream-message-input", inputs: ["isFileUploadEnabled", "areMentionsEnabled", "mentionScope", "mentionAutocompleteItemTemplate", "acceptedFileTypes", "isMultipleFileUploadEnabled", "message"], outputs: ["messageUpdate"] }, { type: NotificationListComponent, selector: "stream-notification-list" }], directives: [{ type: i3__namespace.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3__namespace.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i1__namespace.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], pipes: { "translate": i1__namespace.TranslatePipe } });
|
|
2326
2338
|
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0__namespace, type: MessageActionsBoxComponent, decorators: [{
|
|
2327
2339
|
type: i0.Component,
|
|
2328
2340
|
args: [{
|
|
@@ -2330,7 +2342,9 @@
|
|
|
2330
2342
|
templateUrl: './message-actions-box.component.html',
|
|
2331
2343
|
styles: [],
|
|
2332
2344
|
}]
|
|
2333
|
-
}], ctorParameters: function () { return [{ type: ChatClientService }, { type: NotificationService }, { type: ChannelService }]; }, propDecorators: {
|
|
2345
|
+
}], ctorParameters: function () { return [{ type: ChatClientService }, { type: NotificationService }, { type: ChannelService }]; }, propDecorators: { messageInputTemplate: [{
|
|
2346
|
+
type: i0.Input
|
|
2347
|
+
}], isOpen: [{
|
|
2334
2348
|
type: i0.Input
|
|
2335
2349
|
}], isMine: [{
|
|
2336
2350
|
type: i0.Input
|
|
@@ -2880,30 +2894,6 @@
|
|
|
2880
2894
|
type: i0.Input
|
|
2881
2895
|
}] } });
|
|
2882
2896
|
|
|
2883
|
-
var HighlightMentionsPipe = /** @class */ (function () {
|
|
2884
|
-
function HighlightMentionsPipe() {
|
|
2885
|
-
}
|
|
2886
|
-
HighlightMentionsPipe.prototype.transform = function (value, mentionedUsers) {
|
|
2887
|
-
if (!value || !mentionedUsers) {
|
|
2888
|
-
return value || '';
|
|
2889
|
-
}
|
|
2890
|
-
var result = value;
|
|
2891
|
-
mentionedUsers.forEach(function (u) {
|
|
2892
|
-
result = result.replace(new RegExp("@" + (u.name || u.id), 'g'), "<b>@" + (u.name || u.id) + "</b>");
|
|
2893
|
-
});
|
|
2894
|
-
return result;
|
|
2895
|
-
};
|
|
2896
|
-
return HighlightMentionsPipe;
|
|
2897
|
-
}());
|
|
2898
|
-
HighlightMentionsPipe.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0__namespace, type: HighlightMentionsPipe, deps: [], target: i0__namespace.ɵɵFactoryTarget.Pipe });
|
|
2899
|
-
HighlightMentionsPipe.ɵpipe = i0__namespace.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0__namespace, type: HighlightMentionsPipe, name: "highlightMentions" });
|
|
2900
|
-
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0__namespace, type: HighlightMentionsPipe, decorators: [{
|
|
2901
|
-
type: i0.Pipe,
|
|
2902
|
-
args: [{
|
|
2903
|
-
name: 'highlightMentions',
|
|
2904
|
-
}]
|
|
2905
|
-
}] });
|
|
2906
|
-
|
|
2907
2897
|
var MessageComponent = /** @class */ (function () {
|
|
2908
2898
|
function MessageComponent(chatClientService, channelService) {
|
|
2909
2899
|
this.chatClientService = chatClientService;
|
|
@@ -2913,8 +2903,53 @@
|
|
|
2913
2903
|
this.isReactionSelectorOpen = false;
|
|
2914
2904
|
this.isPressedOnMobile = false;
|
|
2915
2905
|
this.visibleMessageActionsCount = 0;
|
|
2906
|
+
this.messageTextParts = [];
|
|
2916
2907
|
this.user = this.chatClientService.chatClient.user;
|
|
2917
2908
|
}
|
|
2909
|
+
MessageComponent.prototype.ngOnChanges = function (changes) {
|
|
2910
|
+
var _this = this;
|
|
2911
|
+
var _a, _b;
|
|
2912
|
+
if (changes.message) {
|
|
2913
|
+
var content = ((_a = this.message) === null || _a === void 0 ? void 0 : _a.html) || ((_b = this.message) === null || _b === void 0 ? void 0 : _b.text);
|
|
2914
|
+
if (!content) {
|
|
2915
|
+
this.messageTextParts = [];
|
|
2916
|
+
}
|
|
2917
|
+
else {
|
|
2918
|
+
// Backend will wrap HTML content with <p></p>\n
|
|
2919
|
+
if (content.startsWith('<p>')) {
|
|
2920
|
+
content = content.replace('<p>', '');
|
|
2921
|
+
}
|
|
2922
|
+
if (content.endsWith('</p>\n')) {
|
|
2923
|
+
content = content.replace('</p>\n', '');
|
|
2924
|
+
}
|
|
2925
|
+
if (!this.message.mentioned_users ||
|
|
2926
|
+
this.message.mentioned_users.length === 0) {
|
|
2927
|
+
this.messageTextParts = [{ content: content, type: 'text' }];
|
|
2928
|
+
}
|
|
2929
|
+
else {
|
|
2930
|
+
this.messageTextParts = [];
|
|
2931
|
+
var text_1 = content;
|
|
2932
|
+
this.message.mentioned_users.forEach(function (user) {
|
|
2933
|
+
var mention = "@" + (user.name || user.id);
|
|
2934
|
+
var precedingText = text_1.substring(0, text_1.indexOf(mention));
|
|
2935
|
+
_this.messageTextParts.push({
|
|
2936
|
+
content: precedingText,
|
|
2937
|
+
type: 'text',
|
|
2938
|
+
});
|
|
2939
|
+
_this.messageTextParts.push({
|
|
2940
|
+
content: mention,
|
|
2941
|
+
type: 'mention',
|
|
2942
|
+
user: user,
|
|
2943
|
+
});
|
|
2944
|
+
text_1 = text_1.replace(precedingText + mention, '');
|
|
2945
|
+
});
|
|
2946
|
+
if (text_1) {
|
|
2947
|
+
this.messageTextParts.push({ content: text_1, type: 'text' });
|
|
2948
|
+
}
|
|
2949
|
+
}
|
|
2950
|
+
}
|
|
2951
|
+
}
|
|
2952
|
+
};
|
|
2918
2953
|
Object.defineProperty(MessageComponent.prototype, "isSentByCurrentUser", {
|
|
2919
2954
|
get: function () {
|
|
2920
2955
|
var _a, _b, _c;
|
|
@@ -3031,7 +3066,7 @@
|
|
|
3031
3066
|
return MessageComponent;
|
|
3032
3067
|
}());
|
|
3033
3068
|
MessageComponent.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0__namespace, type: MessageComponent, deps: [{ token: ChatClientService }, { token: ChannelService }], target: i0__namespace.ɵɵFactoryTarget.Component });
|
|
3034
|
-
MessageComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.5", type: MessageComponent, selector: "stream-message", inputs: { message: "message", enabledMessageActions: "enabledMessageActions", areReactionsEnabled: "areReactionsEnabled", canReactToMessage: "canReactToMessage", isLastSentMessage: "isLastSentMessage", canReceiveReadEvents: "canReceiveReadEvents" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], ngImport: i0__namespace, template: "<div\n #container\n class=\"str-chat__message-simple str-chat__message str-chat__message--{{\n message?.type\n }} str-chat__message--{{ message?.status }} {{\n message?.text ? 'str-chat__message--has-text' : 'has-no-text'\n }}\"\n [class.str-chat__message--me]=\"isSentByCurrentUser\"\n [class.str-chat__message-simple--me]=\"isSentByCurrentUser\"\n [class.mobile-press]=\"isPressedOnMobile\"\n [class.str-chat__message--has-attachment]=\"hasAttachment\"\n [class.str-chat__message--with-reactions]=\"\n areReactionsEnabled && hasReactions\n \"\n data-testid=\"message-container\"\n>\n <ng-container *ngIf=\"!message?.deleted_at; else deletedMessage\">\n <ng-container *ngIf=\"message?.type !== 'system'; else systemMessage\">\n <ng-container\n *ngIf=\"\n isSentByCurrentUser &&\n ((isLastSentMessage && message?.status === 'received') ||\n message?.status === 'sending')\n \"\n >\n <ng-container *ngIf=\"message?.status === 'sending'; else sentStatus\">\n <ng-container *ngTemplateOutlet=\"sendingStatus\"></ng-container>\n </ng-container>\n <ng-template #sentStatus>\n <ng-container\n *ngIf=\"\n isMessageDeliveredAndRead && canReceiveReadEvents;\n else deliveredStatus\n \"\n >\n <ng-container *ngTemplateOutlet=\"readStatus\"></ng-container>\n </ng-container>\n </ng-template>\n </ng-container>\n <stream-avatar\n data-testid=\"avatar\"\n class=\"str-chat-angular__avatar-host\"\n [imageUrl]=\"message?.user?.image\"\n [name]=\"message?.user?.name || message?.user?.id\"\n ></stream-avatar>\n <div class=\"str-chat__message-inner\">\n <div\n class=\"str-chat__message-simple__actions\"\n data-testid=\"message-options\"\n *ngIf=\"areOptionsVisible\"\n >\n <div\n data-testid=\"message-actions-container\"\n class=\"\n str-chat__message-simple__actions__action\n str-chat__message-simple__actions__action--options\n \"\n [class.str-chat-angular__message-simple__actions__action--options--editing]=\"\n isEditing\n \"\n >\n <stream-message-actions-box\n [isOpen]=\"isActionBoxOpen\"\n [isMine]=\"isSentByCurrentUser\"\n [enabledActions]=\"enabledMessageActions\"\n [message]=\"message\"\n (displayedActionsCount)=\"visibleMessageActionsCount = $event\"\n (isEditing)=\"isEditing = $event; isActionBoxOpen = !isEditing\"\n ></stream-message-actions-box>\n <stream-icon\n *ngIf=\"visibleMessageActionsCount > 0\"\n data-testid=\"action-icon\"\n icon=\"action-icon\"\n (keyup.enter)=\"isActionBoxOpen = !isActionBoxOpen\"\n (click)=\"isActionBoxOpen = !isActionBoxOpen\"\n ></stream-icon>\n </div>\n <div\n *ngIf=\"areReactionsEnabled && canReactToMessage\"\n class=\"\n str-chat__message-simple__actions__action\n str-chat__message-simple__actions__action--reactions\n \"\n data-testid=\"reaction-icon\"\n (click)=\"isReactionSelectorOpen = !isReactionSelectorOpen\"\n (keyup.enter)=\"isReactionSelectorOpen = !isReactionSelectorOpen\"\n >\n <stream-icon icon=\"reaction-icon\"></stream-icon>\n </div>\n </div>\n <stream-message-reactions\n *ngIf=\"areReactionsEnabled\"\n [messageReactionCounts]=\"message?.reaction_counts || {}\"\n [latestReactions]=\"message?.latest_reactions || []\"\n [(isSelectorOpen)]=\"isReactionSelectorOpen\"\n [messageId]=\"message?.id\"\n [ownReactions]=\"message?.own_reactions || []\"\n ></stream-message-reactions>\n <stream-attachment-list\n *ngIf=\"hasAttachment\"\n [attachments]=\"message!.attachments!\"\n ></stream-attachment-list>\n <div class=\"str-chat__message-text\" *ngIf=\"message?.text\">\n <div\n data-testid=\"inner-message\"\n class=\"\n str-chat__message-text-inner str-chat__message-simple-text-inner\n \"\n [class.str-chat__message-light-text-inner--has-attachment]=\"\n hasAttachment\n \"\n (click)=\"\n message?.status === 'failed' && message?.errorStatusCode !== 403\n ? resendMessage()\n : undefined\n \"\n (keyup.enter)=\"\n message?.status === 'failed' && message?.errorStatusCode !== 403\n ? resendMessage()\n : undefined\n \"\n >\n <div\n data-testid=\"client-error-message\"\n *ngIf=\"message?.type === 'error'\"\n class=\"str-chat__simple-message--error-message\"\n >\n {{ \"streamChat.Error \u00B7 Unsent\" | translate }}\n </div>\n <div\n data-testid=\"error-message\"\n *ngIf=\"message?.status === 'failed'\"\n class=\"str-chat__simple-message--error-message\"\n >\n {{\n (message?.errorStatusCode === 403\n ? \"streamChat.Message Failed \u00B7 Unauthorized\"\n : \"streamChat.Message Failed \u00B7 Click to try again\"\n ) | translate\n }}\n </div>\n <div\n (click)=\"textClicked()\"\n (keyup.enter)=\"textClicked()\"\n data-testid=\"text\"\n [innerHTML]=\"\n message?.html || message?.text\n | highlightMentions: message?.mentioned_users\n \"\n ></div>\n </div>\n </div>\n <div class=\"str-chat__message-data str-chat__message-simple-data\">\n <span\n data-testid=\"sender\"\n *ngIf=\"!isSentByCurrentUser\"\n class=\"str-chat__message-simple-name\"\n >\n {{ message?.user?.name ? message?.user?.name : message?.user?.id }}\n </span>\n <span data-testid=\"date\" class=\"str-chat__message-simple-timestamp\">\n {{ parsedDate }}\n </span>\n </div>\n </div>\n </ng-container>\n </ng-container>\n</div>\n\n<ng-template #sendingStatus>\n <span class=\"str-chat__message-simple-status\" data-testid=\"sending-indicator\">\n <div class=\"str-chat__tooltip\">\n {{ \"streamChat.Sending...\" | translate }}\n </div>\n <stream-loading-indicator\n data-testid=\"loading-indicator\"\n ></stream-loading-indicator>\n </span>\n</ng-template>\n<ng-template #readStatus>\n <span class=\"str-chat__message-simple-status\" data-testid=\"read-indicator\">\n <div class=\"str-chat__tooltip\" data-testid=\"read-by-tooltip\">\n {{ readByText }}\n </div>\n <stream-avatar\n class=\"str-chat-angular__avatar-host\"\n data-test-id=\"last-read-user-avatar\"\n [size]=\"15\"\n [imageUrl]=\"lastReadUser?.image\"\n [name]=\"lastReadUser?.name || lastReadUser?.id\"\n ></stream-avatar>\n <span\n data-test-id=\"read-by-length\"\n *ngIf=\"isReadByMultipleUsers\"\n class=\"str-chat__message-simple-status-number\"\n >\n {{ (message?.readBy)!.length }}\n </span>\n </span>\n</ng-template>\n<ng-template #deliveredStatus>\n <span\n class=\"str-chat__message-simple-status\"\n data-testid=\"delivered-indicator\"\n >\n <div class=\"str-chat__tooltip\">\n {{ \"streamChat.Delivered\" | translate }}\n </div>\n <stream-icon\n data-testid=\"delivered-icon\"\n icon=\"delivered-icon\"\n ></stream-icon>\n </span>\n</ng-template>\n\n<ng-template #deletedMessage>\n <div data-testid=\"message-deleted-component\">\n <div class=\"str-chat__message--deleted-inner\" translate>\n streamChat.This message was deleted...\n </div>\n </div>\n</ng-template>\n\n<ng-template #systemMessage>\n <div data-testid=\"system-message\" class=\"str-chat__message--system\">\n <div class=\"str-chat__message--system__text\">\n <div class=\"str-chat__message--system__line\"></div>\n <p>{{ message?.text }}</p>\n <div class=\"str-chat__message--system__line\"></div>\n </div>\n <div class=\"str-chat__message--system__date\">\n {{ parsedDate }}\n </div>\n </div>\n</ng-template>\n", components: [{ type: AvatarComponent, selector: "stream-avatar", inputs: ["name", "imageUrl", "size"] }, { type: MessageActionsBoxComponent, selector: "stream-message-actions-box", inputs: ["isOpen", "isMine", "message", "enabledActions"], outputs: ["displayedActionsCount", "isEditing"] }, { type: IconComponent, selector: "stream-icon", inputs: ["icon", "size"] }, { type: MessageReactionsComponent, selector: "stream-message-reactions", inputs: ["messageId", "messageReactionCounts", "isSelectorOpen", "latestReactions", "ownReactions"], outputs: ["isSelectorOpenChange"] }, { type: AttachmentListComponent, selector: "stream-attachment-list", inputs: ["attachments"] }, { type: LoadingIndicatorComponent, selector: "stream-loading-indicator", inputs: ["size", "color"] }], directives: [{ type: i3__namespace.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3__namespace.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i1__namespace.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], pipes: { "translate": i1__namespace.TranslatePipe, "highlightMentions": HighlightMentionsPipe } });
|
|
3069
|
+
MessageComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.5", type: MessageComponent, selector: "stream-message", inputs: { messageInputTemplate: "messageInputTemplate", mentionTemplate: "mentionTemplate", message: "message", enabledMessageActions: "enabledMessageActions", areReactionsEnabled: "areReactionsEnabled", canReactToMessage: "canReactToMessage", isLastSentMessage: "isLastSentMessage", canReceiveReadEvents: "canReceiveReadEvents" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0__namespace, template: "<div\n #container\n class=\"str-chat__message-simple str-chat__message str-chat__message--{{\n message?.type\n }} str-chat__message--{{ message?.status }} {{\n message?.text ? 'str-chat__message--has-text' : 'has-no-text'\n }}\"\n [class.str-chat__message--me]=\"isSentByCurrentUser\"\n [class.str-chat__message-simple--me]=\"isSentByCurrentUser\"\n [class.mobile-press]=\"isPressedOnMobile\"\n [class.str-chat__message--has-attachment]=\"hasAttachment\"\n [class.str-chat__message--with-reactions]=\"\n areReactionsEnabled && hasReactions\n \"\n data-testid=\"message-container\"\n>\n <ng-container *ngIf=\"!message?.deleted_at; else deletedMessage\">\n <ng-container *ngIf=\"message?.type !== 'system'; else systemMessage\">\n <ng-container\n *ngIf=\"\n isSentByCurrentUser &&\n ((isLastSentMessage && message?.status === 'received') ||\n message?.status === 'sending')\n \"\n >\n <ng-container *ngIf=\"message?.status === 'sending'; else sentStatus\">\n <ng-container *ngTemplateOutlet=\"sendingStatus\"></ng-container>\n </ng-container>\n <ng-template #sentStatus>\n <ng-container\n *ngIf=\"\n isMessageDeliveredAndRead && canReceiveReadEvents;\n else deliveredStatus\n \"\n >\n <ng-container *ngTemplateOutlet=\"readStatus\"></ng-container>\n </ng-container>\n </ng-template>\n </ng-container>\n <stream-avatar\n data-testid=\"avatar\"\n class=\"str-chat-angular__avatar-host\"\n [imageUrl]=\"message?.user?.image\"\n [name]=\"message?.user?.name || message?.user?.id\"\n ></stream-avatar>\n <div class=\"str-chat__message-inner\">\n <div\n class=\"str-chat__message-simple__actions\"\n data-testid=\"message-options\"\n *ngIf=\"areOptionsVisible\"\n >\n <div\n data-testid=\"message-actions-container\"\n class=\"\n str-chat__message-simple__actions__action\n str-chat__message-simple__actions__action--options\n \"\n [class.str-chat-angular__message-simple__actions__action--options--editing]=\"\n isEditing\n \"\n >\n <stream-message-actions-box\n [isOpen]=\"isActionBoxOpen\"\n [isMine]=\"isSentByCurrentUser\"\n [enabledActions]=\"enabledMessageActions\"\n [message]=\"message\"\n (displayedActionsCount)=\"visibleMessageActionsCount = $event\"\n (isEditing)=\"isEditing = $event; isActionBoxOpen = !isEditing\"\n [messageInputTemplate]=\"messageInputTemplate\"\n ></stream-message-actions-box>\n <stream-icon\n *ngIf=\"visibleMessageActionsCount > 0\"\n data-testid=\"action-icon\"\n icon=\"action-icon\"\n (keyup.enter)=\"isActionBoxOpen = !isActionBoxOpen\"\n (click)=\"isActionBoxOpen = !isActionBoxOpen\"\n ></stream-icon>\n </div>\n <div\n *ngIf=\"areReactionsEnabled && canReactToMessage\"\n class=\"\n str-chat__message-simple__actions__action\n str-chat__message-simple__actions__action--reactions\n \"\n data-testid=\"reaction-icon\"\n (click)=\"isReactionSelectorOpen = !isReactionSelectorOpen\"\n (keyup.enter)=\"isReactionSelectorOpen = !isReactionSelectorOpen\"\n >\n <stream-icon icon=\"reaction-icon\"></stream-icon>\n </div>\n </div>\n <stream-message-reactions\n *ngIf=\"areReactionsEnabled\"\n [messageReactionCounts]=\"message?.reaction_counts || {}\"\n [latestReactions]=\"message?.latest_reactions || []\"\n [(isSelectorOpen)]=\"isReactionSelectorOpen\"\n [messageId]=\"message?.id\"\n [ownReactions]=\"message?.own_reactions || []\"\n ></stream-message-reactions>\n <stream-attachment-list\n *ngIf=\"hasAttachment\"\n [attachments]=\"message!.attachments!\"\n ></stream-attachment-list>\n <div class=\"str-chat__message-text\" *ngIf=\"message?.text\">\n <div\n data-testid=\"inner-message\"\n class=\"\n str-chat__message-text-inner str-chat__message-simple-text-inner\n \"\n [class.str-chat__message-light-text-inner--has-attachment]=\"\n hasAttachment\n \"\n (click)=\"\n message?.status === 'failed' && message?.errorStatusCode !== 403\n ? resendMessage()\n : undefined\n \"\n (keyup.enter)=\"\n message?.status === 'failed' && message?.errorStatusCode !== 403\n ? resendMessage()\n : undefined\n \"\n >\n <div\n data-testid=\"client-error-message\"\n *ngIf=\"message?.type === 'error'\"\n class=\"str-chat__simple-message--error-message\"\n >\n {{ \"streamChat.Error \u00B7 Unsent\" | translate }}\n </div>\n <div\n data-testid=\"error-message\"\n *ngIf=\"message?.status === 'failed'\"\n class=\"str-chat__simple-message--error-message\"\n >\n {{\n (message?.errorStatusCode === 403\n ? \"streamChat.Message Failed \u00B7 Unauthorized\"\n : \"streamChat.Message Failed \u00B7 Click to try again\"\n ) | translate\n }}\n </div>\n <div\n (click)=\"textClicked()\"\n (keyup.enter)=\"textClicked()\"\n data-testid=\"text\"\n >\n <p>\n <!-- eslint-disable-next-line @angular-eslint/template/use-track-by-function -->\n <ng-container *ngFor=\"let part of messageTextParts\">\n <span\n *ngIf=\"part.type === 'text'; else mention\"\n [innerHTML]=\"part.content\"\n ></span>\n <ng-template #mention>\n <ng-container *ngIf=\"mentionTemplate; else defaultMention\">\n <ng-container\n *ngTemplateOutlet=\"\n mentionTemplate;\n context: { user: part.user! }\n \"\n ></ng-container>\n </ng-container>\n <ng-template #defaultMention>\n <b>{{ part.content }}</b>\n </ng-template>\n </ng-template>\n </ng-container>\n </p>\n </div>\n </div>\n </div>\n <div class=\"str-chat__message-data str-chat__message-simple-data\">\n <span\n data-testid=\"sender\"\n *ngIf=\"!isSentByCurrentUser\"\n class=\"str-chat__message-simple-name\"\n >\n {{ message?.user?.name ? message?.user?.name : message?.user?.id }}\n </span>\n <span data-testid=\"date\" class=\"str-chat__message-simple-timestamp\">\n {{ parsedDate }}\n </span>\n </div>\n </div>\n </ng-container>\n </ng-container>\n</div>\n\n<ng-template #sendingStatus>\n <span class=\"str-chat__message-simple-status\" data-testid=\"sending-indicator\">\n <div class=\"str-chat__tooltip\">\n {{ \"streamChat.Sending...\" | translate }}\n </div>\n <stream-loading-indicator\n data-testid=\"loading-indicator\"\n ></stream-loading-indicator>\n </span>\n</ng-template>\n<ng-template #readStatus>\n <span class=\"str-chat__message-simple-status\" data-testid=\"read-indicator\">\n <div class=\"str-chat__tooltip\" data-testid=\"read-by-tooltip\">\n {{ readByText }}\n </div>\n <stream-avatar\n class=\"str-chat-angular__avatar-host\"\n data-test-id=\"last-read-user-avatar\"\n [size]=\"15\"\n [imageUrl]=\"lastReadUser?.image\"\n [name]=\"lastReadUser?.name || lastReadUser?.id\"\n ></stream-avatar>\n <span\n data-test-id=\"read-by-length\"\n *ngIf=\"isReadByMultipleUsers\"\n class=\"str-chat__message-simple-status-number\"\n >\n {{ (message?.readBy)!.length }}\n </span>\n </span>\n</ng-template>\n<ng-template #deliveredStatus>\n <span\n class=\"str-chat__message-simple-status\"\n data-testid=\"delivered-indicator\"\n >\n <div class=\"str-chat__tooltip\">\n {{ \"streamChat.Delivered\" | translate }}\n </div>\n <stream-icon\n data-testid=\"delivered-icon\"\n icon=\"delivered-icon\"\n ></stream-icon>\n </span>\n</ng-template>\n\n<ng-template #deletedMessage>\n <div data-testid=\"message-deleted-component\">\n <div class=\"str-chat__message--deleted-inner\" translate>\n streamChat.This message was deleted...\n </div>\n </div>\n</ng-template>\n\n<ng-template #systemMessage>\n <div data-testid=\"system-message\" class=\"str-chat__message--system\">\n <div class=\"str-chat__message--system__text\">\n <div class=\"str-chat__message--system__line\"></div>\n <p>{{ message?.text }}</p>\n <div class=\"str-chat__message--system__line\"></div>\n </div>\n <div class=\"str-chat__message--system__date\">\n {{ parsedDate }}\n </div>\n </div>\n</ng-template>\n", components: [{ type: AvatarComponent, selector: "stream-avatar", inputs: ["name", "imageUrl", "size"] }, { type: MessageActionsBoxComponent, selector: "stream-message-actions-box", inputs: ["messageInputTemplate", "isOpen", "isMine", "message", "enabledActions"], outputs: ["displayedActionsCount", "isEditing"] }, { type: IconComponent, selector: "stream-icon", inputs: ["icon", "size"] }, { type: MessageReactionsComponent, selector: "stream-message-reactions", inputs: ["messageId", "messageReactionCounts", "isSelectorOpen", "latestReactions", "ownReactions"], outputs: ["isSelectorOpenChange"] }, { type: AttachmentListComponent, selector: "stream-attachment-list", inputs: ["attachments"] }, { type: LoadingIndicatorComponent, selector: "stream-loading-indicator", inputs: ["size", "color"] }], directives: [{ type: i3__namespace.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3__namespace.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i3__namespace.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1__namespace.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], pipes: { "translate": i1__namespace.TranslatePipe } });
|
|
3035
3070
|
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0__namespace, type: MessageComponent, decorators: [{
|
|
3036
3071
|
type: i0.Component,
|
|
3037
3072
|
args: [{
|
|
@@ -3039,7 +3074,11 @@
|
|
|
3039
3074
|
templateUrl: './message.component.html',
|
|
3040
3075
|
styles: [],
|
|
3041
3076
|
}]
|
|
3042
|
-
}], ctorParameters: function () { return [{ type: ChatClientService }, { type: ChannelService }]; }, propDecorators: {
|
|
3077
|
+
}], ctorParameters: function () { return [{ type: ChatClientService }, { type: ChannelService }]; }, propDecorators: { messageInputTemplate: [{
|
|
3078
|
+
type: i0.Input
|
|
3079
|
+
}], mentionTemplate: [{
|
|
3080
|
+
type: i0.Input
|
|
3081
|
+
}], message: [{
|
|
3043
3082
|
type: i0.Input
|
|
3044
3083
|
}], enabledMessageActions: [{
|
|
3045
3084
|
type: i0.Input
|
|
@@ -3135,6 +3174,7 @@
|
|
|
3135
3174
|
triggerChar: this.triggerChar,
|
|
3136
3175
|
dropUp: true,
|
|
3137
3176
|
labelKey: this.labelKey,
|
|
3177
|
+
returnTrigger: true,
|
|
3138
3178
|
mentionFilter: function (searchString, items) { return _this.filter(searchString, items); },
|
|
3139
3179
|
mentionSelect: function (item, triggerChar) { return _this.mentioned(item, triggerChar); },
|
|
3140
3180
|
};
|
|
@@ -3174,7 +3214,12 @@
|
|
|
3174
3214
|
return triggerChar + item.autocompleteLabel;
|
|
3175
3215
|
};
|
|
3176
3216
|
AutocompleteTextareaComponent.prototype.autcompleteSearchTermChanged = function (searchTerm) {
|
|
3177
|
-
this.
|
|
3217
|
+
if (searchTerm === this.triggerChar) {
|
|
3218
|
+
void this.updateMentionOptions();
|
|
3219
|
+
}
|
|
3220
|
+
else {
|
|
3221
|
+
this.searchTerm$.next(searchTerm.replace(this.triggerChar, ''));
|
|
3222
|
+
}
|
|
3178
3223
|
};
|
|
3179
3224
|
AutocompleteTextareaComponent.prototype.inputChanged = function () {
|
|
3180
3225
|
this.valueChange.emit(this.messageInput.nativeElement.value);
|
|
@@ -3471,7 +3516,7 @@
|
|
|
3471
3516
|
return MessageListComponent;
|
|
3472
3517
|
}());
|
|
3473
3518
|
MessageListComponent.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0__namespace, type: MessageListComponent, deps: [{ token: ChannelService }, { token: ChatClientService }, { token: ImageLoadService }], target: i0__namespace.ɵɵFactoryTarget.Component });
|
|
3474
|
-
MessageListComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.5", type: MessageListComponent, selector: "stream-message-list", inputs: { messageTemplate: "messageTemplate", areReactionsEnabled: "areReactionsEnabled", enabledMessageActionsInput: ["enabledMessageActions", "enabledMessageActionsInput"] }, host: { properties: { "class": "this.class" } }, viewQueries: [{ propertyName: "scrollContainer", first: true, predicate: ["scrollContainer"], descendants: true }], usesOnChanges: true, ngImport: i0__namespace, 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 *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 }\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 ></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", components: [{ type: MessageComponent, selector: "stream-message", inputs: ["message", "enabledMessageActions", "areReactionsEnabled", "canReactToMessage", "isLastSentMessage", "canReceiveReadEvents"] }], directives: [{ type: i3__namespace.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3__namespace.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3__namespace.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "async": i3__namespace.AsyncPipe } });
|
|
3519
|
+
MessageListComponent.ɵcmp = i0__namespace.ɵɵ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__namespace, 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 *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", components: [{ type: MessageComponent, selector: "stream-message", inputs: ["messageInputTemplate", "mentionTemplate", "message", "enabledMessageActions", "areReactionsEnabled", "canReactToMessage", "isLastSentMessage", "canReceiveReadEvents"] }], directives: [{ type: i3__namespace.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3__namespace.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3__namespace.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "async": i3__namespace.AsyncPipe } });
|
|
3475
3520
|
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0__namespace, type: MessageListComponent, decorators: [{
|
|
3476
3521
|
type: i0.Component,
|
|
3477
3522
|
args: [{
|
|
@@ -3481,6 +3526,10 @@
|
|
|
3481
3526
|
}]
|
|
3482
3527
|
}], ctorParameters: function () { return [{ type: ChannelService }, { type: ChatClientService }, { type: ImageLoadService }]; }, propDecorators: { messageTemplate: [{
|
|
3483
3528
|
type: i0.Input
|
|
3529
|
+
}], messageInputTemplate: [{
|
|
3530
|
+
type: i0.Input
|
|
3531
|
+
}], mentionTemplate: [{
|
|
3532
|
+
type: i0.Input
|
|
3484
3533
|
}], areReactionsEnabled: [{
|
|
3485
3534
|
type: i0.Input
|
|
3486
3535
|
}], enabledMessageActionsInput: [{
|
|
@@ -3533,8 +3582,7 @@
|
|
|
3533
3582
|
NotificationListComponent,
|
|
3534
3583
|
AttachmentPreviewListComponent,
|
|
3535
3584
|
ModalComponent,
|
|
3536
|
-
TextareaDirective,
|
|
3537
|
-
HighlightMentionsPipe], imports: [i3.CommonModule, i1.TranslateModule, StreamAvatarModule], exports: [ChannelComponent,
|
|
3585
|
+
TextareaDirective], imports: [i3.CommonModule, i1.TranslateModule, StreamAvatarModule], exports: [ChannelComponent,
|
|
3538
3586
|
ChannelHeaderComponent,
|
|
3539
3587
|
ChannelListComponent,
|
|
3540
3588
|
ChannelPreviewComponent,
|
|
@@ -3550,8 +3598,8 @@
|
|
|
3550
3598
|
NotificationListComponent,
|
|
3551
3599
|
AttachmentPreviewListComponent,
|
|
3552
3600
|
ModalComponent,
|
|
3553
|
-
|
|
3554
|
-
StreamChatModule.ɵinj = i0__namespace.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0__namespace, type: StreamChatModule, imports: [[i3.CommonModule, i1.TranslateModule, StreamAvatarModule]] });
|
|
3601
|
+
StreamAvatarModule] });
|
|
3602
|
+
StreamChatModule.ɵinj = i0__namespace.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0__namespace, type: StreamChatModule, imports: [[i3.CommonModule, i1.TranslateModule, StreamAvatarModule], StreamAvatarModule] });
|
|
3555
3603
|
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0__namespace, type: StreamChatModule, decorators: [{
|
|
3556
3604
|
type: i0.NgModule,
|
|
3557
3605
|
args: [{
|
|
@@ -3573,7 +3621,6 @@
|
|
|
3573
3621
|
AttachmentPreviewListComponent,
|
|
3574
3622
|
ModalComponent,
|
|
3575
3623
|
TextareaDirective,
|
|
3576
|
-
HighlightMentionsPipe,
|
|
3577
3624
|
],
|
|
3578
3625
|
imports: [i3.CommonModule, i1.TranslateModule, StreamAvatarModule],
|
|
3579
3626
|
exports: [
|
|
@@ -3593,7 +3640,7 @@
|
|
|
3593
3640
|
NotificationListComponent,
|
|
3594
3641
|
AttachmentPreviewListComponent,
|
|
3595
3642
|
ModalComponent,
|
|
3596
|
-
|
|
3643
|
+
StreamAvatarModule,
|
|
3597
3644
|
],
|
|
3598
3645
|
}]
|
|
3599
3646
|
}] });
|
|
@@ -3674,7 +3721,6 @@
|
|
|
3674
3721
|
exports.ChannelPreviewComponent = ChannelPreviewComponent;
|
|
3675
3722
|
exports.ChannelService = ChannelService;
|
|
3676
3723
|
exports.ChatClientService = ChatClientService;
|
|
3677
|
-
exports.HighlightMentionsPipe = HighlightMentionsPipe;
|
|
3678
3724
|
exports.IconComponent = IconComponent;
|
|
3679
3725
|
exports.ImageLoadService = ImageLoadService;
|
|
3680
3726
|
exports.LoadingIndicatorComponent = LoadingIndicatorComponent;
|
|
@@ -3689,6 +3735,7 @@
|
|
|
3689
3735
|
exports.NotificationListComponent = NotificationListComponent;
|
|
3690
3736
|
exports.NotificationService = NotificationService;
|
|
3691
3737
|
exports.StreamAutocompleteTextareaModule = StreamAutocompleteTextareaModule;
|
|
3738
|
+
exports.StreamAvatarModule = StreamAvatarModule;
|
|
3692
3739
|
exports.StreamChatModule = StreamChatModule;
|
|
3693
3740
|
exports.StreamI18nService = StreamI18nService;
|
|
3694
3741
|
exports.StreamTextareaModule = StreamTextareaModule;
|