mirror of
				https://github.com/InsanusMokrassar/TelegramBotAPI.git
				synced 2025-10-25 17:20:07 +00:00 
			
		
		
		
	add UnknownInlineKeyboardButton
This commit is contained in:
		| @@ -44,6 +44,8 @@ | |||||||
|     * `CallbackGameInlineKeyboardButton` was added |     * `CallbackGameInlineKeyboardButton` was added | ||||||
|     ([Issue-79](https://github.com/InsanusMokrassar/TelegramBotAPI/issues/79), |     ([Issue-79](https://github.com/InsanusMokrassar/TelegramBotAPI/issues/79), | ||||||
|     [PR-80](https://github.com/InsanusMokrassar/TelegramBotAPI/pull/80)) |     [PR-80](https://github.com/InsanusMokrassar/TelegramBotAPI/pull/80)) | ||||||
|  |     * `UnknownInlineKeyboardButton` was added. It is unavailable for creating, but you can receive it, for example, in | ||||||
|  |     `InlineQueryResult` | ||||||
|  |  | ||||||
| ### 0.26.2 | ### 0.26.2 | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,12 +4,19 @@ import com.github.insanusmokrassar.TelegramBotAPI.types.* | |||||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.games.CallbackGame | import com.github.insanusmokrassar.TelegramBotAPI.types.games.CallbackGame | ||||||
| import kotlinx.serialization.SerialName | import kotlinx.serialization.SerialName | ||||||
| import kotlinx.serialization.Serializable | import kotlinx.serialization.Serializable | ||||||
|  | import kotlinx.serialization.json.JsonObject | ||||||
|  |  | ||||||
| @Serializable(InlineKeyboardButtonSerializer::class) | @Serializable(InlineKeyboardButtonSerializer::class) | ||||||
| sealed class InlineKeyboardButton { | sealed class InlineKeyboardButton { | ||||||
|     abstract val text: String |     abstract val text: String | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @Serializable | ||||||
|  | data class UnknownInlineKeyboardButton internal constructor( | ||||||
|  |     override val text: String, | ||||||
|  |     val rawData: JsonObject | ||||||
|  | ) : InlineKeyboardButton() | ||||||
|  |  | ||||||
| @Serializable | @Serializable | ||||||
| data class PayInlineKeyboardButton( | data class PayInlineKeyboardButton( | ||||||
|     override val text: String, |     override val text: String, | ||||||
|   | |||||||
| @@ -3,8 +3,7 @@ package com.github.insanusmokrassar.TelegramBotAPI.types.buttons.InlineKeyboardB | |||||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.* | import com.github.insanusmokrassar.TelegramBotAPI.types.* | ||||||
| import com.github.insanusmokrassar.TelegramBotAPI.utils.nonstrictJsonFormat | import com.github.insanusmokrassar.TelegramBotAPI.utils.nonstrictJsonFormat | ||||||
| import kotlinx.serialization.* | import kotlinx.serialization.* | ||||||
| import kotlinx.serialization.json.JsonElementSerializer | import kotlinx.serialization.json.* | ||||||
| import kotlinx.serialization.json.JsonObject |  | ||||||
|  |  | ||||||
| internal object InlineKeyboardButtonSerializer : KSerializer<InlineKeyboardButton> { | internal object InlineKeyboardButtonSerializer : KSerializer<InlineKeyboardButton> { | ||||||
|     override val descriptor: SerialDescriptor = SerialDescriptor( |     override val descriptor: SerialDescriptor = SerialDescriptor( | ||||||
| @@ -12,7 +11,7 @@ internal object InlineKeyboardButtonSerializer : KSerializer<InlineKeyboardButto | |||||||
|         PolymorphicKind.SEALED |         PolymorphicKind.SEALED | ||||||
|     ) |     ) | ||||||
|  |  | ||||||
|     private fun resolveSerializer(json: JsonObject): KSerializer<out InlineKeyboardButton> { |     private fun resolveSerializer(json: JsonObject): KSerializer<out InlineKeyboardButton>? { | ||||||
|         return when { |         return when { | ||||||
|             json[callbackDataField] != null -> CallbackDataInlineKeyboardButton.serializer() |             json[callbackDataField] != null -> CallbackDataInlineKeyboardButton.serializer() | ||||||
|             json[callbackGameField] != null -> CallbackGameInlineKeyboardButton.serializer() |             json[callbackGameField] != null -> CallbackGameInlineKeyboardButton.serializer() | ||||||
| @@ -21,14 +20,16 @@ internal object InlineKeyboardButtonSerializer : KSerializer<InlineKeyboardButto | |||||||
|             json[switchInlineQueryField] != null -> SwitchInlineQueryInlineKeyboardButton.serializer() |             json[switchInlineQueryField] != null -> SwitchInlineQueryInlineKeyboardButton.serializer() | ||||||
|             json[switchInlineQueryCurrentChatField] != null -> SwitchInlineQueryCurrentChatInlineKeyboardButton.serializer() |             json[switchInlineQueryCurrentChatField] != null -> SwitchInlineQueryCurrentChatInlineKeyboardButton.serializer() | ||||||
|             json[urlField] != null -> URLInlineKeyboardButton.serializer() |             json[urlField] != null -> URLInlineKeyboardButton.serializer() | ||||||
|             else -> throw IllegalArgumentException("Can't find correct serializer for inline button serialized as $json") |             else -> null | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     override fun deserialize(decoder: Decoder): InlineKeyboardButton { |     override fun deserialize(decoder: Decoder): InlineKeyboardButton { | ||||||
|         val json = JsonElementSerializer.deserialize(decoder) |         val json = JsonObjectSerializer.deserialize(decoder) | ||||||
|  |  | ||||||
|         return nonstrictJsonFormat.fromJson(resolveSerializer(json.jsonObject), json) |         return resolveSerializer(json) ?.let { | ||||||
|  |             nonstrictJsonFormat.fromJson(it, json) | ||||||
|  |         } ?: UnknownInlineKeyboardButton(json[textField] ?.contentOrNull ?: "", json) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     override fun serialize(encoder: Encoder, value: InlineKeyboardButton) { |     override fun serialize(encoder: Encoder, value: InlineKeyboardButton) { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user