The Helper has been made to create search-based applications. It will help you structure the search of your app with a rock solid foundation, and enhance it with advanced search features. Compared to the JS client, the Helper is focused on providing search only features, and provides an higher level API which will give you an easy access to advanced search filters.
This getting started will show you how to:
The getting started will use jQuery for the sake of simplicity. However, the Helper is agnostic and can also be used with other frameworks or libraries.
In order to follow this tutorial you need to have access to an Algolia index. The easiest way to follow this tutorial is by using the provided credentials, using our ecommerce dataset. You can also adapt it to your own dataset.
In order to use the full power of Algolia in the most efficient manner we have created InstantSearch.js and react-instantsearch to quickly build search UIs.
For the purpose of this tutorial, we'll use our ecommerce dataset. For further reference, here are the credentials that we're going to use:
applicationID
: latency
apiKey
: 249078a3d4337a8231f1665ec5a44966
indexName
: bestbuy
You need an Algolia account. You also need to upload a dataset and your search credentials. Here are the elements you need for the rest of the tutorial:
applicationID
)apiKey
)indexName
)You can still use the provided Algolia index, if you prefer. Otherwise, let's proceed with the setup of the library in the application.
The helper is available on different platforms. You can use it as a script or npm. As the helper extends the client, we need to import both of them.
Using scripts, you can import the helper directly in your webpage. You will also need to import the Algolia JS client. To import the libraries, add those lines in your page:
<script src="https://cdn.jsdelivr.net/npm/algoliasearch@3/dist/algoliasearchLite.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/algoliasearch-helper@3.22.5/dist/algoliasearch.helper.min.js"></script>
In an npm project, include the project with this command:
npm install --save algoliasearch algoliasearch-helper
You can also use Yarn:
yarn add algoliasearch algoliasearch-helper
The first step toward searching in your index is to initialize the client and provide it to the helper factory.
/* if you use npm, you also need to add the correct requirements
var algoliasearch = require('algoliasearch');
var algoliasearchHelper = require('algoliasearch-helper');
*/
var client = algoliasearch(applicationID, apiKey);
var helper = algoliasearchHelper(client, indexName);
Once you've added those lines, you need to listen to the results coming from Algolia. For now, we'll implement a very basic display of the JSON response in the page.
helper.on('result', function (event) {
renderHits(event.results);
});
function renderHits(content) {
$('#container').html(JSON.stringify(content, null, 2));
}
At this point, we have no results yet. It's because we didn't trigger any search. For now, we will do an empty search on your index. This will return the results ordered according to the custom ranking. Let's see how to trigger the search:
helper.search();
The search
method of the helper triggers the search with the current parameters saved in the helper. For the moment we have none, therefore the results contains the first records ordered by the custom ranking.
You now know:
result
event and read the results from AlgoliaThe empty search is a great tool to display the first step of a search but it is not what our users are looking for. They want to search in your data. Let's see how to add a search input to let our users do a textual search in the data.
Before going further, let's customize a little bit the display of our results. We're going to focus on the actual results computed by Algolia. The results are returned in the hits
attribute of the results
. Let's display only the name
of each product for now.
helper.on('result', function (event) {
renderHits(event.results);
});
function renderHits(content) {
$('#container').html(function () {
return $.map(content.hits, function (hit) {
return '<li>' + hit.name + '</li>';
});
});
}
Now that we have filtered the information displayed, let's add our search input:
<input type="text" autocomplete="off" id="search-box" />
And now let's listen to the changes to this input, so that we can update the query and trigger a new search.
$('#search-box').on('keyup', function () {
helper.setQuery($(this).val()).search();
});
When calling setQuery
, we change the value of the query inside the helper. But this does not trigger the search, we need to trigger it manually, that's why we call search
afterwards.
To help our users better understand the results, let's use the highlighted results returned by Algolia. This way the users can easily understand why the results match their query.
helper.on('result', function (event) {
renderHits(event.results);
});
function renderHits(content) {
$('#container').html(function () {
return $.map(content.hits, function (hit) {
return '<li>' + hit._highlightResult.name.value + '</li>';
});
});
}
The object _highlightResult
contains all the attributes that may be highlighted (by default, all the searchable attributes).
In this part, we have seen:
A facet is a filter that can be used to restrict the results to specific values of an attribute. For example, in our records we have an attribute type
, with a facet we can restrict the results to only movie
. This way the results returned by Algolia will only be those for which the attribute type
has movie
as a value.
If you're using your own data in this tutorial, you must add the attributes you want to facet in the display configuration of your index. By the way, we also have a complete documentation on this subject.
First we should declare that we want to use the attribute type
as a facet. This is done during the initialization of the helper.
var helper = algoliasearchHelper(client, indexName, {
facets: ['type'],
});
The list of available facets is returned by the Algolia API. This list is dynamic and should be updated at each new results. So that's why we render this list each time we receive new results. This list also lets our user select a value, so we should also make it so that it's possible using jQuery.
$('#facet-list').on('click', 'input[type=checkbox]', function (e) {
var facetValue = $(this).data('facet');
helper.toggleFacetRefinement('type', facetValue).search();
});
function renderFacetList(content) {
$('#facet-list').html(function () {
return $.map(content.getFacetValues('type'), function (facet) {
var checkbox = $('<input type=checkbox>')
.data('facet', facet.name)
.attr('id', 'fl-' + facet.name);
if (facet.isRefined) checkbox.attr('checked', 'checked');
var label = $('<label>')
.html(facet.name + ' (' + facet.count + ')')
.attr('for', 'fl-' + facet.name);
return $('<li>').append(checkbox).append(label);
});
});
}
The method getFacetValues returns the list of values usable to filter an attribute. The object returned by this method contains three properties:
name
: the value of the facetcount
: the number of items in the whole resultsisRefined
: is this value already selectedLet's add the rendering of the facet list into the result
handler.
helper.on('result', function (event) {
renderFacetList(event.results);
renderHits(event.results);
});
We now have a menu displaying the values that the user can choose from to filter the list of results. Those values are generated by Algolia based on the rest of the search, meaning that it will only provide facet values that are meaningful for the current other parameters. Try typing apple and the filter item movie will be removed.
This kind of facets are called conjunctive facets but they are not the only kind of filtering that you can apply with the helper. You can also do:
In this part, we have seen:
Congratulations! You now know the basics of the Helper. You should, by now, have a better overview of the kind of features available in the Helper, as well as the mechanics involved.
Here are some pointers on where to go next:
Last but not least, the Helper is an intermediate API on top of the client and it doesn't solve the UI complexity on its own. If you're looking for a more off-the-shelf solution, we created instantsearch.js which reuses the helper internally.