Search: Lunr.js

Table of Contents

Configure Lunr.js Search Client

Select Lunr.js as the search client in your config.toml file:

[params.search]
client = "lunr"

Generate Search Index for Lunr.js

Lunr.js will need a search index for searching across your site. So, you’ll need to generate that search index for Lunr.js before you deploy your site.

Engimo comes with a script for generating the search index for Lunr.js: /scripts/generate-search-index-lunr.js.

Install Dependencies

Node.js must be installed on your system for using the generator script.

It also need the following npm packages:

  • glob
  • lunr

For installing lunr and glob globally use the following command:

npm install -g lunr glob

Run the Script

After you’ve generated your site with Hugo, run generate-search-index-lunr.js with node.

If Engimo is installed under /themes/engimo directory, you’ll run it as:

node ./themes/engimo/scripts/generate-search-index-lunr.js

The generate-search-index-lunr.js script accepts an optional argument for Hugo’s publishDir (relative to your site’s root directory).

So, if you’ve got a different publishDir (say site), pass it as the first argument:

node ./themes/engimo/scripts/generate-search-index-lunr.js site

If the generation was successful, you’ll see output like this:

Lunr.js Index Generated for: /search/index.json

That’s all. Now you can deploy your site.