summaryrefslogtreecommitdiffstats
path: root/widget/src/keyed.rs
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón <hector@hecrj.dev>2024-09-19 06:59:05 +0200
committerLibravatar GitHub <noreply@github.com>2024-09-19 06:59:05 +0200
commitddbb8445bf60de7169727721a5cb57048ded3d82 (patch)
tree1f2b90d5f0e010be72e4bbd20da6c22e1478b573 /widget/src/keyed.rs
parent1f8dc1f3dda25c699b94c653d5d569f4142e9b83 (diff)
parent31c42c1d02d6a76dedaa780e6832a23765c8aef2 (diff)
downloadiced-ddbb8445bf60de7169727721a5cb57048ded3d82.tar.gz
iced-ddbb8445bf60de7169727721a5cb57048ded3d82.tar.bz2
iced-ddbb8445bf60de7169727721a5cb57048ded3d82.zip
Merge pull request #2587 from iced-rs/improve-api-reference
Add widget examples to API reference and update `README`
Diffstat (limited to 'widget/src/keyed.rs')
-rw-r--r--widget/src/keyed.rs32
1 files changed, 27 insertions, 5 deletions
diff --git a/widget/src/keyed.rs b/widget/src/keyed.rs
index ad531e66..923cb118 100644
--- a/widget/src/keyed.rs
+++ b/widget/src/keyed.rs
@@ -1,4 +1,4 @@
-//! Use widgets that can provide hints to ensure continuity.
+//! Keyed widgets can provide hints to ensure continuity.
//!
//! # What is continuity?
//! Continuity is the feeling of persistence of state.
@@ -41,13 +41,35 @@ pub mod column;
pub use column::Column;
-/// Creates a [`Column`] with the given children.
+/// Creates a keyed [`Column`] with the given children.
+///
+/// Keyed columns distribute content vertically while keeping continuity.
+///
+/// # Example
+/// ```no_run
+/// # mod iced { pub mod widget { pub use iced_widget::*; } }
+/// # pub type State = ();
+/// # pub type Element<'a, Message> = iced_widget::core::Element<'a, Message, iced_widget::Theme, iced_widget::Renderer>;
+/// use iced::widget::keyed_column;
+///
+/// enum Message {
+/// // ...
+/// }
+///
+/// fn view(state: &State) -> Element<'_, Message> {
+/// keyed_column![
+/// (0, "Item 0"),
+/// (1, "Item 1"),
+/// (2, "Item 2"),
+/// ].into()
+/// }
+/// ```
#[macro_export]
macro_rules! keyed_column {
() => (
- $crate::Column::new()
+ $crate::keyed::Column::new()
);
- ($($x:expr),+ $(,)?) => (
- $crate::keyed::Column::with_children(vec![$($crate::core::Element::from($x)),+])
+ ($(($key:expr, $x:expr)),+ $(,)?) => (
+ $crate::keyed::Column::with_children(vec![$(($key, $crate::core::Element::from($x))),+])
);
}