diff options
-rw-r--r-- | xslt/subsurfacecsv.xslt | 560 |
1 files changed, 280 insertions, 280 deletions
diff --git a/xslt/subsurfacecsv.xslt b/xslt/subsurfacecsv.xslt index 077ec6cb6..33424bc22 100644 --- a/xslt/subsurfacecsv.xslt +++ b/xslt/subsurfacecsv.xslt @@ -55,333 +55,333 @@ </xsl:call-template> </xsl:variable> <xsl:if test="$number >= 0"> - <dive> - <xsl:attribute name="date"> - <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="1"/> - <xsl:with-param name="line" select="$line"/> - </xsl:call-template> - </xsl:attribute> - - <xsl:attribute name="time"> - <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="2"/> - <xsl:with-param name="line" select="$line"/> - </xsl:call-template> - </xsl:attribute> - - <xsl:attribute name="number"> - <xsl:value-of select="$number"/> - </xsl:attribute> - - <xsl:attribute name="duration"> - <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="3"/> - <xsl:with-param name="line" select="$line"/> - </xsl:call-template> - </xsl:attribute> - - <xsl:attribute name="tags"> - <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="22"/> - <xsl:with-param name="line" select="$line"/> - </xsl:call-template> - </xsl:attribute> - - <xsl:variable name="rating"> - <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="18"/> - <xsl:with-param name="line" select="$line"/> - </xsl:call-template> - </xsl:variable> - <xsl:if test="$rating != ''"> - <xsl:attribute name="rating"> - <xsl:value-of select="$rating"/> - </xsl:attribute> - </xsl:if> - - <xsl:variable name="visibility"> - <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="19"/> - <xsl:with-param name="line" select="$line"/> - </xsl:call-template> - </xsl:variable> - <xsl:if test="$visibility != ''"> - <xsl:attribute name="visibility"> - <xsl:value-of select="$visibility"/> + <dive> + <xsl:attribute name="date"> + <xsl:call-template name="getFieldByIndex"> + <xsl:with-param name="index" select="1"/> + <xsl:with-param name="line" select="$line"/> + </xsl:call-template> </xsl:attribute> - </xsl:if> - - <divecomputerid deviceid="ffffffff" model="csv" /> - <depth> - <xsl:variable name="max"> + <xsl:attribute name="time"> <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="4"/> + <xsl:with-param name="index" select="2"/> <xsl:with-param name="line" select="$line"/> </xsl:call-template> - </xsl:variable> - <xsl:variable name="mean"> + </xsl:attribute> + + <xsl:attribute name="number"> + <xsl:value-of select="$number"/> + </xsl:attribute> + + <xsl:attribute name="duration"> <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="5"/> + <xsl:with-param name="index" select="3"/> <xsl:with-param name="line" select="$line"/> </xsl:call-template> - </xsl:variable> - <xsl:if test="$max != ''"> - <xsl:attribute name="max"> - <xsl:choose> - <xsl:when test="$units = 0"> - <xsl:value-of select="$max"/> - </xsl:when> - <xsl:otherwise> - <xsl:value-of select="concat(format-number((substring-before($max, ' ') * 0.3048), '#.##'), ' m')"/> - </xsl:otherwise> - </xsl:choose> - </xsl:attribute> - </xsl:if> - <xsl:if test="$mean != ''"> - <xsl:attribute name="mean"> - <xsl:choose> - <xsl:when test="$units = 0"> - <xsl:value-of select="$mean"/> - </xsl:when> - <xsl:otherwise> - <xsl:value-of select="concat(format-number((substring-before($mean, ' ') * 0.3048), '#.##'), ' m')"/> - </xsl:otherwise> - </xsl:choose> - </xsl:attribute> - </xsl:if> - </depth> + </xsl:attribute> - <divetemperature> - <xsl:variable name="air"> + <xsl:attribute name="tags"> <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="6"/> + <xsl:with-param name="index" select="22"/> <xsl:with-param name="line" select="$line"/> </xsl:call-template> - </xsl:variable> - <xsl:variable name="water"> + </xsl:attribute> + + <xsl:variable name="rating"> <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="7"/> + <xsl:with-param name="index" select="18"/> <xsl:with-param name="line" select="$line"/> </xsl:call-template> </xsl:variable> - <xsl:if test="$air != ''"> - <xsl:attribute name="air"> - <xsl:choose> - <xsl:when test="$units = 0"> - <xsl:value-of select="$air"/> - </xsl:when> - <xsl:otherwise> - <xsl:value-of select="concat(format-number((substring-before($air, ' ') - 32) * 5 div 9, '0.0'), ' C')"/> - </xsl:otherwise> - </xsl:choose> + <xsl:if test="$rating != ''"> + <xsl:attribute name="rating"> + <xsl:value-of select="$rating"/> </xsl:attribute> </xsl:if> - <xsl:if test="$water != ''"> - <xsl:attribute name="water"> - <xsl:choose> - <xsl:when test="$units = 0"> - <xsl:value-of select="$water"/> - </xsl:when> - <xsl:otherwise> - <xsl:value-of select="concat(format-number((substring-before($water, ' ') - 32) * 5 div 9, '0.0'), ' C')"/> - </xsl:otherwise> - </xsl:choose> - </xsl:attribute> - </xsl:if> - </divetemperature> - <cylinder> - <xsl:variable name="size"> + <xsl:variable name="visibility"> <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="8"/> + <xsl:with-param name="index" select="19"/> <xsl:with-param name="line" select="$line"/> </xsl:call-template> </xsl:variable> - <xsl:variable name="start"> - <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="9"/> - <xsl:with-param name="line" select="$line"/> - </xsl:call-template> - </xsl:variable> - <xsl:variable name="end"> + <xsl:if test="$visibility != ''"> + <xsl:attribute name="visibility"> + <xsl:value-of select="$visibility"/> + </xsl:attribute> + </xsl:if> + + <divecomputerid deviceid="ffffffff" model="csv" /> + + <depth> + <xsl:variable name="max"> + <xsl:call-template name="getFieldByIndex"> + <xsl:with-param name="index" select="4"/> + <xsl:with-param name="line" select="$line"/> + </xsl:call-template> + </xsl:variable> + <xsl:variable name="mean"> + <xsl:call-template name="getFieldByIndex"> + <xsl:with-param name="index" select="5"/> + <xsl:with-param name="line" select="$line"/> + </xsl:call-template> + </xsl:variable> + <xsl:if test="$max != ''"> + <xsl:attribute name="max"> + <xsl:choose> + <xsl:when test="$units = 0"> + <xsl:value-of select="$max"/> + </xsl:when> + <xsl:otherwise> + <xsl:value-of select="concat(format-number((substring-before($max, ' ') * 0.3048), '#.##'), ' m')"/> + </xsl:otherwise> + </xsl:choose> + </xsl:attribute> + </xsl:if> + <xsl:if test="$mean != ''"> + <xsl:attribute name="mean"> + <xsl:choose> + <xsl:when test="$units = 0"> + <xsl:value-of select="$mean"/> + </xsl:when> + <xsl:otherwise> + <xsl:value-of select="concat(format-number((substring-before($mean, ' ') * 0.3048), '#.##'), ' m')"/> + </xsl:otherwise> + </xsl:choose> + </xsl:attribute> + </xsl:if> + </depth> + + <divetemperature> + <xsl:variable name="air"> + <xsl:call-template name="getFieldByIndex"> + <xsl:with-param name="index" select="6"/> + <xsl:with-param name="line" select="$line"/> + </xsl:call-template> + </xsl:variable> + <xsl:variable name="water"> + <xsl:call-template name="getFieldByIndex"> + <xsl:with-param name="index" select="7"/> + <xsl:with-param name="line" select="$line"/> + </xsl:call-template> + </xsl:variable> + <xsl:if test="$air != ''"> + <xsl:attribute name="air"> + <xsl:choose> + <xsl:when test="$units = 0"> + <xsl:value-of select="$air"/> + </xsl:when> + <xsl:otherwise> + <xsl:value-of select="concat(format-number((substring-before($air, ' ') - 32) * 5 div 9, '0.0'), ' C')"/> + </xsl:otherwise> + </xsl:choose> + </xsl:attribute> + </xsl:if> + <xsl:if test="$water != ''"> + <xsl:attribute name="water"> + <xsl:choose> + <xsl:when test="$units = 0"> + <xsl:value-of select="$water"/> + </xsl:when> + <xsl:otherwise> + <xsl:value-of select="concat(format-number((substring-before($water, ' ') - 32) * 5 div 9, '0.0'), ' C')"/> + </xsl:otherwise> + </xsl:choose> + </xsl:attribute> + </xsl:if> + </divetemperature> + + <cylinder> + <xsl:variable name="size"> + <xsl:call-template name="getFieldByIndex"> + <xsl:with-param name="index" select="8"/> + <xsl:with-param name="line" select="$line"/> + </xsl:call-template> + </xsl:variable> + <xsl:variable name="start"> + <xsl:call-template name="getFieldByIndex"> + <xsl:with-param name="index" select="9"/> + <xsl:with-param name="line" select="$line"/> + </xsl:call-template> + </xsl:variable> + <xsl:variable name="end"> + <xsl:call-template name="getFieldByIndex"> + <xsl:with-param name="index" select="10"/> + <xsl:with-param name="line" select="$line"/> + </xsl:call-template> + </xsl:variable> + <xsl:variable name="o2"> + <xsl:call-template name="getFieldByIndex"> + <xsl:with-param name="index" select="11"/> + <xsl:with-param name="line" select="$line"/> + </xsl:call-template> + </xsl:variable> + <xsl:variable name="he"> + <xsl:call-template name="getFieldByIndex"> + <xsl:with-param name="index" select="12"/> + <xsl:with-param name="line" select="$line"/> + </xsl:call-template> + </xsl:variable> + + <!-- ALxxx -> xxx cuft at 3000 psi + LPxxx -> xxx cuft at 2400 psi + HPxxx -> xxx cuft at 3440 psi --> + + <xsl:if test="$size != ''"> + <xsl:attribute name="size"> + <xsl:choose> + <xsl:when test="substring($size, 1, 2) = 'AL'"> + <xsl:value-of select="format-number((translate($size, translate($size, '0123456789', ''), '') * 14.7 div 3000) div 0.035315, '#.#')"/> + </xsl:when> + <xsl:when test="substring($size, 1, 2) = 'LP'"> + <xsl:value-of select="format-number((translate($size, translate($size, '0123456789', ''), '') * 14.7 div 2400) div 0.035315, '#.#')"/> + </xsl:when> + <xsl:when test="substring($size, 1, 2) = 'HP'"> + <xsl:value-of select="format-number((translate($size, translate($size, '0123456789', ''), '') * 14.7 div 3440) div 0.035315, '#.#')"/> + </xsl:when> + <xsl:otherwise> + <xsl:value-of select="$size"/> + </xsl:otherwise> + </xsl:choose> + </xsl:attribute> + </xsl:if> + <xsl:if test="substring($size, 1, 2) = 'AL' or substring($size, 1, 2) = 'LP' or substring($size, 1, 2) = 'HP'"> + <xsl:attribute name="description"> + <xsl:value-of select="$size"/> + </xsl:attribute> + </xsl:if> + <xsl:if test="$start != ''"> + <xsl:attribute name="start"> + <xsl:choose> + <xsl:when test="$units = 0"> + <xsl:value-of select="$start"/> + </xsl:when> + <xsl:otherwise> + <xsl:value-of select="concat(format-number((substring-before($start, ' ') div 14.5037738007), '#'), ' bar')"/> + </xsl:otherwise> + </xsl:choose> + </xsl:attribute> + </xsl:if> + <xsl:if test="$end != ''"> + <xsl:attribute name="end"> + <xsl:choose> + <xsl:when test="$units = 0"> + <xsl:value-of select="$end"/> + </xsl:when> + <xsl:otherwise> + <xsl:value-of select="concat(format-number((substring-before($end, ' ') div 14.5037738007), '#'), ' bar')"/> + </xsl:otherwise> + </xsl:choose> + </xsl:attribute> + </xsl:if> + <xsl:if test="$o2 != ''"> + <xsl:attribute name="o2"> + <xsl:value-of select="$o2"/> + </xsl:attribute> + </xsl:if> + <xsl:if test="$he != ''"> + <xsl:attribute name="he"> + <xsl:value-of select="$he"/> + </xsl:attribute> + </xsl:if> + </cylinder> + + <location> + <xsl:variable name="gps"> + <xsl:call-template name="getFieldByIndex"> + <xsl:with-param name="index" select="14"/> + <xsl:with-param name="line" select="$line"/> + </xsl:call-template> + </xsl:variable> + <xsl:variable name="location"> + <xsl:call-template name="getFieldByIndex"> + <xsl:with-param name="index" select="13"/> + <xsl:with-param name="line" select="$line"/> + </xsl:call-template> + </xsl:variable> + <xsl:if test="$gps != ''"> + <xsl:attribute name="gps"> + <xsl:value-of select="$gps"/> + </xsl:attribute> + </xsl:if> + <xsl:if test="$location != ''"> + <xsl:value-of select="$location"/> + </xsl:if> + </location> + + <xsl:variable name="dm"> <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="10"/> + <xsl:with-param name="index" select="15"/> <xsl:with-param name="line" select="$line"/> </xsl:call-template> </xsl:variable> - <xsl:variable name="o2"> + <xsl:if test="$dm != ''"> + <divemaster> + <xsl:value-of select="$dm"/> + </divemaster> + </xsl:if> + + <xsl:variable name="buddy"> <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="11"/> + <xsl:with-param name="index" select="16"/> <xsl:with-param name="line" select="$line"/> </xsl:call-template> </xsl:variable> - <xsl:variable name="he"> + <xsl:if test="$buddy != ''"> + <buddy> + <xsl:value-of select="$buddy"/> + </buddy> + </xsl:if> + + <xsl:variable name="suit"> <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="12"/> + <xsl:with-param name="index" select="17"/> <xsl:with-param name="line" select="$line"/> </xsl:call-template> </xsl:variable> - - <!-- ALxxx -> xxx cuft at 3000 psi - LPxxx -> xxx cuft at 2400 psi - HPxxx -> xxx cuft at 3440 psi --> - - <xsl:if test="$size != ''"> - <xsl:attribute name="size"> - <xsl:choose> - <xsl:when test="substring($size, 1, 2) = 'AL'"> - <xsl:value-of select="format-number((translate($size, translate($size, '0123456789', ''), '') * 14.7 div 3000) div 0.035315, '#.#')"/> - </xsl:when> - <xsl:when test="substring($size, 1, 2) = 'LP'"> - <xsl:value-of select="format-number((translate($size, translate($size, '0123456789', ''), '') * 14.7 div 2400) div 0.035315, '#.#')"/> - </xsl:when> - <xsl:when test="substring($size, 1, 2) = 'HP'"> - <xsl:value-of select="format-number((translate($size, translate($size, '0123456789', ''), '') * 14.7 div 3440) div 0.035315, '#.#')"/> - </xsl:when> - <xsl:otherwise> - <xsl:value-of select="$size"/> - </xsl:otherwise> - </xsl:choose> - </xsl:attribute> - </xsl:if> - <xsl:if test="substring($size, 1, 2) = 'AL' or substring($size, 1, 2) = 'LP' or substring($size, 1, 2) = 'HP'"> - <xsl:attribute name="description"> - <xsl:value-of select="$size"/> - </xsl:attribute> - </xsl:if> - <xsl:if test="$start != ''"> - <xsl:attribute name="start"> - <xsl:choose> - <xsl:when test="$units = 0"> - <xsl:value-of select="$start"/> - </xsl:when> - <xsl:otherwise> - <xsl:value-of select="concat(format-number((substring-before($start, ' ') div 14.5037738007), '#'), ' bar')"/> - </xsl:otherwise> - </xsl:choose> - </xsl:attribute> + <xsl:if test="$suit != ''"> + <suit> + <xsl:value-of select="$suit"/> + </suit> </xsl:if> - <xsl:if test="$end != ''"> - <xsl:attribute name="end"> - <xsl:choose> - <xsl:when test="$units = 0"> - <xsl:value-of select="$end"/> - </xsl:when> - <xsl:otherwise> - <xsl:value-of select="concat(format-number((substring-before($end, ' ') div 14.5037738007), '#'), ' bar')"/> - </xsl:otherwise> - </xsl:choose> - </xsl:attribute> - </xsl:if> - <xsl:if test="$o2 != ''"> - <xsl:attribute name="o2"> - <xsl:value-of select="$o2"/> - </xsl:attribute> - </xsl:if> - <xsl:if test="$he != ''"> - <xsl:attribute name="he"> - <xsl:value-of select="$he"/> - </xsl:attribute> - </xsl:if> - </cylinder> - <location> - <xsl:variable name="gps"> + <xsl:variable name="notes"> <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="14"/> + <xsl:with-param name="index" select="20"/> <xsl:with-param name="line" select="$line"/> + <xsl:with-param name="remaining" select="$remaining"/> </xsl:call-template> </xsl:variable> - <xsl:variable name="location"> + <xsl:if test="$notes != ''"> + <notes> + <xsl:value-of select="$notes"/> + </notes> + </xsl:if> + + <xsl:variable name="weight"> <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="13"/> + <xsl:with-param name="index" select="21"/> <xsl:with-param name="line" select="$line"/> </xsl:call-template> </xsl:variable> - <xsl:if test="$gps != ''"> - <xsl:attribute name="gps"> - <xsl:value-of select="$gps"/> - </xsl:attribute> + <xsl:if test="$weight != ''"> + <weightsystem description="unknown"> + <xsl:attribute name="weight"> + <xsl:choose> + <xsl:when test="$units = 0"> + <xsl:value-of select="$weight"/> + </xsl:when> + <xsl:otherwise> + <xsl:value-of select="concat(format-number((substring-before($weight, ' ') * 0.453592), '#.##'), ' kg')"/> + </xsl:otherwise> + </xsl:choose> + </xsl:attribute> + </weightsystem> </xsl:if> - <xsl:if test="$location != ''"> - <xsl:value-of select="$location"/> - </xsl:if> - </location> - - <xsl:variable name="dm"> - <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="15"/> - <xsl:with-param name="line" select="$line"/> - </xsl:call-template> - </xsl:variable> - <xsl:if test="$dm != ''"> - <divemaster> - <xsl:value-of select="$dm"/> - </divemaster> - </xsl:if> - - <xsl:variable name="buddy"> - <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="16"/> - <xsl:with-param name="line" select="$line"/> - </xsl:call-template> - </xsl:variable> - <xsl:if test="$buddy != ''"> - <buddy> - <xsl:value-of select="$buddy"/> - </buddy> - </xsl:if> - - <xsl:variable name="suit"> - <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="17"/> - <xsl:with-param name="line" select="$line"/> - </xsl:call-template> - </xsl:variable> - <xsl:if test="$suit != ''"> - <suit> - <xsl:value-of select="$suit"/> - </suit> - </xsl:if> - - <xsl:variable name="notes"> - <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="20"/> - <xsl:with-param name="line" select="$line"/> - <xsl:with-param name="remaining" select="$remaining"/> - </xsl:call-template> - </xsl:variable> - <xsl:if test="$notes != ''"> - <notes> - <xsl:value-of select="$notes"/> - </notes> - </xsl:if> - <xsl:variable name="weight"> - <xsl:call-template name="getFieldByIndex"> - <xsl:with-param name="index" select="21"/> - <xsl:with-param name="line" select="$line"/> - </xsl:call-template> - </xsl:variable> - <xsl:if test="$weight != ''"> - <weightsystem description="unknown"> - <xsl:attribute name="weight"> - <xsl:choose> - <xsl:when test="$units = 0"> - <xsl:value-of select="$weight"/> - </xsl:when> - <xsl:otherwise> - <xsl:value-of select="concat(format-number((substring-before($weight, ' ') * 0.453592), '#.##'), ' kg')"/> - </xsl:otherwise> - </xsl:choose> - </xsl:attribute> - </weightsystem> - </xsl:if> - - </dive> - </xsl:if> + </dive> + </xsl:if> </xsl:template> <xsl:template name="getFieldByIndex"> |