Files
sign/apps/web/components/editor/pdf-editor.tsx

105 lines
3.3 KiB
TypeScript
Raw Normal View History

2023-02-13 16:58:25 +01:00
import { NEXT_PUBLIC_WEBAPP_URL } from "@documenso/lib/constants";
import { useRouter } from "next/router";
import dynamic from "next/dynamic";
import { useState } from "react";
import { createOrUpdateField, deleteField } from "@documenso/lib/api";
import { createField } from "@documenso/features/editor";
import RecipientSelector from "./recipient-selector";
import FieldTypeSelector from "./field-type-selector";
const stc = require("string-to-color");
2023-02-13 16:58:25 +01:00
const PDFViewer = dynamic(() => import("./pdf-viewer"), {
ssr: false,
});
export default function PDFEditor(props: any) {
const router = useRouter();
2023-02-14 12:28:33 +01:00
const [fields, setFields] = useState<any[]>(props.document.Field);
const [selectedRecipient, setSelectedRecipient]: any = useState();
const [selectedFieldType, setSelectedFieldType] = useState();
const noRecipients = props?.document.Recipient.length === 0;
const [adding, setAdding] = useState(false);
2023-02-13 16:58:25 +01:00
2023-02-13 18:04:44 +01:00
function onPositionChangedHandler(position: any, id: any) {
if (!position) return;
2023-02-14 13:06:49 +01:00
const movedField = fields.find((e) => e.id == id);
2023-02-22 20:09:30 +01:00
movedField.positionX = position.x.toFixed(0);
movedField.positionY = position.y.toFixed(0);
createOrUpdateField(props.document, movedField);
2023-02-13 18:04:44 +01:00
// no instant redraw neccessary, postion information for saving or later rerender is enough
// setFields(newFields);
}
2023-02-14 17:04:53 +01:00
function onDeleteHandler(id: any) {
const field = fields.find((e) => e.id == id);
const fieldIndex = fields.map((item) => item.id).indexOf(id);
if (fieldIndex > -1) {
2023-02-15 13:28:29 +01:00
const fieldWithoutRemoved = [...fields];
const removedField = fieldWithoutRemoved.splice(fieldIndex, 1);
setFields(fieldWithoutRemoved);
deleteField(field).catch((err) => {
setFields(fieldWithoutRemoved.concat(removedField));
});
2023-02-14 17:04:53 +01:00
}
}
2023-02-13 16:58:25 +01:00
return (
2023-02-13 18:04:44 +01:00
<>
2023-02-22 20:09:30 +01:00
<div>
<PDFViewer
readonly={false}
document={props.document}
fields={fields}
onPositionChanged={onPositionChangedHandler}
onDelete={onDeleteHandler}
pdfUrl={`${NEXT_PUBLIC_WEBAPP_URL}/api/documents/${router.query.id}`}
onMouseUp={(e: any, page: number) => {
e.preventDefault();
e.stopPropagation();
console.log(adding);
if (adding) {
addField(e, page);
setAdding(false);
}
2023-02-22 20:09:30 +01:00
}}
onMouseDown={(e: any, page: number) => {
addField(e, page);
}}
></PDFViewer>
<div
hidden={noRecipients}
className="fixed left-0 top-1/3 max-w-xs border border-slate-300 bg-white py-4 pr-5 rounded-md"
>
<RecipientSelector
recipients={props?.document?.Recipient}
onChange={setSelectedRecipient}
/>
2023-02-22 20:09:30 +01:00
<hr className="m-3 border-slate-300"></hr>
<FieldTypeSelector
setAdding={setAdding}
selectedRecipient={selectedRecipient}
onChange={setSelectedFieldType}
/>
2023-02-22 17:23:51 +01:00
</div>
</div>
2023-02-13 18:04:44 +01:00
</>
2023-02-13 16:58:25 +01:00
);
2023-02-22 20:09:30 +01:00
function addField(e: any, page: number) {
2023-02-28 18:46:24 +01:00
if (!selectedRecipient) return;
if (!selectedFieldType) return;
const signatureField = createField(
e,
page,
selectedRecipient,
selectedFieldType
);
2023-02-22 20:09:30 +01:00
createOrUpdateField(props?.document, signatureField).then((res) => {
2023-02-22 20:09:30 +01:00
setFields(fields.concat(res));
});
}
2023-02-13 16:58:25 +01:00
}