Compare commits

..

No commits in common. "73e749160c25a4b2c83a27fb161129aa71929c8c" and "1450d9eaae82015057515773e08939e20fc6cf38" have entirely different histories.

8 changed files with 220 additions and 500 deletions

View File

@ -1,6 +1,6 @@
MIT License MIT License
Copyright (c) 2022-2023 museum-digital Copyright (c) 2022
Permission is hereby granted, free of charge, to any person obtaining a copy Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal of this software and associated documentation files (the "Software"), to deal

View File

@ -3,30 +3,14 @@
## Formats covered thus far ## Formats covered thus far
- `LIDO 1.0` - `LIDO 1.0`
(Primary exchange export format). See <https://lido-schema.org> (Primary exchange export format)
- LIDO 1.1
Updated version of the LIDO standard, as of 2022. See <https://lido-schema.org>
- EODEM
A LIDO profile (based on LIDO 1.1) specifically designed for the automation of the exchange of loan object information. Contrary to LIDO, it thus also covers some internal fields. See: <https://cidoc.mini.icom.museum/working-groups/documentation-standards/eodem-home/>
## Repository structure ## Repository structure
### [/src](./src) ### /src
Contains the relevant .xsl files used for converting md:xml to other formats. Contains the relevant .xsl files used for converting md:xml to other formats.
#### [/src/schemas](./src/schemas) ### /sample
This directory contains schemas for validating the different formats.
#### [/src/selections](./src/selections)
This directory contains JSON files listing which bits and pieces should be made available during an export from musdb when exporting to a given format. E.g., LIDO cannot represent internal information like insurance values. It thus does not make sense to export such information during the export to md:xml pre-transformation in the first place.
### [/sample](./sample)
Here you can find sample mx:xml files. Here you can find sample mx:xml files.
## License
This project is licensed under the MIT License. See the [LICENSE](./LICENSE) file for the full license text.

View File

@ -34,64 +34,6 @@
</xsl:if> </xsl:if>
<lido:objectClassificationWrap> <lido:objectClassificationWrap>
<lido:objectWorkTypeWrap> <lido:objectWorkTypeWrap>
<xsl:choose>
<xsl:when test="
tagSet[0]/relation_type[. = 'object_type']
| tagSet[1]/relation_type[. = 'object_type']
| tagSet[2]/relation_type[. = 'object_type']
| tagSet[3]/relation_type[. = 'object_type']
| tagSet[4]/relation_type[. = 'object_type']
| tagSet[5]/relation_type[. = 'object_type']
| tagSet[6]/relation_type[. = 'object_type']
| tagSet[7]/relation_type[. = 'object_type']
| tagSet[8]/relation_type[. = 'object_type']
| tagSet[9]/relation_type[. = 'object_type']
| tagSet[10]/relation_type[. = 'object_type']
| tagSet[11]/relation_type[. = 'object_type']
| tagSet[12]/relation_type[. = 'object_type']
| tagSet[13]/relation_type[. = 'object_type']
| tagSet[14]/relation_type[. = 'object_type']
| tagSet[15]/relation_type[. = 'object_type']
| tagSet[16]/relation_type[. = 'object_type']
| tagSet[17]/relation_type[. = 'object_type']
| tagSet[18]/relation_type[. = 'object_type']
">
<!-- objectWorkType exists via tags -->
<xsl:for-each select="tagSet/tag_id">
<xsl:if test="../relation_type = 'object_type'">
<lido:objectWorkType>
<xsl:for-each select="../noda_tag_Set/noda_source">
<xsl:if test="string-length(../noda_link)!=0">
<lido:conceptID>
<xsl:attribute name="lido:source">
<xsl:value-of select="../noda_source"/>
</xsl:attribute>
<xsl:attribute name="lido:type">uri</xsl:attribute>
<xsl:value-of select="../noda_link"/>
</lido:conceptID>
</xsl:if>
</xsl:for-each>
<xsl:for-each select="../tag_name">
<lido:term>
<xsl:attribute name="lido:addedSearchTerm">no</xsl:attribute>
<xsl:if test="string-length(./@lang)!=0">
<xsl:attribute name="xml:lang">
<xsl:value-of select="./@lang"/>
</xsl:attribute>
</xsl:if>
<xsl:value-of select="."/>
<xsl:variable name="objektartschlagwort" select="." />
</lido:term>
</xsl:for-each>
</lido:objectWorkType>
</xsl:if>
</xsl:for-each>
</xsl:when>
<xsl:otherwise>
<lido:objectWorkType> <lido:objectWorkType>
<xsl:for-each select="objektart_gnd"> <xsl:for-each select="objektart_gnd">
<lido:conceptID> <lido:conceptID>
@ -156,11 +98,6 @@
</xsl:for-each> </xsl:for-each>
</xsl:if> </xsl:if>
</lido:objectWorkType> </lido:objectWorkType>
</xsl:otherwise>
</xsl:choose>
</lido:objectWorkTypeWrap> </lido:objectWorkTypeWrap>
<lido:classificationWrap> <lido:classificationWrap>
<xsl:for-each select="collectionSet"> <xsl:for-each select="collectionSet">

View File

@ -33,64 +33,6 @@
</xsl:if> </xsl:if>
<lido:objectClassificationWrap> <lido:objectClassificationWrap>
<lido:objectWorkTypeWrap> <lido:objectWorkTypeWrap>
<xsl:choose>
<xsl:when test="
tagSet[0]/relation_type[. = 'object_type']
| tagSet[1]/relation_type[. = 'object_type']
| tagSet[2]/relation_type[. = 'object_type']
| tagSet[3]/relation_type[. = 'object_type']
| tagSet[4]/relation_type[. = 'object_type']
| tagSet[5]/relation_type[. = 'object_type']
| tagSet[6]/relation_type[. = 'object_type']
| tagSet[7]/relation_type[. = 'object_type']
| tagSet[8]/relation_type[. = 'object_type']
| tagSet[9]/relation_type[. = 'object_type']
| tagSet[10]/relation_type[. = 'object_type']
| tagSet[11]/relation_type[. = 'object_type']
| tagSet[12]/relation_type[. = 'object_type']
| tagSet[13]/relation_type[. = 'object_type']
| tagSet[14]/relation_type[. = 'object_type']
| tagSet[15]/relation_type[. = 'object_type']
| tagSet[16]/relation_type[. = 'object_type']
| tagSet[17]/relation_type[. = 'object_type']
| tagSet[18]/relation_type[. = 'object_type']
">
<!-- objectWorkType exists via tags -->
<xsl:for-each select="tagSet/tag_id">
<xsl:if test="../relation_type = 'object_type'">
<lido:objectWorkType>
<xsl:for-each select="../noda_tag_Set/noda_source">
<xsl:if test="string-length(../noda_link)!=0">
<lido:conceptID>
<xsl:attribute name="lido:source">
<xsl:value-of select="../noda_source"/>
</xsl:attribute>
<xsl:attribute name="lido:type">uri</xsl:attribute>
<xsl:value-of select="../noda_link"/>
</lido:conceptID>
</xsl:if>
</xsl:for-each>
<xsl:for-each select="../tag_name">
<lido:term>
<xsl:attribute name="lido:addedSearchTerm">no</xsl:attribute>
<xsl:if test="string-length(./@lang)!=0">
<xsl:attribute name="xml:lang">
<xsl:value-of select="./@lang"/>
</xsl:attribute>
</xsl:if>
<xsl:value-of select="."/>
<xsl:variable name="objektartschlagwort" select="." />
</lido:term>
</xsl:for-each>
</lido:objectWorkType>
</xsl:if>
</xsl:for-each>
</xsl:when>
<xsl:otherwise>
<lido:objectWorkType> <lido:objectWorkType>
<xsl:for-each select="objektart_gnd"> <xsl:for-each select="objektart_gnd">
<lido:conceptID> <lido:conceptID>
@ -155,11 +97,6 @@
</xsl:for-each> </xsl:for-each>
</xsl:if> </xsl:if>
</lido:objectWorkType> </lido:objectWorkType>
</xsl:otherwise>
</xsl:choose>
</lido:objectWorkTypeWrap> </lido:objectWorkTypeWrap>
<lido:classificationWrap> <lido:classificationWrap>
<xsl:for-each select="collectionSet"> <xsl:for-each select="collectionSet">
@ -925,43 +862,6 @@
</lido:materialsTech> </lido:materialsTech>
</lido:eventMaterialsTech> </lido:eventMaterialsTech>
</xsl:if> </xsl:if>
<xsl:for-each select="tagSet/tag_id">
<xsl:if test="../relation_type = 'material'">
<lido:eventMaterialsTech>
<lido:materialsTech>
<lido:termMaterialsTech lido:type="material">
<xsl:for-each select="../noda_tag_Set/noda_source">
<xsl:if test="string-length(../noda_link)!=0">
<lido:conceptID>
<xsl:attribute name="lido:source">
<xsl:value-of select="../noda_source"/>
</xsl:attribute>
<xsl:attribute name="lido:type">uri</xsl:attribute>
<xsl:value-of select="../noda_link"/>
</lido:conceptID>
</xsl:if>
</xsl:for-each>
<xsl:for-each select="../tag_name">
<lido:term>
<xsl:attribute name="lido:addedSearchTerm">no</xsl:attribute>
<xsl:if test="string-length(./@lang)!=0">
<xsl:attribute name="xml:lang">
<xsl:value-of select="./@lang"/>
</xsl:attribute>
</xsl:if>
<xsl:value-of select="."/>
</lido:term>
</xsl:for-each>
</lido:termMaterialsTech>
</lido:materialsTech>
</lido:eventMaterialsTech>
</xsl:if>
</xsl:for-each>
<xsl:if test="technik2!=''"> <xsl:if test="technik2!=''">
<lido:eventMaterialsTech> <lido:eventMaterialsTech>
<lido:materialsTech> <lido:materialsTech>
@ -973,40 +873,6 @@
</lido:materialsTech> </lido:materialsTech>
</lido:eventMaterialsTech> </lido:eventMaterialsTech>
</xsl:if> </xsl:if>
<xsl:for-each select="tagSet/tag_id">
<xsl:if test="../relation_type = 'technique'">
<lido:eventMaterialsTech>
<lido:materialsTech>
<lido:termMaterialsTech lido:type="technique">
<xsl:for-each select="../noda_tag_Set/noda_source">
<xsl:if test="string-length(../noda_link)!=0">
<lido:conceptID>
<xsl:attribute name="lido:source">
<xsl:value-of select="../noda_source"/>
</xsl:attribute>
<xsl:attribute name="lido:type">uri</xsl:attribute>
<xsl:value-of select="../noda_link"/>
</lido:conceptID>
</xsl:if>
</xsl:for-each>
<xsl:for-each select="../tag_name">
<lido:term>
<xsl:attribute name="lido:addedSearchTerm">no</xsl:attribute>
<xsl:if test="string-length(./@lang)!=0">
<xsl:attribute name="xml:lang">
<xsl:value-of select="./@lang"/>
</xsl:attribute>
</xsl:if>
<xsl:value-of select="."/>
</lido:term>
</xsl:for-each>
</lido:termMaterialsTech>
</lido:materialsTech>
</lido:eventMaterialsTech>
</xsl:if>
</xsl:for-each>
</lido:event> </lido:event>
</lido:eventSet> </lido:eventSet>
</xsl:if> </xsl:if>
@ -1325,7 +1191,6 @@
</xsl:if> </xsl:if>
<xsl:for-each select="tagSet/tag_id"> <xsl:for-each select="tagSet/tag_id">
<xsl:if test="(../relation_type != 'object_type') and (../relation_type != 'material') and (../relation_type != 'technique')">
<lido:subjectSet> <lido:subjectSet>
<lido:subject> <lido:subject>
<lido:subjectConcept> <lido:subjectConcept>
@ -1354,11 +1219,11 @@
</lido:subjectConcept> </lido:subjectConcept>
</lido:subject> </lido:subject>
</lido:subjectSet> </lido:subjectSet>
</xsl:if>
</xsl:for-each> </xsl:for-each>
</lido:subjectWrap> </lido:subjectWrap>
<lido:relatedWorksWrap> <lido:relatedWorksWrap>
<xsl:for-each select="vergleichsobjekte2"> <xsl:for-each select="vergleichsobjekte2">
<lido:relatedWorkSet> <lido:relatedWorkSet>
<lido:relatedWork> <lido:relatedWork>
@ -1893,7 +1758,7 @@
</xsl:for-each> </xsl:for-each>
</lido:resourceRepresentation> </lido:resourceRepresentation>
<lido:resourceRepresentation> <lido:resourceRepresentation>
<xsl:attribute name="lido:type">provided_text</xsl:attribute> <xsl:attribute name="lido:type">text</xsl:attribute>
<xsl:for-each select="../resource_location"> <xsl:for-each select="../resource_location">
<xsl:if test="position() = 1"> <xsl:if test="position() = 1">
<lido:linkResource> <lido:linkResource>

View File

@ -33,64 +33,6 @@
</xsl:if> </xsl:if>
<lido:objectClassificationWrap> <lido:objectClassificationWrap>
<lido:objectWorkTypeWrap> <lido:objectWorkTypeWrap>
<xsl:choose>
<xsl:when test="
tagSet[0]/relation_type[. = 'object_type']
| tagSet[1]/relation_type[. = 'object_type']
| tagSet[2]/relation_type[. = 'object_type']
| tagSet[3]/relation_type[. = 'object_type']
| tagSet[4]/relation_type[. = 'object_type']
| tagSet[5]/relation_type[. = 'object_type']
| tagSet[6]/relation_type[. = 'object_type']
| tagSet[7]/relation_type[. = 'object_type']
| tagSet[8]/relation_type[. = 'object_type']
| tagSet[9]/relation_type[. = 'object_type']
| tagSet[10]/relation_type[. = 'object_type']
| tagSet[11]/relation_type[. = 'object_type']
| tagSet[12]/relation_type[. = 'object_type']
| tagSet[13]/relation_type[. = 'object_type']
| tagSet[14]/relation_type[. = 'object_type']
| tagSet[15]/relation_type[. = 'object_type']
| tagSet[16]/relation_type[. = 'object_type']
| tagSet[17]/relation_type[. = 'object_type']
| tagSet[18]/relation_type[. = 'object_type']
">
<!-- objectWorkType exists via tags -->
<xsl:for-each select="tagSet/tag_id">
<xsl:if test="../relation_type = 'object_type'">
<lido:objectWorkType>
<xsl:for-each select="../noda_tag_Set/noda_source">
<xsl:if test="string-length(../noda_link)!=0">
<lido:conceptID>
<xsl:attribute name="lido:source">
<xsl:value-of select="../noda_source"/>
</xsl:attribute>
<xsl:attribute name="lido:type">uri</xsl:attribute>
<xsl:value-of select="../noda_link"/>
</lido:conceptID>
</xsl:if>
</xsl:for-each>
<xsl:for-each select="../tag_name">
<lido:term>
<xsl:attribute name="lido:addedSearchTerm">no</xsl:attribute>
<xsl:if test="string-length(./@lang)!=0">
<xsl:attribute name="xml:lang">
<xsl:value-of select="./@lang"/>
</xsl:attribute>
</xsl:if>
<xsl:value-of select="."/>
<xsl:variable name="objektartschlagwort" select="." />
</lido:term>
</xsl:for-each>
</lido:objectWorkType>
</xsl:if>
</xsl:for-each>
</xsl:when>
<xsl:otherwise>
<lido:objectWorkType> <lido:objectWorkType>
<xsl:for-each select="objektart_gnd"> <xsl:for-each select="objektart_gnd">
<lido:conceptID> <lido:conceptID>
@ -155,11 +97,6 @@
</xsl:for-each> </xsl:for-each>
</xsl:if> </xsl:if>
</lido:objectWorkType> </lido:objectWorkType>
</xsl:otherwise>
</xsl:choose>
</lido:objectWorkTypeWrap> </lido:objectWorkTypeWrap>
<lido:classificationWrap> <lido:classificationWrap>
<xsl:for-each select="collectionSet"> <xsl:for-each select="collectionSet">

View File

@ -9,7 +9,6 @@
"show_markings": true, "show_markings": true,
"show_transcripts": true, "show_transcripts": true,
"show_links": true, "show_links": true,
"show_object_to_object_links": true,
"show_images": true, "show_images": true,
"show_hidden_images": false, "show_hidden_images": false,
"show_objekt_inventarnr": true, "show_objekt_inventarnr": true,

View File

@ -9,7 +9,6 @@
"show_markings": true, "show_markings": true,
"show_transcripts": true, "show_transcripts": true,
"show_links": true, "show_links": true,
"show_object_to_object_links": true,
"show_images": true, "show_images": true,
"show_hidden_images": false, "show_hidden_images": false,
"show_objekt_inventarnr": true, "show_objekt_inventarnr": true,

View File

@ -9,7 +9,6 @@
"show_markings": true, "show_markings": true,
"show_transcripts": true, "show_transcripts": true,
"show_links": true, "show_links": true,
"show_object_to_object_links": true,
"show_images": true, "show_images": true,
"show_hidden_images": false, "show_hidden_images": false,
"show_objekt_inventarnr": true, "show_objekt_inventarnr": true,