Delivery Request Support: Extend Patron Account Object to Include Fulfillment Preferences
Description
Environment
Potential Workaround
Attachments
Checklist
hideTestRail: Results
Activity

Brooks TravisApril 20, 2022 at 2:19 AM
Thanks for finding this, I’ll get it linked to a feature and try to get it in the queue.

Tim DarlingtonApril 20, 2022 at 2:14 AM
In addition to the scenarios already mentioned:
Given user is creating a request in discovery or OPAC
When fulfillment preference = delivery
If the user sees that the delivery addresses available are outdated, some means of notifying the Library is needed, eg via a Notes field.

Tim DarlingtonApril 20, 2022 at 2:11 AM
This is also needed for Massey University. We offer distance education in addition to teaching on-campus with about half of our students enrolled for distance education and using delivery requesting via our discovery service. In addition, as part of our Covid response we extended delivery requesting to all staff and students, so the great majority of our requests have delivery fulfillment preference. Inclusion of delivery request functionality in edge patron API would help us a lot. ,
Details
Assignee
UnassignedUnassignedReporter
Cate BoeremaCate Boerema(Deactivated)Priority
P3TestRail: Cases
Open TestRail: CasesTestRail: Runs
Open TestRail: Runs
Details
Details
Assignee
Reporter

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