All files / src/app/core/pipes highlight.pipe.ts

100% Statements 11/11
100% Branches 4/4
100% Functions 3/3
100% Lines 9/9

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 232x             2x   4x 2x 2x   6x   2x 6x   2x        
import { Pipe, PipeTransform } from '@angular/core';
 
/**
 * inserts highlighting markup into the text string
 * at the occurrences of the search string.
 */
@Pipe({ name: 'ishHighlight' })
export class HighlightPipe implements PipeTransform {
  transform(text: string, search: string): string {
    if (search && text) {
      let pattern = search.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g, '\\$&').toLowerCase();
      pattern = pattern
        .split(' ')
        .filter(t => t.length > 0)
        .join('|');
      const regex = new RegExp(pattern, 'gi');
      return text.replace(regex, match => `<span class="searchTerm">${match}</span>`);
    } else {
      return text;
    }
  }
}