Implement pure version of pick_list example 🎉
This commit is contained in:
parent
0ca066277a
commit
2737b21d34
4 changed files with 139 additions and 0 deletions
|
|
@ -91,6 +91,7 @@ members = [
|
||||||
"examples/tour",
|
"examples/tour",
|
||||||
"examples/url_handler",
|
"examples/url_handler",
|
||||||
"examples/pure/counter",
|
"examples/pure/counter",
|
||||||
|
"examples/pure/pick_list",
|
||||||
"examples/pure/todos",
|
"examples/pure/todos",
|
||||||
"examples/pure/tour",
|
"examples/pure/tour",
|
||||||
"examples/websocket",
|
"examples/websocket",
|
||||||
|
|
|
||||||
9
examples/pure/pick_list/Cargo.toml
Normal file
9
examples/pure/pick_list/Cargo.toml
Normal 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"] }
|
||||||
18
examples/pure/pick_list/README.md
Normal file
18
examples/pure/pick_list/README.md
Normal 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
|
||||||
111
examples/pure/pick_list/src/main.rs
Normal file
111
examples/pure/pick_list/src/main.rs
Normal 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",
|
||||||
|
}
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue