Advertisement
Kamend1

06.Accordion

Apr 3rd, 2025
452
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1. function solution() {
  2.     let baseUrl = `http://localhost:3030/jsonstore/advanced/articles/list`;
  3.     let detailUrl = `http://localhost:3030/jsonstore/advanced/articles/details/`;
  4.     let mainSection = document.getElementById('main');
  5.    
  6.     getArticles();
  7.  
  8.     async function getArticles () {
  9.        
  10.         try{
  11.             let response = await fetch(baseUrl);
  12.             let data = await response.json();
  13.             let titles = Object.values(data);
  14.  
  15.             for (let item of titles) {
  16.                 let title = item.title;
  17.                 let id = item._id;
  18.  
  19.                 let articleObiect = await fetch(detailUrl + id);
  20.                 let articleDetails = await articleObiect.json();
  21.                 let articleBody = articleDetails.content;
  22.  
  23.                 createTitleDiv(title, id, articleBody);
  24.             }
  25.  
  26.  
  27.         } catch (error) {
  28.             console.error(error);
  29.         }
  30.        
  31.     }
  32.  
  33.     function createTitleDiv(title, id, articleBody) {
  34.         let newArticle = document.createElement('div');
  35.         newArticle.classList.add('accordion')
  36.  
  37.         let newTitle = document.createElement('div');
  38.         newTitle.classList.add('head');
  39.  
  40.         let titleSpan = document.createElement('span');
  41.         titleSpan.textContent = title;
  42.  
  43.         let newMoreBtn = document.createElement('button');
  44.         newMoreBtn.classList.add('button');
  45.         newMoreBtn.dataset.id = id;
  46.         newMoreBtn.textContent = 'More';
  47.  
  48.         newMoreBtn.addEventListener('click', showDetail)
  49.  
  50.         let extraDiv = document.createElement('div');
  51.         extraDiv.classList.add('extra');
  52.         extraDiv.style.display = 'none';
  53.  
  54.         let extraPara = document.createElement('p');
  55.         extraPara.textContent = articleBody;
  56.  
  57.  
  58.         newTitle.appendChild(titleSpan);
  59.         newTitle.appendChild(newMoreBtn);
  60.         extraDiv.appendChild(extraPara);
  61.         newArticle.appendChild(newTitle);
  62.         newArticle.appendChild(extraDiv);
  63.         mainSection.appendChild(newArticle);
  64.     }
  65.  
  66.     function showDetail (event) {
  67.         let currentBtn = event.currentTarget;
  68.         let id = currentBtn.dataset.id;
  69.         let parentArticle = currentBtn.parentElement.parentElement;
  70.  
  71.         let extraDiv = parentArticle.querySelector('.extra');
  72.        
  73.         if (extraDiv) {
  74.             if (extraDiv.style.display === 'block') {
  75.                 extraDiv.style.display = 'none';
  76.                 currentBtn.textContent = 'More';
  77.             } else {
  78.                 extraDiv.style.display = 'block';
  79.                 currentBtn.textContent = 'Less';
  80.             }
  81.             return
  82.         };
  83.     }
  84. }
  85.  
  86. solution();
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement