Revert "fix: address bug in before/after update" (#9480)

* Revert "fix: address bug in before/after update (#9448)"

This reverts commit 9eb969ddd4.

* add changeset
pull/9481/head
Dominic Gannaway 1 year ago committed by GitHub
parent 7e94dee955
commit 60c273eb76
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -0,0 +1,5 @@
---
'svelte': patch
---
revert: address bug in before/after update

@ -1,5 +0,0 @@
---
'svelte': patch
---
fix: corrects a beforeUpdate/afterUpdate bug

@ -960,18 +960,10 @@ export function set_signal_value(signal, value) {
schedule_effect(current_effect, false); schedule_effect(current_effect, false);
} }
mark_signal_consumers(signal, DIRTY, true); mark_signal_consumers(signal, DIRTY, true);
// This logic checks if there are any render effects queued after the above marking // If we have afterUpdates locally on the component, but we're within a render effect
// of consumers. If there are render effects that have the same component context as // then we will need to manually invoke the beforeUpdate/afterUpdate logic.
// the source signal we're writing to, then we can bail-out of this logic as there
// will be a render effect in the queue that hopefully takes case of triggering the
// beforeUpdate/afterUpdate logic (doing it again here would duplicate them). However,
// if the render effects scheduled in the queue are unrelated to the component context,
// then we need to trigger the beforeUpdate/afterUpdate logic here instead.
// TODO: should we put this being a is_runes check and only run it in non-runes mode? // TODO: should we put this being a is_runes check and only run it in non-runes mode?
if ( if (current_effect === null && current_queued_pre_and_render_effects.length === 0) {
current_effect === null &&
current_queued_pre_and_render_effects.every((e) => e.context !== component_context)
) {
const update_callbacks = component_context?.update_callbacks; const update_callbacks = component_context?.update_callbacks;
if (update_callbacks != null) { if (update_callbacks != null) {
update_callbacks.before.forEach(/** @param {any} c */ (c) => c()); update_callbacks.before.forEach(/** @param {any} c */ (c) => c());

@ -1,7 +0,0 @@
<script>
const {count, increment} = $props();
</script>
<button onclick={increment}>
{count}
</button>

@ -1,15 +0,0 @@
import { flushSync } from 'svelte';
import { test } from '../../test';
export default test({
html: '<button>0</button>',
async test({ assert, target, component }) {
const [btn] = target.querySelectorAll('button');
flushSync(() => {
btn.click();
});
assert.deepEqual(component.log, ['beforeUpdate', 'afterUpdate']);
assert.htmlEqual(target.innerHTML, `<button>1</button>`);
}
});

@ -1,22 +0,0 @@
<script>
import Child from './Child.svelte'
import {afterUpdate, beforeUpdate} from 'svelte';
const {log = []} = $props();
let count = $state(0);
const increment = () => {
count++;
}
beforeUpdate(() => {
log.push('beforeUpdate');
});
afterUpdate(() => {
log.push('afterUpdate');
});
</script>
<Child count={count} increment={increment} />
Loading…
Cancel
Save