package dev.inmo.tgbotapi.requests.send.media import dev.inmo.tgbotapi.requests.abstracts.* 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.message.textsources.TextSourcesList import dev.inmo.tgbotapi.types.message.ParseMode import dev.inmo.tgbotapi.types.message.parseModeField import dev.inmo.tgbotapi.types.buttons.KeyboardMarkup import dev.inmo.tgbotapi.types.message.* import dev.inmo.tgbotapi.types.message.RawMessageEntity import dev.inmo.tgbotapi.types.message.abstracts.ContentMessage import dev.inmo.tgbotapi.types.message.abstracts.TelegramBotAPIMessageDeserializationStrategyClass import dev.inmo.tgbotapi.types.message.content.AnimationContent import dev.inmo.tgbotapi.types.message.toRawMessageEntities import dev.inmo.tgbotapi.utils.extensions.makeString import dev.inmo.tgbotapi.utils.mapOfNotNull import dev.inmo.tgbotapi.utils.throwRangeError import kotlinx.serialization.* fun SendAnimation( chatId: ChatIdentifier, animation: InputFile, thumb: InputFile? = null, text: String? = null, parseMode: ParseMode? = null, duration: Long? = null, width: Int? = null, height: Int? = null, disableNotification: Boolean = false, protectContent: Boolean = false, replyToMessageId: MessageId? = null, allowSendingWithoutReply: Boolean? = null, replyMarkup: KeyboardMarkup? = null ): Request> { val animationAsFileId = (animation as? FileId) ?.fileId val animationAsFile = animation as? MultipartFile val thumbAsFileId = (thumb as? FileId) ?.fileId val thumbAsFile = thumb as? MultipartFile val data = SendAnimationData( chatId, animationAsFileId, thumbAsFileId, text, parseMode, null, duration, width, height, disableNotification, protectContent, replyToMessageId, allowSendingWithoutReply, replyMarkup ) return if (animationAsFile == null && thumbAsFile == null) { data } else { MultipartRequestImpl( data, SendAnimationFiles(animationAsFile, thumbAsFile) ) } } fun SendAnimation( chatId: ChatIdentifier, animation: InputFile, thumb: InputFile? = null, entities: TextSourcesList, duration: Long? = null, width: Int? = null, height: Int? = null, disableNotification: Boolean = false, protectContent: Boolean = false, replyToMessageId: MessageId? = null, allowSendingWithoutReply: Boolean? = null, replyMarkup: KeyboardMarkup? = null ): Request> { val animationAsFileId = (animation as? FileId) ?.fileId val animationAsFile = animation as? MultipartFile val thumbAsFileId = (thumb as? FileId) ?.fileId val thumbAsFile = thumb as? MultipartFile val data = SendAnimationData( chatId, animationAsFileId, thumbAsFileId, entities.makeString(), null, entities.toRawMessageEntities(), duration, width, height, disableNotification, protectContent, replyToMessageId, allowSendingWithoutReply, replyMarkup ) return if (animationAsFile == null && thumbAsFile == null) { data } else { MultipartRequestImpl( data, SendAnimationFiles(animationAsFile, thumbAsFile) ) } } private val commonResultDeserializer: DeserializationStrategy> = TelegramBotAPIMessageDeserializationStrategyClass() @Serializable data class SendAnimationData internal constructor( @SerialName(chatIdField) override val chatId: ChatIdentifier, @SerialName(animationField) val animation: String? = null, @SerialName(thumbField) override val thumb: String? = null, @SerialName(captionField) override val text: String? = null, @SerialName(parseModeField) override val parseMode: ParseMode? = null, @SerialName(captionEntitiesField) private val rawEntities: List? = null, @SerialName(durationField) override val duration: Long? = null, @SerialName(widthField) override val width: Int? = null, @SerialName(heightField) override val height: Int? = null, @SerialName(disableNotificationField) override val disableNotification: Boolean = false, @SerialName(protectContentField) override val protectContent: Boolean = false, @SerialName(replyToMessageIdField) override val replyToMessageId: MessageId? = null, @SerialName(allowSendingWithoutReplyField) override val allowSendingWithoutReply: Boolean? = null, @SerialName(replyMarkupField) override val replyMarkup: KeyboardMarkup? = null ) : DataRequest>, SendMessageRequest>, ReplyingMarkupSendMessageRequest>, TextableSendMessageRequest>, ThumbedSendMessageRequest>, DuratedSendMessageRequest>, SizedSendMessageRequest> { override val textSources: TextSourcesList? by lazy { rawEntities ?.asTextSources(text ?: return@lazy null) } init { text ?.let { if (it.length !in captionLength) { throwRangeError("Caption length", captionLength, it.length) } } } override fun method(): String = "sendAnimation" override val resultDeserializer: DeserializationStrategy> get() = commonResultDeserializer override val requestSerializer: SerializationStrategy<*> get() = serializer() } data class SendAnimationFiles internal constructor( val animation: MultipartFile? = null, val thumb: MultipartFile? = null ) : Files by mapOfNotNull( animationField to animation, thumbField to thumb )