├── .babelrc ├── .eslintrc.json ├── .github └── workflows │ └── linters.yml ├── .gitignore ├── .hintrc ├── .stylelintrc.json ├── LICENSE ├── README.md ├── babel.config.json ├── dist ├── assets │ └── img │ │ ├── icons8-menu-rounded-24.png │ │ ├── icons8-multiply-24.png │ │ └── user.png ├── index.bundle.js ├── index.bundle.js.LICENSE.txt ├── index.css ├── index.html └── runtime.bundle.js ├── murple_logo.png ├── package-lock.json ├── package.json ├── src ├── Test │ ├── test_comments.test.js │ ├── test_item_count.test.js │ └── test_reservations.test.js ├── assets │ └── img │ │ ├── comment.png │ │ ├── home.png │ │ ├── icons8-menu-rounded-24.png │ │ ├── icons8-multiply-24.png │ │ ├── reservation.png │ │ └── user.png ├── index.html ├── index.js ├── modules │ ├── apiUrls.js │ ├── commentCounter.js │ ├── displayItems.js │ ├── domSelector.js │ ├── itemCounter.js │ ├── popupComment.js │ ├── popupReservation.js │ └── reservationCounter.js └── style.css └── webpack.config.js /.babelrc: -------------------------------------------------------------------------------- 1 | { 2 | "env": { 3 | "test": { 4 | "plugins": ["@babel/plugin-transform-modules-commonjs"] 5 | } 6 | } 7 | } -------------------------------------------------------------------------------- /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "env": { 3 | "browser": true, 4 | "es6": true, 5 | "jest": true 6 | }, 7 | "parser": "babel-eslint", 8 | "parserOptions": { 9 | "ecmaVersion": 2018, 10 | "sourceType": "module" 11 | }, 12 | "extends": ["airbnb-base"], 13 | "rules": { 14 | "no-shadow": "off", 15 | "no-param-reassign": "off", 16 | "eol-last": "off", 17 | "import/extensions": [ 1, { 18 | "js": "always", "json": "always" 19 | }] 20 | }, 21 | "ignorePatterns": [ 22 | "dist/", 23 | "build/" 24 | ] 25 | } -------------------------------------------------------------------------------- /.github/workflows/linters.yml: -------------------------------------------------------------------------------- 1 | name: Linters 2 | 3 | on: pull_request 4 | 5 | env: 6 | FORCE_COLOR: 1 7 | 8 | jobs: 9 | lighthouse: 10 | name: Lighthouse 11 | runs-on: ubuntu-22.04 12 | steps: 13 | - uses: actions/checkout@v2 14 | - uses: actions/setup-node@v1 15 | with: 16 | node-version: "12.x" 17 | - name: Setup Lighthouse 18 | run: npm install -g @lhci/cli@0.7.x 19 | - name: Lighthouse Report 20 | run: lhci autorun --upload.target=temporary-public-storage --collect.staticDistDir=. 21 | webhint: 22 | name: Webhint 23 | runs-on: ubuntu-22.04 24 | steps: 25 | - uses: actions/checkout@v2 26 | - uses: actions/setup-node@v1 27 | with: 28 | node-version: "12.x" 29 | - name: Setup Webhint 30 | run: | 31 | npm install --save-dev hint@7.x 32 | [ -f .hintrc ] || wget https://raw.githubusercontent.com/microverseinc/linters-config/master/html-css-js/.hintrc 33 | - name: Webhint Report 34 | run: npx hint . 35 | stylelint: 36 | name: Stylelint 37 | runs-on: ubuntu-22.04 38 | steps: 39 | - uses: actions/checkout@v2 40 | - uses: actions/setup-node@v1 41 | with: 42 | node-version: "12.x" 43 | - name: Setup Stylelint 44 | run: | 45 | npm install --save-dev stylelint@13.x stylelint-scss@3.x stylelint-config-standard@21.x stylelint-csstree-validator@1.x 46 | [ -f .stylelintrc.json ] || wget https://raw.githubusercontent.com/microverseinc/linters-config/master/html-css-js/.stylelintrc.json 47 | - name: Stylelint Report 48 | run: npx stylelint "**/*.{css,scss}" 49 | eslint: 50 | name: ESLint 51 | runs-on: ubuntu-22.04 52 | steps: 53 | - uses: actions/checkout@v2 54 | - uses: actions/setup-node@v1 55 | with: 56 | node-version: "12.x" 57 | - name: Setup ESLint 58 | run: | 59 | npm install --save-dev eslint@7.x eslint-config-airbnb-base@14.x eslint-plugin-import@2.x babel-eslint@10.x 60 | [ -f .eslintrc.json ] || wget https://raw.githubusercontent.com/microverseinc/linters-config/master/html-css-js/.eslintrc.json 61 | - name: ESLint Report 62 | run: npx eslint . 63 | nodechecker: 64 | name: node_modules checker 65 | runs-on: ubuntu-22.04 66 | steps: 67 | - uses: actions/checkout@v2 68 | - name: Check node_modules existence 69 | run: | 70 | if [ -d "node_modules/" ]; then echo -e "\e[1;31mThe node_modules/ folder was pushed to the repo. Please remove it from the GitHub repository and try again."; echo -e "\e[1;32mYou can set up a .gitignore file with this folder included on it to prevent this from happening in the future." && exit 1; fi -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules/ 2 | coverage/ -------------------------------------------------------------------------------- /.hintrc: -------------------------------------------------------------------------------- 1 | { 2 | "connector": { 3 | "name": "local", 4 | "options": { 5 | "pattern": ["**", "!.git/**", "!node_modules/**"] 6 | } 7 | }, 8 | "extends": ["development"], 9 | "formatters": ["stylish"], 10 | "hints": [ 11 | "button-type", 12 | "disown-opener", 13 | "html-checker", 14 | "meta-charset-utf-8", 15 | "meta-viewport", 16 | "no-inline-styles:error" 17 | ] 18 | } -------------------------------------------------------------------------------- /.stylelintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": ["stylelint-config-standard"], 3 | "plugins": ["stylelint-scss", "stylelint-csstree-validator"], 4 | "rules": { 5 | "at-rule-no-unknown": [ 6 | true, 7 | { 8 | "ignoreAtRules": ["tailwind", "apply", "variants", "responsive", "screen"] 9 | } 10 | ], 11 | "scss/at-rule-no-unknown": [ 12 | true, 13 | { 14 | "ignoreAtRules": ["tailwind", "apply", "variants", "responsive", "screen"] 15 | } 16 | ], 17 | "csstree/validator": true 18 | }, 19 | "ignoreFiles": ["build/**", "dist/**", "**/reset*.css", "**/bootstrap*.css", "**/*.js", "**/*.jsx"] 20 | } -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2023 Abu Raihan, Salwa Ballouti, Lugard Agu 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | 2 | 3 |
").concat(t.comment,"
\n").concat(t.comment,"
\nNo Data Found
';case 21:case"end":return t.stop()}var p,m,h}),t)})));return function(){return t.apply(this,arguments)}}();r.addEventListener("click",(function(){a.classList.toggle("display-flex")})),o.addEventListener("click",(function(){a.classList.remove("display-flex")})),i.forEach((function(t){t.addEventListener("click",(function(){a.classList.remove("display-flex")}))})),window.onload=function(){Y()}}},t=>{t(t.s=963)}]); 3 | //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.bundle.js","mappings":"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","sources":["webpack://js-capstone/./src/modules/domSelector.js","webpack://js-capstone/./src/modules/apiUrls.js","webpack://js-capstone/./src/modules/commentCounter.js","webpack://js-capstone/./src/modules/popupComment.js","webpack://js-capstone/./src/modules/reservationCounter.js","webpack://js-capstone/./src/modules/popupReservation.js","webpack://js-capstone/./src/modules/displayItems.js","webpack://js-capstone/./src/modules/itemCounter.js","webpack://js-capstone/./src/index.js"],"sourcesContent":["export const menuBtn = document.getElementById('mobile-menu');\nexport const closeBtn = document.getElementById('cross-menu');\nexport const mobileNavlinks = document.querySelectorAll(\n  '.mobile-nav-group .nav-link',\n);\nexport const mobNavGroup = document.querySelector('.mobile-nav-group');\nexport const modalContainer = document.querySelector('.popup-modal');\nexport const listItemsContainer = document.querySelector('.show-group');\nexport const itemCountContainer = document.getElementById('count_item');\n","export const BASE_URL = 'https://us-central1-involvement-api.cloudfunctions.net/capstoneApi/apps/Y1Ocl2k5LoJdVEhHia5O';\nexport const MOVIE_API = 'https://api.tvmaze.com/seasons/1/episodes';\n","const commentCounter = (countContainer, commentContainer) => {\n  const count = commentContainer.childElementCount;\n  countContainer.innerText = `(${count})`;\n  return count;\n};\n\nexport default commentCounter;\n","import { BASE_URL } from './apiUrls.js';\nimport commentCounter from './commentCounter.js';\nimport { modalContainer } from './domSelector.js';\n\nconst createNewComment = async (url, data, commentsContainer, Form) => {\n  const response = await fetch(url, {\n    method: 'POST',\n    headers: {\n      'Content-Type': 'application/json',\n    },\n    body: JSON.stringify(data),\n  });\n\n  if (!response.ok && response.status !== 201) {\n    return;\n  }\n\n  const fetchComUrl = `${BASE_URL}/comments?item_id=${data.item_id}`;\n\n  const commentResponse = await fetch(fetchComUrl);\n\n  const result = await commentResponse.json();\n\n  // manupulate the dom\n  const commentTite = document.createElement('div');\n  commentTite.className = 'comment-title';\n  const commentHeader = document.createElement('h3');\n  commentHeader.className = 'comment-header';\n  commentHeader.innerHTML = 'Comments';\n  const commentCount = document.createElement('p');\n  commentCount.id = 'show_comment_count';\n  commentCount.innerText = 0;\n\n  commentTite.append(commentHeader, commentCount);\n\n  const commentGroup = document.createElement('ul');\n  commentGroup.className = 'comment-goup';\n\n  let commentItems = '';\n\n  if (result.length > 0) {\n    result.forEach((item) => {\n      commentItems += `<li class='comment-item'>\n      <div class='user-info'>\n        <div class='user-avatar'>\n          <img src='./assets/img/user.png' alt='${item.username}'/>\n        </div>\n        <h4 class='user-name'>${item.username}</h4>\n        <span class='submit-date'>${item.creation_date}</span>\n      </div>\n      <p class='user-data'>${item.comment}</p>\n    </li>`;\n    });\n  }\n\n  commentGroup.innerHTML = commentItems; // append comment list\n  commentsContainer.innerHTML = '';\n\n  commentCounter(commentCount, commentGroup);\n\n  commentsContainer.append(commentTite, commentGroup);\n\n  Form.elements.name.value = '';\n  Form.elements.insight.value = '';\n};\n\nconst render = (data) => {\n  // modal card\n  const modalCard = document.createElement('div');\n  modalCard.className = 'modal-card';\n\n  // button\n  const btnCross = document.createElement('button');\n  btnCross.className = 'btn-cross';\n  btnCross.innerHTML = '<img src=\"./assets/img/icons8-multiply-24.png\" alt=\"X\" />';\n  btnCross.addEventListener('click', () => {\n    modalContainer.classList.remove('show');\n  });\n\n  // card img\n  const cardImg = document.createElement('div');\n  cardImg.className = 'card-img';\n  cardImg.innerHTML = `<img\n  src=\"${data.image.original}\"\n  alt=\"${data.name}\"\n/>`;\n\n  // card title\n  const title = document.createElement('h2');\n  title.className = 'card-title';\n  title.innerText = data.name;\n  // card des\n  const des = document.createElement('div');\n  des.className = 'card-des';\n  des.innerHTML = data.summary;\n\n  // card spec group\n  const cardSpec = document.createElement('div');\n  cardSpec.className = 'card-spec-group';\n  cardSpec.innerHTML = `<ul class=\"card-spec\">\n  <li class=\"spec-item\">Season: ${data.season}</li>\n  <li class=\"spec-item\">Duration: ${data.runtime}</li>\n</ul>\n<ul class=\"card-spec\">\n  <li class=\"spec-item\">airdate: ${data.airdate}</li>\n  <li class=\"spec-item\">Rating: ${data.rating.average}</li>\n</ul>`;\n\n  const commentSection = document.createElement('div');\n  commentSection.className = 'comment-section';\n\n  const commentTite = document.createElement('div');\n  commentTite.className = 'comment-title';\n  const commentHeader = document.createElement('h3');\n  commentHeader.className = 'comment-header';\n  commentHeader.innerHTML = 'Comments';\n  const commentCount = document.createElement('p');\n  commentCount.id = 'show_comment_count';\n  commentCount.innerText = 0;\n\n  commentTite.append(commentHeader, commentCount);\n\n  const commentGroup = document.createElement('ul');\n  commentGroup.className = 'comment-goup';\n\n  let commentItems = '';\n\n  if (data.comments.length > 0) {\n    data.comments.forEach((item) => {\n      commentItems += `<li class='comment-item'>\n        <div class='user-info'>\n          <div class='user-avatar'>\n            <img src='./assets/img/user.png' alt='${item.username}'/>\n          </div>\n          <h4 class='user-name'>${item.username}</h4>\n          <span class='submit-date'>${item.creation_date}</span>\n        </div>\n        <p class='user-data'>${item.comment}</p>\n      </li>`;\n    });\n  }\n\n  commentGroup.innerHTML = commentItems; // append comment list\n\n  commentCounter(commentCount, commentGroup);\n\n  commentSection.append(commentTite, commentGroup);\n\n  // Add comment\n  const commentForm = document.createElement('div');\n  commentForm.className = 'comment-form';\n  const addComment = document.createElement('h3');\n  addComment.className = 'comment-title';\n  addComment.innerText = 'Add a comment';\n  const Form = document.createElement('form');\n  Form.innerHTML = `\n<input type=\"text\"  name=\"name\" id=\"name\" placeholder=\"Your name\" maxlength=\"10\" required>\n<textarea id=\"insight\" name=\"insight\" placeholder=\"Your insights\"></textarea>\n<button type=\"submit\" id=\"submitBtn\">Submit</button>`;\n\n  commentForm.append(addComment, Form);\n\n  Form.addEventListener('submit', async (e) => {\n    e.preventDefault();\n    const name = Form.elements.name.value;\n    const insight = Form.elements.insight.value;\n    const commentData = {\n      item_id: data.id,\n      username: name,\n      comment: insight,\n    };\n    const url = `${BASE_URL}/comments`;\n    createNewComment(url, commentData, commentSection, Form);\n  });\n  // append child elements in cardModal\n  modalCard.append(\n    btnCross,\n    cardImg,\n    title,\n    des,\n    cardSpec,\n    commentSection,\n    commentForm,\n  );\n\n  modalContainer.innerHTML = '';\n  modalContainer.append(modalCard); // append cardModal\n};\n\nconst fetchSingleShowComment = async (e) => {\n  modalContainer.classList.add('show');\n  const { id } = e.target.parentElement.parentElement;\n  const url = `https://api.tvmaze.com/episodes/${id}`;\n  const response = await fetch(url);\n  const result = await response.json();\n\n  const commentResponse = await fetch(`${BASE_URL}/comments?item_id=${id}`);\n\n  let filterResult = { ...result };\n\n  const commentResult = await commentResponse.json();\n  if (commentResult && !commentResult.error) {\n    filterResult = { ...filterResult, comments: commentResult };\n  } else {\n    filterResult = { ...filterResult, comments: [] };\n  }\n\n  render(filterResult);\n};\n\nexport default fetchSingleShowComment;\n","const reservationCounter = (countContainer, reservationContainer) => {\n  const count = reservationContainer.childElementCount;\n  countContainer.innerText = `(${count})`;\n  return count;\n};\n\nexport default reservationCounter;\n","import { BASE_URL } from './apiUrls.js';\nimport { modalContainer } from './domSelector.js';\nimport reservationCounter from './reservationCounter.js';\n\nconst createNewReservation = async (url, data, reservationContainer, Form) => {\n  const response = await fetch(url, {\n    method: 'POST',\n    headers: {\n      'Content-Type': 'application/json',\n    },\n    body: JSON.stringify(data),\n  });\n\n  if (!response.ok && response.status !== 201) {\n    return;\n  }\n\n  const fetchComUrl = `${BASE_URL}/reservations?item_id=${data.item_id}`;\n\n  const reservationResponse = await fetch(fetchComUrl);\n\n  const result = await reservationResponse.json();\n\n  // manupulate the dom\n  const reservationHeader = document.createElement('h3');\n  reservationHeader.className = 'reservation-title';\n  reservationHeader.innerHTML = \"Reservations <span id='show_comment_count'>(0)</span>\";\n\n  const reservationGroup = document.createElement('ul');\n  reservationGroup.className = 'reservation-group';\n\n  let reservationItems = '';\n\n  if (result.length > 0) {\n    result.forEach((item) => {\n      reservationItems += `<li class='reservation-item'>\n      <div class='user-info'>\n        <div class='user-avatar'>\n          <img src='./assets/img/user.png' alt='${item.username}'/>\n        </div>\n        <h4 class='user-name'>${item.username}</h4>\n        <span class='submit-date'>${item.date_start} - ${item.date_end}</span>\n      </div>\n    </li>`;\n    });\n  }\n\n  reservationGroup.innerHTML = reservationItems; // append reservation list\n  reservationContainer.innerHTML = '';\n\n  reservationCounter(reservationHeader.children[0], reservationGroup);\n\n  reservationContainer.append(reservationHeader, reservationGroup);\n\n  Form.elements.name.value = '';\n  Form.elements.start_date.value = '';\n  Form.elements.end_date.value = '';\n};\n\nconst render = (data) => {\n  // modal card\n  const modalCard = document.createElement('div');\n  modalCard.className = 'modal-card';\n\n  // button\n  const btnCross = document.createElement('button');\n  btnCross.className = 'btn-cross';\n  btnCross.innerHTML = '<img src=\"./assets/img/icons8-multiply-24.png\" alt=\"X\" />';\n  btnCross.addEventListener('click', () => {\n    modalContainer.classList.remove('show');\n  });\n\n  // card img\n  const cardImg = document.createElement('div');\n  cardImg.className = 'card-img';\n  cardImg.innerHTML = `<img\n  src=\"${data.image.original}\"\n  alt=\"${data.name}\"\n/>`;\n\n  // card title\n  const title = document.createElement('h2');\n  title.className = 'card-title';\n  title.innerText = data.name;\n\n  // card des\n  const des = document.createElement('div');\n  des.className = 'card-des';\n  des.innerHTML = data.summary;\n\n  // card spec group\n  const cardSpec = document.createElement('div');\n  cardSpec.className = 'card-spec-group';\n  cardSpec.innerHTML = `<ul class=\"card-spec\">\n  <li class=\"spec-item\">Season: ${data.season}</li>\n  <li class=\"spec-item\">Duration: ${data.runtime}</li>\n</ul>\n<ul class=\"card-spec\">\n  <li class=\"spec-item\">airdate: ${data.airdate}</li>\n  <li class=\"spec-item\">Rating: ${data.rating.average}</li>\n</ul>`;\n\n  const reservationSection = document.createElement('div');\n  reservationSection.className = 'reservation-section';\n\n  const reservationHeader = document.createElement('h3');\n  reservationHeader.className = 'reservation-title';\n  reservationHeader.innerHTML = \"Reservations <span id='show_comment_count'>(0)</span>\";\n\n  const reservationGroup = document.createElement('ul');\n  reservationGroup.className = 'reservation-group';\n\n  let reservationItems = '';\n\n  if (data.reservations.length > 0) {\n    data.reservations.forEach((item) => {\n      reservationItems += `<li class='reservation-item'>\n      <div class='user-info'>\n        <div class='user-avatar'>\n          <img src='./assets/img/user.png' alt='${item.username}'/>\n        </div>\n        <h4 class='user-name'>${item.username}</h4>\n        <span class='submit-date'>${item.date_start} - ${item.date_end}</span>\n      </div>\n    </li>`;\n    });\n  }\n\n  reservationGroup.innerHTML = reservationItems; // append reservation list\n\n  reservationCounter(reservationHeader.children[0], reservationGroup);\n\n  reservationSection.append(reservationHeader, reservationGroup);\n\n  // Add comment\n  const reservationForm = document.createElement('div');\n  reservationForm.className = 'reservation-form';\n  const addReservation = document.createElement('h3');\n  addReservation.className = 'reservation-title';\n  addReservation.innerText = 'Add a Reservation';\n  const Form = document.createElement('form');\n  Form.innerHTML = `\n  <input type=\"text\"  name=\"name\" id=\"name\" placeholder=\"Your name\" maxlength=\"10\" required>\n  <label for='start_date'>Add your start date below</label>\n  <input type=\"date\"  name=\"start_date\" id=\"start_date\" placeholder=\"Add your start date here.\" required>\n  <label for='end_date'>Add your end date below</label>\n  <input type=\"date\"  name=\"end_date\" id=\"end_date\" placeholder=\"Add your end date here.\" required>\n  <button type=\"submit\" id=\"submitBtn\">Reserve</button>`;\n\n  reservationForm.append(addReservation, Form);\n\n  Form.addEventListener('submit', async (e) => {\n    e.preventDefault();\n    const name = Form.elements.name.value;\n    const startDate = Form.elements.start_date.value;\n    const endDate = Form.elements.end_date.value;\n    const reserveData = {\n      item_id: data.id,\n      username: name,\n      date_start: startDate,\n      date_end: endDate,\n    };\n    const url = `${BASE_URL}/reservations/`;\n    createNewReservation(url, reserveData, reservationSection, Form);\n  });\n\n  // append child elements in cardModal\n  // eslint-disable-next-line max-len\n  modalCard.append(\n    btnCross,\n    cardImg,\n    title,\n    des,\n    cardSpec,\n    reservationSection,\n    reservationForm,\n  );\n\n  modalContainer.innerHTML = '';\n  modalContainer.append(modalCard); // append cardModal\n};\n\nconst fetchSingleShow = async (e) => {\n  modalContainer.classList.add('show');\n  const { id } = e.target.parentElement.parentElement;\n  const url = `https://api.tvmaze.com/episodes/${id}`;\n  const response = await fetch(url);\n  const result = await response.json();\n\n  const reservationResponse = await fetch(\n    `${BASE_URL}/reservations?item_id=${id}`,\n  );\n\n  let filterResult = { ...result };\n\n  const reservationResult = await reservationResponse.json();\n  if (reservationResult && !reservationResult.error) {\n    filterResult = { ...filterResult, reservations: reservationResult };\n  } else {\n    filterResult = { ...filterResult, reservations: [] };\n  }\n\n  render(filterResult);\n};\n\nexport default fetchSingleShow;\n","import { itemCountContainer, listItemsContainer } from './domSelector.js';\nimport fetchSingleShowComment from './popupComment.js';\nimport fetchSingleShow from './popupReservation.js';\nimport { BASE_URL, MOVIE_API } from './apiUrls.js';\nimport itemCounter from './itemCounter.js';\n\n// createNew like\nconst createNewLike = async (id, likeCount, btnLike) => {\n  btnLike.setAttribute('disabled', '');\n  const response = await fetch(`${BASE_URL}/likes`, {\n    method: 'POST',\n    headers: {\n      'Content-Type': 'application/json',\n    },\n    body: JSON.stringify({ item_id: id }),\n  });\n\n  if (!response.ok && response.status !== 201) {\n    return;\n  }\n\n  const responseLikes = await fetch(`${BASE_URL}/likes`);\n  const result = await responseLikes.json();\n  const likeData = result.find((item) => item.item_id === id);\n  if (likeData) {\n    likeCount.innerText = likeData.likes > 1 ? `${likeData.likes} likes` : `${likeData.likes} like`;\n    btnLike.innerHTML = `<?xml version=\"1.0\" encoding=\"iso-8859-1\"?>\n    <!-- Uploaded to: SVG Repo, www.svgrepo.com, Generator: SVG Repo Mixer Tools -->\n    <svg fill=\"#ff7b00\" height=\"22px\" width=\"22px\" version=\"1.1\" id=\"Layer_1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" \n       viewBox=\"0 0 455 455\" xml:space=\"preserve\">\n    <path d=\"M326.632,10.346c-38.733,0-74.991,17.537-99.132,46.92c-24.141-29.383-60.399-46.92-99.132-46.92\n      C57.586,10.346,0,67.931,0,138.714c0,55.426,33.049,119.535,98.23,190.546c50.162,54.649,104.729,96.96,120.257,108.626l9.01,6.769\n      l9.009-6.768c15.53-11.667,70.099-53.979,120.26-108.625C421.95,258.251,455,194.141,455,138.714\n      C455,67.931,397.414,10.346,326.632,10.346z\"/>\n    </svg>`;\n  }\n};\n\n// render the item list\nconst render = (data) => {\n  if (data.length > 0) {\n    listItemsContainer.innerHTML = '';\n\n    data.forEach((i) => {\n      const item = document.createElement('li');\n      item.id = i.id;\n      item.className = 'show-item';\n\n      // create sho Img element\n      const showImg = document.createElement('div');\n      showImg.className = 'show-item-img';\n      showImg.innerHTML = `<img src='${i.image.original}'>`;\n\n      // create show info\n      const showInfo = document.createElement('div');\n      showInfo.className = 'show-info';\n\n      // create tile for show info\n      const title = document.createElement('h3');\n      title.className = 'show-title';\n      title.innerText = i.name;\n\n      // like action\n      const showLikeAction = document.createElement('div');\n      showLikeAction.className = 'shwo-like-action';\n\n      // like button\n      const btnLike = document.createElement('button');\n      btnLike.className = 'btn-like';\n      btnLike.innerHTML = `<?xml version=\"1.0\" encoding=\"iso-8859-1\"?>\n      <!-- Uploaded to: SVG Repo, www.svgrepo.com, Generator: SVG Repo Mixer Tools -->\n      <svg fill=\"#ff7b00\" height=\"22px\" width=\"22px\" version=\"1.1\" id=\"Layer_1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" \n         viewBox=\"0 0 455 455\" xml:space=\"preserve\">\n      <path d=\"M326.632,10.346c-38.733,0-74.991,17.537-99.132,46.92c-24.141-29.384-60.398-46.92-99.132-46.92\n        C57.586,10.346,0,67.931,0,138.714c0,55.426,33.05,119.535,98.23,190.546c50.161,54.647,104.728,96.959,120.257,108.626l9.01,6.769\n        l9.01-6.768c15.529-11.667,70.098-53.978,120.26-108.625C421.949,258.251,455,194.141,455,138.714\n        C455,67.931,397.414,10.346,326.632,10.346z M334.666,308.974c-41.259,44.948-85.648,81.283-107.169,98.029\n        c-21.52-16.746-65.907-53.082-107.166-98.03C61.236,244.592,30,185.717,30,138.714c0-54.24,44.128-98.368,98.368-98.368\n        c35.694,0,68.652,19.454,86.013,50.771l13.119,23.666l13.119-23.666c17.36-31.316,50.318-50.771,86.013-50.771\n        c54.24,0,98.368,44.127,98.368,98.368C425,185.719,393.763,244.594,334.666,308.974z\"/>\n      </svg>`;\n\n      // like count\n      const likeCount = document.createElement('span');\n      if (i.likes > 1) {\n        likeCount.innerText = `${i.likes} likes`;\n      } else {\n        likeCount.innerHTML = `${i.likes} like`;\n      }\n\n      // btn like event to create new like\n      btnLike.addEventListener('click', () => {\n        createNewLike(i.id, likeCount, btnLike);\n      });\n\n      showLikeAction.append(btnLike, likeCount); // append like actions child element.\n\n      showInfo.append(title, showLikeAction); // append in showInfo\n\n      // show action\n      const showActions = document.createElement('div');\n      showActions.className = 'show-actions';\n\n      // create child btn\n      const commentBtn = document.createElement('button');\n      commentBtn.className = 'btn-action btn-comment';\n      commentBtn.innerText = 'Comments';\n      commentBtn.addEventListener('click', (e) => {\n        fetchSingleShowComment(e);\n      });\n\n      const reservationBtn = document.createElement('button');\n      reservationBtn.className = 'btn-action btn-reservation';\n      reservationBtn.innerText = 'Reservations';\n      reservationBtn.addEventListener('click', (e) => {\n        fetchSingleShow(e);\n      });\n\n      showActions.append(commentBtn, reservationBtn); // append child action buttons in showActions\n\n      item.append(showImg, showInfo, showActions); // append clild all the elements in item.\n\n      listItemsContainer.appendChild(item);\n    });\n    itemCounter(itemCountContainer, listItemsContainer);\n  } else {\n    listItemsContainer.innerHTML = '<p class=\"no-data\">No Data Found</p>';\n  }\n};\n\nconst fetchTvShows = async () => {\n  const response = await fetch(MOVIE_API);\n  const result = await response.json();\n\n  // call the Involment api to get likes\n  const responseInvolvement = await fetch(`${BASE_URL}/likes/`);\n  const likesResult = await responseInvolvement.json();\n\n  // filter Array thats have Likes\n  const filterArrWithLikes = [];\n  result.forEach((item) => {\n    likesResult.forEach((likeItem) => {\n      if (item.id === likeItem.item_id) {\n        filterArrWithLikes.push({ ...item, likes: likeItem.likes });\n      }\n    });\n  });\n\n  // filter Array thats have not likes\n  let filterWithoutLikes = [];\n  filterWithoutLikes = result.filter(\n    (el) => !filterArrWithLikes.find((element) => element.id === el.id),\n  ); //eslint-disable-line\n\n  // modify the filterWithout array likes count 0;\n  const modifiyFilterWithoutLikes = [];\n  filterWithoutLikes.forEach((item) => {\n    modifiyFilterWithoutLikes.push({ ...item, likes: 0 });\n  });\n\n  // join and sort the arrays\n  const joinArr = modifiyFilterWithoutLikes.concat(filterArrWithLikes);\n  joinArr.sort((a, b) => a.id - b.id);\n\n  // call render function to display the item list\n  render(joinArr);\n};\n\nexport default fetchTvShows;\n","const itemCounter = (countContainer, itemContainer) => {\n  const count = itemContainer.childElementCount;\n  countContainer.innerText = `(${count})`;\n  return count;\n};\n\nexport default itemCounter;\n","// import static files\nimport './style.css';\nimport './assets/img/icons8-menu-rounded-24.png';\nimport './assets/img/icons8-multiply-24.png';\nimport './assets/img/user.png';\n\nimport fetchTvShow from './modules/displayItems.js';\nimport {\n  closeBtn,\n  menuBtn,\n  mobNavGroup,\n  mobileNavlinks,\n} from './modules/domSelector.js';\n\n// toggle the menu\nmenuBtn.addEventListener('click', () => {\n  mobNavGroup.classList.toggle('display-flex');\n});\n\ncloseBtn.addEventListener('click', () => {\n  mobNavGroup.classList.remove('display-flex');\n});\n\nmobileNavlinks.forEach((item) => {\n  item.addEventListener('click', () => {\n    mobNavGroup.classList.remove('display-flex');\n  });\n});\n\n// load the item list on the fly.\nwindow.onload = () => {\n  fetchTvShow();\n};\n"],"names":["menuBtn","document","getElementById","closeBtn","mobileNavlinks","querySelectorAll","mobNavGroup","querySelector","modalContainer","listItemsContainer","itemCountContainer","BASE_URL","countContainer","commentContainer","count","childElementCount","innerText","i","createNewComment","url","data","commentsContainer","Form","fetch","method","headers","body","JSON","stringify","response","ok","status","fetchComUrl","item_id","commentResponse","json","result","commentTite","createElement","className","commentHeader","innerHTML","commentCount","id","append","commentGroup","commentItems","length","forEach","item","username","creation_date","comment","commentCounter","elements","name","value","insight","render","modalCard","btnCross","addEventListener","classList","remove","cardImg","image","original","title","des","summary","cardSpec","season","runtime","airdate","rating","average","commentSection","comments","commentForm","addComment","e","preventDefault","commentData","add","target","parentElement","filterResult","commentResult","error","reservationContainer","createNewReservation","reservationResponse","reservationHeader","reservationGroup","reservationItems","date_start","date_end","reservationCounter","children","start_date","end_date","reservationSection","reservations","reservationForm","addReservation","startDate","endDate","reserveData","reservationResult","createNewLike","likeCount","btnLike","setAttribute","responseLikes","likeData","find","likes","responseInvolvement","likesResult","filterArrWithLikes","likeItem","push","filterWithoutLikes","filter","el","element","modifiyFilterWithoutLikes","joinArr","concat","sort","a","b","showImg","showInfo","showLikeAction","showActions","commentBtn","fetchSingleShowComment","reservationBtn","fetchSingleShow","appendChild","toggle","window","onload","fetchTvShow"],"sourceRoot":""} -------------------------------------------------------------------------------- /dist/index.bundle.js.LICENSE.txt: -------------------------------------------------------------------------------- 1 | /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ 2 | -------------------------------------------------------------------------------- /dist/index.css: -------------------------------------------------------------------------------- 1 | * { 2 | box-sizing: border-box; 3 | } 4 | 5 | html, 6 | body { 7 | font-family: sans-serif; 8 | padding: 0; 9 | margin: 0; 10 | background: #0d1117; 11 | color: #fff; 12 | } 13 | 14 | a { 15 | text-decoration: none; 16 | } 17 | 18 | .display-flex { 19 | display: flex !important; 20 | } 21 | 22 | .display-none { 23 | display: none !important; 24 | } 25 | 26 | .header { 27 | padding: 3%; 28 | height: 70px; 29 | display: flex; 30 | justify-content: center; 31 | align-items: center; 32 | background: #161b22; 33 | } 34 | 35 | .logo { 36 | font-size: 1.6rem; 37 | font-weight: bold; 38 | color: #ff7b00; 39 | } 40 | 41 | .nav-menu { 42 | display: block; 43 | background: transparent; 44 | border: 1px solid #333; 45 | padding: 3px 5px; 46 | align-self: center; 47 | } 48 | 49 | .nav-menu:active { 50 | background: #333; 51 | } 52 | 53 | .navbar { 54 | display: flex; 55 | width: 100%; 56 | max-width: 1000px; 57 | justify-content: space-between; 58 | align-items: center; 59 | } 60 | 61 | .mobile-nav-group { 62 | display: none; 63 | position: fixed; 64 | left: 0; 65 | right: 0; 66 | bottom: 0; 67 | top: 0; 68 | list-style: none; 69 | flex-direction: column; 70 | margin: 0; 71 | padding: 50px 0; 72 | gap: 20px; 73 | background: #161b22; 74 | } 75 | 76 | .desktop-nav-group { 77 | display: none; 78 | } 79 | 80 | .nav-link { 81 | color: #fff; 82 | color: #ff7b00; 83 | padding: 8px 10px; 84 | text-decoration: none; 85 | transition: all 0.2s ease-in-out; 86 | } 87 | 88 | .mobile-nav-group .nav-link { 89 | display: block; 90 | padding: 15px 20px; 91 | margin-bottom: 5px; 92 | background: #0d1117; 93 | } 94 | 95 | .nav-link:hover { 96 | color: #fff; 97 | background: #ff7b00; 98 | } 99 | 100 | .footer { 101 | left: 0; 102 | right: 0; 103 | bottom: 0; 104 | z-index: 10; 105 | position: relative; 106 | text-align: center; 107 | padding: 20px 25px; 108 | background: #161b22; 109 | border-top: 1px solid #333; 110 | } 111 | 112 | /* Main content css start form here */ 113 | .main-container { 114 | display: flex; 115 | margin: 70px 0; 116 | flex-direction: column; 117 | } 118 | 119 | .tv-shows { 120 | display: flex; 121 | flex-direction: column; 122 | align-items: center; 123 | } 124 | 125 | .show-title { 126 | text-align: center; 127 | } 128 | 129 | .show-group { 130 | display: flex; 131 | list-style: none; 132 | flex-direction: column; 133 | margin: 0; 134 | padding: 0; 135 | align-items: center; 136 | justify-content: center; 137 | width: 100%; 138 | max-width: 1000px; 139 | gap: 20px; 140 | } 141 | 142 | .show-item { 143 | padding: 20px; 144 | background: #161b22; 145 | border: 1px solid #333; 146 | } 147 | 148 | .show-item-img { 149 | display: block; 150 | max-width: 100%; 151 | } 152 | 153 | .show-item-img img { 154 | max-width: 100%; 155 | } 156 | 157 | .show-info { 158 | display: flex; 159 | align-items: center; 160 | justify-content: space-between; 161 | } 162 | 163 | .btn-like { 164 | background: transparent; 165 | border: none; 166 | color: #fff; 167 | margin-left: 10px; 168 | cursor: pointer; 169 | transition: all 0.2s ease-in-out; 170 | } 171 | 172 | .btn-like:active { 173 | transform: translateY(-2px); 174 | } 175 | 176 | .btn-like img { 177 | width: 22px; 178 | max-width: 100%; 179 | filter: invert(54%) sepia(62%) saturate(3447%) hue-rotate(0deg) brightness(102%) contrast(103%); 180 | } 181 | 182 | .btn-like:disabled { 183 | cursor: not-allowed; 184 | } 185 | 186 | .show-actions { 187 | display: flex; 188 | flex-direction: column; 189 | gap: 15px; 190 | } 191 | 192 | .btn-action { 193 | padding: 10px 15px; 194 | background: #ff7b00; 195 | color: #fff; 196 | border: none; 197 | } 198 | 199 | .btn-action:active { 200 | transform: translateY(-2px); 201 | } 202 | 203 | /* Article modal css styles will start from here */ 204 | .popup-modal { 205 | display: none; 206 | width: 100%; 207 | height: 100%; 208 | position: fixed; 209 | z-index: 2000; 210 | left: 0; 211 | top: 0; 212 | bottom: 0; 213 | backdrop-filter: blur(7px); 214 | -webkit-backdrop-filter: blur(10px); 215 | background: rgba(8, 19, 43, 0.4); 216 | box-shadow: 0 8px 32px 0 rgba(31, 38, 135, 0.37); 217 | justify-content: center; 218 | } 219 | 220 | .modal-card { 221 | border-radius: 20px; 222 | display: flex; 223 | flex-direction: column; 224 | background: #161b22; 225 | width: 100%; 226 | height: 100%; 227 | overflow: scroll; 228 | gap: 10px; 229 | padding: 24px; 230 | max-width: 1156px; 231 | margin: 25px 15px; 232 | position: relative; 233 | color: #fff; 234 | } 235 | 236 | .btn-cross { 237 | background: transparent; 238 | border: none; 239 | position: absolute; 240 | right: 10px; 241 | top: 10px; 242 | } 243 | 244 | .btn-cross:active { 245 | transform: translateY(-2px); 246 | } 247 | 248 | .card-img { 249 | display: flex; 250 | justify-content: center; 251 | align-items: center; 252 | margin-top: 15px; 253 | } 254 | 255 | .card-img img { 256 | max-width: 100%; 257 | } 258 | 259 | .card-title { 260 | text-align: center; 261 | font-size: 2rem; 262 | font-weight: normal; 263 | } 264 | 265 | .card-spec-group { 266 | display: flex; 267 | flex-direction: column; 268 | align-items: center; 269 | border: 1px solid #333; 270 | } 271 | 272 | .card-spec { 273 | display: flex; 274 | list-style: none; 275 | justify-content: space-between; 276 | margin: 0; 277 | padding: 0; 278 | width: 100%; 279 | flex-wrap: wrap; 280 | align-items: center; 281 | margin-bottom: 25px; 282 | max-width: 600px; 283 | } 284 | 285 | .spec-item { 286 | padding: 15px; 287 | text-align: justify; 288 | } 289 | 290 | .show { 291 | display: flex; 292 | } 293 | 294 | .comment-section { 295 | display: flex; 296 | flex-direction: column; 297 | align-items: center; 298 | } 299 | 300 | .comment-title { 301 | display: flex; 302 | align-items: center; 303 | text-align: center; 304 | margin: 10px 0; 305 | font-weight: normal; 306 | } 307 | 308 | .comment-header { 309 | margin-right: 10px; 310 | } 311 | 312 | #show_comment_count { 313 | font-size: 1.2rem; 314 | } 315 | 316 | .comment-goup { 317 | width: 100%; 318 | max-width: 600px; 319 | display: flex; 320 | align-items: center; 321 | flex-direction: column; 322 | list-style: none; 323 | padding: 0; 324 | margin: 0; 325 | gap: 15px; 326 | } 327 | 328 | .comment-item { 329 | width: 100%; 330 | margin: 5px; 331 | border: 1px solid #333; 332 | } 333 | 334 | .user-info { 335 | background: #0d1117; 336 | display: flex; 337 | align-items: center; 338 | border-bottom: 1px solid #333; 339 | padding: 0 15px; 340 | } 341 | 342 | .user-avatar { 343 | margin-right: 10px; 344 | } 345 | 346 | .user-name { 347 | margin-right: 10px; 348 | } 349 | 350 | .submit-date { 351 | margin-left: auto; 352 | } 353 | 354 | .user-data { 355 | padding: 15px; 356 | } 357 | 358 | .comment-form { 359 | width: 100%; 360 | display: flex; 361 | flex-direction: column; 362 | align-items: center; 363 | margin-bottom: 20px; 364 | } 365 | 366 | form { 367 | width: 100%; 368 | max-width: 600px; 369 | display: flex; 370 | flex-direction: column; 371 | gap: 15px; 372 | } 373 | 374 | input, 375 | #submitBtn { 376 | border: 2px solid #333; 377 | text-align: justify; 378 | border-radius: 5px; 379 | font-size: 1.2rem; 380 | color: #fff; 381 | background: #010409; 382 | padding: 8px 15px; 383 | /* stylelint-disable-next-line */ 384 | color-scheme: dark; 385 | } 386 | 387 | #submitBtn { 388 | width: fit-content; 389 | padding: 10px 20px; 390 | background: #ff7b00; 391 | color: #fff; 392 | border: none; 393 | } 394 | 395 | textarea { 396 | resize: none; 397 | height: 100px; 398 | padding: 10px 20px; 399 | border: 2px solid #333; 400 | border-radius: 5px; 401 | font-size: 1.2rem; 402 | background: #010409; 403 | color: #fff; 404 | } 405 | 406 | button { 407 | cursor: pointer; 408 | } 409 | 410 | .reservation-section { 411 | display: flex; 412 | flex-direction: column; 413 | align-items: center; 414 | } 415 | 416 | .reservation-title { 417 | text-align: center; 418 | margin: 10px 0; 419 | font-weight: normal; 420 | } 421 | 422 | .reservation-group { 423 | width: 100%; 424 | max-width: 600px; 425 | display: flex; 426 | align-items: center; 427 | flex-direction: column; 428 | list-style: none; 429 | padding: 0; 430 | margin: 0; 431 | gap: 15px; 432 | } 433 | 434 | .reservation-item { 435 | width: 100%; 436 | margin: 5px; 437 | border: 1px solid #333; 438 | } 439 | 440 | .reservation-form { 441 | width: 100%; 442 | display: flex; 443 | flex-direction: column; 444 | align-items: center; 445 | margin-bottom: 25px; 446 | } 447 | 448 | @media screen and (min-width: 768px) { 449 | .mobile-nav-group { 450 | display: none; 451 | } 452 | 453 | .desktop-nav-group { 454 | display: flex; 455 | list-style: none; 456 | gap: 10px; 457 | } 458 | 459 | .nav-menu { 460 | display: none; 461 | } 462 | 463 | /* Main content css start from here */ 464 | .show-group { 465 | flex-direction: row; 466 | flex-wrap: wrap; 467 | } 468 | 469 | .show-item { 470 | width: 31%; 471 | } 472 | 473 | /* popup modal css */ 474 | .card-des { 475 | padding: 0 5%; 476 | } 477 | } 478 | 479 | 480 | /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.css","mappings":"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","sources":["webpack://js-capstone/./src/style.css"],"sourcesContent":["* {\r\n  box-sizing: border-box;\r\n}\r\n\r\nhtml,\r\nbody {\r\n  font-family: sans-serif;\r\n  padding: 0;\r\n  margin: 0;\r\n  background: #0d1117;\r\n  color: #fff;\r\n}\r\n\r\na {\r\n  text-decoration: none;\r\n}\r\n\r\n.display-flex {\r\n  display: flex !important;\r\n}\r\n\r\n.display-none {\r\n  display: none !important;\r\n}\r\n\r\n.header {\r\n  padding: 3%;\r\n  height: 70px;\r\n  display: flex;\r\n  justify-content: center;\r\n  align-items: center;\r\n  background: #161b22;\r\n}\r\n\r\n.logo {\r\n  font-size: 1.6rem;\r\n  font-weight: bold;\r\n  color: #ff7b00;\r\n}\r\n\r\n.nav-menu {\r\n  display: block;\r\n  background: transparent;\r\n  border: 1px solid #333;\r\n  padding: 3px 5px;\r\n  align-self: center;\r\n}\r\n\r\n.nav-menu:active {\r\n  background: #333;\r\n}\r\n\r\n.navbar {\r\n  display: flex;\r\n  width: 100%;\r\n  max-width: 1000px;\r\n  justify-content: space-between;\r\n  align-items: center;\r\n}\r\n\r\n.mobile-nav-group {\r\n  display: none;\r\n  position: fixed;\r\n  left: 0;\r\n  right: 0;\r\n  bottom: 0;\r\n  top: 0;\r\n  list-style: none;\r\n  flex-direction: column;\r\n  margin: 0;\r\n  padding: 50px 0;\r\n  gap: 20px;\r\n  background: #161b22;\r\n}\r\n\r\n.desktop-nav-group {\r\n  display: none;\r\n}\r\n\r\n.nav-link {\r\n  color: #fff;\r\n  color: #ff7b00;\r\n  padding: 8px 10px;\r\n  text-decoration: none;\r\n  transition: all 0.2s ease-in-out;\r\n}\r\n\r\n.mobile-nav-group .nav-link {\r\n  display: block;\r\n  padding: 15px 20px;\r\n  margin-bottom: 5px;\r\n  background: #0d1117;\r\n}\r\n\r\n.nav-link:hover {\r\n  color: #fff;\r\n  background: #ff7b00;\r\n}\r\n\r\n.footer {\r\n  left: 0;\r\n  right: 0;\r\n  bottom: 0;\r\n  z-index: 10;\r\n  position: relative;\r\n  text-align: center;\r\n  padding: 20px 25px;\r\n  background: #161b22;\r\n  border-top: 1px solid #333;\r\n}\r\n\r\n/* Main content css start form here */\r\n.main-container {\r\n  display: flex;\r\n  margin: 70px 0;\r\n  flex-direction: column;\r\n}\r\n\r\n.tv-shows {\r\n  display: flex;\r\n  flex-direction: column;\r\n  align-items: center;\r\n}\r\n\r\n.show-title {\r\n  text-align: center;\r\n}\r\n\r\n.show-group {\r\n  display: flex;\r\n  list-style: none;\r\n  flex-direction: column;\r\n  margin: 0;\r\n  padding: 0;\r\n  align-items: center;\r\n  justify-content: center;\r\n  width: 100%;\r\n  max-width: 1000px;\r\n  gap: 20px;\r\n}\r\n\r\n.show-item {\r\n  padding: 20px;\r\n  background: #161b22;\r\n  border: 1px solid #333;\r\n}\r\n\r\n.show-item-img {\r\n  display: block;\r\n  max-width: 100%;\r\n}\r\n\r\n.show-item-img img {\r\n  max-width: 100%;\r\n}\r\n\r\n.show-info {\r\n  display: flex;\r\n  align-items: center;\r\n  justify-content: space-between;\r\n}\r\n\r\n.btn-like {\r\n  background: transparent;\r\n  border: none;\r\n  color: #fff;\r\n  margin-left: 10px;\r\n  cursor: pointer;\r\n  transition: all 0.2s ease-in-out;\r\n}\r\n\r\n.btn-like:active {\r\n  transform: translateY(-2px);\r\n}\r\n\r\n.btn-like img {\r\n  width: 22px;\r\n  max-width: 100%;\r\n  filter: invert(54%) sepia(62%) saturate(3447%) hue-rotate(0deg) brightness(102%) contrast(103%);\r\n}\r\n\r\n.btn-like:disabled {\r\n  cursor: not-allowed;\r\n}\r\n\r\n.show-actions {\r\n  display: flex;\r\n  flex-direction: column;\r\n  gap: 15px;\r\n}\r\n\r\n.btn-action {\r\n  padding: 10px 15px;\r\n  background: #ff7b00;\r\n  color: #fff;\r\n  border: none;\r\n}\r\n\r\n.btn-action:active {\r\n  transform: translateY(-2px);\r\n}\r\n\r\n/* Article modal css styles will start from here */\r\n.popup-modal {\r\n  display: none;\r\n  width: 100%;\r\n  height: 100%;\r\n  position: fixed;\r\n  z-index: 2000;\r\n  left: 0;\r\n  top: 0;\r\n  bottom: 0;\r\n  backdrop-filter: blur(7px);\r\n  -webkit-backdrop-filter: blur(10px);\r\n  background: rgba(8, 19, 43, 0.4);\r\n  box-shadow: 0 8px 32px 0 rgba(31, 38, 135, 0.37);\r\n  justify-content: center;\r\n}\r\n\r\n.modal-card {\r\n  border-radius: 20px;\r\n  display: flex;\r\n  flex-direction: column;\r\n  background: #161b22;\r\n  width: 100%;\r\n  height: 100%;\r\n  overflow: scroll;\r\n  gap: 10px;\r\n  padding: 24px;\r\n  max-width: 1156px;\r\n  margin: 25px 15px;\r\n  position: relative;\r\n  color: #fff;\r\n}\r\n\r\n.btn-cross {\r\n  background: transparent;\r\n  border: none;\r\n  position: absolute;\r\n  right: 10px;\r\n  top: 10px;\r\n}\r\n\r\n.btn-cross:active {\r\n  transform: translateY(-2px);\r\n}\r\n\r\n.card-img {\r\n  display: flex;\r\n  justify-content: center;\r\n  align-items: center;\r\n  margin-top: 15px;\r\n}\r\n\r\n.card-img img {\r\n  max-width: 100%;\r\n}\r\n\r\n.card-title {\r\n  text-align: center;\r\n  font-size: 2rem;\r\n  font-weight: normal;\r\n}\r\n\r\n.card-spec-group {\r\n  display: flex;\r\n  flex-direction: column;\r\n  align-items: center;\r\n  border: 1px solid #333;\r\n}\r\n\r\n.card-spec {\r\n  display: flex;\r\n  list-style: none;\r\n  justify-content: space-between;\r\n  margin: 0;\r\n  padding: 0;\r\n  width: 100%;\r\n  flex-wrap: wrap;\r\n  align-items: center;\r\n  margin-bottom: 25px;\r\n  max-width: 600px;\r\n}\r\n\r\n.spec-item {\r\n  padding: 15px;\r\n  text-align: justify;\r\n}\r\n\r\n.show {\r\n  display: flex;\r\n}\r\n\r\n.comment-section {\r\n  display: flex;\r\n  flex-direction: column;\r\n  align-items: center;\r\n}\r\n\r\n.comment-title {\r\n  display: flex;\r\n  align-items: center;\r\n  text-align: center;\r\n  margin: 10px 0;\r\n  font-weight: normal;\r\n}\r\n\r\n.comment-header {\r\n  margin-right: 10px;\r\n}\r\n\r\n#show_comment_count {\r\n  font-size: 1.2rem;\r\n}\r\n\r\n.comment-goup {\r\n  width: 100%;\r\n  max-width: 600px;\r\n  display: flex;\r\n  align-items: center;\r\n  flex-direction: column;\r\n  list-style: none;\r\n  padding: 0;\r\n  margin: 0;\r\n  gap: 15px;\r\n}\r\n\r\n.comment-item {\r\n  width: 100%;\r\n  margin: 5px;\r\n  border: 1px solid #333;\r\n}\r\n\r\n.user-info {\r\n  background: #0d1117;\r\n  display: flex;\r\n  align-items: center;\r\n  border-bottom: 1px solid #333;\r\n  padding: 0 15px;\r\n}\r\n\r\n.user-avatar {\r\n  margin-right: 10px;\r\n}\r\n\r\n.user-name {\r\n  margin-right: 10px;\r\n}\r\n\r\n.submit-date {\r\n  margin-left: auto;\r\n}\r\n\r\n.user-data {\r\n  padding: 15px;\r\n}\r\n\r\n.comment-form {\r\n  width: 100%;\r\n  display: flex;\r\n  flex-direction: column;\r\n  align-items: center;\r\n  margin-bottom: 20px;\r\n}\r\n\r\nform {\r\n  width: 100%;\r\n  max-width: 600px;\r\n  display: flex;\r\n  flex-direction: column;\r\n  gap: 15px;\r\n}\r\n\r\ninput,\r\n#submitBtn {\r\n  border: 2px solid #333;\r\n  text-align: justify;\r\n  border-radius: 5px;\r\n  font-size: 1.2rem;\r\n  color: #fff;\r\n  background: #010409;\r\n  padding: 8px 15px;\r\n  /* stylelint-disable-next-line */\r\n  color-scheme: dark;\r\n}\r\n\r\n#submitBtn {\r\n  width: fit-content;\r\n  padding: 10px 20px;\r\n  background: #ff7b00;\r\n  color: #fff;\r\n  border: none;\r\n}\r\n\r\ntextarea {\r\n  resize: none;\r\n  height: 100px;\r\n  padding: 10px 20px;\r\n  border: 2px solid #333;\r\n  border-radius: 5px;\r\n  font-size: 1.2rem;\r\n  background: #010409;\r\n  color: #fff;\r\n}\r\n\r\nbutton {\r\n  cursor: pointer;\r\n}\r\n\r\n.reservation-section {\r\n  display: flex;\r\n  flex-direction: column;\r\n  align-items: center;\r\n}\r\n\r\n.reservation-title {\r\n  text-align: center;\r\n  margin: 10px 0;\r\n  font-weight: normal;\r\n}\r\n\r\n.reservation-group {\r\n  width: 100%;\r\n  max-width: 600px;\r\n  display: flex;\r\n  align-items: center;\r\n  flex-direction: column;\r\n  list-style: none;\r\n  padding: 0;\r\n  margin: 0;\r\n  gap: 15px;\r\n}\r\n\r\n.reservation-item {\r\n  width: 100%;\r\n  margin: 5px;\r\n  border: 1px solid #333;\r\n}\r\n\r\n.reservation-form {\r\n  width: 100%;\r\n  display: flex;\r\n  flex-direction: column;\r\n  align-items: center;\r\n  margin-bottom: 25px;\r\n}\r\n\r\n@media screen and (min-width: 768px) {\r\n  .mobile-nav-group {\r\n    display: none;\r\n  }\r\n\r\n  .desktop-nav-group {\r\n    display: flex;\r\n    list-style: none;\r\n    gap: 10px;\r\n  }\r\n\r\n  .nav-menu {\r\n    display: none;\r\n  }\r\n\r\n  /* Main content css start from here */\r\n  .show-group {\r\n    flex-direction: row;\r\n    flex-wrap: wrap;\r\n  }\r\n\r\n  .show-item {\r\n    width: 31%;\r\n  }\r\n\r\n  /* popup modal css */\r\n  .card-des {\r\n    padding: 0 5%;\r\n  }\r\n}\r\n"],"names":[],"sourceRoot":""}*/ -------------------------------------------------------------------------------- /dist/index.html: -------------------------------------------------------------------------------- 1 |No Data Found
'; 128 | } 129 | }; 130 | 131 | const fetchTvShows = async () => { 132 | const response = await fetch(MOVIE_API); 133 | const result = await response.json(); 134 | 135 | // call the Involment api to get likes 136 | const responseInvolvement = await fetch(`${BASE_URL}/likes/`); 137 | const likesResult = await responseInvolvement.json(); 138 | 139 | // Distribute likes with correct array. 140 | let joinArr = []; 141 | if (!(likesResult.length <= 0)) { 142 | joinArr = result.map((movieItem) => { 143 | let likes = 0; 144 | const findLikes = likesResult.find((likeItem) => likeItem.item_id === movieItem.id); 145 | if (findLikes) { 146 | likes = findLikes.likes; 147 | } 148 | return { ...movieItem, likes }; 149 | }); 150 | } 151 | 152 | // call render function to display the item list 153 | render(joinArr); 154 | }; 155 | 156 | export default fetchTvShows; 157 | -------------------------------------------------------------------------------- /src/modules/domSelector.js: -------------------------------------------------------------------------------- 1 | export const menuBtn = document.getElementById('mobile-menu'); 2 | export const closeBtn = document.getElementById('cross-menu'); 3 | export const mobileNavlinks = document.querySelectorAll( 4 | '.mobile-nav-group .nav-link', 5 | ); 6 | export const mobNavGroup = document.querySelector('.mobile-nav-group'); 7 | export const modalContainer = document.querySelector('.popup-modal'); 8 | export const listItemsContainer = document.querySelector('.show-group'); 9 | export const itemCountContainer = document.getElementById('count_item'); 10 | -------------------------------------------------------------------------------- /src/modules/itemCounter.js: -------------------------------------------------------------------------------- 1 | const itemCounter = (countContainer, itemContainer) => { 2 | const count = itemContainer.childElementCount; 3 | countContainer.innerText = `(${count})`; 4 | return count; 5 | }; 6 | 7 | export default itemCounter; 8 | -------------------------------------------------------------------------------- /src/modules/popupComment.js: -------------------------------------------------------------------------------- 1 | import { BASE_URL } from './apiUrls.js'; 2 | import commentCounter from './commentCounter.js'; 3 | import { modalContainer } from './domSelector.js'; 4 | 5 | const createNewComment = async (url, data, commentsContainer, Form) => { 6 | const response = await fetch(url, { 7 | method: 'POST', 8 | headers: { 9 | 'Content-Type': 'application/json', 10 | }, 11 | body: JSON.stringify(data), 12 | }); 13 | 14 | if (!response.ok && response.status !== 201) { 15 | return; 16 | } 17 | 18 | const fetchComUrl = `${BASE_URL}/comments?item_id=${data.item_id}`; 19 | 20 | const commentResponse = await fetch(fetchComUrl); 21 | 22 | const result = await commentResponse.json(); 23 | 24 | // manupulate the dom 25 | const commentTite = document.createElement('div'); 26 | commentTite.className = 'comment-title'; 27 | const commentHeader = document.createElement('h3'); 28 | commentHeader.className = 'comment-header'; 29 | commentHeader.innerHTML = 'Comments'; 30 | const commentCount = document.createElement('p'); 31 | commentCount.id = 'show_comment_count'; 32 | commentCount.innerText = 0; 33 | 34 | commentTite.append(commentHeader, commentCount); 35 | 36 | const commentGroup = document.createElement('ul'); 37 | commentGroup.className = 'comment-goup'; 38 | 39 | let commentItems = ''; 40 | 41 | if (result.length > 0) { 42 | result.forEach((item) => { 43 | commentItems += `${item.comment}
52 |${item.comment}
139 |