mirror of
https://github.com/withastro/astro.git
synced 2025-01-13 22:11:20 -05:00
Rename the ViewTransitions component to ClientRouter (#11980)
* Rename the ViewTransitions component to ClientRouter * oops, move * Move it
This commit is contained in:
parent
3e70853b76
commit
a604a0ca9e
22 changed files with 96 additions and 72 deletions
11
.changeset/hip-wombats-exercise.md
Normal file
11
.changeset/hip-wombats-exercise.md
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
---
|
||||||
|
'astro': minor
|
||||||
|
---
|
||||||
|
|
||||||
|
ViewTransitions component renamed to ClientRouter
|
||||||
|
|
||||||
|
The `<ViewTransitions />` component has been renamed to `<ClientRouter />`. There are no other changes than the name. The old name will continue to work in Astro 5.x, but will be removed in 6.0.
|
||||||
|
|
||||||
|
This change was done to clarify the role of the component within Astro's View Transitions support. Astro supports View Transitions APIs in a few different ways, and renaming the component makes it more clear that the features you get from the ClientRouter component are slightly different from what you get using the native CSS-based MPA router.
|
||||||
|
|
||||||
|
We still intend to maintain the ClientRouter as before, and it's still important for use-cases that the native support doesn't cover, such as persisting state between pages.
|
|
@ -1,5 +1,5 @@
|
||||||
---
|
---
|
||||||
import { ViewTransitions } from 'astro:transitions';
|
import { ClientRouter } from 'astro:transitions';
|
||||||
import SEO, { type Props as SEOProps } from './SEO.astro';
|
import SEO, { type Props as SEOProps } from './SEO.astro';
|
||||||
import { SiteTitle, SiteDescription } from '../consts';
|
import { SiteTitle, SiteDescription } from '../consts';
|
||||||
|
|
||||||
|
@ -17,4 +17,4 @@ const { title = SiteTitle, name = SiteTitle, description = SiteDescription, ...s
|
||||||
rel="stylesheet"
|
rel="stylesheet"
|
||||||
/>
|
/>
|
||||||
|
|
||||||
<ViewTransitions />
|
<ClientRouter />
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
---
|
---
|
||||||
import '../styles/styles.css';
|
import '../styles/styles.css';
|
||||||
import { ViewTransitions } from 'astro:transitions';
|
import { ClientRouter } from 'astro:transitions';
|
||||||
import Footer from '../components/Footer.astro';
|
import Footer from '../components/Footer.astro';
|
||||||
import Nav from '../components/Nav.astro';
|
import Nav from '../components/Nav.astro';
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@ const { title } = Astro.props as Props;
|
||||||
<meta name="generator" content={Astro.generator} />
|
<meta name="generator" content={Astro.generator} />
|
||||||
<meta name="view-transition" content="same-origin" />
|
<meta name="view-transition" content="same-origin" />
|
||||||
<title>{title}</title>
|
<title>{title}</title>
|
||||||
<ViewTransitions />
|
<ClientRouter />
|
||||||
</head>
|
</head>
|
||||||
<body class="font-sans bg-gray-900 text-white">
|
<body class="font-sans bg-gray-900 text-white">
|
||||||
<div class="h-screen overflow-hidden flex flex-col">
|
<div class="h-screen overflow-hidden flex flex-col">
|
||||||
|
|
8
packages/astro/client.d.ts
vendored
8
packages/astro/client.d.ts
vendored
|
@ -116,8 +116,12 @@ declare module 'astro:transitions' {
|
||||||
export const fade: TransitionModule['fade'];
|
export const fade: TransitionModule['fade'];
|
||||||
export const createAnimationScope: TransitionModule['createAnimationScope'];
|
export const createAnimationScope: TransitionModule['createAnimationScope'];
|
||||||
|
|
||||||
type ViewTransitionsModule = typeof import('./components/ViewTransitions.astro');
|
type ClientRouterModule = typeof import('./components/ClientRouter.astro');
|
||||||
export const ViewTransitions: ViewTransitionsModule['default'];
|
/**
|
||||||
|
* @deprecated The ViewTransitions component has been renamed to ClientRouter
|
||||||
|
*/
|
||||||
|
export const ViewTransitions: ClientRouterModule['default'];
|
||||||
|
export const ClientRouter: ClientRouterModule['default'];
|
||||||
}
|
}
|
||||||
|
|
||||||
declare module 'astro:transitions/client' {
|
declare module 'astro:transitions/client' {
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
---
|
---
|
||||||
import { ViewTransitions } from 'astro:transitions';
|
import { ClientRouter } from 'astro:transitions';
|
||||||
---
|
---
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
<title>View Transition Test</title>
|
<title>View Transition Test</title>
|
||||||
<ViewTransitions />
|
<ClientRouter />
|
||||||
<script is:inline>
|
<script is:inline>
|
||||||
// let playwright know when navigate() is done
|
// let playwright know when navigate() is done
|
||||||
document.addEventListener('astro:before-swap', (e) => {
|
document.addEventListener('astro:before-swap', (e) => {
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
---
|
---
|
||||||
import { ViewTransitions } from 'astro:transitions';
|
import { ClientRouter } from 'astro:transitions';
|
||||||
import { HTMLAttributes } from 'astro/types';
|
import { HTMLAttributes } from 'astro/types';
|
||||||
|
|
||||||
interface Props extends HTMLAttributes<'html'> {}
|
interface Props extends HTMLAttributes<'html'> {}
|
||||||
|
@ -7,7 +7,7 @@ interface Props extends HTMLAttributes<'html'> {}
|
||||||
<html {...Astro.props}>
|
<html {...Astro.props}>
|
||||||
<head>
|
<head>
|
||||||
<title>Testing</title>
|
<title>Testing</title>
|
||||||
<ViewTransitions />
|
<ClientRouter />
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<main transition:animate="slide">
|
<main transition:animate="slide">
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
---
|
---
|
||||||
import { ViewTransitions } from 'astro:transitions';
|
import { ClientRouter } from 'astro:transitions';
|
||||||
import DarkMode from './DarkMode.astro';
|
import DarkMode from './DarkMode.astro';
|
||||||
|
|
||||||
interface Props {
|
interface Props {
|
||||||
|
@ -8,25 +8,27 @@ interface Props {
|
||||||
|
|
||||||
const { link } = Astro.props as Props;
|
const { link } = Astro.props as Props;
|
||||||
---
|
---
|
||||||
|
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>Testing</title>
|
<title>Testing</title>
|
||||||
{link ? <link rel="stylesheet" href={link} > : ''}
|
{link ? <link rel="stylesheet" href={link} /> : ''}
|
||||||
<style>
|
<style>
|
||||||
main {
|
main {
|
||||||
max-width: 900px;
|
max-width: 900px;
|
||||||
margin: auto;
|
margin: auto;
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
<link rel="stylesheet" href="/styles.css">
|
<link rel="stylesheet" href="/styles.css" />
|
||||||
<ViewTransitions handleForms />
|
<ClientRouter handleForms />
|
||||||
<DarkMode />
|
<DarkMode />
|
||||||
<meta name="script-executions" content="0">
|
<meta name="script-executions" content="0" />
|
||||||
<meta charset="utf-8">
|
<meta charset="utf-8" />
|
||||||
<script is:inline defer>
|
<script is:inline defer>
|
||||||
{
|
{
|
||||||
// Increment a global to see if this is running more than once
|
// Increment a global to see if this is running more than once
|
||||||
globalThis.scriptExecutions = globalThis.scriptExecutions == null ? -1 : globalThis.scriptExecutions;
|
globalThis.scriptExecutions =
|
||||||
|
globalThis.scriptExecutions == null ? -1 : globalThis.scriptExecutions;
|
||||||
globalThis.scriptExecutions++;
|
globalThis.scriptExecutions++;
|
||||||
const el = document.querySelector('[name="script-executions"]');
|
const el = document.querySelector('[name="script-executions"]');
|
||||||
el.setAttribute('content', globalThis.scriptExecutions);
|
el.setAttribute('content', globalThis.scriptExecutions);
|
||||||
|
|
|
@ -1,21 +1,21 @@
|
||||||
---
|
---
|
||||||
import { ViewTransitions } from 'astro:transitions';
|
import { ClientRouter } from 'astro:transitions';
|
||||||
---
|
---
|
||||||
|
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<ViewTransitions/>
|
<ClientRouter />
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p>Local transitions</p>
|
<p>Local transitions</p>
|
||||||
<slot/>
|
<slot />
|
||||||
<script>
|
<script>
|
||||||
document.addEventListener("astro:after-swap", () => {
|
document.addEventListener('astro:after-swap', () => {
|
||||||
document.documentElement.setAttribute("class", "blue");
|
document.documentElement.setAttribute('class', 'blue');
|
||||||
document.documentElement.setAttribute("animations", "" + document.getAnimations().length);
|
document.documentElement.setAttribute('animations', '' + document.getAnimations().length);
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
</body>
|
</body><style>
|
||||||
<style>
|
|
||||||
p {
|
p {
|
||||||
transition: color 1s;
|
transition: color 1s;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,29 +1,30 @@
|
||||||
---
|
---
|
||||||
import { ViewTransitions } from 'astro:transitions';
|
import { ClientRouter } from 'astro:transitions';
|
||||||
---
|
---
|
||||||
|
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<ViewTransitions />
|
<ClientRouter />
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<h1>Abort</h1>
|
<h1>Abort</h1>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
<script>
|
<script>
|
||||||
import {navigate } from 'astro:transitions/client';
|
import { navigate } from 'astro:transitions/client';
|
||||||
|
|
||||||
document.addEventListener('astro:before-preparation', (e) => {
|
document.addEventListener('astro:before-preparation', (e) => {
|
||||||
const originalLoader = e.loader;
|
const originalLoader = e.loader;
|
||||||
e.loader = async () => {
|
e.loader = async () => {
|
||||||
const result = await originalLoader();
|
const result = await originalLoader();
|
||||||
if (e.to.href.endsWith("/two")) {
|
if (e.to.href.endsWith('/two')) {
|
||||||
// delay loading of /two
|
// delay loading of /two
|
||||||
await new Promise((resolve) => setTimeout(resolve, 1100));
|
await new Promise((resolve) => setTimeout(resolve, 1100));
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
});
|
});
|
||||||
// starts later, but is faster and overtakes the slower navigation
|
// starts later, but is faster and overtakes the slower navigation
|
||||||
setTimeout(()=>navigate("/one"), 400);
|
setTimeout(() => navigate('/one'), 400);
|
||||||
// starts now, but is to slow to keep its lead
|
// starts now, but is to slow to keep its lead
|
||||||
navigate("/two");
|
navigate('/two');
|
||||||
</script>
|
</script>
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
---
|
---
|
||||||
import { ViewTransitions, fade } from 'astro:transitions';
|
import { ClientRouter, fade } from 'astro:transitions';
|
||||||
---
|
---
|
||||||
<html transition:animate="none">
|
<html transition:animate="none">
|
||||||
<head>
|
<head>
|
||||||
<ViewTransitions />
|
<ClientRouter />
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<h1 transition:name="h1" transition:animate={fade({duration:500})}>Abort</h1>
|
<h1 transition:name="h1" transition:animate={fade({duration:500})}>Abort</h1>
|
||||||
|
|
|
@ -1,12 +1,13 @@
|
||||||
---
|
---
|
||||||
import { ViewTransitions } from "astro:transitions";
|
import { ClientRouter } from 'astro:transitions';
|
||||||
import ClickToNavigate from "../components/ClickToNavigate.jsx"
|
import ClickToNavigate from '../components/ClickToNavigate.jsx';
|
||||||
---
|
---
|
||||||
|
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<ViewTransitions />
|
<ClientRouter />
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<ClickToNavigate id="react-client-load-navigate-button" to="/two" client:load/>
|
<ClickToNavigate id="react-client-load-navigate-button" to="/two" client:load />
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -1,16 +1,17 @@
|
||||||
---
|
---
|
||||||
import { ViewTransitions } from "astro:transitions";
|
import { ClientRouter } from 'astro:transitions';
|
||||||
---
|
---
|
||||||
|
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<ViewTransitions />
|
<ClientRouter />
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<button id="open" onclick="modal.showModal()">Open Modal</button>
|
<button id="open" onclick="modal.showModal()">Open Modal</button>
|
||||||
<dialog id="modal">
|
<dialog id="modal">
|
||||||
<form method="dialog">
|
<form method="dialog">
|
||||||
<button id="close">Close</button>
|
<button id="close">Close</button>
|
||||||
</form>
|
</form>
|
||||||
</dialog>
|
</dialog>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
---
|
---
|
||||||
import { ViewTransitions } from 'astro:transitions';
|
import { ClientRouter } from 'astro:transitions';
|
||||||
---
|
---
|
||||||
|
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<ViewTransitions handleForms/>
|
<ClientRouter handleForms />
|
||||||
<meta charset="UTF-8" />
|
<meta charset="UTF-8" />
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
---
|
---
|
||||||
import { ViewTransitions } from 'astro:transitions';
|
import { ClientRouter } from 'astro:transitions';
|
||||||
|
|
||||||
// For the test fixture, we import the script but we don't use the <ViewTransitions /> component
|
// For the test fixture, we import the script but we don't use the <ClientRouter /> component
|
||||||
// While this seems to be some strange mistake,
|
// While this seems to be some strange mistake,
|
||||||
// it might be realistic, e.g. in a configurable CommonHead component
|
// it might be realistic, e.g. in a configurable CommonHead component
|
||||||
|
|
||||||
|
@ -10,10 +10,11 @@ interface Props {
|
||||||
}
|
}
|
||||||
const { transitions } = Astro.props;
|
const { transitions } = Astro.props;
|
||||||
---
|
---
|
||||||
|
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>Half-Baked</title>
|
<title>Half-Baked</title>
|
||||||
{transitions && <ViewTransitions />}
|
{transitions && <ClientRouter />}
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<main>
|
<main>
|
||||||
|
|
|
@ -1,11 +1,11 @@
|
||||||
---
|
---
|
||||||
import { ViewTransitions } from 'astro:transitions';
|
import { ClientRouter } from 'astro:transitions';
|
||||||
|
|
||||||
---
|
---
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>Testing</title>
|
<title>Testing</title>
|
||||||
<ViewTransitions />
|
<ClientRouter />
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p id="one">One</p>
|
<p id="one">One</p>
|
||||||
|
|
|
@ -1,11 +1,11 @@
|
||||||
---
|
---
|
||||||
import { ViewTransitions } from 'astro:transitions';
|
import { ClientRouter } from 'astro:transitions';
|
||||||
|
|
||||||
---
|
---
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>Testing</title>
|
<title>Testing</title>
|
||||||
<ViewTransitions />
|
<ClientRouter />
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p id="two">Two</p>
|
<p id="two">Two</p>
|
||||||
|
|
|
@ -114,7 +114,7 @@ test.describe('View Transitions', () => {
|
||||||
expect(loads.length, 'There should only be 1 page load').toEqual(1);
|
expect(loads.length, 'There should only be 1 page load').toEqual(1);
|
||||||
});
|
});
|
||||||
|
|
||||||
test('Moving to a page without ViewTransitions triggers a full page navigation', async ({
|
test('Moving to a page without ClientRouter triggers a full page navigation', async ({
|
||||||
page,
|
page,
|
||||||
astro,
|
astro,
|
||||||
}) => {
|
}) => {
|
||||||
|
@ -125,7 +125,7 @@ test.describe('View Transitions', () => {
|
||||||
let p = page.locator('#one');
|
let p = page.locator('#one');
|
||||||
await expect(p, 'should have content').toHaveText('Page 1');
|
await expect(p, 'should have content').toHaveText('Page 1');
|
||||||
|
|
||||||
// Go to page 3 which does *not* have ViewTransitions enabled
|
// Go to page 3 which does *not* have ClientRouter enabled
|
||||||
await page.click('#click-three');
|
await page.click('#click-three');
|
||||||
p = page.locator('#three');
|
p = page.locator('#three');
|
||||||
await expect(p, 'should have content').toHaveText('Page 3');
|
await expect(p, 'should have content').toHaveText('Page 3');
|
||||||
|
@ -136,7 +136,7 @@ test.describe('View Transitions', () => {
|
||||||
).toEqual(2);
|
).toEqual(2);
|
||||||
});
|
});
|
||||||
|
|
||||||
test('Moving within a page without ViewTransitions does not trigger a full page navigation', async ({
|
test('Moving within a page without ClientRouter does not trigger a full page navigation', async ({
|
||||||
page,
|
page,
|
||||||
astro,
|
astro,
|
||||||
}) => {
|
}) => {
|
||||||
|
@ -146,7 +146,7 @@ test.describe('View Transitions', () => {
|
||||||
let p = page.locator('#one');
|
let p = page.locator('#one');
|
||||||
await expect(p, 'should have content').toHaveText('Page 1');
|
await expect(p, 'should have content').toHaveText('Page 1');
|
||||||
|
|
||||||
// Go to page 3 which does *not* have ViewTransitions enabled
|
// Go to page 3 which does *not* have ClientRouter enabled
|
||||||
await page.click('#click-three');
|
await page.click('#click-three');
|
||||||
p = page.locator('#three');
|
p = page.locator('#three');
|
||||||
await expect(p, 'should have content').toHaveText('Page 3');
|
await expect(p, 'should have content').toHaveText('Page 3');
|
||||||
|
@ -167,14 +167,14 @@ test.describe('View Transitions', () => {
|
||||||
).toEqual(2);
|
).toEqual(2);
|
||||||
});
|
});
|
||||||
|
|
||||||
test('Moving from a page without ViewTransitions w/ back button', async ({ page, astro }) => {
|
test('Moving from a page without ClientRouter w/ back button', async ({ page, astro }) => {
|
||||||
const loads = collectLoads(page);
|
const loads = collectLoads(page);
|
||||||
// Go to page 1
|
// Go to page 1
|
||||||
await page.goto(astro.resolveUrl('/one'));
|
await page.goto(astro.resolveUrl('/one'));
|
||||||
let p = page.locator('#one');
|
let p = page.locator('#one');
|
||||||
await expect(p, 'should have content').toHaveText('Page 1');
|
await expect(p, 'should have content').toHaveText('Page 1');
|
||||||
|
|
||||||
// Go to page 3 which does *not* have ViewTransitions enabled
|
// Go to page 3 which does *not* have ClientRouter enabled
|
||||||
await page.click('#click-three');
|
await page.click('#click-three');
|
||||||
p = page.locator('#three');
|
p = page.locator('#three');
|
||||||
await expect(p, 'should have content').toHaveText('Page 3');
|
await expect(p, 'should have content').toHaveText('Page 3');
|
||||||
|
@ -606,7 +606,7 @@ test.describe('View Transitions', () => {
|
||||||
await expect(loads.length, 'There should only be 1 page load').toEqual(1);
|
await expect(loads.length, 'There should only be 1 page load').toEqual(1);
|
||||||
});
|
});
|
||||||
|
|
||||||
test('Importing ViewTransitions w/o using the component must not mess with history', async ({
|
test('Importing ClientRouter w/o using the component must not mess with history', async ({
|
||||||
page,
|
page,
|
||||||
astro,
|
astro,
|
||||||
}) => {
|
}) => {
|
||||||
|
@ -706,7 +706,7 @@ test.describe('View Transitions', () => {
|
||||||
expect(loads.length, 'There should be 2 page load').toEqual(2);
|
expect(loads.length, 'There should be 2 page load').toEqual(2);
|
||||||
});
|
});
|
||||||
|
|
||||||
test('Scroll position is restored on back navigation from page w/o ViewTransitions', async ({
|
test('Scroll position is restored on back navigation from page w/o ClientRouter', async ({
|
||||||
page,
|
page,
|
||||||
astro,
|
astro,
|
||||||
}) => {
|
}) => {
|
||||||
|
@ -716,7 +716,7 @@ test.describe('View Transitions', () => {
|
||||||
let locator = page.locator('#click-external');
|
let locator = page.locator('#click-external');
|
||||||
await expect(locator).toBeInViewport();
|
await expect(locator).toBeInViewport();
|
||||||
|
|
||||||
// Go to a page that has not enabled ViewTransitions
|
// Go to a page that has not enabled ClientRouter
|
||||||
await page.click('#click-external');
|
await page.click('#click-external');
|
||||||
locator = page.locator('#three');
|
locator = page.locator('#three');
|
||||||
await expect(locator).toHaveText('Page 3');
|
await expect(locator).toHaveText('Page 3');
|
||||||
|
|
|
@ -428,7 +428,7 @@ async function transition(
|
||||||
// see https://developer.mozilla.org/en-US/docs/Web/API/DOMParser/parseFromString
|
// see https://developer.mozilla.org/en-US/docs/Web/API/DOMParser/parseFromString
|
||||||
preparationEvent.newDocument.querySelectorAll('noscript').forEach((el) => el.remove());
|
preparationEvent.newDocument.querySelectorAll('noscript').forEach((el) => el.remove());
|
||||||
|
|
||||||
// If ViewTransitions is not enabled on the incoming page, do a full page load to it.
|
// If ClientRouter is not enabled on the incoming page, do a full page load to it.
|
||||||
// Unless this was a form submission, in which case we do not want to trigger another mutation.
|
// Unless this was a form submission, in which case we do not want to trigger another mutation.
|
||||||
if (
|
if (
|
||||||
!preparationEvent.newDocument.querySelector('[name="astro-view-transitions-enabled"]') &&
|
!preparationEvent.newDocument.querySelector('[name="astro-view-transitions-enabled"]') &&
|
||||||
|
|
|
@ -29,7 +29,10 @@ export default function astroTransitions({ settings }: { settings: AstroSettings
|
||||||
if (id === resolvedVirtualModuleId) {
|
if (id === resolvedVirtualModuleId) {
|
||||||
return `
|
return `
|
||||||
export * from "astro/virtual-modules/transitions.js";
|
export * from "astro/virtual-modules/transitions.js";
|
||||||
export { default as ViewTransitions } from "astro/components/ViewTransitions.astro";
|
export {
|
||||||
|
default as ViewTransitions,
|
||||||
|
default as ClientRouter
|
||||||
|
} from "astro/components/ClientRouter.astro";
|
||||||
`;
|
`;
|
||||||
}
|
}
|
||||||
if (id === resolvedVirtualClientModuleId) {
|
if (id === resolvedVirtualClientModuleId) {
|
||||||
|
@ -47,7 +50,7 @@ export default function astroTransitions({ settings }: { settings: AstroSettings
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
transform(code, id) {
|
transform(code, id) {
|
||||||
if (id.includes('ViewTransitions.astro') && id.endsWith('.ts')) {
|
if (id.includes('ClientRouter.astro') && id.endsWith('.ts')) {
|
||||||
const prefetchDisabled = settings.config.prefetch === false;
|
const prefetchDisabled = settings.config.prefetch === false;
|
||||||
return code.replace('__PREFETCH_DISABLED__', JSON.stringify(prefetchDisabled));
|
return code.replace('__PREFETCH_DISABLED__', JSON.stringify(prefetchDisabled));
|
||||||
}
|
}
|
||||||
|
|
|
@ -835,7 +835,7 @@ export interface AstroUserConfig {
|
||||||
* @type {boolean | object}
|
* @type {boolean | object}
|
||||||
* @description
|
* @description
|
||||||
* Enable prefetching for links on your site to provide faster page transitions.
|
* Enable prefetching for links on your site to provide faster page transitions.
|
||||||
* (Enabled by default on pages using the `<ViewTransitions />` router. Set `prefetch: false` to opt out of this behaviour.)
|
* (Enabled by default on pages using the `<ClientRouter />` router. Set `prefetch: false` to opt out of this behaviour.)
|
||||||
*
|
*
|
||||||
* This configuration automatically adds a prefetch script to every page in the project
|
* This configuration automatically adds a prefetch script to every page in the project
|
||||||
* giving you access to the `data-astro-prefetch` attribute.
|
* giving you access to the `data-astro-prefetch` attribute.
|
||||||
|
@ -857,7 +857,7 @@ export interface AstroUserConfig {
|
||||||
* @type {boolean}
|
* @type {boolean}
|
||||||
* @description
|
* @description
|
||||||
* Enable prefetching for all links, including those without the `data-astro-prefetch` attribute.
|
* Enable prefetching for all links, including those without the `data-astro-prefetch` attribute.
|
||||||
* This value defaults to `true` when using the `<ViewTransitions />` router. Otherwise, the default value is `false`.
|
* This value defaults to `true` when using the `<ClientRouter />` router. Otherwise, the default value is `false`.
|
||||||
*
|
*
|
||||||
* ```js
|
* ```js
|
||||||
* prefetch: {
|
* prefetch: {
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
---
|
---
|
||||||
import { ViewTransitions } from 'astro:transitions';
|
import { ClientRouter } from 'astro:transitions';
|
||||||
import 'open-props/normalize';
|
import 'open-props/normalize';
|
||||||
import 'open-props/style';
|
import 'open-props/style';
|
||||||
|
|
||||||
|
@ -19,7 +19,7 @@ const { title } = Astro.props;
|
||||||
<link rel="icon" type="image/svg+xml" href="/favicon.svg" />
|
<link rel="icon" type="image/svg+xml" href="/favicon.svg" />
|
||||||
<meta name="generator" content={Astro.generator} />
|
<meta name="generator" content={Astro.generator} />
|
||||||
<title>{title}</title>
|
<title>{title}</title>
|
||||||
<ViewTransitions handleForms />
|
<ClientRouter handleForms />
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<slot />
|
<slot />
|
||||||
|
|
Loading…
Add table
Reference in a new issue