Skip to content

Commit

Permalink
add example
Browse files Browse the repository at this point in the history
  • Loading branch information
brillout committed Aug 8, 2024
1 parent 647aa49 commit e5bd021
Show file tree
Hide file tree
Showing 3 changed files with 78 additions and 3 deletions.
33 changes: 30 additions & 3 deletions examples/full/.testRun.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ export { testRun };

import { test, expect, run, fetchHtml, page, getServerUrl, autoRetry, partRegex } from "@brillout/test-e2e";
import assert from "node:assert";
const dataHk = partRegex`data-hk="${/[0-9-]+/}"`;

let isProd: boolean;

Expand Down Expand Up @@ -41,6 +42,8 @@ function testRun(cmd: `pnpm run ${"dev" | "preview"}`) {
});

testNavigationBetweenWithSSRAndWithoutSSR();

testUseConfig();
}

function testNavigationBetweenWithSSRAndWithoutSSR() {
Expand Down Expand Up @@ -105,10 +108,8 @@ function testUrl({
expect(html).toContain(text);
}

const dataHkHash = /[0-9-]+/;

expect(getTitle(html)).toBe(title);
expect(html).toMatch(partRegex`<link data-hk="${dataHkHash}" rel="icon" href="${getAssetUrl("logo.svg")}">`);
expect(html).toMatch(partRegex`<link ${dataHk} rel="icon" href="${getAssetUrl("logo.svg")}">`);

if (!description) description = "Demo showcasing Vike + Solid";
expect(html).toMatch(partRegex`<meta name="description" content="${description}">`);
Expand All @@ -123,6 +124,32 @@ function testUrl({
});
}

function testUseConfig() {
test("useConfig() HTML", async () => {
const html = await fetchHtml("/images");
expect(html).toMatch(
partRegex`<script ${dataHk} type="application/ld+json">{"@context":"https://schema.org/","contentUrl":{"src":"${getAssetUrl(
"logo-new.svg",
)}"},"creator":{"@type":"Person","name":"brillout"}}</script>`,
);
expect(html).toMatch(
partRegex`<script ${dataHk} type="application/ld+json">{"@context":"https://schema.org/","contentUrl":{"src":"${getAssetUrl(
"logo.svg",
)}"},"creator":{"@type":"Person","name":"Romuald Brillout"}}</script>`,
);
});
test("useConfig() hydration", async () => {
await page.goto(getServerUrl() + "/");
await testCounter();
ensureWasClientSideRouted("/pages/index");
await page.click('a:has-text("useConfig()")');
await testCounter();
ensureWasClientSideRouted("/pages/index");
await page.goto(getServerUrl() + "/images");
await testCounter();
});
}

function getTitle(html: string) {
const title = html.match(/<title>(.*?)<\/title>/i)?.[1];
return title;
Expand Down
1 change: 1 addition & 0 deletions examples/full/pages/+Layout.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ export function Layout(props: { children?: JSX.Element }) {
<Link href="/without-ssr">Without SSR</Link>
<Link href="/starship">Nested Layout 1</Link>
<Link href="/stardust">Nested Layout 2</Link>
<Link href="/images">useConfig()</Link>
</Sidebar>
<Content>{props.children}</Content>
</div>
Expand Down
47 changes: 47 additions & 0 deletions examples/full/pages/images/+Page.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
export { Page };

import { Head } from "vike-solid/Head";
import logoOld from "../../assets/logo.svg";
import logoNew from "../../assets/logo-new.svg";
import { Counter } from "../../components/Counter";

function Page() {
return (
<>
<p>
Page showcasing an <code>&lt;Image&gt;</code> component that adds/teleports structured data (
<code>&lt;script type="application/ld+json"&gt;</code>) to <code>&lt;head&gt;</code>, see HTML.
</p>
<div>
New logo: <Image src={logoNew} author="brillout" />
</div>
<br />
<div>
Old logo: <Image src={logoOld} author="Romuald Brillout" />
</div>
<br />
<Counter />
</>
);
}

function Image({ src, author }: { src: string; author: string }) {
return (
<>
<img src={src} height={48} style={{ "vertical-align": "middle", "margin-left": "10px" }} />
<Head>
<script
type="application/ld+json"
innerHTML={JSON.stringify({
"@context": "https://schema.org/",
contentUrl: { src },
creator: {
"@type": "Person",
name: author,
},
})}
></script>
</Head>
</>
);
}

0 comments on commit e5bd021

Please sign in to comment.