Files
next-learn/seo/pages/index.js
2025-01-23 08:16:22 -06:00

114 lines
3.1 KiB
JavaScript

import { useState } from 'react';
import Head from 'next/head';
import Fuse from 'fuse.js';
import _ from 'lodash';
import { countries } from '../countries';
import styles from '../styles/Home.module.css';
import CodeSampleModal from '../components/CodeSampleModal';
export default function Start({ countries }) {
const [results, setResults] = useState(countries);
const [isModalOpen, setIsModalOpen] = useState(false);
const fuse = new Fuse(countries, {
keys: ['name'],
threshold: 0.3,
});
return (
<div>
<Head>
<title>Core Web Vitals</title>
<meta name="description" content="Core web vitals walk through" />
<link rel="icon" href="/favicon.ico" />
<link
href="https://fonts.googleapis.com/css2?family=Inter"
rel="stylesheet"
/>
</Head>
<main className={styles.container}>
<h1 className={styles.title}>
Powered by <a href="https://nextjs.org">Next.js!</a>
</h1>
<div className={styles.heroImage}>
<img src="large-image.jpg" alt="Large Image" />
</div>
<div>
<h2 className={styles.secondaryHeading}>Population Lookup</h2>
<input
type="text"
placeholder="Country search..."
className={styles.input}
onChange={async (e) => {
const { value } = e.currentTarget;
const searchResult = fuse
.search(value)
.map((result) => result.item);
const updatedResults = searchResult.length
? searchResult
: countries;
setResults(updatedResults);
// Fake analytics hit
console.info({
searchedAt: _.now(),
});
}}
/>
<ul className={styles.countries}>
{results.map((country) => (
<li key={country.cca2} className={styles.country}>
<p>
{country.name} - {country.population.toLocaleString()}
</p>
</li>
))}
</ul>
</div>
<div className={styles.codeSampleBlock}>
<h2 className={styles.secondaryHeading}>Code Sample</h2>
<p>Ever wondered how to write a function that prints Hello World?</p>
<button onClick={() => setIsModalOpen(true)}>Show Me</button>
<CodeSampleModal
isOpen={isModalOpen}
closeModal={() => setIsModalOpen(false)}
/>
</div>
</main>
<footer className={styles.footer}>
<a
href="https://vercel.com?utm_source=learn&&utm_campaign=core-web-vitals"
target="_blank"
rel="noopener noreferrer"
>
Powered by
<span className={styles.logo}>
<img src="/vercel.svg" alt="Vercel Logo" />
</span>
</a>
</footer>
</div>
);
}
export async function getServerSideProps() {
return {
props: {
countries: countries.map((country) => ({
name: country.name,
cca2: country.cca2,
population: country.population,
})),
},
};
}