Some checks failed
Test examples / Test Examples (20) (push) Has been cancelled
Test examples / Test Examples (22) (push) Has been cancelled
Lock Threads / action (push) Has been cancelled
Trigger Release / start (push) Has been cancelled
Stale issue handler / stale (push) Has been cancelled
Update Font Data / create-pull-request (push) Has been cancelled
build-and-deploy / deploy-target (push) Has been cancelled
build-and-deploy / build (push) Has been cancelled
build-and-deploy / stable - aarch64-unknown-linux-musl - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-unknown-linux-musl - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-unknown-linux-gnu - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-unknown-linux-gnu - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-pc-windows-msvc - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-pc-windows-msvc - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-apple-darwin - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-apple-darwin - node@16 (push) Has been cancelled
build-and-deploy / build-wasm (nodejs) (push) Has been cancelled
build-and-deploy / build-wasm (web) (push) Has been cancelled
build-and-deploy / Deploy preview tarball (push) Has been cancelled
build-and-deploy / Potentially publish release (push) Has been cancelled
build-and-deploy / publish-turbopack-npm-packages (push) Has been cancelled
build-and-deploy / Deploy examples (push) Has been cancelled
build-and-deploy / thank you, build (push) Has been cancelled
build-and-deploy / Upload Turbopack Bytesize metrics to Datadog (push) Has been cancelled
Rspack Next.js development integration tests / Rspack integration tests (push) Has been cancelled
Rspack Next.js production integration tests / Rspack integration tests (push) Has been cancelled
Turbopack Next.js development integration tests / Next.js integration tests (push) Has been cancelled
Turbopack Next.js production integration tests / Next.js integration tests (push) Has been cancelled
Update Rspack test manifest / Update and upload Rspack development test manifest (push) Has been cancelled
Update Rspack test manifest / Update and upload Rspack production test manifest (push) Has been cancelled
Upload bundler test manifests to areweturboyet.com / Upload test results (push) Has been cancelled
Update React / create-pull-request (push) Has been cancelled
test-e2e-project-reset-cron / reset-test-project (push) Has been cancelled
Notify about the top 15 issues/PRs/feature requests (most reacted) in the last 90 days / run (push) Has been cancelled
71 lines
2.0 KiB
TypeScript
71 lines
2.0 KiB
TypeScript
// app/page.tsx
|
|
|
|
"use client"; // Required for client-side rendering
|
|
|
|
import { useState } from "react";
|
|
import Header from "./_components/Header"; // Adjust the path based on your directory structure
|
|
import dynamic from "next/dynamic";
|
|
|
|
const DynamicComponent1 = dynamic(() => import("./_components/hello1"));
|
|
|
|
const DynamicComponent2WithCustomLoading = dynamic(
|
|
() => import("./_components/hello2"),
|
|
{ loading: () => <p>Loading caused by client page transition ...</p> },
|
|
);
|
|
|
|
const DynamicComponent3WithNoSSR = dynamic(
|
|
() => import("./_components/hello3"),
|
|
{ loading: () => <p>Loading ...</p>, ssr: false },
|
|
);
|
|
|
|
const DynamicComponent4 = dynamic(() => import("./_components/hello4"));
|
|
|
|
const DynamicComponent5 = dynamic(() => import("./_components/hello5"));
|
|
|
|
const names = ["Tim", "Joe", "Bel", "Max", "Lee"];
|
|
|
|
export default function IndexPage() {
|
|
const [showMore, setShowMore] = useState(false);
|
|
const [falsyField] = useState(false);
|
|
const [results, setResults] = useState();
|
|
|
|
return (
|
|
<div>
|
|
<Header />
|
|
|
|
{/* Load immediately, but in a separate bundle */}
|
|
<DynamicComponent1 />
|
|
|
|
{/* Show a progress indicator while loading */}
|
|
<DynamicComponent2WithCustomLoading />
|
|
|
|
{/* Load only on the client side */}
|
|
<DynamicComponent3WithNoSSR />
|
|
|
|
{/* This component will never be loaded */}
|
|
{falsyField && <DynamicComponent4 />}
|
|
|
|
{/* Load on demand */}
|
|
{showMore && <DynamicComponent5 />}
|
|
<button onClick={() => setShowMore(!showMore)}>Toggle Show More</button>
|
|
|
|
{/* Load library on demand */}
|
|
<div style={{ marginTop: "1rem" }}>
|
|
<input
|
|
type="text"
|
|
placeholder="Search"
|
|
onChange={async (e) => {
|
|
const { value } = e.currentTarget;
|
|
// Dynamically load fuse.js
|
|
const Fuse = (await import("fuse.js")).default;
|
|
const fuse = new Fuse(names);
|
|
|
|
setResults(fuse.search(value));
|
|
}}
|
|
/>
|
|
<pre>Results: {JSON.stringify(results, null, 2)}</pre>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|