Implement pure version of pick_list example 🎉

This commit is contained in:
Héctor Ramón Jiménez 2022-02-16 17:16:34 +07:00
parent 0ca066277a
commit 2737b21d34
No known key found for this signature in database
GPG key ID: 140CC052C94F138E
4 changed files with 139 additions and 0 deletions

View file

@ -91,6 +91,7 @@ members = [
"examples/tour",
"examples/url_handler",
"examples/pure/counter",
"examples/pure/pick_list",
"examples/pure/todos",
"examples/pure/tour",
"examples/websocket",

View file

@ -0,0 +1,9 @@
[package]
name = "pure_pick_list"
version = "0.1.0"
authors = ["Héctor Ramón Jiménez <hector0193@gmail.com>"]
edition = "2021"
publish = false
[dependencies]
iced = { path = "../../..", features = ["debug", "pure"] }

View file

@ -0,0 +1,18 @@
## Pick-list
A dropdown list of selectable options.
It displays and positions an overlay based on the window position of the widget.
The __[`main`]__ file contains all the code of the example.
<div align="center">
<img src="https://user-images.githubusercontent.com/518289/87125075-2c232e80-c28a-11ea-95c2-769c610b8843.gif">
</div>
You can run it with `cargo run`:
```
cargo run --package pick_list
```
[`main`]: src/main.rs

View file

@ -0,0 +1,111 @@
use iced::pure::widget::{
column, container, pick_list, scrollable, vertical_space,
};
use iced::pure::{Element, Sandbox};
use iced::{Alignment, Length, Settings};
pub fn main() -> iced::Result {
Example::run(Settings::default())
}
#[derive(Default)]
struct Example {
selected_language: Option<Language>,
}
#[derive(Debug, Clone, Copy)]
enum Message {
LanguageSelected(Language),
}
impl Sandbox for Example {
type Message = Message;
fn new() -> Self {
Self::default()
}
fn title(&self) -> String {
String::from("Pick list - Iced")
}
fn update(&mut self, message: Message) {
match message {
Message::LanguageSelected(language) => {
self.selected_language = Some(language);
}
}
}
fn view(&self) -> Element<Message> {
let pick_list = pick_list(
&Language::ALL[..],
self.selected_language,
Message::LanguageSelected,
)
.placeholder("Choose a language...");
let content = column()
.width(Length::Fill)
.align_items(Alignment::Center)
.spacing(10)
.push(vertical_space(Length::Units(600)))
.push("Which is your favorite language?")
.push(pick_list)
.push(vertical_space(Length::Units(600)));
container(scrollable(content))
.width(Length::Fill)
.height(Length::Fill)
.center_x()
.center_y()
.into()
}
}
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
pub enum Language {
Rust,
Elm,
Ruby,
Haskell,
C,
Javascript,
Other,
}
impl Language {
const ALL: [Language; 7] = [
Language::C,
Language::Elm,
Language::Ruby,
Language::Haskell,
Language::Rust,
Language::Javascript,
Language::Other,
];
}
impl Default for Language {
fn default() -> Language {
Language::Rust
}
}
impl std::fmt::Display for Language {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
write!(
f,
"{}",
match self {
Language::Rust => "Rust",
Language::Elm => "Elm",
Language::Ruby => "Ruby",
Language::Haskell => "Haskell",
Language::C => "C",
Language::Javascript => "Javascript",
Language::Other => "Some other language",
}
)
}
}