stream-chat-angular 4.47.3 → 4.49.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 (46) hide show
  1. package/assets/i18n/en.d.ts +2 -1
  2. package/assets/version.d.ts +1 -1
  3. package/bundles/stream-chat-angular.umd.js +114 -29
  4. package/bundles/stream-chat-angular.umd.js.map +1 -1
  5. package/esm2015/assets/i18n/en.js +4 -3
  6. package/esm2015/assets/version.js +2 -2
  7. package/esm2015/lib/attachment.service.js +21 -4
  8. package/esm2015/lib/channel.service.js +80 -16
  9. package/esm2015/lib/types.js +1 -1
  10. package/fesm2015/stream-chat-angular.js +103 -21
  11. package/fesm2015/stream-chat-angular.js.map +1 -1
  12. package/lib/channel.service.d.ts +19 -2
  13. package/lib/types.d.ts +15 -1
  14. package/package.json +1 -1
  15. package/src/assets/i18n/en.ts +5 -2
  16. package/src/assets/styles/css/index.css +1 -1
  17. package/src/assets/styles/scss/MessageInput.scss +6 -0
  18. package/src/assets/styles/scss/_base.scss +0 -41
  19. package/src/assets/styles/scss/index.scss +0 -1
  20. package/src/assets/styles/v2/css/emoji-mart.css +1 -0
  21. package/src/assets/styles/v2/css/emoji-replacement.css +1 -0
  22. package/src/assets/styles/v2/css/index.css +1 -1
  23. package/src/assets/styles/v2/css/index.layout.css +1 -1
  24. package/src/assets/styles/v2/scss/AttachmentPreviewList/AttachmentPreviewList-layout.scss +1 -0
  25. package/src/assets/styles/v2/scss/Autocomplete/Autocomplete-layout.scss +8 -0
  26. package/src/assets/styles/v2/scss/ChannelHeader/ChannelHeader-layout.scss +4 -0
  27. package/src/assets/styles/v2/scss/ChannelPreview/ChannelPreview-layout.scss +1 -0
  28. package/src/assets/styles/v2/scss/ChannelSearch/ChannelSearch-layout.scss +5 -0
  29. package/src/assets/styles/v2/scss/LinkPreview/LinkPreview-layout.scss +49 -0
  30. package/src/assets/styles/v2/scss/LinkPreview/LinkPreview-theme.scss +17 -0
  31. package/src/assets/styles/v2/scss/LinkPreview/index.scss +2 -0
  32. package/src/assets/styles/v2/scss/Message/Message-layout.scss +8 -0
  33. package/src/assets/styles/v2/scss/MessageInput/MessageInput-layout.scss +1 -1
  34. package/src/assets/styles/v2/scss/MessageList/MessageList-layout.scss +1 -0
  35. package/src/assets/styles/v2/scss/MessageList/VirtualizedMessageList-layout.scss +4 -0
  36. package/src/assets/styles/v2/scss/Notification/Notification-layout.scss +4 -0
  37. package/src/assets/styles/v2/scss/Thread/Thread-layout.scss +4 -0
  38. package/src/assets/styles/v2/scss/Tooltip/Tooltip-layout.scss +1 -0
  39. package/src/assets/styles/v2/scss/_emoji-replacement.scss +1 -0
  40. package/src/assets/styles/v2/scss/_utils.scss +5 -0
  41. package/src/assets/styles/v2/scss/index.layout.scss +1 -1
  42. package/src/assets/styles/v2/scss/index.scss +1 -1
  43. package/src/assets/version.ts +1 -1
  44. package/src/assets/styles/css/index.css.map +0 -1
  45. package/src/assets/styles/v2/css/index.css.map +0 -1
  46. package/src/assets/styles/v2/css/index.layout.css.map +0 -1
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../projects/stream-chat-angular/src/lib/types.ts"],"names":[],"mappings":"","sourcesContent":["import { TemplateRef } from '@angular/core';\nimport { Observable, Subject } from 'rxjs';\nimport type {\n  Attachment,\n  Channel,\n  ChannelMemberResponse,\n  CommandResponse,\n  Event,\n  ExtendableGenerics,\n  FormatMessageResponse,\n  LiteralStringForUnion,\n  MessageResponseBase,\n  Mute,\n  ReactionResponse,\n  User,\n  UserResponse,\n} from 'stream-chat';\nimport { AttachmentService } from './attachment.service';\nimport { Icon } from './icon/icon.component';\n\nexport type UnknownType = Record<string, unknown>;\n\nexport type CustomTrigger = {\n  [key: string]: {\n    componentProps: UnknownType;\n    data: UnknownType;\n  };\n};\n\nexport type DefaultStreamChatGenerics = ExtendableGenerics & {\n  attachmentType: DefaultAttachmentType;\n  channelType: DefaultChannelType;\n  commandType: LiteralStringForUnion;\n  eventType: UnknownType;\n  messageType: DefaultMessageType;\n  reactionType: UnknownType;\n  userType: DefaultUserType;\n};\n\nexport type DefaultAttachmentType = UnknownType & {\n  asset_url?: string;\n  id?: string;\n  images?: Array<Attachment<DefaultStreamChatGenerics>>;\n  mime_type?: string;\n  isCustomAttachment?: boolean;\n};\n\nexport type DefaultChannelType = UnknownType & {\n  image?: string;\n  member_count?: number;\n  subtitle?: string;\n};\n\nexport type DefaultCommandType = LiteralStringForUnion;\n\nexport type DefaultMessageType = UnknownType & {\n  customType?: 'channel.intro' | 'message.date';\n  date?: string | Date;\n  errorStatusCode?: number;\n  event?: Event<DefaultStreamChatGenerics>;\n  unread?: boolean;\n  readBy: UserResponse<DefaultStreamChatGenerics>[];\n  translation?: string;\n  quoted_message?: MessageResponseBase<DefaultStreamChatGenerics>;\n};\n\nexport type DefaultUserTypeInternal = {\n  image?: string;\n  status?: string;\n};\n\nexport type DefaultUserType = UnknownType &\n  DefaultUserTypeInternal & {\n    mutes?: Array<Mute<DefaultStreamChatGenerics>>;\n  };\n\nexport type StreamMessage<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = FormatMessageResponse<T>;\n\nexport type AttachmentUpload<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = {\n  file: File;\n  state: 'error' | 'success' | 'uploading';\n  url?: string;\n  type: 'image' | 'file' | 'video';\n  previewUri?: string | ArrayBuffer;\n  thumb_url?: string;\n  fromAttachment?: Attachment<T>;\n};\n\nexport type MentionAutcompleteListItemContext = {\n  item: MentionAutcompleteListItem;\n};\n\nexport type CommandAutocompleteListItemContext = {\n  item: ComandAutocompleteListItem;\n};\n\nexport type MentionAutcompleteListItem = (\n  | ChannelMemberResponse\n  | UserResponse\n) & {\n  autocompleteLabel: string;\n};\n\nexport type ComandAutocompleteListItem = CommandResponse & {\n  autocompleteLabel: string;\n};\n\nexport type NotificationType = 'success' | 'error' | 'info';\n\nexport type NotificationPayload<T = {}> = {\n  id: string;\n  type: NotificationType;\n  text?: string;\n  translateParams?: Object;\n  template?: TemplateRef<T>;\n  templateContext?: T;\n  dismissFn: Function;\n};\n\nexport type ChannelPreviewContext<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = {\n  channel: Channel<T>;\n};\n\nexport type MessageInputContext = {\n  isFileUploadEnabled: boolean | undefined;\n  areMentionsEnabled: boolean | undefined;\n  mentionScope: 'channel' | 'application' | undefined;\n  mode: 'thread' | 'main' | undefined;\n  isMultipleFileUploadEnabled: boolean | undefined;\n  message: StreamMessage | undefined;\n  messageUpdateHandler: Function | undefined;\n  sendMessage$: Observable<void>;\n};\n\nexport type MentionTemplateContext = {\n  content: string;\n  user: UserResponse;\n};\n\nexport type EmojiPickerContext = {\n  emojiInput$: Subject<string>;\n};\n\nexport type TypingIndicatorContext = {\n  usersTyping$: Observable<UserResponse<DefaultStreamChatGenerics>[]>;\n};\n\nexport type MessageContext = {\n  message: StreamMessage | undefined;\n  enabledMessageActions: string[];\n  isLastSentMessage: boolean | undefined;\n  mode: 'thread' | 'main';\n  isHighlighted: boolean;\n  customActions: CustomMessageActionItem[];\n};\n\nexport type ChannelActionsContext<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = { channel: Channel<T> };\n\nexport type AttachmentListContext = {\n  messageId: string;\n  attachments: Attachment<DefaultStreamChatGenerics>[];\n  parentMessageId?: string;\n  imageModalStateChangeHandler?: (state: 'opened' | 'closed') => {};\n};\n\nexport type AvatarType = 'channel' | 'user';\n\nexport type AvatarLocation =\n  | 'channel-preview'\n  | 'channel-header'\n  | 'message-sender'\n  | 'message-reader'\n  | 'quoted-message-sender'\n  | 'autocomplete-item'\n  | 'typing-indicator'\n  | 'reaction';\n\nexport type AvatarContext = {\n  name: string | undefined;\n  imageUrl: string | undefined;\n  size: number | undefined;\n  type: AvatarType | undefined;\n  location: AvatarLocation | undefined;\n  channel?: Channel<DefaultStreamChatGenerics>;\n  user?: User<DefaultStreamChatGenerics>;\n  initialsType?: 'first-letter-of-first-word' | 'first-letter-of-each-word';\n  showOnlineIndicator?: boolean;\n};\n\nexport type AttachmentPreviewListContext = {\n  attachmentUploads$: Observable<AttachmentUpload[]> | undefined;\n  retryUploadHandler: (f: File) => any;\n  deleteUploadHandler: (u: AttachmentUpload) => any;\n};\n\nexport type IconContext = {\n  icon: Icon | undefined;\n  size: number | undefined;\n};\n\nexport type LoadingIndicatorContext = {\n  size: number | undefined;\n  color: string | undefined;\n};\n\nexport type MessageActionsBoxContext = {\n  isOpen: boolean;\n  isMine: boolean;\n  message: StreamMessage | undefined;\n  enabledActions: string[];\n  customActions: CustomMessageActionItem[];\n  /**\n   * @deprecated because the name contains typos, use the `displayedActionsCountChangeHandler` instead\n   */\n  displayedActionsCountChaneHanler: (count: number) => any;\n  displayedActionsCountChangeHandler: (count: number) => any;\n  isEditingChangeHandler: (isEditing: boolean) => any;\n};\n\nexport type MessageActionBoxItemContext<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = {\n  actionName: 'quote' | 'pin' | 'flag' | 'edit' | 'delete' | string;\n  actionLabelOrTranslationKey: ((message: StreamMessage<T>) => string) | string;\n  message: StreamMessage<T>;\n  isMine: boolean;\n  actionHandler: (message: StreamMessage<T>, isMine: boolean) => any;\n};\n\ntype MessageActionItemBase<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = {\n  actionLabelOrTranslationKey: ((message: StreamMessage<T>) => string) | string;\n  isVisible: (\n    enabledActions: string[],\n    isMine: boolean,\n    message: StreamMessage<T>\n  ) => boolean;\n  actionHandler: (message: StreamMessage<T>, isMine: boolean) => any;\n};\n\nexport type MessageActionItem<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = MessageActionItemBase<T> & {\n  actionName: 'quote' | 'pin' | 'flag' | 'edit' | 'delete';\n};\n\nexport type CustomMessageActionItem<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = MessageActionItemBase<T> & {\n  actionName: string;\n};\n\nexport type MessageReactionsContext = {\n  messageId: string | undefined;\n  messageReactionCounts: { [key in MessageReactionType]?: number };\n  isSelectorOpen: boolean;\n  latestReactions: ReactionResponse<DefaultStreamChatGenerics>[];\n  ownReactions: ReactionResponse<DefaultStreamChatGenerics>[];\n  isSelectorOpenChangeHandler: (isOpen: boolean) => any;\n};\n\nexport type ModalContext = {\n  isOpen: boolean;\n  isOpenChangeHandler: (isOpen: boolean) => any;\n  content: TemplateRef<void>;\n};\n\nexport type NotificationContext = {\n  type: NotificationType | undefined;\n  content: TemplateRef<void> | undefined;\n};\n\nexport type ThreadHeaderContext = {\n  parentMessage: StreamMessage | undefined;\n  closeThreadHandler: Function;\n};\n\nexport type MessageReactionType =\n  | 'angry'\n  | 'haha'\n  | 'like'\n  | 'love'\n  | 'sad'\n  | 'wow'\n  | string;\n\nexport type AttachmentConfigration = {\n  url: string;\n  height: string;\n  width: string;\n};\n\nexport type ImageAttachmentConfiguration = AttachmentConfigration & {\n  originalHeight: number;\n  originalWidth: number;\n};\n\nexport type VideoAttachmentConfiguration = ImageAttachmentConfiguration & {\n  thumbUrl?: string;\n};\n\nexport type DeliveredStatusContext = {\n  message: StreamMessage;\n};\n\nexport type SendingStatusContext = {\n  message: StreamMessage;\n};\n\nexport type ReadStatusContext = {\n  message: StreamMessage;\n  readByText: string;\n};\n\nexport type ChannelHeaderInfoContext<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = { channel: Channel<T> };\n\nexport type CustomAttachmentUploadContext = {\n  isMultipleFileUploadEnabled: boolean | undefined;\n  attachmentService: AttachmentService;\n};\n\nexport type AttachmentContext = {\n  attachment: Attachment<DefaultStreamChatGenerics>;\n};\n\nexport type SystemMessageContext = MessageContext & {\n  parsedDate: string | undefined;\n};\n\nexport type DateSeparatorContext = {\n  date: Date;\n  parsedDate: string;\n  isNewMessage: boolean;\n};\n\nexport type ChannelQueryState = {\n  state: 'in-progress' | 'success' | 'error';\n  // No type def from stream-chat\n  error?: unknown;\n};\n\nexport type MessageInput<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = {\n  text: string;\n  attachments: Attachment<T>[];\n  mentionedUsers: UserResponse<T>[];\n  parentId: string | undefined;\n  quotedMessageId: string | undefined;\n  customData: undefined | Partial<T['messageType']>;\n};\n"]}
2
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../projects/stream-chat-angular/src/lib/types.ts"],"names":[],"mappings":"","sourcesContent":["import { TemplateRef } from '@angular/core';\nimport { Observable, Subject } from 'rxjs';\nimport type {\n  Attachment,\n  Channel,\n  ChannelFilters,\n  ChannelMemberResponse,\n  CommandResponse,\n  Event,\n  ExtendableGenerics,\n  FormatMessageResponse,\n  LiteralStringForUnion,\n  MessageResponseBase,\n  Mute,\n  ReactionResponse,\n  User,\n  UserResponse,\n} from 'stream-chat';\nimport { AttachmentService } from './attachment.service';\nimport { Icon } from './icon/icon.component';\n\nexport type UnknownType = Record<string, unknown>;\n\nexport type CustomTrigger = {\n  [key: string]: {\n    componentProps: UnknownType;\n    data: UnknownType;\n  };\n};\n\nexport type DefaultStreamChatGenerics = ExtendableGenerics & {\n  attachmentType: DefaultAttachmentType;\n  channelType: DefaultChannelType;\n  commandType: LiteralStringForUnion;\n  eventType: UnknownType;\n  messageType: DefaultMessageType;\n  reactionType: UnknownType;\n  userType: DefaultUserType;\n};\n\nexport type DefaultAttachmentType = UnknownType & {\n  asset_url?: string;\n  id?: string;\n  images?: Array<Attachment<DefaultStreamChatGenerics>>;\n  mime_type?: string;\n  isCustomAttachment?: boolean;\n};\n\nexport type DefaultChannelType = UnknownType & {\n  image?: string;\n  member_count?: number;\n  subtitle?: string;\n};\n\nexport type DefaultCommandType = LiteralStringForUnion;\n\nexport type DefaultMessageType = UnknownType & {\n  customType?: 'channel.intro' | 'message.date';\n  date?: string | Date;\n  errorStatusCode?: number;\n  event?: Event<DefaultStreamChatGenerics>;\n  unread?: boolean;\n  readBy: UserResponse<DefaultStreamChatGenerics>[];\n  translation?: string;\n  quoted_message?: MessageResponseBase<DefaultStreamChatGenerics>;\n};\n\nexport type DefaultUserTypeInternal = {\n  image?: string;\n  status?: string;\n};\n\nexport type DefaultUserType = UnknownType &\n  DefaultUserTypeInternal & {\n    mutes?: Array<Mute<DefaultStreamChatGenerics>>;\n  };\n\nexport type StreamMessage<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = FormatMessageResponse<T>;\n\nexport type AttachmentUploadErrorReason =\n  | 'file-size'\n  | 'file-extension'\n  | 'unknown';\n\nexport type AttachmentUpload<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = {\n  file: File;\n  state: 'error' | 'success' | 'uploading';\n  errorReason?: AttachmentUploadErrorReason;\n  errorExtraInfo?: { param: string }[];\n  url?: string;\n  type: 'image' | 'file' | 'video';\n  previewUri?: string | ArrayBuffer;\n  thumb_url?: string;\n  fromAttachment?: Attachment<T>;\n};\n\nexport type MentionAutcompleteListItemContext = {\n  item: MentionAutcompleteListItem;\n};\n\nexport type CommandAutocompleteListItemContext = {\n  item: ComandAutocompleteListItem;\n};\n\nexport type MentionAutcompleteListItem = (\n  | ChannelMemberResponse\n  | UserResponse\n) & {\n  autocompleteLabel: string;\n};\n\nexport type ComandAutocompleteListItem = CommandResponse & {\n  autocompleteLabel: string;\n};\n\nexport type NotificationType = 'success' | 'error' | 'info';\n\nexport type NotificationPayload<T = {}> = {\n  id: string;\n  type: NotificationType;\n  text?: string;\n  translateParams?: Object;\n  template?: TemplateRef<T>;\n  templateContext?: T;\n  dismissFn: Function;\n};\n\nexport type ChannelPreviewContext<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = {\n  channel: Channel<T>;\n};\n\nexport type MessageInputContext = {\n  isFileUploadEnabled: boolean | undefined;\n  areMentionsEnabled: boolean | undefined;\n  mentionScope: 'channel' | 'application' | undefined;\n  mode: 'thread' | 'main' | undefined;\n  isMultipleFileUploadEnabled: boolean | undefined;\n  message: StreamMessage | undefined;\n  messageUpdateHandler: Function | undefined;\n  sendMessage$: Observable<void>;\n};\n\nexport type MentionTemplateContext = {\n  content: string;\n  user: UserResponse;\n};\n\nexport type EmojiPickerContext = {\n  emojiInput$: Subject<string>;\n};\n\nexport type TypingIndicatorContext = {\n  usersTyping$: Observable<UserResponse<DefaultStreamChatGenerics>[]>;\n};\n\nexport type MessageContext = {\n  message: StreamMessage | undefined;\n  enabledMessageActions: string[];\n  isLastSentMessage: boolean | undefined;\n  mode: 'thread' | 'main';\n  isHighlighted: boolean;\n  customActions: CustomMessageActionItem[];\n};\n\nexport type ChannelActionsContext<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = { channel: Channel<T> };\n\nexport type AttachmentListContext = {\n  messageId: string;\n  attachments: Attachment<DefaultStreamChatGenerics>[];\n  parentMessageId?: string;\n  imageModalStateChangeHandler?: (state: 'opened' | 'closed') => {};\n};\n\nexport type AvatarType = 'channel' | 'user';\n\nexport type AvatarLocation =\n  | 'channel-preview'\n  | 'channel-header'\n  | 'message-sender'\n  | 'message-reader'\n  | 'quoted-message-sender'\n  | 'autocomplete-item'\n  | 'typing-indicator'\n  | 'reaction';\n\nexport type AvatarContext = {\n  name: string | undefined;\n  imageUrl: string | undefined;\n  size: number | undefined;\n  type: AvatarType | undefined;\n  location: AvatarLocation | undefined;\n  channel?: Channel<DefaultStreamChatGenerics>;\n  user?: User<DefaultStreamChatGenerics>;\n  initialsType?: 'first-letter-of-first-word' | 'first-letter-of-each-word';\n  showOnlineIndicator?: boolean;\n};\n\nexport type AttachmentPreviewListContext = {\n  attachmentUploads$: Observable<AttachmentUpload[]> | undefined;\n  retryUploadHandler: (f: File) => any;\n  deleteUploadHandler: (u: AttachmentUpload) => any;\n};\n\nexport type IconContext = {\n  icon: Icon | undefined;\n  size: number | undefined;\n};\n\nexport type LoadingIndicatorContext = {\n  size: number | undefined;\n  color: string | undefined;\n};\n\nexport type MessageActionsBoxContext = {\n  isOpen: boolean;\n  isMine: boolean;\n  message: StreamMessage | undefined;\n  enabledActions: string[];\n  customActions: CustomMessageActionItem[];\n  /**\n   * @deprecated because the name contains typos, use the `displayedActionsCountChangeHandler` instead\n   */\n  displayedActionsCountChaneHanler: (count: number) => any;\n  displayedActionsCountChangeHandler: (count: number) => any;\n  isEditingChangeHandler: (isEditing: boolean) => any;\n};\n\nexport type MessageActionBoxItemContext<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = {\n  actionName: 'quote' | 'pin' | 'flag' | 'edit' | 'delete' | string;\n  actionLabelOrTranslationKey: ((message: StreamMessage<T>) => string) | string;\n  message: StreamMessage<T>;\n  isMine: boolean;\n  actionHandler: (message: StreamMessage<T>, isMine: boolean) => any;\n};\n\ntype MessageActionItemBase<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = {\n  actionLabelOrTranslationKey: ((message: StreamMessage<T>) => string) | string;\n  isVisible: (\n    enabledActions: string[],\n    isMine: boolean,\n    message: StreamMessage<T>\n  ) => boolean;\n  actionHandler: (message: StreamMessage<T>, isMine: boolean) => any;\n};\n\nexport type MessageActionItem<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = MessageActionItemBase<T> & {\n  actionName: 'quote' | 'pin' | 'flag' | 'edit' | 'delete';\n};\n\nexport type CustomMessageActionItem<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = MessageActionItemBase<T> & {\n  actionName: string;\n};\n\nexport type MessageReactionsContext = {\n  messageId: string | undefined;\n  messageReactionCounts: { [key in MessageReactionType]?: number };\n  isSelectorOpen: boolean;\n  latestReactions: ReactionResponse<DefaultStreamChatGenerics>[];\n  ownReactions: ReactionResponse<DefaultStreamChatGenerics>[];\n  isSelectorOpenChangeHandler: (isOpen: boolean) => any;\n};\n\nexport type ModalContext = {\n  isOpen: boolean;\n  isOpenChangeHandler: (isOpen: boolean) => any;\n  content: TemplateRef<void>;\n};\n\nexport type NotificationContext = {\n  type: NotificationType | undefined;\n  content: TemplateRef<void> | undefined;\n};\n\nexport type ThreadHeaderContext = {\n  parentMessage: StreamMessage | undefined;\n  closeThreadHandler: Function;\n};\n\nexport type MessageReactionType =\n  | 'angry'\n  | 'haha'\n  | 'like'\n  | 'love'\n  | 'sad'\n  | 'wow'\n  | string;\n\nexport type AttachmentConfigration = {\n  url: string;\n  height: string;\n  width: string;\n};\n\nexport type ImageAttachmentConfiguration = AttachmentConfigration & {\n  originalHeight: number;\n  originalWidth: number;\n};\n\nexport type VideoAttachmentConfiguration = ImageAttachmentConfiguration & {\n  thumbUrl?: string;\n};\n\nexport type DeliveredStatusContext = {\n  message: StreamMessage;\n};\n\nexport type SendingStatusContext = {\n  message: StreamMessage;\n};\n\nexport type ReadStatusContext = {\n  message: StreamMessage;\n  readByText: string;\n};\n\nexport type ChannelHeaderInfoContext<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = { channel: Channel<T> };\n\nexport type CustomAttachmentUploadContext = {\n  isMultipleFileUploadEnabled: boolean | undefined;\n  attachmentService: AttachmentService;\n};\n\nexport type AttachmentContext = {\n  attachment: Attachment<DefaultStreamChatGenerics>;\n};\n\nexport type SystemMessageContext = MessageContext & {\n  parsedDate: string | undefined;\n};\n\nexport type DateSeparatorContext = {\n  date: Date;\n  parsedDate: string;\n  isNewMessage: boolean;\n};\n\nexport type ChannelQueryState = {\n  state: 'in-progress' | 'success' | 'error';\n  // No type def from stream-chat\n  error?: unknown;\n};\n\nexport type MessageInput<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = {\n  text: string;\n  attachments: Attachment<T>[];\n  mentionedUsers: UserResponse<T>[];\n  parentId: string | undefined;\n  quotedMessageId: string | undefined;\n  customData: undefined | Partial<T['messageType']>;\n};\n\nexport type OffsetNextPageConfiguration = {\n  type: 'offset';\n  offset: number;\n};\n\nexport type FiltertNextPageConfiguration<\n  T extends DefaultStreamChatGenerics = DefaultStreamChatGenerics\n> = {\n  type: 'filter';\n  paginationFilter: ChannelFilters<T>;\n};\n\nexport type NextPageConfiguration =\n  | OffsetNextPageConfiguration\n  | FiltertNextPageConfiguration;\n"]}
@@ -20,7 +20,7 @@ import transliterate from '@stream-io/transliterate';
20
20
  import * as i8 from 'angular-mentions';
21
21
  import { MentionModule } from 'angular-mentions';
22
22
 
23
- const version = '4.47.3';
23
+ const version = '4.49.0';
24
24
 
25
25
  /**
26
26
  * The `NotificationService` can be used to add or remove notifications. By default the [`NotificationList`](../components/NotificationListComponent.mdx) component displays the currently active notifications.
@@ -601,8 +601,8 @@ class ChannelService {
601
601
  init(filters, sort, options, shouldSetActiveChannel = true) {
602
602
  return __awaiter(this, void 0, void 0, function* () {
603
603
  this.filters = filters;
604
- this.options = Object.assign({ offset: 0, limit: 25, state: true, presence: true, watch: true, message_limit: this.messagePageSize }, options);
605
- this.sort = sort || { last_message_at: -1, updated_at: -1 };
604
+ this.options = Object.assign({ limit: 25, state: true, presence: true, watch: true, message_limit: this.messagePageSize }, options);
605
+ this.sort = sort || { last_message_at: -1 };
606
606
  this.shouldSetActiveChannel = shouldSetActiveChannel;
607
607
  this.clientEventsSubscription = this.chatClientService.events$.subscribe((notification) => void this.handleNotification(notification));
608
608
  try {
@@ -637,7 +637,6 @@ class ChannelService {
637
637
  */
638
638
  loadMoreChannels() {
639
639
  return __awaiter(this, void 0, void 0, function* () {
640
- this.options.offset = this.channels.length;
641
640
  yield this.queryChannels(false);
642
641
  });
643
642
  }
@@ -758,6 +757,7 @@ class ChannelService {
758
757
  ? this.customFileUploadRequest(upload.file, channel)
759
758
  : channel.sendFile(upload.file, upload.file.name, upload.file.type)));
760
759
  uploadResults.forEach((uploadResult, i) => {
760
+ var _a, _b, _c, _d, _e, _f, _g;
761
761
  const file = uploads[i].file;
762
762
  const type = uploads[i].type;
763
763
  if (uploadResult.status === 'fulfilled') {
@@ -771,7 +771,32 @@ class ChannelService {
771
771
  });
772
772
  }
773
773
  else {
774
- result.push({ file, type, state: 'error' });
774
+ let reason = 'unknown';
775
+ let extraData;
776
+ /* eslint-disable-next-line @typescript-eslint/no-unsafe-assignment */
777
+ const message =
778
+ /* eslint-disable-next-line @typescript-eslint/no-unsafe-member-access */
779
+ (_b = (_a = uploadResult.reason.response) === null || _a === void 0 ? void 0 : _a.data) === null || _b === void 0 ? void 0 : _b.message;
780
+ /* eslint-disable-next-line @typescript-eslint/no-unsafe-assignment */
781
+ const code =
782
+ /* eslint-disable-next-line @typescript-eslint/no-unsafe-member-access */
783
+ (_d = (_c = uploadResult.reason.response) === null || _c === void 0 ? void 0 : _c.data) === null || _d === void 0 ? void 0 : _d.code;
784
+ if (code === 22) {
785
+ reason = 'file-size';
786
+ extraData = { param: ((_e = /\d+MB/.exec(message || '')) === null || _e === void 0 ? void 0 : _e[0]) || '100MB' };
787
+ }
788
+ else if (code === 4 &&
789
+ ((_f = message === null || message === void 0 ? void 0 : message.toLowerCase()) === null || _f === void 0 ? void 0 : _f.includes('file extension'))) {
790
+ reason = 'file-extension';
791
+ extraData = { param: ((_g = /\.\w+/.exec(message)) === null || _g === void 0 ? void 0 : _g[0]) || '' };
792
+ }
793
+ result.push({
794
+ file,
795
+ type,
796
+ state: 'error',
797
+ errorReason: reason,
798
+ errorExtraInfo: extraData ? [extraData] : undefined,
799
+ });
775
800
  }
776
801
  });
777
802
  return result;
@@ -985,9 +1010,7 @@ class ChannelService {
985
1010
  }
986
1011
  this.isStateRecoveryInProgress = true;
987
1012
  try {
988
- if (this.options) {
989
- this.options.offset = 0;
990
- }
1013
+ this.nextPageConfiguration = undefined;
991
1014
  // If channel list is not inited, we set the active channel
992
1015
  const shoulSetActiveChannel = this.shouldSetActiveChannel &&
993
1016
  !this.activeChannelSubject.getValue();
@@ -1203,6 +1226,18 @@ class ChannelService {
1203
1226
  yield (activeChannel === null || activeChannel === void 0 ? void 0 : activeChannel.stopTyping(parentId));
1204
1227
  });
1205
1228
  }
1229
+ /**
1230
+ * The current list of channels
1231
+ */
1232
+ get channels() {
1233
+ return this.channelsSubject.getValue() || [];
1234
+ }
1235
+ /**
1236
+ * The current active channel
1237
+ */
1238
+ get activeChannel() {
1239
+ return this.activeChannelSubject.getValue() || undefined;
1240
+ }
1206
1241
  messageUpdated(event) {
1207
1242
  this.ngZone.run(() => {
1208
1243
  var _a;
@@ -1284,21 +1319,39 @@ class ChannelService {
1284
1319
  return __awaiter(this, void 0, void 0, function* () {
1285
1320
  try {
1286
1321
  this.channelQueryStateSubject.next({ state: 'in-progress' });
1287
- const channels = yield this.chatClientService.chatClient.queryChannels(this.filters, this.sort || {}, this.options);
1322
+ let filters;
1323
+ let options;
1324
+ if (this.nextPageConfiguration) {
1325
+ if (this.nextPageConfiguration.type === 'filter') {
1326
+ filters = Object.assign(Object.assign({}, this.filters), this.nextPageConfiguration.paginationFilter);
1327
+ options = this.options;
1328
+ }
1329
+ else {
1330
+ options = Object.assign(Object.assign({}, this.options), { offset: this.nextPageConfiguration.offset });
1331
+ filters = this.filters;
1332
+ }
1333
+ }
1334
+ else {
1335
+ filters = this.filters;
1336
+ options = this.options;
1337
+ }
1338
+ const channels = yield this.chatClientService.chatClient.queryChannels(filters, this.sort || {}, options);
1339
+ this.setNextPageConfiguration(channels);
1288
1340
  channels.forEach((c) => this.watchForChannelEvents(c));
1289
1341
  const prevChannels = recoverState
1290
1342
  ? []
1291
1343
  : this.channelsSubject.getValue() || [];
1292
- this.channelsSubject.next([...prevChannels, ...channels]);
1344
+ const filteredChannels = channels.filter((channel) => !prevChannels.find((existingChannel) => existingChannel.cid === channel.cid));
1345
+ this.channelsSubject.next([...prevChannels, ...filteredChannels]);
1293
1346
  let currentActiveChannel = this.activeChannelSubject.getValue();
1294
- if (channels.length > 0 &&
1347
+ if (filteredChannels.length > 0 &&
1295
1348
  !currentActiveChannel &&
1296
1349
  shouldSetActiveChannel) {
1297
- this.setAsActiveChannel(channels[0]);
1350
+ this.setAsActiveChannel(filteredChannels[0]);
1298
1351
  currentActiveChannel = this.activeChannelSubject.getValue();
1299
1352
  }
1300
1353
  if (recoverState &&
1301
- !channels.find((c) => c.cid === (currentActiveChannel === null || currentActiveChannel === void 0 ? void 0 : currentActiveChannel.cid))) {
1354
+ !filteredChannels.find((c) => c.cid === (currentActiveChannel === null || currentActiveChannel === void 0 ? void 0 : currentActiveChannel.cid))) {
1302
1355
  this.deselectActiveChannel();
1303
1356
  }
1304
1357
  this.hasMoreChannelsSubject.next(channels.length >= this.options.limit);
@@ -1462,9 +1515,6 @@ class ChannelService {
1462
1515
  }
1463
1516
  }
1464
1517
  }
1465
- get channels() {
1466
- return this.channelsSubject.getValue() || [];
1467
- }
1468
1518
  get canSendReadEvents() {
1469
1519
  var _a;
1470
1520
  const channel = this.activeChannelSubject.getValue();
@@ -1588,6 +1638,20 @@ class ChannelService {
1588
1638
  void channel.markRead();
1589
1639
  }
1590
1640
  }
1641
+ setNextPageConfiguration(channelQueryResult) {
1642
+ var _a;
1643
+ if (this.customPaginator) {
1644
+ this.nextPageConfiguration = this.customPaginator(channelQueryResult);
1645
+ }
1646
+ else {
1647
+ this.nextPageConfiguration = {
1648
+ type: 'offset',
1649
+ offset: (((_a = this.nextPageConfiguration) === null || _a === void 0 ? void 0 : _a.type) === 'offset'
1650
+ ? this.nextPageConfiguration.offset
1651
+ : 0) + channelQueryResult.length,
1652
+ };
1653
+ }
1654
+ }
1591
1655
  }
1592
1656
  ChannelService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: ChannelService, deps: [{ token: ChatClientService }, { token: i0.NgZone }, { token: NotificationService }], target: i0.ɵɵFactoryTarget.Injectable });
1593
1657
  ChannelService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: ChannelService, providedIn: 'root' });
@@ -1949,6 +2013,7 @@ class AttachmentService {
1949
2013
  const result = yield this.channelService.uploadAttachments(uploads);
1950
2014
  const attachmentUploads = this.attachmentUploadsSubject.getValue();
1951
2015
  result.forEach((r) => {
2016
+ var _a, _b, _c, _d;
1952
2017
  const upload = attachmentUploads.find((upload) => upload.file === r.file);
1953
2018
  if (!upload) {
1954
2019
  if (r.url) {
@@ -1960,9 +2025,25 @@ class AttachmentService {
1960
2025
  upload.url = r.url;
1961
2026
  upload.thumb_url = r.thumb_url;
1962
2027
  if (upload.state === 'error') {
1963
- this.notificationService.addTemporaryNotification(upload.type === 'image'
1964
- ? 'streamChat.Error uploading image'
1965
- : 'streamChat.Error uploading file');
2028
+ upload.errorReason = r.errorReason;
2029
+ upload.errorExtraInfo = r.errorExtraInfo;
2030
+ let errorKey;
2031
+ const translateParams = { name: upload.file.name };
2032
+ switch (upload.errorReason) {
2033
+ case 'file-extension':
2034
+ errorKey =
2035
+ 'streamChat.Error uploading file, extension not supported';
2036
+ translateParams.ext = (_b = (_a = upload.errorExtraInfo) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.param;
2037
+ break;
2038
+ case 'file-size':
2039
+ errorKey =
2040
+ 'streamChat.Error uploading file, maximum file size exceeded';
2041
+ translateParams.limit = (_d = (_c = upload.errorExtraInfo) === null || _c === void 0 ? void 0 : _c[0]) === null || _d === void 0 ? void 0 : _d.param;
2042
+ break;
2043
+ default:
2044
+ errorKey = 'streamChat.Error uploading file';
2045
+ }
2046
+ this.notificationService.addTemporaryNotification(errorKey, 'error', undefined, translateParams);
1966
2047
  }
1967
2048
  });
1968
2049
  this.attachmentUploadInProgressCounterSubject.next(this.attachmentUploadInProgressCounterSubject.getValue() - 1);
@@ -2166,8 +2247,9 @@ const en = {
2166
2247
  'Error pinning message': 'Error pinning message',
2167
2248
  'Error removing message pin': 'Error removing message pin',
2168
2249
  'Error unmuting a user ...': 'Error unmuting a user ...',
2169
- 'Error uploading file': 'Error uploading file',
2170
- 'Error uploading image': 'Error uploading image',
2250
+ 'Error uploading file': 'Error uploading file "{{ name }}"',
2251
+ 'Error uploading file, maximum file size exceeded': 'Error uploading "{{ name }}", maximum file size {{ limit }} exceeded',
2252
+ 'Error uploading file, extension not supported': 'Error uploading "{{ name }}", extension {{ ext }} not supported',
2171
2253
  'Error deleting attachment': 'Error deleting attachment',
2172
2254
  'Error · Unsent': "Message couldn't be sent",
2173
2255
  'Error: {{ errorMessage }}': 'Error: {{ errorMessage }}',