mirror of
				https://github.com/InsanusMokrassar/TelegramBotAPI.git
				synced 2025-10-26 17:50:15 +00:00 
			
		
		
		
	
							
								
								
									
										26
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										26
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,5 +1,31 @@ | |||||||
| # TelegramBotAPI changelog | # TelegramBotAPI changelog | ||||||
|  |  | ||||||
|  | ## 0.30.4 | ||||||
|  |  | ||||||
|  | * `Common`: | ||||||
|  |     * `Version`: | ||||||
|  |         * `MicroUtils`: `0.3.1` -> `0.3.3` | ||||||
|  | * `Core`: | ||||||
|  |     * `MultilevelTextSource#textSources` has been safely renamed to `subsources` | ||||||
|  |     * `TextContent#fullEntitiesList` has been deprecated | ||||||
|  |     * Now `TextContent` implements `TextedInput` | ||||||
|  |         * `TextContent#entities` has been deprecated | ||||||
|  |     * `GroupEventMessage` now overrides `chatEvent` with type `GroupEvent` | ||||||
|  |     * `SupergroupEventMessage` now overrides `chatEvent` with type `SupergroupEvent` | ||||||
|  |     * Any `ChatEventMessage` now have generic type of its `chatEvent` (just like messages) | ||||||
|  | * `Utils`: | ||||||
|  |     * Old extensions related to chat events are deprecated: | ||||||
|  |         * `Flow<ChatEventMessage<*>>#divideBySource` | ||||||
|  |         * `Flow<ChatEventMessage<*>>#onlyChannelEvents` | ||||||
|  |         * `Flow<ChatEventMessage<*>>#onlyGroupEvents` | ||||||
|  |         * `Flow<ChatEventMessage<*>>#onlySupergroupEvents` | ||||||
|  |     * A lot of extensions for `Flow<ChatEventMessage>` has been added: | ||||||
|  |         * `FlowsUpdatesFilter#events` | ||||||
|  |         * `FlowsUpdatesFilter#channelEvents` | ||||||
|  |         * `FlowsUpdatesFilter#groupEvents` | ||||||
|  |         * `FlowsUpdatesFilter#supergroupEvents` | ||||||
|  |         * And a lot of other filters with specific types | ||||||
|  |  | ||||||
| ## 0.30.3 | ## 0.30.3 | ||||||
|  |  | ||||||
| * `Common`: | * `Common`: | ||||||
|   | |||||||
| @@ -12,12 +12,12 @@ klock_version=1.12.1 | |||||||
| uuid_version=0.2.2 | uuid_version=0.2.2 | ||||||
| ktor_version=1.4.2 | ktor_version=1.4.2 | ||||||
|  |  | ||||||
| micro_utils_version=0.3.1 | micro_utils_version=0.3.3 | ||||||
|  |  | ||||||
| javax_activation_version=1.1.1 | javax_activation_version=1.1.1 | ||||||
|  |  | ||||||
| library_group=dev.inmo | library_group=dev.inmo | ||||||
| library_version=0.30.3 | library_version=0.30.4 | ||||||
|  |  | ||||||
| gradle_bintray_plugin_version=1.8.5 | gradle_bintray_plugin_version=1.8.5 | ||||||
| github_release_plugin_version=2.2.12 | github_release_plugin_version=2.2.12 | ||||||
|   | |||||||
| @@ -36,7 +36,10 @@ interface MultilevelTextSource : TextSource { | |||||||
|     @Deprecated("Will be removed in near major release") |     @Deprecated("Will be removed in near major release") | ||||||
|     val textParts: List<TextPart> |     val textParts: List<TextPart> | ||||||
|         get() = textParts(0) |         get() = textParts(0) | ||||||
|  |     val subsources: List<TextSource> | ||||||
|  |     @Deprecated("Will be removed in near major release", ReplaceWith("subsources")) | ||||||
|     val textSources: List<TextSource> |     val textSources: List<TextSource> | ||||||
|  |         get() = subsources | ||||||
| } | } | ||||||
|  |  | ||||||
| data class TextPart( | data class TextPart( | ||||||
| @@ -46,7 +49,7 @@ data class TextPart( | |||||||
|  |  | ||||||
| fun List<TextPart>.justTextSources() = map { it.source } | fun List<TextPart>.justTextSources() = map { it.source } | ||||||
| fun List<TextSource>.makeString() = joinToString("") { it.source } | fun List<TextSource>.makeString() = joinToString("") { it.source } | ||||||
| internal fun MultilevelTextSource.textParts(offset: Int): List<TextPart> = textSources.toTextParts(offset) | internal fun MultilevelTextSource.textParts(offset: Int): List<TextPart> = subsources.toTextParts(offset) | ||||||
| fun List<TextSource>.separateForMessage(limit: IntRange, numberOfParts: Int? = null): List<List<TextSource>> { | fun List<TextSource>.separateForMessage(limit: IntRange, numberOfParts: Int? = null): List<List<TextSource>> { | ||||||
|     if (isEmpty()) { |     if (isEmpty()) { | ||||||
|         return emptyList() |         return emptyList() | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ import dev.inmo.tgbotapi.utils.internal.boldMarkdownV2 | |||||||
|  */ |  */ | ||||||
| data class BoldTextSource @RiskFeature(DirectInvocationOfTextSourceConstructor) constructor ( | data class BoldTextSource @RiskFeature(DirectInvocationOfTextSourceConstructor) constructor ( | ||||||
|     override val source: String, |     override val source: String, | ||||||
|     override val textSources: List<TextSource> |     override val subsources: List<TextSource> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|     override val asMarkdownSource: String by lazy { source.boldMarkdown() } |     override val asMarkdownSource: String by lazy { source.boldMarkdown() } | ||||||
|     override val asMarkdownV2Source: String by lazy { boldMarkdownV2() } |     override val asMarkdownV2Source: String by lazy { boldMarkdownV2() } | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ import dev.inmo.tgbotapi.utils.internal.cashTagMarkdownV2 | |||||||
|  */ |  */ | ||||||
| data class CashTagTextSource @RiskFeature(DirectInvocationOfTextSourceConstructor) constructor ( | data class CashTagTextSource @RiskFeature(DirectInvocationOfTextSourceConstructor) constructor ( | ||||||
|     override val source: String, |     override val source: String, | ||||||
|     override val textSources: List<TextSource> |     override val subsources: List<TextSource> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|     override val asMarkdownSource: String by lazy { source.cashTagMarkdown() } |     override val asMarkdownSource: String by lazy { source.cashTagMarkdown() } | ||||||
|     override val asMarkdownV2Source: String by lazy { cashTagMarkdownV2() } |     override val asMarkdownV2Source: String by lazy { cashTagMarkdownV2() } | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ import dev.inmo.tgbotapi.utils.internal.emailMarkdownV2 | |||||||
|  */ |  */ | ||||||
| data class EMailTextSource @RiskFeature(DirectInvocationOfTextSourceConstructor) constructor ( | data class EMailTextSource @RiskFeature(DirectInvocationOfTextSourceConstructor) constructor ( | ||||||
|     override val source: String, |     override val source: String, | ||||||
|     override val textSources: List<TextSource> |     override val subsources: List<TextSource> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|     override val asMarkdownSource: String by lazy { source.emailMarkdown() } |     override val asMarkdownSource: String by lazy { source.emailMarkdown() } | ||||||
|     override val asMarkdownV2Source: String by lazy { emailMarkdownV2(source) } |     override val asMarkdownV2Source: String by lazy { emailMarkdownV2(source) } | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ import dev.inmo.tgbotapi.utils.internal.hashTagMarkdownV2 | |||||||
|  */ |  */ | ||||||
| data class HashTagTextSource @RiskFeature(DirectInvocationOfTextSourceConstructor) constructor ( | data class HashTagTextSource @RiskFeature(DirectInvocationOfTextSourceConstructor) constructor ( | ||||||
|     override val source: String, |     override val source: String, | ||||||
|     override val textSources: List<TextSource> |     override val subsources: List<TextSource> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|     override val asMarkdownSource: String by lazy { source.hashTagMarkdown() } |     override val asMarkdownSource: String by lazy { source.hashTagMarkdown() } | ||||||
|     override val asMarkdownV2Source: String by lazy { hashTagMarkdownV2() } |     override val asMarkdownV2Source: String by lazy { hashTagMarkdownV2() } | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ import dev.inmo.tgbotapi.utils.internal.italicMarkdownV2 | |||||||
|  */ |  */ | ||||||
| data class ItalicTextSource @RiskFeature(DirectInvocationOfTextSourceConstructor) constructor ( | data class ItalicTextSource @RiskFeature(DirectInvocationOfTextSourceConstructor) constructor ( | ||||||
|     override val source: String, |     override val source: String, | ||||||
|     override val textSources: List<TextSource> |     override val subsources: List<TextSource> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|     override val asMarkdownSource: String by lazy { source.italicMarkdown() } |     override val asMarkdownSource: String by lazy { source.italicMarkdown() } | ||||||
|     override val asMarkdownV2Source: String by lazy { italicMarkdownV2() } |     override val asMarkdownV2Source: String by lazy { italicMarkdownV2() } | ||||||
|   | |||||||
| @@ -18,7 +18,7 @@ private val String.withoutCommercialAt | |||||||
|  */ |  */ | ||||||
| data class MentionTextSource @RiskFeature(DirectInvocationOfTextSourceConstructor) constructor ( | data class MentionTextSource @RiskFeature(DirectInvocationOfTextSourceConstructor) constructor ( | ||||||
|     override val source: String, |     override val source: String, | ||||||
|     override val textSources: List<TextSource> |     override val subsources: List<TextSource> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|     override val asMarkdownSource: String by lazy { source.mentionMarkdown() } |     override val asMarkdownSource: String by lazy { source.mentionMarkdown() } | ||||||
|     override val asMarkdownV2Source: String by lazy { mentionMarkdownV2() } |     override val asMarkdownV2Source: String by lazy { mentionMarkdownV2() } | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ import dev.inmo.tgbotapi.utils.internal.phoneMarkdownV2 | |||||||
|  */ |  */ | ||||||
| data class PhoneNumberTextSource @RiskFeature(DirectInvocationOfTextSourceConstructor) constructor ( | data class PhoneNumberTextSource @RiskFeature(DirectInvocationOfTextSourceConstructor) constructor ( | ||||||
|     override val source: String, |     override val source: String, | ||||||
|     override val textSources: List<TextSource> |     override val subsources: List<TextSource> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|     override val asMarkdownSource: String by lazy { source.phoneMarkdown() } |     override val asMarkdownSource: String by lazy { source.phoneMarkdown() } | ||||||
|     override val asMarkdownV2Source: String by lazy { phoneMarkdownV2() } |     override val asMarkdownV2Source: String by lazy { phoneMarkdownV2() } | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ import dev.inmo.tgbotapi.utils.internal.strikethroughMarkdownV2 | |||||||
|  */ |  */ | ||||||
| data class StrikethroughTextSource @RiskFeature(DirectInvocationOfTextSourceConstructor) constructor ( | data class StrikethroughTextSource @RiskFeature(DirectInvocationOfTextSourceConstructor) constructor ( | ||||||
|     override val source: String, |     override val source: String, | ||||||
|     override val textSources: List<TextSource> |     override val subsources: List<TextSource> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|     override val asHtmlSource: String by lazy { strikethroughHTML() } |     override val asHtmlSource: String by lazy { strikethroughHTML() } | ||||||
|     override val asMarkdownV2Source: String by lazy { strikethroughMarkdownV2() } |     override val asMarkdownV2Source: String by lazy { strikethroughMarkdownV2() } | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ import dev.inmo.tgbotapi.utils.internal.textMentionMarkdownV2 | |||||||
| data class TextMentionTextSource @RiskFeature(DirectInvocationOfTextSourceConstructor) constructor ( | data class TextMentionTextSource @RiskFeature(DirectInvocationOfTextSourceConstructor) constructor ( | ||||||
|     override val source: String, |     override val source: String, | ||||||
|     val user: User, |     val user: User, | ||||||
|     override val textSources: List<TextSource> |     override val subsources: List<TextSource> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|     override val asMarkdownSource: String by lazy { source.textMentionMarkdown(user.id) } |     override val asMarkdownSource: String by lazy { source.textMentionMarkdown(user.id) } | ||||||
|     override val asMarkdownV2Source: String by lazy { textMentionMarkdownV2(user.id) } |     override val asMarkdownV2Source: String by lazy { textMentionMarkdownV2(user.id) } | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ import dev.inmo.tgbotapi.utils.internal.underlineMarkdownV2 | |||||||
|  */ |  */ | ||||||
| data class UnderlineTextSource @RiskFeature(DirectInvocationOfTextSourceConstructor) constructor ( | data class UnderlineTextSource @RiskFeature(DirectInvocationOfTextSourceConstructor) constructor ( | ||||||
|     override val source: String, |     override val source: String, | ||||||
|     override val textSources: List<TextSource> |     override val subsources: List<TextSource> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|     override val asMarkdownSource: String by lazy { source.underlineMarkdown() } |     override val asMarkdownSource: String by lazy { source.underlineMarkdown() } | ||||||
|     override val asMarkdownV2Source: String by lazy { underlineMarkdownV2() } |     override val asMarkdownV2Source: String by lazy { underlineMarkdownV2() } | ||||||
|   | |||||||
| @@ -4,11 +4,12 @@ import com.soywiz.klock.DateTime | |||||||
| import dev.inmo.tgbotapi.types.MessageIdentifier | import dev.inmo.tgbotapi.types.MessageIdentifier | ||||||
| import dev.inmo.tgbotapi.types.chat.abstracts.ChannelChat | import dev.inmo.tgbotapi.types.chat.abstracts.ChannelChat | ||||||
| import dev.inmo.tgbotapi.types.message.ChatEvents.abstracts.ChannelEvent | import dev.inmo.tgbotapi.types.message.ChatEvents.abstracts.ChannelEvent | ||||||
|  | import dev.inmo.tgbotapi.types.message.ChatEvents.abstracts.GroupEvent | ||||||
| import dev.inmo.tgbotapi.types.message.abstracts.ChatEventMessage | import dev.inmo.tgbotapi.types.message.abstracts.ChatEventMessage | ||||||
|  |  | ||||||
| data class ChannelEventMessage( | data class ChannelEventMessage<T : ChannelEvent>( | ||||||
|     override val messageId: MessageIdentifier, |     override val messageId: MessageIdentifier, | ||||||
|     override val chat: ChannelChat, |     override val chat: ChannelChat, | ||||||
|     override val chatEvent: ChannelEvent, |     override val chatEvent: T, | ||||||
|     override val date: DateTime |     override val date: DateTime | ||||||
| ) : ChatEventMessage | ) : ChatEventMessage<T> | ||||||
|   | |||||||
| @@ -1,3 +1,3 @@ | |||||||
| package dev.inmo.tgbotapi.types.message.ChatEvents.abstracts | package dev.inmo.tgbotapi.types.message.ChatEvents.abstracts | ||||||
|  |  | ||||||
| interface SupergroupEvent: ChatEvent | interface SupergroupEvent: GroupEvent | ||||||
| @@ -8,12 +8,12 @@ import dev.inmo.tgbotapi.types.message.ChatEvents.abstracts.GroupEvent | |||||||
| import dev.inmo.tgbotapi.types.message.abstracts.GroupEventMessage | import dev.inmo.tgbotapi.types.message.abstracts.GroupEventMessage | ||||||
|  |  | ||||||
| @Deprecated("Renamed", ReplaceWith("CommonGroupEventMessage")) | @Deprecated("Renamed", ReplaceWith("CommonGroupEventMessage")) | ||||||
| typealias GroupEventMessage = CommonGroupEventMessage | typealias GroupEventMessage = CommonGroupEventMessage<*> | ||||||
|  |  | ||||||
| data class CommonGroupEventMessage( | data class CommonGroupEventMessage<T : GroupEvent>( | ||||||
|     override val messageId: MessageIdentifier, |     override val messageId: MessageIdentifier, | ||||||
|     override val user: User, |     override val user: User, | ||||||
|     override val chat: GroupChat, |     override val chat: GroupChat, | ||||||
|     override val chatEvent: GroupEvent, |     override val chatEvent: T, | ||||||
|     override val date: DateTime |     override val date: DateTime | ||||||
| ) : GroupEventMessage | ) : GroupEventMessage<T> | ||||||
|   | |||||||
| @@ -4,16 +4,17 @@ import com.soywiz.klock.DateTime | |||||||
| import dev.inmo.tgbotapi.types.MessageIdentifier | import dev.inmo.tgbotapi.types.MessageIdentifier | ||||||
| import dev.inmo.tgbotapi.types.User | import dev.inmo.tgbotapi.types.User | ||||||
| import dev.inmo.tgbotapi.types.chat.abstracts.SupergroupChat | import dev.inmo.tgbotapi.types.chat.abstracts.SupergroupChat | ||||||
|  | import dev.inmo.tgbotapi.types.message.ChatEvents.abstracts.GroupEvent | ||||||
| import dev.inmo.tgbotapi.types.message.ChatEvents.abstracts.SupergroupEvent | import dev.inmo.tgbotapi.types.message.ChatEvents.abstracts.SupergroupEvent | ||||||
| import dev.inmo.tgbotapi.types.message.abstracts.SupergroupEventMessage | import dev.inmo.tgbotapi.types.message.abstracts.SupergroupEventMessage | ||||||
|  |  | ||||||
| @Deprecated("Renamed", ReplaceWith("CommonSupergroupEventMessage")) | @Deprecated("Renamed", ReplaceWith("CommonSupergroupEventMessage")) | ||||||
| typealias SupergroupEventMessage = CommonSupergroupEventMessage | typealias SupergroupEventMessage = CommonSupergroupEventMessage<*> | ||||||
|  |  | ||||||
| data class CommonSupergroupEventMessage( | data class CommonSupergroupEventMessage<T : SupergroupEvent>( | ||||||
|     override val messageId: MessageIdentifier, |     override val messageId: MessageIdentifier, | ||||||
|     override val user: User, |     override val user: User, | ||||||
|     override val chat: SupergroupChat, |     override val chat: SupergroupChat, | ||||||
|     override val chatEvent: SupergroupEvent, |     override val chatEvent: T, | ||||||
|     override val date: DateTime |     override val date: DateTime | ||||||
| ) : SupergroupEventMessage | ) : SupergroupEventMessage<T> | ||||||
|   | |||||||
| @@ -38,6 +38,7 @@ data class AnonymousGroupMessageImpl<T : MessageContent>( | |||||||
| data class CommonGroupMessageImpl<T : MessageContent>( | data class CommonGroupMessageImpl<T : MessageContent>( | ||||||
|     override val chat: GroupChat, |     override val chat: GroupChat, | ||||||
|     override val messageId: MessageIdentifier, |     override val messageId: MessageIdentifier, | ||||||
|  |     override val user: User, | ||||||
|     override val date: DateTime, |     override val date: DateTime, | ||||||
|     override val forwardInfo: ForwardInfo?, |     override val forwardInfo: ForwardInfo?, | ||||||
|     override val editDate: DateTime?, |     override val editDate: DateTime?, | ||||||
|   | |||||||
| @@ -296,6 +296,7 @@ internal data class RawMessage( | |||||||
|                             null -> CommonGroupMessageImpl( |                             null -> CommonGroupMessageImpl( | ||||||
|                                 chat, |                                 chat, | ||||||
|                                 messageId, |                                 messageId, | ||||||
|  |                                 from ?: error("It is expected that in messages from non anonymous users and channels user must be specified"), | ||||||
|                                 date.asDate, |                                 date.asDate, | ||||||
|                                 forwarded, |                                 forwarded, | ||||||
|                                 edit_date ?.asDate, |                                 edit_date ?.asDate, | ||||||
|   | |||||||
| @@ -2,6 +2,6 @@ package dev.inmo.tgbotapi.types.message.abstracts | |||||||
|  |  | ||||||
| import dev.inmo.tgbotapi.types.message.ChatEvents.abstracts.ChatEvent | import dev.inmo.tgbotapi.types.message.ChatEvents.abstracts.ChatEvent | ||||||
|  |  | ||||||
| interface ChatEventMessage : Message { | interface ChatEventMessage<T : ChatEvent> : Message { | ||||||
|     val chatEvent: ChatEvent |     val chatEvent: T | ||||||
| } | } | ||||||
| @@ -1,3 +1,5 @@ | |||||||
| package dev.inmo.tgbotapi.types.message.abstracts | package dev.inmo.tgbotapi.types.message.abstracts | ||||||
|  |  | ||||||
| interface GroupEventMessage : ChatEventMessage, FromUserMessage | import dev.inmo.tgbotapi.types.message.ChatEvents.abstracts.GroupEvent | ||||||
|  |  | ||||||
|  | interface GroupEventMessage<T : GroupEvent> : ChatEventMessage<T>, FromUserMessage | ||||||
|   | |||||||
| @@ -17,4 +17,4 @@ interface AnonymousGroupMessage<T : MessageContent> : GroupMessage<T>, SignedMes | |||||||
|     override val senderChat: GroupChat |     override val senderChat: GroupChat | ||||||
|         get() = chat |         get() = chat | ||||||
| } | } | ||||||
| interface CommonGroupMessage<T : MessageContent> : GroupMessage<T> | interface CommonGroupMessage<T : MessageContent> : GroupMessage<T>, FromUserMessage | ||||||
|   | |||||||
| @@ -1,3 +1,5 @@ | |||||||
| package dev.inmo.tgbotapi.types.message.abstracts | package dev.inmo.tgbotapi.types.message.abstracts | ||||||
|  |  | ||||||
| interface SupergroupEventMessage : GroupEventMessage | import dev.inmo.tgbotapi.types.message.ChatEvents.abstracts.SupergroupEvent | ||||||
|  |  | ||||||
|  | interface SupergroupEventMessage<T : SupergroupEvent> : GroupEventMessage<T> | ||||||
|   | |||||||
| @@ -1,7 +1,6 @@ | |||||||
| package dev.inmo.tgbotapi.types.message.content | package dev.inmo.tgbotapi.types.message.content | ||||||
|  |  | ||||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSourcesList | import dev.inmo.tgbotapi.CommonAbstracts.* | ||||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextPart |  | ||||||
| import dev.inmo.tgbotapi.requests.abstracts.Request | import dev.inmo.tgbotapi.requests.abstracts.Request | ||||||
| import dev.inmo.tgbotapi.requests.send.SendTextMessage | import dev.inmo.tgbotapi.requests.send.SendTextMessage | ||||||
| import dev.inmo.tgbotapi.types.ChatIdentifier | import dev.inmo.tgbotapi.types.ChatIdentifier | ||||||
| @@ -15,13 +14,13 @@ import dev.inmo.tgbotapi.utils.internal.fullListOfSubSource | |||||||
| import dev.inmo.tgbotapi.utils.internal.toMarkdownTexts | import dev.inmo.tgbotapi.utils.internal.toMarkdownTexts | ||||||
|  |  | ||||||
| data class TextContent( | data class TextContent( | ||||||
|     val text: String, |     override val text: String, | ||||||
|     /** |     override val textEntities: List<TextPart> = emptyList() | ||||||
|      * Not full list of entities. This list WILL NOT contain [TextPart]s with [dev.inmo.tgbotapi.types.MessageEntity.textsources.RegularTextSource] | ) : MessageContent, TextedInput { | ||||||
|      * @see [TextContent.fullEntitiesList] |     @Deprecated("Has been renamed", ReplaceWith("textEntities")) | ||||||
|      */ |     val entities: List<TextPart> | ||||||
|     val entities: List<TextPart> = emptyList() |         get() = textEntities | ||||||
| ) : MessageContent { |  | ||||||
|     override fun createResend( |     override fun createResend( | ||||||
|         chatId: ChatIdentifier, |         chatId: ChatIdentifier, | ||||||
|         disableNotification: Boolean, |         disableNotification: Boolean, | ||||||
| @@ -83,4 +82,5 @@ data class TextContent( | |||||||
|  * Convert its [TextContent.entities] to list of [dev.inmo.tgbotapi.CommonAbstracts.TextSource] |  * Convert its [TextContent.entities] to list of [dev.inmo.tgbotapi.CommonAbstracts.TextSource] | ||||||
|  * with [dev.inmo.tgbotapi.types.MessageEntity.textsources.RegularTextSource] |  * with [dev.inmo.tgbotapi.types.MessageEntity.textsources.RegularTextSource] | ||||||
|  */ |  */ | ||||||
|  | @Deprecated("Useless due to the fact that currently every message contains full list of sources") | ||||||
| fun TextContent.fullEntitiesList(): TextSourcesList = text.fullListOfSubSource(entities).map { it.source } | fun TextContent.fullEntitiesList(): TextSourcesList = text.fullListOfSubSource(entities).map { it.source } | ||||||
|   | |||||||
| @@ -83,19 +83,19 @@ private fun List<TextSource>.joinSubSourcesHtml() = joinToString("") { | |||||||
| internal fun MultilevelTextSource.markdownV2Default( | internal fun MultilevelTextSource.markdownV2Default( | ||||||
|     openControlSymbol: String, |     openControlSymbol: String, | ||||||
|     closeControlSymbol: String = openControlSymbol |     closeControlSymbol: String = openControlSymbol | ||||||
| ) = "$openControlSymbol${textSources.joinSubSourcesMarkdownV2()}$closeControlSymbol" | ) = "$openControlSymbol${subsources.joinSubSourcesMarkdownV2()}$closeControlSymbol" | ||||||
| internal fun MultilevelTextSource.htmlDefault( | internal fun MultilevelTextSource.htmlDefault( | ||||||
|     openControlSymbol: String, |     openControlSymbol: String, | ||||||
|     closeControlSymbol: String = openControlSymbol |     closeControlSymbol: String = openControlSymbol | ||||||
| ) = "<$openControlSymbol>${textSources.joinSubSourcesHtml()}</$closeControlSymbol>" | ) = "<$openControlSymbol>${subsources.joinSubSourcesHtml()}</$closeControlSymbol>" | ||||||
|  |  | ||||||
|  |  | ||||||
| internal fun MultilevelTextSource.linkMarkdownV2( | internal fun MultilevelTextSource.linkMarkdownV2( | ||||||
|     link: String |     link: String | ||||||
| ) = "[${textSources.joinSubSourcesMarkdownV2()}](${link.escapeMarkdownV2Link()})" | ) = "[${subsources.joinSubSourcesMarkdownV2()}](${link.escapeMarkdownV2Link()})" | ||||||
| internal fun MultilevelTextSource.linkHTML( | internal fun MultilevelTextSource.linkHTML( | ||||||
|     link: String |     link: String | ||||||
| ) = "<a href=\"${link.toHtml()}\">${textSources.joinSubSourcesHtml()}</a>" | ) = "<a href=\"${link.toHtml()}\">${subsources.joinSubSourcesHtml()}</a>" | ||||||
|  |  | ||||||
|  |  | ||||||
| internal fun MultilevelTextSource.optionalPrefix( | internal fun MultilevelTextSource.optionalPrefix( | ||||||
| @@ -116,8 +116,8 @@ internal fun MultilevelTextSource.boldMarkdownV2(): String = markdownV2Default(m | |||||||
| internal fun MultilevelTextSource.boldHTML(): String = htmlDefault(htmlBoldControl) | internal fun MultilevelTextSource.boldHTML(): String = htmlDefault(htmlBoldControl) | ||||||
|  |  | ||||||
|  |  | ||||||
| internal fun MultilevelTextSource.cashTagMarkdownV2(): String = textSources.joinSubSourcesMarkdownV2() | internal fun MultilevelTextSource.cashTagMarkdownV2(): String = subsources.joinSubSourcesMarkdownV2() | ||||||
| internal fun MultilevelTextSource.cashTagHTML(): String = textSources.joinSubSourcesHtml() | internal fun MultilevelTextSource.cashTagHTML(): String = subsources.joinSubSourcesHtml() | ||||||
|  |  | ||||||
|  |  | ||||||
| internal fun MultilevelTextSource.italicMarkdownV2(): String = markdownV2Default(markdownItalicControl) | internal fun MultilevelTextSource.italicMarkdownV2(): String = markdownV2Default(markdownItalicControl) | ||||||
| @@ -135,21 +135,21 @@ internal fun MultilevelTextSource.underlineHTML(): String = htmlDefault(htmlUnde | |||||||
| internal fun MultilevelTextSource.textMentionMarkdownV2(userId: UserId): String = linkMarkdownV2(userId.link) | internal fun MultilevelTextSource.textMentionMarkdownV2(userId: UserId): String = linkMarkdownV2(userId.link) | ||||||
| internal fun MultilevelTextSource.textMentionHTML(userId: UserId): String = linkHTML(userId.link) | internal fun MultilevelTextSource.textMentionHTML(userId: UserId): String = linkHTML(userId.link) | ||||||
|  |  | ||||||
| internal fun MultilevelTextSource.mentionMarkdownV2(): String = optionalPrefix("@") + textSources.joinSubSourcesMarkdownV2() | internal fun MultilevelTextSource.mentionMarkdownV2(): String = optionalPrefix("@") + subsources.joinSubSourcesMarkdownV2() | ||||||
| internal fun MultilevelTextSource.mentionHTML(): String = optionalPrefix("@") + textSources.joinSubSourcesHtml() | internal fun MultilevelTextSource.mentionHTML(): String = optionalPrefix("@") + subsources.joinSubSourcesHtml() | ||||||
|  |  | ||||||
|  |  | ||||||
| internal fun MultilevelTextSource.hashTagMarkdownV2(): String = when { | internal fun MultilevelTextSource.hashTagMarkdownV2(): String = when { | ||||||
|     source.startsWith("\\#") || source.startsWith("#") -> "" |     source.startsWith("\\#") || source.startsWith("#") -> "" | ||||||
|     else -> "\\#" |     else -> "\\#" | ||||||
| } + textSources.joinSubSourcesMarkdownV2() | } + subsources.joinSubSourcesMarkdownV2() | ||||||
| internal fun MultilevelTextSource.hashTagHTML(): String = optionalPrefix("#") + textSources.joinSubSourcesHtml() | internal fun MultilevelTextSource.hashTagHTML(): String = optionalPrefix("#") + subsources.joinSubSourcesHtml() | ||||||
|  |  | ||||||
|  |  | ||||||
| internal fun MultilevelTextSource.phoneMarkdownV2(): String = textSources.joinSubSourcesMarkdownV2() | internal fun MultilevelTextSource.phoneMarkdownV2(): String = subsources.joinSubSourcesMarkdownV2() | ||||||
| internal fun MultilevelTextSource.phoneHTML(): String = textSources.joinSubSourcesHtml() | internal fun MultilevelTextSource.phoneHTML(): String = subsources.joinSubSourcesHtml() | ||||||
|  |  | ||||||
|  |  | ||||||
| internal fun MultilevelTextSource.commandMarkdownV2(): String = optionalPrefix("/") + textSources.joinSubSourcesMarkdownV2() | internal fun MultilevelTextSource.commandMarkdownV2(): String = optionalPrefix("/") + subsources.joinSubSourcesMarkdownV2() | ||||||
| internal fun MultilevelTextSource.commandHTML(): String = optionalPrefix("/") + textSources.joinSubSourcesHtml() | internal fun MultilevelTextSource.commandHTML(): String = optionalPrefix("/") + subsources.joinSubSourcesHtml() | ||||||
|  |  | ||||||
|   | |||||||
| @@ -49,8 +49,8 @@ fun List<TextPart>.testTextParts() { | |||||||
|     assertTrue (get(5).source is MentionTextSource) |     assertTrue (get(5).source is MentionTextSource) | ||||||
|  |  | ||||||
|     val boldSource = get(1).source as BoldTextSource |     val boldSource = get(1).source as BoldTextSource | ||||||
|     assertTrue (boldSource.textSources.first() is ItalicTextSource) |     assertTrue (boldSource.subsources.first() is ItalicTextSource) | ||||||
|     assertTrue (boldSource.textSources[1] is RegularTextSource) |     assertTrue (boldSource.subsources[1] is RegularTextSource) | ||||||
|     assertTrue (boldSource.textSources[2] is StrikethroughTextSource) |     assertTrue (boldSource.subsources[2] is StrikethroughTextSource) | ||||||
|     assertTrue ((boldSource.textSources[2] as StrikethroughTextSource).textSources.first() is UnderlineTextSource) |     assertTrue ((boldSource.subsources[2] as StrikethroughTextSource).subsources.first() is UnderlineTextSource) | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,13 +1,13 @@ | |||||||
| package dev.inmo.tgbotapi.extensions.utils.chat_events | package dev.inmo.tgbotapi.extensions.utils.chat_events | ||||||
|  |  | ||||||
| import dev.inmo.tgbotapi.types.message.* | import dev.inmo.tgbotapi.extensions.utils.shortcuts.* | ||||||
| import dev.inmo.tgbotapi.types.message.abstracts.ChatEventMessage | import dev.inmo.tgbotapi.types.message.abstracts.ChatEventMessage | ||||||
| import kotlinx.coroutines.flow.Flow | import kotlinx.coroutines.flow.Flow | ||||||
| import kotlinx.coroutines.flow.mapNotNull | import kotlinx.coroutines.flow.mapNotNull | ||||||
| import kotlin.reflect.KClass | import kotlin.reflect.KClass | ||||||
|  |  | ||||||
|  | @Deprecated("Refactored, replaced and renamed", ReplaceWith("filterByChatEvent", "dev.inmo.tgbotapi.extensions.utils.shortcuts.filterByChatEvent")) | ||||||
| fun <T : ChatEventMessage> Flow<ChatEventMessage>.divideBySource(contentType: KClass<T>) = mapNotNull { | fun <T : ChatEventMessage<*>> Flow<ChatEventMessage<*>>.divideBySource(contentType: KClass<T>) = mapNotNull { | ||||||
|     if (contentType.isInstance(it)) { |     if (contentType.isInstance(it)) { | ||||||
|         @Suppress("UNCHECKED_CAST") |         @Suppress("UNCHECKED_CAST") | ||||||
|         it as T |         it as T | ||||||
| @@ -16,6 +16,9 @@ fun <T : ChatEventMessage> Flow<ChatEventMessage>.divideBySource(contentType: KC | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| fun Flow<ChatEventMessage>.onlyChannelEvents() = divideBySource(ChannelEventMessage::class) | @Deprecated("Replaced and renamed", ReplaceWith("channelEvents", "dev.inmo.tgbotapi.extensions.utils.shortcuts.channelEvents")) | ||||||
| fun Flow<ChatEventMessage>.onlyGroupEvents() = divideBySource(CommonGroupEventMessage::class) | fun Flow<ChatEventMessage<*>>.onlyChannelEvents() = channelEvents() | ||||||
| fun Flow<ChatEventMessage>.onlySupergroupEvents() = divideBySource(CommonSupergroupEventMessage::class) | @Deprecated("Replaced and renamed", ReplaceWith("groupEvents", "dev.inmo.tgbotapi.extensions.utils.shortcuts.groupEvents")) | ||||||
|  | fun Flow<ChatEventMessage<*>>.onlyGroupEvents() = groupEvents() | ||||||
|  | @Deprecated("Replaced and renamed", ReplaceWith("supergroupEvents", "dev.inmo.tgbotapi.extensions.utils.shortcuts.supergroupEvents")) | ||||||
|  | fun Flow<ChatEventMessage<*>>.onlySupergroupEvents() = supergroupEvents() | ||||||
|   | |||||||
| @@ -1,6 +1,7 @@ | |||||||
| package dev.inmo.tgbotapi.extensions.utils.shortcuts | package dev.inmo.tgbotapi.extensions.utils.shortcuts | ||||||
|  |  | ||||||
| import dev.inmo.tgbotapi.CommonAbstracts.TextSource | import dev.inmo.tgbotapi.CommonAbstracts.TextSource | ||||||
|  | import dev.inmo.tgbotapi.CommonAbstracts.textSources | ||||||
| import dev.inmo.tgbotapi.extensions.utils.onlyTextContentMessages | import dev.inmo.tgbotapi.extensions.utils.onlyTextContentMessages | ||||||
| import dev.inmo.tgbotapi.extensions.utils.updates.asContentMessagesFlow | import dev.inmo.tgbotapi.extensions.utils.updates.asContentMessagesFlow | ||||||
| import dev.inmo.tgbotapi.types.MessageEntity.textsources.BotCommandTextSource | import dev.inmo.tgbotapi.types.MessageEntity.textsources.BotCommandTextSource | ||||||
| @@ -27,7 +28,7 @@ import kotlinx.coroutines.flow.* | |||||||
| fun <T : ContentMessage<TextContent>> Flow<T>.filterExactCommands( | fun <T : ContentMessage<TextContent>> Flow<T>.filterExactCommands( | ||||||
|     commandRegex: Regex |     commandRegex: Regex | ||||||
| ) = filter { contentMessage -> | ) = filter { contentMessage -> | ||||||
|     (contentMessage.content.fullEntitiesList().singleOrNull() as? BotCommandTextSource) ?.let { commandRegex.matches(it.command) } == true |     (contentMessage.content.textSources.singleOrNull() as? BotCommandTextSource) ?.let { commandRegex.matches(it.command) } == true | ||||||
| } | } | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -46,7 +47,7 @@ fun <T : ContentMessage<TextContent>> Flow<T>.filterExactCommands( | |||||||
| fun <T : ContentMessage<TextContent>> Flow<T>.filterCommandsInsideTextMessages( | fun <T : ContentMessage<TextContent>> Flow<T>.filterCommandsInsideTextMessages( | ||||||
|     commandRegex: Regex |     commandRegex: Regex | ||||||
| ) = filter { contentMessage -> | ) = filter { contentMessage -> | ||||||
|     contentMessage.content.fullEntitiesList().any { |     contentMessage.content.textSources.any { | ||||||
|         (it as? BotCommandTextSource) ?.let { commandRegex.matches(it.command) } == true |         (it as? BotCommandTextSource) ?.let { commandRegex.matches(it.command) } == true | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -70,7 +71,7 @@ fun <T : ContentMessage<TextContent>> Flow<T>.filterCommandsInsideTextMessages( | |||||||
| fun <T : ContentMessage<TextContent>> Flow<T>.filterCommandsWithArgs( | fun <T : ContentMessage<TextContent>> Flow<T>.filterCommandsWithArgs( | ||||||
|     commandRegex: Regex |     commandRegex: Regex | ||||||
| ) = mapNotNull { contentMessage -> | ) = mapNotNull { contentMessage -> | ||||||
|     val allEntities = contentMessage.content.fullEntitiesList() |     val allEntities = contentMessage.content.textSources | ||||||
|     (allEntities.firstOrNull() as? BotCommandTextSource) ?.let { |     (allEntities.firstOrNull() as? BotCommandTextSource) ?.let { | ||||||
|         if (commandRegex.matches(it.command)) { |         if (commandRegex.matches(it.command)) { | ||||||
|             contentMessage to allEntities.flatMap { |             contentMessage to allEntities.flatMap { | ||||||
|   | |||||||
| @@ -0,0 +1,98 @@ | |||||||
|  | @file:Suppress("NOTHING_TO_INLINE", "unused", "EXPERIMENTAL_API_USAGE") | ||||||
|  |  | ||||||
|  | package dev.inmo.tgbotapi.extensions.utils.shortcuts | ||||||
|  |  | ||||||
|  | import dev.inmo.micro_utils.coroutines.plus | ||||||
|  | import dev.inmo.tgbotapi.types.message.ChannelEventMessage | ||||||
|  | import dev.inmo.tgbotapi.types.message.ChatEvents.* | ||||||
|  | import dev.inmo.tgbotapi.types.message.ChatEvents.abstracts.* | ||||||
|  | import dev.inmo.tgbotapi.types.message.abstracts.* | ||||||
|  | import dev.inmo.tgbotapi.updateshandlers.FlowsUpdatesFilter | ||||||
|  | import dev.inmo.tgbotapi.utils.RiskFeature | ||||||
|  | import kotlinx.coroutines.flow.* | ||||||
|  |  | ||||||
|  | @RiskFeature("Use with caution") | ||||||
|  | inline fun FlowsUpdatesFilter.events(): Flow<ChatEventMessage<*>> { | ||||||
|  |     return channelPostFlow.mapNotNull { it.data as? ChatEventMessage<*> } + messageFlow.mapNotNull { it.data as? ChatEventMessage<*> } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @RiskFeature("Use with caution") | ||||||
|  | inline fun FlowsUpdatesFilter.channelEvents(): Flow<ChannelEventMessage<*>> = channelPostFlow.mapNotNull { | ||||||
|  |     it.data as? ChannelEventMessage<*> | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @RiskFeature("Use with caution") | ||||||
|  | inline fun FlowsUpdatesFilter.groupEvents(): Flow<GroupEventMessage<*>> = messageFlow.mapNotNull { | ||||||
|  |     it.data as? GroupEventMessage<*> | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @RiskFeature("Use with caution") | ||||||
|  | inline fun FlowsUpdatesFilter.supergroupEvents(): Flow<SupergroupEventMessage<*>> = messageFlow.mapNotNull { | ||||||
|  |     it.data as? SupergroupEventMessage<*> | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @RiskFeature("Use with caution") | ||||||
|  | inline fun <reified T: ChatEvent, reified O: ChatEventMessage<T>> Flow<ChatEventMessage<*>>.filterByChatEvent(): Flow<O> = mapNotNull { | ||||||
|  |     if (it.chatEvent is T) it as? O else null | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @RiskFeature("Use with caution") | ||||||
|  | inline fun <reified T : ChannelEvent> Flow<ChatEventMessage<*>>.filterChannelEvents() = filterByChatEvent<T, ChannelEventMessage<T>>() | ||||||
|  | @RiskFeature("Use with caution") | ||||||
|  | inline fun <reified T : ChannelEvent> FlowsUpdatesFilter.filterChannelEvents() = channelEvents().filterChannelEvents<T>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.channelCreatedEvents() = filterChannelEvents<ChannelChatCreated>() | ||||||
|  | inline fun FlowsUpdatesFilter.channelCreatedEvents() = filterChannelEvents<ChannelChatCreated>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.deletedChannelPhotoEvents() = filterChannelEvents<DeleteChatPhoto>() | ||||||
|  | inline fun FlowsUpdatesFilter.deletedChannelPhotoEvents() = filterChannelEvents<DeleteChatPhoto>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.newChannelPhotoEvents() = filterChannelEvents<NewChatPhoto>() | ||||||
|  | inline fun FlowsUpdatesFilter.newChannelPhotoEvents() = filterChannelEvents<NewChatPhoto>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.newChannelTitleEvents() = filterChannelEvents<NewChatTitle>() | ||||||
|  | inline fun FlowsUpdatesFilter.newChannelTitleEvents() = filterChannelEvents<NewChatTitle>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.newChannelPinnedMessageEvents() = filterChannelEvents<PinnedMessage>() | ||||||
|  | inline fun FlowsUpdatesFilter.newChannelPinnedMessageEvents() = filterChannelEvents<PinnedMessage>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.channelEvents() = filterChannelEvents<ChannelEvent>() | ||||||
|  |  | ||||||
|  | @RiskFeature("Use with caution") | ||||||
|  | inline fun <reified T : GroupEvent> Flow<ChatEventMessage<*>>.filterGroupEvents() = filterByChatEvent<T, GroupEventMessage<T>>() | ||||||
|  | @RiskFeature("Use with caution") | ||||||
|  | inline fun <reified T : GroupEvent> FlowsUpdatesFilter.filterGroupEvents() = groupEvents().filterByChatEvent<T, GroupEventMessage<T>>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.groupCreatedEvents() = filterGroupEvents<GroupChatCreated>() | ||||||
|  | inline fun FlowsUpdatesFilter.groupCreatedEvents() = filterGroupEvents<GroupChatCreated>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.deletedGroupPhotoEvents() = filterGroupEvents<DeleteChatPhoto>() | ||||||
|  | inline fun FlowsUpdatesFilter.deletedGroupPhotoEvents() = filterGroupEvents<DeleteChatPhoto>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.newGroupMembersEvents() = filterGroupEvents<NewChatMembers>() | ||||||
|  | inline fun FlowsUpdatesFilter.newGroupMembersEvents() = filterGroupEvents<NewChatMembers>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.leftGroupMemberEvents() = filterGroupEvents<LeftChatMember>() | ||||||
|  | inline fun FlowsUpdatesFilter.leftGroupMemberEvents() = filterGroupEvents<LeftChatMember>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.newGroupPhotoEvents() = filterGroupEvents<NewChatPhoto>() | ||||||
|  | inline fun FlowsUpdatesFilter.newGroupPhotoEvents() = filterGroupEvents<NewChatPhoto>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.newGroupTitleEvents() = filterGroupEvents<NewChatTitle>() | ||||||
|  | inline fun FlowsUpdatesFilter.newGroupTitleEvents() = filterGroupEvents<NewChatTitle>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.newGroupPinnedMessageEvents() = filterGroupEvents<PinnedMessage>() | ||||||
|  | inline fun FlowsUpdatesFilter.newGroupPinnedMessageEvents() = filterGroupEvents<PinnedMessage>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.proximityAlertTriggeredInGroupEvents() = filterGroupEvents<ProximityAlertTriggered>() | ||||||
|  | inline fun FlowsUpdatesFilter.proximityAlertTriggeredInGroupEvents() = filterGroupEvents<ProximityAlertTriggered>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.groupEvents() = filterGroupEvents<GroupEvent>() | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @RiskFeature("Use with caution") | ||||||
|  | inline fun <reified T : SupergroupEvent> Flow<ChatEventMessage<*>>.filterSupergroupEvents() = filterByChatEvent<T, SupergroupEventMessage<T>>() | ||||||
|  | @RiskFeature("Use with caution") | ||||||
|  | inline fun <reified T : SupergroupEvent> FlowsUpdatesFilter.filterSupergroupEvents() = supergroupEvents().filterByChatEvent<T, SupergroupEventMessage<T>>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.supergroupCreatedEvents() = filterSupergroupEvents<SupergroupChatCreated>() | ||||||
|  | inline fun FlowsUpdatesFilter.supergroupCreatedEvents() = filterSupergroupEvents<SupergroupChatCreated>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.deletedSupergroupPhotoEvents() = filterSupergroupEvents<DeleteChatPhoto>() | ||||||
|  | inline fun FlowsUpdatesFilter.deletedSupergroupPhotoEvents() = filterSupergroupEvents<DeleteChatPhoto>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.newSupergroupMembersEvents() = filterSupergroupEvents<NewChatMembers>() | ||||||
|  | inline fun FlowsUpdatesFilter.newSupergroupMembersEvents() = filterSupergroupEvents<NewChatMembers>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.leftSupergroupMemberEvents() = filterSupergroupEvents<LeftChatMember>() | ||||||
|  | inline fun FlowsUpdatesFilter.leftSupergroupMemberEvents() = filterSupergroupEvents<LeftChatMember>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.newSupergroupPhotoEvents() = filterSupergroupEvents<NewChatPhoto>() | ||||||
|  | inline fun FlowsUpdatesFilter.newSupergroupPhotoEvents() = filterSupergroupEvents<NewChatPhoto>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.newSupergroupTitleEvents() = filterSupergroupEvents<NewChatTitle>() | ||||||
|  | inline fun FlowsUpdatesFilter.newSupergroupTitleEvents() = filterSupergroupEvents<NewChatTitle>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.newSupergroupPinnedMessageEvents() = filterSupergroupEvents<PinnedMessage>() | ||||||
|  | inline fun FlowsUpdatesFilter.newSupergroupPinnedMessageEvents() = filterSupergroupEvents<PinnedMessage>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.proximityAlertTriggeredInSupergroupEvents() = filterSupergroupEvents<ProximityAlertTriggered>() | ||||||
|  | inline fun FlowsUpdatesFilter.proximityAlertTriggeredInSupergroupEvents() = filterSupergroupEvents<ProximityAlertTriggered>() | ||||||
|  | inline fun Flow<ChatEventMessage<*>>.supergroupEvents() = filterSupergroupEvents<SupergroupEvent>() | ||||||
| @@ -19,12 +19,15 @@ fun <T : BaseSentMessageUpdate> Flow<T>.asCommonMessagesFlow() = mapNotNull { | |||||||
|     it.data as? CommonMessage<*> |     it.data as? CommonMessage<*> | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @Suppress("NOTHING_TO_INLINE") | ||||||
|  | inline fun <T : BaseSentMessageUpdate> Flow<T>.chatEvents() = mapNotNull { | ||||||
|  |     it.data as? ChatEventMessage<*> | ||||||
|  | } | ||||||
| /** | /** | ||||||
|  * Will map incoming [BaseSentMessageUpdate]s to [ChatEventMessage] from [BaseSentMessageUpdate.data] |  * Will map incoming [BaseSentMessageUpdate]s to [ChatEventMessage] from [BaseSentMessageUpdate.data] | ||||||
|  */ |  */ | ||||||
| fun <T : BaseSentMessageUpdate> Flow<T>.asChatEventsFlow() = mapNotNull { | @Deprecated("Renamed", ReplaceWith("chatEvents", "dev.inmo.tgbotapi.extensions.utils.updates.chatEvents")) | ||||||
|     it.data as? ChatEventMessage | fun <T : BaseSentMessageUpdate> Flow<T>.asChatEventsFlow() = chatEvents() | ||||||
| } |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Will map incoming [BaseSentMessageUpdate]s to [UnknownMessageType] from [BaseSentMessageUpdate.data] |  * Will map incoming [BaseSentMessageUpdate]s to [UnknownMessageType] from [BaseSentMessageUpdate.data] | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user