Files
documenso/apps/web/pages/dashboard.tsx
2023-01-23 17:57:50 +01:00

155 lines
4.4 KiB
TypeScript

import { useSession } from "next-auth/react";
import Head from "next/head";
import { ReactElement, useEffect, useState } from "react";
import Layout from "../components/layout";
import Settings from "../components/settings";
import Link from "next/link";
import type { NextPageWithLayout } from "./_app";
import {
BellSnoozeIcon,
CheckBadgeIcon,
EnvelopeIcon,
EyeIcon,
SunIcon,
XCircleIcon,
} from "@heroicons/react/24/outline";
import { FormProvider, useForm } from "react-hook-form";
import Router from "next/router";
import { NEXT_PUBLIC_WEBAPP_URL } from "@documenso/lib";
type FormValues = {
document: File;
};
const DashboardPage: NextPageWithLayout = () => {
const stats = [
{
name: "Draft",
stat: "0",
icon: SunIcon,
link: "/documents?filter=",
},
{
name: "Sent",
stat: "0",
icon: EnvelopeIcon,
link: "/documents?filter=",
},
{
name: "Viewed",
stat: "0",
icon: EyeIcon,
link: "/documents?filter=",
},
{
name: "Signed",
stat: "0",
icon: CheckBadgeIcon,
link: "/documents?filter=",
},
{
name: "Expired",
stat: "0",
icon: BellSnoozeIcon,
link: "/documents?filter=",
},
{
name: "Declined",
stat: "0",
icon: XCircleIcon,
link: "/documents?filter=",
},
];
const uploadToServer = async (event: any) => {
if (event.target.files && event.target.files[0]) {
const body = new FormData();
const document = event.target.files[0];
body.append("document", document || "");
const response: any = await fetch("/api/documents", {
method: "POST",
body,
}).then((response: any) => {
Router.push(
`${NEXT_PUBLIC_WEBAPP_URL}/documents/${
response.json().creadtedDocumentId
}`
);
});
}
};
return (
<>
<Head>
<title>Dashboard | Documenso</title>
</Head>
<div className="py-10 max-sm:px-4">
<header>
<h1 className="text-3xl font-bold leading-tight tracking-tight text-gray-900">
Dashboard
</h1>
</header>
<dl className="mt-8 grid grid-cols-1 gap-5 sm:grid-cols-3">
{stats.map((item) => (
<Link href={item.link} key={item.name}>
<div className="overflow-hidden rounded-lg bg-white px-4 py-5 shadow sm:p-6">
<dt className="truncate text-sm font-medium text-gray-500">
<item.icon
className="flex-shrink-0 mr-3 h-6 w-6 inline text-neon"
aria-hidden="true"
></item.icon>
{item.name}
</dt>
<dd className="mt-1 text-3xl font-semibold tracking-tight text-gray-900">
{item.stat}
</dd>
</div>
</Link>
))}
</dl>
<div className="mt-12">
<button
type="button"
onClick={() => {
document?.getElementById("fileUploadHelper")?.click();
}}
className="relative block w-full rounded-lg border-2 border-dashed border-gray-300 p-12 text-center hover:border-neon focus:outline-none focus:ring-2 focus:ring-indigo-500 focus:ring-offset-2"
>
<svg
className="mx-auto h-12 w-12 text-gray-400"
stroke="currentColor"
fill="none"
viewBox="0 00 20 25"
aria-hidden="true"
>
<path
strokeLinecap="round"
strokeLinejoin="round"
d="M19.5 14.25v-2.625a3.375 3.375 0 00-3.375-3.375h-1.5A1.125 1.125 0 0113.5 7.125v-1.5a3.375 3.375 0 00-3.375-3.375H8.25m2.25 0H5.625c-.621 0-1.125.504-1.125 1.125v17.25c0 .621.504 1.125 1.125 1.125h12.75c.621 0 1.125-.504 1.125-1.125V11.25a9 9 0 00-9-9z"
/>
</svg>
<span className="mt-2 block text-sm font-medium text-neon">
Upload a new PDF document
</span>
</button>
<input
id="fileUploadHelper"
type="file"
onChange={(event: any) => {
uploadToServer(event);
}}
hidden
/>
</div>
</div>
</>
);
};
// todo layout as component
DashboardPage.getLayout = function getLayout(page: ReactElement) {
return <Layout>{page}</Layout>;
};
export default DashboardPage;