docsearch
docsearch copied to clipboard
feat: restore focus after closing modal
Related issue https://github.com/algolia/docsearch/issues/1370
data:image/s3,"s3://crabby-images/387c0/387c0ec55518bcbdc78a73e5bdcc4c31b1748033" alt=""
cc @patrickhlauke if you don't mind please help review this one.
Basically the code would store the document.activeElement
when modal is opened, and call focus
on that stored document.activeElement
when modal is closed.
I've added a button to the examples so we can test if the focus can be retained.
Deploy Preview for docsearch canceled.
Name | Link |
---|---|
Latest commit | 715e120eb2f946379f1d6b7267162e0b66c8f53e |
Latest deploy log | https://app.netlify.com/sites/docsearch/deploys/63aefd2b2e5af50008198490 |
is there an easy way for me to check this live without having to work out how to run it locally?
from looking over the code itself, this looks correct though.
Thanks a lot for the PR!
is there an easy way for me to check this live without having to work out how to run it locally?
For a concrete test you'd have to run de playground locally, it should only require installing deps and run yarn playground:start
Thanks a lot for the PR!
is there an easy way for me to check this live without having to work out how to run it locally?
For a concrete test you'd have to run de playground locally, it should only require installing deps and run
yarn playground:start
I can see there's a netlify deploy preview, but it's canceled, any chance to make it work so anyone can test it online instead of running it locally?
Thanks for tackling this, would you mind adding a cypress test for this case?
Sure, I'll add one.
Thanks a lot for the PR!
is there an easy way for me to check this live without having to work out how to run it locally?
For a concrete test you'd have to run de playground locally, it should only require installing deps and run
yarn playground:start
I can see there's a netlify deploy preview, but it's canceled, any chance to make it work so anyone can test it online instead of running it locally?
You can remove the ignore build command of the netlify.toml file, but I don't know if we have a button to re-focus on the website.
Converted into draft until I figure out the cypress test here.
@shortcuts Seems we can't test this feature against the website as docusaurus customizes its search function based on DocSearch
per https://github.com/facebook/docusaurus/blob/0985fa0af338068b4906f409a3f874a319f5359c/packages/docusaurus-theme-search-algolia/src/theme/SearchBar/index.tsx#L148.
Hence I would suggest running cypress against the example site, either react-example
or js-example
should be ok. Testing against a customized search function based on DocSearch where we have no control does't make sense to me.
is there an easy way for me to check this live without having to work out how to run it locally?
from looking over the code itself, this looks correct though.
FYI, if you're going to run locally, you would need Node 16. 18 won't work as far as I see. Here's how you would run the project locally:
- clone
- run
yarn
- run
yarn build
- run
yarn playground:start
Hence I would suggest running cypress against the example site, either react-example or js-example should be ok. Testing against a customized search function based on DocSearch where we have no control does't make sense to me.
Makes a lot of sense indeed! Changing the website:test
here https://github.com/algolia/docsearch/blob/main/package.json#L24 with playground:start
should solve this, no?
(again thanks a lot for the time spent here!)
(again thanks a lot for the time spent here!)
It's my pleasure to improve a project I use every day :)
I think it's ready for review now, I've added some comments to explain why I made such change.
Ooops, CI failed due to https://support.circleci.com/hc/en-us/articles/115014359648-Exit-Code-137-Out-of-Memory
Ooops, CI failed due to https://support.circleci.com/hc/en-us/articles/115014359648-Exit-Code-137-Out-of-Memory
oops D: you can update https://github.com/algolia/docsearch/blob/main/package.json#L18 to prevent building the playground, we don't need it on the CI anyway
I think adding --ignore @docsearch/(cypress|react-example|js-example)
should do it