mirror of
https://github.com/DioxusLabs/dioxus
synced 2024-12-03 17:39:11 +00:00
cleanup code and examples
This commit is contained in:
parent
029255c7ac
commit
bbd49bb37c
7 changed files with 120 additions and 71 deletions
|
@ -41,49 +41,53 @@ fn app(cx: Scope) -> Element {
|
||||||
height: "10%",
|
height: "10%",
|
||||||
maxlength: "11",
|
maxlength: "11",
|
||||||
}
|
}
|
||||||
// Input{
|
Input{
|
||||||
// oninput: |data: FormData| {
|
oninput: |data: FormData| {
|
||||||
// if (data.value.parse::<f32>().unwrap() - 40.0).abs() < 5.0 {
|
if (data.value.parse::<f32>().unwrap() - 40.0).abs() < 5.0 {
|
||||||
// bg_green.set(true);
|
bg_green.set(true);
|
||||||
// } else{
|
} else{
|
||||||
// bg_green.set(false);
|
bg_green.set(false);
|
||||||
// }
|
}
|
||||||
// },
|
},
|
||||||
// r#type: "range",
|
r#type: "range",
|
||||||
// min: "20",
|
width: "50%",
|
||||||
// max: "80",
|
height: "10%",
|
||||||
// }
|
min: "20",
|
||||||
// Input{
|
max: "80",
|
||||||
// oninput: |data: FormData| {
|
}
|
||||||
// if data.value == "10"{
|
Input{
|
||||||
// bg_green.set(true);
|
oninput: |data: FormData| {
|
||||||
// } else{
|
if data.value == "10"{
|
||||||
// bg_green.set(false);
|
bg_green.set(true);
|
||||||
// }
|
} else{
|
||||||
// },
|
bg_green.set(false);
|
||||||
// r#type: "number",
|
}
|
||||||
// maxlength: "4",
|
},
|
||||||
// }
|
r#type: "number",
|
||||||
// Input{
|
width: "50%",
|
||||||
// oninput: |data: FormData| {
|
height: "10%",
|
||||||
// if data.value == "hello world"{
|
maxlength: "4",
|
||||||
// bg_green.set(true);
|
}
|
||||||
// } else{
|
Input{
|
||||||
// bg_green.set(false);
|
oninput: |data: FormData| {
|
||||||
// }
|
if data.value == "hello world"{
|
||||||
// },
|
bg_green.set(true);
|
||||||
// r#type: "password",
|
} else{
|
||||||
// width: "13px",
|
bg_green.set(false);
|
||||||
// height: "3px",
|
}
|
||||||
// maxlength: "11",
|
},
|
||||||
// }
|
r#type: "password",
|
||||||
// Input{
|
width: "50%",
|
||||||
// onclick: |_: FormData| bg_green.set(true),
|
height: "10%",
|
||||||
// r#type: "button",
|
maxlength: "11",
|
||||||
// value: "green",
|
}
|
||||||
// height: "3px",
|
Input{
|
||||||
// width: "7px",
|
onclick: |_: FormData| bg_green.set(true),
|
||||||
// }
|
r#type: "button",
|
||||||
|
value: "green",
|
||||||
|
width: "50%",
|
||||||
|
height: "10%",
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,7 +7,7 @@ use dioxus_native_core::state::ChildDepState;
|
||||||
use dioxus_native_core_macro::sorted_str_slice;
|
use dioxus_native_core_macro::sorted_str_slice;
|
||||||
use taffy::prelude::*;
|
use taffy::prelude::*;
|
||||||
|
|
||||||
use crate::screen_to_layout_space;
|
use crate::{screen_to_layout_space, unit_to_layout_space};
|
||||||
|
|
||||||
#[derive(Debug, Clone, Copy, PartialEq)]
|
#[derive(Debug, Clone, Copy, PartialEq)]
|
||||||
pub(crate) enum PossiblyUninitalized<T> {
|
pub(crate) enum PossiblyUninitalized<T> {
|
||||||
|
@ -105,6 +105,59 @@ impl ChildDepState for TaffyLayout {
|
||||||
child_layout.push(l.node.unwrap());
|
child_layout.push(l.node.unwrap());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn scale_dimention(d: Dimension) -> Dimension {
|
||||||
|
match d {
|
||||||
|
Dimension::Points(p) => Dimension::Points(unit_to_layout_space(p)),
|
||||||
|
Dimension::Percent(p) => Dimension::Percent(p),
|
||||||
|
Dimension::Auto => Dimension::Auto,
|
||||||
|
Dimension::Undefined => Dimension::Undefined,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
let style = Style {
|
||||||
|
position: Rect {
|
||||||
|
left: scale_dimention(style.position.left),
|
||||||
|
right: scale_dimention(style.position.right),
|
||||||
|
top: scale_dimention(style.position.top),
|
||||||
|
bottom: scale_dimention(style.position.bottom),
|
||||||
|
},
|
||||||
|
margin: Rect {
|
||||||
|
left: scale_dimention(style.margin.left),
|
||||||
|
right: scale_dimention(style.margin.right),
|
||||||
|
top: scale_dimention(style.margin.top),
|
||||||
|
bottom: scale_dimention(style.margin.bottom),
|
||||||
|
},
|
||||||
|
padding: Rect {
|
||||||
|
left: scale_dimention(style.padding.left),
|
||||||
|
right: scale_dimention(style.padding.right),
|
||||||
|
top: scale_dimention(style.padding.top),
|
||||||
|
bottom: scale_dimention(style.padding.bottom),
|
||||||
|
},
|
||||||
|
border: Rect {
|
||||||
|
left: scale_dimention(style.border.left),
|
||||||
|
right: scale_dimention(style.border.right),
|
||||||
|
top: scale_dimention(style.border.top),
|
||||||
|
bottom: scale_dimention(style.border.bottom),
|
||||||
|
},
|
||||||
|
gap: Size {
|
||||||
|
width: scale_dimention(style.gap.width),
|
||||||
|
height: scale_dimention(style.gap.height),
|
||||||
|
},
|
||||||
|
flex_basis: scale_dimention(style.flex_basis),
|
||||||
|
size: Size {
|
||||||
|
width: scale_dimention(style.size.width),
|
||||||
|
height: scale_dimention(style.size.height),
|
||||||
|
},
|
||||||
|
min_size: Size {
|
||||||
|
width: scale_dimention(style.min_size.width),
|
||||||
|
height: scale_dimention(style.min_size.height),
|
||||||
|
},
|
||||||
|
max_size: Size {
|
||||||
|
width: scale_dimention(style.max_size.width),
|
||||||
|
height: scale_dimention(style.max_size.height),
|
||||||
|
},
|
||||||
|
..style
|
||||||
|
};
|
||||||
|
|
||||||
if let PossiblyUninitalized::Initialized(n) = self.node {
|
if let PossiblyUninitalized::Initialized(n) = self.node {
|
||||||
if self.style != style {
|
if self.style != style {
|
||||||
taffy.set_style(n, style).unwrap();
|
taffy.set_style(n, style).unwrap();
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
use anyhow::Result;
|
use anyhow::Result;
|
||||||
use crossterm::{
|
use crossterm::{
|
||||||
|
cursor::{MoveTo, RestorePosition, SavePosition, Show},
|
||||||
event::{DisableMouseCapture, EnableMouseCapture, Event as TermEvent, KeyCode, KeyModifiers},
|
event::{DisableMouseCapture, EnableMouseCapture, Event as TermEvent, KeyCode, KeyModifiers},
|
||||||
execute,
|
execute,
|
||||||
terminal::{disable_raw_mode, enable_raw_mode, EnterAlternateScreen, LeaveAlternateScreen},
|
terminal::{disable_raw_mode, enable_raw_mode, EnterAlternateScreen, LeaveAlternateScreen},
|
||||||
|
@ -45,6 +46,10 @@ pub(crate) fn screen_to_layout_space(screen: u16) -> f32 {
|
||||||
screen as f32 * 10.0
|
screen as f32 * 10.0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub(crate) fn unit_to_layout_space(screen: f32) -> f32 {
|
||||||
|
screen * 10.0
|
||||||
|
}
|
||||||
|
|
||||||
pub(crate) fn layout_to_screen_space(layout: f32) -> f32 {
|
pub(crate) fn layout_to_screen_space(layout: f32) -> f32 {
|
||||||
layout / 10.0
|
layout / 10.0
|
||||||
}
|
}
|
||||||
|
@ -138,7 +143,13 @@ fn render_vdom(
|
||||||
let mut terminal = (!cfg.headless).then(|| {
|
let mut terminal = (!cfg.headless).then(|| {
|
||||||
enable_raw_mode().unwrap();
|
enable_raw_mode().unwrap();
|
||||||
let mut stdout = std::io::stdout();
|
let mut stdout = std::io::stdout();
|
||||||
execute!(stdout, EnterAlternateScreen, EnableMouseCapture).unwrap();
|
execute!(
|
||||||
|
stdout,
|
||||||
|
EnterAlternateScreen,
|
||||||
|
EnableMouseCapture,
|
||||||
|
MoveTo(0, 1000)
|
||||||
|
)
|
||||||
|
.unwrap();
|
||||||
let backend = CrosstermBackend::new(io::stdout());
|
let backend = CrosstermBackend::new(io::stdout());
|
||||||
Terminal::new(backend).unwrap()
|
Terminal::new(backend).unwrap()
|
||||||
});
|
});
|
||||||
|
@ -183,14 +194,16 @@ fn render_vdom(
|
||||||
taffy.compute_layout(root_node, size).unwrap();
|
taffy.compute_layout(root_node, size).unwrap();
|
||||||
}
|
}
|
||||||
if let Some(terminal) = &mut terminal {
|
if let Some(terminal) = &mut terminal {
|
||||||
|
execute!(terminal.backend_mut(), SavePosition).unwrap();
|
||||||
terminal.draw(|frame| {
|
terminal.draw(|frame| {
|
||||||
let rdom = rdom.borrow();
|
let rdom = rdom.borrow();
|
||||||
let mut taffy = taffy.lock().expect("taffy lock poisoned");
|
let mut taffy = taffy.lock().expect("taffy lock poisoned");
|
||||||
// size is guaranteed to not change when rendering
|
// size is guaranteed to not change when rendering
|
||||||
resize(frame.size(), &mut *taffy, &rdom);
|
resize(frame.size(), &mut taffy, &rdom);
|
||||||
let root = &rdom[NodeId(0)];
|
let root = &rdom[NodeId(0)];
|
||||||
render::render_vnode(frame, &*taffy, &rdom, root, cfg, Point::ZERO);
|
render::render_vnode(frame, &taffy, &rdom, root, cfg, Point::ZERO);
|
||||||
})?;
|
})?;
|
||||||
|
execute!(terminal.backend_mut(), RestorePosition, Show).unwrap();
|
||||||
} else {
|
} else {
|
||||||
let rdom = rdom.borrow();
|
let rdom = rdom.borrow();
|
||||||
resize(
|
resize(
|
||||||
|
|
|
@ -42,6 +42,9 @@ pub(crate) fn Button<'a>(cx: Scope<'a, ButtonProps>) -> Element<'a> {
|
||||||
width: "{width}",
|
width: "{width}",
|
||||||
height: "{height}",
|
height: "{height}",
|
||||||
border_style: "{border_style}",
|
border_style: "{border_style}",
|
||||||
|
flex_direction: "row",
|
||||||
|
align_items: "center",
|
||||||
|
justify_content: "center",
|
||||||
onclick: move |_| {
|
onclick: move |_| {
|
||||||
update();
|
update();
|
||||||
},
|
},
|
||||||
|
|
|
@ -206,26 +206,6 @@ pub(crate) fn NumbericInput<'a>(cx: Scope<'a, NumbericInputProps>) -> Element<'a
|
||||||
}
|
}
|
||||||
|
|
||||||
"{text_after_second_cursor}"
|
"{text_after_second_cursor}"
|
||||||
|
|
||||||
div{
|
|
||||||
background_color: "rgba(255, 255, 255, 50%)",
|
|
||||||
color: "black",
|
|
||||||
Input{
|
|
||||||
r#type: "button",
|
|
||||||
onclick: move |_| {
|
|
||||||
decrease();
|
|
||||||
}
|
|
||||||
value: "<",
|
|
||||||
}
|
|
||||||
" "
|
|
||||||
Input{
|
|
||||||
r#type: "button",
|
|
||||||
onclick: move |_| {
|
|
||||||
increase();
|
|
||||||
}
|
|
||||||
value: ">",
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -88,7 +88,6 @@ pub(crate) fn Password<'a>(cx: Scope<'a, PasswordProps>) -> Element<'a> {
|
||||||
width: "{width}",
|
width: "{width}",
|
||||||
height: "{height}",
|
height: "{height}",
|
||||||
border_style: "{border}",
|
border_style: "{border}",
|
||||||
align_items: "left",
|
|
||||||
|
|
||||||
onkeydown: move |k| {
|
onkeydown: move |k| {
|
||||||
if k.key()== Key::Enter {
|
if k.key()== Key::Enter {
|
||||||
|
|
|
@ -84,9 +84,6 @@ pub(crate) fn TextBox<'a>(cx: Scope<'a, TextBoxProps>) -> Element<'a> {
|
||||||
width: "{width}",
|
width: "{width}",
|
||||||
height: "{height}",
|
height: "{height}",
|
||||||
border_style: "{border}",
|
border_style: "{border}",
|
||||||
flex_direction: "row",
|
|
||||||
align_items: "center",
|
|
||||||
justify_content: "center",
|
|
||||||
|
|
||||||
onkeydown: move |k| {
|
onkeydown: move |k| {
|
||||||
if k.key() == Key::Enter {
|
if k.key() == Key::Enter {
|
||||||
|
|
Loading…
Reference in a new issue