@natlibfi/marc-record-validators-melinda 11.6.7-alpha.1 → 12.0.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.
Files changed (545) hide show
  1. package/.github/workflows/melinda-node-tests.yml +1 -1
  2. package/dist/access-rights.js +63 -91
  3. package/dist/access-rights.js.map +7 -1
  4. package/dist/access-rights.test.js +137 -0
  5. package/dist/access-rights.test.js.map +7 -0
  6. package/dist/addMissingField041.js +21 -53
  7. package/dist/addMissingField041.js.map +7 -1
  8. package/dist/addMissingField041.test.js +39 -0
  9. package/dist/addMissingField041.test.js.map +7 -0
  10. package/dist/addMissingField336.js +99 -191
  11. package/dist/addMissingField336.js.map +7 -1
  12. package/dist/addMissingField336.test.js +39 -0
  13. package/dist/addMissingField336.test.js.map +7 -0
  14. package/dist/addMissingField337.js +63 -132
  15. package/dist/addMissingField337.js.map +7 -1
  16. package/dist/addMissingField337.test.js +39 -0
  17. package/dist/addMissingField337.test.js.map +7 -0
  18. package/dist/addMissingField338.js +147 -253
  19. package/dist/addMissingField338.js.map +7 -1
  20. package/dist/addMissingField338.test.js +39 -0
  21. package/dist/addMissingField338.test.js.map +7 -0
  22. package/dist/cyrillux-usemarcon-replacement.js +119 -272
  23. package/dist/cyrillux-usemarcon-replacement.js.map +7 -1
  24. package/dist/cyrillux-usemarcon-replacement.test.js +46 -0
  25. package/dist/cyrillux-usemarcon-replacement.test.js.map +7 -0
  26. package/dist/cyrillux.js +119 -223
  27. package/dist/cyrillux.js.map +7 -1
  28. package/dist/cyrillux.test.js +39 -0
  29. package/dist/cyrillux.test.js.map +7 -0
  30. package/dist/disambiguateSeriesStatements.js +40 -81
  31. package/dist/disambiguateSeriesStatements.js.map +7 -1
  32. package/dist/disambiguateSeriesStatements.test.js +44 -0
  33. package/dist/disambiguateSeriesStatements.test.js.map +7 -0
  34. package/dist/double-commas.js +7 -14
  35. package/dist/double-commas.js.map +7 -1
  36. package/dist/double-commas.test.js +48 -0
  37. package/dist/double-commas.test.js.map +7 -0
  38. package/dist/duplicates-ind1.js +10 -31
  39. package/dist/duplicates-ind1.js.map +7 -1
  40. package/dist/duplicates-ind1.test.js +40 -0
  41. package/dist/duplicates-ind1.test.js.map +7 -0
  42. package/dist/empty-fields.js +10 -22
  43. package/dist/empty-fields.js.map +7 -1
  44. package/dist/empty-fields.test.js +129 -0
  45. package/dist/empty-fields.test.js.map +7 -0
  46. package/dist/ending-punctuation-conf.js +871 -769
  47. package/dist/ending-punctuation-conf.js.map +7 -1
  48. package/dist/ending-punctuation.js +84 -167
  49. package/dist/ending-punctuation.js.map +7 -1
  50. package/dist/ending-punctuation.test.js +2290 -0
  51. package/dist/ending-punctuation.test.js.map +7 -0
  52. package/dist/ending-whitespace.js +10 -35
  53. package/dist/ending-whitespace.js.map +7 -1
  54. package/dist/ending-whitespace.test.js +38 -0
  55. package/dist/ending-whitespace.test.js.map +7 -0
  56. package/dist/field-008-18-34-character-groups.js +40 -125
  57. package/dist/field-008-18-34-character-groups.js.map +7 -1
  58. package/dist/field-008-18-34-character-groups.test.js +45 -0
  59. package/dist/field-008-18-34-character-groups.test.js.map +7 -0
  60. package/dist/field-505-separators.js +19 -39
  61. package/dist/field-505-separators.js.map +7 -1
  62. package/dist/field-505-separators.test.js +45 -0
  63. package/dist/field-505-separators.test.js.map +7 -0
  64. package/dist/field-521-fix.js +19 -47
  65. package/dist/field-521-fix.js.map +7 -1
  66. package/dist/field-521-fix.test.js +44 -0
  67. package/dist/field-521-fix.test.js.map +7 -0
  68. package/dist/field-exclusion.js +37 -91
  69. package/dist/field-exclusion.js.map +7 -1
  70. package/dist/field-exclusion.test.js +821 -0
  71. package/dist/field-exclusion.test.js.map +7 -0
  72. package/dist/field-structure.js +52 -104
  73. package/dist/field-structure.js.map +7 -1
  74. package/dist/field-structure.test.js +587 -0
  75. package/dist/field-structure.test.js.map +7 -0
  76. package/dist/field33XUtils.js +119 -503
  77. package/dist/field33XUtils.js.map +7 -1
  78. package/dist/fields-present.js +11 -23
  79. package/dist/fields-present.js.map +7 -1
  80. package/dist/fields-present.test.js +95 -0
  81. package/dist/fields-present.test.js.map +7 -0
  82. package/dist/fix-33X.js +393 -431
  83. package/dist/fix-33X.js.map +7 -1
  84. package/dist/fix-33X.test.js +39 -0
  85. package/dist/fix-33X.test.js.map +7 -0
  86. package/dist/fix-country-codes.js +20 -50
  87. package/dist/fix-country-codes.js.map +7 -1
  88. package/dist/fix-country-codes.test.js +44 -0
  89. package/dist/fix-country-codes.test.js.map +7 -0
  90. package/dist/fix-language-codes.js +23 -53
  91. package/dist/fix-language-codes.js.map +7 -1
  92. package/dist/fix-language-codes.test.js +38 -0
  93. package/dist/fix-language-codes.test.js.map +7 -0
  94. package/dist/fixRelatorTerms.js +82 -209
  95. package/dist/fixRelatorTerms.js.map +7 -1
  96. package/dist/fixRelatorTerms.test.js +44 -0
  97. package/dist/fixRelatorTerms.test.js.map +7 -0
  98. package/dist/fixed-fields.js +21 -30
  99. package/dist/fixed-fields.js.map +7 -1
  100. package/dist/fixed-fields.test.js +87 -0
  101. package/dist/fixed-fields.test.js.map +7 -0
  102. package/dist/identical-fields.js +8 -24
  103. package/dist/identical-fields.js.map +7 -1
  104. package/dist/identical-fields.test.js +119 -0
  105. package/dist/identical-fields.test.js.map +7 -0
  106. package/dist/index.js +119 -413
  107. package/dist/index.js.map +7 -1
  108. package/dist/indicator-fixes.js +57 -95
  109. package/dist/indicator-fixes.js.map +7 -1
  110. package/dist/indicator-fixes.test.js +42 -0
  111. package/dist/indicator-fixes.test.js.map +7 -0
  112. package/dist/isbn-issn.js +66 -126
  113. package/dist/isbn-issn.js.map +7 -1
  114. package/dist/isbn-issn.test.js +398 -0
  115. package/dist/isbn-issn.test.js.map +7 -0
  116. package/dist/item-language.js +32 -65
  117. package/dist/item-language.js.map +7 -1
  118. package/dist/item-language.test.js +322 -0
  119. package/dist/item-language.test.js.map +7 -0
  120. package/dist/melindaCustomMergeFields.js +5182 -11233
  121. package/dist/melindaCustomMergeFields.js.map +7 -1
  122. package/dist/merge-fields/controlSubfields.js +75 -142
  123. package/dist/merge-fields/controlSubfields.js.map +7 -1
  124. package/dist/merge-fields/counterpartField.js +182 -379
  125. package/dist/merge-fields/counterpartField.js.map +7 -1
  126. package/dist/merge-fields/index.js +15 -49
  127. package/dist/merge-fields/index.js.map +7 -1
  128. package/dist/merge-fields/mergableIndicator.js +18 -51
  129. package/dist/merge-fields/mergableIndicator.js.map +7 -1
  130. package/dist/merge-fields/mergableTag.js +78 -30
  131. package/dist/merge-fields/mergableTag.js.map +7 -1
  132. package/dist/merge-fields/mergeConfig.js +66 -171
  133. package/dist/merge-fields/mergeConfig.js.map +7 -1
  134. package/dist/merge-fields/mergeConstraints.js +323 -1214
  135. package/dist/merge-fields/mergeConstraints.js.map +7 -1
  136. package/dist/merge-fields/mergeField.js +47 -111
  137. package/dist/merge-fields/mergeField.js.map +7 -1
  138. package/dist/merge-fields/mergeIndicator.js +64 -118
  139. package/dist/merge-fields/mergeIndicator.js.map +7 -1
  140. package/dist/merge-fields/mergeOrAddPostprocess.js +14 -38
  141. package/dist/merge-fields/mergeOrAddPostprocess.js.map +7 -1
  142. package/dist/merge-fields/mergeOrAddSubfield.js +62 -104
  143. package/dist/merge-fields/mergeOrAddSubfield.js.map +7 -1
  144. package/dist/merge-fields/mergeSubfield.js +47 -95
  145. package/dist/merge-fields/mergeSubfield.js.map +7 -1
  146. package/dist/merge-fields/removeDuplicateSubfields.js +18 -31
  147. package/dist/merge-fields/removeDuplicateSubfields.js.map +7 -1
  148. package/dist/merge-fields/worldKnowledge.js +15 -40
  149. package/dist/merge-fields/worldKnowledge.js.map +7 -1
  150. package/dist/merge-fields.test.js +44 -0
  151. package/dist/merge-fields.test.js.map +7 -0
  152. package/dist/mergeField500Lisapainokset.js +28 -57
  153. package/dist/mergeField500Lisapainokset.js.map +7 -1
  154. package/dist/mergeField500Lisapainokset.test.js +44 -0
  155. package/dist/mergeField500Lisapainokset.test.js.map +7 -0
  156. package/dist/mergeRelatorTermFields.js +33 -69
  157. package/dist/mergeRelatorTermFields.js.map +7 -1
  158. package/dist/mergeRelatorTermFields.test.js +44 -0
  159. package/dist/mergeRelatorTermFields.test.js.map +7 -0
  160. package/dist/modernize-502.js +23 -55
  161. package/dist/modernize-502.js.map +7 -1
  162. package/dist/modernize-502.test.js +38 -0
  163. package/dist/modernize-502.test.js.map +7 -0
  164. package/dist/multiple-subfield-0.js +23 -48
  165. package/dist/multiple-subfield-0.js.map +7 -1
  166. package/dist/multiple-subfield-0.test.js +44 -0
  167. package/dist/multiple-subfield-0.test.js.map +7 -0
  168. package/dist/non-breaking-space.js +11 -32
  169. package/dist/non-breaking-space.js.map +7 -1
  170. package/dist/non-breaking-space.test.js +38 -0
  171. package/dist/non-breaking-space.test.js.map +7 -0
  172. package/dist/normalize-dashes.js +18 -37
  173. package/dist/normalize-dashes.js.map +7 -1
  174. package/dist/normalize-dashes.test.js +44 -0
  175. package/dist/normalize-dashes.test.js.map +7 -0
  176. package/dist/normalize-identifiers.js +54 -140
  177. package/dist/normalize-identifiers.js.map +7 -1
  178. package/dist/normalize-identifiers.test.js +44 -0
  179. package/dist/normalize-identifiers.test.js.map +7 -0
  180. package/dist/normalize-qualifying-information.js +23 -48
  181. package/dist/normalize-qualifying-information.js.map +7 -1
  182. package/dist/normalize-qualifying-information.test.js +44 -0
  183. package/dist/normalize-qualifying-information.test.js.map +7 -0
  184. package/dist/normalize-utf8-diacritics.js +19 -105
  185. package/dist/normalize-utf8-diacritics.js.map +7 -1
  186. package/dist/normalize-utf8-diacritics.test.js +44 -0
  187. package/dist/normalize-utf8-diacritics.test.js.map +7 -0
  188. package/dist/normalizeFieldForComparison.js +67 -158
  189. package/dist/normalizeFieldForComparison.js.map +7 -1
  190. package/dist/normalizeSubfieldValueForComparison.js +37 -77
  191. package/dist/normalizeSubfieldValueForComparison.js.map +7 -1
  192. package/dist/prepublicationUtils.js +58 -111
  193. package/dist/prepublicationUtils.js.map +7 -1
  194. package/dist/punctuation/index.js +56 -72
  195. package/dist/punctuation/index.js.map +7 -1
  196. package/dist/punctuation/rules/aut.js +372 -331
  197. package/dist/punctuation/rules/aut.js.map +7 -1
  198. package/dist/punctuation/rules/bib.js +420 -373
  199. package/dist/punctuation/rules/bib.js.map +7 -1
  200. package/dist/punctuation/rules/index.js +7 -21
  201. package/dist/punctuation/rules/index.js.map +7 -1
  202. package/dist/punctuation.test.js +44 -0
  203. package/dist/punctuation.test.js.map +7 -0
  204. package/dist/punctuation2.js +251 -800
  205. package/dist/punctuation2.js.map +7 -1
  206. package/dist/punctuation2.test.js +44 -0
  207. package/dist/punctuation2.test.js.map +7 -0
  208. package/dist/reindexSubfield6OccurenceNumbers.js +61 -96
  209. package/dist/reindexSubfield6OccurenceNumbers.js.map +7 -1
  210. package/dist/reindexSubfield6OccurenceNumbers.test.js +44 -0
  211. package/dist/reindexSubfield6OccurenceNumbers.test.js.map +7 -0
  212. package/dist/removeDuplicateDataFields.js +102 -202
  213. package/dist/removeDuplicateDataFields.js.map +7 -1
  214. package/dist/removeDuplicateDataFields.test.js +44 -0
  215. package/dist/removeDuplicateDataFields.test.js.map +7 -0
  216. package/dist/removeInferiorDataFields.js +103 -227
  217. package/dist/removeInferiorDataFields.js.map +7 -1
  218. package/dist/removeInferiorDataFields.test.js +44 -0
  219. package/dist/removeInferiorDataFields.test.js.map +7 -0
  220. package/dist/resolvable-ext-references-melinda.js +25 -60
  221. package/dist/resolvable-ext-references-melinda.js.map +7 -1
  222. package/dist/resolvable-ext-references-melinda.test.js +160 -0
  223. package/dist/resolvable-ext-references-melinda.test.js.map +7 -0
  224. package/dist/resolveOrphanedSubfield6s.js +33 -64
  225. package/dist/resolveOrphanedSubfield6s.js.map +7 -1
  226. package/dist/resolveOrphanedSubfield6s.test.js +44 -0
  227. package/dist/resolveOrphanedSubfield6s.test.js.map +7 -0
  228. package/dist/sanitize-vocabulary-source-codes.js +27 -55
  229. package/dist/sanitize-vocabulary-source-codes.js.map +7 -1
  230. package/dist/sanitize-vocabulary-source-codes.test.js +45 -0
  231. package/dist/sanitize-vocabulary-source-codes.test.js.map +7 -0
  232. package/dist/sort-tags.js +13 -25
  233. package/dist/sort-tags.js.map +7 -1
  234. package/dist/sort-tags.test.js +261 -0
  235. package/dist/sort-tags.test.js.map +7 -0
  236. package/dist/sortFields.js +152 -222
  237. package/dist/sortFields.js.map +7 -1
  238. package/dist/sortFields.test.js +44 -0
  239. package/dist/sortFields.test.js.map +7 -0
  240. package/dist/sortRelatorTerms.js +30 -68
  241. package/dist/sortRelatorTerms.js.map +7 -1
  242. package/dist/sortRelatorTerms.test.js +44 -0
  243. package/dist/sortRelatorTerms.test.js.map +7 -0
  244. package/dist/sortSubfields.js +102 -255
  245. package/dist/sortSubfields.js.map +7 -1
  246. package/dist/sortSubfields.test.js +44 -0
  247. package/dist/sortSubfields.test.js.map +7 -0
  248. package/dist/stripPunctuation.js +13 -36
  249. package/dist/stripPunctuation.js.map +7 -1
  250. package/dist/stripPunctuation.test.js +44 -0
  251. package/dist/stripPunctuation.test.js.map +7 -0
  252. package/dist/subfield-exclusion.js +28 -75
  253. package/dist/subfield-exclusion.js.map +7 -1
  254. package/dist/subfield-exclusion.test.js +471 -0
  255. package/dist/subfield-exclusion.test.js.map +7 -0
  256. package/dist/subfield6Utils.js +107 -269
  257. package/dist/subfield6Utils.js.map +7 -1
  258. package/dist/subfield8Utils.js +26 -50
  259. package/dist/subfield8Utils.js.map +7 -1
  260. package/dist/subfieldValueNormalizations.js +40 -74
  261. package/dist/subfieldValueNormalizations.js.map +7 -1
  262. package/dist/subfieldValueNormalizations.test.js +45 -0
  263. package/dist/subfieldValueNormalizations.test.js.map +7 -0
  264. package/dist/sync-007-and-300.js +22 -53
  265. package/dist/sync-007-and-300.js.map +7 -1
  266. package/dist/sync-007-and-300.test.js +44 -0
  267. package/dist/sync-007-and-300.test.js.map +7 -0
  268. package/dist/translate-terms.js +67 -155
  269. package/dist/translate-terms.js.map +7 -1
  270. package/dist/translate-terms.test.js +44 -0
  271. package/dist/translate-terms.test.js.map +7 -0
  272. package/dist/typeOfDate-008.js +10 -25
  273. package/dist/typeOfDate-008.js.map +7 -1
  274. package/dist/typeOfDate-008.test.js +40 -0
  275. package/dist/typeOfDate-008.test.js.map +7 -0
  276. package/dist/unicode-decomposition.js +94 -107
  277. package/dist/unicode-decomposition.js.map +7 -1
  278. package/dist/unicode-decomposition.test.js +94 -0
  279. package/dist/unicode-decomposition.test.js.map +7 -0
  280. package/dist/update-field-540.js +30 -75
  281. package/dist/update-field-540.js.map +7 -1
  282. package/dist/update-field-540.test.js +44 -0
  283. package/dist/update-field-540.test.js.map +7 -0
  284. package/dist/urn.js +55 -128
  285. package/dist/urn.js.map +7 -1
  286. package/dist/urn.test.js +44 -0
  287. package/dist/urn.test.js.map +7 -0
  288. package/dist/utils.js +72 -126
  289. package/dist/utils.js.map +7 -1
  290. package/eslint.config.mjs +1 -2
  291. package/package.json +21 -93
  292. package/src/access-rights.js +1 -1
  293. package/src/{access-rights.spec.js → access-rights.test.js} +9 -10
  294. package/src/addMissingField041.js +1 -1
  295. package/src/{addMissingField336.spec.js → addMissingField041.test.js} +13 -14
  296. package/src/addMissingField336.js +3 -3
  297. package/src/{addMissingField041.spec.js → addMissingField336.test.js} +13 -14
  298. package/src/addMissingField337.js +2 -2
  299. package/src/{addMissingField337.spec.js → addMissingField337.test.js} +13 -14
  300. package/src/addMissingField338.js +2 -2
  301. package/src/{addMissingField338.spec.js → addMissingField338.test.js} +13 -14
  302. package/src/cyrillux-usemarcon-replacement.js +18 -18
  303. package/src/cyrillux-usemarcon-replacement.test.js +55 -0
  304. package/src/cyrillux.js +19 -12
  305. package/src/{cyrillux.spec.js → cyrillux.test.js} +13 -14
  306. package/src/disambiguateSeriesStatements.js +2 -2
  307. package/src/{disambiguateSeriesStatements.spec.js → disambiguateSeriesStatements.test.js} +12 -13
  308. package/src/double-commas.js +1 -1
  309. package/src/{double-commas.spec.js → double-commas.test.js} +9 -11
  310. package/src/duplicates-ind1.js +1 -1
  311. package/src/{duplicates-ind1.spec.js → duplicates-ind1.test.js} +12 -13
  312. package/src/{empty-fields.spec.js → empty-fields.test.js} +11 -13
  313. package/src/ending-punctuation.js +1 -1
  314. package/src/{ending-punctuation.spec.js → ending-punctuation.test.js} +172 -173
  315. package/src/{ending-whitespace.spec.js → ending-whitespace.test.js} +12 -13
  316. package/src/field-008-18-34-character-groups.js +2 -2
  317. package/src/{field-008-18-34-character-groups.spec.js → field-008-18-34-character-groups.test.js} +13 -13
  318. package/src/field-505-separators.js +3 -3
  319. package/src/{field-505-separators.spec.js → field-505-separators.test.js} +16 -14
  320. package/src/field-521-fix.js +2 -2
  321. package/src/{field-521-fix.spec.js → field-521-fix.test.js} +12 -13
  322. package/src/field-exclusion.js +1 -1
  323. package/src/{field-exclusion.spec.js → field-exclusion.test.js} +60 -57
  324. package/src/{field-structure.spec.js → field-structure.test.js} +29 -29
  325. package/src/{fields-present.spec.js → fields-present.test.js} +12 -15
  326. package/src/fix-33X.js +4 -4
  327. package/src/{fix-33X.spec.js → fix-33X.test.js} +13 -14
  328. package/src/fix-country-codes.js +1 -1
  329. package/src/{fix-country-codes.spec.js → fix-country-codes.test.js} +12 -13
  330. package/src/fix-language-codes.js +5 -5
  331. package/src/{fix-language-codes.spec.js → fix-language-codes.test.js} +12 -13
  332. package/src/fixRelatorTerms.js +5 -5
  333. package/src/{fixRelatorTerms.spec.js → fixRelatorTerms.test.js} +13 -13
  334. package/src/{fixed-fields.spec.js → fixed-fields.test.js} +11 -14
  335. package/src/identical-fields.js +1 -1
  336. package/src/{identical-fields.spec.js → identical-fields.test.js} +9 -11
  337. package/src/indicator-fixes.js +3 -3
  338. package/src/{indicator-fixes.spec.js → indicator-fixes.test.js} +9 -12
  339. package/src/isbn-issn.js +1 -1
  340. package/src/{isbn-issn.spec.js → isbn-issn.test.js} +20 -22
  341. package/src/{item-language.spec.js → item-language.test.js} +21 -22
  342. package/src/merge-fields/controlSubfields.js +1 -1
  343. package/src/merge-fields/counterpartField.js +8 -9
  344. package/src/merge-fields/index.js +1 -1
  345. package/src/merge-fields/mergableIndicator.js +1 -1
  346. package/src/merge-fields/mergeField.js +6 -6
  347. package/src/merge-fields/mergeIndicator.js +1 -1
  348. package/src/merge-fields/mergeOrAddPostprocess.js +4 -4
  349. package/src/merge-fields/mergeOrAddSubfield.js +2 -2
  350. package/src/merge-fields/mergeSubfield.js +4 -4
  351. package/src/merge-fields/removeDuplicateSubfields.js +2 -2
  352. package/src/{merge-fields.spec.js → merge-fields.test.js} +12 -13
  353. package/src/{mergeField500Lisapainokset.spec.js → mergeField500Lisapainokset.test.js} +12 -13
  354. package/src/mergeRelatorTermFields.js +5 -7
  355. package/src/{mergeRelatorTermFields.spec.js → mergeRelatorTermFields.test.js} +12 -13
  356. package/src/modernize-502.js +1 -1
  357. package/src/{modernize-502.spec.js → modernize-502.test.js} +12 -13
  358. package/src/multiple-subfield-0.js +3 -3
  359. package/src/{multiple-subfield-0.spec.js → multiple-subfield-0.test.js} +13 -13
  360. package/src/{non-breaking-space.spec.js → non-breaking-space.test.js} +12 -13
  361. package/src/normalize-dashes.js +2 -2
  362. package/src/{normalize-dashes.spec.js → normalize-dashes.test.js} +12 -13
  363. package/src/normalize-identifiers.js +1 -1
  364. package/src/{normalize-identifiers.spec.js → normalize-identifiers.test.js} +12 -13
  365. package/src/normalize-qualifying-information.js +2 -2
  366. package/src/{normalize-qualifying-information.spec.js → normalize-qualifying-information.test.js} +12 -13
  367. package/src/normalize-utf8-diacritics.js +2 -2
  368. package/src/{normalize-utf8-diacritics.spec.js → normalize-utf8-diacritics.test.js} +13 -13
  369. package/src/normalizeFieldForComparison.js +6 -6
  370. package/src/normalizeSubfieldValueForComparison.js +1 -1
  371. package/src/prepublicationUtils.js +4 -4
  372. package/src/punctuation/index.js +1 -1
  373. package/src/punctuation/rules/index.js +2 -2
  374. package/src/{punctuation.spec.js → punctuation.test.js} +12 -13
  375. package/src/punctuation2.js +4 -4
  376. package/src/{punctuation2.spec.js → punctuation2.test.js} +12 -13
  377. package/src/reindexSubfield6OccurenceNumbers.js +5 -7
  378. package/src/{reindexSubfield6OccurenceNumbers.spec.js → reindexSubfield6OccurenceNumbers.test.js} +12 -13
  379. package/src/removeDuplicateDataFields.js +11 -19
  380. package/src/{removeDuplicateDataFields.spec.js → removeDuplicateDataFields.test.js} +12 -13
  381. package/src/removeInferiorDataFields.js +11 -11
  382. package/src/{removeInferiorDataFields.spec.js → removeInferiorDataFields.test.js} +13 -13
  383. package/src/resolvable-ext-references-melinda.js +1 -1
  384. package/src/{resolvable-ext-references-melinda.spec.js → resolvable-ext-references-melinda.test.js} +42 -27
  385. package/src/resolveOrphanedSubfield6s.js +5 -5
  386. package/src/{resolveOrphanedSubfield6s.spec.js → resolveOrphanedSubfield6s.test.js} +13 -13
  387. package/src/sanitize-vocabulary-source-codes.js +4 -4
  388. package/src/{sanitize-vocabulary-source-codes.spec.js → sanitize-vocabulary-source-codes.test.js} +16 -14
  389. package/src/{sort-tags.spec.js → sort-tags.test.js} +9 -11
  390. package/src/sortFields.js +4 -4
  391. package/src/{sortFields.spec.js → sortFields.test.js} +12 -13
  392. package/src/sortRelatorTerms.js +3 -3
  393. package/src/{sortRelatorTerms.spec.js → sortRelatorTerms.test.js} +13 -13
  394. package/src/sortSubfields.js +1 -1
  395. package/src/{sortSubfields.spec.js → sortSubfields.test.js} +13 -13
  396. package/src/stripPunctuation.js +3 -3
  397. package/src/{stripPunctuation.spec.js → stripPunctuation.test.js} +13 -13
  398. package/src/subfield-exclusion.js +1 -1
  399. package/src/{subfield-exclusion.spec.js → subfield-exclusion.test.js} +45 -36
  400. package/src/subfield6Utils.js +6 -10
  401. package/src/subfield8Utils.js +4 -4
  402. package/src/subfieldValueNormalizations.js +3 -3
  403. package/src/{subfieldValueNormalizations.spec.js → subfieldValueNormalizations.test.js} +18 -14
  404. package/src/sync-007-and-300.js +2 -2
  405. package/src/{sync-007-and-300.spec.js → sync-007-and-300.test.js} +13 -13
  406. package/src/translate-terms.js +3 -3
  407. package/src/{translate-terms.spec.js → translate-terms.test.js} +13 -13
  408. package/src/{typeOfDate-008.spec.js → typeOfDate-008.test.js} +12 -13
  409. package/src/{unicode-decomposition.spec.js → unicode-decomposition.test.js} +10 -16
  410. package/src/update-field-540.js +2 -2
  411. package/src/{update-field-540.spec.js → update-field-540.test.js} +13 -10
  412. package/src/urn.js +2 -2
  413. package/src/{urn.spec.js → urn.test.js} +12 -13
  414. package/src/utils.js +3 -3
  415. package/test-fixtures/field-505-separators/03/expectedResult.json +3 -1
  416. package/test-fixtures/field-505-separators/03/record.json +3 -0
  417. package/test-fixtures/normalize-subfield-value/01/metadata.json +4 -1
  418. package/test-fixtures/normalize-subfield-value/01/record.json +3 -0
  419. package/test-fixtures/normalize-subfield-value/02/expectedResult.json +3 -1
  420. package/test-fixtures/normalize-subfield-value/02/metadata.json +2 -1
  421. package/test-fixtures/normalize-subfield-value/02/record.json +3 -0
  422. package/test-fixtures/sanitize-vocabulary-source-codes/f03/expectedResult.json +3 -1
  423. package/test-fixtures/sanitize-vocabulary-source-codes/f04/expectedResult.json +3 -1
  424. package/test-fixtures/sanitize-vocabulary-source-codes/v04/metadata.json +1 -4
  425. package/test-fixtures/sanitize-vocabulary-source-codes/v04/record.json +1 -1
  426. package/dist/access-rights.spec.js +0 -195
  427. package/dist/access-rights.spec.js.map +0 -1
  428. package/dist/addMissingField041.spec.js +0 -45
  429. package/dist/addMissingField041.spec.js.map +0 -1
  430. package/dist/addMissingField336.spec.js +0 -45
  431. package/dist/addMissingField336.spec.js.map +0 -1
  432. package/dist/addMissingField337.spec.js +0 -43
  433. package/dist/addMissingField337.spec.js.map +0 -1
  434. package/dist/addMissingField338.spec.js +0 -45
  435. package/dist/addMissingField338.spec.js.map +0 -1
  436. package/dist/cyrillux-usemarcon-replacement.spec.js +0 -45
  437. package/dist/cyrillux-usemarcon-replacement.spec.js.map +0 -1
  438. package/dist/cyrillux.spec.js +0 -46
  439. package/dist/cyrillux.spec.js.map +0 -1
  440. package/dist/disambiguateSeriesStatements.spec.js +0 -51
  441. package/dist/disambiguateSeriesStatements.spec.js.map +0 -1
  442. package/dist/double-commas.spec.js +0 -73
  443. package/dist/double-commas.spec.js.map +0 -1
  444. package/dist/duplicates-ind1.spec.js +0 -45
  445. package/dist/duplicates-ind1.spec.js.map +0 -1
  446. package/dist/empty-fields.spec.js +0 -118
  447. package/dist/empty-fields.spec.js.map +0 -1
  448. package/dist/ending-punctuation.spec.js +0 -2654
  449. package/dist/ending-punctuation.spec.js.map +0 -1
  450. package/dist/ending-whitespace.spec.js +0 -42
  451. package/dist/ending-whitespace.spec.js.map +0 -1
  452. package/dist/field-008-18-34-character-groups.spec.js +0 -51
  453. package/dist/field-008-18-34-character-groups.spec.js.map +0 -1
  454. package/dist/field-505-separators.spec.js +0 -51
  455. package/dist/field-505-separators.spec.js.map +0 -1
  456. package/dist/field-521-fix.spec.js +0 -51
  457. package/dist/field-521-fix.spec.js.map +0 -1
  458. package/dist/field-exclusion.spec.js +0 -1054
  459. package/dist/field-exclusion.spec.js.map +0 -1
  460. package/dist/field-structure.spec.js +0 -535
  461. package/dist/field-structure.spec.js.map +0 -1
  462. package/dist/fields-present.spec.js +0 -121
  463. package/dist/fields-present.spec.js.map +0 -1
  464. package/dist/fix-33X.spec.js +0 -45
  465. package/dist/fix-33X.spec.js.map +0 -1
  466. package/dist/fix-country-codes.spec.js +0 -51
  467. package/dist/fix-country-codes.spec.js.map +0 -1
  468. package/dist/fix-language-codes.spec.js +0 -44
  469. package/dist/fix-language-codes.spec.js.map +0 -1
  470. package/dist/fixRelatorTerms.spec.js +0 -51
  471. package/dist/fixRelatorTerms.spec.js.map +0 -1
  472. package/dist/fixed-fields.spec.js +0 -140
  473. package/dist/fixed-fields.spec.js.map +0 -1
  474. package/dist/identical-fields.spec.js +0 -99
  475. package/dist/identical-fields.spec.js.map +0 -1
  476. package/dist/indicator-fixes.spec.js +0 -51
  477. package/dist/indicator-fixes.spec.js.map +0 -1
  478. package/dist/isbn-issn.spec.js +0 -595
  479. package/dist/isbn-issn.spec.js.map +0 -1
  480. package/dist/item-language.spec.js +0 -306
  481. package/dist/item-language.spec.js.map +0 -1
  482. package/dist/melindaCustomMergeFields.json +0 -5120
  483. package/dist/merge-fields.spec.js +0 -51
  484. package/dist/merge-fields.spec.js.map +0 -1
  485. package/dist/mergeField500Lisapainokset.spec.js +0 -51
  486. package/dist/mergeField500Lisapainokset.spec.js.map +0 -1
  487. package/dist/mergeRelatorTermFields.spec.js +0 -51
  488. package/dist/mergeRelatorTermFields.spec.js.map +0 -1
  489. package/dist/modernize-502.spec.js +0 -49
  490. package/dist/modernize-502.spec.js.map +0 -1
  491. package/dist/multiple-subfield-0.spec.js +0 -51
  492. package/dist/multiple-subfield-0.spec.js.map +0 -1
  493. package/dist/non-breaking-space.spec.js +0 -42
  494. package/dist/non-breaking-space.spec.js.map +0 -1
  495. package/dist/normalize-dashes.spec.js +0 -51
  496. package/dist/normalize-dashes.spec.js.map +0 -1
  497. package/dist/normalize-identifiers.spec.js +0 -51
  498. package/dist/normalize-identifiers.spec.js.map +0 -1
  499. package/dist/normalize-qualifying-information.spec.js +0 -51
  500. package/dist/normalize-qualifying-information.spec.js.map +0 -1
  501. package/dist/normalize-utf8-diacritics.spec.js +0 -51
  502. package/dist/normalize-utf8-diacritics.spec.js.map +0 -1
  503. package/dist/punctuation.spec.js +0 -51
  504. package/dist/punctuation.spec.js.map +0 -1
  505. package/dist/punctuation2.spec.js +0 -51
  506. package/dist/punctuation2.spec.js.map +0 -1
  507. package/dist/reindexSubfield6OccurenceNumbers.spec.js +0 -51
  508. package/dist/reindexSubfield6OccurenceNumbers.spec.js.map +0 -1
  509. package/dist/removeDuplicateDataFields.spec.js +0 -51
  510. package/dist/removeDuplicateDataFields.spec.js.map +0 -1
  511. package/dist/removeInferiorDataFields.spec.js +0 -51
  512. package/dist/removeInferiorDataFields.spec.js.map +0 -1
  513. package/dist/resolvable-ext-references-melinda.spec.js +0 -166
  514. package/dist/resolvable-ext-references-melinda.spec.js.map +0 -1
  515. package/dist/resolveOrphanedSubfield6s.spec.js +0 -51
  516. package/dist/resolveOrphanedSubfield6s.spec.js.map +0 -1
  517. package/dist/sanitize-vocabulary-source-codes.spec.js +0 -51
  518. package/dist/sanitize-vocabulary-source-codes.spec.js.map +0 -1
  519. package/dist/sort-tags.spec.js +0 -207
  520. package/dist/sort-tags.spec.js.map +0 -1
  521. package/dist/sortFields.spec.js +0 -51
  522. package/dist/sortFields.spec.js.map +0 -1
  523. package/dist/sortRelatorTerms.spec.js +0 -51
  524. package/dist/sortRelatorTerms.spec.js.map +0 -1
  525. package/dist/sortSubfields.spec.js +0 -52
  526. package/dist/sortSubfields.spec.js.map +0 -1
  527. package/dist/stripPunctuation.spec.js +0 -51
  528. package/dist/stripPunctuation.spec.js.map +0 -1
  529. package/dist/subfield-exclusion.spec.js +0 -523
  530. package/dist/subfield-exclusion.spec.js.map +0 -1
  531. package/dist/subfieldValueNormalizations.spec.js +0 -51
  532. package/dist/subfieldValueNormalizations.spec.js.map +0 -1
  533. package/dist/sync-007-and-300.spec.js +0 -51
  534. package/dist/sync-007-and-300.spec.js.map +0 -1
  535. package/dist/translate-terms.spec.js +0 -51
  536. package/dist/translate-terms.spec.js.map +0 -1
  537. package/dist/typeOfDate-008.spec.js +0 -47
  538. package/dist/typeOfDate-008.spec.js.map +0 -1
  539. package/dist/unicode-decomposition.spec.js +0 -91
  540. package/dist/unicode-decomposition.spec.js.map +0 -1
  541. package/dist/update-field-540.spec.js +0 -51
  542. package/dist/update-field-540.spec.js.map +0 -1
  543. package/dist/urn.spec.js +0 -52
  544. package/dist/urn.spec.js.map +0 -1
  545. package/src/cyrillux-usemarcon-replacement.spec.js +0 -47
@@ -0,0 +1,471 @@
1
+ import assert from "node:assert";
2
+ import { MarcRecord } from "@natlibfi/marc-record";
3
+ import validatorFactory from "../src/subfield-exclusion.js";
4
+ import { describe, it } from "node:test";
5
+ describe("subfield-exclusion", () => {
6
+ describe("#validate: Check configuration validation", () => {
7
+ it("Creates a validator from simple config", async () => {
8
+ const config = [
9
+ {
10
+ tag: /^500$/u,
11
+ subfields: [{ code: /4/u }]
12
+ }
13
+ ];
14
+ const validator = await validatorFactory(config);
15
+ assert.equal(typeof validator, "object");
16
+ assert.equal(typeof validator.description, "string");
17
+ assert.equal(typeof validator.validate, "function");
18
+ });
19
+ it("Creates a validator from complex config", async () => {
20
+ const config = [
21
+ {
22
+ tag: /^210$/u,
23
+ ind2: /\s/u,
24
+ subfields: [
25
+ {
26
+ code: /2/u,
27
+ value: /.+/u
28
+ }
29
+ ]
30
+ }
31
+ ];
32
+ const validator = await validatorFactory(config);
33
+ assert.equal(typeof validator, "object");
34
+ assert.equal(typeof validator.description, "string");
35
+ assert.equal(typeof validator.validate, "function");
36
+ });
37
+ it("Fails to create a validator from invalid config - subfields missing", () => {
38
+ const config = [
39
+ {
40
+ tag: /^210$/u
41
+ }
42
+ ];
43
+ try {
44
+ validatorFactory(config);
45
+ } catch (error) {
46
+ assert.equal(error instanceof Error, true);
47
+ assert.equal(error.message, "Configuration not valid - missing mandatory element: subfields");
48
+ }
49
+ });
50
+ it("Fails to create a validator from invalid config - tag", () => {
51
+ const config = [
52
+ {
53
+ tag: "500",
54
+ subfields: [{ code: /9/u, value: /^(?!FENNI<KEEP>).*$/u }]
55
+ }
56
+ ];
57
+ try {
58
+ validatorFactory(config);
59
+ } catch (error) {
60
+ assert.equal(error instanceof Error, true);
61
+ assert.equal(error.message, "Configuration not valid - invalid data type for: tag");
62
+ }
63
+ });
64
+ it("Fails to create a validator from invalid config - missing array", () => {
65
+ const config = {
66
+ tag: "500",
67
+ subfields: [{ code: /9/u, value: /^(?!FENNI<KEEP>).*$/u }]
68
+ };
69
+ try {
70
+ validatorFactory(config);
71
+ } catch (error) {
72
+ assert.equal(error instanceof Error, true);
73
+ assert.equal(error.message, "Configuration array not provided");
74
+ }
75
+ });
76
+ it("Fails to create a validator from invalid config - code", () => {
77
+ const config = [
78
+ {
79
+ tag: /^500$/u,
80
+ subfields: [{ code: 9, value: /^(?!FENNI<KEEP>).*$/u }]
81
+ }
82
+ ];
83
+ try {
84
+ validatorFactory(config);
85
+ } catch (error) {
86
+ assert.equal(error instanceof Error, true);
87
+ assert.equal(error.message, "Configuration not valid - invalid data type for: code");
88
+ }
89
+ });
90
+ it("Fails to create a validator from invalid config - value", () => {
91
+ const config = [
92
+ {
93
+ tag: /^500$/u,
94
+ subfields: [{ code: /9/u, value: "Fenni" }]
95
+ }
96
+ ];
97
+ try {
98
+ validatorFactory(config);
99
+ } catch (error) {
100
+ assert.equal(error instanceof Error, true);
101
+ assert.equal(error.message, "Configuration not valid - invalid data type for: value");
102
+ }
103
+ });
104
+ it("Fails to create a validator from invalid config - missing mandatory: tag", () => {
105
+ const config = [
106
+ {
107
+ value: /^500$/u,
108
+ subfields: [{ code: /9/u, value: /^(?!FENNI<KEEP>).*$/u }]
109
+ }
110
+ ];
111
+ try {
112
+ validatorFactory(config);
113
+ } catch (error) {
114
+ assert.equal(error instanceof Error, true);
115
+ assert.equal(error.message, "Configuration not valid - missing mandatory element: tag");
116
+ }
117
+ });
118
+ it("Fails to create a validator from invalid config - subfield not object: array", () => {
119
+ const config = [
120
+ {
121
+ tag: /^500$/u,
122
+ subfields: [
123
+ ["/9/", "/^(?!FENNI<KEEP>).*$/"],
124
+ { value: /^(?!FENNI<KEEP>).*$/u }
125
+ ]
126
+ }
127
+ ];
128
+ try {
129
+ validatorFactory(config);
130
+ } catch (error) {
131
+ assert.equal(error instanceof Error, true);
132
+ assert.equal(error.message, "Configuration not valid - subfield: /9/,/^(?!FENNI<KEEP>).*$/ not object");
133
+ }
134
+ });
135
+ it("Fails to create a validator from invalid config - subfield not object: string", () => {
136
+ const config = [
137
+ {
138
+ tag: /^500$/u,
139
+ subfields: [
140
+ "/9/",
141
+ "/^(?!FENNI<KEEP>).*$/",
142
+ { value: /^(?!FENNI<KEEP>).*$/u }
143
+ ]
144
+ }
145
+ ];
146
+ try {
147
+ validatorFactory(config);
148
+ } catch (error) {
149
+ assert.equal(error instanceof Error, true);
150
+ assert.equal(error.message, "Configuration not valid - subfield: /9/ not object");
151
+ }
152
+ });
153
+ it("Fails to create a validator from invalid config - missing mandatory: subfield.code", () => {
154
+ const config = [
155
+ {
156
+ tag: /^500$/u,
157
+ subfields: [
158
+ { code: /9/u, value: /^(?!FENNI<KEEP>).*$/u },
159
+ { value: /^(?!FENNI<KEEP>).*$/u }
160
+ ]
161
+ }
162
+ ];
163
+ try {
164
+ validatorFactory(config);
165
+ } catch (error) {
166
+ assert.equal(error instanceof Error, true);
167
+ assert.equal(error.message, "Configuration not valid - missing mandatory element: code");
168
+ }
169
+ });
170
+ it("Fails to create a validator from invalid config - unidentified field: unidentified", () => {
171
+ const config = [
172
+ {
173
+ tag: /^500$/u,
174
+ unidentified: /^500$/u,
175
+ subfields: [
176
+ { code: /9/u, value: /^(?!FENNI<KEEP>).*$/u },
177
+ { value: /^(?!FENNI<KEEP>).*$/u }
178
+ ]
179
+ }
180
+ ];
181
+ try {
182
+ validatorFactory(config);
183
+ } catch (error) {
184
+ assert.equal(error instanceof Error, true);
185
+ assert.equal(error.message, "Configuration not valid - unidentified value: unidentified");
186
+ }
187
+ });
188
+ });
189
+ describe("#validate: Simple configuration (spec)", () => {
190
+ const config = [
191
+ {
192
+ tag: /^100$/u,
193
+ subfields: [{ code: /4/u }]
194
+ }
195
+ ];
196
+ const recordValid = new MarcRecord({
197
+ leader: "foo",
198
+ fields: [
199
+ {
200
+ tag: "100",
201
+ ind1: " ",
202
+ ind2: " ",
203
+ subfields: [{ code: "a", value: "Foo Bar" }]
204
+ },
205
+ {
206
+ tag: "245",
207
+ ind1: " ",
208
+ ind2: " ",
209
+ subfields: [{ code: "a", value: "Fubar" }]
210
+ }
211
+ ]
212
+ });
213
+ const recordInvalid = new MarcRecord({
214
+ leader: "foo",
215
+ fields: [
216
+ {
217
+ tag: "100",
218
+ ind1: " ",
219
+ ind2: " ",
220
+ subfields: [
221
+ { code: "a", value: "Foo Bar" },
222
+ { code: "4", value: "att" }
223
+ ]
224
+ },
225
+ {
226
+ tag: "245",
227
+ ind1: " ",
228
+ ind2: " ",
229
+ subfields: [{ code: "a", value: "Fubar" }]
230
+ }
231
+ ]
232
+ });
233
+ const recordInvalidFixed = new MarcRecord({
234
+ leader: "foo",
235
+ fields: [
236
+ {
237
+ tag: "100",
238
+ ind1: " ",
239
+ ind2: " ",
240
+ subfields: [{ code: "a", value: "Foo Bar" }]
241
+ },
242
+ {
243
+ tag: "245",
244
+ ind1: " ",
245
+ ind2: " ",
246
+ subfields: [{ code: "a", value: "Fubar" }]
247
+ }
248
+ ]
249
+ });
250
+ it("Finds the record valid (spec)", async () => {
251
+ const validator = await validatorFactory(config);
252
+ const result = await validator.validate(recordValid);
253
+ assert.deepEqual(result, { valid: true, message: [] });
254
+ });
255
+ it("Finds the record invalid (spec)", async () => {
256
+ const validator = await validatorFactory(config);
257
+ const result = await validator.validate(recordInvalid);
258
+ assert.deepEqual(result, { valid: false, message: ["Subfield $100$$4should be excluded"] });
259
+ });
260
+ it("Repairs invalid record", async () => {
261
+ const validator = await validatorFactory(config);
262
+ await validator.fix(recordInvalid);
263
+ assert(recordInvalid.equalsTo(recordInvalidFixed), true);
264
+ });
265
+ });
266
+ describe("#validate: Remove only subfield -> remove field as well", () => {
267
+ const config = [
268
+ {
269
+ tag: /^041$/u,
270
+ subfields: [{ code: /^[ad]$/u, value: /^zxx$/u }]
271
+ }
272
+ ];
273
+ const recordOriginal = new MarcRecord({
274
+ leader: "foo",
275
+ fields: [
276
+ {
277
+ tag: "041",
278
+ ind1: " ",
279
+ ind2: " ",
280
+ subfields: [{ code: "a", value: "zxx" }]
281
+ },
282
+ {
283
+ tag: "245",
284
+ ind1: " ",
285
+ ind2: " ",
286
+ subfields: [{ code: "a", value: "Fubar" }]
287
+ }
288
+ ]
289
+ });
290
+ const recordModified = new MarcRecord({
291
+ leader: "foo",
292
+ fields: [
293
+ {
294
+ tag: "245",
295
+ ind1: " ",
296
+ ind2: " ",
297
+ subfields: [{ code: "a", value: "Fubar" }]
298
+ }
299
+ ]
300
+ });
301
+ it("Finds the record with 041$a zxx invalid (spec)", async () => {
302
+ const validator = await validatorFactory(config);
303
+ const result = await validator.validate(recordOriginal);
304
+ assert.deepEqual(result, { valid: false, message: ["Subfield $041$$ashould be excluded"] });
305
+ });
306
+ it("Repairs invalid record", async () => {
307
+ const validator = await validatorFactory(config);
308
+ await validator.fix(recordOriginal);
309
+ assert.equal(recordOriginal.equalsTo(recordModified), true);
310
+ });
311
+ });
312
+ describe("#validate: Complex configuration (spec)", () => {
313
+ const config = [
314
+ {
315
+ tag: /^210$/u,
316
+ ind2: /\s/u,
317
+ subfields: [{ code: /2/u, value: /.+/u }]
318
+ }
319
+ ];
320
+ const recordValid = new MarcRecord({
321
+ leader: "foo",
322
+ fields: [
323
+ {
324
+ tag: "210",
325
+ ind1: " ",
326
+ ind2: " ",
327
+ subfields: [{ code: "a", value: "Foo" }]
328
+ },
329
+ {
330
+ tag: "245",
331
+ ind1: " ",
332
+ ind2: " ",
333
+ subfields: [{ code: "a", value: "Fubar" }]
334
+ }
335
+ ]
336
+ });
337
+ const recordInvalid = new MarcRecord({
338
+ leader: "foo",
339
+ fields: [
340
+ {
341
+ tag: "210",
342
+ ind1: " ",
343
+ ind2: " ",
344
+ subfields: [
345
+ { code: "a", value: "Foo" },
346
+ { code: "2", value: "dnlm" }
347
+ ]
348
+ },
349
+ {
350
+ tag: "245",
351
+ ind1: " ",
352
+ ind2: " ",
353
+ subfields: [{ code: "a", value: "Fubar" }]
354
+ }
355
+ ]
356
+ });
357
+ const recordInvalidFixed = new MarcRecord({
358
+ leader: "foo",
359
+ fields: [
360
+ {
361
+ tag: "210",
362
+ ind1: " ",
363
+ ind2: " ",
364
+ subfields: [{ code: "a", value: "Foo" }]
365
+ },
366
+ {
367
+ tag: "245",
368
+ ind1: " ",
369
+ ind2: " ",
370
+ subfields: [{ code: "a", value: "Fubar" }]
371
+ }
372
+ ]
373
+ });
374
+ it("Finds the record valid (spec)", async () => {
375
+ const validator = await validatorFactory(config);
376
+ const result = await validator.validate(recordValid);
377
+ assert.deepEqual(result, { valid: true, message: [] });
378
+ });
379
+ it("Finds the record invalid (spec)", async () => {
380
+ const validator = await validatorFactory(config);
381
+ const result = await validator.validate(recordInvalid);
382
+ assert.deepEqual(result, { valid: false, message: ["Subfield $210$$2should be excluded"] });
383
+ });
384
+ it("Repairs invalid record", async () => {
385
+ const validator = await validatorFactory(config);
386
+ await validator.fix(recordInvalid);
387
+ assert.equal(recordInvalid.equalsTo(recordInvalidFixed), true);
388
+ });
389
+ });
390
+ describe("#validate: Custom configuration", () => {
391
+ const configInd = [
392
+ {
393
+ tag: /^500$/u,
394
+ ind1: /^8$/u,
395
+ ind2: /^4$/u,
396
+ subfields: [{ code: /2/u, value: /.+/u }]
397
+ }
398
+ ];
399
+ const recordValid = new MarcRecord({
400
+ leader: "foo",
401
+ fields: [
402
+ {
403
+ tag: "210",
404
+ ind1: " ",
405
+ ind2: " ",
406
+ subfields: [{ code: "a", value: "Foo" }]
407
+ },
408
+ {
409
+ tag: "500",
410
+ subfields: [
411
+ { code: "a", value: "Foo" },
412
+ { code: "2", value: "dnlm" }
413
+ ]
414
+ }
415
+ ]
416
+ });
417
+ const recordIndInvalid = new MarcRecord({
418
+ leader: "foo",
419
+ fields: [
420
+ {
421
+ tag: "245",
422
+ ind1: " ",
423
+ ind2: " ",
424
+ subfields: [{ code: "a", value: "Fubar" }]
425
+ },
426
+ {
427
+ tag: "500",
428
+ ind1: "8",
429
+ ind2: "4",
430
+ subfields: [
431
+ { code: "a", value: "Foo" },
432
+ { code: "2", value: "dnlm" }
433
+ ]
434
+ }
435
+ ]
436
+ });
437
+ const recordIndInvalidFixed = new MarcRecord({
438
+ leader: "foo",
439
+ fields: [
440
+ {
441
+ tag: "245",
442
+ ind1: " ",
443
+ ind2: " ",
444
+ subfields: [{ code: "a", value: "Fubar" }]
445
+ },
446
+ {
447
+ tag: "500",
448
+ ind1: "8",
449
+ ind2: "4",
450
+ subfields: [{ code: "a", value: "Foo" }]
451
+ }
452
+ ]
453
+ });
454
+ it("Finds the record valid - Ind1&Ind2", async () => {
455
+ const validator = await validatorFactory(configInd);
456
+ const result = await validator.validate(recordValid);
457
+ assert.deepEqual(result, { valid: true, message: [] });
458
+ });
459
+ it("Finds the record invalid - Ind", async () => {
460
+ const validator = await validatorFactory(configInd);
461
+ const result = await validator.validate(recordIndInvalid);
462
+ assert.deepEqual(result, { valid: false, message: ["Subfield $500$$2should be excluded"] });
463
+ });
464
+ it("Repairs invalid record", async () => {
465
+ const validator = await validatorFactory(configInd);
466
+ await validator.fix(recordIndInvalid);
467
+ assert.equal(recordIndInvalid.equalsTo(recordIndInvalidFixed), true);
468
+ });
469
+ });
470
+ });
471
+ //# sourceMappingURL=subfield-exclusion.test.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/subfield-exclusion.test.js"],
4
+ "sourcesContent": ["import assert from 'node:assert';\nimport {MarcRecord} from '@natlibfi/marc-record';\nimport validatorFactory from '../src/subfield-exclusion.js';\nimport {describe, it} from 'node:test';\n\n//chai.use(chaiAsPromised);\n\n// Factory validation\ndescribe('subfield-exclusion', () => {\n describe('#validate: Check configuration validation', () => {\n it('Creates a validator from simple config', async () => {\n const config = [\n {\n tag: /^500$/u,\n subfields: [{code: /4/u}]\n }\n ];\n\n const validator = await validatorFactory(config);\n assert.equal(typeof validator, 'object');\n assert.equal(typeof validator.description, 'string');\n assert.equal(typeof validator.validate, 'function');\n });\n\n it('Creates a validator from complex config', async () => {\n const config = [\n {\n tag: /^210$/u,\n ind2: /\\s/u,\n subfields: [\n {\n code: /2/u,\n value: /.+/u\n }\n ]\n }\n ];\n\n const validator = await validatorFactory(config);\n assert.equal(typeof validator, 'object');\n assert.equal(typeof validator.description, 'string');\n assert.equal(typeof validator.validate, 'function');\n });\n\n it('Fails to create a validator from invalid config - subfields missing', () => {\n const config = [\n {\n tag: /^210$/u\n }\n ];\n\n try {\n validatorFactory(config);\n } catch (error) {\n assert.equal(error instanceof Error, true);\n assert.equal(error.message, 'Configuration not valid - missing mandatory element: subfields');\n }\n });\n\n it('Fails to create a validator from invalid config - tag', () => {\n const config = [\n {\n tag: '500',\n subfields: [{code: /9/u, value: /^(?!FENNI<KEEP>).*$/u}]\n }\n ];\n\n try {\n validatorFactory(config);\n } catch (error) {\n assert.equal(error instanceof Error, true);\n assert.equal(error.message, 'Configuration not valid - invalid data type for: tag');\n }\n });\n\n it('Fails to create a validator from invalid config - missing array', () => {\n const config = {\n tag: '500',\n subfields: [{code: /9/u, value: /^(?!FENNI<KEEP>).*$/u}]\n };\n\n try {\n validatorFactory(config);\n } catch (error) {\n assert.equal(error instanceof Error, true);\n assert.equal(error.message, 'Configuration array not provided');\n }\n });\n\n it('Fails to create a validator from invalid config - code', () => {\n const config = [\n {\n tag: /^500$/u,\n subfields: [{code: 9, value: /^(?!FENNI<KEEP>).*$/u}]\n }\n ];\n\n try {\n validatorFactory(config);\n } catch (error) {\n assert.equal(error instanceof Error, true);\n assert.equal(error.message, 'Configuration not valid - invalid data type for: code');\n }\n });\n\n it('Fails to create a validator from invalid config - value', () => {\n const config = [\n {\n tag: /^500$/u,\n subfields: [{code: /9/u, value: 'Fenni'}]\n }\n ];\n\n try {\n validatorFactory(config);\n } catch (error) {\n assert.equal(error instanceof Error, true);\n assert.equal(error.message, 'Configuration not valid - invalid data type for: value');\n }\n });\n\n\n it('Fails to create a validator from invalid config - missing mandatory: tag', () => {\n const config = [\n {\n value: /^500$/u,\n subfields: [{code: /9/u, value: /^(?!FENNI<KEEP>).*$/u}]\n }\n ];\n\n try {\n validatorFactory(config);\n } catch (error) {\n assert.equal(error instanceof Error, true);\n assert.equal(error.message, 'Configuration not valid - missing mandatory element: tag');\n }\n });\n\n it('Fails to create a validator from invalid config - subfield not object: array', () => {\n const config = [\n {\n tag: /^500$/u,\n subfields: [\n ['/9/', '/^(?!FENNI<KEEP>).*$/'],\n {value: /^(?!FENNI<KEEP>).*$/u}\n ]\n }\n ];\n\n try {\n validatorFactory(config);\n } catch (error) {\n assert.equal(error instanceof Error, true);\n assert.equal(error.message, 'Configuration not valid - subfield: /9/,/^(?!FENNI<KEEP>).*$/ not object');\n }\n });\n\n it('Fails to create a validator from invalid config - subfield not object: string', () => {\n const config = [\n {\n tag: /^500$/u,\n subfields: [\n '/9/',\n '/^(?!FENNI<KEEP>).*$/',\n {value: /^(?!FENNI<KEEP>).*$/u}\n ]\n }\n ];\n\n try {\n validatorFactory(config);\n } catch (error) {\n assert.equal(error instanceof Error, true);\n assert.equal(error.message, 'Configuration not valid - subfield: /9/ not object');\n }\n });\n\n it('Fails to create a validator from invalid config - missing mandatory: subfield.code', () => {\n const config = [\n {\n tag: /^500$/u,\n subfields: [\n {code: /9/u, value: /^(?!FENNI<KEEP>).*$/u},\n {value: /^(?!FENNI<KEEP>).*$/u}\n ]\n }\n ];\n\n try {\n validatorFactory(config);\n } catch (error) {\n assert.equal(error instanceof Error, true);\n assert.equal(error.message, 'Configuration not valid - missing mandatory element: code');\n }\n });\n\n it('Fails to create a validator from invalid config - unidentified field: unidentified', () => {\n const config = [\n {\n tag: /^500$/u,\n unidentified: /^500$/u,\n subfields: [\n {code: /9/u, value: /^(?!FENNI<KEEP>).*$/u},\n {value: /^(?!FENNI<KEEP>).*$/u}\n ]\n }\n ];\n\n try {\n validatorFactory(config);\n } catch (error) {\n assert.equal(error instanceof Error, true);\n assert.equal(error.message, 'Configuration not valid - unidentified value: unidentified');\n //assert(error).to.be.an('error').with.property('message', 'Configuration not valid - unidentified value: unidentified');\n }\n });\n });\n\n // Simple configuration https://github.com/NatLibFi/marc-record-validators-melinda/issues/46\n describe('#validate: Simple configuration (spec)', () => {\n const config = [\n {\n tag: /^100$/u,\n subfields: [{code: /4/u}]\n }\n ];\n\n const recordValid = new MarcRecord({\n leader: 'foo',\n fields: [\n {\n tag: '100',\n ind1: ' ',\n ind2: ' ',\n subfields: [{code: 'a', value: 'Foo Bar'}]\n }, {\n tag: '245',\n ind1: ' ',\n ind2: ' ',\n subfields: [{code: 'a', value: 'Fubar'}]\n }\n ]\n });\n\n const recordInvalid = new MarcRecord({\n leader: 'foo',\n fields: [\n {\n tag: '100',\n ind1: ' ',\n ind2: ' ',\n subfields: [\n {code: 'a', value: 'Foo Bar'},\n {code: '4', value: 'att'}\n ]\n }, {\n tag: '245',\n ind1: ' ',\n ind2: ' ',\n subfields: [{code: 'a', value: 'Fubar'}]\n }\n ]\n });\n\n const recordInvalidFixed = new MarcRecord({\n leader: 'foo',\n fields: [\n {\n tag: '100',\n ind1: ' ',\n ind2: ' ',\n subfields: [{code: 'a', value: 'Foo Bar'}]\n }, {\n tag: '245',\n ind1: ' ',\n ind2: ' ',\n subfields: [{code: 'a', value: 'Fubar'}]\n }\n ]\n });\n\n it('Finds the record valid (spec)', async () => {\n const validator = await validatorFactory(config);\n const result = await validator.validate(recordValid);\n assert.deepEqual(result, {valid: true, message: []});\n });\n\n it('Finds the record invalid (spec)', async () => {\n const validator = await validatorFactory(config);\n const result = await validator.validate(recordInvalid);\n assert.deepEqual(result, {valid: false, message: ['Subfield $100$$4should be excluded']});\n });\n\n it('Repairs invalid record', async () => {\n const validator = await validatorFactory(config);\n await validator.fix(recordInvalid);\n //assert(recordInvalid.equalsTo(recordInvalidFixed)).to.eql(true);\n assert(recordInvalid.equalsTo(recordInvalidFixed), true);\n });\n });\n\n\n describe('#validate: Remove only subfield -> remove field as well', () => {\n const config = [\n {\n tag: /^041$/u,\n subfields: [{code: /^[ad]$/u, value: /^zxx$/u}]\n }\n ];\n\n const recordOriginal = new MarcRecord({\n leader: 'foo',\n fields: [\n {\n tag: '041',\n ind1: ' ',\n ind2: ' ',\n subfields: [{code: 'a', value: 'zxx'}]\n }, {\n tag: '245',\n ind1: ' ',\n ind2: ' ',\n subfields: [{code: 'a', value: 'Fubar'}]\n }\n ]\n });\n\n const recordModified = new MarcRecord({\n leader: 'foo',\n fields: [\n {\n tag: '245',\n ind1: ' ',\n ind2: ' ',\n subfields: [{code: 'a', value: 'Fubar'}]\n }\n ]\n });\n\n it('Finds the record with 041$a zxx invalid (spec)', async () => {\n const validator = await validatorFactory(config);\n const result = await validator.validate(recordOriginal);\n assert.deepEqual(result, {valid: false, message: ['Subfield $041$$ashould be excluded']});\n });\n\n it('Repairs invalid record', async () => {\n const validator = await validatorFactory(config);\n await validator.fix(recordOriginal);\n //assert(recordOriginal.equalsTo(recordModified)).to.eql(true);\n assert.equal(recordOriginal.equalsTo(recordModified), true);\n });\n });\n\n // Complex configuration https://github.com/NatLibFi/marc-record-validators-melinda/issues/46\n describe('#validate: Complex configuration (spec)', () => {\n const config = [\n {\n tag: /^210$/u,\n ind2: /\\s/u,\n subfields: [{code: /2/u, value: /.+/u}]\n }\n ];\n\n const recordValid = new MarcRecord({\n leader: 'foo',\n fields: [\n {\n tag: '210',\n ind1: ' ',\n ind2: ' ',\n subfields: [{code: 'a', value: 'Foo'}]\n }, {\n tag: '245',\n ind1: ' ',\n ind2: ' ',\n subfields: [{code: 'a', value: 'Fubar'}]\n }\n ]\n });\n\n const recordInvalid = new MarcRecord({\n leader: 'foo',\n fields: [\n {\n tag: '210',\n ind1: ' ',\n ind2: ' ',\n subfields: [\n {code: 'a', value: 'Foo'},\n {code: '2', value: 'dnlm'}\n ]\n }, {\n tag: '245',\n ind1: ' ',\n ind2: ' ',\n subfields: [{code: 'a', value: 'Fubar'}]\n }\n ]\n });\n\n const recordInvalidFixed = new MarcRecord({\n leader: 'foo',\n fields: [\n {\n tag: '210',\n ind1: ' ',\n ind2: ' ',\n subfields: [{code: 'a', value: 'Foo'}]\n }, {\n tag: '245',\n ind1: ' ',\n ind2: ' ',\n subfields: [{code: 'a', value: 'Fubar'}]\n }\n ]\n });\n\n it('Finds the record valid (spec)', async () => {\n const validator = await validatorFactory(config);\n const result = await validator.validate(recordValid);\n assert.deepEqual(result, {valid: true, message: []});\n });\n\n it('Finds the record invalid (spec)', async () => {\n const validator = await validatorFactory(config);\n const result = await validator.validate(recordInvalid);\n assert.deepEqual(result, {valid: false, message: ['Subfield $210$$2should be excluded']});\n });\n\n it('Repairs invalid record', async () => {\n const validator = await validatorFactory(config);\n await validator.fix(recordInvalid);\n // assert(recordInvalid.equalsTo(recordInvalidFixed)).to.eql(true);\n assert.equal(recordInvalid.equalsTo(recordInvalidFixed), true);\n });\n });\n\n // More special cases to increase coverage\n describe('#validate: Custom configuration', () => {\n const configInd = [\n {\n tag: /^500$/u,\n ind1: /^8$/u,\n ind2: /^4$/u,\n subfields: [{code: /2/u, value: /.+/u}]\n }\n ];\n\n const recordValid = new MarcRecord({\n leader: 'foo',\n fields: [\n {\n tag: '210',\n ind1: ' ',\n ind2: ' ',\n subfields: [{code: 'a', value: 'Foo'}]\n }, {\n tag: '500',\n subfields: [\n {code: 'a', value: 'Foo'},\n {code: '2', value: 'dnlm'}\n ]\n }\n ]\n });\n\n const recordIndInvalid = new MarcRecord({\n leader: 'foo',\n fields: [\n {\n tag: '245',\n ind1: ' ',\n ind2: ' ',\n subfields: [{code: 'a', value: 'Fubar'}]\n }, {\n tag: '500',\n ind1: '8',\n ind2: '4',\n subfields: [\n {code: 'a', value: 'Foo'},\n {code: '2', value: 'dnlm'}\n ]\n }\n ]\n });\n\n const recordIndInvalidFixed = new MarcRecord({\n leader: 'foo',\n fields: [\n {\n tag: '245',\n ind1: ' ',\n ind2: ' ',\n subfields: [{code: 'a', value: 'Fubar'}]\n }, {\n tag: '500',\n ind1: '8',\n ind2: '4',\n subfields: [{code: 'a', value: 'Foo'}]\n }\n ]\n });\n\n it('Finds the record valid - Ind1&Ind2', async () => {\n const validator = await validatorFactory(configInd);\n const result = await validator.validate(recordValid);\n assert.deepEqual(result, {valid: true, message: []});\n });\n\n it('Finds the record invalid - Ind', async () => {\n const validator = await validatorFactory(configInd);\n const result = await validator.validate(recordIndInvalid);\n assert.deepEqual(result, {valid: false, message: ['Subfield $500$$2should be excluded']});\n });\n\n it('Repairs invalid record', async () => {\n const validator = await validatorFactory(configInd);\n await validator.fix(recordIndInvalid);\n // assert(recordIndInvalid.equalsTo(recordIndInvalidFixed)).to.eql(true);\n assert.equal(recordIndInvalid.equalsTo(recordIndInvalidFixed), true);\n });\n });\n});\n"],
5
+ "mappings": "AAAA,OAAO,YAAY;AACnB,SAAQ,kBAAiB;AACzB,OAAO,sBAAsB;AAC7B,SAAQ,UAAU,UAAS;AAK3B,SAAS,sBAAsB,MAAM;AACnC,WAAS,6CAA6C,MAAM;AAC1D,OAAG,0CAA0C,YAAY;AACvD,YAAM,SAAS;AAAA,QACb;AAAA,UACE,KAAK;AAAA,UACL,WAAW,CAAC,EAAC,MAAM,KAAI,CAAC;AAAA,QAC1B;AAAA,MACF;AAEA,YAAM,YAAY,MAAM,iBAAiB,MAAM;AAC/C,aAAO,MAAM,OAAO,WAAW,QAAQ;AACvC,aAAO,MAAM,OAAO,UAAU,aAAa,QAAQ;AACnD,aAAO,MAAM,OAAO,UAAU,UAAU,UAAU;AAAA,IACpD,CAAC;AAED,OAAG,2CAA2C,YAAY;AACxD,YAAM,SAAS;AAAA,QACb;AAAA,UACE,KAAK;AAAA,UACL,MAAM;AAAA,UACN,WAAW;AAAA,YACT;AAAA,cACE,MAAM;AAAA,cACN,OAAO;AAAA,YACT;AAAA,UACF;AAAA,QACF;AAAA,MACF;AAEA,YAAM,YAAY,MAAM,iBAAiB,MAAM;AAC/C,aAAO,MAAM,OAAO,WAAW,QAAQ;AACvC,aAAO,MAAM,OAAO,UAAU,aAAa,QAAQ;AACnD,aAAO,MAAM,OAAO,UAAU,UAAU,UAAU;AAAA,IACpD,CAAC;AAED,OAAG,uEAAuE,MAAM;AAC9E,YAAM,SAAS;AAAA,QACb;AAAA,UACE,KAAK;AAAA,QACP;AAAA,MACF;AAEA,UAAI;AACF,yBAAiB,MAAM;AAAA,MACzB,SAAS,OAAO;AACd,eAAO,MAAM,iBAAiB,OAAO,IAAI;AACzC,eAAO,MAAM,MAAM,SAAS,gEAAgE;AAAA,MAC9F;AAAA,IACF,CAAC;AAED,OAAG,yDAAyD,MAAM;AAChE,YAAM,SAAS;AAAA,QACb;AAAA,UACE,KAAK;AAAA,UACL,WAAW,CAAC,EAAC,MAAM,MAAM,OAAO,uBAAsB,CAAC;AAAA,QACzD;AAAA,MACF;AAEA,UAAI;AACF,yBAAiB,MAAM;AAAA,MACzB,SAAS,OAAO;AACd,eAAO,MAAM,iBAAiB,OAAO,IAAI;AACzC,eAAO,MAAM,MAAM,SAAS,sDAAsD;AAAA,MACpF;AAAA,IACF,CAAC;AAED,OAAG,mEAAmE,MAAM;AAC1E,YAAM,SAAS;AAAA,QACb,KAAK;AAAA,QACL,WAAW,CAAC,EAAC,MAAM,MAAM,OAAO,uBAAsB,CAAC;AAAA,MACzD;AAEA,UAAI;AACF,yBAAiB,MAAM;AAAA,MACzB,SAAS,OAAO;AACd,eAAO,MAAM,iBAAiB,OAAO,IAAI;AACzC,eAAO,MAAM,MAAM,SAAS,kCAAkC;AAAA,MAChE;AAAA,IACF,CAAC;AAED,OAAG,0DAA0D,MAAM;AACjE,YAAM,SAAS;AAAA,QACb;AAAA,UACE,KAAK;AAAA,UACL,WAAW,CAAC,EAAC,MAAM,GAAG,OAAO,uBAAsB,CAAC;AAAA,QACtD;AAAA,MACF;AAEA,UAAI;AACF,yBAAiB,MAAM;AAAA,MACzB,SAAS,OAAO;AACd,eAAO,MAAM,iBAAiB,OAAO,IAAI;AACzC,eAAO,MAAM,MAAM,SAAS,uDAAuD;AAAA,MACrF;AAAA,IACF,CAAC;AAED,OAAG,2DAA2D,MAAM;AAClE,YAAM,SAAS;AAAA,QACb;AAAA,UACE,KAAK;AAAA,UACL,WAAW,CAAC,EAAC,MAAM,MAAM,OAAO,QAAO,CAAC;AAAA,QAC1C;AAAA,MACF;AAEA,UAAI;AACF,yBAAiB,MAAM;AAAA,MACzB,SAAS,OAAO;AACd,eAAO,MAAM,iBAAiB,OAAO,IAAI;AACzC,eAAO,MAAM,MAAM,SAAS,wDAAwD;AAAA,MACtF;AAAA,IACF,CAAC;AAGD,OAAG,4EAA4E,MAAM;AACnF,YAAM,SAAS;AAAA,QACb;AAAA,UACE,OAAO;AAAA,UACP,WAAW,CAAC,EAAC,MAAM,MAAM,OAAO,uBAAsB,CAAC;AAAA,QACzD;AAAA,MACF;AAEA,UAAI;AACF,yBAAiB,MAAM;AAAA,MACzB,SAAS,OAAO;AACd,eAAO,MAAM,iBAAiB,OAAO,IAAI;AACzC,eAAO,MAAM,MAAM,SAAS,0DAA0D;AAAA,MACxF;AAAA,IACF,CAAC;AAED,OAAG,gFAAgF,MAAM;AACvF,YAAM,SAAS;AAAA,QACb;AAAA,UACE,KAAK;AAAA,UACL,WAAW;AAAA,YACT,CAAC,OAAO,uBAAuB;AAAA,YAC/B,EAAC,OAAO,uBAAsB;AAAA,UAChC;AAAA,QACF;AAAA,MACF;AAEA,UAAI;AACF,yBAAiB,MAAM;AAAA,MACzB,SAAS,OAAO;AACd,eAAO,MAAM,iBAAiB,OAAO,IAAI;AACzC,eAAO,MAAM,MAAM,SAAS,0EAA0E;AAAA,MACxG;AAAA,IACF,CAAC;AAED,OAAG,iFAAiF,MAAM;AACxF,YAAM,SAAS;AAAA,QACb;AAAA,UACE,KAAK;AAAA,UACL,WAAW;AAAA,YACT;AAAA,YACA;AAAA,YACA,EAAC,OAAO,uBAAsB;AAAA,UAChC;AAAA,QACF;AAAA,MACF;AAEA,UAAI;AACF,yBAAiB,MAAM;AAAA,MACzB,SAAS,OAAO;AACd,eAAO,MAAM,iBAAiB,OAAO,IAAI;AACzC,eAAO,MAAM,MAAM,SAAS,oDAAoD;AAAA,MAClF;AAAA,IACF,CAAC;AAED,OAAG,sFAAsF,MAAM;AAC7F,YAAM,SAAS;AAAA,QACb;AAAA,UACE,KAAK;AAAA,UACL,WAAW;AAAA,YACT,EAAC,MAAM,MAAM,OAAO,uBAAsB;AAAA,YAC1C,EAAC,OAAO,uBAAsB;AAAA,UAChC;AAAA,QACF;AAAA,MACF;AAEA,UAAI;AACF,yBAAiB,MAAM;AAAA,MACzB,SAAS,OAAO;AACd,eAAO,MAAM,iBAAiB,OAAO,IAAI;AACzC,eAAO,MAAM,MAAM,SAAS,2DAA2D;AAAA,MACzF;AAAA,IACF,CAAC;AAED,OAAG,sFAAsF,MAAM;AAC7F,YAAM,SAAS;AAAA,QACb;AAAA,UACE,KAAK;AAAA,UACL,cAAc;AAAA,UACd,WAAW;AAAA,YACT,EAAC,MAAM,MAAM,OAAO,uBAAsB;AAAA,YAC1C,EAAC,OAAO,uBAAsB;AAAA,UAChC;AAAA,QACF;AAAA,MACF;AAEA,UAAI;AACF,yBAAiB,MAAM;AAAA,MACzB,SAAS,OAAO;AACd,eAAO,MAAM,iBAAiB,OAAO,IAAI;AACzC,eAAO,MAAM,MAAM,SAAS,4DAA4D;AAAA,MAE1F;AAAA,IACF,CAAC;AAAA,EACH,CAAC;AAGD,WAAS,0CAA0C,MAAM;AACvD,UAAM,SAAS;AAAA,MACb;AAAA,QACE,KAAK;AAAA,QACL,WAAW,CAAC,EAAC,MAAM,KAAI,CAAC;AAAA,MAC1B;AAAA,IACF;AAEA,UAAM,cAAc,IAAI,WAAW;AAAA,MACjC,QAAQ;AAAA,MACR,QAAQ;AAAA,QACN;AAAA,UACE,KAAK;AAAA,UACL,MAAM;AAAA,UACN,MAAM;AAAA,UACN,WAAW,CAAC,EAAC,MAAM,KAAK,OAAO,UAAS,CAAC;AAAA,QAC3C;AAAA,QAAG;AAAA,UACD,KAAK;AAAA,UACL,MAAM;AAAA,UACN,MAAM;AAAA,UACN,WAAW,CAAC,EAAC,MAAM,KAAK,OAAO,QAAO,CAAC;AAAA,QACzC;AAAA,MACF;AAAA,IACF,CAAC;AAED,UAAM,gBAAgB,IAAI,WAAW;AAAA,MACnC,QAAQ;AAAA,MACR,QAAQ;AAAA,QACN;AAAA,UACE,KAAK;AAAA,UACL,MAAM;AAAA,UACN,MAAM;AAAA,UACN,WAAW;AAAA,YACT,EAAC,MAAM,KAAK,OAAO,UAAS;AAAA,YAC5B,EAAC,MAAM,KAAK,OAAO,MAAK;AAAA,UAC1B;AAAA,QACF;AAAA,QAAG;AAAA,UACD,KAAK;AAAA,UACL,MAAM;AAAA,UACN,MAAM;AAAA,UACN,WAAW,CAAC,EAAC,MAAM,KAAK,OAAO,QAAO,CAAC;AAAA,QACzC;AAAA,MACF;AAAA,IACF,CAAC;AAED,UAAM,qBAAqB,IAAI,WAAW;AAAA,MACxC,QAAQ;AAAA,MACR,QAAQ;AAAA,QACN;AAAA,UACE,KAAK;AAAA,UACL,MAAM;AAAA,UACN,MAAM;AAAA,UACN,WAAW,CAAC,EAAC,MAAM,KAAK,OAAO,UAAS,CAAC;AAAA,QAC3C;AAAA,QAAG;AAAA,UACD,KAAK;AAAA,UACL,MAAM;AAAA,UACN,MAAM;AAAA,UACN,WAAW,CAAC,EAAC,MAAM,KAAK,OAAO,QAAO,CAAC;AAAA,QACzC;AAAA,MACF;AAAA,IACF,CAAC;AAED,OAAG,iCAAiC,YAAY;AAC9C,YAAM,YAAY,MAAM,iBAAiB,MAAM;AAC/C,YAAM,SAAS,MAAM,UAAU,SAAS,WAAW;AACnD,aAAO,UAAU,QAAQ,EAAC,OAAO,MAAM,SAAS,CAAC,EAAC,CAAC;AAAA,IACrD,CAAC;AAED,OAAG,mCAAmC,YAAY;AAChD,YAAM,YAAY,MAAM,iBAAiB,MAAM;AAC/C,YAAM,SAAS,MAAM,UAAU,SAAS,aAAa;AACrD,aAAO,UAAU,QAAQ,EAAC,OAAO,OAAO,SAAS,CAAC,oCAAoC,EAAC,CAAC;AAAA,IAC1F,CAAC;AAED,OAAG,0BAA0B,YAAY;AACvC,YAAM,YAAY,MAAM,iBAAiB,MAAM;AAC/C,YAAM,UAAU,IAAI,aAAa;AAEjC,aAAO,cAAc,SAAS,kBAAkB,GAAG,IAAI;AAAA,IACzD,CAAC;AAAA,EACH,CAAC;AAGD,WAAS,2DAA2D,MAAM;AACxE,UAAM,SAAS;AAAA,MACb;AAAA,QACE,KAAK;AAAA,QACL,WAAW,CAAC,EAAC,MAAM,WAAW,OAAO,SAAQ,CAAC;AAAA,MAChD;AAAA,IACF;AAEA,UAAM,iBAAiB,IAAI,WAAW;AAAA,MACpC,QAAQ;AAAA,MACR,QAAQ;AAAA,QACN;AAAA,UACE,KAAK;AAAA,UACL,MAAM;AAAA,UACN,MAAM;AAAA,UACN,WAAW,CAAC,EAAC,MAAM,KAAK,OAAO,MAAK,CAAC;AAAA,QACvC;AAAA,QAAG;AAAA,UACD,KAAK;AAAA,UACL,MAAM;AAAA,UACN,MAAM;AAAA,UACN,WAAW,CAAC,EAAC,MAAM,KAAK,OAAO,QAAO,CAAC;AAAA,QACzC;AAAA,MACF;AAAA,IACF,CAAC;AAED,UAAM,iBAAiB,IAAI,WAAW;AAAA,MACpC,QAAQ;AAAA,MACR,QAAQ;AAAA,QACN;AAAA,UACE,KAAK;AAAA,UACL,MAAM;AAAA,UACN,MAAM;AAAA,UACN,WAAW,CAAC,EAAC,MAAM,KAAK,OAAO,QAAO,CAAC;AAAA,QACzC;AAAA,MACF;AAAA,IACF,CAAC;AAED,OAAG,kDAAkD,YAAY;AAC/D,YAAM,YAAY,MAAM,iBAAiB,MAAM;AAC/C,YAAM,SAAS,MAAM,UAAU,SAAS,cAAc;AACtD,aAAO,UAAU,QAAQ,EAAC,OAAO,OAAO,SAAS,CAAC,oCAAoC,EAAC,CAAC;AAAA,IAC1F,CAAC;AAED,OAAG,0BAA0B,YAAY;AACvC,YAAM,YAAY,MAAM,iBAAiB,MAAM;AAC/C,YAAM,UAAU,IAAI,cAAc;AAElC,aAAO,MAAM,eAAe,SAAS,cAAc,GAAG,IAAI;AAAA,IAC5D,CAAC;AAAA,EACH,CAAC;AAGD,WAAS,2CAA2C,MAAM;AACxD,UAAM,SAAS;AAAA,MACb;AAAA,QACE,KAAK;AAAA,QACL,MAAM;AAAA,QACN,WAAW,CAAC,EAAC,MAAM,MAAM,OAAO,MAAK,CAAC;AAAA,MACxC;AAAA,IACF;AAEA,UAAM,cAAc,IAAI,WAAW;AAAA,MACjC,QAAQ;AAAA,MACR,QAAQ;AAAA,QACN;AAAA,UACE,KAAK;AAAA,UACL,MAAM;AAAA,UACN,MAAM;AAAA,UACN,WAAW,CAAC,EAAC,MAAM,KAAK,OAAO,MAAK,CAAC;AAAA,QACvC;AAAA,QAAG;AAAA,UACD,KAAK;AAAA,UACL,MAAM;AAAA,UACN,MAAM;AAAA,UACN,WAAW,CAAC,EAAC,MAAM,KAAK,OAAO,QAAO,CAAC;AAAA,QACzC;AAAA,MACF;AAAA,IACF,CAAC;AAED,UAAM,gBAAgB,IAAI,WAAW;AAAA,MACnC,QAAQ;AAAA,MACR,QAAQ;AAAA,QACN;AAAA,UACE,KAAK;AAAA,UACL,MAAM;AAAA,UACN,MAAM;AAAA,UACN,WAAW;AAAA,YACT,EAAC,MAAM,KAAK,OAAO,MAAK;AAAA,YACxB,EAAC,MAAM,KAAK,OAAO,OAAM;AAAA,UAC3B;AAAA,QACF;AAAA,QAAG;AAAA,UACD,KAAK;AAAA,UACL,MAAM;AAAA,UACN,MAAM;AAAA,UACN,WAAW,CAAC,EAAC,MAAM,KAAK,OAAO,QAAO,CAAC;AAAA,QACzC;AAAA,MACF;AAAA,IACF,CAAC;AAED,UAAM,qBAAqB,IAAI,WAAW;AAAA,MACxC,QAAQ;AAAA,MACR,QAAQ;AAAA,QACN;AAAA,UACE,KAAK;AAAA,UACL,MAAM;AAAA,UACN,MAAM;AAAA,UACN,WAAW,CAAC,EAAC,MAAM,KAAK,OAAO,MAAK,CAAC;AAAA,QACvC;AAAA,QAAG;AAAA,UACD,KAAK;AAAA,UACL,MAAM;AAAA,UACN,MAAM;AAAA,UACN,WAAW,CAAC,EAAC,MAAM,KAAK,OAAO,QAAO,CAAC;AAAA,QACzC;AAAA,MACF;AAAA,IACF,CAAC;AAED,OAAG,iCAAiC,YAAY;AAC9C,YAAM,YAAY,MAAM,iBAAiB,MAAM;AAC/C,YAAM,SAAS,MAAM,UAAU,SAAS,WAAW;AACnD,aAAO,UAAU,QAAQ,EAAC,OAAO,MAAM,SAAS,CAAC,EAAC,CAAC;AAAA,IACrD,CAAC;AAED,OAAG,mCAAmC,YAAY;AAChD,YAAM,YAAY,MAAM,iBAAiB,MAAM;AAC/C,YAAM,SAAS,MAAM,UAAU,SAAS,aAAa;AACrD,aAAO,UAAU,QAAQ,EAAC,OAAO,OAAO,SAAS,CAAC,oCAAoC,EAAC,CAAC;AAAA,IAC1F,CAAC;AAED,OAAG,0BAA0B,YAAY;AACvC,YAAM,YAAY,MAAM,iBAAiB,MAAM;AAC/C,YAAM,UAAU,IAAI,aAAa;AAEjC,aAAO,MAAM,cAAc,SAAS,kBAAkB,GAAG,IAAI;AAAA,IAC/D,CAAC;AAAA,EACH,CAAC;AAGD,WAAS,mCAAmC,MAAM;AAChD,UAAM,YAAY;AAAA,MAChB;AAAA,QACE,KAAK;AAAA,QACL,MAAM;AAAA,QACN,MAAM;AAAA,QACN,WAAW,CAAC,EAAC,MAAM,MAAM,OAAO,MAAK,CAAC;AAAA,MACxC;AAAA,IACF;AAEA,UAAM,cAAc,IAAI,WAAW;AAAA,MACjC,QAAQ;AAAA,MACR,QAAQ;AAAA,QACN;AAAA,UACE,KAAK;AAAA,UACL,MAAM;AAAA,UACN,MAAM;AAAA,UACN,WAAW,CAAC,EAAC,MAAM,KAAK,OAAO,MAAK,CAAC;AAAA,QACvC;AAAA,QAAG;AAAA,UACD,KAAK;AAAA,UACL,WAAW;AAAA,YACT,EAAC,MAAM,KAAK,OAAO,MAAK;AAAA,YACxB,EAAC,MAAM,KAAK,OAAO,OAAM;AAAA,UAC3B;AAAA,QACF;AAAA,MACF;AAAA,IACF,CAAC;AAED,UAAM,mBAAmB,IAAI,WAAW;AAAA,MACtC,QAAQ;AAAA,MACR,QAAQ;AAAA,QACN;AAAA,UACE,KAAK;AAAA,UACL,MAAM;AAAA,UACN,MAAM;AAAA,UACN,WAAW,CAAC,EAAC,MAAM,KAAK,OAAO,QAAO,CAAC;AAAA,QACzC;AAAA,QAAG;AAAA,UACD,KAAK;AAAA,UACL,MAAM;AAAA,UACN,MAAM;AAAA,UACN,WAAW;AAAA,YACT,EAAC,MAAM,KAAK,OAAO,MAAK;AAAA,YACxB,EAAC,MAAM,KAAK,OAAO,OAAM;AAAA,UAC3B;AAAA,QACF;AAAA,MACF;AAAA,IACF,CAAC;AAED,UAAM,wBAAwB,IAAI,WAAW;AAAA,MAC3C,QAAQ;AAAA,MACR,QAAQ;AAAA,QACN;AAAA,UACE,KAAK;AAAA,UACL,MAAM;AAAA,UACN,MAAM;AAAA,UACN,WAAW,CAAC,EAAC,MAAM,KAAK,OAAO,QAAO,CAAC;AAAA,QACzC;AAAA,QAAG;AAAA,UACD,KAAK;AAAA,UACL,MAAM;AAAA,UACN,MAAM;AAAA,UACN,WAAW,CAAC,EAAC,MAAM,KAAK,OAAO,MAAK,CAAC;AAAA,QACvC;AAAA,MACF;AAAA,IACF,CAAC;AAED,OAAG,sCAAsC,YAAY;AACnD,YAAM,YAAY,MAAM,iBAAiB,SAAS;AAClD,YAAM,SAAS,MAAM,UAAU,SAAS,WAAW;AACnD,aAAO,UAAU,QAAQ,EAAC,OAAO,MAAM,SAAS,CAAC,EAAC,CAAC;AAAA,IACrD,CAAC;AAED,OAAG,kCAAkC,YAAY;AAC/C,YAAM,YAAY,MAAM,iBAAiB,SAAS;AAClD,YAAM,SAAS,MAAM,UAAU,SAAS,gBAAgB;AACxD,aAAO,UAAU,QAAQ,EAAC,OAAO,OAAO,SAAS,CAAC,oCAAoC,EAAC,CAAC;AAAA,IAC1F,CAAC;AAED,OAAG,0BAA0B,YAAY;AACvC,YAAM,YAAY,MAAM,iBAAiB,SAAS;AAClD,YAAM,UAAU,IAAI,gBAAgB;AAEpC,aAAO,MAAM,iBAAiB,SAAS,qBAAqB,GAAG,IAAI;AAAA,IACrE,CAAC;AAAA,EACH,CAAC;AACH,CAAC;",
6
+ "names": []
7
+ }