@natlibfi/marc-record-validators-melinda 11.3.2 → 11.3.3

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.
@@ -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 {