search: auto-focus search field on navigate
I'm going to add a search changelog on this commit since I forgot to do so previously. Fixes: https://linear.app/damus/issue/DECK-538/auto-focus-search-field-on-search-view Changelog-Added: Added fulltext search ui Signed-off-by: William Casarin <jb55@jb55.com>
This commit is contained in:
@@ -12,7 +12,7 @@ use tracing::{error, info, warn};
|
||||
|
||||
mod state;
|
||||
|
||||
pub use state::{SearchQueryState, SearchState};
|
||||
pub use state::{FocusState, SearchQueryState, SearchState};
|
||||
|
||||
pub struct SearchView<'a> {
|
||||
query: &'a mut SearchQueryState,
|
||||
@@ -57,7 +57,7 @@ impl<'a> SearchView<'a> {
|
||||
}
|
||||
|
||||
match self.query.state {
|
||||
SearchState::New => None,
|
||||
SearchState::New | SearchState::Navigating => None,
|
||||
|
||||
SearchState::Searched | SearchState::Typing => {
|
||||
if self.query.state == SearchState::Typing {
|
||||
@@ -163,7 +163,7 @@ fn search_box(query: &mut SearchQueryState, ui: &mut egui::Ui) -> bool {
|
||||
|
||||
// Search input field
|
||||
//let font_size = notedeck::fonts::get_font_size(ui.ctx(), &NotedeckTextStyle::Body);
|
||||
ui.add_sized(
|
||||
let response = ui.add_sized(
|
||||
[ui.available_width(), search_height],
|
||||
TextEdit::singleline(&mut query.string)
|
||||
.hint_text(RichText::new("Search notes...").weak())
|
||||
@@ -173,6 +173,11 @@ fn search_box(query: &mut SearchQueryState, ui: &mut egui::Ui) -> bool {
|
||||
.frame(false),
|
||||
);
|
||||
|
||||
if query.focus_state == FocusState::ShouldRequestFocus {
|
||||
response.request_focus();
|
||||
query.focus_state = FocusState::RequestedFocus;
|
||||
}
|
||||
|
||||
let after_len = query.string.len();
|
||||
|
||||
let changed = before_len != after_len;
|
||||
|
||||
@@ -6,9 +6,22 @@ use std::time::Duration;
|
||||
pub enum SearchState {
|
||||
Typing,
|
||||
Searched,
|
||||
Navigating,
|
||||
New,
|
||||
}
|
||||
|
||||
#[derive(Debug, Eq, PartialEq)]
|
||||
pub enum FocusState {
|
||||
/// Get ready to focus
|
||||
Navigating,
|
||||
|
||||
/// We should request focus when we stop navigating
|
||||
ShouldRequestFocus,
|
||||
|
||||
/// We already focused, we don't need to do that again
|
||||
RequestedFocus,
|
||||
}
|
||||
|
||||
/// Search query state that exists between frames
|
||||
#[derive(Debug)]
|
||||
pub struct SearchQueryState {
|
||||
@@ -20,6 +33,10 @@ pub struct SearchQueryState {
|
||||
/// again next frames
|
||||
pub state: SearchState,
|
||||
|
||||
/// A bit of context to know if we're navigating to the view. We
|
||||
/// can use this to know when to request focus on the textedit
|
||||
pub focus_state: FocusState,
|
||||
|
||||
/// When was the input updated? We use this to debounce searches
|
||||
pub debouncer: Debouncer,
|
||||
|
||||
@@ -39,6 +56,7 @@ impl SearchQueryState {
|
||||
string: "".to_string(),
|
||||
state: SearchState::New,
|
||||
notes: TimelineTab::default(),
|
||||
focus_state: FocusState::Navigating,
|
||||
debouncer: Debouncer::new(Duration::from_millis(200)),
|
||||
}
|
||||
}
|
||||
|
||||
@@ -324,7 +324,6 @@ impl<'a> DesktopSidePanel<'a> {
|
||||
}
|
||||
SidePanelAction::Search => {
|
||||
// TODO
|
||||
info!("Clicked search button");
|
||||
if router.top() == &Route::Search {
|
||||
router.go_back();
|
||||
} else {
|
||||
|
||||
Reference in New Issue
Block a user