stream-chat-angular 5.0.0-v5.21 → 5.0.0-v5.22

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.
@@ -205,10 +205,6 @@ export declare class CustomTemplatesService<T extends DefaultStreamChatGenerics
205
205
  * The template to show if the thread message list is empty
206
206
  */
207
207
  emptyThreadMessageListPlaceholder$: BehaviorSubject<TemplateRef<void> | undefined>;
208
- /**
209
- * The template used to display the [edit message form](../components/EditMessageFormComponent.mdx)
210
- */
211
- editMessageFormTemplate$: BehaviorSubject<TemplateRef<void> | undefined>;
212
208
  /**
213
209
  * The template used to display the [message bounce prompt](../components/MessageBouncePromptComponent.mdx)
214
210
  */
@@ -70,6 +70,7 @@ export declare class AutocompleteTextareaComponent implements TextareaInterface,
70
70
  private userMentionConfig;
71
71
  private slashCommandConfig;
72
72
  private searchTerm$;
73
+ private isViewInited;
73
74
  constructor(channelService: ChannelService, chatClientService: ChatClientService, transliterationService: TransliterationService, emojiInputService: EmojiInputService, customTemplatesService: CustomTemplatesService, themeService: ThemeService, cdRef: ChangeDetectorRef);
74
75
  ngOnChanges(changes: SimpleChanges): void;
75
76
  ngAfterViewInit(): void;
@@ -10,6 +10,7 @@ import { MessageInputConfigService } from './message-input-config.service';
10
10
  import { TextareaInterface } from './textarea.interface';
11
11
  import { EmojiInputService } from './emoji-input.service';
12
12
  import { CustomTemplatesService } from '../custom-templates.service';
13
+ import { MessageActionsService } from '../message-actions.service';
13
14
  import * as i0 from "@angular/core";
14
15
  /**
15
16
  * The `MessageInput` component displays an input where users can type their messages and upload files, and sends the message to the active channel. The component can be used to compose new messages or update existing ones. To send messages, the chat user needs to have the necessary [channel capability](https://getstream.io/chat/docs/javascript/channel_capabilities/?language=javascript).
@@ -25,6 +26,7 @@ export declare class MessageInputComponent implements OnInit, OnChanges, OnDestr
25
26
  private chatClient;
26
27
  private emojiInputService;
27
28
  private customTemplatesService;
29
+ private messageActionsService;
28
30
  /**
29
31
  * If file upload is enabled, the user can open a file selector from the input. Please note that the user also needs to have the necessary [channel capability](https://getstream.io/chat/docs/javascript/channel_capabilities/?language=javascript). If no value is provided, it is set from the [`MessageInputConfigService`](../services/MessageInputConfigService.mdx).
30
32
  */
@@ -61,6 +63,16 @@ export declare class MessageInputComponent implements OnInit, OnChanges, OnDestr
61
63
  * Enables or disables auto focus on the textarea element
62
64
  */
63
65
  autoFocus: boolean;
66
+ /**
67
+ * By default the input will react to changes in `messageToEdit$` from [`MessageActionsService`](../services/MessageActionsService.mdx) and display the message to be edited (taking into account the current `mode`).
68
+ *
69
+ * If you don't need that behavior, you can turn this of with this flag. In that case you should create your own edit message UI.
70
+ */
71
+ watchForMessageToEdit: boolean;
72
+ /**
73
+ * Use this input to control wether a send button is rendered or not. If you don't render a send button, you can still trigger message send using the `sendMessage$` input.
74
+ */
75
+ displaySendButton: boolean;
64
76
  /**
65
77
  * Emits when a message was successfuly sent or updated
66
78
  */
@@ -95,7 +107,8 @@ export declare class MessageInputComponent implements OnInit, OnChanges, OnDestr
95
107
  private sendMessageSubcription;
96
108
  private readonly defaultTextareaPlaceholder;
97
109
  private readonly slowModeTextareaPlaceholder;
98
- constructor(channelService: ChannelService, notificationService: NotificationService, attachmentService: AttachmentService, configService: MessageInputConfigService, textareaType: Type<TextareaInterface>, componentFactoryResolver: ComponentFactoryResolver, cdRef: ChangeDetectorRef, chatClient: ChatClientService, emojiInputService: EmojiInputService, customTemplatesService: CustomTemplatesService);
110
+ private messageToEdit?;
111
+ constructor(channelService: ChannelService, notificationService: NotificationService, attachmentService: AttachmentService, configService: MessageInputConfigService, textareaType: Type<TextareaInterface>, componentFactoryResolver: ComponentFactoryResolver, cdRef: ChangeDetectorRef, chatClient: ChatClientService, emojiInputService: EmojiInputService, customTemplatesService: CustomTemplatesService, messageActionsService: MessageActionsService);
99
112
  ngOnInit(): void;
100
113
  ngAfterViewInit(): void;
101
114
  ngOnChanges(changes: SimpleChanges): void;
@@ -128,19 +141,22 @@ export declare class MessageInputComponent implements OnInit, OnChanges, OnDestr
128
141
  get disabledTextareaText(): "" | "streamChat.You can't send thread replies in this channel" | "streamChat.You can't send messages in this channel";
129
142
  filesSelected(fileList: FileList | null): Promise<void>;
130
143
  deselectMessageToQuote(): void;
144
+ deselectMessageToEdit(): void;
131
145
  getEmojiPickerContext(): EmojiPickerContext;
132
146
  getAttachmentPreviewListContext(): AttachmentPreviewListContext;
133
147
  getAttachmentUploadContext(): CustomAttachmentUploadContext;
148
+ get isUpdate(): boolean;
134
149
  private deleteUpload;
135
150
  private retryUpload;
136
151
  private clearFileInput;
137
- private get isUpdate();
138
152
  private initTextarea;
139
153
  private areAttachemntsValid;
140
154
  private setCanSendMessages;
141
155
  private get parentMessageId();
142
156
  private startCooldown;
143
157
  private stopCooldown;
158
+ private checkIfInEditMode;
159
+ private messageToUpdateChanged;
144
160
  static ɵfac: i0.ɵɵFactoryDeclaration<MessageInputComponent, never>;
145
- static ɵcmp: i0.ɵɵComponentDeclaration<MessageInputComponent, "stream-message-input", never, { "isFileUploadEnabled": "isFileUploadEnabled"; "areMentionsEnabled": "areMentionsEnabled"; "mentionScope": "mentionScope"; "mode": "mode"; "isMultipleFileUploadEnabled": "isMultipleFileUploadEnabled"; "message": "message"; "sendMessage$": "sendMessage$"; "inputMode": "inputMode"; "autoFocus": "autoFocus"; }, { "messageUpdate": "messageUpdate"; }, never, never, false, never>;
161
+ static ɵcmp: i0.ɵɵComponentDeclaration<MessageInputComponent, "stream-message-input", never, { "isFileUploadEnabled": "isFileUploadEnabled"; "areMentionsEnabled": "areMentionsEnabled"; "mentionScope": "mentionScope"; "mode": "mode"; "isMultipleFileUploadEnabled": "isMultipleFileUploadEnabled"; "message": "message"; "sendMessage$": "sendMessage$"; "inputMode": "inputMode"; "autoFocus": "autoFocus"; "watchForMessageToEdit": "watchForMessageToEdit"; "displaySendButton": "displaySendButton"; }, { "messageUpdate": "messageUpdate"; }, never, never, false, never>;
146
162
  }
@@ -36,6 +36,7 @@ export declare class TextareaComponent implements TextareaInterface, OnChanges,
36
36
  readonly send: EventEmitter<void>;
37
37
  private messageInput;
38
38
  private subscriptions;
39
+ private isViewInited;
39
40
  constructor(emojiInputService: EmojiInputService, themeService: ThemeService);
40
41
  ngOnChanges(changes: SimpleChanges): void;
41
42
  ngAfterViewInit(): void;
@@ -19,17 +19,16 @@ import * as i17 from "./message-input/textarea.directive";
19
19
  import * as i18 from "./thread/thread.component";
20
20
  import * as i19 from "./icon-placeholder/icon-placeholder.component";
21
21
  import * as i20 from "./loading-indicator-placeholder/loading-indicator-placeholder.component";
22
- import * as i21 from "./edit-message-form/edit-message-form.component";
23
- import * as i22 from "./message-bounce-prompt/message-bounce-prompt.component";
24
- import * as i23 from "./voice-recording/voice-recording.component";
25
- import * as i24 from "./voice-recording/voice-recording-wavebar/voice-recording-wavebar.component";
26
- import * as i25 from "./message-reactions-selector/message-reactions-selector.component";
27
- import * as i26 from "@angular/common";
28
- import * as i27 from "ngx-float-ui";
29
- import * as i28 from "./stream-avatar.module";
30
- import * as i29 from "@ngx-translate/core";
22
+ import * as i21 from "./message-bounce-prompt/message-bounce-prompt.component";
23
+ import * as i22 from "./voice-recording/voice-recording.component";
24
+ import * as i23 from "./voice-recording/voice-recording-wavebar/voice-recording-wavebar.component";
25
+ import * as i24 from "./message-reactions-selector/message-reactions-selector.component";
26
+ import * as i25 from "@angular/common";
27
+ import * as i26 from "ngx-float-ui";
28
+ import * as i27 from "./stream-avatar.module";
29
+ import * as i28 from "@ngx-translate/core";
31
30
  export declare class StreamChatModule {
32
31
  static ɵfac: i0.ɵɵFactoryDeclaration<StreamChatModule, never>;
33
- static ɵmod: i0.ɵɵNgModuleDeclaration<StreamChatModule, [typeof i1.ChannelComponent, typeof i2.ChannelHeaderComponent, typeof i3.ChannelListComponent, typeof i4.ChannelPreviewComponent, typeof i5.MessageComponent, typeof i6.MessageInputComponent, typeof i7.MessageListComponent, typeof i8.LoadingIndicatorComponent, typeof i9.IconComponent, typeof i10.MessageActionsBoxComponent, typeof i11.AttachmentListComponent, typeof i12.MessageReactionsComponent, typeof i13.NotificationComponent, typeof i14.NotificationListComponent, typeof i15.AttachmentPreviewListComponent, typeof i16.ModalComponent, typeof i17.TextareaDirective, typeof i18.ThreadComponent, typeof i19.IconPlaceholderComponent, typeof i20.LoadingIndicatorPlaceholderComponent, typeof i21.EditMessageFormComponent, typeof i22.MessageBouncePromptComponent, typeof i23.VoiceRecordingComponent, typeof i24.VoiceRecordingWavebarComponent, typeof i25.MessageReactionsSelectorComponent], [typeof i26.CommonModule, typeof i27.NgxFloatUiModule, typeof i28.StreamAvatarModule, typeof i29.TranslateModule], [typeof i1.ChannelComponent, typeof i2.ChannelHeaderComponent, typeof i3.ChannelListComponent, typeof i4.ChannelPreviewComponent, typeof i5.MessageComponent, typeof i6.MessageInputComponent, typeof i7.MessageListComponent, typeof i8.LoadingIndicatorComponent, typeof i9.IconComponent, typeof i10.MessageActionsBoxComponent, typeof i11.AttachmentListComponent, typeof i12.MessageReactionsComponent, typeof i13.NotificationComponent, typeof i14.NotificationListComponent, typeof i15.AttachmentPreviewListComponent, typeof i16.ModalComponent, typeof i28.StreamAvatarModule, typeof i18.ThreadComponent, typeof i19.IconPlaceholderComponent, typeof i20.LoadingIndicatorPlaceholderComponent, typeof i21.EditMessageFormComponent, typeof i22.MessageBouncePromptComponent, typeof i23.VoiceRecordingComponent, typeof i24.VoiceRecordingWavebarComponent, typeof i25.MessageReactionsSelectorComponent]>;
32
+ static ɵmod: i0.ɵɵNgModuleDeclaration<StreamChatModule, [typeof i1.ChannelComponent, typeof i2.ChannelHeaderComponent, typeof i3.ChannelListComponent, typeof i4.ChannelPreviewComponent, typeof i5.MessageComponent, typeof i6.MessageInputComponent, typeof i7.MessageListComponent, typeof i8.LoadingIndicatorComponent, typeof i9.IconComponent, typeof i10.MessageActionsBoxComponent, typeof i11.AttachmentListComponent, typeof i12.MessageReactionsComponent, typeof i13.NotificationComponent, typeof i14.NotificationListComponent, typeof i15.AttachmentPreviewListComponent, typeof i16.ModalComponent, typeof i17.TextareaDirective, typeof i18.ThreadComponent, typeof i19.IconPlaceholderComponent, typeof i20.LoadingIndicatorPlaceholderComponent, typeof i21.MessageBouncePromptComponent, typeof i22.VoiceRecordingComponent, typeof i23.VoiceRecordingWavebarComponent, typeof i24.MessageReactionsSelectorComponent], [typeof i25.CommonModule, typeof i26.NgxFloatUiModule, typeof i27.StreamAvatarModule, typeof i28.TranslateModule], [typeof i1.ChannelComponent, typeof i2.ChannelHeaderComponent, typeof i3.ChannelListComponent, typeof i4.ChannelPreviewComponent, typeof i5.MessageComponent, typeof i6.MessageInputComponent, typeof i7.MessageListComponent, typeof i8.LoadingIndicatorComponent, typeof i9.IconComponent, typeof i10.MessageActionsBoxComponent, typeof i11.AttachmentListComponent, typeof i12.MessageReactionsComponent, typeof i13.NotificationComponent, typeof i14.NotificationListComponent, typeof i15.AttachmentPreviewListComponent, typeof i16.ModalComponent, typeof i27.StreamAvatarModule, typeof i18.ThreadComponent, typeof i19.IconPlaceholderComponent, typeof i20.LoadingIndicatorPlaceholderComponent, typeof i21.MessageBouncePromptComponent, typeof i22.VoiceRecordingComponent, typeof i23.VoiceRecordingWavebarComponent, typeof i24.MessageReactionsSelectorComponent]>;
34
33
  static ɵinj: i0.ɵɵInjectorDeclaration<StreamChatModule>;
35
34
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "stream-chat-angular",
3
- "version": "5.0.0-v5.21",
3
+ "version": "5.0.0-v5.22",
4
4
  "description": "Angular components to create chat conversations or livestream style chat",
5
5
  "author": "GetStream",
6
6
  "homepage": "https://getstream.io/chat/",
package/public-api.d.ts CHANGED
@@ -19,7 +19,6 @@ export * from './lib/message/message.component';
19
19
  export * from './lib/parse-date';
20
20
  export * from './lib/list-users';
21
21
  export * from './lib/message-input/message-input.component';
22
- export * from './lib/edit-message-form/edit-message-form.component';
23
22
  export * from './lib/message-bounce-prompt/message-bounce-prompt.component';
24
23
  export * from './lib/message-input/textarea/textarea.component';
25
24
  export * from './lib/message-input/autocomplete-textarea/autocomplete-textarea.component';
@@ -1 +1 @@
1
- export const version = '5.0.0-v5.21';
1
+ export const version = '5.0.0-v5.22';
@@ -1,83 +0,0 @@
1
- import { Component, HostBinding, ViewChild, } from '@angular/core';
2
- import { Subject } from 'rxjs';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "../custom-templates.service";
5
- import * as i2 from "../message-actions.service";
6
- import * as i3 from "@angular/common";
7
- import * as i4 from "@ngx-translate/core";
8
- import * as i5 from "../message-input/message-input.component";
9
- import * as i6 from "../notification-list/notification-list.component";
10
- import * as i7 from "../modal/modal.component";
11
- /**
12
- * The edit message form displays a modal that's opened when a user edits a message. The component uses the [`MessageActionsService`](../../services/MessageActionsService) to know which message is being edited.
13
- *
14
- * By default this is displayed within the [`stream-channel` component](../../components/ChannelComponent).
15
- */
16
- export class EditMessageFormComponent {
17
- constructor(customTemplatesService, messageActionsService) {
18
- this.customTemplatesService = customTemplatesService;
19
- this.messageActionsService = messageActionsService;
20
- this.class = 'str-chat-angular__edit-message-form';
21
- this.isModalOpen = false;
22
- this.sendMessageSubject = new Subject();
23
- this.subscriptions = [];
24
- this.sendMessage$ = this.sendMessageSubject.asObservable();
25
- }
26
- ngOnInit() {
27
- this.messageActionsService.messageToEdit$.subscribe((message) => {
28
- if ((message && !this.isModalOpen) || (!message && this.isModalOpen)) {
29
- this.message = message;
30
- this.isModalOpen = !!message;
31
- }
32
- });
33
- }
34
- ngOnDestroy() {
35
- this.subscriptions.forEach((s) => s.unsubscribe());
36
- }
37
- getEditModalContext() {
38
- return {
39
- isOpen: this.isModalOpen,
40
- isOpenChangeHandler: (isOpen) => {
41
- this.isModalOpen = isOpen;
42
- if (!this.isModalOpen) {
43
- this.dismissed();
44
- }
45
- },
46
- content: this.modalContent,
47
- };
48
- }
49
- getMessageInputContext() {
50
- return {
51
- message: this.message,
52
- messageUpdateHandler: () => {
53
- this.dismissed();
54
- },
55
- isFileUploadEnabled: undefined,
56
- areMentionsEnabled: undefined,
57
- isMultipleFileUploadEnabled: undefined,
58
- mentionScope: undefined,
59
- mode: undefined,
60
- sendMessage$: this.sendMessage$,
61
- };
62
- }
63
- sendClicked() {
64
- this.sendMessageSubject.next();
65
- }
66
- dismissed() {
67
- this.isModalOpen = false;
68
- this.message = undefined;
69
- this.messageActionsService.messageToEdit$.next(undefined);
70
- }
71
- }
72
- EditMessageFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: EditMessageFormComponent, deps: [{ token: i1.CustomTemplatesService }, { token: i2.MessageActionsService }], target: i0.ɵɵFactoryTarget.Component });
73
- EditMessageFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: EditMessageFormComponent, selector: "stream-edit-message-form", host: { properties: { "class": "this.class" } }, viewQueries: [{ propertyName: "modalContent", first: true, predicate: ["editMessageForm"], descendants: true, static: true }], ngImport: i0, template: "<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 *ngIf=\"isOpen\"\n [isOpen]=\"isOpen\"\n [content]=\"content\"\n (isOpenChange)=\"isOpenChangeHandler($event)\"\n >\n </stream-modal>\n</ng-template>\n\n<ng-template #editMessageForm>\n <div class=\"str-chat__edit-message-form\">\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 [sendMessage$]=\"sendMessage$Input\"\n (messageUpdate)=\"messageUpdateHandler()\"\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)=\"dismissed()\"\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", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i4.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i5.MessageInputComponent, selector: "stream-message-input", inputs: ["isFileUploadEnabled", "areMentionsEnabled", "mentionScope", "mode", "isMultipleFileUploadEnabled", "message", "sendMessage$", "inputMode", "autoFocus"], outputs: ["messageUpdate"] }, { kind: "component", type: i6.NotificationListComponent, selector: "stream-notification-list" }, { kind: "component", type: i7.ModalComponent, selector: "stream-modal", inputs: ["isOpen", "content"], outputs: ["isOpenChange"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }] });
74
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: EditMessageFormComponent, decorators: [{
75
- type: Component,
76
- args: [{ selector: 'stream-edit-message-form', template: "<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 *ngIf=\"isOpen\"\n [isOpen]=\"isOpen\"\n [content]=\"content\"\n (isOpenChange)=\"isOpenChangeHandler($event)\"\n >\n </stream-modal>\n</ng-template>\n\n<ng-template #editMessageForm>\n <div class=\"str-chat__edit-message-form\">\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 [sendMessage$]=\"sendMessage$Input\"\n (messageUpdate)=\"messageUpdateHandler()\"\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)=\"dismissed()\"\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" }]
77
- }], ctorParameters: function () { return [{ type: i1.CustomTemplatesService }, { type: i2.MessageActionsService }]; }, propDecorators: { class: [{
78
- type: HostBinding
79
- }], modalContent: [{
80
- type: ViewChild,
81
- args: ['editMessageForm', { static: true }]
82
- }] } });
83
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edit-message-form.component.js","sourceRoot":"","sources":["../../../../../projects/stream-chat-angular/src/lib/edit-message-form/edit-message-form.component.ts","../../../../../projects/stream-chat-angular/src/lib/edit-message-form/edit-message-form.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,WAAW,EAIX,SAAS,GACV,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAc,OAAO,EAAgB,MAAM,MAAM,CAAC;;;;;;;;;AAGzD;;;;GAIG;AAMH,MAAM,OAAO,wBAAwB;IAUnC,YACW,sBAA8C,EAC/C,qBAA4C;QAD3C,2BAAsB,GAAtB,sBAAsB,CAAwB;QAC/C,0BAAqB,GAArB,qBAAqB,CAAuB;QAXvC,UAAK,GAAG,qCAAqC,CAAC;QAE7D,gBAAW,GAAG,KAAK,CAAC;QAIZ,uBAAkB,GAAG,IAAI,OAAO,EAAQ,CAAC;QACzC,kBAAa,GAAmB,EAAE,CAAC;QAMzC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;IAC7D,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,qBAAqB,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE;YAC9D,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,OAAO,IAAI,IAAI,CAAC,WAAW,CAAC,EAAE;gBACpE,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;gBACvB,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,OAAO,CAAC;aAC9B;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;IACrD,CAAC;IAED,mBAAmB;QACjB,OAAO;YACL,MAAM,EAAE,IAAI,CAAC,WAAW;YACxB,mBAAmB,EAAE,CAAC,MAAM,EAAE,EAAE;gBAC9B,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC;gBAC1B,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;oBACrB,IAAI,CAAC,SAAS,EAAE,CAAC;iBAClB;YACH,CAAC;YACD,OAAO,EAAE,IAAI,CAAC,YAAY;SAC3B,CAAC;IACJ,CAAC;IAED,sBAAsB;QACpB,OAAO;YACL,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,oBAAoB,EAAE,GAAG,EAAE;gBACzB,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,CAAC;YACD,mBAAmB,EAAE,SAAS;YAC9B,kBAAkB,EAAE,SAAS;YAC7B,2BAA2B,EAAE,SAAS;YACtC,YAAY,EAAE,SAAS;YACvB,IAAI,EAAE,SAAS;YACf,YAAY,EAAE,IAAI,CAAC,YAAY;SAChC,CAAC;IACJ,CAAC;IAED,WAAW;QACT,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC;IACjC,CAAC;IAED,SAAS;QACP,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;QACzB,IAAI,CAAC,qBAAqB,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC5D,CAAC;;qHAlEU,wBAAwB;yGAAxB,wBAAwB,gPCvBrC,w9DA0EA;2FDnDa,wBAAwB;kBALpC,SAAS;+BACE,0BAA0B;iJAKrB,KAAK;sBAAnB,WAAW;gBAKJ,YAAY;sBADnB,SAAS;uBAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import {\n  Component,\n  HostBinding,\n  OnDestroy,\n  OnInit,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { CustomTemplatesService } from '../custom-templates.service';\nimport { MessageInputContext, ModalContext, StreamMessage } from '../types';\nimport { Observable, Subject, Subscription } from 'rxjs';\nimport { MessageActionsService } from '../message-actions.service';\n\n/**\n * The edit message form displays a modal that's opened when a user edits a message. The component uses the [`MessageActionsService`](../../services/MessageActionsService) to know which message is being edited.\n *\n * By default this is displayed within the [`stream-channel` component](../../components/ChannelComponent).\n */\n@Component({\n  selector: 'stream-edit-message-form',\n  templateUrl: './edit-message-form.component.html',\n  styles: [],\n})\nexport class EditMessageFormComponent implements OnInit, OnDestroy {\n  @HostBinding() class = 'str-chat-angular__edit-message-form';\n  sendMessage$: Observable<void>;\n  isModalOpen = false;\n  message?: StreamMessage;\n  @ViewChild('editMessageForm', { static: true })\n  private modalContent!: TemplateRef<void>;\n  private sendMessageSubject = new Subject<void>();\n  private subscriptions: Subscription[] = [];\n\n  constructor(\n    readonly customTemplatesService: CustomTemplatesService,\n    private messageActionsService: MessageActionsService\n  ) {\n    this.sendMessage$ = this.sendMessageSubject.asObservable();\n  }\n\n  ngOnInit(): void {\n    this.messageActionsService.messageToEdit$.subscribe((message) => {\n      if ((message && !this.isModalOpen) || (!message && this.isModalOpen)) {\n        this.message = message;\n        this.isModalOpen = !!message;\n      }\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach((s) => s.unsubscribe());\n  }\n\n  getEditModalContext(): ModalContext {\n    return {\n      isOpen: this.isModalOpen,\n      isOpenChangeHandler: (isOpen) => {\n        this.isModalOpen = isOpen;\n        if (!this.isModalOpen) {\n          this.dismissed();\n        }\n      },\n      content: this.modalContent,\n    };\n  }\n\n  getMessageInputContext(): MessageInputContext {\n    return {\n      message: this.message,\n      messageUpdateHandler: () => {\n        this.dismissed();\n      },\n      isFileUploadEnabled: undefined,\n      areMentionsEnabled: undefined,\n      isMultipleFileUploadEnabled: undefined,\n      mentionScope: undefined,\n      mode: undefined,\n      sendMessage$: this.sendMessage$,\n    };\n  }\n\n  sendClicked() {\n    this.sendMessageSubject.next();\n  }\n\n  dismissed() {\n    this.isModalOpen = false;\n    this.message = undefined;\n    this.messageActionsService.messageToEdit$.next(undefined);\n  }\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    *ngIf=\"isOpen\"\n    [isOpen]=\"isOpen\"\n    [content]=\"content\"\n    (isOpenChange)=\"isOpenChangeHandler($event)\"\n  >\n  </stream-modal>\n</ng-template>\n\n<ng-template #editMessageForm>\n  <div class=\"str-chat__edit-message-form\">\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        [sendMessage$]=\"sendMessage$Input\"\n        (messageUpdate)=\"messageUpdateHandler()\"\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)=\"dismissed()\"\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"]}
@@ -1,31 +0,0 @@
1
- import { OnDestroy, OnInit } from '@angular/core';
2
- import { CustomTemplatesService } from '../custom-templates.service';
3
- import { MessageInputContext, ModalContext, StreamMessage } from '../types';
4
- import { Observable } from 'rxjs';
5
- import { MessageActionsService } from '../message-actions.service';
6
- import * as i0 from "@angular/core";
7
- /**
8
- * The edit message form displays a modal that's opened when a user edits a message. The component uses the [`MessageActionsService`](../../services/MessageActionsService) to know which message is being edited.
9
- *
10
- * By default this is displayed within the [`stream-channel` component](../../components/ChannelComponent).
11
- */
12
- export declare class EditMessageFormComponent implements OnInit, OnDestroy {
13
- readonly customTemplatesService: CustomTemplatesService;
14
- private messageActionsService;
15
- class: string;
16
- sendMessage$: Observable<void>;
17
- isModalOpen: boolean;
18
- message?: StreamMessage;
19
- private modalContent;
20
- private sendMessageSubject;
21
- private subscriptions;
22
- constructor(customTemplatesService: CustomTemplatesService, messageActionsService: MessageActionsService);
23
- ngOnInit(): void;
24
- ngOnDestroy(): void;
25
- getEditModalContext(): ModalContext;
26
- getMessageInputContext(): MessageInputContext;
27
- sendClicked(): void;
28
- dismissed(): void;
29
- static ɵfac: i0.ɵɵFactoryDeclaration<EditMessageFormComponent, never>;
30
- static ɵcmp: i0.ɵɵComponentDeclaration<EditMessageFormComponent, "stream-edit-message-form", never, {}, {}, never, never, false, never>;
31
- }