Skip to content

Commit

Permalink
fix: svelte:element with dynamic this and spread attributes throws er…
Browse files Browse the repository at this point in the history
…ror (#9112)

fixes #9092

---------

Co-authored-by: gtmnayan <[email protected]>
Co-authored-by: Simon H <[email protected]>
  • Loading branch information
3 people authored Sep 20, 2023
1 parent 3191147 commit 228dd4d
Show file tree
Hide file tree
Showing 5 changed files with 19 additions and 3 deletions.
5 changes: 5 additions & 0 deletions .changeset/khaki-wolves-dream.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'svelte': patch
---

fix: handle `svelte:element` with dynamic this and spread attributes
Original file line number Diff line number Diff line change
Expand Up @@ -990,7 +990,8 @@ export default class ElementWrapper extends Wrapper {
const static_attributes = [];
this.attributes.forEach((attr) => {
if (attr instanceof SpreadAttributeWrapper) {
static_attributes.push({ type: 'SpreadElement', argument: attr.node.expression.node });
const snippet = { type: 'SpreadElement', argument: attr.node.expression.manipulate(block) };
static_attributes.push(snippet);
} else {
const name = attr.property_name || attr.name;
static_attributes.push(p`${name}: ${attr.get_value(block)}`);
Expand Down
4 changes: 2 additions & 2 deletions packages/svelte/test/js/samples/svelte-element/expected.js
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ function create_dynamic_element_3(ctx) {
return {
c() {
svelte_element = element(static_value);
set_dynamic_element_data(static_value)(svelte_element, { static_value, ...static_obj });
set_dynamic_element_data(static_value)(svelte_element, { static_value, .../*static_obj*/ ctx[2] });
toggle_class(svelte_element, "foo", static_value);
},
m(target, anchor) {
Expand All @@ -43,7 +43,7 @@ function create_dynamic_element_2(ctx) {
return {
c() {
svelte_element = element(/*dynamic_value*/ ctx[0]);
set_dynamic_element_data(/*dynamic_value*/ ctx[0])(svelte_element, { static_value, ...static_obj });
set_dynamic_element_data(/*dynamic_value*/ ctx[0])(svelte_element, { static_value, .../*static_obj*/ ctx[2] });
toggle_class(svelte_element, "foo", static_value);
},
m(target, anchor) {
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
export default {
html: '<div id="element" class="element-handler">this is div</div>'
};
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
<script>
let props = {
id: "element",
class: "element-handler"
}
</script>
<svelte:element this={"div"} {...props}>this is div</svelte:element>

0 comments on commit 228dd4d

Please sign in to comment.