Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

highlight-words-core

brianvaughn3.1mMIT1.2.3

Utility functions shared by react-highlight-words and react-native-highlight-words

highlighter, highlight, text, words, matches, substring, occurrences, search

readme

Utility functions shared by react-highlight-words and react-native-highlight-words.


🎉 Become a sponsor or ☕ Buy me a coffee


API

The primary API for this package is a function exported as findAll. This method searches a string of text for a set of search terms and returns an array of "chunks" that describe the matches found.

Each "chunk" is an object consisting of a pair of indices (chunk.start and chunk.end) and a boolean specfifying whether the chunk is a match (chunk.highlight). For example:

import { findAll } from "highlight-words-core";

const textToHighlight = "This is some text to highlight.";
const searchWords = ["This", "i"];

const chunks = findAll({
  searchWords,
  textToHighlight
});

const highlightedText = chunks
  .map(chunk => {
    const { end, highlight, start } = chunk;
    const text = textToHighlight.substr(start, end - start);
    if (highlight) {
      return `<mark>${text}</mark>`;
    } else {
      return text;
    }
  })
  .join("");

Run this example on Code Sandbox.

findAll

The findAll function accepts several parameters, although only the searchWords array and textToHighlight string are required.

Parameter Required? Type Description
autoEscape | boolean Escape special regular expression characters
caseSensitive | boolean Search should be case sensitive
findChunks | Function Custom find function (advanced)
sanitize | Function Custom sanitize function (advanced)
searchWords Array<string> Array of words to search for
textToHighlight string Text to search and highlight

License

MIT License - fork, modify and use however you want.