This commit is contained in:
@@ -4,8 +4,9 @@ SEARCH SPECS
|
||||
|
||||
CASES
|
||||
|
||||
SEARCH: - to have ability to filter by client
|
||||
https://rockfish.ayanova.com/default.htm#!/rfcaseEdit/1503
|
||||
//NOPE: this one deprecated to priority 2, not really required and may be problematic
|
||||
//SEARCH: - to have ability to filter by client
|
||||
//https://rockfish.ayanova.com/default.htm#!/rfcaseEdit/1503
|
||||
|
||||
SEARCH:UI:GENERAL: - Search in V8: should be integrated, not a separate form
|
||||
https://rockfish.ayanova.com/default.htm#!/rfcaseEdit/1672
|
||||
@@ -32,8 +33,12 @@ https://rockfish.ayanova.com/default.htm#!/rfcaseEdit/3506
|
||||
|
||||
REQUIREMENTS
|
||||
|
||||
- USE-CASE: Central text search for any match. Can include tags. Can specify a type of object.
|
||||
- USE-CASE: In-object text search for the typeandid that user is in, e.g. when in Client info form can search on that client.
|
||||
- USE-CASE: Central text search for any match. Can include tags. Can specify a type of object result desired.
|
||||
|
||||
- ? USE-CASE: In-object text search for the typeandid that user is in, e.g. when in Client info form can search on that client.
|
||||
- This is problematic because it seems to require searching for related objects but that's deprecated to priority 2
|
||||
- Maybe more ideally is a search that can be something like "search all workorders FOR THIS CLIENT" or search all units "FOR THIS CLIENT"
|
||||
|
||||
- USE-CASE: Picklist / chooser Search for text of a specific type of object, e.g. find all Clients that contain "squirrel" to drive picklists everywhere
|
||||
- USE-CASE: No snippet (excerpts) just name and type. I think for the initial release I'm *not* going to include snippets with result for several reasons:
|
||||
- Performance: better to get an immediate result than to wait a while to get excerpts that
|
||||
@@ -48,14 +53,20 @@ REQUIREMENTS
|
||||
|
||||
- ROLES: Needs to internally be able to filter by CANREAD property of role user is in (e.g. if no rights to read client no clients returned)
|
||||
- INDEX VISIBLE ID NUMBERS MUST be searchable so ensure they get put into text search with the regular text.
|
||||
- OBJECT ID and/or OBJECT TYPE criteria support (AyaTypeId must be included in search index)
|
||||
- PARENT / OPENABLE OBJECT: Objects that are searchable but not openable directly need to contain their parent type and id, this way we can follow a chain to the openeable object if necessary
|
||||
- OBJECT TYPE criteria support (AyaType must be included in search index)
|
||||
|
||||
- CLIENT_NOT_SERVER_REQUIREMENT: PARENT / OPENABLE OBJECT: Objects that are searchable but not openable directly will be handled by the client
|
||||
- Maybe this is a client concern, not a backend concern as pre-finding all the parents at the backend for the results is slower than
|
||||
dynamically pulling it for one being opened from the client
|
||||
- This is in the object, not in the searchkey as it would be inefficient
|
||||
- Need parent AyaType as an ENUM ATTRIBUTE in the AyaType table for easy traversal
|
||||
- Maybe need parent AyaType as an ENUM ATTRIBUTE in the AyaType table for easy traversal?
|
||||
|
||||
- CLEANUP: Generator able to cleanup index with no matching word (if possible), index with no matching typeandid
|
||||
- CJK INDEX support: same as v7 but tied to Locale, not globally
|
||||
- GROUP BY: group by objectype then objectid (then created date?)
|
||||
- Coding: break this into separate discrete classes, the old v7 code is very monolithic and in-elegant
|
||||
|
||||
//TODO:
|
||||
- SAMPLE DATA: Need a huge amount of sample data indexed to load test it
|
||||
- INDEXES: play with it and see what works best
|
||||
|
||||
|
||||
@@ -33,6 +33,8 @@ IMMEDIATE ITEMS:
|
||||
- Add tests using widget which now sports a Notes property
|
||||
- Add code to do actual search and return results and routes (tags need support too as per search specs)
|
||||
- Add tests for searching and routes
|
||||
- Update all the seeder code to add search indexing so can properly test huge search datasets
|
||||
- Need to find a way to add random text to Notes fields that varies but has some overlap ideally
|
||||
|
||||
- EventLogProcessor.AddEntry: CHANGE this to save the context itself and then change all callers to handle that (remove save)
|
||||
- I originally didn't have the save in there because I thought subsequent code might all share in the single context save,
|
||||
|
||||
Reference in New Issue
Block a user