Skip to content

Instantly share code, notes, and snippets.

@rayrutjes
Created July 7, 2016 12:48
Show Gist options
  • Star 9 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save rayrutjes/0814a08ec0ad78e370299b572840405b to your computer and use it in GitHub Desktop.
Save rayrutjes/0814a08ec0ad78e370299b572840405b to your computer and use it in GitHub Desktop.
Some boilerplate to create an instantsearch.js search experience in your WordPress theme. This works in combination with the Algolia Search plugin for WordPress.
#ais-wrapper {
display: flex;
}
#ais-main {
padding: 1rem;
width: 100%;
}
#ais-facets {
width: 40%;
padding: 5%;
padding: 1rem;
}
.ais-facets {
margin-bottom: 2rem;
}
.ais-clearfix {
clear: both;
}
#algolia-search-box {
position: relative;
margin-bottom: 2rem;
}
.ais-search-box--input {
/* search input */
}
.ais-search-box--powered-by {
font-size: .8em;
text-align: right;
margin-top: 2px;
}
.ais-search-box--powered-by-link {
display: inline-block;
width: 45px;
height: 16px;
text-indent: 101%;
overflow: hidden;
white-space: nowrap;
background-image: url("");
background-repeat: no-repeat;
background-size: contain;
vertical-align: middle;
}
.ais-stats {
position: absolute;
bottom: 0;
font-size: .8rem;
}
.ais-stats--header {
/* widget header */
}
.ais-stats--body {
/* widget body */
}
.ais-stats--time {
/* processing time */
}
.ais-stats--footer {
/* widget footer */
}
.ais-sort-by-selector--item {
/* selector item */
}
.ais-hits__empty {
/* empty container */
}
.ais-hits--item {
/* hit item */
margin-bottom: 2rem;
}
.ais-hits--item h2 {
margin-bottom: .75rem;
}
.ais-hits--categories {
margin-bottom: 1rem;
}
.ais-hits--category {
background: #F2F2F2;
padding: 0.5rem 1rem;
border-radius: 3px;
display: inline-block;
margin-right: .5rem;
margin-bottom: .5rem;
}
.ais-hits--item em, .ais-hits--item a em {
font-style: normal;
background: #21A4D7;
color: #FFFFFF;
}
.ais-hits--thumbnail {
float: left;
margin-right: 2rem;
}
.ais-hits--content {
overflow: hidden;
}
.ais-hits--thumbnail img {
border-radius: 3px;
}
.ais-pagination {
margin: 0;
}
.ais-pagination--item {
/* pagination item */
display: inline-block;
padding: 3px;
}
.ais-pagination--item__disabled {
/* disabled pagination item */
display: none;
}
.ais-pagination--item__active {
/* active pagination item */
}
.ais-pagination--item__first {
/* first pagination item */
}
.ais-pagination--item__previous {
/* previous pagination item */
}
.ais-pagination--item__page {
/* page pagination item */
}
.ais-pagination--item__next {
/* next pagination item */
}
.ais-pagination--item__last {
/* last pagination item */
}
.ais-pagination--link {
/* pagination link */
}
.ais-refinement-list--header {
/* widget header */
}
.ais-refinement-list--body {
/* wudget footer */
}
.ais-refinement-list--list {
/* item list */
}
.ais-refinement-list--item {
/* list item */
}
.ais-refinement-list--item__active {
/* active list item */
}
.ais-refinement-list--label {
/* item label */
}
.ais-refinement-list--checkbox {
/* item checkbox */
}
.ais-refinement-list--count {
/* item count */
display: none;
}
.ais-refinement-list--footer {
/* widget footer */
}
/* Sub block for the show more of the refinement list */
.ais-show-more__active {
/* Show more button is activated */
}
.ais-show-more__inactive {
/* Show more button is deactivated */
}
.ais-menu--header {
/* widget header */
}
.ais-menu--body {
/* widget body */
}
.ais-menu--list {
/* item list */
}
.ais-menu--item {
/* list item */
}
.ais-menu--item__active {
/* active list item */
font-weight: bold;
}
.ais-menu--link {
/* item link */
}
.ais-menu--count {
/* item count */
display: none;
}
.ais-menu--footer {
/* widget footer */
}
.ais-toggle--header {
/* widget header */
}
.ais-toggle--body {
/* wudget body */
}
.ais-toggle--list {
/* item list */
}
.ais-toggle--item {
/* list item */
}
.ais-toggle--item__active {
/* active list item */
}
.ais-toggle--label {
/* item label */
}
.ais-toggle--checkbox {
/* item checkbox */
}
.ais-toggle--count {
/* item count */
}
.ais-toggle--footer {
/* widget footer */
}
.ais-hierarchical-menu--header {
/* widget header */
}
.ais-hierarchical-menu--body {
/* widget body */
}
.ais-hierarchical-menu--list {
/* item list */
}
.ais-hierarchical-menu--list__lvl0 {
/* item list level 0 */
}
.ais-hierarchical-menu--list__lvl1 {
/* item list level 1 */
margin-left: 10px;
}
.ais-hierarchical-menu--list__lvl2 {
/* item list level 0 */
margin-left: 10px;
}
.ais-hierarchical-menu--item {
/* list item */
}
.ais-hierarchical-menu--item__active {
/* active list item */
}
.ais-hierarchical-menu--link {
/* item link */
}
.ais-hierarchical-menu--count {
/* item count */
}
.ais-hierarchical-menu--footer {
/* widget footer */
}
.ais-range-slider--target {
position: relative;
direction: ltr;
background: #F3F4F7;
height: 6px;
margin-top: 2em;
margin-bottom: 2em;
}
.ais-range-slider--base {
height: 100%;
position: relative;
z-index: 1;
border-top: 1px solid #DDD;
border-bottom: 1px solid #DDD;
border-left: 2px solid #DDD;
border-right: 2px solid #DDD;
}
.ais-range-slider--origin {
position: absolute;
right: 0;
top: 0;
left: 0;
bottom: 0;
}
.ais-range-slider--connect {
background: #46AEDA;
}
.ais-range-slider--background {
background: #F3F4F7;
}
.ais-range-slider--handle {
width: 20px;
height: 20px;
position: relative;
z-index: 1;
background: #FFFFFF;
border: 1px solid #46AEDA;
border-radius: 50%;
cursor: pointer;
}
.ais-range-slider--handle-lower {
left: -10px;
bottom: 7px;
}
.ais-range-slider--handle-upper {
right: 10px;
bottom: 7px;
}
.ais-range-slider--tooltip {
position: absolute;
background: #FFFFFF;
top: -22px;
font-size: .8em;
}
.ais-range-slider--pips {
box-sizing: border-box;
position: absolute;
height: 3em;
top: 100%;
left: 0;
width: 100%;
}
.ais-range-slider--value {
width: 40px;
position: absolute;
text-align: center;
margin-left: -20px;
padding-top: 15px;
font-size: .8em;
}
.ais-range-slider--value-sub {
font-size: .8em;
padding-top: 15px;
}
.ais-range-slider--marker {
position: absolute;
background: #DDD;
margin-left: -1px;
width: 1px;
height: 5px;
}
.ais-range-slider--marker-sub {
background: #DDD;
width: 2px;
margin-left: -2px;
height: 13px;
}
.ais-range-slider--marker-large {
background: #DDD;
width: 2px;
margin-left: -2px;
height: 12px;
}
.ais-range-slider--marker-large:first-child {
margin-left: 0;
}
.ais-star-rating--header {
/* widget header */
}
.ais-star-rating--body {
/* wudget footer */
}
.ais-star-rating--list {
/* item list */
}
.ais-star-rating--item {
/* list item */
vertical-align: middle;
}
.ais-star-rating--item__active {
/* active list item */
font-weight: bold;
}
.ais-star-rating--star {
/* item star */
display: inline-block;
width: 1em;
height: 1em;
}
.ais-star-rating--star:before {
content: '\2605';
color: #FBAE00;
}
.ais-star-rating--star__empty {
/* empty star */
display: inline-block;
width: 1em;
height: 1em;
}
.ais-star-rating--star__empty:before {
content: '\2606';
color: #FBAE00;
}
.ais-star-rating--link {
/* item link */
}
.ais-star-rating--link__disabled {
/* disabled list item */
}
.ais-star-rating--link__disabled .ais-star-rating--star:before {
color: #C9C9C9;
}
.ais-star-rating--link__disabled .ais-star-rating--star__empty:before {
color: #C9C9C9;
}
.ais-star-rating--count {
/* item count */
}
.ais-star-rating--footer {
/* widget footer */
}
.ais-price-ranges--header {
/* widget header */
}
.ais-price-ranges--body {
/* widget body */
}
.ais-price-ranges--footer {
/* widget footer */
}
.ais-price-ranges--list {
/* item list */
}
.ais-price-ranges--item {
/* list item */
}
.ais-price-ranges--item__active {
/* active list item */
}
.ais-price-ranges--link {
/* item link */
}
.ais-price-ranges--form {
/* custom form */
}
.ais-price-ranges--label {
/* custom form label */
}
.ais-price-ranges--currency {
/* currency */
}
.ais-price-ranges--input {
/* custom form input */
}
.ais-price-ranges--separator {
/* custom form separator */
}
.ais-price-ranges--button {
/* custom form button */
}
.ais-clear-all--header {
/* widget header */
}
.ais-clear-all--body {
/* widget body */
}
.ais-clear-all--link {
/* widget link */
}
.ais-clear-all--footer {
/* widget footer */
}
.ais-current-refined-values--header {
/* widget header */
}
.ais-current-refined-values--body {
/* widget body */
}
.ais-current-refined-values--clear-all {
/* widget clearAll link */
}
.ais-current-refined-values--list {
/* widget list */
}
.ais-current-refined-values--item {
/* widget item */
}
.ais-current-refined-values--link {
/* widget link */
}
.ais-current-refined-values--count {
/* widget count */
}
.ais-current-refined-values--footer {
/* widget footer */
}
.ais-root__collapsible .ais-header {
cursor: pointer;
}
.ais-root__collapsed .ais-body, .ais-root__collapsed .ais-footer {
display: none;
}
jQuery(function() {
if(jQuery('#algolia-search-box').length > 0) {
/* global instantsearch */
var search = instantsearch({
appId: algolia.application_id,
apiKey: algolia.search_api_key,
indexName: algolia.indices.searchable_posts.name,
urlSync: {
mapping: {'q': 's'},
trackedParameters: ['query']
}
});
search.addWidget(
instantsearch.widgets.searchBox({
container: '#algolia-search-box',
placeholder: 'Rechercher un article...',
wrapInput: false,
poweredBy: true
})
);
search.addWidget(
instantsearch.widgets.stats({
container: '#algolia-stats'
})
);
var hitTemplate = jQuery("#tmpl-hit").html();
var noResultsTemplate =
'Aucun post ne correspond à la recherche "<strong>{{query}}</strong>".';
search.addWidget(
instantsearch.widgets.hits({
container: '#algolia-hits',
hitsPerPage: 10,
templates: {
empty: noResultsTemplate,
item: hitTemplate
}
})
);
search.addWidget(
instantsearch.widgets.pagination({
container: '#algolia-pagination'
})
);
search.addWidget(
instantsearch.widgets.menu({
container: '#facet-post-types',
attributeName: 'post_type_label',
sortBy: ['isRefined', 'count:desc', 'name:asc'],
limit: 10,
templates: {
header: '<h3 class="widgettitle">Type</h3>'
},
})
);
search.addWidget(
instantsearch.widgets.menu({
container: '#facet-categories',
attributeName: 'taxonomy_category',
sortBy: ['isRefined', 'count:desc', 'name:asc'],
limit: 10,
templates: {
header: '<h3 class="widgettitle">Catégories</h3>'
},
})
);
search.addWidget(
instantsearch.widgets.refinementList({
container: '#facet-tags',
attributeName: 'taxonomy_post_tag',
operator: 'and',
limit: 15,
sortBy: ['isRefined', 'count:desc', 'name:asc'],
templates: {
header: '<h3 class="widgettitle">Tags</h3>'
}
})
);
search.addWidget(
instantsearch.widgets.menu({
container: '#facet-users',
attributeName: 'post_author.display_name',
sortBy: ['isRefined', 'count:desc', 'name:asc'],
limit: 10,
templates: {
header: '<h3 class="widgettitle">Auteurs</h3>'
}
})
);
search.templatesConfig.helpers.relevantContent = function() {
var attributes = ['content', 'title6', 'title5', 'title4', 'title3', 'title2', 'title1'];
var attribute_name;
for ( var index in attributes ) {
attribute_name = attributes[ index ];
if ( this._highlightResult[ attribute_name ].matchedWords.length > 0 ) {
return this._snippetResult[ attribute_name ].value;
}
}
return this._snippetResult[ attributes[ 0 ] ].value;
};
search.start();
jQuery('#algolia-search-box input').attr('type', 'search');
}
});
<?php
// functions.php file of your theme.
function theme_name_scripts() {
wp_enqueue_style( 'theme-name-ais-page', get_template_directory_uri() . '/css/ais-wp.css' );
wp_enqueue_script( 'theme-name-ais-page', get_template_directory_uri() . '/js/ais-wp.js', array( 'algolia-instantsearch', 'jquery' ) );
}
add_action( 'wp_enqueue_scripts', 'theme_name_scripts' );
<?php
/**
* The template for displaying instantsearch results pages
*/
get_header(); ?>
<div id="ais-wrapper">
<main id="ais-main">
<div id="algolia-search-box">
<div id="algolia-stats"></div>
</div>
<div id="algolia-hits"></div>
<div id="algolia-pagination"></div>
</main>
<aside id="ais-facets">
<section class="ais-facets" id="facet-post-types"></section>
<section class="ais-facets" id="facet-categories"></section>
<section class="ais-facets" id="facet-tags"></section>
<section class="ais-facets" id="facet-users"></section>
</aside>
</div>
<script type="text/html" id="tmpl-hit">
<article itemtype="http://schema.org/Article">
{{#thumbnail_url}}
<div class="ais-hits--thumbnail">
<a href="{{ permalink }}" title="{{ post_title }}">
<img src="{{ thumbnail_url }}" alt="{{{ post_title }}}" title="{{{ post_title }}}" itemprop="image">
</a>
</div>
{{/thumbnail_url}}
<div class="ais-hits--content">
<h2 itemprop="name headline"><a href="{{ permalink }}" title="{{ post_title }}" itemprop="url">{{{ _highlightResult.post_title.value }}}</a></h2>
<div class="ais-hits--categories">
{{#taxonomy_category}}
<span class="ais-hits--category">{{.}}</span>
{{/taxonomy_category}}
</div>
<div class="excerpt">
<p>
{{#helpers.relevantContent}}{{/helpers.relevantContent}}
</p>
</div>
</div>
<div class="ais-clearfix"></div>
</article>
</script>
<?php get_footer(); ?>
@amitramani
Copy link

Woohoo!! Thank you for this awesome and simple to follow guide! I was just able to implement Instant Search on my site. The speed of the results is unbelievably fast! Great job. Special Thanks to @rayrutjes

@rayrutjes
Copy link
Author

Wow didn't see your comment here @amitramani, thank you for the kind words.

If you have any suggestion on how when could simplify this even more, feel free to share!

@amitramani
Copy link

@rayrutjes
I understand this is off-topic, but any ideas on how to send search query data to Google Analytics?

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