Implement Advanced search modal

CSP Request Details

None

CSP Rejection Details

None

CSP Approved

None

Description

Overview: Implementation of Advanced search in Inventory will support search using boolean operators. The Advanced Search modal is already implemented in the MARC Authority app (https://folio-snapshot.dev.folio.org/marc-authorities). Elasticsearch does support search across all record types in Inventory (Instance, Holdings, Item - )

In scope:

  • Advanced search modal in Inventory search on Instance / Holdings / Item toggles

Out of scope:

  • Selecting record type in modal

  • Use case: A staff user want to combine searches across all one or two record types, and have more advanced search options than provide with the simple Search and filter screen; one example is be able to mix item material type search with an instance search.

Requirements (see attached mockup):

  • Add new "Advanced search" button to the right of the "Reset all" button for Instance, Holdings, and Item toggles

  • Add boolean operator dropdown for AND, OR, and NOT

  • Include all search options (with the exception of Query search)

  • Additional dropdown that supports: starts with, exact phrase, and contains all and contains all should be the default value in the dropdown

Scenarios:

  1. Scenario - Modal

    • Given the user is in the Inventory app and

    • When the user selects the "Advanced search" button to the right of the "Reset all" button

    • Then the Advanced search modal should appear

  2. Scenario - Modal options

    • Given the user has selected the "Advanced search" button to the right of the "Reset all" button

    • When the Advanced search modal appears

    • Then the modal should contain 6 rows of four fields:

      • Boolean operator dropdown

      • Search for term

      • Search type

      • Search field

  3. Scenario - AND operator

    • Given the user has selected the Advanced search button and the Advanced search modal appeared

    • When the user uses the AND operator

    • Then the search query should return Instances that meet both criteria

  4. Scenario - OR operator

    • Given the user has selected the Advanced search button and the Advanced search modal appeared

    • When the user uses the OR operator

    • Then the search query should return Instances that meet any of the criteria

  5. Scenario - NOT operator

    • Given the user has selected the Advanced search button and the Advanced search modal appeared

    • When the user selects the NOT operator

    • Then the search query should return Instances that do not meet the entered criteria

  6. Scenario - Starts with 

    • Given the user has selected the Advanced search button and the Advanced search modal appeared

    • When the user selects the Starts with search type

    • Then the search query should return Instances that match the left-anchored search term

  7. Scenario - Exact match

    • Given the user has selected the Advanced search button and the Advanced search modal appeared

    • When the user selects the Exact phrase search type

    • Then the search query should return Instances that exactly match the search term entered

  8. Scenario - Contains

    • Given the user has selected the Advanced search button and the Advanced search modal appeared

    • When the user selects the Contains type

    • Then the search query should return Instances that contain the entered search term 

Additional Information:

 

Environment

None

Potential Workaround

None

Attachments

22

relates to

Checklist

hide

TestRail: Results

Activity

Show:

Christine Schultz-RichertJuly 28, 2023 at 1:43 PM

Hi - Yes, we will be considering this option in a later iteration of the modal. Thank you for keeping tabs on it!

 

Charlotte WhittJuly 21, 2023 at 3:04 PM
Edited

- users typical would like to search across record types (Instance, Holdings, Item) when using Advanced search. Right now the the advanced search modal only supports search within the given segment:

One way to solve it would be to add a column, where you could select record type, and then the drop down menu with search options would be reflecting the choise of record type.
Is this something coming at a later iteration of the Advanced search modal?

CC:

Yauhen ViazauJuly 19, 2023 at 3:28 PM

Moving this ticket to PO review as remaining related issues will be reviewed and addressed in , 

Yauhen ViazauJuly 19, 2023 at 2:06 PM

Tested on Snapshot-1 - issue remains

Issue 1 still remains. See attached screencasts: 

  •  

Also found a new, possibly related, issue - Instance tab - Effective CN option - does not search for Item call number (specified either in Holdings or in Item). Opened a separate ticket for it -

Denys BohdanJuly 18, 2023 at 11:47 AM

Hey , could you take a look at issue 2? What is the difference between holdingsNormalizedCallNumbers="value" and holdingsNormalizedCallNumbers=="value"? From https://github.com/folio-org/mod-search#cql-query-operators it looks like = is the same as == for term fields

Done

Details

Assignee

Reporter

Tester Assignee

Priority

Story Points

Sprint

Development Team

Spitfire

Fix versions

Release

Poppy (R2 2023)

TestRail: Cases

Open TestRail: Cases

TestRail: Runs

Open TestRail: Runs

Created February 3, 2022 at 3:14 PM
Updated December 21, 2023 at 4:56 PM
Resolved July 28, 2023 at 2:07 PM
TestRail: Cases
TestRail: Runs