<!DOCTYPE html> <html> <head> <title>Search results</title> <meta charset="utf-8" /> <meta name="description" content="Search results" /> <link type="text/css" rel="stylesheet" href="../editor.css" /> <script src="js/jquery.min.js"></script> <script src="indexes.js"></script> <script src="js/lunr.js"></script> <script src="js/lunr-languages/lunr.stemmer.support.js"></script> <script src="js/lunr-languages/lunr.multi.js"></script> <script src="js/lunr-languages/lunr.es.js"></script> <style type="text/css"> ul { padding-left: 15px; margin-top: 20px; } li { list-style-type: decimal; line-height: 1.5em; padding-bottom: 1.5em; } li a { font-family: 'Open Sans',sans-serif,Arial; font-size: 1.2em; } li p { margin: 0.5em 0; } li p.info { color: #999; font-size: 0.9em; font-style: italic; } li a span { background: yellow; } li p span { background: yellow; } </style> </head> <body> <script> (function() { var getParameterByName = function(name, url) { if (!url) url = window.location.href; name = name.replace(/[\[\]]/g, "\\$&"); var regex = new RegExp("[?&]" + name + "(=([^&#]*)|&|#|$)"), results = regex.exec(url); if (!results) return null; if (!results[2]) return ''; return decodeURIComponent(results[2].replace(/\+/g, " ")); }; var getInfoById = function(id) { var objects = $.grep(indexes, function(e){ return e.id == id; }); if (objects.length > 0) { return objects[0] } return null; }; var uniqueArray = function(array) { return array.map(JSON.stringify).reverse().filter(function (e, i, a) { return a.indexOf(e, i+1) === -1; }).reverse().map(JSON.parse) }; var higtlightTitles = function(result, info, positions) { var elements = positions.map(function(position) { return $('<li>') .append( $('<a>', { href: "../" + result.ref, html: [ info.title.slice(0, position[0]), "<span>", info.title.slice(position[0], position[0] + position[1]), "</span>", info.title.slice(position[0] + position[1]) ].join('') }) ) .append($('<p>').text(info.body.substring(0, 250) + "...")) }); return elements; }; var higtlightBodyes = function(result, info, positions) { var elements = positions.map(function(position) { var html = [ info.body.slice(0, position[0]), "<span>", info.body.slice(position[0], position[0] + position[1]), "</span>", info.body.slice(position[0] + position[1]) ].join(''); var sentences = html.split("."), displayBody = "", sentenceCount = 0, commonLength = 0; $(sentences).each(function(index, sentence) { commonLength += sentence.length; if (commonLength > position[0]) { sentenceCount++; displayBody += sentence + "."; } if (commonLength > 450 && sentenceCount > 2) { displayBody = displayBody.substring(0, 450) + "..." return false; } }); return $('<li>') .append( $('<a>', { href: "../" + result.ref, html: info.title.substring(0, 150) }) ) .append( $('<p>') .html(displayBody) ) }); return elements; }; var processSearch = function() { var self = this, query = getParameterByName("query"); if (query !== null && query.length > 0) { var parameterisedPlugin = function (builder, fields) { fields.forEach(function (field) { builder.field(field) }) } var idx = lunr(function () { this.use(lunr.multiLanguage('en', 'es')) this.ref('id') this.field('title', {boost: 10}) this.field('body') this.metadataWhitelist = ['position'] this.use(parameterisedPlugin, ['title', 'body']); indexes.forEach(function (doc) { this.add(doc) }, this) }); var results = idx.search(query), resultsCount = 0; if (results.length > 0) { $("#search-results").append( results.map(function(result) { var displayInfo = getInfoById(result.ref); if (displayInfo) { var elements = [] Object.keys(result.matchData.metadata).forEach(function (term) { Object.keys(result.matchData.metadata[term]).forEach(function (fieldName) { if (fieldName == "title") { var positions = uniqueArray(result.matchData.metadata[term][fieldName].position); elements = elements.concat(higtlightTitles(result, displayInfo, positions)); } else if (fieldName == "body") { var positions = uniqueArray(result.matchData.metadata[term][fieldName].position); elements = elements.concat(higtlightBodyes(result, displayInfo, positions)); } }) }) resultsCount += elements.length; return elements.map(function(element) { return $("<div>").append(element).html() }).join(''); } }) ) $(".subtitle").html("Search results: " + resultsCount); } else { $(".subtitle").html("No search results"); } $("h1").text("Search results"); } else { $("h1").text("Search results"); $(".subtitle").html("No search results"); } } $(document).ready(function() { setTimeout(processSearch, 50); }); })(); function doSearch(e) { if (e.keyCode == 13) { document.location.href = 'search.html?query=' + document.getElementById('search').value; } } </script> <div class="mainpart"> <div class="search-field"> <input id="search" class="searchBar" placeholder="Search" type="search" onkeypress="doSearch(event)"> </div> <h1>Searching...</h1> <span class="subtitle"></span> <ul id="search-results"></ul> </div> </body> </html>