stream-chat-angular 4.66.1 → 5.0.0-v5.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (161) hide show
  1. package/assets/version.d.ts +1 -1
  2. package/{esm2015/assets/version.js → esm2020/assets/version.mjs} +2 -2
  3. package/esm2020/lib/attachment-configuration.service.mjs +185 -0
  4. package/esm2020/lib/attachment-list/attachment-list.component.mjs +205 -0
  5. package/esm2020/lib/attachment-preview-list/attachment-preview-list.component.mjs +45 -0
  6. package/esm2020/lib/attachment.service.mjs +262 -0
  7. package/esm2020/lib/avatar/avatar.component.mjs +163 -0
  8. package/esm2020/lib/avatar-placeholder/avatar-placeholder.component.mjs +74 -0
  9. package/esm2020/lib/channel/channel.component.mjs +46 -0
  10. package/esm2020/lib/channel-header/channel-header.component.mjs +79 -0
  11. package/esm2020/lib/channel-list/channel-list-toggle.service.mjs +72 -0
  12. package/esm2020/lib/channel-list/channel-list.component.mjs +60 -0
  13. package/esm2020/lib/channel-preview/channel-preview.component.mjs +155 -0
  14. package/esm2020/lib/channel.service.mjs +1460 -0
  15. package/esm2020/lib/chat-client.service.mjs +206 -0
  16. package/{esm2015/lib/custom-templates.service.js → esm2020/lib/custom-templates.service.mjs} +3 -3
  17. package/{esm2015/lib/date-parser.service.js → esm2020/lib/date-parser.service.mjs} +3 -3
  18. package/esm2020/lib/edit-message-form/edit-message-form.component.mjs +83 -0
  19. package/esm2020/lib/get-channel-display-text.mjs +14 -0
  20. package/esm2020/lib/get-message-translation.mjs +12 -0
  21. package/esm2020/lib/icon/icon.component.mjs +21 -0
  22. package/esm2020/lib/icon-placeholder/icon-placeholder.component.mjs +31 -0
  23. package/esm2020/lib/loading-indicator/loading-indicator.component.mjs +31 -0
  24. package/esm2020/lib/loading-indicator-placeholder/loading-indicator-placeholder.component.mjs +38 -0
  25. package/esm2020/lib/message/message.component.mjs +418 -0
  26. package/esm2020/lib/message-actions-box/message-actions-box.component.mjs +130 -0
  27. package/esm2020/lib/message-actions.service.mjs +119 -0
  28. package/esm2020/lib/message-bounce-prompt/message-bounce-prompt.component.mjs +71 -0
  29. package/esm2020/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.mjs +262 -0
  30. package/{esm2015/lib/message-input/emoji-input.service.js → esm2020/lib/message-input/emoji-input.service.mjs} +3 -3
  31. package/{esm2015/lib/message-input/message-input-config.service.js → esm2020/lib/message-input/message-input-config.service.mjs} +3 -3
  32. package/esm2020/lib/message-input/message-input.component.mjs +443 -0
  33. package/{esm2015/lib/message-input/textarea/textarea.component.js → esm2020/lib/message-input/textarea/textarea.component.mjs} +5 -9
  34. package/esm2020/lib/message-input/textarea.directive.mjs +89 -0
  35. package/esm2020/lib/message-list/group-styles.mjs +52 -0
  36. package/{esm2015/lib/message-list/image-load.service.js → esm2020/lib/message-list/image-load.service.mjs} +3 -3
  37. package/esm2020/lib/message-list/message-list.component.mjs +699 -0
  38. package/esm2020/lib/message-preview.mjs +21 -0
  39. package/esm2020/lib/message-reactions/message-reactions.component.mjs +252 -0
  40. package/{esm2015/lib/message-reactions.service.js → esm2020/lib/message-reactions.service.mjs} +3 -3
  41. package/{esm2015/lib/message.service.js → esm2020/lib/message.service.mjs} +4 -4
  42. package/esm2020/lib/modal/modal.component.mjs +69 -0
  43. package/esm2020/lib/notification/notification.component.mjs +20 -0
  44. package/esm2020/lib/notification-list/notification-list.component.mjs +37 -0
  45. package/esm2020/lib/notification.service.mjs +79 -0
  46. package/esm2020/lib/read-by.mjs +12 -0
  47. package/{esm2015/lib/stream-autocomplete-textarea.module.js → esm2020/lib/stream-autocomplete-textarea.module.mjs} +6 -6
  48. package/{esm2015/lib/stream-avatar.module.js → esm2020/lib/stream-avatar.module.mjs} +5 -5
  49. package/{esm2015/lib/stream-chat.module.js → esm2020/lib/stream-chat.module.mjs} +14 -16
  50. package/{esm2015/lib/stream-i18n.service.js → esm2020/lib/stream-i18n.service.mjs} +5 -5
  51. package/{esm2015/lib/stream-textarea.module.js → esm2020/lib/stream-textarea.module.mjs} +6 -6
  52. package/esm2020/lib/theme.service.mjs +123 -0
  53. package/esm2020/lib/thread/thread.component.mjs +51 -0
  54. package/{esm2015/lib/transliteration.service.js → esm2020/lib/transliteration.service.mjs} +3 -3
  55. package/esm2020/lib/types.mjs +2 -0
  56. package/esm2020/lib/voice-recording/voice-recording-wavebar/voice-recording-wavebar.component.mjs +183 -0
  57. package/esm2020/lib/voice-recording/voice-recording.component.mjs +102 -0
  58. package/fesm2015/{stream-chat-angular.js → stream-chat-angular.mjs} +313 -426
  59. package/fesm2015/stream-chat-angular.mjs.map +1 -0
  60. package/fesm2020/stream-chat-angular.mjs +7123 -0
  61. package/fesm2020/stream-chat-angular.mjs.map +1 -0
  62. package/lib/attachment-list/attachment-list.component.d.ts +3 -3
  63. package/lib/attachment-preview-list/attachment-preview-list.component.d.ts +1 -1
  64. package/lib/attachment.service.d.ts +0 -1
  65. package/lib/avatar/avatar.component.d.ts +1 -1
  66. package/lib/avatar-placeholder/avatar-placeholder.component.d.ts +1 -1
  67. package/lib/channel/channel.component.d.ts +1 -1
  68. package/lib/channel-header/channel-header.component.d.ts +1 -1
  69. package/lib/channel-list/channel-list-toggle.service.d.ts +0 -1
  70. package/lib/channel-list/channel-list.component.d.ts +1 -1
  71. package/lib/channel-preview/channel-preview.component.d.ts +1 -1
  72. package/lib/channel.service.d.ts +7 -7
  73. package/lib/chat-client.service.d.ts +1 -1
  74. package/lib/edit-message-form/edit-message-form.component.d.ts +1 -1
  75. package/lib/get-message-translation.d.ts +1 -1
  76. package/lib/icon/icon.component.d.ts +1 -1
  77. package/lib/icon-placeholder/icon-placeholder.component.d.ts +1 -1
  78. package/lib/loading-indicator/loading-indicator.component.d.ts +1 -1
  79. package/lib/loading-indicator-placeholder/loading-indicator-placeholder.component.d.ts +1 -1
  80. package/lib/message/message.component.d.ts +3 -7
  81. package/lib/message-actions-box/message-actions-box.component.d.ts +2 -4
  82. package/lib/message-actions.service.d.ts +0 -1
  83. package/lib/message-bounce-prompt/message-bounce-prompt.component.d.ts +1 -1
  84. package/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.d.ts +1 -1
  85. package/lib/message-input/message-input.component.d.ts +2 -2
  86. package/lib/message-input/textarea/textarea.component.d.ts +1 -1
  87. package/lib/message-input/textarea.directive.d.ts +1 -1
  88. package/lib/message-list/group-styles.d.ts +1 -1
  89. package/lib/message-list/message-list.component.d.ts +4 -5
  90. package/lib/message-reactions/message-reactions.component.d.ts +1 -4
  91. package/lib/message.service.d.ts +0 -1
  92. package/lib/modal/modal.component.d.ts +1 -1
  93. package/lib/notification/notification.component.d.ts +1 -1
  94. package/lib/notification-list/notification-list.component.d.ts +2 -2
  95. package/lib/notification.service.d.ts +2 -5
  96. package/lib/stream-chat.module.d.ts +3 -3
  97. package/lib/theme.service.d.ts +1 -2
  98. package/lib/thread/thread.component.d.ts +1 -1
  99. package/lib/types.d.ts +18 -18
  100. package/lib/voice-recording/voice-recording-wavebar/voice-recording-wavebar.component.d.ts +2 -2
  101. package/lib/voice-recording/voice-recording.component.d.ts +1 -1
  102. package/package.json +31 -17
  103. package/src/assets/styles/v2/css/index.css +1 -1
  104. package/src/assets/styles/v2/css/index.layout.css +1 -1
  105. package/src/assets/styles/v2/scss/_base.scss +2 -2
  106. package/src/assets/version.ts +1 -1
  107. package/bundles/stream-chat-angular.umd.js +0 -8445
  108. package/bundles/stream-chat-angular.umd.js.map +0 -1
  109. package/esm2015/lib/attachment-configuration.service.js +0 -186
  110. package/esm2015/lib/attachment-list/attachment-list.component.js +0 -209
  111. package/esm2015/lib/attachment-preview-list/attachment-preview-list.component.js +0 -49
  112. package/esm2015/lib/attachment.service.js +0 -276
  113. package/esm2015/lib/avatar/avatar.component.js +0 -172
  114. package/esm2015/lib/avatar-placeholder/avatar-placeholder.component.js +0 -78
  115. package/esm2015/lib/channel/channel.component.js +0 -50
  116. package/esm2015/lib/channel-header/channel-header.component.js +0 -86
  117. package/esm2015/lib/channel-list/channel-list-toggle.service.js +0 -73
  118. package/esm2015/lib/channel-list/channel-list.component.js +0 -67
  119. package/esm2015/lib/channel-preview/channel-preview.component.js +0 -167
  120. package/esm2015/lib/channel.service.js +0 -1487
  121. package/esm2015/lib/chat-client.service.js +0 -211
  122. package/esm2015/lib/edit-message-form/edit-message-form.component.js +0 -87
  123. package/esm2015/lib/get-channel-display-text.js +0 -15
  124. package/esm2015/lib/get-message-translation.js +0 -13
  125. package/esm2015/lib/icon/icon.component.js +0 -25
  126. package/esm2015/lib/icon-placeholder/icon-placeholder.component.js +0 -35
  127. package/esm2015/lib/loading-indicator/loading-indicator.component.js +0 -35
  128. package/esm2015/lib/loading-indicator-placeholder/loading-indicator-placeholder.component.js +0 -42
  129. package/esm2015/lib/message/message.component.js +0 -436
  130. package/esm2015/lib/message-actions-box/message-actions-box.component.js +0 -137
  131. package/esm2015/lib/message-actions.service.js +0 -114
  132. package/esm2015/lib/message-bounce-prompt/message-bounce-prompt.component.js +0 -80
  133. package/esm2015/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.js +0 -262
  134. package/esm2015/lib/message-input/message-input.component.js +0 -455
  135. package/esm2015/lib/message-input/textarea.directive.js +0 -90
  136. package/esm2015/lib/message-list/group-styles.js +0 -53
  137. package/esm2015/lib/message-list/message-list.component.js +0 -726
  138. package/esm2015/lib/message-preview.js +0 -7
  139. package/esm2015/lib/message-reactions/message-reactions.component.js +0 -266
  140. package/esm2015/lib/modal/modal.component.js +0 -74
  141. package/esm2015/lib/notification/notification.component.js +0 -24
  142. package/esm2015/lib/notification-list/notification-list.component.js +0 -38
  143. package/esm2015/lib/notification.service.js +0 -79
  144. package/esm2015/lib/read-by.js +0 -13
  145. package/esm2015/lib/theme.service.js +0 -122
  146. package/esm2015/lib/thread/thread.component.js +0 -55
  147. package/esm2015/lib/types.js +0 -2
  148. package/esm2015/lib/voice-recording/voice-recording-wavebar/voice-recording-wavebar.component.js +0 -192
  149. package/esm2015/lib/voice-recording/voice-recording.component.js +0 -115
  150. package/fesm2015/stream-chat-angular.js.map +0 -1
  151. /package/{esm2015/assets/i18n/en.js → esm2020/assets/i18n/en.mjs} +0 -0
  152. /package/{esm2015/lib/injection-tokens.js → esm2020/lib/injection-tokens.mjs} +0 -0
  153. /package/{esm2015/lib/is-image-attachment.js → esm2020/lib/is-image-attachment.mjs} +0 -0
  154. /package/{esm2015/lib/is-image-file.js → esm2020/lib/is-image-file.mjs} +0 -0
  155. /package/{esm2015/lib/is-on-separate-date.js → esm2020/lib/is-on-separate-date.mjs} +0 -0
  156. /package/{esm2015/lib/list-users.js → esm2020/lib/list-users.mjs} +0 -0
  157. /package/{esm2015/lib/message-input/textarea.interface.js → esm2020/lib/message-input/textarea.interface.mjs} +0 -0
  158. /package/{esm2015/lib/parse-date.js → esm2020/lib/parse-date.mjs} +0 -0
  159. /package/{esm2015/public-api.js → esm2020/public-api.mjs} +0 -0
  160. /package/{esm2015/stream-chat-angular.js → esm2020/stream-chat-angular.mjs} +0 -0
  161. /package/{stream-chat-angular.d.ts → index.d.ts} +0 -0
@@ -73,15 +73,11 @@ export class TextareaComponent {
73
73
  }
74
74
  }
75
75
  }
76
- TextareaComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: TextareaComponent, deps: [{ token: i1.EmojiInputService }, { token: i2.ThemeService }], target: i0.ɵɵFactoryTarget.Component });
77
- TextareaComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.5", type: TextareaComponent, selector: "stream-textarea", inputs: { value: "value", placeholder: "placeholder", inputMode: "inputMode", autoFocus: "autoFocus" }, outputs: { valueChange: "valueChange", send: "send" }, host: { properties: { "class": "this.class" } }, viewQueries: [{ propertyName: "messageInput", first: true, predicate: ["input"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<textarea\n [value]=\"value || ''\"\n [autofocus]=\"autoFocus\"\n data-testid=\"textarea\"\n #input\n placeholder=\"{{ placeholder | translate }}\"\n class=\"\n rta__textarea\n str-chat__textarea__textarea\n str-chat__angular-textarea\n str-chat__message-textarea\n \"\n rows=\"1\"\n (input)=\"inputChanged()\"\n (keydown.enter)=\"enterHit($event)\"\n></textarea>\n", pipes: { "translate": i3.TranslatePipe } });
78
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: TextareaComponent, decorators: [{
76
+ TextareaComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: TextareaComponent, deps: [{ token: i1.EmojiInputService }, { token: i2.ThemeService }], target: i0.ɵɵFactoryTarget.Component });
77
+ TextareaComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: TextareaComponent, selector: "stream-textarea", inputs: { value: "value", placeholder: "placeholder", inputMode: "inputMode", autoFocus: "autoFocus" }, outputs: { valueChange: "valueChange", send: "send" }, host: { properties: { "class": "this.class" } }, viewQueries: [{ propertyName: "messageInput", first: true, predicate: ["input"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<textarea\n #input\n data-testid=\"textarea\"\n class=\"\n rta__textarea\n str-chat__textarea__textarea\n str-chat__angular-textarea\n str-chat__message-textarea\n \"\n rows=\"1\"\n [value]=\"value || ''\"\n [autofocus]=\"autoFocus\"\n placeholder=\"{{ placeholder | translate }}\"\n (input)=\"inputChanged()\"\n (keydown.enter)=\"enterHit($event)\"\n></textarea>\n", dependencies: [{ kind: "pipe", type: i3.TranslatePipe, name: "translate" }] });
78
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: TextareaComponent, decorators: [{
79
79
  type: Component,
80
- args: [{
81
- selector: 'stream-textarea',
82
- templateUrl: './textarea.component.html',
83
- styles: [],
84
- }]
80
+ args: [{ selector: 'stream-textarea', template: "<textarea\n #input\n data-testid=\"textarea\"\n class=\"\n rta__textarea\n str-chat__textarea__textarea\n str-chat__angular-textarea\n str-chat__message-textarea\n \"\n rows=\"1\"\n [value]=\"value || ''\"\n [autofocus]=\"autoFocus\"\n placeholder=\"{{ placeholder | translate }}\"\n (input)=\"inputChanged()\"\n (keydown.enter)=\"enterHit($event)\"\n></textarea>\n" }]
85
81
  }], ctorParameters: function () { return [{ type: i1.EmojiInputService }, { type: i2.ThemeService }]; }, propDecorators: { class: [{
86
82
  type: HostBinding
87
83
  }], value: [{
@@ -100,4 +96,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
100
96
  type: ViewChild,
101
97
  args: ['input']
102
98
  }] } });
103
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"textarea.component.js","sourceRoot":"","sources":["../../../../../../projects/stream-chat-angular/src/lib/message-input/textarea/textarea.component.ts","../../../../../../projects/stream-chat-angular/src/lib/message-input/textarea/textarea.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { ThemeService } from '../../theme.service';\nimport { EmojiInputService } from '../emoji-input.service';\nimport { TextareaInterface } from '../textarea.interface';\n\n/**\n * The `Textarea` component is used by the [`MessageInput`](./MessageInputComponent.mdx) component to display the input HTML element where users can type their message.\n */\n@Component({\n  selector: 'stream-textarea',\n  templateUrl: './textarea.component.html',\n  styles: [],\n})\nexport class TextareaComponent\n  implements TextareaInterface, OnChanges, OnDestroy, AfterViewInit\n{\n  @HostBinding() class =\n    'str-chat__textarea str-chat__message-textarea-angular-host';\n  /**\n   * The value of the input HTML element.\n   */\n  @Input() value = '';\n  /**\n   * Placeholder of the textarea\n   */\n  @Input() placeholder = '';\n  /**\n   * See [`MessageInputConfigService`](../services/MessageInputConfigService.mdx) for more information\n   */\n  @Input() inputMode!: 'desktop' | 'mobile';\n  /**\n   * Enables or disables auto focus on the textarea element\n   */\n  @Input() autoFocus = true;\n  /**\n   * Emits the current value of the input element when a user types.\n   */\n  @Output() readonly valueChange = new EventEmitter<string>();\n  /**\n   * Emits when a user triggers a message send event (this happens when they hit the `Enter` key).\n   */\n  @Output() readonly send = new EventEmitter<void>();\n  @ViewChild('input') private messageInput!: ElementRef<HTMLInputElement>;\n  private subscriptions: Subscription[] = [];\n\n  constructor(\n    private emojiInputService: EmojiInputService,\n    private themeService: ThemeService\n  ) {\n    this.subscriptions.push(\n      this.emojiInputService.emojiInput$.subscribe((emoji) => {\n        this.messageInput.nativeElement.focus();\n        const { selectionStart } = this.messageInput.nativeElement;\n        this.messageInput.nativeElement.setRangeText(emoji);\n        this.messageInput.nativeElement.selectionStart =\n          selectionStart! + emoji.length;\n        this.messageInput.nativeElement.selectionEnd =\n          selectionStart! + emoji.length;\n        this.inputChanged();\n      })\n    );\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.value && !this.value && this.messageInput) {\n      this.messageInput.nativeElement.style.height = 'auto';\n    }\n  }\n\n  ngAfterViewInit(): void {\n    if (this.messageInput.nativeElement.scrollHeight > 0) {\n      this.adjustTextareaHeight();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach((s) => s.unsubscribe());\n  }\n\n  inputChanged() {\n    this.valueChange.emit(this.messageInput.nativeElement.value);\n    this.adjustTextareaHeight();\n  }\n\n  enterHit(event: Event) {\n    if (this.inputMode === 'desktop') {\n      event.preventDefault();\n      this.send.next();\n    }\n  }\n\n  private adjustTextareaHeight() {\n    if (this.themeService.themeVersion === '2') {\n      this.messageInput.nativeElement.style.height = '';\n      this.messageInput.nativeElement.style.height = `${this.messageInput.nativeElement.scrollHeight}px`;\n    }\n  }\n}\n","<textarea\n  [value]=\"value || ''\"\n  [autofocus]=\"autoFocus\"\n  data-testid=\"textarea\"\n  #input\n  placeholder=\"{{ placeholder | translate }}\"\n  class=\"\n    rta__textarea\n    str-chat__textarea__textarea\n    str-chat__angular-textarea\n    str-chat__message-textarea\n  \"\n  rows=\"1\"\n  (input)=\"inputChanged()\"\n  (keydown.enter)=\"enterHit($event)\"\n></textarea>\n"]}
99
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"textarea.component.js","sourceRoot":"","sources":["../../../../../../projects/stream-chat-angular/src/lib/message-input/textarea/textarea.component.ts","../../../../../../projects/stream-chat-angular/src/lib/message-input/textarea/textarea.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { ThemeService } from '../../theme.service';\nimport { EmojiInputService } from '../emoji-input.service';\nimport { TextareaInterface } from '../textarea.interface';\n\n/**\n * The `Textarea` component is used by the [`MessageInput`](./MessageInputComponent.mdx) component to display the input HTML element where users can type their message.\n */\n@Component({\n  selector: 'stream-textarea',\n  templateUrl: './textarea.component.html',\n  styles: [],\n})\nexport class TextareaComponent\n  implements TextareaInterface, OnChanges, OnDestroy, AfterViewInit\n{\n  @HostBinding() class =\n    'str-chat__textarea str-chat__message-textarea-angular-host';\n  /**\n   * The value of the input HTML element.\n   */\n  @Input() value = '';\n  /**\n   * Placeholder of the textarea\n   */\n  @Input() placeholder = '';\n  /**\n   * See [`MessageInputConfigService`](../services/MessageInputConfigService.mdx) for more information\n   */\n  @Input() inputMode!: 'desktop' | 'mobile';\n  /**\n   * Enables or disables auto focus on the textarea element\n   */\n  @Input() autoFocus = true;\n  /**\n   * Emits the current value of the input element when a user types.\n   */\n  @Output() readonly valueChange = new EventEmitter<string>();\n  /**\n   * Emits when a user triggers a message send event (this happens when they hit the `Enter` key).\n   */\n  @Output() readonly send = new EventEmitter<void>();\n  @ViewChild('input') private messageInput!: ElementRef<HTMLInputElement>;\n  private subscriptions: Subscription[] = [];\n\n  constructor(\n    private emojiInputService: EmojiInputService,\n    private themeService: ThemeService\n  ) {\n    this.subscriptions.push(\n      this.emojiInputService.emojiInput$.subscribe((emoji) => {\n        this.messageInput.nativeElement.focus();\n        const { selectionStart } = this.messageInput.nativeElement;\n        this.messageInput.nativeElement.setRangeText(emoji);\n        this.messageInput.nativeElement.selectionStart =\n          selectionStart! + emoji.length;\n        this.messageInput.nativeElement.selectionEnd =\n          selectionStart! + emoji.length;\n        this.inputChanged();\n      })\n    );\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.value && !this.value && this.messageInput) {\n      this.messageInput.nativeElement.style.height = 'auto';\n    }\n  }\n\n  ngAfterViewInit(): void {\n    if (this.messageInput.nativeElement.scrollHeight > 0) {\n      this.adjustTextareaHeight();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach((s) => s.unsubscribe());\n  }\n\n  inputChanged() {\n    this.valueChange.emit(this.messageInput.nativeElement.value);\n    this.adjustTextareaHeight();\n  }\n\n  enterHit(event: Event) {\n    if (this.inputMode === 'desktop') {\n      event.preventDefault();\n      this.send.next();\n    }\n  }\n\n  private adjustTextareaHeight() {\n    if (this.themeService.themeVersion === '2') {\n      this.messageInput.nativeElement.style.height = '';\n      this.messageInput.nativeElement.style.height = `${this.messageInput.nativeElement.scrollHeight}px`;\n    }\n  }\n}\n","<textarea\n  #input\n  data-testid=\"textarea\"\n  class=\"\n    rta__textarea\n    str-chat__textarea__textarea\n    str-chat__angular-textarea\n    str-chat__message-textarea\n  \"\n  rows=\"1\"\n  [value]=\"value || ''\"\n  [autofocus]=\"autoFocus\"\n  placeholder=\"{{ placeholder | translate }}\"\n  (input)=\"inputChanged()\"\n  (keydown.enter)=\"enterHit($event)\"\n></textarea>\n"]}
@@ -0,0 +1,89 @@
1
+ import { EventEmitter, Input, Output, } from '@angular/core';
2
+ import { Directive } from '@angular/core';
3
+ import * as i0 from "@angular/core";
4
+ export class TextareaDirective {
5
+ constructor(viewContainerRef) {
6
+ this.viewContainerRef = viewContainerRef;
7
+ this.value = '';
8
+ this.valueChange = new EventEmitter();
9
+ this.send = new EventEmitter();
10
+ this.userMentions = new EventEmitter();
11
+ this.subscriptions = [];
12
+ this.unpropagatedChanges = [];
13
+ }
14
+ ngOnChanges(changes) {
15
+ this.unpropagatedChanges.push(changes);
16
+ if (!this.componentRef) {
17
+ return;
18
+ }
19
+ if (changes.componentRef) {
20
+ this.subscriptions.forEach((s) => s.unsubscribe());
21
+ if (this.componentRef) {
22
+ this.subscriptions.push(this.componentRef.instance.valueChange.subscribe((value) => this.valueChange.next(value)));
23
+ this.subscriptions.push(this.componentRef.instance.send.subscribe((value) => this.send.next(value)));
24
+ if (this.componentRef.instance.userMentions) {
25
+ this.subscriptions.push(this.componentRef.instance.userMentions.subscribe((value) => this.userMentions.next(value)));
26
+ }
27
+ this.componentRef.instance.areMentionsEnabled = this.areMentionsEnabled;
28
+ this.componentRef.instance.mentionScope = this.mentionScope;
29
+ this.componentRef.instance.value = this.value;
30
+ this.componentRef.instance.placeholder = this.placeholder;
31
+ this.componentRef.instance.inputMode = this.inputMode;
32
+ this.componentRef.instance.autoFocus = this.autoFocus;
33
+ }
34
+ }
35
+ if (changes.areMentionsEnabled) {
36
+ this.componentRef.instance.areMentionsEnabled = this.areMentionsEnabled;
37
+ }
38
+ if (changes.mentionScope) {
39
+ this.componentRef.instance.mentionScope = this.mentionScope;
40
+ }
41
+ if (changes.value) {
42
+ this.componentRef.instance.value = this.value;
43
+ }
44
+ if (changes.placeholder) {
45
+ this.componentRef.instance.placeholder = this.placeholder;
46
+ }
47
+ if (changes.inputMode) {
48
+ this.componentRef.instance.inputMode = this.inputMode;
49
+ }
50
+ if (changes.autoFocus) {
51
+ this.componentRef.instance.autoFocus = this.autoFocus;
52
+ }
53
+ // ngOnChanges not called for dynamic components since we don't use template binding
54
+ let changesToPropagate = {};
55
+ this.unpropagatedChanges.forEach((c) => (changesToPropagate = { ...changesToPropagate, ...c }));
56
+ // eslint-disable-next-line @angular-eslint/no-lifecycle-call
57
+ this.componentRef.instance.ngOnChanges?.(changesToPropagate);
58
+ this.unpropagatedChanges = [];
59
+ }
60
+ }
61
+ TextareaDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: TextareaDirective, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
62
+ TextareaDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.0.4", type: TextareaDirective, selector: "[streamTextarea]", inputs: { componentRef: "componentRef", areMentionsEnabled: "areMentionsEnabled", mentionScope: "mentionScope", inputMode: "inputMode", value: "value", placeholder: "placeholder", autoFocus: "autoFocus" }, outputs: { valueChange: "valueChange", send: "send", userMentions: "userMentions" }, usesOnChanges: true, ngImport: i0 });
63
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: TextareaDirective, decorators: [{
64
+ type: Directive,
65
+ args: [{
66
+ selector: '[streamTextarea]',
67
+ }]
68
+ }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }]; }, propDecorators: { componentRef: [{
69
+ type: Input
70
+ }], areMentionsEnabled: [{
71
+ type: Input
72
+ }], mentionScope: [{
73
+ type: Input
74
+ }], inputMode: [{
75
+ type: Input
76
+ }], value: [{
77
+ type: Input
78
+ }], placeholder: [{
79
+ type: Input
80
+ }], autoFocus: [{
81
+ type: Input
82
+ }], valueChange: [{
83
+ type: Output
84
+ }], send: [{
85
+ type: Output
86
+ }], userMentions: [{
87
+ type: Output
88
+ }] } });
89
+ //# 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  ViewContainerRef,\n} from '@angular/core';\nimport { Directive } from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { UserResponse } from 'stream-chat';\nimport { TextareaInterface } from './textarea.interface';\n\n@Directive({\n  selector: '[streamTextarea]',\n})\nexport class TextareaDirective implements OnChanges {\n  @Input() componentRef:\n    | ComponentRef<TextareaInterface & Partial<OnChanges>>\n    | undefined;\n  @Input() areMentionsEnabled: boolean | undefined;\n  @Input() mentionScope?: 'channel' | 'application';\n  @Input() inputMode!: 'mobile' | 'desktop';\n  @Input() value = '';\n  @Input() placeholder: string | undefined;\n  @Input() autoFocus!: boolean;\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.mentionScope = this.mentionScope;\n        this.componentRef.instance.value = this.value;\n        this.componentRef.instance.placeholder = this.placeholder;\n        this.componentRef.instance.inputMode = this.inputMode;\n        this.componentRef.instance.autoFocus = this.autoFocus;\n      }\n    }\n    if (changes.areMentionsEnabled) {\n      this.componentRef.instance.areMentionsEnabled = this.areMentionsEnabled;\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    if (changes.placeholder) {\n      this.componentRef.instance.placeholder = this.placeholder;\n    }\n    if (changes.inputMode) {\n      this.componentRef.instance.inputMode = this.inputMode;\n    }\n    if (changes.autoFocus) {\n      this.componentRef.instance.autoFocus = this.autoFocus;\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"]}
@@ -0,0 +1,52 @@
1
+ export const getGroupStyles = (message, previousMessage, nextMessage, options = {
2
+ noGroupByUser: false,
3
+ lastReadMessageId: undefined,
4
+ noGroupByReadState: false,
5
+ }) => {
6
+ if (options.noGroupByUser ||
7
+ (message.attachments && message.attachments.length !== 0))
8
+ return 'single';
9
+ const isTopMessage = !previousMessage ||
10
+ !isOnSameDay(previousMessage.created_at, message.created_at) ||
11
+ previousMessage.type === 'system' ||
12
+ (previousMessage.attachments &&
13
+ previousMessage.attachments?.length !== 0) ||
14
+ message.user?.id !== previousMessage.user?.id ||
15
+ previousMessage.type === 'error' ||
16
+ previousMessage.deleted_at ||
17
+ (previousMessage.id === options.lastReadMessageId &&
18
+ !options.noGroupByReadState) ||
19
+ previousMessage.message_text_updated_at ||
20
+ (message.reaction_counts &&
21
+ Object.keys(message.reaction_counts).length > 0);
22
+ const isBottomMessage = !nextMessage ||
23
+ !isOnSameDay(message.created_at, nextMessage.created_at) ||
24
+ nextMessage.type === 'system' ||
25
+ (nextMessage.attachments && nextMessage.attachments?.length !== 0) ||
26
+ message.user?.id !== nextMessage.user?.id ||
27
+ nextMessage.type === 'error' ||
28
+ nextMessage.deleted_at ||
29
+ (message.id === options.lastReadMessageId && !options.noGroupByReadState) ||
30
+ message.message_text_updated_at ||
31
+ (nextMessage.reaction_counts &&
32
+ Object.keys(nextMessage.reaction_counts).length > 0);
33
+ if (!isTopMessage && !isBottomMessage) {
34
+ if (message.deleted_at || message.type === 'error')
35
+ return 'single';
36
+ return 'middle';
37
+ }
38
+ if (isBottomMessage) {
39
+ if (isTopMessage || message.deleted_at || message.type === 'error')
40
+ return 'single';
41
+ return 'bottom';
42
+ }
43
+ if (isTopMessage)
44
+ return 'top';
45
+ return '';
46
+ };
47
+ const isOnSameDay = (date1, date2) => {
48
+ return (date1.getFullYear() === date2.getFullYear() &&
49
+ date1.getMonth() === date2.getMonth() &&
50
+ date1.getDate() === date2.getDate());
51
+ };
52
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JvdXAtc3R5bGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3RyZWFtLWNoYXQtYW5ndWxhci9zcmMvbGliL21lc3NhZ2UtbGlzdC9ncm91cC1zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBSUEsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLENBQzVCLE9BQXNCLEVBQ3RCLGVBQStCLEVBQy9CLFdBQTJCLEVBQzNCLFVBQTZCO0lBQzNCLGFBQWEsRUFBRSxLQUFLO0lBQ3BCLGlCQUFpQixFQUFFLFNBQVM7SUFDNUIsa0JBQWtCLEVBQUUsS0FBSztDQUMxQixFQUNXLEVBQUU7SUFDZCxJQUNFLE9BQU8sQ0FBQyxhQUFhO1FBQ3JCLENBQUMsT0FBTyxDQUFDLFdBQVcsSUFBSSxPQUFPLENBQUMsV0FBVyxDQUFDLE1BQU0sS0FBSyxDQUFDLENBQUM7UUFFekQsT0FBTyxRQUFRLENBQUM7SUFFbEIsTUFBTSxZQUFZLEdBQ2hCLENBQUMsZUFBZTtRQUNoQixDQUFDLFdBQVcsQ0FBQyxlQUFlLENBQUMsVUFBVSxFQUFFLE9BQU8sQ0FBQyxVQUFVLENBQUM7UUFDNUQsZUFBZSxDQUFDLElBQUksS0FBSyxRQUFRO1FBQ2pDLENBQUMsZUFBZSxDQUFDLFdBQVc7WUFDMUIsZUFBZSxDQUFDLFdBQVcsRUFBRSxNQUFNLEtBQUssQ0FBQyxDQUFDO1FBQzVDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsRUFBRSxLQUFLLGVBQWUsQ0FBQyxJQUFJLEVBQUUsRUFBRTtRQUM3QyxlQUFlLENBQUMsSUFBSSxLQUFLLE9BQU87UUFDaEMsZUFBZSxDQUFDLFVBQVU7UUFDMUIsQ0FBQyxlQUFlLENBQUMsRUFBRSxLQUFLLE9BQU8sQ0FBQyxpQkFBaUI7WUFDL0MsQ0FBQyxPQUFPLENBQUMsa0JBQWtCLENBQUM7UUFDOUIsZUFBZSxDQUFDLHVCQUF1QjtRQUN2QyxDQUFDLE9BQU8sQ0FBQyxlQUFlO1lBQ3RCLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLGVBQWUsQ0FBQyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQztJQUVyRCxNQUFNLGVBQWUsR0FDbkIsQ0FBQyxXQUFXO1FBQ1osQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLFVBQVUsRUFBRSxXQUFXLENBQUMsVUFBVSxDQUFDO1FBQ3hELFdBQVcsQ0FBQyxJQUFJLEtBQUssUUFBUTtRQUM3QixDQUFDLFdBQVcsQ0FBQyxXQUFXLElBQUksV0FBVyxDQUFDLFdBQVcsRUFBRSxNQUFNLEtBQUssQ0FBQyxDQUFDO1FBQ2xFLE9BQU8sQ0FBQyxJQUFJLEVBQUUsRUFBRSxLQUFLLFdBQVcsQ0FBQyxJQUFJLEVBQUUsRUFBRTtRQUN6QyxXQUFXLENBQUMsSUFBSSxLQUFLLE9BQU87UUFDNUIsV0FBVyxDQUFDLFVBQVU7UUFDdEIsQ0FBQyxPQUFPLENBQUMsRUFBRSxLQUFLLE9BQU8sQ0FBQyxpQkFBaUIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxrQkFBa0IsQ0FBQztRQUN6RSxPQUFPLENBQUMsdUJBQXVCO1FBQy9CLENBQUMsV0FBVyxDQUFDLGVBQWU7WUFDMUIsTUFBTSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsZUFBZSxDQUFDLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBRXpELElBQUksQ0FBQyxZQUFZLElBQUksQ0FBQyxlQUFlLEVBQUU7UUFDckMsSUFBSSxPQUFPLENBQUMsVUFBVSxJQUFJLE9BQU8sQ0FBQyxJQUFJLEtBQUssT0FBTztZQUFFLE9BQU8sUUFBUSxDQUFDO1FBQ3BFLE9BQU8sUUFBUSxDQUFDO0tBQ2pCO0lBRUQsSUFBSSxlQUFlLEVBQUU7UUFDbkIsSUFBSSxZQUFZLElBQUksT0FBTyxDQUFDLFVBQVUsSUFBSSxPQUFPLENBQUMsSUFBSSxLQUFLLE9BQU87WUFDaEUsT0FBTyxRQUFRLENBQUM7UUFDbEIsT0FBTyxRQUFRLENBQUM7S0FDakI7SUFFRCxJQUFJLFlBQVk7UUFBRSxPQUFPLEtBQUssQ0FBQztJQUUvQixPQUFPLEVBQUUsQ0FBQztBQUNaLENBQUMsQ0FBQztBQUVGLE1BQU0sV0FBVyxHQUFHLENBQUMsS0FBVyxFQUFFLEtBQVcsRUFBRSxFQUFFO0lBQy9DLE9BQU8sQ0FDTCxLQUFLLENBQUMsV0FBVyxFQUFFLEtBQUssS0FBSyxDQUFDLFdBQVcsRUFBRTtRQUMzQyxLQUFLLENBQUMsUUFBUSxFQUFFLEtBQUssS0FBSyxDQUFDLFFBQVEsRUFBRTtRQUNyQyxLQUFLLENBQUMsT0FBTyxFQUFFLEtBQUssS0FBSyxDQUFDLE9BQU8sRUFBRSxDQUNwQyxDQUFDO0FBQ0osQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgR3JvdXBTdHlsZU9wdGlvbnMsIFN0cmVhbU1lc3NhZ2UgfSBmcm9tICcuLi90eXBlcyc7XG5cbmV4cG9ydCB0eXBlIEdyb3VwU3R5bGUgPSAnJyB8ICdtaWRkbGUnIHwgJ3RvcCcgfCAnYm90dG9tJyB8ICdzaW5nbGUnO1xuXG5leHBvcnQgY29uc3QgZ2V0R3JvdXBTdHlsZXMgPSAoXG4gIG1lc3NhZ2U6IFN0cmVhbU1lc3NhZ2UsXG4gIHByZXZpb3VzTWVzc2FnZT86IFN0cmVhbU1lc3NhZ2UsXG4gIG5leHRNZXNzYWdlPzogU3RyZWFtTWVzc2FnZSxcbiAgb3B0aW9uczogR3JvdXBTdHlsZU9wdGlvbnMgPSB7XG4gICAgbm9Hcm91cEJ5VXNlcjogZmFsc2UsXG4gICAgbGFzdFJlYWRNZXNzYWdlSWQ6IHVuZGVmaW5lZCxcbiAgICBub0dyb3VwQnlSZWFkU3RhdGU6IGZhbHNlLFxuICB9XG4pOiBHcm91cFN0eWxlID0+IHtcbiAgaWYgKFxuICAgIG9wdGlvbnMubm9Hcm91cEJ5VXNlciB8fFxuICAgIChtZXNzYWdlLmF0dGFjaG1lbnRzICYmIG1lc3NhZ2UuYXR0YWNobWVudHMubGVuZ3RoICE9PSAwKVxuICApXG4gICAgcmV0dXJuICdzaW5nbGUnO1xuXG4gIGNvbnN0IGlzVG9wTWVzc2FnZSA9XG4gICAgIXByZXZpb3VzTWVzc2FnZSB8fFxuICAgICFpc09uU2FtZURheShwcmV2aW91c01lc3NhZ2UuY3JlYXRlZF9hdCwgbWVzc2FnZS5jcmVhdGVkX2F0KSB8fFxuICAgIHByZXZpb3VzTWVzc2FnZS50eXBlID09PSAnc3lzdGVtJyB8fFxuICAgIChwcmV2aW91c01lc3NhZ2UuYXR0YWNobWVudHMgJiZcbiAgICAgIHByZXZpb3VzTWVzc2FnZS5hdHRhY2htZW50cz8ubGVuZ3RoICE9PSAwKSB8fFxuICAgIG1lc3NhZ2UudXNlcj8uaWQgIT09IHByZXZpb3VzTWVzc2FnZS51c2VyPy5pZCB8fFxuICAgIHByZXZpb3VzTWVzc2FnZS50eXBlID09PSAnZXJyb3InIHx8XG4gICAgcHJldmlvdXNNZXNzYWdlLmRlbGV0ZWRfYXQgfHxcbiAgICAocHJldmlvdXNNZXNzYWdlLmlkID09PSBvcHRpb25zLmxhc3RSZWFkTWVzc2FnZUlkICYmXG4gICAgICAhb3B0aW9ucy5ub0dyb3VwQnlSZWFkU3RhdGUpIHx8XG4gICAgcHJldmlvdXNNZXNzYWdlLm1lc3NhZ2VfdGV4dF91cGRhdGVkX2F0IHx8XG4gICAgKG1lc3NhZ2UucmVhY3Rpb25fY291bnRzICYmXG4gICAgICBPYmplY3Qua2V5cyhtZXNzYWdlLnJlYWN0aW9uX2NvdW50cykubGVuZ3RoID4gMCk7XG5cbiAgY29uc3QgaXNCb3R0b21NZXNzYWdlID1cbiAgICAhbmV4dE1lc3NhZ2UgfHxcbiAgICAhaXNPblNhbWVEYXkobWVzc2FnZS5jcmVhdGVkX2F0LCBuZXh0TWVzc2FnZS5jcmVhdGVkX2F0KSB8fFxuICAgIG5leHRNZXNzYWdlLnR5cGUgPT09ICdzeXN0ZW0nIHx8XG4gICAgKG5leHRNZXNzYWdlLmF0dGFjaG1lbnRzICYmIG5leHRNZXNzYWdlLmF0dGFjaG1lbnRzPy5sZW5ndGggIT09IDApIHx8XG4gICAgbWVzc2FnZS51c2VyPy5pZCAhPT0gbmV4dE1lc3NhZ2UudXNlcj8uaWQgfHxcbiAgICBuZXh0TWVzc2FnZS50eXBlID09PSAnZXJyb3InIHx8XG4gICAgbmV4dE1lc3NhZ2UuZGVsZXRlZF9hdCB8fFxuICAgIChtZXNzYWdlLmlkID09PSBvcHRpb25zLmxhc3RSZWFkTWVzc2FnZUlkICYmICFvcHRpb25zLm5vR3JvdXBCeVJlYWRTdGF0ZSkgfHxcbiAgICBtZXNzYWdlLm1lc3NhZ2VfdGV4dF91cGRhdGVkX2F0IHx8XG4gICAgKG5leHRNZXNzYWdlLnJlYWN0aW9uX2NvdW50cyAmJlxuICAgICAgT2JqZWN0LmtleXMobmV4dE1lc3NhZ2UucmVhY3Rpb25fY291bnRzKS5sZW5ndGggPiAwKTtcblxuICBpZiAoIWlzVG9wTWVzc2FnZSAmJiAhaXNCb3R0b21NZXNzYWdlKSB7XG4gICAgaWYgKG1lc3NhZ2UuZGVsZXRlZF9hdCB8fCBtZXNzYWdlLnR5cGUgPT09ICdlcnJvcicpIHJldHVybiAnc2luZ2xlJztcbiAgICByZXR1cm4gJ21pZGRsZSc7XG4gIH1cblxuICBpZiAoaXNCb3R0b21NZXNzYWdlKSB7XG4gICAgaWYgKGlzVG9wTWVzc2FnZSB8fCBtZXNzYWdlLmRlbGV0ZWRfYXQgfHwgbWVzc2FnZS50eXBlID09PSAnZXJyb3InKVxuICAgICAgcmV0dXJuICdzaW5nbGUnO1xuICAgIHJldHVybiAnYm90dG9tJztcbiAgfVxuXG4gIGlmIChpc1RvcE1lc3NhZ2UpIHJldHVybiAndG9wJztcblxuICByZXR1cm4gJyc7XG59O1xuXG5jb25zdCBpc09uU2FtZURheSA9IChkYXRlMTogRGF0ZSwgZGF0ZTI6IERhdGUpID0+IHtcbiAgcmV0dXJuIChcbiAgICBkYXRlMS5nZXRGdWxsWWVhcigpID09PSBkYXRlMi5nZXRGdWxsWWVhcigpICYmXG4gICAgZGF0ZTEuZ2V0TW9udGgoKSA9PT0gZGF0ZTIuZ2V0TW9udGgoKSAmJlxuICAgIGRhdGUxLmdldERhdGUoKSA9PT0gZGF0ZTIuZ2V0RGF0ZSgpXG4gICk7XG59O1xuIl19
@@ -13,9 +13,9 @@ export class ImageLoadService {
13
13
  this.imageLoad$ = new Subject();
14
14
  }
15
15
  }
16
- ImageLoadService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: ImageLoadService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
17
- ImageLoadService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: ImageLoadService, providedIn: 'root' });
18
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: ImageLoadService, decorators: [{
16
+ ImageLoadService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: ImageLoadService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
17
+ ImageLoadService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: ImageLoadService, providedIn: 'root' });
18
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: ImageLoadService, decorators: [{
19
19
  type: Injectable,
20
20
  args: [{
21
21
  providedIn: 'root',