@natlibfi/marc-record-validators-melinda 11.3.2-alpha.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/src/access-rights.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {isElectronicMaterial} from './utils';
|
|
2
2
|
|
|
3
|
-
export default function () {
|
|
3
|
+
export default function (isViolaRecord = false) {
|
|
4
4
|
const sf506 = [{code: 'a', value: /aineisto on käytettävissä vapaakappaletyöasemilla/ui}];
|
|
5
5
|
const sf506old = [{code: 'a', value: /aineisto on käytettävissä vapaakappalekirjastoissa/ui}];
|
|
6
6
|
const sf540 = [{code: 'c', value: /laki kulttuuriaineistojen tallettamisesta ja säilyttämisestä/ui}];
|
|
@@ -10,27 +10,27 @@ export default function () {
|
|
|
10
10
|
|
|
11
11
|
// If material is electronic add theis if missing
|
|
12
12
|
if (!hasTag(record, '506', sf506) && !hasTag(record, '506', sf506old)) { // eslint-disable-line functional/no-conditional-statements
|
|
13
|
+
const subfield9 = isViolaRecord ? [{code: '9', value: 'VIOLA<KEEP>'}] : [{code: '9', value: 'FENNI<KEEP>'}];
|
|
14
|
+
const staticSubfields = [
|
|
15
|
+
{
|
|
16
|
+
code: 'a',
|
|
17
|
+
value: 'Aineisto on käytettävissä vapaakappaletyöasemilla.'
|
|
18
|
+
}, {
|
|
19
|
+
code: 'f',
|
|
20
|
+
value: 'Online access with authorization'
|
|
21
|
+
}, {
|
|
22
|
+
code: '2',
|
|
23
|
+
value: 'star'
|
|
24
|
+
}, {
|
|
25
|
+
code: '5',
|
|
26
|
+
value: 'FI-Vapaa'
|
|
27
|
+
}
|
|
28
|
+
];
|
|
29
|
+
|
|
13
30
|
record.insertField({
|
|
14
31
|
tag: '506',
|
|
15
32
|
ind1: '1',
|
|
16
|
-
subfields:
|
|
17
|
-
{
|
|
18
|
-
code: 'a',
|
|
19
|
-
value: 'Aineisto on käytettävissä vapaakappaletyöasemilla.'
|
|
20
|
-
}, {
|
|
21
|
-
code: 'f',
|
|
22
|
-
value: 'Online access with authorization'
|
|
23
|
-
}, {
|
|
24
|
-
code: '2',
|
|
25
|
-
value: 'star'
|
|
26
|
-
}, {
|
|
27
|
-
code: '5',
|
|
28
|
-
value: 'FI-Vapaa'
|
|
29
|
-
}, {
|
|
30
|
-
code: '9',
|
|
31
|
-
value: 'FENNI<KEEP>'
|
|
32
|
-
}
|
|
33
|
-
]
|
|
33
|
+
subfields: staticSubfields.concat(subfield9)
|
|
34
34
|
});
|
|
35
35
|
}
|
|
36
36
|
|
|
@@ -42,7 +42,7 @@ export default function () {
|
|
|
42
42
|
.value = 'Aineisto on käytettävissä vapaakappaletyöasemilla.';
|
|
43
43
|
}
|
|
44
44
|
|
|
45
|
-
if (!hasTag(record, '540', sf540)) { // eslint-disable-line functional/no-conditional-statements
|
|
45
|
+
if (!hasTag(record, '540', sf540) && !isViolaRecord) { // eslint-disable-line functional/no-conditional-statements
|
|
46
46
|
record.insertField({
|
|
47
47
|
tag: '540',
|
|
48
48
|
subfields: [
|
|
@@ -78,7 +78,7 @@ export default function () {
|
|
|
78
78
|
return {valid: true};
|
|
79
79
|
}
|
|
80
80
|
|
|
81
|
-
return {valid: hasTag(record, '506', sf506) && hasTag(record, '540', sf540)};
|
|
81
|
+
return {valid: hasTag(record, '506', sf506) && (hasTag(record, '540', sf540) || isViolaRecord)};
|
|
82
82
|
}
|
|
83
83
|
|
|
84
84
|
return {
|