handle positional_args

This commit is contained in:
Evan Almloff 2022-05-28 12:11:22 -05:00
parent 06390b9be5
commit c1072aa95a
3 changed files with 17 additions and 7 deletions

View file

@ -6,7 +6,7 @@ edition = "2021"
[dependencies]
syn = "1.0"
quote = "1.0"
dioxus-rsx = { path = "../rsx" }
dioxus-rsx = { path = "../rsx", default-features = false }
dioxus-ssr = { path = "../ssr" }
dioxus-core = { path = "../core" }
dioxus-html = { path = "../html" }

View file

@ -55,7 +55,6 @@ impl CapturedContextBuilder {
captured.captured_expressions.push(value);
}
ElementAttr::EventTokens { .. } => captured.listeners.push(attr),
_ => (),
}
}
for child in el.children {
@ -71,7 +70,6 @@ impl CapturedContextBuilder {
captured.text.push(formated);
}
BodyNode::RawExpr(_) => captured.iterators.push(node),
BodyNode::Meta(_) => (),
}
captured
}
@ -97,14 +95,27 @@ impl ToTokens for CapturedContextBuilder {
BodyNode::RawExpr(expr) => expr.to_token_stream().to_string(),
_ => unreachable!(),
});
let captured: Vec<_> = attributes
let captured_named: Vec<_> = attributes
.iter()
.map(|(_, fmt)| fmt.named_args.iter())
.chain(text.iter().map(|fmt| fmt.named_args.iter()))
.flatten()
.collect();
let captured_names = captured.iter().map(|(n, _)| n.to_string());
let captured_expr = captured.iter().map(|(_, e)| e);
let captured_expr: Vec<_> = attributes
.iter()
.map(|(_, fmt)| fmt.positional_args.iter())
.chain(text.iter().map(|fmt| fmt.positional_args.iter()))
.flatten()
.collect();
let captured_names = captured_named.iter().map(|(n, _)| n.to_string()).chain(
captured_expr
.iter()
.map(|expr| expr.to_token_stream().to_string()),
);
let captured_expr = captured_named
.iter()
.map(|(_, e)| e)
.chain(captured_expr.iter().map(|expr| *expr));
let captured_attr_expressions_text = captured_expressions
.iter()
.map(|e| format!("{}", e.to_token_stream()));

View file

@ -259,6 +259,5 @@ fn build_node<'a>(
);
}
}
BodyNode::Meta(_) => todo!(),
}
}