mirror of
https://github.com/DioxusLabs/dioxus
synced 2024-11-23 04:33:06 +00:00
Merge branch 'DioxusLabs:master' into master
This commit is contained in:
commit
c34c57a29f
3 changed files with 118 additions and 6 deletions
101
examples/svg.rs
Normal file
101
examples/svg.rs
Normal file
|
@ -0,0 +1,101 @@
|
||||||
|
// Thanks to @japsu and their project https://github.com/japsu/jatsi for the example!
|
||||||
|
|
||||||
|
use dioxus::{events::MouseEvent, prelude::*};
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
dioxus::desktop::launch(app);
|
||||||
|
}
|
||||||
|
|
||||||
|
fn app(cx: Scope) -> Element {
|
||||||
|
let (val, set_val) = use_state(&cx, || 5);
|
||||||
|
|
||||||
|
cx.render(rsx! {
|
||||||
|
div {
|
||||||
|
user_select: "none",
|
||||||
|
webkit_user_select: "none",
|
||||||
|
margin_left: "10%",
|
||||||
|
margin_right: "10%",
|
||||||
|
h1 { "Click die to generate a new value" }
|
||||||
|
div {
|
||||||
|
cursor: "pointer",
|
||||||
|
height: "80%",
|
||||||
|
width: "80%",
|
||||||
|
Die {
|
||||||
|
value: *val,
|
||||||
|
keep: true,
|
||||||
|
onclick: move |_| {
|
||||||
|
use rand::Rng;
|
||||||
|
let mut rng = rand::thread_rng();
|
||||||
|
set_val(rng.gen_range(1..6));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Props)]
|
||||||
|
pub struct DieProps<'a> {
|
||||||
|
pub value: u64,
|
||||||
|
pub keep: bool,
|
||||||
|
pub onclick: EventHandler<'a, MouseEvent>,
|
||||||
|
}
|
||||||
|
|
||||||
|
const DOTS: [(i64, i64); 7] = [(-1, -1), (-1, -0), (-1, 1), (1, -1), (1, 0), (1, 1), (0, 0)];
|
||||||
|
const DOTS_FOR_VALUE: [[bool; 7]; 6] = [
|
||||||
|
[false, false, false, false, false, false, true],
|
||||||
|
[false, false, true, true, false, false, false],
|
||||||
|
[false, false, true, true, false, false, true],
|
||||||
|
[true, false, true, true, false, true, false],
|
||||||
|
[true, false, true, true, false, true, true],
|
||||||
|
[true, true, true, true, true, true, false],
|
||||||
|
];
|
||||||
|
|
||||||
|
const OFFSET: i64 = 600;
|
||||||
|
const DOT_RADIUS: &str = "200";
|
||||||
|
const HELD_COLOR: &str = "#aaa";
|
||||||
|
const UNHELD_COLOR: &str = "#ddd";
|
||||||
|
|
||||||
|
// A six-sided die (D6) with dots.
|
||||||
|
#[allow(non_snake_case)]
|
||||||
|
pub fn Die<'a>(cx: Scope<'a, DieProps<'a>>) -> Element {
|
||||||
|
let &DieProps { value, keep, .. } = cx.props;
|
||||||
|
|
||||||
|
let active_dots = &DOTS_FOR_VALUE[(value - 1) as usize];
|
||||||
|
let fill = if keep { HELD_COLOR } else { UNHELD_COLOR };
|
||||||
|
let dots = DOTS
|
||||||
|
.iter()
|
||||||
|
.zip(active_dots.iter())
|
||||||
|
.filter(|(_, &active)| active)
|
||||||
|
.map(|((x, y), _)| {
|
||||||
|
let dcx = x * OFFSET;
|
||||||
|
let dcy = y * OFFSET;
|
||||||
|
rsx!(circle {
|
||||||
|
cx: "{dcx}",
|
||||||
|
cy: "{dcy}",
|
||||||
|
r: "{DOT_RADIUS}",
|
||||||
|
fill: "#333"
|
||||||
|
})
|
||||||
|
});
|
||||||
|
|
||||||
|
rsx!(cx,
|
||||||
|
svg {
|
||||||
|
onclick: move |e| cx.props.onclick.call(e),
|
||||||
|
prevent_default: "onclick",
|
||||||
|
"dioxus-prevent-default": "onclick",
|
||||||
|
class: "die",
|
||||||
|
view_box: "-1000 -1000 2000 2000",
|
||||||
|
|
||||||
|
rect {
|
||||||
|
x: "-1000",
|
||||||
|
y: "-1000",
|
||||||
|
width: "2000",
|
||||||
|
height: "2000",
|
||||||
|
rx: "{DOT_RADIUS}",
|
||||||
|
fill: "{fill}",
|
||||||
|
}
|
||||||
|
|
||||||
|
dots
|
||||||
|
}
|
||||||
|
)
|
||||||
|
}
|
|
@ -1047,7 +1047,7 @@ impl input {
|
||||||
/// - `text`
|
/// - `text`
|
||||||
/// - `time`
|
/// - `time`
|
||||||
/// - `url`
|
/// - `url`
|
||||||
/// - `week`
|
/// - `week`
|
||||||
pub fn r#type<'a>(&self, cx: NodeFactory<'a>, val: Arguments) -> Attribute<'a> {
|
pub fn r#type<'a>(&self, cx: NodeFactory<'a>, val: Arguments) -> Attribute<'a> {
|
||||||
cx.attr("type", val, None, false)
|
cx.attr("type", val, None, false)
|
||||||
}
|
}
|
||||||
|
@ -1100,11 +1100,6 @@ impl label {
|
||||||
cx.attr("for", val, None, false)
|
cx.attr("for", val, None, false)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
impl a {
|
|
||||||
pub fn prevent_default<'a>(&self, cx: NodeFactory<'a>, val: Arguments) -> Attribute<'a> {
|
|
||||||
cx.attr("dioxus-prevent-default", val, None, false)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
builder_constructors! {
|
builder_constructors! {
|
||||||
// SVG components
|
// SVG components
|
||||||
|
|
|
@ -49,6 +49,10 @@ macro_rules! aria_trait_methods {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub trait GlobalAttributes {
|
pub trait GlobalAttributes {
|
||||||
|
/// Prevent the default action for this element.
|
||||||
|
///
|
||||||
|
/// For more information, see the MDN docs:
|
||||||
|
/// <https://developer.mozilla.org/en-US/docs/Web/API/Event/preventDefault>
|
||||||
fn prevent_default<'a>(&self, cx: NodeFactory<'a>, val: Arguments) -> Attribute<'a> {
|
fn prevent_default<'a>(&self, cx: NodeFactory<'a>, val: Arguments) -> Attribute<'a> {
|
||||||
cx.attr("dioxus-prevent-default", val, None, false)
|
cx.attr("dioxus-prevent-default", val, None, false)
|
||||||
}
|
}
|
||||||
|
@ -603,6 +607,11 @@ pub trait GlobalAttributes {
|
||||||
/// Specifies the speed curve of the transition effect.
|
/// Specifies the speed curve of the transition effect.
|
||||||
transition_timing_function: "transition-timing-function",
|
transition_timing_function: "transition-timing-function",
|
||||||
|
|
||||||
|
/// The user-select CSS property controls whether the user can select text.
|
||||||
|
/// This doesn't have any effect on content loaded as part of a browser's user interface (its chrome), except in textboxes.
|
||||||
|
user_select: "user-select",
|
||||||
|
webkit_user_select: "-webkit-user-select",
|
||||||
|
|
||||||
/// Sets the vertical positioning of an element relative to the current text baseline.
|
/// Sets the vertical positioning of an element relative to the current text baseline.
|
||||||
vertical_align: "vertical-align",
|
vertical_align: "vertical-align",
|
||||||
|
|
||||||
|
@ -685,6 +694,13 @@ pub trait GlobalAttributes {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub trait SvgAttributes {
|
pub trait SvgAttributes {
|
||||||
|
/// Prevent the default action for this element.
|
||||||
|
///
|
||||||
|
/// For more information, see the MDN docs:
|
||||||
|
/// <https://developer.mozilla.org/en-US/docs/Web/API/Event/preventDefault>
|
||||||
|
fn prevent_default<'a>(&self, cx: NodeFactory<'a>, val: Arguments) -> Attribute<'a> {
|
||||||
|
cx.attr("dioxus-prevent-default", val, None, false)
|
||||||
|
}
|
||||||
aria_trait_methods! {
|
aria_trait_methods! {
|
||||||
accent_height: "accent-height",
|
accent_height: "accent-height",
|
||||||
accumulate: "accumulate",
|
accumulate: "accumulate",
|
||||||
|
|
Loading…
Reference in a new issue