-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathscript.js
More file actions
129 lines (119 loc) · 4.11 KB
/
script.js
File metadata and controls
129 lines (119 loc) · 4.11 KB
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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
const modal = document.getElementById('modal');
const modalShow = document.getElementById('show-modal');
const modalClose = document.getElementById('close-modal');
const bookmarkForm = document.getElementById('bookmark-form');
const websiteNameEl = document.getElementById('website-name');
const websiteUrlEl = document.getElementById('website-url');
const bookmarksCantainer = document.getElementById('bookmarks-container');
let bookmarks = [];
// Show Modal, Focus on Input
function showModal() {
modal.classList.add('show-modal');
websiteNameEl.focus();
}
// Modal Event Listeners
modalShow.addEventListener('click', showModal);
modalClose.addEventListener('click', () => {
modal.classList.remove('show-modal');
});
window.addEventListener('click', (e) => {
(e.target === modal ? modal.classList.remove('show-modal') : false);
});
// Validate Form
function validate(nameValue, urlValue) {
const expression = /https?:\/\/(www\.)?[-a-zA-Z0-9@:%._\+~#=]{1,256}\.[a-zA-Z0-9()]{1,6}\b([-a-zA-Z0-9()@:%_\+.~#?&//=]*)/g;
const regex = new RegExp(expression);
if(!nameValue || !urlValue) {
alert("Please submit values for both fields.");
}
if(!urlValue.match(regex)) {
alert('Please provide a valid web address');
return false;
}
// Valid
return true;
}
// Build Bookmarks DOM
function buildBookmarks() {
// Clear container - remove all bookmark elements
bookmarksCantainer.innerHTML="";
// Build items
bookmarks.forEach((bookmark) => {
const {name, url} = bookmark;
// Item
const item = document.createElement('div');
item.classList.add('item');
const deleteIcon = document.createElement('i');
deleteIcon.classList.add('fa-solid', 'fa-xmark');
deleteIcon.setAttribute('id', 'delete-bookmark');
deleteIcon.setAttribute('title', "Delete Bookmark");
deleteIcon.setAttribute('onclick', `deleteBookmark('${url}')`)
// Favicon Link Container
const linkInfo = document.createElement('div');
linkInfo.classList.add('name');
// Favicon
const favicon = document.createElement('img');
favicon.setAttribute('src', `http://s2.googleusercontent.com/s2/favicons?domain_url=${url}`);
favicon.setAttribute('alt', 'Favicon');
// Link
const link = document.createElement('a');
link.setAttribute('href', `${url}`);
link.setAttribute('target', '_blank');
link.textContent = name;
// Append to bookmarks contaienr
linkInfo.append(favicon, link);
item.append(deleteIcon, linkInfo);
bookmarksCantainer.append(item);
});
}
// Fetch Bookmarks
function fetchBookmarks() {
// Get bookmarks from localStorage if availbale
if(localStorage.getItem('bookmarks')) {
bookmarks = JSON.parse(localStorage.getItem('bookmarks'));
} else {
// Create bookmarks array in localStorage
bookmarks = [{
name: "Google",
url: "https://google.com",
},];
localStorage.setItem('bookmarks', JSON.stringify(bookmarks));
}
buildBookmarks();
}
// Delete Bookmark
function deleteBookmark(url) {
bookmarks.forEach((bookmark, i) => {
if(bookmark.url === url) {
bookmarks.splice(i, 1);
}
});
// Update bookmarks array in localStorage, re-populate DOM
localStorage.setItem('bookmarks', JSON.stringify(bookmarks));
fetchBookmarks();
}
// Handle Data from Form
function storeBookmark(e) {
e.preventDefault();
const nameValue = websiteNameEl.value;
let urlValue = websiteUrlEl.value;
if(!urlValue.includes('http://') && !urlValue.includes('https://')) {
urlValue = `https://${urlValue}`;
}
if(!validate(nameValue, urlValue)) {
return false;
}
const bookmark = {
name: nameValue,
url: urlValue,
};
bookmarks.push(bookmark);
localStorage.setItem('bookmarks', JSON.stringify(bookmarks));
fetchBookmarks();
bookmarkForm.reset();
websiteNameEl.focus();
}
// Event Listener
bookmarkForm.addEventListener('submit', storeBookmark);
// On Load
fetchBookmarks();