import { truncate } from '../utils/string'; /** * The `highlight` helper searches for a word phrase in a string, and wraps * matches with the tag. * * @param {String} string The string to highlight. * @param {String|RegExp} phrase The word or words to highlight. * @param {Integer} [length] The number of characters to truncate the string to. * The string will be truncated surrounding the first match. * @return {Object} */ export default function highlight(string, phrase, length) { if (!phrase && !length) return string; // Convert the word phrase into a global regular expression (if it isn't // already) so we can search the string for matched. const regexp = phrase instanceof RegExp ? phrase : new RegExp(phrase, 'gi'); let highlighted = string; let start = 0; // If a length was given, the truncate the string surrounding the first match. if (length) { if (phrase) start = Math.max(0, string.search(regexp) - length / 2); highlighted = truncate(highlighted, length, start); } // Convert the string into HTML entities, then highlight all matches with // tags. Then we will return the result as a trusted HTML string. highlighted = $('
').text(highlighted).html(); if (phrase) highlighted = highlighted.replace(regexp, '$&'); return m.trust(highlighted); }