-
Notifications
You must be signed in to change notification settings - Fork 0
/
script.js
55 lines (46 loc) · 2.51 KB
/
script.js
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
// Axel Cotón Gutiérrez Copyright 2023
// Define una variable para almacenar las definiciones
let definitions = {};
// Cargar las definiciones desde el archivo JSON
fetch('definitions.json')
.then(response => response.json())
.then(data => {
definitions = data; // Asigna las definiciones cargadas al objeto definitions
const searchInput = document.getElementById("search-input");
const searchButton = document.getElementById("search-button");
const definitionResult = document.getElementById("definition-result");
searchButton.addEventListener("click", () => {
const searchTerm = searchInput.value.trim().toLowerCase();
// Busca definiciones cuyo título contenga el término de búsqueda
const matchingDefinitions = Object.keys(definitions)
.filter(term => {
const definition = definitions[term];
return definition.title.toLowerCase().includes(searchTerm);
})
.sort(); // Ordena los resultados alfabéticamente
if (matchingDefinitions.length > 0) {
const resultsHTML = matchingDefinitions.map(term => {
const definition = definitions[term];
return `
<div class="definition">
<h3>${definition.title}</h3>
<p>${definition.source}</p>
<p>${definition.definition}</p>
<p><strong style='color: #007BFF;'>Coloquialmente:</strong> ${definition.description}</p>
${definition.link ? `<p><a href="${definition.link}" target="_blank">Enlace a más información</a></p>` : ""}
${definition.video ? `
<div class="video-container">
<iframe width="560" height="315" src="${definition.video}" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>
</div>` : ""}
</div>
`;
}).join("");
definitionResult.innerHTML = resultsHTML;
} else {
definitionResult.innerHTML = "<p id='no-definition'>No encontramos definiciones relacionadas con ese término.</p>";
}
});
})
.catch(error => {
console.error('Error al cargar las definiciones:', error);
});