stream-chat-angular 2.3.0 → 2.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/assets/version.d.ts +1 -1
- package/bundles/stream-chat-angular.umd.js +28 -17
- package/bundles/stream-chat-angular.umd.js.map +1 -1
- package/esm2015/assets/version.js +2 -2
- package/esm2015/lib/message-input/message-input.component.js +16 -14
- package/esm2015/lib/message-input/textarea.directive.js +12 -2
- package/fesm2015/stream-chat-angular.js +27 -15
- package/fesm2015/stream-chat-angular.js.map +1 -1
- package/lib/message-input/message-input.component.d.ts +2 -3
- package/lib/message-input/textarea.directive.d.ts +1 -0
- package/package.json +1 -1
- package/src/assets/version.ts +1 -1
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export const version = '2.3.
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
export const version = '2.3.1';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2Fzc2V0cy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgdmVyc2lvbiA9ICcyLjMuMSc7XG4iXX0=
|
|
@@ -27,23 +27,13 @@ export class MessageInputComponent {
|
|
|
27
27
|
this.textareaValue = '';
|
|
28
28
|
this.mentionedUsers = [];
|
|
29
29
|
this.subscriptions = [];
|
|
30
|
+
this.isViewInited = false;
|
|
30
31
|
this.subscriptions.push(this.attachmentService.attachmentUploadInProgressCounter$.subscribe((counter) => {
|
|
31
32
|
if (counter === 0 && this.hideNotification) {
|
|
32
33
|
this.hideNotification();
|
|
33
34
|
this.hideNotification = undefined;
|
|
34
35
|
}
|
|
35
36
|
}));
|
|
36
|
-
this.attachmentUploads$ = this.attachmentService.attachmentUploads$;
|
|
37
|
-
this.isFileUploadEnabled = this.configService.isFileUploadEnabled;
|
|
38
|
-
this.acceptedFileTypes = this.configService.acceptedFileTypes;
|
|
39
|
-
this.isMultipleFileUploadEnabled =
|
|
40
|
-
this.configService.isMultipleFileUploadEnabled;
|
|
41
|
-
this.areMentionsEnabled = this.configService.areMentionsEnabled;
|
|
42
|
-
this.mentionAutocompleteItemTemplate =
|
|
43
|
-
this.configService.mentionAutocompleteItemTemplate;
|
|
44
|
-
this.mentionScope = this.configService.mentionScope;
|
|
45
|
-
}
|
|
46
|
-
ngOnInit() {
|
|
47
37
|
this.subscriptions.push(this.channelService.activeChannel$.subscribe((channel) => {
|
|
48
38
|
var _a;
|
|
49
39
|
this.textareaValue = '';
|
|
@@ -54,12 +44,24 @@ export class MessageInputComponent {
|
|
|
54
44
|
capabilities.indexOf('upload-file') !== -1;
|
|
55
45
|
this.canSendLinks = capabilities.indexOf('send-links') !== -1;
|
|
56
46
|
this.canSendMessages = capabilities.indexOf('send-message') !== -1;
|
|
57
|
-
this.
|
|
58
|
-
|
|
47
|
+
if (this.isViewInited) {
|
|
48
|
+
this.cdRef.detectChanges();
|
|
49
|
+
this.initTextarea();
|
|
50
|
+
}
|
|
59
51
|
}
|
|
60
52
|
}));
|
|
53
|
+
this.attachmentUploads$ = this.attachmentService.attachmentUploads$;
|
|
54
|
+
this.isFileUploadEnabled = this.configService.isFileUploadEnabled;
|
|
55
|
+
this.acceptedFileTypes = this.configService.acceptedFileTypes;
|
|
56
|
+
this.isMultipleFileUploadEnabled =
|
|
57
|
+
this.configService.isMultipleFileUploadEnabled;
|
|
58
|
+
this.areMentionsEnabled = this.configService.areMentionsEnabled;
|
|
59
|
+
this.mentionAutocompleteItemTemplate =
|
|
60
|
+
this.configService.mentionAutocompleteItemTemplate;
|
|
61
|
+
this.mentionScope = this.configService.mentionScope;
|
|
61
62
|
}
|
|
62
63
|
ngAfterViewInit() {
|
|
64
|
+
this.isViewInited = true;
|
|
63
65
|
this.initTextarea();
|
|
64
66
|
}
|
|
65
67
|
ngOnChanges(changes) {
|
|
@@ -200,4 +202,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
|
|
|
200
202
|
type: ViewChild,
|
|
201
203
|
args: [TextareaDirective, { static: false }]
|
|
202
204
|
}] } });
|
|
203
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"message-input.component.js","sourceRoot":"","sources":["../../../../../projects/stream-chat-angular/src/lib/message-input/message-input.component.ts","../../../../../projects/stream-chat-angular/src/lib/message-input/message-input.component.html"],"names":[],"mappings":";AACA,OAAO,EAGL,SAAS,EAIT,YAAY,EACZ,MAAM,EACN,KAAK,EAGL,MAAM,EAIN,SAAS,GACV,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAEvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAE1D,OAAO,EAAE,sBAAsB,EAAE,MAAM,qBAAqB,CAAC;AAQ7D,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;;;;;;;;;;;AASzD,MAAM,OAAO,qBAAqB;IA0BhC,YACU,cAA8B,EAC9B,mBAAwC,EACxC,iBAAoC,EACpC,aAAwC,EAExC,YAAqC,EACrC,wBAAkD,EAClD,KAAwB;QAPxB,mBAAc,GAAd,cAAc,CAAgB;QAC9B,wBAAmB,GAAnB,mBAAmB,CAAqB;QACxC,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,kBAAa,GAAb,aAAa,CAA2B;QAExC,iBAAY,GAAZ,YAAY,CAAyB;QACrC,6BAAwB,GAAxB,wBAAwB,CAA0B;QAClD,UAAK,GAAL,KAAK,CAAmB;QAtBf,kBAAa,GAAG,IAAI,YAAY,EAAQ,CAAC;QAK5D,kBAAa,GAAG,EAAE,CAAC;QAEnB,mBAAc,GAAmB,EAAE,CAAC;QAI5B,kBAAa,GAAmB,EAAE,CAAC;QAazC,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,iBAAiB,CAAC,kCAAkC,CAAC,SAAS,CACjE,CAAC,OAAO,EAAE,EAAE;YACV,IAAI,OAAO,KAAK,CAAC,IAAI,IAAI,CAAC,gBAAgB,EAAE;gBAC1C,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBACxB,IAAI,CAAC,gBAAgB,GAAG,SAAS,CAAC;aACnC;QACH,CAAC,CACF,CACF,CAAC;QACF,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,CAAC;QACpE,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAC;QAClE,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC;QAC9D,IAAI,CAAC,2BAA2B;YAC9B,IAAI,CAAC,aAAa,CAAC,2BAA2B,CAAC;QACjD,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC;QAChE,IAAI,CAAC,+BAA+B;YAClC,IAAI,CAAC,aAAa,CAAC,+BAA+B,CAAC;QACrD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC;IACtD,CAAC;IACD,QAAQ;QACN,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE;;YACvD,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;YACxB,IAAI,CAAC,iBAAiB,CAAC,sBAAsB,EAAE,CAAC;YAChD,MAAM,YAAY,GAAG,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,IAAI,0CAAE,gBAA4B,CAAC;YACjE,IAAI,YAAY,EAAE;gBAChB,IAAI,CAAC,sBAAsB;oBACzB,YAAY,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC;gBAC7C,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC,OAAO,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC;gBAC9D,IAAI,CAAC,eAAe,GAAG,YAAY,CAAC,OAAO,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC;gBACnE,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;gBAC3B,IAAI,CAAC,YAAY,EAAE,CAAC;aACrB;QACH,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,eAAe;QACb,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,OAAO,EAAE;YACnB,IAAI,CAAC,iBAAiB,CAAC,sBAAsB,EAAE,CAAC;YAChD,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,IAAI,CAAC,iBAAiB,CAAC,qBAAqB,CAC1C,IAAI,CAAC,OAAQ,CAAC,WAAW,IAAI,EAAE,CAChC,CAAC;gBACF,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,OAAQ,CAAC,IAAI,IAAI,EAAE,CAAC;aAC/C;SACF;QACD,IAAI,OAAO,CAAC,mBAAmB,EAAE;YAC/B,IAAI,CAAC,aAAa,CAAC,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,CAAC;SACnE;QACD,IAAI,OAAO,CAAC,iBAAiB,EAAE;YAC7B,IAAI,CAAC,aAAa,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC;SAC/D;QACD,IAAI,OAAO,CAAC,2BAA2B,EAAE;YACvC,IAAI,CAAC,aAAa,CAAC,2BAA2B;gBAC5C,IAAI,CAAC,2BAA2B,CAAC;SACpC;QACD,IAAI,OAAO,CAAC,kBAAkB,EAAE;YAC9B,IAAI,CAAC,aAAa,CAAC,kBAAkB,GAAG,IAAI,CAAC,kBAAkB,CAAC;SACjE;QACD,IAAI,OAAO,CAAC,+BAA+B,EAAE;YAC3C,IAAI,CAAC,aAAa,CAAC,+BAA+B;gBAChD,IAAI,CAAC,+BAA+B,CAAC;SACxC;QACD,IAAI,OAAO,CAAC,YAAY,EAAE;YACxB,IAAI,CAAC,aAAa,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC;SACrD;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;IACrD,CAAC;IAEK,WAAW;;YACf,IAAI,iCAA0C,CAAC;YAC/C,IAAI,CAAC,iBAAiB,CAAC,kCAAkC;iBACtD,IAAI,CAAC,KAAK,EAAE,CAAC;iBACb,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,iCAAiC,GAAG,OAAO,CAAC,CAAC,CAAC;YACzE,IAAI,iCAAiC,GAAG,CAAC,EAAE;gBACzC,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;oBAC1B,IAAI,CAAC,gBAAgB;wBACnB,IAAI,CAAC,mBAAmB,CAAC,wBAAwB,CAC/C,qDAAqD,CACtD,CAAC;iBACL;gBACD,OAAO;aACR;YACD,MAAM,WAAW,GAAG,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,EAAE,CAAC;YAC9D,MAAM,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC;YAChC,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC,WAAW,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,CAAC,EAAE;gBACvD,OAAO;aACR;YACD,IAAI,IAAI,CAAC,aAAa,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;gBAC5C,IAAI,CAAC,mBAAmB,CAAC,wBAAwB,CAC/C,8DAA8D,CAC/D,CAAC;gBACF,OAAO;aACR;YACD,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;gBAClB,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;aACzB;YACD,IAAI;gBACF,MAAM,CAAC,IAAI,CAAC,QAAQ;oBAClB,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,iCAC5B,IAAI,CAAC,OAAQ,KAChB,IAAI,EAAE,IAAI,EACV,WAAW,EAAE,WAAW,IACxB;oBACJ,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,WAAW,CAC7B,IAAI,EACJ,WAAW,EACX,IAAI,CAAC,cAAc,CACpB,CAAC,CAAC;gBACP,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;gBAC1B,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;oBAClB,IAAI,CAAC,iBAAiB,CAAC,sBAAsB,EAAE,CAAC;iBACjD;aACF;YAAC,OAAO,KAAK,EAAE;gBACd,IAAI,IAAI,CAAC,QAAQ,EAAE;oBACjB,IAAI,CAAC,mBAAmB,CAAC,wBAAwB,CAC/C,wCAAwC,CACzC,CAAC;iBACH;aACF;QACH,CAAC;KAAA;IAED,IAAI,aAAa;QACf,OAAO,qDAAqD,CAAC,IAAI,CAC/D,IAAI,CAAC,aAAa,CACnB,CAAC;IACJ,CAAC;IAED,IAAI,MAAM;;QACR,OAAO,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,MAAA,IAAI,CAAC,iBAAiB,0CAAE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IACzE,CAAC;IAEK,aAAa,CAAC,QAAyB;;YAC3C,MAAM,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;YACrD,IAAI,CAAC,cAAc,EAAE,CAAC;QACxB,CAAC;KAAA;IAEO,cAAc;QACpB,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,GAAG,EAAE,CAAC;IAC1C,CAAC;IAED,IAAY,QAAQ;QAClB,OAAO,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAEO,YAAY;QAClB,IAAI,CAAC,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;YACrE,OAAO;SACR;QACD,MAAM,gBAAgB,GACpB,IAAI,CAAC,wBAAwB,CAAC,uBAAuB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAC3E,IAAI,CAAC,WAAW;YACd,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,eAAe,CAClD,gBAAgB,CACjB,CAAC;QACJ,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;IAC7B,CAAC;;kHAzMU,qBAAqB,6JA+BtB,sBAAsB;sGA/BrB,qBAAqB,wZAFrB,CAAC,iBAAiB,CAAC,mKAuBnB,iBAAiB,qEC9D9B,25EAuEA;2FD9Ba,qBAAqB;kBANjC,SAAS;mBAAC;oBACT,QAAQ,EAAE,sBAAsB;oBAChC,WAAW,EAAE,gCAAgC;oBAC7C,MAAM,EAAE,EAAE;oBACV,SAAS,EAAE,CAAC,iBAAiB,CAAC;iBAC/B;;0BAgCI,MAAM;2BAAC,sBAAsB;mHA5BvB,mBAAmB;sBAA3B,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,+BAA+B;sBAAvC,KAAK;gBAGG,iBAAiB;sBAAzB,KAAK;gBACG,2BAA2B;sBAAnC,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACa,aAAa;sBAA/B,MAAM;gBAQyB,SAAS;sBAAxC,SAAS;uBAAC,WAAW;gBAEd,cAAc;sBADrB,SAAS;uBAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE","sourcesContent":["import { OnInit } from '@angular/core';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ComponentFactoryResolver,\n  ComponentRef,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  Type,\n  ViewChild,\n} from '@angular/core';\nimport { Observable, Subscription } from 'rxjs';\nimport { first } from 'rxjs/operators';\nimport { UserResponse } from 'stream-chat';\nimport { AttachmentService } from '../attachment.service';\nimport { ChannelService } from '../channel.service';\nimport { textareaInjectionToken } from '../injection-tokens';\nimport { NotificationService } from '../notification.service';\nimport {\n  AttachmentUpload,\n  MentionAutcompleteListItemContext,\n  StreamMessage,\n} from '../types';\nimport { MessageInputConfigService } from './message-input-config.service';\nimport { TextareaDirective } from './textarea.directive';\nimport { TextareaInterface } from './textarea.interface';\n\n@Component({\n  selector: 'stream-message-input',\n  templateUrl: './message-input.component.html',\n  styles: [],\n  providers: [AttachmentService],\n})\nexport class MessageInputComponent\n  implements OnInit, OnChanges, OnDestroy, AfterViewInit\n{\n  @Input() isFileUploadEnabled: boolean | undefined;\n  @Input() areMentionsEnabled: boolean | undefined;\n  @Input() mentionScope: 'channel' | 'application' | undefined;\n  @Input() mentionAutocompleteItemTemplate:\n    | TemplateRef<MentionAutcompleteListItemContext>\n    | undefined;\n  @Input() acceptedFileTypes: string[] | undefined;\n  @Input() isMultipleFileUploadEnabled: boolean | undefined;\n  @Input() message: StreamMessage | undefined;\n  @Output() readonly messageUpdate = new EventEmitter<void>();\n  isFileUploadAuthorized: boolean | undefined;\n  canSendLinks: boolean | undefined;\n  canSendMessages: boolean | undefined;\n  attachmentUploads$: Observable<AttachmentUpload[]>;\n  textareaValue = '';\n  textareaRef: ComponentRef<TextareaInterface> | undefined;\n  mentionedUsers: UserResponse[] = [];\n  @ViewChild('fileInput') private fileInput!: ElementRef<HTMLInputElement>;\n  @ViewChild(TextareaDirective, { static: false })\n  private textareaAnchor!: TextareaDirective;\n  private subscriptions: Subscription[] = [];\n  private hideNotification: Function | undefined;\n\n  constructor(\n    private channelService: ChannelService,\n    private notificationService: NotificationService,\n    private attachmentService: AttachmentService,\n    private configService: MessageInputConfigService,\n    @Inject(textareaInjectionToken)\n    private textareaType: Type<TextareaInterface>,\n    private componentFactoryResolver: ComponentFactoryResolver,\n    private cdRef: ChangeDetectorRef\n  ) {\n    this.subscriptions.push(\n      this.attachmentService.attachmentUploadInProgressCounter$.subscribe(\n        (counter) => {\n          if (counter === 0 && this.hideNotification) {\n            this.hideNotification();\n            this.hideNotification = undefined;\n          }\n        }\n      )\n    );\n    this.attachmentUploads$ = this.attachmentService.attachmentUploads$;\n    this.isFileUploadEnabled = this.configService.isFileUploadEnabled;\n    this.acceptedFileTypes = this.configService.acceptedFileTypes;\n    this.isMultipleFileUploadEnabled =\n      this.configService.isMultipleFileUploadEnabled;\n    this.areMentionsEnabled = this.configService.areMentionsEnabled;\n    this.mentionAutocompleteItemTemplate =\n      this.configService.mentionAutocompleteItemTemplate;\n    this.mentionScope = this.configService.mentionScope;\n  }\n  ngOnInit(): void {\n    this.subscriptions.push(\n      this.channelService.activeChannel$.subscribe((channel) => {\n        this.textareaValue = '';\n        this.attachmentService.resetAttachmentUploads();\n        const capabilities = channel?.data?.own_capabilities as string[];\n        if (capabilities) {\n          this.isFileUploadAuthorized =\n            capabilities.indexOf('upload-file') !== -1;\n          this.canSendLinks = capabilities.indexOf('send-links') !== -1;\n          this.canSendMessages = capabilities.indexOf('send-message') !== -1;\n          this.cdRef.detectChanges();\n          this.initTextarea();\n        }\n      })\n    );\n  }\n\n  ngAfterViewInit(): void {\n    this.initTextarea();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.message) {\n      this.attachmentService.resetAttachmentUploads();\n      if (this.isUpdate) {\n        this.attachmentService.createFromAttachments(\n          this.message!.attachments || []\n        );\n        this.textareaValue = this.message!.text || '';\n      }\n    }\n    if (changes.isFileUploadEnabled) {\n      this.configService.isFileUploadEnabled = this.isFileUploadEnabled;\n    }\n    if (changes.acceptedFileTypes) {\n      this.configService.acceptedFileTypes = this.acceptedFileTypes;\n    }\n    if (changes.isMultipleFileUploadEnabled) {\n      this.configService.isMultipleFileUploadEnabled =\n        this.isMultipleFileUploadEnabled;\n    }\n    if (changes.areMentionsEnabled) {\n      this.configService.areMentionsEnabled = this.areMentionsEnabled;\n    }\n    if (changes.mentionAutocompleteItemTemplate) {\n      this.configService.mentionAutocompleteItemTemplate =\n        this.mentionAutocompleteItemTemplate;\n    }\n    if (changes.mentionScope) {\n      this.configService.mentionScope = this.mentionScope;\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach((s) => s.unsubscribe());\n  }\n\n  async messageSent() {\n    let attachmentUploadInProgressCounter!: number;\n    this.attachmentService.attachmentUploadInProgressCounter$\n      .pipe(first())\n      .subscribe((counter) => (attachmentUploadInProgressCounter = counter));\n    if (attachmentUploadInProgressCounter > 0) {\n      if (!this.hideNotification) {\n        this.hideNotification =\n          this.notificationService.addPermanentNotification(\n            'streamChat.Wait until all attachments have uploaded'\n          );\n      }\n      return;\n    }\n    const attachments = this.attachmentService.mapToAttachments();\n    const text = this.textareaValue;\n    if (!text && (!attachments || attachments.length === 0)) {\n      return;\n    }\n    if (this.containsLinks && !this.canSendLinks) {\n      this.notificationService.addTemporaryNotification(\n        'streamChat.Sending links is not allowed in this conversation'\n      );\n      return;\n    }\n    if (!this.isUpdate) {\n      this.textareaValue = '';\n    }\n    try {\n      await (this.isUpdate\n        ? this.channelService.updateMessage({\n            ...this.message!,\n            text: text,\n            attachments: attachments,\n          })\n        : this.channelService.sendMessage(\n            text,\n            attachments,\n            this.mentionedUsers\n          ));\n      this.messageUpdate.emit();\n      if (!this.isUpdate) {\n        this.attachmentService.resetAttachmentUploads();\n      }\n    } catch (error) {\n      if (this.isUpdate) {\n        this.notificationService.addTemporaryNotification(\n          'streamChat.Edit message request failed'\n        );\n      }\n    }\n  }\n\n  get containsLinks() {\n    return /(?:(?:https?|ftp):\\/\\/)?[\\w/\\-?=%.]+\\.[\\w/\\-&?=%.]+/.test(\n      this.textareaValue\n    );\n  }\n\n  get accept() {\n    return this.acceptedFileTypes ? this.acceptedFileTypes?.join(',') : '';\n  }\n\n  async filesSelected(fileList: FileList | null) {\n    await this.attachmentService.filesSelected(fileList);\n    this.clearFileInput();\n  }\n\n  private clearFileInput() {\n    this.fileInput.nativeElement.value = '';\n  }\n\n  private get isUpdate() {\n    return !!this.message;\n  }\n\n  private initTextarea() {\n    if (!this.canSendMessages || this.textareaRef || !this.textareaAnchor) {\n      return;\n    }\n    const componentFactory =\n      this.componentFactoryResolver.resolveComponentFactory(this.textareaType);\n    this.textareaRef =\n      this.textareaAnchor.viewContainerRef.createComponent<any>(\n        componentFactory\n      );\n    this.cdRef.detectChanges();\n  }\n}\n","<div\n  class=\"str-chat__input-flat\"\n  [class.str-chat__input-flat-has-attachments]=\"\n    (attachmentUploads$ | async)!.length > 0\n  \"\n>\n  <div class=\"str-chat__input-flat-wrapper\">\n    <div class=\"str-chat__input-flat--textarea-wrapper\">\n      <stream-attachment-preview-list\n        class=\"rfu-image-previewer-angular-host\"\n      ></stream-attachment-preview-list>\n      <div class=\"rta str-chat__textarea\">\n        <ng-template\n          *ngIf=\"canSendMessages; else notAllowed\"\n          streamTextarea\n          [(value)]=\"textareaValue\"\n          (send)=\"messageSent()\"\n          [componentRef]=\"textareaRef\"\n          (userMentions)=\"mentionedUsers = $event\"\n          [areMentionsEnabled]=\"areMentionsEnabled\"\n          [mentionAutocompleteItemTemplate]=\"mentionAutocompleteItemTemplate\"\n          [mentionScope]=\"mentionScope\"\n        ></ng-template>\n        <ng-template #notAllowed>\n          <textarea\n            disabled\n            rows=\"1\"\n            [value]=\"\n              'streamChat.You can\\'t send messages in this channel' | translate\n            \"\n            class=\"rta__textarea str-chat__textarea__textarea\"\n          ></textarea>\n        </ng-template>\n      </div>\n      <div\n        *ngIf=\"isFileUploadEnabled && isFileUploadAuthorized && canSendMessages\"\n        class=\"str-chat__fileupload-wrapper\"\n        data-testid=\"file-upload-button\"\n      >\n        <div class=\"str-chat__tooltip\">\n          {{ \"streamChat.Attach files\" | translate }}\n        </div>\n        <div class=\"rfu-file-upload-button\">\n          <label>\n            <input\n              #fileInput\n              type=\"file\"\n              class=\"rfu-file-input\"\n              data-testid=\"file-input\"\n              [accept]=\"accept\"\n              [multiple]=\"isMultipleFileUploadEnabled\"\n              (change)=\"filesSelected(fileInput.files)\"\n            />\n            <span class=\"str-chat__input-flat-fileupload\">\n              <stream-icon icon=\"file-upload\"></stream-icon>\n            </span>\n          </label>\n        </div>\n      </div>\n    </div>\n    <button\n      *ngIf=\"canSendMessages\"\n      data-testid=\"send-button\"\n      class=\"str-chat__send-button\"\n      (click)=\"messageSent()\"\n      (keyup.enter)=\"messageSent()\"\n    >\n      <stream-icon icon=\"send\"></stream-icon>\n    </button>\n  </div>\n</div>\n"]}
|
|
205
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"message-input.component.js","sourceRoot":"","sources":["../../../../../projects/stream-chat-angular/src/lib/message-input/message-input.component.ts","../../../../../projects/stream-chat-angular/src/lib/message-input/message-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ComponentFactoryResolver,\n  ComponentRef,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  Type,\n  ViewChild,\n} from '@angular/core';\nimport { Observable, Subscription } from 'rxjs';\nimport { first } from 'rxjs/operators';\nimport { UserResponse } from 'stream-chat';\nimport { AttachmentService } from '../attachment.service';\nimport { ChannelService } from '../channel.service';\nimport { textareaInjectionToken } from '../injection-tokens';\nimport { NotificationService } from '../notification.service';\nimport {\n  AttachmentUpload,\n  MentionAutcompleteListItemContext,\n  StreamMessage,\n} from '../types';\nimport { MessageInputConfigService } from './message-input-config.service';\nimport { TextareaDirective } from './textarea.directive';\nimport { TextareaInterface } from './textarea.interface';\n\n@Component({\n  selector: 'stream-message-input',\n  templateUrl: './message-input.component.html',\n  styles: [],\n  providers: [AttachmentService],\n})\nexport class MessageInputComponent\n  implements OnChanges, OnDestroy, AfterViewInit\n{\n  @Input() isFileUploadEnabled: boolean | undefined;\n  @Input() areMentionsEnabled: boolean | undefined;\n  @Input() mentionScope: 'channel' | 'application' | undefined;\n  @Input() mentionAutocompleteItemTemplate:\n    | TemplateRef<MentionAutcompleteListItemContext>\n    | undefined;\n  @Input() acceptedFileTypes: string[] | undefined;\n  @Input() isMultipleFileUploadEnabled: boolean | undefined;\n  @Input() message: StreamMessage | undefined;\n  @Output() readonly messageUpdate = new EventEmitter<void>();\n  isFileUploadAuthorized: boolean | undefined;\n  canSendLinks: boolean | undefined;\n  canSendMessages: boolean | undefined;\n  attachmentUploads$: Observable<AttachmentUpload[]>;\n  textareaValue = '';\n  textareaRef: ComponentRef<TextareaInterface> | undefined;\n  mentionedUsers: UserResponse[] = [];\n  @ViewChild('fileInput') private fileInput!: ElementRef<HTMLInputElement>;\n  @ViewChild(TextareaDirective, { static: false })\n  private textareaAnchor!: TextareaDirective;\n  private subscriptions: Subscription[] = [];\n  private hideNotification: Function | undefined;\n  private isViewInited = false;\n\n  constructor(\n    private channelService: ChannelService,\n    private notificationService: NotificationService,\n    private attachmentService: AttachmentService,\n    private configService: MessageInputConfigService,\n    @Inject(textareaInjectionToken)\n    private textareaType: Type<TextareaInterface>,\n    private componentFactoryResolver: ComponentFactoryResolver,\n    private cdRef: ChangeDetectorRef\n  ) {\n    this.subscriptions.push(\n      this.attachmentService.attachmentUploadInProgressCounter$.subscribe(\n        (counter) => {\n          if (counter === 0 && this.hideNotification) {\n            this.hideNotification();\n            this.hideNotification = undefined;\n          }\n        }\n      )\n    );\n    this.subscriptions.push(\n      this.channelService.activeChannel$.subscribe((channel) => {\n        this.textareaValue = '';\n        this.attachmentService.resetAttachmentUploads();\n        const capabilities = channel?.data?.own_capabilities as string[];\n        if (capabilities) {\n          this.isFileUploadAuthorized =\n            capabilities.indexOf('upload-file') !== -1;\n          this.canSendLinks = capabilities.indexOf('send-links') !== -1;\n          this.canSendMessages = capabilities.indexOf('send-message') !== -1;\n          if (this.isViewInited) {\n            this.cdRef.detectChanges();\n            this.initTextarea();\n          }\n        }\n      })\n    );\n    this.attachmentUploads$ = this.attachmentService.attachmentUploads$;\n    this.isFileUploadEnabled = this.configService.isFileUploadEnabled;\n    this.acceptedFileTypes = this.configService.acceptedFileTypes;\n    this.isMultipleFileUploadEnabled =\n      this.configService.isMultipleFileUploadEnabled;\n    this.areMentionsEnabled = this.configService.areMentionsEnabled;\n    this.mentionAutocompleteItemTemplate =\n      this.configService.mentionAutocompleteItemTemplate;\n    this.mentionScope = this.configService.mentionScope;\n  }\n\n  ngAfterViewInit(): void {\n    this.isViewInited = true;\n    this.initTextarea();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.message) {\n      this.attachmentService.resetAttachmentUploads();\n      if (this.isUpdate) {\n        this.attachmentService.createFromAttachments(\n          this.message!.attachments || []\n        );\n        this.textareaValue = this.message!.text || '';\n      }\n    }\n    if (changes.isFileUploadEnabled) {\n      this.configService.isFileUploadEnabled = this.isFileUploadEnabled;\n    }\n    if (changes.acceptedFileTypes) {\n      this.configService.acceptedFileTypes = this.acceptedFileTypes;\n    }\n    if (changes.isMultipleFileUploadEnabled) {\n      this.configService.isMultipleFileUploadEnabled =\n        this.isMultipleFileUploadEnabled;\n    }\n    if (changes.areMentionsEnabled) {\n      this.configService.areMentionsEnabled = this.areMentionsEnabled;\n    }\n    if (changes.mentionAutocompleteItemTemplate) {\n      this.configService.mentionAutocompleteItemTemplate =\n        this.mentionAutocompleteItemTemplate;\n    }\n    if (changes.mentionScope) {\n      this.configService.mentionScope = this.mentionScope;\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach((s) => s.unsubscribe());\n  }\n\n  async messageSent() {\n    let attachmentUploadInProgressCounter!: number;\n    this.attachmentService.attachmentUploadInProgressCounter$\n      .pipe(first())\n      .subscribe((counter) => (attachmentUploadInProgressCounter = counter));\n    if (attachmentUploadInProgressCounter > 0) {\n      if (!this.hideNotification) {\n        this.hideNotification =\n          this.notificationService.addPermanentNotification(\n            'streamChat.Wait until all attachments have uploaded'\n          );\n      }\n      return;\n    }\n    const attachments = this.attachmentService.mapToAttachments();\n    const text = this.textareaValue;\n    if (!text && (!attachments || attachments.length === 0)) {\n      return;\n    }\n    if (this.containsLinks && !this.canSendLinks) {\n      this.notificationService.addTemporaryNotification(\n        'streamChat.Sending links is not allowed in this conversation'\n      );\n      return;\n    }\n    if (!this.isUpdate) {\n      this.textareaValue = '';\n    }\n    try {\n      await (this.isUpdate\n        ? this.channelService.updateMessage({\n            ...this.message!,\n            text: text,\n            attachments: attachments,\n          })\n        : this.channelService.sendMessage(\n            text,\n            attachments,\n            this.mentionedUsers\n          ));\n      this.messageUpdate.emit();\n      if (!this.isUpdate) {\n        this.attachmentService.resetAttachmentUploads();\n      }\n    } catch (error) {\n      if (this.isUpdate) {\n        this.notificationService.addTemporaryNotification(\n          'streamChat.Edit message request failed'\n        );\n      }\n    }\n  }\n\n  get containsLinks() {\n    return /(?:(?:https?|ftp):\\/\\/)?[\\w/\\-?=%.]+\\.[\\w/\\-&?=%.]+/.test(\n      this.textareaValue\n    );\n  }\n\n  get accept() {\n    return this.acceptedFileTypes ? this.acceptedFileTypes?.join(',') : '';\n  }\n\n  async filesSelected(fileList: FileList | null) {\n    await this.attachmentService.filesSelected(fileList);\n    this.clearFileInput();\n  }\n\n  private clearFileInput() {\n    this.fileInput.nativeElement.value = '';\n  }\n\n  private get isUpdate() {\n    return !!this.message;\n  }\n\n  private initTextarea() {\n    if (!this.canSendMessages || this.textareaRef || !this.textareaAnchor) {\n      return;\n    }\n    const componentFactory =\n      this.componentFactoryResolver.resolveComponentFactory(this.textareaType);\n    this.textareaRef =\n      this.textareaAnchor.viewContainerRef.createComponent<any>(\n        componentFactory\n      );\n    this.cdRef.detectChanges();\n  }\n}\n","<div\n  class=\"str-chat__input-flat\"\n  [class.str-chat__input-flat-has-attachments]=\"\n    (attachmentUploads$ | async)!.length > 0\n  \"\n>\n  <div class=\"str-chat__input-flat-wrapper\">\n    <div class=\"str-chat__input-flat--textarea-wrapper\">\n      <stream-attachment-preview-list\n        class=\"rfu-image-previewer-angular-host\"\n      ></stream-attachment-preview-list>\n      <div class=\"rta str-chat__textarea\">\n        <ng-template\n          *ngIf=\"canSendMessages; else notAllowed\"\n          streamTextarea\n          [(value)]=\"textareaValue\"\n          (send)=\"messageSent()\"\n          [componentRef]=\"textareaRef\"\n          (userMentions)=\"mentionedUsers = $event\"\n          [areMentionsEnabled]=\"areMentionsEnabled\"\n          [mentionAutocompleteItemTemplate]=\"mentionAutocompleteItemTemplate\"\n          [mentionScope]=\"mentionScope\"\n        ></ng-template>\n        <ng-template #notAllowed>\n          <textarea\n            disabled\n            rows=\"1\"\n            [value]=\"\n              'streamChat.You can\\'t send messages in this channel' | translate\n            \"\n            class=\"rta__textarea str-chat__textarea__textarea\"\n          ></textarea>\n        </ng-template>\n      </div>\n      <div\n        *ngIf=\"isFileUploadEnabled && isFileUploadAuthorized && canSendMessages\"\n        class=\"str-chat__fileupload-wrapper\"\n        data-testid=\"file-upload-button\"\n      >\n        <div class=\"str-chat__tooltip\">\n          {{ \"streamChat.Attach files\" | translate }}\n        </div>\n        <div class=\"rfu-file-upload-button\">\n          <label>\n            <input\n              #fileInput\n              type=\"file\"\n              class=\"rfu-file-input\"\n              data-testid=\"file-input\"\n              [accept]=\"accept\"\n              [multiple]=\"isMultipleFileUploadEnabled\"\n              (change)=\"filesSelected(fileInput.files)\"\n            />\n            <span class=\"str-chat__input-flat-fileupload\">\n              <stream-icon icon=\"file-upload\"></stream-icon>\n            </span>\n          </label>\n        </div>\n      </div>\n    </div>\n    <button\n      *ngIf=\"canSendMessages\"\n      data-testid=\"send-button\"\n      class=\"str-chat__send-button\"\n      (click)=\"messageSent()\"\n      (keyup.enter)=\"messageSent()\"\n    >\n      <stream-icon icon=\"send\"></stream-icon>\n    </button>\n  </div>\n</div>\n"]}
|
|
@@ -9,8 +9,10 @@ export class TextareaDirective {
|
|
|
9
9
|
this.send = new EventEmitter();
|
|
10
10
|
this.userMentions = new EventEmitter();
|
|
11
11
|
this.subscriptions = [];
|
|
12
|
+
this.unpropagatedChanges = [];
|
|
12
13
|
}
|
|
13
14
|
ngOnChanges(changes) {
|
|
15
|
+
this.unpropagatedChanges.push(changes);
|
|
14
16
|
if (!this.componentRef) {
|
|
15
17
|
return;
|
|
16
18
|
}
|
|
@@ -22,6 +24,11 @@ export class TextareaDirective {
|
|
|
22
24
|
if (this.componentRef.instance.userMentions) {
|
|
23
25
|
this.subscriptions.push(this.componentRef.instance.userMentions.subscribe((value) => this.userMentions.next(value)));
|
|
24
26
|
}
|
|
27
|
+
this.componentRef.instance.areMentionsEnabled = this.areMentionsEnabled;
|
|
28
|
+
this.componentRef.instance.mentionAutocompleteItemTemplate =
|
|
29
|
+
this.mentionAutocompleteItemTemplate;
|
|
30
|
+
this.componentRef.instance.mentionScope = this.mentionScope;
|
|
31
|
+
this.componentRef.instance.value = this.value;
|
|
25
32
|
}
|
|
26
33
|
}
|
|
27
34
|
if (changes.areMentionsEnabled) {
|
|
@@ -38,8 +45,11 @@ export class TextareaDirective {
|
|
|
38
45
|
this.componentRef.instance.value = this.value;
|
|
39
46
|
}
|
|
40
47
|
// ngOnChanges not called for dynamic components since we don't use template binding
|
|
48
|
+
let changesToPropagate = {};
|
|
49
|
+
this.unpropagatedChanges.forEach((c) => (changesToPropagate = Object.assign(Object.assign({}, changesToPropagate), c)));
|
|
41
50
|
// eslint-disable-next-line @angular-eslint/no-lifecycle-call
|
|
42
|
-
this.componentRef.instance.ngOnChanges(
|
|
51
|
+
this.componentRef.instance.ngOnChanges(changesToPropagate);
|
|
52
|
+
this.unpropagatedChanges = [];
|
|
43
53
|
}
|
|
44
54
|
}
|
|
45
55
|
TextareaDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: TextareaDirective, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
@@ -66,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
|
|
|
66
76
|
}], userMentions: [{
|
|
67
77
|
type: Output
|
|
68
78
|
}] } });
|
|
69
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"textarea.directive.js","sourceRoot":"","sources":["../../../../../projects/stream-chat-angular/src/lib/message-input/textarea.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  ViewContainerRef,\n} from '@angular/core';\nimport { Directive } from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { UserResponse } from 'stream-chat';\nimport { MentionAutcompleteListItemContext } from '../types';\nimport { TextareaInterface } from './textarea.interface';\n\n@Directive({\n  selector: '[streamTextarea]',\n})\nexport class TextareaDirective implements OnChanges {\n  @Input() componentRef: ComponentRef<TextareaInterface> | undefined;\n  @Input() areMentionsEnabled: boolean | undefined;\n  @Input() mentionAutocompleteItemTemplate:\n    | TemplateRef<MentionAutcompleteListItemContext>\n    | undefined;\n  @Input() mentionScope?: 'channel' | 'application';\n  @Input() value = '';\n  @Output() readonly valueChange = new EventEmitter<string>();\n  @Output() readonly send = new EventEmitter<void>();\n  @Output() readonly userMentions = new EventEmitter<UserResponse[]>();\n  private subscriptions: Subscription[] = [];\n  private unpropagatedChanges: SimpleChanges[] = [];\n  constructor(public viewContainerRef: ViewContainerRef) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this.unpropagatedChanges.push(changes);\n    if (!this.componentRef) {\n      return;\n    }\n    if (changes.componentRef) {\n      this.subscriptions.forEach((s) => s.unsubscribe());\n      if (this.componentRef) {\n        this.subscriptions.push(\n          this.componentRef.instance.valueChange.subscribe((value) =>\n            this.valueChange.next(value)\n          )\n        );\n        this.subscriptions.push(\n          this.componentRef.instance.send.subscribe((value) =>\n            this.send.next(value)\n          )\n        );\n        if (this.componentRef.instance.userMentions) {\n          this.subscriptions.push(\n            this.componentRef.instance.userMentions.subscribe((value) =>\n              this.userMentions.next(value)\n            )\n          );\n        }\n        this.componentRef.instance.areMentionsEnabled = this.areMentionsEnabled;\n        this.componentRef.instance.mentionAutocompleteItemTemplate =\n          this.mentionAutocompleteItemTemplate;\n        this.componentRef.instance.mentionScope = this.mentionScope;\n        this.componentRef.instance.value = this.value;\n      }\n    }\n    if (changes.areMentionsEnabled) {\n      this.componentRef.instance.areMentionsEnabled = this.areMentionsEnabled;\n    }\n    if (changes.mentionAutocompleteItemTemplate) {\n      this.componentRef.instance.mentionAutocompleteItemTemplate =\n        this.mentionAutocompleteItemTemplate;\n    }\n    if (changes.mentionScope) {\n      this.componentRef.instance.mentionScope = this.mentionScope;\n    }\n    if (changes.value) {\n      this.componentRef.instance.value = this.value;\n    }\n    // ngOnChanges not called for dynamic components since we don't use template binding\n    let changesToPropagate = {};\n    this.unpropagatedChanges.forEach(\n      (c) => (changesToPropagate = { ...changesToPropagate, ...c })\n    );\n    // eslint-disable-next-line @angular-eslint/no-lifecycle-call\n    this.componentRef.instance.ngOnChanges(changesToPropagate);\n    this.unpropagatedChanges = [];\n  }\n}\n"]}
|
|
@@ -16,7 +16,7 @@ import transliterate from '@stream-io/transliterate';
|
|
|
16
16
|
import * as i5 from 'angular-mentions';
|
|
17
17
|
import { MentionModule } from 'angular-mentions';
|
|
18
18
|
|
|
19
|
-
const version = '2.3.
|
|
19
|
+
const version = '2.3.1';
|
|
20
20
|
|
|
21
21
|
class NotificationService {
|
|
22
22
|
constructor() {
|
|
@@ -1129,8 +1129,10 @@ class TextareaDirective {
|
|
|
1129
1129
|
this.send = new EventEmitter();
|
|
1130
1130
|
this.userMentions = new EventEmitter();
|
|
1131
1131
|
this.subscriptions = [];
|
|
1132
|
+
this.unpropagatedChanges = [];
|
|
1132
1133
|
}
|
|
1133
1134
|
ngOnChanges(changes) {
|
|
1135
|
+
this.unpropagatedChanges.push(changes);
|
|
1134
1136
|
if (!this.componentRef) {
|
|
1135
1137
|
return;
|
|
1136
1138
|
}
|
|
@@ -1142,6 +1144,11 @@ class TextareaDirective {
|
|
|
1142
1144
|
if (this.componentRef.instance.userMentions) {
|
|
1143
1145
|
this.subscriptions.push(this.componentRef.instance.userMentions.subscribe((value) => this.userMentions.next(value)));
|
|
1144
1146
|
}
|
|
1147
|
+
this.componentRef.instance.areMentionsEnabled = this.areMentionsEnabled;
|
|
1148
|
+
this.componentRef.instance.mentionAutocompleteItemTemplate =
|
|
1149
|
+
this.mentionAutocompleteItemTemplate;
|
|
1150
|
+
this.componentRef.instance.mentionScope = this.mentionScope;
|
|
1151
|
+
this.componentRef.instance.value = this.value;
|
|
1145
1152
|
}
|
|
1146
1153
|
}
|
|
1147
1154
|
if (changes.areMentionsEnabled) {
|
|
@@ -1158,8 +1165,11 @@ class TextareaDirective {
|
|
|
1158
1165
|
this.componentRef.instance.value = this.value;
|
|
1159
1166
|
}
|
|
1160
1167
|
// ngOnChanges not called for dynamic components since we don't use template binding
|
|
1168
|
+
let changesToPropagate = {};
|
|
1169
|
+
this.unpropagatedChanges.forEach((c) => (changesToPropagate = Object.assign(Object.assign({}, changesToPropagate), c)));
|
|
1161
1170
|
// eslint-disable-next-line @angular-eslint/no-lifecycle-call
|
|
1162
|
-
this.componentRef.instance.ngOnChanges(
|
|
1171
|
+
this.componentRef.instance.ngOnChanges(changesToPropagate);
|
|
1172
|
+
this.unpropagatedChanges = [];
|
|
1163
1173
|
}
|
|
1164
1174
|
}
|
|
1165
1175
|
TextareaDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: TextareaDirective, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
@@ -1247,23 +1257,13 @@ class MessageInputComponent {
|
|
|
1247
1257
|
this.textareaValue = '';
|
|
1248
1258
|
this.mentionedUsers = [];
|
|
1249
1259
|
this.subscriptions = [];
|
|
1260
|
+
this.isViewInited = false;
|
|
1250
1261
|
this.subscriptions.push(this.attachmentService.attachmentUploadInProgressCounter$.subscribe((counter) => {
|
|
1251
1262
|
if (counter === 0 && this.hideNotification) {
|
|
1252
1263
|
this.hideNotification();
|
|
1253
1264
|
this.hideNotification = undefined;
|
|
1254
1265
|
}
|
|
1255
1266
|
}));
|
|
1256
|
-
this.attachmentUploads$ = this.attachmentService.attachmentUploads$;
|
|
1257
|
-
this.isFileUploadEnabled = this.configService.isFileUploadEnabled;
|
|
1258
|
-
this.acceptedFileTypes = this.configService.acceptedFileTypes;
|
|
1259
|
-
this.isMultipleFileUploadEnabled =
|
|
1260
|
-
this.configService.isMultipleFileUploadEnabled;
|
|
1261
|
-
this.areMentionsEnabled = this.configService.areMentionsEnabled;
|
|
1262
|
-
this.mentionAutocompleteItemTemplate =
|
|
1263
|
-
this.configService.mentionAutocompleteItemTemplate;
|
|
1264
|
-
this.mentionScope = this.configService.mentionScope;
|
|
1265
|
-
}
|
|
1266
|
-
ngOnInit() {
|
|
1267
1267
|
this.subscriptions.push(this.channelService.activeChannel$.subscribe((channel) => {
|
|
1268
1268
|
var _a;
|
|
1269
1269
|
this.textareaValue = '';
|
|
@@ -1274,12 +1274,24 @@ class MessageInputComponent {
|
|
|
1274
1274
|
capabilities.indexOf('upload-file') !== -1;
|
|
1275
1275
|
this.canSendLinks = capabilities.indexOf('send-links') !== -1;
|
|
1276
1276
|
this.canSendMessages = capabilities.indexOf('send-message') !== -1;
|
|
1277
|
-
this.
|
|
1278
|
-
|
|
1277
|
+
if (this.isViewInited) {
|
|
1278
|
+
this.cdRef.detectChanges();
|
|
1279
|
+
this.initTextarea();
|
|
1280
|
+
}
|
|
1279
1281
|
}
|
|
1280
1282
|
}));
|
|
1283
|
+
this.attachmentUploads$ = this.attachmentService.attachmentUploads$;
|
|
1284
|
+
this.isFileUploadEnabled = this.configService.isFileUploadEnabled;
|
|
1285
|
+
this.acceptedFileTypes = this.configService.acceptedFileTypes;
|
|
1286
|
+
this.isMultipleFileUploadEnabled =
|
|
1287
|
+
this.configService.isMultipleFileUploadEnabled;
|
|
1288
|
+
this.areMentionsEnabled = this.configService.areMentionsEnabled;
|
|
1289
|
+
this.mentionAutocompleteItemTemplate =
|
|
1290
|
+
this.configService.mentionAutocompleteItemTemplate;
|
|
1291
|
+
this.mentionScope = this.configService.mentionScope;
|
|
1281
1292
|
}
|
|
1282
1293
|
ngAfterViewInit() {
|
|
1294
|
+
this.isViewInited = true;
|
|
1283
1295
|
this.initTextarea();
|
|
1284
1296
|
}
|
|
1285
1297
|
ngOnChanges(changes) {
|