/
Inventory app Version history

Inventory app Version history

Feature

https://folio-org.atlassian.net/browse/UXPROD-4125

https://folio-org.atlassian.net/browse/UXPROD-4126

Release

Sunflower

Document status

draft

Overview

Action items

  1. Document business expectations? Where do we differ from Acquisitions? Some examples:

    1. ECS handling - change ownership

    2. Setting record for deletion

    3. Default display (sort, number to display, how to go through more history) - endless scroll? More?

  2. Document some user workflows (i.e. Single record overlay)

  3. Work with Kimie to revise UX ( )

    1. Remove “sort by”

    2. Remove examples where the app is identified as the trigger for the change

    3. When the record is created (look at Orders app)

    4. ECS event of “Shared”

  4. Write user stories

In scope

Log that contains

  • User who made the change

  • Date time of change

  • Change made

  • Feature toggle

  • Applied to both FOLIO and MARC source instances

  • Configuration of number of cards to show (default 15)

Out of scope

  • Ability to rollback to and/or view previous versions

  • Ability to sort

  • Including the app that triggered the change

  • Exporting version history

  • Highlighting the fields changed

Team Responsibilities

Category

Folijet

Spitfire

Notes

Version history UI

  • Instances

  • FOLIO holdings

  • Items

  • MARC source view

    • Bibs

    • Authorities

       

 

Domain events & rest endpoints

  • MARC bibs

  • MARC authorities

  • Instances

  • FOLIO holdings

  • Items

 

Change log feature toggle

 

 

Whichever team has capacity after UI

https://folio-org.atlassian.net/browse/MODAUD-209

Display configuration

 

 

Whichever team has capacity after UI

https://folio-org.atlassian.net/browse/MODAUD-207

https://folio-org.atlassian.net/browse/UIIN-3206

Tech design

Inventory Audit log

Requirements overview

Requirement

Notes

Folijet

Spitfire

Status

Requirement

Notes

Folijet

Spitfire

Status

1

Feature toggle so that libraries can set whether the feature is enabled (applies to both FOLIO and MARC source records)

  • ECS: This should be controlled by a central tenant feature flag

  • Should apply to all record types (in Inventory & MARC authority)

https://folio-org.atlassian.net/browse/UIIN-2950

 

complete

2

Add icon to open change log

 

UIIN-3170: Instance: Add Change log icon to details viewOpen

https://folio-org.atlassian.net/browse/UIIN-3171

UIIN-3172: Item: Add Change log icon to details viewOpen

 

complete

3

After clicking change log icon, suppress accordions/tags/actions menu

 

https://folio-org.atlassian.net/browse/UIIN-3176

UIIN-3177: Holdings: Suppress accordions/tags/action menu when clicking Change log iconOpen

https://folio-org.atlassian.net/browse/UIIN-3178

 

complete

4

Include version history on:

  • Instance detail view (fourth pane)

  • Holdings detail view

  • Items detail view

  • source view for MARC source records (bibs & authorities - second pane)

 

UIIN-3173: Instance: Display all versions in View history fourth paneOpen

UIIN-3174: Holdings: Display all versions in View history fourth paneOpen

https://folio-org.atlassian.net/browse/UIIN-3175

https://folio-org.atlassian.net/browse/UIQM-674

https://folio-org.atlassian.net/browse/UIQM-673

 

complete

5

Display the date and time of the change in local timezone

 

 

 

complete

6

Display the user source of the change

 

 

 

complete

7

Identify as a “Change”, and indicate whether the field was:

  • Added

  • Edited

  • Removed

 

 

 

complete

8

Identify as a “Change” when holdings/item records are moved

When holdings are moved, show change on holdings record of:

  • Holdings record (Moved)

When item records are moved, show change on item record of:

  • Item record (Moved)

 

 

 

complete

9

Indicate the field changed on Instances detail view for both FOLIO and MARC source records.

Note: for MARC source records, the field changed should reflect the Instance field changed (see other requirement for Source view)

 

 

 

complete

10

In Source view for MARC source records, identify the specific MARC fields (not to the point of indicators or subfields) changed

 

 

 

complete

11

If a MARC field is changed that does NOT map to a FOLIO instance, do not include the change in the Instance detail view log

 

 

 

complete

12

15 cards on version history to show as default

  • Add configuration for number of cards to show at once with a maximum value in Settings

  • Inventory display settings

  • 15 as default

Only include 15 cards in the log at a time in the instance history view

  • Need mockup for configuration

Backend configuration: https://folio-org.atlassian.net/browse/MODAUD-207

https://folio-org.atlassian.net/browse/UIIN-3206

 

 

review

13

Add a “Load more” button to the bottom of the version history pane

  • Talk to Ryan about Load more button

https://folio-org.atlassian.net/browse/UIIN-3179

https://folio-org.atlassian.net/browse/UIIN-3180

https://folio-org.atlassian.net/browse/UIIN-3181

 

review

14

Present a toast message that loading additional changes may take time

 

 

 

review

15

When records are promoted to shared:

  • Capture and show that the record has been shared in the audit log

    • Instead of “Original version”, replace with “Shared”

  • Do not retain the history of the local record

Tech design considerations:

  1. Copy data from local mod-audit to central mod-audit

  2. For storing information on source of change, we only store the user ID, this user would only be shown if a shadow user exists in the central tenant?

 

 

complete

Questions

Question

Answer

Refinement Notes

Answer Date

Status

Question

Answer

Refinement Notes

Answer Date

Status

1

In the mockups, the user name is hyperlinked - does this just go to the user record?

Yes

 

Dec 20, 2024

complete

2

Do we indicate when one record is updated from changes made to another record (such as updating the call number on a holdings record which then updates the effective call number on the item record)?

If there is a field that is autogenerated/updated, needs to be reflected in item version history

 

Likely need to exclude from the version history (CSR needs to come up with the list of fields to exclude)

  • If we don’t want to include these changes to the item record audit log: Need list of fields to ignore on the item record that are updated from the holdings record changes

Jan 16, 2025

complete

3

Do we include a change of “Shared” for ECS?

Replace “Changed” to “Shared” and remove the audit history from the previous local record


Yes. Need to determine LOE for indicating that the record was Shared as opposed to just Created (CSR to determine what will replace “Original version” when shared and create backend story) @Christine Schultz-Richert - to determine UI wording

We do not need to retain the local version history when shared.

  • To be able to show that the record (instance and related MARC bib record) was not created but shared we need to solution

    • 1/16/24: Specific event sent by mod-inventory so we can do this

  • For retaining local history when shared: Need to review with Folijet to think about if we need to move audit history to central tenant

    • Determine scope and LOE for retaining the local history

      • Would require moving local mod-audit to central mod-audit

      • Would potentially require both Folijet and Spitfire; depending on solution

      • Note: If user does not have a shadow user in central tenant, this would not be able to be shown in the audit log for a shared record

    • Decided that it will not be included

Jan 21, 2025

complete

4

Do we include a change of “Derived” and “Duplicate”?

Yes No, not for this phase. Just indicating that the new record was created is in scope.

  • Potentially not feasible: On backend, we do not specify whether it’s duplicated/derived, only that it is created *

*could be similar to effort of “via” line that we omitted

Jan 14, 2025

complete

5

Do we include a change if

  • holdings moved to another instance

  • items moved to another holdings

Yes

  • Moving to another instance/holdings

    • Show some sort of indication that record was moved “Record (moved)” under a header of “Changed”

  • @Christine Schultz-Richert to talk to Kimie

Changed

  • Holdings record (Moved)

 

  • Moving the record just changes the id (not recording this change would be more effort)

Jan 21, 2025

complete

6

ECS change ownership

When holdings are moved to another instance, that holdings record is deleted and a new one is created on the instance. Therefore, the holdings would just be deleted, we wouldn’t need to capture that change anywhere. The new holdings record would just have a history of being created. We don’t need to retain the history of the deleted holdings

 

Jan 16, 2025

complete

7

Is keeping one year of history sufficient? Potentially need some sort of workflow where a user can make a call to some sort of archive to get more history?

Existing story for configuring retention period

  • For now there is no archiving capability included in design; configuration for retention period but not for archiving

  • Need to define what we mean by “archive” and if it’s really needed

Jan 16, 2025

complete

8

Do we need to track when fields are reordered in quickMARC?

Yes - indicate field and an action of “Moved”? - Ping acq about what they’re doing if:

  • there is a situation where data is reordered within the record?

  • there is a situation where record is moved?

Do not include as a change

@Kateryna Senchenko check to see if these changes would be captured anyway

Analysis

9

Confirm whether there will be changes logged when records are linked together? (might show with parent/child?)

For parent/child changes, we need to show high level that a new child or parent relationship was added, edited, or removed

Based on additional effort needed, we will not be logging this in the change history.

@Pavlo Smahin needs to review how the relationships are stored
PS: Relationships are stored in the instance_relationship table, treating relationships as separate entities. Therefore, incorporating them into the audit log would require additional effort: creating domain events for relationships, consuming these events, and documenting the changes in the instance audit database table.

Jan 21, 2025

complete

10

Confirm whether the linking of authorities to bibs be reflected in change log

When a MARC bib field is linked to a MARC authority heading, indicate that the field was changed in the bib version history

@Kateryna Senchenko to confirm that this will be captured as an update in quickMARC

 

analysis

11

Do we need to implement this issue (https://folio-org.atlassian.net/browse/MODINVSTOR-1220 ) as a part of UXPROD-4125 or UXPROD-4126?

 

  • Specific story not related to feature

  •  

Jan 14, 2025

complete

12

What is the impact of implementing these issues https://folio-org.atlassian.net/browse/MODINVSTOR-1207 and https://folio-org.atlassian.net/browse/MODINVSTOR-1268 after UXPROD-4125 or UXPROD-4126?

 

Not related

Jan 14, 2025

complete

13

Requirement for showing only 15 cards at one time (need UI requirements)

  • What if the entire card won’t fit on the screen, do we wrap or something else (collapsing, additional see more button?)

  • Do not make cards expandable/collapsible

 

Jan 14, 2025

complete

14

How do we show change history when the repeatable fields are changed in Instance?

We do not need to add a separate line for each contributor(s) that was changed. If more than one contributor has been added/edited/removed, just have one line of “Contributors” with the change type. We don’t have to capture the inner fields that have changed, just the higher level field.

  • See answer

  • Need requirements:

    • Potentially just show that the contributors list was updated

    • If there are multiple contributors changed, do we have one line that contributor(s) were changed or multiple lines with each contributor

    • For inner fields of objects, how should we display these changes?

    • Do we append the index/order into the name of the field, like "contributors.0.xxx" or "contributors[0].xxx" when showing in the change history

Jan 14, 2025

complete

15

How do we show change history when the multiple fields are changed in quickMARC?

For repeatable fields, include a card for each separate field (ex: multiple 600s would have a separate card for each 600)

 

Jan 16, 2025

complete

16

Will we add the highlighted fields on the record in the future?

Yes - need to discuss how to do this in the current implementation.

@Christine Schultz-Richert -

  •  

review

17

Will we add the rollback capability in the future?

Yes

  • N/A until planned in future release (would require some level of changes to current design)

Jan 14, 2025

complete

18

Do we include bound-with changes?

No

  •  

Jan 16, 2025

complete

19

What do we do with records that are already in the system?

 

  • Check with Thunderjet FE - maybe pulling metadata component?

    • Capture just at the first update

analysis

20

Holdings & item deletion - where do we log?

We don’t have to display in the UI version history. But we need a way for an institution to make a call that will return records that were deleted via an API

@Khalilah Gambrell - to create a spike for team to investigate the LOE for exposing deleted holdings/items so that institutions can make a call via API to retrieve

Jan 16, 2025

complete

21

Do/where we display deletions for instances and authorities?

No, we do not need to display deletions for instances or authorities

 

Jan 16, 2025

complete

22

For which records do we retain the audit history when deleted?

Based on conversation below, we should retain audit history for Instances even when marked as set for delete.


Question: Instances - @Ryan Taylor - in the scenario where the Instance record is set for deletion, are we saying that the history is removed too? Or should we retain the history?

Answer:@Christine Schultz-Richert -- Version history should be retained when an Instance has been set for deletion. Since “hard deletes” are not supported in UI for Instances today. Users will still have the ability to change an Instance back to active (or “un-delete”). As such, we should retain Instance Version History even after its been set for deletion.

 

Jan 21, 2025

complete

23

Do we retain history for authority records that are in the archive?

Remove history when authority record is deleted from the UI/data import action

 

Jan 16, 2025

complete

 

Related pages