stream-chat-angular 5.13.0 → 6.0.0-beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (165) hide show
  1. package/assets/i18n/en.d.ts +1 -0
  2. package/assets/version.d.ts +1 -1
  3. package/{esm2020 → esm2022}/assets/i18n/en.mjs +2 -1
  4. package/{esm2020 → esm2022}/assets/version.mjs +2 -2
  5. package/{esm2020 → esm2022}/lib/attachment-configuration.service.mjs +4 -4
  6. package/esm2022/lib/attachment-list/attachment-list.component.mjs +212 -0
  7. package/esm2022/lib/attachment-preview-list/attachment-preview-list.component.mjs +55 -0
  8. package/{esm2020 → esm2022}/lib/attachment.service.mjs +5 -5
  9. package/esm2022/lib/avatar/avatar.component.mjs +157 -0
  10. package/{esm2020 → esm2022}/lib/avatar-placeholder/avatar-placeholder.component.mjs +6 -6
  11. package/esm2022/lib/channel/channel.component.mjs +45 -0
  12. package/esm2022/lib/channel-header/channel-header.component.mjs +72 -0
  13. package/esm2022/lib/channel-list/channel-list.component.mjs +50 -0
  14. package/esm2022/lib/channel-preview/channel-preview.component.mjs +150 -0
  15. package/esm2022/lib/channel.service.mjs +1389 -0
  16. package/esm2022/lib/chat-client.service.mjs +227 -0
  17. package/{esm2020 → esm2022}/lib/custom-templates.service.mjs +5 -5
  18. package/{esm2020 → esm2022}/lib/date-parser.service.mjs +5 -5
  19. package/esm2022/lib/file-utils.mjs +35 -0
  20. package/{esm2020 → esm2022}/lib/get-channel-display-text.mjs +1 -1
  21. package/{esm2020 → esm2022}/lib/get-message-translation.mjs +1 -1
  22. package/{esm2020 → esm2022}/lib/icon/icon-placeholder/icon-placeholder.component.mjs +6 -6
  23. package/{esm2020 → esm2022}/lib/icon/icon.component.mjs +5 -5
  24. package/{esm2020 → esm2022}/lib/icon/icon.module.mjs +11 -11
  25. package/{esm2020 → esm2022}/lib/icon/loading-indicator/loading-indicator.component.mjs +5 -5
  26. package/{esm2020 → esm2022}/lib/icon/loading-indicator-placeholder/loading-indicator-placeholder.component.mjs +6 -6
  27. package/{esm2020 → esm2022}/lib/list-users.mjs +1 -1
  28. package/esm2022/lib/message/message.component.mjs +486 -0
  29. package/esm2022/lib/message-actions-box/message-actions-box.component.mjs +120 -0
  30. package/{esm2020 → esm2022}/lib/message-actions.service.mjs +5 -5
  31. package/esm2022/lib/message-bounce-prompt/message-bounce-prompt.component.mjs +71 -0
  32. package/{esm2020 → esm2022}/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.mjs +6 -6
  33. package/{esm2020 → esm2022}/lib/message-input/emoji-input.service.mjs +5 -5
  34. package/{esm2020 → esm2022}/lib/message-input/message-input-config.service.mjs +5 -5
  35. package/esm2022/lib/message-input/message-input.component.mjs +507 -0
  36. package/{esm2020 → esm2022}/lib/message-input/textarea/textarea.component.mjs +5 -5
  37. package/{esm2020 → esm2022}/lib/message-input/textarea.directive.mjs +5 -5
  38. package/{esm2020 → esm2022}/lib/message-input/voice-recorder.service.mjs +5 -5
  39. package/{esm2020 → esm2022}/lib/message-list/group-styles.mjs +1 -1
  40. package/esm2022/lib/message-list/message-list.component.mjs +715 -0
  41. package/{esm2020 → esm2022}/lib/message-preview.mjs +1 -1
  42. package/esm2022/lib/message-reactions/message-reactions.component.mjs +165 -0
  43. package/esm2022/lib/message-reactions-selector/message-reactions-selector.component.mjs +57 -0
  44. package/{esm2020 → esm2022}/lib/message-reactions.service.mjs +5 -5
  45. package/{esm2020 → esm2022}/lib/message-text/message-text.component.mjs +6 -6
  46. package/esm2022/lib/message.service.mjs +43 -0
  47. package/{esm2020 → esm2022}/lib/modal/modal.component.mjs +6 -6
  48. package/{esm2020 → esm2022}/lib/notification/notification.component.mjs +6 -6
  49. package/esm2022/lib/notification-list/notification-list.component.mjs +33 -0
  50. package/{esm2020 → esm2022}/lib/notification.service.mjs +5 -5
  51. package/esm2022/lib/paginated-list/paginated-list.component.mjs +94 -0
  52. package/{esm2020 → esm2022}/lib/parse-date.mjs +1 -1
  53. package/{esm2020 → esm2022}/lib/read-by.mjs +1 -1
  54. package/esm2022/lib/stream-autocomplete-textarea.module.mjs +33 -0
  55. package/{esm2020 → esm2022}/lib/stream-avatar.module.mjs +5 -5
  56. package/{esm2020 → esm2022}/lib/stream-chat.module.mjs +59 -59
  57. package/{esm2020 → esm2022}/lib/stream-i18n.service.mjs +5 -5
  58. package/esm2022/lib/stream-textarea.module.mjs +31 -0
  59. package/{esm2020 → esm2022}/lib/theme.service.mjs +5 -5
  60. package/{esm2020 → esm2022}/lib/thread/thread.component.mjs +6 -6
  61. package/{esm2020 → esm2022}/lib/transliteration.service.mjs +5 -5
  62. package/esm2022/lib/types.mjs +2 -0
  63. package/{esm2020 → esm2022}/lib/user-list/user-list.component.mjs +5 -5
  64. package/esm2022/lib/virtualized-list.service.mjs +273 -0
  65. package/{esm2020 → esm2022}/lib/virtualized-message-list.service.mjs +1 -1
  66. package/{esm2020 → esm2022}/lib/voice-recorder/amplitude-recorder.service.mjs +5 -5
  67. package/{esm2020 → esm2022}/lib/voice-recorder/audio-recorder.service.mjs +5 -5
  68. package/{esm2020 → esm2022}/lib/voice-recorder/media-recorder.mjs +1 -1
  69. package/esm2022/lib/voice-recorder/mp3-transcoder.mjs +61 -0
  70. package/esm2022/lib/voice-recorder/transcoder.service.mjs +121 -0
  71. package/esm2022/lib/voice-recorder/voice-recorder-wavebar/voice-recorder-wavebar.component.mjs +32 -0
  72. package/esm2022/lib/voice-recorder/voice-recorder.component.mjs +80 -0
  73. package/{esm2020 → esm2022}/lib/voice-recorder/voice-recorder.module.mjs +9 -9
  74. package/esm2022/lib/voice-recording/voice-recording-wavebar/voice-recording-wavebar.component.mjs +112 -0
  75. package/esm2022/lib/voice-recording/voice-recording.component.mjs +91 -0
  76. package/{esm2020 → esm2022}/lib/voice-recording/voice-recording.module.mjs +5 -5
  77. package/{esm2020 → esm2022}/lib/wave-form-sampler.mjs +1 -1
  78. package/esm2022/public-api.mjs +82 -0
  79. package/{fesm2020 → fesm2022}/stream-chat-angular.mjs +865 -1140
  80. package/fesm2022/stream-chat-angular.mjs.map +1 -0
  81. package/lib/attachment-list/attachment-list.component.d.ts +2 -5
  82. package/lib/attachment-preview-list/attachment-preview-list.component.d.ts +2 -2
  83. package/lib/attachment.service.d.ts +1 -1
  84. package/lib/avatar/avatar.component.d.ts +4 -4
  85. package/lib/avatar-placeholder/avatar-placeholder.component.d.ts +1 -1
  86. package/lib/channel-list/channel-list.component.d.ts +1 -0
  87. package/lib/channel-preview/channel-preview.component.d.ts +3 -4
  88. package/lib/channel.service.d.ts +40 -106
  89. package/lib/chat-client.service.d.ts +1 -4
  90. package/lib/custom-templates.service.d.ts +10 -10
  91. package/lib/icon/icon-placeholder/icon-placeholder.component.d.ts +1 -1
  92. package/lib/icon/icon.component.d.ts +2 -2
  93. package/lib/message/message.component.d.ts +2 -2
  94. package/lib/message-actions-box/message-actions-box.component.d.ts +2 -3
  95. package/lib/message-actions.service.d.ts +1 -1
  96. package/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.d.ts +2 -2
  97. package/lib/message-input/message-input.component.d.ts +2 -2
  98. package/lib/message-input/textarea/textarea.component.d.ts +1 -1
  99. package/lib/message-input/textarea.directive.d.ts +2 -2
  100. package/lib/message-list/group-styles.d.ts +1 -1
  101. package/lib/message-list/message-list.component.d.ts +2 -3
  102. package/lib/message-reactions/message-reactions.component.d.ts +2 -3
  103. package/lib/message-reactions-selector/message-reactions-selector.component.d.ts +1 -2
  104. package/lib/message-text/message-text.component.d.ts +2 -2
  105. package/lib/modal/modal.component.d.ts +1 -1
  106. package/lib/notification/notification.component.d.ts +1 -1
  107. package/lib/notification-list/notification-list.component.d.ts +0 -1
  108. package/lib/paginated-list/paginated-list.component.d.ts +5 -2
  109. package/lib/read-by.d.ts +1 -1
  110. package/lib/types.d.ts +98 -84
  111. package/lib/user-list/user-list.component.d.ts +1 -1
  112. package/lib/voice-recorder/amplitude-recorder.service.d.ts +2 -2
  113. package/lib/voice-recorder/media-recorder.d.ts +2 -2
  114. package/lib/voice-recorder/transcoder.service.d.ts +4 -4
  115. package/lib/voice-recorder/voice-recorder-wavebar/voice-recorder-wavebar.component.d.ts +0 -1
  116. package/lib/voice-recorder/voice-recorder.component.d.ts +2 -2
  117. package/lib/voice-recording/voice-recording-wavebar/voice-recording-wavebar.component.d.ts +3 -3
  118. package/lib/voice-recording/voice-recording.component.d.ts +1 -1
  119. package/package.json +15 -21
  120. package/public-api.d.ts +0 -1
  121. package/src/assets/i18n/en.ts +1 -0
  122. package/src/assets/version.ts +1 -1
  123. package/esm2020/lib/attachment-list/attachment-list.component.mjs +0 -224
  124. package/esm2020/lib/attachment-preview-list/attachment-preview-list.component.mjs +0 -55
  125. package/esm2020/lib/avatar/avatar.component.mjs +0 -160
  126. package/esm2020/lib/channel/channel.component.mjs +0 -45
  127. package/esm2020/lib/channel-header/channel-header.component.mjs +0 -72
  128. package/esm2020/lib/channel-list/channel-list.component.mjs +0 -47
  129. package/esm2020/lib/channel-preview/channel-preview.component.mjs +0 -155
  130. package/esm2020/lib/channel-query.mjs +0 -77
  131. package/esm2020/lib/channel.service.mjs +0 -1546
  132. package/esm2020/lib/chat-client.service.mjs +0 -238
  133. package/esm2020/lib/file-utils.mjs +0 -35
  134. package/esm2020/lib/message/message.component.mjs +0 -486
  135. package/esm2020/lib/message-actions-box/message-actions-box.component.mjs +0 -123
  136. package/esm2020/lib/message-bounce-prompt/message-bounce-prompt.component.mjs +0 -71
  137. package/esm2020/lib/message-input/message-input.component.mjs +0 -507
  138. package/esm2020/lib/message-list/message-list.component.mjs +0 -717
  139. package/esm2020/lib/message-reactions/message-reactions.component.mjs +0 -168
  140. package/esm2020/lib/message-reactions-selector/message-reactions-selector.component.mjs +0 -61
  141. package/esm2020/lib/message.service.mjs +0 -43
  142. package/esm2020/lib/notification-list/notification-list.component.mjs +0 -36
  143. package/esm2020/lib/paginated-list/paginated-list.component.mjs +0 -94
  144. package/esm2020/lib/stream-autocomplete-textarea.module.mjs +0 -33
  145. package/esm2020/lib/stream-textarea.module.mjs +0 -31
  146. package/esm2020/lib/types.mjs +0 -2
  147. package/esm2020/lib/virtualized-list.service.mjs +0 -271
  148. package/esm2020/lib/voice-recorder/mp3-transcoder.mjs +0 -61
  149. package/esm2020/lib/voice-recorder/transcoder.service.mjs +0 -121
  150. package/esm2020/lib/voice-recorder/voice-recorder-wavebar/voice-recorder-wavebar.component.mjs +0 -35
  151. package/esm2020/lib/voice-recorder/voice-recorder.component.mjs +0 -80
  152. package/esm2020/lib/voice-recording/voice-recording-wavebar/voice-recording-wavebar.component.mjs +0 -112
  153. package/esm2020/lib/voice-recording/voice-recording.component.mjs +0 -91
  154. package/esm2020/public-api.mjs +0 -83
  155. package/fesm2015/stream-chat-angular.mjs +0 -9152
  156. package/fesm2015/stream-chat-angular.mjs.map +0 -1
  157. package/fesm2020/stream-chat-angular.mjs.map +0 -1
  158. package/lib/channel-query.d.ts +0 -26
  159. /package/{esm2020 → esm2022}/lib/format-duration.mjs +0 -0
  160. /package/{esm2020 → esm2022}/lib/injection-tokens.mjs +0 -0
  161. /package/{esm2020 → esm2022}/lib/is-image-attachment.mjs +0 -0
  162. /package/{esm2020 → esm2022}/lib/is-on-separate-date.mjs +0 -0
  163. /package/{esm2020 → esm2022}/lib/is-safari.mjs +0 -0
  164. /package/{esm2020 → esm2022}/lib/message-input/textarea.interface.mjs +0 -0
  165. /package/{esm2020 → esm2022}/stream-chat-angular.mjs +0 -0
@@ -11,13 +11,13 @@ export class ThemeService {
11
11
  */
12
12
  this.theme$ = new BehaviorSubject('light');
13
13
  }
14
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0", ngImport: i0, type: ThemeService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
15
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.0.0", ngImport: i0, type: ThemeService, providedIn: 'root' }); }
14
16
  }
15
- ThemeService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: ThemeService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
16
- ThemeService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: ThemeService, providedIn: 'root' });
17
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: ThemeService, decorators: [{
17
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0", ngImport: i0, type: ThemeService, decorators: [{
18
18
  type: Injectable,
19
19
  args: [{
20
20
  providedIn: 'root',
21
21
  }]
22
- }], ctorParameters: function () { return []; } });
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhlbWUuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi90aGVtZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFFdkM7O0dBRUc7QUFJSCxNQUFNLE9BQU8sWUFBWTtJQU12QjtRQUxBOztXQUVHO1FBQ0gsV0FBTSxHQUFHLElBQUksZUFBZSxDQUFTLE9BQU8sQ0FBQyxDQUFDO0lBRS9CLENBQUM7O3lHQU5MLFlBQVk7NkdBQVosWUFBWSxjQUZYLE1BQU07MkZBRVAsWUFBWTtrQkFIeEIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QgfSBmcm9tICdyeGpzJztcblxuLyoqXG4gKiBUaGUgYFRoZW1lU2VydmljZWAgY2FuIGJlIHVzZWQgdG8gY2hhbmdlIHRoZSB0aGVtZSBvZiB0aGUgY2hhdCBVSSBhbmQgdG8gY3VzdG9taXplIHRoZSB0aGVtZS4gT3VyIFt0aGVtaW5nIGd1aWRlXSgvY2hhdC9kb2NzL3Nkay9hbmd1bGFyL3RoZW1pbmcvdGhlbWluZ3YyLykgZ2l2ZXMgYSBjb21wbGV0ZSBvdmVydmlldyBhYm91dCB0aGUgdG9waWMuXG4gKi9cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBUaGVtZVNlcnZpY2Uge1xuICAvKipcbiAgICogQSBTdWJqZWN0IHRoYXQgY2FuIGJlIHVzZWQgdG8gZ2V0IG9yIHNldCB0aGUgY3VycmVudGx5IGFjdGl2ZSB0aGVtZS4gQnkgZGVmYXVsdCBsaWdodCBhbmQgZGFyayB0aGVtZXMgYXJlIHN1cHBvcnRlZC5cbiAgICovXG4gIHRoZW1lJCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8c3RyaW5nPignbGlnaHQnKTtcblxuICBjb25zdHJ1Y3RvcigpIHt9XG59XG4iXX0=
22
+ }], ctorParameters: () => [] });
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhlbWUuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi90aGVtZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFFdkM7O0dBRUc7QUFJSCxNQUFNLE9BQU8sWUFBWTtJQU12QjtRQUxBOztXQUVHO1FBQ0gsV0FBTSxHQUFHLElBQUksZUFBZSxDQUFTLE9BQU8sQ0FBQyxDQUFDO0lBRS9CLENBQUM7OEdBTkwsWUFBWTtrSEFBWixZQUFZLGNBRlgsTUFBTTs7MkZBRVAsWUFBWTtrQkFIeEIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QgfSBmcm9tICdyeGpzJztcblxuLyoqXG4gKiBUaGUgYFRoZW1lU2VydmljZWAgY2FuIGJlIHVzZWQgdG8gY2hhbmdlIHRoZSB0aGVtZSBvZiB0aGUgY2hhdCBVSSBhbmQgdG8gY3VzdG9taXplIHRoZSB0aGVtZS4gT3VyIFt0aGVtaW5nIGd1aWRlXSgvY2hhdC9kb2NzL3Nkay9hbmd1bGFyL3RoZW1pbmcvdGhlbWluZ3YyLykgZ2l2ZXMgYSBjb21wbGV0ZSBvdmVydmlldyBhYm91dCB0aGUgdG9waWMuXG4gKi9cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBUaGVtZVNlcnZpY2Uge1xuICAvKipcbiAgICogQSBTdWJqZWN0IHRoYXQgY2FuIGJlIHVzZWQgdG8gZ2V0IG9yIHNldCB0aGUgY3VycmVudGx5IGFjdGl2ZSB0aGVtZS4gQnkgZGVmYXVsdCBsaWdodCBhbmQgZGFyayB0aGVtZXMgYXJlIHN1cHBvcnRlZC5cbiAgICovXG4gIHRoZW1lJCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8c3RyaW5nPignbGlnaHQnKTtcblxuICBjb25zdHJ1Y3RvcigpIHt9XG59XG4iXX0=
@@ -38,14 +38,14 @@ export class ThreadComponent {
38
38
  }
39
39
  return getChannelDisplayText(this.channel, this.chatClientService.chatClient.user);
40
40
  }
41
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0", ngImport: i0, type: ThreadComponent, deps: [{ token: i1.CustomTemplatesService }, { token: i2.ChannelService }, { token: i3.ChatClientService }], target: i0.ɵɵFactoryTarget.Component }); }
42
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.0", type: ThreadComponent, selector: "stream-thread", host: { properties: { "class": "this.class" } }, ngImport: i0, template: "<div class=\"str-chat__thread-container\">\n <ng-container\n *ngTemplateOutlet=\"\n (customTemplatesService.threadHeaderTemplate$ | async) ||\n defaultThreadHeader;\n context: getThreadHeaderContext()\n \"\n />\n <ng-content />\n</div>\n\n<ng-template\n #defaultThreadHeader\n let-parentMessage=\"parentMessage\"\n let-closeThreadHandler=\"closeThreadHandler\"\n>\n <div class=\"str-chat__thread-header\">\n <div class=\"str-chat__thread-header-details\">\n <div class=\"str-chat__thread-header-name\" translate>\n streamChat.Thread\n </div>\n <div\n class=\"str-chat__thread-header-channel-name\"\n data-testid=\"channel-name\"\n >\n {{ channelName }}\n </div>\n </div>\n <button\n class=\"str-chat__square-button str-chat__close-thread-button\"\n data-testid=\"close-button\"\n (click)=\"closeThreadHandler()\"\n >\n <stream-icon-placeholder icon=\"close\" />\n </button>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i5.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i6.IconPlaceholderComponent, selector: "stream-icon-placeholder", inputs: ["icon"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }] }); }
41
43
  }
42
- ThreadComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: ThreadComponent, deps: [{ token: i1.CustomTemplatesService }, { token: i2.ChannelService }, { token: i3.ChatClientService }], target: i0.ɵɵFactoryTarget.Component });
43
- ThreadComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: ThreadComponent, selector: "stream-thread", host: { properties: { "class": "this.class" } }, ngImport: i0, template: "<div class=\"str-chat__thread-container\">\n <ng-container\n *ngTemplateOutlet=\"\n (customTemplatesService.threadHeaderTemplate$ | async) ||\n defaultThreadHeader;\n context: getThreadHeaderContext()\n \"\n ></ng-container>\n <ng-content></ng-content>\n</div>\n\n<ng-template\n #defaultThreadHeader\n let-parentMessage=\"parentMessage\"\n let-closeThreadHandler=\"closeThreadHandler\"\n>\n <div class=\"str-chat__thread-header\">\n <div class=\"str-chat__thread-header-details\">\n <div class=\"str-chat__thread-header-name\" translate>\n streamChat.Thread\n </div>\n <div\n class=\"str-chat__thread-header-channel-name\"\n data-testid=\"channel-name\"\n >\n {{ channelName }}\n </div>\n </div>\n <button\n class=\"str-chat__square-button str-chat__close-thread-button\"\n data-testid=\"close-button\"\n (click)=\"closeThreadHandler()\"\n >\n <stream-icon-placeholder icon=\"close\"></stream-icon-placeholder>\n </button>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i5.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i6.IconPlaceholderComponent, selector: "stream-icon-placeholder", inputs: ["icon"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }] });
44
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: ThreadComponent, decorators: [{
44
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0", ngImport: i0, type: ThreadComponent, decorators: [{
45
45
  type: Component,
46
- args: [{ selector: 'stream-thread', template: "<div class=\"str-chat__thread-container\">\n <ng-container\n *ngTemplateOutlet=\"\n (customTemplatesService.threadHeaderTemplate$ | async) ||\n defaultThreadHeader;\n context: getThreadHeaderContext()\n \"\n ></ng-container>\n <ng-content></ng-content>\n</div>\n\n<ng-template\n #defaultThreadHeader\n let-parentMessage=\"parentMessage\"\n let-closeThreadHandler=\"closeThreadHandler\"\n>\n <div class=\"str-chat__thread-header\">\n <div class=\"str-chat__thread-header-details\">\n <div class=\"str-chat__thread-header-name\" translate>\n streamChat.Thread\n </div>\n <div\n class=\"str-chat__thread-header-channel-name\"\n data-testid=\"channel-name\"\n >\n {{ channelName }}\n </div>\n </div>\n <button\n class=\"str-chat__square-button str-chat__close-thread-button\"\n data-testid=\"close-button\"\n (click)=\"closeThreadHandler()\"\n >\n <stream-icon-placeholder icon=\"close\"></stream-icon-placeholder>\n </button>\n </div>\n</ng-template>\n" }]
47
- }], ctorParameters: function () { return [{ type: i1.CustomTemplatesService }, { type: i2.ChannelService }, { type: i3.ChatClientService }]; }, propDecorators: { class: [{
46
+ args: [{ selector: 'stream-thread', template: "<div class=\"str-chat__thread-container\">\n <ng-container\n *ngTemplateOutlet=\"\n (customTemplatesService.threadHeaderTemplate$ | async) ||\n defaultThreadHeader;\n context: getThreadHeaderContext()\n \"\n />\n <ng-content />\n</div>\n\n<ng-template\n #defaultThreadHeader\n let-parentMessage=\"parentMessage\"\n let-closeThreadHandler=\"closeThreadHandler\"\n>\n <div class=\"str-chat__thread-header\">\n <div class=\"str-chat__thread-header-details\">\n <div class=\"str-chat__thread-header-name\" translate>\n streamChat.Thread\n </div>\n <div\n class=\"str-chat__thread-header-channel-name\"\n data-testid=\"channel-name\"\n >\n {{ channelName }}\n </div>\n </div>\n <button\n class=\"str-chat__square-button str-chat__close-thread-button\"\n data-testid=\"close-button\"\n (click)=\"closeThreadHandler()\"\n >\n <stream-icon-placeholder icon=\"close\" />\n </button>\n </div>\n</ng-template>\n" }]
47
+ }], ctorParameters: () => [{ type: i1.CustomTemplatesService }, { type: i2.ChannelService }, { type: i3.ChatClientService }], propDecorators: { class: [{
48
48
  type: HostBinding,
49
49
  args: ['class']
50
50
  }] } });
51
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhyZWFkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi90aHJlYWQvdGhyZWFkLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi90aHJlYWQvdGhyZWFkLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFhLE1BQU0sZUFBZSxDQUFDO0FBTWxFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDOzs7Ozs7OztBQU9wRTs7R0FFRztBQU1ILE1BQU0sT0FBTyxlQUFlO0lBTTFCLFlBQ1Msc0JBQThDLEVBQzdDLGNBQThCLEVBQzlCLGlCQUFvQztRQUZyQywyQkFBc0IsR0FBdEIsc0JBQXNCLENBQXdCO1FBQzdDLG1CQUFjLEdBQWQsY0FBYyxDQUFnQjtRQUM5QixzQkFBaUIsR0FBakIsaUJBQWlCLENBQW1CO1FBUmhCLFVBQUssR0FBRyxrQkFBa0IsQ0FBQztRQUdqRCxrQkFBYSxHQUFtQixFQUFFLENBQUM7UUFPekMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQ3JCLElBQUksQ0FBQyxjQUFjLENBQUMsb0JBQW9CLENBQUMsU0FBUyxDQUNoRCxDQUFDLGFBQWEsRUFBRSxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsYUFBYSxHQUFHLGFBQWEsQ0FBQyxDQUN4RCxDQUNGLENBQUM7UUFDRixJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FDckIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxjQUFjLENBQUMsU0FBUyxDQUMxQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQyxDQUN0QyxDQUNGLENBQUM7SUFDSixDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztJQUNyRCxDQUFDO0lBRUQsc0JBQXNCO1FBQ3BCLE9BQU87WUFDTCxhQUFhLEVBQUUsSUFBSSxDQUFDLGFBQWE7WUFDakMsa0JBQWtCLEVBQUUsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRTtTQUM3QyxDQUFDO0lBQ0osQ0FBQztJQUVELFdBQVc7UUFDVCxLQUFLLElBQUksQ0FBQyxjQUFjLENBQUMsd0JBQXdCLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDL0QsQ0FBQztJQUVELElBQUksV0FBVztRQUNiLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLFVBQVUsQ0FBQyxJQUFJLEVBQUU7WUFDNUQsT0FBTyxFQUFFLENBQUM7U0FDWDtRQUNELE9BQU8scUJBQXFCLENBQzFCLElBQUksQ0FBQyxPQUFPLEVBQ1osSUFBSSxDQUFDLGlCQUFpQixDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQ3ZDLENBQUM7SUFDSixDQUFDOzs0R0E5Q1UsZUFBZTtnR0FBZixlQUFlLHNHQ3JCNUIsOGlDQXFDQTsyRkRoQmEsZUFBZTtrQkFMM0IsU0FBUzsrQkFDRSxlQUFlOzBLQUtLLEtBQUs7c0JBQWxDLFdBQVc7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU3Vic2NyaXB0aW9uIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBDaGFubmVsIH0gZnJvbSAnc3RyZWFtLWNoYXQnO1xuaW1wb3J0IHsgQ2hhdENsaWVudFNlcnZpY2UgfSBmcm9tICcuLi9jaGF0LWNsaWVudC5zZXJ2aWNlJztcbmltcG9ydCB7IENoYW5uZWxTZXJ2aWNlIH0gZnJvbSAnLi4vY2hhbm5lbC5zZXJ2aWNlJztcbmltcG9ydCB7IEN1c3RvbVRlbXBsYXRlc1NlcnZpY2UgfSBmcm9tICcuLi9jdXN0b20tdGVtcGxhdGVzLnNlcnZpY2UnO1xuaW1wb3J0IHsgZ2V0Q2hhbm5lbERpc3BsYXlUZXh0IH0gZnJvbSAnLi4vZ2V0LWNoYW5uZWwtZGlzcGxheS10ZXh0JztcbmltcG9ydCB7XG4gIERlZmF1bHRTdHJlYW1DaGF0R2VuZXJpY3MsXG4gIFN0cmVhbU1lc3NhZ2UsXG4gIFRocmVhZEhlYWRlckNvbnRleHQsXG59IGZyb20gJy4uL3R5cGVzJztcblxuLyoqXG4gKiBUaGUgYFRocmVhZGAgY29tcG9uZW50IHJlcHJlc2VudHMgYSBbbWVzc2FnZSB0aHJlYWRdKC9jaGF0L2RvY3MvamF2YXNjcmlwdC90aHJlYWRzLyksIGl0IGlzIGEgY29udGFpbmVyIGNvbXBvbmVudCB0aGF0IGRpc3BsYXlzIGEgdGhyZWFkIHdpdGggYSBoZWFkZXIsIFtgTWVzc2FnZUxpc3RgXSgvY2hhdC9kb2NzL3Nkay9hbmd1bGFyL2NvbXBvbmVudHMvTWVzc2FnZUxpc3RDb21wb25lbnQpIGFuZCBbYE1lc3NhZ2VJbnB1dGBdKC9jaGF0L2RvY3Mvc2RrL2FuZ3VsYXIvY29tcG9uZW50cy9NZXNzYWdlSW5wdXRDb21wb25lbnQvKSBjb21wb25lbnRzLlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzdHJlYW0tdGhyZWFkJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3RocmVhZC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlczogW10sXG59KVxuZXhwb3J0IGNsYXNzIFRocmVhZENvbXBvbmVudCBpbXBsZW1lbnRzIE9uRGVzdHJveSB7XG4gIEBIb3N0QmluZGluZygnY2xhc3MnKSBwcml2YXRlIGNsYXNzID0gJ3N0ci1jaGF0X190aHJlYWQnO1xuICBwYXJlbnRNZXNzYWdlOiBTdHJlYW1NZXNzYWdlIHwgdW5kZWZpbmVkO1xuICBjaGFubmVsOiBDaGFubmVsPERlZmF1bHRTdHJlYW1DaGF0R2VuZXJpY3M+IHwgdW5kZWZpbmVkO1xuICBwcml2YXRlIHN1YnNjcmlwdGlvbnM6IFN1YnNjcmlwdGlvbltdID0gW107XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHVibGljIGN1c3RvbVRlbXBsYXRlc1NlcnZpY2U6IEN1c3RvbVRlbXBsYXRlc1NlcnZpY2UsXG4gICAgcHJpdmF0ZSBjaGFubmVsU2VydmljZTogQ2hhbm5lbFNlcnZpY2UsXG4gICAgcHJpdmF0ZSBjaGF0Q2xpZW50U2VydmljZTogQ2hhdENsaWVudFNlcnZpY2VcbiAgKSB7XG4gICAgdGhpcy5zdWJzY3JpcHRpb25zLnB1c2goXG4gICAgICB0aGlzLmNoYW5uZWxTZXJ2aWNlLmFjdGl2ZVBhcmVudE1lc3NhZ2UkLnN1YnNjcmliZShcbiAgICAgICAgKHBhcmVudE1lc3NhZ2UpID0+ICh0aGlzLnBhcmVudE1lc3NhZ2UgPSBwYXJlbnRNZXNzYWdlKVxuICAgICAgKVxuICAgICk7XG4gICAgdGhpcy5zdWJzY3JpcHRpb25zLnB1c2goXG4gICAgICB0aGlzLmNoYW5uZWxTZXJ2aWNlLmFjdGl2ZUNoYW5uZWwkLnN1YnNjcmliZShcbiAgICAgICAgKGNoYW5uZWwpID0+ICh0aGlzLmNoYW5uZWwgPSBjaGFubmVsKVxuICAgICAgKVxuICAgICk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLnN1YnNjcmlwdGlvbnMuZm9yRWFjaCgocykgPT4gcy51bnN1YnNjcmliZSgpKTtcbiAgfVxuXG4gIGdldFRocmVhZEhlYWRlckNvbnRleHQoKTogVGhyZWFkSGVhZGVyQ29udGV4dCB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHBhcmVudE1lc3NhZ2U6IHRoaXMucGFyZW50TWVzc2FnZSxcbiAgICAgIGNsb3NlVGhyZWFkSGFuZGxlcjogKCkgPT4gdGhpcy5jbG9zZVRocmVhZCgpLFxuICAgIH07XG4gIH1cblxuICBjbG9zZVRocmVhZCgpIHtcbiAgICB2b2lkIHRoaXMuY2hhbm5lbFNlcnZpY2Uuc2V0QXNBY3RpdmVQYXJlbnRNZXNzYWdlKHVuZGVmaW5lZCk7XG4gIH1cblxuICBnZXQgY2hhbm5lbE5hbWUoKSB7XG4gICAgaWYgKCF0aGlzLmNoYW5uZWwgfHwgIXRoaXMuY2hhdENsaWVudFNlcnZpY2UuY2hhdENsaWVudC51c2VyKSB7XG4gICAgICByZXR1cm4gJyc7XG4gICAgfVxuICAgIHJldHVybiBnZXRDaGFubmVsRGlzcGxheVRleHQoXG4gICAgICB0aGlzLmNoYW5uZWwsXG4gICAgICB0aGlzLmNoYXRDbGllbnRTZXJ2aWNlLmNoYXRDbGllbnQudXNlclxuICAgICk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJzdHItY2hhdF9fdGhyZWFkLWNvbnRhaW5lclwiPlxuICA8bmctY29udGFpbmVyXG4gICAgKm5nVGVtcGxhdGVPdXRsZXQ9XCJcbiAgICAgIChjdXN0b21UZW1wbGF0ZXNTZXJ2aWNlLnRocmVhZEhlYWRlclRlbXBsYXRlJCB8IGFzeW5jKSB8fFxuICAgICAgICBkZWZhdWx0VGhyZWFkSGVhZGVyO1xuICAgICAgY29udGV4dDogZ2V0VGhyZWFkSGVhZGVyQ29udGV4dCgpXG4gICAgXCJcbiAgPjwvbmctY29udGFpbmVyPlxuICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG48L2Rpdj5cblxuPG5nLXRlbXBsYXRlXG4gICNkZWZhdWx0VGhyZWFkSGVhZGVyXG4gIGxldC1wYXJlbnRNZXNzYWdlPVwicGFyZW50TWVzc2FnZVwiXG4gIGxldC1jbG9zZVRocmVhZEhhbmRsZXI9XCJjbG9zZVRocmVhZEhhbmRsZXJcIlxuPlxuICA8ZGl2IGNsYXNzPVwic3RyLWNoYXRfX3RocmVhZC1oZWFkZXJcIj5cbiAgICA8ZGl2IGNsYXNzPVwic3RyLWNoYXRfX3RocmVhZC1oZWFkZXItZGV0YWlsc1wiPlxuICAgICAgPGRpdiBjbGFzcz1cInN0ci1jaGF0X190aHJlYWQtaGVhZGVyLW5hbWVcIiB0cmFuc2xhdGU+XG4gICAgICAgIHN0cmVhbUNoYXQuVGhyZWFkXG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXZcbiAgICAgICAgY2xhc3M9XCJzdHItY2hhdF9fdGhyZWFkLWhlYWRlci1jaGFubmVsLW5hbWVcIlxuICAgICAgICBkYXRhLXRlc3RpZD1cImNoYW5uZWwtbmFtZVwiXG4gICAgICA+XG4gICAgICAgIHt7IGNoYW5uZWxOYW1lIH19XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgICA8YnV0dG9uXG4gICAgICBjbGFzcz1cInN0ci1jaGF0X19zcXVhcmUtYnV0dG9uIHN0ci1jaGF0X19jbG9zZS10aHJlYWQtYnV0dG9uXCJcbiAgICAgIGRhdGEtdGVzdGlkPVwiY2xvc2UtYnV0dG9uXCJcbiAgICAgIChjbGljayk9XCJjbG9zZVRocmVhZEhhbmRsZXIoKVwiXG4gICAgPlxuICAgICAgPHN0cmVhbS1pY29uLXBsYWNlaG9sZGVyIGljb249XCJjbG9zZVwiPjwvc3RyZWFtLWljb24tcGxhY2Vob2xkZXI+XG4gICAgPC9idXR0b24+XG4gIDwvZGl2PlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhyZWFkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi90aHJlYWQvdGhyZWFkLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi90aHJlYWQvdGhyZWFkLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFhLE1BQU0sZUFBZSxDQUFDO0FBTWxFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDOzs7Ozs7OztBQU9wRTs7R0FFRztBQU1ILE1BQU0sT0FBTyxlQUFlO0lBTTFCLFlBQ1Msc0JBQThDLEVBQzdDLGNBQThCLEVBQzlCLGlCQUFvQztRQUZyQywyQkFBc0IsR0FBdEIsc0JBQXNCLENBQXdCO1FBQzdDLG1CQUFjLEdBQWQsY0FBYyxDQUFnQjtRQUM5QixzQkFBaUIsR0FBakIsaUJBQWlCLENBQW1CO1FBUmhCLFVBQUssR0FBRyxrQkFBa0IsQ0FBQztRQUdqRCxrQkFBYSxHQUFtQixFQUFFLENBQUM7UUFPekMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQ3JCLElBQUksQ0FBQyxjQUFjLENBQUMsb0JBQW9CLENBQUMsU0FBUyxDQUNoRCxDQUFDLGFBQWEsRUFBRSxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsYUFBYSxHQUFHLGFBQWEsQ0FBQyxDQUN4RCxDQUNGLENBQUM7UUFDRixJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FDckIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxjQUFjLENBQUMsU0FBUyxDQUMxQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQyxDQUN0QyxDQUNGLENBQUM7SUFDSixDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztJQUNyRCxDQUFDO0lBRUQsc0JBQXNCO1FBQ3BCLE9BQU87WUFDTCxhQUFhLEVBQUUsSUFBSSxDQUFDLGFBQWE7WUFDakMsa0JBQWtCLEVBQUUsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRTtTQUM3QyxDQUFDO0lBQ0osQ0FBQztJQUVELFdBQVc7UUFDVCxLQUFLLElBQUksQ0FBQyxjQUFjLENBQUMsd0JBQXdCLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDL0QsQ0FBQztJQUVELElBQUksV0FBVztRQUNiLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLFVBQVUsQ0FBQyxJQUFJLEVBQUU7WUFDNUQsT0FBTyxFQUFFLENBQUM7U0FDWDtRQUNELE9BQU8scUJBQXFCLENBQzFCLElBQUksQ0FBQyxPQUFPLEVBQ1osSUFBSSxDQUFDLGlCQUFpQixDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQ3ZDLENBQUM7SUFDSixDQUFDOzhHQTlDVSxlQUFlO2tHQUFmLGVBQWUsc0dDckI1Qiw2L0JBcUNBOzsyRkRoQmEsZUFBZTtrQkFMM0IsU0FBUzsrQkFDRSxlQUFlO3dKQUtLLEtBQUs7c0JBQWxDLFdBQVc7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU3Vic2NyaXB0aW9uIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBDaGFubmVsIH0gZnJvbSAnc3RyZWFtLWNoYXQnO1xuaW1wb3J0IHsgQ2hhdENsaWVudFNlcnZpY2UgfSBmcm9tICcuLi9jaGF0LWNsaWVudC5zZXJ2aWNlJztcbmltcG9ydCB7IENoYW5uZWxTZXJ2aWNlIH0gZnJvbSAnLi4vY2hhbm5lbC5zZXJ2aWNlJztcbmltcG9ydCB7IEN1c3RvbVRlbXBsYXRlc1NlcnZpY2UgfSBmcm9tICcuLi9jdXN0b20tdGVtcGxhdGVzLnNlcnZpY2UnO1xuaW1wb3J0IHsgZ2V0Q2hhbm5lbERpc3BsYXlUZXh0IH0gZnJvbSAnLi4vZ2V0LWNoYW5uZWwtZGlzcGxheS10ZXh0JztcbmltcG9ydCB7XG4gIERlZmF1bHRTdHJlYW1DaGF0R2VuZXJpY3MsXG4gIFN0cmVhbU1lc3NhZ2UsXG4gIFRocmVhZEhlYWRlckNvbnRleHQsXG59IGZyb20gJy4uL3R5cGVzJztcblxuLyoqXG4gKiBUaGUgYFRocmVhZGAgY29tcG9uZW50IHJlcHJlc2VudHMgYSBbbWVzc2FnZSB0aHJlYWRdKC9jaGF0L2RvY3MvamF2YXNjcmlwdC90aHJlYWRzLyksIGl0IGlzIGEgY29udGFpbmVyIGNvbXBvbmVudCB0aGF0IGRpc3BsYXlzIGEgdGhyZWFkIHdpdGggYSBoZWFkZXIsIFtgTWVzc2FnZUxpc3RgXSgvY2hhdC9kb2NzL3Nkay9hbmd1bGFyL2NvbXBvbmVudHMvTWVzc2FnZUxpc3RDb21wb25lbnQpIGFuZCBbYE1lc3NhZ2VJbnB1dGBdKC9jaGF0L2RvY3Mvc2RrL2FuZ3VsYXIvY29tcG9uZW50cy9NZXNzYWdlSW5wdXRDb21wb25lbnQvKSBjb21wb25lbnRzLlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzdHJlYW0tdGhyZWFkJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3RocmVhZC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlczogW10sXG59KVxuZXhwb3J0IGNsYXNzIFRocmVhZENvbXBvbmVudCBpbXBsZW1lbnRzIE9uRGVzdHJveSB7XG4gIEBIb3N0QmluZGluZygnY2xhc3MnKSBwcml2YXRlIGNsYXNzID0gJ3N0ci1jaGF0X190aHJlYWQnO1xuICBwYXJlbnRNZXNzYWdlOiBTdHJlYW1NZXNzYWdlIHwgdW5kZWZpbmVkO1xuICBjaGFubmVsOiBDaGFubmVsPERlZmF1bHRTdHJlYW1DaGF0R2VuZXJpY3M+IHwgdW5kZWZpbmVkO1xuICBwcml2YXRlIHN1YnNjcmlwdGlvbnM6IFN1YnNjcmlwdGlvbltdID0gW107XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHVibGljIGN1c3RvbVRlbXBsYXRlc1NlcnZpY2U6IEN1c3RvbVRlbXBsYXRlc1NlcnZpY2UsXG4gICAgcHJpdmF0ZSBjaGFubmVsU2VydmljZTogQ2hhbm5lbFNlcnZpY2UsXG4gICAgcHJpdmF0ZSBjaGF0Q2xpZW50U2VydmljZTogQ2hhdENsaWVudFNlcnZpY2UsXG4gICkge1xuICAgIHRoaXMuc3Vic2NyaXB0aW9ucy5wdXNoKFxuICAgICAgdGhpcy5jaGFubmVsU2VydmljZS5hY3RpdmVQYXJlbnRNZXNzYWdlJC5zdWJzY3JpYmUoXG4gICAgICAgIChwYXJlbnRNZXNzYWdlKSA9PiAodGhpcy5wYXJlbnRNZXNzYWdlID0gcGFyZW50TWVzc2FnZSksXG4gICAgICApLFxuICAgICk7XG4gICAgdGhpcy5zdWJzY3JpcHRpb25zLnB1c2goXG4gICAgICB0aGlzLmNoYW5uZWxTZXJ2aWNlLmFjdGl2ZUNoYW5uZWwkLnN1YnNjcmliZShcbiAgICAgICAgKGNoYW5uZWwpID0+ICh0aGlzLmNoYW5uZWwgPSBjaGFubmVsKSxcbiAgICAgICksXG4gICAgKTtcbiAgfVxuXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgIHRoaXMuc3Vic2NyaXB0aW9ucy5mb3JFYWNoKChzKSA9PiBzLnVuc3Vic2NyaWJlKCkpO1xuICB9XG5cbiAgZ2V0VGhyZWFkSGVhZGVyQ29udGV4dCgpOiBUaHJlYWRIZWFkZXJDb250ZXh0IHtcbiAgICByZXR1cm4ge1xuICAgICAgcGFyZW50TWVzc2FnZTogdGhpcy5wYXJlbnRNZXNzYWdlLFxuICAgICAgY2xvc2VUaHJlYWRIYW5kbGVyOiAoKSA9PiB0aGlzLmNsb3NlVGhyZWFkKCksXG4gICAgfTtcbiAgfVxuXG4gIGNsb3NlVGhyZWFkKCkge1xuICAgIHZvaWQgdGhpcy5jaGFubmVsU2VydmljZS5zZXRBc0FjdGl2ZVBhcmVudE1lc3NhZ2UodW5kZWZpbmVkKTtcbiAgfVxuXG4gIGdldCBjaGFubmVsTmFtZSgpIHtcbiAgICBpZiAoIXRoaXMuY2hhbm5lbCB8fCAhdGhpcy5jaGF0Q2xpZW50U2VydmljZS5jaGF0Q2xpZW50LnVzZXIpIHtcbiAgICAgIHJldHVybiAnJztcbiAgICB9XG4gICAgcmV0dXJuIGdldENoYW5uZWxEaXNwbGF5VGV4dChcbiAgICAgIHRoaXMuY2hhbm5lbCxcbiAgICAgIHRoaXMuY2hhdENsaWVudFNlcnZpY2UuY2hhdENsaWVudC51c2VyLFxuICAgICk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJzdHItY2hhdF9fdGhyZWFkLWNvbnRhaW5lclwiPlxuICA8bmctY29udGFpbmVyXG4gICAgKm5nVGVtcGxhdGVPdXRsZXQ9XCJcbiAgICAgIChjdXN0b21UZW1wbGF0ZXNTZXJ2aWNlLnRocmVhZEhlYWRlclRlbXBsYXRlJCB8IGFzeW5jKSB8fFxuICAgICAgICBkZWZhdWx0VGhyZWFkSGVhZGVyO1xuICAgICAgY29udGV4dDogZ2V0VGhyZWFkSGVhZGVyQ29udGV4dCgpXG4gICAgXCJcbiAgLz5cbiAgPG5nLWNvbnRlbnQgLz5cbjwvZGl2PlxuXG48bmctdGVtcGxhdGVcbiAgI2RlZmF1bHRUaHJlYWRIZWFkZXJcbiAgbGV0LXBhcmVudE1lc3NhZ2U9XCJwYXJlbnRNZXNzYWdlXCJcbiAgbGV0LWNsb3NlVGhyZWFkSGFuZGxlcj1cImNsb3NlVGhyZWFkSGFuZGxlclwiXG4+XG4gIDxkaXYgY2xhc3M9XCJzdHItY2hhdF9fdGhyZWFkLWhlYWRlclwiPlxuICAgIDxkaXYgY2xhc3M9XCJzdHItY2hhdF9fdGhyZWFkLWhlYWRlci1kZXRhaWxzXCI+XG4gICAgICA8ZGl2IGNsYXNzPVwic3RyLWNoYXRfX3RocmVhZC1oZWFkZXItbmFtZVwiIHRyYW5zbGF0ZT5cbiAgICAgICAgc3RyZWFtQ2hhdC5UaHJlYWRcbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdlxuICAgICAgICBjbGFzcz1cInN0ci1jaGF0X190aHJlYWQtaGVhZGVyLWNoYW5uZWwtbmFtZVwiXG4gICAgICAgIGRhdGEtdGVzdGlkPVwiY2hhbm5lbC1uYW1lXCJcbiAgICAgID5cbiAgICAgICAge3sgY2hhbm5lbE5hbWUgfX1cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICAgIDxidXR0b25cbiAgICAgIGNsYXNzPVwic3RyLWNoYXRfX3NxdWFyZS1idXR0b24gc3RyLWNoYXRfX2Nsb3NlLXRocmVhZC1idXR0b25cIlxuICAgICAgZGF0YS10ZXN0aWQ9XCJjbG9zZS1idXR0b25cIlxuICAgICAgKGNsaWNrKT1cImNsb3NlVGhyZWFkSGFuZGxlcigpXCJcbiAgICA+XG4gICAgICA8c3RyZWFtLWljb24tcGxhY2Vob2xkZXIgaWNvbj1cImNsb3NlXCIgLz5cbiAgICA8L2J1dHRvbj5cbiAgPC9kaXY+XG48L25nLXRlbXBsYXRlPlxuIl19
@@ -14,11 +14,11 @@ export class TransliterationService {
14
14
  transliterate(s) {
15
15
  return transliterate(s);
16
16
  }
17
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0", ngImport: i0, type: TransliterationService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
18
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.0.0", ngImport: i0, type: TransliterationService, providedIn: 'root' }); }
17
19
  }
18
- TransliterationService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: TransliterationService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
19
- TransliterationService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: TransliterationService, providedIn: 'root' });
20
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: TransliterationService, decorators: [{
20
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0", ngImport: i0, type: TransliterationService, decorators: [{
21
21
  type: Injectable,
22
22
  args: [{ providedIn: 'root' }]
23
- }], ctorParameters: function () { return []; } });
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsaXRlcmF0aW9uLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9zdHJlYW0tY2hhdC1hbmd1bGFyL3NyYy9saWIvdHJhbnNsaXRlcmF0aW9uLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLGFBQWEsTUFBTSwwQkFBMEIsQ0FBQzs7QUFFckQ7O0dBRUc7QUFFSCxNQUFNLE9BQU8sc0JBQXNCO0lBQ2pDLGdCQUFlLENBQUM7SUFFaEI7Ozs7T0FJRztJQUNILGFBQWEsQ0FBQyxDQUFTO1FBQ3JCLE9BQU8sYUFBYSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQzFCLENBQUM7O21IQVZVLHNCQUFzQjt1SEFBdEIsc0JBQXNCLGNBRFQsTUFBTTsyRkFDbkIsc0JBQXNCO2tCQURsQyxVQUFVO21CQUFDLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB0cmFuc2xpdGVyYXRlIGZyb20gJ0BzdHJlYW0taW8vdHJhbnNsaXRlcmF0ZSc7XG5cbi8qKlxuICogVGhlIGBUcmFuc2xpdGVyYXRpb25TZXJ2aWNlYCB3cmFwcyB0aGUgW0BzaW5kcmVzb3JodXMvdHJhbnNsaXRlcmF0ZV0oaHR0cHM6Ly93d3cubnBtanMuY29tL3BhY2thZ2UvQHNpbmRyZXNvcmh1cy90cmFuc2xpdGVyYXRlKSBsaWJyYXJ5XG4gKi9cbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0pXG5leHBvcnQgY2xhc3MgVHJhbnNsaXRlcmF0aW9uU2VydmljZSB7XG4gIGNvbnN0cnVjdG9yKCkge31cblxuICAvKipcbiAgICpcbiAgICogQHBhcmFtIHMgdGhlIHN0cmluZyB0byBiZSB0cmFuc2xpdGVyYXRlZFxuICAgKiBAcmV0dXJucyB0aGUgcmVzdWx0IG9mIHRoZSB0cmFuc2xpdGVyYXRpb25cbiAgICovXG4gIHRyYW5zbGl0ZXJhdGUoczogc3RyaW5nKSB7XG4gICAgcmV0dXJuIHRyYW5zbGl0ZXJhdGUocyk7XG4gIH1cbn1cbiJdfQ==
23
+ }], ctorParameters: () => [] });
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsaXRlcmF0aW9uLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9zdHJlYW0tY2hhdC1hbmd1bGFyL3NyYy9saWIvdHJhbnNsaXRlcmF0aW9uLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLGFBQWEsTUFBTSwwQkFBMEIsQ0FBQzs7QUFFckQ7O0dBRUc7QUFFSCxNQUFNLE9BQU8sc0JBQXNCO0lBQ2pDLGdCQUFlLENBQUM7SUFFaEI7Ozs7T0FJRztJQUNILGFBQWEsQ0FBQyxDQUFTO1FBQ3JCLE9BQU8sYUFBYSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQzFCLENBQUM7OEdBVlUsc0JBQXNCO2tIQUF0QixzQkFBc0IsY0FEVCxNQUFNOzsyRkFDbkIsc0JBQXNCO2tCQURsQyxVQUFVO21CQUFDLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB0cmFuc2xpdGVyYXRlIGZyb20gJ0BzdHJlYW0taW8vdHJhbnNsaXRlcmF0ZSc7XG5cbi8qKlxuICogVGhlIGBUcmFuc2xpdGVyYXRpb25TZXJ2aWNlYCB3cmFwcyB0aGUgW0BzaW5kcmVzb3JodXMvdHJhbnNsaXRlcmF0ZV0oaHR0cHM6Ly93d3cubnBtanMuY29tL3BhY2thZ2UvQHNpbmRyZXNvcmh1cy90cmFuc2xpdGVyYXRlKSBsaWJyYXJ5XG4gKi9cbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0pXG5leHBvcnQgY2xhc3MgVHJhbnNsaXRlcmF0aW9uU2VydmljZSB7XG4gIGNvbnN0cnVjdG9yKCkge31cblxuICAvKipcbiAgICpcbiAgICogQHBhcmFtIHMgdGhlIHN0cmluZyB0byBiZSB0cmFuc2xpdGVyYXRlZFxuICAgKiBAcmV0dXJucyB0aGUgcmVzdWx0IG9mIHRoZSB0cmFuc2xpdGVyYXRpb25cbiAgICovXG4gIHRyYW5zbGl0ZXJhdGUoczogc3RyaW5nKSB7XG4gICAgcmV0dXJuIHRyYW5zbGl0ZXJhdGUocyk7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../projects/stream-chat-angular/src/lib/types.ts"],"names":[],"mappings":"","sourcesContent":["import { TemplateRef } from '@angular/core';\nimport { Observable, Subject } from 'rxjs';\nimport type {\n  Attachment,\n  Channel,\n  ChannelFilters,\n  ChannelManagerEventHandlerOverrides,\n  ChannelManagerOptions,\n  ChannelMemberResponse,\n  ChannelOptions,\n  ChannelSort,\n  CommandResponse,\n  Event,\n  ExtendableGenerics,\n  FormatMessageResponse,\n  LiteralStringForUnion,\n  MessageResponseBase,\n  Mute,\n  ReactionGroupResponse,\n  ReactionResponse,\n  User,\n  UserResponse,\n} from 'stream-chat';\nimport { AttachmentService } from './attachment.service';\nimport { Icon } from './icon/icon.component';\n\nexport type UnknownType = Record<string, unknown>;\n\nexport type CustomTrigger = {\n  [key: string]: {\n    componentProps: UnknownType;\n    data: UnknownType;\n  };\n};\n\nexport type DefaultStreamChatGenerics = ExtendableGenerics & {\n  attachmentType: DefaultAttachmentType;\n  channelType: DefaultChannelType;\n  commandType: LiteralStringForUnion;\n  eventType: UnknownType;\n  messageType: DefaultMessageType;\n  reactionType: UnknownType;\n  userType: DefaultUserType;\n};\n\nexport type DefaultAttachmentType = UnknownType & {\n  asset_url?: string;\n  id?: string;\n  images?: Array<Attachment<DefaultStreamChatGenerics>>;\n  mime_type?: string;\n  isCustomAttachment?: boolean;\n};\n\nexport type DefaultChannelType = UnknownType & {\n  image?: string;\n  member_count?: number;\n  subtitle?: string;\n};\n\nexport type DefaultCommandType = LiteralStringForUnion;\n\nexport type DefaultMessageType = UnknownType & {\n  customType?: 'channel.intro' | 'message.date';\n  date?: string | Date;\n  errorStatusCode?: number;\n  event?: Event<DefaultStreamChatGenerics>;\n  unread?: boolean;\n  readBy: UserResponse<DefaultStreamChatGenerics>[];\n  translation?: string;\n  quoted_message?: MessageResponseBase<DefaultStreamChatGenerics>;\n};\n\nexport type DefaultUserTypeInternal = {\n  image?: string;\n  status?: string;\n};\n\nexport type DefaultUserType = UnknownType &\n  DefaultUserTypeInternal & {\n    mutes?: Array<Mute<DefaultStreamChatGenerics>>;\n  };\n\nexport type StreamMessage<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = FormatMessageResponse<T>;\n\nexport type AttachmentUploadErrorReason =\n  | 'file-size'\n  | 'file-extension'\n  | 'unknown';\n\nexport type AttachmentUpload<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = {\n  file: File;\n  state: 'error' | 'success' | 'uploading';\n  errorReason?: AttachmentUploadErrorReason;\n  errorExtraInfo?: { param: string }[];\n  url?: string;\n  type: 'image' | 'file' | 'video' | 'voiceRecording';\n  previewUri?: string | ArrayBuffer;\n  thumb_url?: string;\n  extraData?: Partial<Attachment<T>>;\n  fromAttachment?: Attachment<T>;\n};\n\nexport type MentionAutcompleteListItemContext = {\n  item: MentionAutcompleteListItem;\n};\n\nexport type CommandAutocompleteListItemContext = {\n  item: ComandAutocompleteListItem;\n};\n\nexport type MentionAutcompleteListItem = (\n  | ChannelMemberResponse\n  | UserResponse\n) & {\n  autocompleteLabel: string;\n};\n\nexport type ComandAutocompleteListItem = CommandResponse & {\n  autocompleteLabel: string;\n};\n\nexport type NotificationType = 'success' | 'error' | 'info';\n\nexport type NotificationPayload<T = object> = {\n  id: string;\n  type: NotificationType;\n  text?: string;\n  translateParams?: object;\n  template?: TemplateRef<T>;\n  templateContext?: T;\n  dismissFn: () => void;\n};\n\nexport type ChannelPreviewContext<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = {\n  channel: Channel<T>;\n};\n\nexport type ChannelPreviewInfoContext<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = ChannelPreviewContext & {\n  latestMessage?: StreamMessage<T>;\n  /**\n   * The text of the latest message, or some meta information (for example: \"Nothing yet\")\n   */\n  latestMessageText: string;\n  /**\n   * The title of the channel, or the name of the channel members\n   */\n  channelDisplayTitle: string;\n  /**\n   * The status of the last message (only available if the last message was sent by the current user)\n   */\n  latestMessageStatus?: 'delivered' | 'read';\n  /**\n   * The time of the last message (formatted to a user-friendly string)\n   */\n  latestMessageTime?: string;\n  unreadCount: number;\n};\n\nexport type MentionTemplateContext = {\n  content: string;\n  user: UserResponse;\n};\n\nexport type EmojiPickerContext = {\n  emojiInput$: Subject<string>;\n};\n\nexport type TypingIndicatorContext = {\n  usersTyping$: Observable<UserResponse<DefaultStreamChatGenerics>[]>;\n};\n\nexport type MessageContext = {\n  message: StreamMessage | undefined;\n  enabledMessageActions: string[];\n  isLastSentMessage: boolean | undefined;\n  mode: 'thread' | 'main';\n  isHighlighted: boolean;\n  customActions: CustomMessageActionItem[];\n  scroll$?: Observable<void>;\n};\n\nexport type ChannelActionsContext<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = { channel: Channel<T> };\n\nexport type CustomAttachmentListContext<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = {\n  messageId: string;\n  attachments: Attachment<T>[];\n  parentMessageId?: string;\n};\n\nexport type AttachmentListContext = CustomAttachmentListContext & {\n  imageModalStateChangeHandler?: (state: 'opened' | 'closed') => void;\n};\n\nexport type AvatarType = 'channel' | 'user';\n\nexport type AvatarLocation =\n  | 'channel-preview'\n  | 'channel-header'\n  | 'message-sender'\n  | 'message-reader'\n  | 'quoted-message-sender'\n  | 'autocomplete-item'\n  | 'typing-indicator'\n  /**\n   * @deprecated this will be renamed to user-list in the next major release\n   */\n  | 'reaction';\n\nexport type AvatarContext = {\n  name: string | undefined;\n  imageUrl: string | undefined;\n  type: AvatarType | undefined;\n  location: AvatarLocation | undefined;\n  channel?: Channel<DefaultStreamChatGenerics>;\n  user?: User<DefaultStreamChatGenerics>;\n  initialsType?: 'first-letter-of-first-word' | 'first-letter-of-each-word';\n  showOnlineIndicator?: boolean;\n};\n\nexport type AttachmentPreviewListContext = {\n  attachmentUploads$: Observable<AttachmentUpload[]> | undefined;\n  retryUploadHandler: (f: File) => void;\n  deleteUploadHandler: (u: AttachmentUpload) => void;\n  service: AttachmentService;\n};\n\nexport type IconContext = {\n  icon: Icon | undefined;\n};\n\nexport type MessageActionsBoxContext<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = {\n  isMine: boolean;\n  message: StreamMessage<T> | undefined;\n  enabledActions: string[];\n  messageTextHtmlElement: HTMLElement | undefined;\n};\n\nexport type MessageActionHandlerExtraParams = {\n  isMine: boolean;\n  messageTextHtmlElement?: HTMLElement;\n};\n\nexport type MessageActionHandler<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = (\n  message: StreamMessage<T>,\n  params: MessageActionHandlerExtraParams,\n) => void;\n\nexport type MessageActionBoxItemContext<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = {\n  actionName: string;\n  actionLabelOrTranslationKey: ((message: StreamMessage<T>) => string) | string;\n  message: StreamMessage<T>;\n  actionHandlerExtraParams: MessageActionHandlerExtraParams;\n  actionHandler: MessageActionHandler<T>;\n};\n\nexport type MessageReactionActionItem<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = {\n  actionName: 'react';\n  isVisible: (\n    enabledActions: string[],\n    isMine: boolean,\n    message: StreamMessage<T>,\n  ) => boolean;\n};\n\ntype MessageActionItemBase<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = {\n  actionLabelOrTranslationKey: ((message: StreamMessage<T>) => string) | string;\n  isVisible: (\n    enabledActions: string[],\n    isMine: boolean,\n    message: StreamMessage<T>,\n  ) => boolean;\n  actionHandler: MessageActionHandler;\n};\n\nexport type MessageActionItem<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = MessageActionItemBase<T> & {\n  actionName:\n    | 'quote'\n    | 'pin'\n    | 'flag'\n    | 'edit'\n    | 'delete'\n    | 'mark-unread'\n    | 'thread-reply'\n    | 'copy-message-text';\n};\n\nexport type CustomMessageActionItem<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = MessageActionItemBase<T> & {\n  actionName: string;\n};\n\nexport type MessageReactionsSelectorContext = {\n  messageId: string | undefined;\n  ownReactions: ReactionResponse<DefaultStreamChatGenerics>[];\n};\n\nexport type MessageReactionsContext = {\n  messageId: string | undefined;\n  /** @deprecated use `messageReactionGroups` */\n  messageReactionCounts: { [key in MessageReactionType]?: number };\n  /** @deprecated you can fetch the reactions using [`chatService.chatClient.queryReactions()`](/chat/docs/javascript/send_reaction/&q=queryReactions#query-reactions) */\n  latestReactions: ReactionResponse<DefaultStreamChatGenerics>[];\n  ownReactions: ReactionResponse<DefaultStreamChatGenerics>[];\n  messageReactionGroups: {\n    [key in MessageReactionType]: ReactionGroupResponse;\n  };\n};\n\nexport type ModalContext = {\n  isOpen: boolean;\n  isOpenChangeHandler: (isOpen: boolean) => void;\n  content: TemplateRef<void>;\n};\n\nexport type NotificationContext = {\n  type: NotificationType | undefined;\n  content: TemplateRef<void> | undefined;\n};\n\nexport type ThreadHeaderContext = {\n  parentMessage: StreamMessage | undefined;\n  closeThreadHandler: () => void;\n};\n\nexport type MessageReactionType = string;\n\nexport type AttachmentConfigration = {\n  url: string;\n  height: string;\n  width: string;\n};\n\nexport type ImageAttachmentConfiguration = AttachmentConfigration & {\n  originalHeight: number;\n  originalWidth: number;\n};\n\nexport type VideoAttachmentConfiguration = ImageAttachmentConfiguration & {\n  thumbUrl?: string;\n};\n\nexport type DeliveredStatusContext = {\n  message: StreamMessage;\n};\n\nexport type SendingStatusContext = {\n  message: StreamMessage;\n};\n\nexport type CustomMetadataContext<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = {\n  message: StreamMessage<T>;\n};\n\nexport type ReadStatusContext = {\n  message: StreamMessage;\n  readByText: string;\n};\n\nexport type ChannelHeaderInfoContext<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = { channel: Channel<T> };\n\nexport type CustomAttachmentUploadContext = {\n  isMultipleFileUploadEnabled: boolean | undefined;\n  attachmentService: AttachmentService;\n};\n\nexport type AttachmentContext = {\n  attachment: Attachment<DefaultStreamChatGenerics>;\n};\n\nexport type SystemMessageContext = MessageContext & {\n  parsedDate: string | undefined;\n};\n\nexport type DateSeparatorContext = {\n  date: Date;\n  parsedDate: string;\n};\n\nexport type UnreadMessagesIndicatorContext = {\n  unreadCount: number;\n};\n\nexport type UnreadMessagesNotificationContext =\n  UnreadMessagesIndicatorContext & {\n    onJump: () => void;\n    onDismiss: () => void;\n  };\n\nexport type ChannelQueryState = {\n  state: 'in-progress' | 'success' | 'error';\n  // No type def from stream-chat\n  error?: unknown;\n};\n\nexport type MessageInput<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = {\n  text: string;\n  attachments: Attachment<T>[];\n  mentionedUsers: UserResponse<T>[];\n  parentId: string | undefined;\n  quotedMessageId: string | undefined;\n  customData: undefined | Partial<T['messageType']>;\n};\n\nexport type OffsetNextPageConfiguration = {\n  type: 'offset';\n  offset: number;\n};\n\nexport type FiltertNextPageConfiguration<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = {\n  type: 'filter';\n  paginationFilter: ChannelFilters<T>;\n};\n\nexport type NextPageConfiguration =\n  | OffsetNextPageConfiguration\n  | FiltertNextPageConfiguration\n  | undefined;\n\nexport type MessageReactionClickDetails = {\n  messageId: string;\n  reactionType: string;\n};\n\nexport type MessageActionsClickDetails<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = MessageActionsBoxContext<T> & { customActions: CustomMessageActionItem[] };\n\nexport type GroupStyleOptions = {\n  noGroupByUser?: boolean;\n  lastReadMessageId?: string;\n  noGroupByReadState?: boolean;\n};\n\nexport type ChannelQueryType = 'first-page' | 'next-page' | 'recover-state';\n\nexport type ChannelQueryResult<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = {\n  channels: Channel<T>[];\n  hasMorePage: boolean;\n};\n\nexport type VirtualizedListScrollPosition = 'top' | 'bottom' | 'middle';\n\nexport type VirtualizedListQueryState = {\n  state: 'loading-top' | 'loading-bottom' | 'success' | 'error';\n  error?: unknown;\n};\n\nexport type VirtualizedListQueryDirection = 'top' | 'bottom';\n\nexport type VirtualizedListVerticalItemPosition = 'top' | 'bottom' | 'middle';\n\nexport type AudioRecording = MediaRecording & { waveform_data: number[] };\n\nexport type MediaRecording = {\n  recording: File;\n  duration: number;\n  mime_type: string;\n  asset_url: string | ArrayBuffer | undefined;\n};\n\nexport type CustomAttachmentPreviewListContext<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = {\n  service: AttachmentService<T>;\n};\n\nexport type ThreadReplyButtonContext<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = {\n  message: StreamMessage<T>;\n};\n\nexport type CustomAutocompleteItemContext = {\n  item: CustomAutocompleteItem;\n};\n\nexport type CustomAutocompleteItem = {\n  /**\n   * This is the text that will be inserted into the message input once a user selects an option (appended after the trigger character)\n   */\n  autocompleteLabel: string;\n};\n\nexport type CustomAutocomplete = {\n  /**\n   * The character that will trigger the autocomplete (for example #)\n   *\n   * The SDK supports @ and / by default, so you can't use those\n   */\n  triggerCharacter: string;\n  /**\n   * The HTML template to display an item in the autocomplete list\n   */\n  templateRef: TemplateRef<{ item: CustomAutocompleteItem }>;\n  /**\n   * Set to `true` if space characters can be part of the `autocompleteLabel`\n   */\n  allowSpace: boolean;\n  /**\n   * The options to choose from\n   *\n   * In case you want to use dynamic/server-side filtering, use `updateOptions` instead\n   */\n  options: CustomAutocompleteItem[];\n  /**\n   * If you want to have dynamic/server-side filtering provide a  method that will be called any time the autocomplete options should be filtered\n   * @param searchTerm the text to filter by (without the trigger character), can be an empty string\n   * @returns a promise that will resolve to the options, you should take care of error handling\n   */\n  updateOptions?: (searchTerm: string) => Promise<CustomAutocompleteItem[]>;\n};\n\nexport type MessageTextContext = {\n  message: StreamMessage | undefined | MessageResponseBase;\n  isQuoted: boolean;\n  shouldTranslate: boolean;\n};\n\nexport type ChannelServiceOptions<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = ChannelManagerOptions & {\n  shouldSetActiveChannel?: boolean;\n  eventHandlerOverrides?: ChannelManagerEventHandlerOverrides<T>;\n};\n\nexport type ChannelQueryConfig<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = {\n  filters: ChannelFilters<T>;\n  sort: ChannelSort<T>;\n  options: ChannelOptions;\n};\n\nexport type ChannelQueryConfigInput<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics,\n> = {\n  filters: ChannelFilters<T>;\n  sort?: ChannelSort<T>;\n  options?: ChannelOptions;\n};\n"]}
@@ -29,12 +29,12 @@ export class UserListComponent {
29
29
  trackByUserId(_, item) {
30
30
  return item.id;
31
31
  }
32
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0", ngImport: i0, type: UserListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
33
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.0", type: UserListComponent, selector: "stream-user-list", inputs: { users: "users", isLoading: "isLoading", hasMore: "hasMore" }, outputs: { loadMore: "loadMore" }, ngImport: i0, template: "<stream-paginated-list\n [items]=\"users\"\n [hasMore]=\"hasMore\"\n (loadMore)=\"loadMore.emit()\"\n [isLoading]=\"isLoading\"\n [trackBy]=\"trackByUserId\"\n>\n <ng-template let-user=\"item\">\n <div class=\"str-chat__user-list-item\">\n <stream-avatar-placeholder\n data-testclass=\"avatar\"\n class=\"str-chat__avatar str-chat__avatar--circle\"\n type=\"user\"\n location=\"reaction\"\n [imageUrl]=\"user.image\"\n [name]=\"user.name\"\n [user]=\"user\"\n />\n <span data-testclass=\"username\" class=\"str-chat__user-item--name\">{{\n user.name\n }}</span>\n </div>\n </ng-template>\n</stream-paginated-list>\n", dependencies: [{ kind: "component", type: i1.AvatarPlaceholderComponent, selector: "stream-avatar-placeholder", inputs: ["name", "imageUrl", "location", "channel", "user", "type", "initialsType", "showOnlineIndicator"] }, { kind: "component", type: i2.PaginatedListComponent, selector: "stream-paginated-list", inputs: ["items", "isLoading", "hasMore", "trackBy"], outputs: ["loadMore"] }] }); }
32
34
  }
33
- UserListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: UserListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
34
- UserListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: UserListComponent, selector: "stream-user-list", inputs: { users: "users", isLoading: "isLoading", hasMore: "hasMore" }, outputs: { loadMore: "loadMore" }, ngImport: i0, template: "<stream-paginated-list\n [items]=\"users\"\n [hasMore]=\"hasMore\"\n (loadMore)=\"loadMore.emit()\"\n [isLoading]=\"isLoading\"\n [trackBy]=\"trackByUserId\"\n>\n <ng-template let-user=\"item\">\n <div class=\"str-chat__user-list-item\">\n <stream-avatar-placeholder\n data-testclass=\"avatar\"\n class=\"str-chat__avatar str-chat__avatar--circle\"\n type=\"user\"\n location=\"reaction\"\n [imageUrl]=\"user.image\"\n [name]=\"user.name\"\n [user]=\"user\"\n ></stream-avatar-placeholder>\n <span data-testclass=\"username\" class=\"str-chat__user-item--name\">{{\n user.name\n }}</span>\n </div>\n </ng-template>\n</stream-paginated-list>\n", dependencies: [{ kind: "component", type: i1.AvatarPlaceholderComponent, selector: "stream-avatar-placeholder", inputs: ["name", "imageUrl", "location", "channel", "user", "type", "initialsType", "showOnlineIndicator"] }, { kind: "component", type: i2.PaginatedListComponent, selector: "stream-paginated-list", inputs: ["items", "isLoading", "hasMore", "trackBy"], outputs: ["loadMore"] }] });
35
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: UserListComponent, decorators: [{
35
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0", ngImport: i0, type: UserListComponent, decorators: [{
36
36
  type: Component,
37
- args: [{ selector: 'stream-user-list', template: "<stream-paginated-list\n [items]=\"users\"\n [hasMore]=\"hasMore\"\n (loadMore)=\"loadMore.emit()\"\n [isLoading]=\"isLoading\"\n [trackBy]=\"trackByUserId\"\n>\n <ng-template let-user=\"item\">\n <div class=\"str-chat__user-list-item\">\n <stream-avatar-placeholder\n data-testclass=\"avatar\"\n class=\"str-chat__avatar str-chat__avatar--circle\"\n type=\"user\"\n location=\"reaction\"\n [imageUrl]=\"user.image\"\n [name]=\"user.name\"\n [user]=\"user\"\n ></stream-avatar-placeholder>\n <span data-testclass=\"username\" class=\"str-chat__user-item--name\">{{\n user.name\n }}</span>\n </div>\n </ng-template>\n</stream-paginated-list>\n" }]
37
+ args: [{ selector: 'stream-user-list', template: "<stream-paginated-list\n [items]=\"users\"\n [hasMore]=\"hasMore\"\n (loadMore)=\"loadMore.emit()\"\n [isLoading]=\"isLoading\"\n [trackBy]=\"trackByUserId\"\n>\n <ng-template let-user=\"item\">\n <div class=\"str-chat__user-list-item\">\n <stream-avatar-placeholder\n data-testclass=\"avatar\"\n class=\"str-chat__avatar str-chat__avatar--circle\"\n type=\"user\"\n location=\"reaction\"\n [imageUrl]=\"user.image\"\n [name]=\"user.name\"\n [user]=\"user\"\n />\n <span data-testclass=\"username\" class=\"str-chat__user-item--name\">{{\n user.name\n }}</span>\n </div>\n </ng-template>\n</stream-paginated-list>\n" }]
38
38
  }], propDecorators: { users: [{
39
39
  type: Input
40
40
  }], isLoading: [{
@@ -44,4 +44,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImpor
44
44
  }], loadMore: [{
45
45
  type: Output
46
46
  }] } });
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci1saXN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi91c2VyLWxpc3QvdXNlci1saXN0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi91c2VyLWxpc3QvdXNlci1saXN0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFJdkU7O0dBRUc7QUFNSCxNQUFNLE9BQU8saUJBQWlCO0lBTDlCO1FBTUU7O1dBRUc7UUFDTSxVQUFLLEdBQThDLEVBQUUsQ0FBQztRQUMvRDs7V0FFRztRQUNNLGNBQVMsR0FBRyxLQUFLLENBQUM7UUFDM0I7O1dBRUc7UUFDTSxZQUFPLEdBQUcsS0FBSyxDQUFDO1FBQ3pCOzs7O1dBSUc7UUFDZ0IsYUFBUSxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7S0FLeEQ7SUFIQyxhQUFhLENBQUMsQ0FBUyxFQUFFLElBQWtCO1FBQ3pDLE9BQU8sSUFBSSxDQUFDLEVBQUUsQ0FBQztJQUNqQixDQUFDOzs4R0F0QlUsaUJBQWlCO2tHQUFqQixpQkFBaUIsbUtDWjlCLDZ0QkF3QkE7MkZEWmEsaUJBQWlCO2tCQUw3QixTQUFTOytCQUNFLGtCQUFrQjs4QkFRbkIsS0FBSztzQkFBYixLQUFLO2dCQUlHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBSUcsT0FBTztzQkFBZixLQUFLO2dCQU1hLFFBQVE7c0JBQTFCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVXNlclJlc3BvbnNlIH0gZnJvbSAnc3RyZWFtLWNoYXQnO1xuaW1wb3J0IHsgRGVmYXVsdFN0cmVhbUNoYXRHZW5lcmljcyB9IGZyb20gJy4uL3R5cGVzJztcblxuLyoqXG4gKiBUaGUgYFVzZXJMaXN0Q29tcG9uZW50YCBjYW4gZGlzcGxheSBhIGxpc3Qgb2YgU3RyZWFtIHVzZXJzIHdpdGggcGFnaW5hdGlvblxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzdHJlYW0tdXNlci1saXN0JyxcbiAgdGVtcGxhdGVVcmw6ICcuL3VzZXItbGlzdC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlczogW10sXG59KVxuZXhwb3J0IGNsYXNzIFVzZXJMaXN0Q29tcG9uZW50IHtcbiAgLyoqXG4gICAqIFRoZSB1c2VycyB0byBkaXNwbGF5XG4gICAqL1xuICBASW5wdXQoKSB1c2VyczogVXNlclJlc3BvbnNlPERlZmF1bHRTdHJlYW1DaGF0R2VuZXJpY3M+W10gPSBbXTtcbiAgLyoqXG4gICAqIElmIGB0cnVlYCwgdGhlIGxvYWRpbmcgaW5kaWNhdG9yIHdpbGwgYmUgZGlzcGxheWVkXG4gICAqL1xuICBASW5wdXQoKSBpc0xvYWRpbmcgPSBmYWxzZTtcbiAgLyoqXG4gICAqIElmIGBmYWxzZWAgdGhlIGNvbXBvbmVudCB3b24ndCBhc2sgZm9yIG1vcmUgZGF0YSB2dWEgdGhlIGBsb2FkTW9yZWAgb3V0cHV0XG4gICAqL1xuICBASW5wdXQoKSBoYXNNb3JlID0gZmFsc2U7XG4gIC8qKlxuICAgKiBUaGUgY29tcG9uZW50IHdpbGwgc2lnbmFsIHZpYSB0aGlzIG91dHB1dCB3aGVuIG1vcmUgaXRlbXMgc2hvdWxkIGJlIGZldGNoZWRcbiAgICpcbiAgICogVGhlIG5ldyBpdGVtcyBzaG91bGQgYmUgYXBwZW5kZWQgdG8gdGhlIGBpdGVtc2AgYXJyYXlcbiAgICovXG4gIEBPdXRwdXQoKSByZWFkb25seSBsb2FkTW9yZSA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcblxuICB0cmFja0J5VXNlcklkKF86IG51bWJlciwgaXRlbTogVXNlclJlc3BvbnNlKSB7XG4gICAgcmV0dXJuIGl0ZW0uaWQ7XG4gIH1cbn1cbiIsIjxzdHJlYW0tcGFnaW5hdGVkLWxpc3RcbiAgW2l0ZW1zXT1cInVzZXJzXCJcbiAgW2hhc01vcmVdPVwiaGFzTW9yZVwiXG4gIChsb2FkTW9yZSk9XCJsb2FkTW9yZS5lbWl0KClcIlxuICBbaXNMb2FkaW5nXT1cImlzTG9hZGluZ1wiXG4gIFt0cmFja0J5XT1cInRyYWNrQnlVc2VySWRcIlxuPlxuICA8bmctdGVtcGxhdGUgbGV0LXVzZXI9XCJpdGVtXCI+XG4gICAgPGRpdiBjbGFzcz1cInN0ci1jaGF0X191c2VyLWxpc3QtaXRlbVwiPlxuICAgICAgPHN0cmVhbS1hdmF0YXItcGxhY2Vob2xkZXJcbiAgICAgICAgZGF0YS10ZXN0Y2xhc3M9XCJhdmF0YXJcIlxuICAgICAgICBjbGFzcz1cInN0ci1jaGF0X19hdmF0YXIgc3RyLWNoYXRfX2F2YXRhci0tY2lyY2xlXCJcbiAgICAgICAgdHlwZT1cInVzZXJcIlxuICAgICAgICBsb2NhdGlvbj1cInJlYWN0aW9uXCJcbiAgICAgICAgW2ltYWdlVXJsXT1cInVzZXIuaW1hZ2VcIlxuICAgICAgICBbbmFtZV09XCJ1c2VyLm5hbWVcIlxuICAgICAgICBbdXNlcl09XCJ1c2VyXCJcbiAgICAgID48L3N0cmVhbS1hdmF0YXItcGxhY2Vob2xkZXI+XG4gICAgICA8c3BhbiBkYXRhLXRlc3RjbGFzcz1cInVzZXJuYW1lXCIgY2xhc3M9XCJzdHItY2hhdF9fdXNlci1pdGVtLS1uYW1lXCI+e3tcbiAgICAgICAgdXNlci5uYW1lXG4gICAgICB9fTwvc3Bhbj5cbiAgICA8L2Rpdj5cbiAgPC9uZy10ZW1wbGF0ZT5cbjwvc3RyZWFtLXBhZ2luYXRlZC1saXN0PlxuIl19
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci1saXN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi91c2VyLWxpc3QvdXNlci1saXN0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi91c2VyLWxpc3QvdXNlci1saXN0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFJdkU7O0dBRUc7QUFNSCxNQUFNLE9BQU8saUJBQWlCO0lBTDlCO1FBTUU7O1dBRUc7UUFDTSxVQUFLLEdBQThDLEVBQUUsQ0FBQztRQUMvRDs7V0FFRztRQUNNLGNBQVMsR0FBRyxLQUFLLENBQUM7UUFDM0I7O1dBRUc7UUFDTSxZQUFPLEdBQUcsS0FBSyxDQUFDO1FBQ3pCOzs7O1dBSUc7UUFDZ0IsYUFBUSxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7S0FLeEQ7SUFIQyxhQUFhLENBQUMsQ0FBUyxFQUFFLElBQWtCO1FBQ3pDLE9BQU8sSUFBSSxDQUFDLEVBQUUsQ0FBQztJQUNqQixDQUFDOzhHQXRCVSxpQkFBaUI7a0dBQWpCLGlCQUFpQixtS0NaOUIsa3NCQXdCQTs7MkZEWmEsaUJBQWlCO2tCQUw3QixTQUFTOytCQUNFLGtCQUFrQjs4QkFRbkIsS0FBSztzQkFBYixLQUFLO2dCQUlHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBSUcsT0FBTztzQkFBZixLQUFLO2dCQU1hLFFBQVE7c0JBQTFCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVXNlclJlc3BvbnNlIH0gZnJvbSAnc3RyZWFtLWNoYXQnO1xuaW1wb3J0IHsgRGVmYXVsdFN0cmVhbUNoYXRHZW5lcmljcyB9IGZyb20gJy4uL3R5cGVzJztcblxuLyoqXG4gKiBUaGUgYFVzZXJMaXN0Q29tcG9uZW50YCBjYW4gZGlzcGxheSBhIGxpc3Qgb2YgU3RyZWFtIHVzZXJzIHdpdGggcGFnaW5hdGlvblxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzdHJlYW0tdXNlci1saXN0JyxcbiAgdGVtcGxhdGVVcmw6ICcuL3VzZXItbGlzdC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlczogW10sXG59KVxuZXhwb3J0IGNsYXNzIFVzZXJMaXN0Q29tcG9uZW50IHtcbiAgLyoqXG4gICAqIFRoZSB1c2VycyB0byBkaXNwbGF5XG4gICAqL1xuICBASW5wdXQoKSB1c2VyczogVXNlclJlc3BvbnNlPERlZmF1bHRTdHJlYW1DaGF0R2VuZXJpY3M+W10gPSBbXTtcbiAgLyoqXG4gICAqIElmIGB0cnVlYCwgdGhlIGxvYWRpbmcgaW5kaWNhdG9yIHdpbGwgYmUgZGlzcGxheWVkXG4gICAqL1xuICBASW5wdXQoKSBpc0xvYWRpbmcgPSBmYWxzZTtcbiAgLyoqXG4gICAqIElmIGBmYWxzZWAgdGhlIGNvbXBvbmVudCB3b24ndCBhc2sgZm9yIG1vcmUgZGF0YSB2dWEgdGhlIGBsb2FkTW9yZWAgb3V0cHV0XG4gICAqL1xuICBASW5wdXQoKSBoYXNNb3JlID0gZmFsc2U7XG4gIC8qKlxuICAgKiBUaGUgY29tcG9uZW50IHdpbGwgc2lnbmFsIHZpYSB0aGlzIG91dHB1dCB3aGVuIG1vcmUgaXRlbXMgc2hvdWxkIGJlIGZldGNoZWRcbiAgICpcbiAgICogVGhlIG5ldyBpdGVtcyBzaG91bGQgYmUgYXBwZW5kZWQgdG8gdGhlIGBpdGVtc2AgYXJyYXlcbiAgICovXG4gIEBPdXRwdXQoKSByZWFkb25seSBsb2FkTW9yZSA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcblxuICB0cmFja0J5VXNlcklkKF86IG51bWJlciwgaXRlbTogVXNlclJlc3BvbnNlKSB7XG4gICAgcmV0dXJuIGl0ZW0uaWQ7XG4gIH1cbn1cbiIsIjxzdHJlYW0tcGFnaW5hdGVkLWxpc3RcbiAgW2l0ZW1zXT1cInVzZXJzXCJcbiAgW2hhc01vcmVdPVwiaGFzTW9yZVwiXG4gIChsb2FkTW9yZSk9XCJsb2FkTW9yZS5lbWl0KClcIlxuICBbaXNMb2FkaW5nXT1cImlzTG9hZGluZ1wiXG4gIFt0cmFja0J5XT1cInRyYWNrQnlVc2VySWRcIlxuPlxuICA8bmctdGVtcGxhdGUgbGV0LXVzZXI9XCJpdGVtXCI+XG4gICAgPGRpdiBjbGFzcz1cInN0ci1jaGF0X191c2VyLWxpc3QtaXRlbVwiPlxuICAgICAgPHN0cmVhbS1hdmF0YXItcGxhY2Vob2xkZXJcbiAgICAgICAgZGF0YS10ZXN0Y2xhc3M9XCJhdmF0YXJcIlxuICAgICAgICBjbGFzcz1cInN0ci1jaGF0X19hdmF0YXIgc3RyLWNoYXRfX2F2YXRhci0tY2lyY2xlXCJcbiAgICAgICAgdHlwZT1cInVzZXJcIlxuICAgICAgICBsb2NhdGlvbj1cInJlYWN0aW9uXCJcbiAgICAgICAgW2ltYWdlVXJsXT1cInVzZXIuaW1hZ2VcIlxuICAgICAgICBbbmFtZV09XCJ1c2VyLm5hbWVcIlxuICAgICAgICBbdXNlcl09XCJ1c2VyXCJcbiAgICAgIC8+XG4gICAgICA8c3BhbiBkYXRhLXRlc3RjbGFzcz1cInVzZXJuYW1lXCIgY2xhc3M9XCJzdHItY2hhdF9fdXNlci1pdGVtLS1uYW1lXCI+e3tcbiAgICAgICAgdXNlci5uYW1lXG4gICAgICB9fTwvc3Bhbj5cbiAgICA8L2Rpdj5cbiAgPC9uZy10ZW1wbGF0ZT5cbjwvc3RyZWFtLXBhZ2luYXRlZC1saXN0PlxuIl19
@@ -0,0 +1,273 @@
1
+ import { BehaviorSubject, Subject, combineLatest, distinctUntilChanged, filter, merge, of, pairwise, switchMap, take, } from 'rxjs';
2
+ /**
3
+ * The `VirtualizedListService` removes items from a list that are not currently displayed. This is a high-level overview of how it works:
4
+ * - Create a new instance for each list that needs virtualization
5
+ * - Input: Provide a reactive stream that emits all items in the list
6
+ * - Input: Provide a reactive stream that emit the current scroll position (top, middle or bottom)
7
+ * - Input: maximum number of items that are allowed in the list (in practice the service can make the virtualized list half this number, you should take this into account when choosing the value)
8
+ * - Output: The service will emit the current list of displayed items via the virtualized items reactive stream
9
+ * - For simplicity, the service won't track the height of the items, nor it needs an exact scroll location -> this is how removing items work:
10
+ * - If scroll location is bottom/top items around the current bottom/top item will be emitted in the virtualized items stream
11
+ * - If scroll location is middle, the service won't remove items, if new items are received, those will be appended to the virtualized list (this means that in theory the list can grow very big if a lot of new items are received while the user is scrolled somewhere, this is a trade-off for the simplicity of no height tracking)
12
+ * - Since there is no height tracking, you should make sure to provide a maximum number that is big enough to fill the biggest expected screen size twice
13
+ * - If the user scrolls to the bottom/top and there are no more local items to show, the service will trigger a query to load more items
14
+ * - Input: you should provide the page size to use, in order for the service to determine if loading is necessary
15
+ *
16
+ * The `VirtualizedMessageListService` provides an implementation for the message list component.
17
+ */
18
+ export class VirtualizedListService {
19
+ constructor(allItems$, scrollPosition$, jumpToItem$, pageSize = 25, maxItemCount = pageSize * 4) {
20
+ this.allItems$ = allItems$;
21
+ this.scrollPosition$ = scrollPosition$;
22
+ this.jumpToItem$ = jumpToItem$;
23
+ this.pageSize = pageSize;
24
+ this.maxItemCount = maxItemCount;
25
+ this.queryStateSubject = new BehaviorSubject({
26
+ state: 'success',
27
+ });
28
+ this.bufferOnTop = 0;
29
+ this.bufferOnBottom = 0;
30
+ this.loadFromBuffer$ = new Subject();
31
+ this.virtualizedItemsSubject = new BehaviorSubject([]);
32
+ this.subscriptions = [];
33
+ this.virtualizedItems$ = this.virtualizedItemsSubject.asObservable();
34
+ this.queryState$ = this.queryStateSubject.asObservable();
35
+ this.subscriptions.push(this.virtualizedItems$.subscribe((virtaluzedItems) => {
36
+ this.allItems$.pipe(take(1)).subscribe((allItems) => {
37
+ if (virtaluzedItems.length === allItems.length) {
38
+ this.bufferOnTop = 0;
39
+ this.bufferOnBottom = 0;
40
+ }
41
+ else if (virtaluzedItems.length === 0) {
42
+ this.bufferOnTop = allItems.length;
43
+ this.bufferOnBottom = 0;
44
+ }
45
+ else {
46
+ this.bufferOnTop = allItems.indexOf(virtaluzedItems[0]);
47
+ this.bufferOnBottom =
48
+ allItems.length -
49
+ allItems.indexOf(virtaluzedItems[virtaluzedItems.length - 1]) -
50
+ 1;
51
+ }
52
+ });
53
+ }));
54
+ this.subscriptions.push(merge(this.allItems$, this.loadFromBuffer$)
55
+ .pipe(switchMap(() => {
56
+ return combineLatest([
57
+ this.allItems$.pipe(take(1)),
58
+ this.scrollPosition$.pipe(take(1)),
59
+ ]);
60
+ }))
61
+ .subscribe(([items, scrollPosition]) => {
62
+ if (scrollPosition === 'middle') {
63
+ return;
64
+ }
65
+ const currentItems = this.virtualizedItemsSubject.getValue();
66
+ if (items.length <= this.maxItemCount) {
67
+ this.virtualizedItemsSubject.next(items);
68
+ }
69
+ else {
70
+ let startIndex = 0;
71
+ let endIndex = undefined;
72
+ const numberOfItemsToRemove = items.length - Math.round(this.maxItemCount / 2);
73
+ const numberOfItemsAfterRemove = items.length - numberOfItemsToRemove;
74
+ switch (scrollPosition) {
75
+ case 'top':
76
+ if (currentItems.length > 0) {
77
+ const middleIndex = items.findIndex((i) => this.isEqual(i, currentItems[0]));
78
+ if (middleIndex !== -1) {
79
+ startIndex = Math.max(0, middleIndex - Math.ceil(numberOfItemsAfterRemove / 2));
80
+ endIndex = startIndex + numberOfItemsAfterRemove;
81
+ }
82
+ }
83
+ else {
84
+ endIndex = numberOfItemsAfterRemove;
85
+ }
86
+ break;
87
+ case 'bottom':
88
+ if (currentItems.length > 0) {
89
+ const middleIndex = items.findIndex((i) => this.isEqual(i, currentItems[currentItems.length - 1]));
90
+ if (middleIndex !== -1) {
91
+ endIndex = Math.min(items.length, middleIndex +
92
+ Math.floor(numberOfItemsAfterRemove / 2) +
93
+ 1);
94
+ startIndex = endIndex - numberOfItemsAfterRemove;
95
+ }
96
+ }
97
+ else {
98
+ startIndex = items.length - numberOfItemsAfterRemove;
99
+ }
100
+ break;
101
+ }
102
+ const virtualizedItems = items.slice(startIndex, endIndex);
103
+ this.virtualizedItemsSubject.next(virtualizedItems);
104
+ }
105
+ }));
106
+ this.subscriptions.push(this.scrollPosition$
107
+ .pipe(distinctUntilChanged())
108
+ .subscribe((position) => {
109
+ if (this.queryStateSubject.getValue().state === `loading-${position}`) {
110
+ return;
111
+ }
112
+ if (position === 'top') {
113
+ if (this.bufferOnTop < this.pageSize) {
114
+ void this.loadMore(position);
115
+ }
116
+ else {
117
+ this.loadMoreFromBuffer('top');
118
+ }
119
+ }
120
+ else if (position === 'bottom') {
121
+ if (this.bufferOnBottom < this.pageSize) {
122
+ void this.loadMore(position);
123
+ }
124
+ else {
125
+ this.loadMoreFromBuffer('bottom');
126
+ }
127
+ }
128
+ }));
129
+ this.subscriptions.push(this.allItems$
130
+ .pipe(pairwise(), filter(() => {
131
+ let scrollPosition;
132
+ this.scrollPosition$
133
+ .pipe(take(1))
134
+ .subscribe((s) => (scrollPosition = s));
135
+ return scrollPosition === 'middle';
136
+ }))
137
+ .subscribe(([prevItems, currentItems]) => {
138
+ if (currentItems.length < this.maxItemCount ||
139
+ this.virtualizedItems.length === 0) {
140
+ this.virtualizedItemsSubject.next(currentItems);
141
+ }
142
+ else {
143
+ const currentFirstItem = this.virtualizedItems[0];
144
+ const currentLastItem = this.virtualizedItems[this.virtualizedItems.length - 1];
145
+ const prevStartIndex = prevItems.findIndex((i) => this.isEqual(i, currentFirstItem));
146
+ const prevEndIndex = prevItems.findIndex((i) => this.isEqual(i, currentLastItem));
147
+ const isStartRemainedSame = currentItems[prevStartIndex]
148
+ ? this.isEqual(currentItems[prevStartIndex], currentFirstItem)
149
+ : false;
150
+ const isEndRemainedSame = currentItems[prevEndIndex]
151
+ ? this.isEqual(currentItems[prevEndIndex], currentLastItem)
152
+ : false;
153
+ const hasNewItemsBottom = prevEndIndex === prevItems.length - 1 && isEndRemainedSame
154
+ ? prevItems.length !== currentItems.length
155
+ : false;
156
+ if (isStartRemainedSame && isEndRemainedSame) {
157
+ const endIndex = hasNewItemsBottom ? undefined : prevEndIndex + 1;
158
+ this.virtualizedItemsSubject.next(currentItems.slice(prevStartIndex, endIndex));
159
+ }
160
+ let currentStartIndex = isStartRemainedSame ? prevStartIndex : -1;
161
+ let currentEndIndex = isEndRemainedSame ? prevEndIndex : -1;
162
+ if (!isStartRemainedSame) {
163
+ currentStartIndex = currentItems.findIndex((i) => this.isEqual(i, currentFirstItem));
164
+ }
165
+ if (!isEndRemainedSame) {
166
+ currentEndIndex = currentItems.findIndex((i) => this.isEqual(i, currentLastItem));
167
+ }
168
+ const hasNewItemsTop = prevStartIndex === 0 && !isStartRemainedSame
169
+ ? currentStartIndex !== 0
170
+ : false;
171
+ if (currentStartIndex !== -1 && currentEndIndex !== -1) {
172
+ const startIndex = hasNewItemsTop ? 0 : currentStartIndex;
173
+ this.virtualizedItemsSubject.next(currentItems.slice(startIndex, currentEndIndex + 1));
174
+ }
175
+ else {
176
+ if (currentStartIndex === -1 && currentEndIndex !== -1) {
177
+ currentStartIndex = Math.max(0, currentEndIndex - (prevEndIndex - prevStartIndex));
178
+ }
179
+ if (currentEndIndex === -1 && currentStartIndex !== -1) {
180
+ currentEndIndex = Math.min(currentItems.length - 1, currentStartIndex + (prevEndIndex - prevStartIndex));
181
+ }
182
+ this.virtualizedItemsSubject.next(currentItems.slice(currentStartIndex, currentEndIndex + 1));
183
+ }
184
+ }
185
+ }));
186
+ if (this.jumpToItem$) {
187
+ this.subscriptions.push(this.jumpToItem$
188
+ .pipe(switchMap((jumpToItem) => combineLatest([this.allItems$.pipe(take(1)), of(jumpToItem)])))
189
+ .subscribe(([allItems, jumpToItem]) => {
190
+ if (jumpToItem.item) {
191
+ if (allItems.length < this.maxItemCount) {
192
+ this.virtualizedItemsSubject.next(allItems);
193
+ }
194
+ else {
195
+ const itemIndex = allItems.findIndex((i) =>
196
+ // @ts-expect-error TODO: do we know a better typing here?
197
+ this.isEqual(i, jumpToItem.item));
198
+ if (itemIndex === -1) {
199
+ return;
200
+ }
201
+ else {
202
+ const position = jumpToItem.position || 'middle';
203
+ const numberOfItemsToRemove = allItems.length - Math.round(this.maxItemCount / 2);
204
+ const numberOfItemsAfterRemove = allItems.length - numberOfItemsToRemove;
205
+ let startIndex = -1;
206
+ let endIndex = -1;
207
+ switch (position) {
208
+ case 'top':
209
+ startIndex = itemIndex;
210
+ endIndex = Math.min(allItems.length, startIndex + numberOfItemsAfterRemove);
211
+ break;
212
+ case 'bottom':
213
+ endIndex = itemIndex + 1;
214
+ startIndex = Math.max(0, endIndex - numberOfItemsAfterRemove);
215
+ break;
216
+ case 'middle': {
217
+ const itemsOnTop = itemIndex;
218
+ const itemsOnBottom = allItems.length - itemIndex;
219
+ if (itemsOnTop < Math.ceil(numberOfItemsAfterRemove / 2)) {
220
+ startIndex = 0;
221
+ }
222
+ if (itemsOnBottom <
223
+ Math.floor(numberOfItemsAfterRemove / 2) + 1) {
224
+ endIndex = allItems.length;
225
+ }
226
+ if (startIndex === -1) {
227
+ if (endIndex !== -1) {
228
+ startIndex = endIndex - numberOfItemsAfterRemove;
229
+ }
230
+ else {
231
+ startIndex =
232
+ itemIndex - Math.ceil(numberOfItemsAfterRemove / 2);
233
+ }
234
+ }
235
+ if (endIndex === -1) {
236
+ endIndex = startIndex + numberOfItemsAfterRemove;
237
+ }
238
+ }
239
+ }
240
+ this.virtualizedItemsSubject.next(allItems.slice(startIndex, endIndex));
241
+ }
242
+ }
243
+ }
244
+ }));
245
+ }
246
+ }
247
+ /**
248
+ * The current value of virtualized items
249
+ */
250
+ get virtualizedItems() {
251
+ return this.virtualizedItemsSubject.getValue();
252
+ }
253
+ /**
254
+ * Remove all subscriptions, call this once you're done using an instance of this service
255
+ */
256
+ dispose() {
257
+ this.subscriptions.forEach((s) => s.unsubscribe());
258
+ }
259
+ loadMoreFromBuffer(_) {
260
+ this.loadFromBuffer$.next();
261
+ }
262
+ async loadMore(direction) {
263
+ this.queryStateSubject.next({ state: `loading-${direction}` });
264
+ try {
265
+ await this.query(direction);
266
+ this.queryStateSubject.next({ state: 'success' });
267
+ }
268
+ catch (e) {
269
+ this.queryStateSubject.next({ state: 'error', error: e });
270
+ }
271
+ }
272
+ }
273
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"virtualized-list.service.js","sourceRoot":"","sources":["../../../../projects/stream-chat-angular/src/lib/virtualized-list.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BehaviorSubject,\n  Observable,\n  Subject,\n  Subscription,\n  combineLatest,\n  distinctUntilChanged,\n  filter,\n  merge,\n  of,\n  pairwise,\n  switchMap,\n  take,\n} from 'rxjs';\nimport {\n  VirtualizedListQueryDirection,\n  VirtualizedListQueryState,\n  VirtualizedListScrollPosition,\n  VirtualizedListVerticalItemPosition,\n} from './types';\n\n/**\n * The `VirtualizedListService` removes items from a list that are not currently displayed. This is a high-level overview of how it works:\n * - Create a new instance for each list that needs virtualization\n * - Input: Provide a reactive stream that emits all items in the list\n * - Input: Provide a reactive stream that emit the current scroll position (top, middle or bottom)\n * - Input: maximum number of items that are allowed in the list (in practice the service can make the virtualized list half this number, you should take this into account when choosing the value)\n * - Output: The service will emit the current list of displayed items via the virtualized items reactive stream\n * - For simplicity, the service won't track the height of the items, nor it needs an exact scroll location -> this is how removing items work:\n *   - If scroll location is bottom/top items around the current bottom/top item will be emitted in the virtualized items stream\n *   - If scroll location is middle, the service won't remove items, if new items are received, those will be appended to the virtualized list  (this means that in theory the list can grow very big if a lot of new items are received while the user is scrolled somewhere, this is a trade-off for the simplicity of no height tracking)\n *   - Since there is no height tracking, you should make sure to provide a maximum number that is big enough to fill the biggest expected screen size twice\n * - If the user scrolls to the bottom/top and there are no more local items to show, the service will trigger a query to load more items\n *   - Input: you should provide the page size to use, in order for the service to determine if loading is necessary\n *\n * The `VirtualizedMessageListService` provides an implementation for the message list component.\n */\nexport abstract class VirtualizedListService<T> {\n  /**\n   * The items that should be currently displayed, a subset of all items\n   */\n  virtualizedItems$: Observable<T[]>;\n  /**\n   * The result of the last query used to load more items\n   */\n  queryState$: Observable<VirtualizedListQueryState>;\n  protected queryStateSubject = new BehaviorSubject<VirtualizedListQueryState>({\n    state: 'success',\n  });\n  protected bufferOnTop = 0;\n  protected bufferOnBottom = 0;\n  protected loadFromBuffer$ = new Subject<void>();\n  private virtualizedItemsSubject = new BehaviorSubject<T[]>([]);\n  private subscriptions: Subscription[] = [];\n\n  constructor(\n    private allItems$: Observable<T[]>,\n    private scrollPosition$: Observable<VirtualizedListScrollPosition>,\n    public readonly jumpToItem$?: Observable<{\n      item: Partial<T> | undefined;\n      position?: VirtualizedListVerticalItemPosition;\n    }>,\n    public readonly pageSize = 25,\n    public readonly maxItemCount = pageSize * 4,\n  ) {\n    this.virtualizedItems$ = this.virtualizedItemsSubject.asObservable();\n    this.queryState$ = this.queryStateSubject.asObservable();\n    this.subscriptions.push(\n      this.virtualizedItems$.subscribe((virtaluzedItems) => {\n        this.allItems$.pipe(take(1)).subscribe((allItems) => {\n          if (virtaluzedItems.length === allItems.length) {\n            this.bufferOnTop = 0;\n            this.bufferOnBottom = 0;\n          } else if (virtaluzedItems.length === 0) {\n            this.bufferOnTop = allItems.length;\n            this.bufferOnBottom = 0;\n          } else {\n            this.bufferOnTop = allItems.indexOf(virtaluzedItems[0]);\n            this.bufferOnBottom =\n              allItems.length -\n              allItems.indexOf(virtaluzedItems[virtaluzedItems.length - 1]) -\n              1;\n          }\n        });\n      }),\n    );\n    this.subscriptions.push(\n      merge(this.allItems$, this.loadFromBuffer$)\n        .pipe(\n          switchMap(() => {\n            return combineLatest([\n              this.allItems$.pipe(take(1)),\n              this.scrollPosition$.pipe(take(1)),\n            ]);\n          }),\n        )\n        .subscribe(([items, scrollPosition]) => {\n          if (scrollPosition === 'middle') {\n            return;\n          }\n          const currentItems = this.virtualizedItemsSubject.getValue();\n          if (items.length <= this.maxItemCount) {\n            this.virtualizedItemsSubject.next(items);\n          } else {\n            let startIndex = 0;\n            let endIndex = undefined;\n            const numberOfItemsToRemove =\n              items.length - Math.round(this.maxItemCount / 2);\n            const numberOfItemsAfterRemove =\n              items.length - numberOfItemsToRemove;\n            switch (scrollPosition) {\n              case 'top':\n                if (currentItems.length > 0) {\n                  const middleIndex = items.findIndex((i) =>\n                    this.isEqual(i, currentItems[0]),\n                  );\n                  if (middleIndex !== -1) {\n                    startIndex = Math.max(\n                      0,\n                      middleIndex - Math.ceil(numberOfItemsAfterRemove / 2),\n                    );\n                    endIndex = startIndex + numberOfItemsAfterRemove;\n                  }\n                } else {\n                  endIndex = numberOfItemsAfterRemove;\n                }\n                break;\n              case 'bottom':\n                if (currentItems.length > 0) {\n                  const middleIndex = items.findIndex((i) =>\n                    this.isEqual(i, currentItems[currentItems.length - 1]),\n                  );\n                  if (middleIndex !== -1) {\n                    endIndex = Math.min(\n                      items.length,\n                      middleIndex +\n                        Math.floor(numberOfItemsAfterRemove / 2) +\n                        1,\n                    );\n                    startIndex = endIndex - numberOfItemsAfterRemove;\n                  }\n                } else {\n                  startIndex = items.length - numberOfItemsAfterRemove;\n                }\n                break;\n            }\n            const virtualizedItems = items.slice(startIndex, endIndex);\n            this.virtualizedItemsSubject.next(virtualizedItems);\n          }\n        }),\n    );\n    this.subscriptions.push(\n      this.scrollPosition$\n        .pipe(distinctUntilChanged())\n        .subscribe((position) => {\n          if (\n            this.queryStateSubject.getValue().state === `loading-${position}`\n          ) {\n            return;\n          }\n          if (position === 'top') {\n            if (this.bufferOnTop < this.pageSize) {\n              void this.loadMore(position);\n            } else {\n              this.loadMoreFromBuffer('top');\n            }\n          } else if (position === 'bottom') {\n            if (this.bufferOnBottom < this.pageSize) {\n              void this.loadMore(position);\n            } else {\n              this.loadMoreFromBuffer('bottom');\n            }\n          }\n        }),\n    );\n    this.subscriptions.push(\n      this.allItems$\n        .pipe(\n          pairwise(),\n          filter(() => {\n            let scrollPosition!: VirtualizedListScrollPosition;\n            this.scrollPosition$\n              .pipe(take(1))\n              .subscribe((s) => (scrollPosition = s));\n            return scrollPosition === 'middle';\n          }),\n        )\n        .subscribe(([prevItems, currentItems]) => {\n          if (\n            currentItems.length < this.maxItemCount ||\n            this.virtualizedItems.length === 0\n          ) {\n            this.virtualizedItemsSubject.next(currentItems);\n          } else {\n            const currentFirstItem = this.virtualizedItems[0];\n            const currentLastItem =\n              this.virtualizedItems[this.virtualizedItems.length - 1];\n            const prevStartIndex = prevItems.findIndex((i) =>\n              this.isEqual(i, currentFirstItem),\n            );\n            const prevEndIndex = prevItems.findIndex((i) =>\n              this.isEqual(i, currentLastItem),\n            );\n\n            const isStartRemainedSame = currentItems[prevStartIndex]\n              ? this.isEqual(currentItems[prevStartIndex], currentFirstItem)\n              : false;\n            const isEndRemainedSame = currentItems[prevEndIndex]\n              ? this.isEqual(currentItems[prevEndIndex], currentLastItem)\n              : false;\n\n            const hasNewItemsBottom =\n              prevEndIndex === prevItems.length - 1 && isEndRemainedSame\n                ? prevItems.length !== currentItems.length\n                : false;\n\n            if (isStartRemainedSame && isEndRemainedSame) {\n              const endIndex = hasNewItemsBottom ? undefined : prevEndIndex + 1;\n              this.virtualizedItemsSubject.next(\n                currentItems.slice(prevStartIndex, endIndex),\n              );\n            }\n\n            let currentStartIndex = isStartRemainedSame ? prevStartIndex : -1;\n            let currentEndIndex = isEndRemainedSame ? prevEndIndex : -1;\n\n            if (!isStartRemainedSame) {\n              currentStartIndex = currentItems.findIndex((i) =>\n                this.isEqual(i, currentFirstItem),\n              );\n            }\n            if (!isEndRemainedSame) {\n              currentEndIndex = currentItems.findIndex((i) =>\n                this.isEqual(i, currentLastItem),\n              );\n            }\n\n            const hasNewItemsTop =\n              prevStartIndex === 0 && !isStartRemainedSame\n                ? currentStartIndex !== 0\n                : false;\n\n            if (currentStartIndex !== -1 && currentEndIndex !== -1) {\n              const startIndex = hasNewItemsTop ? 0 : currentStartIndex;\n              this.virtualizedItemsSubject.next(\n                currentItems.slice(startIndex, currentEndIndex + 1),\n              );\n            } else {\n              if (currentStartIndex === -1 && currentEndIndex !== -1) {\n                currentStartIndex = Math.max(\n                  0,\n                  currentEndIndex - (prevEndIndex - prevStartIndex),\n                );\n              }\n\n              if (currentEndIndex === -1 && currentStartIndex !== -1) {\n                currentEndIndex = Math.min(\n                  currentItems.length - 1,\n                  currentStartIndex + (prevEndIndex - prevStartIndex),\n                );\n              }\n\n              this.virtualizedItemsSubject.next(\n                currentItems.slice(currentStartIndex, currentEndIndex + 1),\n              );\n            }\n          }\n        }),\n    );\n    if (this.jumpToItem$) {\n      this.subscriptions.push(\n        this.jumpToItem$\n          .pipe(\n            switchMap((jumpToItem) =>\n              combineLatest([this.allItems$.pipe(take(1)), of(jumpToItem)]),\n            ),\n          )\n          .subscribe(([allItems, jumpToItem]) => {\n            if (jumpToItem.item) {\n              if (allItems.length < this.maxItemCount) {\n                this.virtualizedItemsSubject.next(allItems);\n              } else {\n                const itemIndex = allItems.findIndex((i) =>\n                  // @ts-expect-error TODO: do we know a better typing here?\n                  this.isEqual(i, jumpToItem.item),\n                );\n                if (itemIndex === -1) {\n                  return;\n                } else {\n                  const position = jumpToItem.position || 'middle';\n                  const numberOfItemsToRemove =\n                    allItems.length - Math.round(this.maxItemCount / 2);\n                  const numberOfItemsAfterRemove =\n                    allItems.length - numberOfItemsToRemove;\n                  let startIndex = -1;\n                  let endIndex = -1;\n\n                  switch (position) {\n                    case 'top':\n                      startIndex = itemIndex;\n                      endIndex = Math.min(\n                        allItems.length,\n                        startIndex + numberOfItemsAfterRemove,\n                      );\n                      break;\n                    case 'bottom':\n                      endIndex = itemIndex + 1;\n                      startIndex = Math.max(\n                        0,\n                        endIndex - numberOfItemsAfterRemove,\n                      );\n                      break;\n                    case 'middle': {\n                      const itemsOnTop = itemIndex;\n                      const itemsOnBottom = allItems.length - itemIndex;\n                      if (\n                        itemsOnTop < Math.ceil(numberOfItemsAfterRemove / 2)\n                      ) {\n                        startIndex = 0;\n                      }\n                      if (\n                        itemsOnBottom <\n                        Math.floor(numberOfItemsAfterRemove / 2) + 1\n                      ) {\n                        endIndex = allItems.length;\n                      }\n\n                      if (startIndex === -1) {\n                        if (endIndex !== -1) {\n                          startIndex = endIndex - numberOfItemsAfterRemove;\n                        } else {\n                          startIndex =\n                            itemIndex - Math.ceil(numberOfItemsAfterRemove / 2);\n                        }\n                      }\n\n                      if (endIndex === -1) {\n                        endIndex = startIndex + numberOfItemsAfterRemove;\n                      }\n                    }\n                  }\n\n                  this.virtualizedItemsSubject.next(\n                    allItems.slice(startIndex, endIndex),\n                  );\n                }\n              }\n            }\n          }),\n      );\n    }\n  }\n\n  /**\n   * The current value of virtualized items\n   */\n  get virtualizedItems() {\n    return this.virtualizedItemsSubject.getValue();\n  }\n\n  /**\n   * Remove all subscriptions, call this once you're done using an instance of this service\n   */\n  dispose() {\n    this.subscriptions.forEach((s) => s.unsubscribe());\n  }\n\n  protected loadMoreFromBuffer(_: VirtualizedListQueryDirection) {\n    this.loadFromBuffer$.next();\n  }\n\n  private async loadMore(direction: VirtualizedListQueryDirection) {\n    this.queryStateSubject.next({ state: `loading-${direction}` });\n    try {\n      await this.query(direction);\n      this.queryStateSubject.next({ state: 'success' });\n    } catch (e) {\n      this.queryStateSubject.next({ state: 'error', error: e });\n    }\n  }\n\n  protected abstract isEqual: (t1: T, t2: T) => boolean;\n\n  protected abstract query: (\n    direction: VirtualizedListQueryDirection,\n  ) => Promise<unknown>;\n}\n"]}
@@ -70,4 +70,4 @@ export class VirtualizedMessageListService extends VirtualizedListService {
70
70
  });
71
71
  }
72
72
  }
73
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"virtualized-message-list.service.js","sourceRoot":"","sources":["../../../../projects/stream-chat-angular/src/lib/virtualized-message-list.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChannelService } from './channel.service';\nimport {\n  VirtualizedListQueryDirection,\n  VirtualizedListScrollPosition,\n  StreamMessage,\n  VirtualizedListVerticalItemPosition,\n} from './types';\nimport { map, Observable } from 'rxjs';\nimport { VirtualizedListService } from './virtualized-list.service';\n\n/**\n * The `VirtualizedMessageListService` removes messages from the message list that are currently not in view\n */\nexport class VirtualizedMessageListService extends VirtualizedListService<StreamMessage> {\n  constructor(\n    public readonly mode: 'thread' | 'main',\n    scrollPosition$: Observable<VirtualizedListScrollPosition>,\n    private channelService: ChannelService\n  ) {\n    const jumpToMessage$ = channelService.jumpToMessage$.pipe(\n      map<\n        { id?: string; parentId?: string },\n        {\n          item: Partial<StreamMessage> | undefined;\n          position?: VirtualizedListVerticalItemPosition;\n        }\n      >((jumpToMessage) => {\n        let result: {\n          item: Partial<StreamMessage> | undefined;\n          position?: VirtualizedListVerticalItemPosition;\n        } = {\n          item: undefined,\n        };\n        let targetMessageId: string | undefined;\n        if (mode === 'main') {\n          targetMessageId = jumpToMessage.parentId\n            ? jumpToMessage.parentId\n            : jumpToMessage.id;\n        } else {\n          targetMessageId = jumpToMessage.parentId\n            ? jumpToMessage.id\n            : undefined;\n        }\n\n        if (targetMessageId) {\n          const messages =\n            mode === 'main'\n              ? channelService.activeChannelMessages\n              : channelService.activeChannelThreadReplies;\n          const id =\n            targetMessageId === 'latest'\n              ? messages[messages.length - 1]?.id\n              : targetMessageId;\n          if (id) {\n            result = {\n              item: { id },\n              position: jumpToMessage.id === 'latest' ? 'bottom' : 'middle',\n            };\n          }\n          channelService.clearMessageJump();\n        }\n\n        return result;\n      })\n    );\n    const messages$ =\n      mode === 'main'\n        ? channelService.activeChannelMessages$\n        : channelService.activeThreadMessages$;\n    super(\n      messages$,\n      scrollPosition$,\n      jumpToMessage$,\n      channelService.messagePageSize\n    );\n  }\n\n  protected loadMoreFromBuffer(direction: VirtualizedListQueryDirection): void {\n    this.queryStateSubject.next({ state: `loading-${direction}` });\n    setTimeout(() => {\n      this.loadFromBuffer$.next();\n      this.queryStateSubject.next({ state: 'success' });\n    });\n  }\n\n  protected isEqual = (t1: StreamMessage, t2: StreamMessage) => t1.id === t2.id;\n\n  protected query = (direction: VirtualizedListQueryDirection) => {\n    const request =\n      this.mode === 'main'\n        ? (direction: 'older' | 'newer') =>\n            this.channelService.loadMoreMessages(direction)\n        : (direction: 'older' | 'newer') =>\n            this.channelService.loadMoreThreadReplies(direction);\n    const result = request(direction === 'top' ? 'older' : 'newer');\n    if (result) {\n      return result;\n    } else {\n      this.queryStateSubject.next({ state: 'success' });\n      if (\n        (direction === 'top' && this.bufferOnTop > 0) ||\n        (direction === 'bottom' && this.bufferOnBottom > 0)\n      ) {\n        this.loadFromBuffer$.next();\n      }\n      return Promise.resolve();\n    }\n  };\n}\n"]}
73
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"virtualized-message-list.service.js","sourceRoot":"","sources":["../../../../projects/stream-chat-angular/src/lib/virtualized-message-list.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChannelService } from './channel.service';\nimport {\n  VirtualizedListQueryDirection,\n  VirtualizedListScrollPosition,\n  StreamMessage,\n  VirtualizedListVerticalItemPosition,\n} from './types';\nimport { map, Observable } from 'rxjs';\nimport { VirtualizedListService } from './virtualized-list.service';\n\n/**\n * The `VirtualizedMessageListService` removes messages from the message list that are currently not in view\n */\nexport class VirtualizedMessageListService extends VirtualizedListService<StreamMessage> {\n  constructor(\n    public readonly mode: 'thread' | 'main',\n    scrollPosition$: Observable<VirtualizedListScrollPosition>,\n    private channelService: ChannelService,\n  ) {\n    const jumpToMessage$ = channelService.jumpToMessage$.pipe(\n      map<\n        { id?: string; parentId?: string },\n        {\n          item: Partial<StreamMessage> | undefined;\n          position?: VirtualizedListVerticalItemPosition;\n        }\n      >((jumpToMessage) => {\n        let result: {\n          item: Partial<StreamMessage> | undefined;\n          position?: VirtualizedListVerticalItemPosition;\n        } = {\n          item: undefined,\n        };\n        let targetMessageId: string | undefined;\n        if (mode === 'main') {\n          targetMessageId = jumpToMessage.parentId\n            ? jumpToMessage.parentId\n            : jumpToMessage.id;\n        } else {\n          targetMessageId = jumpToMessage.parentId\n            ? jumpToMessage.id\n            : undefined;\n        }\n\n        if (targetMessageId) {\n          const messages =\n            mode === 'main'\n              ? channelService.activeChannelMessages\n              : channelService.activeChannelThreadReplies;\n          const id =\n            targetMessageId === 'latest'\n              ? messages[messages.length - 1]?.id\n              : targetMessageId;\n          if (id) {\n            result = {\n              item: { id },\n              position: jumpToMessage.id === 'latest' ? 'bottom' : 'middle',\n            };\n          }\n          channelService.clearMessageJump();\n        }\n\n        return result;\n      }),\n    );\n    const messages$ =\n      mode === 'main'\n        ? channelService.activeChannelMessages$\n        : channelService.activeThreadMessages$;\n    super(\n      messages$,\n      scrollPosition$,\n      jumpToMessage$,\n      channelService.messagePageSize,\n    );\n  }\n\n  protected loadMoreFromBuffer(direction: VirtualizedListQueryDirection): void {\n    this.queryStateSubject.next({ state: `loading-${direction}` });\n    setTimeout(() => {\n      this.loadFromBuffer$.next();\n      this.queryStateSubject.next({ state: 'success' });\n    });\n  }\n\n  protected isEqual = (t1: StreamMessage, t2: StreamMessage) => t1.id === t2.id;\n\n  protected query = (direction: VirtualizedListQueryDirection) => {\n    const request =\n      this.mode === 'main'\n        ? (direction: 'older' | 'newer') =>\n            this.channelService.loadMoreMessages(direction)\n        : (direction: 'older' | 'newer') =>\n            this.channelService.loadMoreThreadReplies(direction);\n    const result = request(direction === 'top' ? 'older' : 'newer');\n    if (result) {\n      return result;\n    } else {\n      this.queryStateSubject.next({ state: 'success' });\n      if (\n        (direction === 'top' && this.bufferOnTop > 0) ||\n        (direction === 'bottom' && this.bufferOnBottom > 0)\n      ) {\n        this.loadFromBuffer$.next();\n      }\n      return Promise.resolve();\n    }\n  };\n}\n"]}