Make search work again
This commit is contained in:
parent
5ee898c9c5
commit
0fe6bf1db2
@ -121,7 +121,11 @@ impl SimpleComponent for AppModel {
|
|||||||
fn update(&mut self, message: Self::Input, _sender: ComponentSender<Self>) {
|
fn update(&mut self, message: Self::Input, _sender: ComponentSender<Self>) {
|
||||||
match message {
|
match message {
|
||||||
AppInput::SheetPressed(sheet) => opener::open(sheet).unwrap(),
|
AppInput::SheetPressed(sheet) => opener::open(sheet).unwrap(),
|
||||||
AppInput::SearchStarted(query) => {} //self.sheet_listing.emit(SheetListingInput { query }),
|
AppInput::SearchStarted(query) => {
|
||||||
|
self.sheets_and_files_listing
|
||||||
|
.emit(SheetListingInput::Query(query.clone()));
|
||||||
|
self.new_files_listing.emit(SheetListingInput::Query(query));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,23 +1,28 @@
|
|||||||
use std::path::PathBuf;
|
use std::path::PathBuf;
|
||||||
|
|
||||||
use gtk::prelude::*;
|
use gtk::prelude::*;
|
||||||
|
use log::debug;
|
||||||
use relm4::factory::FactoryVecDeque;
|
use relm4::factory::FactoryVecDeque;
|
||||||
use relm4::prelude::*;
|
|
||||||
use relm4::{
|
use relm4::{
|
||||||
gtk, Component, ComponentController, ComponentParts, ComponentSender, SimpleComponent,
|
gtk, Component, ComponentController, ComponentParts, ComponentSender, SimpleComponent,
|
||||||
};
|
};
|
||||||
|
use relm4::{prelude::*, RelmListBoxExt};
|
||||||
use walkdir::WalkDir;
|
use walkdir::WalkDir;
|
||||||
|
|
||||||
use super::sheet_model::{SheetModel, SheetModelType};
|
use super::sheet_model::{OnQueryUpdate, SheetModel, SheetModelType};
|
||||||
|
|
||||||
pub struct SheetListingModel {
|
pub struct SheetListingModel {
|
||||||
query: String,
|
|
||||||
sheets: FactoryVecDeque<SheetModel>,
|
sheets: FactoryVecDeque<SheetModel>,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub struct SheetListingInput {
|
pub enum SheetListingInput {
|
||||||
pub query: String,
|
Query(String),
|
||||||
|
ListBoxRowClicked(i32),
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct SheetModelSelected {
|
||||||
|
sheet_model_type: SheetModelType,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[relm4::component(pub)]
|
#[relm4::component(pub)]
|
||||||
@ -31,10 +36,14 @@ impl SimpleComponent for SheetListingModel {
|
|||||||
gtk::Box {
|
gtk::Box {
|
||||||
// set_orientation: gtk::Orientation::Vertical,
|
// set_orientation: gtk::Orientation::Vertical,
|
||||||
|
|
||||||
model.sheets.widget() -> >k::ListBox {
|
model.sheets.widget() -> &relm4::gtk::ListBox {
|
||||||
set_hexpand: true,
|
set_hexpand: true,
|
||||||
// set_orientation: gtk::Orientation::Vertical,
|
// set_orientation: gtk::Orientation::Vertical,
|
||||||
// set_spacing: 5,
|
// set_spacing: 5,
|
||||||
|
connect_row_activated[sender] => move |list_box, row| {
|
||||||
|
let index = list_box.index_of_child(row).unwrap();
|
||||||
|
sender.input(SheetListingInput::ListBoxRowClicked(index));
|
||||||
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -49,15 +58,20 @@ impl SimpleComponent for SheetListingModel {
|
|||||||
sheets.guard().push_back(sheet_model_type);
|
sheets.guard().push_back(sheet_model_type);
|
||||||
}
|
}
|
||||||
|
|
||||||
let model = SheetListingModel {
|
let model = SheetListingModel { sheets };
|
||||||
query: String::new(),
|
|
||||||
sheets,
|
|
||||||
};
|
|
||||||
let widgets = view_output!();
|
let widgets = view_output!();
|
||||||
ComponentParts { model, widgets }
|
ComponentParts { model, widgets }
|
||||||
}
|
}
|
||||||
|
|
||||||
fn update(&mut self, message: Self::Input, _sender: ComponentSender<Self>) {
|
fn update(&mut self, message: Self::Input, _sender: ComponentSender<Self>) {
|
||||||
self.query = message.query;
|
match message {
|
||||||
|
SheetListingInput::Query(query) => {
|
||||||
|
self.sheets.broadcast(OnQueryUpdate { query });
|
||||||
|
}
|
||||||
|
SheetListingInput::ListBoxRowClicked(index) => {
|
||||||
|
let x = self.sheets.get(index as usize).unwrap();
|
||||||
|
debug!("clicked: {}!!!!!", x.label);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -13,7 +13,16 @@ pub enum SheetModelType {
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub struct SheetModel {
|
pub struct SheetModel {
|
||||||
label: String,
|
pub label: String,
|
||||||
|
visible: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Debug)]
|
||||||
|
pub struct RowActivated;
|
||||||
|
|
||||||
|
#[derive(Debug, Clone)]
|
||||||
|
pub struct OnQueryUpdate {
|
||||||
|
pub query: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[relm4::factory(pub)]
|
#[relm4::factory(pub)]
|
||||||
@ -22,12 +31,14 @@ impl FactoryComponent for SheetModel {
|
|||||||
type ParentWidget = gtk::ListBox;
|
type ParentWidget = gtk::ListBox;
|
||||||
type CommandOutput = ();
|
type CommandOutput = ();
|
||||||
type ParentInput = SheetListingInput;
|
type ParentInput = SheetListingInput;
|
||||||
type Input = ();
|
type Input = OnQueryUpdate;
|
||||||
type Output = ();
|
type Output = RowActivated;
|
||||||
|
|
||||||
view! {
|
view! {
|
||||||
#[root]
|
#[root]
|
||||||
gtk::ListBoxRow {
|
gtk::ListBoxRow {
|
||||||
|
#[watch]
|
||||||
|
set_visible: self.visible,
|
||||||
gtk::Box {
|
gtk::Box {
|
||||||
set_orientation: gtk::Orientation::Vertical,
|
set_orientation: gtk::Orientation::Vertical,
|
||||||
append = >k::Label {
|
append = >k::Label {
|
||||||
@ -41,10 +52,25 @@ impl FactoryComponent for SheetModel {
|
|||||||
|
|
||||||
fn init_model(value: Self::Init, _index: &DynamicIndex, _sender: FactorySender<Self>) -> Self {
|
fn init_model(value: Self::Init, _index: &DynamicIndex, _sender: FactorySender<Self>) -> Self {
|
||||||
let label = match value {
|
let label = match value {
|
||||||
SheetModelType::Sheet { sheet } => sheet.name,
|
SheetModelType::Sheet { sheet } => format!("{}", sheet.name),
|
||||||
SheetModelType::Pdf { path } => path.file_name().unwrap().to_str().unwrap().to_string(),
|
SheetModelType::Pdf { path } => {
|
||||||
|
format!("{}", path.file_name().unwrap().to_str().unwrap())
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
SheetModel { label }
|
SheetModel {
|
||||||
|
label,
|
||||||
|
visible: true,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn update(&mut self, msg: Self::Input, _sender: FactorySender<Self>) {
|
||||||
|
let query = msg.query.to_ascii_lowercase();
|
||||||
|
let split = query.split_ascii_whitespace();
|
||||||
|
let label = self.label.to_ascii_lowercase();
|
||||||
|
|
||||||
|
self.visible = split
|
||||||
|
.into_iter()
|
||||||
|
.all(|query_part| label.contains(query_part));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user