2021-10-03 14:37:14 +00:00
|
|
|
@file:Suppress("unused")
|
|
|
|
|
|
|
|
package dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling
|
|
|
|
|
|
|
|
import dev.inmo.tgbotapi.extensions.behaviour_builder.*
|
|
|
|
import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.SimpleFilter
|
2022-05-07 18:30:47 +00:00
|
|
|
import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories.ByUserIdChosenInlineResultMarkerFactory
|
|
|
|
import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories.MarkerFactory
|
2022-08-05 10:31:39 +00:00
|
|
|
import dev.inmo.tgbotapi.extensions.utils.chosenInlineResultUpdateOrNull
|
2021-10-03 14:37:14 +00:00
|
|
|
import dev.inmo.tgbotapi.types.InlineQueries.ChosenInlineResult.*
|
|
|
|
import dev.inmo.tgbotapi.types.update.abstracts.Update
|
|
|
|
|
2021-10-13 08:22:01 +00:00
|
|
|
internal suspend inline fun <BC : BehaviourContext, reified T : ChosenInlineResult> BC.onChosenInlineResultBase(
|
2022-04-21 09:42:32 +00:00
|
|
|
initialFilter: SimpleFilter<T>? = null,
|
2021-10-13 08:22:01 +00:00
|
|
|
noinline subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, T, Update>? = null,
|
2021-10-03 14:37:14 +00:00
|
|
|
markerFactory: MarkerFactory<in T, Any> = ByUserIdChosenInlineResultMarkerFactory,
|
2021-10-13 08:22:01 +00:00
|
|
|
noinline scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, T>
|
2021-10-03 14:37:14 +00:00
|
|
|
) = on(markerFactory, initialFilter, subcontextUpdatesFilter, scenarioReceiver) {
|
2022-08-05 10:31:39 +00:00
|
|
|
(it.chosenInlineResultUpdateOrNull() ?.data as? T) ?.let(::listOfNotNull)
|
2021-10-03 14:37:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call
|
|
|
|
* @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example,
|
|
|
|
* this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage].
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContextAndTwoTypesReceiver] function to create your own.
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.plus] or [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.times]
|
|
|
|
* to combinate several filters
|
|
|
|
* @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously
|
|
|
|
* in one "stream". Output of [markerFactory] will be used as a key for "stream"
|
|
|
|
* @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that
|
|
|
|
* data
|
|
|
|
*/
|
2021-10-13 08:22:01 +00:00
|
|
|
suspend fun <BC : BehaviourContext> BC.onChosenInlineResult(
|
2021-10-03 14:37:14 +00:00
|
|
|
initialFilter: SimpleFilter<ChosenInlineResult>? = null,
|
2021-10-13 08:22:01 +00:00
|
|
|
subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, ChosenInlineResult, Update>? = null,
|
2021-10-03 14:37:14 +00:00
|
|
|
markerFactory: MarkerFactory<in ChosenInlineResult, Any> = ByUserIdChosenInlineResultMarkerFactory,
|
2021-10-13 08:22:01 +00:00
|
|
|
scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, ChosenInlineResult>
|
2021-10-03 14:37:14 +00:00
|
|
|
) = onChosenInlineResultBase(
|
|
|
|
initialFilter,
|
|
|
|
subcontextUpdatesFilter,
|
|
|
|
markerFactory,
|
|
|
|
scenarioReceiver
|
|
|
|
)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call
|
|
|
|
* @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example,
|
|
|
|
* this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage].
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContextAndTwoTypesReceiver] function to create your own.
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.plus] or [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.times]
|
|
|
|
* to combinate several filters
|
|
|
|
* @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously
|
|
|
|
* in one "stream". Output of [markerFactory] will be used as a key for "stream"
|
|
|
|
* @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that
|
|
|
|
* data
|
|
|
|
*/
|
2021-10-13 08:22:01 +00:00
|
|
|
suspend fun <BC : BehaviourContext> BC.onLocationChosenInlineResult(
|
2021-10-03 14:37:14 +00:00
|
|
|
initialFilter: SimpleFilter<LocationChosenInlineResult>? = null,
|
2021-10-13 08:22:01 +00:00
|
|
|
subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, LocationChosenInlineResult, Update>? = null,
|
2021-10-03 14:37:14 +00:00
|
|
|
markerFactory: MarkerFactory<in LocationChosenInlineResult, Any> = ByUserIdChosenInlineResultMarkerFactory,
|
2021-10-13 08:22:01 +00:00
|
|
|
scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, LocationChosenInlineResult>
|
2021-10-03 14:37:14 +00:00
|
|
|
) = onChosenInlineResultBase(
|
|
|
|
initialFilter,
|
|
|
|
subcontextUpdatesFilter,
|
|
|
|
markerFactory,
|
|
|
|
scenarioReceiver
|
|
|
|
)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call
|
|
|
|
* @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example,
|
|
|
|
* this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage].
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContextAndTwoTypesReceiver] function to create your own.
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.plus] or [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.times]
|
|
|
|
* to combinate several filters
|
|
|
|
* @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously
|
|
|
|
* in one "stream". Output of [markerFactory] will be used as a key for "stream"
|
|
|
|
* @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that
|
|
|
|
* data
|
|
|
|
*/
|
2021-10-13 08:22:01 +00:00
|
|
|
suspend fun <BC : BehaviourContext> BC.onBaseChosenInlineResult(
|
2021-10-03 14:37:14 +00:00
|
|
|
initialFilter: SimpleFilter<BaseChosenInlineResult>? = null,
|
2021-10-13 08:22:01 +00:00
|
|
|
subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, BaseChosenInlineResult, Update>? = null,
|
2021-10-03 14:37:14 +00:00
|
|
|
markerFactory: MarkerFactory<in BaseChosenInlineResult, Any> = ByUserIdChosenInlineResultMarkerFactory,
|
2021-10-13 08:22:01 +00:00
|
|
|
scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, BaseChosenInlineResult>
|
2021-10-03 14:37:14 +00:00
|
|
|
) = onChosenInlineResultBase(
|
|
|
|
initialFilter,
|
|
|
|
subcontextUpdatesFilter,
|
|
|
|
markerFactory,
|
|
|
|
scenarioReceiver
|
|
|
|
)
|