stream-chat-angular 4.55.1 → 4.55.2-perf-message-list.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 +326 -167
- package/bundles/stream-chat-angular.umd.js.map +1 -1
- package/esm2015/assets/version.js +2 -2
- package/esm2015/lib/attachment-configuration.service.js +2 -2
- package/esm2015/lib/attachment-list/attachment-list.component.js +9 -2
- package/esm2015/lib/message/message.component.js +44 -14
- package/esm2015/lib/message-actions-box/message-actions-box.component.js +60 -81
- package/esm2015/lib/message-actions.service.js +108 -0
- package/esm2015/lib/message-list/message-list.component.js +61 -24
- package/esm2015/lib/message-reactions.service.js +2 -2
- package/esm2015/lib/types.js +1 -1
- package/esm2015/public-api.js +2 -1
- package/fesm2015/stream-chat-angular.js +276 -121
- package/fesm2015/stream-chat-angular.js.map +1 -1
- package/lib/attachment-list/attachment-list.component.d.ts +4 -2
- package/lib/message/message.component.d.ts +6 -1
- package/lib/message-actions-box/message-actions-box.component.d.ts +24 -9
- package/lib/message-actions.service.d.ts +37 -0
- package/lib/message-list/message-list.component.d.ts +5 -1
- package/lib/message-reactions.service.d.ts +1 -1
- package/lib/types.d.ts +15 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/src/assets/version.ts +1 -1
|
@@ -1,25 +1,21 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
1
|
import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
3
2
|
import { Subject } from 'rxjs';
|
|
4
3
|
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "../
|
|
6
|
-
import * as i2 from "../
|
|
7
|
-
import * as i3 from "../
|
|
8
|
-
import * as i4 from "../
|
|
9
|
-
import * as i5 from "../
|
|
10
|
-
import * as i6 from "
|
|
11
|
-
import * as i7 from "
|
|
12
|
-
import * as i8 from "@angular/common";
|
|
13
|
-
import * as i9 from "@ngx-translate/core";
|
|
4
|
+
import * as i1 from "../custom-templates.service";
|
|
5
|
+
import * as i2 from "../message-actions.service";
|
|
6
|
+
import * as i3 from "../modal/modal.component";
|
|
7
|
+
import * as i4 from "../message-input/message-input.component";
|
|
8
|
+
import * as i5 from "../notification-list/notification-list.component";
|
|
9
|
+
import * as i6 from "@angular/common";
|
|
10
|
+
import * as i7 from "@ngx-translate/core";
|
|
14
11
|
/**
|
|
15
12
|
* The `MessageActionsBox` component displays a list of message actions (i.e edit), that can be opened or closed. You can find the [list of the supported actions](../concepts/message-interactions.mdx) in the message interaction guide.
|
|
16
13
|
*/
|
|
17
14
|
export class MessageActionsBoxComponent {
|
|
18
|
-
constructor(
|
|
19
|
-
this.chatClientService = chatClientService;
|
|
20
|
-
this.notificationService = notificationService;
|
|
21
|
-
this.channelService = channelService;
|
|
15
|
+
constructor(customTemplatesService, messageActionsService, cdRef) {
|
|
22
16
|
this.customTemplatesService = customTemplatesService;
|
|
17
|
+
this.messageActionsService = messageActionsService;
|
|
18
|
+
this.cdRef = cdRef;
|
|
23
19
|
/**
|
|
24
20
|
* Indicates if the list should be opened or closed. Adding a UI element to open and close the list is the parent's component responsibility.
|
|
25
21
|
* @deprecated No need for this since [theme-v2](../theming/introduction.mdx)
|
|
@@ -35,94 +31,70 @@ export class MessageActionsBoxComponent {
|
|
|
35
31
|
this.enabledActions = [];
|
|
36
32
|
/**
|
|
37
33
|
* A list of custom message actions to be displayed in the action box
|
|
34
|
+
*
|
|
35
|
+
* In the next major release this will be released with `messageReactionsService.customActions$`
|
|
36
|
+
*
|
|
37
|
+
* More information: https://getstream.io/chat/docs/sdk/angular/services/MessageActionsService
|
|
38
38
|
*/
|
|
39
39
|
this.customActions = [];
|
|
40
40
|
/**
|
|
41
41
|
* The number of authorized actions (it can be less or equal than the number of enabled actions)
|
|
42
|
+
*
|
|
43
|
+
* @deprecated components should use `messageReactionsService.getAuthorizedMessageActionsCount` method
|
|
44
|
+
*
|
|
45
|
+
* More information: https://getstream.io/chat/docs/sdk/angular/services/MessageActionsService
|
|
42
46
|
*/
|
|
43
47
|
this.displayedActionsCount = new EventEmitter();
|
|
44
48
|
/**
|
|
45
49
|
* An event which emits `true` if the edit message modal is open, and `false` when it is closed.
|
|
50
|
+
*
|
|
51
|
+
* @deprecated components should use `messageReactionsService.getAuthorizedMessageActionsCount` method
|
|
52
|
+
*
|
|
53
|
+
* More information: https://getstream.io/chat/docs/sdk/angular/services/MessageActionsService
|
|
46
54
|
*/
|
|
47
55
|
this.isEditing = new EventEmitter();
|
|
48
56
|
this.isEditModalOpen = false;
|
|
49
57
|
this.visibleMessageActionItems = [];
|
|
50
58
|
this.sendMessageSubject = new Subject();
|
|
59
|
+
this.subscriptions = [];
|
|
60
|
+
this.isViewInited = false;
|
|
51
61
|
this.modalClosed = () => {
|
|
52
62
|
this.isEditModalOpen = false;
|
|
53
|
-
this.
|
|
63
|
+
this.messageActionsService.messageToEdit$.next(undefined);
|
|
54
64
|
};
|
|
55
|
-
this.messageActionItems =
|
|
56
|
-
{
|
|
57
|
-
actionName: 'quote',
|
|
58
|
-
actionLabelOrTranslationKey: 'streamChat.Reply',
|
|
59
|
-
actionHandler: (message) => this.channelService.selectMessageToQuote(message),
|
|
60
|
-
isVisible: (enabledActions) => enabledActions.indexOf('quote-message') !== -1,
|
|
61
|
-
},
|
|
62
|
-
{
|
|
63
|
-
actionName: 'pin',
|
|
64
|
-
actionLabelOrTranslationKey: (message) => message.pinned ? 'streamChat.Unpin' : 'streamChat.Pin',
|
|
65
|
-
actionHandler: (message) => message.pinned
|
|
66
|
-
? this.channelService.unpinMessage(message)
|
|
67
|
-
: this.channelService.pinMessage(message),
|
|
68
|
-
isVisible: (enabledActions) => enabledActions.indexOf('pin-message') !== -1,
|
|
69
|
-
},
|
|
70
|
-
{
|
|
71
|
-
actionName: 'flag',
|
|
72
|
-
actionLabelOrTranslationKey: 'streamChat.Flag',
|
|
73
|
-
actionHandler: (message) => __awaiter(this, void 0, void 0, function* () {
|
|
74
|
-
try {
|
|
75
|
-
yield this.chatClientService.flagMessage(message.id);
|
|
76
|
-
this.notificationService.addTemporaryNotification('streamChat.Message has been successfully flagged', 'success');
|
|
77
|
-
}
|
|
78
|
-
catch (err) {
|
|
79
|
-
this.notificationService.addTemporaryNotification('streamChat.Error adding flag');
|
|
80
|
-
}
|
|
81
|
-
}),
|
|
82
|
-
isVisible: (enabledActions, isMine) => enabledActions.indexOf('flag-message') !== -1 && !isMine,
|
|
83
|
-
},
|
|
84
|
-
{
|
|
85
|
-
actionName: 'edit',
|
|
86
|
-
actionLabelOrTranslationKey: 'streamChat.Edit Message',
|
|
87
|
-
actionHandler: () => {
|
|
88
|
-
this.isEditing.emit(true);
|
|
89
|
-
this.isEditModalOpen = true;
|
|
90
|
-
},
|
|
91
|
-
isVisible: (enabledActions, isMine) => (enabledActions.indexOf('update-own-message') !== -1 && isMine) ||
|
|
92
|
-
enabledActions.indexOf('update-any-message') !== -1,
|
|
93
|
-
},
|
|
94
|
-
{
|
|
95
|
-
actionName: 'delete',
|
|
96
|
-
actionLabelOrTranslationKey: 'streamChat.Delete',
|
|
97
|
-
actionHandler: (message) => __awaiter(this, void 0, void 0, function* () {
|
|
98
|
-
try {
|
|
99
|
-
yield this.channelService.deleteMessage(message);
|
|
100
|
-
}
|
|
101
|
-
catch (error) {
|
|
102
|
-
this.notificationService.addTemporaryNotification('streamChat.Error deleting message');
|
|
103
|
-
}
|
|
104
|
-
}),
|
|
105
|
-
isVisible: (enabledActions, isMine) => ((enabledActions.indexOf('delete') !== -1 ||
|
|
106
|
-
enabledActions.indexOf('delete-own-message') !== -1) &&
|
|
107
|
-
isMine) ||
|
|
108
|
-
enabledActions.indexOf('delete-any') !== -1 ||
|
|
109
|
-
enabledActions.indexOf('delete-any-message') !== -1,
|
|
110
|
-
},
|
|
111
|
-
];
|
|
65
|
+
this.messageActionItems = this.messageActionsService.defaultActions;
|
|
112
66
|
this.sendMessage$ = this.sendMessageSubject.asObservable();
|
|
113
67
|
}
|
|
68
|
+
ngOnInit() {
|
|
69
|
+
this.subscriptions.push(this.messageActionsService.messageToEdit$.subscribe((m) => {
|
|
70
|
+
var _a;
|
|
71
|
+
let isEditModalOpen = false;
|
|
72
|
+
if (m && m.id === ((_a = this.message) === null || _a === void 0 ? void 0 : _a.id)) {
|
|
73
|
+
isEditModalOpen = true;
|
|
74
|
+
}
|
|
75
|
+
if (isEditModalOpen !== this.isEditModalOpen) {
|
|
76
|
+
this.isEditModalOpen = isEditModalOpen;
|
|
77
|
+
this.isEditing.emit(this.isEditModalOpen);
|
|
78
|
+
if (this.isViewInited) {
|
|
79
|
+
this.cdRef.detectChanges();
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
}));
|
|
83
|
+
}
|
|
114
84
|
ngOnChanges(changes) {
|
|
115
85
|
if (changes.isMine ||
|
|
116
86
|
changes.enabledActions ||
|
|
117
87
|
changes.message ||
|
|
118
88
|
changes.customActions) {
|
|
119
|
-
this.
|
|
120
|
-
...this.messageActionItems,
|
|
121
|
-
...this.customActions,
|
|
122
|
-
].filter((item) => item.isVisible(this.enabledActions, this.isMine, this.message));
|
|
123
|
-
this.displayedActionsCount.emit(this.visibleMessageActionItems.length);
|
|
89
|
+
this.setVisibleActions();
|
|
124
90
|
}
|
|
125
91
|
}
|
|
92
|
+
ngAfterViewInit() {
|
|
93
|
+
this.isViewInited = true;
|
|
94
|
+
}
|
|
95
|
+
ngOnDestroy() {
|
|
96
|
+
this.subscriptions.forEach((s) => s.unsubscribe());
|
|
97
|
+
}
|
|
126
98
|
getActionLabel(actionLabelOrTranslationKey) {
|
|
127
99
|
return typeof actionLabelOrTranslationKey === 'string'
|
|
128
100
|
? actionLabelOrTranslationKey
|
|
@@ -167,9 +139,16 @@ export class MessageActionsBoxComponent {
|
|
|
167
139
|
trackByActionName(_, item) {
|
|
168
140
|
return item.actionName;
|
|
169
141
|
}
|
|
142
|
+
setVisibleActions() {
|
|
143
|
+
this.visibleMessageActionItems = [
|
|
144
|
+
...this.messageActionItems,
|
|
145
|
+
...this.customActions,
|
|
146
|
+
].filter((item) => item.isVisible(this.enabledActions, this.isMine, this.message));
|
|
147
|
+
this.displayedActionsCount.emit(this.visibleMessageActionItems.length);
|
|
148
|
+
}
|
|
170
149
|
}
|
|
171
|
-
MessageActionsBoxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: MessageActionsBoxComponent, deps: [{ token: i1.
|
|
172
|
-
MessageActionsBoxComponent.ɵcmp = i0.ɵɵ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", customActions: "customActions" }, outputs: { displayedActionsCount: "displayedActionsCount", isEditing: "isEditing" }, viewQueries: [{ propertyName: "modalContent", first: true, predicate: ["modalContent"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<div\n #actionBox\n data-testid=\"action-box\"\n class=\"str-chat__message-actions-box str-chat__message-actions-box-angular\"\n [class.str-chat__message-actions-box--open]=\"true\"\n>\n <ul class=\"str-chat__message-actions-list\">\n <ng-container\n *ngFor=\"let item of visibleMessageActionItems; trackBy: trackByActionName\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n (customTemplatesService.messageActionsBoxItemTemplate$ | async) ||\n defaultMessageActionItem;\n context: getMessageActionTemplateContext(item)\n \"\n ></ng-container>\n </ng-container>\n </ul>\n</div>\n\n<ng-template\n #defaultMessageActionItem\n let-actionName=\"actionName\"\n let-actionHandler=\"actionHandler\"\n let-actionLabelOrTranslationKey=\"actionLabelOrTranslationKey\"\n>\n <button\n class=\"str-chat__message-actions-list-item-button\"\n [attr.data-testid]=\"actionName + '-action'\"\n (click)=\"actionHandler(message, isMine)\"\n >\n <li class=\"str-chat__message-actions-list-item\">\n {{ getActionLabel(actionLabelOrTranslationKey) | translate }}\n </li>\n </button>\n</ng-template>\n\n<ng-container\n *ngTemplateOutlet=\"\n (customTemplatesService.modalTemplate$ | async) || defaultModal;\n context: getEditModalContext()\n \"\n></ng-container>\n\n<ng-template\n #defaultModal\n let-isOpen=\"isOpen\"\n let-isOpenChangeHandler=\"isOpenChangeHandler\"\n let-content=\"content\"\n>\n <stream-modal\n [isOpen]=\"isOpen\"\n (isOpenChange)=\"isOpenChangeHandler($event)\"\n [content]=\"content\"\n >\n </stream-modal>\n</ng-template>\n\n<ng-template #modalContent>\n <div class=\"str-chat__edit-message-form\" *ngIf=\"isEditModalOpen\">\n <ng-template\n #defaultInput\n let-messageInput=\"message\"\n let-messageUpdateHandler=\"messageUpdateHandler\"\n let-sendMessage$Input=\"sendMessage$\"\n >\n <stream-message-input\n [message]=\"messageInput\"\n (messageUpdate)=\"messageUpdateHandler()\"\n [sendMessage$]=\"sendMessage$Input\"\n ></stream-message-input>\n </ng-template>\n <ng-container\n *ngTemplateOutlet=\"\n (customTemplatesService.messageInputTemplate$ | async) || defaultInput;\n context: getMessageInputContext()\n \"\n >\n </ng-container>\n\n <stream-notification-list></stream-notification-list>\n <div\n class=\"\n str-chat__message-team-form-footer\n str-chat__message-team-form-footer-angular\n \"\n >\n <div class=\"str-chat__edit-message-form-options\">\n <button\n class=\"str-chat__edit-message-cancel\"\n translate\n data-testid=\"cancel-button\"\n (click)=\"modalClosed()\"\n >\n streamChat.Cancel\n </button>\n <button\n type=\"submit\"\n translate\n class=\"str-chat__edit-message-send\"\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</ng-template>\n", components: [{ type:
|
|
150
|
+
MessageActionsBoxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: MessageActionsBoxComponent, deps: [{ token: i1.CustomTemplatesService }, { token: i2.MessageActionsService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
151
|
+
MessageActionsBoxComponent.ɵcmp = i0.ɵɵ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", customActions: "customActions" }, outputs: { displayedActionsCount: "displayedActionsCount", isEditing: "isEditing" }, viewQueries: [{ propertyName: "modalContent", first: true, predicate: ["modalContent"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<div\n #actionBox\n data-testid=\"action-box\"\n class=\"str-chat__message-actions-box str-chat__message-actions-box-angular\"\n [class.str-chat__message-actions-box--open]=\"true\"\n *ngIf=\"isOpen\"\n>\n <ul class=\"str-chat__message-actions-list\">\n <ng-container\n *ngFor=\"let item of visibleMessageActionItems; trackBy: trackByActionName\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n (customTemplatesService.messageActionsBoxItemTemplate$ | async) ||\n defaultMessageActionItem;\n context: getMessageActionTemplateContext(item)\n \"\n ></ng-container>\n </ng-container>\n </ul>\n</div>\n\n<ng-template\n #defaultMessageActionItem\n let-actionName=\"actionName\"\n let-actionHandler=\"actionHandler\"\n let-actionLabelOrTranslationKey=\"actionLabelOrTranslationKey\"\n>\n <button\n class=\"str-chat__message-actions-list-item-button\"\n [attr.data-testid]=\"actionName + '-action'\"\n (click)=\"actionHandler(message, isMine)\"\n >\n <li class=\"str-chat__message-actions-list-item\">\n {{ getActionLabel(actionLabelOrTranslationKey) | translate }}\n </li>\n </button>\n</ng-template>\n\n<ng-container\n *ngTemplateOutlet=\"\n (customTemplatesService.modalTemplate$ | async) || defaultModal;\n context: getEditModalContext()\n \"\n></ng-container>\n\n<ng-template\n #defaultModal\n let-isOpen=\"isOpen\"\n let-isOpenChangeHandler=\"isOpenChangeHandler\"\n let-content=\"content\"\n>\n <stream-modal\n [isOpen]=\"isOpen\"\n *ngIf=\"isOpen\"\n (isOpenChange)=\"isOpenChangeHandler($event)\"\n [content]=\"content\"\n >\n </stream-modal>\n</ng-template>\n\n<ng-template #modalContent>\n <div class=\"str-chat__edit-message-form\" *ngIf=\"isEditModalOpen\">\n <ng-template\n #defaultInput\n let-messageInput=\"message\"\n let-messageUpdateHandler=\"messageUpdateHandler\"\n let-sendMessage$Input=\"sendMessage$\"\n >\n <stream-message-input\n [message]=\"messageInput\"\n (messageUpdate)=\"messageUpdateHandler()\"\n [sendMessage$]=\"sendMessage$Input\"\n ></stream-message-input>\n </ng-template>\n <ng-container\n *ngTemplateOutlet=\"\n (customTemplatesService.messageInputTemplate$ | async) || defaultInput;\n context: getMessageInputContext()\n \"\n >\n </ng-container>\n\n <stream-notification-list></stream-notification-list>\n <div\n class=\"\n str-chat__message-team-form-footer\n str-chat__message-team-form-footer-angular\n \"\n >\n <div class=\"str-chat__edit-message-form-options\">\n <button\n class=\"str-chat__edit-message-cancel\"\n translate\n data-testid=\"cancel-button\"\n (click)=\"modalClosed()\"\n >\n streamChat.Cancel\n </button>\n <button\n type=\"submit\"\n translate\n class=\"str-chat__edit-message-send\"\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</ng-template>\n", components: [{ type: i3.ModalComponent, selector: "stream-modal", inputs: ["isOpen", "content"], outputs: ["isOpenChange"] }, { type: i4.MessageInputComponent, selector: "stream-message-input", inputs: ["isFileUploadEnabled", "areMentionsEnabled", "mentionScope", "mode", "isMultipleFileUploadEnabled", "message", "sendMessage$", "inputMode", "autoFocus"], outputs: ["messageUpdate"] }, { type: i5.NotificationListComponent, selector: "stream-notification-list" }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i7.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], pipes: { "async": i6.AsyncPipe, "translate": i7.TranslatePipe } });
|
|
173
152
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: MessageActionsBoxComponent, decorators: [{
|
|
174
153
|
type: Component,
|
|
175
154
|
args: [{
|
|
@@ -177,7 +156,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
|
|
|
177
156
|
templateUrl: './message-actions-box.component.html',
|
|
178
157
|
styles: [],
|
|
179
158
|
}]
|
|
180
|
-
}], ctorParameters: function () { return [{ type: i1.
|
|
159
|
+
}], ctorParameters: function () { return [{ type: i1.CustomTemplatesService }, { type: i2.MessageActionsService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { isOpen: [{
|
|
181
160
|
type: Input
|
|
182
161
|
}], isMine: [{
|
|
183
162
|
type: Input
|
|
@@ -195,4 +174,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
|
|
|
195
174
|
type: ViewChild,
|
|
196
175
|
args: ['modalContent', { static: true }]
|
|
197
176
|
}] } });
|
|
198
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"message-actions-box.component.js","sourceRoot":"","sources":["../../../../../projects/stream-chat-angular/src/lib/message-actions-box/message-actions-box.component.ts","../../../../../projects/stream-chat-angular/src/lib/message-actions-box/message-actions-box.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { Observable, Subject } from 'rxjs';\nimport { ChannelService } from '../channel.service';\nimport { ChatClientService } from '../chat-client.service';\nimport { CustomTemplatesService } from '../custom-templates.service';\nimport { NotificationService } from '../notification.service';\nimport {\n  CustomMessageActionItem,\n  MessageActionBoxItemContext,\n  MessageActionItem,\n  MessageInputContext,\n  ModalContext,\n  StreamMessage,\n} from '../types';\n/**\n * The `MessageActionsBox` component displays a list of message actions (i.e edit), that can be opened or closed. You can find the [list of the supported actions](../concepts/message-interactions.mdx) in the message interaction guide.\n */\n@Component({\n  selector: 'stream-message-actions-box',\n  templateUrl: './message-actions-box.component.html',\n  styles: [],\n})\nexport class MessageActionsBoxComponent implements OnChanges {\n  /**\n   * Indicates if the list should be opened or closed. Adding a UI element to open and close the list is the parent's component responsibility.\n   * @deprecated No need for this since [theme-v2](../theming/introduction.mdx)\n   */\n  @Input() isOpen = false;\n  /**\n   * Indicates if the message actions are belonging to a message that was sent by the current user or not.\n   */\n  @Input() isMine = false;\n  /**\n   * The message the actions will be executed on\n   */\n  @Input() message: StreamMessage | undefined;\n  /**\n   * The list of [channel capabilities](https://getstream.io/chat/docs/javascript/channel_capabilities/?language=javascript) that are enabled for the current user, the list of [supported interactions](../concepts/message-interactions.mdx) can be found in our message interaction guide. Unathorized actions won't be displayed on the UI.\n   */\n  @Input() enabledActions: string[] = [];\n  /**\n   * A list of custom message actions to be displayed in the action box\n   */\n  @Input() customActions: CustomMessageActionItem[] = [];\n  /**\n   * The number of authorized actions (it can be less or equal than the number of enabled actions)\n   */\n  @Output() readonly displayedActionsCount = new EventEmitter<number>();\n  /**\n   * An event which emits `true` if the edit message modal is open, and `false` when it is closed.\n   */\n  @Output() readonly isEditing = new EventEmitter<boolean>();\n  isEditModalOpen = false;\n  messageInputTemplate: TemplateRef<MessageInputContext> | undefined;\n  messageActionItemTemplate:\n    | TemplateRef<MessageActionBoxItemContext>\n    | undefined;\n  modalTemplate: TemplateRef<ModalContext> | undefined;\n  visibleMessageActionItems: (MessageActionItem | CustomMessageActionItem)[] =\n    [];\n  sendMessage$: Observable<void>;\n  private readonly messageActionItems: MessageActionItem[];\n  @ViewChild('modalContent', { static: true })\n  private modalContent!: TemplateRef<void>;\n  private sendMessageSubject = new Subject<void>();\n  constructor(\n    private chatClientService: ChatClientService,\n    private notificationService: NotificationService,\n    private channelService: ChannelService,\n    public readonly customTemplatesService: CustomTemplatesService\n  ) {\n    this.messageActionItems = [\n      {\n        actionName: 'quote',\n        actionLabelOrTranslationKey: 'streamChat.Reply',\n        actionHandler: (message: StreamMessage) =>\n          this.channelService.selectMessageToQuote(message),\n        isVisible: (enabledActions: string[]) =>\n          enabledActions.indexOf('quote-message') !== -1,\n      },\n      {\n        actionName: 'pin',\n        actionLabelOrTranslationKey: (message: StreamMessage) =>\n          message.pinned ? 'streamChat.Unpin' : 'streamChat.Pin',\n        actionHandler: (message: StreamMessage) =>\n          message.pinned\n            ? this.channelService.unpinMessage(message)\n            : this.channelService.pinMessage(message),\n        isVisible: (enabledActions: string[]) =>\n          enabledActions.indexOf('pin-message') !== -1,\n      },\n      {\n        actionName: 'flag',\n        actionLabelOrTranslationKey: 'streamChat.Flag',\n        actionHandler: async (message: StreamMessage) => {\n          try {\n            await this.chatClientService.flagMessage(message.id);\n            this.notificationService.addTemporaryNotification(\n              'streamChat.Message has been successfully flagged',\n              'success'\n            );\n          } catch (err) {\n            this.notificationService.addTemporaryNotification(\n              'streamChat.Error adding flag'\n            );\n          }\n        },\n        isVisible: (enabledActions: string[], isMine: boolean) =>\n          enabledActions.indexOf('flag-message') !== -1 && !isMine,\n      },\n      {\n        actionName: 'edit',\n        actionLabelOrTranslationKey: 'streamChat.Edit Message',\n        actionHandler: () => {\n          this.isEditing.emit(true);\n          this.isEditModalOpen = true;\n        },\n        isVisible: (enabledActions: string[], isMine: boolean) =>\n          (enabledActions.indexOf('update-own-message') !== -1 && isMine) ||\n          enabledActions.indexOf('update-any-message') !== -1,\n      },\n      {\n        actionName: 'delete',\n        actionLabelOrTranslationKey: 'streamChat.Delete',\n        actionHandler: async (message: StreamMessage) => {\n          try {\n            await this.channelService.deleteMessage(message);\n          } catch (error) {\n            this.notificationService.addTemporaryNotification(\n              'streamChat.Error deleting message'\n            );\n          }\n        },\n        isVisible: (enabledActions: string[], isMine: boolean) =>\n          ((enabledActions.indexOf('delete') !== -1 ||\n            enabledActions.indexOf('delete-own-message') !== -1) &&\n            isMine) ||\n          enabledActions.indexOf('delete-any') !== -1 ||\n          enabledActions.indexOf('delete-any-message') !== -1,\n      },\n    ];\n    this.sendMessage$ = this.sendMessageSubject.asObservable();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (\n      changes.isMine ||\n      changes.enabledActions ||\n      changes.message ||\n      changes.customActions\n    ) {\n      this.visibleMessageActionItems = [\n        ...this.messageActionItems,\n        ...this.customActions,\n      ].filter((item) =>\n        item.isVisible(this.enabledActions, this.isMine, this.message!)\n      );\n      this.displayedActionsCount.emit(this.visibleMessageActionItems.length);\n    }\n  }\n\n  getActionLabel(\n    actionLabelOrTranslationKey: ((message: StreamMessage) => string) | string\n  ) {\n    return typeof actionLabelOrTranslationKey === 'string'\n      ? actionLabelOrTranslationKey\n      : actionLabelOrTranslationKey(this.message!);\n  }\n\n  getMessageActionTemplateContext(\n    item: MessageActionItem | CustomMessageActionItem\n  ): MessageActionBoxItemContext<any> {\n    return {\n      actionHandler: item.actionHandler,\n      isMine: this.isMine,\n      actionName: item.actionName,\n      message: this.message,\n      actionLabelOrTranslationKey: item.actionLabelOrTranslationKey,\n    };\n  }\n\n  sendClicked() {\n    this.sendMessageSubject.next();\n  }\n\n  modalClosed = () => {\n    this.isEditModalOpen = false;\n    this.isEditing.emit(false);\n  };\n\n  getMessageInputContext(): MessageInputContext {\n    return {\n      message: this.message,\n      messageUpdateHandler: this.modalClosed,\n      isFileUploadEnabled: undefined,\n      areMentionsEnabled: undefined,\n      isMultipleFileUploadEnabled: undefined,\n      mentionScope: undefined,\n      mode: undefined,\n      sendMessage$: this.sendMessage$,\n    };\n  }\n\n  getEditModalContext(): ModalContext {\n    return {\n      isOpen: this.isEditModalOpen,\n      isOpenChangeHandler: (isOpen) => {\n        this.isEditModalOpen = isOpen;\n        if (!this.isEditModalOpen) {\n          this.modalClosed();\n        }\n      },\n      content: this.modalContent,\n    };\n  }\n\n  trackByActionName(\n    _: number,\n    item: MessageActionItem | CustomMessageActionItem\n  ) {\n    return item.actionName;\n  }\n}\n","<div\n  #actionBox\n  data-testid=\"action-box\"\n  class=\"str-chat__message-actions-box str-chat__message-actions-box-angular\"\n  [class.str-chat__message-actions-box--open]=\"true\"\n>\n  <ul class=\"str-chat__message-actions-list\">\n    <ng-container\n      *ngFor=\"let item of visibleMessageActionItems; trackBy: trackByActionName\"\n    >\n      <ng-container\n        *ngTemplateOutlet=\"\n          (customTemplatesService.messageActionsBoxItemTemplate$ | async) ||\n            defaultMessageActionItem;\n          context: getMessageActionTemplateContext(item)\n        \"\n      ></ng-container>\n    </ng-container>\n  </ul>\n</div>\n\n<ng-template\n  #defaultMessageActionItem\n  let-actionName=\"actionName\"\n  let-actionHandler=\"actionHandler\"\n  let-actionLabelOrTranslationKey=\"actionLabelOrTranslationKey\"\n>\n  <button\n    class=\"str-chat__message-actions-list-item-button\"\n    [attr.data-testid]=\"actionName + '-action'\"\n    (click)=\"actionHandler(message, isMine)\"\n  >\n    <li class=\"str-chat__message-actions-list-item\">\n      {{ getActionLabel(actionLabelOrTranslationKey) | translate }}\n    </li>\n  </button>\n</ng-template>\n\n<ng-container\n  *ngTemplateOutlet=\"\n    (customTemplatesService.modalTemplate$ | async) || defaultModal;\n    context: getEditModalContext()\n  \"\n></ng-container>\n\n<ng-template\n  #defaultModal\n  let-isOpen=\"isOpen\"\n  let-isOpenChangeHandler=\"isOpenChangeHandler\"\n  let-content=\"content\"\n>\n  <stream-modal\n    [isOpen]=\"isOpen\"\n    (isOpenChange)=\"isOpenChangeHandler($event)\"\n    [content]=\"content\"\n  >\n  </stream-modal>\n</ng-template>\n\n<ng-template #modalContent>\n  <div class=\"str-chat__edit-message-form\" *ngIf=\"isEditModalOpen\">\n    <ng-template\n      #defaultInput\n      let-messageInput=\"message\"\n      let-messageUpdateHandler=\"messageUpdateHandler\"\n      let-sendMessage$Input=\"sendMessage$\"\n    >\n      <stream-message-input\n        [message]=\"messageInput\"\n        (messageUpdate)=\"messageUpdateHandler()\"\n        [sendMessage$]=\"sendMessage$Input\"\n      ></stream-message-input>\n    </ng-template>\n    <ng-container\n      *ngTemplateOutlet=\"\n        (customTemplatesService.messageInputTemplate$ | async) || defaultInput;\n        context: getMessageInputContext()\n      \"\n    >\n    </ng-container>\n\n    <stream-notification-list></stream-notification-list>\n    <div\n      class=\"\n        str-chat__message-team-form-footer\n        str-chat__message-team-form-footer-angular\n      \"\n    >\n      <div class=\"str-chat__edit-message-form-options\">\n        <button\n          class=\"str-chat__edit-message-cancel\"\n          translate\n          data-testid=\"cancel-button\"\n          (click)=\"modalClosed()\"\n        >\n          streamChat.Cancel\n        </button>\n        <button\n          type=\"submit\"\n          translate\n          class=\"str-chat__edit-message-send\"\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</ng-template>\n"]}
|
|
177
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"message-actions-box.component.js","sourceRoot":"","sources":["../../../../../projects/stream-chat-angular/src/lib/message-actions-box/message-actions-box.component.ts","../../../../../projects/stream-chat-angular/src/lib/message-actions-box/message-actions-box.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { Observable, Subject, Subscription } from 'rxjs';\nimport { CustomTemplatesService } from '../custom-templates.service';\nimport {\n  CustomMessageActionItem,\n  MessageActionBoxItemContext,\n  MessageActionItem,\n  MessageInputContext,\n  ModalContext,\n  StreamMessage,\n} from '../types';\nimport { MessageActionsService } from '../message-actions.service';\n/**\n * The `MessageActionsBox` component displays a list of message actions (i.e edit), that can be opened or closed. You can find the [list of the supported actions](../concepts/message-interactions.mdx) in the message interaction guide.\n */\n@Component({\n  selector: 'stream-message-actions-box',\n  templateUrl: './message-actions-box.component.html',\n  styles: [],\n})\nexport class MessageActionsBoxComponent\n  implements OnInit, OnChanges, OnDestroy, AfterViewInit\n{\n  /**\n   * Indicates if the list should be opened or closed. Adding a UI element to open and close the list is the parent's component responsibility.\n   * @deprecated No need for this since [theme-v2](../theming/introduction.mdx)\n   */\n  @Input() isOpen = false;\n  /**\n   * Indicates if the message actions are belonging to a message that was sent by the current user or not.\n   */\n  @Input() isMine = false;\n  /**\n   * The message the actions will be executed on\n   */\n  @Input() message: StreamMessage | undefined;\n  /**\n   * The list of [channel capabilities](https://getstream.io/chat/docs/javascript/channel_capabilities/?language=javascript) that are enabled for the current user, the list of [supported interactions](../concepts/message-interactions.mdx) can be found in our message interaction guide. Unathorized actions won't be displayed on the UI.\n   */\n  @Input() enabledActions: string[] = [];\n  /**\n   * A list of custom message actions to be displayed in the action box\n   *\n   * In the next major release this will be released with `messageReactionsService.customActions$`\n   *\n   * More information: https://getstream.io/chat/docs/sdk/angular/services/MessageActionsService\n   */\n  @Input() customActions: CustomMessageActionItem[] = [];\n  /**\n   * The number of authorized actions (it can be less or equal than the number of enabled actions)\n   *\n   * @deprecated components should use `messageReactionsService.getAuthorizedMessageActionsCount` method\n   *\n   * More information: https://getstream.io/chat/docs/sdk/angular/services/MessageActionsService\n   */\n  @Output() readonly displayedActionsCount = new EventEmitter<number>();\n  /**\n   * An event which emits `true` if the edit message modal is open, and `false` when it is closed.\n   *\n   * @deprecated components should use `messageReactionsService.getAuthorizedMessageActionsCount` method\n   *\n   * More information: https://getstream.io/chat/docs/sdk/angular/services/MessageActionsService\n   */\n  @Output() readonly isEditing = new EventEmitter<boolean>();\n  isEditModalOpen = false;\n  messageInputTemplate: TemplateRef<MessageInputContext> | undefined;\n  messageActionItemTemplate:\n    | TemplateRef<MessageActionBoxItemContext>\n    | undefined;\n  modalTemplate: TemplateRef<ModalContext> | undefined;\n  visibleMessageActionItems: (MessageActionItem | CustomMessageActionItem)[] =\n    [];\n  sendMessage$: Observable<void>;\n  private readonly messageActionItems: MessageActionItem[];\n  @ViewChild('modalContent', { static: true })\n  private modalContent!: TemplateRef<void>;\n  private sendMessageSubject = new Subject<void>();\n  private subscriptions: Subscription[] = [];\n  private isViewInited = false;\n  constructor(\n    public readonly customTemplatesService: CustomTemplatesService,\n    private messageActionsService: MessageActionsService,\n    private cdRef: ChangeDetectorRef\n  ) {\n    this.messageActionItems = this.messageActionsService.defaultActions;\n    this.sendMessage$ = this.sendMessageSubject.asObservable();\n  }\n\n  ngOnInit(): void {\n    this.subscriptions.push(\n      this.messageActionsService.messageToEdit$.subscribe((m) => {\n        let isEditModalOpen = false;\n        if (m && m.id === this.message?.id) {\n          isEditModalOpen = true;\n        }\n        if (isEditModalOpen !== this.isEditModalOpen) {\n          this.isEditModalOpen = isEditModalOpen;\n          this.isEditing.emit(this.isEditModalOpen);\n          if (this.isViewInited) {\n            this.cdRef.detectChanges();\n          }\n        }\n      })\n    );\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (\n      changes.isMine ||\n      changes.enabledActions ||\n      changes.message ||\n      changes.customActions\n    ) {\n      this.setVisibleActions();\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.isViewInited = true;\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach((s) => s.unsubscribe());\n  }\n\n  getActionLabel(\n    actionLabelOrTranslationKey: ((message: StreamMessage) => string) | string\n  ) {\n    return typeof actionLabelOrTranslationKey === 'string'\n      ? actionLabelOrTranslationKey\n      : actionLabelOrTranslationKey(this.message!);\n  }\n\n  getMessageActionTemplateContext(\n    item: MessageActionItem | CustomMessageActionItem\n  ): MessageActionBoxItemContext<any> {\n    return {\n      actionHandler: item.actionHandler,\n      isMine: this.isMine,\n      actionName: item.actionName,\n      message: this.message,\n      actionLabelOrTranslationKey: item.actionLabelOrTranslationKey,\n    };\n  }\n\n  sendClicked() {\n    this.sendMessageSubject.next();\n  }\n\n  modalClosed = () => {\n    this.isEditModalOpen = false;\n    this.messageActionsService.messageToEdit$.next(undefined);\n  };\n\n  getMessageInputContext(): MessageInputContext {\n    return {\n      message: this.message,\n      messageUpdateHandler: this.modalClosed,\n      isFileUploadEnabled: undefined,\n      areMentionsEnabled: undefined,\n      isMultipleFileUploadEnabled: undefined,\n      mentionScope: undefined,\n      mode: undefined,\n      sendMessage$: this.sendMessage$,\n    };\n  }\n\n  getEditModalContext(): ModalContext {\n    return {\n      isOpen: this.isEditModalOpen,\n      isOpenChangeHandler: (isOpen) => {\n        this.isEditModalOpen = isOpen;\n        if (!this.isEditModalOpen) {\n          this.modalClosed();\n        }\n      },\n      content: this.modalContent,\n    };\n  }\n\n  trackByActionName(\n    _: number,\n    item: MessageActionItem | CustomMessageActionItem\n  ) {\n    return item.actionName;\n  }\n\n  private setVisibleActions() {\n    this.visibleMessageActionItems = [\n      ...this.messageActionItems,\n      ...this.customActions,\n    ].filter((item) =>\n      item.isVisible(this.enabledActions, this.isMine, this.message!)\n    );\n    this.displayedActionsCount.emit(this.visibleMessageActionItems.length);\n  }\n}\n","<div\n  #actionBox\n  data-testid=\"action-box\"\n  class=\"str-chat__message-actions-box str-chat__message-actions-box-angular\"\n  [class.str-chat__message-actions-box--open]=\"true\"\n  *ngIf=\"isOpen\"\n>\n  <ul class=\"str-chat__message-actions-list\">\n    <ng-container\n      *ngFor=\"let item of visibleMessageActionItems; trackBy: trackByActionName\"\n    >\n      <ng-container\n        *ngTemplateOutlet=\"\n          (customTemplatesService.messageActionsBoxItemTemplate$ | async) ||\n            defaultMessageActionItem;\n          context: getMessageActionTemplateContext(item)\n        \"\n      ></ng-container>\n    </ng-container>\n  </ul>\n</div>\n\n<ng-template\n  #defaultMessageActionItem\n  let-actionName=\"actionName\"\n  let-actionHandler=\"actionHandler\"\n  let-actionLabelOrTranslationKey=\"actionLabelOrTranslationKey\"\n>\n  <button\n    class=\"str-chat__message-actions-list-item-button\"\n    [attr.data-testid]=\"actionName + '-action'\"\n    (click)=\"actionHandler(message, isMine)\"\n  >\n    <li class=\"str-chat__message-actions-list-item\">\n      {{ getActionLabel(actionLabelOrTranslationKey) | translate }}\n    </li>\n  </button>\n</ng-template>\n\n<ng-container\n  *ngTemplateOutlet=\"\n    (customTemplatesService.modalTemplate$ | async) || defaultModal;\n    context: getEditModalContext()\n  \"\n></ng-container>\n\n<ng-template\n  #defaultModal\n  let-isOpen=\"isOpen\"\n  let-isOpenChangeHandler=\"isOpenChangeHandler\"\n  let-content=\"content\"\n>\n  <stream-modal\n    [isOpen]=\"isOpen\"\n    *ngIf=\"isOpen\"\n    (isOpenChange)=\"isOpenChangeHandler($event)\"\n    [content]=\"content\"\n  >\n  </stream-modal>\n</ng-template>\n\n<ng-template #modalContent>\n  <div class=\"str-chat__edit-message-form\" *ngIf=\"isEditModalOpen\">\n    <ng-template\n      #defaultInput\n      let-messageInput=\"message\"\n      let-messageUpdateHandler=\"messageUpdateHandler\"\n      let-sendMessage$Input=\"sendMessage$\"\n    >\n      <stream-message-input\n        [message]=\"messageInput\"\n        (messageUpdate)=\"messageUpdateHandler()\"\n        [sendMessage$]=\"sendMessage$Input\"\n      ></stream-message-input>\n    </ng-template>\n    <ng-container\n      *ngTemplateOutlet=\"\n        (customTemplatesService.messageInputTemplate$ | async) || defaultInput;\n        context: getMessageInputContext()\n      \"\n    >\n    </ng-container>\n\n    <stream-notification-list></stream-notification-list>\n    <div\n      class=\"\n        str-chat__message-team-form-footer\n        str-chat__message-team-form-footer-angular\n      \"\n    >\n      <div class=\"str-chat__edit-message-form-options\">\n        <button\n          class=\"str-chat__edit-message-cancel\"\n          translate\n          data-testid=\"cancel-button\"\n          (click)=\"modalClosed()\"\n        >\n          streamChat.Cancel\n        </button>\n        <button\n          type=\"submit\"\n          translate\n          class=\"str-chat__edit-message-send\"\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</ng-template>\n"]}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { Injectable } from '@angular/core';
|
|
3
|
+
import { BehaviorSubject } from 'rxjs';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "./chat-client.service";
|
|
6
|
+
import * as i2 from "./notification.service";
|
|
7
|
+
import * as i3 from "./channel.service";
|
|
8
|
+
/**
|
|
9
|
+
* The message actions service provides customization options for the [message actions](../../components/MessageActionsBoxComponent)
|
|
10
|
+
*/
|
|
11
|
+
export class MessageActionsService {
|
|
12
|
+
constructor(chatClientService, notificationService, channelService) {
|
|
13
|
+
this.chatClientService = chatClientService;
|
|
14
|
+
this.notificationService = notificationService;
|
|
15
|
+
this.channelService = channelService;
|
|
16
|
+
/**
|
|
17
|
+
* Default actions - these are the actions that are handled by the built-in component
|
|
18
|
+
*/
|
|
19
|
+
this.defaultActions = [
|
|
20
|
+
{
|
|
21
|
+
actionName: 'quote',
|
|
22
|
+
actionLabelOrTranslationKey: 'streamChat.Reply',
|
|
23
|
+
actionHandler: (message) => this.channelService.selectMessageToQuote(message),
|
|
24
|
+
isVisible: (enabledActions) => enabledActions.indexOf('quote-message') !== -1,
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
actionName: 'pin',
|
|
28
|
+
actionLabelOrTranslationKey: (message) => message.pinned ? 'streamChat.Unpin' : 'streamChat.Pin',
|
|
29
|
+
actionHandler: (message) => message.pinned
|
|
30
|
+
? this.channelService.unpinMessage(message)
|
|
31
|
+
: this.channelService.pinMessage(message),
|
|
32
|
+
isVisible: (enabledActions) => enabledActions.indexOf('pin-message') !== -1,
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
actionName: 'flag',
|
|
36
|
+
actionLabelOrTranslationKey: 'streamChat.Flag',
|
|
37
|
+
actionHandler: (message) => __awaiter(this, void 0, void 0, function* () {
|
|
38
|
+
try {
|
|
39
|
+
yield this.chatClientService.flagMessage(message.id);
|
|
40
|
+
this.notificationService.addTemporaryNotification('streamChat.Message has been successfully flagged', 'success');
|
|
41
|
+
}
|
|
42
|
+
catch (err) {
|
|
43
|
+
this.notificationService.addTemporaryNotification('streamChat.Error adding flag');
|
|
44
|
+
}
|
|
45
|
+
}),
|
|
46
|
+
isVisible: (enabledActions, isMine) => enabledActions.indexOf('flag-message') !== -1 && !isMine,
|
|
47
|
+
},
|
|
48
|
+
{
|
|
49
|
+
actionName: 'edit',
|
|
50
|
+
actionLabelOrTranslationKey: 'streamChat.Edit Message',
|
|
51
|
+
actionHandler: (message) => {
|
|
52
|
+
this.messageToEdit$.next(message);
|
|
53
|
+
},
|
|
54
|
+
isVisible: (enabledActions, isMine) => (enabledActions.indexOf('update-own-message') !== -1 && isMine) ||
|
|
55
|
+
enabledActions.indexOf('update-any-message') !== -1,
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
actionName: 'delete',
|
|
59
|
+
actionLabelOrTranslationKey: 'streamChat.Delete',
|
|
60
|
+
actionHandler: (message) => __awaiter(this, void 0, void 0, function* () {
|
|
61
|
+
try {
|
|
62
|
+
yield this.channelService.deleteMessage(message);
|
|
63
|
+
}
|
|
64
|
+
catch (error) {
|
|
65
|
+
this.notificationService.addTemporaryNotification('streamChat.Error deleting message');
|
|
66
|
+
}
|
|
67
|
+
}),
|
|
68
|
+
isVisible: (enabledActions, isMine) => ((enabledActions.indexOf('delete') !== -1 ||
|
|
69
|
+
enabledActions.indexOf('delete-own-message') !== -1) &&
|
|
70
|
+
isMine) ||
|
|
71
|
+
enabledActions.indexOf('delete-any') !== -1 ||
|
|
72
|
+
enabledActions.indexOf('delete-any-message') !== -1,
|
|
73
|
+
},
|
|
74
|
+
];
|
|
75
|
+
/**
|
|
76
|
+
* The built-in components will handle changes to this observable.
|
|
77
|
+
*/
|
|
78
|
+
this.messageToEdit$ = new BehaviorSubject(undefined);
|
|
79
|
+
/**
|
|
80
|
+
* You can pass your own custom actions that will be displayed inside the built-in message actions component
|
|
81
|
+
*/
|
|
82
|
+
this.customActions$ = new BehaviorSubject([]);
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* This method returns how many authorized actions are available to the given message
|
|
86
|
+
*
|
|
87
|
+
* @param message
|
|
88
|
+
* @param enabledActions
|
|
89
|
+
* @returns the count
|
|
90
|
+
*/
|
|
91
|
+
getAuthorizedMessageActionsCount(message, enabledActions) {
|
|
92
|
+
var _a;
|
|
93
|
+
const customActions = this.customActions$.getValue() || [];
|
|
94
|
+
const allActions = [...this.defaultActions, ...customActions];
|
|
95
|
+
const currentUserId = (_a = this.chatClientService.chatClient.user) === null || _a === void 0 ? void 0 : _a.id;
|
|
96
|
+
const isMine = message.user_id === currentUserId;
|
|
97
|
+
return allActions.filter((item) => item.isVisible(enabledActions, isMine, message)).length;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
MessageActionsService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: MessageActionsService, deps: [{ token: i1.ChatClientService }, { token: i2.NotificationService }, { token: i3.ChannelService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
101
|
+
MessageActionsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: MessageActionsService, providedIn: 'root' });
|
|
102
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: MessageActionsService, decorators: [{
|
|
103
|
+
type: Injectable,
|
|
104
|
+
args: [{
|
|
105
|
+
providedIn: 'root',
|
|
106
|
+
}]
|
|
107
|
+
}], ctorParameters: function () { return [{ type: i1.ChatClientService }, { type: i2.NotificationService }, { type: i3.ChannelService }]; } });
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"message-actions.service.js","sourceRoot":"","sources":["../../../../projects/stream-chat-angular/src/lib/message-actions.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { BehaviorSubject } from 'rxjs';\nimport {\n  CustomMessageActionItem,\n  DefaultStreamChatGenerics,\n  MessageActionItem,\n  StreamMessage,\n} from './types';\nimport { ChatClientService } from './chat-client.service';\nimport { NotificationService } from './notification.service';\nimport { ChannelService } from './channel.service';\n\n/**\n * The message actions service provides customization options for the [message actions](../../components/MessageActionsBoxComponent)\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class MessageActionsService<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> {\n  /**\n   * Default actions - these are the actions that are handled by the built-in component\n   */\n  readonly defaultActions: MessageActionItem<T>[] = [\n    {\n      actionName: 'quote',\n      actionLabelOrTranslationKey: 'streamChat.Reply',\n      actionHandler: (message: StreamMessage<T>) =>\n        this.channelService.selectMessageToQuote(message),\n      isVisible: (enabledActions: string[]) =>\n        enabledActions.indexOf('quote-message') !== -1,\n    },\n    {\n      actionName: 'pin',\n      actionLabelOrTranslationKey: (message: StreamMessage<T>) =>\n        message.pinned ? 'streamChat.Unpin' : 'streamChat.Pin',\n      actionHandler: (message: StreamMessage<T>) =>\n        message.pinned\n          ? this.channelService.unpinMessage(message)\n          : this.channelService.pinMessage(message),\n      isVisible: (enabledActions: string[]) =>\n        enabledActions.indexOf('pin-message') !== -1,\n    },\n    {\n      actionName: 'flag',\n      actionLabelOrTranslationKey: 'streamChat.Flag',\n      actionHandler: async (message: StreamMessage<T>) => {\n        try {\n          await this.chatClientService.flagMessage(message.id);\n          this.notificationService.addTemporaryNotification(\n            'streamChat.Message has been successfully flagged',\n            'success'\n          );\n        } catch (err) {\n          this.notificationService.addTemporaryNotification(\n            'streamChat.Error adding flag'\n          );\n        }\n      },\n      isVisible: (enabledActions: string[], isMine: boolean) =>\n        enabledActions.indexOf('flag-message') !== -1 && !isMine,\n    },\n    {\n      actionName: 'edit',\n      actionLabelOrTranslationKey: 'streamChat.Edit Message',\n      actionHandler: (message: StreamMessage<T>) => {\n        this.messageToEdit$.next(message);\n      },\n      isVisible: (enabledActions: string[], isMine: boolean) =>\n        (enabledActions.indexOf('update-own-message') !== -1 && isMine) ||\n        enabledActions.indexOf('update-any-message') !== -1,\n    },\n    {\n      actionName: 'delete',\n      actionLabelOrTranslationKey: 'streamChat.Delete',\n      actionHandler: async (message: StreamMessage<T>) => {\n        try {\n          await this.channelService.deleteMessage(message);\n        } catch (error) {\n          this.notificationService.addTemporaryNotification(\n            'streamChat.Error deleting message'\n          );\n        }\n      },\n      isVisible: (enabledActions: string[], isMine: boolean) =>\n        ((enabledActions.indexOf('delete') !== -1 ||\n          enabledActions.indexOf('delete-own-message') !== -1) &&\n          isMine) ||\n        enabledActions.indexOf('delete-any') !== -1 ||\n        enabledActions.indexOf('delete-any-message') !== -1,\n    },\n  ];\n  /**\n   * The built-in components will handle changes to this observable.\n   */\n  messageToEdit$ = new BehaviorSubject<StreamMessage<T> | undefined>(undefined);\n  /**\n   * You can pass your own custom actions that will be displayed inside the built-in message actions component\n   */\n  customActions$ = new BehaviorSubject<CustomMessageActionItem[]>([]);\n\n  constructor(\n    private chatClientService: ChatClientService,\n    private notificationService: NotificationService,\n    private channelService: ChannelService\n  ) {}\n\n  /**\n   * This method returns how many authorized actions are available to the given message\n   *\n   * @param message\n   * @param enabledActions\n   * @returns the count\n   */\n  getAuthorizedMessageActionsCount(\n    message: StreamMessage<T>,\n    enabledActions: string[]\n  ) {\n    const customActions = this.customActions$.getValue() || [];\n    const allActions = [...this.defaultActions, ...customActions];\n    const currentUserId = this.chatClientService.chatClient.user?.id;\n    const isMine = message.user_id === currentUserId;\n\n    return allActions.filter((item) =>\n      item.isVisible(enabledActions, isMine, message)\n    ).length;\n  }\n}\n"]}
|