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.
- package/assets/version.d.ts +1 -1
- package/esm2020/assets/version.mjs +2 -2
- package/esm2020/lib/channel/channel.component.mjs +5 -6
- package/esm2020/lib/custom-templates.service.mjs +1 -5
- package/esm2020/lib/message-actions.service.mjs +18 -2
- package/esm2020/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.mjs +13 -1
- package/esm2020/lib/message-input/message-input.component.mjs +75 -23
- package/esm2020/lib/message-input/textarea/textarea.component.mjs +13 -1
- package/esm2020/lib/stream-chat.module.mjs +1 -6
- package/esm2020/public-api.mjs +1 -2
- package/fesm2015/stream-chat-angular.mjs +2014 -2004
- package/fesm2015/stream-chat-angular.mjs.map +1 -1
- package/fesm2020/stream-chat-angular.mjs +1951 -1941
- package/fesm2020/stream-chat-angular.mjs.map +1 -1
- package/lib/custom-templates.service.d.ts +0 -4
- package/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.d.ts +1 -0
- package/lib/message-input/message-input.component.d.ts +19 -3
- package/lib/message-input/textarea/textarea.component.d.ts +1 -0
- package/lib/stream-chat.module.d.ts +9 -10
- package/package.json +1 -1
- package/public-api.d.ts +0 -1
- package/src/assets/version.ts +1 -1
- package/esm2020/lib/edit-message-form/edit-message-form.component.mjs +0 -83
- package/lib/edit-message-form/edit-message-form.component.d.ts +0 -31
|
@@ -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
|
-
|
|
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 "./
|
|
23
|
-
import * as i22 from "./
|
|
24
|
-
import * as i23 from "./voice-recording/voice-recording.component";
|
|
25
|
-
import * as i24 from "./
|
|
26
|
-
import * as i25 from "
|
|
27
|
-
import * as i26 from "
|
|
28
|
-
import * as i27 from "
|
|
29
|
-
import * as i28 from "
|
|
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.
|
|
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
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';
|
package/src/assets/version.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export const version = '5.0.0-v5.
|
|
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
|
-
}
|