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

fix(searchbox): handle Enter key in the input field to search + blur #1065

Merged
merged 1 commit into from
Apr 18, 2024

Conversation

lorumic
Copy link
Contributor

@lorumic lorumic commented Apr 8, 2024

Done

  • Make SearchBox trigger search on Enter keydown, and blur the input field.

QA

Storybook

To see rendered examples of all react-components, run:

yarn start

QA in your project

from react-components run:

yarn build
npm pack

Install the resulting tarball in your project with:

yarn add <path-to-tarball>

QA steps

  • Check SearchBox examples in Storybook
  • Press "Enter" on the enabled examples and see that the input field blurs

Percy steps

This should not produce visual changes in Percy.

@webteam-app
Copy link

@bartaz
Copy link
Member

bartaz commented Apr 8, 2024

When is this needed?

Search box includes a submit button to perform search. And it should be placed inside a form element that performs given search. In such case ENTER key is handled natively by the browser (it performs the submit of the form).

image

I guess in apps it may be more natural to use SearchBox component outside of the context of the form that does the search. Then maybe the form itself could be part of the component?

Because the proposed solution looks a bit like a workaround to something that could work natively.

@bartaz
Copy link
Member

bartaz commented Apr 8, 2024

Now I noticed the difference. In Vanilla examples the p-search-box is on <form> element.
In React the root element of the SearchBox component is a <div>.

So a better solution would be to change the React component to use <form> instead and handle submit on it (that would cover both clicking on submit icon and enter key).
The downside (and I think that's why it was not done this way) is that if you want to use such component INSIDE another form it would be an issue to have it's own form built-in.

@lorumic
Copy link
Contributor Author

lorumic commented Apr 8, 2024

This is needed every time we have a search box to filter the results in any table / list of results. No form in that case as the action (filtering) is performed onChange. So it's just a way to align the behaviour of the click on the magnifier icon and the Enter key press. I'll leave any further clarification to the requester of this change, @acarege

@bartaz
Copy link
Member

bartaz commented Apr 8, 2024

I don't think this component was meant to do filtering at all.

Search & Filter component was meant to more advanced search and filter functionality.

@lorumic
Copy link
Contributor Author

lorumic commented Apr 8, 2024

Maybe I didn't express myself properly. By "filtering" I mean setting a search query and showing only the results matching that query, as in the example below:

Peek 2024-04-08 09-42

I don't think the SearchAndFilter is the right component to do this. Also, it doesn't have the magnifier icon, so it would not have the correct appearance.

@bartaz
Copy link
Member

bartaz commented Apr 8, 2024

I guess we get to the point where it's more of a design UX question than implementation question.

So far the SearchBox component was meant for triggering search (when Enter/Search is hit). Not for automatic searching/filtering.
The SearchAndFilter component was meant for automatic searching and filtering (why it doesn't have a search icon is a question I don't have answer to).

If neither component does what you want to do, it's something that should be brought up in design (possibly Vanilla Working Group).

@lorumic
Copy link
Contributor Author

lorumic commented Apr 8, 2024

SearchAndFilter seems an overkill to do what shown in the screen capture above. To be honest, I don't see which problem the changes in this PR create. It should just work fine in every case - both inside and outside a form.

@lorumic lorumic force-pushed the searchbox-enter-key branch from a7c6ae3 to cb3b51b Compare April 8, 2024 08:12
@lorumic lorumic requested a review from edlerd April 8, 2024 08:13
@bartaz
Copy link
Member

bartaz commented Apr 8, 2024

SearchAndFilter seems an overkill to do what shown in the screen capture above. To be honest, I don't see which problem the changes in this PR create. It should just work fine in every case - both inside and outside a form.

I agree that SearchAndFilter seems overkill, I just wanted to make sure it's clarified from design point of view, because there was some effort at some point to define how search/filter should work and which component does what, and by allowing some exceptions we may move away from consistency.

As for the functionality itself, it seems that the fact that there actually is onSearch handler on SearchBox component already is allowing it not only to "submit" search relying on external form. So I guess making sure ENTER triggers it as well is an improvement.
Would be good to verify how does that behave with form now. Would enter trigger the search AND submit the form? Should it cancel propagation (or default handler) so that form is not submitted if handler is triggered?

@lorumic
Copy link
Contributor Author

lorumic commented Apr 8, 2024

Would be good to verify how does that behave with form now. Would enter trigger the search AND submit the form? Should it cancel propagation (or default handler) so that form is not submitted if handler is triggered?

Good point. I will test this specifically and get back to you with the result.

@lorumic
Copy link
Contributor Author

lorumic commented Apr 8, 2024

@bartaz I tested the behaviour in Form component's Storybook. I added an onSubmit argument with a simple console.log to the args of the default example, then replaced the Input children with a SearchBox, and tried hitting Enter there to see if the onSubmit code got executed, but it didn't.

I'm not sure this is a good approach to test it, what do you think? Should I add an e.stopPropagation() to the keydown event handler for the Enter key just in case?

@bartaz
Copy link
Member

bartaz commented Apr 8, 2024

Should I add an e.stopPropagation() to the keydown event handler for the Enter key just in case?

I'm afraid that adding that in by default will actually prevent ENTER from triggering submit of a form when it's needed.
So it's probably better as is.

The only problematic scenario may be if someone has both onSearch and a surrounding form to submit. But that would be a weird case already.

Copy link
Member

@bartaz bartaz left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM from code point of view.

@bartaz
Copy link
Member

bartaz commented Apr 8, 2024

I'm not 100% sure if blur by default is a desired behaviour (what if there is some validation and you should stay in the search to fix the value?). But I guess we can verify in practice if that creates any issues.

@lorumic
Copy link
Contributor Author

lorumic commented Apr 8, 2024

I'm not 100% sure if blur by default is a desired behaviour (what if there is some validation and you should stay in the search to fix the value?). But I guess we can verify in practice if that creates any issues.

What about changing the condition to:

      if (e.key === "Enter" && internalRef.current.checkValidity()) {

Would that be a good solution?

Copy link
Contributor

@edlerd edlerd left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@lorumic lorumic force-pushed the searchbox-enter-key branch from cb3b51b to 5e4c27e Compare April 16, 2024 19:15
@@ -91,6 +91,13 @@ const SearchBox = React.forwardRef<HTMLInputElement, Props>(
onSearch && onSearch();
};

const onKeyDown = (e: KeyboardEvent<HTMLInputElement>) => {
if (e.key === "Enter" && internalRef.current.checkValidity()) {
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This should stop blur when the input contains an invalid value (#1065 (comment))

@lorumic lorumic merged commit f4f011b into canonical:main Apr 18, 2024
8 checks passed
@lorumic lorumic deleted the searchbox-enter-key branch April 18, 2024 08:45
Copy link

🎉 This PR is included in version 0.51.5 🎉

The release is available on:

Your semantic-release bot 📦🚀

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

Successfully merging this pull request may close these issues.

4 participants