From f10bb5c3e08bc7df42e293484828362c30a0312b Mon Sep 17 00:00:00 2001 From: Maybe Waffle Date: Mon, 12 Sep 2022 16:50:59 +0400 Subject: [PATCH] Properly handle callback queries in `examples/buttons.rs` Former-commit-id: 376ffc85f9a89a38aa26d544d515fcca121854ce --- examples/buttons.rs | 20 +++++++++++--------- 1 file changed, 11 insertions(+), 9 deletions(-) diff --git a/examples/buttons.rs b/examples/buttons.rs index 8ce0e21a..e2a54bfe 100644 --- a/examples/buttons.rs +++ b/examples/buttons.rs @@ -112,15 +112,17 @@ async fn callback_handler( if let Some(version) = q.data { let text = format!("You chose: {version}"); - match q.message { - Some(Message { id, chat, .. }) => { - bot.edit_message_text(chat.id, id, text).await?; - } - None => { - if let Some(id) = q.inline_message_id { - bot.edit_message_text_inline(id, text).await?; - } - } + // Tell telegram that we've seen this query, to remove 🕑 icons from the + // + // clients. You could also use `answer_callback_query`'s optional + // parameters to tweak what happens on the client side. + bot.answer_callback_query(q.id).await?; + + // Edit text of the message to which the buttons were attached + if let Some(Message { id, chat, .. }) = q.message { + bot.edit_message_text(chat.id, id, text).await?; + } else if let Some(id) = q.inline_message_id { + bot.edit_message_text_inline(id, text).await?; } log::info!("You chose: {}", version);