diff --git a/packages/svelte/src/internal/client/dom/elements/events.js b/packages/svelte/src/internal/client/dom/elements/events.js
index 536b1c044244..b030996fbcb8 100644
--- a/packages/svelte/src/internal/client/dom/elements/events.js
+++ b/packages/svelte/src/internal/client/dom/elements/events.js
@@ -122,22 +122,22 @@ export function handle_event_propagation(handler_element, event) {
}
});
- /** @param {Element} current_target */
- function next(current_target) {
+ /** @param {Element} next_target */
+ function next(next_target) {
+ current_target = next_target;
/** @type {null | Element} */
- var parent_element =
- current_target.parentNode || /** @type {any} */ (current_target).host || null;
+ var parent_element = next_target.parentNode || /** @type {any} */ (next_target).host || null;
try {
// @ts-expect-error
- var delegated = current_target['__' + event_name];
+ var delegated = next_target['__' + event_name];
- if (delegated !== undefined && !(/** @type {any} */ (current_target).disabled)) {
+ if (delegated !== undefined && !(/** @type {any} */ (next_target).disabled)) {
if (is_array(delegated)) {
var [fn, ...data] = delegated;
- fn.apply(current_target, [event, ...data]);
+ fn.apply(next_target, [event, ...data]);
} else {
- delegated.call(current_target, event);
+ delegated.call(next_target, event);
}
}
} finally {
@@ -145,7 +145,7 @@ export function handle_event_propagation(handler_element, event) {
!event.cancelBubble &&
parent_element !== handler_element &&
parent_element !== null &&
- current_target !== handler_element
+ next_target !== handler_element
) {
next(parent_element);
}
diff --git a/packages/svelte/tests/runtime-runes/samples/event-prop-current-target/_config.js b/packages/svelte/tests/runtime-runes/samples/event-prop-current-target/_config.js
new file mode 100644
index 000000000000..f6f5c3b7d949
--- /dev/null
+++ b/packages/svelte/tests/runtime-runes/samples/event-prop-current-target/_config.js
@@ -0,0 +1,12 @@
+import { test } from '../../test';
+
+export default test({
+ async test({ assert, target, logs }) {
+ const [s1] = target.querySelectorAll('span');
+
+ s1?.click();
+ await Promise.resolve();
+
+ assert.deepEqual(logs, [false]);
+ }
+});
diff --git a/packages/svelte/tests/runtime-runes/samples/event-prop-current-target/main.svelte b/packages/svelte/tests/runtime-runes/samples/event-prop-current-target/main.svelte
new file mode 100644
index 000000000000..60fbe8baeb05
--- /dev/null
+++ b/packages/svelte/tests/runtime-runes/samples/event-prop-current-target/main.svelte
@@ -0,0 +1,13 @@
+
+
+
+