Support edit for publication patterns

Description

Purpose:

To support an edit option for publication patterns that have not yet been used to generate predicted pieces. If there are any predicted piece sets linked to a publication pattern it will not be possible to edit the pattern (although an active pattern can be deprecated by making a new active pattern as currently)

User story statement(s):

As a Serials librarian
I want to edit a serials publication pattern
so that I can fix any issues, or work incrementally on a pattern

Scenarios:

  1.  

    Given the publication pattern view with no associated predicted piece sets, and a user with permission ui-serials-management.rulesets.edit
    When I view the publication pattern
    There is an action menu with an active Edit option
    NB The Ctrl+Shift+E / Cmd+Opt+E short cut should work to also trigger the edit if the pattern can be edited and the user has permissions

  2.  

    Given the publication pattern view with no associated predicted piece sets, and a user withOUT permission ui-serials-management.rulesets.edit
    When I view the publication pattern
    There is an action menu with an inactive Edit option

  3.  

    Given the publication pattern view WITH associated predicted piece sets
    When I view the publication pattern
    There is an action menu with an inactive Edit option


  4. Given the publication pattern view with an active edit option
    When I select Edit
    Then the Publication pattern edit view is displayed


  5. Given the publication edit view
    When I see the edit screen
    Then it lays out all the information for the publication pattern in an edit form that is the same as the current publication pattern creation form. Note that it is important that the labelling ordering and template tokens are preserved in the right order (i.e. if there are two enumerations and one chronology, then enumeration1 and enumeration2 and chronology1 are all preserved in the same way as when the pattern was created
    NB we could consider splitting the Labelling into “Enumeration” and “Chronology” in both creation and edit form to make ordering of display and management more intuitive


  6. Given the publication edit view with a status set to “Active”
    When I save the publication pattern
    Then the saved publication pattern is made active, and any currently active publication patterns for the serial are made Deprecated


  7. Given the publication edit view with valid data
    When I make changes
    Then the Save & Close button becomes active

  8.  

    Given the publication edit view
    When I make changes that are invalid
    Then validation rules should operate as for the Create publication pattern form

Environment

None

Potential Workaround

None

CSP Approved

None

CSP Request Details

None

CSP Rejection Details

None
100% Done
Loading...

Checklist

hide

Activity

Show:

Gill OsguthorpeOctober 29, 2024 at 4:48 PM
Edited

QA: 30/10

User does not have permission "ui-serials-management.rulesets.edit"

  1. The Edit option should not be displayed at all. This follows the UX guideline to hide any elements which will never be active for the user.

User has the permission "ui-serials-management.rulesets.edit"

  1. When the pattern has predicted piece sets.

  • Edit option displays and is inactive.

  1. When the pattern has no predicted piece sets.

  • Edit option displays and is active.

  • Pattern edit form is the same as the "New" pattern form.

  • Label order is maintained.

    • Note: The combination rules were reordered when the form was edited. However, this also happens when a new pattern is created.

  1. When Status is changed to "Active" and the pattern is saved:

    1. the saved pattern is made the Active one on the serial.

    2. AND the existing active pattern status is changed to "Deprecated".

      1. Note: the user is not informed via a toast that the pattern has been deprecated. Will create separate ticket for this.

    3. The pub pattern view displays rather than the Serial view

      1. Note: a new pattern should also follow this behaviour - instead the serial is displayed. Need a ticket for this.

Owen StephensOctober 3, 2024 at 12:16 PM
Edited

Agreed between Owen/Gill 2nd Oct → we should offer two options in the Action menu:

  1. Edit → this is visible in the Actions menu if the user has perms to edit, BUT it is only active as an option if the publication pattern is not linked to any predicted piece sets and the replaceandDelete option can be used. To the user this will look like an edit and no further explanation of the underlying mechanism is required in the UI. In this scenario the rulesetNumber should be copied along with the rest of the data so that when the user saves the new pattern it has the same number as the original, now deleted, pattern. The modal the user interacts with after choose “Edit” should be headed “Edit”

  2. Copy and deprecate → this is visible in the Actions menu if the user has perms to edit and is always Active. This should be implemented instead of the “Create modified” in although the basic mechanism is the same but it uses the proposed replaceandDeprecate option. In this case there should be a new rulesetNumber for the new pattern. The modal the user interacts with after choose “Copy and deprecate” should be headed “Copy and deprecate”

Jag GorayaOctober 2, 2024 at 10:43 AM

  • Test coverage > 80% achieved

  • Mockups pending following UI/UX and language discussion

    • use Edit when ruleset not used

    • use Replace and Deprecate when ruleset is used

  • UNKNOWN: Workflow use case: “duplicate and deprecate” / “clone”

    • is this needed? if so, is this work to do as part of this?

    • to follow up with in Slack

  • Terminology to be clarified.

  • TODO: new tests

Jag GorayaSeptember 30, 2024 at 10:29 AM
Edited

  • Need UI/UX input as to whether

    • single Edit option is sufficient

    • Edit labelling

    • how we feedback to users that a deprecated ruleset is in play

  • See Slack thread for approach update: handle these through a replaceAndDelete and/or replaceAndDeprecate  endpoint.

Jag GorayaAugust 21, 2024 at 11:42 AM

  • Approach

    • PUT endpoint for pattern needs to validate to prevent in-use pattern being edited

    • Check frontend form data is reversible

    • Add reverser for form

    • Determine how to decide whether Edit action is visible/active

    • Ensure order of rules are maintained

  • Components and Changes

    • Frontend: new route for serials ruleset edit

    • Backend: custom binding, PUT endpoint validation

  • Tests / Data / Dependencies

    • extend tests for ruleset form (for populated form with initial values)

    • new tests for new ruleset edit route component

  • Known Unknowns

    • Check what happens when attempting to re-bind

    • Complexity with some reversal transformations, eg, dates

  • QA: snapshot

  • Release Target: Ramsons

  • Development Estimate:

Done

Details

Assignee

Reporter

Priority

Sprint

Development Team

Bienenvolk

Release

Ramsons (R2 2024)

TestRail: Cases

Open TestRail: Cases

TestRail: Runs

Open TestRail: Runs

Created August 21, 2024 at 8:34 AM
Updated November 8, 2024 at 2:38 PM
Resolved November 8, 2024 at 2:38 PM
TestRail: Cases
TestRail: Runs