-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscript.js
71 lines (53 loc) · 2.16 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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
const url = "https://api.dictionaryapi.dev/api/v2/entries/en/";
const result = document.getElementById("result");
const sound = document.getElementById("sound");
const btn = document.getElementById("search-btn");
btn.addEventListener('click', () => {
let input = document.getElementById("input-word").value;
fetch(`${url}${input}`)
.then((response) => response.json())
.then((data) => {
console.log(data);
result.innerHTML = "";
for (let index = 0; index < data[0].meanings.length; index++) {
const m = data[0].meanings[index];
const ph_len = data[0].phonetics.length;
const ph = data[0].phonetics[ph_len - 1];
result.innerHTML += `
<div class="word">
<h3 id="txt">${input}</h3>
<button onclick="playSound()">
<i class="fa-solid fa-volume-high"></i>
</button>
</div>
<div class="details">
<p>${m.partOfSpeech}</p>
<p>${ph.text}</p>
</div>`;
for (let i = 0; i < data[0].meanings[index].definitions.length; i++) {
const def = data[0].meanings[index].definitions[i];
result.innerHTML += `
<p class="def">
Def ${i + 1} :</p>
<p class="word-meaning">
${def.definition}</p>
<p class="word-example">
${def.example || ""}
</p>
`;
}
}
const ph_len = data[0].phonetics.length;
const ph = data[0].phonetics[ph_len - 1];
const ph2 = data[0].phonetics[0];
var soundAudio = ph2.audio == "" ? ph.audio : ph2.audio;
sound.setAttribute("src", `${soundAudio}`);
// console.log(data[0].phonetics[ph_len - 1] == "");
})
.catch(() => {
result.innerHTML = `<h3 class="error">Couldn't Find The Word</h3>`;
});
});
function playSound() {
sound.play();
}