|
@@ -3,13 +3,11 @@ use dioxus_rsx::{
|
|
BodyNode, CallBody, Component, ElementAttr, ElementAttrNamed, IfmtInput, Segment,
|
|
BodyNode, CallBody, Component, ElementAttr, ElementAttrNamed, IfmtInput, Segment,
|
|
};
|
|
};
|
|
use quote::{quote, ToTokens, TokenStreamExt};
|
|
use quote::{quote, ToTokens, TokenStreamExt};
|
|
-use std::collections::HashMap;
|
|
|
|
use syn::{Expr, Ident, Result};
|
|
use syn::{Expr, Ident, Result};
|
|
|
|
|
|
#[derive(Default)]
|
|
#[derive(Default)]
|
|
pub struct CapturedContextBuilder {
|
|
pub struct CapturedContextBuilder {
|
|
- pub attributes: HashMap<String, IfmtInput>,
|
|
|
|
- pub text: Vec<IfmtInput>,
|
|
|
|
|
|
+ pub ifmted: Vec<IfmtInput>,
|
|
pub components: Vec<Component>,
|
|
pub components: Vec<Component>,
|
|
pub iterators: Vec<BodyNode>,
|
|
pub iterators: Vec<BodyNode>,
|
|
pub captured_expressions: Vec<Expr>,
|
|
pub captured_expressions: Vec<Expr>,
|
|
@@ -19,8 +17,7 @@ pub struct CapturedContextBuilder {
|
|
|
|
|
|
impl CapturedContextBuilder {
|
|
impl CapturedContextBuilder {
|
|
pub fn extend(&mut self, other: CapturedContextBuilder) {
|
|
pub fn extend(&mut self, other: CapturedContextBuilder) {
|
|
- self.attributes.extend(other.attributes);
|
|
|
|
- self.text.extend(other.text);
|
|
|
|
|
|
+ self.ifmted.extend(other.ifmted);
|
|
self.components.extend(other.components);
|
|
self.components.extend(other.components);
|
|
self.iterators.extend(other.iterators);
|
|
self.iterators.extend(other.iterators);
|
|
self.listeners.extend(other.listeners);
|
|
self.listeners.extend(other.listeners);
|
|
@@ -42,25 +39,28 @@ impl CapturedContextBuilder {
|
|
BodyNode::Element(el) => {
|
|
BodyNode::Element(el) => {
|
|
for attr in el.attributes {
|
|
for attr in el.attributes {
|
|
match attr.attr {
|
|
match attr.attr {
|
|
- ElementAttr::AttrText { name, value } => {
|
|
|
|
- let (name, value_tokens) = (name.to_string(), value.to_token_stream());
|
|
|
|
|
|
+ ElementAttr::AttrText { value, .. }
|
|
|
|
+ | ElementAttr::CustomAttrText { value, .. } => {
|
|
|
|
+ let value_tokens = value.to_token_stream();
|
|
let formated: IfmtInput = syn::parse2(value_tokens)?;
|
|
let formated: IfmtInput = syn::parse2(value_tokens)?;
|
|
- captured.attributes.insert(name, formated);
|
|
|
|
|
|
+ captured.ifmted.push(formated);
|
|
}
|
|
}
|
|
ElementAttr::AttrExpression { name: _, value } => {
|
|
ElementAttr::AttrExpression { name: _, value } => {
|
|
captured.captured_expressions.push(value);
|
|
captured.captured_expressions.push(value);
|
|
}
|
|
}
|
|
- ElementAttr::CustomAttrText { name, value } => {
|
|
|
|
- let (name, value_tokens) = (name.value(), value.to_token_stream());
|
|
|
|
- let formated: IfmtInput = syn::parse2(value_tokens)?;
|
|
|
|
- captured.attributes.insert(name, formated);
|
|
|
|
- }
|
|
|
|
ElementAttr::CustomAttrExpression { name: _, value } => {
|
|
ElementAttr::CustomAttrExpression { name: _, value } => {
|
|
captured.captured_expressions.push(value);
|
|
captured.captured_expressions.push(value);
|
|
}
|
|
}
|
|
ElementAttr::EventTokens { .. } => captured.listeners.push(attr),
|
|
ElementAttr::EventTokens { .. } => captured.listeners.push(attr),
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
+
|
|
|
|
+ if let Some(key) = el.key {
|
|
|
|
+ let value_tokens = key.to_token_stream();
|
|
|
|
+ let formated: IfmtInput = syn::parse2(value_tokens)?;
|
|
|
|
+ captured.ifmted.push(formated);
|
|
|
|
+ }
|
|
|
|
+
|
|
for child in el.children {
|
|
for child in el.children {
|
|
captured.extend(Self::find_captured(child)?);
|
|
captured.extend(Self::find_captured(child)?);
|
|
}
|
|
}
|
|
@@ -71,7 +71,7 @@ impl CapturedContextBuilder {
|
|
BodyNode::Text(t) => {
|
|
BodyNode::Text(t) => {
|
|
let tokens = t.to_token_stream();
|
|
let tokens = t.to_token_stream();
|
|
let formated: IfmtInput = syn::parse2(tokens).unwrap();
|
|
let formated: IfmtInput = syn::parse2(tokens).unwrap();
|
|
- captured.text.push(formated);
|
|
|
|
|
|
+ captured.ifmted.push(formated);
|
|
}
|
|
}
|
|
BodyNode::RawExpr(_) => captured.iterators.push(node),
|
|
BodyNode::RawExpr(_) => captured.iterators.push(node),
|
|
}
|
|
}
|
|
@@ -82,8 +82,7 @@ impl CapturedContextBuilder {
|
|
impl ToTokens for CapturedContextBuilder {
|
|
impl ToTokens for CapturedContextBuilder {
|
|
fn to_tokens(&self, tokens: &mut quote::__private::TokenStream) {
|
|
fn to_tokens(&self, tokens: &mut quote::__private::TokenStream) {
|
|
let CapturedContextBuilder {
|
|
let CapturedContextBuilder {
|
|
- attributes,
|
|
|
|
- text,
|
|
|
|
|
|
+ ifmted,
|
|
components,
|
|
components,
|
|
iterators,
|
|
iterators,
|
|
captured_expressions,
|
|
captured_expressions,
|
|
@@ -100,9 +99,8 @@ impl ToTokens for CapturedContextBuilder {
|
|
BodyNode::RawExpr(expr) => expr.to_token_stream().to_string(),
|
|
BodyNode::RawExpr(expr) => expr.to_token_stream().to_string(),
|
|
_ => unreachable!(),
|
|
_ => unreachable!(),
|
|
});
|
|
});
|
|
- let captured: Vec<_> = attributes
|
|
|
|
- .values()
|
|
|
|
- .chain(text.iter())
|
|
|
|
|
|
+ let captured: Vec<_> = ifmted
|
|
|
|
+ .iter()
|
|
.map(|input| input.segments.iter())
|
|
.map(|input| input.segments.iter())
|
|
.flatten()
|
|
.flatten()
|
|
.filter_map(|seg| match seg {
|
|
.filter_map(|seg| match seg {
|