Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Binary file added .DS_Store
Binary file not shown.
Binary file added css/.DS_Store
Binary file not shown.
3 changes: 3 additions & 0 deletions css/style.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
.fav{
background-color: #d4f5c4;
}
26 changes: 26 additions & 0 deletions index.htm
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
<!DOCTYPE html>
<html>
<head>
<title>NewsList</title>
<link rel="stylesheet" type="text/css" href="css/style.css">
<script type="text/javascript" src="js/script.js" defer></script>
</head>
<body>

<section id="header">
<div id="userArea">
username

</div>

</section>

<section id="content">
<ul id="newsList">

</ul>

</section>

</body>
</html>
Binary file added js/.DS_Store
Binary file not shown.
169 changes: 169 additions & 0 deletions js/script.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,169 @@
let currentUser
let oldUsers = []


function User(username){
let favs = [];
let count = 0;

function addFav(x){

if(favs.includes(x))
{
alert("already added")
return false;
}
if(counter()){
favs.push(x)
return true
}else{
return false
}

}

function getFav(){
return favs
}

function counter(){
return (count < 3) ? count+=1 : alert("Sorry, you have reached your capacity");
}

return { name : username, addFav, getFav}
}





let userArea = () => {
let element = document.getElementById('userArea')
if(currentUser){
element.innerHTML = "Hello " + currentUser.name + " | <a href='#' onclick='switchUser(true)'>Log out</a>";
}else{
element.innerHTML = `
<form id="login">
Create User <br />
<input type="text" id="username" placeholder="Username" />
<button type="submit" onclick="switchUser()">Create</button>
</form>
`;
}
}



const switchUser = (logout = false) => {
if(logout){
currentUser = ""
userArea()
clearFav()
return
}

let userName = document.querySelector('#username').value;

if(!userName){
alert("User name can't be empty")
return false
}

if(oldUsers[userName]){
currentUser = oldUsers[userName]
userArea()
checkFav()
}else{
currentUser = new User(userName)
oldUsers[userName] = currentUser
userArea()
}
}

const getNews = () => {
let key = "0c5aa5107409412a82f137ff8148d6eb"
let api = "https://newsapi.org/v2/everything?q=toronto&sortBy=publishedAt&apiKey=" + key;

fetch(api, {
method: 'GET',
headers: {
'Content-Type': 'text/plain',
'X-Api-Key': key,
}
})
.then(function(response) {
//if the response status not ok then show me the response
if (response.status !== 200) {
console.log('Looks like there was a problem. Status Code: ' +
response.status);
return;
}

//i did not understand why we did use .then here so please i need some explination
response.json().then(function(data) {
let articles = data.articles

for (let i = 0; i < 5; i++) {
let item = articles[i]
//console.log(item)
let el = document.createElement('li')
el.innerHTML = `
<h1>${item.title}</h1>
<p>
${item.description}
<button class="addFav">Add to FAV</button>
</p>
`;
document.getElementById('newsList').appendChild(el)
}


let items = document.querySelectorAll('li button');

for (let i = 0; i < items.length; i++) {
items[i].addEventListener('click', function(e){
if(!currentUser){
alert("Create a user first")
return false
}


let x = e.target.parentNode.parentNode.children[0].innerHTML
if (currentUser.addFav(x)){
e.target.parentNode.parentNode.classList = "fav"
}
});
}

});

})
.catch(function(err) {
console.log('Error :', err);
});

}

const clearFav = () => {
let lis = document.querySelectorAll('li');
lis.forEach(function(list){
list.classList = "";
})
}

const checkFav = () => {
let fav = currentUser.getFav()
let lis = document.querySelectorAll('li');
lis.forEach(function(list){

if(fav.includes(list.children[0].innerHTML)){
list.classList = "fav";
}
})
}


getNews()
userArea()