diff options
author | 2025-02-17 11:15:36 -0800 | |
---|---|---|
committer | 2025-02-21 18:56:41 -0800 | |
commit | 9cba92f57f5686f5295cb3430a3787aa3694a1fc (patch) | |
tree | 8dbca0f05527c1632aacc5901e5c5c434257fcc6 /core | |
parent | f1ed99cb47997e1d194a41e7cdf2846f8eb5f8fa (diff) | |
download | iced-9cba92f57f5686f5295cb3430a3787aa3694a1fc.tar.gz iced-9cba92f57f5686f5295cb3430a3787aa3694a1fc.tar.bz2 iced-9cba92f57f5686f5295cb3430a3787aa3694a1fc.zip |
Add `is_focused` function that produces an `Operation` to get the focused state of a `focusable` by ID.
Add `is_focused` function that produces a `Task` to get the focused state of a `text_input` by ID.
Diffstat (limited to 'core')
-rw-r--r-- | core/src/widget/operation/focusable.rs | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/core/src/widget/operation/focusable.rs b/core/src/widget/operation/focusable.rs index 1ee41244..49c574c4 100644 --- a/core/src/widget/operation/focusable.rs +++ b/core/src/widget/operation/focusable.rs @@ -257,3 +257,48 @@ pub fn find_focused() -> impl Operation<Id> { FindFocused { focused: None } } + +/// Produces an [`Operation`] that searches for the focusable widget +/// and stores whether it is focused or not. This ignores widgets that +/// do not have an ID. +pub fn is_focused(target: Id) -> impl Operation<bool> { + struct IsFocused { + target: Id, + is_focused: Option<bool>, + } + + impl Operation<bool> for IsFocused { + fn focusable( + &mut self, + id: Option<&Id>, + _bounds: Rectangle, + state: &mut dyn Focusable, + ) { + if id.is_some_and(|id| *id == self.target) { + self.is_focused = Some(state.is_focused()); + } + } + + fn container( + &mut self, + _id: Option<&Id>, + _bounds: Rectangle, + operate_on_children: &mut dyn FnMut(&mut dyn Operation<bool>), + ) { + operate_on_children(self); + } + + fn finish(&self) -> Outcome<bool> { + if let Some(is_focused) = &self.is_focused { + Outcome::Some(*is_focused) + } else { + Outcome::None + } + } + } + + IsFocused { + target, + is_focused: None, + } +} |