@natlibfi/marc-record-validators-melinda 11.0.0 → 11.1.0-alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/addMissingField336.js +272 -0
- package/dist/addMissingField336.js.map +1 -0
- package/dist/addMissingField336.spec.js +45 -0
- package/dist/addMissingField336.spec.js.map +1 -0
- package/dist/addMissingField337.js +177 -0
- package/dist/addMissingField337.js.map +1 -0
- package/dist/addMissingField337.spec.js +43 -0
- package/dist/addMissingField337.spec.js.map +1 -0
- package/dist/addMissingField338.js +424 -0
- package/dist/addMissingField338.js.map +1 -0
- package/dist/addMissingField338.spec.js +45 -0
- package/dist/addMissingField338.spec.js.map +1 -0
- package/dist/cyrillux-usemarcon-replacement.js +370 -0
- package/dist/cyrillux-usemarcon-replacement.js.map +1 -0
- package/dist/cyrillux-usemarcon-replacement.spec.js +45 -0
- package/dist/cyrillux-usemarcon-replacement.spec.js.map +1 -0
- package/dist/field33XUtils.js +529 -0
- package/dist/field33XUtils.js.map +1 -0
- package/dist/fix-33X.js +484 -0
- package/dist/fix-33X.js.map +1 -0
- package/dist/fix-33X.spec.js +45 -0
- package/dist/fix-33X.spec.js.map +1 -0
- package/dist/fix-language-codes.js +109 -0
- package/dist/fix-language-codes.js.map +1 -0
- package/dist/fix-language-codes.spec.js +44 -0
- package/dist/fix-language-codes.spec.js.map +1 -0
- package/dist/fixRelatorTerms.js +1 -1
- package/dist/fixRelatorTerms.js.map +1 -1
- package/dist/punctuation2.js +4 -3
- package/dist/punctuation2.js.map +1 -1
- package/dist/resolvable-ext-references-melinda.spec.js +1 -1
- package/dist/resolvable-ext-references-melinda.spec.js.map +1 -1
- package/dist/sanitize-vocabulary-source-codes.js +7 -10
- package/dist/sanitize-vocabulary-source-codes.js.map +1 -1
- package/dist/utils.js +13 -8
- package/dist/utils.js.map +1 -1
- package/package.json +7 -7
- package/src/addMissingField336.js +260 -0
- package/src/addMissingField336.spec.js +46 -0
- package/src/addMissingField337.js +132 -0
- package/src/addMissingField337.spec.js +45 -0
- package/src/addMissingField338.js +446 -0
- package/src/addMissingField338.spec.js +46 -0
- package/src/cyrillux-usemarcon-replacement.js +410 -0
- package/src/cyrillux-usemarcon-replacement.spec.js +47 -0
- package/src/field33XUtils.js +156 -0
- package/src/fix-33X.js +473 -0
- package/src/fix-33X.spec.js +46 -0
- package/src/fix-language-codes.js +121 -0
- package/src/fix-language-codes.spec.js +45 -0
- package/src/fixRelatorTerms.js +1 -1
- package/src/punctuation2.js +3 -3
- package/src/sanitize-vocabulary-source-codes.js +9 -11
- package/src/utils.js +13 -8
- package/test-fixtures/addMissingField336/01/expectedResult.json +6 -0
- package/test-fixtures/addMissingField336/01/metadata.json +7 -0
- package/test-fixtures/addMissingField336/01/record.json +8 -0
- package/test-fixtures/addMissingField336/02/expectedResult.json +4 -0
- package/test-fixtures/addMissingField336/02/metadata.json +7 -0
- package/test-fixtures/addMissingField336/02/record.json +13 -0
- package/test-fixtures/addMissingField336/cod/expectedResult.json +12 -0
- package/test-fixtures/addMissingField336/cod/metadata.json +6 -0
- package/test-fixtures/addMissingField336/cod/record.json +6 -0
- package/test-fixtures/addMissingField336/cop/expectedResult.json +12 -0
- package/test-fixtures/addMissingField336/cop/metadata.json +6 -0
- package/test-fixtures/addMissingField336/cop/record.json +6 -0
- package/test-fixtures/addMissingField336/cop2/expectedResult.json +13 -0
- package/test-fixtures/addMissingField336/cop2/metadata.json +6 -0
- package/test-fixtures/addMissingField336/cop2/record.json +7 -0
- package/test-fixtures/addMissingField336/crf/expectedResult.json +12 -0
- package/test-fixtures/addMissingField336/crf/metadata.json +6 -0
- package/test-fixtures/addMissingField336/crf/record.json +6 -0
- package/test-fixtures/addMissingField336/cri/expectedResult.json +12 -0
- package/test-fixtures/addMissingField336/cri/metadata.json +6 -0
- package/test-fixtures/addMissingField336/cri/record.json +6 -0
- package/test-fixtures/addMissingField336/crt/expectedResult.json +13 -0
- package/test-fixtures/addMissingField336/crt/metadata.json +6 -0
- package/test-fixtures/addMissingField336/crt/record.json +7 -0
- package/test-fixtures/addMissingField336/f01/expectedResult.json +17 -0
- package/test-fixtures/addMissingField336/f01/metadata.json +6 -0
- package/test-fixtures/addMissingField336/f01/record.json +11 -0
- package/test-fixtures/addMissingField336/f02/expectedResult.json +15 -0
- package/test-fixtures/addMissingField336/f02/metadata.json +6 -0
- package/test-fixtures/addMissingField336/f02/record.json +9 -0
- package/test-fixtures/addMissingField336/mixed2txt/expectedResult.json +12 -0
- package/test-fixtures/addMissingField336/mixed2txt/metadata.json +6 -0
- package/test-fixtures/addMissingField336/mixed2txt/record.json +6 -0
- package/test-fixtures/addMissingField336/mixed2xxx/expectedResult.json +12 -0
- package/test-fixtures/addMissingField336/mixed2xxx/metadata.json +6 -0
- package/test-fixtures/addMissingField336/mixed2xxx/record.json +6 -0
- package/test-fixtures/addMissingField336/ntm/expectedResult.json +12 -0
- package/test-fixtures/addMissingField336/ntm/metadata.json +6 -0
- package/test-fixtures/addMissingField336/ntm/record.json +6 -0
- package/test-fixtures/addMissingField336/snd/expectedResult.json +12 -0
- package/test-fixtures/addMissingField336/snd/metadata.json +6 -0
- package/test-fixtures/addMissingField336/snd/record.json +6 -0
- package/test-fixtures/addMissingField336/spw/expectedResult.json +12 -0
- package/test-fixtures/addMissingField336/spw/metadata.json +6 -0
- package/test-fixtures/addMissingField336/spw/record.json +6 -0
- package/test-fixtures/addMissingField336/spw2/expectedResult.json +13 -0
- package/test-fixtures/addMissingField336/spw2/metadata.json +6 -0
- package/test-fixtures/addMissingField336/spw2/record.json +7 -0
- package/test-fixtures/addMissingField336/spw_txt/expectedResult.json +18 -0
- package/test-fixtures/addMissingField336/spw_txt/metadata.json +6 -0
- package/test-fixtures/addMissingField336/spw_txt/record.json +7 -0
- package/test-fixtures/addMissingField336/sti/expectedResult.json +12 -0
- package/test-fixtures/addMissingField336/sti/metadata.json +6 -0
- package/test-fixtures/addMissingField336/sti/record.json +6 -0
- package/test-fixtures/addMissingField336/sti_projected/expectedResult.json +13 -0
- package/test-fixtures/addMissingField336/sti_projected/metadata.json +6 -0
- package/test-fixtures/addMissingField336/sti_projected/record.json +7 -0
- package/test-fixtures/addMissingField336/tci/expectedResult.json +12 -0
- package/test-fixtures/addMissingField336/tci/metadata.json +6 -0
- package/test-fixtures/addMissingField336/tci/record.json +6 -0
- package/test-fixtures/addMissingField336/tcm/expectedResult.json +12 -0
- package/test-fixtures/addMissingField336/tcm/metadata.json +6 -0
- package/test-fixtures/addMissingField336/tcm/record.json +6 -0
- package/test-fixtures/addMissingField336/tdf/expectedResult.json +12 -0
- package/test-fixtures/addMissingField336/tdf/metadata.json +6 -0
- package/test-fixtures/addMissingField336/tdf/record.json +6 -0
- package/test-fixtures/addMissingField336/tdi/expectedResult.json +13 -0
- package/test-fixtures/addMissingField336/tdi/metadata.json +6 -0
- package/test-fixtures/addMissingField336/tdi/record.json +7 -0
- package/test-fixtures/addMissingField336/txt/expectedResult.json +12 -0
- package/test-fixtures/addMissingField336/txt/metadata.json +6 -0
- package/test-fixtures/addMissingField336/txt/record.json +6 -0
- package/test-fixtures/addMissingField336/zzz/expectedResult.json +13 -0
- package/test-fixtures/addMissingField336/zzz/metadata.json +6 -0
- package/test-fixtures/addMissingField336/zzz/record.json +7 -0
- package/test-fixtures/addMissingField337/c1/expectedResult.json +12 -0
- package/test-fixtures/addMissingField337/c1/metadata.json +6 -0
- package/test-fixtures/addMissingField337/c1/record.json +7 -0
- package/test-fixtures/addMissingField337/g1/expectedResult.json +13 -0
- package/test-fixtures/addMissingField337/g1/metadata.json +6 -0
- package/test-fixtures/addMissingField337/g1/record.json +7 -0
- package/test-fixtures/addMissingField337/n1/expectedResult.json +12 -0
- package/test-fixtures/addMissingField337/n1/metadata.json +6 -0
- package/test-fixtures/addMissingField337/n1/record.json +6 -0
- package/test-fixtures/addMissingField337/no_action_required/expectedResult.json +12 -0
- package/test-fixtures/addMissingField337/no_action_required/metadata.json +7 -0
- package/test-fixtures/addMissingField337/no_action_required/record.json +11 -0
- package/test-fixtures/addMissingField337/p1/expectedResult.json +12 -0
- package/test-fixtures/addMissingField337/p1/metadata.json +6 -0
- package/test-fixtures/addMissingField337/p1/record.json +6 -0
- package/test-fixtures/addMissingField337/validate_x1/expectedResult.json +6 -0
- package/test-fixtures/addMissingField337/validate_x1/metadata.json +6 -0
- package/test-fixtures/addMissingField337/validate_x1/record.json +6 -0
- package/test-fixtures/addMissingField338/cb/expectedResult.json +14 -0
- package/test-fixtures/addMissingField338/cb/metadata.json +6 -0
- package/test-fixtures/addMissingField338/cb/record.json +8 -0
- package/test-fixtures/addMissingField338/cd/expectedResult.json +14 -0
- package/test-fixtures/addMissingField338/cd/metadata.json +6 -0
- package/test-fixtures/addMissingField338/cd/record.json +8 -0
- package/test-fixtures/addMissingField338/ck/expectedResult.json +14 -0
- package/test-fixtures/addMissingField338/ck/metadata.json +6 -0
- package/test-fixtures/addMissingField338/ck/record.json +8 -0
- package/test-fixtures/addMissingField338/cr/expectedResult.json +15 -0
- package/test-fixtures/addMissingField338/cr/metadata.json +6 -0
- package/test-fixtures/addMissingField338/cr/record.json +9 -0
- package/test-fixtures/addMissingField338/cr2/expectedResult.json +14 -0
- package/test-fixtures/addMissingField338/cr2/metadata.json +6 -0
- package/test-fixtures/addMissingField338/cr2/record.json +8 -0
- package/test-fixtures/addMissingField338/cr3/expectedResult.json +18 -0
- package/test-fixtures/addMissingField338/cr3/metadata.json +6 -0
- package/test-fixtures/addMissingField338/cr3/record.json +12 -0
- package/test-fixtures/addMissingField338/cr4/expectedResult.json +15 -0
- package/test-fixtures/addMissingField338/cr4/metadata.json +6 -0
- package/test-fixtures/addMissingField338/cr4/record.json +9 -0
- package/test-fixtures/addMissingField338/gc/expectedResult.json +12 -0
- package/test-fixtures/addMissingField338/gc/metadata.json +6 -0
- package/test-fixtures/addMissingField338/gc/record.json +7 -0
- package/test-fixtures/addMissingField338/gd/expectedResult.json +13 -0
- package/test-fixtures/addMissingField338/gd/metadata.json +6 -0
- package/test-fixtures/addMissingField338/gd/record.json +8 -0
- package/test-fixtures/addMissingField338/gf/expectedResult.json +13 -0
- package/test-fixtures/addMissingField338/gf/metadata.json +6 -0
- package/test-fixtures/addMissingField338/gf/record.json +8 -0
- package/test-fixtures/addMissingField338/gs/expectedResult.json +15 -0
- package/test-fixtures/addMissingField338/gs/metadata.json +6 -0
- package/test-fixtures/addMissingField338/gs/record.json +9 -0
- package/test-fixtures/addMissingField338/gt/expectedResult.json +15 -0
- package/test-fixtures/addMissingField338/gt/metadata.json +6 -0
- package/test-fixtures/addMissingField338/gt/record.json +9 -0
- package/test-fixtures/addMissingField338/hd/expectedResult.json +16 -0
- package/test-fixtures/addMissingField338/hd/metadata.json +6 -0
- package/test-fixtures/addMissingField338/hd/record.json +10 -0
- package/test-fixtures/addMissingField338/he/expectedResult.json +15 -0
- package/test-fixtures/addMissingField338/he/metadata.json +6 -0
- package/test-fixtures/addMissingField338/he/record.json +9 -0
- package/test-fixtures/addMissingField338/he2/expectedResult.json +12 -0
- package/test-fixtures/addMissingField338/he2/metadata.json +6 -0
- package/test-fixtures/addMissingField338/he2/record.json +6 -0
- package/test-fixtures/addMissingField338/hg/expectedResult.json +15 -0
- package/test-fixtures/addMissingField338/hg/metadata.json +7 -0
- package/test-fixtures/addMissingField338/hg/record.json +9 -0
- package/test-fixtures/addMissingField338/hg2/expectedResult.json +15 -0
- package/test-fixtures/addMissingField338/hg2/metadata.json +6 -0
- package/test-fixtures/addMissingField338/hg2/record.json +9 -0
- package/test-fixtures/addMissingField338/hj/expectedResult.json +15 -0
- package/test-fixtures/addMissingField338/hj/metadata.json +6 -0
- package/test-fixtures/addMissingField338/hj/record.json +9 -0
- package/test-fixtures/addMissingField338/hj2/expectedResult.json +15 -0
- package/test-fixtures/addMissingField338/hj2/metadata.json +6 -0
- package/test-fixtures/addMissingField338/hj2/record.json +9 -0
- package/test-fixtures/addMissingField338/mo/expectedResult.json +15 -0
- package/test-fixtures/addMissingField338/mo/metadata.json +6 -0
- package/test-fixtures/addMissingField338/mo/record.json +9 -0
- package/test-fixtures/addMissingField338/nc/expectedResult.json +19 -0
- package/test-fixtures/addMissingField338/nc/metadata.json +6 -0
- package/test-fixtures/addMissingField338/nc/record.json +13 -0
- package/test-fixtures/addMissingField338/nr/expectedResult.json +12 -0
- package/test-fixtures/addMissingField338/nr/metadata.json +7 -0
- package/test-fixtures/addMissingField338/nr/record.json +6 -0
- package/test-fixtures/addMissingField338/sd/expectedResult.json +14 -0
- package/test-fixtures/addMissingField338/sd/metadata.json +6 -0
- package/test-fixtures/addMissingField338/sd/record.json +8 -0
- package/test-fixtures/addMissingField338/sd2/expectedResult.json +14 -0
- package/test-fixtures/addMissingField338/sd2/metadata.json +6 -0
- package/test-fixtures/addMissingField338/sd2/record.json +8 -0
- package/test-fixtures/addMissingField338/sd3/expectedResult.json +14 -0
- package/test-fixtures/addMissingField338/sd3/metadata.json +6 -0
- package/test-fixtures/addMissingField338/sd3/record.json +8 -0
- package/test-fixtures/addMissingField338/ss/expectedResult.json +14 -0
- package/test-fixtures/addMissingField338/ss/metadata.json +6 -0
- package/test-fixtures/addMissingField338/ss/record.json +8 -0
- package/test-fixtures/addMissingField338/ss2/expectedResult.json +14 -0
- package/test-fixtures/addMissingField338/ss2/metadata.json +6 -0
- package/test-fixtures/addMissingField338/ss2/record.json +8 -0
- package/test-fixtures/addMissingField338/vd/expectedResult.json +15 -0
- package/test-fixtures/addMissingField338/vd/metadata.json +6 -0
- package/test-fixtures/addMissingField338/vd/record.json +9 -0
- package/test-fixtures/addMissingField338/vd2/expectedResult.json +13 -0
- package/test-fixtures/addMissingField338/vd2/metadata.json +6 -0
- package/test-fixtures/addMissingField338/vd2/record.json +8 -0
- package/test-fixtures/addMissingField338/vf/expectedResult.json +15 -0
- package/test-fixtures/addMissingField338/vf/metadata.json +6 -0
- package/test-fixtures/addMissingField338/vf/record.json +9 -0
- package/test-fixtures/addMissingField338/zu/expectedResult.json +14 -0
- package/test-fixtures/addMissingField338/zu/metadata.json +6 -0
- package/test-fixtures/addMissingField338/zu/record.json +8 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f01/expectedResult.json +32 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f01/metadata.json +7 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f01/record.json +20 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f02/expectedResult.json +29 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f02/metadata.json +7 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f02/record.json +9 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f03/expectedResult.json +34 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f03/metadata.json +7 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f03/record.json +12 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f04/expectedResult.json +26 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f04/metadata.json +8 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f04/record.json +6 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f05/expectedResult.json +27 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f05/metadata.json +7 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f05/record.json +8 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f06/expectedResult.json +27 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f06/metadata.json +7 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f06/record.json +8 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f07/expectedResult.json +25 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f07/metadata.json +7 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f07/record.json +8 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f08/expectedResult.json +34 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f08/metadata.json +6 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f08/record.json +33 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f09/expectedResult.json +35 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f09/metadata.json +6 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f09/record.json +35 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f10/expectedResult.json +41 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f10/metadata.json +7 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f10/record.json +33 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f11/expectedResult.json +32 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f11/metadata.json +6 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/f11/record.json +22 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/v01/expectedResult.json +7 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/v01/metadata.json +6 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/v01/record.json +20 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/v02/expectedResult.json +5 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/v02/metadata.json +6 -0
- package/test-fixtures/cyrillux-usemarcon-replacement/v02/record.json +29 -0
- package/test-fixtures/fix-33X/f11/expectedResult.json +29 -0
- package/test-fixtures/fix-33X/f11/metadata.json +6 -0
- package/test-fixtures/fix-33X/f11/record.json +22 -0
- package/test-fixtures/fix-33X/v11/expectedResult.json +9 -0
- package/test-fixtures/fix-33X/v11/metadata.json +6 -0
- package/test-fixtures/fix-33X/v11/record.json +22 -0
- package/test-fixtures/fix-language-codes/01/expectedResult.json +5 -0
- package/test-fixtures/fix-language-codes/01/metadata.json +6 -0
- package/test-fixtures/fix-language-codes/01/record.json +7 -0
- package/test-fixtures/fix-language-codes/02/expectedResult.json +7 -0
- package/test-fixtures/fix-language-codes/02/metadata.json +6 -0
- package/test-fixtures/fix-language-codes/02/record.json +10 -0
- package/test-fixtures/fix-language-codes/03/expectedResult.json +10 -0
- package/test-fixtures/fix-language-codes/03/metadata.json +6 -0
- package/test-fixtures/fix-language-codes/03/record.json +8 -0
- package/test-fixtures/fix-language-codes/04/expectedResult.json +9 -0
- package/test-fixtures/fix-language-codes/04/metadata.json +7 -0
- package/test-fixtures/fix-language-codes/04/record.json +7 -0
- package/test-fixtures/fix-language-codes/05/expectedResult.json +8 -0
- package/test-fixtures/fix-language-codes/05/metadata.json +6 -0
- package/test-fixtures/fix-language-codes/05/record.json +5 -0
- package/test-fixtures/punctuation2/95/expectedResult.json +22 -0
- package/test-fixtures/punctuation2/95/metadata.json +6 -0
- package/test-fixtures/punctuation2/95/record.json +20 -0
- package/test-fixtures/sanitize-vocabulary-source-codes/f03/expectedResult.json +143 -0
- package/test-fixtures/sanitize-vocabulary-source-codes/f03/metadata.json +9 -0
- package/test-fixtures/sanitize-vocabulary-source-codes/f03/record.json +145 -0
- package/test-fixtures/sanitize-vocabulary-source-codes/v03/expectedResult.json +5 -0
- package/test-fixtures/sanitize-vocabulary-source-codes/v03/metadata.json +6 -0
- package/test-fixtures/sanitize-vocabulary-source-codes/v03/record.json +145 -0
package/src/fix-33X.js
ADDED
|
@@ -0,0 +1,473 @@
|
|
|
1
|
+
//import createDebugLogger from 'debug';
|
|
2
|
+
import clone from 'clone';
|
|
3
|
+
import {fieldToString, getCatalogingLanguage, nvdebug} from './utils';
|
|
4
|
+
import {map336CodeToTerm, map337CodeToTerm, map338CodeToTerm} from './field33XUtils';
|
|
5
|
+
|
|
6
|
+
const description = 'Fix non-RDA 33X field(s)';
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
const map336 = {
|
|
10
|
+
'Bild (kartografisk ; att vidra)': 'crt',
|
|
11
|
+
'Bild (kartografisk ; rörlig)': 'crm',
|
|
12
|
+
'Bild (kartografisk)': 'cri',
|
|
13
|
+
'Bild (rörlig ; tredimensionell)': 'tdm',
|
|
14
|
+
'Bild (rörlig ; tvådimensionell)': 'tdi',
|
|
15
|
+
'Bild (still ; att vidra)': 'tci',
|
|
16
|
+
'Bild (still ; tredimensionell)': 'sti',
|
|
17
|
+
'Bild (still)': 'sti',
|
|
18
|
+
'Data': 'cod',
|
|
19
|
+
'Data (kartografinen)': 'crd',
|
|
20
|
+
'Dataset': 'cod',
|
|
21
|
+
'Dataset (kartografisk)': 'crd',
|
|
22
|
+
'Datorprogram': 'cop',
|
|
23
|
+
'Esine': 'tdf',
|
|
24
|
+
'Esine (kartografinen ; kosketeltava)': 'crn',
|
|
25
|
+
'Esine (kartografinen)': 'crf',
|
|
26
|
+
'Esine (kartogragrafinen ; kolmiulotteinen)': 'crf',
|
|
27
|
+
'Esine (kolmiulotteinen)': 'tdf',
|
|
28
|
+
'Esine (kosketeltava)': 'tcf',
|
|
29
|
+
'Flera innehållstyper': 'zzz',
|
|
30
|
+
'Föremal': 'tdf',
|
|
31
|
+
'Föremål (att vidra)': 'tcf',
|
|
32
|
+
'Föremål (kartografisk ; att vidra)': 'crn',
|
|
33
|
+
'Föremål (kartografisk ; tredimensionell)': 'crn',
|
|
34
|
+
'Föremål (tredimensionell)': 'tdf',
|
|
35
|
+
'Geräusche': 'snd',
|
|
36
|
+
'Kuva': 'sti',
|
|
37
|
+
'Kuva (kartografinen ; kosketeltava)': 'crt',
|
|
38
|
+
'Kuva (kartografinen ; liikkuva)': 'crm',
|
|
39
|
+
'Kuva (kartografinen)': 'cri',
|
|
40
|
+
'Kuva (liikkuva ; kaksiulotteinen)': 'tdi',
|
|
41
|
+
'Kuva (liikkuva ; kolmiulotteinen)': 'tdm',
|
|
42
|
+
'Kuva (still ; kaksiulotteinen)': 'sti',
|
|
43
|
+
'Kuva (still ; kolmiulotteinen)': 'sti',
|
|
44
|
+
'Kuva (still ; kosketeltava)': 'tci',
|
|
45
|
+
'Kuva (still)': 'sti',
|
|
46
|
+
'Liike (kosketeltava ; notatoitu)': 'tcn',
|
|
47
|
+
'Liike (notatoitu ; kosketeltava': 'tcn',
|
|
48
|
+
'Liike (notatoitu)': 'ntv',
|
|
49
|
+
'Ljud': 'snd',
|
|
50
|
+
'Musiikki (esitetty)': 'prm',
|
|
51
|
+
'Musiikki (kosketeltava ; notatoitu)': 'tcm',
|
|
52
|
+
'Musiikki (notatoitu ; kosketeltava)': 'tcm',
|
|
53
|
+
'Musiikki (notatoitu)': 'ntm',
|
|
54
|
+
'Musik (notation ; att vidra)': 'tcm',
|
|
55
|
+
'Musik (notation)': 'ntm',
|
|
56
|
+
'Musik (performance)': 'prm',
|
|
57
|
+
'Määrittelemätön': 'zzz',
|
|
58
|
+
'Määrittelemätön sisältötyyppi': 'zzz',
|
|
59
|
+
'Obestämd innehållstyp': 'zzz',
|
|
60
|
+
'Ospecificerad innehållstyp': 'zzz',
|
|
61
|
+
'Puhe': 'spw',
|
|
62
|
+
'Rörelse (notation ; att vidra)': 'tcn',
|
|
63
|
+
'Rörelse (notation)': 'ntv',
|
|
64
|
+
'Tal': 'spw',
|
|
65
|
+
'Teksti': 'txt',
|
|
66
|
+
'Teksti (kosketeltava); Text (att vidra)': 'tct',
|
|
67
|
+
'Text': 'txt',
|
|
68
|
+
'Tietokoneohjelma': 'cop',
|
|
69
|
+
'Useita sisältötyyppejä': 'zzz',
|
|
70
|
+
'Vild (still ; tvådimensionell)': 'sti',
|
|
71
|
+
'annan': 'xxx',
|
|
72
|
+
'cartographic dataset': 'crd',
|
|
73
|
+
'cartographic image': 'cri',
|
|
74
|
+
'cartographic moving image': 'crm',
|
|
75
|
+
'cartographic tactile image': 'crt',
|
|
76
|
+
'cartographic tactile three-dimensional form': 'crn',
|
|
77
|
+
'cartographic three-dimensional form': 'crf',
|
|
78
|
+
'cartographic three-dimensional tactile form': 'crn',
|
|
79
|
+
'computer dataset': 'cod',
|
|
80
|
+
'computer program': 'cop',
|
|
81
|
+
'dataset': 'cod',
|
|
82
|
+
'datorprogram': 'cop',
|
|
83
|
+
'digitaalinen data': 'cod',
|
|
84
|
+
'digitalt dataset': 'cod',
|
|
85
|
+
'esitetty musiikki': 'prm',
|
|
86
|
+
'framförd musik': 'prm',
|
|
87
|
+
'gesprochenes Wort': 'spw',
|
|
88
|
+
'kaksiulotteinen liikkuva kuva': 'tdi',
|
|
89
|
+
'kartografinen data': 'crd',
|
|
90
|
+
'kartografinen kolmiulotteinen muoto': 'crf',
|
|
91
|
+
'kartografinen kuva': 'cri',
|
|
92
|
+
'kartografinen liikkuva kuva': 'crm',
|
|
93
|
+
'kartografinen taktiili kolmiulotteinen muoto': 'crn',
|
|
94
|
+
'kartografinen taktiili kuva': 'crt',
|
|
95
|
+
'kartografisk bild': 'cri',
|
|
96
|
+
'kartografisk data': 'crd',
|
|
97
|
+
'kartografisk rörlig bild': 'crm',
|
|
98
|
+
'kartografisk taktil bild': 'crt',
|
|
99
|
+
'kartografisk taktil tredimensionell form': 'crn',
|
|
100
|
+
'kartografisk tredimensionell form': 'crf',
|
|
101
|
+
'kolmiulotteinen liikkuva kuva': 'tdm',
|
|
102
|
+
'kolmiulotteinen muoto': 'tdf',
|
|
103
|
+
'liikenotaatio': 'ntv',
|
|
104
|
+
'ljud': 'snd',
|
|
105
|
+
'muu': 'xxx',
|
|
106
|
+
'määrittelemätön': 'zzz',
|
|
107
|
+
'notated movement': 'ntv',
|
|
108
|
+
'notated music': 'ntm',
|
|
109
|
+
'noterad musik': 'ntm',
|
|
110
|
+
'nuottikirjoitus': 'ntm',
|
|
111
|
+
'ospecificerad': 'zzz',
|
|
112
|
+
'other': 'xxx',
|
|
113
|
+
'performed music': 'prm',
|
|
114
|
+
'puhe': 'spw',
|
|
115
|
+
'rörelsenotation': 'ntv',
|
|
116
|
+
'sounds': 'snd',
|
|
117
|
+
'spoken word': 'spw',
|
|
118
|
+
'still image': 'sti',
|
|
119
|
+
'stillbild': 'sti',
|
|
120
|
+
'stillkuva': 'sti',
|
|
121
|
+
'tactile image': 'tci',
|
|
122
|
+
'tactile notated movement': 'tcn',
|
|
123
|
+
'tactile notated music': 'tcm',
|
|
124
|
+
'tactile text': 'tct',
|
|
125
|
+
'tactile three-dimensional form': 'tcf',
|
|
126
|
+
'taktiili kolmiulotteinen muoto': 'tcf',
|
|
127
|
+
'taktiili kuva': 'tci',
|
|
128
|
+
'taktiili liikenotaatio': 'tcn',
|
|
129
|
+
'taktiili nuottikirjoitus': 'tcm',
|
|
130
|
+
'taktiili teksti': 'tct',
|
|
131
|
+
'taktil bild': 'tci',
|
|
132
|
+
'taktil musiknotation': 'tcm',
|
|
133
|
+
'taktil noterad rörelse': 'tcn',
|
|
134
|
+
'taktil text': 'tct',
|
|
135
|
+
'taktil tredimensionell form': 'tcf',
|
|
136
|
+
'tal': 'spw',
|
|
137
|
+
'teksti': 'txt',
|
|
138
|
+
'text': 'txt',
|
|
139
|
+
'texte': 'txt',
|
|
140
|
+
'texte tactile': 'tct',
|
|
141
|
+
'three-dimensional form': 'tdf',
|
|
142
|
+
'three-dimensional moving image': 'tdm',
|
|
143
|
+
'tietokoneohjelma': 'cop',
|
|
144
|
+
'tredimensionell form': 'tdf',
|
|
145
|
+
'tredimensionell rörlig bild': 'tdm',
|
|
146
|
+
'tvådimensionell rörlig bild': 'tdi',
|
|
147
|
+
'two-dimensional moving image': 'tdi',
|
|
148
|
+
'unbewegtes Bild': 'sti',
|
|
149
|
+
'unspecified': 'zzz',
|
|
150
|
+
'Ääni': 'snd',
|
|
151
|
+
'ääni': 'snd'
|
|
152
|
+
};
|
|
153
|
+
|
|
154
|
+
const map337 = {
|
|
155
|
+
'Computermedien': 'c',
|
|
156
|
+
'Mikroform': 'h',
|
|
157
|
+
'annan': 'x',
|
|
158
|
+
'audio': 's',
|
|
159
|
+
'computer': 'c',
|
|
160
|
+
'dator': 'c',
|
|
161
|
+
'datoranvändbar': 'c',
|
|
162
|
+
'ei välittävää laitetta': 'n',
|
|
163
|
+
'elektroninen': 'c',
|
|
164
|
+
'elektronisk': 'c',
|
|
165
|
+
'heijastettava': 'g',
|
|
166
|
+
'ingen medietyp': 'n',
|
|
167
|
+
'käytettävissä ilman laitetta': 'n',
|
|
168
|
+
'microform': 'h',
|
|
169
|
+
'microscopic': 'p',
|
|
170
|
+
'mikroform': 'h',
|
|
171
|
+
'mikromuoto': 'h',
|
|
172
|
+
'mikroskooppinen': 'p',
|
|
173
|
+
'mikroskopisch': 'p',
|
|
174
|
+
'mikroskopisk': 'p',
|
|
175
|
+
'muu': 'x',
|
|
176
|
+
'määrittelemätön': 'z',
|
|
177
|
+
'määrittelemätön välittävä laite': 'z',
|
|
178
|
+
'oförmedlad': 'n',
|
|
179
|
+
'ohne Hilfsmittel zu benutzen': 'n',
|
|
180
|
+
'omedierad': 'n',
|
|
181
|
+
'ospecificerad': 'z',
|
|
182
|
+
'ospecificerad medietyp': 'z',
|
|
183
|
+
'other': 'x',
|
|
184
|
+
'projected': 'g',
|
|
185
|
+
'projektion': 'g',
|
|
186
|
+
'projicerad': 'g',
|
|
187
|
+
'projicerbar': 'g',
|
|
188
|
+
'projizierbar': 'g',
|
|
189
|
+
'stereografinen': 'e',
|
|
190
|
+
'stereografisch': 'e',
|
|
191
|
+
'stereografisk': 'e',
|
|
192
|
+
'stereographic': 'e',
|
|
193
|
+
'tietokonekäyttöinen': 'c',
|
|
194
|
+
'unmediated': 'n',
|
|
195
|
+
'unspecified': 'z',
|
|
196
|
+
'useita mediatyyppejä': 'z',
|
|
197
|
+
'video': 'v',
|
|
198
|
+
'övrig': 'x'
|
|
199
|
+
};
|
|
200
|
+
|
|
201
|
+
const map338 = {
|
|
202
|
+
'aperture card': 'ha',
|
|
203
|
+
'ark': 'nb',
|
|
204
|
+
'arkki': 'nb',
|
|
205
|
+
'audio belt': 'sb',
|
|
206
|
+
'audio cartridge': 'sg',
|
|
207
|
+
'audio cylinder': 'se',
|
|
208
|
+
'audio disc': 'sd',
|
|
209
|
+
'audio roll': 'sq',
|
|
210
|
+
'audio wire reel': 'sw',
|
|
211
|
+
'audiocassette': 'ss',
|
|
212
|
+
'audiotape reel': 'st',
|
|
213
|
+
'bildband': 'gf',
|
|
214
|
+
'bildbandsmagasin': 'gc',
|
|
215
|
+
'blädderblock': 'nn',
|
|
216
|
+
'card': 'no',
|
|
217
|
+
'computer card': 'ck',
|
|
218
|
+
'computer cartridge': 'cb',
|
|
219
|
+
'computer disc': 'cd',
|
|
220
|
+
'computer disc cartridge': 'ce',
|
|
221
|
+
'computer tape cartridge': 'ca',
|
|
222
|
+
'computer tape cassette': 'cf',
|
|
223
|
+
'computer tape reel': 'ch',
|
|
224
|
+
'datorbandmagasin': 'ca',
|
|
225
|
+
'datorbandspole': 'ch',
|
|
226
|
+
'datorkassett': 'cf',
|
|
227
|
+
'datorkort': 'ck',
|
|
228
|
+
'datorminnesmodul': 'cb',
|
|
229
|
+
'datorskiva': 'cd',
|
|
230
|
+
'datorskivmagasin': 'ce',
|
|
231
|
+
'dia': 'gs',
|
|
232
|
+
'diabild': 'gs',
|
|
233
|
+
'film cartridge': 'mc',
|
|
234
|
+
'film cassette': 'mf',
|
|
235
|
+
'film reel': 'mr',
|
|
236
|
+
'film roll': 'mo',
|
|
237
|
+
'filmikasetti': 'mf',
|
|
238
|
+
'filmikela': 'mr',
|
|
239
|
+
'filmiliuska': 'gd',
|
|
240
|
+
'filmirulla': 'mo',
|
|
241
|
+
'filmisilmukkakasetti': 'mc',
|
|
242
|
+
'filmkassett': 'mf',
|
|
243
|
+
'filmljudspole': 'si',
|
|
244
|
+
'filmmagasin': 'mc',
|
|
245
|
+
'filmremsa': 'gd',
|
|
246
|
+
'filmrulle': 'mo',
|
|
247
|
+
'filmslip': 'gd',
|
|
248
|
+
'filmspole': 'mr',
|
|
249
|
+
'filmstrip': 'gf',
|
|
250
|
+
'filmstrip cartridge': 'gc',
|
|
251
|
+
'flipchart': 'nn',
|
|
252
|
+
'fönsterkort': 'ha',
|
|
253
|
+
'föremål': 'nr',
|
|
254
|
+
'ikkunakortti': 'ha',
|
|
255
|
+
'kort': 'no',
|
|
256
|
+
'kortti': 'no',
|
|
257
|
+
'lehtiötaulu': 'nn',
|
|
258
|
+
'ljudcylinder': 'se',
|
|
259
|
+
'ljudkassett': 'ss',
|
|
260
|
+
'ljudmagasin': 'sg',
|
|
261
|
+
'ljudrulle': 'sq',
|
|
262
|
+
'ljudskiva': 'sd',
|
|
263
|
+
'ljudslinga': 'sb',
|
|
264
|
+
'ljudspole': 'st',
|
|
265
|
+
'ljudtråd': 'sw',
|
|
266
|
+
'microfiche': 'he',
|
|
267
|
+
'microfiche cassette': 'hf',
|
|
268
|
+
'microfilm cartridge': 'hb',
|
|
269
|
+
'microfilm cassette': 'hc',
|
|
270
|
+
'microfilm reel': 'hd',
|
|
271
|
+
'microfilm roll': 'hj',
|
|
272
|
+
'microfilm slip': 'hh',
|
|
273
|
+
'microopaque': 'hg',
|
|
274
|
+
'microscope slide': 'pp',
|
|
275
|
+
'mikrofiche': 'he',
|
|
276
|
+
'mikrofiche (ogenomskinlig)': 'hg',
|
|
277
|
+
'mikrofichekassett': 'hf',
|
|
278
|
+
'mikrofilmikasetti': 'hc',
|
|
279
|
+
'mikrofilmikela': 'hd',
|
|
280
|
+
'mikrofilmiliuska': 'hh',
|
|
281
|
+
'mikrofilmirulla': 'hj',
|
|
282
|
+
'mikrofilmisilmukkakasetti': 'hb',
|
|
283
|
+
'mikrofilmskassett': 'hc',
|
|
284
|
+
'mikrofilmsmagasin': 'hb',
|
|
285
|
+
'mikrofilmsremsa': 'hh',
|
|
286
|
+
'mikrofilmsrulle': 'hj',
|
|
287
|
+
'mikrofilmsspole': 'hd',
|
|
288
|
+
'mikrokortti': 'he',
|
|
289
|
+
'mikrokortti (läpinäkymätön)': 'hg',
|
|
290
|
+
'mikrokorttikasetti': 'hf',
|
|
291
|
+
'mikroskoperingspreparat': 'pp',
|
|
292
|
+
'muistikortti': 'ck',
|
|
293
|
+
'määrittelemätön': 'zu',
|
|
294
|
+
'nide': 'nc',
|
|
295
|
+
'object': 'nr',
|
|
296
|
+
'objekti': 'nr',
|
|
297
|
+
'online resource': 'cr',
|
|
298
|
+
'onlineresurs': 'cr',
|
|
299
|
+
'ospecificerad': 'zu',
|
|
300
|
+
'overhead transparency': 'gt',
|
|
301
|
+
'piirikotelo': 'cb',
|
|
302
|
+
'piirtoheitinkalvo': 'gt',
|
|
303
|
+
'preparaattilasi': 'pp',
|
|
304
|
+
'raina': 'gf',
|
|
305
|
+
'rainakasetti': 'gc',
|
|
306
|
+
'roll': 'na',
|
|
307
|
+
'rulla': 'na',
|
|
308
|
+
'rulle': 'na',
|
|
309
|
+
'sheet': 'nb',
|
|
310
|
+
'slide': 'gs',
|
|
311
|
+
'sound-track reel': 'si',
|
|
312
|
+
'stereografinen kortti': 'eh',
|
|
313
|
+
'stereografinen levy': 'es',
|
|
314
|
+
'stereografisk skiva': 'es',
|
|
315
|
+
'stereografiskt kort': 'eh',
|
|
316
|
+
'stereograph card': 'eh',
|
|
317
|
+
'stereograph disc': 'es',
|
|
318
|
+
'tietokasetti': 'cf',
|
|
319
|
+
'tietolevy': 'cd',
|
|
320
|
+
'tietolevykotelo': 'ce',
|
|
321
|
+
'tietonauhakela': 'ch',
|
|
322
|
+
'tietonauhan silmukkakasetti': 'ca',
|
|
323
|
+
'transparang': 'gt',
|
|
324
|
+
'unspecified': 'zu',
|
|
325
|
+
'verkkoaineisto': 'cr',
|
|
326
|
+
'video cartridge': 'vc',
|
|
327
|
+
'videocassette': 'vf',
|
|
328
|
+
'videodisc': 'vd',
|
|
329
|
+
'videokasetti': 'vf',
|
|
330
|
+
'videokassett': 'vf',
|
|
331
|
+
'videokela': 'vr',
|
|
332
|
+
'videolevy': 'vd',
|
|
333
|
+
'videomagasin': 'vc',
|
|
334
|
+
'videosilmukkakasetti': 'vc',
|
|
335
|
+
'videoskiva': 'vd',
|
|
336
|
+
'videospole': 'vr',
|
|
337
|
+
'videotape reel': 'vr',
|
|
338
|
+
'volume': 'nc',
|
|
339
|
+
'volym': 'nc',
|
|
340
|
+
'äänihihna': 'sb',
|
|
341
|
+
'äänikasetti': 'ss',
|
|
342
|
+
'äänikela': 'st',
|
|
343
|
+
'äänilankakela': 'sw',
|
|
344
|
+
'äänilevy': 'sd',
|
|
345
|
+
'ääniraitakela': 'si',
|
|
346
|
+
'äänirulla': 'sq',
|
|
347
|
+
'äänisilmukkakasetti': 'sg',
|
|
348
|
+
'äänisylinteri': 'se'
|
|
349
|
+
};
|
|
350
|
+
|
|
351
|
+
// const multimediaRegexp = /multimedia/ui;
|
|
352
|
+
|
|
353
|
+
export default function () {
|
|
354
|
+
|
|
355
|
+
return {
|
|
356
|
+
description, validate, fix
|
|
357
|
+
};
|
|
358
|
+
|
|
359
|
+
function fix(record) {
|
|
360
|
+
nvdebug(`FIX ${description}...`);
|
|
361
|
+
const catLang = getCatalogingLanguage(record) || 'fin';
|
|
362
|
+
const fields = getRelevantFields(record);
|
|
363
|
+
fields.forEach(f => fixField(f, catLang));
|
|
364
|
+
nvdebug(` GOT ${fields.length}...`);
|
|
365
|
+
// FFS: we actually need newFields array here! Videogame, for example, might be
|
|
366
|
+
// 336 ## ‡a kaksiulotteinen liikkuva kuva ‡b tdi ‡2 rdacontent
|
|
367
|
+
// 336 ## ‡a tietokoneohjelma ‡b cop ‡2 rdacontent
|
|
368
|
+
const res = {message: [], fix: [], valid: true};
|
|
369
|
+
|
|
370
|
+
return res;
|
|
371
|
+
}
|
|
372
|
+
|
|
373
|
+
function validate(record) {
|
|
374
|
+
nvdebug(`VALIDATE ${description}...`); // NOT READY YET
|
|
375
|
+
const catLang = getCatalogingLanguage(record) || 'fin';
|
|
376
|
+
const fields = getRelevantFields(record);
|
|
377
|
+
if (fields.length === 0) {
|
|
378
|
+
return {message: [], valid: true};
|
|
379
|
+
}
|
|
380
|
+
const originalStrings = fields.map(f => fieldToString(f));
|
|
381
|
+
const clonedFields = fields.map(f => clone(f));
|
|
382
|
+
clonedFields.forEach(f => fixField(f, catLang));
|
|
383
|
+
const modifiedStrings = clonedFields.map(f => fieldToString(f));
|
|
384
|
+
|
|
385
|
+
const changes = originalStrings.map((str, i) => `'${str}' => '${modifiedStrings[i]}'`);
|
|
386
|
+
|
|
387
|
+
return {message: changes, valid: false};
|
|
388
|
+
}
|
|
389
|
+
|
|
390
|
+
|
|
391
|
+
function getA(field) {
|
|
392
|
+
const as = field.subfields.filter(f => f.code === 'a');
|
|
393
|
+
if (as.length === 1) {
|
|
394
|
+
return as[0];
|
|
395
|
+
}
|
|
396
|
+
return undefined;
|
|
397
|
+
}
|
|
398
|
+
|
|
399
|
+
|
|
400
|
+
function mapTermToCode(term, tag) {
|
|
401
|
+
nvdebug(`TERM/${tag}: '${term}'`);
|
|
402
|
+
if (tag === '336' && term in map336) {
|
|
403
|
+
return map336[term];
|
|
404
|
+
}
|
|
405
|
+
if (tag === '337' && term in map337) {
|
|
406
|
+
return map337[term];
|
|
407
|
+
}
|
|
408
|
+
if (tag === '338' && term in map338) {
|
|
409
|
+
return map338[term];
|
|
410
|
+
}
|
|
411
|
+
return undefined;
|
|
412
|
+
}
|
|
413
|
+
|
|
414
|
+
function mapFieldToCode(field) {
|
|
415
|
+
const subfieldA = getA(field);
|
|
416
|
+
if (subfieldA) {
|
|
417
|
+
return mapTermToCode(subfieldA.value, field.tag);
|
|
418
|
+
}
|
|
419
|
+
return undefined;
|
|
420
|
+
}
|
|
421
|
+
|
|
422
|
+
function getRelevantFields(record) {
|
|
423
|
+
const fields = record.get('33[678]');
|
|
424
|
+
// Currently not handline $3 etc
|
|
425
|
+
return fields.filter(f => f.subfields.length === 1 && mapFieldToCode(f));
|
|
426
|
+
}
|
|
427
|
+
|
|
428
|
+
function tagToSubfield2(tag) {
|
|
429
|
+
if (tag === '336') {
|
|
430
|
+
return {'code': '2', 'value': 'rdacontent'};
|
|
431
|
+
}
|
|
432
|
+
if (tag === '337') {
|
|
433
|
+
return {'code': '2', 'value': 'rdamedia'};
|
|
434
|
+
}
|
|
435
|
+
if (tag === '338') {
|
|
436
|
+
return {'code': '2', 'value': 'rdacarrier'};
|
|
437
|
+
}
|
|
438
|
+
}
|
|
439
|
+
|
|
440
|
+
function fixField(field, catalogingLanguage = 'fin') {
|
|
441
|
+
const subfieldA = getA(field);
|
|
442
|
+
if (!subfieldA) {
|
|
443
|
+
return;
|
|
444
|
+
}
|
|
445
|
+
const code = mapTermToCode(subfieldA.value, field.tag);
|
|
446
|
+
if (!code) {
|
|
447
|
+
return;
|
|
448
|
+
}
|
|
449
|
+
const newTerm = codeToTerm(code);
|
|
450
|
+
if (!newTerm) {
|
|
451
|
+
return;
|
|
452
|
+
}
|
|
453
|
+
|
|
454
|
+
subfieldA.value = newTerm; // eslint-disable-line functional/immutable-data
|
|
455
|
+
field.subfields.push({'code': 'b', 'value': code}); // eslint-disable-line functional/immutable-data
|
|
456
|
+
field.subfields.push(tagToSubfield2(field.tag)); // eslint-disable-line functional/immutable-data
|
|
457
|
+
|
|
458
|
+
function codeToTerm(code) {
|
|
459
|
+
if (field.tag === '336') {
|
|
460
|
+
return map336CodeToTerm(code, catalogingLanguage);
|
|
461
|
+
}
|
|
462
|
+
if (field.tag === '337') {
|
|
463
|
+
return map337CodeToTerm(code, catalogingLanguage);
|
|
464
|
+
}
|
|
465
|
+
if (field.tag === '338') {
|
|
466
|
+
return map338CodeToTerm(code, catalogingLanguage);
|
|
467
|
+
}
|
|
468
|
+
return undefined;
|
|
469
|
+
}
|
|
470
|
+
}
|
|
471
|
+
|
|
472
|
+
}
|
|
473
|
+
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import {expect} from 'chai';
|
|
2
|
+
import {MarcRecord} from '@natlibfi/marc-record';
|
|
3
|
+
import validatorFactory from './fix-33X';
|
|
4
|
+
import {READERS} from '@natlibfi/fixura';
|
|
5
|
+
import generateTests from '@natlibfi/fixugen';
|
|
6
|
+
|
|
7
|
+
generateTests({
|
|
8
|
+
callback,
|
|
9
|
+
path: [__dirname, '..', 'test-fixtures', 'fix-33X'],
|
|
10
|
+
useMetadataFile: true,
|
|
11
|
+
recurse: false,
|
|
12
|
+
fixura: {
|
|
13
|
+
reader: READERS.JSON
|
|
14
|
+
},
|
|
15
|
+
mocha: {
|
|
16
|
+
before: () => testValidatorFactory()
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
async function testValidatorFactory() {
|
|
21
|
+
const validator = await validatorFactory();
|
|
22
|
+
|
|
23
|
+
expect(validator)
|
|
24
|
+
.to.be.an('object')
|
|
25
|
+
.that.has.any.keys('description', 'validate');
|
|
26
|
+
|
|
27
|
+
expect(validator.description).to.be.a('string');
|
|
28
|
+
expect(validator.validate).to.be.a('function');
|
|
29
|
+
expect(validator.fix).to.be.a('function');
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
async function callback({getFixture, fix = false}) {
|
|
33
|
+
const validator = await validatorFactory();
|
|
34
|
+
const record = new MarcRecord(getFixture('record.json'));
|
|
35
|
+
const expectedResult = getFixture('expectedResult.json');
|
|
36
|
+
// console.log(expectedResult); // eslint-disable-line
|
|
37
|
+
|
|
38
|
+
if (!fix) {
|
|
39
|
+
const result = await validator.validate(record);
|
|
40
|
+
expect(result).to.eql(expectedResult);
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
await validator.fix(record);
|
|
45
|
+
expect(record).to.eql(expectedResult);
|
|
46
|
+
}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import clone from 'clone';
|
|
2
|
+
import {fieldToString} from './utils';
|
|
3
|
+
// Fix language codes in 008/35-37 and 041 (does not sync them)
|
|
4
|
+
//
|
|
5
|
+
// Author(s): Nicholas Volk
|
|
6
|
+
|
|
7
|
+
//import createDebugLogger from 'debug';
|
|
8
|
+
//import {fieldToString, nvdebug} from './utils';
|
|
9
|
+
|
|
10
|
+
const description = 'Fix language codes';
|
|
11
|
+
|
|
12
|
+
export default function () {
|
|
13
|
+
|
|
14
|
+
return {description, validate, fix};
|
|
15
|
+
|
|
16
|
+
function fix(record) {
|
|
17
|
+
//nvdebug(`FIX ME`);
|
|
18
|
+
const res = {message: [], fix: [], valid: true};
|
|
19
|
+
|
|
20
|
+
const [field008] = record.get('008');
|
|
21
|
+
if (!field008) {
|
|
22
|
+
return res;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
fixLanguageField008(field008);
|
|
26
|
+
|
|
27
|
+
const f041 = record.get('041');
|
|
28
|
+
f041.forEach(f => fixField041(f));
|
|
29
|
+
|
|
30
|
+
return res;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
function validate(record) {
|
|
35
|
+
const res = {message: [], valid: true};
|
|
36
|
+
|
|
37
|
+
validateField008(record, res);
|
|
38
|
+
|
|
39
|
+
const f041 = record.get('041');
|
|
40
|
+
f041.forEach(f => validateField041(f, res));
|
|
41
|
+
|
|
42
|
+
res.valid = !(res.message.length >= 1); // eslint-disable-line functional/immutable-data
|
|
43
|
+
return res;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
function validateField008(record, res) {
|
|
47
|
+
const [field008] = record.get('008');
|
|
48
|
+
|
|
49
|
+
if (!field008) {
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
const originalLanguage = getLanguageFromField008(field008);
|
|
54
|
+
const modifiedLanguage = deprecatedLanguageToCurrentLanguage(originalLanguage);
|
|
55
|
+
if (originalLanguage === modifiedLanguage) {
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
res.message.push(`Modify 008/35-37: '${originalLanguage}' => '${modifiedLanguage}'`); // eslint-disable-line functional/immutable-data
|
|
60
|
+
res.valid = false; // eslint-disable-line functional/immutable-data
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
|
|
64
|
+
function isRelevantField041SubfieldCode(subfield) {
|
|
65
|
+
return 'abdefghijkmnpqrt'.includes(subfield.code);
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
|
|
69
|
+
function validateField041(field, res) {
|
|
70
|
+
|
|
71
|
+
const clonedField = clone(field);
|
|
72
|
+
fixField041(clonedField);
|
|
73
|
+
|
|
74
|
+
const originalString = fieldToString(field);
|
|
75
|
+
const modifiedString = fieldToString(clonedField);
|
|
76
|
+
|
|
77
|
+
if (originalString === modifiedString) {
|
|
78
|
+
return;
|
|
79
|
+
}
|
|
80
|
+
const msg = `${originalString} => ${modifiedString}`;
|
|
81
|
+
res.message.push(msg); // eslint-disable-line functional/immutable-data
|
|
82
|
+
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
|
|
86
|
+
function fixLanguageField008(field008) {
|
|
87
|
+
const originalLanguage = getLanguageFromField008(field008);
|
|
88
|
+
const modifiedLanguage = deprecatedLanguageToCurrentLanguage(originalLanguage);
|
|
89
|
+
if (originalLanguage !== modifiedLanguage && modifiedLanguage.length === 3) {
|
|
90
|
+
field008.value = `${field008.value.substring(0, 35)}${modifiedLanguage}${field008.value.substring(38)}`; // eslint-disable-line functional/immutable-data
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
function fixField041(field) {
|
|
96
|
+
if (field.subfields.some(sf => sf.code === '2')) {
|
|
97
|
+
return;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
field.subfields.forEach(sf => fixField041Subfield(sf));
|
|
101
|
+
|
|
102
|
+
function fixField041Subfield(subfield) {
|
|
103
|
+
if (!isRelevantField041SubfieldCode(subfield)) {
|
|
104
|
+
return;
|
|
105
|
+
}
|
|
106
|
+
subfield.value = deprecatedLanguageToCurrentLanguage(subfield.value); // eslint-disable-line functional/immutable-data
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
function getLanguageFromField008(field) {
|
|
111
|
+
return field.value.substring(35, 38); // return 008/35-37
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
function deprecatedLanguageToCurrentLanguage(language) {
|
|
115
|
+
if (language === 'nno' || language === 'nob') { // Nynorsk ja bokmål
|
|
116
|
+
return 'nor'; // Norwegian
|
|
117
|
+
}
|
|
118
|
+
return language;
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import {expect} from 'chai';
|
|
2
|
+
import {MarcRecord} from '@natlibfi/marc-record';
|
|
3
|
+
import validatorFactory from './fix-language-codes';
|
|
4
|
+
import {READERS} from '@natlibfi/fixura';
|
|
5
|
+
import generateTests from '@natlibfi/fixugen';
|
|
6
|
+
|
|
7
|
+
generateTests({
|
|
8
|
+
callback,
|
|
9
|
+
path: [__dirname, '..', 'test-fixtures', 'fix-language-codes'],
|
|
10
|
+
useMetadataFile: true,
|
|
11
|
+
recurse: false,
|
|
12
|
+
fixura: {
|
|
13
|
+
reader: READERS.JSON
|
|
14
|
+
},
|
|
15
|
+
mocha: {
|
|
16
|
+
before: () => testValidatorFactory()
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
async function testValidatorFactory() {
|
|
21
|
+
const validator = await validatorFactory();
|
|
22
|
+
|
|
23
|
+
expect(validator)
|
|
24
|
+
.to.be.an('object')
|
|
25
|
+
.that.has.any.keys('description', 'validate');
|
|
26
|
+
|
|
27
|
+
expect(validator.description).to.be.a('string');
|
|
28
|
+
expect(validator.validate).to.be.a('function');
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
async function callback({getFixture, fix = false}) {
|
|
32
|
+
const validator = await validatorFactory();
|
|
33
|
+
const record = new MarcRecord(getFixture('record.json'));
|
|
34
|
+
const expectedResult = getFixture('expectedResult.json');
|
|
35
|
+
// console.log(expectedResult); // eslint-disable-line
|
|
36
|
+
|
|
37
|
+
if (!fix) {
|
|
38
|
+
const result = await validator.validate(record);
|
|
39
|
+
expect(result).to.eql(expectedResult);
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
await validator.fix(record);
|
|
44
|
+
expect(record).to.eql(expectedResult);
|
|
45
|
+
}
|
package/src/fixRelatorTerms.js
CHANGED
|
@@ -115,7 +115,7 @@ function subfieldHandleRelatorTermAbbreviation(subfield, language) {
|
|
|
115
115
|
return;
|
|
116
116
|
}
|
|
117
117
|
nvdebug(`Relator cand subfield: '${subfieldToString(subfield)}', lang: ${language ? language : 'NULL'}`, debugDev);
|
|
118
|
-
if (language
|
|
118
|
+
if (!language || language === 'mul') {
|
|
119
119
|
subfieldHandleRelatorTermAbbreviation(subfield, 'fin');
|
|
120
120
|
// Maybe later add Swedish here...
|
|
121
121
|
return;
|