diff --git a/.changeset/proud-fans-type.md b/.changeset/proud-fans-type.md
new file mode 100644
index 000000000..8b58da136
--- /dev/null
+++ b/.changeset/proud-fans-type.md
@@ -0,0 +1,5 @@
+---
+'astro': minor
+---
+
+Finalize View Transition event names
diff --git a/packages/astro/components/ViewTransitions.astro b/packages/astro/components/ViewTransitions.astro
index 85d5124e9..42e8deb74 100644
--- a/packages/astro/components/ViewTransitions.astro
+++ b/packages/astro/components/ViewTransitions.astro
@@ -17,14 +17,14 @@ const { fallback = 'animate' } = Astro.props as Props;
index: number;
scrollY: number;
};
- type Events = 'astro:load' | 'astro:beforeload';
+ type Events = 'astro:page-load' | 'astro:after-swap';
const persistState = (state: State) => history.replaceState(state, '');
const supportsViewTransitions = !!document.startViewTransition;
const transitionEnabledOnThisPage = () =>
!!document.querySelector('[name="astro-view-transitions-enabled"]');
const triggerEvent = (name: Events) => document.dispatchEvent(new Event(name));
- const onload = () => triggerEvent('astro:load');
+ const onPageLoad = () => triggerEvent('astro:page-load');
const PERSIST_ATTR = 'data-astro-transition-persist';
// The History API does not tell you if navigation is forward or back, so
@@ -193,7 +193,7 @@ const { fallback = 'animate' } = Astro.props as Props;
scrollTo(0, state.scrollY); // usings default scrollBehavior
}
- triggerEvent('astro:beforeload');
+ triggerEvent('astro:after-swap');
};
// Wait on links to finish, to prevent FOUC
@@ -263,7 +263,7 @@ const { fallback = 'animate' } = Astro.props as Props;
// document.documentElement.removeAttribute('data-astro-transition');
await runScripts();
markScriptsExec();
- onload();
+ onPageLoad();
}
}
@@ -383,7 +383,7 @@ const { fallback = 'animate' } = Astro.props as Props;
{ passive: true, capture: true }
);
});
- addEventListener('load', onload);
+ addEventListener('load', onPageLoad);
// There's not a good way to record scroll position before a back button.
// So the way we do it is by listening to scroll and just continuously recording it.
addEventListener(
diff --git a/packages/astro/e2e/fixtures/view-transitions/src/components/DarkMode.astro b/packages/astro/e2e/fixtures/view-transitions/src/components/DarkMode.astro
index b8eb585c8..39cb4b952 100644
--- a/packages/astro/e2e/fixtures/view-transitions/src/components/DarkMode.astro
+++ b/packages/astro/e2e/fixtures/view-transitions/src/components/DarkMode.astro
@@ -6,7 +6,7 @@
}
toggle();
- document.addEventListener('astro:beforeload', () => {
+ document.addEventListener('astro:after-swap', () => {
toggle();
})
diff --git a/packages/astro/e2e/fixtures/view-transitions/src/pages/two.astro b/packages/astro/e2e/fixtures/view-transitions/src/pages/two.astro
index 84b16f259..af67edbd5 100644
--- a/packages/astro/e2e/fixtures/view-transitions/src/pages/two.astro
+++ b/packages/astro/e2e/fixtures/view-transitions/src/pages/two.astro
@@ -6,7 +6,7 @@ import Layout from '../components/Layout.astro';
diff --git a/packages/astro/e2e/view-transitions.test.js b/packages/astro/e2e/view-transitions.test.js
index 11b6d1e13..02fb76e4f 100644
--- a/packages/astro/e2e/view-transitions.test.js
+++ b/packages/astro/e2e/view-transitions.test.js
@@ -181,7 +181,7 @@ test.describe('View Transitions', () => {
await expect(p, 'imported CSS updated').toHaveCSS('font-size', '24px');
});
- test('astro:load event fires when navigating to new page', async ({ page, astro }) => {
+ test('astro:page-load event fires when navigating to new page', async ({ page, astro }) => {
// Go to page 1
await page.goto(astro.resolveUrl('/one'));
const p = page.locator('#one');
@@ -193,14 +193,14 @@ test.describe('View Transitions', () => {
await expect(article, 'should have script content').toHaveText('works');
});
- test('astro:load event fires when navigating directly to a page', async ({ page, astro }) => {
+ test('astro:page-load event fires when navigating directly to a page', async ({ page, astro }) => {
// Go to page 2
await page.goto(astro.resolveUrl('/two'));
const article = page.locator('#twoarticle');
await expect(article, 'should have script content').toHaveText('works');
});
- test('astro:beforeload event fires right before the swap', async ({ page, astro }) => {
+ test('astro:after-swap event fires right after the swap', async ({ page, astro }) => {
// Go to page 1
await page.goto(astro.resolveUrl('/one'));
let p = page.locator('#one');