-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.js
54 lines (42 loc) · 1.47 KB
/
main.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
let isLoding = false;
function getTheArticle(){
const input = document.querySelector('.search__input').value
console.log(input)
keywords = input.trim();
number = 2;
limit = 10;
const searchArticleUrl = `https://en.wikipedia.org/w/api.php?origin=*&action=query&list=search&format=json&srlimit=${limit}&srsearch=${keywords}&sroffset=${number}`;
isLoding = true;
fetch(searchArticleUrl)
.then(res=>res.json())
.then(data=>{
console.log(data)
const articles = data.query.search;
displayArticles(articles);
})
.then(err=>console.log(err))
isLoding = false;
//reset the search bar
}
function displayArticles(articles){
// Store a reference to `.searchResults`
const searchResults = document.querySelector('.searchResults');
// Remove all child elements
searchResults.innerHTML = '';
// Loop over results array
articles.forEach(article => {
const url = encodeURI(`https://en.wikipedia.org/wiki/${article.title}`);
searchResults.insertAdjacentHTML('beforeend',
`<div class="resultItem">
<h3 class="resultItem-title">
<a href="${url}" target="_blank" rel="noopener">${article.title}</a>
</h3>
<span class="resultItem-snippet">${article.snippet}</span><br>
<a href="${url}" class="resultItem-link" target="_blank" rel="noopener">${url}</a>
</div>`
);
});
}
function displayLoadingSpinner(){
if(isLoding)console.log('display spinner')
}