home *** CD-ROM | disk | FTP | other *** search
/ PC World 2004 January / PCWorld_2004-01_cd.bin / akce / openoffice / f_0373 / main_wml.xsl
Text File  |  2003-04-04  |  11KB  |  227 lines

  1. <!--
  2.  
  3.    The Contents of this file are made available subject to the terms of
  4.    either of the following licenses
  5.  
  6.           - GNU Lesser General Public License Version 2.1
  7.           - Sun Industry Standards Source License Version 1.1
  8.  
  9.    Sun Microsystems Inc., October, 2000
  10.  
  11.    GNU Lesser General Public License Version 2.1
  12.    =============================================
  13.    Copyright 2000 by Sun Microsystems, Inc.
  14.    901 San Antonio Road, Palo Alto, CA 94303, USA
  15.  
  16.    This library is free software; you can redistribute it and/or
  17.    modify it under the terms of the GNU Lesser General Public
  18.    License version 2.1, as published by the Free Software Foundation.
  19.  
  20.    This library is distributed in the hope that it will be useful,
  21.    but WITHOUT ANY WARRANTY; without even the implied warranty of
  22.    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  23.    Lesser General Public License for more details.
  24.  
  25.    You should have received a copy of the GNU Lesser General Public
  26.    License along with this library; if not, write to the Free Software
  27.    Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  28.    MA  02111-1307  USA
  29.  
  30.  
  31.    Sun Industry Standards Source License Version 1.1
  32.    =================================================
  33.    The contents of this file are subject to the Sun Industry Standards
  34.    Source License Version 1.1 (the "License"); You may not use this file
  35.    except in compliance with the License. You may obtain a copy of the
  36.    License at http://www.openoffice.org/license.html.
  37.  
  38.    Software provided under this License is provided on an "AS IS" basis,
  39.    WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING,
  40.    WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
  41.    MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
  42.    See the License for the specific provisions governing your rights and
  43.    obligations concerning the Software.
  44.  
  45.    The Initial Developer of the Original Code is: Sun Microsystems, Inc.
  46.  
  47.    Copyright ┬⌐ 2002 by Sun Microsystems, Inc.
  48.  
  49.    All Rights Reserved.
  50.  
  51.    Contributor(s): _______________________________________
  52.  
  53. -->
  54. <xsl:stylesheet version="1.0"
  55.                 xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
  56.                 xmlns:office="http://openoffice.org/2000/office"
  57.                 xmlns:style="http://openoffice.org/2000/style"
  58.                 xmlns:text="http://openoffice.org/2000/text"
  59.                 xmlns:table="http://openoffice.org/2000/table"
  60.                 xmlns:draw="http://openoffice.org/2000/drawing"
  61.                 xmlns:fo="http://www.w3.org/1999/XSL/Format"
  62.                 xmlns:xlink="http://www.w3.org/1999/xlink"
  63.                 xmlns:number="http://openoffice.org/2000/datastyle"
  64.                 xmlns:svg="http://www.w3.org/2000/svg"
  65.                 xmlns:chart="http://openoffice.org/2000/chart"
  66.                 xmlns:dr3d="http://openoffice.org/2000/dr3d"
  67.                 xmlns:math="http://www.w3.org/1998/Math/MathML"
  68.                 xmlns:form="http://openoffice.org/2000/form"
  69.                 xmlns:script="http://openoffice.org/2000/script"
  70.                 office:class="text"
  71.                 office:version="1.0"
  72.                 xmlns:dc="http://purl.org/dc/elements/1.1/"
  73.                 xmlns:meta="http://openoffice.org/2000/meta"
  74.                 xmlns:config="http://openoffice.org/2001/config"
  75.                 xmlns:help="http://openoffice.org/2000/help"
  76.                 xmlns:xt="http://www.jclark.com/xt"
  77.                 xmlns:system="http://www.jclark.com/xt/java/java.lang.System"
  78.                 xmlns:urlencoder="http://www.jclark.com/xt/java/java.net.URLEncoder"
  79.                 xmlns:xalan="http://xml.apache.org/xalan"
  80.                 xmlns:java="http://xml.apache.org/xslt/java"
  81.                 exclude-result-prefixes="java">
  82.  
  83.  
  84.     <xsl:output method               = "xml"
  85.                 omit-xml-declaration = "no"
  86.                 media-type           = "text/vnd.wap.wml"
  87.                 encoding             = "UTF-8"
  88.                 indent               = "yes"
  89.                 doctype-public       = "-//WAPFORUM//DTD WML 1.1//EN"
  90.                 doctype-system       = "http://www.wapforum.org/DTD/wml_1.1.xml"/>
  91.  
  92.  
  93.     <!--+++++ INCLUDED XSL MODULES +++++-->
  94.  
  95.       <!-- inherited style properties will be collected and written in a CSS header (CSS) -->
  96.     <xsl:include href="style_header.xsl"/>
  97.       <!-- inherited style properties will be collected and written as html properties in a temporary variable (HTML4, PALM) -->
  98.     <xsl:include href="style_inlined.xsl"/>
  99.       <!-- our xml style properties will be mapped to CSS and HTML4.x properties -->
  100.     <xsl:include href="style_mapping.xsl"/>
  101.       <!-- common element handling -->
  102.     <xsl:include href="common.xsl"/>
  103.       <!-- table handling -->
  104.     <xsl:include href="table.xsl"/>
  105.     <xsl:include href="table_wml.xsl"/>
  106.       <!-- palm handling -->
  107.     <xsl:include href="palm.xsl"/>
  108.  
  109.  
  110.  
  111.     <!--+++++ PARAMETER FROM THE APPLICATION AND GLOBAL VARIABLES +++++-->
  112.  
  113.    <!--+++++ PARAMETER FROM THE APPLICATION AND GLOBAL VARIABLES +++++-->
  114.  
  115.     <!-- MANDATORY: URL of meta stream -->
  116.     <xsl:param name="metaFileURL"/>
  117.  
  118.     <!-- MANDATORY: URL of styles stream -->
  119.     <xsl:param name="stylesFileURL"/>
  120.  
  121.     <!-- MANDATORY: for resolving relative links
  122.         For resolving realtive links to the packed SO document, i.e. the path/URL of the jared sxw file (e.g. meta.xml, styles.xml, links to graphics in a relative directory) -->
  123.     <xsl:param name="absoluteSourceDirRef"/>
  124.  
  125.     <!-- OPTIONAL (mandatory, when when source is compressed): Necessary for the in the packed OO document embedded files (mostly graphics from the compressed /Picture dir).
  126.          When the OpenOffice (OO) file has been unpacked the absoluteSoureDirRef can be taken,
  127.          Otherwise, a JAR URL could be choosen or when working with OpenOffice a so called Package-URL encoded over HTTP can be used to
  128.          access the jared contents of the the jared document. . -->
  129.     <xsl:param name="jaredRootURL" select="$absoluteSourceDirRef"/>
  130.  
  131.     <!-- OPTIONAL (mandatory, when used in session based environment)
  132.          Useful for WebApplications: if a HTTP session is not cookie based, URL rewriting is beeing used (the session is appended to the URL).
  133.          This URL session is used when creating links to graphics by XSLT. Otherwise the user havt to log again in for every graphic he would like to see. -->
  134.     <xsl:param name="optionalURLSuffix"/>
  135.  
  136.     <!-- OPTIONAL: DPI (dots per inch) the standard solution of given pictures (necessary for the conversion of 'cm' into 'pixel')-->
  137.     <xsl:param name="dpi" select="96"/>
  138.  
  139.     <!-- OPTIONAL: in case of using a different processor than a JAVA XSLT, you can unable the Java functionality
  140.          (i.e. debugging time and encoding chapter names for the content-table as href and anchors ) -->
  141.     <xsl:param name="isJavaDisabled" select="false()"/>
  142.  
  143.     <!-- OPTIONAL: user-agent will be differntiated by this parameter given by application (e.g. java servlet)-->
  144.     <xsl:param name="outputType" select="'WML'"/>
  145.  
  146.     <!-- OPTIONAL: for activating the debug mode set the variable here to 'true()' or give any value from outside -->
  147.     <xsl:param name="isDebugMode"   select="false()"/>
  148.  
  149.     <!-- not tested for WML -->
  150.     <xsl:param name="disableLinkedTableOfContent" select="true()"/>
  151.  
  152.     <!-- following variables are not used for WML transformation, but have to be declared -->
  153.     <xsl:param name="precedingChapterLevel1"  select="0"/>
  154.     <xsl:param name="precedingChapterLevel2"  select="0"/>
  155.     <xsl:param name="precedingChapterLevel3"  select="0"/>
  156.     <xsl:param name="precedingChapterLevel4"  select="0"/>
  157.     <xsl:param name="precedingChapterLevel5"  select="0"/>
  158.     <xsl:param name="precedingChapterLevel6"  select="0"/>
  159.     <xsl:param name="precedingChapterLevel7"  select="0"/>
  160.     <xsl:param name="precedingChapterLevel8"  select="0"/>
  161.     <xsl:param name="precedingChapterLevel9"  select="0"/>
  162.     <xsl:param name="precedingChapterLevel10" select="0"/>
  163.     <xsl:param name="contentTableURL"/>
  164.  
  165.  
  166.  
  167.     <!-- works for normal separated zipped xml files as for flat filter single xml file format as well -->
  168.     <xsl:variable name="office:meta-file"           select="document($metaFileURL)"/>
  169.     <xsl:variable name="office:styles-file"         select="document($stylesFileURL)"/>
  170.     <xsl:variable name="office:font-decls"          select="$office:styles-file/*/office:font-decls"/>
  171.     <xsl:variable name="office:styles"              select="$office:styles-file/*/office:styles"/>
  172.     <!-- office:automatic-styles may occure in two different files (i.d. content.xml and styles.xml). Furthermore the top level tag is different in a flat xml file -->
  173.     <xsl:variable name="office:automatic-styles"    select="/*/office:automatic-styles"/>
  174.  
  175.  
  176.     <!--    AVOID NESTING PARAGRAPHS IN WML:
  177.             The list of all office tags, which map to a paragraph. This is necessary as no nested
  178.             paragraph tags are allowed in WML1.1 so a parent check before open has to be done.
  179.             Checked in a table cell, the table row is ALWAYS an ancestor, so it have to be excluded -->
  180.     <xsl:variable name="wap-paragraph-elements-without-table-row" select="'text:p text:h text:span text:a text:section text:list-item draw:text-box draw:page table:sub-table'"/>
  181.     <xsl:variable name="wap-paragraph-elements"                   select="concat($wap-paragraph-elements-without-table-row, ' table:table-row ')"/>
  182.  
  183.  
  184.  
  185.  
  186.     <!-- ************************************* -->
  187.     <!-- *** build the propriate HTML file *** -->
  188.     <!-- ************************************* -->
  189.  
  190.     <xsl:template match="/">
  191.         <!--    to access the variable like a node-set it is necessary to convert it
  192.                 from a result-tree-fragment (RTF) to a node set using the James Clark extension-->
  193.         <xsl:variable name="collectedGlobalData-RTF">
  194.                 <xsl:call-template name='create-all-inline-styles'/>
  195.         </xsl:variable>
  196.         <xsl:choose>
  197.             <xsl:when test="function-available('xt:node-set')">
  198.                 <xsl:call-template name="start">
  199.                     <xsl:with-param name="collectedGlobalData" select="xt:node-set($collectedGlobalData-RTF)"/>
  200.                 </xsl:call-template>
  201.             </xsl:when>
  202.             <xsl:when test="function-available('xalan:nodeset')">
  203.                 <xsl:call-template name="start">
  204.                     <xsl:with-param name="collectedGlobalData" select="xalan:nodeset($collectedGlobalData-RTF)"/>
  205.                 </xsl:call-template>
  206.             </xsl:when>
  207.             <xsl:otherwise>
  208.                 <xsl:element name="NodeSetFunctionNotAvailable"/>
  209.                 <xsl:call-template name="start"/>
  210.             </xsl:otherwise>
  211.         </xsl:choose>
  212.     </xsl:template>
  213.  
  214.     <xsl:template name="start">
  215.         <xsl:param name="collectedGlobalData"/>
  216.  
  217.         <xsl:element name="wml">
  218.             <xsl:element name="card">
  219.                 <!-- processing the content of the xml file -->
  220.                 <xsl:apply-templates select="/*/office:body">
  221.                     <xsl:with-param name="collectedGlobalData" select="$collectedGlobalData"/>
  222.                 </xsl:apply-templates>
  223.             </xsl:element>
  224.         </xsl:element>
  225.     </xsl:template>
  226.  
  227. </xsl:stylesheet>