diff options
-rw-r--r-- | .changeset/wicked-books-appear.md | 5 | ||||
-rw-r--r-- | packages/astro/src/vite-plugin-astro/hmr.ts | 4 |
2 files changed, 7 insertions, 2 deletions
diff --git a/.changeset/wicked-books-appear.md b/.changeset/wicked-books-appear.md new file mode 100644 index 000000000..930091da7 --- /dev/null +++ b/.changeset/wicked-books-appear.md @@ -0,0 +1,5 @@ +--- +'astro': patch +--- + +Fix edge case where `<style>` updates inside of `.astro` files would ocassionally fail to update without reloading the page. diff --git a/packages/astro/src/vite-plugin-astro/hmr.ts b/packages/astro/src/vite-plugin-astro/hmr.ts index 27cc2d10f..ca1c13a95 100644 --- a/packages/astro/src/vite-plugin-astro/hmr.ts +++ b/packages/astro/src/vite-plugin-astro/hmr.ts @@ -97,8 +97,8 @@ export async function handleHotUpdate( // If only styles are changed, remove the component file from the update list if (isStyleOnlyChange) { logger.info('astro', msg.hmr({ file, style: true })); - // remove base file and hoisted scripts - return mods.filter((mod) => mod.id !== ctx.file && !mod.id?.endsWith('.ts')); + // Only return the Astro styles that have changed! + return mods.filter((mod) => mod.id?.includes('astro&type=style')); } // Add hoisted scripts so these get invalidated |