Details
Assignee
UnassignedUnassignedReporter
Cate BoeremaCate Boerema(Deactivated)Priority
P3TestRail: Cases
Open TestRail: CasesTestRail: Runs
Open TestRail: Runs
Details
Details
Assignee
Unassigned
UnassignedReporter
Cate Boerema
Cate Boerema(Deactivated)Priority
TestRail: Cases
Open TestRail: Cases
TestRail: Runs
Open TestRail: Runs
Created November 24, 2020 at 2:00 PM
Updated May 10, 2022 at 6:35 PM
Problem:
We need to update the edge/mod-patron API schemas to enable creation of delivery fulfillment holds (Requests), rather than the current "pick-up only" support. To do so, we must provide both support for the fields in hold creation payloads (instance and item) required to create a delivery request (fulfillment preference and delivery address), but also indicate to the edge client (eg. a discovery interface) whether the user indicated is permitted to place delivery requests based on their User Request Fulfillment preferences, what their default pickup location or delivery addresses are, and what other delivery addresses are available on their account. This story will address the latter.
Requirements
Extend the schema for
/patron/account/{id
} to include (optional, via url argument, a la loans, holds, and fees/fines) an object containing the user's request fulfillment preferences/options:deliveryEnabled (required if included, boolean)
defaultPickupLocation (optional, UUID of a service point, if set in the user's fulfillment preferences)
defaultFulfillmentMethod (optional, enum of "Holdshelf" or "Delivery")
deliveryAddresses (an array of the addresses on a user's account, with an indicator of which is the default, includes fielded address data)
Acceptance Criteria
When requesting a patron's account information via edge patron, the client can indicate whether request preferences/options are needed
If the client indicates that the patron's request preferences/options are needed, the indicated information is returned based on the user's fulfillment preferences and user contact information
"null" values are not included in the returned object (i.e. if delivery is not enabled, do not include address information, or if defaultPickupLocation is not set, do not include the field in the response)
If mod-patron is unable to resolve the user's fulfillment preferences, it should always return an empty object (i.e. no 500 Errors)
====Original story draft below, for historical reference====
As a patron who is creating a request through EDS or an OPAC (e.g. Blacklight, VuFind)
I want to be able to select a fulfillment preference for my request (this can be hold shelf or, if allowed for my user, delivery) as well as an address for delivery
So that it is clear to FOLIO and circ staff that I need the request to be delivered and where it should be delivered to
Scenarios:
Scenario:
Given user has delivery enabled for their user record
When they create a request via discovery or OPAC
Then edgepatron should enable them to select a fulfillment preference (hold shelf or delivery) for their request
Scenario:
Given user does NOT have delivery enabled for their user record
When they create a request via discovery or OPAC
Then edgepatron should assume that fulfillment preference for the request is hold shelf
Scenario:
Given user has delivery enabled for their user record
When they create a request via discovery or OPAC
Then edgepatron should pass the fulfillment preference (hold shelf or delivery) for the user so it can be auto-selected when they create a request (this is just a convenience for the patron - they should be able to manually change their fulfillment preference, if they wish)
Scenario:
Given user is creating a request in discovery or OPAC
When fulfillment preference = delivery
Then edgepatron should pass:
The default delivery address for the user so it can be auto-selected when they create a request (this is just a convenience for the patron - they should be able to manually change their fulfillment preference, if they wish)
To enable users to change their delivery address, edgepatron should also pass all other address types from the user record
Scenario:
Given user is creating a request in discovery or OPAC
When fulfillment preference = holdshelf
Then edgepatron should pass the default pickup service point from the user record so it can be auto-selected when they create the request (this is just a convenience for the patron - they should be able to manually change their pickup service point, if they wish)
Mock-ups: There is no UI in scope for this user story, but understanding what UI is planned may help clarify the requirements. See attached deck.
Screencast: This screencast shows how user preferences interface with request creation in FOLIO: https://drive.google.com/file/d/1Z0x0XrIXRPFAqBKk-5jCT4ItabFlktja/view?usp=sharing