Files
documenso/apps/web/components/editor/pdf-signer.tsx
Timur Ercan 5a3dd547b8 🚧 signign workflow
2023-02-17 13:37:28 +01:00

108 lines
3.0 KiB
TypeScript

import Logo from "../logo";
import { NEXT_PUBLIC_WEBAPP_URL } from "@documenso/lib/constants";
import { useRouter } from "next/router";
import dynamic from "next/dynamic";
import SignatureDialog from "./signature-dialog";
import { useState } from "react";
import { Button } from "@documenso/ui";
import { CheckBadgeIcon } from "@heroicons/react/24/outline";
import toast from "react-hot-toast";
const PDFViewer = dynamic(() => import("./pdf-viewer"), {
ssr: false,
});
export default function PDFSigner(props: any) {
const router = useRouter();
const [open, setOpen] = useState(false);
const [signatures, setSignatures] = useState<any[]>([]);
const [dialogField, setDialogField] = useState<any>();
function onClick(item: any) {
if (item.type === "SIGNATURE") {
setDialogField(item);
setOpen(true);
}
}
function onDialogClose(dialogResult: any) {
console.log(dialogResult);
console.log(dialogField);
setSignatures(
signatures.concat({
fieldId: dialogField.id,
type: dialogResult.type,
name: dialogResult.name,
signatureImage: null,
})
);
setOpen(false);
setDialogField(null);
}
function sign() {
const body = { documentId: props.document.id, signatures: signatures };
toast.promise(
fetch(
`/api/documents/${props.document.id}/sign?token=${router.query.token}`,
{
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify(body),
}
).then(() => {
router.push(
`/documents/${props.document.id}/signed?token=${router.query.token}`
);
}),
{
loading: "Signing...",
success: `"${props.document.title}" signed successfully.`,
error: "Could not sign :/",
}
);
// goto signing done page
}
return (
<>
<SignatureDialog open={open} setOpen={setOpen} onClose={onDialogClose} />
<div className="bg-neon p-4">
<div className="flex">
<div className="flex-shrink-0">
<Logo className="inline w-10"></Logo>
</div>
<div className="ml-3 flex-1 md:flex md:justify-between">
<p className="text-lg text-slate-700">
Timur Ercan (timur.ercan31@gmail.com) would like you to sign this
document.
</p>
<Button
disabled={signatures.length < props.fields.length}
color="secondary"
icon={CheckBadgeIcon}
className="float-right"
onClick={() => {
sign();
}}
>
Done
</Button>
</div>
</div>
</div>
{/* todo use public url with token auth to get document */}
<PDFViewer
readonly={true}
document={props.document}
fields={props.fields}
pdfUrl={`${NEXT_PUBLIC_WEBAPP_URL}/api/documents/${router.query.id}?token=${router.query.token}`}
onClick={onClick}
></PDFViewer>
</>
);
}