Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Spatial Tree - Id is included in search result though the Id is hidden #749

Open
muthubentley opened this issue Jan 30, 2024 · 5 comments
Open

Comments

@muthubentley
Copy link

In Spatial tree even if we hide the Ids from displaying it gets included in search result.
Steps to reproduce:

  1. Input the id "2O" in the search box. Node with id "2O" is filtered and highlighted
    image
    2)Now hide the Id by unchecking the "Show IDs" menu
    image
    3)Again search by inputting "2O" in the search box. Same result gets filtered out
    image

Since the ID is hidden it should not be considered in the search result.
User is using custom trees with LabelOverrides. They are facing the same issue in custom tree as well. Though we search the overridden Label it is not getting reflected in the search result. Please analyze.

@grigasp
Copy link
Member

grigasp commented Jan 30, 2024

This happens because filtering is being done on the backend using default label rules, but ID suffixes are dropped on the frontend. I think suffixes should be dropped by modifying the ruleset instead.

Having said that, the @itwin/breakdown-trees-react package doesn't have a maintainer at the moment, so I'm not sure if we have anyone willing to work on this.

@muthubentley
Copy link
Author

@grigasp I understand dropping the ID on frontend is the reason. But user says there is a specific case that has to be addressed. Say the user uses InstanceLabelOverride and sets the label to UserLabel. In the tree when the UserLabel could not be calculated then the value in 「Presentation.json」の「label.notSpecified」is displayed. User has set this value to "Not specified". This value is not searchable and this will occur in any tree not just @itwin/breakdown-trees-react package.
Take a look at below tree:
image
When I search using "Not specified" nothing shows up:
image
Whereas if just input "not" in the search box, the same node gets filtered:
image

User feels this is bit confusing for them. Is it possible to make the text that is displayed in the tree searchable. In this case "Not specified" should filter out to that one node.

@grigasp
Copy link
Member

grigasp commented Jan 30, 2024

This is an interesting problem...

As I mentioned earlier, filtering is being performed on the backend against the created hierarchy. The "Not specified" label is assigned to nodes that don't have a label, but instead of assigning an English string, we assign a localized string identifier (in this specific case - @Presentation:label.notSpecified@). The string gets translated to user's language on the frontend and the result may not even be close to the identifier (e.g. in Lithuanian it would be "Nenurodyta") and to make things worse - users could enter just a substring of that.

I think to make this totally correct we should:

  1. Match user's input against localized strings used in the hierarchy.
  2. In case there are matches, include their keys in the list of substrings we look for when filtering.

This is a bit more complicated than it may sound as the required APIs don't exist today - there's no way to get a list of all localized strings on the frontend for step 1 and the filtering request currently accepts only 1 filter string while we may need more for step 2.

I'm also not sure this is a big problem - wouldn't it be better to assign fallback values for labels to see at least some useful information instead of "Not specified"? E.g. another property like CodeValue or class label...

@grigasp
Copy link
Member

grigasp commented Jan 30, 2024

FWIW, I filed an issue in our backlog to make sure we support this situation in the new hierarchies builder implementation we've been working on lately.

@muthubentley
Copy link
Author

Thanks for creating a backlog. I understand it is complex. Let me check the priority with user.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants