forked from Yashu1th/news_application
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
77 lines (58 loc) · 2.3 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
const API_KEY="99a9d9233c0192aba6435485fa9fa71a";
const url="https://gnews.io/api/v4/search?q=";
const max=20;
window.addEventListener('load',() => fetchNews("India"));
async function fetchNews(query){
const res= await fetch(`${url}${query}&max=20&apikey=${API_KEY}`);
const data= await res.json();
console.log(data);
bindData(data.articles);
}
function bindData(articles){
const cardsContainer=document.getElementById("cards-container");
const newsCardTemplate=document.getElementById("template-news-card");
cardsContainer.innerHTML="";
articles.forEach((article) => {
const cardClone = newsCardTemplate.content.cloneNode(true);
fillDataInCard(cardClone, article);
cardsContainer.appendChild(cardClone);
});
}
function fillDataInCard(cardClone,article){
const newsImg = cardClone.querySelector('#news-img');
const newsTitle = cardClone.querySelector('#news-title');
const newsSource = cardClone.querySelector('#news-source');
const newsDesc = cardClone.querySelector('#news-desc');
newsImg.src=article.image;
newsTitle.innerHTML=article.title;
newsSource.innerHTML=article.source.name;
newsDesc.innerHTML=article.description;
// const date=new Date(article.publishedAt).toLocaleDateString("en-US", {
// timeZone:"Asia/Vijayawada",
// });
// newsSource.innerHTML=`${article.source.name} . ${date}`;
cardClone.firstElementChild.addEventListener("click",()=>{
window.open(article.url,"_blank");
});
}
let curSelectedNav=null;
function navItemClick(id){
fetchNews(id);
const navItem=document.getElementById(id);
curSelectedNav?.classList.remove("active");
curSelectedNav=navItem;
curSelectedNav.classList.add("active");
}
const searchButton=document.getElementById('search-button');
const searchText=document.getElementById('search-text');
searchButton.addEventListener("click",() => {
const query=searchText.value;
if(!query) return;
fetchNews(query);
curSelectedNav?.classList.remove("active");
curSelectedNav=null;
})
// const cardsContainer=document.getElementById("cards-container");
// const newsCardTemplate=document.getElementById("template-news-card");
// const cardClone=newsCardTemplate.content.cloneNode(true);
// cardsContainer.appendChild(cardClone);