More logic for sorting direction
This commit is contained in:
parent
de24bbcf99
commit
5cccefbd4a
3 changed files with 33 additions and 27 deletions
|
|
@ -13,9 +13,9 @@ use crate :: { collection :: * , ui :: component :: * } ;
|
|||
|
||||
|
||||
|
||||
pub enum FilmsSortedBy { Name , ReleaseDate , Runtime }
|
||||
pub enum SeriesSortedBy { Name , FirstReleaseDate }
|
||||
pub enum SortingDirection { Ascending , Descending }
|
||||
# [ derive (PartialEq) ] pub enum FilmsSortedBy { Name , ReleaseDate , Runtime }
|
||||
# [ derive (PartialEq) ] pub enum SeriesSortedBy { Name , FirstReleaseDate }
|
||||
# [ derive (PartialEq) ] pub enum SortingDirection { Ascending , Descending }
|
||||
|
||||
pub struct CollatedFilmsGrid {
|
||||
film_widget_pairs : RefCell < Vec < ( Film , Box ) > > ,
|
||||
|
|
@ -27,37 +27,37 @@ pub struct CollatedSeriesGrid {
|
|||
}
|
||||
|
||||
impl CollatedFilmsGrid {
|
||||
pub fn new ( films : Vec <Film> , sorting : FilmsSortedBy ) -> Self {
|
||||
pub fn new ( films : Vec <Film> , sorting : FilmsSortedBy , direction : SortingDirection ) -> Self {
|
||||
let grid_widget = create_flow_box () ;
|
||||
let film_widget_pairs = RefCell :: new ( vec ! () ) ;
|
||||
|
||||
let component = Self { film_widget_pairs , grid_widget } ;
|
||||
component . set_films ( films , sorting ) ;
|
||||
component . set_films ( films , sorting , direction ) ;
|
||||
|
||||
component
|
||||
}
|
||||
|
||||
pub fn set_films ( & self , films : Vec <Film> , sorting : FilmsSortedBy ) {
|
||||
pub fn set_films ( & self , films : Vec <Film> , sorting : FilmsSortedBy , direction : SortingDirection ) {
|
||||
let widgets = films . iter ()
|
||||
. map (create_film_entry)
|
||||
. collect :: < Vec <_> > () ;
|
||||
* self . film_widget_pairs . borrow_mut () = zip ( films , widgets )
|
||||
. collect () ;
|
||||
|
||||
for ( _ , film_widget ) in self . sort_film_widget_pairs (sorting) {
|
||||
for ( _ , film_widget ) in self . sort_film_widget_pairs ( sorting , direction ) {
|
||||
self . grid_widget . append ( & film_widget ) ;
|
||||
}
|
||||
}
|
||||
|
||||
pub fn set_sorting ( & self , sorting : FilmsSortedBy ) {
|
||||
pub fn set_sorting ( & self , sorting : FilmsSortedBy , direction : SortingDirection ) {
|
||||
self . grid_widget . remove_all () ;
|
||||
|
||||
for ( _ , film_widget ) in self . sort_film_widget_pairs (sorting) {
|
||||
for ( _ , film_widget ) in self . sort_film_widget_pairs ( sorting , direction ) {
|
||||
self . grid_widget . append ( & film_widget ) ;
|
||||
}
|
||||
}
|
||||
|
||||
fn sort_film_widget_pairs ( & self , sorting : FilmsSortedBy ) -> Vec < ( Film , Box ) > {
|
||||
fn sort_film_widget_pairs ( & self , sorting : FilmsSortedBy , direction : SortingDirection ) -> Vec < ( Film , Box ) > {
|
||||
let mut sorted = Vec :: from (
|
||||
self . film_widget_pairs . borrow () . as_slice () ) ;
|
||||
|
||||
|
|
@ -69,7 +69,9 @@ impl CollatedFilmsGrid {
|
|||
FilmsSortedBy :: Runtime =>
|
||||
film_1 . runtime_minutes . cmp ( & film_2 . runtime_minutes ) ,
|
||||
} ) ;
|
||||
if direction == SortingDirection :: Descending { sorted . reverse () }
|
||||
|
||||
// See it, say it, ...
|
||||
sorted
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue