stream-chat-angular 2.19.0 → 3.0.0-beta.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/assets/version.d.ts +1 -1
- package/bundles/stream-chat-angular.umd.js +374 -365
- package/bundles/stream-chat-angular.umd.js.map +1 -1
- package/esm2015/assets/version.js +2 -2
- package/esm2015/lib/channel-header/channel-header.component.js +26 -9
- package/esm2015/lib/channel-list/channel-list.component.js +23 -13
- package/esm2015/lib/channel.service.js +71 -59
- package/esm2015/lib/chat-client.service.js +26 -2
- package/esm2015/lib/custom-templates.service.js +55 -0
- package/esm2015/lib/message/message.component.js +32 -23
- package/esm2015/lib/message-actions-box/message-actions-box.component.js +28 -12
- package/esm2015/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.js +13 -13
- package/esm2015/lib/message-input/message-input-config.service.js +1 -1
- package/esm2015/lib/message-input/message-input.component.js +26 -45
- package/esm2015/lib/message-input/textarea.directive.js +2 -18
- package/esm2015/lib/message-input/textarea.interface.js +1 -1
- package/esm2015/lib/message-list/message-list.component.js +32 -93
- package/esm2015/lib/notification/notification.component.js +1 -1
- package/esm2015/lib/notification-list/notification-list.component.js +7 -4
- package/esm2015/lib/notification.service.js +34 -18
- package/esm2015/lib/types.js +1 -1
- package/esm2015/public-api.js +2 -1
- package/fesm2015/stream-chat-angular.js +325 -270
- package/fesm2015/stream-chat-angular.js.map +1 -1
- package/lib/channel-header/channel-header.component.d.ts +12 -2
- package/lib/channel-list/channel-list.component.d.ts +12 -9
- package/lib/channel.service.d.ts +13 -13
- package/lib/chat-client.service.d.ts +7 -1
- package/lib/custom-templates.service.d.ts +48 -0
- package/lib/message/message.component.d.ts +13 -28
- package/lib/message-actions-box/message-actions-box.component.d.ts +12 -13
- package/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.d.ts +6 -10
- package/lib/message-input/message-input-config.service.d.ts +0 -19
- package/lib/message-input/message-input.component.d.ts +11 -25
- package/lib/message-input/textarea.directive.d.ts +2 -5
- package/lib/message-input/textarea.interface.d.ts +1 -4
- package/lib/message-list/message-list.component.d.ts +10 -34
- package/lib/notification/notification.component.d.ts +1 -1
- package/lib/notification-list/notification-list.component.d.ts +6 -2
- package/lib/notification.service.d.ts +14 -13
- package/lib/types.d.ts +44 -1
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/src/assets/version.ts +1 -1
|
@@ -5,19 +5,21 @@ import * as i0 from "@angular/core";
|
|
|
5
5
|
import * as i1 from "../chat-client.service";
|
|
6
6
|
import * as i2 from "../notification.service";
|
|
7
7
|
import * as i3 from "../channel.service";
|
|
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 "@
|
|
8
|
+
import * as i4 from "../custom-templates.service";
|
|
9
|
+
import * as i5 from "../modal/modal.component";
|
|
10
|
+
import * as i6 from "../message-input/message-input.component";
|
|
11
|
+
import * as i7 from "../notification-list/notification-list.component";
|
|
12
|
+
import * as i8 from "@angular/common";
|
|
13
|
+
import * as i9 from "@ngx-translate/core";
|
|
13
14
|
/**
|
|
14
15
|
* 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.
|
|
15
16
|
*/
|
|
16
17
|
export class MessageActionsBoxComponent {
|
|
17
|
-
constructor(chatClientService, notificationService, channelService) {
|
|
18
|
+
constructor(chatClientService, notificationService, channelService, customTemplatesService) {
|
|
18
19
|
this.chatClientService = chatClientService;
|
|
19
20
|
this.notificationService = notificationService;
|
|
20
21
|
this.channelService = channelService;
|
|
22
|
+
this.customTemplatesService = customTemplatesService;
|
|
21
23
|
/**
|
|
22
24
|
* 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.
|
|
23
25
|
*/
|
|
@@ -39,10 +41,12 @@ export class MessageActionsBoxComponent {
|
|
|
39
41
|
*/
|
|
40
42
|
this.isEditing = new EventEmitter();
|
|
41
43
|
this.isEditModalOpen = false;
|
|
44
|
+
this.subscriptions = [];
|
|
42
45
|
this.modalClosed = () => {
|
|
43
46
|
this.isEditModalOpen = false;
|
|
44
47
|
this.isEditing.emit(false);
|
|
45
48
|
};
|
|
49
|
+
this.subscriptions.push(this.customTemplatesService.messageInputTemplate$.subscribe((template) => (this.messageInputTemplate = template)));
|
|
46
50
|
}
|
|
47
51
|
ngOnChanges(changes) {
|
|
48
52
|
if (changes.isMine || changes.enabledActions) {
|
|
@@ -68,6 +72,9 @@ export class MessageActionsBoxComponent {
|
|
|
68
72
|
this.displayedActionsCount.next(displayedActionsCount);
|
|
69
73
|
}
|
|
70
74
|
}
|
|
75
|
+
ngOnDestroy() {
|
|
76
|
+
this.subscriptions.forEach((s) => s.unsubscribe());
|
|
77
|
+
}
|
|
71
78
|
get isQuoteVisible() {
|
|
72
79
|
var _a;
|
|
73
80
|
return ((this.enabledActions.indexOf('quote') !== -1 ||
|
|
@@ -127,6 +134,17 @@ export class MessageActionsBoxComponent {
|
|
|
127
134
|
var _a;
|
|
128
135
|
(_a = this.messageInput) === null || _a === void 0 ? void 0 : _a.messageSent();
|
|
129
136
|
}
|
|
137
|
+
getMessageInputContext() {
|
|
138
|
+
return {
|
|
139
|
+
message: this.message,
|
|
140
|
+
messageUpdateHandler: this.modalClosed,
|
|
141
|
+
isFileUploadEnabled: undefined,
|
|
142
|
+
areMentionsEnabled: undefined,
|
|
143
|
+
isMultipleFileUploadEnabled: undefined,
|
|
144
|
+
mentionScope: undefined,
|
|
145
|
+
mode: undefined,
|
|
146
|
+
};
|
|
147
|
+
}
|
|
130
148
|
deleteClicked() {
|
|
131
149
|
return __awaiter(this, void 0, void 0, function* () {
|
|
132
150
|
try {
|
|
@@ -138,8 +156,8 @@ export class MessageActionsBoxComponent {
|
|
|
138
156
|
});
|
|
139
157
|
}
|
|
140
158
|
}
|
|
141
|
-
MessageActionsBoxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: MessageActionsBoxComponent, deps: [{ token: i1.ChatClientService }, { token: i2.NotificationService }, { token: i3.ChannelService }], target: i0.ɵɵFactoryTarget.Component });
|
|
142
|
-
MessageActionsBoxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.5", type: MessageActionsBoxComponent, selector: "stream-message-actions-box", inputs: {
|
|
159
|
+
MessageActionsBoxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: MessageActionsBoxComponent, deps: [{ token: i1.ChatClientService }, { token: i2.NotificationService }, { token: i3.ChannelService }, { token: i4.CustomTemplatesService }], target: i0.ɵɵFactoryTarget.Component });
|
|
160
|
+
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" }, outputs: { displayedActionsCount: "displayedActionsCount", isEditing: "isEditing" }, viewQueries: [{ propertyName: "messageInput", first: true, predicate: MessageInputComponent, descendants: true }], usesOnChanges: true, ngImport: i0, 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-template\n #defaultInput\n let-messageInput=\"message\"\n let-messageUpdateHandler=\"messageUpdateHandler\"\n >\n <stream-message-input\n [message]=\"messageInput\"\n (messageUpdate)=\"messageUpdateHandler()\"\n ></stream-message-input>\n </ng-template>\n <ng-container\n *ngTemplateOutlet=\"\n messageInputTemplate || 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 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: i5.ModalComponent, selector: "stream-modal", inputs: ["isOpen"], outputs: ["isOpenChange"] }, { type: i6.MessageInputComponent, selector: "stream-message-input", inputs: ["isFileUploadEnabled", "areMentionsEnabled", "mentionScope", "mode", "isMultipleFileUploadEnabled", "message"], outputs: ["messageUpdate"] }, { type: i7.NotificationListComponent, selector: "stream-notification-list" }], directives: [{ type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i9.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], pipes: { "translate": i9.TranslatePipe } });
|
|
143
161
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: MessageActionsBoxComponent, decorators: [{
|
|
144
162
|
type: Component,
|
|
145
163
|
args: [{
|
|
@@ -147,9 +165,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
|
|
|
147
165
|
templateUrl: './message-actions-box.component.html',
|
|
148
166
|
styles: [],
|
|
149
167
|
}]
|
|
150
|
-
}], ctorParameters: function () { return [{ type: i1.ChatClientService }, { type: i2.NotificationService }, { type: i3.ChannelService }]; }, propDecorators: {
|
|
151
|
-
type: Input
|
|
152
|
-
}], isOpen: [{
|
|
168
|
+
}], ctorParameters: function () { return [{ type: i1.ChatClientService }, { type: i2.NotificationService }, { type: i3.ChannelService }, { type: i4.CustomTemplatesService }]; }, propDecorators: { isOpen: [{
|
|
153
169
|
type: Input
|
|
154
170
|
}], isMine: [{
|
|
155
171
|
type: Input
|
|
@@ -165,4 +181,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
|
|
|
165
181
|
type: ViewChild,
|
|
166
182
|
args: [MessageInputComponent]
|
|
167
183
|
}] } });
|
|
168
|
-
//# 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 { ChannelService } from '../channel.service';\nimport { ChatClientService } from '../chat-client.service';\nimport { MessageInputComponent } from '../message-input/message-input.component';\nimport { NotificationService } from '../notification.service';\nimport { StreamMessage } from '../types';\n\n/**\n * @deprecated https://getstream.io/chat/docs/sdk/angular/components/message-actions/#required-enabledactions\n */\nexport type MessageActions =\n  | 'edit'\n  | 'delete'\n  | 'edit-any'\n  | 'delete-any'\n  | 'pin'\n  | 'quote'\n  | 'flag'\n  | 'mute';\n\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   * The input used for message edit. By default, the [default message input component](./MessageInputComponent.mdx) is used. To change the input for message edit, provide [your own custom template](./MessageInputComponent.mdx/#customization).\n   */\n  @Input() messageInputTemplate: TemplateRef<any> | undefined;\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   */\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   * 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  @ViewChild(MessageInputComponent) private messageInput:\n    | MessageInputComponent\n    | undefined;\n\n  constructor(\n    private chatClientService: ChatClientService,\n    private notificationService: NotificationService,\n    private channelService: ChannelService\n  ) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.isMine || changes.enabledActions) {\n      let displayedActionsCount = 0;\n      if (this.isQuoteVisible) {\n        displayedActionsCount++;\n      }\n      if (this.isEditVisible) {\n        displayedActionsCount++;\n      }\n      if (this.isDeleteVisible) {\n        displayedActionsCount++;\n      }\n      if (this.isMuteVisible) {\n        displayedActionsCount++;\n      }\n      if (this.isFlagVisible) {\n        displayedActionsCount++;\n      }\n      if (this.isPinVisible) {\n        displayedActionsCount++;\n      }\n      this.displayedActionsCount.next(displayedActionsCount);\n    }\n  }\n\n  get isQuoteVisible() {\n    return (\n      (this.enabledActions.indexOf('quote') !== -1 ||\n        this.enabledActions.indexOf('quote-message') !== -1) &&\n      !this.message?.quoted_message\n    );\n  }\n\n  get isEditVisible() {\n    return (\n      ((this.enabledActions.indexOf('edit') !== -1 ||\n        this.enabledActions.indexOf('update-own-message') !== -1) &&\n        this.isMine) ||\n      this.enabledActions.indexOf('edit-any') !== -1 ||\n      this.enabledActions.indexOf('update-any-message') !== -1\n    );\n  }\n\n  get isDeleteVisible() {\n    return (\n      ((this.enabledActions.indexOf('delete') !== -1 ||\n        this.enabledActions.indexOf('delete-own-message') !== -1) &&\n        this.isMine) ||\n      this.enabledActions.indexOf('delete-any') !== -1 ||\n      this.enabledActions.indexOf('delete-any-message') !== -1\n    );\n  }\n\n  get isMuteVisible() {\n    return this.enabledActions.indexOf('mute') !== -1;\n  }\n\n  get isFlagVisible() {\n    return (\n      (this.enabledActions.indexOf('flag') !== -1 ||\n        this.enabledActions.indexOf('flag-message') !== -1) &&\n      !this.isMine\n    );\n  }\n\n  get isPinVisible() {\n    return this.enabledActions.indexOf('pin') !== -1;\n  }\n\n  pinClicked() {\n    alert('Feature not yet implemented');\n  }\n\n  async flagClicked() {\n    try {\n      await this.chatClientService.flagMessage(this.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\n  muteClicked() {\n    alert('Feature not yet implemented');\n  }\n\n  quoteClicked() {\n    this.channelService.selectMessageToQuote(this.message);\n  }\n\n  editClicked() {\n    this.isEditing.emit(true);\n    this.isEditModalOpen = true;\n  }\n\n  sendClicked() {\n    this.messageInput?.messageSent();\n  }\n\n  modalClosed = () => {\n    this.isEditModalOpen = false;\n    this.isEditing.emit(false);\n  };\n\n  async deleteClicked() {\n    try {\n      await this.channelService.deleteMessage(this.message!);\n    } catch (error) {\n      this.notificationService.addTemporaryNotification(\n        'streamChat.Error deleting message'\n      );\n    }\n  }\n}\n","<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\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 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"]}
|
|
184
|
+
//# 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  OnDestroy,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { ChannelService } from '../channel.service';\nimport { ChatClientService } from '../chat-client.service';\nimport { CustomTemplatesService } from '../custom-templates.service';\nimport { MessageInputComponent } from '../message-input/message-input.component';\nimport { NotificationService } from '../notification.service';\nimport { MessageInputContext, StreamMessage } 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, OnDestroy {\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   */\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   * 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  subscriptions: Subscription[] = [];\n  @ViewChild(MessageInputComponent) private messageInput:\n    | MessageInputComponent\n    | undefined;\n\n  constructor(\n    private chatClientService: ChatClientService,\n    private notificationService: NotificationService,\n    private channelService: ChannelService,\n    private customTemplatesService: CustomTemplatesService\n  ) {\n    this.subscriptions.push(\n      this.customTemplatesService.messageInputTemplate$.subscribe(\n        (template) => (this.messageInputTemplate = template)\n      )\n    );\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.isMine || changes.enabledActions) {\n      let displayedActionsCount = 0;\n      if (this.isQuoteVisible) {\n        displayedActionsCount++;\n      }\n      if (this.isEditVisible) {\n        displayedActionsCount++;\n      }\n      if (this.isDeleteVisible) {\n        displayedActionsCount++;\n      }\n      if (this.isMuteVisible) {\n        displayedActionsCount++;\n      }\n      if (this.isFlagVisible) {\n        displayedActionsCount++;\n      }\n      if (this.isPinVisible) {\n        displayedActionsCount++;\n      }\n      this.displayedActionsCount.next(displayedActionsCount);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach((s) => s.unsubscribe());\n  }\n\n  get isQuoteVisible() {\n    return (\n      (this.enabledActions.indexOf('quote') !== -1 ||\n        this.enabledActions.indexOf('quote-message') !== -1) &&\n      !this.message?.quoted_message\n    );\n  }\n\n  get isEditVisible() {\n    return (\n      ((this.enabledActions.indexOf('edit') !== -1 ||\n        this.enabledActions.indexOf('update-own-message') !== -1) &&\n        this.isMine) ||\n      this.enabledActions.indexOf('edit-any') !== -1 ||\n      this.enabledActions.indexOf('update-any-message') !== -1\n    );\n  }\n\n  get isDeleteVisible() {\n    return (\n      ((this.enabledActions.indexOf('delete') !== -1 ||\n        this.enabledActions.indexOf('delete-own-message') !== -1) &&\n        this.isMine) ||\n      this.enabledActions.indexOf('delete-any') !== -1 ||\n      this.enabledActions.indexOf('delete-any-message') !== -1\n    );\n  }\n\n  get isMuteVisible() {\n    return this.enabledActions.indexOf('mute') !== -1;\n  }\n\n  get isFlagVisible() {\n    return (\n      (this.enabledActions.indexOf('flag') !== -1 ||\n        this.enabledActions.indexOf('flag-message') !== -1) &&\n      !this.isMine\n    );\n  }\n\n  get isPinVisible() {\n    return this.enabledActions.indexOf('pin') !== -1;\n  }\n\n  pinClicked() {\n    alert('Feature not yet implemented');\n  }\n\n  async flagClicked() {\n    try {\n      await this.chatClientService.flagMessage(this.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\n  muteClicked() {\n    alert('Feature not yet implemented');\n  }\n\n  quoteClicked() {\n    this.channelService.selectMessageToQuote(this.message);\n  }\n\n  editClicked() {\n    this.isEditing.emit(true);\n    this.isEditModalOpen = true;\n  }\n\n  sendClicked() {\n    this.messageInput?.messageSent();\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    };\n  }\n\n  async deleteClicked() {\n    try {\n      await this.channelService.deleteMessage(this.message!);\n    } catch (error) {\n      this.notificationService.addTemporaryNotification(\n        'streamChat.Error deleting message'\n      );\n    }\n  }\n}\n","<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-template\n      #defaultInput\n      let-messageInput=\"message\"\n      let-messageUpdateHandler=\"messageUpdateHandler\"\n    >\n      <stream-message-input\n        [message]=\"messageInput\"\n        (messageUpdate)=\"messageUpdateHandler()\"\n      ></stream-message-input>\n    </ng-template>\n    <ng-container\n      *ngTemplateOutlet=\"\n        messageInputTemplate || 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 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"]}
|
|
@@ -7,19 +7,21 @@ import * as i1 from "../../channel.service";
|
|
|
7
7
|
import * as i2 from "../../chat-client.service";
|
|
8
8
|
import * as i3 from "../../transliteration.service";
|
|
9
9
|
import * as i4 from "../emoji-input.service";
|
|
10
|
-
import * as i5 from "../../
|
|
11
|
-
import * as i6 from "
|
|
12
|
-
import * as i7 from "
|
|
13
|
-
import * as i8 from "@
|
|
10
|
+
import * as i5 from "../../custom-templates.service";
|
|
11
|
+
import * as i6 from "../../avatar/avatar.component";
|
|
12
|
+
import * as i7 from "angular-mentions";
|
|
13
|
+
import * as i8 from "@angular/common";
|
|
14
|
+
import * as i9 from "@ngx-translate/core";
|
|
14
15
|
/**
|
|
15
16
|
* The `AutocompleteTextarea` component is used by the [`MessageInput`](./MessageInputComponent.mdx) component to display the input HTML element where users can type their message.
|
|
16
17
|
*/
|
|
17
18
|
export class AutocompleteTextareaComponent {
|
|
18
|
-
constructor(channelService, chatClientService, transliterationService, emojiInputService) {
|
|
19
|
+
constructor(channelService, chatClientService, transliterationService, emojiInputService, customTemplatesService) {
|
|
19
20
|
this.channelService = channelService;
|
|
20
21
|
this.chatClientService = chatClientService;
|
|
21
22
|
this.transliterationService = transliterationService;
|
|
22
23
|
this.emojiInputService = emojiInputService;
|
|
24
|
+
this.customTemplatesService = customTemplatesService;
|
|
23
25
|
this.class = 'str-chat__textarea';
|
|
24
26
|
/**
|
|
25
27
|
* The value of the input HTML element.
|
|
@@ -95,6 +97,8 @@ export class AutocompleteTextareaComponent {
|
|
|
95
97
|
selectionStart + emoji.length;
|
|
96
98
|
this.inputChanged();
|
|
97
99
|
}));
|
|
100
|
+
this.subscriptions.push(this.customTemplatesService.mentionAutocompleteItemTemplate$.subscribe((template) => (this.mentionAutocompleteItemTemplate = template)));
|
|
101
|
+
this.subscriptions.push(this.customTemplatesService.commandAutocompleteItemTemplate$.subscribe((template) => (this.commandAutocompleteItemTemplate = template)));
|
|
98
102
|
this.autocompleteConfig.mentions = [
|
|
99
103
|
this.userMentionConfig,
|
|
100
104
|
this.slashCommandConfig,
|
|
@@ -193,8 +197,8 @@ export class AutocompleteTextareaComponent {
|
|
|
193
197
|
}
|
|
194
198
|
}
|
|
195
199
|
}
|
|
196
|
-
AutocompleteTextareaComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: AutocompleteTextareaComponent, deps: [{ token: i1.ChannelService }, { token: i2.ChatClientService }, { token: i3.TransliterationService }, { token: i4.EmojiInputService }], target: i0.ɵɵFactoryTarget.Component });
|
|
197
|
-
AutocompleteTextareaComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.5", type: AutocompleteTextareaComponent, selector: "stream-autocomplete-textarea", inputs: { value: "value", areMentionsEnabled: "areMentionsEnabled",
|
|
200
|
+
AutocompleteTextareaComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: AutocompleteTextareaComponent, deps: [{ token: i1.ChannelService }, { token: i2.ChatClientService }, { token: i3.TransliterationService }, { token: i4.EmojiInputService }, { token: i5.CustomTemplatesService }], target: i0.ɵɵFactoryTarget.Component });
|
|
201
|
+
AutocompleteTextareaComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.5", type: AutocompleteTextareaComponent, selector: "stream-autocomplete-textarea", inputs: { value: "value", areMentionsEnabled: "areMentionsEnabled", mentionScope: "mentionScope" }, outputs: { valueChange: "valueChange", send: "send", userMentions: "userMentions" }, host: { properties: { "class": "this.class" } }, viewQueries: [{ propertyName: "messageInput", first: true, predicate: ["input"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<textarea\n [value]=\"value || ''\"\n autofocus\n data-testid=\"textarea\"\n #input\n placeholder=\"{{ 'streamChat.Type your message' | translate }}\"\n class=\"rta__textarea str-chat__textarea__textarea str-chat__angular-textarea\"\n rows=\"1\"\n (input)=\"inputChanged()\"\n (keydown.enter)=\"sent($event)\"\n [mentionConfig]=\"autocompleteConfig\"\n (searchTerm)=\"autcompleteSearchTermChanged($event)\"\n [mentionListTemplate]=\"autocompleteItem\"\n (blur)=\"inputLeft()\"\n></textarea>\n<ng-template #autocompleteItem let-item=\"item\">\n <div class=\"rta rta__item str-chat__emojisearch__item\" [ngSwitch]=\"item.type\">\n <div class=\"rta__entity\" *ngSwitchCase=\"'mention'\">\n <ng-container\n *ngTemplateOutlet=\"\n mentionAutocompleteItemTemplate || defaultMentionTemplate;\n context: { item: item }\n \"\n ></ng-container>\n </div>\n <div class=\"rta__entity\" *ngSwitchCase=\"'command'\">\n <ng-container\n *ngTemplateOutlet=\"\n commandAutocompleteItemTemplate || defaultCommandTemplate;\n context: { item: item }\n \"\n ></ng-container>\n </div>\n </div>\n</ng-template>\n\n<ng-template #defaultCommandTemplate let-item=\"item\">\n <div class=\"str-chat__slash-command\">\n <span class=\"str-chat__slash-command-header\">\n <strong data-testclass=\"command-name\">{{ item.name }}</strong>\n {{ item.args }}\n </span>\n <br />\n <span class=\"str-chat__slash-command-description\">{{\n item.description\n }}</span>\n </div>\n</ng-template>\n\n<ng-template #defaultMentionTemplate let-item=\"item\">\n <div class=\"str-chat__user-item\">\n <stream-avatar\n data-testclass=\"avatar\"\n class=\"str-chat__avatar str-chat__avatar--circle\"\n style=\"height: 20px\"\n [size]=\"20\"\n [imageUrl]=\"item.image || item.user?.image\"\n [name]=\"item.autocompleteLabel\"\n ></stream-avatar>\n <span data-testclass=\"username\" class=\"str-chat__user-item--name\">{{\n item.autocompleteLabel\n }}</span>\n </div>\n</ng-template>\n", components: [{ type: i6.AvatarComponent, selector: "stream-avatar", inputs: ["name", "imageUrl", "size"] }], directives: [{ type: i7.MentionDirective, selector: "[mention], [mentionConfig]", inputs: ["mentionConfig", "mention", "mentionListTemplate"], outputs: ["searchTerm", "itemSelected", "opened", "closed"] }, { type: i8.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i8.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i8.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "translate": i9.TranslatePipe } });
|
|
198
202
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: AutocompleteTextareaComponent, decorators: [{
|
|
199
203
|
type: Component,
|
|
200
204
|
args: [{
|
|
@@ -202,16 +206,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
|
|
|
202
206
|
templateUrl: './autocomplete-textarea.component.html',
|
|
203
207
|
styles: [],
|
|
204
208
|
}]
|
|
205
|
-
}], ctorParameters: function () { return [{ type: i1.ChannelService }, { type: i2.ChatClientService }, { type: i3.TransliterationService }, { type: i4.EmojiInputService }]; }, propDecorators: { class: [{
|
|
209
|
+
}], ctorParameters: function () { return [{ type: i1.ChannelService }, { type: i2.ChatClientService }, { type: i3.TransliterationService }, { type: i4.EmojiInputService }, { type: i5.CustomTemplatesService }]; }, propDecorators: { class: [{
|
|
206
210
|
type: HostBinding
|
|
207
211
|
}], value: [{
|
|
208
212
|
type: Input
|
|
209
213
|
}], areMentionsEnabled: [{
|
|
210
214
|
type: Input
|
|
211
|
-
}], mentionAutocompleteItemTemplate: [{
|
|
212
|
-
type: Input
|
|
213
|
-
}], commandAutocompleteItemTemplate: [{
|
|
214
|
-
type: Input
|
|
215
215
|
}], mentionScope: [{
|
|
216
216
|
type: Input
|
|
217
217
|
}], valueChange: [{
|
|
@@ -224,4 +224,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
|
|
|
224
224
|
type: ViewChild,
|
|
225
225
|
args: ['input']
|
|
226
226
|
}] } });
|
|
227
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete-textarea.component.js","sourceRoot":"","sources":["../../../../../../projects/stream-chat-angular/src/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.ts","../../../../../../projects/stream-chat-angular/src/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { MentionConfig, Mentions } from 'angular-mentions';\nimport {\n  MentionAutcompleteListItemContext,\n  MentionAutcompleteListItem,\n  CommandAutocompleteListItemContext,\n} from '../../types';\n\nimport { BehaviorSubject, Subscription } from 'rxjs';\nimport { UserResponse } from 'stream-chat';\nimport { ChannelService } from '../../channel.service';\nimport { TextareaInterface } from '../textarea.interface';\nimport { ChatClientService } from '../../chat-client.service';\nimport { debounceTime, distinctUntilChanged } from 'rxjs/operators';\nimport { TransliterationService } from '../../transliteration.service';\nimport { EmojiInputService } from '../emoji-input.service';\n\n/**\n * The `AutocompleteTextarea` component is used by the [`MessageInput`](./MessageInputComponent.mdx) component to display the input HTML element where users can type their message.\n */\n@Component({\n  selector: 'stream-autocomplete-textarea',\n  templateUrl: './autocomplete-textarea.component.html',\n  styles: [],\n})\nexport class AutocompleteTextareaComponent\n  implements TextareaInterface, OnChanges\n{\n  @HostBinding() class = 'str-chat__textarea';\n  /**\n   * The value of the input HTML element.\n   */\n  @Input() value = '';\n  /**\n   * If true, users can mention other users in messages. You can also set this input on the [`MessageInput`](./MessageInputComponent.mdx/#inputs-and-outputs) component.\n   */\n  @Input() areMentionsEnabled: boolean | undefined = true;\n  /**\n   * You can provide your own template for the autocomplete list for user mentions. You can also set this input on the [`MessageInput`](./MessageInputComponent.mdx/#inputs-and-outputs) component.\n   */\n  @Input() mentionAutocompleteItemTemplate:\n    | TemplateRef<MentionAutcompleteListItemContext>\n    | undefined;\n  /**\n   * You can provide your own template for the autocomplete list for commands. You can also set this input on the [`MessageInput`](./MessageInputComponent.mdx/#inputs-and-outputs) component.\n   */\n  @Input() commandAutocompleteItemTemplate:\n    | TemplateRef<CommandAutocompleteListItemContext>\n    | undefined;\n  /**\n   * The scope for user mentions, either members of the current channel of members of the application. You can also set this input on the [`MessageInput`](./MessageInputComponent.mdx/#inputs-and-outputs) component.\n   */\n  @Input() mentionScope: 'channel' | 'application' = 'channel';\n  /**\n   * Emits the current value of the input element when a user types.\n   */\n  @Output() readonly valueChange = new EventEmitter<string>();\n  /**\n   * Emits when a user triggers a message send event (this happens when they hit the `Enter` key).\n   */\n  @Output() readonly send = new EventEmitter<void>();\n  /**\n   * Emits the array of users that are mentioned in the message, it is updated when a user mentions a new user or deletes a mention.\n   */\n  @Output() readonly userMentions = new EventEmitter<UserResponse[]>();\n  private readonly autocompleteKey = 'autocompleteLabel';\n  private readonly mentionTriggerChar = '@';\n  private readonly commandTriggerChar = '/';\n  autocompleteConfig: MentionConfig = {\n    mentions: [],\n  };\n  @ViewChild('input') private messageInput!: ElementRef<HTMLInputElement>;\n  private subscriptions: Subscription[] = [];\n  private mentionedUsers: UserResponse[] = [];\n  private userMentionConfig: Mentions = {\n    triggerChar: this.mentionTriggerChar,\n    dropUp: true,\n    labelKey: this.autocompleteKey,\n    returnTrigger: true,\n    mentionFilter: (\n      searchString: string,\n      items: { autocompleteLabel: string }[]\n    ) => this.filter(searchString, items),\n    mentionSelect: (item, triggerChar) =>\n      this.itemSelectedFromAutocompleteList(item, triggerChar),\n  };\n  private slashCommandConfig: Mentions = {\n    triggerChar: this.commandTriggerChar,\n    dropUp: true,\n    labelKey: 'name',\n    returnTrigger: true,\n    mentionFilter: (\n      searchString: string,\n      items: { autocompleteLabel: string }[]\n    ) => this.filter(searchString, items),\n    mentionSelect: (item, triggerChar) =>\n      this.itemSelectedFromAutocompleteList(item, triggerChar),\n  };\n  private searchTerm$ = new BehaviorSubject<string>('');\n\n  constructor(\n    private channelService: ChannelService,\n    private chatClientService: ChatClientService,\n    private transliterationService: TransliterationService,\n    private emojiInputService: EmojiInputService\n  ) {\n    this.searchTerm$\n      .pipe(debounceTime(300), distinctUntilChanged())\n      .subscribe((searchTerm) => {\n        if (searchTerm.startsWith(this.mentionTriggerChar)) {\n          void this.updateMentionOptions(searchTerm);\n        }\n      });\n    this.subscriptions.push(\n      this.channelService.activeChannel$.subscribe((channel) => {\n        const commands = channel?.getConfig()?.commands || [];\n        this.slashCommandConfig.items = commands.map((c) => ({\n          ...c,\n          [this.autocompleteKey]: c.name,\n          type: 'command',\n        }));\n        this.mentionedUsers = [];\n        this.userMentions.next([...this.mentionedUsers]);\n        void this.updateMentionOptions(this.searchTerm$.getValue());\n      })\n    );\n    this.subscriptions.push(\n      this.emojiInputService.emojiInput$.subscribe((emoji) => {\n        this.messageInput.nativeElement.focus();\n        const { selectionStart } = this.messageInput.nativeElement;\n        this.messageInput.nativeElement.setRangeText(emoji);\n        this.messageInput.nativeElement.selectionStart =\n          selectionStart! + emoji.length;\n        this.messageInput.nativeElement.selectionEnd =\n          selectionStart! + emoji.length;\n        this.inputChanged();\n      })\n    );\n    this.autocompleteConfig.mentions = [\n      this.userMentionConfig,\n      this.slashCommandConfig,\n    ];\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.areMentionsEnabled) {\n      if (this.areMentionsEnabled) {\n        this.autocompleteConfig.mentions = [\n          this.userMentionConfig,\n          this.slashCommandConfig,\n        ];\n        this.autocompleteConfig = { ...this.autocompleteConfig };\n      } else {\n        this.autocompleteConfig.mentions = [this.slashCommandConfig];\n        this.autocompleteConfig = { ...this.autocompleteConfig };\n      }\n    }\n    if (changes.mentionScope) {\n      void this.updateMentionOptions(this.searchTerm$.getValue());\n    }\n  }\n\n  filter(searchString: string, items: { autocompleteLabel: string }[]) {\n    return items.filter((item) =>\n      this.transliterate(item.autocompleteLabel.toLowerCase()).includes(\n        this.transliterate(searchString.toLowerCase())\n      )\n    );\n  }\n\n  itemSelectedFromAutocompleteList(\n    item: MentionAutcompleteListItem,\n    triggerChar = ''\n  ) {\n    if (triggerChar === this.mentionTriggerChar) {\n      this.mentionedUsers.push((item.user ? item.user : item) as UserResponse);\n      this.userMentions.next([...this.mentionedUsers]);\n    }\n    return (\n      triggerChar +\n      item.autocompleteLabel +\n      (triggerChar === this.commandTriggerChar ? ' ' : '')\n    );\n  }\n\n  autcompleteSearchTermChanged(searchTerm: string) {\n    if (searchTerm === this.mentionTriggerChar) {\n      void this.updateMentionOptions();\n    } else {\n      this.searchTerm$.next(searchTerm);\n    }\n  }\n\n  inputChanged() {\n    this.valueChange.emit(this.messageInput.nativeElement.value);\n  }\n\n  inputLeft() {\n    this.updateMentionedUsersFromText();\n  }\n\n  sent(event: Event) {\n    event.preventDefault();\n    this.updateMentionedUsersFromText();\n    this.send.next();\n  }\n\n  private transliterate(s: string) {\n    if (this.transliterationService) {\n      return this.transliterationService.transliterate(s);\n    } else {\n      return s;\n    }\n  }\n\n  private async updateMentionOptions(searchTerm?: string) {\n    if (!this.areMentionsEnabled) {\n      return;\n    }\n    searchTerm = searchTerm?.replace(this.mentionTriggerChar, '');\n    const request =\n      this.mentionScope === 'application'\n        ? (s: string) => this.chatClientService.autocompleteUsers(s)\n        : (s: string) => this.channelService.autocompleteMembers(s);\n    const result = await request(searchTerm || '');\n    const items = this.filter(\n      searchTerm || '',\n      result.map((i) => {\n        const user = (i.user ? i.user : i) as UserResponse;\n        return {\n          ...i,\n          autocompleteLabel: user.name || user.id,\n          type: 'mention',\n        };\n      })\n    );\n    this.userMentionConfig.items = items;\n    this.autocompleteConfig.mentions = [\n      this.userMentionConfig,\n      this.slashCommandConfig,\n    ];\n    this.autocompleteConfig = { ...this.autocompleteConfig };\n  }\n\n  private updateMentionedUsersFromText() {\n    const updatedMentionedUsers: UserResponse[] = [];\n    this.mentionedUsers.forEach((u) => {\n      const key = u.name || u.id;\n      if (this.value.includes(`${this.mentionTriggerChar}${key}`)) {\n        updatedMentionedUsers.push(u);\n      }\n    });\n    if (updatedMentionedUsers.length !== this.mentionedUsers.length) {\n      this.userMentions.next([...updatedMentionedUsers]);\n      this.mentionedUsers = updatedMentionedUsers;\n    }\n  }\n}\n","<textarea\n  [value]=\"value || ''\"\n  autofocus\n  data-testid=\"textarea\"\n  #input\n  placeholder=\"{{ 'streamChat.Type your message' | translate }}\"\n  class=\"rta__textarea str-chat__textarea__textarea str-chat__angular-textarea\"\n  rows=\"1\"\n  (input)=\"inputChanged()\"\n  (keydown.enter)=\"sent($event)\"\n  [mentionConfig]=\"autocompleteConfig\"\n  (searchTerm)=\"autcompleteSearchTermChanged($event)\"\n  [mentionListTemplate]=\"autocompleteItem\"\n  (blur)=\"inputLeft()\"\n></textarea>\n<ng-template #autocompleteItem let-item=\"item\">\n  <div class=\"rta rta__item str-chat__emojisearch__item\" [ngSwitch]=\"item.type\">\n    <div class=\"rta__entity\" *ngSwitchCase=\"'mention'\">\n      <ng-container\n        *ngTemplateOutlet=\"\n          mentionAutocompleteItemTemplate || defaultMentionTemplate;\n          context: { item: item }\n        \"\n      ></ng-container>\n    </div>\n    <div class=\"rta__entity\" *ngSwitchCase=\"'command'\">\n      <ng-container\n        *ngTemplateOutlet=\"\n          commandAutocompleteItemTemplate || defaultCommandTemplate;\n          context: { item: item }\n        \"\n      ></ng-container>\n    </div>\n  </div>\n</ng-template>\n\n<ng-template #defaultCommandTemplate let-item=\"item\">\n  <div class=\"str-chat__slash-command\">\n    <span class=\"str-chat__slash-command-header\">\n      <strong data-testclass=\"command-name\">{{ item.name }}</strong>\n      {{ item.args }}\n    </span>\n    <br />\n    <span class=\"str-chat__slash-command-description\">{{\n      item.description\n    }}</span>\n  </div>\n</ng-template>\n\n<ng-template #defaultMentionTemplate let-item=\"item\">\n  <div class=\"str-chat__user-item\">\n    <stream-avatar\n      data-testclass=\"avatar\"\n      class=\"str-chat__avatar str-chat__avatar--circle\"\n      style=\"height: 20px\"\n      [size]=\"20\"\n      [imageUrl]=\"item.image || item.user?.image\"\n      [name]=\"item.autocompleteLabel\"\n    ></stream-avatar>\n    <span data-testclass=\"username\" class=\"str-chat__user-item--name\">{{\n      item.autocompleteLabel\n    }}</span>\n  </div>\n</ng-template>\n"]}
|
|
227
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete-textarea.component.js","sourceRoot":"","sources":["../../../../../../projects/stream-chat-angular/src/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.ts","../../../../../../projects/stream-chat-angular/src/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { MentionConfig, Mentions } from 'angular-mentions';\nimport {\n  MentionAutcompleteListItemContext,\n  MentionAutcompleteListItem,\n  CommandAutocompleteListItemContext,\n} from '../../types';\n\nimport { BehaviorSubject, Subscription } from 'rxjs';\nimport { UserResponse } from 'stream-chat';\nimport { ChannelService } from '../../channel.service';\nimport { TextareaInterface } from '../textarea.interface';\nimport { ChatClientService } from '../../chat-client.service';\nimport { debounceTime, distinctUntilChanged } from 'rxjs/operators';\nimport { TransliterationService } from '../../transliteration.service';\nimport { EmojiInputService } from '../emoji-input.service';\nimport { CustomTemplatesService } from '../../custom-templates.service';\n\n/**\n * The `AutocompleteTextarea` component is used by the [`MessageInput`](./MessageInputComponent.mdx) component to display the input HTML element where users can type their message.\n */\n@Component({\n  selector: 'stream-autocomplete-textarea',\n  templateUrl: './autocomplete-textarea.component.html',\n  styles: [],\n})\nexport class AutocompleteTextareaComponent\n  implements TextareaInterface, OnChanges\n{\n  @HostBinding() class = 'str-chat__textarea';\n  /**\n   * The value of the input HTML element.\n   */\n  @Input() value = '';\n  /**\n   * If true, users can mention other users in messages. You can also set this input on the [`MessageInput`](./MessageInputComponent.mdx/#inputs-and-outputs) component.\n   */\n  @Input() areMentionsEnabled: boolean | undefined = true;\n  /**\n   * The scope for user mentions, either members of the current channel of members of the application. You can also set this input on the [`MessageInput`](./MessageInputComponent.mdx/#inputs-and-outputs) component.\n   */\n  @Input() mentionScope: 'channel' | 'application' = 'channel';\n  /**\n   * Emits the current value of the input element when a user types.\n   */\n  @Output() readonly valueChange = new EventEmitter<string>();\n  /**\n   * Emits when a user triggers a message send event (this happens when they hit the `Enter` key).\n   */\n  @Output() readonly send = new EventEmitter<void>();\n  /**\n   * Emits the array of users that are mentioned in the message, it is updated when a user mentions a new user or deletes a mention.\n   */\n  @Output() readonly userMentions = new EventEmitter<UserResponse[]>();\n  mentionAutocompleteItemTemplate:\n    | TemplateRef<MentionAutcompleteListItemContext>\n    | undefined;\n  commandAutocompleteItemTemplate:\n    | TemplateRef<CommandAutocompleteListItemContext>\n    | undefined;\n  private readonly autocompleteKey = 'autocompleteLabel';\n  private readonly mentionTriggerChar = '@';\n  private readonly commandTriggerChar = '/';\n  autocompleteConfig: MentionConfig = {\n    mentions: [],\n  };\n  @ViewChild('input') private messageInput!: ElementRef<HTMLInputElement>;\n  private subscriptions: Subscription[] = [];\n  private mentionedUsers: UserResponse[] = [];\n  private userMentionConfig: Mentions = {\n    triggerChar: this.mentionTriggerChar,\n    dropUp: true,\n    labelKey: this.autocompleteKey,\n    returnTrigger: true,\n    mentionFilter: (\n      searchString: string,\n      items: { autocompleteLabel: string }[]\n    ) => this.filter(searchString, items),\n    mentionSelect: (item, triggerChar) =>\n      this.itemSelectedFromAutocompleteList(item, triggerChar),\n  };\n  private slashCommandConfig: Mentions = {\n    triggerChar: this.commandTriggerChar,\n    dropUp: true,\n    labelKey: 'name',\n    returnTrigger: true,\n    mentionFilter: (\n      searchString: string,\n      items: { autocompleteLabel: string }[]\n    ) => this.filter(searchString, items),\n    mentionSelect: (item, triggerChar) =>\n      this.itemSelectedFromAutocompleteList(item, triggerChar),\n  };\n  private searchTerm$ = new BehaviorSubject<string>('');\n\n  constructor(\n    private channelService: ChannelService,\n    private chatClientService: ChatClientService,\n    private transliterationService: TransliterationService,\n    private emojiInputService: EmojiInputService,\n    private customTemplatesService: CustomTemplatesService\n  ) {\n    this.searchTerm$\n      .pipe(debounceTime(300), distinctUntilChanged())\n      .subscribe((searchTerm) => {\n        if (searchTerm.startsWith(this.mentionTriggerChar)) {\n          void this.updateMentionOptions(searchTerm);\n        }\n      });\n    this.subscriptions.push(\n      this.channelService.activeChannel$.subscribe((channel) => {\n        const commands = channel?.getConfig()?.commands || [];\n        this.slashCommandConfig.items = commands.map((c) => ({\n          ...c,\n          [this.autocompleteKey]: c.name,\n          type: 'command',\n        }));\n        this.mentionedUsers = [];\n        this.userMentions.next([...this.mentionedUsers]);\n        void this.updateMentionOptions(this.searchTerm$.getValue());\n      })\n    );\n    this.subscriptions.push(\n      this.emojiInputService.emojiInput$.subscribe((emoji) => {\n        this.messageInput.nativeElement.focus();\n        const { selectionStart } = this.messageInput.nativeElement;\n        this.messageInput.nativeElement.setRangeText(emoji);\n        this.messageInput.nativeElement.selectionStart =\n          selectionStart! + emoji.length;\n        this.messageInput.nativeElement.selectionEnd =\n          selectionStart! + emoji.length;\n        this.inputChanged();\n      })\n    );\n    this.subscriptions.push(\n      this.customTemplatesService.mentionAutocompleteItemTemplate$.subscribe(\n        (template) => (this.mentionAutocompleteItemTemplate = template)\n      )\n    );\n    this.subscriptions.push(\n      this.customTemplatesService.commandAutocompleteItemTemplate$.subscribe(\n        (template) => (this.commandAutocompleteItemTemplate = template)\n      )\n    );\n    this.autocompleteConfig.mentions = [\n      this.userMentionConfig,\n      this.slashCommandConfig,\n    ];\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.areMentionsEnabled) {\n      if (this.areMentionsEnabled) {\n        this.autocompleteConfig.mentions = [\n          this.userMentionConfig,\n          this.slashCommandConfig,\n        ];\n        this.autocompleteConfig = { ...this.autocompleteConfig };\n      } else {\n        this.autocompleteConfig.mentions = [this.slashCommandConfig];\n        this.autocompleteConfig = { ...this.autocompleteConfig };\n      }\n    }\n    if (changes.mentionScope) {\n      void this.updateMentionOptions(this.searchTerm$.getValue());\n    }\n  }\n\n  filter(searchString: string, items: { autocompleteLabel: string }[]) {\n    return items.filter((item) =>\n      this.transliterate(item.autocompleteLabel.toLowerCase()).includes(\n        this.transliterate(searchString.toLowerCase())\n      )\n    );\n  }\n\n  itemSelectedFromAutocompleteList(\n    item: MentionAutcompleteListItem,\n    triggerChar = ''\n  ) {\n    if (triggerChar === this.mentionTriggerChar) {\n      this.mentionedUsers.push((item.user ? item.user : item) as UserResponse);\n      this.userMentions.next([...this.mentionedUsers]);\n    }\n    return (\n      triggerChar +\n      item.autocompleteLabel +\n      (triggerChar === this.commandTriggerChar ? ' ' : '')\n    );\n  }\n\n  autcompleteSearchTermChanged(searchTerm: string) {\n    if (searchTerm === this.mentionTriggerChar) {\n      void this.updateMentionOptions();\n    } else {\n      this.searchTerm$.next(searchTerm);\n    }\n  }\n\n  inputChanged() {\n    this.valueChange.emit(this.messageInput.nativeElement.value);\n  }\n\n  inputLeft() {\n    this.updateMentionedUsersFromText();\n  }\n\n  sent(event: Event) {\n    event.preventDefault();\n    this.updateMentionedUsersFromText();\n    this.send.next();\n  }\n\n  private transliterate(s: string) {\n    if (this.transliterationService) {\n      return this.transliterationService.transliterate(s);\n    } else {\n      return s;\n    }\n  }\n\n  private async updateMentionOptions(searchTerm?: string) {\n    if (!this.areMentionsEnabled) {\n      return;\n    }\n    searchTerm = searchTerm?.replace(this.mentionTriggerChar, '');\n    const request =\n      this.mentionScope === 'application'\n        ? (s: string) => this.chatClientService.autocompleteUsers(s)\n        : (s: string) => this.channelService.autocompleteMembers(s);\n    const result = await request(searchTerm || '');\n    const items = this.filter(\n      searchTerm || '',\n      result.map((i) => {\n        const user = (i.user ? i.user : i) as UserResponse;\n        return {\n          ...i,\n          autocompleteLabel: user.name || user.id,\n          type: 'mention',\n        };\n      })\n    );\n    this.userMentionConfig.items = items;\n    this.autocompleteConfig.mentions = [\n      this.userMentionConfig,\n      this.slashCommandConfig,\n    ];\n    this.autocompleteConfig = { ...this.autocompleteConfig };\n  }\n\n  private updateMentionedUsersFromText() {\n    const updatedMentionedUsers: UserResponse[] = [];\n    this.mentionedUsers.forEach((u) => {\n      const key = u.name || u.id;\n      if (this.value.includes(`${this.mentionTriggerChar}${key}`)) {\n        updatedMentionedUsers.push(u);\n      }\n    });\n    if (updatedMentionedUsers.length !== this.mentionedUsers.length) {\n      this.userMentions.next([...updatedMentionedUsers]);\n      this.mentionedUsers = updatedMentionedUsers;\n    }\n  }\n}\n","<textarea\n  [value]=\"value || ''\"\n  autofocus\n  data-testid=\"textarea\"\n  #input\n  placeholder=\"{{ 'streamChat.Type your message' | translate }}\"\n  class=\"rta__textarea str-chat__textarea__textarea str-chat__angular-textarea\"\n  rows=\"1\"\n  (input)=\"inputChanged()\"\n  (keydown.enter)=\"sent($event)\"\n  [mentionConfig]=\"autocompleteConfig\"\n  (searchTerm)=\"autcompleteSearchTermChanged($event)\"\n  [mentionListTemplate]=\"autocompleteItem\"\n  (blur)=\"inputLeft()\"\n></textarea>\n<ng-template #autocompleteItem let-item=\"item\">\n  <div class=\"rta rta__item str-chat__emojisearch__item\" [ngSwitch]=\"item.type\">\n    <div class=\"rta__entity\" *ngSwitchCase=\"'mention'\">\n      <ng-container\n        *ngTemplateOutlet=\"\n          mentionAutocompleteItemTemplate || defaultMentionTemplate;\n          context: { item: item }\n        \"\n      ></ng-container>\n    </div>\n    <div class=\"rta__entity\" *ngSwitchCase=\"'command'\">\n      <ng-container\n        *ngTemplateOutlet=\"\n          commandAutocompleteItemTemplate || defaultCommandTemplate;\n          context: { item: item }\n        \"\n      ></ng-container>\n    </div>\n  </div>\n</ng-template>\n\n<ng-template #defaultCommandTemplate let-item=\"item\">\n  <div class=\"str-chat__slash-command\">\n    <span class=\"str-chat__slash-command-header\">\n      <strong data-testclass=\"command-name\">{{ item.name }}</strong>\n      {{ item.args }}\n    </span>\n    <br />\n    <span class=\"str-chat__slash-command-description\">{{\n      item.description\n    }}</span>\n  </div>\n</ng-template>\n\n<ng-template #defaultMentionTemplate let-item=\"item\">\n  <div class=\"str-chat__user-item\">\n    <stream-avatar\n      data-testclass=\"avatar\"\n      class=\"str-chat__avatar str-chat__avatar--circle\"\n      style=\"height: 20px\"\n      [size]=\"20\"\n      [imageUrl]=\"item.image || item.user?.image\"\n      [name]=\"item.autocompleteLabel\"\n    ></stream-avatar>\n    <span data-testclass=\"username\" class=\"str-chat__user-item--name\">{{\n      item.autocompleteLabel\n    }}</span>\n  </div>\n</ng-template>\n"]}
|
|
@@ -31,4 +31,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
|
|
|
31
31
|
providedIn: 'root',
|
|
32
32
|
}]
|
|
33
33
|
}], ctorParameters: function () { return []; } });
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVzc2FnZS1pbnB1dC1jb25maWcuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi9tZXNzYWdlLWlucHV0L21lc3NhZ2UtaW5wdXQtY29uZmlnLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFM0M7O0dBRUc7QUFJSCxNQUFNLE9BQU8seUJBQXlCO0lBa0JwQztRQWpCQTs7V0FFRztRQUNILHdCQUFtQixHQUF3QixJQUFJLENBQUM7UUFDaEQ7O1dBRUc7UUFDSCx1QkFBa0IsR0FBd0IsSUFBSSxDQUFDO1FBQy9DOztXQUVHO1FBQ0gsZ0NBQTJCLEdBQXdCLElBQUksQ0FBQztRQUN4RDs7V0FFRztRQUNILGlCQUFZLEdBQTBDLFNBQVMsQ0FBQztJQUVqRCxDQUFDOztzSEFsQkwseUJBQXlCOzBIQUF6Qix5QkFBeUIsY0FGeEIsTUFBTTsyRkFFUCx5QkFBeUI7a0JBSHJDLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIFRoZSBgTWVzc2FnZUlucHV0Q29uZmlnU2VydmljZWAgaXMgdXNlZCB0byBrZWVwIGEgY29uc2lzdGVudCBjb25maWd1cmF0aW9uIGFtb25nIHRoZSBkaWZmZXJlbnQgW2BNZXNzYWdlSW5wdXRgXSguLi9jb21wb25lbnRzL01lc3NhZ2VJbnB1dENvbXBvbmVudC5tZHgpIGNvbXBvbmVudHMgaWYgeW91ciBVSSBoYXMgbW9yZSB0aGFuIG9uZSBpbnB1dCBjb21wb25lbnQuXG4gKi9cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBNZXNzYWdlSW5wdXRDb25maWdTZXJ2aWNlIHtcbiAgLyoqXG4gICAqIElmIGZpbGUgdXBsb2FkIGlzIGVuYWJsZWQsIHRoZSB1c2VyIGNhbiBvcGVuIGEgZmlsZSBzZWxlY3RvciBmcm9tIHRoZSBpbnB1dC4gUGxlYXNlIG5vdGUgdGhhdCB0aGUgdXNlciBhbHNvIG5lZWRzIHRvIGhhdmUgdGhlIG5lY2Vzc2FyeSBbY2hhbm5lbCBjYXBhYmlsaXR5XShodHRwczovL2dldHN0cmVhbS5pby9jaGF0L2RvY3MvamF2YXNjcmlwdC9jaGFubmVsX2NhcGFiaWxpdGllcy8/bGFuZ3VhZ2U9amF2YXNjcmlwdCkuXG4gICAqL1xuICBpc0ZpbGVVcGxvYWRFbmFibGVkOiBib29sZWFuIHwgdW5kZWZpbmVkID0gdHJ1ZTtcbiAgLyoqXG4gICAqIElmIHRydWUsIHVzZXJzIGNhbiBtZW50aW9uIG90aGVyIHVzZXJzIGluIG1lc3NhZ2VzLiBZb3UgYWxzbyBbbmVlZCB0byB1c2UgdGhlIGBBdXRvY29tcGxldGVUZXh0YXJlYWBdKC4uL2NvbmNlcHRzL29wdC1pbi1hcmNoaXRlY3R1cmUubWR4KSBmb3IgdGhpcyBmZWF0dXJlIHRvIHdvcmsuXG4gICAqL1xuICBhcmVNZW50aW9uc0VuYWJsZWQ6IGJvb2xlYW4gfCB1bmRlZmluZWQgPSB0cnVlO1xuICAvKipcbiAgICogSWYgYGZhbHNlYCwgdXNlcnMgY2FuIG9ubHkgdXBsb2FkIG9uZSBhdHRhY2htZW50IHBlciBtZXNzYWdlXG4gICAqL1xuICBpc011bHRpcGxlRmlsZVVwbG9hZEVuYWJsZWQ6IGJvb2xlYW4gfCB1bmRlZmluZWQgPSB0cnVlO1xuICAvKipcbiAgICogVGhlIHNjb3BlIGZvciB1c2VyIG1lbnRpb25zLCBlaXRoZXIgbWVtYmVycyBvZiB0aGUgY3VycmVudCBjaGFubmVsIG9mIG1lbWJlcnMgb2YgdGhlIGFwcGxpY2F0aW9uXG4gICAqL1xuICBtZW50aW9uU2NvcGU6ICdjaGFubmVsJyB8ICdhcHBsaWNhdGlvbicgfCB1bmRlZmluZWQgPSAnY2hhbm5lbCc7XG5cbiAgY29uc3RydWN0b3IoKSB7fVxufVxuIl19
|