Search UI
For the fast development of modern, engaging search experiences. 🎉
A JavaScript library for the fast development of modern, engaging search experiences with Elastic. Get up and running quickly without re-inventing the wheel.
Features 👍
- You know, for search - Maintained by Elastic, the team behind Elasticsearch.
- Speedy Implementation - Build a complete search experience with a few lines of code.
- Customizable - Tune the components, markup, styles, and behaviors to your liking.
- Smart URLs - Searches, paging, filtering, and more, are captured in the URL for direct result linking.
- Flexible front-end - Not just for React. Use with any JavaScript library, even vanilla JavaScript.
- Flexible back-end - Use it with Elasticsearch, Elastic Enterprise Search, or any other search API.
Live demos 👀
Connectors
- Elasticsearch
- Elastic Site Search (Swiftype)
- ⚠️ DEPRECATED. Elastic App Search
- ⚠️ DEPRECATED. Elastic Workplace Search
Examples
Get Started 🌟
Installation
npm install @elastic/search-ui @elastic/react-search-ui @elastic/react-search-ui-views
# or
yarn add @elastic/search-ui @elastic/react-search-ui @elastic/react-search-ui-views
Tutorials
Get started quickly with Search UI and your favorite Elastic product by following one of the tutorials below:
Use Cases
Ecommerce
Search UI works great in the ecommerce use-case. Check out our ecommerce guide that includes demo and code examples, as well as general guidance for ecommerce search.
FAQ 🔮
Is Search UI only for React?
Search UI is "headless". You can use vanilla JavaScript or write support for it into any JavaScript framework.
Read about the search-ui package for more information, or check out the Vue.js Example.
Can I use my own styles?
You can!
Read the Custom Styles and Layout Guide to learn more, or check out the Seattle Indies Expo demo.
Can I build my own Components?
Yes! Absolutely.
Check out the Build Your Own Component Guide.
Does Search UI only work with App Search?
Nope! We do have two first party connectors: Site Search and App Search.
But Search UI is headless. You can use any Search API.
Read the Building a custom connector to learn more about building your own connector for your API.
How do I use this with Elasticsearch?
Read the Elasticsearch Connector docs.
Where do I report issues with the Search UI?
If something is not working as expected, please open an issue.
Where can I go to get help?
The Enterprise Search team at Elastic maintains this library and are happy to help. Try posting your question to the Elastic Enterprise Search discuss forums. Be sure to mention that you're using Search UI and also let us know what backend your using; whether it's App Search, Site Search, Elasticsearch, or something else entirely.
Contribute 🚀
We welcome contributors to the project. Before you begin, a couple notes...
- Read the Search UI Contributor's Guide.
- Prior to opening a pull request, please:
- Create an issue to discuss the scope of your proposal.
- Sign the Contributor License Agreement. We are not asking you to assign copyright to us, but to give us the right to distribute your code without restriction. We ask this of all contributors in order to assure our users of the origin and continuing existence of the code. You only need to sign the CLA once.
- Please write simple code and concise documentation, when appropriate.
License 📗
Thank you to all the contributors! 🙏 🙏