trigram-search

trigram-based library for fast indexing and search over large arrays of data

Usage no npm install needed!

<script type="module">
  import trigramSearch from 'https://cdn.skypack.dev/trigram-search';
</script>

README

Trigram search

Trigram-based library for fast indexing and search over large arrays of data, written in TypeScript, built for Node.js and browser.

Demo

At codesandbox

Installation

npm i trigram-search

Usage

import Trigram from "trigram-search";
// or
// import Trigram from "trigram-search/build/browser";
const data = [{ id: 0, title: "Javascript" }, { id: 1, title: "Python" }, { id: 2, title: "Go" }, ...];
const searcher = new Trigram(data);

searcher.find('Py'); // will output sorted array of results

API

Constructor

new Trigram(items, config);

items — array of objects with id, title and optional sort fields (defaults).

id — must be unique

title — contains text for search

sort — can be used to prioritize specific items higher in the results, even if match rate for them is lower

config:

type TrigramConfig = {
  idField?: string; // key of the unique field of each item, default — "id"
  searchField?: string; // key of text-for-search field of each item, default — "title"
  sortField?: string; // key of sort field of each item, default — "sort"
  count?: number; // max length of the result array, default — "10"
  minRate?: number; // min match rate for item to be added to result, default — "0"
}

Methods

interface ITrigram {
  find(query: string, settings?: { count?: number; minRate?: number; }): TrigramOutput;
}

count and minRate in arguments will take precedence over global instance settings.

type TrigramOutput = {
  value: any; // item from input
  rate: number; // match rating of item for provided query    
}[];

Credits

Original TrigramJS algo by tqh.