fix: apply event attribute validation to elements only (#9772)

fixes #9755
pull/9783/head
Simon H 1 year ago committed by GitHub
parent ede5dab230
commit ef158ff729
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -0,0 +1,5 @@
---
'svelte': patch
---
fix: apply event attribute validation to elements only

@ -65,12 +65,24 @@ function validate_element(node, context) {
error(attribute, 'invalid-attribute-name', attribute.name); error(attribute, 'invalid-attribute-name', attribute.name);
} }
if (attribute.name === 'is' && context.state.options.namespace !== 'foreign') { if (attribute.name.startsWith('on') && attribute.name.length > 2) {
warn(context.state.analysis.warnings, attribute, context.path, 'avoid-is'); if (
} else if (attribute.name === 'slot') { attribute.value === true ||
is_text_attribute(attribute) ||
attribute.value.length > 1
) {
error(attribute, 'invalid-event-attribute-value');
}
}
if (attribute.name === 'slot') {
/** @type {import('#compiler').RegularElement | import('#compiler').SvelteElement | import('#compiler').Component | import('#compiler').SvelteComponent | import('#compiler').SvelteSelf | undefined} */ /** @type {import('#compiler').RegularElement | import('#compiler').SvelteElement | import('#compiler').Component | import('#compiler').SvelteComponent | import('#compiler').SvelteSelf | undefined} */
validate_slot_attribute(context, attribute); validate_slot_attribute(context, attribute);
} }
if (attribute.name === 'is' && context.state.options.namespace !== 'foreign') {
warn(context.state.analysis.warnings, attribute, context.path, 'avoid-is');
}
} else if (attribute.type === 'AnimateDirective') { } else if (attribute.type === 'AnimateDirective') {
const parent = context.path.at(-2); const parent = context.path.at(-2);
if (parent?.type !== 'EachBlock') { if (parent?.type !== 'EachBlock') {
@ -316,13 +328,6 @@ function is_tag_valid_with_parent(tag, parent_tag) {
* @type {import('zimmerframe').Visitors<import('#compiler').SvelteNode, import('./types.js').AnalysisState>} * @type {import('zimmerframe').Visitors<import('#compiler').SvelteNode, import('./types.js').AnalysisState>}
*/ */
export const validation = { export const validation = {
Attribute(node) {
if (node.name.startsWith('on') && node.name.length > 2) {
if (node.value === true || is_text_attribute(node) || node.value.length > 1) {
error(node, 'invalid-event-attribute-value');
}
}
},
BindDirective(node, context) { BindDirective(node, context) {
validate_no_const_assignment(node, node.expression, context.state.scope, true); validate_no_const_assignment(node, node.expression, context.state.scope, true);

@ -0,0 +1,14 @@
[
{
"message": "Event attribute must be a JavaScript expression, not a string",
"code": "invalid-event-attribute-value",
"start": {
"line": 4,
"column": 8
},
"end": {
"line": 4,
"column": 21
}
}
]

@ -0,0 +1,4 @@
<button onclick={() => {}}>ok</button>
<Button onclick onbar="bar">ok</Button>
<button onclick="foo">not ok</button>
Loading…
Cancel
Save