forked from idea-agro/plataforma-idea-agro
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsearch.js
More file actions
71 lines (56 loc) · 2.6 KB
/
search.js
File metadata and controls
71 lines (56 loc) · 2.6 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
document.getElementById('searchInput').addEventListener('input', function(event) {
const query = event.target.value.trim().toLowerCase();
const searchableElements = document.querySelectorAll('.searchable');
let results = [];
searchableElements.forEach(element => {
const isVisible = window.getComputedStyle(element).getPropertyValue('display') !== 'none';
const text = element.innerText.trim().toLowerCase();
if (isVisible && text.includes(query)) {
results.push({ element, text });
}
});
showResults(results, query);
});
function showResults(results, query) {
const searchResultsList = document.getElementById('searchResults');
searchResultsList.innerHTML = ''; // Limpiar los resultados anteriores
if (query === '') {
return; // No mostrar resultados si no hay búsqueda
}
if (results.length === 0) {
const listItem = document.createElement('li');
listItem.textContent = 'No se encontraron resultados para: ' + query;
searchResultsList.appendChild(listItem);
return; // Salir de la función si no hay resultados
}
results.forEach(({ element, text }) => {
const listItem = document.createElement('li');
const link = document.createElement('a');
const startIndex = text.indexOf(query); // Índice de inicio de la coincidencia
const endIndex = text.indexOf('.', startIndex) + 1; // Índice de fin de la oración
const sentence = text.substring(startIndex, endIndex).trim(); // Obtener la oración que contiene la coincidencia
link.textContent = sentence; // Mostrar solo la oración relevante
link.href = '#' + element.id; // Agregar un enlace al ID del elemento
link.addEventListener('click', function(event) {
event.preventDefault();
element.scrollIntoView({ behavior: 'smooth', block: 'start' });
removeHighlight(); // Eliminar cualquier resaltado existente
highlightMatches(element, query); // Resaltar solo la consulta dentro del elemento
});
listItem.appendChild(link);
searchResultsList.appendChild(listItem);
});
}
// Función para resaltar solo las coincidencias de búsqueda dentro del elemento dado
function highlightMatches(element, query) {
const text = element.innerText.trim();
const regex = new RegExp(query, 'gi');
element.innerHTML = text.replace(regex, '<mark>$&</mark>');
}
// Función para eliminar el resaltado de búsqueda existente
function removeHighlight() {
const highlightedElements = document.querySelectorAll('mark');
highlightedElements.forEach(element => {
element.outerHTML = element.textContent;
});
}