From b7faf0920237f00c10c9ae02b3e0c9c1477404aa Mon Sep 17 00:00:00 2001 From: Andreas Abraham Date: Tue, 26 Nov 2019 08:48:29 +0100 Subject: started implementing signature placeholder --- .../at/asit/pdfover/gui/workflow/states/OpenState.java | 17 +++++++++++++++-- 1 file changed, 15 insertions(+), 2 deletions(-) (limited to 'pdf-over-gui/src/main/java') diff --git a/pdf-over-gui/src/main/java/at/asit/pdfover/gui/workflow/states/OpenState.java b/pdf-over-gui/src/main/java/at/asit/pdfover/gui/workflow/states/OpenState.java index 9caee52d..769e772e 100644 --- a/pdf-over-gui/src/main/java/at/asit/pdfover/gui/workflow/states/OpenState.java +++ b/pdf-over-gui/src/main/java/at/asit/pdfover/gui/workflow/states/OpenState.java @@ -16,6 +16,7 @@ package at.asit.pdfover.gui.workflow.states; import java.io.IOException; +import java.util.List; import org.apache.pdfbox.pdmodel.PDDocument; @@ -35,7 +36,9 @@ import at.asit.pdfover.gui.workflow.config.ConfigProvider; import at.asit.pdfover.signator.SignaturePosition; import at.gv.egiz.pdfas.common.exceptions.PdfAsException; import at.gv.egiz.pdfas.lib.impl.placeholder.SignaturePlaceholderData; +import at.gv.egiz.pdfas.lib.impl.pdfbox2.placeholder.SignatureFieldsExtractor; import at.gv.egiz.pdfas.lib.impl.pdfbox2.placeholder.SignaturePlaceholderExtractor; +//import at.gv.egiz.pdfas.lib.impl.pdfbox2.placeholder. /** @@ -98,13 +101,20 @@ public class OpenState extends State { // - see if we want to scan for placeholders in the settings if (getStateMachine().getConfigProvider().getUseMarker()) { try { + // - scan for placeholders PDDocument pddocument = PDDocument.load(getStateMachine().getStatus().getDocument()); + + // test other placeholders + List fields = SignatureFieldsExtractor.findEmptySignatureFields(pddocument); + for (String string : fields) { + System.out.println(string); + } + SignaturePlaceholderData signaturePlaceholderData = SignaturePlaceholderExtractor.extract(pddocument, "1", 3); - if (null != signaturePlaceholderData) { - log.debug("we got a position", signaturePlaceholderData.getId()); //$NON-NLS-1$ + if (null != signaturePlaceholderData || fields.size() > 0) { // create a dialog with ok and cancel buttons and a question // icon MessageBox dialog = new MessageBox(getStateMachine().getGUIProvider().getMainShell(), @@ -114,6 +124,9 @@ public class OpenState extends State { // open dialog and await user selection if (SWT.YES == dialog.open()) { + + //TODO if yes handle the two differnet cases + // if the user chooses to use the signature placeholder // - fill the position information so that we skip to // the -- cgit v1.2.3