stream-chat-angular 1.4.2 → 2.0.0

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 (44) hide show
  1. package/assets/version.d.ts +1 -1
  2. package/bundles/stream-chat-angular.umd.js +508 -51
  3. package/bundles/stream-chat-angular.umd.js.map +1 -1
  4. package/esm2015/assets/version.js +2 -2
  5. package/esm2015/lib/channel.service.js +29 -3
  6. package/esm2015/lib/chat-client.service.js +16 -1
  7. package/esm2015/lib/injection-tokens.js +3 -0
  8. package/esm2015/lib/message/highlight-mentions.pipe.js +23 -0
  9. package/esm2015/lib/message/message.component.js +3 -2
  10. package/esm2015/lib/message-actions-box/message-actions-box.component.js +2 -2
  11. package/esm2015/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.js +145 -0
  12. package/esm2015/lib/message-input/message-input-config.service.js +3 -1
  13. package/esm2015/lib/message-input/message-input.component.js +52 -19
  14. package/esm2015/lib/message-input/textarea/textarea.component.js +42 -0
  15. package/esm2015/lib/message-input/textarea.directive.js +69 -0
  16. package/esm2015/lib/message-input/textarea.interface.js +2 -0
  17. package/esm2015/lib/message-preview.js +3 -2
  18. package/esm2015/lib/stream-autocomplete-textarea.module.js +33 -0
  19. package/esm2015/lib/stream-avatar.module.js +19 -0
  20. package/esm2015/lib/stream-chat.module.js +15 -11
  21. package/esm2015/lib/stream-textarea.module.js +31 -0
  22. package/esm2015/lib/types.js +1 -1
  23. package/esm2015/public-api.js +9 -1
  24. package/fesm2015/stream-chat-angular.js +454 -50
  25. package/fesm2015/stream-chat-angular.js.map +1 -1
  26. package/lib/channel.service.d.ts +3 -2
  27. package/lib/chat-client.service.d.ts +1 -0
  28. package/lib/injection-tokens.d.ts +3 -0
  29. package/lib/message/highlight-mentions.pipe.d.ts +8 -0
  30. package/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.d.ts +42 -0
  31. package/lib/message-input/message-input-config.service.d.ts +5 -0
  32. package/lib/message-input/message-input.component.d.ts +18 -7
  33. package/lib/message-input/textarea/textarea.component.d.ts +16 -0
  34. package/lib/message-input/textarea.directive.d.ts +21 -0
  35. package/lib/message-input/textarea.interface.d.ts +12 -0
  36. package/lib/message-preview.d.ts +1 -1
  37. package/lib/stream-autocomplete-textarea.module.d.ts +11 -0
  38. package/lib/stream-avatar.module.d.ts +9 -0
  39. package/lib/stream-chat.module.d.ts +23 -21
  40. package/lib/stream-textarea.module.d.ts +9 -0
  41. package/lib/types.d.ts +7 -1
  42. package/package.json +2 -1
  43. package/public-api.d.ts +8 -0
  44. package/src/assets/version.ts +1 -1
@@ -1,2 +1,2 @@
1
- export const version = '1.4.2';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2Fzc2V0cy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgdmVyc2lvbiA9ICcxLjQuMic7XG4iXX0=
1
+ export const version = '2.0.0';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2Fzc2V0cy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgdmVyc2lvbiA9ICcyLjAuMCc7XG4iXX0=
@@ -108,9 +108,9 @@ export class ChannelService {
108
108
  .getValue()) === null || _a === void 0 ? void 0 : _a.deleteReaction(messageId, reactionType));
109
109
  });
110
110
  }
111
- sendMessage(text, attachments = []) {
111
+ sendMessage(text, attachments = [], mentionedUsers = []) {
112
112
  return __awaiter(this, void 0, void 0, function* () {
113
- const preview = createMessagePreview(this.chatClientService.chatClient.user, text, attachments);
113
+ const preview = createMessagePreview(this.chatClientService.chatClient.user, text, attachments, mentionedUsers);
114
114
  const channel = this.activeChannelSubject.getValue();
115
115
  preview.readBy = [];
116
116
  channel.state.addMessageSorted(preview, true);
@@ -167,7 +167,32 @@ export class ChannelService {
167
167
  : channel.deleteFile(attachmentUpload.url));
168
168
  });
169
169
  }
170
+ autocompleteMembers(searchTerm) {
171
+ return __awaiter(this, void 0, void 0, function* () {
172
+ const activeChannel = this.activeChannelSubject.getValue();
173
+ if (!activeChannel) {
174
+ return [];
175
+ }
176
+ if (Object.keys(activeChannel.state.members).length <= 100) {
177
+ return Object.values(activeChannel.state.members).filter((m) => { var _a; return ((_a = m.user) === null || _a === void 0 ? void 0 : _a.id) !== this.chatClientService.chatClient.userID; });
178
+ }
179
+ else {
180
+ if (!searchTerm) {
181
+ return [];
182
+ }
183
+ const result = yield activeChannel.queryMembers({
184
+ $or: [
185
+ { id: { $autocomplete: searchTerm } },
186
+ { name: { $autocomplete: searchTerm } },
187
+ ],
188
+ id: { $ne: this.chatClientService.chatClient.userID },
189
+ });
190
+ return Object.values(result.members);
191
+ }
192
+ });
193
+ }
170
194
  sendMessageRequest(preview) {
195
+ var _a;
171
196
  return __awaiter(this, void 0, void 0, function* () {
172
197
  const channel = this.activeChannelSubject.getValue();
173
198
  this.activeChannelMessagesSubject.next([...channel.state.messages]);
@@ -175,6 +200,7 @@ export class ChannelService {
175
200
  yield channel.sendMessage({
176
201
  text: preview.text,
177
202
  attachments: preview.attachments,
203
+ mentioned_users: (_a = preview.mentioned_users) === null || _a === void 0 ? void 0 : _a.map((u) => u.id),
178
204
  id: preview.id,
179
205
  });
180
206
  }
@@ -473,4 +499,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
473
499
  providedIn: 'root',
474
500
  }]
475
501
  }], ctorParameters: function () { return [{ type: i1.ChatClientService }, { type: i0.ApplicationRef }, { type: i0.NgZone }]; } });
476
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"channel.service.js","sourceRoot":"","sources":["../../../../projects/stream-chat-angular/src/lib/channel.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ApplicationRef, Injectable, NgZone } from '@angular/core';\nimport { BehaviorSubject, Observable, ReplaySubject } from 'rxjs';\nimport { first, map } from 'rxjs/operators';\nimport {\n  Attachment,\n  Channel,\n  ChannelFilters,\n  ChannelOptions,\n  ChannelSort,\n  Event,\n  FormatMessageResponse,\n  MessageResponse,\n  UpdatedMessage,\n} from 'stream-chat';\nimport { ChatClientService, Notification } from './chat-client.service';\nimport { createMessagePreview } from './message-preview';\nimport { MessageReactionType } from './message-reactions/message-reactions.component';\nimport { getReadBy } from './read-by';\nimport { AttachmentUpload, StreamMessage } from './types';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class ChannelService {\n  hasMoreChannels$: Observable<boolean>;\n  channels$: Observable<Channel[] | undefined>;\n  activeChannel$: Observable<Channel | undefined>;\n  activeChannelMessages$: Observable<StreamMessage[]>;\n  customNewMessageNotificationHandler?: (\n    notification: Notification,\n    channelListSetter: (channels: Channel[]) => void\n  ) => void;\n  customAddedToChannelNotificationHandler?: (\n    notification: Notification,\n    channelListSetter: (channels: Channel[]) => void\n  ) => void;\n  customRemovedFromChannelNotificationHandler?: (\n    notification: Notification,\n    channelListSetter: (channels: Channel[]) => void\n  ) => void;\n  customChannelDeletedHandler?: (\n    event: Event,\n    channel: Channel,\n    channelListSetter: (channels: Channel[]) => void,\n    messageListSetter: (messages: StreamMessage[]) => void\n  ) => void;\n  customChannelUpdatedHandler?: (\n    event: Event,\n    channel: Channel,\n    channelListSetter: (channels: Channel[]) => void,\n    messageListSetter: (messages: StreamMessage[]) => void\n  ) => void;\n  customChannelTruncatedHandler?: (\n    event: Event,\n    channel: Channel,\n    channelListSetter: (channels: Channel[]) => void,\n    messageListSetter: (messages: StreamMessage[]) => void\n  ) => void;\n  customChannelHiddenHandler?: (\n    event: Event,\n    channel: Channel,\n    channelListSetter: (channels: Channel[]) => void,\n    messageListSetter: (messages: StreamMessage[]) => void\n  ) => void;\n  customChannelVisibleHandler?: (\n    event: Event,\n    channel: Channel,\n    channelListSetter: (channels: Channel[]) => void,\n    messageListSetter: (messages: StreamMessage[]) => void\n  ) => void;\n  customNewMessageHandler?: (\n    event: Event,\n    channel: Channel,\n    channelListSetter: (channels: Channel[]) => void,\n    messageListSetter: (messages: StreamMessage[]) => void\n  ) => void;\n  private channelsSubject = new BehaviorSubject<Channel[] | undefined>(\n    undefined\n  );\n  private activeChannelSubject = new BehaviorSubject<Channel | undefined>(\n    undefined\n  );\n  private activeChannelMessagesSubject = new BehaviorSubject<\n    (StreamMessage | MessageResponse | FormatMessageResponse)[]\n  >([]);\n  private hasMoreChannelsSubject = new ReplaySubject<boolean>(1);\n  private activeChannelSubscriptions: { unsubscribe: () => void }[] = [];\n  private filters: ChannelFilters | undefined;\n  private sort: ChannelSort | undefined;\n  private options: ChannelOptions | undefined;\n\n  private channelListSetter = (channels: Channel[]) => {\n    this.channelsSubject.next(channels);\n  };\n\n  private messageListSetter = (messages: StreamMessage[]) => {\n    this.activeChannelMessagesSubject.next(messages);\n  };\n\n  constructor(\n    private chatClientService: ChatClientService,\n    private appRef: ApplicationRef,\n    private ngZone: NgZone\n  ) {\n    this.channels$ = this.channelsSubject.asObservable();\n    this.activeChannel$ = this.activeChannelSubject.asObservable();\n    this.activeChannelMessages$ = this.activeChannelMessagesSubject.pipe(\n      map((messages) => {\n        const channel = this.activeChannelSubject.getValue()!;\n        return messages.map((message) => {\n          if (\n            this.isStreamMessage(message) &&\n            this.isFormatMessageResponse(message)\n          ) {\n            return message;\n          } else if (this.isFormatMessageResponse(message)) {\n            return { ...message, readBy: getReadBy(message, channel) };\n          } else {\n            const formatMessage = this.formatMessage(message);\n            return {\n              ...formatMessage,\n              readBy: getReadBy(formatMessage, channel),\n            };\n          }\n        });\n      })\n    );\n    this.hasMoreChannels$ = this.hasMoreChannelsSubject.asObservable();\n  }\n\n  setAsActiveChannel(channel: Channel) {\n    const prevActiveChannel = this.activeChannelSubject.getValue();\n    this.stopWatchForActiveChannelEvents(prevActiveChannel);\n    this.watchForActiveChannelEvents(channel);\n    this.activeChannelSubject.next(channel);\n    channel.state.messages.forEach((m) => {\n      m.readBy = getReadBy(m, channel);\n    });\n    void channel.markRead();\n    this.activeChannelMessagesSubject.next([...channel.state.messages]);\n  }\n\n  async loadMoreMessages() {\n    const activeChnannel = this.activeChannelSubject.getValue();\n    const lastMessageId = this.activeChannelMessagesSubject.getValue()[0]?.id;\n    await activeChnannel?.query({\n      messages: { limit: 25, id_lt: lastMessageId },\n      members: { limit: 0 },\n      watchers: { limit: 0 },\n    });\n    if (\n      activeChnannel?.data?.id ===\n      this.activeChannelSubject.getValue()?.data?.id\n    ) {\n      this.activeChannelMessagesSubject.next([\n        ...activeChnannel!.state.messages,\n      ]);\n    }\n  }\n\n  async init(\n    filters: ChannelFilters,\n    sort?: ChannelSort,\n    options?: ChannelOptions\n  ) {\n    this.filters = filters;\n    this.options = options || {\n      offset: 0,\n      limit: 25,\n      state: true,\n      presence: true,\n      watch: true,\n      message_limit: 25,\n    };\n    this.sort = sort || { last_message_at: -1, updated_at: -1 };\n    await this.queryChannels();\n    this.chatClientService.notification$.subscribe(\n      (notification) => void this.handleNotification(notification)\n    );\n  }\n\n  async loadMoreChannels() {\n    this.options!.offset = this.channels.length!;\n    await this.queryChannels();\n  }\n\n  async addReaction(messageId: string, reactionType: MessageReactionType) {\n    await this.activeChannelSubject.getValue()?.sendReaction(messageId, {\n      type: reactionType,\n    });\n  }\n\n  async removeReaction(messageId: string, reactionType: MessageReactionType) {\n    await this.activeChannelSubject\n      .getValue()\n      ?.deleteReaction(messageId, reactionType);\n  }\n\n  async sendMessage(text: string, attachments: Attachment[] = []) {\n    const preview = createMessagePreview(\n      this.chatClientService.chatClient.user!,\n      text,\n      attachments\n    );\n    const channel = this.activeChannelSubject.getValue()!;\n    preview.readBy = [];\n    channel.state.addMessageSorted(preview, true);\n    await this.sendMessageRequest(preview);\n  }\n\n  async resendMessage(message: StreamMessage) {\n    const channel = this.activeChannelSubject.getValue()!;\n    channel.state.addMessageSorted(\n      {\n        ...(message as any as MessageResponse),\n        errorStatusCode: undefined,\n        status: 'sending',\n      },\n      true\n    );\n    await this.sendMessageRequest(message);\n  }\n\n  async updateMessage(message: StreamMessage) {\n    await this.chatClientService.chatClient.updateMessage(\n      message as UpdatedMessage\n    );\n  }\n\n  async deleteMessage(message: StreamMessage) {\n    await this.chatClientService.chatClient.deleteMessage(message.id);\n  }\n\n  async uploadAttachments(\n    uploads: AttachmentUpload[]\n  ): Promise<AttachmentUpload[]> {\n    const result: AttachmentUpload[] = [];\n    const channel = this.activeChannelSubject.getValue()!;\n    const uploadResults = await Promise.allSettled(\n      uploads.map((upload) =>\n        upload.type === 'image'\n          ? channel.sendImage(upload.file)\n          : channel.sendFile(upload.file)\n      )\n    );\n    uploadResults.forEach((uploadResult, i) => {\n      const file = uploads[i].file;\n      const type = uploads[i].type;\n      if (uploadResult.status === 'fulfilled') {\n        result.push({\n          file,\n          type,\n          state: 'success',\n          url: uploadResult.value.file,\n        });\n      } else {\n        result.push({ file, type, state: 'error' });\n      }\n    });\n\n    return result;\n  }\n\n  async deleteAttachment(attachmentUpload: AttachmentUpload) {\n    const channel = this.activeChannelSubject.getValue()!;\n    await (attachmentUpload.type === 'image'\n      ? channel.deleteImage(attachmentUpload.url!)\n      : channel.deleteFile(attachmentUpload.url!));\n  }\n\n  private async sendMessageRequest(preview: MessageResponse | StreamMessage) {\n    const channel = this.activeChannelSubject.getValue()!;\n    this.activeChannelMessagesSubject.next([...channel.state.messages]);\n    try {\n      await channel.sendMessage({\n        text: preview.text,\n        attachments: preview.attachments,\n        id: preview.id,\n      });\n    } catch (error) {\n      const stringError = JSON.stringify(error);\n      const parsedError: { status?: number } = stringError\n        ? (JSON.parse(stringError) as { status?: number })\n        : {};\n\n      channel.state.addMessageSorted(\n        {\n          ...(preview as MessageResponse),\n          errorStatusCode: parsedError.status || undefined,\n          status: 'failed',\n        },\n        true\n      );\n      this.activeChannelMessagesSubject.next([...channel.state.messages]);\n    }\n  }\n\n  private async handleNotification(notification: Notification) {\n    switch (notification.eventType) {\n      case 'notification.message_new': {\n        if (this.customNewMessageNotificationHandler) {\n          this.customNewMessageNotificationHandler(\n            notification,\n            this.channelListSetter\n          );\n        } else {\n          await this.handleNewMessageNotification(notification);\n        }\n        break;\n      }\n      case 'notification.added_to_channel': {\n        if (this.customAddedToChannelNotificationHandler) {\n          this.customAddedToChannelNotificationHandler(\n            notification,\n            this.channelListSetter\n          );\n        } else {\n          await this.handleAddedToChannelNotification(notification);\n        }\n        break;\n      }\n      case 'notification.removed_from_channel': {\n        if (this.customRemovedFromChannelNotificationHandler) {\n          this.customRemovedFromChannelNotificationHandler(\n            notification,\n            this.channelListSetter\n          );\n        } else {\n          this.handleRemovedFromChannelNotification(notification);\n        }\n      }\n    }\n  }\n\n  private handleRemovedFromChannelNotification(notification: Notification) {\n    this.ngZone.run(() => {\n      const channelIdToBeRemoved = notification.event.channel!.cid;\n      this.removeFromChannelList(channelIdToBeRemoved);\n    });\n  }\n\n  private async handleNewMessageNotification(notification: Notification) {\n    await this.addChannelFromNotification(notification);\n  }\n\n  private async handleAddedToChannelNotification(notification: Notification) {\n    await this.addChannelFromNotification(notification);\n  }\n\n  private async addChannelFromNotification(notification: Notification) {\n    const channel = this.chatClientService.chatClient.channel(\n      notification.event.channel?.type!,\n      notification.event.channel?.id\n    );\n    await channel.watch();\n    this.watchForChannelEvents(channel);\n    this.ngZone.run(() => {\n      this.channelsSubject.next([\n        channel,\n        ...(this.channelsSubject.getValue() || []),\n      ]);\n    });\n  }\n\n  private removeFromChannelList(cid: string) {\n    const channels = this.channels.filter((c) => c.cid !== cid);\n    if (channels.length < this.channels.length) {\n      this.channelsSubject.next(channels);\n      if (this.activeChannelSubject.getValue()!.cid === cid) {\n        this.setAsActiveChannel(channels[0]);\n      }\n    }\n  }\n\n  private watchForActiveChannelEvents(channel: Channel) {\n    this.activeChannelSubscriptions.push(\n      channel.on('message.new', () => {\n        this.ngZone.run(() => {\n          this.activeChannelMessagesSubject.next([...channel.state.messages]);\n          this.activeChannel$\n            .pipe(first())\n            .subscribe((c) => void c?.markRead());\n        });\n      })\n    );\n    this.activeChannelSubscriptions.push(\n      channel.on('message.updated', (event) => this.messageUpdated(event))\n    );\n    this.activeChannelSubscriptions.push(\n      channel.on('message.deleted', (event) => this.messageUpdated(event))\n    );\n    this.activeChannelSubscriptions.push(\n      channel.on('reaction.new', (e) => this.messageReactionEventReceived(e))\n    );\n    this.activeChannelSubscriptions.push(\n      channel.on('reaction.deleted', (e) =>\n        this.messageReactionEventReceived(e)\n      )\n    );\n    this.activeChannelSubscriptions.push(\n      channel.on('reaction.updated', (e) =>\n        this.messageReactionEventReceived(e)\n      )\n    );\n    this.activeChannelSubscriptions.push(\n      channel.on('message.read', (e) => {\n        let latestMessage!: StreamMessage;\n        this.activeChannelMessages$.pipe(first()).subscribe((messages) => {\n          latestMessage = messages[messages.length - 1];\n        });\n        if (!latestMessage || !e.user) {\n          return;\n        }\n        latestMessage.readBy = getReadBy(latestMessage, channel);\n\n        this.activeChannelMessagesSubject.next(\n          this.activeChannelMessagesSubject.getValue()\n        );\n      })\n    );\n  }\n\n  private messageUpdated(event: Event) {\n    this.ngZone.run(() => {\n      const messages = this.activeChannelMessagesSubject.getValue();\n      const messageIndex = messages.findIndex(\n        (m) => m.id === event.message?.id\n      );\n      if (messageIndex !== -1 && event.message) {\n        messages[messageIndex] = event.message;\n        this.activeChannelMessagesSubject.next([...messages]);\n      }\n    });\n  }\n\n  private messageReactionEventReceived(e: Event) {\n    this.ngZone.run(() => {\n      let messages!: StreamMessage[];\n      this.activeChannelMessages$\n        .pipe(first())\n        .subscribe((m) => (messages = m));\n      const message = messages.find((m) => m.id === e?.message?.id);\n      if (!message) {\n        return;\n      }\n      message.reaction_counts = { ...e.message?.reaction_counts };\n      message.reaction_scores = { ...e.message?.reaction_scores };\n      message.latest_reactions = [...(e.message?.latest_reactions || [])];\n      message.own_reactions = [...(e.message?.own_reactions || [])];\n      this.activeChannelMessagesSubject.next([...messages]);\n    });\n  }\n\n  private formatMessage(message: MessageResponse) {\n    return {\n      ...message,\n      // parse the date..\n      pinned_at: message.pinned_at ? new Date(message.pinned_at) : null,\n      created_at: message.created_at\n        ? new Date(message.created_at)\n        : new Date(),\n      updated_at: message.updated_at\n        ? new Date(message.updated_at)\n        : new Date(),\n      status: message.status || 'received',\n    };\n  }\n\n  private isStreamMessage(\n    message: StreamMessage | FormatMessageResponse | MessageResponse\n  ): message is StreamMessage {\n    return !!message.readBy;\n  }\n\n  private isFormatMessageResponse(\n    message: StreamMessage | FormatMessageResponse | MessageResponse\n  ): message is FormatMessageResponse {\n    return message.created_at instanceof Date;\n  }\n\n  private stopWatchForActiveChannelEvents(channel: Channel | undefined) {\n    if (!channel) {\n      return;\n    }\n    this.activeChannelSubscriptions.forEach((s) => s.unsubscribe());\n    this.activeChannelSubscriptions = [];\n  }\n\n  private async queryChannels() {\n    try {\n      const channels = await this.chatClientService.chatClient.queryChannels(\n        this.filters!,\n        this.sort,\n        this.options\n      );\n      channels.forEach((c) => this.watchForChannelEvents(c));\n      const prevChannels = this.channelsSubject.getValue() || [];\n      this.channelsSubject.next([...prevChannels, ...channels]);\n      if (channels.length > 0 && !this.activeChannelSubject.getValue()) {\n        this.setAsActiveChannel(channels[0]);\n      }\n      this.hasMoreChannelsSubject.next(channels.length >= this.options!.limit!);\n    } catch (error) {\n      this.channelsSubject.error(error);\n    }\n  }\n\n  private watchForChannelEvents(channel: Channel) {\n    channel.on((event: Event) => {\n      switch (event.type) {\n        case 'message.new': {\n          if (this.customNewMessageHandler) {\n            this.customNewMessageHandler(\n              event,\n              channel,\n              this.channelListSetter,\n              this.messageListSetter\n            );\n          } else {\n            this.handleNewMessage(event, channel);\n          }\n          break;\n        }\n        case 'channel.hidden': {\n          if (this.customChannelHiddenHandler) {\n            this.customChannelHiddenHandler(\n              event,\n              channel,\n              this.channelListSetter,\n              this.messageListSetter\n            );\n          } else {\n            this.handleChannelHidden(event);\n          }\n          this.appRef.tick();\n          break;\n        }\n        case 'channel.deleted': {\n          if (this.customChannelDeletedHandler) {\n            this.customChannelDeletedHandler(\n              event,\n              channel,\n              this.channelListSetter,\n              this.messageListSetter\n            );\n          } else {\n            this.handleChannelDeleted(event);\n          }\n          this.appRef.tick();\n          break;\n        }\n        case 'channel.visible': {\n          if (this.customChannelVisibleHandler) {\n            this.customChannelVisibleHandler(\n              event,\n              channel,\n              this.channelListSetter,\n              this.messageListSetter\n            );\n          } else {\n            this.handleChannelVisible(event, channel);\n          }\n          this.appRef.tick();\n          break;\n        }\n        case 'channel.updated': {\n          if (this.customChannelUpdatedHandler) {\n            this.customChannelUpdatedHandler(\n              event,\n              channel,\n              this.channelListSetter,\n              this.messageListSetter\n            );\n          } else {\n            this.handleChannelUpdate(event);\n          }\n          this.appRef.tick();\n          break;\n        }\n        case 'channel.truncated': {\n          if (this.customChannelTruncatedHandler) {\n            this.customChannelTruncatedHandler(\n              event,\n              channel,\n              this.channelListSetter,\n              this.messageListSetter\n            );\n          } else {\n            this.handleChannelTruncate(event);\n          }\n          this.appRef.tick();\n          break;\n        }\n      }\n      setTimeout(() => this.appRef.tick(), 0);\n    });\n  }\n\n  private handleNewMessage(_: Event, channel: Channel) {\n    const channelIndex = this.channels.findIndex((c) => c.cid === channel.cid);\n    this.channels.splice(channelIndex, 1);\n    this.channelsSubject.next([channel, ...this.channels]);\n  }\n\n  private handleChannelHidden(event: Event) {\n    this.removeFromChannelList(event.channel!.cid);\n  }\n\n  private handleChannelDeleted(event: Event) {\n    this.removeFromChannelList(event.channel!.cid);\n  }\n\n  private handleChannelVisible(event: Event, channel: Channel) {\n    if (!this.channels.find((c) => c.cid === event.cid)) {\n      this.ngZone.run(() =>\n        this.channelsSubject.next([...this.channels, channel])\n      );\n    }\n  }\n\n  private handleChannelUpdate(event: Event) {\n    const channelIndex = this.channels.findIndex(\n      (c) => c.cid === event.channel!.cid\n    );\n    if (channelIndex !== -1) {\n      this.channels[channelIndex].data = event.channel;\n      this.channelsSubject.next([...this.channels]);\n      if (event.channel?.cid === this.activeChannelSubject.getValue()?.cid) {\n        const channel = this.activeChannelSubject.getValue()!;\n        channel.data = event.channel;\n        this.activeChannelSubject.next(channel);\n      }\n    }\n  }\n\n  private handleChannelTruncate(event: Event) {\n    const channelIndex = this.channels.findIndex(\n      (c) => c.cid === event.channel!.cid\n    );\n    if (channelIndex !== -1) {\n      this.channels[channelIndex].state.messages = [];\n      this.channelsSubject.next([...this.channels]);\n      if (event.channel?.cid === this.activeChannelSubject.getValue()?.cid) {\n        const channel = this.activeChannelSubject.getValue()!;\n        channel.state.messages = [];\n        this.activeChannelSubject.next(channel);\n        this.activeChannelMessagesSubject.next([]);\n      }\n    }\n  }\n\n  private get channels() {\n    return this.channelsSubject.getValue() || [];\n  }\n}\n"]}
502
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"channel.service.js","sourceRoot":"","sources":["../../../../projects/stream-chat-angular/src/lib/channel.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ApplicationRef, Injectable, NgZone } from '@angular/core';\nimport { BehaviorSubject, Observable, ReplaySubject } from 'rxjs';\nimport { first, map } from 'rxjs/operators';\nimport {\n  Attachment,\n  Channel,\n  ChannelFilters,\n  ChannelOptions,\n  ChannelSort,\n  Event,\n  FormatMessageResponse,\n  MessageResponse,\n  UpdatedMessage,\n  UserResponse,\n} from 'stream-chat';\nimport { ChatClientService, Notification } from './chat-client.service';\nimport { createMessagePreview } from './message-preview';\nimport { MessageReactionType } from './message-reactions/message-reactions.component';\nimport { getReadBy } from './read-by';\nimport { AttachmentUpload, StreamMessage } from './types';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class ChannelService {\n  hasMoreChannels$: Observable<boolean>;\n  channels$: Observable<Channel[] | undefined>;\n  activeChannel$: Observable<Channel | undefined>;\n  activeChannelMessages$: Observable<StreamMessage[]>;\n  customNewMessageNotificationHandler?: (\n    notification: Notification,\n    channelListSetter: (channels: Channel[]) => void\n  ) => void;\n  customAddedToChannelNotificationHandler?: (\n    notification: Notification,\n    channelListSetter: (channels: Channel[]) => void\n  ) => void;\n  customRemovedFromChannelNotificationHandler?: (\n    notification: Notification,\n    channelListSetter: (channels: Channel[]) => void\n  ) => void;\n  customChannelDeletedHandler?: (\n    event: Event,\n    channel: Channel,\n    channelListSetter: (channels: Channel[]) => void,\n    messageListSetter: (messages: StreamMessage[]) => void\n  ) => void;\n  customChannelUpdatedHandler?: (\n    event: Event,\n    channel: Channel,\n    channelListSetter: (channels: Channel[]) => void,\n    messageListSetter: (messages: StreamMessage[]) => void\n  ) => void;\n  customChannelTruncatedHandler?: (\n    event: Event,\n    channel: Channel,\n    channelListSetter: (channels: Channel[]) => void,\n    messageListSetter: (messages: StreamMessage[]) => void\n  ) => void;\n  customChannelHiddenHandler?: (\n    event: Event,\n    channel: Channel,\n    channelListSetter: (channels: Channel[]) => void,\n    messageListSetter: (messages: StreamMessage[]) => void\n  ) => void;\n  customChannelVisibleHandler?: (\n    event: Event,\n    channel: Channel,\n    channelListSetter: (channels: Channel[]) => void,\n    messageListSetter: (messages: StreamMessage[]) => void\n  ) => void;\n  customNewMessageHandler?: (\n    event: Event,\n    channel: Channel,\n    channelListSetter: (channels: Channel[]) => void,\n    messageListSetter: (messages: StreamMessage[]) => void\n  ) => void;\n  private channelsSubject = new BehaviorSubject<Channel[] | undefined>(\n    undefined\n  );\n  private activeChannelSubject = new BehaviorSubject<Channel | undefined>(\n    undefined\n  );\n  private activeChannelMessagesSubject = new BehaviorSubject<\n    (StreamMessage | MessageResponse | FormatMessageResponse)[]\n  >([]);\n  private hasMoreChannelsSubject = new ReplaySubject<boolean>(1);\n  private activeChannelSubscriptions: { unsubscribe: () => void }[] = [];\n  private filters: ChannelFilters | undefined;\n  private sort: ChannelSort | undefined;\n  private options: ChannelOptions | undefined;\n\n  private channelListSetter = (channels: Channel[]) => {\n    this.channelsSubject.next(channels);\n  };\n\n  private messageListSetter = (messages: StreamMessage[]) => {\n    this.activeChannelMessagesSubject.next(messages);\n  };\n\n  constructor(\n    private chatClientService: ChatClientService,\n    private appRef: ApplicationRef,\n    private ngZone: NgZone\n  ) {\n    this.channels$ = this.channelsSubject.asObservable();\n    this.activeChannel$ = this.activeChannelSubject.asObservable();\n    this.activeChannelMessages$ = this.activeChannelMessagesSubject.pipe(\n      map((messages) => {\n        const channel = this.activeChannelSubject.getValue()!;\n        return messages.map((message) => {\n          if (\n            this.isStreamMessage(message) &&\n            this.isFormatMessageResponse(message)\n          ) {\n            return message;\n          } else if (this.isFormatMessageResponse(message)) {\n            return { ...message, readBy: getReadBy(message, channel) };\n          } else {\n            const formatMessage = this.formatMessage(message);\n            return {\n              ...formatMessage,\n              readBy: getReadBy(formatMessage, channel),\n            };\n          }\n        });\n      })\n    );\n    this.hasMoreChannels$ = this.hasMoreChannelsSubject.asObservable();\n  }\n\n  setAsActiveChannel(channel: Channel) {\n    const prevActiveChannel = this.activeChannelSubject.getValue();\n    this.stopWatchForActiveChannelEvents(prevActiveChannel);\n    this.watchForActiveChannelEvents(channel);\n    this.activeChannelSubject.next(channel);\n    channel.state.messages.forEach((m) => {\n      m.readBy = getReadBy(m, channel);\n    });\n    void channel.markRead();\n    this.activeChannelMessagesSubject.next([...channel.state.messages]);\n  }\n\n  async loadMoreMessages() {\n    const activeChnannel = this.activeChannelSubject.getValue();\n    const lastMessageId = this.activeChannelMessagesSubject.getValue()[0]?.id;\n    await activeChnannel?.query({\n      messages: { limit: 25, id_lt: lastMessageId },\n      members: { limit: 0 },\n      watchers: { limit: 0 },\n    });\n    if (\n      activeChnannel?.data?.id ===\n      this.activeChannelSubject.getValue()?.data?.id\n    ) {\n      this.activeChannelMessagesSubject.next([\n        ...activeChnannel!.state.messages,\n      ]);\n    }\n  }\n\n  async init(\n    filters: ChannelFilters,\n    sort?: ChannelSort,\n    options?: ChannelOptions\n  ) {\n    this.filters = filters;\n    this.options = options || {\n      offset: 0,\n      limit: 25,\n      state: true,\n      presence: true,\n      watch: true,\n      message_limit: 25,\n    };\n    this.sort = sort || { last_message_at: -1, updated_at: -1 };\n    await this.queryChannels();\n    this.chatClientService.notification$.subscribe(\n      (notification) => void this.handleNotification(notification)\n    );\n  }\n\n  async loadMoreChannels() {\n    this.options!.offset = this.channels.length!;\n    await this.queryChannels();\n  }\n\n  async addReaction(messageId: string, reactionType: MessageReactionType) {\n    await this.activeChannelSubject.getValue()?.sendReaction(messageId, {\n      type: reactionType,\n    });\n  }\n\n  async removeReaction(messageId: string, reactionType: MessageReactionType) {\n    await this.activeChannelSubject\n      .getValue()\n      ?.deleteReaction(messageId, reactionType);\n  }\n\n  async sendMessage(\n    text: string,\n    attachments: Attachment[] = [],\n    mentionedUsers: UserResponse[] = []\n  ) {\n    const preview = createMessagePreview(\n      this.chatClientService.chatClient.user!,\n      text,\n      attachments,\n      mentionedUsers\n    );\n    const channel = this.activeChannelSubject.getValue()!;\n    preview.readBy = [];\n    channel.state.addMessageSorted(preview, true);\n    await this.sendMessageRequest(preview);\n  }\n\n  async resendMessage(message: StreamMessage) {\n    const channel = this.activeChannelSubject.getValue()!;\n    channel.state.addMessageSorted(\n      {\n        ...(message as any as MessageResponse),\n        errorStatusCode: undefined,\n        status: 'sending',\n      },\n      true\n    );\n    await this.sendMessageRequest(message);\n  }\n\n  async updateMessage(message: StreamMessage) {\n    await this.chatClientService.chatClient.updateMessage(\n      message as UpdatedMessage\n    );\n  }\n\n  async deleteMessage(message: StreamMessage) {\n    await this.chatClientService.chatClient.deleteMessage(message.id);\n  }\n\n  async uploadAttachments(\n    uploads: AttachmentUpload[]\n  ): Promise<AttachmentUpload[]> {\n    const result: AttachmentUpload[] = [];\n    const channel = this.activeChannelSubject.getValue()!;\n    const uploadResults = await Promise.allSettled(\n      uploads.map((upload) =>\n        upload.type === 'image'\n          ? channel.sendImage(upload.file)\n          : channel.sendFile(upload.file)\n      )\n    );\n    uploadResults.forEach((uploadResult, i) => {\n      const file = uploads[i].file;\n      const type = uploads[i].type;\n      if (uploadResult.status === 'fulfilled') {\n        result.push({\n          file,\n          type,\n          state: 'success',\n          url: uploadResult.value.file,\n        });\n      } else {\n        result.push({ file, type, state: 'error' });\n      }\n    });\n\n    return result;\n  }\n\n  async deleteAttachment(attachmentUpload: AttachmentUpload) {\n    const channel = this.activeChannelSubject.getValue()!;\n    await (attachmentUpload.type === 'image'\n      ? channel.deleteImage(attachmentUpload.url!)\n      : channel.deleteFile(attachmentUpload.url!));\n  }\n\n  async autocompleteMembers(searchTerm: string) {\n    const activeChannel = this.activeChannelSubject.getValue();\n    if (!activeChannel) {\n      return [];\n    }\n    if (Object.keys(activeChannel.state.members).length <= 100) {\n      return Object.values(activeChannel.state.members).filter(\n        (m) => m.user?.id !== this.chatClientService.chatClient.userID!\n      );\n    } else {\n      if (!searchTerm) {\n        return [];\n      }\n      const result = await activeChannel.queryMembers({\n        $or: [\n          { id: { $autocomplete: searchTerm } },\n          { name: { $autocomplete: searchTerm } },\n        ],\n        id: { $ne: this.chatClientService.chatClient.userID! },\n      });\n      return Object.values(result.members);\n    }\n  }\n\n  private async sendMessageRequest(preview: MessageResponse | StreamMessage) {\n    const channel = this.activeChannelSubject.getValue()!;\n    this.activeChannelMessagesSubject.next([...channel.state.messages]);\n    try {\n      await channel.sendMessage({\n        text: preview.text,\n        attachments: preview.attachments,\n        mentioned_users: preview.mentioned_users?.map((u) => u.id),\n        id: preview.id,\n      });\n    } catch (error) {\n      const stringError = JSON.stringify(error);\n      const parsedError: { status?: number } = stringError\n        ? (JSON.parse(stringError) as { status?: number })\n        : {};\n\n      channel.state.addMessageSorted(\n        {\n          ...(preview as MessageResponse),\n          errorStatusCode: parsedError.status || undefined,\n          status: 'failed',\n        },\n        true\n      );\n      this.activeChannelMessagesSubject.next([...channel.state.messages]);\n    }\n  }\n\n  private async handleNotification(notification: Notification) {\n    switch (notification.eventType) {\n      case 'notification.message_new': {\n        if (this.customNewMessageNotificationHandler) {\n          this.customNewMessageNotificationHandler(\n            notification,\n            this.channelListSetter\n          );\n        } else {\n          await this.handleNewMessageNotification(notification);\n        }\n        break;\n      }\n      case 'notification.added_to_channel': {\n        if (this.customAddedToChannelNotificationHandler) {\n          this.customAddedToChannelNotificationHandler(\n            notification,\n            this.channelListSetter\n          );\n        } else {\n          await this.handleAddedToChannelNotification(notification);\n        }\n        break;\n      }\n      case 'notification.removed_from_channel': {\n        if (this.customRemovedFromChannelNotificationHandler) {\n          this.customRemovedFromChannelNotificationHandler(\n            notification,\n            this.channelListSetter\n          );\n        } else {\n          this.handleRemovedFromChannelNotification(notification);\n        }\n      }\n    }\n  }\n\n  private handleRemovedFromChannelNotification(notification: Notification) {\n    this.ngZone.run(() => {\n      const channelIdToBeRemoved = notification.event.channel!.cid;\n      this.removeFromChannelList(channelIdToBeRemoved);\n    });\n  }\n\n  private async handleNewMessageNotification(notification: Notification) {\n    await this.addChannelFromNotification(notification);\n  }\n\n  private async handleAddedToChannelNotification(notification: Notification) {\n    await this.addChannelFromNotification(notification);\n  }\n\n  private async addChannelFromNotification(notification: Notification) {\n    const channel = this.chatClientService.chatClient.channel(\n      notification.event.channel?.type!,\n      notification.event.channel?.id\n    );\n    await channel.watch();\n    this.watchForChannelEvents(channel);\n    this.ngZone.run(() => {\n      this.channelsSubject.next([\n        channel,\n        ...(this.channelsSubject.getValue() || []),\n      ]);\n    });\n  }\n\n  private removeFromChannelList(cid: string) {\n    const channels = this.channels.filter((c) => c.cid !== cid);\n    if (channels.length < this.channels.length) {\n      this.channelsSubject.next(channels);\n      if (this.activeChannelSubject.getValue()!.cid === cid) {\n        this.setAsActiveChannel(channels[0]);\n      }\n    }\n  }\n\n  private watchForActiveChannelEvents(channel: Channel) {\n    this.activeChannelSubscriptions.push(\n      channel.on('message.new', () => {\n        this.ngZone.run(() => {\n          this.activeChannelMessagesSubject.next([...channel.state.messages]);\n          this.activeChannel$\n            .pipe(first())\n            .subscribe((c) => void c?.markRead());\n        });\n      })\n    );\n    this.activeChannelSubscriptions.push(\n      channel.on('message.updated', (event) => this.messageUpdated(event))\n    );\n    this.activeChannelSubscriptions.push(\n      channel.on('message.deleted', (event) => this.messageUpdated(event))\n    );\n    this.activeChannelSubscriptions.push(\n      channel.on('reaction.new', (e) => this.messageReactionEventReceived(e))\n    );\n    this.activeChannelSubscriptions.push(\n      channel.on('reaction.deleted', (e) =>\n        this.messageReactionEventReceived(e)\n      )\n    );\n    this.activeChannelSubscriptions.push(\n      channel.on('reaction.updated', (e) =>\n        this.messageReactionEventReceived(e)\n      )\n    );\n    this.activeChannelSubscriptions.push(\n      channel.on('message.read', (e) => {\n        let latestMessage!: StreamMessage;\n        this.activeChannelMessages$.pipe(first()).subscribe((messages) => {\n          latestMessage = messages[messages.length - 1];\n        });\n        if (!latestMessage || !e.user) {\n          return;\n        }\n        latestMessage.readBy = getReadBy(latestMessage, channel);\n\n        this.activeChannelMessagesSubject.next(\n          this.activeChannelMessagesSubject.getValue()\n        );\n      })\n    );\n  }\n\n  private messageUpdated(event: Event) {\n    this.ngZone.run(() => {\n      const messages = this.activeChannelMessagesSubject.getValue();\n      const messageIndex = messages.findIndex(\n        (m) => m.id === event.message?.id\n      );\n      if (messageIndex !== -1 && event.message) {\n        messages[messageIndex] = event.message;\n        this.activeChannelMessagesSubject.next([...messages]);\n      }\n    });\n  }\n\n  private messageReactionEventReceived(e: Event) {\n    this.ngZone.run(() => {\n      let messages!: StreamMessage[];\n      this.activeChannelMessages$\n        .pipe(first())\n        .subscribe((m) => (messages = m));\n      const message = messages.find((m) => m.id === e?.message?.id);\n      if (!message) {\n        return;\n      }\n      message.reaction_counts = { ...e.message?.reaction_counts };\n      message.reaction_scores = { ...e.message?.reaction_scores };\n      message.latest_reactions = [...(e.message?.latest_reactions || [])];\n      message.own_reactions = [...(e.message?.own_reactions || [])];\n      this.activeChannelMessagesSubject.next([...messages]);\n    });\n  }\n\n  private formatMessage(message: MessageResponse) {\n    return {\n      ...message,\n      // parse the date..\n      pinned_at: message.pinned_at ? new Date(message.pinned_at) : null,\n      created_at: message.created_at\n        ? new Date(message.created_at)\n        : new Date(),\n      updated_at: message.updated_at\n        ? new Date(message.updated_at)\n        : new Date(),\n      status: message.status || 'received',\n    };\n  }\n\n  private isStreamMessage(\n    message: StreamMessage | FormatMessageResponse | MessageResponse\n  ): message is StreamMessage {\n    return !!message.readBy;\n  }\n\n  private isFormatMessageResponse(\n    message: StreamMessage | FormatMessageResponse | MessageResponse\n  ): message is FormatMessageResponse {\n    return message.created_at instanceof Date;\n  }\n\n  private stopWatchForActiveChannelEvents(channel: Channel | undefined) {\n    if (!channel) {\n      return;\n    }\n    this.activeChannelSubscriptions.forEach((s) => s.unsubscribe());\n    this.activeChannelSubscriptions = [];\n  }\n\n  private async queryChannels() {\n    try {\n      const channels = await this.chatClientService.chatClient.queryChannels(\n        this.filters!,\n        this.sort,\n        this.options\n      );\n      channels.forEach((c) => this.watchForChannelEvents(c));\n      const prevChannels = this.channelsSubject.getValue() || [];\n      this.channelsSubject.next([...prevChannels, ...channels]);\n      if (channels.length > 0 && !this.activeChannelSubject.getValue()) {\n        this.setAsActiveChannel(channels[0]);\n      }\n      this.hasMoreChannelsSubject.next(channels.length >= this.options!.limit!);\n    } catch (error) {\n      this.channelsSubject.error(error);\n    }\n  }\n\n  private watchForChannelEvents(channel: Channel) {\n    channel.on((event: Event) => {\n      switch (event.type) {\n        case 'message.new': {\n          if (this.customNewMessageHandler) {\n            this.customNewMessageHandler(\n              event,\n              channel,\n              this.channelListSetter,\n              this.messageListSetter\n            );\n          } else {\n            this.handleNewMessage(event, channel);\n          }\n          break;\n        }\n        case 'channel.hidden': {\n          if (this.customChannelHiddenHandler) {\n            this.customChannelHiddenHandler(\n              event,\n              channel,\n              this.channelListSetter,\n              this.messageListSetter\n            );\n          } else {\n            this.handleChannelHidden(event);\n          }\n          this.appRef.tick();\n          break;\n        }\n        case 'channel.deleted': {\n          if (this.customChannelDeletedHandler) {\n            this.customChannelDeletedHandler(\n              event,\n              channel,\n              this.channelListSetter,\n              this.messageListSetter\n            );\n          } else {\n            this.handleChannelDeleted(event);\n          }\n          this.appRef.tick();\n          break;\n        }\n        case 'channel.visible': {\n          if (this.customChannelVisibleHandler) {\n            this.customChannelVisibleHandler(\n              event,\n              channel,\n              this.channelListSetter,\n              this.messageListSetter\n            );\n          } else {\n            this.handleChannelVisible(event, channel);\n          }\n          this.appRef.tick();\n          break;\n        }\n        case 'channel.updated': {\n          if (this.customChannelUpdatedHandler) {\n            this.customChannelUpdatedHandler(\n              event,\n              channel,\n              this.channelListSetter,\n              this.messageListSetter\n            );\n          } else {\n            this.handleChannelUpdate(event);\n          }\n          this.appRef.tick();\n          break;\n        }\n        case 'channel.truncated': {\n          if (this.customChannelTruncatedHandler) {\n            this.customChannelTruncatedHandler(\n              event,\n              channel,\n              this.channelListSetter,\n              this.messageListSetter\n            );\n          } else {\n            this.handleChannelTruncate(event);\n          }\n          this.appRef.tick();\n          break;\n        }\n      }\n      setTimeout(() => this.appRef.tick(), 0);\n    });\n  }\n\n  private handleNewMessage(_: Event, channel: Channel) {\n    const channelIndex = this.channels.findIndex((c) => c.cid === channel.cid);\n    this.channels.splice(channelIndex, 1);\n    this.channelsSubject.next([channel, ...this.channels]);\n  }\n\n  private handleChannelHidden(event: Event) {\n    this.removeFromChannelList(event.channel!.cid);\n  }\n\n  private handleChannelDeleted(event: Event) {\n    this.removeFromChannelList(event.channel!.cid);\n  }\n\n  private handleChannelVisible(event: Event, channel: Channel) {\n    if (!this.channels.find((c) => c.cid === event.cid)) {\n      this.ngZone.run(() =>\n        this.channelsSubject.next([...this.channels, channel])\n      );\n    }\n  }\n\n  private handleChannelUpdate(event: Event) {\n    const channelIndex = this.channels.findIndex(\n      (c) => c.cid === event.channel!.cid\n    );\n    if (channelIndex !== -1) {\n      this.channels[channelIndex].data = event.channel;\n      this.channelsSubject.next([...this.channels]);\n      if (event.channel?.cid === this.activeChannelSubject.getValue()?.cid) {\n        const channel = this.activeChannelSubject.getValue()!;\n        channel.data = event.channel;\n        this.activeChannelSubject.next(channel);\n      }\n    }\n  }\n\n  private handleChannelTruncate(event: Event) {\n    const channelIndex = this.channels.findIndex(\n      (c) => c.cid === event.channel!.cid\n    );\n    if (channelIndex !== -1) {\n      this.channels[channelIndex].state.messages = [];\n      this.channelsSubject.next([...this.channels]);\n      if (event.channel?.cid === this.activeChannelSubject.getValue()?.cid) {\n        const channel = this.activeChannelSubject.getValue()!;\n        channel.state.messages = [];\n        this.activeChannelSubject.next(channel);\n        this.activeChannelMessagesSubject.next([]);\n      }\n    }\n  }\n\n  private get channels() {\n    return this.channelsSubject.getValue() || [];\n  }\n}\n"]}
@@ -64,6 +64,21 @@ export class ChatClientService {
64
64
  yield this.chatClient.flagMessage(messageId);
65
65
  });
66
66
  }
67
+ autocompleteUsers(searchTerm) {
68
+ return __awaiter(this, void 0, void 0, function* () {
69
+ if (!searchTerm) {
70
+ return [];
71
+ }
72
+ const result = yield this.chatClient.queryUsers({
73
+ $or: [
74
+ { id: { $autocomplete: searchTerm } },
75
+ { name: { $autocomplete: searchTerm } },
76
+ ],
77
+ id: { $ne: this.chatClient.userID },
78
+ });
79
+ return result.users;
80
+ });
81
+ }
67
82
  }
68
83
  ChatClientService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: ChatClientService, deps: [{ token: i0.NgZone }, { token: i0.ApplicationRef }, { token: i1.NotificationService }], target: i0.ɵɵFactoryTarget.Injectable });
69
84
  ChatClientService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: ChatClientService, providedIn: 'root' });
@@ -73,4 +88,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
73
88
  providedIn: 'root',
74
89
  }]
75
90
  }], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i0.ApplicationRef }, { type: i1.NotificationService }]; } });
76
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdC1jbGllbnQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi9jaGF0LWNsaWVudC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQWtCLFVBQVUsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUNuRSxPQUFPLEVBQWMsYUFBYSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQ2pELE9BQU8sRUFBUyxVQUFVLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDaEQsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLG1CQUFtQixDQUFDOzs7QUFjNUMsTUFBTSxPQUFPLGlCQUFpQjtJQU81QixZQUNVLE1BQWMsRUFDZCxNQUFzQixFQUN0QixtQkFBd0M7UUFGeEMsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUNkLFdBQU0sR0FBTixNQUFNLENBQWdCO1FBQ3RCLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBcUI7UUFOMUMsd0JBQW1CLEdBQUcsSUFBSSxhQUFhLENBQWUsQ0FBQyxDQUFDLENBQUM7UUFDekQsMkJBQXNCLEdBQUcsSUFBSSxhQUFhLENBQXVCLENBQUMsQ0FBQyxDQUFDO1FBTzFFLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLG1CQUFtQixDQUFDLFlBQVksRUFBRSxDQUFDO1FBQzdELElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxJQUFJLENBQUMsc0JBQXNCLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDckUsQ0FBQztJQUVLLElBQUksQ0FBQyxNQUFjLEVBQUUsTUFBYyxFQUFFLFNBQWlCOztZQUMxRCxJQUFJLENBQUMsVUFBVSxHQUFHLFVBQVUsQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDakQsTUFBTSxJQUFJLENBQUMsTUFBTSxDQUFDLGlCQUFpQixDQUFDLEdBQVMsRUFBRTtnQkFDN0MsTUFBTSxJQUFJLENBQUMsVUFBVSxDQUFDLFdBQVcsQ0FBQyxFQUFFLEVBQUUsRUFBRSxNQUFNLEVBQUUsRUFBRSxTQUFTLENBQUMsQ0FBQztnQkFDN0QsSUFBSSxDQUFDLFVBQVUsQ0FBQyxZQUFZLENBQzFCLHVCQUF1QixPQUFPLElBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQyxZQUFZLEVBQUUsRUFBRSxDQUNuRSxDQUFDO1lBQ0osQ0FBQyxDQUFBLENBQUMsQ0FBQztZQUNILElBQUksQ0FBQyxVQUFVLENBQUMsRUFBRSxDQUFDLCtCQUErQixFQUFFLENBQUMsQ0FBQyxFQUFFLEVBQUU7Z0JBQ3hELElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUM7b0JBQzVCLFNBQVMsRUFBRSwrQkFBK0I7b0JBQzFDLEtBQUssRUFBRSxDQUFDO2lCQUNULENBQUMsQ0FBQztnQkFDSCxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ3JCLENBQUMsQ0FBQyxDQUFDO1lBQ0gsSUFBSSxDQUFDLFVBQVUsQ0FBQyxFQUFFLENBQUMsMEJBQTBCLEVBQUUsQ0FBQyxDQUFDLEVBQUUsRUFBRTtnQkFDbkQsSUFBSSxDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQztvQkFDNUIsU0FBUyxFQUFFLDBCQUEwQjtvQkFDckMsS0FBSyxFQUFFLENBQUM7aUJBQ1QsQ0FBQyxDQUFDO2dCQUNILElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDckIsQ0FBQyxDQUFDLENBQUM7WUFDSCxJQUFJLENBQUMsVUFBVSxDQUFDLEVBQUUsQ0FBQyxtQ0FBbUMsRUFBRSxDQUFDLENBQUMsRUFBRSxFQUFFO2dCQUM1RCxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDO29CQUM1QixTQUFTLEVBQUUsbUNBQW1DO29CQUM5QyxLQUFLLEVBQUUsQ0FBQztpQkFDVCxDQUFDLENBQUM7Z0JBQ0gsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNyQixDQUFDLENBQUMsQ0FBQztZQUNILElBQUksa0JBQXdDLENBQUM7WUFDN0MsSUFBSSxDQUFDLFVBQVUsQ0FBQyxFQUFFLENBQUMsb0JBQW9CLEVBQUUsQ0FBQyxDQUFDLEVBQUUsRUFBRTtnQkFDN0MsTUFBTSxRQUFRLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQztnQkFDMUIsSUFBSSxRQUFRLEVBQUU7b0JBQ1osSUFBSSxrQkFBa0IsRUFBRTt3QkFDdEIsa0JBQWtCLEVBQUUsQ0FBQztxQkFDdEI7aUJBQ0Y7cUJBQU07b0JBQ0wsa0JBQWtCLEdBQUcsSUFBSSxDQUFDLG1CQUFtQixDQUFDLHdCQUF3QixDQUNwRSxvREFBb0QsQ0FDckQsQ0FBQztpQkFDSDtnQkFDRCxJQUFJLENBQUMsc0JBQXNCLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQztnQkFDbEUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNyQixDQUFDLENBQUMsQ0FBQztRQUNMLENBQUM7S0FBQTtJQUVLLFdBQVcsQ0FBQyxTQUFpQjs7WUFDakMsTUFBTSxJQUFJLENBQUMsVUFBVSxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUMvQyxDQUFDO0tBQUE7OzhHQWhFVSxpQkFBaUI7a0hBQWpCLGlCQUFpQixjQUZoQixNQUFNOzJGQUVQLGlCQUFpQjtrQkFIN0IsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBcHBsaWNhdGlvblJlZiwgSW5qZWN0YWJsZSwgTmdab25lIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBSZXBsYXlTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBFdmVudCwgU3RyZWFtQ2hhdCB9IGZyb20gJ3N0cmVhbS1jaGF0JztcbmltcG9ydCB7IHZlcnNpb24gfSBmcm9tICcuLi9hc3NldHMvdmVyc2lvbic7XG5pbXBvcnQgeyBOb3RpZmljYXRpb25TZXJ2aWNlIH0gZnJvbSAnLi9ub3RpZmljYXRpb24uc2VydmljZSc7XG5cbmV4cG9ydCB0eXBlIE5vdGlmaWNhdGlvbiA9IHtcbiAgZXZlbnRUeXBlOlxuICAgIHwgJ25vdGlmaWNhdGlvbi5hZGRlZF90b19jaGFubmVsJ1xuICAgIHwgJ25vdGlmaWNhdGlvbi5tZXNzYWdlX25ldydcbiAgICB8ICdub3RpZmljYXRpb24ucmVtb3ZlZF9mcm9tX2NoYW5uZWwnO1xuICBldmVudDogRXZlbnQ7XG59O1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgQ2hhdENsaWVudFNlcnZpY2Uge1xuICBjaGF0Q2xpZW50ITogU3RyZWFtQ2hhdDtcbiAgbm90aWZpY2F0aW9uJDogT2JzZXJ2YWJsZTxOb3RpZmljYXRpb24+O1xuICBjb25uZWN0aW9uU3RhdGUkOiBPYnNlcnZhYmxlPCdvZmZsaW5lJyB8ICdvbmxpbmUnPjtcbiAgcHJpdmF0ZSBub3RpZmljYXRpb25TdWJqZWN0ID0gbmV3IFJlcGxheVN1YmplY3Q8Tm90aWZpY2F0aW9uPigxKTtcbiAgcHJpdmF0ZSBjb25uZWN0aW9uU3RhdGVTdWJqZWN0ID0gbmV3IFJlcGxheVN1YmplY3Q8J29mZmxpbmUnIHwgJ29ubGluZSc+KDEpO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgbmdab25lOiBOZ1pvbmUsXG4gICAgcHJpdmF0ZSBhcHBSZWY6IEFwcGxpY2F0aW9uUmVmLFxuICAgIHByaXZhdGUgbm90aWZpY2F0aW9uU2VydmljZTogTm90aWZpY2F0aW9uU2VydmljZVxuICApIHtcbiAgICB0aGlzLm5vdGlmaWNhdGlvbiQgPSB0aGlzLm5vdGlmaWNhdGlvblN1YmplY3QuYXNPYnNlcnZhYmxlKCk7XG4gICAgdGhpcy5jb25uZWN0aW9uU3RhdGUkID0gdGhpcy5jb25uZWN0aW9uU3RhdGVTdWJqZWN0LmFzT2JzZXJ2YWJsZSgpO1xuICB9XG5cbiAgYXN5bmMgaW5pdChhcGlLZXk6IHN0cmluZywgdXNlcklkOiBzdHJpbmcsIHVzZXJUb2tlbjogc3RyaW5nKSB7XG4gICAgdGhpcy5jaGF0Q2xpZW50ID0gU3RyZWFtQ2hhdC5nZXRJbnN0YW5jZShhcGlLZXkpO1xuICAgIGF3YWl0IHRoaXMubmdab25lLnJ1bk91dHNpZGVBbmd1bGFyKGFzeW5jICgpID0+IHtcbiAgICAgIGF3YWl0IHRoaXMuY2hhdENsaWVudC5jb25uZWN0VXNlcih7IGlkOiB1c2VySWQgfSwgdXNlclRva2VuKTtcbiAgICAgIHRoaXMuY2hhdENsaWVudC5zZXRVc2VyQWdlbnQoXG4gICAgICAgIGBzdHJlYW0tY2hhdC1hbmd1bGFyLSR7dmVyc2lvbn0tJHt0aGlzLmNoYXRDbGllbnQuZ2V0VXNlckFnZW50KCl9YFxuICAgICAgKTtcbiAgICB9KTtcbiAgICB0aGlzLmNoYXRDbGllbnQub24oJ25vdGlmaWNhdGlvbi5hZGRlZF90b19jaGFubmVsJywgKGUpID0+IHtcbiAgICAgIHRoaXMubm90aWZpY2F0aW9uU3ViamVjdC5uZXh0KHtcbiAgICAgICAgZXZlbnRUeXBlOiAnbm90aWZpY2F0aW9uLmFkZGVkX3RvX2NoYW5uZWwnLFxuICAgICAgICBldmVudDogZSxcbiAgICAgIH0pO1xuICAgICAgdGhpcy5hcHBSZWYudGljaygpO1xuICAgIH0pO1xuICAgIHRoaXMuY2hhdENsaWVudC5vbignbm90aWZpY2F0aW9uLm1lc3NhZ2VfbmV3JywgKGUpID0+IHtcbiAgICAgIHRoaXMubm90aWZpY2F0aW9uU3ViamVjdC5uZXh0KHtcbiAgICAgICAgZXZlbnRUeXBlOiAnbm90aWZpY2F0aW9uLm1lc3NhZ2VfbmV3JyxcbiAgICAgICAgZXZlbnQ6IGUsXG4gICAgICB9KTtcbiAgICAgIHRoaXMuYXBwUmVmLnRpY2soKTtcbiAgICB9KTtcbiAgICB0aGlzLmNoYXRDbGllbnQub24oJ25vdGlmaWNhdGlvbi5yZW1vdmVkX2Zyb21fY2hhbm5lbCcsIChlKSA9PiB7XG4gICAgICB0aGlzLm5vdGlmaWNhdGlvblN1YmplY3QubmV4dCh7XG4gICAgICAgIGV2ZW50VHlwZTogJ25vdGlmaWNhdGlvbi5yZW1vdmVkX2Zyb21fY2hhbm5lbCcsXG4gICAgICAgIGV2ZW50OiBlLFxuICAgICAgfSk7XG4gICAgICB0aGlzLmFwcFJlZi50aWNrKCk7XG4gICAgfSk7XG4gICAgbGV0IHJlbW92ZU5vdGlmaWNhdGlvbjogdW5kZWZpbmVkIHwgRnVuY3Rpb247XG4gICAgdGhpcy5jaGF0Q2xpZW50Lm9uKCdjb25uZWN0aW9uLmNoYW5nZWQnLCAoZSkgPT4ge1xuICAgICAgY29uc3QgaXNPbmxpbmUgPSBlLm9ubGluZTtcbiAgICAgIGlmIChpc09ubGluZSkge1xuICAgICAgICBpZiAocmVtb3ZlTm90aWZpY2F0aW9uKSB7XG4gICAgICAgICAgcmVtb3ZlTm90aWZpY2F0aW9uKCk7XG4gICAgICAgIH1cbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHJlbW92ZU5vdGlmaWNhdGlvbiA9IHRoaXMubm90aWZpY2F0aW9uU2VydmljZS5hZGRQZXJtYW5lbnROb3RpZmljYXRpb24oXG4gICAgICAgICAgJ3N0cmVhbUNoYXQuQ29ubmVjdGlvbiBmYWlsdXJlLCByZWNvbm5lY3Rpbmcgbm93Li4uJ1xuICAgICAgICApO1xuICAgICAgfVxuICAgICAgdGhpcy5jb25uZWN0aW9uU3RhdGVTdWJqZWN0Lm5leHQoaXNPbmxpbmUgPyAnb25saW5lJyA6ICdvZmZsaW5lJyk7XG4gICAgICB0aGlzLmFwcFJlZi50aWNrKCk7XG4gICAgfSk7XG4gIH1cblxuICBhc3luYyBmbGFnTWVzc2FnZShtZXNzYWdlSWQ6IHN0cmluZykge1xuICAgIGF3YWl0IHRoaXMuY2hhdENsaWVudC5mbGFnTWVzc2FnZShtZXNzYWdlSWQpO1xuICB9XG59XG4iXX0=
91
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chat-client.service.js","sourceRoot":"","sources":["../../../../projects/stream-chat-angular/src/lib/chat-client.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ApplicationRef, Injectable, NgZone } from '@angular/core';\nimport { Observable, ReplaySubject } from 'rxjs';\nimport { Event, StreamChat } from 'stream-chat';\nimport { version } from '../assets/version';\nimport { NotificationService } from './notification.service';\n\nexport type Notification = {\n  eventType:\n    | 'notification.added_to_channel'\n    | 'notification.message_new'\n    | 'notification.removed_from_channel';\n  event: Event;\n};\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class ChatClientService {\n  chatClient!: StreamChat;\n  notification$: Observable<Notification>;\n  connectionState$: Observable<'offline' | 'online'>;\n  private notificationSubject = new ReplaySubject<Notification>(1);\n  private connectionStateSubject = new ReplaySubject<'offline' | 'online'>(1);\n\n  constructor(\n    private ngZone: NgZone,\n    private appRef: ApplicationRef,\n    private notificationService: NotificationService\n  ) {\n    this.notification$ = this.notificationSubject.asObservable();\n    this.connectionState$ = this.connectionStateSubject.asObservable();\n  }\n\n  async init(apiKey: string, userId: string, userToken: string) {\n    this.chatClient = StreamChat.getInstance(apiKey);\n    await this.ngZone.runOutsideAngular(async () => {\n      await this.chatClient.connectUser({ id: userId }, userToken);\n      this.chatClient.setUserAgent(\n        `stream-chat-angular-${version}-${this.chatClient.getUserAgent()}`\n      );\n    });\n    this.chatClient.on('notification.added_to_channel', (e) => {\n      this.notificationSubject.next({\n        eventType: 'notification.added_to_channel',\n        event: e,\n      });\n      this.appRef.tick();\n    });\n    this.chatClient.on('notification.message_new', (e) => {\n      this.notificationSubject.next({\n        eventType: 'notification.message_new',\n        event: e,\n      });\n      this.appRef.tick();\n    });\n    this.chatClient.on('notification.removed_from_channel', (e) => {\n      this.notificationSubject.next({\n        eventType: 'notification.removed_from_channel',\n        event: e,\n      });\n      this.appRef.tick();\n    });\n    let removeNotification: undefined | Function;\n    this.chatClient.on('connection.changed', (e) => {\n      const isOnline = e.online;\n      if (isOnline) {\n        if (removeNotification) {\n          removeNotification();\n        }\n      } else {\n        removeNotification = this.notificationService.addPermanentNotification(\n          'streamChat.Connection failure, reconnecting now...'\n        );\n      }\n      this.connectionStateSubject.next(isOnline ? 'online' : 'offline');\n      this.appRef.tick();\n    });\n  }\n\n  async flagMessage(messageId: string) {\n    await this.chatClient.flagMessage(messageId);\n  }\n\n  async autocompleteUsers(searchTerm: string) {\n    if (!searchTerm) {\n      return [];\n    }\n    const result = await this.chatClient.queryUsers({\n      $or: [\n        { id: { $autocomplete: searchTerm } },\n        { name: { $autocomplete: searchTerm } },\n      ],\n      id: { $ne: this.chatClient.userID! },\n    });\n    return result.users;\n  }\n}\n"]}
@@ -0,0 +1,3 @@
1
+ import { InjectionToken } from '@angular/core';
2
+ export const textareaInjectionToken = new InjectionToken('textareaInjectionToken');
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5qZWN0aW9uLXRva2Vucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi9pbmplY3Rpb24tdG9rZW5zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQVEsTUFBTSxlQUFlLENBQUM7QUFHckQsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsSUFBSSxjQUFjLENBRXRELHdCQUF3QixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiwgVHlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVGV4dGFyZWFJbnRlcmZhY2UgfSBmcm9tICcuL21lc3NhZ2UtaW5wdXQvdGV4dGFyZWEuaW50ZXJmYWNlJztcblxuZXhwb3J0IGNvbnN0IHRleHRhcmVhSW5qZWN0aW9uVG9rZW4gPSBuZXcgSW5qZWN0aW9uVG9rZW48XG4gIFR5cGU8VGV4dGFyZWFJbnRlcmZhY2U+XG4+KCd0ZXh0YXJlYUluamVjdGlvblRva2VuJyk7XG4iXX0=
@@ -0,0 +1,23 @@
1
+ import { Pipe } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class HighlightMentionsPipe {
4
+ transform(value, mentionedUsers) {
5
+ if (!value || !mentionedUsers) {
6
+ return value || '';
7
+ }
8
+ let result = value;
9
+ mentionedUsers.forEach((u) => {
10
+ result = result.replace(new RegExp(`@${u.name || u.id}`, 'g'), `<b>@${u.name || u.id}</b>`);
11
+ });
12
+ return result;
13
+ }
14
+ }
15
+ HighlightMentionsPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: HighlightMentionsPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
16
+ HighlightMentionsPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: HighlightMentionsPipe, name: "highlightMentions" });
17
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: HighlightMentionsPipe, decorators: [{
18
+ type: Pipe,
19
+ args: [{
20
+ name: 'highlightMentions',
21
+ }]
22
+ }] });
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGlnaGxpZ2h0LW1lbnRpb25zLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zdHJlYW0tY2hhdC1hbmd1bGFyL3NyYy9saWIvbWVzc2FnZS9oaWdobGlnaHQtbWVudGlvbnMucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQzs7QUFNcEQsTUFBTSxPQUFPLHFCQUFxQjtJQUNoQyxTQUFTLENBQUMsS0FBYyxFQUFFLGNBQStCO1FBQ3ZELElBQUksQ0FBQyxLQUFLLElBQUksQ0FBQyxjQUFjLEVBQUU7WUFDN0IsT0FBTyxLQUFLLElBQUksRUFBRSxDQUFDO1NBQ3BCO1FBQ0QsSUFBSSxNQUFNLEdBQUcsS0FBSyxDQUFDO1FBQ25CLGNBQWMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRTtZQUMzQixNQUFNLEdBQUcsTUFBTSxDQUFDLE9BQU8sQ0FDckIsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxJQUFJLENBQUMsQ0FBQyxFQUFFLEVBQUUsRUFBRSxHQUFHLENBQUMsRUFDckMsT0FBTyxDQUFDLENBQUMsSUFBSSxJQUFJLENBQUMsQ0FBQyxFQUFFLE1BQU0sQ0FDNUIsQ0FBQztRQUNKLENBQUMsQ0FBQyxDQUFDO1FBRUgsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQzs7a0hBZFUscUJBQXFCO2dIQUFyQixxQkFBcUI7MkZBQXJCLHFCQUFxQjtrQkFIakMsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsbUJBQW1CO2lCQUMxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFVzZXJSZXNwb25zZSB9IGZyb20gJ3N0cmVhbS1jaGF0JztcblxuQFBpcGUoe1xuICBuYW1lOiAnaGlnaGxpZ2h0TWVudGlvbnMnLFxufSlcbmV4cG9ydCBjbGFzcyBIaWdobGlnaHRNZW50aW9uc1BpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcbiAgdHJhbnNmb3JtKHZhbHVlPzogc3RyaW5nLCBtZW50aW9uZWRVc2Vycz86IFVzZXJSZXNwb25zZVtdKTogc3RyaW5nIHtcbiAgICBpZiAoIXZhbHVlIHx8ICFtZW50aW9uZWRVc2Vycykge1xuICAgICAgcmV0dXJuIHZhbHVlIHx8ICcnO1xuICAgIH1cbiAgICBsZXQgcmVzdWx0ID0gdmFsdWU7XG4gICAgbWVudGlvbmVkVXNlcnMuZm9yRWFjaCgodSkgPT4ge1xuICAgICAgcmVzdWx0ID0gcmVzdWx0LnJlcGxhY2UoXG4gICAgICAgIG5ldyBSZWdFeHAoYEAke3UubmFtZSB8fCB1LmlkfWAsICdnJyksXG4gICAgICAgIGA8Yj5AJHt1Lm5hbWUgfHwgdS5pZH08L2I+YFxuICAgICAgKTtcbiAgICB9KTtcblxuICAgIHJldHVybiByZXN1bHQ7XG4gIH1cbn1cbiJdfQ==
@@ -13,6 +13,7 @@ import * as i7 from "../attachment-list/attachment-list.component";
13
13
  import * as i8 from "../loading-indicator/loading-indicator.component";
14
14
  import * as i9 from "@angular/common";
15
15
  import * as i10 from "@ngx-translate/core";
16
+ import * as i11 from "./highlight-mentions.pipe";
16
17
  export class MessageComponent {
17
18
  constructor(chatClientService, channelService) {
18
19
  this.chatClientService = chatClientService;
@@ -97,7 +98,7 @@ export class MessageComponent {
97
98
  }
98
99
  }
99
100
  MessageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: MessageComponent, deps: [{ token: i1.ChatClientService }, { token: i2.ChannelService }], target: i0.ɵɵFactoryTarget.Component });
100
- MessageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.5", type: MessageComponent, selector: "stream-message", inputs: { message: "message", enabledMessageActions: "enabledMessageActions", areReactionsEnabled: "areReactionsEnabled", canReactToMessage: "canReactToMessage", isLastSentMessage: "isLastSentMessage" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], ngImport: i0, template: "<div\n #container\n class=\"str-chat__message-simple str-chat__message str-chat__message--{{\n message?.type\n }} str-chat__message--{{ message?.status }} {{\n message?.text ? 'str-chat__message--has-text' : 'has-no-text'\n }}\"\n [class.str-chat__message--me]=\"isSentByCurrentUser\"\n [class.str-chat__message-simple--me]=\"isSentByCurrentUser\"\n [class.mobile-press]=\"isPressedOnMobile\"\n [class.str-chat__message--has-attachment]=\"hasAttachment\"\n [class.str-chat__message--with-reactions]=\"\n areReactionsEnabled && hasReactions\n \"\n data-testid=\"message-container\"\n>\n <ng-container *ngIf=\"!message?.deleted_at; else deletedMessage\">\n <ng-container *ngIf=\"message?.type !== 'system'; else systemMessage\">\n <ng-container\n *ngIf=\"\n isSentByCurrentUser &&\n ((isLastSentMessage && message?.status === 'received') ||\n message?.status === 'sending')\n \"\n >\n <ng-container *ngIf=\"message?.status === 'sending'; else sentStatus\">\n <ng-container *ngTemplateOutlet=\"sendingStatus\"></ng-container>\n </ng-container>\n <ng-template #sentStatus>\n <ng-container *ngIf=\"isMessageDeliveredAndRead; else deliveredStatus\">\n <ng-container *ngTemplateOutlet=\"readStatus\"></ng-container>\n </ng-container>\n </ng-template>\n </ng-container>\n <stream-avatar\n data-testid=\"avatar\"\n class=\"str-chat-angular__avatar-host\"\n [imageUrl]=\"message?.user?.image\"\n [name]=\"message?.user?.name || message?.user?.id\"\n ></stream-avatar>\n <div class=\"str-chat__message-inner\">\n <div\n class=\"str-chat__message-simple__actions\"\n data-testid=\"message-options\"\n *ngIf=\"areOptionsVisible\"\n >\n <div\n data-testid=\"message-actions-container\"\n class=\"\n str-chat__message-simple__actions__action\n str-chat__message-simple__actions__action--options\n \"\n [class.str-chat-angular__message-simple__actions__action--options--editing]=\"\n isEditing\n \"\n >\n <stream-message-actions-box\n [isOpen]=\"isActionBoxOpen\"\n [isMine]=\"isSentByCurrentUser\"\n [enabledActions]=\"enabledMessageActions\"\n [message]=\"message\"\n (displayedActionsCount)=\"visibleMessageActionsCount = $event\"\n (isEditing)=\"isEditing = $event; isActionBoxOpen = !isEditing\"\n ></stream-message-actions-box>\n <stream-icon\n *ngIf=\"visibleMessageActionsCount > 0\"\n data-testid=\"action-icon\"\n icon=\"action-icon\"\n (keyup.enter)=\"isActionBoxOpen = !isActionBoxOpen\"\n (click)=\"isActionBoxOpen = !isActionBoxOpen\"\n ></stream-icon>\n </div>\n <div\n *ngIf=\"areReactionsEnabled && canReactToMessage\"\n class=\"\n str-chat__message-simple__actions__action\n str-chat__message-simple__actions__action--reactions\n \"\n data-testid=\"reaction-icon\"\n (click)=\"isReactionSelectorOpen = !isReactionSelectorOpen\"\n (keyup.enter)=\"isReactionSelectorOpen = !isReactionSelectorOpen\"\n >\n <stream-icon icon=\"reaction-icon\"></stream-icon>\n </div>\n </div>\n <stream-message-reactions\n *ngIf=\"areReactionsEnabled\"\n [messageReactionCounts]=\"message?.reaction_counts || {}\"\n [latestReactions]=\"message?.latest_reactions || []\"\n [(isSelectorOpen)]=\"isReactionSelectorOpen\"\n [messageId]=\"message?.id\"\n [ownReactions]=\"message?.own_reactions || []\"\n ></stream-message-reactions>\n <stream-attachment-list\n *ngIf=\"hasAttachment\"\n [attachments]=\"message!.attachments!\"\n ></stream-attachment-list>\n <div class=\"str-chat__message-text\" *ngIf=\"message?.text\">\n <div\n data-testid=\"inner-message\"\n class=\"\n str-chat__message-text-inner str-chat__message-simple-text-inner\n \"\n [class.str-chat__message-light-text-inner--has-attachment]=\"\n hasAttachment\n \"\n (click)=\"\n message?.status === 'failed' && message?.errorStatusCode !== 403\n ? resendMessage()\n : undefined\n \"\n (keyup.enter)=\"\n message?.status === 'failed' && message?.errorStatusCode !== 403\n ? resendMessage()\n : undefined\n \"\n >\n <div\n data-testid=\"client-error-message\"\n *ngIf=\"message?.type === 'error'\"\n class=\"str-chat__simple-message--error-message\"\n >\n {{ \"streamChat.Error \u00B7 Unsent\" | translate }}\n </div>\n <div\n data-testid=\"error-message\"\n *ngIf=\"message?.status === 'failed'\"\n class=\"str-chat__simple-message--error-message\"\n >\n {{\n (message?.errorStatusCode === 403\n ? \"streamChat.Message Failed \u00B7 Unauthorized\"\n : \"streamChat.Message Failed \u00B7 Click to try again\"\n ) | translate\n }}\n </div>\n <div\n (click)=\"textClicked()\"\n (keyup.enter)=\"textClicked()\"\n data-testid=\"text\"\n [innerHTML]=\"message?.html || message?.text\"\n ></div>\n </div>\n </div>\n <div class=\"str-chat__message-data str-chat__message-simple-data\">\n <span\n data-testid=\"sender\"\n *ngIf=\"!isSentByCurrentUser\"\n class=\"str-chat__message-simple-name\"\n >\n {{ message?.user?.name ? message?.user?.name : message?.user?.id }}\n </span>\n <span data-testid=\"date\" class=\"str-chat__message-simple-timestamp\">\n {{ parsedDate }}\n </span>\n </div>\n </div>\n </ng-container>\n </ng-container>\n</div>\n\n<ng-template #sendingStatus>\n <span class=\"str-chat__message-simple-status\" data-testid=\"sending-indicator\">\n <div class=\"str-chat__tooltip\">\n {{ \"streamChat.Sending...\" | translate }}\n </div>\n <stream-loading-indicator\n data-testid=\"loading-indicator\"\n ></stream-loading-indicator>\n </span>\n</ng-template>\n<ng-template #readStatus>\n <span class=\"str-chat__message-simple-status\" data-testid=\"read-indicator\">\n <div class=\"str-chat__tooltip\" data-testid=\"read-by-tooltip\">\n {{ readByText }}\n </div>\n <stream-avatar\n class=\"str-chat-angular__avatar-host\"\n data-test-id=\"last-read-user-avatar\"\n [size]=\"15\"\n [imageUrl]=\"lastReadUser?.image\"\n [name]=\"lastReadUser?.name || lastReadUser?.id\"\n ></stream-avatar>\n <span\n data-test-id=\"read-by-length\"\n *ngIf=\"isReadByMultipleUsers\"\n class=\"str-chat__message-simple-status-number\"\n >\n {{ (message?.readBy)!.length }}\n </span>\n </span>\n</ng-template>\n<ng-template #deliveredStatus>\n <span\n class=\"str-chat__message-simple-status\"\n data-testid=\"delivered-indicator\"\n >\n <div class=\"str-chat__tooltip\">\n {{ \"streamChat.Delivered\" | translate }}\n </div>\n <stream-icon\n data-testid=\"delivered-icon\"\n icon=\"delivered-icon\"\n ></stream-icon>\n </span>\n</ng-template>\n\n<ng-template #deletedMessage>\n <div data-testid=\"message-deleted-component\">\n <div class=\"str-chat__message--deleted-inner\" translate>\n streamChat.This message was deleted...\n </div>\n </div>\n</ng-template>\n\n<ng-template #systemMessage>\n <div data-testid=\"system-message\" class=\"str-chat__message--system\">\n <div class=\"str-chat__message--system__text\">\n <div class=\"str-chat__message--system__line\"></div>\n <p>{{ message?.text }}</p>\n <div class=\"str-chat__message--system__line\"></div>\n </div>\n <div class=\"str-chat__message--system__date\">\n {{ parsedDate }}\n </div>\n </div>\n</ng-template>\n", components: [{ type: i3.AvatarComponent, selector: "stream-avatar", inputs: ["name", "imageUrl", "size"] }, { type: i4.MessageActionsBoxComponent, selector: "stream-message-actions-box", inputs: ["isOpen", "isMine", "message", "enabledActions"], outputs: ["displayedActionsCount", "isEditing"] }, { type: i5.IconComponent, selector: "stream-icon", inputs: ["icon", "size"] }, { type: i6.MessageReactionsComponent, selector: "stream-message-reactions", inputs: ["messageId", "messageReactionCounts", "isSelectorOpen", "latestReactions", "ownReactions"], outputs: ["isSelectorOpenChange"] }, { type: i7.AttachmentListComponent, selector: "stream-attachment-list", inputs: ["attachments"] }, { type: i8.LoadingIndicatorComponent, selector: "stream-loading-indicator", inputs: ["size", "color"] }], directives: [{ type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i9.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i10.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], pipes: { "translate": i10.TranslatePipe } });
101
+ MessageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.5", type: MessageComponent, selector: "stream-message", inputs: { message: "message", enabledMessageActions: "enabledMessageActions", areReactionsEnabled: "areReactionsEnabled", canReactToMessage: "canReactToMessage", isLastSentMessage: "isLastSentMessage" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], ngImport: i0, template: "<div\n #container\n class=\"str-chat__message-simple str-chat__message str-chat__message--{{\n message?.type\n }} str-chat__message--{{ message?.status }} {{\n message?.text ? 'str-chat__message--has-text' : 'has-no-text'\n }}\"\n [class.str-chat__message--me]=\"isSentByCurrentUser\"\n [class.str-chat__message-simple--me]=\"isSentByCurrentUser\"\n [class.mobile-press]=\"isPressedOnMobile\"\n [class.str-chat__message--has-attachment]=\"hasAttachment\"\n [class.str-chat__message--with-reactions]=\"\n areReactionsEnabled && hasReactions\n \"\n data-testid=\"message-container\"\n>\n <ng-container *ngIf=\"!message?.deleted_at; else deletedMessage\">\n <ng-container *ngIf=\"message?.type !== 'system'; else systemMessage\">\n <ng-container\n *ngIf=\"\n isSentByCurrentUser &&\n ((isLastSentMessage && message?.status === 'received') ||\n message?.status === 'sending')\n \"\n >\n <ng-container *ngIf=\"message?.status === 'sending'; else sentStatus\">\n <ng-container *ngTemplateOutlet=\"sendingStatus\"></ng-container>\n </ng-container>\n <ng-template #sentStatus>\n <ng-container *ngIf=\"isMessageDeliveredAndRead; else deliveredStatus\">\n <ng-container *ngTemplateOutlet=\"readStatus\"></ng-container>\n </ng-container>\n </ng-template>\n </ng-container>\n <stream-avatar\n data-testid=\"avatar\"\n class=\"str-chat-angular__avatar-host\"\n [imageUrl]=\"message?.user?.image\"\n [name]=\"message?.user?.name || message?.user?.id\"\n ></stream-avatar>\n <div class=\"str-chat__message-inner\">\n <div\n class=\"str-chat__message-simple__actions\"\n data-testid=\"message-options\"\n *ngIf=\"areOptionsVisible\"\n >\n <div\n data-testid=\"message-actions-container\"\n class=\"\n str-chat__message-simple__actions__action\n str-chat__message-simple__actions__action--options\n \"\n [class.str-chat-angular__message-simple__actions__action--options--editing]=\"\n isEditing\n \"\n >\n <stream-message-actions-box\n [isOpen]=\"isActionBoxOpen\"\n [isMine]=\"isSentByCurrentUser\"\n [enabledActions]=\"enabledMessageActions\"\n [message]=\"message\"\n (displayedActionsCount)=\"visibleMessageActionsCount = $event\"\n (isEditing)=\"isEditing = $event; isActionBoxOpen = !isEditing\"\n ></stream-message-actions-box>\n <stream-icon\n *ngIf=\"visibleMessageActionsCount > 0\"\n data-testid=\"action-icon\"\n icon=\"action-icon\"\n (keyup.enter)=\"isActionBoxOpen = !isActionBoxOpen\"\n (click)=\"isActionBoxOpen = !isActionBoxOpen\"\n ></stream-icon>\n </div>\n <div\n *ngIf=\"areReactionsEnabled && canReactToMessage\"\n class=\"\n str-chat__message-simple__actions__action\n str-chat__message-simple__actions__action--reactions\n \"\n data-testid=\"reaction-icon\"\n (click)=\"isReactionSelectorOpen = !isReactionSelectorOpen\"\n (keyup.enter)=\"isReactionSelectorOpen = !isReactionSelectorOpen\"\n >\n <stream-icon icon=\"reaction-icon\"></stream-icon>\n </div>\n </div>\n <stream-message-reactions\n *ngIf=\"areReactionsEnabled\"\n [messageReactionCounts]=\"message?.reaction_counts || {}\"\n [latestReactions]=\"message?.latest_reactions || []\"\n [(isSelectorOpen)]=\"isReactionSelectorOpen\"\n [messageId]=\"message?.id\"\n [ownReactions]=\"message?.own_reactions || []\"\n ></stream-message-reactions>\n <stream-attachment-list\n *ngIf=\"hasAttachment\"\n [attachments]=\"message!.attachments!\"\n ></stream-attachment-list>\n <div class=\"str-chat__message-text\" *ngIf=\"message?.text\">\n <div\n data-testid=\"inner-message\"\n class=\"\n str-chat__message-text-inner str-chat__message-simple-text-inner\n \"\n [class.str-chat__message-light-text-inner--has-attachment]=\"\n hasAttachment\n \"\n (click)=\"\n message?.status === 'failed' && message?.errorStatusCode !== 403\n ? resendMessage()\n : undefined\n \"\n (keyup.enter)=\"\n message?.status === 'failed' && message?.errorStatusCode !== 403\n ? resendMessage()\n : undefined\n \"\n >\n <div\n data-testid=\"client-error-message\"\n *ngIf=\"message?.type === 'error'\"\n class=\"str-chat__simple-message--error-message\"\n >\n {{ \"streamChat.Error \u00B7 Unsent\" | translate }}\n </div>\n <div\n data-testid=\"error-message\"\n *ngIf=\"message?.status === 'failed'\"\n class=\"str-chat__simple-message--error-message\"\n >\n {{\n (message?.errorStatusCode === 403\n ? \"streamChat.Message Failed \u00B7 Unauthorized\"\n : \"streamChat.Message Failed \u00B7 Click to try again\"\n ) | translate\n }}\n </div>\n <div\n (click)=\"textClicked()\"\n (keyup.enter)=\"textClicked()\"\n data-testid=\"text\"\n [innerHTML]=\"\n message?.html || message?.text\n | highlightMentions: message?.mentioned_users\n \"\n ></div>\n </div>\n </div>\n <div class=\"str-chat__message-data str-chat__message-simple-data\">\n <span\n data-testid=\"sender\"\n *ngIf=\"!isSentByCurrentUser\"\n class=\"str-chat__message-simple-name\"\n >\n {{ message?.user?.name ? message?.user?.name : message?.user?.id }}\n </span>\n <span data-testid=\"date\" class=\"str-chat__message-simple-timestamp\">\n {{ parsedDate }}\n </span>\n </div>\n </div>\n </ng-container>\n </ng-container>\n</div>\n\n<ng-template #sendingStatus>\n <span class=\"str-chat__message-simple-status\" data-testid=\"sending-indicator\">\n <div class=\"str-chat__tooltip\">\n {{ \"streamChat.Sending...\" | translate }}\n </div>\n <stream-loading-indicator\n data-testid=\"loading-indicator\"\n ></stream-loading-indicator>\n </span>\n</ng-template>\n<ng-template #readStatus>\n <span class=\"str-chat__message-simple-status\" data-testid=\"read-indicator\">\n <div class=\"str-chat__tooltip\" data-testid=\"read-by-tooltip\">\n {{ readByText }}\n </div>\n <stream-avatar\n class=\"str-chat-angular__avatar-host\"\n data-test-id=\"last-read-user-avatar\"\n [size]=\"15\"\n [imageUrl]=\"lastReadUser?.image\"\n [name]=\"lastReadUser?.name || lastReadUser?.id\"\n ></stream-avatar>\n <span\n data-test-id=\"read-by-length\"\n *ngIf=\"isReadByMultipleUsers\"\n class=\"str-chat__message-simple-status-number\"\n >\n {{ (message?.readBy)!.length }}\n </span>\n </span>\n</ng-template>\n<ng-template #deliveredStatus>\n <span\n class=\"str-chat__message-simple-status\"\n data-testid=\"delivered-indicator\"\n >\n <div class=\"str-chat__tooltip\">\n {{ \"streamChat.Delivered\" | translate }}\n </div>\n <stream-icon\n data-testid=\"delivered-icon\"\n icon=\"delivered-icon\"\n ></stream-icon>\n </span>\n</ng-template>\n\n<ng-template #deletedMessage>\n <div data-testid=\"message-deleted-component\">\n <div class=\"str-chat__message--deleted-inner\" translate>\n streamChat.This message was deleted...\n </div>\n </div>\n</ng-template>\n\n<ng-template #systemMessage>\n <div data-testid=\"system-message\" class=\"str-chat__message--system\">\n <div class=\"str-chat__message--system__text\">\n <div class=\"str-chat__message--system__line\"></div>\n <p>{{ message?.text }}</p>\n <div class=\"str-chat__message--system__line\"></div>\n </div>\n <div class=\"str-chat__message--system__date\">\n {{ parsedDate }}\n </div>\n </div>\n</ng-template>\n", components: [{ type: i3.AvatarComponent, selector: "stream-avatar", inputs: ["name", "imageUrl", "size"] }, { type: i4.MessageActionsBoxComponent, selector: "stream-message-actions-box", inputs: ["isOpen", "isMine", "message", "enabledActions"], outputs: ["displayedActionsCount", "isEditing"] }, { type: i5.IconComponent, selector: "stream-icon", inputs: ["icon", "size"] }, { type: i6.MessageReactionsComponent, selector: "stream-message-reactions", inputs: ["messageId", "messageReactionCounts", "isSelectorOpen", "latestReactions", "ownReactions"], outputs: ["isSelectorOpenChange"] }, { type: i7.AttachmentListComponent, selector: "stream-attachment-list", inputs: ["attachments"] }, { type: i8.LoadingIndicatorComponent, selector: "stream-loading-indicator", inputs: ["size", "color"] }], directives: [{ type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i9.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i10.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], pipes: { "translate": i10.TranslatePipe, "highlightMentions": i11.HighlightMentionsPipe } });
101
102
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: MessageComponent, decorators: [{
102
103
  type: Component,
103
104
  args: [{
@@ -119,4 +120,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
119
120
  type: ViewChild,
120
121
  args: ['container']
121
122
  }] } });
122
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"message.component.js","sourceRoot":"","sources":["../../../../../projects/stream-chat-angular/src/lib/message/message.component.ts","../../../../../projects/stream-chat-angular/src/lib/message/message.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, ViewChild } from '@angular/core';\nimport { UserResponse } from 'stream-chat';\nimport { ChannelService } from '../channel.service';\nimport { ChatClientService } from '../chat-client.service';\nimport { getDeviceWidth } from '../device-width';\nimport { MessageActions } from '../message-actions-box/message-actions-box.component';\nimport { DefaultUserType, StreamMessage } from '../types';\nimport { parseDate } from './parse-date';\nimport { getReadByText } from './read-by-text';\n\n@Component({\n  selector: 'stream-message',\n  templateUrl: './message.component.html',\n  styles: [],\n})\nexport class MessageComponent {\n  @Input() message: StreamMessage | undefined;\n  @Input() enabledMessageActions: MessageActions[] = [];\n  @Input() areReactionsEnabled: boolean | undefined;\n  @Input() canReactToMessage: boolean | undefined;\n  @Input() isLastSentMessage: boolean | undefined;\n  isEditing: boolean | undefined;\n  isActionBoxOpen = false;\n  isReactionSelectorOpen = false;\n  isPressedOnMobile = false;\n  visibleMessageActionsCount = 0;\n  private user: UserResponse<DefaultUserType> | undefined;\n  @ViewChild('container') private container:\n    | ElementRef<HTMLElement>\n    | undefined;\n\n  constructor(\n    private chatClientService: ChatClientService,\n    private channelService: ChannelService\n  ) {\n    this.user = this.chatClientService.chatClient.user;\n  }\n\n  get isSentByCurrentUser() {\n    return this.message?.user?.id === this.user?.id;\n  }\n\n  get readByText() {\n    return getReadByText(this.message!.readBy);\n  }\n\n  get lastReadUser() {\n    return this.message?.readBy.filter((u) => u.id !== this.user?.id)[0];\n  }\n\n  get isOnlyReadByMe() {\n    return this.message && this.message.readBy.length === 0;\n  }\n\n  get isReadByMultipleUsers() {\n    return this.message && this.message.readBy.length > 1;\n  }\n\n  get isMessageDeliveredAndRead() {\n    return (\n      this.message &&\n      this.message.readBy &&\n      this.message.status === 'received' &&\n      this.message.readBy.length > 0\n    );\n  }\n\n  get parsedDate() {\n    if (!this.message || !this.message?.created_at) {\n      return;\n    }\n    return parseDate(this.message.created_at);\n  }\n\n  get areOptionsVisible() {\n    if (!this.message) {\n      return false;\n    }\n    return !(\n      !this.message.type ||\n      this.message.type === 'error' ||\n      this.message.type === 'system' ||\n      this.message.type === 'ephemeral' ||\n      this.message.status === 'failed' ||\n      this.message.status === 'sending'\n    );\n  }\n\n  get hasAttachment() {\n    return !!this.message?.attachments && !!this.message.attachments.length;\n  }\n\n  get hasReactions() {\n    return (\n      !!this.message?.reaction_counts &&\n      Object.keys(this.message.reaction_counts).length > 0\n    );\n  }\n\n  resendMessage() {\n    void this.channelService.resendMessage(this.message!);\n  }\n\n  textClicked() {\n    if (getDeviceWidth().device !== 'mobile') {\n      this.isPressedOnMobile = false;\n      return;\n    }\n    if (this.isPressedOnMobile) {\n      return;\n    }\n    this.isPressedOnMobile = true;\n    const eventHandler = (event: Event) => {\n      if (!this.container?.nativeElement.contains(event.target as Node)) {\n        this.isPressedOnMobile = false;\n        window.removeEventListener('click', eventHandler);\n      }\n    };\n    window.addEventListener('click', eventHandler);\n  }\n}\n","<div\n  #container\n  class=\"str-chat__message-simple str-chat__message str-chat__message--{{\n    message?.type\n  }} str-chat__message--{{ message?.status }} {{\n    message?.text ? 'str-chat__message--has-text' : 'has-no-text'\n  }}\"\n  [class.str-chat__message--me]=\"isSentByCurrentUser\"\n  [class.str-chat__message-simple--me]=\"isSentByCurrentUser\"\n  [class.mobile-press]=\"isPressedOnMobile\"\n  [class.str-chat__message--has-attachment]=\"hasAttachment\"\n  [class.str-chat__message--with-reactions]=\"\n    areReactionsEnabled && hasReactions\n  \"\n  data-testid=\"message-container\"\n>\n  <ng-container *ngIf=\"!message?.deleted_at; else deletedMessage\">\n    <ng-container *ngIf=\"message?.type !== 'system'; else systemMessage\">\n      <ng-container\n        *ngIf=\"\n          isSentByCurrentUser &&\n          ((isLastSentMessage && message?.status === 'received') ||\n            message?.status === 'sending')\n        \"\n      >\n        <ng-container *ngIf=\"message?.status === 'sending'; else sentStatus\">\n          <ng-container *ngTemplateOutlet=\"sendingStatus\"></ng-container>\n        </ng-container>\n        <ng-template #sentStatus>\n          <ng-container *ngIf=\"isMessageDeliveredAndRead; else deliveredStatus\">\n            <ng-container *ngTemplateOutlet=\"readStatus\"></ng-container>\n          </ng-container>\n        </ng-template>\n      </ng-container>\n      <stream-avatar\n        data-testid=\"avatar\"\n        class=\"str-chat-angular__avatar-host\"\n        [imageUrl]=\"message?.user?.image\"\n        [name]=\"message?.user?.name || message?.user?.id\"\n      ></stream-avatar>\n      <div class=\"str-chat__message-inner\">\n        <div\n          class=\"str-chat__message-simple__actions\"\n          data-testid=\"message-options\"\n          *ngIf=\"areOptionsVisible\"\n        >\n          <div\n            data-testid=\"message-actions-container\"\n            class=\"\n              str-chat__message-simple__actions__action\n              str-chat__message-simple__actions__action--options\n            \"\n            [class.str-chat-angular__message-simple__actions__action--options--editing]=\"\n              isEditing\n            \"\n          >\n            <stream-message-actions-box\n              [isOpen]=\"isActionBoxOpen\"\n              [isMine]=\"isSentByCurrentUser\"\n              [enabledActions]=\"enabledMessageActions\"\n              [message]=\"message\"\n              (displayedActionsCount)=\"visibleMessageActionsCount = $event\"\n              (isEditing)=\"isEditing = $event; isActionBoxOpen = !isEditing\"\n            ></stream-message-actions-box>\n            <stream-icon\n              *ngIf=\"visibleMessageActionsCount > 0\"\n              data-testid=\"action-icon\"\n              icon=\"action-icon\"\n              (keyup.enter)=\"isActionBoxOpen = !isActionBoxOpen\"\n              (click)=\"isActionBoxOpen = !isActionBoxOpen\"\n            ></stream-icon>\n          </div>\n          <div\n            *ngIf=\"areReactionsEnabled && canReactToMessage\"\n            class=\"\n              str-chat__message-simple__actions__action\n              str-chat__message-simple__actions__action--reactions\n            \"\n            data-testid=\"reaction-icon\"\n            (click)=\"isReactionSelectorOpen = !isReactionSelectorOpen\"\n            (keyup.enter)=\"isReactionSelectorOpen = !isReactionSelectorOpen\"\n          >\n            <stream-icon icon=\"reaction-icon\"></stream-icon>\n          </div>\n        </div>\n        <stream-message-reactions\n          *ngIf=\"areReactionsEnabled\"\n          [messageReactionCounts]=\"message?.reaction_counts || {}\"\n          [latestReactions]=\"message?.latest_reactions || []\"\n          [(isSelectorOpen)]=\"isReactionSelectorOpen\"\n          [messageId]=\"message?.id\"\n          [ownReactions]=\"message?.own_reactions || []\"\n        ></stream-message-reactions>\n        <stream-attachment-list\n          *ngIf=\"hasAttachment\"\n          [attachments]=\"message!.attachments!\"\n        ></stream-attachment-list>\n        <div class=\"str-chat__message-text\" *ngIf=\"message?.text\">\n          <div\n            data-testid=\"inner-message\"\n            class=\"\n              str-chat__message-text-inner str-chat__message-simple-text-inner\n            \"\n            [class.str-chat__message-light-text-inner--has-attachment]=\"\n              hasAttachment\n            \"\n            (click)=\"\n              message?.status === 'failed' && message?.errorStatusCode !== 403\n                ? resendMessage()\n                : undefined\n            \"\n            (keyup.enter)=\"\n              message?.status === 'failed' && message?.errorStatusCode !== 403\n                ? resendMessage()\n                : undefined\n            \"\n          >\n            <div\n              data-testid=\"client-error-message\"\n              *ngIf=\"message?.type === 'error'\"\n              class=\"str-chat__simple-message--error-message\"\n            >\n              {{ \"streamChat.Error · Unsent\" | translate }}\n            </div>\n            <div\n              data-testid=\"error-message\"\n              *ngIf=\"message?.status === 'failed'\"\n              class=\"str-chat__simple-message--error-message\"\n            >\n              {{\n                (message?.errorStatusCode === 403\n                  ? \"streamChat.Message Failed · Unauthorized\"\n                  : \"streamChat.Message Failed · Click to try again\"\n                ) | translate\n              }}\n            </div>\n            <div\n              (click)=\"textClicked()\"\n              (keyup.enter)=\"textClicked()\"\n              data-testid=\"text\"\n              [innerHTML]=\"message?.html || message?.text\"\n            ></div>\n          </div>\n        </div>\n        <div class=\"str-chat__message-data str-chat__message-simple-data\">\n          <span\n            data-testid=\"sender\"\n            *ngIf=\"!isSentByCurrentUser\"\n            class=\"str-chat__message-simple-name\"\n          >\n            {{ message?.user?.name ? message?.user?.name : message?.user?.id }}\n          </span>\n          <span data-testid=\"date\" class=\"str-chat__message-simple-timestamp\">\n            {{ parsedDate }}\n          </span>\n        </div>\n      </div>\n    </ng-container>\n  </ng-container>\n</div>\n\n<ng-template #sendingStatus>\n  <span class=\"str-chat__message-simple-status\" data-testid=\"sending-indicator\">\n    <div class=\"str-chat__tooltip\">\n      {{ \"streamChat.Sending...\" | translate }}\n    </div>\n    <stream-loading-indicator\n      data-testid=\"loading-indicator\"\n    ></stream-loading-indicator>\n  </span>\n</ng-template>\n<ng-template #readStatus>\n  <span class=\"str-chat__message-simple-status\" data-testid=\"read-indicator\">\n    <div class=\"str-chat__tooltip\" data-testid=\"read-by-tooltip\">\n      {{ readByText }}\n    </div>\n    <stream-avatar\n      class=\"str-chat-angular__avatar-host\"\n      data-test-id=\"last-read-user-avatar\"\n      [size]=\"15\"\n      [imageUrl]=\"lastReadUser?.image\"\n      [name]=\"lastReadUser?.name || lastReadUser?.id\"\n    ></stream-avatar>\n    <span\n      data-test-id=\"read-by-length\"\n      *ngIf=\"isReadByMultipleUsers\"\n      class=\"str-chat__message-simple-status-number\"\n    >\n      {{ (message?.readBy)!.length }}\n    </span>\n  </span>\n</ng-template>\n<ng-template #deliveredStatus>\n  <span\n    class=\"str-chat__message-simple-status\"\n    data-testid=\"delivered-indicator\"\n  >\n    <div class=\"str-chat__tooltip\">\n      {{ \"streamChat.Delivered\" | translate }}\n    </div>\n    <stream-icon\n      data-testid=\"delivered-icon\"\n      icon=\"delivered-icon\"\n    ></stream-icon>\n  </span>\n</ng-template>\n\n<ng-template #deletedMessage>\n  <div data-testid=\"message-deleted-component\">\n    <div class=\"str-chat__message--deleted-inner\" translate>\n      streamChat.This message was deleted...\n    </div>\n  </div>\n</ng-template>\n\n<ng-template #systemMessage>\n  <div data-testid=\"system-message\" class=\"str-chat__message--system\">\n    <div class=\"str-chat__message--system__text\">\n      <div class=\"str-chat__message--system__line\"></div>\n      <p>{{ message?.text }}</p>\n      <div class=\"str-chat__message--system__line\"></div>\n    </div>\n    <div class=\"str-chat__message--system__date\">\n      {{ parsedDate }}\n    </div>\n  </div>\n</ng-template>\n"]}
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"message.component.js","sourceRoot":"","sources":["../../../../../projects/stream-chat-angular/src/lib/message/message.component.ts","../../../../../projects/stream-chat-angular/src/lib/message/message.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, ViewChild } from '@angular/core';\nimport { UserResponse } from 'stream-chat';\nimport { ChannelService } from '../channel.service';\nimport { ChatClientService } from '../chat-client.service';\nimport { getDeviceWidth } from '../device-width';\nimport { MessageActions } from '../message-actions-box/message-actions-box.component';\nimport { DefaultUserType, StreamMessage } from '../types';\nimport { parseDate } from './parse-date';\nimport { getReadByText } from './read-by-text';\n\n@Component({\n  selector: 'stream-message',\n  templateUrl: './message.component.html',\n  styles: [],\n})\nexport class MessageComponent {\n  @Input() message: StreamMessage | undefined;\n  @Input() enabledMessageActions: MessageActions[] = [];\n  @Input() areReactionsEnabled: boolean | undefined;\n  @Input() canReactToMessage: boolean | undefined;\n  @Input() isLastSentMessage: boolean | undefined;\n  isEditing: boolean | undefined;\n  isActionBoxOpen = false;\n  isReactionSelectorOpen = false;\n  isPressedOnMobile = false;\n  visibleMessageActionsCount = 0;\n  private user: UserResponse<DefaultUserType> | undefined;\n  @ViewChild('container') private container:\n    | ElementRef<HTMLElement>\n    | undefined;\n\n  constructor(\n    private chatClientService: ChatClientService,\n    private channelService: ChannelService\n  ) {\n    this.user = this.chatClientService.chatClient.user;\n  }\n\n  get isSentByCurrentUser() {\n    return this.message?.user?.id === this.user?.id;\n  }\n\n  get readByText() {\n    return getReadByText(this.message!.readBy);\n  }\n\n  get lastReadUser() {\n    return this.message?.readBy.filter((u) => u.id !== this.user?.id)[0];\n  }\n\n  get isOnlyReadByMe() {\n    return this.message && this.message.readBy.length === 0;\n  }\n\n  get isReadByMultipleUsers() {\n    return this.message && this.message.readBy.length > 1;\n  }\n\n  get isMessageDeliveredAndRead() {\n    return (\n      this.message &&\n      this.message.readBy &&\n      this.message.status === 'received' &&\n      this.message.readBy.length > 0\n    );\n  }\n\n  get parsedDate() {\n    if (!this.message || !this.message?.created_at) {\n      return;\n    }\n    return parseDate(this.message.created_at);\n  }\n\n  get areOptionsVisible() {\n    if (!this.message) {\n      return false;\n    }\n    return !(\n      !this.message.type ||\n      this.message.type === 'error' ||\n      this.message.type === 'system' ||\n      this.message.type === 'ephemeral' ||\n      this.message.status === 'failed' ||\n      this.message.status === 'sending'\n    );\n  }\n\n  get hasAttachment() {\n    return !!this.message?.attachments && !!this.message.attachments.length;\n  }\n\n  get hasReactions() {\n    return (\n      !!this.message?.reaction_counts &&\n      Object.keys(this.message.reaction_counts).length > 0\n    );\n  }\n\n  resendMessage() {\n    void this.channelService.resendMessage(this.message!);\n  }\n\n  textClicked() {\n    if (getDeviceWidth().device !== 'mobile') {\n      this.isPressedOnMobile = false;\n      return;\n    }\n    if (this.isPressedOnMobile) {\n      return;\n    }\n    this.isPressedOnMobile = true;\n    const eventHandler = (event: Event) => {\n      if (!this.container?.nativeElement.contains(event.target as Node)) {\n        this.isPressedOnMobile = false;\n        window.removeEventListener('click', eventHandler);\n      }\n    };\n    window.addEventListener('click', eventHandler);\n  }\n}\n","<div\n  #container\n  class=\"str-chat__message-simple str-chat__message str-chat__message--{{\n    message?.type\n  }} str-chat__message--{{ message?.status }} {{\n    message?.text ? 'str-chat__message--has-text' : 'has-no-text'\n  }}\"\n  [class.str-chat__message--me]=\"isSentByCurrentUser\"\n  [class.str-chat__message-simple--me]=\"isSentByCurrentUser\"\n  [class.mobile-press]=\"isPressedOnMobile\"\n  [class.str-chat__message--has-attachment]=\"hasAttachment\"\n  [class.str-chat__message--with-reactions]=\"\n    areReactionsEnabled && hasReactions\n  \"\n  data-testid=\"message-container\"\n>\n  <ng-container *ngIf=\"!message?.deleted_at; else deletedMessage\">\n    <ng-container *ngIf=\"message?.type !== 'system'; else systemMessage\">\n      <ng-container\n        *ngIf=\"\n          isSentByCurrentUser &&\n          ((isLastSentMessage && message?.status === 'received') ||\n            message?.status === 'sending')\n        \"\n      >\n        <ng-container *ngIf=\"message?.status === 'sending'; else sentStatus\">\n          <ng-container *ngTemplateOutlet=\"sendingStatus\"></ng-container>\n        </ng-container>\n        <ng-template #sentStatus>\n          <ng-container *ngIf=\"isMessageDeliveredAndRead; else deliveredStatus\">\n            <ng-container *ngTemplateOutlet=\"readStatus\"></ng-container>\n          </ng-container>\n        </ng-template>\n      </ng-container>\n      <stream-avatar\n        data-testid=\"avatar\"\n        class=\"str-chat-angular__avatar-host\"\n        [imageUrl]=\"message?.user?.image\"\n        [name]=\"message?.user?.name || message?.user?.id\"\n      ></stream-avatar>\n      <div class=\"str-chat__message-inner\">\n        <div\n          class=\"str-chat__message-simple__actions\"\n          data-testid=\"message-options\"\n          *ngIf=\"areOptionsVisible\"\n        >\n          <div\n            data-testid=\"message-actions-container\"\n            class=\"\n              str-chat__message-simple__actions__action\n              str-chat__message-simple__actions__action--options\n            \"\n            [class.str-chat-angular__message-simple__actions__action--options--editing]=\"\n              isEditing\n            \"\n          >\n            <stream-message-actions-box\n              [isOpen]=\"isActionBoxOpen\"\n              [isMine]=\"isSentByCurrentUser\"\n              [enabledActions]=\"enabledMessageActions\"\n              [message]=\"message\"\n              (displayedActionsCount)=\"visibleMessageActionsCount = $event\"\n              (isEditing)=\"isEditing = $event; isActionBoxOpen = !isEditing\"\n            ></stream-message-actions-box>\n            <stream-icon\n              *ngIf=\"visibleMessageActionsCount > 0\"\n              data-testid=\"action-icon\"\n              icon=\"action-icon\"\n              (keyup.enter)=\"isActionBoxOpen = !isActionBoxOpen\"\n              (click)=\"isActionBoxOpen = !isActionBoxOpen\"\n            ></stream-icon>\n          </div>\n          <div\n            *ngIf=\"areReactionsEnabled && canReactToMessage\"\n            class=\"\n              str-chat__message-simple__actions__action\n              str-chat__message-simple__actions__action--reactions\n            \"\n            data-testid=\"reaction-icon\"\n            (click)=\"isReactionSelectorOpen = !isReactionSelectorOpen\"\n            (keyup.enter)=\"isReactionSelectorOpen = !isReactionSelectorOpen\"\n          >\n            <stream-icon icon=\"reaction-icon\"></stream-icon>\n          </div>\n        </div>\n        <stream-message-reactions\n          *ngIf=\"areReactionsEnabled\"\n          [messageReactionCounts]=\"message?.reaction_counts || {}\"\n          [latestReactions]=\"message?.latest_reactions || []\"\n          [(isSelectorOpen)]=\"isReactionSelectorOpen\"\n          [messageId]=\"message?.id\"\n          [ownReactions]=\"message?.own_reactions || []\"\n        ></stream-message-reactions>\n        <stream-attachment-list\n          *ngIf=\"hasAttachment\"\n          [attachments]=\"message!.attachments!\"\n        ></stream-attachment-list>\n        <div class=\"str-chat__message-text\" *ngIf=\"message?.text\">\n          <div\n            data-testid=\"inner-message\"\n            class=\"\n              str-chat__message-text-inner str-chat__message-simple-text-inner\n            \"\n            [class.str-chat__message-light-text-inner--has-attachment]=\"\n              hasAttachment\n            \"\n            (click)=\"\n              message?.status === 'failed' && message?.errorStatusCode !== 403\n                ? resendMessage()\n                : undefined\n            \"\n            (keyup.enter)=\"\n              message?.status === 'failed' && message?.errorStatusCode !== 403\n                ? resendMessage()\n                : undefined\n            \"\n          >\n            <div\n              data-testid=\"client-error-message\"\n              *ngIf=\"message?.type === 'error'\"\n              class=\"str-chat__simple-message--error-message\"\n            >\n              {{ \"streamChat.Error · Unsent\" | translate }}\n            </div>\n            <div\n              data-testid=\"error-message\"\n              *ngIf=\"message?.status === 'failed'\"\n              class=\"str-chat__simple-message--error-message\"\n            >\n              {{\n                (message?.errorStatusCode === 403\n                  ? \"streamChat.Message Failed · Unauthorized\"\n                  : \"streamChat.Message Failed · Click to try again\"\n                ) | translate\n              }}\n            </div>\n            <div\n              (click)=\"textClicked()\"\n              (keyup.enter)=\"textClicked()\"\n              data-testid=\"text\"\n              [innerHTML]=\"\n                message?.html || message?.text\n                  | highlightMentions: message?.mentioned_users\n              \"\n            ></div>\n          </div>\n        </div>\n        <div class=\"str-chat__message-data str-chat__message-simple-data\">\n          <span\n            data-testid=\"sender\"\n            *ngIf=\"!isSentByCurrentUser\"\n            class=\"str-chat__message-simple-name\"\n          >\n            {{ message?.user?.name ? message?.user?.name : message?.user?.id }}\n          </span>\n          <span data-testid=\"date\" class=\"str-chat__message-simple-timestamp\">\n            {{ parsedDate }}\n          </span>\n        </div>\n      </div>\n    </ng-container>\n  </ng-container>\n</div>\n\n<ng-template #sendingStatus>\n  <span class=\"str-chat__message-simple-status\" data-testid=\"sending-indicator\">\n    <div class=\"str-chat__tooltip\">\n      {{ \"streamChat.Sending...\" | translate }}\n    </div>\n    <stream-loading-indicator\n      data-testid=\"loading-indicator\"\n    ></stream-loading-indicator>\n  </span>\n</ng-template>\n<ng-template #readStatus>\n  <span class=\"str-chat__message-simple-status\" data-testid=\"read-indicator\">\n    <div class=\"str-chat__tooltip\" data-testid=\"read-by-tooltip\">\n      {{ readByText }}\n    </div>\n    <stream-avatar\n      class=\"str-chat-angular__avatar-host\"\n      data-test-id=\"last-read-user-avatar\"\n      [size]=\"15\"\n      [imageUrl]=\"lastReadUser?.image\"\n      [name]=\"lastReadUser?.name || lastReadUser?.id\"\n    ></stream-avatar>\n    <span\n      data-test-id=\"read-by-length\"\n      *ngIf=\"isReadByMultipleUsers\"\n      class=\"str-chat__message-simple-status-number\"\n    >\n      {{ (message?.readBy)!.length }}\n    </span>\n  </span>\n</ng-template>\n<ng-template #deliveredStatus>\n  <span\n    class=\"str-chat__message-simple-status\"\n    data-testid=\"delivered-indicator\"\n  >\n    <div class=\"str-chat__tooltip\">\n      {{ \"streamChat.Delivered\" | translate }}\n    </div>\n    <stream-icon\n      data-testid=\"delivered-icon\"\n      icon=\"delivered-icon\"\n    ></stream-icon>\n  </span>\n</ng-template>\n\n<ng-template #deletedMessage>\n  <div data-testid=\"message-deleted-component\">\n    <div class=\"str-chat__message--deleted-inner\" translate>\n      streamChat.This message was deleted...\n    </div>\n  </div>\n</ng-template>\n\n<ng-template #systemMessage>\n  <div data-testid=\"system-message\" class=\"str-chat__message--system\">\n    <div class=\"str-chat__message--system__text\">\n      <div class=\"str-chat__message--system__line\"></div>\n      <p>{{ message?.text }}</p>\n      <div class=\"str-chat__message--system__line\"></div>\n    </div>\n    <div class=\"str-chat__message--system__date\">\n      {{ parsedDate }}\n    </div>\n  </div>\n</ng-template>\n"]}