mirror of
https://github.com/DioxusLabs/dioxus
synced 2025-01-07 02:08:53 +00:00
296 lines
7.1 KiB
Rust
296 lines
7.1 KiB
Rust
use std::borrow::BorrowMut;
|
|
use std::cell::{Cell, RefCell};
|
|
use std::marker::PhantomData;
|
|
|
|
use dioxus::component::Scope;
|
|
use dioxus::events::on::MouseEvent;
|
|
use dioxus::nodes::{IntoVNode, VComponent, VFragment, VText};
|
|
use dioxus_core as dioxus;
|
|
use dioxus_core::prelude::*;
|
|
use dioxus_core_macro::*;
|
|
use dioxus_html as dioxus_elements;
|
|
|
|
fn main() {}
|
|
|
|
fn t() {
|
|
let g = rsx! {
|
|
div {
|
|
div {
|
|
|
|
}
|
|
}
|
|
};
|
|
|
|
let g = {
|
|
let ___p: Box<dyn FnOnce(NodeFactory) -> VNode> = Box::new(|__cx: NodeFactory| {
|
|
use dioxus_elements::{GlobalAttributes, SvgAttributes};
|
|
__cx.element(dioxus_elements::div, [], [], [], None)
|
|
});
|
|
// let __z = ___p as ;
|
|
// __z
|
|
};
|
|
}
|
|
|
|
// #[derive(PartialEq, Props)]
|
|
// struct OurProps {
|
|
// foo: String,
|
|
// }
|
|
|
|
// fn App<'a>((cx, props): Scope<'a, OurProps>) -> Element<'a> {
|
|
// let a = rsx! {
|
|
// div {
|
|
// "asd"
|
|
// "{props.foo}"
|
|
// }
|
|
// };
|
|
|
|
// let p = (0..10).map(|f| {
|
|
// rsx! {
|
|
// div {
|
|
|
|
// }
|
|
// }
|
|
// });
|
|
|
|
// let g = match "text" {
|
|
// "a" => {
|
|
// rsx!("asd")
|
|
// }
|
|
// _ => {
|
|
// rsx!("asd")
|
|
// }
|
|
// };
|
|
|
|
// let items = ["bob", "bill", "jack"];
|
|
|
|
// let f = items
|
|
// .iter()
|
|
// .filter(|f| f.starts_with('b'))
|
|
// .map(|f| rsx!("hello {f}"));
|
|
|
|
// // use dioxus_hooks;
|
|
// // let g = use_state(|| "hello".to_string());
|
|
|
|
// let s: &'a mut String = cx.use_hook(|_| String::new(), |f| f, |_| {});
|
|
|
|
// /*
|
|
// the final closure is allowed to borrow anything provided it
|
|
// */
|
|
// // cx.render({
|
|
// // let p: Option<Box<dyn FnOnce(_) -> _>> = Some(Box::new(move |__cx: NodeFactory| {
|
|
// // use dioxus_elements::{GlobalAttributes, SvgAttributes};
|
|
|
|
// // let props = Child2Props { foo: s };
|
|
// // let ch: VNode = __cx.component(Child2, props, None, []);
|
|
// // __cx.element(
|
|
// // dioxus_elements::div,
|
|
// // [],
|
|
// // [],
|
|
// // [ch],
|
|
// // // [__cx.component(Child2, fc_to_builder(Child2).foo(s).build(), None, [])],
|
|
// // None,
|
|
// // )
|
|
// // }));
|
|
// // p
|
|
// // // let ___p: Box<dyn FnOnce(NodeFactory) -> VNode> = Box::new(move |__cx| {
|
|
// // // use dioxus_elements::{GlobalAttributes, SvgAttributes};
|
|
|
|
// // // let props = Child2Props { foo: s };
|
|
// // // let ch: VNode = __cx.component(Child2, props, None, []);
|
|
// // // __cx.element(
|
|
// // // dioxus_elements::div,
|
|
// // // [],
|
|
// // // [],
|
|
// // // [ch],
|
|
// // // // [__cx.component(Child2, fc_to_builder(Child2).foo(s).build(), None, [])],
|
|
// // // None,
|
|
// // // )
|
|
// // // });
|
|
// // // Some(___p)
|
|
// // })
|
|
|
|
// let a = annotate_lazy(move |f| {
|
|
// //
|
|
// todo!()
|
|
// });
|
|
// let b = annotate_lazy(move |f| {
|
|
// //
|
|
// f.text(format_args!("{}", props.foo))
|
|
// });
|
|
|
|
// let c = annotate_lazy(move |f| {
|
|
// //
|
|
// f.component(
|
|
// Child,
|
|
// OurProps {
|
|
// //
|
|
// foo: "hello".to_string(),
|
|
// },
|
|
// None,
|
|
// [],
|
|
// )
|
|
// });
|
|
|
|
// let st: &'a String = cx.use_hook(|_| "hello".to_string(), |f| f, |_| {});
|
|
|
|
// let d = annotate_lazy(move |f| {
|
|
// //
|
|
// f.component(
|
|
// Child2,
|
|
// Child2Props {
|
|
// //
|
|
// foo: st,
|
|
// },
|
|
// None,
|
|
// [],
|
|
// )
|
|
// });
|
|
|
|
// let e = match "asd" {
|
|
// b => {
|
|
// //
|
|
|
|
// annotate_lazy(move |f| {
|
|
// //
|
|
// f.text(format_args!("{}", props.foo))
|
|
// })
|
|
// }
|
|
// a => {
|
|
// //
|
|
|
|
// annotate_lazy(move |f| {
|
|
// //
|
|
// f.text(format_args!("{}", props.foo))
|
|
// })
|
|
// }
|
|
// };
|
|
|
|
// cx.render(annotate_lazy(move |f| {
|
|
// //
|
|
|
|
// f.raw_element(
|
|
// "div",
|
|
// None,
|
|
// [],
|
|
// [],
|
|
// [
|
|
// //
|
|
// f.fragment_from_iter(a),
|
|
// f.fragment_from_iter(b),
|
|
// f.fragment_from_iter(c),
|
|
// f.fragment_from_iter(e),
|
|
// ],
|
|
// None,
|
|
// )
|
|
// // todo!()
|
|
// }))
|
|
// // cx.render(rsx! {
|
|
// // div {
|
|
// // div {
|
|
// // {a}
|
|
// // // {p}
|
|
// // // {g}
|
|
// // // {f}
|
|
// // }
|
|
// // // div {
|
|
// // // "asd"
|
|
// // // div {
|
|
// // // "asd"
|
|
// // // }
|
|
// // // }
|
|
// // // Child {
|
|
// // // foo: "asd".to_string(),
|
|
// // // }
|
|
// // Child2 {
|
|
// // foo: s,
|
|
// // }
|
|
// // }
|
|
// // })
|
|
// }
|
|
|
|
// fn Child((cx, props): Scope<OurProps>) -> Element {
|
|
// cx.render(rsx! {
|
|
// div {
|
|
// div {}
|
|
// }
|
|
// })
|
|
// }
|
|
|
|
#[derive(Props)]
|
|
struct Child2Props<'a> {
|
|
foo: &'a String,
|
|
}
|
|
|
|
fn Child2<'a>((cx, props): Scope<'a, Child2Props>) -> Element<'a> {
|
|
let node = cx
|
|
.render(rsx! {
|
|
div {
|
|
|
|
}
|
|
})
|
|
.unwrap();
|
|
|
|
let b = cx.bump();
|
|
let node: &'a VNode<'a> = b.alloc(node);
|
|
|
|
let children = Children { pthru: node };
|
|
|
|
cx.render(rsx! {
|
|
div {
|
|
ChildrenComp {
|
|
children: children
|
|
}
|
|
}
|
|
})
|
|
}
|
|
|
|
#[derive(Props)]
|
|
struct ChildrenTest<'a> {
|
|
children: Children<'a>,
|
|
}
|
|
|
|
struct Children<'a> {
|
|
pthru: &'a VNode<'a>,
|
|
}
|
|
|
|
impl<'a> Clone for Children<'a> {
|
|
fn clone(&self) -> Self {
|
|
Self { pthru: self.pthru }
|
|
}
|
|
}
|
|
impl<'a> Copy for Children<'a> {}
|
|
|
|
impl<'a> IntoVNode<'a> for Children<'a> {
|
|
fn into_vnode(self, _: NodeFactory<'a>) -> VNode<'a> {
|
|
match self.pthru {
|
|
VNode::Text(f) => VNode::Text(*f),
|
|
VNode::Element(e) => VNode::Element(*e),
|
|
VNode::Component(c) => VNode::Component(*c),
|
|
VNode::Suspended(s) => VNode::Suspended(*s),
|
|
VNode::Anchor(a) => VNode::Anchor(a),
|
|
VNode::Fragment(f) => VNode::Fragment(VFragment {
|
|
children: f.children,
|
|
is_static: f.is_static,
|
|
key: f.key,
|
|
}),
|
|
}
|
|
}
|
|
}
|
|
|
|
fn ChildrenComp<'a>((cx, props): Scope<'a, ChildrenTest<'a>>) -> Element<'a> {
|
|
cx.render(rsx! {
|
|
div {
|
|
div {
|
|
|
|
// if the node's id is already assigned, then it's being passed in as a child
|
|
// in these instances, we don't worry about re-checking the node?
|
|
|
|
{Some(props.children)}
|
|
}
|
|
}
|
|
})
|
|
}
|
|
|
|
fn ChildrenMemo((cx, props): Scope<()>) -> Element {
|
|
todo!()
|
|
}
|