mirror of
https://github.com/remoteintech/remote-jobs
synced 2025-01-12 12:38:43 +00:00
Updated the setupSearch function
This commit is contained in:
parent
a87987fe11
commit
a999ed7f67
1 changed files with 12 additions and 101 deletions
|
@ -30,32 +30,17 @@ function setupSearch() {
|
||||||
if ( ! searchData || searchLoading ) {
|
if ( ! searchData || searchLoading ) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
var searchValue = searchInput.value.toLowerCase();
|
||||||
|
var allMatch = !searchValue;
|
||||||
|
var searchResults = [];
|
||||||
|
|
||||||
var searchValue = searchInput.value
|
searchData.textData.forEach( function( company, index ) {
|
||||||
.replace( /[^a-z0-9_']+/gi, ' ' )
|
var companyName = company.nameText.toLowerCase();
|
||||||
.trim()
|
if(companyName.includes(searchValue)){
|
||||||
.split( ' ' )
|
searchResults.push({ref: index});
|
||||||
.map( function( term ) {
|
|
||||||
term = term
|
|
||||||
.replace( /('m|'ve|n't|'d|'ll|'ve|'s|'re)$/, '' )
|
|
||||||
.replace( /'/g, '' );
|
|
||||||
if ( ! lunr.stopWordFilter( term.toLowerCase() ) ) {
|
|
||||||
return null;
|
|
||||||
} else if ( term ) {
|
|
||||||
return '+' + term;
|
|
||||||
} else {
|
|
||||||
return term;
|
|
||||||
}
|
}
|
||||||
} )
|
});
|
||||||
.filter( Boolean )
|
var searchDisplayValue = searchInput.value.trim();
|
||||||
.join( ' ' );
|
|
||||||
var allMatch = ! searchValue;
|
|
||||||
var searchResults = searchValue ? searchIndex.search( searchValue ) : [];
|
|
||||||
var searchDisplayValue = (
|
|
||||||
searchValue === '+_incomplete'
|
|
||||||
? 'Incomplete profile'
|
|
||||||
: searchInput.value.trim()
|
|
||||||
);
|
|
||||||
if ( allMatch ) {
|
if ( allMatch ) {
|
||||||
searchStatus.innerHTML = (
|
searchStatus.innerHTML = (
|
||||||
'Empty search; showing all '
|
'Empty search; showing all '
|
||||||
|
@ -86,81 +71,7 @@ function setupSearch() {
|
||||||
}
|
}
|
||||||
row.style.display = ( match || allMatch ? '' : 'none' );
|
row.style.display = ( match || allMatch ? '' : 'none' );
|
||||||
row.classList.remove( 'has-match' );
|
row.classList.remove( 'has-match' );
|
||||||
if ( match ) {
|
|
||||||
row.classList.add( 'has-match' );
|
|
||||||
var metadata = match.matchData.metadata;
|
|
||||||
var contextWords = ( window.innerWidth <= 600 ? 4 : 6 );
|
|
||||||
var k1, k2, pos;
|
|
||||||
loop1: for ( k1 in metadata ) {
|
|
||||||
for ( k2 in metadata[ k1 ] ) {
|
|
||||||
pos = metadata[ k1 ][ k2 ].position[ 0 ];
|
|
||||||
if ( k2 !== 'nameText' ) {
|
|
||||||
// Accept company name for matches, but prefer
|
|
||||||
// other fields if there are any
|
|
||||||
break loop1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
rowMatch = document.createElement( 'tr' );
|
|
||||||
rowMatch.setAttribute( 'class', 'company-match' );
|
|
||||||
var rowMatchCell = document.createElement( 'td' );
|
|
||||||
rowMatchCell.setAttribute( 'colspan', 3 );
|
|
||||||
var spanBefore = document.createElement( 'span' );
|
|
||||||
var spanMatch = document.createElement( 'strong' );
|
|
||||||
var spanAfter = document.createElement( 'span' );
|
|
||||||
var text = company[ k2 ];
|
|
||||||
var words = [];
|
|
||||||
var currentWord = '';
|
|
||||||
var i, inWord, c;
|
|
||||||
for ( i = pos[ 0 ] - 1; i >= 0; i-- ) {
|
|
||||||
c = text.substring( i, i + 1 );
|
|
||||||
inWord = /\S/.test( c );
|
|
||||||
if ( inWord ) {
|
|
||||||
currentWord = c + currentWord;
|
|
||||||
}
|
|
||||||
if ( ( ! inWord || i === 0 ) && currentWord ) {
|
|
||||||
words.unshift( currentWord );
|
|
||||||
currentWord = '';
|
|
||||||
if ( words.length === contextWords + 1 ) {
|
|
||||||
words[ 0 ] = '\u2026';
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
spanBefore.innerText = (
|
|
||||||
( window.innerWidth > 600 ? searchData.headings[ k2 ] + ': ' : '' )
|
|
||||||
+ words.join( ' ' )
|
|
||||||
+ ' '
|
|
||||||
).replace( /\(_incomplete\)/, '(Incomplete)' );
|
|
||||||
spanMatch.innerText = text
|
|
||||||
.substring( pos[ 0 ], pos[ 0 ] + pos[ 1 ] )
|
|
||||||
.replace( /\(_incomplete\)/, '(Incomplete)' );
|
|
||||||
words = [];
|
|
||||||
currentWord = '';
|
|
||||||
for ( i = pos[ 0 ] + pos[ 1 ] + 1; i < text.length; i++ ) {
|
|
||||||
c = text.substring( i, i + 1 );
|
|
||||||
inWord = /\S/.test( c );
|
|
||||||
if ( inWord ) {
|
|
||||||
currentWord += c;
|
|
||||||
}
|
|
||||||
if ( ( ! inWord || i === text.length - 1 ) && currentWord ) {
|
|
||||||
words.push( currentWord );
|
|
||||||
currentWord = '';
|
|
||||||
if ( words.length === contextWords + 1 ) {
|
|
||||||
words[ contextWords ] = '\u2026';
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
spanAfter.innerText = (
|
|
||||||
' ' + words.join( ' ' )
|
|
||||||
).replace( /\(_incomplete\)/, '(Incomplete)' );
|
|
||||||
rowMatchCell.appendChild( spanBefore );
|
|
||||||
rowMatchCell.appendChild( spanMatch );
|
|
||||||
rowMatchCell.appendChild( spanAfter );
|
|
||||||
rowMatch.appendChild( rowMatchCell );
|
|
||||||
row.parentNode.insertBefore( rowMatch, row.nextSibling );
|
|
||||||
}
|
|
||||||
} );
|
} );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -208,7 +119,7 @@ function setupSearch() {
|
||||||
if ( updateTimeout ) {
|
if ( updateTimeout ) {
|
||||||
clearTimeout( updateTimeout );
|
clearTimeout( updateTimeout );
|
||||||
}
|
}
|
||||||
updateTimeout = setTimeout( updateSearch, 450 );
|
updateTimeout = setTimeout( updateSearch, 100);
|
||||||
} );
|
} );
|
||||||
|
|
||||||
document.body.setAttribute(
|
document.body.setAttribute(
|
||||||
|
|
Loading…
Reference in a new issue