Popular
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140import type { WebAppInfo } from "./markup.ts";
/** This object represents the bot's description. */export interface BotDescription { /** The bot's description */ description: string;}
/** This object represents the bot's short description. */export interface BotShortDescription { /** The bot's short description */ short_description: string;}
/** This object describes the bot's menu button in a private chat. It should be one of- MenuButtonCommands- MenuButtonWebApp- MenuButtonDefault
If a menu button other than MenuButtonDefault is set for a private chat, then it is applied in the chat. Otherwise the default menu button is applied. By default, the menu button opens the list of bot commands. */export type MenuButton = | MenuButtonCommands | MenuButtonWebApp | MenuButtonDefault;
/** Represents a menu button, which opens the bot's list of commands. */export interface MenuButtonCommands { /** Type of the button, must be commands */ type: "commands";}
/** Represents a menu button, which launches a Web App. */export interface MenuButtonWebApp { /** Button type, must be web_app */ type: "web_app"; /** Text on the button */ text: string; /** Description of the Web App that will be launched when the user presses the button. The Web App will be able to send an arbitrary message on behalf of the user using the method answerWebAppQuery. */ web_app: WebAppInfo;}
/** Describes that no specific value for the menu button was set. */export interface MenuButtonDefault { /** Type of the button, must be default */ type: "default";}
/** This object represents the scope to which bot commands are applied. Currently, the following 7 scopes are supported:- BotCommandScopeDefault- BotCommandScopeAllPrivateChats- BotCommandScopeAllGroupChats- BotCommandScopeAllChatAdministrators- BotCommandScopeChat- BotCommandScopeChatAdministrators- BotCommandScopeChatMember
## Determining list of commands
The following algorithm is used to determine the list of commands for a particular user viewing the bot menu. The first list of commands which is set is returned:
### Commands in the chat with the bot- botCommandScopeChat + language_code- botCommandScopeChat- botCommandScopeAllPrivateChats + language_code- botCommandScopeAllPrivateChats- botCommandScopeDefault + language_code- botCommandScopeDefault
### Commands in group and supergroup chats- botCommandScopeChatMember + language_code- botCommandScopeChatMember- botCommandScopeChatAdministrators + language_code (administrators only)- botCommandScopeChatAdministrators (administrators only)- botCommandScopeChat + language_code- botCommandScopeChat- botCommandScopeAllChatAdministrators + language_code (administrators only)- botCommandScopeAllChatAdministrators (administrators only)- botCommandScopeAllGroupChats + language_code- botCommandScopeAllGroupChats- botCommandScopeDefault + language_code- botCommandScopeDefault */export type BotCommandScope = | BotCommandScopeDefault | BotCommandScopeAllPrivateChats | BotCommandScopeAllGroupChats | BotCommandScopeAllChatAdministrators | BotCommandScopeChat | BotCommandScopeChatAdministrators | BotCommandScopeChatMember;
/** Represents the default scope of bot commands. Default commands are used if no commands with a narrower scope are specified for the user. */export interface BotCommandScopeDefault { /** Scope type, must be default */ type: "default";}
/** Represents the scope of bot commands, covering all private chats. */export interface BotCommandScopeAllPrivateChats { /** Scope type, must be all_private_chats */ type: "all_private_chats";}
/** Represents the scope of bot commands, covering all group and supergroup chats. */export interface BotCommandScopeAllGroupChats { /** Scope type, must be all_group_chats */ type: "all_group_chats";}
/** Represents the scope of bot commands, covering all group and supergroup chat administrators. */export interface BotCommandScopeAllChatAdministrators { /** Scope type, must be all_chat_administrators */ type: "all_chat_administrators";}
/** Represents the scope of bot commands, covering a specific chat. */export interface BotCommandScopeChat { /** Scope type, must be chat */ type: "chat"; /** Unique identifier for the target chat or username of the target supergroup (in the format @supergroupusername) */ chat_id: number | string;}
/** Represents the scope of bot commands, covering all administrators of a specific group or supergroup chat. */export interface BotCommandScopeChatAdministrators { /** Scope type, must be chat_administrators */ type: "chat_administrators"; /** Unique identifier for the target chat or username of the target supergroup (in the format @supergroupusername) */ chat_id: number | string;}
/** Represents the scope of bot commands, covering a specific member of a group or supergroup chat. */export interface BotCommandScopeChatMember { /** Scope type, must be chat_member */ type: "chat_member"; /** Unique identifier for the target chat or username of the target supergroup (in the format @supergroupusername) */ chat_id: number | string; /** Unique identifier of the target user */ user_id: number;}