mirror of
				https://github.com/InsanusMokrassar/TelegramBotAPI.git
				synced 2025-10-25 09:10:07 +00:00 
			
		
		
		
	a lot of types has been converted to sealed
This commit is contained in:
		| @@ -11,6 +11,8 @@ | ||||
|         * `Klock`: `2.0.7` -> `2.1.2` | ||||
|         * `UUID`: `0.2.3` -> `0.3.0` | ||||
|         * `Ktor`: `1.5.4` -> `1.6.0` | ||||
| * `Core`: | ||||
|     * `ForceReply` has been renamed to `ReplyForce` | ||||
|  | ||||
| ## 0.34.1 | ||||
|  | ||||
|   | ||||
| @@ -1,110 +1,79 @@ | ||||
| package dev.inmo.tgbotapi.CommonAbstracts | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSourceSerializer | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.regular | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.* | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.MultilevelTextSource | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSourcesList | ||||
| import dev.inmo.tgbotapi.types.captionLength | ||||
| import dev.inmo.tgbotapi.types.textLength | ||||
| import kotlinx.serialization.Serializable | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.separateForCaption | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.separateForMessage | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.separateForText | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.makeString | ||||
|  | ||||
| const val DirectInvocationOfTextSourceConstructor = "It is strongly not recommended to use constructors directly instead of factory methods" | ||||
| const val DirectInvocationOfTextSourceConstructor = | ||||
|     "It is strongly not recommended to use constructors directly instead of factory methods" | ||||
|  | ||||
| typealias TextSourcesList = List<TextSource> | ||||
|  | ||||
| @Serializable(TextSourceSerializer::class) | ||||
| interface TextSource { | ||||
|     val markdown: String | ||||
|     val markdownV2: String | ||||
|     val html: String | ||||
|     val source: String | ||||
|  | ||||
|     val asText: String | ||||
|         get() = source | ||||
|  | ||||
|     companion object { | ||||
|         fun serializer() = TextSourceSerializer | ||||
|     } | ||||
| } | ||||
|  | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline operator fun TextSource.plus(other: TextSource) = listOf(this, other) | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline operator fun TextSource.plus(other: List<TextSource>) = listOf(this) + other | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline operator fun TextSource.plus(text: String) = listOf(this, regular(text)) | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline operator fun List<TextSource>.plus(text: String) = this + regular(text) | ||||
|  | ||||
| @Serializable(TextSourceSerializer::class) | ||||
| interface MultilevelTextSource : TextSource { | ||||
|     val subsources: List<TextSource> | ||||
|  | ||||
|     companion object { | ||||
|         fun serializer() = TextSourceSerializer | ||||
|     } | ||||
| } | ||||
|  | ||||
| @Deprecated("This class will be removed soon. Use TextSources instead") | ||||
| data class TextPart( | ||||
|     val range: IntRange, | ||||
|     val source: TextSource | ||||
| @Deprecated( | ||||
|     "Replaced", | ||||
|     ReplaceWith("TextSourcesList", "dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSourcesList") | ||||
| ) | ||||
| typealias TextSourcesList = TextSourcesList | ||||
|  | ||||
| @Deprecated("This method is no longer required to work with TextSources") | ||||
| fun List<TextPart>.justTextSources() = map { it.source } | ||||
| internal fun List<TextSource>.toTextParts(preOffset: Int = 0): List<TextPart> { | ||||
|     var i = preOffset | ||||
|     return map { | ||||
|         TextPart( | ||||
|             i until (i + it.source.length), | ||||
|             it | ||||
|         ).also { | ||||
|             i = it.range.last + 1 | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @Deprecated("Replaced", ReplaceWith("TextSource", "dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource")) | ||||
| typealias TextSource = dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource | ||||
|  | ||||
| fun List<TextSource>.makeString() = joinToString("") { it.source } | ||||
| fun List<TextSource>.separateForMessage(limit: IntRange, numberOfParts: Int? = null): List<List<TextSource>> { | ||||
|     if (isEmpty()) { | ||||
|         return emptyList() | ||||
|     } | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| @Deprecated("Replaced", ReplaceWith("plus", "dev.inmo.tgbotapi.types.MessageEntity.textsources.plus")) | ||||
| inline operator fun dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource.plus(other: dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource) = | ||||
|     listOf(this, other) | ||||
|  | ||||
|     val resultList = mutableListOf<MutableList<TextSource>>(mutableListOf()) | ||||
|     var currentPartLength = 0 | ||||
|     val maxSize = limit.last + 1 | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| @Deprecated("Replaced", ReplaceWith("plus", "dev.inmo.tgbotapi.types.MessageEntity.textsources.plus")) | ||||
| inline operator fun dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource.plus(other: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>) = | ||||
|     listOf(this) + other | ||||
|  | ||||
|     for (current in this) { | ||||
|         if (current.source.length > maxSize) { | ||||
|             error("Currently unsupported parts with size more than target one-message parts (${current.source.length} > ${maxSize})") | ||||
|         } | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| @Deprecated("Replaced", ReplaceWith("plus", "dev.inmo.tgbotapi.types.MessageEntity.textsources.plus")) | ||||
| inline operator fun dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource.plus(text: String) = | ||||
|     listOf(this, regular(text)) | ||||
|  | ||||
|         if (currentPartLength + current.source.length > maxSize) { | ||||
|             if (numberOfParts == null || numberOfParts < resultList.size) { | ||||
|                 resultList.add(mutableListOf()) | ||||
|                 currentPartLength = 0 | ||||
|             } else { | ||||
|                 break | ||||
|             } | ||||
|         } | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| @Deprecated("Replaced", ReplaceWith("plus", "dev.inmo.tgbotapi.types.MessageEntity.textsources.plus")) | ||||
| inline operator fun List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>.plus(text: String) = this + regular(text) | ||||
|  | ||||
|         resultList.last().add(current) | ||||
|         currentPartLength += current.source.length | ||||
|     } | ||||
| @Deprecated( | ||||
|     "Replaced", | ||||
|     ReplaceWith("MultilevelTextSource", "dev.inmo.tgbotapi.types.MessageEntity.textsources.MultilevelTextSource") | ||||
| ) | ||||
| typealias MultilevelTextSource = MultilevelTextSource | ||||
|  | ||||
|     return resultList | ||||
| } | ||||
| @Deprecated("Replaced", ReplaceWith("makeString", "dev.inmo.tgbotapi.types.MessageEntity.textsources.makeString")) | ||||
| fun List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>.makeString() = makeString() | ||||
|  | ||||
| @Deprecated( | ||||
|     "Replaced", | ||||
|     ReplaceWith("separateForMessage", "dev.inmo.tgbotapi.types.MessageEntity.textsources.separateForMessage") | ||||
| ) | ||||
| fun List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>.separateForMessage(limit: IntRange, numberOfParts: Int? = null) = | ||||
|     separateForMessage(limit, numberOfParts) | ||||
|  | ||||
| /** | ||||
|  * This method will prepare [TextSource]s list for messages. Remember, that first part will be separated with | ||||
|  * [captionLength] and all others with | ||||
|  */ | ||||
| fun List<TextSource>.separateForCaption(): List<List<TextSource>> { | ||||
|     val captionPart = separateForMessage(captionLength, 1).first() | ||||
|     return listOf(captionPart) + minus(captionPart).separateForMessage(textLength) | ||||
| } | ||||
| @Deprecated( | ||||
|     "Replaced", | ||||
|     ReplaceWith("separateForCaption", "dev.inmo.tgbotapi.types.MessageEntity.textsources.separateForCaption") | ||||
| ) | ||||
| fun List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>.separateForCaption() = separateForCaption() | ||||
|  | ||||
| /** | ||||
|  * This method will prepare [TextSource]s list for messages with [textLength] | ||||
|  */ | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun List<TextSource>.separateForText(): List<List<TextSource>> = separateForMessage(textLength) | ||||
| @Deprecated( | ||||
|     "Replaced", | ||||
|     ReplaceWith("separateForText", "dev.inmo.tgbotapi.types.MessageEntity.textsources.separateForText") | ||||
| ) | ||||
| inline fun List<TextSource>.separateForText() = separateForText() | ||||
|   | ||||
| @@ -1,5 +1,6 @@ | ||||
| package dev.inmo.tgbotapi.CommonAbstracts | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource | ||||
| import dev.inmo.tgbotapi.types.ParseMode.ParseMode | ||||
|  | ||||
| interface Texted { | ||||
| @@ -9,7 +10,7 @@ interface TextedWithTextSources : Texted { | ||||
|     /** | ||||
|      * Full list of [TextSource] built from source[TextedInput.textEntities] | ||||
|      */ | ||||
|     val textSources: List<TextSource>? | ||||
|     val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? | ||||
| } | ||||
|  | ||||
| interface ParsableOutput : Texted { | ||||
| @@ -17,7 +18,7 @@ interface ParsableOutput : Texted { | ||||
| } | ||||
|  | ||||
| interface EntitiesOutput : TextedWithTextSources { | ||||
|     val entities: List<TextSource>? | ||||
|     val entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? | ||||
|         get() = textSources | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.requests.edit.caption | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.requests.edit.abstracts.* | ||||
| import dev.inmo.tgbotapi.requests.edit.media.MediaContentMessageResultDeserializer | ||||
| @@ -33,7 +32,7 @@ fun EditChatMessageCaption( | ||||
| fun EditChatMessageCaption( | ||||
|     chatId: ChatIdentifier, | ||||
|     messageId: MessageIdentifier, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = EditChatMessageCaption( | ||||
|     chatId, | ||||
| @@ -59,7 +58,7 @@ data class EditChatMessageCaption internal constructor( | ||||
|     @SerialName(replyMarkupField) | ||||
|     override val replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) : EditChatMessage<MediaContent>, EditTextChatMessage, EditReplyMessage { | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text) | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.requests.edit.caption | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.requests.edit.abstracts.* | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| @@ -25,7 +24,7 @@ fun EditInlineMessageCaption( | ||||
|  | ||||
| fun EditInlineMessageCaption( | ||||
|     inlineMessageId: InlineMessageIdentifier, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = EditInlineMessageCaption( | ||||
|     inlineMessageId, | ||||
| @@ -48,7 +47,7 @@ data class EditInlineMessageCaption internal constructor( | ||||
|     @SerialName(replyMarkupField) | ||||
|     override val replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) : EditInlineMessage, EditTextChatMessage, EditReplyMessage { | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text) | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.requests.edit.text | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.requests.edit.abstracts.* | ||||
| import dev.inmo.tgbotapi.requests.send.TextContentMessageResultDeserializer | ||||
| @@ -35,7 +34,7 @@ fun EditChatMessageText( | ||||
| fun EditChatMessageText( | ||||
|     chatId: ChatIdentifier, | ||||
|     messageId: MessageIdentifier, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     disableWebPagePreview: Boolean? = null, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = EditChatMessageText( | ||||
| @@ -65,7 +64,7 @@ data class EditChatMessageText internal constructor( | ||||
|     @SerialName(replyMarkupField) | ||||
|     override val replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) : EditChatMessage<TextContent>, EditTextChatMessage, EditReplyMessage, EditDisableWebPagePreviewMessage { | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text) | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.requests.edit.text | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.requests.edit.abstracts.* | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| @@ -27,7 +26,7 @@ fun EditInlineMessageText( | ||||
|  | ||||
| fun EditInlineMessageText( | ||||
|     inlineMessageId: InlineMessageIdentifier, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     disableWebPagePreview: Boolean? = null, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = EditInlineMessageText( | ||||
| @@ -54,7 +53,7 @@ data class EditInlineMessageText internal constructor( | ||||
|     @SerialName(replyMarkupField) | ||||
|     override val replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) : EditInlineMessage, EditTextChatMessage, EditReplyMessage, EditDisableWebPagePreviewMessage { | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text) | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -6,6 +6,7 @@ import dev.inmo.tgbotapi.requests.abstracts.SimpleRequest | ||||
| import dev.inmo.tgbotapi.requests.send.abstracts.ReplyingMarkupSendMessageRequest | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.* | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource | ||||
| import dev.inmo.tgbotapi.types.ParseMode.ParseMode | ||||
| import dev.inmo.tgbotapi.types.ParseMode.parseModeField | ||||
| import dev.inmo.tgbotapi.types.buttons.KeyboardMarkup | ||||
| @@ -27,7 +28,7 @@ fun CopyMessage( | ||||
|     fromChatId: ChatIdentifier, | ||||
|     toChatId: ChatIdentifier, | ||||
|     messageId: MessageIdentifier, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     allowSendingWithoutReply: Boolean? = null, | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.requests.send | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.types.DisableWebPagePreview | ||||
| import dev.inmo.tgbotapi.requests.send.abstracts.* | ||||
| @@ -41,7 +40,7 @@ fun SendTextMessage( | ||||
|  | ||||
| fun SendTextMessage( | ||||
|     chatId: ChatIdentifier, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     disableWebPagePreview: Boolean? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
| @@ -84,7 +83,7 @@ data class SendTextMessage internal constructor( | ||||
|     TextableSendMessageRequest<ContentMessage<TextContent>>, | ||||
|     DisableWebPagePreview | ||||
| { | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text) | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.requests.send.media | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.requests.abstracts.* | ||||
| import dev.inmo.tgbotapi.requests.send.abstracts.* | ||||
| @@ -66,7 +65,7 @@ fun SendAnimation( | ||||
|     chatId: ChatIdentifier, | ||||
|     animation: InputFile, | ||||
|     thumb: InputFile? = null, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     duration: Long? = null, | ||||
|     width: Int? = null, | ||||
|     height: Int? = null, | ||||
| @@ -145,7 +144,7 @@ data class SendAnimationData internal constructor( | ||||
|     DuratedSendMessageRequest<ContentMessage<AnimationContent>>, | ||||
|     SizedSendMessageRequest<ContentMessage<AnimationContent>> | ||||
| { | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text ?: return@lazy null) | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -6,6 +6,7 @@ import dev.inmo.tgbotapi.requests.send.abstracts.* | ||||
| import dev.inmo.tgbotapi.requests.send.media.base.* | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.* | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource | ||||
| import dev.inmo.tgbotapi.types.ParseMode.ParseMode | ||||
| import dev.inmo.tgbotapi.types.ParseMode.parseModeField | ||||
| import dev.inmo.tgbotapi.types.buttons.KeyboardMarkup | ||||
| @@ -65,7 +66,7 @@ fun SendAudio( | ||||
|     chatId: ChatIdentifier, | ||||
|     audio: InputFile, | ||||
|     thumb: InputFile? = null, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     duration: Long? = null, | ||||
|     performer: String? = null, | ||||
|     title: String? = null, | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.requests.send.media | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.requests.abstracts.* | ||||
| import dev.inmo.tgbotapi.requests.send.abstracts.* | ||||
| @@ -80,7 +79,7 @@ fun SendDocument( | ||||
|     chatId: ChatIdentifier, | ||||
|     document: InputFile, | ||||
|     thumb: InputFile? = null, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     allowSendingWithoutReply: Boolean? = null, | ||||
| @@ -158,7 +157,7 @@ data class SendDocumentData internal constructor( | ||||
|     TextableSendMessageRequest<ContentMessage<DocumentContent>>, | ||||
|     ThumbedSendMessageRequest<ContentMessage<DocumentContent>> | ||||
| { | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text ?: return@lazy null) | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.requests.send.media | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.requests.abstracts.* | ||||
| import dev.inmo.tgbotapi.requests.send.abstracts.* | ||||
| @@ -48,7 +47,7 @@ fun SendPhoto( | ||||
| fun SendPhoto( | ||||
|     chatId: ChatIdentifier, | ||||
|     photo: InputFile, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     allowSendingWithoutReply: Boolean? = null, | ||||
| @@ -101,7 +100,7 @@ data class SendPhotoData internal constructor( | ||||
|     ReplyingMarkupSendMessageRequest<ContentMessage<PhotoContent>>, | ||||
|     TextableSendMessageRequest<ContentMessage<PhotoContent>> | ||||
| { | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text ?: return@lazy null) | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.requests.send.media | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.requests.abstracts.* | ||||
| import dev.inmo.tgbotapi.requests.send.abstracts.* | ||||
| @@ -68,7 +67,7 @@ fun SendVideo( | ||||
|     chatId: ChatIdentifier, | ||||
|     video: InputFile, | ||||
|     thumb: InputFile? = null, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     duration: Long? = null, | ||||
|     width: Int? = null, | ||||
|     height: Int? = null, | ||||
| @@ -151,7 +150,7 @@ data class SendVideoData internal constructor( | ||||
|     DuratedSendMessageRequest<ContentMessage<VideoContent>>, | ||||
|     SizedSendMessageRequest<ContentMessage<VideoContent>> | ||||
| { | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text ?: return@lazy null) | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.requests.send.media | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.requests.abstracts.* | ||||
| import dev.inmo.tgbotapi.requests.send.abstracts.* | ||||
| @@ -57,7 +56,7 @@ fun SendVoice( | ||||
| fun SendVoice( | ||||
|     chatId: ChatIdentifier, | ||||
|     voice: InputFile, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     duration: Long? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
| @@ -121,7 +120,7 @@ data class SendVoiceData internal constructor( | ||||
|     TextableSendMessageRequest<ContentMessage<VoiceContent>>, | ||||
|     DuratedSendMessageRequest<ContentMessage<VoiceContent>> | ||||
| { | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text ?: return@lazy null) | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -6,6 +6,7 @@ import dev.inmo.tgbotapi.requests.send.abstracts.ReplyingMarkupSendMessageReques | ||||
| import dev.inmo.tgbotapi.requests.send.abstracts.SendMessageRequest | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.* | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource | ||||
| import dev.inmo.tgbotapi.types.ParseMode.ParseMode | ||||
| import dev.inmo.tgbotapi.types.buttons.KeyboardMarkup | ||||
| import dev.inmo.tgbotapi.types.message.abstracts.ContentMessage | ||||
| @@ -267,7 +268,7 @@ fun SendQuizPoll( | ||||
|     correctOptionId: Int, | ||||
|     isAnonymous: Boolean = true, | ||||
|     isClosed: Boolean = false, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     closeInfo: ScheduledCloseInfo? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|   | ||||
| @@ -3,7 +3,7 @@ package dev.inmo.tgbotapi.types.CallbackQuery | ||||
| import dev.inmo.tgbotapi.types.CallbackQueryIdentifier | ||||
| import dev.inmo.tgbotapi.types.User | ||||
|  | ||||
| interface CallbackQuery { | ||||
| sealed interface CallbackQuery { | ||||
|     val id: CallbackQueryIdentifier | ||||
|     val user: User | ||||
|     val chatInstance: String | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.CallbackQuery | ||||
|  | ||||
| interface DataCallbackQuery : CallbackQuery { | ||||
| sealed interface DataCallbackQuery : CallbackQuery { | ||||
|     val data: String | ||||
| } | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.CallbackQuery | ||||
|  | ||||
| interface GameShortNameCallbackQuery : CallbackQuery { | ||||
| sealed interface GameShortNameCallbackQuery : CallbackQuery { | ||||
|     val gameShortName: String | ||||
| } | ||||
|   | ||||
| @@ -2,6 +2,6 @@ package dev.inmo.tgbotapi.types.CallbackQuery | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.InlineMessageIdentifier | ||||
|  | ||||
| interface InlineMessageIdCallbackQuery : CallbackQuery { | ||||
| sealed interface InlineMessageIdCallbackQuery : CallbackQuery { | ||||
|     val inlineMessageId: InlineMessageIdentifier | ||||
| } | ||||
| } | ||||
|   | ||||
| @@ -2,6 +2,6 @@ package dev.inmo.tgbotapi.types.CallbackQuery | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.message.abstracts.Message | ||||
|  | ||||
| interface MessageCallbackQuery : CallbackQuery { | ||||
| sealed interface MessageCallbackQuery : CallbackQuery { | ||||
|     val message: Message | ||||
| } | ||||
| } | ||||
|   | ||||
| @@ -1,12 +0,0 @@ | ||||
| package dev.inmo.tgbotapi.types.ChatMember | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.ChatMember.abstracts.ChatMember | ||||
| import kotlinx.serialization.* | ||||
|  | ||||
| @Serializable | ||||
| data class LeftChatMember(@SerialName(userField) override val user: User) : ChatMember { | ||||
|     @SerialName(statusField) | ||||
|     @Required | ||||
|     private val type: String = "left" | ||||
| } | ||||
| @@ -0,0 +1,16 @@ | ||||
| package dev.inmo.tgbotapi.types.ChatMember | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.ChatMember.abstracts.ChatMember | ||||
| import dev.inmo.tgbotapi.types.ChatMember.abstracts.LeftChatMember | ||||
| import kotlinx.serialization.* | ||||
|  | ||||
| @Serializable | ||||
| data class LeftChatMemberImpl(@SerialName(userField) override val user: User) : LeftChatMember { | ||||
|     @SerialName(statusField) | ||||
|     @Required | ||||
|     private val type: String = "left" | ||||
| } | ||||
|  | ||||
| @Deprecated("Renamed", ReplaceWith("LeftChatMemberImpl", "dev.inmo.tgbotapi.types.ChatMember.LeftChatMemberImpl")) | ||||
| typealias LeftChatMember = LeftChatMemberImpl | ||||
| @@ -1,12 +0,0 @@ | ||||
| package dev.inmo.tgbotapi.types.ChatMember | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.ChatMember.abstracts.ChatMember | ||||
| import kotlinx.serialization.* | ||||
|  | ||||
| @Serializable | ||||
| data class MemberChatMember(@SerialName(userField) override val user: User) : ChatMember { | ||||
|     @SerialName(statusField) | ||||
|     @Required | ||||
|     private val type: String = "member" | ||||
| } | ||||
| @@ -0,0 +1,16 @@ | ||||
| package dev.inmo.tgbotapi.types.ChatMember | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.ChatMember.abstracts.ChatMember | ||||
| import dev.inmo.tgbotapi.types.ChatMember.abstracts.MemberChatMember | ||||
| import kotlinx.serialization.* | ||||
|  | ||||
| @Serializable | ||||
| data class MemberChatMemberImpl(@SerialName(userField) override val user: User) : MemberChatMember { | ||||
|     @SerialName(statusField) | ||||
|     @Required | ||||
|     private val type: String = "member" | ||||
| } | ||||
|  | ||||
| @Deprecated("Renamed", ReplaceWith("MemberChatMember", "dev.inmo.tgbotapi.types.ChatMember.MemberChatMemberImpl")) | ||||
| typealias MemberChatMember = MemberChatMemberImpl | ||||
| @@ -13,7 +13,7 @@ import kotlinx.serialization.json.JsonObject | ||||
| import kotlinx.serialization.json.jsonPrimitive | ||||
|  | ||||
| @Serializable(ChatMemberSerializer::class) | ||||
| interface ChatMember { | ||||
| sealed interface ChatMember { | ||||
|     val user: User | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -0,0 +1,3 @@ | ||||
| package dev.inmo.tgbotapi.types.ChatMember.abstracts | ||||
|  | ||||
| interface LeftChatMember : ChatMember | ||||
| @@ -0,0 +1,3 @@ | ||||
| package dev.inmo.tgbotapi.types.ChatMember.abstracts | ||||
|  | ||||
| interface MemberChatMember : ChatMember | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.requests.abstracts.FileId | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| @@ -26,7 +25,7 @@ fun InlineQueryResultAudioCachedImpl( | ||||
| fun InlineQueryResultAudioCachedImpl( | ||||
|     id: InlineQueryIdentifier, | ||||
|     fileId: FileId, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null, | ||||
|     inputMessageContent: InputMessageContent? = null | ||||
| ) = InlineQueryResultAudioCachedImpl(id, fileId, entities.makeString(), null, entities.toRawMessageEntities(), replyMarkup, inputMessageContent) | ||||
| @@ -49,7 +48,7 @@ data class InlineQueryResultAudioCachedImpl internal constructor( | ||||
|     override val inputMessageContent: InputMessageContent? = null | ||||
| ) : InlineQueryResultAudioCached { | ||||
|     override val type: String = inlineQueryResultAudioType | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text ?: return@lazy null) | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult.abstracts.results.audio.InlineQueryResultAudio | ||||
| @@ -31,7 +30,7 @@ fun InlineQueryResultAudioImpl( | ||||
|     title: String, | ||||
|     performer: String? = null, | ||||
|     duration: Int? = null, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null, | ||||
|     inputMessageContent: InputMessageContent? = null | ||||
| ) = InlineQueryResultAudioImpl(id, url, title, performer, duration, entities.makeString(), null, entities.toRawMessageEntities(), replyMarkup, inputMessageContent) | ||||
| @@ -60,7 +59,7 @@ data class InlineQueryResultAudioImpl internal constructor( | ||||
|     override val inputMessageContent: InputMessageContent? = null | ||||
| ) : InlineQueryResultAudio { | ||||
|     override val type: String = inlineQueryResultAudioType | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text ?: return@lazy null) | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.requests.abstracts.FileId | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| @@ -30,7 +29,7 @@ fun InlineQueryResultDocumentCachedImpl( | ||||
|     fileId: FileId, | ||||
|     title: String, | ||||
|     description: String? = null, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null, | ||||
|     inputMessageContent: InputMessageContent? = null | ||||
| ) = InlineQueryResultDocumentCachedImpl(id, fileId, title, description, entities.makeString(), null, entities.toRawMessageEntities(), replyMarkup, inputMessageContent) | ||||
| @@ -57,7 +56,7 @@ data class InlineQueryResultDocumentCachedImpl internal constructor( | ||||
|     override val inputMessageContent: InputMessageContent? = null | ||||
| ) : InlineQueryResultDocumentCached { | ||||
|     override val type: String = inlineQueryResultDocumentType | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text ?: return@lazy null) | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult.abstracts.results.document.InlineQueryResultDocument | ||||
| @@ -39,7 +38,7 @@ fun InlineQueryResultDocumentImpl( | ||||
|     thumbWidth: Int? = null, | ||||
|     thumbHeight: Int? = null, | ||||
|     description: String? = null, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null, | ||||
|     inputMessageContent: InputMessageContent? = null | ||||
| ) = InlineQueryResultDocumentImpl(id, url, title, mimeType, thumbUrl, thumbWidth, thumbHeight, description, entities.makeString(), null, entities.toRawMessageEntities(), replyMarkup, inputMessageContent) | ||||
| @@ -74,7 +73,7 @@ data class InlineQueryResultDocumentImpl internal constructor( | ||||
|     override val inputMessageContent: InputMessageContent? = null | ||||
| ) : InlineQueryResultDocument { | ||||
|     override val type: String = inlineQueryResultDocumentType | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text ?: return@lazy null) | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.requests.abstracts.FileId | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| @@ -28,7 +27,7 @@ fun InlineQueryResultGifCachedImpl( | ||||
|     id: InlineQueryIdentifier, | ||||
|     fileId: FileId, | ||||
|     title: String? = null, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null, | ||||
|     inputMessageContent: InputMessageContent? = null | ||||
| ) = InlineQueryResultGifCachedImpl(id, fileId, title, entities.makeString(), null, entities.toRawMessageEntities(), replyMarkup, inputMessageContent) | ||||
| @@ -53,7 +52,7 @@ data class InlineQueryResultGifCachedImpl internal constructor( | ||||
|     override val inputMessageContent: InputMessageContent? = null | ||||
| ) : InlineQueryResultGifCached { | ||||
|     override val type: String = inlineQueryResultGifType | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text ?: return@lazy null) | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult.abstracts.results.gif.InlineQueryResultGif | ||||
| @@ -38,7 +37,7 @@ fun InlineQueryResultGifImpl( | ||||
|     height: Int? = null, | ||||
|     duration: Int? = null, | ||||
|     title: String? = null, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null, | ||||
|     inputMessageContent: InputMessageContent? = null | ||||
| ) = InlineQueryResultGifImpl(id, url, thumbUrl, thumbMimeType, width, height, duration, title, entities.makeString(), null, entities.toRawMessageEntities(), replyMarkup, inputMessageContent) | ||||
| @@ -73,7 +72,7 @@ data class InlineQueryResultGifImpl internal constructor( | ||||
|     override val inputMessageContent: InputMessageContent? = null | ||||
| ) : InlineQueryResultGif { | ||||
|     override val type: String = inlineQueryResultGifType | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text ?: return@lazy null) | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.requests.abstracts.FileId | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| @@ -28,7 +27,7 @@ fun InlineQueryResultMpeg4GifCachedImpl( | ||||
|     id: InlineQueryIdentifier, | ||||
|     fileId: FileId, | ||||
|     title: String? = null, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null, | ||||
|     inputMessageContent: InputMessageContent? = null | ||||
| ) = InlineQueryResultMpeg4GifCachedImpl(id, fileId, title, entities.makeString(), null, entities.toRawMessageEntities(), replyMarkup, inputMessageContent) | ||||
| @@ -53,7 +52,7 @@ data class InlineQueryResultMpeg4GifCachedImpl internal constructor( | ||||
|     override val inputMessageContent: InputMessageContent? = null | ||||
| ) : InlineQueryResultMpeg4GifCached { | ||||
|     override val type: String = inlineQueryResultMpeg4GifType | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text ?: return@lazy null) | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult.abstracts.results.mpeg4gif.InlineQueryResultMpeg4Gif | ||||
| @@ -38,7 +37,7 @@ fun InlineQueryResultMpeg4GifImpl( | ||||
|     height: Int? = null, | ||||
|     duration: Int? = null, | ||||
|     title: String? = null, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null, | ||||
|     inputMessageContent: InputMessageContent? = null | ||||
| ) = InlineQueryResultMpeg4GifImpl(id, url, thumbUrl, thumbMimeType, width, height, duration, title, entities.makeString(), null, entities.toRawMessageEntities(), replyMarkup, inputMessageContent) | ||||
| @@ -73,7 +72,7 @@ data class InlineQueryResultMpeg4GifImpl internal constructor( | ||||
|     override val inputMessageContent: InputMessageContent? = null | ||||
| ) : InlineQueryResultMpeg4Gif { | ||||
|     override val type: String = inlineQueryResultMpeg4GifType | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text ?: return@lazy null) | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.requests.abstracts.FileId | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| @@ -30,7 +29,7 @@ fun InlineQueryResultPhotoCachedImpl( | ||||
|     fileId: FileId, | ||||
|     title: String? = null, | ||||
|     description: String? = null, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null, | ||||
|     inputMessageContent: InputMessageContent? = null | ||||
| ) = InlineQueryResultPhotoCachedImpl(id, fileId, title, description, entities.makeString(), null, entities.toRawMessageEntities(), replyMarkup, inputMessageContent) | ||||
| @@ -57,7 +56,7 @@ data class InlineQueryResultPhotoCachedImpl internal constructor( | ||||
|     override val inputMessageContent: InputMessageContent? = null | ||||
| ) : InlineQueryResultPhotoCached { | ||||
|     override val type: String = inlineQueryResultPhotoType | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text ?: return@lazy null) | ||||
|     } | ||||
| } | ||||
| } | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult.abstracts.results.photo.InlineQueryResultPhoto | ||||
| @@ -35,7 +34,7 @@ fun InlineQueryResultPhotoImpl( | ||||
|     height: Int? = null, | ||||
|     title: String? = null, | ||||
|     description: String? = null, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null, | ||||
|     inputMessageContent: InputMessageContent? = null | ||||
| ) = InlineQueryResultPhotoImpl(id, url, thumbUrl, width, height, title, description, entities.makeString(), null, entities.toRawMessageEntities(), replyMarkup, inputMessageContent) | ||||
| @@ -68,7 +67,7 @@ data class InlineQueryResultPhotoImpl internal constructor( | ||||
|     override val inputMessageContent: InputMessageContent? = null | ||||
| ) : InlineQueryResultPhoto { | ||||
|     override val type: String = inlineQueryResultPhotoType | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text ?: return@lazy null) | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.requests.abstracts.FileId | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| @@ -30,7 +29,7 @@ fun InlineQueryResultVideoCachedImpl( | ||||
|     fileId: FileId, | ||||
|     title: String, | ||||
|     description: String? = null, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null, | ||||
|     inputMessageContent: InputMessageContent? = null | ||||
| ) = InlineQueryResultVideoCachedImpl(id, fileId, title, description, entities.makeString(), null, entities.toRawMessageEntities(), replyMarkup, inputMessageContent) | ||||
| @@ -57,7 +56,7 @@ data class InlineQueryResultVideoCachedImpl internal constructor( | ||||
|     override val inputMessageContent: InputMessageContent? = null | ||||
| ) : InlineQueryResultVideoCached { | ||||
|     override val type: String = inlineQueryResultVideoType | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text ?: return@lazy null) | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult.abstracts.results.video.InlineQueryResultVideo | ||||
| @@ -41,7 +40,7 @@ fun InlineQueryResultVideoImpl( | ||||
|     height: Int? = null, | ||||
|     duration: Int? = null, | ||||
|     description: String? = null, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null, | ||||
|     inputMessageContent: InputMessageContent? = null | ||||
| ) = InlineQueryResultVideoImpl(id, url, thumbUrl, mimeType, title, width, height, duration, description, entities.makeString(), null, entities.toRawMessageEntities(), replyMarkup, inputMessageContent) | ||||
| @@ -78,7 +77,7 @@ data class InlineQueryResultVideoImpl internal constructor( | ||||
|     override val inputMessageContent: InputMessageContent? = null | ||||
| ) : InlineQueryResultVideo { | ||||
|     override val type: String = inlineQueryResultVideoType | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text ?: return@lazy null) | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.requests.abstracts.FileId | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| @@ -28,7 +27,7 @@ fun InlineQueryResultVoiceCachedImpl( | ||||
|     id: InlineQueryIdentifier, | ||||
|     fileId: FileId, | ||||
|     title: String, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null, | ||||
|     inputMessageContent: InputMessageContent? = null | ||||
| ) = InlineQueryResultVoiceCachedImpl(id, fileId, title, entities.makeString(), null, entities.toRawMessageEntities(), replyMarkup, inputMessageContent) | ||||
| @@ -53,7 +52,7 @@ data class InlineQueryResultVoiceCachedImpl internal constructor( | ||||
|     override val inputMessageContent: InputMessageContent? = null | ||||
| ) : InlineQueryResultVoiceCached { | ||||
|     override val type: String = inlineQueryResultVoiceType | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text ?: return@lazy null) | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.InlineQueries.InlineQueryResult.abstracts.results.voice.InlineQueryResultVoice | ||||
| @@ -39,7 +38,7 @@ fun InlineQueryResultVoiceImpl( | ||||
|     url: String, | ||||
|     title: String, | ||||
|     duration: Int? = null, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null, | ||||
|     inputMessageContent: InputMessageContent? = null | ||||
| ) = InlineQueryResultVoiceImpl(id, url, title, duration, entities.makeString(), null, entities.toRawMessageEntities(), replyMarkup, inputMessageContent) | ||||
| @@ -66,7 +65,7 @@ data class InlineQueryResultVoiceImpl internal constructor( | ||||
|     override val inputMessageContent: InputMessageContent? = null | ||||
| ) : InlineQueryResultVoice { | ||||
|     override val type: String = inlineQueryResultVoiceType | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text ?: return@lazy null) | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -2,7 +2,6 @@ package dev.inmo.tgbotapi.types.InlineQueries.InputMessageContent | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.CommonContactData | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.InlineQueries.abstracts.InputMessageContent | ||||
| import kotlinx.serialization.SerialName | ||||
| import kotlinx.serialization.Serializable | ||||
|  | ||||
| @@ -16,4 +15,4 @@ data class InputContactMessageContent( | ||||
|     override val lastName: String? = null, | ||||
|     @SerialName(vcardField) | ||||
|     override val vcard: String? = null | ||||
| ) : CommonContactData, InputMessageContent | ||||
| ) : CommonContactData, InputMessageContent | ||||
|   | ||||
| @@ -2,7 +2,6 @@ package dev.inmo.tgbotapi.types.InlineQueries.InputMessageContent | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.CommonSendInvoiceData | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.InlineQueries.abstracts.InputMessageContent | ||||
| import dev.inmo.tgbotapi.types.payments.LabeledPrice | ||||
| import dev.inmo.tgbotapi.types.payments.LabeledPricesSerializer | ||||
| import dev.inmo.tgbotapi.types.payments.abstracts.Currency | ||||
|   | ||||
| @@ -2,7 +2,6 @@ package dev.inmo.tgbotapi.types.InlineQueries.InputMessageContent | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.* | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.InlineQueries.abstracts.InputMessageContent | ||||
| import kotlinx.serialization.SerialName | ||||
| import kotlinx.serialization.Serializable | ||||
|  | ||||
| @@ -20,4 +19,4 @@ data class InputLocationMessageContent( | ||||
|     override val heading: Degrees? = null, | ||||
|     @SerialName(proximityAlertRadiusField) | ||||
|     override val proximityAlertRadius: Meters? = null | ||||
| ) : Locationed, HorizontallyAccured, ProximityAlertable, Livable, Headed, InputMessageContent | ||||
| ) : Locationed, HorizontallyAccured, ProximityAlertable, Livable, Headed, InputMessageContent | ||||
|   | ||||
| @@ -0,0 +1,7 @@ | ||||
| package dev.inmo.tgbotapi.types.InlineQueries.InputMessageContent | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.InlineQueries.InputMessageContentSerializer | ||||
| import kotlinx.serialization.Serializable | ||||
|  | ||||
| @Serializable(InputMessageContentSerializer::class) | ||||
| sealed interface InputMessageContent | ||||
| @@ -3,8 +3,8 @@ package dev.inmo.tgbotapi.types.InlineQueries.InputMessageContent | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.* | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.types.DisableWebPagePreview | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.InlineQueries.abstracts.InputMessageContent | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.* | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource | ||||
| import dev.inmo.tgbotapi.types.ParseMode.ParseMode | ||||
| import dev.inmo.tgbotapi.types.ParseMode.parseModeField | ||||
| import kotlinx.serialization.SerialName | ||||
| @@ -23,7 +23,7 @@ fun InputTextMessageContent( | ||||
|  * Represents the [InputMessageContent] of a text message to be sent as the result of an inline query. | ||||
|  */ | ||||
| fun InputTextMessageContent( | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     disableWebPagePreview: Boolean? = null | ||||
| ) = InputTextMessageContent(entities.makeString(), null, entities.toRawMessageEntities(), disableWebPagePreview) | ||||
|  | ||||
| @@ -41,4 +41,4 @@ data class InputTextMessageContent internal constructor( | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text) | ||||
|     } | ||||
| } | ||||
| } | ||||
|   | ||||
| @@ -3,7 +3,6 @@ package dev.inmo.tgbotapi.types.InlineQueries.InputMessageContent | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.CommonVenueData | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.Locationed | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.InlineQueries.abstracts.InputMessageContent | ||||
| import kotlinx.serialization.SerialName | ||||
| import kotlinx.serialization.Serializable | ||||
|  | ||||
|   | ||||
| @@ -1,13 +1,9 @@ | ||||
| package dev.inmo.tgbotapi.types.InlineQueries.abstracts | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.InlineQueries.query.InlineQuery | ||||
| import dev.inmo.tgbotapi.types.InlineQueryIdentifier | ||||
| import dev.inmo.tgbotapi.types.User | ||||
| import dev.inmo.tgbotapi.types.chat.ChatType | ||||
|  | ||||
| interface InlineQuery { | ||||
|     val id: InlineQueryIdentifier | ||||
|     val from: User | ||||
|     val query: String | ||||
|     val offset: String | ||||
|     val chatType: ChatType? | ||||
| } | ||||
| @Deprecated("Replaced", ReplaceWith("InlineQuery", "dev.inmo.tgbotapi.types.InlineQueries.query.InlineQuery")) | ||||
| typealias InlineQuery = InlineQuery | ||||
|   | ||||
| @@ -1,7 +1,8 @@ | ||||
| package dev.inmo.tgbotapi.types.InlineQueries.abstracts | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.InlineQueries.InputMessageContent.InputMessageContent | ||||
| import dev.inmo.tgbotapi.types.InlineQueries.InputMessageContentSerializer | ||||
| import kotlinx.serialization.Serializable | ||||
|  | ||||
| @Serializable(InputMessageContentSerializer::class) | ||||
| interface InputMessageContent | ||||
| @Deprecated("Replaced", ReplaceWith("InputMessageContent", "dev.inmo.tgbotapi.types.InlineQueries.InputMessageContent.InputMessageContent")) | ||||
| typealias InputMessageContent = InputMessageContent | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.InlineQueries.query | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.InlineQueries.abstracts.InlineQuery | ||||
| import dev.inmo.tgbotapi.types.InlineQueryIdentifier | ||||
| import dev.inmo.tgbotapi.types.User | ||||
| import dev.inmo.tgbotapi.types.chat.ChatType | ||||
|   | ||||
| @@ -0,0 +1,13 @@ | ||||
| package dev.inmo.tgbotapi.types.InlineQueries.query | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.InlineQueryIdentifier | ||||
| import dev.inmo.tgbotapi.types.User | ||||
| import dev.inmo.tgbotapi.types.chat.ChatType | ||||
|  | ||||
| sealed interface InlineQuery { | ||||
|     val id: InlineQueryIdentifier | ||||
|     val from: User | ||||
|     val query: String | ||||
|     val offset: String | ||||
|     val chatType: ChatType? | ||||
| } | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.InlineQueries.query | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.InlineQueries.abstracts.InlineQuery | ||||
| import dev.inmo.tgbotapi.types.InlineQueryIdentifier | ||||
| import dev.inmo.tgbotapi.types.User | ||||
| import dev.inmo.tgbotapi.types.chat.ChatType | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.InputMedia | ||||
|  | ||||
| interface DuratedInputMedia : InputMedia { | ||||
| sealed interface DuratedInputMedia : InputMedia { | ||||
|     val duration: Long? | ||||
| } | ||||
| } | ||||
|   | ||||
| @@ -4,8 +4,8 @@ import dev.inmo.tgbotapi.requests.abstracts.InputFile | ||||
| import kotlinx.serialization.Serializable | ||||
|  | ||||
| @Serializable(InputMediaSerializer::class) | ||||
| interface InputMedia { | ||||
| sealed interface InputMedia { | ||||
|     val type: String | ||||
|     val file: InputFile | ||||
|     val media: String | ||||
| } | ||||
| } | ||||
|   | ||||
| @@ -5,6 +5,7 @@ import dev.inmo.tgbotapi.requests.abstracts.InputFile | ||||
| import dev.inmo.tgbotapi.requests.abstracts.fileIdToSend | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.* | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource | ||||
| import dev.inmo.tgbotapi.types.ParseMode.ParseMode | ||||
| import dev.inmo.tgbotapi.types.ParseMode.parseModeField | ||||
| import kotlinx.serialization.SerialName | ||||
| @@ -22,7 +23,7 @@ fun InputMediaAnimation( | ||||
|  | ||||
| fun InputMediaAnimation( | ||||
|     file: InputFile, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     width: Int? = null, | ||||
|     height: Int? = null, | ||||
|     duration: Long? = null, | ||||
|   | ||||
| @@ -5,6 +5,7 @@ import dev.inmo.tgbotapi.requests.abstracts.InputFile | ||||
| import dev.inmo.tgbotapi.requests.abstracts.fileIdToSend | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.* | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource | ||||
| import dev.inmo.tgbotapi.types.ParseMode.ParseMode | ||||
| import dev.inmo.tgbotapi.types.ParseMode.parseModeField | ||||
| import dev.inmo.tgbotapi.types.files.AudioFile | ||||
| @@ -14,7 +15,7 @@ internal const val audioInputMediaType = "audio" | ||||
|  | ||||
| fun InputMediaAudio( | ||||
|     file: InputFile, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     duration: Long? = null, | ||||
|     performer: String? = null, | ||||
|     title: String? = null, | ||||
|   | ||||
| @@ -4,6 +4,7 @@ import dev.inmo.tgbotapi.CommonAbstracts.* | ||||
| import dev.inmo.tgbotapi.requests.abstracts.* | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.* | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource | ||||
| import dev.inmo.tgbotapi.types.ParseMode.ParseMode | ||||
| import dev.inmo.tgbotapi.types.ParseMode.parseModeField | ||||
| import dev.inmo.tgbotapi.types.files.DocumentFile | ||||
| @@ -21,7 +22,7 @@ fun InputMediaDocument( | ||||
|  | ||||
| fun InputMediaDocument( | ||||
|     file: InputFile, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     thumb: InputFile? = null, | ||||
|     disableContentTypeDetection: Boolean? = null | ||||
| ) = InputMediaDocument(file, entities.makeString(), null, entities.toRawMessageEntities(), thumb, disableContentTypeDetection) | ||||
|   | ||||
| @@ -5,6 +5,7 @@ import dev.inmo.tgbotapi.requests.abstracts.InputFile | ||||
| import dev.inmo.tgbotapi.requests.abstracts.fileIdToSend | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.* | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource | ||||
| import dev.inmo.tgbotapi.types.ParseMode.ParseMode | ||||
| import dev.inmo.tgbotapi.types.ParseMode.parseModeField | ||||
| import dev.inmo.tgbotapi.types.files.PhotoSize | ||||
| @@ -20,7 +21,7 @@ fun InputMediaPhoto( | ||||
|  | ||||
| fun InputMediaPhoto( | ||||
|     file: InputFile, | ||||
|     entities: List<TextSource> | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource> | ||||
| ) = InputMediaPhoto(file, entities.makeString(), null, entities.toRawMessageEntities()) | ||||
|  | ||||
| @Serializable | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.InputMedia | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.requests.abstracts.InputFile | ||||
| import dev.inmo.tgbotapi.requests.abstracts.fileIdToSend | ||||
| @@ -24,7 +23,7 @@ fun InputMediaVideo( | ||||
|  | ||||
| fun InputMediaVideo( | ||||
|     file: InputFile, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     width: Int? = null, | ||||
|     height: Int? = null, | ||||
|     duration: Long? = null, | ||||
| @@ -46,7 +45,7 @@ data class InputMediaVideo internal constructor ( | ||||
|     override val thumb: InputFile? = null | ||||
| ) : InputMedia, SizedInputMedia, DuratedInputMedia, ThumbedInputMedia, VisualMediaGroupMemberInputMedia { | ||||
|     override val type: String = videoInputMediaType | ||||
|     override val textSources: List<TextSource>? by lazy { | ||||
|     override val textSources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>? by lazy { | ||||
|         rawEntities ?.asTextSources(text ?: return@lazy null) | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -15,12 +15,12 @@ internal fun <T> T.buildArguments(withSerializer: SerializationStrategy<T>) = ar | ||||
| ) | ||||
|  | ||||
| @Serializable(MediaGroupMemberInputMediaSerializer::class) | ||||
| interface MediaGroupMemberInputMedia : InputMedia, TextedOutput { | ||||
| sealed interface MediaGroupMemberInputMedia : InputMedia, TextedOutput { | ||||
|     fun serialize(format: StringFormat): String | ||||
| } | ||||
|  | ||||
| interface AudioMediaGroupMemberInputMedia: MediaGroupMemberInputMedia | ||||
| interface DocumentMediaGroupMemberInputMedia: MediaGroupMemberInputMedia | ||||
| sealed interface AudioMediaGroupMemberInputMedia: MediaGroupMemberInputMedia | ||||
| sealed interface DocumentMediaGroupMemberInputMedia: MediaGroupMemberInputMedia | ||||
|  | ||||
| @Serializable(MediaGroupMemberInputMediaSerializer::class) | ||||
| interface VisualMediaGroupMemberInputMedia : MediaGroupMemberInputMedia | ||||
| sealed interface VisualMediaGroupMemberInputMedia : MediaGroupMemberInputMedia | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| package dev.inmo.tgbotapi.types.InputMedia | ||||
|  | ||||
| interface SizedInputMedia : InputMedia { | ||||
| sealed interface SizedInputMedia : InputMedia { | ||||
|     val width: Int? | ||||
|     val height: Int? | ||||
| } | ||||
| } | ||||
|   | ||||
| @@ -2,6 +2,6 @@ package dev.inmo.tgbotapi.types.InputMedia | ||||
|  | ||||
| import dev.inmo.tgbotapi.requests.abstracts.InputFile | ||||
|  | ||||
| interface ThumbedInputMedia : InputMedia { | ||||
| sealed interface ThumbedInputMedia : InputMedia { | ||||
|     val thumb: InputFile? | ||||
| } | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.InputMedia | ||||
|  | ||||
| interface TitledInputMedia : InputMedia { | ||||
| sealed interface TitledInputMedia : InputMedia { | ||||
|     val title: String? | ||||
| } | ||||
|   | ||||
| @@ -1,7 +1,6 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.MultilevelTextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.* | ||||
| import dev.inmo.tgbotapi.types.User | ||||
| import kotlinx.serialization.Serializable | ||||
| @@ -22,8 +21,8 @@ internal data class RawMessageEntity( | ||||
|  | ||||
| internal fun RawMessageEntity.asTextSource( | ||||
|     source: String, | ||||
|     subParts: List<TextSource> | ||||
| ): TextSource { | ||||
|     subParts: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource> | ||||
| ): dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource { | ||||
|     val sourceSubstring: String = source.substring(range) | ||||
|     val subPartsWithRegulars by lazy { | ||||
|         subParts.fillWithRegulars(sourceSubstring) | ||||
| @@ -40,8 +39,15 @@ internal fun RawMessageEntity.asTextSource( | ||||
|         "italic" -> ItalicTextSource(sourceSubstring, subPartsWithRegulars) | ||||
|         "code" -> CodeTextSource(sourceSubstring) | ||||
|         "pre" -> PreTextSource(sourceSubstring, language) | ||||
|         "text_link" -> TextLinkTextSource(sourceSubstring, url ?: throw IllegalStateException("URL must not be null for text link")) | ||||
|         "text_mention" -> TextMentionTextSource(sourceSubstring, user ?: throw IllegalStateException("User must not be null for text mention"), subPartsWithRegulars) | ||||
|         "text_link" -> TextLinkTextSource( | ||||
|             sourceSubstring, | ||||
|             url ?: throw IllegalStateException("URL must not be null for text link") | ||||
|         ) | ||||
|         "text_mention" -> TextMentionTextSource( | ||||
|             sourceSubstring, | ||||
|             user ?: throw IllegalStateException("User must not be null for text mention"), | ||||
|             subPartsWithRegulars | ||||
|         ) | ||||
|         "underline" -> UnderlineTextSource(sourceSubstring, subPartsWithRegulars) | ||||
|         "strikethrough" -> StrikethroughTextSource(sourceSubstring, subPartsWithRegulars) | ||||
|         else -> RegularTextSource(sourceSubstring) | ||||
| @@ -52,9 +58,9 @@ private inline operator fun <T : Comparable<T>> ClosedRange<T>.contains(other: C | ||||
|     return start <= other.start && endInclusive >= other.endInclusive | ||||
| } | ||||
|  | ||||
| internal fun List<TextSource>.fillWithRegulars(source: String): List<TextSource> { | ||||
| internal fun List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>.fillWithRegulars(source: String): List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource> { | ||||
|     var index = 0 | ||||
|     val result = mutableListOf<TextSource>() | ||||
|     val result = mutableListOf<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>() | ||||
|     for (i in 0 until size) { | ||||
|         val textSource = get(i) | ||||
|         val thisSourceInStart = source.startsWith(textSource.source, index) | ||||
| @@ -74,9 +80,12 @@ internal fun List<TextSource>.fillWithRegulars(source: String): List<TextSource> | ||||
|     return result | ||||
| } | ||||
|  | ||||
| private fun createTextSources(originalFullString: String, entities: RawMessageEntities): List<TextSource> { | ||||
| private fun createTextSources( | ||||
|     originalFullString: String, | ||||
|     entities: RawMessageEntities | ||||
| ): List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource> { | ||||
|     val mutableEntities = entities.toMutableList().apply { sortBy { it.offset } } | ||||
|     val resultList = mutableListOf<TextSource>() | ||||
|     val resultList = mutableListOf<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>() | ||||
|  | ||||
|     while (mutableEntities.isNotEmpty()) { | ||||
|         var parent = mutableEntities.removeFirst() | ||||
| @@ -130,7 +139,7 @@ private fun createTextSources(originalFullString: String, entities: RawMessageEn | ||||
|     return resultList | ||||
| } | ||||
|  | ||||
| internal fun TextSource.toRawMessageEntities(offset: Int = 0): List<RawMessageEntity> { | ||||
| internal fun dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource.toRawMessageEntities(offset: Int = 0): List<RawMessageEntity> { | ||||
|     val source = source | ||||
|     val length = source.length | ||||
|     return listOfNotNull( | ||||
| @@ -160,23 +169,24 @@ internal fun TextSource.toRawMessageEntities(offset: Int = 0): List<RawMessageEn | ||||
| } | ||||
|  | ||||
|  | ||||
| internal fun List<TextSource>.toRawMessageEntities(preOffset: Int = 0): List<RawMessageEntity> { | ||||
| internal fun List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>.toRawMessageEntities(preOffset: Int = 0): List<RawMessageEntity> { | ||||
|     var i = preOffset | ||||
|     return flatMap { textSource -> | ||||
|         textSource.toRawMessageEntities(i).also { | ||||
|             i += it.maxByOrNull { it.length } ?.length ?: textSource.source.length | ||||
|             i += it.maxByOrNull { it.length }?.length ?: textSource.source.length | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| fun String.removeLeading(word: String) = if (startsWith(word)){ | ||||
| fun String.removeLeading(word: String) = if (startsWith(word)) { | ||||
|     substring(word.length) | ||||
| } else { | ||||
|     this | ||||
| } | ||||
|  | ||||
| internal fun List<TextSource>.toRawMessageEntities(): List<RawMessageEntity> = toRawMessageEntities(0) | ||||
| internal fun List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>.toRawMessageEntities(): List<RawMessageEntity> = toRawMessageEntities(0) | ||||
|  | ||||
| internal fun RawMessageEntities.asTextSources(sourceString: String): List<TextSource> = createTextSources(sourceString, this).fillWithRegulars(sourceString) | ||||
| internal fun RawMessageEntities.asTextSources(sourceString: String): List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource> = | ||||
|     createTextSources(sourceString, this).fillWithRegulars(sourceString) | ||||
|  | ||||
| internal typealias RawMessageEntities = List<RawMessageEntity> | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity.textsources | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.* | ||||
| import dev.inmo.tgbotapi.utils.RiskFeature | ||||
| import dev.inmo.tgbotapi.utils.internal.* | ||||
| import kotlinx.serialization.Serializable | ||||
|   | ||||
| @@ -1,7 +1,6 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity.textsources | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.DirectInvocationOfTextSourceConstructor | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.utils.RiskFeature | ||||
| import dev.inmo.tgbotapi.utils.internal.* | ||||
| import kotlinx.serialization.Serializable | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity.textsources | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.* | ||||
| import dev.inmo.tgbotapi.utils.RiskFeature | ||||
| import dev.inmo.tgbotapi.utils.internal.* | ||||
| import kotlinx.serialization.Serializable | ||||
|   | ||||
| @@ -1,7 +1,6 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity.textsources | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.DirectInvocationOfTextSourceConstructor | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.utils.RiskFeature | ||||
| import dev.inmo.tgbotapi.utils.internal.* | ||||
| import kotlinx.serialization.Serializable | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity.textsources | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.* | ||||
| import dev.inmo.tgbotapi.utils.RiskFeature | ||||
| import dev.inmo.tgbotapi.utils.internal.* | ||||
| import kotlinx.serialization.Serializable | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity.textsources | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.* | ||||
| import dev.inmo.tgbotapi.utils.RiskFeature | ||||
| import dev.inmo.tgbotapi.utils.internal.* | ||||
| import kotlinx.serialization.Serializable | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity.textsources | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.* | ||||
| import dev.inmo.tgbotapi.utils.RiskFeature | ||||
| import dev.inmo.tgbotapi.utils.internal.* | ||||
| import kotlinx.serialization.Serializable | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity.textsources | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.* | ||||
| import dev.inmo.tgbotapi.utils.RiskFeature | ||||
| import dev.inmo.tgbotapi.utils.internal.* | ||||
| import kotlinx.serialization.Serializable | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity.textsources | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.* | ||||
| import dev.inmo.tgbotapi.utils.RiskFeature | ||||
| import dev.inmo.tgbotapi.utils.internal.* | ||||
| import kotlinx.serialization.Serializable | ||||
|   | ||||
| @@ -1,7 +1,6 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity.textsources | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.DirectInvocationOfTextSourceConstructor | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.utils.RiskFeature | ||||
| import dev.inmo.tgbotapi.utils.internal.* | ||||
| import kotlinx.serialization.Serializable | ||||
|   | ||||
| @@ -1,7 +1,6 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity.textsources | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.DirectInvocationOfTextSourceConstructor | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.utils.RiskFeature | ||||
| import dev.inmo.tgbotapi.utils.internal.* | ||||
| import kotlinx.serialization.Serializable | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity.textsources | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.* | ||||
| import dev.inmo.tgbotapi.utils.RiskFeature | ||||
| import dev.inmo.tgbotapi.utils.internal.* | ||||
| import kotlinx.serialization.Serializable | ||||
| @@ -23,4 +22,4 @@ inline fun strikethrough(parts: List<TextSource>) = StrikethroughTextSource(part | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun strikethrough(vararg parts: TextSource) = strikethrough(parts.toList()) | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun strikethrough(text: String) = strikethrough(regular(text)) | ||||
| inline fun strikethrough(text: String) = strikethrough(regular(text)) | ||||
|   | ||||
| @@ -1,7 +1,6 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity.textsources | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.DirectInvocationOfTextSourceConstructor | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.utils.RiskFeature | ||||
| import dev.inmo.tgbotapi.utils.internal.* | ||||
| import kotlinx.serialization.Serializable | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity.textsources | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.* | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.utils.RiskFeature | ||||
| import dev.inmo.tgbotapi.utils.internal.* | ||||
|   | ||||
| @@ -0,0 +1,88 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity.textsources | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.captionLength | ||||
| import dev.inmo.tgbotapi.types.textLength | ||||
| import kotlinx.serialization.Serializable | ||||
|  | ||||
| const val DirectInvocationOfTextSourceConstructor = "It is strongly not recommended to use constructors directly instead of factory methods" | ||||
|  | ||||
| typealias TextSourcesList = List<TextSource> | ||||
|  | ||||
| @Serializable(TextSourceSerializer::class) | ||||
| sealed interface TextSource { | ||||
|     val markdown: String | ||||
|     val markdownV2: String | ||||
|     val html: String | ||||
|     val source: String | ||||
|  | ||||
|     val asText: String | ||||
|         get() = source | ||||
|  | ||||
|     companion object { | ||||
|         fun serializer() = TextSourceSerializer | ||||
|     } | ||||
| } | ||||
|  | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline operator fun TextSource.plus(other: TextSource) = listOf(this, other) | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline operator fun TextSource.plus(other: List<TextSource>) = listOf(this) + other | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline operator fun TextSource.plus(text: String) = listOf(this, regular(text)) | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline operator fun List<TextSource>.plus(text: String) = this + regular(text) | ||||
|  | ||||
| @Serializable(TextSourceSerializer::class) | ||||
| sealed interface MultilevelTextSource : TextSource { | ||||
|     val subsources: List<TextSource> | ||||
|  | ||||
|     companion object { | ||||
|         fun serializer() = TextSourceSerializer | ||||
|     } | ||||
| } | ||||
|  | ||||
| fun List<TextSource>.makeString() = joinToString("") { it.source } | ||||
| fun List<TextSource>.separateForMessage(limit: IntRange, numberOfParts: Int? = null): List<List<TextSource>> { | ||||
|     if (isEmpty()) { | ||||
|         return emptyList() | ||||
|     } | ||||
|  | ||||
|     val resultList = mutableListOf<MutableList<TextSource>>(mutableListOf()) | ||||
|     var currentPartLength = 0 | ||||
|     val maxSize = limit.last + 1 | ||||
|  | ||||
|     for (current in this) { | ||||
|         if (current.source.length > maxSize) { | ||||
|             error("Currently unsupported parts with size more than target one-message parts (${current.source.length} > ${maxSize})") | ||||
|         } | ||||
|  | ||||
|         if (currentPartLength + current.source.length > maxSize) { | ||||
|             if (numberOfParts == null || numberOfParts < resultList.size) { | ||||
|                 resultList.add(mutableListOf()) | ||||
|                 currentPartLength = 0 | ||||
|             } else { | ||||
|                 break | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         resultList.last().add(current) | ||||
|         currentPartLength += current.source.length | ||||
|     } | ||||
|  | ||||
|     return resultList | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * This method will prepare [TextSource]s list for messages. Remember, that first part will be separated with | ||||
|  * [captionLength] and all others with | ||||
|  */ | ||||
| fun List<TextSource>.separateForCaption(): List<List<TextSource>> { | ||||
|     val captionPart = separateForMessage(captionLength, 1).first() | ||||
|     return listOf(captionPart) + minus(captionPart).separateForMessage(textLength) | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * This method will prepare [TextSource]s list for messages with [textLength] | ||||
|  */ | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun List<TextSource>.separateForText(): List<List<TextSource>> = separateForMessage(textLength) | ||||
| @@ -1,14 +1,7 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity.textsources | ||||
|  | ||||
| import dev.inmo.micro_utils.serialization.typed_serializer.TypedSerializer | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.RawMessageEntity | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.asTextSources | ||||
| import kotlinx.serialization.KSerializer | ||||
| import kotlinx.serialization.Serializer | ||||
| import kotlinx.serialization.builtins.ListSerializer | ||||
| import kotlinx.serialization.descriptors.SerialDescriptor | ||||
| import kotlinx.serialization.encoding.Decoder | ||||
|  | ||||
| private val baseSerializers: Map<String, KSerializer<out TextSource>> = mapOf( | ||||
|     "regular" to RegularTextSource.serializer(), | ||||
|   | ||||
| @@ -1,7 +1,6 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity.textsources | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.DirectInvocationOfTextSourceConstructor | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.utils.RiskFeature | ||||
| import dev.inmo.tgbotapi.utils.internal.* | ||||
| import kotlinx.serialization.Serializable | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity.textsources | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.* | ||||
| import dev.inmo.tgbotapi.utils.RiskFeature | ||||
| import dev.inmo.tgbotapi.utils.internal.* | ||||
| import kotlinx.serialization.Serializable | ||||
| @@ -23,4 +22,4 @@ inline fun underline(parts: List<TextSource>) = UnderlineTextSource(parts.makeSt | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun underline(vararg parts: TextSource) = underline(parts.toList()) | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun underline(text: String) = underline(regular(text)) | ||||
| inline fun underline(text: String) = underline(regular(text)) | ||||
|   | ||||
| @@ -1,31 +1,33 @@ | ||||
| package dev.inmo.tgbotapi.types.ParseMode | ||||
|  | ||||
| import kotlinx.serialization.* | ||||
| import kotlinx.serialization.builtins.serializer | ||||
| import kotlinx.serialization.descriptors.SerialDescriptor | ||||
| import kotlinx.serialization.encoding.Decoder | ||||
| import kotlinx.serialization.encoding.Encoder | ||||
|  | ||||
| internal const val parseModeField = "parse_mode" | ||||
|  | ||||
| @Serializable(ParseModeSerializerObject::class) | ||||
| sealed class ParseMode { | ||||
|     abstract val parseModeName: String | ||||
| sealed interface ParseMode { | ||||
|     val parseModeName: String | ||||
| } | ||||
|  | ||||
| @Serializable(ParseModeSerializerObject::class) | ||||
| object MarkdownParseMode : ParseMode() { | ||||
| object MarkdownParseMode : ParseMode { | ||||
|     @Serializable | ||||
|     @SerialName(parseModeField) | ||||
|     override val parseModeName: String = "Markdown" | ||||
| } | ||||
|  | ||||
| @Serializable(ParseModeSerializerObject::class) | ||||
| object MarkdownV2ParseMode : ParseMode() { | ||||
| object MarkdownV2ParseMode : ParseMode { | ||||
|     @Serializable | ||||
|     @SerialName(parseModeField) | ||||
|     override val parseModeName: String = "MarkdownV2" | ||||
| } | ||||
| @Serializable(ParseModeSerializerObject::class) | ||||
| object HTMLParseMode : ParseMode() { | ||||
| object HTMLParseMode : ParseMode { | ||||
|     @Serializable | ||||
|     @SerialName(parseModeField) | ||||
|     override val parseModeName: String = "HTML" | ||||
| @@ -45,6 +47,7 @@ var defaultParseMode: ParseMode = HTML | ||||
|  | ||||
| @Serializer(ParseMode::class) | ||||
| internal object ParseModeSerializerObject : KSerializer<ParseMode> { | ||||
|     override val descriptor: SerialDescriptor = String.serializer().descriptor | ||||
|     override fun deserialize(decoder: Decoder): ParseMode { | ||||
|         return when (decoder.decodeString()) { | ||||
|             Markdown.parseModeName -> Markdown | ||||
|   | ||||
| @@ -1,12 +0,0 @@ | ||||
| package dev.inmo.tgbotapi.types.buttons | ||||
|  | ||||
| import kotlinx.serialization.SerialName | ||||
| import kotlinx.serialization.Serializable | ||||
|  | ||||
| @Serializable | ||||
| data class ForceReply( | ||||
|     val selective: Boolean? = null | ||||
| ) : KeyboardMarkup { | ||||
|     @SerialName("force_reply") | ||||
|     val forceReply: Boolean = true | ||||
| } | ||||
| @@ -3,30 +3,31 @@ package dev.inmo.tgbotapi.types.buttons | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.utils.nonstrictJsonFormat | ||||
| import kotlinx.serialization.* | ||||
| import kotlinx.serialization.descriptors.SerialDescriptor | ||||
| import kotlinx.serialization.encoding.Decoder | ||||
| import kotlinx.serialization.encoding.Encoder | ||||
| import kotlinx.serialization.json.* | ||||
|  | ||||
| @Serializable(KeyboardButtonSerializer::class) | ||||
| sealed class KeyboardButton { | ||||
|     abstract val text: String | ||||
| sealed interface KeyboardButton { | ||||
|     val text: String | ||||
| } | ||||
|  | ||||
| @Serializable | ||||
| data class SimpleKeyboardButton( | ||||
|     override val text: String | ||||
| ) : KeyboardButton() | ||||
| ) : KeyboardButton | ||||
|  | ||||
| @Serializable | ||||
| data class UnknownKeyboardButton internal constructor( | ||||
|     override val text: String, | ||||
|     val raw: String | ||||
| ) : KeyboardButton() | ||||
| ) : KeyboardButton | ||||
|  | ||||
| @Serializable | ||||
| data class RequestContactKeyboardButton( | ||||
|     override val text: String | ||||
| ) : KeyboardButton() { | ||||
| ) : KeyboardButton { | ||||
|     @SerialName(requestContactField) | ||||
|     val requestContact: Boolean = true | ||||
| } | ||||
| @@ -34,7 +35,7 @@ data class RequestContactKeyboardButton( | ||||
| @Serializable | ||||
| data class RequestLocationKeyboardButton( | ||||
|     override val text: String | ||||
| ) : KeyboardButton() { | ||||
| ) : KeyboardButton { | ||||
|     @SerialName(requestLocationField) | ||||
|     val requestLocation: Boolean = true | ||||
| } | ||||
| @@ -44,12 +45,15 @@ data class RequestPollKeyboardButton( | ||||
|     override val text: String, | ||||
|     @SerialName(requestPollField) | ||||
|     val requestPoll: KeyboardButtonPollType | ||||
| ) : KeyboardButton() | ||||
| ) : KeyboardButton | ||||
|  | ||||
| @Serializer(KeyboardButton::class) | ||||
| internal object KeyboardButtonSerializer : KSerializer<KeyboardButton> { | ||||
|     private val internalSerializer = JsonElement.serializer() | ||||
|     override val descriptor: SerialDescriptor = internalSerializer.descriptor | ||||
|  | ||||
|     override fun deserialize(decoder: Decoder): KeyboardButton { | ||||
|         val asJson = JsonElement.serializer().deserialize(decoder) | ||||
|         val asJson = internalSerializer.deserialize(decoder) | ||||
|  | ||||
|         return when { | ||||
|             asJson is JsonPrimitive -> SimpleKeyboardButton(asJson.content) | ||||
| @@ -62,7 +66,7 @@ internal object KeyboardButtonSerializer : KSerializer<KeyboardButton> { | ||||
|             asJson is JsonObject && asJson[requestPollField] != null -> RequestPollKeyboardButton( | ||||
|                 asJson[textField]!!.jsonPrimitive.content, | ||||
|                 nonstrictJsonFormat.decodeFromJsonElement( | ||||
|                     KeyboardButtonPollType.serializer(), | ||||
|                     KeyboardButtonPollTypeSerializer, | ||||
|                     asJson[requestPollField] ?.jsonObject ?: buildJsonObject {  } | ||||
|                 ) | ||||
|             ) | ||||
|   | ||||
| @@ -2,34 +2,36 @@ package dev.inmo.tgbotapi.types.buttons | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import kotlinx.serialization.* | ||||
| import kotlinx.serialization.descriptors.SerialDescriptor | ||||
| import kotlinx.serialization.encoding.Decoder | ||||
| import kotlinx.serialization.encoding.Encoder | ||||
| import kotlinx.serialization.json.* | ||||
|  | ||||
| @Serializable(KeyboardButtonPollTypeSerializer::class) | ||||
| sealed class KeyboardButtonPollType { | ||||
|     abstract val type: String | ||||
| sealed interface KeyboardButtonPollType { | ||||
|     val type: String | ||||
| } | ||||
|  | ||||
| @Serializable | ||||
| class UnknownKeyboardButtonPollType internal constructor(override val type: String): KeyboardButtonPollType() | ||||
| class UnknownKeyboardButtonPollType internal constructor(override val type: String): KeyboardButtonPollType | ||||
|  | ||||
| @Serializable | ||||
| object RegularKeyboardButtonPollType : KeyboardButtonPollType() { | ||||
| object RegularKeyboardButtonPollType : KeyboardButtonPollType { | ||||
|     override val type: String = regularPollType | ||||
| } | ||||
|  | ||||
| @Serializable | ||||
| object QuizKeyboardButtonPollType : KeyboardButtonPollType() { | ||||
| object QuizKeyboardButtonPollType : KeyboardButtonPollType { | ||||
|     override val type: String = quizPollType | ||||
| } | ||||
|  | ||||
| @Serializer(KeyboardButtonPollType::class) | ||||
| internal object KeyboardButtonPollTypeSerializer : KSerializer<KeyboardButtonPollType> { | ||||
|     override fun deserialize(decoder: Decoder): KeyboardButtonPollType { | ||||
|         val asJson = JsonElement.serializer().deserialize(decoder) | ||||
|     private val internalSerializer = JsonElement.serializer() | ||||
|     override val descriptor: SerialDescriptor = internalSerializer.descriptor | ||||
|  | ||||
|         val type = when (asJson) { | ||||
|     override fun deserialize(decoder: Decoder): KeyboardButtonPollType { | ||||
|         val type = when (val asJson = internalSerializer.deserialize(decoder)) { | ||||
|             is JsonPrimitive -> asJson.content | ||||
|             else -> asJson.jsonObject[typeField] ?.jsonPrimitive ?.content ?: "absent" | ||||
|         } | ||||
| @@ -45,7 +47,7 @@ internal object KeyboardButtonPollTypeSerializer : KSerializer<KeyboardButtonPol | ||||
|      * Crutch due to the fact that direct serialization of objects currently does not work perfectly | ||||
|      */ | ||||
|     override fun serialize(encoder: Encoder, value: KeyboardButtonPollType) { | ||||
|         JsonObject.serializer().serialize( | ||||
|         internalSerializer.serialize( | ||||
|             encoder, | ||||
|             JsonObject( | ||||
|                 mapOf( | ||||
|   | ||||
| @@ -3,4 +3,4 @@ package dev.inmo.tgbotapi.types.buttons | ||||
| import kotlinx.serialization.Serializable | ||||
|  | ||||
| @Serializable(KeyboardMarkupSerializer::class) | ||||
| interface KeyboardMarkup | ||||
| sealed interface KeyboardMarkup | ||||
|   | ||||
| @@ -14,7 +14,7 @@ internal object KeyboardMarkupSerializer : KSerializer<KeyboardMarkup> { | ||||
|     ) | ||||
|     override fun serialize(encoder: Encoder, value: KeyboardMarkup) { | ||||
|         when(value) { | ||||
|             is ForceReply -> ForceReply.serializer().serialize(encoder, value) | ||||
|             is ReplyForce -> ReplyForce.serializer().serialize(encoder, value) | ||||
|             is InlineKeyboardMarkup -> InlineKeyboardMarkup.serializer().serialize(encoder, value) | ||||
|             is ReplyKeyboardMarkup -> ReplyKeyboardMarkup.serializer().serialize(encoder, value) | ||||
|             is ReplyKeyboardRemove -> ReplyKeyboardRemove.serializer().serialize(encoder, value) | ||||
|   | ||||
| @@ -0,0 +1,21 @@ | ||||
| package dev.inmo.tgbotapi.types.buttons | ||||
|  | ||||
| import kotlinx.serialization.* | ||||
|  | ||||
| @Serializable | ||||
| data class ReplyForce( | ||||
|     val selective: Boolean? = null | ||||
| ) : KeyboardMarkup { | ||||
|     @SerialName("force_reply") | ||||
|     @Required | ||||
|     val forceReply: Boolean = true | ||||
|  | ||||
|     companion object { | ||||
|         val ReplyForceSelective = ReplyForce(true) | ||||
|         val ReplyForceNonSelective = ReplyForce(false) | ||||
|         val ReplyForceDefault = ReplyForce() | ||||
|     } | ||||
| } | ||||
|  | ||||
| @Deprecated("Renamed", ReplaceWith("ReplyForce", "dev.inmo.tgbotapi.types.buttons.ReplyForce")) | ||||
| typealias ForceReply = ReplyForce | ||||
| @@ -1,12 +1,12 @@ | ||||
| package dev.inmo.tgbotapi.types.buttons | ||||
|  | ||||
| import kotlinx.serialization.SerialName | ||||
| import kotlinx.serialization.Serializable | ||||
| import kotlinx.serialization.* | ||||
|  | ||||
| @Serializable | ||||
| data class ReplyKeyboardRemove( | ||||
|     val selective: Boolean? = null | ||||
| ) : KeyboardMarkup { | ||||
|     @SerialName("remove_keyboard") | ||||
|     @Required | ||||
|     val removeKeyboard: Boolean = true | ||||
| } | ||||
|   | ||||
| @@ -7,42 +7,42 @@ import kotlinx.serialization.encoding.Decoder | ||||
| import kotlinx.serialization.encoding.Encoder | ||||
|  | ||||
| @Serializable(DiceAnimationTypeSerializer::class) | ||||
| sealed class DiceAnimationType { | ||||
|     abstract val emoji: String | ||||
|     abstract val valueLimits: IntRange | ||||
| sealed interface DiceAnimationType { | ||||
|     val emoji: String | ||||
|     val valueLimits: IntRange | ||||
| } | ||||
| @Serializable(DiceAnimationTypeSerializer::class) | ||||
| object CubeDiceAnimationType : DiceAnimationType() { | ||||
| object CubeDiceAnimationType : DiceAnimationType { | ||||
|     override val emoji: String = "\uD83C\uDFB2" | ||||
|     override val valueLimits: IntRange | ||||
|         get() = dartsCubeAndBowlingDiceResultLimit | ||||
| } | ||||
| @Serializable(DiceAnimationTypeSerializer::class) | ||||
| object DartsDiceAnimationType : DiceAnimationType() { | ||||
| object DartsDiceAnimationType : DiceAnimationType { | ||||
|     override val emoji: String = "\uD83C\uDFAF" | ||||
|     override val valueLimits: IntRange | ||||
|         get() = dartsCubeAndBowlingDiceResultLimit | ||||
| } | ||||
| @Serializable(DiceAnimationTypeSerializer::class) | ||||
| object BasketballDiceAnimationType : DiceAnimationType() { | ||||
| object BasketballDiceAnimationType : DiceAnimationType { | ||||
|     override val emoji: String = "\uD83C\uDFC0" | ||||
|     override val valueLimits: IntRange | ||||
|         get() = basketballAndFootballDiceResultLimit | ||||
| } | ||||
| @Serializable(DiceAnimationTypeSerializer::class) | ||||
| object FootballDiceAnimationType : DiceAnimationType() { | ||||
| object FootballDiceAnimationType : DiceAnimationType { | ||||
|     override val emoji: String = "⚽" | ||||
|     override val valueLimits: IntRange | ||||
|         get() = basketballAndFootballDiceResultLimit | ||||
| } | ||||
| @Serializable(DiceAnimationTypeSerializer::class) | ||||
| object BowlingDiceAnimationType : DiceAnimationType() { | ||||
| object BowlingDiceAnimationType : DiceAnimationType { | ||||
|     override val emoji: String = "\uD83C\uDFB3" | ||||
|     override val valueLimits: IntRange | ||||
|         get() = dartsCubeAndBowlingDiceResultLimit | ||||
| } | ||||
| @Serializable(DiceAnimationTypeSerializer::class) | ||||
| object SlotMachineDiceAnimationType : DiceAnimationType() { | ||||
| object SlotMachineDiceAnimationType : DiceAnimationType { | ||||
|     override val emoji: String = "\uD83C\uDFB0" | ||||
|     override val valueLimits: IntRange | ||||
|         get() = slotMachineDiceResultLimit | ||||
| @@ -50,7 +50,7 @@ object SlotMachineDiceAnimationType : DiceAnimationType() { | ||||
| @Serializable(DiceAnimationTypeSerializer::class) | ||||
| data class CustomDiceAnimationType( | ||||
|     override val emoji: String | ||||
| ) : DiceAnimationType() { | ||||
| ) : DiceAnimationType { | ||||
|     override val valueLimits: IntRange | ||||
|         get() = error("Custom dice animation type have unknown value limits") | ||||
| } | ||||
|   | ||||
| @@ -4,13 +4,14 @@ import dev.inmo.tgbotapi.CommonAbstracts.* | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.utils.nonstrictJsonFormat | ||||
| import kotlinx.serialization.* | ||||
| import kotlinx.serialization.descriptors.SerialDescriptor | ||||
| import kotlinx.serialization.encoding.Decoder | ||||
| import kotlinx.serialization.encoding.Encoder | ||||
| import kotlinx.serialization.json.JsonNull | ||||
| import kotlinx.serialization.json.JsonObject | ||||
|  | ||||
| @Serializable(LocationSerializer::class) | ||||
| sealed class Location : Locationed, HorizontallyAccured | ||||
| sealed interface Location : Locationed, HorizontallyAccured | ||||
|  | ||||
| @Serializable | ||||
| data class StaticLocation( | ||||
| @@ -20,7 +21,7 @@ data class StaticLocation( | ||||
|     override val latitude: Double, | ||||
|     @SerialName(horizontalAccuracyField) | ||||
|     override val horizontalAccuracy: Meters? = null | ||||
| ) : Location() | ||||
| ) : Location | ||||
|  | ||||
| @Serializable | ||||
| data class LiveLocation( | ||||
| @@ -36,11 +37,13 @@ data class LiveLocation( | ||||
|     override val heading: Degrees? = null, | ||||
|     @SerialName(proximityAlertRadiusField) | ||||
|     override val proximityAlertRadius: Meters? = null | ||||
| ) : Location(), Livable, ProximityAlertable, Headed | ||||
| ) : Location, Livable, ProximityAlertable, Headed | ||||
|  | ||||
| @Serializer(Location::class) | ||||
| object LocationSerializer : KSerializer<Location> { | ||||
|     override fun deserialize(decoder: Decoder): Location = JsonObject.serializer().deserialize(decoder).let { | ||||
|     private val internalSerializer = JsonObject.serializer() | ||||
|     override val descriptor: SerialDescriptor = internalSerializer.descriptor | ||||
|     override fun deserialize(decoder: Decoder): Location = internalSerializer.deserialize(decoder).let { | ||||
|         if (it.containsKey(livePeriodField) && it[livePeriodField] != JsonNull) { | ||||
|             nonstrictJsonFormat.decodeFromJsonElement(LiveLocation.serializer(), it) | ||||
|         } else { | ||||
|   | ||||
| @@ -2,10 +2,10 @@ package dev.inmo.tgbotapi.types.polls | ||||
|  | ||||
| import com.soywiz.klock.DateTime | ||||
| import com.soywiz.klock.TimeSpan | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.ExplainedInput | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.* | ||||
| import dev.inmo.tgbotapi.types.* | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.* | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource | ||||
| import dev.inmo.tgbotapi.utils.nonstrictJsonFormat | ||||
| import kotlinx.serialization.* | ||||
| import kotlinx.serialization.descriptors.SerialDescriptor | ||||
| @@ -13,19 +13,19 @@ import kotlinx.serialization.encoding.Decoder | ||||
| import kotlinx.serialization.encoding.Encoder | ||||
| import kotlinx.serialization.json.* | ||||
|  | ||||
| sealed class ScheduledCloseInfo { | ||||
|     abstract val closeDateTime: DateTime | ||||
| sealed interface ScheduledCloseInfo { | ||||
|     val closeDateTime: DateTime | ||||
| } | ||||
|  | ||||
| data class ExactScheduledCloseInfo( | ||||
|     override val closeDateTime: DateTime | ||||
| ) : ScheduledCloseInfo() | ||||
| ) : ScheduledCloseInfo | ||||
|  | ||||
| data class ApproximateScheduledCloseInfo( | ||||
|     val openDuration: TimeSpan, | ||||
|     @Suppress("MemberVisibilityCanBePrivate") | ||||
|     val startPoint: DateTime = DateTime.now() | ||||
| ) : ScheduledCloseInfo() { | ||||
| ) : ScheduledCloseInfo { | ||||
|     override val closeDateTime: DateTime = startPoint + openDuration | ||||
| } | ||||
|  | ||||
| @@ -42,18 +42,18 @@ val LongSeconds.asExactScheduledCloseInfo | ||||
|     ) | ||||
|  | ||||
| @Serializable(PollSerializer::class) | ||||
| sealed class Poll { | ||||
|     abstract val id: PollIdentifier | ||||
|     abstract val question: String | ||||
|     abstract val options: List<PollOption> | ||||
|     abstract val votesCount: Int | ||||
|     abstract val isClosed: Boolean | ||||
|     abstract val isAnonymous: Boolean | ||||
|     abstract val scheduledCloseInfo: ScheduledCloseInfo? | ||||
| sealed interface Poll { | ||||
|     val id: PollIdentifier | ||||
|     val question: String | ||||
|     val options: List<PollOption> | ||||
|     val votesCount: Int | ||||
|     val isClosed: Boolean | ||||
|     val isAnonymous: Boolean | ||||
|     val scheduledCloseInfo: ScheduledCloseInfo? | ||||
| } | ||||
|  | ||||
| @Serializable(PollSerializer::class) | ||||
| sealed class MultipleAnswersPoll : Poll() | ||||
| sealed interface MultipleAnswersPoll : Poll | ||||
|  | ||||
| @Serializable | ||||
| private class RawPoll( | ||||
| @@ -105,7 +105,7 @@ data class UnknownPollType internal constructor( | ||||
|     override val isAnonymous: Boolean = false, | ||||
|     @Serializable | ||||
|     val raw: JsonObject | ||||
| ) : Poll() { | ||||
| ) : Poll { | ||||
|     @Transient | ||||
|     override val scheduledCloseInfo: ScheduledCloseInfo? = (raw[closeDateField] ?: raw[openPeriodField]) | ||||
|         ?.jsonPrimitive | ||||
| @@ -123,7 +123,7 @@ data class RegularPoll( | ||||
|     override val isAnonymous: Boolean = false, | ||||
|     val allowMultipleAnswers: Boolean = false, | ||||
|     override val scheduledCloseInfo: ScheduledCloseInfo? = null | ||||
| ) : MultipleAnswersPoll() | ||||
| ) : MultipleAnswersPoll | ||||
|  | ||||
| @Serializable(PollSerializer::class) | ||||
| data class QuizPoll( | ||||
| @@ -140,7 +140,7 @@ data class QuizPoll( | ||||
|     override val isClosed: Boolean = false, | ||||
|     override val isAnonymous: Boolean = false, | ||||
|     override val scheduledCloseInfo: ScheduledCloseInfo? = null | ||||
| ) : Poll(), ExplainedInput | ||||
| ) : Poll, TextedInput | ||||
|  | ||||
| @Serializer(Poll::class) | ||||
| internal object PollSerializer : KSerializer<Poll> { | ||||
|   | ||||
| @@ -1,17 +1,16 @@ | ||||
| package dev.inmo.tgbotapi.utils.internal | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.MultilevelTextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.types.UserId | ||||
| import dev.inmo.tgbotapi.types.link | ||||
| import dev.inmo.tgbotapi.utils.extensions.escapeMarkdownV2Link | ||||
| import dev.inmo.tgbotapi.utils.extensions.toHtml | ||||
|  | ||||
| private fun List<TextSource>.joinSubSourcesMarkdownV2() = joinToString("") { | ||||
| private fun List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>.joinSubSourcesMarkdownV2() = joinToString("") { | ||||
|     it.markdownV2 | ||||
| } | ||||
|  | ||||
| private fun List<TextSource>.joinSubSourcesHtml() = joinToString("") { | ||||
| private fun List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>.joinSubSourcesHtml() = joinToString("") { | ||||
|     it.html | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.* | ||||
| import kotlin.test.assertTrue | ||||
|  | ||||
| @@ -40,7 +39,7 @@ internal val testTextEntities = listOf( | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| fun List<TextSource>.testTextSources() { | ||||
| fun List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>.testTextSources() { | ||||
|     assertTrue (first() is RegularTextSource) | ||||
|     assertTrue (get(1) is BoldTextSource) | ||||
|     assertTrue (get(2) is RegularTextSource) | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types.MessageEntity | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.plus | ||||
| import dev.inmo.tgbotapi.extensions.utils.formatting.* | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.* | ||||
| @@ -40,7 +39,7 @@ class StringFormattingTests { | ||||
|  | ||||
|     @Test | ||||
|     fun testThatCreatingOfStringWithSimpleDSLWorksCorrectly() { | ||||
|         val sources: List<TextSource> = regular("It ") + | ||||
|         val sources: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource> = regular("It ") + | ||||
|             bold(italic("is") + | ||||
|                 " " + | ||||
|                 strikethrough(underline("simple"))) + | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.types | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.makeString | ||||
| import dev.inmo.tgbotapi.TestsJsonFormat | ||||
| import dev.inmo.tgbotapi.extensions.utils.formatting.* | ||||
| @@ -34,4 +33,4 @@ class TextSourcesTests { | ||||
|         assertEquals(testList, deserialized) | ||||
|         assertEquals(testList.makeString(), deserialized.makeString()) | ||||
|     } | ||||
| } | ||||
| } | ||||
|   | ||||
| @@ -4,6 +4,7 @@ import dev.inmo.tgbotapi.CommonAbstracts.* | ||||
| import dev.inmo.tgbotapi.bot.TelegramBot | ||||
| import dev.inmo.tgbotapi.requests.edit.caption.EditChatMessageCaption | ||||
| import dev.inmo.tgbotapi.types.ChatIdentifier | ||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource | ||||
| import dev.inmo.tgbotapi.types.MessageIdentifier | ||||
| import dev.inmo.tgbotapi.types.ParseMode.ParseMode | ||||
| import dev.inmo.tgbotapi.types.buttons.InlineKeyboardMarkup | ||||
| @@ -41,7 +42,7 @@ suspend fun <T> TelegramBot.editMessageCaption( | ||||
| suspend fun TelegramBot.editMessageCaption( | ||||
|     chatId: ChatIdentifier, | ||||
|     messageId: MessageIdentifier, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     EditChatMessageCaption(chatId, messageId, entities, replyMarkup) | ||||
| @@ -50,7 +51,7 @@ suspend fun TelegramBot.editMessageCaption( | ||||
| suspend fun TelegramBot.editMessageCaption( | ||||
|     chat: Chat, | ||||
|     messageId: MessageIdentifier, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = editMessageCaption(chat.id, messageId, entities, replyMarkup) | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.extensions.api.edit.caption | ||||
|  | ||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||
| import dev.inmo.tgbotapi.bot.TelegramBot | ||||
| import dev.inmo.tgbotapi.requests.edit.caption.EditInlineMessageCaption | ||||
| import dev.inmo.tgbotapi.types.InlineMessageIdentifier | ||||
| @@ -16,6 +15,6 @@ suspend fun TelegramBot.editMessageCaption( | ||||
|  | ||||
| suspend fun TelegramBot.editMessageCaption( | ||||
|     inlineMessageId: InlineMessageIdentifier, | ||||
|     entities: List<TextSource>, | ||||
|     entities: List<dev.inmo.tgbotapi.types.MessageEntity.textsources.TextSource>, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = execute(EditInlineMessageCaption(inlineMessageId, entities, replyMarkup)) | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user