forked from extern/egroupware
Better handling of HTML tables when merging.
Fixes table within table broke format parsing.
This commit is contained in:
parent
55784ec703
commit
0d5bb226bf
@ -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;
|
||||||
|
@ -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>
|
||||||
|
Loading…
Reference in New Issue
Block a user