-
-
Notifications
You must be signed in to change notification settings - Fork 4
/
index.js
98 lines (95 loc) 路 2.66 KB
/
index.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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
const searchInput = document.getElementById("search-input");
const results = document.getElementById("results");
const apiUrl = "https://api.lyrics.ovh";
const lyricsDiv = document.getElementById("lyrics");
let timeoutSuggest;
searchInput.addEventListener("input", () => {
if (timeoutSuggest) {
clearTimeout(timeoutSuggest);
}
timeoutSuggest = setTimeout(suggestions, 300);
});
removeResults = () => {
results.innerHTML = "";
};
suggestions = () => {
const term = searchInput.value;
if (!term) {
removeResults();
return;
}
results.innerHTML = "Loading...";
fetch(`${apiUrl}/suggest/${term}`)
.then((response) => response.json())
.then(({ data }) => {
removeResults();
const finalResults = [];
const seenResults = [];
data.forEach(({ title, artist, album }) => {
if (seenResults.length >= 10) {
return;
}
const t = `${title} - ${artist.name}`;
if (seenResults.includes(t)) {
return;
}
seenResults.push(t);
finalResults.push({
title,
artist: artist.name,
album: album.title,
cover: album.cover_medium,
});
});
const l = finalResults.length;
if (l) {
finalResults.forEach((result, i) => {
let c = "result";
if (i == l - 1) {
c += " result-last";
}
const e = document.createElement("li");
e.classList.add("flex");
e.innerHTML = `
<div class="${c}">
<div class="background-image" style="background-image: url('${result.cover}')"></div>
<img src="${result.cover}" class="cover">
<div class="title">${result.title}</div>
<div class="artist">${result.artist}</div>
</div>
`;
results.appendChild(e);
e.addEventListener("click", () => {
songLyrics(result);
});
});
} else {
results.innerHTML = "No results";
}
})
.catch((error) => {
results.innerHTML = error;
});
};
songLyrics = ({ artist, title, cover, album }) => {
removeResults();
lyricsDiv.innerHTML = "Loading...";
fetch(`${apiUrl}/v1/${artist}/${title}`)
.then((response) => response.json())
.then(({ lyrics }) => {
let html = `
<img src="${cover}" class="cover-large">
<h3 class="lyrics-title">
${title} - ${artist} (${album})
</h3>`;
html += `
<div id="thelyrics" class="thelyrics">
${lyrics.replace(/\n/g, "<br />")}
</div>
`;
lyricsDiv.innerHTML = html;
})
.catch((error) => {
lyricsDiv.innerHTML = "Not found";
});
};