Better handling of HTML tables when merging.

Fixes table within table broke format parsing.
This commit is contained in:
nathangray 2018-09-12 16:46:11 -06:00
parent 55784ec703
commit 0d5bb226bf
2 changed files with 33 additions and 16 deletions

View File

@ -602,14 +602,6 @@ abstract class Merge
case 'application/vnd.oasis.opendocument.text-template': case 'application/vnd.oasis.opendocument.text-template':
case 'application/vnd.oasis.opendocument.spreadsheet-template': case 'application/vnd.oasis.opendocument.spreadsheet-template':
case 'application/vnd.oasis.opendocument.presentation-template': case 'application/vnd.oasis.opendocument.presentation-template':
// It seems easier to split the parent tags here
$replace_tags = array(
'/<(ol|ul|table)( [^>]*)?>/' => '</text:p><$1$2>',
'/<\/(ol|ul|table)>/' => '</$1><text:p>',
//'/<(li)(.*?)>(.*?)<\/\1>/' => '<$1 $2>$3</$1>',
);
$content = preg_replace(array_keys($replace_tags),array_values($replace_tags),$content);
$doc = new DOMDocument(); $doc = new DOMDocument();
$xslt = new XSLTProcessor(); $xslt = new XSLTProcessor();
$doc->load(EGW_INCLUDE_ROOT.'/api/templates/default/Merge/openoffice.xslt'); $doc->load(EGW_INCLUDE_ROOT.'/api/templates/default/Merge/openoffice.xslt');
@ -669,7 +661,7 @@ abstract class Merge
throw new Api\Exception('Unable to parse merged document for styles. Check warnings in log for details.'); throw new Api\Exception('Unable to parse merged document for styles. Check warnings in log for details.');
} }
$content = $xslt->transformToXml($element); $content = $xslt->transformToXml($element);
//echo $content;die();
// Word 2003 needs two declarations, add extra declaration back in // Word 2003 needs two declarations, add extra declaration back in
if($mimetype == 'application/xml' && $mso_application_progid == 'Word.Document' && strpos($content, '<?xml') !== 0) { if($mimetype == 'application/xml' && $mso_application_progid == 'Word.Document' && strpos($content, '<?xml') !== 0) {
$content = '<?xml version="1.0" encoding="UTF-8" standalone="yes"?>'.$content; $content = '<?xml version="1.0" encoding="UTF-8" standalone="yes"?>'.$content;

View File

@ -16,12 +16,12 @@
<xsl:variable name="custom-styles"> <xsl:variable name="custom-styles">
<style:style style:name="Custom" style:family="text" /> <style:style style:name="Custom" style:family="text" />
</xsl:variable> </xsl:variable>
<xsl:template match="node()|@*"> <xsl:template match="node()|@*" name="identity">
<xsl:copy> <xsl:copy>
<xsl:apply-templates select="node()|@*"/> <xsl:apply-templates select="node()|@*"/>
</xsl:copy> </xsl:copy>
</xsl:template> </xsl:template>
<!-- Fonts --> <!-- Fonts -->
<xsl:template match="office:font-face-decls"> <xsl:template match="office:font-face-decls">
<xsl:copy> <xsl:copy>
@ -29,7 +29,7 @@
<xsl:call-template name="extract-fonts"/> <xsl:call-template name="extract-fonts"/>
</xsl:copy> </xsl:copy>
</xsl:template> </xsl:template>
<!-- Add in some known styles --> <!-- Add in some known styles -->
<xsl:template match="office:automatic-styles"> <xsl:template match="office:automatic-styles">
<xsl:copy> <xsl:copy>
@ -261,7 +261,27 @@
</text:p></text:list-item> </text:p></text:list-item>
</xsl:template> </xsl:template>
<xsl:template match="table[ancestor::office:text]"> <!-- This section to deal with tables, which need to be outside the text:p tag -->
<xsl:template match="text:p[table]">
<xsl:apply-templates select="node()[1]"/>
</xsl:template>
<xsl:template match="text:p/table">
<xsl:call-template name="tableator"/>
<xsl:apply-templates select="following-sibling::node()[1]"/>
</xsl:template>
<xsl:template match="text:p[table]/node()[not(self::table)]">
<text:p>
<xsl:value-of select="node()"/>
<xsl:apply-templates select="following-sibling::node()[1][not(self::table)]" mode="copy"/>
</text:p>
<xsl:apply-templates select="following-sibling::node()[self::table][1]"/>
</xsl:template>
<xsl:template match="text:p[table]/node()[not(self::table)]" mode="copy">
<xsl:call-template name="identity"/>
<xsl:apply-templates select="following-sibling::node()[1][not(self::table)]" mode="copy"/>
</xsl:template>
<!-- Actually swap the HTML table tag for openoffice table tags -->
<xsl:template match="table" name="tableator">
<table:table table:name="Table{generate-id(.)}" table:style-name="TableX"> <table:table table:name="Table{generate-id(.)}" table:style-name="TableX">
<table:table-column table:style-name="TableX.A" table:number-columns-repeated="{count(tr[position() = 1]/td | tr[position() = 1]/th)}"/> <table:table-column table:style-name="TableX.A" table:number-columns-repeated="{count(tr[position() = 1]/td | tr[position() = 1]/th)}"/>
<xsl:apply-templates/> <xsl:apply-templates/>
@ -287,11 +307,16 @@
</table:table-cell> </table:table-cell>
</xsl:template> </xsl:template>
<xsl:template match="td"> <xsl:template match="td[not(table:table)]">
<table:table-cell table:style-name="TableX.A1"> <table:table-cell table:style-name="TableX.A1">
<text:p><xsl:apply-templates/></text:p> <text:p><xsl:apply-templates/></text:p>
</table:table-cell> </table:table-cell>
</xsl:template> </xsl:template>
<xsl:template match="td[table]">
<table:table-cell table:style-name="TableX.A1">
<xsl:apply-templates/>
</table:table-cell>
</xsl:template>
<xsl:template match="tr"> <xsl:template match="tr">
<table:table-row> <table:table-row>
@ -312,7 +337,7 @@
<xsl:template match="span"> <xsl:template match="span">
<text:span text:style-name="TSpan{generate-id(.)}"><xsl:apply-templates/></text:span> <text:span text:style-name="TSpan{generate-id(.)}"><xsl:apply-templates/></text:span>
</xsl:template> </xsl:template>
<!-- Convert rgb(r,g,b) to hex RGB values --> <!-- Convert rgb(r,g,b) to hex RGB values -->
<xsl:template name="rbga-to-hex"> <xsl:template name="rbga-to-hex">
<xsl:param name="rgba-val"/> <xsl:param name="rgba-val"/>
@ -332,7 +357,7 @@
<xsl:otherwise> <xsl:otherwise>
<xsl:call-template name="to-hex"> <xsl:call-template name="to-hex">
<xsl:with-param name="val" select="$rgba-val"/> <xsl:with-param name="val" select="$rgba-val"/>
</xsl:call-template> </xsl:call-template>
</xsl:otherwise> </xsl:otherwise>
</xsl:choose> </xsl:choose>
</xsl:template> </xsl:template>