2018-06-20 11:50:31 +08:00
|
|
|
import { truncate } from '../utils/string';
|
2015-07-07 14:46:20 +08:00
|
|
|
|
2015-07-15 12:30:11 +08:00
|
|
|
/**
|
|
|
|
* The `highlight` helper searches for a word phrase in a string, and wraps
|
|
|
|
* matches with the <mark> 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;
|
2015-06-03 16:40:56 +08:00
|
|
|
|
2015-07-15 12:30:11 +08:00
|
|
|
// Convert the word phrase into a global regular expression (if it isn't
|
|
|
|
// already) so we can search the string for matched.
|
2015-07-07 19:05:18 +08:00
|
|
|
const regexp = phrase instanceof RegExp ? phrase : new RegExp(phrase, 'gi');
|
2015-07-07 14:46:20 +08:00
|
|
|
|
2015-07-15 12:30:11 +08:00
|
|
|
let highlighted = string;
|
2015-07-07 14:46:20 +08:00
|
|
|
let start = 0;
|
|
|
|
|
2015-07-15 12:30:11 +08:00
|
|
|
// If a length was given, the truncate the string surrounding the first match.
|
2015-07-07 14:46:20 +08:00
|
|
|
if (length) {
|
2015-07-15 12:30:11 +08:00
|
|
|
if (phrase) start = Math.max(0, string.search(regexp) - length / 2);
|
|
|
|
|
|
|
|
highlighted = truncate(highlighted, length, start);
|
2015-06-03 16:40:56 +08:00
|
|
|
}
|
|
|
|
|
2015-07-15 12:30:11 +08:00
|
|
|
// Convert the string into HTML entities, then highlight all matches with
|
|
|
|
// <mark> tags. Then we will return the result as a trusted HTML string.
|
|
|
|
highlighted = $('<div/>').text(highlighted).html();
|
|
|
|
|
|
|
|
if (phrase) highlighted = highlighted.replace(regexp, '<mark>$&</mark>');
|
2015-07-07 14:46:20 +08:00
|
|
|
|
2015-07-15 12:30:11 +08:00
|
|
|
return m.trust(highlighted);
|
2015-06-03 16:40:56 +08:00
|
|
|
}
|