Funeoz's blog
Create a submit button for Instantsearch.js
Funeoz
06 January 2022
Instantsearch.js docs don’t have a precise description to create a button that makes a request.
Here is a simple way to do it.
Create a parent div to the one that gets the code inserted by Instantsearch:
<div id="searchbar">
<div id="search-box">
<!-- Searchbox widget will be here -->
</div>
</div>
<script src="search.js"></script>
In the JS file, we have:
// search.js
search.addWidget(
instantsearch.widgets.searchBox({
container: "#search-box",
placeholder: "Search for articles",
showSubmit: true,
searchAsYouType: false,
poweredBy: true,
searchOnEnterKeyPressOnly: true,
})
);
We have to use JS to generate the button. It is impossible to put it directly into the HTML file as it blocks the insertion of the Searchbox widget.
Therefore in the Javascript file, we will create the button, give it its text and create the search function:
// search.js
const submitButton = document.createElement("button");
submitButton.innerHTML = "Submit";
submitButton.onclick = onSubmitClick;
document.getElementById("searchbar").appendChild(submitButton);
function onSubmitClick() {
let query = new URLSearchParams(window.location.search).get("query");
search.helper.setQuery(query).search();
}
Final code
<-- search.html -->
<div id="searchbar">
<div id="search-box">
</div>
</div>
<div id="hits">
</div>
<link rel="stylesheet" type="text/css"
href="https://cdn.jsdelivr.net/npm/instantsearch.js@latest/dist/instantsearch.min.css">
<link rel="stylesheet" type="text/css"
href="https://cdn.jsdelivr.net/npm/instantsearch.js@latest/dist/instantsearch-theme-algolia.min.css">
<script src="https://cdn.jsdelivr.net/npm/instantsearch.js@2.10.4"></script>
<script src="https://cdn.jsdelivr.net/npm/algoliasearch@4.5.1/dist/algoliasearch.umd.js"></script>
<script src="assets/js/search.js"></script>
// search.js
const search = instantsearch({
/* your code */
});
search.addWidget(
instantsearch.widgets.searchBox({
container: "#search-box",
placeholder: "Search for articles",
showSubmit: true,
searchAsYouType: false,
poweredBy: true,
searchOnEnterKeyPressOnly: true,
})
);
search.addWidget(
instantsearch.widgets.hits({
/* your code */
})
);
const submitButton = document.createElement("button");
submitButton.innerHTML = "Submit";
submitButton.onclick = onSubmitClick;
submitButton.className = "button is-primary submit-search";
document.getElementById("searchbar").appendChild(submitButton);
function onSubmitClick() {
let query = new URLSearchParams(window.location.search).get("query");
search.helper.setQuery(query).search();
}
search.start();