I have a code for a localstorage favorite list. It's working fine for example if I click on Article 1 (id: 22) or Article 4 (id: 25) it is added to the favorite list. So far fine. But what I need and can't do alone is: after I add some article id to My Favorite id's (In local storage), then I need when I click on that favorited article id item , I need the page to scroll down to its content.
Javascript code:
//index db
const favoriteButtonAttr = 'data-add-to-favorite';
const isFavorite = 'data-is-favorite';
const listSelector = '[data-my-favorites]';
class FavoritesList {
constructor () {
this.storageName = 'favoritesList';
this.list = this.initList();
}
initList () {
if (window.localStorage.getItem(this.storageName)) {
// todo: repetitive parse?
const list = JSON.parse(window.localStorage.getItem(this.storageName));
updateHtmlList(list);
return list;
} else {
return [];
}
}
initButton(button) {
const id = parseInt(button.getAttribute(favoriteButtonAttr));
button.addEventListener('click', (event) => {
const button = event.target;
!inArray(id, this.list) ? this.list.push(id) : removeFromArray(id, this.list);
setState(id, this.list);
this.updateList();
})
function setState (id, list) {
return button.toggleAttribute(isFavorite, inArray(id, list));
}
setState(id, this.list);
return button;
}
updateList() {
setLocalStorage(this.storageName, this.list);
updateHtmlList(this.list);
}
}
function updateHtmlList(list) {
if(list.length > 0) {
// lastest favorites on top & don't modify original list;
const newList = list.slice(0).reverse();
favoritesHTMLElement.innerHTML = '';
listItems = document.createElement('ul');
newList.forEach( item => {
let htmlLi = document.createElement('li');
htmlLi.innerHTML = item;
favoritesHTMLElement.appendChild(htmlLi);
});
} else {
favoritesHTMLElement.innerHTML = '';
}
}
function inArray(element, array) {
return array.indexOf(element) != -1;
}
function removeFromArray(element, array) {
array.splice(array.indexOf(element), 1);
}
function setLocalStorage(key, value) {
console.log(value)
window.localStorage.setItem(key, JSON.stringify(value));
}
const buttons = document.querySelectorAll(`[${favoriteButtonAttr}]`);
const favoritesHTMLElement = document.querySelector(listSelector);
let favorites = new FavoritesList();
buttons.forEach( button => favorites.initButton(button) );
Html code:
<article class="layout">
<div class="shop">
<h1>Our articles</h1>
<p>Articles will be added to favorite list ordered by last added.</p>
<ul>
<li id="22">
<span>Article 1 (id: 22)</span>
<button class="shop-item__favorite-button" data-add-to-favorite="22" data-favorite-title="Meredith dress">
<span class="sr-only"
data-favorite="Add to my favorites"
data-favorite-added="Remove from my favorites"></span>
</button>
</li>
<li id="23">
<span>Article 2 (id: 23)</span>
<button class="shop-item__favorite-button" data-add-to-favorite="23" data-favorite-title="Meredith Skirt">
<span class="sr-only"
data-favorite="Add to my favorites"
data-favorite-added="Remove from my favorites"></span>
</button>
</li>
<li id="24">
<span>Article 3 (id: 24)</span>
<button class="shop-item__favorite-button" data-add-to-favorite="24" data-favorite-title="Josephine short">
<span class="sr-only"
data-favorite="Add to my favorites"
data-favorite-added="Remove from my favorites"></span>
</button>
</li>
<li id="25">
<span>Article 4 (id: 25)</span>
<button class="shop-item__favorite-button" data-add-to-favorite="25" data-favorite-title="Josephine shirt">
<span class="sr-only"
data-favorite="Add to my favorites"
data-favorite-added="Remove from my favorites"></span>
</button>
</li>
</ul>
</div>
<section class="favorites">
<h2>My Favorite id's (In local storage)</h2>
<ul class="favorites__list" data-my-favorites data-my-favorites-empty="No favorites yet"></ul>
</section>
</article>