Class MessageReactionUpdated

Hierarchy (View Summary)

  • Base
    • MessageReactionUpdated

Constructors

Properties

actorChat: Chat

The chat on behalf of which the reaction was changed, if the user is anonymous

chat: Chat

The chat containing the message the user reacted to

createdUnixTime: number

Date of the change in Unix time

customEmojiSummary?: { added: string[]; kept: string[]; removed: string[] }

Summary of custom emoji reactions

emojiSummary?: {
    added: (
        | "👍"
        | "👎"
        | "❤"
        | "🔥"
        | "🥰"
        | "👏"
        | "😁"
        | "🤔"
        | "🤯"
        | "😱"
        | "🤬"
        | "😢"
        | "🎉"
        | "🤩"
        | "🤮"
        | "💩"
        | "🙏"
        | "👌"
        | "🕊"
        | "🤡"
        | "🥱"
        | "🥴"
        | "😍"
        | "🐳"
        | "❤‍🔥"
        | "🌚"
        | "🌭"
        | "💯"
        | "🤣"
        | "⚡"
        | "🍌"
        | "🏆"
        | "💔"
        | "🤨"
        | "😐"
        | "🍓"
        | "🍾"
        | "💋"
        | "🖕"
        | "😈"
        | "😴"
        | "😭"
        | "🤓"
        | "👻"
        | "👨‍💻"
        | "👀"
        | "🎃"
        | "🙈"
        | "😇"
        | "😨"
        | "🤝"
        | "✍"
        | "🤗"
        | "🫡"
        | "🎅"
        | "🎄"
        | "☃"
        | "💅"
        | "🤪"
        | "🗿"
        | "🆒"
        | "💘"
        | "🙉"
        | "🦄"
        | "😘"
        | "💊"
        | "🙊"
        | "😎"
        | "👾"
        | "🤷‍♂"
        | "🤷"
        | "🤷‍♀"
        | "😡"
    )[];
    kept: (
        | "👍"
        | "👎"
        | "❤"
        | "🔥"
        | "🥰"
        | "👏"
        | "😁"
        | "🤔"
        | "🤯"
        | "😱"
        | "🤬"
        | "😢"
        | "🎉"
        | "🤩"
        | "🤮"
        | "💩"
        | "🙏"
        | "👌"
        | "🕊"
        | "🤡"
        | "🥱"
        | "🥴"
        | "😍"
        | "🐳"
        | "❤‍🔥"
        | "🌚"
        | "🌭"
        | "💯"
        | "🤣"
        | "⚡"
        | "🍌"
        | "🏆"
        | "💔"
        | "🤨"
        | "😐"
        | "🍓"
        | "🍾"
        | "💋"
        | "🖕"
        | "😈"
        | "😴"
        | "😭"
        | "🤓"
        | "👻"
        | "👨‍💻"
        | "👀"
        | "🎃"
        | "🙈"
        | "😇"
        | "😨"
        | "🤝"
        | "✍"
        | "🤗"
        | "🫡"
        | "🎅"
        | "🎄"
        | "☃"
        | "💅"
        | "🤪"
        | "🗿"
        | "🆒"
        | "💘"
        | "🙉"
        | "🦄"
        | "😘"
        | "💊"
        | "🙊"
        | "😎"
        | "👾"
        | "🤷‍♂"
        | "🤷"
        | "🤷‍♀"
        | "😡"
    )[];
    removed: (
        | "👍"
        | "👎"
        | "❤"
        | "🔥"
        | "🥰"
        | "👏"
        | "😁"
        | "🤔"
        | "🤯"
        | "😱"
        | "🤬"
        | "😢"
        | "🎉"
        | "🤩"
        | "🤮"
        | "💩"
        | "🙏"
        | "👌"
        | "🕊"
        | "🤡"
        | "🥱"
        | "🥴"
        | "😍"
        | "🐳"
        | "❤‍🔥"
        | "🌚"
        | "🌭"
        | "💯"
        | "🤣"
        | "⚡"
        | "🍌"
        | "🏆"
        | "💔"
        | "🤨"
        | "😐"
        | "🍓"
        | "🍾"
        | "💋"
        | "🖕"
        | "😈"
        | "😴"
        | "😭"
        | "🤓"
        | "👻"
        | "👨‍💻"
        | "👀"
        | "🎃"
        | "🙈"
        | "😇"
        | "😨"
        | "🤝"
        | "✍"
        | "🤗"
        | "🫡"
        | "🎅"
        | "🎄"
        | "☃"
        | "💅"
        | "🤪"
        | "🗿"
        | "🆒"
        | "💘"
        | "🙉"
        | "🦄"
        | "😘"
        | "💊"
        | "🙊"
        | "😎"
        | "👾"
        | "🤷‍♂"
        | "🤷"
        | "🤷‍♀"
        | "😡"
    )[];
}

Summary of emoji reactions

id: string

Unique identifier of the message inside the chat

paidEmoji?: { added: boolean; removed: boolean }

Summary of paid emoji reactions

user?: User

The user that changed the reaction, if the user isn't anonymous

Accessors

  • get createdAt(): Date
  • Date of the change

    Returns Date

  • get createdTimestamp(): number
  • Return the timestamp change, in milliseconds

    Returns number

Methods

  • Protected

    Creates a clone of the current instance

    Returns Base

    A clone of the current instance

  • Protected

    Patches the current instance with new data

    Parameters

    • data: Record<string, any>

      The data to patch the instance with

    Returns Record<string, any>

    The patched data

  • Protected

    Updates the current instance with new data and returns a clone of the updated instance

    Parameters

    • data: Record<string, any>

      The data to update the instance with

    Returns Base

    A clone of the updated instance

  • Use this method to copy messages of any kind. Service messages, paid media messages, giveaway messages, giveaway winners messages, and invoice messages can't be copied. A quiz poll can be copied only if the value of the field correct_option_id is known to the bot. The method is analogous to the method forwardMessage, but the copied message doesn't have a link to the original message.

    Parameters

    • chatId: string | number

      Unique identifier for the target chat or username of the target channel (in the format @channelusername)

    • Optionaloptions: Omit<
          {
              caption?: string;
              captionEntities?: MessageEntity[];
              chatId: string
              | number;
              disableNotification?: boolean;
              fromChatId: string | number;
              messageId: string | number;
              messageThreadId?: string | number;
              parseMode?: string;
              protectContent?: boolean;
              replyMarkup?:
                  | InlineKeyboardMarkup
                  | ForceReply
                  | ReplyKeyboardMarkup
                  | ReplyKeyboardRemove;
              replyParameters?: ReplyParameters;
              showCaptionAboveMedia?: boolean;
          },
          "chatId"
          | "messageId"
          | "fromChatId",
      >

      out parameters

    Returns Promise<number>

    Returns the message id of the sent message on success.

  • Use this method to delete a message, including service messages, with the following limitations:

    • A message can only be deleted if it was sent less than 48 hours ago.
    • Service messages about a supergroup, channel, or forum topic creation can't be deleted.
    • A dice message in a private chat can only be deleted if it was sent more than 24 hours ago.
    • Bots can delete outgoing messages in private chats, groups, and supergroups.
    • Bots can delete incoming messages in private chats.
    • Bots granted can_post_messages permissions can delete outgoing messages in channels.
    • If the bot is an administrator of a group, it can delete any message there.
    • If the bot has can_delete_messages permission in a supergroup or a channel, it can delete any message there.

    Returns Promise<true>

    Returns True on success.

  • Use this method to edit text and game messages.

    Parameters

    • text: string

      New text of the message, 1-4096 characters after entities parsing

    • Optionaloptions: Omit<
          {
              businessConnectionId?: string;
              chatId?: string
              | number;
              entities?: MessageEntity[];
              inlineMessageId?: string | number;
              linkPreviewOptions?: LinkPreviewOptions;
              messageId?: string | number;
              parseMode?: ParseMode;
              replyMarkup?: InlineKeyboardMarkup;
              text: string;
          },
          "text"
          | "chatId"
          | "messageId",
      >

      out parameters

    Returns Promise<
        | true
        | Message & {
            content: string;
            editedAt: Date;
            editedTimestamp: number;
            editedUnixTime: number;
        },
    >

    On success, if the edited message is not an inline message, the edited Message is returned, otherwise True is returned. Note that business messages that were not sent by the bot and do not contain an inline keyboard can only be edited within 48 hours from the time they were sent.

  • Use this method to edit captions of messages.

    Parameters

    • Optionalcaption: string

      New caption of the message, 0-1024 characters after entities parsing

    • Optionaloptions: Omit<
          {
              businessConnectionId?: string;
              caption?: string;
              captionEntities?: MessageEntity[];
              chatId?: string
              | number;
              inlineMessageId?: string | number;
              messageId?: string | number;
              parseMode?: ParseMode;
              replyMarkup?: InlineKeyboardMarkup;
              showCaptionAboveMedia?: boolean;
          },
          "caption"
          | "chatId"
          | "messageId",
      >

      out parameters

    Returns Promise<
        | true
        | Message & {
            caption?: string;
            editedAt: Date;
            editedTimestamp: number;
            editedUnixTime: number;
        },
    >

    On success, if the edited message is not an inline message, the edited Message is returned, otherwise True is returned. Note that business messages that were not sent by the bot and do not contain an inline keyboard can only be edited within 48 hours from the time they were sent.

  • Use this method to edit live location messages. A location can be edited until its live_period expires or editing is explicitly disabled by a call to stopMessageLiveLocation.

    Parameters

    • latitude: number

      Latitude of new location

    • longitude: number

      Longitude of new location

    • Optionaloptions: Omit<
          {
              businessConnectionId?: string;
              chatId?: string
              | number;
              heading?: number;
              horizontalAccuracy?: number;
              inlineMessageId?: string | number;
              latitude: number;
              livePeriod?: number;
              longitude: number;
              messageId?: string | number;
              proximityAlertRadius?: number;
              replyMarkup?: InlineKeyboardMarkup;
          },
          "chatId"
          | "messageId"
          | "latitude"
          | "longitude",
      >

      out parameters

    Returns Promise<
        | true
        | Message & {
            editedAt: Date;
            editedTimestamp: number;
            editedUnixTime: number;
            location: Location;
        },
    >

    On success, if the edited message is not an inline message, the edited Message is returned, otherwise True is returned.

  • Use this method to edit animation, audio, document, photo, video messages or to add media to text messages. If a message is part of a message album, then it can be edited only to an audio for audio albums, only to a document for document albums and to a photo or a video otherwise. When an inline message is edited, a new file can't be uploaded; use a previously uploaded file via its file_id or specify a URL.

    Parameters

    • media: InputMedia

      An object for a new media content of the message

    • Optionaloptions: Omit<
          {
              businessConnectionId?: string;
              chatId?: string
              | number;
              inlineMessageId?: string | number;
              media: InputMedia;
              messageId?: string | number;
              replyMarkup?: InlineKeyboardMarkup;
          },
          "media"
          | "chatId"
          | "messageId",
      >

      out parameters

    Returns Promise<
        | true
        | Message & {
            editedAt: Date;
            editedTimestamp: number;
            editedUnixTime: number;
        },
    >

    On success, if the edited message is not an inline message, the edited Message is returned, otherwise True is returned. Note that business messages that were not sent by the bot and do not contain an inline keyboard can only be edited within 48 hours from the time they were sent.

  • Use this method to edit only the reply markup of messages.

    Parameters

    • replyMarkup: InlineKeyboardMarkup

      An object for an inline keyboard

    • Optionaloptions: Omit<
          {
              businessConnectionId?: string;
              chatId?: string
              | number;
              inlineMessageId?: string | number;
              messageId?: string | number;
              replyMarkup?: InlineKeyboardMarkup;
          },
          "media"
          | "chatId"
          | "messageId",
      >

      out parameters

    Returns Promise<
        | true
        | Message & {
            editedAt: Date;
            editedTimestamp: number;
            editedUnixTime: number;
        },
    >

    On success, if the edited message is not an inline message, the edited Message is returned, otherwise True is returned. Note that business messages that were not sent by the bot and do not contain an inline keyboard can only be edited within 48 hours from the time they were sent.

  • Use this method to forward messages of any kind. Service messages and messages with protected content can't be forwarded.

    Parameters

    • chatId: string | number

      Unique identifier for the target chat or username of the target channel (in the format @channelusername)

    • Optionaloptions: Omit<
          {
              chatId: string
              | number;
              disableNotification?: boolean;
              fromChatId: string | number;
              messageId: string | number;
              messageThreadId?: string | number;
              protectContent?: boolean;
          },
          "chatId"
          | "messageId"
          | "fromChatId",
      >

      out parameters

    Returns Promise<Message>

    On success, the sent Message is returned.

  • Use this method to add a message to the list of pinned messages in a chat. If the chat is not a private chat, the bot must be an administrator in the chat for this to work and must have the 'can_pin_messages' admin right in a supergroup or 'can_edit_messages' admin right in a channel.

    Parameters

    • Optionaloptions: { businessConnectionId?: string; notification?: boolean }

      options for pinned message

      • OptionalbusinessConnectionId?: string

        Unique identifier of the business connection on behalf of which the message will be pinned

      • Optionalnotification?: boolean

        Pass True if it is not necessary to send a notification to all chat members about the new pinned message. Notifications are always disabled in channels and private chats

    Returns Promise<true>

    Returns True on success.

  • Use this method to change the chosen reactions on a message. Service messages can't be reacted to. Automatically forwarded messages from a channel to its discussion group have the same available reactions as messages in the channel. In albums, bots must react to the first message.

    Parameters

    • reaction: string | ReactionType | ReactionType[] | ReactionType | ReactionType[]

      A JSON-serialized list of reaction types to set on the message. Currently, as non-premium users, bots can set up to one reaction per message. A custom emoji reaction can be used if it is either already present on the message or explicitly allowed by chat administrators. Paid reactions can't be used by bots

    • OptionalisBig: boolean

      Pass True to set the reaction with a big animation

    Returns Promise<true>

    Returns True on success.

  • Reply to the current message

    Parameters

    • text: string

      Text of the message to be sent, 1-4096 characters after entities parsing

    • Optionaloptions: Omit<
          {
              businessConnectionId?: string;
              chatId: string
              | number;
              disableNotification?: boolean;
              entities?: MessageEntity[];
              linkPreviewOptions?: LinkPreviewOptions;
              messageEffectId?: string;
              messageThreadId?: string | number;
              parseMode?: ParseMode;
              protectContent?: boolean;
              replyMarkup?:
                  | InlineKeyboardMarkup
                  | ForceReply
                  | ReplyKeyboardMarkup
                  | ReplyKeyboardRemove;
              replyParameters?: ReplyParameters;
              text: string;
          },
          "text"
          | "chatId",
      >

      out parameters

    Returns Promise<Message & { content: string }>

    On success, the sent Message is returned.

  • Use this method to stop updating a live location message before live_period expires.

    Parameters

    • Optionaloptions: Omit<
          {
              businessConnectionId?: string;
              chatId?: string
              | number;
              inlineMessageId?: string;
              messageId?: string | number;
              replyMarkup?: InlineKeyboardMarkup;
          },
          "chatId"
          | "messageId",
      >

      out parameters

    Returns Promise<
        | true
        | Message & {
            editedAt: Date;
            editedTimestamp: number;
            editedUnixTime: number;
            location: Location;
        },
    >

    On success, if the message is not an inline message, the edited Message is returned, otherwise True is returned.

  • Flatten an object. Any properties that are collections will get converted to an array of keys.

    Parameters

    • OptionalpropsRecursive: boolean

      Optional. If true, calls toJSON method on nested objects.

    • ...props: Record<string, string | boolean>[]

      Optional. Specific properties to include/exclude, or rename.

    Returns Record<string, any>

    Flattened object.

  • Use this method to remove a message from the list of pinned messages in a chat. If the chat is not a private chat, the bot must be an administrator in the chat for this to work and must have the 'can_pin_messages' admin right in a supergroup or 'can_edit_messages' admin right in a channel.

    Parameters

    • OptionalbusinessConnectionId: string

      Unique identifier of the business connection on behalf of which the message will be unpinned

    Returns Promise<true>

    Returns True on success.

  • Returns the id instance Chat, User, ChatMember and other

    Returns null | string