<?xml version="1.0" encoding="UTF-8"?>
-<!-- $Id: marc21.xsl,v 1.19 2007-08-16 03:12:42 quinn Exp $ -->
<xsl:stylesheet
version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
<!-- Extract metadata from MARC21/USMARC
http://www.loc.gov/marc/bibliographic/ecbdhome.html
-->
+ <xsl:include href="pz2-ourl-marc21.xsl" />
<xsl:template match="/marc:record">
<xsl:variable name="title_medium" select="marc:datafield[@tag='245']/marc:subfield[@code='h']"/>
<xsl:value-of select="$medium"/>
</xsl:attribute>
+
<xsl:for-each select="marc:controlfield[@tag='001']">
<pz:metadata type="id">
<xsl:value-of select="."/>
<pz:metadata type="title-medium">
<xsl:value-of select="marc:subfield[@code='h']"/>
</pz:metadata>
+ <pz:metadata type="title-number-section">
+ <xsl:value-of select="marc:subfield[@code='n']"/>
+ </pz:metadata>
</xsl:for-each>
<xsl:for-each select="marc:datafield[@tag='250']">
</pz:metadata>
</xsl:for-each>
- <xsl:for-each select="marc:datafield[@tag >= 500 and @tag <= 599]
- [@tag != '506' and @tag != '530' and
- @tag != '540' and @tag != '546'
- and @tag != '522']">
+ <xsl:for-each select="marc:datafield[@tag = '500' or @tag = '505' or
+ @tag = '518' or @tag = '520' or @tag = '522']">
<pz:metadata type="description">
<xsl:value-of select="*/text()"/>
</pz:metadata>
</xsl:for-each>
- <xsl:for-each select="marc:datafield[@tag='650' or @tag='653']">
+ <xsl:for-each select="marc:datafield[@tag='600' or @tag='610' or @tag='611' or @tag='630' or @tag='648' or @tag='650' or @tag='651' or @tag='653' or @tag='654' or @tag='655' or @tag='656' or @tag='657' or @tag='658' or @tag='662' or @tag='69X']">
<pz:metadata type="subject">
<xsl:value-of select="marc:subfield[@code='a']"/>
</pz:metadata>
<xsl:value-of select="$medium"/>
</pz:metadata>
- <xsl:if test="$fulltext_a">
+ <xsl:for-each select="marc:datafield[@tag='900']/marc:subfield[@code='a']">
+ <pz:metadata type="fulltext">
+ <xsl:value-of select="."/>
+ </pz:metadata>
+ </xsl:for-each>
+
+ <!-- <xsl:if test="$fulltext_a">
<pz:metadata type="fulltext">
<xsl:value-of select="$fulltext_a"/>
</pz:metadata>
- </xsl:if>
+ </xsl:if> -->
+
+ <xsl:for-each select="marc:datafield[@tag='900']/marc:subfield[@code='b']">
+ <pz:metadata type="fulltext">
+ <xsl:value-of select="."/>
+ </pz:metadata>
+ </xsl:for-each>
- <xsl:if test="$fulltext_b">
+ <!-- <xsl:if test="$fulltext_b">
<pz:metadata type="fulltext">
<xsl:value-of select="$fulltext_b"/>
</pz:metadata>
+ </xsl:if> -->
+
+ <xsl:for-each select="marc:datafield[@tag='907']">
+ <pz:metadata type="iii-id">
+ <xsl:value-of select="marc:subfield[@code='a']"/>
+ </pz:metadata>
+ </xsl:for-each>
+
+ <xsl:for-each select="marc:datafield[@tag='926']">
+ <pz:metadata type="holding">
+ <xsl:for-each select="marc:subfield">
+ <xsl:if test="position() > 1">
+ <xsl:text> </xsl:text>
+ </xsl:if>
+ <xsl:value-of select="."/>
+ </xsl:for-each>
+ </pz:metadata>
+ </xsl:for-each>
+
+ <xsl:for-each select="marc:datafield[@tag='948']">
+ <pz:metadata type="holding">
+ <xsl:for-each select="marc:subfield">
+ <xsl:if test="position() > 1">
+ <xsl:text> </xsl:text>
+ </xsl:if>
+ <xsl:value-of select="."/>
+ </xsl:for-each>
+ </pz:metadata>
+ </xsl:for-each>
+
+ <xsl:for-each select="marc:datafield[@tag='991']">
+ <pz:metadata type="holding">
+ <xsl:for-each select="marc:subfield">
+ <xsl:if test="position() > 1">
+ <xsl:text> </xsl:text>
+ </xsl:if>
+ <xsl:value-of select="."/>
+ </xsl:for-each>
+ </pz:metadata>
+ </xsl:for-each>
+
+ <xsl:if test="$open_url_resolver">
+ <pz:metadata type="open-url">
+ <xsl:call-template name="insert-md-openurl" />
+ </pz:metadata>
</xsl:if>
- </pz:record>
+
+ </pz:record>
</xsl:template>
+
+ <xsl:template match="text()"/>
</xsl:stylesheet>