Baixar DoR interativa

Um caso de uso comum é o de ser capaz de baixar uma DoR interativa com os dados do Formulário adaptável. O DoR baixado será concluído usando o Adobe Acrobat ou o Adobe Reader.

O formulário adaptável não se baseia no esquema XSD

Se o XDP e o formulário adaptável não estiverem baseados em nenhum esquema, siga as etapas a seguir para gerar um Documento de registro interativo.

Criar formulário adaptável

Crie um formulário adaptável e verifique se os nomes dos campos do formulário adaptável são idênticos aos nomes dos campos no modelo xdp.
Anote o nome do elemento raiz do seu modelo xdp.
elemento-raiz

Biblioteca do cliente

O código a seguir é acionado quando o botão Baixar PDF é acionado

$(document).ready(function() {
    $(".downloadPDF").click(function() {
        window.guideBridge.getDataXML({
            success: function(guideResultObject) {
                var req = new XMLHttpRequest();
                req.open("POST", "/bin/generateinteractivedor", true);
                req.responseType = "blob";
                var postParameters = new FormData();
                postParameters.append("dataXml", guideResultObject.data);
                postParameters.append("xdpName","two.xdp")
                postParameters.append("formBasedOnSchema", "false");
                postParameters.append("xfaRootElement","form1");
                console.log(guideResultObject.data);
                req.send(postParameters);
                req.onreadystatechange = function() {
                    if (req.readyState == 4 && req.status == 200) {
                        download(this.response, "report.pdf", "application/pdf");
                    }


                }
            }
        });

    });
});

Formulário adaptável com base no esquema XSD

Se o xdp não for baseado em XSD, siga as etapas a seguir para criar XSD(schema) no qual você baseará seu formulário adaptável

Gerar dados de amostra para o XDP

  • Abra o XDP no AEM Forms Designer.
  • Clique em Arquivo | Propriedades do formulário | Visualizar
  • Clique em Gerar dados de visualização
  • Clique em Gerar
  • Forneça um nome de arquivo significativo, como "form-data.xml"

Gerar XSD a partir dos dados xml

Você pode usar qualquer uma das ferramentas online gratuitas para gerar XSD a partir dos dados xml gerados na etapa anterior.

Criar formulário adaptável

Crie um formulário adaptável com base no XSD da etapa anterior. Associe o formulário para usar a biblioteca do cliente "irs". Esta biblioteca cliente tem o código para fazer uma chamada POST para o servlet que retorna o PDF para o aplicativo de chamada.
O código a seguir é acionado ao clicar em Baixar PDF

$(document).ready(function() {
    $(".downloadPDF").click(function() {
        window.guideBridge.getDataXML({
            success: function(guideResultObject) {
                var req = new XMLHttpRequest();
                req.open("POST", "/bin/generateinteractivedor", true);
                req.responseType = "blob";
                var postParameters = new FormData();
                postParameters.append("dataXml", guideResultObject.data);
                postParameters.append("xdpName","f8918-r14e_redo-barcode_3 2.xdp")
                postParameters.append("formBasedOnSchema", "true");
                postParameters.append("dataNodeToExtract","afData/afBoundData/topmostSubform");
                console.log(guideResultObject.data);
                req.send(postParameters);
                req.onreadystatechange = function() {
                    if (req.readyState == 4 && req.status == 200) {
                        download(this.response, "report.pdf", "application/pdf");
                    }


                }
            }
        });

    });
});

Criar servlet personalizado

Crie um servlet personalizado que mesclará os dados com o modelo XDP e retornará o pdf. O código para fazer isso está listado abaixo. O servlet personalizado faz parte do pacote AEMFormsDocumentServices.core-1.0-SNAPSHOT).

public class GenerateIInteractiveDor extends SlingAllMethodsServlet {
    private static final long serialVersionUID = 1 L;
    @Reference
    DocumentServices documentServices;
    @Reference
    FormsService formsService;
    private static final Logger log = LoggerFactory.getLogger(GenerateIInteractiveDor.class);

    protected void doGet(SlingHttpServletRequest request, SlingHttpServletResponse response) {
        doPost(request, response);
    }
    protected void doPost(SlingHttpServletRequest request, SlingHttpServletResponse response) {
        String xdpName = request.getParameter("xdpName");

        boolean formBasedOnXSD = Boolean.parseBoolean(request.getParameter("formBasedOnSchema"));

        XPathFactory xfact = XPathFactory.newInstance();
        XPath xpath = xfact.newXPath();
        String dataXml = request.getParameter("dataXml");
        log.debug("The data xml is " + dataXml);
        org.w3c.dom.Document xmlDataDoc = documentServices.w3cDocumentFromStrng(dataXml);
        Document renderedPDF = null;
        try {
            if (!formBasedOnXSD) {
                String xfaRootElement = request.getParameter("xfaRootElement");
                DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
                DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
                org.w3c.dom.Document newXMLDocument = dBuilder.newDocument();
                Element rootElement = newXMLDocument.createElement(xfaRootElement);
                String unboundData = "afData/afUnboundData/data";
                Node dataNode = (Node) xpath.evaluate(unboundData, xmlDataDoc, XPathConstants.NODE);
                NodeList dataChildNodes = dataNode.getChildNodes();
                for (int i = 0; i<dataChildNodes.getLength(); i++) {
                    Node childNode = dataChildNodes.item(i);
                    if (childNode.getNodeType() == 1) {
                        Element newElement = newXMLDocument.createElement(childNode.getNodeName());
                        newElement.setTextContent(childNode.getTextContent());
                        rootElement.appendChild(newElement);
                        log.debug("the node name is  " + childNode.getNodeName() + " and its value is " + childNode.getTextContent());
                    }
                }
                newXMLDocument.appendChild(rootElement);
                Document xmlDataDocument = documentServices.orgw3cDocumentToAEMFDDocument(newXMLDocument);
                String xdpTemplatePath = "crx:///content/dam/formsanddocuments";
                com.adobe.fd.forms.api.PDFFormRenderOptions renderOptions = new com.adobe.fd.forms.api.PDFFormRenderOptions();
                renderOptions.setAcrobatVersion(com.adobe.fd.forms.api.AcrobatVersion.Acrobat_11);
                renderOptions.setContentRoot(xdpTemplatePath);
                renderOptions.setRenderAtClient(com.adobe.fd.forms.api.RenderAtClient.NO);
                renderedPDF = formsService.renderPDFForm(xdpName, xmlDataDocument, renderOptions);

            } else {
                // form is based on xsd
                // get the actual xml data that needs to be merged with the template. This can be made more generic
                String nodeToExtract = request.getParameter("dataNodeToExtract");
                Node dataNode = (Node) xpath.evaluate(nodeToExtract, xmlDataDoc, XPathConstants.NODE);
                StringWriter writer = new StringWriter();
                Transformer transformer = TransformerFactory.newInstance().newTransformer();
                transformer.transform(new DOMSource(dataNode), new StreamResult(writer));
                String xml = writer.toString();
                System.out.println(xml);
                xmlDataDoc = documentServices.w3cDocumentFromStrng(xml);
                Document xmlDataDocument = documentServices.orgw3cDocumentToAEMFDDocument(xmlDataDoc);
                String xdpTemplatePath = "crx:///content/dam/formsanddocuments";
                com.adobe.fd.forms.api.PDFFormRenderOptions renderOptions = new com.adobe.fd.forms.api.PDFFormRenderOptions();
                renderOptions.setAcrobatVersion(com.adobe.fd.forms.api.AcrobatVersion.Acrobat_11);
                renderOptions.setContentRoot(xdpTemplatePath);
                renderOptions.setRenderAtClient(com.adobe.fd.forms.api.RenderAtClient.NO);
                renderedPDF = formsService.renderPDFForm(xdpName, xmlDataDocument, renderOptions);
            }
            InputStream fileInputStream = renderedPDF.getInputStream();
            response.setContentType("application/pdf");
            response.addHeader("Content-Disposition", "attachment; filename=" + xdpName.replace("xdp", "pdf"));
            response.setContentLength((int) fileInputStream.available());
            OutputStream responseOutputStream = response.getOutputStream();
            int bytes;
            while ((bytes = fileInputStream.read()) != -1) {
                responseOutputStream.write(bytes);
            }
            responseOutputStream.flush();
            responseOutputStream.close();

        } catch (XPathExpressionException | TransformerException | FormsServiceException | IOException | ParserConfigurationException e) {
            log.debug(e.getMessage());
        }

    }

}

Neste exemplo de código, o nome xdp e outros parâmetros são extraídos do objeto de solicitação. Se o formulário não for baseado em um XSD, um novo documento XML será criado para mesclar com o xdp. No entanto, se o formulário for baseado em XSD, o nó relevante será extraído diretamente dos dados enviados do formulário adaptável e um documento XML será gerado para mesclar-se com o modelo xdp de acordo.

Implantar a amostra no servidor

Para testar isso no servidor local, siga as seguintes etapas:

  1. Baixe e instale o pacote DevelopingWithServiceUser
  2. Adicione a seguinte entrada no serviço Mapeador de usuários do Apache Sling Service
    DevelopingWithServiceUser.core:getformsresourceresolver=fd-service
  3. Baixe e instale o pacote personalizado de DocumentServices. Ele tem o servlet para mesclar os dados com o modelo XDP e transmitir o pdf de volta
  4. Importar a biblioteca do cliente
  5. Importar o artigo Assets (formulário adaptável, modelos XDP e XSD)
  6. Visualizar formulário adaptável
  7. Preencha alguns dos campos de formulário.
  8. Clique em Baixar o PDF para obter a PDF. Talvez seja necessário aguardar alguns segundos para que o PDF seja baixado.
NOTE
Ao abrir o PDF baixado usando o visualizador de pdf do navegador, você não verá os dados no pdf. Abra o PDF baixado usando o Adobe Acrobat ou o Adobe Reader.
NOTE
Você pode tentar o mesmo caso de uso com formulário adaptável baseado em não xsd. Transmita os parâmetros apropriados para o endpoint de publicação no streampdf.js localizado na biblioteca de clientes irs.
recommendation-more-help
8de24117-1378-413c-a581-01e660b7163e