You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
{{ message }}
This repository has been archived by the owner on Jan 11, 2023. It is now read-only.
Describe the bug
When you use $preloading in template and:
You put it inside of a component that uses slot and that component uses a component that uses slot and that component uses a slot. So {$preloading} end up in 3 level of slots.
You use exported property along with {$preloading} inside of component.
Navigate to same route but with different parameters just to trigger preload.
$preloading value in the template turns to true once preload is started but doesn't return back to false once preload is finished.
You should see that all the preloading values remain false (or quickly turn to true and then false) but the one in Deep3 component that uses exported props turn to true and stays like that.
Deep1.svelte
<div><slot></slot></div>
Deep2.svelte
<Deep1><slot></slot></Deep1>
Deep3.svelte
<Deep2><slot></slot></Deep2>
index.svelte
...
<Deep2>
{$preloading} <!-- This works -->
{exportedProp}
</Deep2>
<Deep3>
{$preloading} <!-- This doesn't. It first shows false, upon navigation turns to true and stays true-->
{exportedProp}
</Deep3>
<Deep3>
{$preloading} <!-- This also works-->
</Deep3>
Expected behavior
All {$preloading} expressions in the template should return to false once preload function is finished.
Severity
As a workaround you can assign $preloading value to a variable after a tick() so it's not too severe.
The text was updated successfully, but these errors were encountered:
Sign up for freeto subscribe to this conversation on GitHub.
Already have an account?
Sign in.
Describe the bug
When you use
$preloading
in template and:{$preloading}
end up in 3 level of slots.{$preloading}
inside of component.$preloading
value in the template turns totrue
once preload is started but doesn't return back tofalse
once preload is finished.To Reproduce
Here is a minimal Sapper project to recreate the problem: https://github.com/mirvaris/SapperPreloadingSlots
npm run dev
You should see that all the preloading values remain
false
(or quickly turn totrue
and thenfalse
) but the one in Deep3 component that uses exported props turn totrue
and stays like that.Deep1.svelte
Deep2.svelte
Deep3.svelte
index.svelte
Expected behavior
All
{$preloading}
expressions in the template should return tofalse
once preload function is finished.Severity
As a workaround you can assign
$preloading
value to a variable after atick()
so it's not too severe.The text was updated successfully, but these errors were encountered: