I'm a beginner to XSLT, I'm trying to convert flash Text Format into HTML based format
There are <LI></LI>
blocks in the source xml and all <LI>
blocks contains 1 or many <FONT>
nodes. I need to apply the styles of the <FONT>
in inline css to the <LI>
and remove the <FONT>
node (first FONT child).
( Example for explanation only - start ) From:
<LI>
<FONT FACE="Lato" SIZE="24" COLOR="#F7941D" LETTERSPACING="0" KERNING="0">
<I>ertrr</I>
<FONT SIZE="12" COLOR="#4B4B4B">sdfsd</FONT>
</FONT>
</LI>
To:
<li style="font-family:Lato; font-size:24px; color:#F7941D;">
<I>ertrr</I>
<span style="font-size:12px; color:#4B4B4B;">sdfsd</span>
</li>
( Example for explanation only - end )
XML Source
<root>
<TEXTFORMAT LEADING="2">
<LI>
<FONT FACE="Lato" SIZE="24" COLOR="#F7941D" LETTERSPACING="0" KERNING="0">
<I>ertrr</I>
<FONT SIZE="12" COLOR="#4B4B4B"></FONT>
</FONT>
</LI>
</TEXTFORMAT>
<TEXTFORMAT LEADING="2">
<LI>
<FONT FACE="Lato" SIZE="24" COLOR="#000000" LETTERSPACING="0" KERNING="0">
<I><U>ert</U></I>
<FONT SIZE="12" COLOR="#4B4B4B"></FONT>
</FONT>
</LI>
</TEXTFORMAT>
<TEXTFORMAT LEADING="2">
<LI>
<FONT FACE="System" SIZE="16" COLOR="#4B4B4B" LETTERSPACING="0" KERNING="0">
<B>hgjgj</B>
<FONT FACE="Lato" SIZE="12"></FONT>
</FONT>
</LI>
</TEXTFORMAT>
<TEXTFORMAT LEADING="2">
<LI>
<FONT FACE="System" SIZE="16" COLOR="#4B4B4B" LETTERSPACING="0" KERNING="0">ghjghj
<FONT FACE="Lato" SIZE="12"></FONT>
</FONT>
</LI>
</TEXTFORMAT>
<TEXTFORMAT LEADING="2">
<LI>
<FONT FACE="Lato" SIZE="12" COLOR="#4B4B4B" LETTERSPACING="0" KERNING="0">@#dgsdg
<FONT FACE="Gabriola">sdfgdfg</FONT> dsfg df
<FONT SIZE="16">gdsfg</FONT>sd s
<FONT FACE="Lucida Console">d
<I>fg df</I> gs
<FONT FACE="Verdana">dg sdgfgsd</FONT>
</FONT> gdfg </FONT>
</LI>
</TEXTFORMAT>
<TEXTFORMAT LEADING="2">
<LI>
<FONT FACE="Lato" SIZE="24" COLOR="#000000" LETTERSPACING="0" KERNING="0">
<I><U>ert</U></I>
<FONT SIZE="12" COLOR="#4B4B4B">sdfsd</FONT>
</FONT>
</LI>
</TEXTFORMAT>
</root>
Expected Output
<div>
<li style="font-family:Lato; font-size:24px; color:#F7941D;">
<I>ertrr</I><span style="font-size:12px; color:#4B4B4B;"></span>
</li>
<li style="font-family:Lato; font-size:24px; color:#000000;">
<I><U>ert</U></I><span style="font-size:12px; color:#4B4B4B;"></span>
</li>
<li style="font-family:System; font-size:16px; color:#4B4B4B;">
<B>hgjgj</B><span style="font-family:Lato; font-size:12px; "></span>
</li>
<li style="font-family:System; font-size:16px; color:#4B4B4B;">
ghjghj
<span style="font-family:Lato; font-size:12px; "></span>
</li>
<li style="font-family:Lato; font-size:12px; color:#4B4B4B;">
@#dgsdg
<span style="font-family:Gabriola; ">sdfgdfg</span> dsfg df
<span style="font-size:16px; ">gdsfg</span>sd s
<span style="font-family:Lucida Console; ">d
<I>fg df</I> gs
<span style="font-family:Verdana; ">dg sdgfgsd</span></span> gdfg
</li>
<li style="font-family:Lato; font-size:24px; color:#000000;">
<I><U>ert</U></I><span style="font-size:12px; color:#4B4B4B;">sdfsd</span>
</li>
</div>
My code:
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
version="1.0">
<xsl:strip-space elements="*"/>
<xsl:output indent="yes" method="html"/>
<!-- identity template -->
<xsl:template match="node()|@*">
<xsl:copy>
<xsl:apply-templates select="node()|@*"/>
</xsl:copy>
</xsl:template>
<xsl:template match="root">
<div>
<xsl:apply-templates/>
</div>
</xsl:template>
<xsl:template match="FONT">
<span>
<xsl:attribute name="style">
<!-- collect attributes -->
<xsl:variable name="styles">
<xsl:if test="@FACE">
<xsl:value-of select="concat('font-family:', @FACE)"/>
<xsl:text>; </xsl:text>
</xsl:if>
<xsl:if test="@SIZE">
<xsl:value-of select="concat('font-size:', @SIZE, 'px')"/>
<xsl:text>; </xsl:text>
</xsl:if>
<xsl:if test="@COLOR">
<xsl:value-of select="concat('color:', @COLOR)"/>
<xsl:text>;</xsl:text>
</xsl:if>
</xsl:variable>
<xsl:value-of select="$styles"/>
</xsl:attribute>
<xsl:apply-templates/>
</span>
</xsl:template>
<!-- remove unwanted attributes -->
<xsl:template match="@LETTERSPACING|@KERNING"/>
<!-- Replace <LI> with <li> -->
<xsl:template match="LI">
<li>
<xsl:attribute name="style">
<!-- collect attributes -->
<xsl:variable name="styles">
<xsl:if test="FONT/@FACE">
<xsl:value-of select="concat('font-family:', FONT/@FACE)"/>
<xsl:text>; </xsl:text>
</xsl:if>
<xsl:if test="FONT/@SIZE">
<xsl:value-of select="concat('font-size:', FONT/@SIZE, 'px')"/>
<xsl:text>; </xsl:text>
</xsl:if>
<xsl:if test="FONT/@COLOR">
<xsl:value-of select="concat('color:', FONT/@COLOR)"/>
<xsl:text>;</xsl:text>
</xsl:if>
</xsl:variable>
<!-- delete trailing spaces -->
<xsl:value-of select="$styles"/>
</xsl:attribute>
<xsl:apply-templates/>
</li>
</xsl:template>
<!-- Remove TEXTFORMAT -->
<xsl:template match="TEXTFORMAT">
<xsl:apply-templates/>
</xsl:template>
</xsl:stylesheet>
Current Output
<div>
<li style="font-family:Lato; font-size:24px; color:#F7941D;">
<span style="font-family:Lato; font-size:24px; color:#F7941D;"><I>ertrr</I><span style="font-size:12px; color:#4B4B4B;"></span></span>
</li>
<li style="font-family:Lato; font-size:24px; color:#000000;">
<span style="font-family:Lato; font-size:24px; color:#000000;"><I><U>ert</U></I><span style="font-size:12px; color:#4B4B4B;"></span></span>
</li>
<li style="font-family:System; font-size:16px; color:#4B4B4B;">
<span style="font-family:System; font-size:16px; color:#4B4B4B;"><B>hgjgj</B><span style="font-family:Lato; font-size:12px; "></span></span>
</li>
<li style="font-family:System; font-size:16px; color:#4B4B4B;">
<span style="font-family:System; font-size:16px; color:#4B4B4B;">ghjghj
<span style="font-family:Lato; font-size:12px; "></span></span>
</li>
<li style="font-family:Lato; font-size:12px; color:#4B4B4B;">
<span style="font-family:Lato; font-size:12px; color:#4B4B4B;">@#dgsdg
<span style="font-family:Gabriola; ">sdfgdfg</span> dsfg df
<span style="font-size:16px; ">gdsfg</span>sd s
<span style="font-family:Lucida Console; ">d
<I>fg df</I> gs
<span style="font-family:Verdana; ">dg sdgfgsd</span></span> gdfg </span>
</li>
<li style="font-family:Lato; font-size:24px; color:#000000;">
<span style="font-family:Lato; font-size:24px; color:#000000;"><I><U>ert</U></I><span style="font-size:12px; color:#4B4B4B;">sdfsd</span></span>
</li>
</div>