Support edit for publication patterns
Description
Environment
Potential Workaround
CSP Approved
CSP Request Details
CSP Rejection Details
defines
is cloned by
is duplicated by
Checklist
hideActivity

Gill OsguthorpeOctober 29, 2024 at 4:48 PMEdited
QA: 30/10
User does not have permission "ui-serials-management.rulesets.edit"
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"
When the pattern has predicted piece sets.
Edit option displays and is inactive.
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.
When Status is changed to "Active" and the pattern is saved:
the saved pattern is made the Active one on the serial.
AND the existing active pattern status is changed to "Deprecated".
Note: the user is not informed via a toast that the pattern has been deprecated. Will create separate ticket for this.
The pub pattern view displays rather than the Serial view
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 PMEdited
Agreed between Owen/Gill 2nd Oct → we should offer two options in the Action menu:
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 therulesetNumber
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”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 newrulesetNumber
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 AMEdited
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/orreplaceAndDeprecate
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:
Details
Assignee
Owen StephensOwen StephensReporter
Owen StephensOwen StephensPriority
TBDSprint
NoneDevelopment Team
BienenvolkRelease
Ramsons (R2 2024)TestRail: Cases
Open TestRail: CasesTestRail: Runs
Open TestRail: Runs
Details
Details
Assignee

Reporter

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:
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
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
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
Given the publication pattern view with an active edit option
When I select Edit
Then the Publication pattern edit view is displayed
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
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
Given the publication edit view with valid data
When I make changes
Then the Save & Close button becomes active
Given the publication edit view
When I make changes that are invalid
Then validation rules should operate as for the Create publication pattern form