Overview
This version is for Appian 23.2 and above. Cloud customers on a lower version of Appian that want to install this plugin should open a support case. Self-managed customers can find the latest jar for Appian 23.1 and lower version in the folder pre-23.2
Convert, merge and generate DOCX, PDF and XML files automatically in an Appian process
Key Features & Functionality
Function: xsltransform - Transform source XML using XSL Transform
As a follow up...do you know if there are any special characters or formatting the conversion might not like?
I have upgraded our DEV environment to version 2.1.0. I was hoping the new version would help with an issue we currently have in all environments. We are currently on version 23.1. We are using the PDF from Multiple DOCX (no fonts) and it attempts to convert the file but on the output there is no file, we are getting this error:
org.docx4j.openpackaging.exceptions.Docx4JException: Exception exporting package
Hello,
I'm using docxncolumntable to generate a table for a word doc. The table that gets created is too narrow to fit the page and requires manual readjustment of the table.
The parameters for the function do not appear in the help screen. I checked the documentation provided with the plug in but there's no mention of the parameters used by docxncolumntable. Is there a way to get a list of the parameters supported by this function in order to adjust the table?
Thank you.
After utilizing OWASP dependency-check, we have identified the following vulnerabilities (outlined below). Are there any plans in place to mitigate these CVEs?
I can confirm at least in version 2.0.4 Arabic Letters can be displayed, if you provide a proper Font Document as an input
I am looking for a recommendation with a solution we are bulding using the smart service PDF from XSL FO Transformation With Fonts, to get text justified when there is no space on it, but keeping words together correctly when text has proper spaces.
We have found two different solutions that help us with part of the incident, but we are looking for another one to join both of them:
<fo:block margin-left="0mm" margin-top="3mm" margin-bottom="0mm" linefeed-treatment='preserve' ><xsl:value-of select="descripcion_txt" /></fo:block>
Result:
2nd Solution: correct text (spaces or urls) are being cut when "x" number of characters are reaching the border, but texts without spaces are shown correct.
For this solution we are using 2 templates:
<xsl:template name="zero_width_space_1"><xsl:param name="data"/><xsl:param name="counter" select="0"/><xsl:choose><xsl:when test="$counter < string-length($data)"><xsl:value-of select='concat(substring($data,$counter,1),"​")'/><xsl:call-template name="zero_width_space_2"><xsl:with-param name="data" select="$data"/><xsl:with-param name="counter" select="$counter+1"/></xsl:call-template></xsl:when><xsl:otherwise></xsl:otherwise></xsl:choose></xsl:template><xsl:template name="zero_width_space_2"><xsl:param name="data"/><xsl:param name="counter"/><xsl:value-of select='concat(substring($data,$counter,1),"​")'/><xsl:call-template name="zero_width_space_1"><xsl:with-param name="data" select="$data"/><xsl:with-param name="counter" select="$counter+1"/></xsl:call-template></xsl:template>
Block:
<fo:block margin-left="0mm" margin-top="3mm" margin-bottom="0mm" linefeed-treatment='preserve' > <xsl:call-template name="zero_width_space_1"> <xsl:with-param name="data" select="descripcion_txt"/> </xsl:call-template> </fo:block>
Here is an example of the xml and xsl we are using:
XML
<doc> <prefijo> <nombre>Example</nombre> <fecha>2023-03-16z</fecha> </prefijo> <seccion_campos> <titulo_txt>DESCRIPCIÓN DEL ACTO O MOTIVO:</titulo_txt> <descripcion_txt>Peropueden surgir empresas tecnológicas en países con legislaciones que hacen difícil cualquier emprendimiento? No hay duda de que un mal clima de negocios, burocracias infernales y la corrupción son grandes trabas. Es difícil crear una empresa innovadora en Venezuela, donde según los estudios del Banco Mundial de los que hablábamos en el prólogo hacen falta 17 trámites legales para registrar una nueva empresa, o en Argentina, donde se requieren 14, o en Brasil y Colombia, donde hacen falta 13, y que por lo general tardan varios meses en completarse. I cannot find that it is an error from an XSLFO standpoint this surprises me, so maybe I just missed it, but from an implementation standpoint in other words, from within FOP, there really is no way to process hyphenation without knowing which language (and therefore which hyphenation dictionary to use. Probably what is happening is that FOP jumps to a default dictionary no doubt English or U.S. English. If you are using that default language your result is ok, but it is only by accident the FOP developers could just as easily have chosen Turkish as the default. LOS INNOVADORES QUIEREN VIVIR EN LUGARES VIBRANTES </descripcion_txt> </seccion_campos> <seccion_campos> <titulo_txt>EFECTO SOBRE LOS TENEDORES:</titulo_txt> <descripcion_txt>efaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaecto</descripcion_txt> </seccion_campos> <seccion_campos> <titulo_txt>NOTA COMPARATIVA RESPECTO A LAS DIFERENCIAS MÁS RELEVANTES:</titulo_txt> <descripcion_txt>find that it is an error from an XSLFO standpoint this surprises me, so maybe I just missed it, but from an implementation standpoint in other words, from within FOP, there really is no way to process hyphenation without knowing which language (and therefore which hyphenation dictionary to use. Probably what is happening is that FOP jumps to a default dictionary no doubt English or U.S. English. If you are using that default language your result is ok, but it is https://bmv-test.appiancloud.com/suite/design/lMBfe49_FfR7AnMpoon-ShAtibjpv4wDQFXudCPCREuKKkRzDRcUEpwDURnyVjx6t5Id2ExlrieqaqxXUWH2p-p8UnK2B1i6V-dwFn5rL-hfDlzgQ https://bmv-dev.appiancloud.com/suite/design/ksBCPzGojqGmiD_JHPtxO7RCAQ-3vL2745szbJZQQ8SUhuzlQk7uOeJCGKZaLcUdUNjeq78ZzD3wC_HeaHmkRH4V2TqtAoPkovRsTk </descripcion_txt> </seccion_campos> <seccion_campos> <titulo_txt>URL:</titulo_txt> <descripcion_txt>find that it is an error from an XSLFO standpoint this surprises me, so maybe I just missed it, but from an implementation standpoint in other words, from within FOP, there really is no way to process hyphenation without knowing which language (and therefore which hyphenation dictionary to use. Probably what is happening is that FOP jumps to a default dictionary no doubt English or U.S. English. If you are using that default language your result is ok, but it is https://grupovass.sharepoint.com/:x:/r/teams/BMV-Emisnet/_layouts/15/Doc.aspx?sourcedoc=%7B491E1B70-8EE3-4C32-B1B2-8EFAAC1E1713%7D&file=Incidentes%20reportados%20por%20BMV.xlsx&action=default&mobileredirect=true&clickparams=eyJBcHBOYW1lIjoiVGVhbXMtRGVza3RvcCIsIkFwcFZlcnNpb24iOiIyNy8yMzAyMDUwMTQyMSIsIkhhc0ZlZGVyYXRlZFVzZXIiOmZhbHNlfQ%3D%3D&cid=b21dabe8-a8cf-432e-a4bd-844b12946b5e</descripcion_txt> </seccion_campos> </doc>
XSL
<?xml version="1.0" encoding="UTF-8"?> <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:fo="http://www.w3.org/1999/XSL/Format" > <xsl:template name="zero_width_space_1"> <xsl:param name="data"/> <xsl:param name="counter" select="0"/> <xsl:choose> <xsl:when test="$counter < string-length($data)"> <xsl:value-of select='concat(substring($data,$counter,1),"​")'/> <xsl:call-template name="zero_width_space_2"> <xsl:with-param name="data" select="$data"/> <xsl:with-param name="counter" select="$counter+1"/> </xsl:call-template> </xsl:when> <xsl:otherwise> </xsl:otherwise> </xsl:choose> </xsl:template> <xsl:template name="zero_width_space_2"> <xsl:param name="data"/> <xsl:param name="counter"/> <xsl:value-of select='concat(substring($data,$counter,1),"​")'/> <xsl:call-template name="zero_width_space_1"> <xsl:with-param name="data" select="$data"/> <xsl:with-param name="counter" select="$counter+1"/> </xsl:call-template> </xsl:template> <xsl:template name="getDateBy"> <xsl:param name="date_dt"/> <xsl:value-of select="concat('',substring($date_dt,9,2),'/',substring($date_dt,6,2),'/',substring($date_dt,1,4))" /> </xsl:template> <xsl:template match="doc"> <fo:root xml:lang="es" xmlns:fo="http://www.w3.org/1999/XSL/Format"> <fo:layout-master-set> <fo:simple-page-master master-name="A4" page-width="220mm" page-height="280mm" margin-top="1cm" margin-bottom="1cm" margin-left="1cm" margin-right="1cm"> <fo:region-body margin-top="6cm" margin-bottom="1cm" margin-left="0mm" margin-right="5mm" /> <fo:region-before margin-top="0cm" margin-bottom="20cm" margin-left="0cm" margin-right="0cm" /> <fo:region-after margin-top="0cm" margin-bottom="1cm" margin-left="0cm" margin-right="3cm" /> </fo:simple-page-master> </fo:layout-master-set> <fo:page-sequence master-reference="A4"> <!-- HEADER --> <fo:static-content flow-name="xsl-region-before" > <fo:block-container height="0cm" background-color="white" margin-top="-20mm" margin-left="-10mm" margin-right="43mm" > <!-- NOMBRE DEL PREFIJO --> <fo:block text-align="left" font-size="13pt" margin-top="25mm" margin-left="20mm" color="black" font-weight="bold" > <xsl:value-of select="prefijo/nombre" /> </fo:block> <!-- TERMINA EL NOMBRE DEL PREFIJO --> <!-- LOGO --> <fo:block margin-left="135mm" margin-top="-15mm"> <fo:external-graphic src = "url('')" height="10.5cm" content-width="8.5cm" /> </fo:block> <!-- TERMINA EL LOGO --> <!-- FECHA --> <fo:block margin-left="15mm" margin-bottom="-30mm" margin-top="-63mm" > <fo:table table-layout="fixed" width="100%" > <fo:table-column column-width="249mm" /> <fo:table-body> <fo:table-row> <fo:table-cell> <fo:block-container font-size="11pt" border-bottom-style="solid" border-color="black" > <fo:block margin-left="-5mm" color="black" >Fecha: <xsl:call-template name="getDateBy"> <xsl:with-param name="date_dt" select="prefijo/fecha"/> </xsl:call-template> </fo:block> </fo:block-container> </fo:table-cell> </fo:table-row> </fo:table-body> </fo:table> </fo:block> <!-- TERMINA LA FECHA --> </fo:block-container> </fo:static-content> <!-- TERMINA EL HEADER --> <!-- FOOTER --> <fo:static-content flow-name="xsl-region-after" height="10cm"> <fo:block text-align="left" font-size="9pt" border-bottom-style="solid" border-top-style="solid" border-color="black" > <fo:table table-layout="fixed" width="100%" > <fo:table-column column-width="198mm" /> <fo:table-column column-width="2mm" /> <fo:table-body> <fo:table-row> <fo:table-cell> <fo:block-container > <fo:block margin-left="0mm" margin-top="1mm" margin-bottom="0.5mm" > Customer </fo:block> </fo:block-container> </fo:table-cell> <fo:table-cell> <fo:block-container > <fo:block margin-left="0mm" margin-top="1mm" margin-bottom="0.5mm" > <fo:page-number/> </fo:block> </fo:block-container> </fo:table-cell> </fo:table-row> </fo:table-body> </fo:table> </fo:block> </fo:static-content> <!-- TERMINA EL FOOTER --> <!-- BODY --> <fo:flow flow-name="xsl-region-body" > <fo:block text-align="justify" font-size="9pt" > <fo:table table-layout="fixed" width="100%" > <fo:table-column column-width="200mm" /> <fo:table-body> <!-- SECCION DE CAMPOS DINAMICOS --> <fo:table-row> <fo:table-cell> <fo:block font-size="11pt" > <fo:table table-layout="fixed" width="100%" > <fo:table-column column-width="200mm" /> <fo:table-column column-width="200mm" /> <fo:table-body> <xsl:for-each select="seccion_campos"> <fo:table-row> <fo:table-cell> <fo:block-container > <fo:block margin-left="0mm" margin-top="6mm" margin-bottom="0mm" font-weight="bold" > <xsl:value-of select="titulo_txt" /> </fo:block> </fo:block-container> </fo:table-cell> </fo:table-row> <fo:table-row> <fo:table-cell> <fo:block-container > <fo:block margin-left="0mm" margin-top="3mm" margin-bottom="0mm" linefeed-treatment='preserve' > <!-- <xsl:value-of select="descripcion_txt" /> --> <xsl:call-template name="zero_width_space_1"> <xsl:with-param name="data" select="descripcion_txt"/> </xsl:call-template> </fo:block> </fo:block-container> </fo:table-cell> </fo:table-row> </xsl:for-each> </fo:table-body> </fo:table> </fo:block> </fo:table-cell> </fo:table-row> <!-- TERMINA SECCION DE CAMPOS DINAMICOS --> </fo:table-body> </fo:table> </fo:block> <fo:block id="TheVeryLastPage"> </fo:block> </fo:flow> <!-- TERMINA EL BODY --> </fo:page-sequence> </fo:root> </xsl:template> </xsl:stylesheet>
Please upload an example document with problems and the issues you are seeing.