Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[#2] Updated contributors mapping #7

Open
wants to merge 1 commit into
base: main
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
27 changes: 21 additions & 6 deletions transformations/abcd2bioschemas/abcd2bioschemas-xml.xslt
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ exclude-result-prefixes="xsl md panxslt set">
<xsl:variable name="dataset_version_issued" select="/abcd:DataSets/abcd:DataSet/abcd:Metadata/abcd:Version/abcd:DateIssued"></xsl:variable>
<xsl:variable name="dataset_direct_access" select="/abcd:DataSets/abcd:DataSet/abcd:Metadata/abcd:DirectAccessURI"></xsl:variable>
<xsl:variable name="ipr_statement" select="/abcd:DataSets/abcd:DataSet/abcd:Metadata/abcd:IPRStatements/abcd:Citations/abcd:Citation/abcd:Text"></xsl:variable>
<!-- TODO: dataset_uri is probably redundant to dataset_url and can be removed -->
<xsl:variable name="dataset_uri" select="/abcd:DataSets/abcd:DataSet/abcd:Metadata/abcd:Description/abcd:Representation/abcd:URI"></xsl:variable>
<xsl:variable name="terms_of_use" select="/abcd:DataSets/abcd:DataSet/abcd:Metadata/abcd:IPRStatements/abcd:TermsOfUseStatements/abcd:TermsOfUse"></xsl:variable>
<xsl:variable name="licence" select="/abcd:DataSets/abcd:DataSet/abcd:Metadata/abcd:IPRStatements/abcd:Licenses/abcd:License"></xsl:variable>
Expand All @@ -43,6 +44,7 @@ exclude-result-prefixes="xsl md panxslt set">
<xsl:variable name="taxon_name" select="/abcd:DataSets/abcd:DataSet/abcd:Units/abcd:Unit/abcd:Identifications/abcd:Identification/abcd:Result/abcd:TaxonIdentified/abcd:ScientificName/abcd:FullScientificNameString"></xsl:variable>
<xsl:variable name="higher_taxon" select="/abcd:DataSets/abcd:DataSet/abcd:Units/abcd:Unit/abcd:Identifications/abcd:Identification/abcd:Result/abcd:TaxonIdentified/abcd:HigherTaxa/abcd:HigherTaxon/abcd:HigherTaxonName"></xsl:variable>

<xsl:variable name="gathering_agents" select="/abcd:DataSets/abcd:DataSet/abcd:Units/abcd:Unit/abcd:Gathering/abcd:GatheringAgents/abcd:GatheringAgent"></xsl:variable>



Expand Down Expand Up @@ -92,6 +94,7 @@ exclude-result-prefixes="xsl md panxslt set">
<xsl:if test="$dataset_version_major">
<version>
<xsl:value-of select="$dataset_version_major" />
<!-- TODO: Check if dataset_version_minor's value should be selected here instead -->
<xsl:if test="$dataset_version_minor"><xsl:text>.</xsl:text><xsl:value-of select="$dataset_version_major" />
<xsl:if test="$dataset_version_modifier"><xsl:text>.</xsl:text><xsl:value-of select="$dataset_version_modifier" />
</xsl:if>
Expand All @@ -110,6 +113,7 @@ exclude-result-prefixes="xsl md panxslt set">
<xsl:if test="./abcd:URI">
<url><xsl:value-of select="./abcd:URI"/></url>
</xsl:if>
<!-- TODO: Check if this variable is really necessary -->
<xsl:if test="./abcd:URL">
<url><xsl:value-of select="./abcd:URL"/></url>
</xsl:if>
Expand Down Expand Up @@ -343,7 +347,7 @@ exclude-result-prefixes="xsl md panxslt set">
<identifier><xsl:value-of select="."/></identifier>
</xsl:for-each>
</xsl:if>

<!-- name -->
<name><xsl:value-of select="./abcd:Organisation/abcd:Name/abcd:Representation/abcd:Text"/></name>
<xsl:if test="./abcd:Organisation/abcd:Name/abcd:Representation/abcd:Abbreviation">
Expand All @@ -361,7 +365,7 @@ exclude-result-prefixes="xsl md panxslt set">
</xsl:for-each>
</xsl:otherwise>
</xsl:choose>

<!-- phone -->
<xsl:choose>
<xsl:when test="./abcd:TelephoneNumbers/abcd:TelephoneNumber[@preferred='true']">
Expand Down Expand Up @@ -406,10 +410,21 @@ exclude-result-prefixes="xsl md panxslt set">
</maintainer>
</xsl:for-each>
<xsl:if test="$dataset_contributors">
<!-- TODO, slit string by comma and repeat element -->
<contributor type="Person">
<name><xsl:value-of select="$dataset_contributors"/></name>
</contributor>
<xsl:choose>
<xsl:when test="contains($dataset_contributors,',')">
<xsl:variable name="contributors" select="tokenize($dataset_contributors,',')"/>
<xsl:for-each select="$contributors">
<contributor type="Person">
<name><xsl:value-of select="."/></name>
</contributor>
</xsl:for-each>
</xsl:when>
<xsl:otherwise>
<contributor type="Person">
<name><xsl:value-of select="$dataset_contributors"/></name>
</contributor>
</xsl:otherwise>
</xsl:choose>
</xsl:if>
<!-- TODO:
- Gathering Agents as contributors?
Expand Down