turned pager into a single type
This commit is contained in:
parent
a362a24cfc
commit
4490f19c04
@ -13,7 +13,7 @@ use serenity::{builder::CreateEmbed, client::Context, model::channel::Channel};
|
|||||||
use crate::{
|
use crate::{
|
||||||
check_subscription_on_message,
|
check_subscription_on_message,
|
||||||
component_models::{
|
component_models::{
|
||||||
pager::{DelPager, LookPager, Pager},
|
pager::{DelData, LookData, Pager},
|
||||||
ComponentDataModel, DelSelector,
|
ComponentDataModel, DelSelector,
|
||||||
},
|
},
|
||||||
consts::{
|
consts::{
|
||||||
@ -329,7 +329,7 @@ async fn look(ctx: &Context, invoke: &mut CommandInvoke, args: CommandOptions) {
|
|||||||
.fold(0, |t, r| t + r.len())
|
.fold(0, |t, r| t + r.len())
|
||||||
.div_ceil(EMBED_DESCRIPTION_MAX_LENGTH);
|
.div_ceil(EMBED_DESCRIPTION_MAX_LENGTH);
|
||||||
|
|
||||||
let pager = LookPager::new(flags, timezone);
|
let pager = Pager::new(0, LookData { flags, timezone });
|
||||||
|
|
||||||
invoke
|
invoke
|
||||||
.respond(
|
.respond(
|
||||||
@ -395,7 +395,7 @@ pub fn show_delete_page(
|
|||||||
page: usize,
|
page: usize,
|
||||||
timezone: Tz,
|
timezone: Tz,
|
||||||
) -> CreateGenericResponse {
|
) -> CreateGenericResponse {
|
||||||
let pager = DelPager::new(page, timezone);
|
let pager = Pager::new(page, DelData { timezone });
|
||||||
|
|
||||||
if reminders.is_empty() {
|
if reminders.is_empty() {
|
||||||
return CreateGenericResponse::new()
|
return CreateGenericResponse::new()
|
||||||
|
@ -3,7 +3,7 @@ use serenity::client::Context;
|
|||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
component_models::{
|
component_models::{
|
||||||
pager::{Pager, TodoPager},
|
pager::{Pager, TodoData},
|
||||||
ComponentDataModel, TodoSelector,
|
ComponentDataModel, TodoSelector,
|
||||||
},
|
},
|
||||||
consts::{EMBED_DESCRIPTION_MAX_LENGTH, SELECT_MAX_ENTRIES, THEME_COLOR},
|
consts::{EMBED_DESCRIPTION_MAX_LENGTH, SELECT_MAX_ENTRIES, THEME_COLOR},
|
||||||
@ -136,7 +136,7 @@ pub fn show_todo_page(
|
|||||||
channel_id: Option<u64>,
|
channel_id: Option<u64>,
|
||||||
guild_id: Option<u64>,
|
guild_id: Option<u64>,
|
||||||
) -> CreateGenericResponse {
|
) -> CreateGenericResponse {
|
||||||
let pager = TodoPager::new(page, user_id, channel_id, guild_id);
|
let pager = Pager::new(page, TodoData { user_id, channel_id, guild_id });
|
||||||
|
|
||||||
let pages = max_todo_page(todo_values);
|
let pages = max_todo_page(todo_values);
|
||||||
let mut page = page;
|
let mut page = page;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
pub(crate) mod pager;
|
pub mod pager;
|
||||||
|
|
||||||
use std::io::Cursor;
|
use std::io::Cursor;
|
||||||
|
|
||||||
@ -21,7 +21,7 @@ use crate::{
|
|||||||
reminder_cmds::{max_delete_page, show_delete_page},
|
reminder_cmds::{max_delete_page, show_delete_page},
|
||||||
todo_cmds::{max_todo_page, show_todo_page},
|
todo_cmds::{max_todo_page, show_todo_page},
|
||||||
},
|
},
|
||||||
component_models::pager::{DelPager, LookPager, Pager, TodoPager},
|
component_models::pager::{DelData, LookData, Pager, TodoData},
|
||||||
consts::{EMBED_DESCRIPTION_MAX_LENGTH, THEME_COLOR},
|
consts::{EMBED_DESCRIPTION_MAX_LENGTH, THEME_COLOR},
|
||||||
framework::CommandInvoke,
|
framework::CommandInvoke,
|
||||||
models::reminder::Reminder,
|
models::reminder::Reminder,
|
||||||
@ -29,15 +29,14 @@ use crate::{
|
|||||||
};
|
};
|
||||||
|
|
||||||
#[derive(Deserialize, Serialize)]
|
#[derive(Deserialize, Serialize)]
|
||||||
#[serde(tag = "type")]
|
#[serde(untagged)]
|
||||||
#[repr(u8)]
|
|
||||||
pub enum ComponentDataModel {
|
pub enum ComponentDataModel {
|
||||||
Restrict(Restrict),
|
Restrict(Restrict),
|
||||||
LookPager(LookPager),
|
|
||||||
DelPager(DelPager),
|
|
||||||
TodoPager(TodoPager),
|
|
||||||
DelSelector(DelSelector),
|
DelSelector(DelSelector),
|
||||||
TodoSelector(TodoSelector),
|
TodoSelector(TodoSelector),
|
||||||
|
LookPager(Pager<LookData>),
|
||||||
|
DelPager(Pager<DelData>),
|
||||||
|
TodoPager(Pager<TodoData>),
|
||||||
}
|
}
|
||||||
|
|
||||||
impl ComponentDataModel {
|
impl ComponentDataModel {
|
||||||
@ -94,7 +93,7 @@ INSERT IGNORE INTO roles (role, name, guild_id) VALUES (?, \"Role\", (SELECT id
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
ComponentDataModel::LookPager(pager) => {
|
ComponentDataModel::LookPager(pager) => {
|
||||||
let flags = pager.flags;
|
let flags = pager.data.flags;
|
||||||
|
|
||||||
let channel_opt = component.channel_id.to_channel_cached(&ctx);
|
let channel_opt = component.channel_id.to_channel_cached(&ctx);
|
||||||
|
|
||||||
@ -112,7 +111,7 @@ INSERT IGNORE INTO roles (role, name, guild_id) VALUES (?, \"Role\", (SELECT id
|
|||||||
|
|
||||||
let pages = reminders
|
let pages = reminders
|
||||||
.iter()
|
.iter()
|
||||||
.map(|reminder| reminder.display(&flags, &pager.timezone))
|
.map(|reminder| reminder.display(&flags, &pager.data.timezone))
|
||||||
.fold(0, |t, r| t + r.len())
|
.fold(0, |t, r| t + r.len())
|
||||||
.div_ceil(EMBED_DESCRIPTION_MAX_LENGTH);
|
.div_ceil(EMBED_DESCRIPTION_MAX_LENGTH);
|
||||||
|
|
||||||
@ -130,7 +129,7 @@ INSERT IGNORE INTO roles (role, name, guild_id) VALUES (?, \"Role\", (SELECT id
|
|||||||
|
|
||||||
let display = reminders
|
let display = reminders
|
||||||
.iter()
|
.iter()
|
||||||
.map(|reminder| reminder.display(&flags, &pager.timezone))
|
.map(|reminder| reminder.display(&flags, &pager.data.timezone))
|
||||||
.skip_while(|p| {
|
.skip_while(|p| {
|
||||||
skip_char_count += p.len();
|
skip_char_count += p.len();
|
||||||
|
|
||||||
@ -172,9 +171,10 @@ INSERT IGNORE INTO roles (role, name, guild_id) VALUES (?, \"Role\", (SELECT id
|
|||||||
let reminders =
|
let reminders =
|
||||||
Reminder::from_guild(ctx, component.guild_id, component.user.id).await;
|
Reminder::from_guild(ctx, component.guild_id, component.user.id).await;
|
||||||
|
|
||||||
let max_pages = max_delete_page(&reminders, &pager.timezone);
|
let max_pages = max_delete_page(&reminders, &pager.data.timezone);
|
||||||
|
|
||||||
let resp = show_delete_page(&reminders, pager.next_page(max_pages), pager.timezone);
|
let resp =
|
||||||
|
show_delete_page(&reminders, pager.next_page(max_pages), pager.data.timezone);
|
||||||
|
|
||||||
let mut invoke = CommandInvoke::component(component);
|
let mut invoke = CommandInvoke::component(component);
|
||||||
let _ = invoke.respond(&ctx, resp).await;
|
let _ = invoke.respond(&ctx, resp).await;
|
||||||
@ -202,9 +202,9 @@ INSERT IGNORE INTO roles (role, name, guild_id) VALUES (?, \"Role\", (SELECT id
|
|||||||
let values = sqlx::query!(
|
let values = sqlx::query!(
|
||||||
// fucking braindead mysql use <=> instead of = for null comparison
|
// fucking braindead mysql use <=> instead of = for null comparison
|
||||||
"SELECT id, value FROM todos WHERE user_id <=> ? AND channel_id <=> ? AND guild_id <=> ?",
|
"SELECT id, value FROM todos WHERE user_id <=> ? AND channel_id <=> ? AND guild_id <=> ?",
|
||||||
pager.user_id,
|
pager.data.user_id,
|
||||||
pager.channel_id,
|
pager.data.channel_id,
|
||||||
pager.guild_id,
|
pager.data.guild_id,
|
||||||
)
|
)
|
||||||
.fetch_all(&pool)
|
.fetch_all(&pool)
|
||||||
.await
|
.await
|
||||||
@ -218,9 +218,9 @@ INSERT IGNORE INTO roles (role, name, guild_id) VALUES (?, \"Role\", (SELECT id
|
|||||||
let resp = show_todo_page(
|
let resp = show_todo_page(
|
||||||
&values,
|
&values,
|
||||||
pager.next_page(max_pages),
|
pager.next_page(max_pages),
|
||||||
pager.user_id,
|
pager.data.user_id,
|
||||||
pager.channel_id,
|
pager.data.channel_id,
|
||||||
pager.guild_id,
|
pager.data.guild_id,
|
||||||
);
|
);
|
||||||
|
|
||||||
let mut invoke = CommandInvoke::component(component);
|
let mut invoke = CommandInvoke::component(component);
|
||||||
|
@ -1,15 +1,87 @@
|
|||||||
// todo split pager out into a single struct
|
|
||||||
use chrono_tz::Tz;
|
use chrono_tz::Tz;
|
||||||
|
use rmp_serde::Serializer;
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use serde_repr::*;
|
use serde_repr::*;
|
||||||
use serenity::{builder::CreateComponents, model::interactions::message_component::ButtonStyle};
|
use serenity::{builder::CreateComponents, model::interactions::message_component::ButtonStyle};
|
||||||
|
|
||||||
use crate::{component_models::ComponentDataModel, models::reminder::look_flags::LookFlags};
|
use crate::{component_models::ComponentDataModel, models::reminder::look_flags::LookFlags};
|
||||||
|
|
||||||
pub trait Pager {
|
#[derive(Serialize, Deserialize)]
|
||||||
fn next_page(&self, max_pages: usize) -> usize;
|
pub struct Pager<D> {
|
||||||
|
pub page: usize,
|
||||||
|
action: PageAction,
|
||||||
|
pub data: D,
|
||||||
|
}
|
||||||
|
|
||||||
fn create_button_row(&self, max_pages: usize, comp: &mut CreateComponents);
|
impl<D> Pager<D>
|
||||||
|
where
|
||||||
|
D: Serialize + Clone,
|
||||||
|
{
|
||||||
|
pub fn new(page: usize, data: D) -> Self {
|
||||||
|
Self { page, action: PageAction::Refresh, data }
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn next_page(&self, max_pages: usize) -> usize {
|
||||||
|
match self.action {
|
||||||
|
PageAction::First => 0,
|
||||||
|
PageAction::Previous => 0.max(self.page - 1),
|
||||||
|
PageAction::Refresh => self.page,
|
||||||
|
PageAction::Next => (max_pages - 1).min(self.page + 1),
|
||||||
|
PageAction::Last => max_pages - 1,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn to_custom_id(&self) -> String {
|
||||||
|
let mut buf = Vec::new();
|
||||||
|
self.serialize(&mut Serializer::new(&mut buf)).unwrap();
|
||||||
|
base64::encode(buf)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn buttons(&self, page: usize) -> (Pager<D>, Pager<D>, Pager<D>, Pager<D>, Pager<D>) {
|
||||||
|
(
|
||||||
|
Pager { page, action: PageAction::First, data: self.data.clone() },
|
||||||
|
Pager { page, action: PageAction::Previous, data: self.data.clone() },
|
||||||
|
Pager { page, action: PageAction::Refresh, data: self.data.clone() },
|
||||||
|
Pager { page, action: PageAction::Next, data: self.data.clone() },
|
||||||
|
Pager { page, action: PageAction::Last, data: self.data.clone() },
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn create_button_row(&self, max_pages: usize, comp: &mut CreateComponents) {
|
||||||
|
let next_page = self.next_page(max_pages);
|
||||||
|
|
||||||
|
let (page_first, page_prev, page_refresh, page_next, page_last) = self.buttons(next_page);
|
||||||
|
|
||||||
|
comp.create_action_row(|row| {
|
||||||
|
row.create_button(|b| {
|
||||||
|
b.label("⏮️")
|
||||||
|
.style(ButtonStyle::Primary)
|
||||||
|
.custom_id(page_first.to_custom_id())
|
||||||
|
.disabled(next_page == 0)
|
||||||
|
})
|
||||||
|
.create_button(|b| {
|
||||||
|
b.label("◀️")
|
||||||
|
.style(ButtonStyle::Secondary)
|
||||||
|
.custom_id(page_prev.to_custom_id())
|
||||||
|
.disabled(next_page == 0)
|
||||||
|
})
|
||||||
|
.create_button(|b| {
|
||||||
|
b.label("🔁").style(ButtonStyle::Secondary).custom_id(page_refresh.to_custom_id())
|
||||||
|
})
|
||||||
|
.create_button(|b| {
|
||||||
|
b.label("▶️")
|
||||||
|
.style(ButtonStyle::Secondary)
|
||||||
|
.custom_id(page_next.to_custom_id())
|
||||||
|
.disabled(next_page + 1 == max_pages)
|
||||||
|
})
|
||||||
|
.create_button(|b| {
|
||||||
|
b.label("⏭️")
|
||||||
|
.style(ButtonStyle::Primary)
|
||||||
|
.custom_id(page_last.to_custom_id())
|
||||||
|
.disabled(next_page + 1 == max_pages)
|
||||||
|
})
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize_repr, Deserialize_repr)]
|
#[derive(Serialize_repr, Deserialize_repr)]
|
||||||
@ -22,311 +94,20 @@ enum PageAction {
|
|||||||
Last = 4,
|
Last = 4,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Deserialize, Serialize, Clone)]
|
||||||
pub struct LookPager {
|
pub struct LookData {
|
||||||
pub flags: LookFlags,
|
pub flags: LookFlags,
|
||||||
pub page: usize,
|
|
||||||
action: PageAction,
|
|
||||||
pub timezone: Tz,
|
pub timezone: Tz,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Pager for LookPager {
|
#[derive(Deserialize, Serialize, Clone)]
|
||||||
fn next_page(&self, max_pages: usize) -> usize {
|
pub struct DelData {
|
||||||
match self.action {
|
|
||||||
PageAction::First => 0,
|
|
||||||
PageAction::Previous => 0.max(self.page - 1),
|
|
||||||
PageAction::Refresh => self.page,
|
|
||||||
PageAction::Next => (max_pages - 1).min(self.page + 1),
|
|
||||||
PageAction::Last => max_pages - 1,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn create_button_row(&self, max_pages: usize, comp: &mut CreateComponents) {
|
|
||||||
let next_page = self.next_page(max_pages);
|
|
||||||
|
|
||||||
let (page_first, page_prev, page_refresh, page_next, page_last) =
|
|
||||||
LookPager::buttons(self.flags, next_page, self.timezone);
|
|
||||||
|
|
||||||
comp.create_action_row(|row| {
|
|
||||||
row.create_button(|b| {
|
|
||||||
b.label("⏮️")
|
|
||||||
.style(ButtonStyle::Primary)
|
|
||||||
.custom_id(page_first.to_custom_id())
|
|
||||||
.disabled(next_page == 0)
|
|
||||||
})
|
|
||||||
.create_button(|b| {
|
|
||||||
b.label("◀️")
|
|
||||||
.style(ButtonStyle::Secondary)
|
|
||||||
.custom_id(page_prev.to_custom_id())
|
|
||||||
.disabled(next_page == 0)
|
|
||||||
})
|
|
||||||
.create_button(|b| {
|
|
||||||
b.label("🔁").style(ButtonStyle::Secondary).custom_id(page_refresh.to_custom_id())
|
|
||||||
})
|
|
||||||
.create_button(|b| {
|
|
||||||
b.label("▶️")
|
|
||||||
.style(ButtonStyle::Secondary)
|
|
||||||
.custom_id(page_next.to_custom_id())
|
|
||||||
.disabled(next_page + 1 == max_pages)
|
|
||||||
})
|
|
||||||
.create_button(|b| {
|
|
||||||
b.label("⏭️")
|
|
||||||
.style(ButtonStyle::Primary)
|
|
||||||
.custom_id(page_last.to_custom_id())
|
|
||||||
.disabled(next_page + 1 == max_pages)
|
|
||||||
})
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl LookPager {
|
|
||||||
pub fn new(flags: LookFlags, timezone: Tz) -> Self {
|
|
||||||
Self { flags, page: 0, action: PageAction::First, timezone }
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn buttons(
|
|
||||||
flags: LookFlags,
|
|
||||||
page: usize,
|
|
||||||
timezone: Tz,
|
|
||||||
) -> (
|
|
||||||
ComponentDataModel,
|
|
||||||
ComponentDataModel,
|
|
||||||
ComponentDataModel,
|
|
||||||
ComponentDataModel,
|
|
||||||
ComponentDataModel,
|
|
||||||
) {
|
|
||||||
(
|
|
||||||
ComponentDataModel::LookPager(LookPager {
|
|
||||||
flags,
|
|
||||||
page,
|
|
||||||
action: PageAction::First,
|
|
||||||
timezone,
|
|
||||||
}),
|
|
||||||
ComponentDataModel::LookPager(LookPager {
|
|
||||||
flags,
|
|
||||||
page,
|
|
||||||
action: PageAction::Previous,
|
|
||||||
timezone,
|
|
||||||
}),
|
|
||||||
ComponentDataModel::LookPager(LookPager {
|
|
||||||
flags,
|
|
||||||
page,
|
|
||||||
action: PageAction::Refresh,
|
|
||||||
timezone,
|
|
||||||
}),
|
|
||||||
ComponentDataModel::LookPager(LookPager {
|
|
||||||
flags,
|
|
||||||
page,
|
|
||||||
action: PageAction::Next,
|
|
||||||
timezone,
|
|
||||||
}),
|
|
||||||
ComponentDataModel::LookPager(LookPager {
|
|
||||||
flags,
|
|
||||||
page,
|
|
||||||
action: PageAction::Last,
|
|
||||||
timezone,
|
|
||||||
}),
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
|
||||||
pub struct DelPager {
|
|
||||||
pub page: usize,
|
|
||||||
action: PageAction,
|
|
||||||
pub timezone: Tz,
|
pub timezone: Tz,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Pager for DelPager {
|
#[derive(Deserialize, Serialize, Clone)]
|
||||||
fn next_page(&self, max_pages: usize) -> usize {
|
pub struct TodoData {
|
||||||
match self.action {
|
|
||||||
PageAction::First => 0,
|
|
||||||
PageAction::Previous => 0.max(self.page - 1),
|
|
||||||
PageAction::Refresh => self.page,
|
|
||||||
PageAction::Next => (max_pages - 1).min(self.page + 1),
|
|
||||||
PageAction::Last => max_pages - 1,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn create_button_row(&self, max_pages: usize, comp: &mut CreateComponents) {
|
|
||||||
let next_page = self.next_page(max_pages);
|
|
||||||
|
|
||||||
let (page_first, page_prev, page_refresh, page_next, page_last) =
|
|
||||||
DelPager::buttons(next_page, self.timezone);
|
|
||||||
|
|
||||||
comp.create_action_row(|row| {
|
|
||||||
row.create_button(|b| {
|
|
||||||
b.label("⏮️")
|
|
||||||
.style(ButtonStyle::Primary)
|
|
||||||
.custom_id(page_first.to_custom_id())
|
|
||||||
.disabled(next_page == 0)
|
|
||||||
})
|
|
||||||
.create_button(|b| {
|
|
||||||
b.label("◀️")
|
|
||||||
.style(ButtonStyle::Secondary)
|
|
||||||
.custom_id(page_prev.to_custom_id())
|
|
||||||
.disabled(next_page == 0)
|
|
||||||
})
|
|
||||||
.create_button(|b| {
|
|
||||||
b.label("🔁").style(ButtonStyle::Secondary).custom_id(page_refresh.to_custom_id())
|
|
||||||
})
|
|
||||||
.create_button(|b| {
|
|
||||||
b.label("▶️")
|
|
||||||
.style(ButtonStyle::Secondary)
|
|
||||||
.custom_id(page_next.to_custom_id())
|
|
||||||
.disabled(next_page + 1 == max_pages)
|
|
||||||
})
|
|
||||||
.create_button(|b| {
|
|
||||||
b.label("⏭️")
|
|
||||||
.style(ButtonStyle::Primary)
|
|
||||||
.custom_id(page_last.to_custom_id())
|
|
||||||
.disabled(next_page + 1 == max_pages)
|
|
||||||
})
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl DelPager {
|
|
||||||
pub fn new(page: usize, timezone: Tz) -> Self {
|
|
||||||
Self { page, action: PageAction::Refresh, timezone }
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn buttons(
|
|
||||||
page: usize,
|
|
||||||
timezone: Tz,
|
|
||||||
) -> (
|
|
||||||
ComponentDataModel,
|
|
||||||
ComponentDataModel,
|
|
||||||
ComponentDataModel,
|
|
||||||
ComponentDataModel,
|
|
||||||
ComponentDataModel,
|
|
||||||
) {
|
|
||||||
(
|
|
||||||
ComponentDataModel::DelPager(DelPager { page, action: PageAction::First, timezone }),
|
|
||||||
ComponentDataModel::DelPager(DelPager { page, action: PageAction::Previous, timezone }),
|
|
||||||
ComponentDataModel::DelPager(DelPager { page, action: PageAction::Refresh, timezone }),
|
|
||||||
ComponentDataModel::DelPager(DelPager { page, action: PageAction::Next, timezone }),
|
|
||||||
ComponentDataModel::DelPager(DelPager { page, action: PageAction::Last, timezone }),
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Deserialize, Serialize)]
|
|
||||||
pub struct TodoPager {
|
|
||||||
pub page: usize,
|
|
||||||
action: PageAction,
|
|
||||||
pub user_id: Option<u64>,
|
pub user_id: Option<u64>,
|
||||||
pub channel_id: Option<u64>,
|
pub channel_id: Option<u64>,
|
||||||
pub guild_id: Option<u64>,
|
pub guild_id: Option<u64>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Pager for TodoPager {
|
|
||||||
fn next_page(&self, max_pages: usize) -> usize {
|
|
||||||
match self.action {
|
|
||||||
PageAction::First => 0,
|
|
||||||
PageAction::Previous => 0.max(self.page - 1),
|
|
||||||
PageAction::Refresh => self.page,
|
|
||||||
PageAction::Next => (max_pages - 1).min(self.page + 1),
|
|
||||||
PageAction::Last => max_pages - 1,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn create_button_row(&self, max_pages: usize, comp: &mut CreateComponents) {
|
|
||||||
let next_page = self.next_page(max_pages);
|
|
||||||
|
|
||||||
let (page_first, page_prev, page_refresh, page_next, page_last) =
|
|
||||||
TodoPager::buttons(next_page, self.user_id, self.channel_id, self.guild_id);
|
|
||||||
|
|
||||||
comp.create_action_row(|row| {
|
|
||||||
row.create_button(|b| {
|
|
||||||
b.label("⏮️")
|
|
||||||
.style(ButtonStyle::Primary)
|
|
||||||
.custom_id(page_first.to_custom_id())
|
|
||||||
.disabled(next_page == 0)
|
|
||||||
})
|
|
||||||
.create_button(|b| {
|
|
||||||
b.label("◀️")
|
|
||||||
.style(ButtonStyle::Secondary)
|
|
||||||
.custom_id(page_prev.to_custom_id())
|
|
||||||
.disabled(next_page == 0)
|
|
||||||
})
|
|
||||||
.create_button(|b| {
|
|
||||||
b.label("🔁").style(ButtonStyle::Secondary).custom_id(page_refresh.to_custom_id())
|
|
||||||
})
|
|
||||||
.create_button(|b| {
|
|
||||||
b.label("▶️")
|
|
||||||
.style(ButtonStyle::Secondary)
|
|
||||||
.custom_id(page_next.to_custom_id())
|
|
||||||
.disabled(next_page + 1 == max_pages)
|
|
||||||
})
|
|
||||||
.create_button(|b| {
|
|
||||||
b.label("⏭️")
|
|
||||||
.style(ButtonStyle::Primary)
|
|
||||||
.custom_id(page_last.to_custom_id())
|
|
||||||
.disabled(next_page + 1 == max_pages)
|
|
||||||
})
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl TodoPager {
|
|
||||||
pub fn new(
|
|
||||||
page: usize,
|
|
||||||
user_id: Option<u64>,
|
|
||||||
channel_id: Option<u64>,
|
|
||||||
guild_id: Option<u64>,
|
|
||||||
) -> Self {
|
|
||||||
Self { page, action: PageAction::Refresh, user_id, channel_id, guild_id }
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn buttons(
|
|
||||||
page: usize,
|
|
||||||
user_id: Option<u64>,
|
|
||||||
channel_id: Option<u64>,
|
|
||||||
guild_id: Option<u64>,
|
|
||||||
) -> (
|
|
||||||
ComponentDataModel,
|
|
||||||
ComponentDataModel,
|
|
||||||
ComponentDataModel,
|
|
||||||
ComponentDataModel,
|
|
||||||
ComponentDataModel,
|
|
||||||
) {
|
|
||||||
(
|
|
||||||
ComponentDataModel::TodoPager(TodoPager {
|
|
||||||
page,
|
|
||||||
action: PageAction::First,
|
|
||||||
user_id,
|
|
||||||
channel_id,
|
|
||||||
guild_id,
|
|
||||||
}),
|
|
||||||
ComponentDataModel::TodoPager(TodoPager {
|
|
||||||
page,
|
|
||||||
action: PageAction::Previous,
|
|
||||||
user_id,
|
|
||||||
channel_id,
|
|
||||||
guild_id,
|
|
||||||
}),
|
|
||||||
ComponentDataModel::TodoPager(TodoPager {
|
|
||||||
page,
|
|
||||||
action: PageAction::Refresh,
|
|
||||||
user_id,
|
|
||||||
channel_id,
|
|
||||||
guild_id,
|
|
||||||
}),
|
|
||||||
ComponentDataModel::TodoPager(TodoPager {
|
|
||||||
page,
|
|
||||||
action: PageAction::Next,
|
|
||||||
user_id,
|
|
||||||
channel_id,
|
|
||||||
guild_id,
|
|
||||||
}),
|
|
||||||
ComponentDataModel::TodoPager(TodoPager {
|
|
||||||
page,
|
|
||||||
action: PageAction::Last,
|
|
||||||
user_id,
|
|
||||||
channel_id,
|
|
||||||
guild_id,
|
|
||||||
}),
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
Loading…
Reference in New Issue
Block a user