web3.news/src/app/search/page.tsx

59 lines
1.8 KiB
TypeScript
Raw Normal View History

2023-11-14 15:52:42 +00:00
import React, { FormEvent } from "react"
import Link from "next/link"
import { ArrowLeftIcon } from "@heroicons/react/24/outline"
import { formatDate, getResults } from "@/utils"
2023-11-14 15:52:42 +00:00
import SimplifiedSearchBar from "@/components/SimplifiedSearchBar"
type Props = {
searchParams: {
q?: string
}
}
const Page = async ({ searchParams }: Props) => {
const query = searchParams.q ?? ""
const results = await getResults({ query: searchParams.q })
return (
<div className="w-full items-center text-lg">
<SimplifiedSearchBar
value={query}
placeholder={
query ? undefined : "Search for web3 news from the community"
}
/>
<Link href="/">
2023-12-05 17:38:27 +00:00
<button className="my-4 -ml-3 px-3 py-2 text-gray-400 hover:bg-gray-800 hover:text-white rounded">
<ArrowLeftIcon className="w-4 h-4 inline mr-2 -mt-1" />
Go Back Home
</button>
</Link>
2023-11-14 15:52:42 +00:00
{results.length > 0 && (
<>
{results.map((item) => (
<Link
href={`/article/${item.slug}`}
2023-11-14 15:52:42 +00:00
key={item.id}
className="flex cursor-pointer flex-row items-center space-x-5 my-2 py-2 px-4 hover:bg-gray-800 rounded-md"
>
<span className="text-sm text-gray-400">
{formatDate(item.timestamp)}
</span>
<h3 className="text-md font-semibold text-white">{item.title}</h3>
</Link>
2023-11-14 15:52:42 +00:00
))}
<Link href={`/search?q=${encodeURIComponent(query)}`}>
<button className="rounded mt-4 flex justify-center items-center bg-gray-800 mx-auto w-44 py-7 text-white hover:bg-gray-800/50 transition-colors">
Load More
</button>
</Link>
</>
)}
</div>
)
}
export default Page