|
|
|
@ -4,19 +4,23 @@ use serenity::builder::CreateMessage;
|
|
|
|
|
use serenity::client::Context;
|
|
|
|
|
use serenity::model::id::ChannelId;
|
|
|
|
|
use serenity_rich_interaction::core::EXTRA_LONG_TIMEOUT;
|
|
|
|
|
use serenity_rich_interaction::menu::{display_page, MenuBuilder, Page};
|
|
|
|
|
use serenity_rich_interaction::menu::{
|
|
|
|
|
close_menu, display_page, MenuBuilder, Page, CLOSE_MENU_EMOJI,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
static REFRESH_CONTROL: &str = "🔄";
|
|
|
|
|
static REFRESH_EMOJI: &str = "🔄";
|
|
|
|
|
|
|
|
|
|
pub async fn create_inspirobot_menu(ctx: &Context, channel_id: ChannelId) -> BotResult<()> {
|
|
|
|
|
MenuBuilder::default()
|
|
|
|
|
.add_control(0, REFRESH_CONTROL, |ctx, menu, _r| {
|
|
|
|
|
.add_control(0, REFRESH_EMOJI, |ctx, menu, _r| {
|
|
|
|
|
Box::pin(async move {
|
|
|
|
|
display_page(ctx, menu).await?;
|
|
|
|
|
Ok(())
|
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
.add_help(REFRESH_CONTROL, "Creates a new inspiring image.")
|
|
|
|
|
.add_help(REFRESH_EMOJI, "Creates a new inspiring image.")
|
|
|
|
|
.add_control(1, CLOSE_MENU_EMOJI, |c, m, r| Box::pin(close_menu(c, m, r)))
|
|
|
|
|
.add_help(CLOSE_MENU_EMOJI, "Closes this menu.")
|
|
|
|
|
.show_help()
|
|
|
|
|
.add_page(Page::new_builder(|| {
|
|
|
|
|
Box::pin(async {
|
|
|
|
@ -36,7 +40,11 @@ pub async fn create_inspirobot_menu(ctx: &Context, channel_id: ChannelId) -> Bot
|
|
|
|
|
async fn create_inspirobot_page<'a>() -> BotResult<CreateMessage<'a>> {
|
|
|
|
|
let image = get_inspirobot_image().await?;
|
|
|
|
|
let mut message = CreateMessage::default();
|
|
|
|
|
message.embed(|e| e.image(image).title("Be inspired"));
|
|
|
|
|
message.embed(|e| {
|
|
|
|
|
e.image(image)
|
|
|
|
|
.title("Be inspired")
|
|
|
|
|
.footer(|f| f.text("Powered by inspirobot.me"))
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
Ok(message)
|
|
|
|
|
}
|
|
|
|
|