mirror of
https://github.com/subsurface/subsurface.git
synced 2024-12-11 03:21:29 +00:00
ee0bdd9043
Need to discard dive site notes on csv export.. miika From ab23245e2acee32410fa680d0eaab098af69b5c2 Mon Sep 17 00:00:00 2001 From: Miika Turkia <miika.turkia@gmail.com> Date: Mon, 21 Mar 2016 17:50:28 +0800 Subject: [PATCH] CSV export: discard dive site notes The new format of divesite management breaks the CSV export as the notes of divesites are matched. Signed-off-by: Miika Turkia <miika.turkia@gmail.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
315 lines
11 KiB
HTML
315 lines
11 KiB
HTML
<?xml version="1.0"?>
|
|
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
|
|
xmlns:xt="http://www.jclark.com/xt"
|
|
extension-element-prefixes="xt" version="1.0">
|
|
<xsl:strip-space elements="*"/>
|
|
<xsl:param name="units" select="units"/>
|
|
<xsl:output method="text" encoding="UTF-8"/>
|
|
|
|
<xsl:variable name="fs"><xsl:text> </xsl:text></xsl:variable>
|
|
<xsl:variable name="lf"><xsl:text>
|
|
</xsl:text></xsl:variable>
|
|
|
|
<xsl:template match="/divelog/dives">
|
|
<xsl:value-of select="concat('"dive number"', $fs, '"date"', $fs, '"time"', $fs, '"duration"', $fs, '"maxdepth"', $fs, '"avgdepth"', $fs, '"airtemp"', $fs, '"watertemp"', $fs, '"cylinder size"', $fs, '"startpressure"', $fs, '"endpressure"', $fs, '"o2"', $fs, '"he"', $fs, '"location"', $fs, '"gps"', $fs, '"divemaster"', $fs, '"buddy"', $fs, '"suit"', $fs, '"rating"', $fs, '"visibility"', $fs, '"notes"', $fs, '"weight"', $fs, '"tags"')"/>
|
|
<xsl:text>
|
|
</xsl:text>
|
|
<xsl:apply-templates select="dive|trip/dive"/>
|
|
</xsl:template>
|
|
|
|
<xsl:template match="divesites/site/notes"/>
|
|
|
|
<xsl:template match="dive">
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="@number"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="@date"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="@time"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="@duration"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:choose>
|
|
<xsl:when test="divecomputer[1]/depth/@mean|divecomputer[1]/depth/@max != ''">
|
|
<xsl:apply-templates select="divecomputer[1]/depth"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>""</xsl:text>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>""</xsl:text>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
<xsl:choose>
|
|
<xsl:when test="divetemperature/@air|divetemperature/@water != ''">
|
|
<xsl:apply-templates select="divetemperature"/>
|
|
</xsl:when>
|
|
<xsl:when test="divecomputer[1]/temperature/@air|divecomputer[1]/temperature/@water != ''">
|
|
<xsl:apply-templates select="divecomputer[1]/temperature"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<!-- empty air temperature -->
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>""</xsl:text>
|
|
<!-- water temperature -->
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>""</xsl:text>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
<xsl:choose>
|
|
<xsl:when test="cylinder[1]/@start|cylinder[1]/@end != ''">
|
|
<xsl:apply-templates select="cylinder[1]"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:choose>
|
|
<xsl:when test="$units = 1">
|
|
<xsl:value-of select="cylinder/@description"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="cylinder[1]/@size"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:choose>
|
|
<xsl:when test="$units = 1">
|
|
<xsl:value-of select="concat(format-number((substring-before(divecomputer[1]/sample[@pressure]/@pressure, ' ') * 14.5037738007), '#'), ' psi')"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="divecomputer[1]/sample[@pressure]/@pressure"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:choose>
|
|
<xsl:when test="$units = 1">
|
|
<xsl:value-of select="concat(format-number((substring-before(divecomputer[1]/sample[@pressure][last()]/@pressure, ' ') * 14.5037738007), '#'), ' psi')"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="divecomputer[1]/sample[@pressure][last()]/@pressure"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="cylinder[1]/@o2"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="cylinder[1]/@he"/>
|
|
<xsl:text>"</xsl:text>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
<xsl:choose>
|
|
<!-- Old location format -->
|
|
<xsl:when test="location != ''">
|
|
<xsl:apply-templates select="location"/>
|
|
<xsl:if test="string-length(location) = 0">
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>""</xsl:text>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>""</xsl:text>
|
|
</xsl:if>
|
|
</xsl:when>
|
|
<!-- Format with dive site managemenet -->
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:if test="string-length(@divesiteid) > 0">
|
|
<xsl:variable name="uuid">
|
|
<xsl:value-of select="@divesiteid" />
|
|
</xsl:variable>
|
|
<xsl:value-of select="//divesites/site[@uuid = $uuid]/@name"/>
|
|
</xsl:if>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:if test="string-length(@divesiteid) > 0">
|
|
<xsl:variable name="uuid">
|
|
<xsl:value-of select="@divesiteid" />
|
|
</xsl:variable>
|
|
<xsl:value-of select="//divesites/site[@uuid = $uuid]/@gps"/>
|
|
</xsl:if>
|
|
<xsl:text>"</xsl:text>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
<xsl:apply-templates select="divemaster"/>
|
|
<xsl:if test="string-length(divemaster) = 0">
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>""</xsl:text>
|
|
</xsl:if>
|
|
<xsl:apply-templates select="buddy"/>
|
|
<xsl:if test="string-length(buddy) = 0">
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>""</xsl:text>
|
|
</xsl:if>
|
|
<xsl:apply-templates select="suit"/>
|
|
<xsl:if test="string-length(suit) = 0">
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>""</xsl:text>
|
|
</xsl:if>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="@rating"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="@visibility"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:apply-templates select="notes"/>
|
|
<xsl:if test="string-length(notes) = 0">
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>""</xsl:text>
|
|
</xsl:if>
|
|
|
|
<xsl:variable name="trimmedweightlist">
|
|
<xsl:for-each select="weightsystem">
|
|
<weight>
|
|
<xsl:value-of select="substring-before(@weight, ' ')"/>
|
|
</weight>
|
|
</xsl:for-each>
|
|
</xsl:variable>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:if test="weightsystem">
|
|
<xsl:value-of select="concat(sum(xt:node-set($trimmedweightlist)/node()), ' kg')"/>
|
|
</xsl:if>
|
|
<xsl:text>"</xsl:text>
|
|
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="@tags"/>
|
|
<xsl:text>"</xsl:text>
|
|
|
|
<xsl:text>
|
|
</xsl:text>
|
|
</xsl:template>
|
|
<xsl:template match="divecomputer/depth">
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:choose>
|
|
<xsl:when test="$units = 1">
|
|
<xsl:value-of select="concat(format-number((substring-before(@max, ' ') div 0.3048), '#.#'), ' ft')"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="@max"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:choose>
|
|
<xsl:when test="$units = 1">
|
|
<xsl:value-of select="concat(format-number((substring-before(@mean, ' ') div 0.3048), '#.#'), ' ft')"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="@mean"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
<xsl:text>"</xsl:text>
|
|
</xsl:template>
|
|
<xsl:template match="divetemperature|temperature">
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:choose>
|
|
<xsl:when test="$units = 1">
|
|
<xsl:value-of select="concat(format-number((substring-before(@air, ' ') * 1.8) + 32, '0.0'), ' F')"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="@air"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:choose>
|
|
<xsl:when test="$units = 1">
|
|
<xsl:value-of select="concat(format-number((substring-before(@water, ' ') * 1.8) + 32, '0.0'), ' F')"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="@water"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
<xsl:text>"</xsl:text>
|
|
</xsl:template>
|
|
<xsl:template match="cylinder">
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="@size"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:choose>
|
|
<xsl:when test="$units = 1">
|
|
<xsl:value-of select="concat(format-number((substring-before(@start, ' ') * 14.5037738007), '#'), ' psi')"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="@start"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:choose>
|
|
<xsl:when test="$units = 1">
|
|
<xsl:value-of select="concat(format-number((substring-before(@end, ' ') * 14.5037738007), '#'), ' psi')"/>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<xsl:value-of select="@end"/>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="@o2"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="@he"/>
|
|
<xsl:text>"</xsl:text>
|
|
</xsl:template>
|
|
<xsl:template match="location">
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="."/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="@gps"/>
|
|
<xsl:text>"</xsl:text>
|
|
</xsl:template>
|
|
<xsl:template match="divemaster">
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="."/>
|
|
<xsl:text>"</xsl:text>
|
|
</xsl:template>
|
|
<xsl:template match="buddy">
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="."/>
|
|
<xsl:text>"</xsl:text>
|
|
</xsl:template>
|
|
<xsl:template match="suit">
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="."/>
|
|
<xsl:text>"</xsl:text>
|
|
</xsl:template>
|
|
<xsl:template match="notes">
|
|
<xsl:value-of select="$fs"/>
|
|
<xsl:text>"</xsl:text>
|
|
<xsl:value-of select="translate(translate(., $fs, ' '), $lf, ' ')"/>
|
|
<xsl:text>"</xsl:text>
|
|
</xsl:template>
|
|
</xsl:stylesheet>
|