From 346fbe3d5e238c10fc59d5950d347a78a0ae045e Mon Sep 17 00:00:00 2001 From: Inaha Date: Wed, 27 Mar 2024 21:14:59 +0800 Subject: [PATCH] feature: add first,previous,next,last selections in item page --- resources/ui/item.ui | 55 +++++++++++++++++++++++++++++++++--------- src/ui/widgets/item.rs | 42 ++++++++++++++++++++++++++++++++ 2 files changed, 85 insertions(+), 12 deletions(-) diff --git a/resources/ui/item.ui b/resources/ui/item.ui index ae0be467..9cff20c8 100644 --- a/resources/ui/item.ui +++ b/resources/ui/item.ui @@ -40,11 +40,11 @@ - 30 - 15 - 150 - start - start + 30 + 15 + 150 + start + start @@ -52,21 +52,52 @@ horizontal + 6 + true + + + end + go-first-symbolic + item.first + true + + + + + end + go-previous-symbolic + item.previous + + + + + end + go-next-symbolic + item.next + + + + + end + go-last-symbolic + item.last + + - - never - fill - 3 + + 700 + False - - 700 - False + + never + fill + 3 horizontal diff --git a/src/ui/widgets/item.rs b/src/ui/widgets/item.rs index 5c7abb03..ca7587f1 100644 --- a/src/ui/widgets/item.rs +++ b/src/ui/widgets/item.rs @@ -1,6 +1,8 @@ use glib::Object; use gtk::prelude::*; use gtk::{gio, glib}; +use adw::subclass::prelude::*; + mod imp { use crate::ui::network::{self, runtime}; use adw::subclass::prelude::*; @@ -45,6 +47,18 @@ mod imp { fn class_init(klass: &mut Self::Class) { klass.bind_template(); + klass.install_action("item.first", None, move |window, _action, _parameter| { + window.itemfirst(); + }); + klass.install_action("item.previous", None, move |window, _action, _parameter| { + window.itemprevious(); + }); + klass.install_action("item.next", None, move |window, _action, _parameter| { + window.itemnext(); + }); + klass.install_action("item.last", None, move |window, _action, _parameter| { + window.itemlast(); + }); } fn instance_init(obj: &InitializingObject) { @@ -267,4 +281,32 @@ impl ItemPage { osd.append(&logo); osd.add_css_class("logo"); } + + pub fn itemfirst(&self) { + let imp = self.imp(); + imp.itemlist.scroll_to(0, gtk::ListScrollFlags::SELECT, None); + } + + pub fn itemprevious(&self) { + let imp = self.imp(); + let selection = &imp.selection; + let position = selection.selected(); + if position > 0 { + imp.itemlist.scroll_to(position - 1, gtk::ListScrollFlags::SELECT, None); + } + } + + pub fn itemnext(&self) { + let imp = self.imp(); + let selection = &imp.selection; + let position = selection.selected(); + if position < imp.itemlist.model().unwrap().n_items() { + imp.itemlist.scroll_to(position + 1, gtk::ListScrollFlags::SELECT, None); + } + } + + pub fn itemlast(&self) { + let imp = self.imp(); + imp.itemlist.scroll_to(imp.itemlist.model().unwrap().n_items() - 1, gtk::ListScrollFlags::SELECT, None); + } }