6 Commits
0.0.2 ... 0.0.3

Author SHA1 Message Date
b9700a8fd9 make force refresh button optional 2022-09-16 21:11:30 +06:00
79c195f534 small updates 2022-09-16 16:53:57 +06:00
91221d865c update dependencies 2022-09-16 15:34:08 +06:00
5808f45677 start 0.0.3 2022-09-16 15:32:48 +06:00
29d6d11d87 update sample config 2022-09-15 02:27:06 +06:00
609c6b97fc Merge pull request #2 from InsanusMokrassar/0.0.2
0.0.2
2022-09-15 02:22:44 +06:00
5 changed files with 62 additions and 44 deletions

View File

@@ -10,5 +10,5 @@ android.enableJetifier=true
# Project data
group=dev.inmo
version=0.0.2
android_code_version=2
version=0.0.3
android_code_version=3

View File

@@ -3,14 +3,14 @@
kotlin = "1.7.10"
kotlin-serialization = "1.4.0"
plagubot = "2.3.1"
tgbotapi = "3.2.1"
plagubot = "2.3.2"
tgbotapi = "3.2.3"
microutils = "0.12.13"
kslog = "0.5.2"
krontab = "0.8.1"
tgbotapi-libraries = "0.5.3"
psql = "42.3.6"
psql = "42.5.0"
dexcount = "3.1.0"
junit_version = "4.12"

View File

@@ -10,8 +10,10 @@ import dev.inmo.plaguposter.common.ChatConfig
import dev.inmo.plaguposter.posts.models.PostId
import dev.inmo.plaguposter.posts.panel.repos.PostsMessages
import dev.inmo.plaguposter.posts.repo.PostsRepo
import dev.inmo.tgbotapi.extensions.api.answers.answer
import dev.inmo.tgbotapi.extensions.api.delete
import dev.inmo.tgbotapi.extensions.api.edit.edit
import dev.inmo.tgbotapi.extensions.api.edit.text.editMessageText
import dev.inmo.tgbotapi.extensions.api.send.send
import dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContext
import dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitMessageDataCallbackQuery
@@ -19,14 +21,11 @@ import dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling.onMessag
import dev.inmo.tgbotapi.extensions.utils.extensions.sameMessage
import dev.inmo.tgbotapi.extensions.utils.types.buttons.dataButton
import dev.inmo.tgbotapi.extensions.utils.types.buttons.flatInlineKeyboard
import dev.inmo.tgbotapi.extensions.utils.withContentOrNull
import dev.inmo.tgbotapi.types.ChatId
import dev.inmo.tgbotapi.types.MessageIdentifier
import dev.inmo.tgbotapi.types.buttons.InlineKeyboardButtons.CallbackDataInlineKeyboardButton
import dev.inmo.tgbotapi.types.buttons.InlineKeyboardMarkup
import dev.inmo.tgbotapi.types.message.ParseMode
import dev.inmo.tgbotapi.types.message.abstracts.Message
import dev.inmo.tgbotapi.types.message.content.TextContent
import kotlinx.coroutines.flow.first
import kotlinx.serialization.Serializable
import kotlinx.serialization.json.*
@@ -41,7 +40,8 @@ object Plugin : Plugin {
val parseMode: ParseMode? = null,
val buttonsPerRow: Int = 4,
val deleteButtonText: String? = null,
val rootButtonText: String = "Return to panel"
val rootButtonText: String = "\uD83D\uDD19",
val refreshButtonText: String? = "\uD83D\uDD04"
)
override fun Module.setupDI(database: Database, params: JsonObject) {
params["panel"] ?.let { element ->
@@ -57,6 +57,14 @@ object Plugin : Plugin {
"delete ${it.id.string}"
)
}
},
config.refreshButtonText ?.let { text ->
PanelButtonBuilder {
CallbackDataInlineKeyboardButton(
text,
"refresh ${it.id.string}"
)
}
}
)
PanelButtonsAPI(
@@ -97,7 +105,7 @@ object Plugin : Plugin {
delete(chatId, messageId)
}
suspend fun updatePost(
suspend fun refreshPostMessage(
postId: PostId,
chatId: ChatId,
messageId: MessageIdentifier
@@ -108,9 +116,10 @@ object Plugin : Plugin {
builder.buildButton(post)
}.takeIf { it.isNotEmpty() }
}
edit(
editMessageText(
chatId,
messageId,
text = config.text,
replyMarkup = InlineKeyboardMarkup(buttons)
)
}
@@ -121,7 +130,7 @@ object Plugin : Plugin {
}
) {
val postId = it.data.removePrefix(PanelButtonsAPI.openGlobalMenuDataPrefix).let(::PostId)
updatePost(postId, it.message.chat.id, it.message.messageId)
refreshPostMessage(postId, it.message.chat.id, it.message.messageId)
}
onMessageDataCallbackQuery(
initialFilter = {
@@ -140,6 +149,7 @@ object Plugin : Plugin {
api.RootPanelButtonBuilder.buildButton(post) ?.let(::add)
}
)
answer(query)
val pushedButton = waitMessageDataCallbackQuery().first {
it.message.sameMessage(query.message)
@@ -149,10 +159,25 @@ object Plugin : Plugin {
postsRepo.deleteById(postId)
}
}
onMessageDataCallbackQuery(
initialFilter = {
it.data.startsWith("refresh ") && it.message.chat.id == chatsConfig.sourceChatId
}
) { query ->
val postId = query.data.removePrefix("refresh ").let(::PostId)
val (chatId, messageId) = postsMessages.get(postId) ?: return@onMessageDataCallbackQuery
refreshPostMessage(
postId,
chatId,
messageId
)
answer(query)
}
api.forceRefreshFlow.subscribeSafelyWithoutExceptions(this) {
val (chatId, messageId) = postsMessages.get(it) ?: return@subscribeSafelyWithoutExceptions
updatePost(it, chatId, messageId)
refreshPostMessage(it, chatId, messageId)
}
}
}

View File

@@ -273,6 +273,7 @@ object Plugin : Plugin {
attachPoll(postId)
}
}
answer(it)
}
}
}

View File

@@ -13,19 +13,24 @@
"dev.inmo.plaguposter.ratings.source.Plugin",
"dev.inmo.plaguposter.ratings.selector.Plugin",
"dev.inmo.plaguposter.triggers.selector_with_timer.Plugin",
"dev.inmo.plaguposter.ratings.gc.Plugin",
"dev.inmo.plaguposter.inlines.Plugin",
"dev.inmo.plaguposter.triggers.command.Plugin"
"dev.inmo.plaguposter.triggers.command.Plugin",
"dev.inmo.plaguposter.posts.panel.Plugin"
],
"posts": {
"targetChat": 12345678,
"cacheChat": 12345678,
"sourceChat": 12345678
"chats": {
"targetChat": 12345678,
"cacheChat": 12345678,
"sourceChat": 12345678
}
},
"ratingsPolls": {
"variants": {
"Ok": 1,
"Not ok": -1
"Круть": 2,
"Ок": 1,
"Не ок": -1,
"Совсем не ок": -2,
"Посмотреть результаты": 0
},
"autoAttach": true,
"ratingOfferText": "What do you think about it?"
@@ -35,33 +40,18 @@
{
"time": {
"from": "00:00",
"to": "00:00"
"to": "23:59"
},
"rating": {
"min": 0.0,
"max": 1.0,
"prefer": "random"
"prefer": "max"
}
},
{
"time": {
"from": "00:00",
"from": "23:59",
"to": "00:00"
},
"rating": {
"min": 0.0,
"max": 1.0,
"prefer": "min"
}
},
{
"time": {
"from": "00:00",
"to": "00:00"
},
"rating": {
"min": 0.0,
"max": 1.0,
"prefer": "max"
}
}
@@ -70,11 +60,13 @@
"timer_trigger": {
"krontab": "0 30 2/4 * *"
},
"gc": {
"autoclear": {
"rating": -2,
"autoClearKrontab": "0 0 0 * *",
"skipPostAge": 86400
}
"panel": {
"textPrefix": "Post management:",
"buttonsPerRow": 2,
"parseMode": "MarkdownV2",
"deleteButtonText": "Delete"
},
"publish_command": {
"panelButtonText": "Publish"
}
}