mirror of
				https://github.com/InsanusMokrassar/TelegramBotAPI.git
				synced 2025-10-26 17:50:15 +00:00 
			
		
		
		
	| @@ -2,9 +2,6 @@ package dev.inmo.tgbotapi.types.buttons.InlineKeyboardButtons | ||||
|  | ||||
| import dev.inmo.tgbotapi.utils.internal.ClassCastsIncluded | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.buttons.KeyboardButton | ||||
| import dev.inmo.tgbotapi.types.buttons.KeyboardButtonRequestChat | ||||
| import dev.inmo.tgbotapi.types.buttons.KeyboardButtonRequestUser | ||||
| import dev.inmo.tgbotapi.types.games.CallbackGame | ||||
| import dev.inmo.tgbotapi.types.webapps.WebAppInfo | ||||
| import kotlinx.serialization.* | ||||
| @@ -137,39 +134,3 @@ data class WebAppInlineKeyboardButton( | ||||
|     @SerialName(webAppField) | ||||
|     val webApp: WebAppInfo | ||||
| ) : InlineKeyboardButton | ||||
|  | ||||
| /** | ||||
|  * Private chats only. When user will tap on this button, he will be asked for the chat with [requestChat] options. You | ||||
|  * will be able to catch this [ChatId] in updates and data using | ||||
|  * [dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling.onUserShared] in case you are using Behaviour | ||||
|  * Builder OR with [dev.inmo.tgbotapi.updateshandlers.FlowsUpdatesFilter.messagesFlow] | ||||
|  * and [kotlinx.coroutines.flow.filterIsInstance]. | ||||
|  * | ||||
|  * In case you will use [dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling.onUserShared] it is | ||||
|  * recommended to use [kotlinx.coroutines.flow.Flow] [kotlinx.coroutines.flow.filter] with checking of incoming | ||||
|  * [dev.inmo.tgbotapi.types.request.UserShared.requestId] | ||||
|  */ | ||||
| @Serializable | ||||
| data class RequestUserInlineKeyboardButton( | ||||
|     override val text: String, | ||||
|     @SerialName(requestUserField) | ||||
|     val requestUser: KeyboardButtonRequestUser | ||||
| ) : InlineKeyboardButton | ||||
|  | ||||
| /** | ||||
|  * Private chats only. When user will tap on this button, he will be asked for the chat with [requestChat] options. You | ||||
|  * will be able to catch this [ChatId] in updates and data using | ||||
|  * [dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling.onChatShared] in case you are using Behaviour | ||||
|  * Builder OR with [dev.inmo.tgbotapi.updateshandlers.FlowsUpdatesFilter.messagesFlow] | ||||
|  * and [kotlinx.coroutines.flow.filterIsInstance]. | ||||
|  * | ||||
|  * In case you will use [dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling.onChatShared] it is | ||||
|  * recommended to use [kotlinx.coroutines.flow.Flow] [kotlinx.coroutines.flow.filter] with checking of incoming | ||||
|  * [dev.inmo.tgbotapi.types.request.ChatShared.requestId] | ||||
|  */ | ||||
| @Serializable | ||||
| data class RequestChatInlineKeyboardButton( | ||||
|     override val text: String, | ||||
|     @SerialName(requestChatField) | ||||
|     val requestChat: KeyboardButtonRequestChat | ||||
| ) : InlineKeyboardButton | ||||
|   | ||||
| @@ -28,8 +28,6 @@ object InlineKeyboardButtonSerializer : KSerializer<InlineKeyboardButton> { | ||||
|             json[switchInlineQueryField] != null -> SwitchInlineQueryInlineKeyboardButton.serializer() | ||||
|             json[switchInlineQueryCurrentChatField] != null -> SwitchInlineQueryCurrentChatInlineKeyboardButton.serializer() | ||||
|             json[urlField] != null -> URLInlineKeyboardButton.serializer() | ||||
|             json[requestUserField] != null -> RequestUserInlineKeyboardButton.serializer() | ||||
|             json[requestChatField] != null -> RequestChatInlineKeyboardButton.serializer() | ||||
|             else -> null | ||||
|         } | ||||
|     } | ||||
| @@ -52,8 +50,6 @@ object InlineKeyboardButtonSerializer : KSerializer<InlineKeyboardButton> { | ||||
|             is URLInlineKeyboardButton -> URLInlineKeyboardButton.serializer().serialize(encoder, value) | ||||
|             is WebAppInlineKeyboardButton -> WebAppInlineKeyboardButton.serializer().serialize(encoder, value) | ||||
|             is CallbackGameInlineKeyboardButton -> CallbackGameInlineKeyboardButton.serializer().serialize(encoder, value) | ||||
|             is RequestUserInlineKeyboardButton -> RequestUserInlineKeyboardButton.serializer().serialize(encoder, value) | ||||
|             is RequestChatInlineKeyboardButton -> RequestChatInlineKeyboardButton.serializer().serialize(encoder, value) | ||||
|             is UnknownInlineKeyboardButton -> JsonElement.serializer().serialize(encoder, value.rawData) | ||||
|         } | ||||
|     } | ||||
|   | ||||
| @@ -94,6 +94,42 @@ data class RequestPollKeyboardButton( | ||||
|     val requestPoll: KeyboardButtonPollType | ||||
| ) : KeyboardButton | ||||
|  | ||||
| /** | ||||
|  * Private chats only. When user will tap on this button, he will be asked for the chat with [requestChat] options. You | ||||
|  * will be able to catch this [ChatId] in updates and data using | ||||
|  * [dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling.onUserShared] in case you are using Behaviour | ||||
|  * Builder OR with [dev.inmo.tgbotapi.updateshandlers.FlowsUpdatesFilter.messagesFlow] | ||||
|  * and [kotlinx.coroutines.flow.filterIsInstance]. | ||||
|  * | ||||
|  * In case you will use [dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling.onUserShared] it is | ||||
|  * recommended to use [kotlinx.coroutines.flow.Flow] [kotlinx.coroutines.flow.filter] with checking of incoming | ||||
|  * [dev.inmo.tgbotapi.types.request.UserShared.requestId] | ||||
|  */ | ||||
| @Serializable | ||||
| data class RequestUserKeyboardButton( | ||||
|     override val text: String, | ||||
|     @SerialName(requestUserField) | ||||
|     val requestUser: KeyboardButtonRequestUser | ||||
| ) : KeyboardButton | ||||
|  | ||||
| /** | ||||
|  * Private chats only. When user will tap on this button, he will be asked for the chat with [requestChat] options. You | ||||
|  * will be able to catch this [ChatId] in updates and data using | ||||
|  * [dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling.onChatShared] in case you are using Behaviour | ||||
|  * Builder OR with [dev.inmo.tgbotapi.updateshandlers.FlowsUpdatesFilter.messagesFlow] | ||||
|  * and [kotlinx.coroutines.flow.filterIsInstance]. | ||||
|  * | ||||
|  * In case you will use [dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling.onChatShared] it is | ||||
|  * recommended to use [kotlinx.coroutines.flow.Flow] [kotlinx.coroutines.flow.filter] with checking of incoming | ||||
|  * [dev.inmo.tgbotapi.types.request.ChatShared.requestId] | ||||
|  */ | ||||
| @Serializable | ||||
| data class RequestChatKeyboardButton( | ||||
|     override val text: String, | ||||
|     @SerialName(requestChatField) | ||||
|     val requestChat: KeyboardButtonRequestChat | ||||
| ) : KeyboardButton | ||||
|  | ||||
| @RiskFeature | ||||
| object KeyboardButtonSerializer : KSerializer<KeyboardButton> { | ||||
|     private val internalSerializer = JsonElement.serializer() | ||||
| @@ -124,6 +160,20 @@ object KeyboardButtonSerializer : KSerializer<KeyboardButton> { | ||||
|                     asJson[requestPollField] ?.jsonObject ?: buildJsonObject {  } | ||||
|                 ) | ||||
|             ) | ||||
|             asJson is JsonObject && asJson[requestUserField] != null -> RequestUserKeyboardButton( | ||||
|                 asJson[textField]!!.jsonPrimitive.content, | ||||
|                 nonstrictJsonFormat.decodeFromJsonElement( | ||||
|                     KeyboardButtonRequestUser.serializer(), | ||||
|                     asJson[requestUserField] ?.jsonObject ?: buildJsonObject {  } | ||||
|                 ) | ||||
|             ) | ||||
|             asJson is JsonObject && asJson[requestChatField] != null -> RequestChatKeyboardButton( | ||||
|                 asJson[textField]!!.jsonPrimitive.content, | ||||
|                 nonstrictJsonFormat.decodeFromJsonElement( | ||||
|                     KeyboardButtonRequestChat.serializer(), | ||||
|                     asJson[requestChatField] ?.jsonObject ?: buildJsonObject {  } | ||||
|                 ) | ||||
|             ) | ||||
|             else -> UnknownKeyboardButton( | ||||
|                 when (asJson) { | ||||
|                     is JsonObject -> asJson[textField]!!.jsonPrimitive.content | ||||
| @@ -142,6 +192,8 @@ object KeyboardButtonSerializer : KSerializer<KeyboardButton> { | ||||
|             is WebAppKeyboardButton -> WebAppKeyboardButton.serializer().serialize(encoder, value) | ||||
|             is RequestPollKeyboardButton -> RequestPollKeyboardButton.serializer().serialize(encoder, value) | ||||
|             is SimpleKeyboardButton -> encoder.encodeString(value.text) | ||||
|             is RequestUserKeyboardButton -> RequestUserKeyboardButton.serializer().serialize(encoder, value) | ||||
|             is RequestChatKeyboardButton -> RequestChatKeyboardButton.serializer().serialize(encoder, value) | ||||
|             is UnknownKeyboardButton -> JsonElement.serializer().serialize(encoder, nonstrictJsonFormat.parseToJsonElement(value.raw)) | ||||
|         } | ||||
|     } | ||||
|   | ||||
| @@ -2,10 +2,6 @@ package dev.inmo.tgbotapi.types.buttons.inline | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.LoginURL | ||||
| import dev.inmo.tgbotapi.types.buttons.InlineKeyboardButtons.* | ||||
| import dev.inmo.tgbotapi.types.buttons.KeyboardButtonRequestChat | ||||
| import dev.inmo.tgbotapi.types.buttons.KeyboardButtonRequestUser | ||||
| import dev.inmo.tgbotapi.types.chat.member.ChatAdministratorRights | ||||
| import dev.inmo.tgbotapi.types.request.RequestId | ||||
| import dev.inmo.tgbotapi.types.webapps.WebAppInfo | ||||
|  | ||||
| /** | ||||
| @@ -104,100 +100,3 @@ inline fun webAppInlineButton( | ||||
|     text: String, | ||||
|     url: String | ||||
| ) = webAppInlineButton(text, WebAppInfo(url)) | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestUserKeyboardButton] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun requestUserInlineButton( | ||||
|     text: String, | ||||
|     requestUser: KeyboardButtonRequestUser | ||||
| ) = RequestUserInlineKeyboardButton( | ||||
|     text, | ||||
|     requestUser | ||||
| ) | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestUserKeyboardButton] with [KeyboardButtonRequestUser.Bot] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun requestBotInlineButton( | ||||
|     text: String, | ||||
|     requestId: RequestId | ||||
| ) = requestUserInlineButton( | ||||
|     text, | ||||
|     KeyboardButtonRequestUser.Bot(requestId) | ||||
| ) | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestUserKeyboardButton] with [KeyboardButtonRequestUser.Common] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun requestUserInlineButton( | ||||
|     text: String, | ||||
|     requestId: RequestId, | ||||
|     premiumUser: Boolean? = null | ||||
| ) = requestUserInlineButton( | ||||
|     text, | ||||
|     KeyboardButtonRequestUser.Common(requestId, premiumUser) | ||||
| ) | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestUserKeyboardButton] with [KeyboardButtonRequestUser.Any] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun requestUserOrBotInlineButton( | ||||
|     text: String, | ||||
|     requestId: RequestId | ||||
| ) = requestUserInlineButton( | ||||
|     text, | ||||
|     KeyboardButtonRequestUser.Any(requestId) | ||||
| ) | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestChatKeyboardButton] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun requestChatInlineButton( | ||||
|     text: String, | ||||
|     requestChat: KeyboardButtonRequestChat | ||||
| ) = RequestChatInlineKeyboardButton( | ||||
|     text, | ||||
|     requestChat | ||||
| ) | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestChatKeyboardButton] with [KeyboardButtonRequestChat] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun requestChatInlineButton( | ||||
|     text: String, | ||||
|     requestId: RequestId, | ||||
|     isChannel: Boolean? = null, | ||||
|     isForum: Boolean? = null, | ||||
|     withUsername: Boolean? = null, | ||||
|     ownedBy: Boolean? = null, | ||||
|     userRightsInChat: ChatAdministratorRights? = null, | ||||
|     botRightsInChat: ChatAdministratorRights? = null, | ||||
|     botIsMember: Boolean = false | ||||
| ) = requestChatInlineButton( | ||||
|     text, | ||||
|     KeyboardButtonRequestChat( | ||||
|         requestId, isChannel, isForum, withUsername, ownedBy, userRightsInChat, botRightsInChat, botIsMember | ||||
|     ) | ||||
| ) | ||||
|  | ||||
|   | ||||
| @@ -69,3 +69,99 @@ inline fun webAppReplyButton( | ||||
|     text: String, | ||||
|     url: String | ||||
| ) = webAppReplyButton(text, WebAppInfo(url)) | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestUserKeyboardButton] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun requestUserReplyButton( | ||||
|     text: String, | ||||
|     requestUser: KeyboardButtonRequestUser | ||||
| ) = RequestUserKeyboardButton( | ||||
|     text, | ||||
|     requestUser | ||||
| ) | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestUserKeyboardButton] with [KeyboardButtonRequestUser.Bot] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun requestBotReplyButton( | ||||
|     text: String, | ||||
|     requestId: RequestId | ||||
| ) = requestUserReplyButton( | ||||
|     text, | ||||
|     KeyboardButtonRequestUser.Bot(requestId) | ||||
| ) | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestUserKeyboardButton] with [KeyboardButtonRequestUser.Common] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun requestUserReplyButton( | ||||
|     text: String, | ||||
|     requestId: RequestId, | ||||
|     premiumUser: Boolean? = null | ||||
| ) = requestUserReplyButton( | ||||
|     text, | ||||
|     KeyboardButtonRequestUser.Common(requestId, premiumUser) | ||||
| ) | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestUserKeyboardButton] with [KeyboardButtonRequestUser.Any] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun requestUserOrBotReplyButton( | ||||
|     text: String, | ||||
|     requestId: RequestId | ||||
| ) = requestUserReplyButton( | ||||
|     text, | ||||
|     KeyboardButtonRequestUser.Any(requestId) | ||||
| ) | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestChatKeyboardButton] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun requestChatReplyButton( | ||||
|     text: String, | ||||
|     requestChat: KeyboardButtonRequestChat | ||||
| ) = RequestChatKeyboardButton( | ||||
|     text, | ||||
|     requestChat | ||||
| ) | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestChatKeyboardButton] with [KeyboardButtonRequestChat] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun requestChatReplyButton( | ||||
|     text: String, | ||||
|     requestId: RequestId, | ||||
|     isChannel: Boolean? = null, | ||||
|     isForum: Boolean? = null, | ||||
|     withUsername: Boolean? = null, | ||||
|     ownedBy: Boolean? = null, | ||||
|     userRightsInChat: ChatAdministratorRights? = null, | ||||
|     botRightsInChat: ChatAdministratorRights? = null, | ||||
|     botIsMember: Boolean = false | ||||
| ) = requestChatReplyButton( | ||||
|     text, | ||||
|     KeyboardButtonRequestChat( | ||||
|         requestId, isChannel, isForum, withUsername, ownedBy, userRightsInChat, botRightsInChat, botIsMember | ||||
|     ) | ||||
| ) | ||||
|   | ||||
| @@ -3,12 +3,6 @@ package dev.inmo.tgbotapi.extensions.utils.types.buttons | ||||
| import dev.inmo.tgbotapi.types.LoginURL | ||||
| import dev.inmo.tgbotapi.types.buttons.InlineKeyboardButtons.* | ||||
| import dev.inmo.tgbotapi.types.buttons.InlineKeyboardMarkup | ||||
| import dev.inmo.tgbotapi.types.buttons.KeyboardButtonRequestChat | ||||
| import dev.inmo.tgbotapi.types.buttons.KeyboardButtonRequestUser | ||||
| import dev.inmo.tgbotapi.types.buttons.inline.requestChatInlineButton | ||||
| import dev.inmo.tgbotapi.types.buttons.inline.requestUserInlineButton | ||||
| import dev.inmo.tgbotapi.types.chat.member.ChatAdministratorRights | ||||
| import dev.inmo.tgbotapi.types.request.RequestId | ||||
| import dev.inmo.tgbotapi.types.webapps.WebAppInfo | ||||
| import dev.inmo.tgbotapi.utils.* | ||||
|  | ||||
| @@ -167,103 +161,3 @@ inline fun InlineKeyboardRowBuilder.webAppButton( | ||||
|     text: String, | ||||
|     url: String | ||||
| ) = webAppButton(text, WebAppInfo(url)) | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestUserKeyboardButton] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun InlineKeyboardRowBuilder.requestUserButton( | ||||
|     text: String, | ||||
|     requestUser: KeyboardButtonRequestUser | ||||
| ) = add( | ||||
|     requestUserInlineButton( | ||||
|         text, | ||||
|         requestUser | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestUserKeyboardButton] with [KeyboardButtonRequestUser.Bot] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun InlineKeyboardRowBuilder.requestBotButton( | ||||
|     text: String, | ||||
|     requestId: RequestId | ||||
| ) = requestUserButton( | ||||
|     text, | ||||
|     KeyboardButtonRequestUser.Bot(requestId) | ||||
| ) | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestUserKeyboardButton] with [KeyboardButtonRequestUser.Common] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun InlineKeyboardRowBuilder.requestUserButton( | ||||
|     text: String, | ||||
|     requestId: RequestId, | ||||
|     premiumUser: Boolean? = null | ||||
| ) = requestUserButton( | ||||
|     text, | ||||
|     KeyboardButtonRequestUser.Common(requestId, premiumUser) | ||||
| ) | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestUserKeyboardButton] with [KeyboardButtonRequestUser.Any] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun InlineKeyboardRowBuilder.requestUserOrBotButton( | ||||
|     text: String, | ||||
|     requestId: RequestId | ||||
| ) = requestUserButton( | ||||
|     text, | ||||
|     KeyboardButtonRequestUser.Any(requestId) | ||||
| ) | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestChatKeyboardButton] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun InlineKeyboardRowBuilder.requestChatButton( | ||||
|     text: String, | ||||
|     requestChat: KeyboardButtonRequestChat | ||||
| ) = add( | ||||
|     requestChatInlineButton( | ||||
|         text, | ||||
|         requestChat | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestChatKeyboardButton] with [KeyboardButtonRequestChat] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun InlineKeyboardRowBuilder.requestChatButton( | ||||
|     text: String, | ||||
|     requestId: RequestId, | ||||
|     isChannel: Boolean? = null, | ||||
|     isForum: Boolean? = null, | ||||
|     withUsername: Boolean? = null, | ||||
|     ownedBy: Boolean? = null, | ||||
|     userRightsInChat: ChatAdministratorRights? = null, | ||||
|     botRightsInChat: ChatAdministratorRights? = null, | ||||
|     botIsMember: Boolean = false | ||||
| ) = requestChatButton( | ||||
|     text, | ||||
|     KeyboardButtonRequestChat( | ||||
|         requestId, isChannel, isForum, withUsername, ownedBy, userRightsInChat, botRightsInChat, botIsMember | ||||
|     ) | ||||
| ) | ||||
|   | ||||
| @@ -1,6 +1,10 @@ | ||||
| package dev.inmo.tgbotapi.extensions.utils.types.buttons | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.buttons.* | ||||
| import dev.inmo.tgbotapi.types.buttons.reply.requestChatReplyButton | ||||
| import dev.inmo.tgbotapi.types.buttons.reply.requestUserReplyButton | ||||
| import dev.inmo.tgbotapi.types.chat.member.ChatAdministratorRights | ||||
| import dev.inmo.tgbotapi.types.request.RequestId | ||||
| import dev.inmo.tgbotapi.types.webapps.WebAppInfo | ||||
| import dev.inmo.tgbotapi.utils.* | ||||
|  | ||||
| @@ -138,3 +142,103 @@ inline fun ReplyKeyboardRowBuilder.webAppButton( | ||||
|     text: String, | ||||
|     url: String | ||||
| ) = webAppButton(text, WebAppInfo(url)) | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestUserKeyboardButton] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun ReplyKeyboardRowBuilder.requestUserButton( | ||||
|     text: String, | ||||
|     requestUser: KeyboardButtonRequestUser | ||||
| ) = add( | ||||
|     requestUserReplyButton( | ||||
|         text, | ||||
|         requestUser | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestUserKeyboardButton] with [KeyboardButtonRequestUser.Bot] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun ReplyKeyboardRowBuilder.requestBotButton( | ||||
|     text: String, | ||||
|     requestId: RequestId | ||||
| ) = requestUserButton( | ||||
|     text, | ||||
|     KeyboardButtonRequestUser.Bot(requestId) | ||||
| ) | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestUserKeyboardButton] with [KeyboardButtonRequestUser.Common] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun ReplyKeyboardRowBuilder.requestUserButton( | ||||
|     text: String, | ||||
|     requestId: RequestId, | ||||
|     premiumUser: Boolean? = null | ||||
| ) = requestUserButton( | ||||
|     text, | ||||
|     KeyboardButtonRequestUser.Common(requestId, premiumUser) | ||||
| ) | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestUserKeyboardButton] with [KeyboardButtonRequestUser.Any] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun ReplyKeyboardRowBuilder.requestUserOrBotButton( | ||||
|     text: String, | ||||
|     requestId: RequestId | ||||
| ) = requestUserButton( | ||||
|     text, | ||||
|     KeyboardButtonRequestUser.Any(requestId) | ||||
| ) | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestChatKeyboardButton] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun ReplyKeyboardRowBuilder.requestChatButton( | ||||
|     text: String, | ||||
|     requestChat: KeyboardButtonRequestChat | ||||
| ) = add( | ||||
|     requestChatReplyButton( | ||||
|         text, | ||||
|         requestChat | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| /** | ||||
|  * Creates and put [RequestChatKeyboardButton] with [KeyboardButtonRequestChat] | ||||
|  * | ||||
|  * @see replyKeyboard | ||||
|  * @see ReplyKeyboardBuilder.row | ||||
|  */ | ||||
| inline fun ReplyKeyboardRowBuilder.requestChatButton( | ||||
|     text: String, | ||||
|     requestId: RequestId, | ||||
|     isChannel: Boolean? = null, | ||||
|     isForum: Boolean? = null, | ||||
|     withUsername: Boolean? = null, | ||||
|     ownedBy: Boolean? = null, | ||||
|     userRightsInChat: ChatAdministratorRights? = null, | ||||
|     botRightsInChat: ChatAdministratorRights? = null, | ||||
|     botIsMember: Boolean = false | ||||
| ) = requestChatButton( | ||||
|     text, | ||||
|     KeyboardButtonRequestChat( | ||||
|         requestId, isChannel, isForum, withUsername, ownedBy, userRightsInChat, botRightsInChat, botIsMember | ||||
|     ) | ||||
| ) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user