/algoliasearch-wordpress

AlgoliaSearch for Wordpress

Primary LanguagePHPOtherNOASSERTION

WARNING

This extension is currently in beta. You can download it and play with it as much as you want, but we would only recommend its usage to experienced developers

Algolia Realtime Search Wordpress Plugin

Algolia Search is a hosted full-text, numerical, and faceted search engine capable of delivering realtime results from the first keystroke.

This plugin replaces the default search of Wordpress adding an as-you-type auto-completion menu and an instant search results page. It has been designed to support plugins like WooCommerce in addition to the standard blog system.

Latest version MIT Wordpress 4.2 Wordpress 4.1 Wordpress 4.0 Wordpress 3.9 Wordpress 3.8 PHP >= 5.3

Installation

  1. Create an Algolia account
  2. Once logged in, go to the Credentials section and get your Application ID, ADMIN API key and Search-only API key
  3. Install Algolia Wordpress Plugin from your Wordpress dashboard or unzip the plugin archive in the wp-content/plugins directory.
  4. Activate the plugin through the Plugins menu in Wordpress
  5. Go to the Algolia Search left menu configuration page and fill your credentials
  6. Configure the way you want the plugin to render your search results
  7. Click the "Re-index" button

Features

Search bar with auto-complete

This extension adds an auto-completion menu to your search bar displaying product, categories & pages "as-you-type".

Instant & Faceted search results page

This extension adds a default implementation of an instant & faceted search results page. Just customize the underlying CSS & JavaScript to suits your shop theme.

Typo-tolerant full-text search

If you choose not to use the instant search. The extension will replace the fulltext indexer providing you a typo-tolerant & relevant search experience.

If you choose to use the instant search, when you search for something fulltext indexer replacement is still used so that you can have a backend implementation of the search in order to keep a good SEO

Configuration

Once the plugin is installed a new tab will appears in Wordpress admin panel

Credentials

In this section you configure two things:

  1. Your Application ID & API keys:

You need to configure this section based on your Algolia credentials. You can fetch them from here.

  1. Your index names prefix:

The plugin will create several indices, all of them will be prefixed by this value:

* 1 index for the instant search results page
* 1 index for each section of the auto-completion menu
* 1 (slave) index for each sort order you enable

UI Integration

Search Experience Configuration

  1. Search Bar

To be able to trigger the search at each keystroke on your site you need to specify where the plugin is supposed to find the search input. You do that by specifying a jQuery/DOM selector.

In Wordpress's default theme it is: [name='s']

  1. Instant search

You need to indicate the jQuery/DOM selector specifying where the plugin is supposed to inject your results.

You can also configure the number of results you want by page.

Results template

The plugin supports templates which allows you to customize the way your results are displayed. You can choose one of the 2 sample templates or build your own.

The template is totally independent from the Wordpress theme. The default templates are handling both Autocompletion AND Instant-search results page.

Types

You can choose the Wordpress types you want to index. By default, only post and page are selected. If one of your extensions (WooCommerce for instance) creates new types you will see them in this list.

You can order them to change the order of each section in the auto-completion menu. You can also specify the label used for each type to display the title of each auto-completion menu section.

Attributes

You can configure additional attributes or taxonomies you want to index. If you use Wordpress as a blog you shouldn't have to change anything. When using Wordpress with plugins like WooCommerce this should be very useful as you probably want to include the price or the total_sales attributes as well.

When you enable an attribute, the plugin will add this attribute to the record but it will NOT be searchable UNLESS you enable it in the Search Configuration tab.

When you make an attribute facetable AND if you are in Instant Search Results Page mode you will see a faceting/filtering bloc appears in which you can filter your results easily.

There is two facet types you can choose:

  1. Conjunctive

    Your refinements are ANDed. Think about a post having the tags lifestyle AND mood.

  2. Disjunctive

    Your refinements are ORed. Think about a products search with: 4 OR 5 stars.

  3. Custom: slider, tag clouds, ...

    A results template can declare new facet types. The "Default" template is adding the "slider" type.

You can add a label to each enabled facet to display the Facet bloc title. You can also order the facet blocs ordering the attributes.

Search

For each attribute you enable, you can decide to make it searchable. You can also choose if you want the attribute to be consider ordered or not:

  1. Ordered

    Matches at the beginning of an attribute will be considered more important than matches at the end. This setting is recommended for short attributes like title.

  2. Unordered

Matches at the beginning of the list will not be considered more important than matches at the end. This setting is recommended for long attribute like content.

Notes: If an attribute does not appear in this tab, be sure that you first enabled it on the Attributes tab.

Ranking

For each attribute you enable, you can make them part of your custom ranking formula.

Notes: Attributes that you enable here NEED to be numerical attributes.

Sorting

For each attribute or taxonomy you enable you can select the ones you want to sort with.

Notes: Adding a new sort order will create a slave index with the exact same settings except the ranking formula will have the use the attribute you enable as the first ranking criterion. You can choose a label which will be displayed on the instant search result page.

Advanced

To avoid errors with too large record. We cut the content attribute. If you choose to disable it, you could have error while reindexing. To increase the limit you need to contact us.

Indexing

Initial import

Once you configure your credentials and others settings do not forget to reindex data. You can do that from the Algolia Search config page on your Wordpress admin

Indexing flow

Once the initial import done. Every time you add/update some wordpress content. It will be indexed automatically to Algolia.

If you have modified some settings or clear/delete some indices you will need reindex everything. For that you just do like the initial import.

Customizing

Template folder architecture

A template is composed by several MANDATORY files:

  • config.php

    It should look like

     <?php
    
     return array(
       'name'                      => 'Woo Default',
       'screenshot'                => 'screenshot.png',
       'facet_types'               => array()
     );

    The name will be displayed on the UI Page: it's your template's name. And the screenshot is the path screenshot (relative to your template root directory).

  • styles.css

    This file contains every CSS rules used by the template.

  • templates.php

    This file contains all the HTML (we use Hogan.js) templates you need. The mandory content is:

    <script type="text/template" id="autocomplete-template">
    /* Your autocomplete Hogan template HERE */
    </script>
    
    <script type="text/template" id="instant-content-template">
    /* Your instant search results Hogan template HERE */
    </script>
    
    <script type="text/template" id="instant-facets-template">
    /* Your facets template HERE */
    </script>
    
    <script type="text/template" id="instant-pagination-template">
      /* Your Pagination template HERE */
    </script>
  • template.js

    This file includes all the JavaScript logic.

Add settings programatically to an index

You can use the prepare_algolia_set_settings filter

add_filter('prepare_algolia_set_settings', function ($index_name, $settings)
{
	 if ($index_name == 'SOME_INDEX_NAME')
	 {
	   // Add settings here to the $settings object
	 }
	
    return $settings;
}, 10, 3);

Add some attributes to a record

You can use the prepare_algolia_record filter

add_filter('prepare_algolia_record', function ($data) {
	
	if ($data->type == 'product')
	{
		// Add any attribute you want here
	}

    return $data;
});

Add a custom facet filter type

This can be done with several steps (Bellow is the example for a slider)

  1. On the config.php file add to facet_types so that it show up on the UI tab of the configuration
return array(
   'name'                      => 'Default',
   'screenshot'                => 'screenshot.png',
   'facet_types'               => array('slider' => 'Slider')
);
  1. Choose the behavior of the facet type (conjunctive or disjunctive)

Locate this code in template.js

```php
	for (var i = 0; i < algoliaSettings.facets.length; i++)
    {
        if (algoliaSettings.facets[i].type == "conjunctive")
            conjunctive_facets.push(algoliaSettings.facets[i].tax);

        if (algoliaSettings.facets[i].type == "disjunctive")
            disjunctive_facets.push(algoliaSettings.facets[i].tax);
	[...]
```

And add a condition for slider type

```js
if (algoliaSettings.facets[i].type == "slider")
   disjunctive_facets.push(algoliaSettings.facets[i].tax);
```
  1. Create a function in the custom_facets_types variable that will generate an object usable by Hogan

    custom_facets_types["slider"] = function (helper, content, facet) {
    	var params = {
    	 // the params you need in Hogan
    	};
    
    	params.type[facet.type] = true;
    
    	return [params];
    });
  2. Add all the dom binding you need

    $("body").on("slidechange", ".algolia-slider-true", function (event, ui) {
    	// handle event
    });
    
    $("body").on("slide", "", function (event, ui) {
    	// handle event
    });
  3. Handle the slider type in templates.php

    You can add the slider in the instant-facets-template hogan template for example

    like this:

    {{#type.slider}}
       <div class="algolia-slider">
    		<!-- Any content you need -->
       </div>
    	<div class="algolia-slider-info">
    		<!-- Any content you need -->
    	</div>
    {{/type.slider}}
    
    

FAQ

Are my other plugins compatible?

It depends :) The plugin handles every other plugins that uses the post and meta tables of Wordpress. If a plugin creates its own tablem the plugin will not be able to see it.

How do I handle a non-supported plugin?

You can use the filters to add any attribute you want to the record

What happens if I modify a setting from the Algolia dashboard?

The plugin tries to merge the settings that have been modified from the Algolia dashboard and the one generated from your plugin configuration. In every case the following settings will be erased:

  1. For the autocompletion-menu
  • attributesToIndex
  • attributesToHighlight
  • attributesToSnippet
  1. For the instant search results page
  • attributesToIndex
  • attributesForFaceting
  • attributesToSnippet
  • customRanking
  • slaves
  • ranking (only for the sorting (slaves) indexes)

I want to change a facet value for example the "Types" facet, what should I do ?

In your template template.js file in the root directory of the plugin you may want to add those attributes to this line:

window.facetsLabels = {
    'post': 'Article',
    'page': 'Page'
};

For example if you want to replace "product" by "Products" in the facets elements, it will look like this:

window.facetsLabels = {
    'post': 'Article',
    'page': 'Page',
    'product': 'Product'
};

This works for any other facet but the Type one is the most likely to have non wanted formating.

I saved my configuration but I do not see any change on my results?

When you change a setting that impacts the index you may want to use the Re-index data button to reflect your changes in your Algolia index.