Geração de documento pdf com fragmentos usando o script ECMA developing-with-output-and-forms-services-in-aem-forms
Neste artigo, usaremos o serviço de saída para gerar arquivos pdf usando fragmentos xdp. O xdp principal e os fragmentos residem no repositório crx. É importante imitar a estrutura de pastas do sistema de arquivos no AEM. Por exemplo, se estiver usando um fragmento na pasta de fragmentos do xdp, você deve criar uma pasta chamada fragmentos na pasta base do AEM. A pasta base conterá o modelo base xdp. Por exemplo, se você tiver a seguinte estrutura em seu sistema de arquivos
- c:\xdptemplates - Conterá o modelo base xdp
- c:\xdptemplates\fragments - Essa pasta conterá fragmentos e o modelo principal fará referência ao fragmento conforme mostrado abaixo
- A pasta xdpdocuments conterá o modelo base e os fragmentos na pasta fragmentos
Você pode criar a estrutura necessária usando os formulários e a interface do usuário do documento
A seguir está a estrutura de pastas da amostra xdp que usa 2 fragmentos
- Serviço de saída - Normalmente, esse serviço é usado para mesclar dados xml com modelo xdp ou pdf para gerar pdf nivelado. Para obter mais detalhes, consulte o javadoc para o Serviço de saída. Nesta amostra, estamos usando fragmentos que residem no repositório crx.
O script ECMA a seguir foi usado para gerar o PDF. Observe o uso de ResourceResolver e ResourceResolverHelper no código. O ResourceResolver é necessário, pois esse código está sendo executado fora de qualquer contexto de usuário.
var inputMap = processorContext.getInputMap();
var itr = inputMap.entrySet().iterator();
var entry = inputMap.entrySet().iterator().next();
var xmlData = inputMap.get(entry.getKey());
log.info("Got XML Data File");
var resourceResolverHelper = sling.getService(Packages.com.adobe.granite.resourceresolverhelper.ResourceResolverHelper);
var aemDemoListings = sling.getService(Packages.com.mergeandfuse.getserviceuserresolver.GetResolver);
log.info("Got service resolver");
var resourceResolver = aemDemoListings.getFormsServiceResolver();
//The ResourceResolverHelper execute's the following code within the context of the resourceResolver
resourceResolverHelper.callWith(resourceResolver, {call: function()
{
//var statement = new Packages.com.adobe.aemfd.docmanager.Document("/content/dam/formsanddocuments/xdpdocuments/main.xdp",resourceResolver);
var outputService = sling.getService(Packages.com.adobe.fd.output.api.OutputService);
var pdfOutputOptions = new Packages.com.adobe.fd.output.api.PDFOutputOptions();
pdfOutputOptions.setContentRoot("crx:///content/dam/formsanddocuments/xdpdocuments");
pdfOutputOptions.setAcrobatVersion(Packages.com.adobe.fd.output.api.AcrobatVersion.Acrobat_11);
var dataMergedDocument = outputService.generatePDFOutput("main.xdp",xmlData,pdfOutputOptions);
//var dataMergedDocument = outputService.generatePDFOutput(statement,xmlData,pdfOutputOptions);
processorContext.setResult("mergeddocument.pdf",dataMergedDocument);
log.info("Generated the pdf document with fragments");
}
});
Para testar o pacote de exemplo em seu sistema
-
Adicione a entrada DevelopingWithServiceUser.core:getformsresourceresolver=fd-service no aditamento do serviço de mapeador do usuário, conforme mostrado na captura de tela abaixo
-
Baixe e importe os arquivos xdp de exemplo e os scripts ECMA.
Isso criará uma estrutura de pasta monitorada na pasta c:/fragmentsandoutputservice -
Extraia o arquivo de dados de exemplo e coloque-o na pasta de instalação da pasta monitorada (c:\fragmentsandoutputservice\install)
-
Verifique a pasta de resultados da configuração da pasta monitorada para o arquivo pdf gerado