forked from extern/egroupware
- Fix missing formatting in xml/word documents
- some changes in bullets, maybe avoid error in docx documents
This commit is contained in:
parent
e8e5a3066a
commit
1cddecb832
@ -314,7 +314,7 @@ abstract class bo_merge
|
|||||||
}
|
}
|
||||||
|
|
||||||
// check export-limit and fail if user tries to export more entries then allowed
|
// check export-limit and fail if user tries to export more entries then allowed
|
||||||
$limit_exception = count(array_intersect(array($GLOBALS['egw_info']['user']['account_id']) + $GLOBALS['egw']->accounts->memberships($GLOBALS['egw_info']['user']['account_id'],true), unserialize($GLOBALS['egw_info']['server']['export_limit_excepted']))) > 0;
|
$limit_exception = count(@array_intersect(array($GLOBALS['egw_info']['user']['account_id']) + $GLOBALS['egw']->accounts->memberships($GLOBALS['egw_info']['user']['account_id'],true), unserialize($GLOBALS['egw_info']['server']['export_limit_excepted']))) > 0;
|
||||||
if ($this->export_limit && !($GLOBALS['egw_info']['user']['apps']['admin'] || $limit_exception) &&
|
if ($this->export_limit && !($GLOBALS['egw_info']['user']['apps']['admin'] || $limit_exception) &&
|
||||||
count($ids) > (int)$this->export_limit)
|
count($ids) > (int)$this->export_limit)
|
||||||
{
|
{
|
||||||
@ -337,10 +337,21 @@ abstract class bo_merge
|
|||||||
return $content;
|
return $content;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function apply_styles (&$content, $mimetype) {
|
protected function apply_styles (&$content, $mimetype)
|
||||||
|
{
|
||||||
|
if ($mimetype == 'application/xml' &&
|
||||||
|
preg_match('/'.preg_quote('<?mso-application progid="').'([^"]+)'.preg_quote('"?>').'/',substr($content,0,200),$matches))
|
||||||
|
{
|
||||||
|
$mso_application_progid = $matches[1];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$mso_application_progid = '';
|
||||||
|
}
|
||||||
|
|
||||||
// Tags we can replace with the target document's version
|
// Tags we can replace with the target document's version
|
||||||
$replace_tags = array();
|
$replace_tags = array();
|
||||||
switch($mimetype)
|
switch($mimetype.$mso_application_progid)
|
||||||
{
|
{
|
||||||
case 'application/vnd.oasis.opendocument.text': // open office
|
case 'application/vnd.oasis.opendocument.text': // open office
|
||||||
case 'application/vnd.oasis.opendocument.spreadsheet':
|
case 'application/vnd.oasis.opendocument.spreadsheet':
|
||||||
@ -370,12 +381,17 @@ abstract class bo_merge
|
|||||||
'/<(ol|ul|table)(.*?)>/' => '</w:t></w:r></w:p><$1$2>',
|
'/<(ol|ul|table)(.*?)>/' => '</w:t></w:r></w:p><$1$2>',
|
||||||
'/<\/(ol|ul|table)>/' => '</$1><w:p><w:r><w:t>',
|
'/<\/(ol|ul|table)>/' => '</$1><w:p><w:r><w:t>',
|
||||||
'/<(li)(.*?)>(.*?)<\/\1>/' => '<$1 $2>$3</$1>',
|
'/<(li)(.*?)>(.*?)<\/\1>/' => '<$1 $2>$3</$1>',
|
||||||
|
/*
|
||||||
|
'/<(span)(.*?)>/' => "\n".'</w:t></w:r><$1$2>',
|
||||||
|
'/<\/(span)>/' => '</$1><w:r><w:t>'."\n",
|
||||||
|
*/
|
||||||
);
|
);
|
||||||
$content = preg_replace(array_keys($replace_tags),array_values($replace_tags),$content);
|
$content = preg_replace(array_keys($replace_tags),array_values($replace_tags),$content);
|
||||||
//echo $content;die();
|
//echo $content;die();
|
||||||
$doc = new DOMDocument();
|
$doc = new DOMDocument();
|
||||||
$xslt = new XSLTProcessor();
|
$xslt = new XSLTProcessor();
|
||||||
$doc->load(EGW_INCLUDE_ROOT.'/etemplate/templates/default/msoffice.xslt');
|
$xslt_file = $mimetype == 'application/xml' ? 'wordml.xslt' : 'msoffice.xslt';
|
||||||
|
$doc->load(EGW_INCLUDE_ROOT.'/etemplate/templates/default/'.$xslt_file);
|
||||||
$xslt->importStyleSheet($doc);
|
$xslt->importStyleSheet($doc);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -630,7 +646,7 @@ abstract class bo_merge
|
|||||||
|
|
||||||
// Tags we can replace with the target document's version
|
// Tags we can replace with the target document's version
|
||||||
$replace_tags = array();
|
$replace_tags = array();
|
||||||
switch($mimetype)
|
switch($mimetype.$mso_application_progid)
|
||||||
{
|
{
|
||||||
case 'application/vnd.oasis.opendocument.text': // open office
|
case 'application/vnd.oasis.opendocument.text': // open office
|
||||||
case 'application/vnd.oasis.opendocument.spreadsheet':
|
case 'application/vnd.oasis.opendocument.spreadsheet':
|
||||||
|
@ -134,15 +134,6 @@ Breakers
|
|||||||
|
|
||||||
<!-- Color & font -->
|
<!-- Color & font -->
|
||||||
<xsl:template match="span">
|
<xsl:template match="span">
|
||||||
<!--
|
|
||||||
<xsl:choose>
|
|
||||||
<xsl:when test="contains(@style,';')">
|
|
||||||
</xsl:when>
|
|
||||||
<xsl:otherwise>
|
|
||||||
<xsl:variable name="style" select="@style" />
|
|
||||||
</xsl:otherwise>
|
|
||||||
</xsl:choose>
|
|
||||||
-->
|
|
||||||
<xsl:variable name="style" select="str:tokenize(@style,';')" />
|
<xsl:variable name="style" select="str:tokenize(@style,';')" />
|
||||||
<xsl:for-each select="$style">
|
<xsl:for-each select="$style">
|
||||||
<xsl:if test="starts-with(.,'color:')">
|
<xsl:if test="starts-with(.,'color:')">
|
||||||
@ -173,19 +164,24 @@ Breakers
|
|||||||
</xsl:otherwise>
|
</xsl:otherwise>
|
||||||
</xsl:choose>
|
</xsl:choose>
|
||||||
</xsl:variable>
|
</xsl:variable>
|
||||||
|
<!--
|
||||||
<w:shd w:fill="{$hex}"/>
|
<w:shd w:fill="{$hex}"/>
|
||||||
|
-->
|
||||||
|
<w:highlight w:val="FF950E"/>
|
||||||
</xsl:if>
|
</xsl:if>
|
||||||
<xsl:if test="starts-with(.,'font-size')">
|
<xsl:if test="starts-with(.,'font-size')">
|
||||||
<xsl:variable name="font-size" select="substring-after(text(),'font-size:')" />
|
<xsl:variable name="font-size" select="substring-after(text(),'font-size:')" />
|
||||||
<!-- Approximate conversion that seems to work -->
|
<!-- Approximate conversion that seems to work -->
|
||||||
<xsl:variable name="size" select="ceiling(number(translate($font-size,translate($font-size,'0123456789',''),''))*1.5)"/>
|
<xsl:variable name="size" select="ceiling(number(translate($font-size,translate($font-size,'0123456789',''),''))*1.5)"/>
|
||||||
<w:sz w:val="{$size}"/>
|
<w:sz w:val="{$size}"/>
|
||||||
|
<w:szCs w:val="{$size}"/>
|
||||||
</xsl:if>
|
</xsl:if>
|
||||||
<xsl:if test="starts-with(., 'font-family:')">
|
<xsl:if test="starts-with(., 'font-family:')">
|
||||||
<xsl:variable name="font-name" select="translate(substring-before(substring-after(.,'font-family:'),','),"'",'')" />
|
<xsl:variable name="font-name" select="translate(substring-before(substring-after(.,'font-family:'),','),"'",'')" />
|
||||||
<w:rFonts w:ascii="{$font-name}" w:hAnsi="{$font-name}"/>
|
<w:rFonts w:ascii="{$font-name}" w:hAnsi="{$font-name}"/>
|
||||||
</xsl:if>
|
</xsl:if>
|
||||||
</xsl:for-each>
|
</xsl:for-each>
|
||||||
|
<xsl:apply-templates select="./span"/>
|
||||||
</xsl:template>
|
</xsl:template>
|
||||||
|
|
||||||
<!--
|
<!--
|
||||||
@ -207,7 +203,7 @@ Breakers
|
|||||||
<w:numId w:val="1"/>
|
<w:numId w:val="1"/>
|
||||||
<w:numFmt w:val="bullet"/>
|
<w:numFmt w:val="bullet"/>
|
||||||
<w:lvlJc w:val="left"/>
|
<w:lvlJc w:val="left"/>
|
||||||
<w:lvlText w:val="·"/>
|
<w:lvlText w:val="·"/>
|
||||||
</xsl:otherwise>
|
</xsl:otherwise>
|
||||||
</xsl:choose>
|
</xsl:choose>
|
||||||
</w:numPr>
|
</w:numPr>
|
||||||
@ -228,7 +224,10 @@ Breakers
|
|||||||
<w:rPr>
|
<w:rPr>
|
||||||
<w:rFonts w:ascii="Symbol" w:cs="Symbol" w:hAnsi="Symbol" w:hint="default"/>
|
<w:rFonts w:ascii="Symbol" w:cs="Symbol" w:hAnsi="Symbol" w:hint="default"/>
|
||||||
</w:rPr>
|
</w:rPr>
|
||||||
|
<!--
|
||||||
<w:t>· </w:t>
|
<w:t>· </w:t>
|
||||||
|
-->
|
||||||
|
<w:t>·</w:t>
|
||||||
</xsl:otherwise>
|
</xsl:otherwise>
|
||||||
</xsl:choose>
|
</xsl:choose>
|
||||||
</w:r>
|
</w:r>
|
||||||
|
260
etemplate/templates/default/wordml.xslt
Normal file
260
etemplate/templates/default/wordml.xslt
Normal file
@ -0,0 +1,260 @@
|
|||||||
|
<?xml version="1.0" encoding="ISO-8859-1"?>
|
||||||
|
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
|
||||||
|
xmlns:w="http://schemas.microsoft.com/office/word/2003/wordml"
|
||||||
|
xmlns:str="http://exslt.org/strings"
|
||||||
|
extension-element-prefixes="str"
|
||||||
|
>
|
||||||
|
<!-- xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" -->
|
||||||
|
<xsl:output method="xml" omit-xml-declaration="yes"/>
|
||||||
|
<xsl:template name="rbga-to-hex">
|
||||||
|
<xsl:param name="rgba-val"/>
|
||||||
|
<xsl:param name="count" select="1"/>
|
||||||
|
<xsl:variable name="val" select="substring-before($rgba-val,',')"/>
|
||||||
|
<xsl:variable name="tail" select="substring-after($rgba-val,concat($val,','))"/>
|
||||||
|
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="$count < 3">
|
||||||
|
<xsl:call-template name="to-hex">
|
||||||
|
<xsl:with-param name="val" select="$val"/>
|
||||||
|
</xsl:call-template>
|
||||||
|
<xsl:call-template name="rbga-to-hex">
|
||||||
|
<xsl:with-param name="count" select="$count + 1"/>
|
||||||
|
<xsl:with-param name="rgba-val" select="$tail"/>
|
||||||
|
</xsl:call-template>
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:otherwise>
|
||||||
|
<xsl:call-template name="to-hex">
|
||||||
|
<xsl:with-param name="val" select="$rgba-val"/>
|
||||||
|
</xsl:call-template>
|
||||||
|
</xsl:otherwise>
|
||||||
|
</xsl:choose>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<xsl:template name="to-hex">
|
||||||
|
<xsl:param name="val"/>
|
||||||
|
<xsl:param name="max" select="255"/>
|
||||||
|
<xsl:param name="min" select="0"/>
|
||||||
|
<xsl:param name="hex-key" select="'0123456789ABCDEF'"/>
|
||||||
|
|
||||||
|
<!-- REMOVE NON-NUMERIC CHARACTERS -->
|
||||||
|
<xsl:variable name="val"
|
||||||
|
select="translate($val,'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ,.-_=+!@#$%^*():; ','')"/>
|
||||||
|
|
||||||
|
<!-- insure that the rgb value is within 0-255 -->
|
||||||
|
<xsl:variable name="num">
|
||||||
|
<xsl:choose>
|
||||||
|
|
||||||
|
<xsl:when test="$val > $max">
|
||||||
|
<xsl:value-of select="$max"/>
|
||||||
|
</xsl:when>
|
||||||
|
|
||||||
|
<xsl:when test="$val < $min">
|
||||||
|
<xsl:value-of select="$min"/>
|
||||||
|
</xsl:when>
|
||||||
|
|
||||||
|
<!-- insure that we have whole numbers -->
|
||||||
|
<xsl:otherwise>
|
||||||
|
<xsl:value-of select="round($val)"/>
|
||||||
|
</xsl:otherwise>
|
||||||
|
|
||||||
|
</xsl:choose>
|
||||||
|
</xsl:variable>
|
||||||
|
|
||||||
|
<!-- Return Hex Val -->
|
||||||
|
<!-- substring(string, position, length) -->
|
||||||
|
<xsl:value-of select="concat( substring($hex-key,(ceiling(($num - ceiling($num mod 16)) div 16)+1),1),
|
||||||
|
substring($hex-key,($num mod 16)+1,1)
|
||||||
|
)"/>
|
||||||
|
</xsl:template>
|
||||||
|
<xsl:template match="node()|@*">
|
||||||
|
<xsl:copy>
|
||||||
|
<xsl:apply-templates select="node()|@*"/>
|
||||||
|
</xsl:copy>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<!-- Try to do replacements completely in XSLT
|
||||||
|
|
||||||
|
-->
|
||||||
|
<!-- w:p doesn't work right now
|
||||||
|
<xsl:template match="w:p[descendant::ul|descendant::ol]">
|
||||||
|
<xsl:for-each select="node()|@*">
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="descendant::ul|descendant::ol" >
|
||||||
|
<xsl:variable name="current" select="." />
|
||||||
|
<xsl:variable name="break" select="descendant::*[ul|ol|table]" />
|
||||||
|
Breakers
|
||||||
|
<xsl:copy-of select="$break" />
|
||||||
|
</xsl:template>
|
||||||
|
-->
|
||||||
|
|
||||||
|
<xsl:template match="w:r[descendant::strong|descendant::em|descendant::u|descendant::span]">
|
||||||
|
<xsl:for-each select="node()|@*[not(w:rPr)]">
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="descendant::strong|descendant::em|descendant::u|descendant::span" >
|
||||||
|
<xsl:for-each select="node()|@*">
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="descendant-or-self::strong|descendant-or-self::em|descendant-or-self::u|descendant-or-self::span" >
|
||||||
|
<w:r>
|
||||||
|
<w:rPr>
|
||||||
|
<xsl:apply-templates select=".|child::*" />
|
||||||
|
</w:rPr>
|
||||||
|
<w:t xml:space="preserve"><xsl:value-of select="." /></w:t>
|
||||||
|
</w:r>
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:otherwise>
|
||||||
|
<w:r><w:t xml:space="preserve"><xsl:copy-of select="." /></w:t></w:r>
|
||||||
|
</xsl:otherwise>
|
||||||
|
</xsl:choose>
|
||||||
|
</xsl:for-each>
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:otherwise>
|
||||||
|
<w:r>
|
||||||
|
<xsl:copy-of select="." />
|
||||||
|
</w:r>
|
||||||
|
</xsl:otherwise>
|
||||||
|
</xsl:choose>
|
||||||
|
</xsl:for-each>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<!-- Fix any bad breaks -->
|
||||||
|
<xsl:template match="w:t[child::w:br]">
|
||||||
|
<w:t>
|
||||||
|
<xsl:copy-of select="text()"/>
|
||||||
|
</w:t>
|
||||||
|
<w:br/>
|
||||||
|
</xsl:template>
|
||||||
|
<xsl:template match="i|em">
|
||||||
|
<w:i />
|
||||||
|
</xsl:template>
|
||||||
|
<xsl:template match="b|strong">
|
||||||
|
<w:b />
|
||||||
|
</xsl:template>
|
||||||
|
<xsl:template match="u">
|
||||||
|
<w:u w:val="single" />
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<!-- Color & font -->
|
||||||
|
<xsl:template match="span">
|
||||||
|
<xsl:variable name="style" select="str:tokenize(@style,';')" />
|
||||||
|
<xsl:for-each select="$style">
|
||||||
|
<xsl:if test="starts-with(.,'color:')">
|
||||||
|
<xsl:variable name="hex">
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="contains(., 'rgb(')">
|
||||||
|
<xsl:call-template name="rbga-to-hex">
|
||||||
|
<xsl:with-param name="rgba-val" select="substring-after(.,':')"/>
|
||||||
|
</xsl:call-template>
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:otherwise>
|
||||||
|
<xsl:value-of select="substring-after(.,'#')" />
|
||||||
|
</xsl:otherwise>
|
||||||
|
</xsl:choose>
|
||||||
|
</xsl:variable>
|
||||||
|
<w:color w:val="{$hex}" />
|
||||||
|
</xsl:if>
|
||||||
|
<xsl:if test="starts-with(.,'background-color:')">
|
||||||
|
<xsl:variable name="hex">
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="contains(., 'rgb(')">
|
||||||
|
<xsl:call-template name="rbga-to-hex">
|
||||||
|
<xsl:with-param name="rgba-val" select="substring-after(.,':')"/>
|
||||||
|
</xsl:call-template>
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:otherwise>
|
||||||
|
<xsl:value-of select="substring-after(.,'#')" />
|
||||||
|
</xsl:otherwise>
|
||||||
|
</xsl:choose>
|
||||||
|
</xsl:variable>
|
||||||
|
<!--
|
||||||
|
<w:shd w:fill="{$hex}"/>
|
||||||
|
-->
|
||||||
|
<w:highlight w:val="FF950E"/>
|
||||||
|
</xsl:if>
|
||||||
|
<xsl:if test="starts-with(.,'font-size')">
|
||||||
|
<xsl:variable name="font-size" select="substring-after(text(),'font-size:')" />
|
||||||
|
<!-- Approximate conversion that seems to work -->
|
||||||
|
<xsl:variable name="size" select="ceiling(number(translate($font-size,translate($font-size,'0123456789',''),''))*1.5)"/>
|
||||||
|
<w:sz w:val="{$size}"/>
|
||||||
|
<w:szCs w:val="{$size}"/>
|
||||||
|
</xsl:if>
|
||||||
|
<xsl:if test="starts-with(., 'font-family:')">
|
||||||
|
<xsl:variable name="font-name" select="translate(substring-before(substring-after(.,'font-family:'),','),"'",'')" />
|
||||||
|
<w:rFonts w:ascii="{$font-name}" w:hAnsi="{$font-name}"/>
|
||||||
|
</xsl:if>
|
||||||
|
</xsl:for-each>
|
||||||
|
<xsl:apply-templates select="./span"/>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Unordered (bullet) list
|
||||||
|
|
||||||
|
Numbers determined by examining a docx file from OpenOffice.org
|
||||||
|
-->
|
||||||
|
<xsl:template match="ul[child::li]|ol[child::li]">
|
||||||
|
<xsl:for-each select="./li">
|
||||||
|
<w:p>
|
||||||
|
<w:pPr>
|
||||||
|
<w:numPr>
|
||||||
|
<w:ilvl w:val="0"/>
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="name(..)='ol'">
|
||||||
|
<w:numId w:val="2"/>
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:otherwise>
|
||||||
|
<w:numId w:val="1"/>
|
||||||
|
<w:numFmt w:val="bullet"/>
|
||||||
|
<w:lvlJc w:val="left"/>
|
||||||
|
<w:lvlText w:val="·"/>
|
||||||
|
</xsl:otherwise>
|
||||||
|
</xsl:choose>
|
||||||
|
</w:numPr>
|
||||||
|
<w:tabs>
|
||||||
|
<w:tab w:leader="none" w:pos="707" w:val="left"/>
|
||||||
|
</w:tabs>
|
||||||
|
<w:ind w:hanging="283" w:left="707" w:right="0"/>
|
||||||
|
<w:spacing w:after="0" w:before="0"/>
|
||||||
|
</w:pPr>
|
||||||
|
<w:r>
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="name(..)='ol'">
|
||||||
|
<!-- This line gives numbers when opened in OO.o, but when the file is opened in MSWord, the numbers are doubled.
|
||||||
|
<w:t><xsl:number value="position()" format="1" />. </w:t>
|
||||||
|
-->
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:otherwise>
|
||||||
|
<w:rPr>
|
||||||
|
<w:rFonts w:ascii="Symbol" w:cs="Symbol" w:hAnsi="Symbol" w:hint="default"/>
|
||||||
|
</w:rPr>
|
||||||
|
<w:t>· </w:t>
|
||||||
|
</xsl:otherwise>
|
||||||
|
</xsl:choose>
|
||||||
|
</w:r>
|
||||||
|
<w:r>
|
||||||
|
<w:t><xsl:value-of select="normalize-space(text())" /></w:t>
|
||||||
|
</w:r>
|
||||||
|
</w:p>
|
||||||
|
</xsl:for-each>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<!-- HTML Table -->
|
||||||
|
<xsl:template match="table">
|
||||||
|
<w:tbl>
|
||||||
|
<w:tblPr>
|
||||||
|
<w:tblW w:type="dxa" w:w="9972"/>
|
||||||
|
<w:jc w:value="left"/>
|
||||||
|
</w:tblPr>
|
||||||
|
<w:tblGrid>
|
||||||
|
<xsl:for-each select="./tr[1]/td">
|
||||||
|
<w:gridCol />
|
||||||
|
</xsl:for-each>
|
||||||
|
</w:tblGrid>
|
||||||
|
<xsl:for-each select="./tr">
|
||||||
|
<w:tr>
|
||||||
|
<xsl:for-each select="./td">
|
||||||
|
<w:tc><w:p><w:r><w:t><xsl:apply-templates select="child::node()" /></w:t></w:r></w:p></w:tc>
|
||||||
|
</xsl:for-each>
|
||||||
|
</w:tr>
|
||||||
|
</xsl:for-each>
|
||||||
|
</w:tbl>
|
||||||
|
</xsl:template>
|
||||||
|
</xsl:stylesheet>
|
Loading…
Reference in New Issue
Block a user