Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ang-zeyu/infisearch

Easy and flexible client-side search for static sites
https://github.com/ang-zeyu/infisearch

jamstack javascript rust search static-site wasm

Last synced: 7 days ago
JSON representation

Easy and flexible client-side search for static sites

Awesome Lists containing this project

README

        

# InfiSearch

### ❗ Deprecated ❗

This project is no longer being actively developed.

As an alternative for scalable static site search, please check out https://pagefind.app/ which also implements the core idea of InfiSearch - a fragmented static index.

The documentation for the latest release version will continue to be hosted at the URLs in this README, if needed.

If you have been trying out or even contributing ideas and reports to InfiSearch, thank you for the huge time investment.

![CI workflow](https://github.com/ang-zeyu/infisearch/actions/workflows/ci.yml/badge.svg)

Easy and flexible client-side search for static sites.

## Description

InfiSearch is a client-side search solution made for static sites, depending on a pre-built index generated by a CLI tool.

## Features

- **Relevant Search** 🔍: spelling correction, automatic prefix search, boolean and phrase queries, BM25 scoring, proximity scoring, facet filters and more...
- **Speedy** 🏇: WebAssembly & WebWorker powered, enabling efficient, non-blocking query processing. Backed by persistent caching to minimize network requests, and a multi-threaded CLI indexer.
- **Semi-Scalable**, achieved by optionally splitting the index into tiny morsels, complete with incremental indexing.
- A **customisable**, **accessible** [user interface](https://ang-zeyu.github.io/infisearch-website/infisearch/search_configuration_styling.html) 🖥️
- Support for **multiple file formats** (`.json,csv,pdf,html`) to satisfy more custom data requirements.

## Documentation

The documentation, which uses InfiSearch for its search function, can be found [here](https://ang-zeyu.github.io/infisearch-website/infisearch/getting_started.html).

## Preview

Some demos of InfiSearch on a much larger Gutenberg collection are also available [here](https://ang-zeyu.github.io/infisearch-website).

## Getting Started

Powering static site search with InfiSearch is extremely easy, and requires just a folder of your HTML files — titles, headings, and other text are automatically extracted. Links to your pages are automatically generated based on your folder structure, but can also be manually specified.

### 1. Installing the indexer

There are a couple of options for installing the indexer:
- Install the global npm package with `npm install -g @infisearch/cli`.
- If you have the rust / cargo toolchains setup, run `cargo install infisearch --vers 0.10.1`.
- You can also grab the cli binaries [here](https://github.com/ang-zeyu/infisearch/releases).

### 2. Running the indexer

Run the executable as such, replacing `` with the relative or absolute folder path of your source html files, and `` with your desired index output folder.

```
infisearch
```

### 3. Installing the Search UI via CDN

Add the following resources to your pages:

```html

```

If you wish to host the files, you can find them in the `/assets` directory generated by the indexer, or in the [releases](https://github.com/ang-zeyu/infisearch/releases) page.

### 4. UI Initialisation

Give any `` element in your page an `id` of `infi-search`, then call:

```js
infisearch.init({
searcherOptions: {
// Output folder URL specified as the second parameter in the cli command
// URLs like '/output/' will work as well
url: 'http:///output/',
},
uiOptions: {
// Input folder URL specified as the first parameter in the cli command
// This is where the generated result preview links will point to,
// and where you host your site.
sourceFilesUrl: 'http:///source/',
}
});
```

## License

This project is [MIT licensed](./LICENSE.md).