@natlibfi/marc-record-validators-melinda 11.3.2 → 11.3.3-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/access-rights.js +24 -19
- package/dist/access-rights.js.map +1 -1
- package/dist/melindaCustomMergeFields.js +11236 -0
- package/dist/melindaCustomMergeFields.js.map +1 -0
- package/dist/merge-fields/index.js +6 -5
- package/dist/merge-fields/index.js.map +1 -1
- package/dist/merge-fields/mergeConfig.js +175 -0
- package/dist/merge-fields/mergeConfig.js.map +1 -0
- package/dist/sortSubfields.js +5 -0
- package/dist/sortSubfields.js.map +1 -1
- package/dist/utils.js +8 -5
- package/dist/utils.js.map +1 -1
- package/package.json +5 -5
- package/src/access-rights.js +21 -21
- package/src/melindaCustomMergeFields.js +5142 -0
- package/src/merge-fields/index.js +5 -3
- package/src/merge-fields/mergeConfig.js +69 -0
- package/src/sortSubfields.js +1 -0
- package/src/utils.js +4 -3
- package/dist/merge-fields/config.json +0 -83
- package/src/merge-fields/config.json +0 -83
package/dist/access-rights.js
CHANGED
|
@@ -5,7 +5,7 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
5
5
|
});
|
|
6
6
|
exports.default = _default;
|
|
7
7
|
var _utils = require("./utils");
|
|
8
|
-
function _default() {
|
|
8
|
+
function _default(isViolaRecord = false) {
|
|
9
9
|
const sf506 = [{
|
|
10
10
|
code: 'a',
|
|
11
11
|
value: /aineisto on käytettävissä vapaakappaletyöasemilla/ui
|
|
@@ -24,25 +24,30 @@ function _default() {
|
|
|
24
24
|
// If material is electronic add theis if missing
|
|
25
25
|
if (!hasTag(record, '506', sf506) && !hasTag(record, '506', sf506old)) {
|
|
26
26
|
// eslint-disable-line functional/no-conditional-statements
|
|
27
|
+
const subfield9 = isViolaRecord ? [{
|
|
28
|
+
code: '9',
|
|
29
|
+
value: 'VIOLA<KEEP>'
|
|
30
|
+
}] : [{
|
|
31
|
+
code: '9',
|
|
32
|
+
value: 'FENNI<KEEP>'
|
|
33
|
+
}];
|
|
34
|
+
const staticSubfields = [{
|
|
35
|
+
code: 'a',
|
|
36
|
+
value: 'Aineisto on käytettävissä vapaakappaletyöasemilla.'
|
|
37
|
+
}, {
|
|
38
|
+
code: 'f',
|
|
39
|
+
value: 'Online access with authorization'
|
|
40
|
+
}, {
|
|
41
|
+
code: '2',
|
|
42
|
+
value: 'star'
|
|
43
|
+
}, {
|
|
44
|
+
code: '5',
|
|
45
|
+
value: 'FI-Vapaa'
|
|
46
|
+
}];
|
|
27
47
|
record.insertField({
|
|
28
48
|
tag: '506',
|
|
29
49
|
ind1: '1',
|
|
30
|
-
subfields:
|
|
31
|
-
code: 'a',
|
|
32
|
-
value: 'Aineisto on käytettävissä vapaakappaletyöasemilla.'
|
|
33
|
-
}, {
|
|
34
|
-
code: 'f',
|
|
35
|
-
value: 'Online access with authorization'
|
|
36
|
-
}, {
|
|
37
|
-
code: '2',
|
|
38
|
-
value: 'star'
|
|
39
|
-
}, {
|
|
40
|
-
code: '5',
|
|
41
|
-
value: 'FI-Vapaa'
|
|
42
|
-
}, {
|
|
43
|
-
code: '9',
|
|
44
|
-
value: 'FENNI<KEEP>'
|
|
45
|
-
}]
|
|
50
|
+
subfields: staticSubfields.concat(subfield9)
|
|
46
51
|
});
|
|
47
52
|
}
|
|
48
53
|
|
|
@@ -58,7 +63,7 @@ function _default() {
|
|
|
58
63
|
value
|
|
59
64
|
}) => sf.code === code && value.test(sf.value))).value = 'Aineisto on käytettävissä vapaakappaletyöasemilla.';
|
|
60
65
|
}
|
|
61
|
-
if (!hasTag(record, '540', sf540)) {
|
|
66
|
+
if (!hasTag(record, '540', sf540) && !isViolaRecord) {
|
|
62
67
|
// eslint-disable-line functional/no-conditional-statements
|
|
63
68
|
record.insertField({
|
|
64
69
|
tag: '540',
|
|
@@ -93,7 +98,7 @@ function _default() {
|
|
|
93
98
|
};
|
|
94
99
|
}
|
|
95
100
|
return {
|
|
96
|
-
valid: hasTag(record, '506', sf506) && hasTag(record, '540', sf540)
|
|
101
|
+
valid: hasTag(record, '506', sf506) && (hasTag(record, '540', sf540) || isViolaRecord)
|
|
97
102
|
};
|
|
98
103
|
}
|
|
99
104
|
return {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"access-rights.js","names":["_utils","require","_default","sf506","code","value","sf506old","sf540","fix","record","hasTag","insertField","tag","ind1","subfields","fields","find","f","every","some","sf","test","validate","isElectronicMaterial","valid","description","rec","sfcv"],"sources":["../src/access-rights.js"],"sourcesContent":["import {isElectronicMaterial} from './utils';\n\nexport default function () {\n const sf506 = [{code: 'a', value: /aineisto on käytettävissä vapaakappaletyöasemilla/ui}];\n const sf506old = [{code: 'a', value: /aineisto on käytettävissä vapaakappalekirjastoissa/ui}];\n const sf540 = [{code: 'c', value: /laki kulttuuriaineistojen tallettamisesta ja säilyttämisestä/ui}];\n\n function fix(record) {\n // If printed do nothing\n\n // If material is electronic add theis if missing\n if (!hasTag(record, '506', sf506) && !hasTag(record, '506', sf506old)) { // eslint-disable-line functional/no-conditional-statements\n
|
|
1
|
+
{"version":3,"file":"access-rights.js","names":["_utils","require","_default","isViolaRecord","sf506","code","value","sf506old","sf540","fix","record","hasTag","subfield9","staticSubfields","insertField","tag","ind1","subfields","concat","fields","find","f","every","some","sf","test","validate","isElectronicMaterial","valid","description","rec","sfcv"],"sources":["../src/access-rights.js"],"sourcesContent":["import {isElectronicMaterial} from './utils';\n\nexport default function (isViolaRecord = false) {\n const sf506 = [{code: 'a', value: /aineisto on käytettävissä vapaakappaletyöasemilla/ui}];\n const sf506old = [{code: 'a', value: /aineisto on käytettävissä vapaakappalekirjastoissa/ui}];\n const sf540 = [{code: 'c', value: /laki kulttuuriaineistojen tallettamisesta ja säilyttämisestä/ui}];\n\n function fix(record) {\n // If printed do nothing\n\n // If material is electronic add theis if missing\n if (!hasTag(record, '506', sf506) && !hasTag(record, '506', sf506old)) { // eslint-disable-line functional/no-conditional-statements\n const subfield9 = isViolaRecord ? [{code: '9', value: 'VIOLA<KEEP>'}] : [{code: '9', value: 'FENNI<KEEP>'}];\n const staticSubfields = [\n {\n code: 'a',\n value: 'Aineisto on käytettävissä vapaakappaletyöasemilla.'\n }, {\n code: 'f',\n value: 'Online access with authorization'\n }, {\n code: '2',\n value: 'star'\n }, {\n code: '5',\n value: 'FI-Vapaa'\n }\n ];\n\n record.insertField({\n tag: '506',\n ind1: '1',\n subfields: staticSubfields.concat(subfield9)\n });\n }\n\n // Change phrase from old to new if field with old phrase is found\n if (!hasTag(record, '506', sf506) && hasTag(record, '506', sf506old)) { // eslint-disable-line functional/no-conditional-statements\n record.fields // eslint-disable-line functional/immutable-data\n .find(f => f.tag === '506' && sf506old.every(({code, value}) => f.subfields.some(sf => sf.code === code && value.test(sf.value))))\n .subfields.find(sf => sf506old.every(({code, value}) => sf.code === code && value.test(sf.value)))\n .value = 'Aineisto on käytettävissä vapaakappaletyöasemilla.';\n }\n\n if (!hasTag(record, '540', sf540) && !isViolaRecord) { // eslint-disable-line functional/no-conditional-statements\n record.insertField({\n tag: '540',\n subfields: [\n {\n code: 'a',\n value: 'Aineisto on käytettävissä tutkimus- ja muihin tarkoituksiin;'\n }, {\n code: 'b',\n value: 'Kansalliskirjasto;'\n }, {\n code: 'c',\n value: 'Laki kulttuuriaineistojen tallettamisesta ja säilyttämisestä'\n }, {\n code: 'u',\n value: 'http://www.finlex.fi/fi/laki/ajantasa/2007/20071433'\n }, {\n code: '5',\n value: 'FI-Vapaa'\n }, {\n code: '9',\n value: 'FENNI<KEEP>'\n }\n ]\n });\n }\n\n return true;\n }\n\n function validate(record) {\n // if not electronic skip this validator\n if (!isElectronicMaterial(record)) {\n return {valid: true};\n }\n\n return {valid: hasTag(record, '506', sf506) && (hasTag(record, '540', sf540) || isViolaRecord)};\n }\n\n return {\n description: 'Adds access rights fields for a record (if not existing)',\n validate,\n fix\n };\n\n function hasTag(rec, tag, sfcv) {\n return rec.fields.some(f => f.tag === tag && sfcv.every(({code, value}) => f.subfields.some(sf => sf.code === code && value.test(sf.value))));\n }\n}\n"],"mappings":"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","ignoreList":[]}
|