diff --git a/packages/nextjs/app/submissions/_components/SubmissionCard.tsx b/packages/nextjs/app/submissions/_components/SubmissionCard.tsx new file mode 100644 index 0000000..16b28a8 --- /dev/null +++ b/packages/nextjs/app/submissions/_components/SubmissionCard.tsx @@ -0,0 +1,29 @@ +import { Address } from "~~/components/scaffold-eth"; +import { Submission } from "~~/services/database/repositories/submissions"; + +export const SubmissionCard = ({ submission }: { submission: Submission }) => { + return ( +
+
+

{submission.title}

+
+
+ {submission.linkToRepository && ( + + github icon + + )} + + + youtube icon + +
+ + {submission.builder &&
} +
+ +

{submission.description}

+
+
+ ); +}; diff --git a/packages/nextjs/app/submissions/page.tsx b/packages/nextjs/app/submissions/page.tsx new file mode 100644 index 0000000..4b8547d --- /dev/null +++ b/packages/nextjs/app/submissions/page.tsx @@ -0,0 +1,30 @@ +import { SubmissionCard } from "./_components/SubmissionCard"; +import type { NextPage } from "next"; +import { getAllSubmissions } from "~~/services/database/repositories/submissions"; +import { getMetadata } from "~~/utils/scaffold-eth/getMetadata"; + +export const metadata = getMetadata({ + title: "Submissions", + description: "Check all the submissions for the SE-2 extensions hackathon.", +}); + +const Submissions: NextPage = async () => { + const submissions = await getAllSubmissions(); + + return ( +
+
+ {submissions.length === 0 && ( +
+ No submissions yet. +
+ )} + {submissions.map(submission => { + return ; + })} +
+
+ ); +}; + +export default Submissions; diff --git a/packages/nextjs/components/Header.tsx b/packages/nextjs/components/Header.tsx index 2dd0b6a..7d14d29 100644 --- a/packages/nextjs/components/Header.tsx +++ b/packages/nextjs/components/Header.tsx @@ -3,7 +3,7 @@ import React, { useCallback, useRef, useState } from "react"; import Image from "next/image"; import Link from "next/link"; -import { Bars3Icon, ChatBubbleLeftEllipsisIcon, LockClosedIcon } from "@heroicons/react/24/outline"; +import { Bars3Icon, ChatBubbleLeftEllipsisIcon, DocumentTextIcon, LockClosedIcon } from "@heroicons/react/24/outline"; import { RainbowKitCustomConnectButton } from "~~/components/scaffold-eth"; import { useOutsideClick } from "~~/hooks/scaffold-eth"; import { useAuthSession } from "~~/hooks/useAuthSession"; @@ -15,6 +15,11 @@ type HeaderMenuLink = { }; export const menuLinks: HeaderMenuLink[] = [ + { + label: "Submissions", + href: "/submissions", + icon: , + }, { label: "Admin", href: "/admin", diff --git a/packages/nextjs/utils/scaffold-eth/getMetadata.ts b/packages/nextjs/utils/scaffold-eth/getMetadata.ts index ad531ae..6787e37 100644 --- a/packages/nextjs/utils/scaffold-eth/getMetadata.ts +++ b/packages/nextjs/utils/scaffold-eth/getMetadata.ts @@ -3,7 +3,7 @@ import type { Metadata } from "next"; const baseUrl = process.env.VERCEL_PROJECT_PRODUCTION_URL ? `https://${process.env.VERCEL_PROJECT_PRODUCTION_URL}` : `http://localhost:${process.env.PORT || 3000}`; -const titleTemplate = "%s | Scaffold-ETH 2"; +const titleTemplate = "%s | Extensions Hackathon"; export const getMetadata = ({ title,