Type: New Feature
Status: Open (View Workflow)
Affects Version/s: None
Fix Version/s: None
Template:UXPROD features customfield_11200 40506
Analysis Estimate:Small < 3 days
Calculated Total Rank:66
Kiwi Planning Points (DO NOT CHANGE):40
Rank: Chalmers (Impl Aut 2019):R5
Rank: Chicago (MVP Sum 2020):R1
Rank: Cornell (Full Sum 2021):R2
Rank: Duke (Full Sum 2021):R1
Rank: 5Colleges (Full Jul 2021):R2
Rank: FLO (MVP Sum 2020):R1
Rank: GBV (MVP Sum 2020):R4
Rank: Lehigh (MVP Summer 2020):R1
Rank: MO State (MVP June 2020):R2
Rank: TAMU (MVP Jan 2021):R2
Rank: U of AL (MVP Oct 2020):R2
This feature allows for multiple holdings and/or items to be created or edited based on data supplied in a single MARC record
Purpose: To update multiple holdings and items on the same instance, from the same imported MARC record
As a staff person working with data import
I want to update multiple holdings and their associated items when importing a single MARC record
So that I can use all of the holdings/items data on the MARC record properly
- Scenario 1
- Given a MARC record with multiple holdings and item data in it
- When importing to update holdings and items
- Then update all relevant holdings on the same instance and update all relevant items on the appropriate holdings
- Include any holdings and items data in the same MARC field, different subfields
- If multiple item records are to be updated on the same holdings, repeat the holdings data in repeated MARC fields, with each item's data in a separate MARC field. Item data/subfields for multiple item records cannot be included in the same MARC field
- See example MARC record below
- Scenario 2
- Ensure this story passes Accessibility testing
- Scenario 3
- Ensure automated testing coverage for this new code is 80% plus and confirm with screenshot
See attached MARC file; test load to update instance, holdings, and item to ensure the logic is working correctly.
- Match for holdings could be based on
- Holdings HRID/UUID
- Instance HRID/UUID plus secondary match on Holdings HRID/UUID or Location code
- Match for item could be based on
- Item HRID, UUID, or barcode
- Holdings HRID/UUID plus secondary match on Item copy number
Sample record with multiple holdings/item data:
=LDR 01262nam a2200301Ia 4500
=130 0\$aBible.$pNew Testament$lEnglish.$sScarlett.$f1798.
=245 12$aA translation of the New Testament from the original Greek /$chumbly attempted by Nathaniel Scarlett, assisted by men of piety & literature ; with notes.
$aLondon :$bPrinted by T. Gillet; and sold by Nathaniel Scarlett, No. 349, near Exeter 'Change, Strand; also F. & C. Rivington, St. Paul's Church Yard,$c1798.
$axi, 483, vi p.,  folded leaf of plates :$bill. ;$c19 cm.
$aIncludes Observations on some terms used in this translation: vi p. at end.
=510 3\$aDarlow-Moule-Herbert 1433
=700 1\$aScarlett, Nathaniel,$d1753-1802.
=740 02$aObservations on some terms used in this translation.
$a34678234678246423786427$b1$hKU/CC/DI/M <===== $a = item barcode, $b = copy number, $h = holdings permanent location
If this record were updating holdings and items, it would do so as follows:
- Update 1 instance, with the data in the main part of the MARC bib record
- Update 2 holdings, 1 for permanent location KU/CC.DI/M and 1 for permanent location KU/CC/DI/A, using holdings mapping data from 945$h and the defaults in the holdings mapping profile
- Update 3 item records, 2 linked to the holdings for KU/CC/DI/M and 1 linked to the holdings for KU/CC/DI/A, using item mapping data from 945$a, 945$b, and the defaults in the item mapping profile
NOTE: These 9xx fields and subfields are just examples. Real fields/subfields would be mapped in the field mapping profile. The key is that related holdings and item data must be in the same field, different subfields, and that item data for different items must be in separate MARC fields, not concatenated in the same MARC field.
- MappingManager should return JSON value - backend
- extend mapping profile schema with param "entityPerValue" (for items and holdings) backend/UI
- add a possibility to link item and holding in mapping profile for item (holding location: 945$h) backend/UI
- Change Mapper interface to read "entityPerValue" fields call reader for n times per entity - backend
- update all handlers for support list of holdings and items in the context