class Tourmaline::InlineKeyboardButton

Overview

This object represents one button of an inline keyboard. Exactly one of the fields other than text, icon_custom_emoji_id, and style must be used to specify the type of the button.

Included Modules

Defined in:

tourmaline/types/api.cr

Constructors

Instance Method Summary

Constructor Detail

def self.new(pull : JSON::PullParser) #

[View source]
def self.new(text : String, icon_custom_emoji_id : String | Nil = nil, style : String | Nil = nil, url : String | Nil = nil, callback_data : String | Nil = nil, web_app : Tourmaline::WebAppInfo | Nil = nil, login_url : Tourmaline::LoginUrl | Nil = nil, switch_inline_query : String | Nil = nil, switch_inline_query_current_chat : String | Nil = nil, switch_inline_query_chosen_chat : Tourmaline::SwitchInlineQueryChosenChat | Nil = nil, copy_text : Tourmaline::CopyTextButton | Nil = nil, callback_game : Tourmaline::CallbackGame | Nil = nil, pay : Bool | Nil = nil) #

[View source]

Instance Method Detail

def callback_data : String | Nil #

Optional. Data to be sent in a callback query to the bot when the button is pressed, 1-64 bytes


[View source]
def callback_data=(callback_data : String | Nil) #

Optional. Data to be sent in a callback query to the bot when the button is pressed, 1-64 bytes


[View source]
def callback_game : Tourmaline::CallbackGame | Nil #

Optional. Description of the game that will be launched when the user presses the button. NOTE: This type of button must always be the first button in the first row.


[View source]
def callback_game=(callback_game : Tourmaline::CallbackGame | Nil) #

Optional. Description of the game that will be launched when the user presses the button. NOTE: This type of button must always be the first button in the first row.


[View source]
def copy_text : Tourmaline::CopyTextButton | Nil #

Optional. Description of the button that copies the specified text to the clipboard.


[View source]
def copy_text=(copy_text : Tourmaline::CopyTextButton | Nil) #

Optional. Description of the button that copies the specified text to the clipboard.


[View source]
def icon_custom_emoji_id : String | Nil #

Optional. Unique identifier of the custom emoji shown before the text of the button. Can only be used by bots that purchased additional usernames on Fragment or in the messages directly sent by the bot to private, group and supergroup chats if the owner of the bot has a Telegram Premium subscription.


[View source]
def icon_custom_emoji_id=(icon_custom_emoji_id : String | Nil) #

Optional. Unique identifier of the custom emoji shown before the text of the button. Can only be used by bots that purchased additional usernames on Fragment or in the messages directly sent by the bot to private, group and supergroup chats if the owner of the bot has a Telegram Premium subscription.


[View source]
def login_url : Tourmaline::LoginUrl | Nil #

Optional. An HTTPS URL used to automatically authorize the user. Can be used as a replacement for the Telegram Login Widget.


[View source]
def login_url=(login_url : Tourmaline::LoginUrl | Nil) #

Optional. An HTTPS URL used to automatically authorize the user. Can be used as a replacement for the Telegram Login Widget.


[View source]
def pay=(pay : Bool | Nil) #

Optional. Specify True, to send a Pay button. Substrings "⭐" and "XTR" in the buttons's text will be replaced with a Telegram Star icon. NOTE: This type of button must always be the first button in the first row and can only be used in invoice messages.


[View source]
def pay? : Bool | Nil #

Optional. Specify True, to send a Pay button. Substrings "⭐" and "XTR" in the buttons's text will be replaced with a Telegram Star icon. NOTE: This type of button must always be the first button in the first row and can only be used in invoice messages.


[View source]
def style : String | Nil #

Optional. Style of the button. Must be one of "danger" (red), "success" (green) or "primary" (blue). If omitted, then an app-specific style is used.


[View source]
def style=(style : String | Nil) #

Optional. Style of the button. Must be one of "danger" (red), "success" (green) or "primary" (blue). If omitted, then an app-specific style is used.


[View source]
def switch_inline_query : String | Nil #

Optional. If set, pressing the button will prompt the user to select one of their chats, open that chat and insert the bot's username and the specified inline query in the input field. May be empty, in which case just the bot's username will be inserted. Not supported for messages sent in channel direct messages chats and on behalf of a Telegram Business account.


[View source]
def switch_inline_query=(switch_inline_query : String | Nil) #

Optional. If set, pressing the button will prompt the user to select one of their chats, open that chat and insert the bot's username and the specified inline query in the input field. May be empty, in which case just the bot's username will be inserted. Not supported for messages sent in channel direct messages chats and on behalf of a Telegram Business account.


[View source]
def switch_inline_query_chosen_chat : Tourmaline::SwitchInlineQueryChosenChat | Nil #

Optional. If set, pressing the button will prompt the user to select one of their chats of the specified type, open that chat and insert the bot's username and the specified inline query in the input field. Not supported for messages sent in channel direct messages chats and on behalf of a Telegram Business account.


[View source]
def switch_inline_query_chosen_chat=(switch_inline_query_chosen_chat : Tourmaline::SwitchInlineQueryChosenChat | Nil) #

Optional. If set, pressing the button will prompt the user to select one of their chats of the specified type, open that chat and insert the bot's username and the specified inline query in the input field. Not supported for messages sent in channel direct messages chats and on behalf of a Telegram Business account.


[View source]
def switch_inline_query_current_chat : String | Nil #

Optional. If set, pressing the button will insert the bot's username and the specified inline query in the current chat's input field. May be empty, in which case only the bot's username will be inserted. This offers a quick way for the user to open your bot in inline mode in the same chat - good for selecting something from multiple options. Not supported in channels and for messages sent in channel direct messages chats and on behalf of a Telegram Business account.


[View source]
def switch_inline_query_current_chat=(switch_inline_query_current_chat : String | Nil) #

Optional. If set, pressing the button will insert the bot's username and the specified inline query in the current chat's input field. May be empty, in which case only the bot's username will be inserted. This offers a quick way for the user to open your bot in inline mode in the same chat - good for selecting something from multiple options. Not supported in channels and for messages sent in channel direct messages chats and on behalf of a Telegram Business account.


[View source]
def text : String #

Label text on the button


[View source]
def text=(text : String) #

Label text on the button


[View source]
def url : String | Nil #

Optional. HTTP or tg:// URL to be opened when the button is pressed. Links tg://user?id=<user_id> can be used to mention a user by their identifier without using a username, if this is allowed by their privacy settings.


[View source]
def url=(url : String | Nil) #

Optional. HTTP or tg:// URL to be opened when the button is pressed. Links tg://user?id=<user_id> can be used to mention a user by their identifier without using a username, if this is allowed by their privacy settings.


[View source]
def web_app : Tourmaline::WebAppInfo | Nil #

Optional. 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. Available only in private chats between a user and the bot. Not supported for messages sent on behalf of a Telegram Business account.


[View source]
def web_app=(web_app : Tourmaline::WebAppInfo | Nil) #

Optional. 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. Available only in private chats between a user and the bot. Not supported for messages sent on behalf of a Telegram Business account.


[View source]