Skip to content

Commit

Permalink
fix: support camelCase properties on custom elements (sveltejs#9328)
Browse files Browse the repository at this point in the history
while attributes are case insensitive, properties are not. to not introduce a breaking change, the lowercased variant is checked first.
fixes sveltejs#9325
  • Loading branch information
dummdidumm authored and kelvinsjk committed Oct 19, 2023
1 parent 5b0c469 commit 9cac63b
Show file tree
Hide file tree
Showing 7 changed files with 83 additions and 3 deletions.
5 changes: 5 additions & 0 deletions .changeset/seven-cars-drum.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'svelte': patch
---

fix: support camelCase properties on custom elements
Original file line number Diff line number Diff line change
Expand Up @@ -103,8 +103,8 @@ export default class AttributeWrapper extends BaseAttributeWrapper {
this.parent.has_dynamic_value = true;
}
}
if (this.parent.node.namespace == namespaces.foreign) {
// leave attribute case alone for elements in the "foreign" namespace
if (this.parent.node.namespace == namespaces.foreign || this.parent.node.name.includes('-')) {
// leave attribute case alone for elements in the "foreign" namespace and for custom elements
this.name = this.node.name;
this.metadata = this.get_metadata();
this.is_indirectly_bound_value = false;
Expand Down
5 changes: 4 additions & 1 deletion packages/svelte/src/runtime/internal/dom.js
Original file line number Diff line number Diff line change
Expand Up @@ -480,7 +480,10 @@ export function set_custom_element_data_map(node, data_map) {
/**
* @returns {void} */
export function set_custom_element_data(node, prop, value) {
if (prop in node) {
const lower = prop.toLowerCase(); // for backwards compatibility with existing behavior we do lowercase first
if (lower in node) {
node[lower] = typeof node[lower] === 'boolean' && value === '' ? true : value;
} else if (prop in node) {
node[prop] = typeof node[prop] === 'boolean' && value === '' ? true : value;
} else {
attr(node, prop, value);
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
export default {
skip_if_ssr: true,
skip_if_hydrate: true,
html: `
<my-custom-element>Hello World!</my-custom-element>
`
};
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
<script>
class MyCustomElement extends HTMLElement {
constructor() {
super();
this._obj = null;
}
set camelCase(obj) {
this._obj = obj;
this.render();
}
connectedCallback() {
this.render();
}
render() {
this.innerHTML = 'Hello ' + this._obj.text + '!';
}
}
window.customElements.define('my-custom-element', MyCustomElement);
</script>

<my-custom-element camelCase={{ text: 'World' }} />
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
export default {
skip_if_ssr: true,
skip_if_hydrate: true,
html: `
<my-custom-inheritance-element>Hello World!</my-custom-inheritance-element>
`
};
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
<script>
class MyCustomElement extends HTMLElement {
constructor() {
super();
this._obj = null;
this._text = null;
}
set text(text) {
this._text = text;
this.render();
}
set camelCase(obj) {
this._obj = obj;
this.render();
}
connectedCallback() {
this.render();
}
render() {
this.innerHTML = 'Hello ' + this._obj.text + this._text;
}
}
class Extended extends MyCustomElement {}
window.customElements.define('my-custom-inheritance-element', Extended);
</script>

<my-custom-inheritance-element camelCase={{ text: 'World' }} text="!" />

0 comments on commit 9cac63b

Please sign in to comment.