From 2995d1031c4214a1a2ac7c0ac55ee05cf020de2a Mon Sep 17 00:00:00 2001 From: Neeraj Date: Mon, 22 Jan 2024 01:36:48 +0530 Subject: [PATCH 1/7] [ISSUE - 219] Add a Drag & Drop Feature and Redesign of the Upload Section This pull request addresses issue #219 by introducing a Drag & Drop feature, providing users with a seamless and interactive way to upload content. Additionally, the Upload Section has undergone a redesign to improve its visual appeal and usability. --- assets/main.css | 260 +++++++++++++++++++++++++++++++++++++++-------- assets/main.html | 27 ++--- assets/main.js | 177 ++++++++++++++++++++++++-------- 3 files changed, 365 insertions(+), 99 deletions(-) diff --git a/assets/main.css b/assets/main.css index 6f5e22c..99f60ab 100644 --- a/assets/main.css +++ b/assets/main.css @@ -503,78 +503,248 @@ img { object-fit: contain; } -/* Upload section */ +/* ----------------- Upload section ------------------- */ -.upload-edible-section { +.container-upload { + display: flex; + flex-direction: column; + align-items: center; + justify-content: center; margin-bottom: 100px !important; } -.upload-edible-btn { +.uploadzone { display: flex; align-items: center; justify-content: center; + padding-top: 0.1px; + padding-bottom: 0.1em; } -.upload-edible-btn h5 { - margin-top: 0rem !important; +.wrapper { + width: 498px; + background-color: #fff; + border-radius: 16px; + backdrop-filter: blur(8.5px); + -webkit-backdrop-filter: blur(8.5px); + border: 3px solid var(--primary); + padding: 30px; } -.upload-btn { +.wrapper .dragDrop { + height: 210px; display: flex; - flex-direction: column; + cursor: pointer; align-items: center; justify-content: center; - position: relative; - padding-left: 5px; - padding-right: 5px; - width: 20vw !important; - height: auto !important; + flex-direction: column; + border-radius: 5px; + border: 0.23rem dashed #000; } -.upload-btn:hover { - background-color: var(--block); - transform: scale(1); +form :where(i, p) { + color: #000; } -.upload-btn img { - margin-top: 1rem; - width: 120px !important; - height: 120px !important; - object-fit: contain; +form i { + font-size: 50px; + color: var(--block); } -#choose-edible { - background-color: var(--c); - font-size: small; - color: white; - padding: 0.5rem; - font-family: sans-serif; - border-radius: 0.3rem; - margin-top: 1rem; - margin-bottom: 0.25rem; +form p { + margin-top: 15px; + font-size: 18px; + color: #000; } -#choose-edible:hover { - transform: scale(1.1); - transition: all 0.3s ease; +/* Animation - Optional */ +@keyframes fadeIn { + from { + opacity: 0; + } + + to { + opacity: 1; + } } -#choose-uploaded-edible { - background-color: #4CAF50; - font-size: small; - color: white; - padding: 0.5rem; - padding-left: 1rem; - padding-right: 1rem; +.styled-url-input, +.submit-button { + animation: fadeIn 1s ease; +} + +section .row-upload { + margin-bottom: 10px; + background: #e9f0ff; + list-style: none; + padding: 15px 20px; + border-radius: 5px; + display: flex; + align-items: center; + justify-content: space-between; +} + +section .row-upload i { + color: #000; + font-size: 30px; +} + +section .details-upload span { + font-size: 14px; +} + +.content-upload .progress-bar .progress { + height: 100%; + width: 0%; + background: #000; + border-radius: inherit; +} + +.name{ + font-size: 14px; + font-weight: 600; + color: #000; +} + +.uploaded-area { + max-height: 232px; + overflow-y: scroll; +} + +.uploaded-area.onprogress { + max-height: 150px; +} + +.uploaded-area::-webkit-scrollbar { + width: 0px; +} + +.uploaded-area .row-upload .content-upload { + display: flex; + align-items: center; +} + +.uploaded-area .row-upload .details-upload { + display: flex; + margin-left: 15px; + flex-direction: column; +} + +.uploaded-area .row-upload .details-upload .size { + color: #404040; + font-size: 12px; +} + +.uploaded-area i.fa-check { + font-size: 16px; +} + +.uploaded-area .file-preview{ + width: 50px; + height: 50px; + margin-right: 15px; + background-size: cover; + background-position: center; +} + +#upload-btn{ + display: none; border: none; - font-family: sans-serif; - border-radius: 0.3rem; + margin-top: 1rem; + color: white; + padding: .5em 1.5em; + text-align: center; + text-decoration: none; + font-size: 18px; + cursor:none; + background-color: var(--block); + border-radius: 0.5em; + scale: 1; + transition: scale .3s ease-in-out; } -#choose-uploaded-edible:hover { - background-color: #3e8e41; - transform: scale(1.1); - transition: all 0.3s ease; +#upload-btn:hover{ + scale: 1.05; +} + +#upload-btn:active{ + scale: 0.95; +} + +#snackbar { + visibility: hidden; + min-width: 250px; + background-color: rgba(255, 255, 255, 0.5); + border-radius: 16px; + box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1); + backdrop-filter: blur(8.5px); + -webkit-backdrop-filter: blur(8.5px); + border: 1px solid rgba(97, 97, 97, 0.11); + color: #000; + text-align: center; + padding: 16px; + position: fixed; + left: 50%; + transform: translate(-50%, 0); + z-index: 1; + bottom: 30px; + font-size: 17px; +} + +#snackbar.show { + visibility: visible; + -webkit-animation: fadein 0.5s, fadeout 0.5s 2.5s; + animation: fadein 0.5s, fadeout 0.5s 2.5s; +} + + +/* Animations for Toast Message */ +@-webkit-keyframes fadein { + from { + bottom: 0; + opacity: 0; + } + + to { + bottom: 30px; + opacity: 1; + } +} + +@keyframes fadein { + from { + bottom: 0; + opacity: 0; + } + + to { + bottom: 30px; + opacity: 1; + } +} + +@-webkit-keyframes fadeout { + from { + bottom: 30px; + opacity: 1; + } + + to { + bottom: 0; + opacity: 0; + } +} + +@keyframes fadeout { + from { + bottom: 30px; + opacity: 1; + } + + to { + bottom: 0; + opacity: 0; + } } @media (max-width: 768px) { diff --git a/assets/main.html b/assets/main.html index ea49cd5..d3a1461 100644 --- a/assets/main.html +++ b/assets/main.html @@ -410,21 +410,24 @@

OR

- -
-
-

Didn't find your favourite Edible ?

-

Upload your Edible to continue....

-
-
- Uploaded Edible - - - +
+

Didn't find your favourite Edible ?

+

Upload your Edible to continue....

+
+
+
+
+ + +

Click Or Drag and Drop File to Upload

+
+
-
(Make sure that your image has a transparent background)
+
+ +
(Make sure that your image has a transparent background)
diff --git a/assets/main.js b/assets/main.js index 7d392ac..e912c24 100644 --- a/assets/main.js +++ b/assets/main.js @@ -206,53 +206,146 @@ start_btn.addEventListener("click", function () { head.style.display = "flex"; }); -// --------------- uploading image ---------------- -const input = document.getElementById('file-upload'); -const previewPhoto = () => { - const file = input.files; - if (file) { - const fileReader = new FileReader(); - const preview = document.getElementById('file-preview'); - fileReader.onload = event => { - preview.setAttribute('src', event.target.result); - const play_on_upload_btn = document.querySelector('.upload-btn').querySelector('button'); - play_on_upload_btn.style.display = 'block'; - } - fileReader.readAsDataURL(file[0]); +// --------------- Uploading Image Start ---------------- + +const form = document.querySelector("form"); +const dropArea = document.querySelector(".drag-area"); +const fileInput = document.querySelector(".file-input"); +const progressArea = document.querySelector(".progress-area"); +const uploadedArea = document.querySelector(".uploaded-area"); + +const allowed_EXT = /\.(jpg|jpeg|png)$/i; + +const files_name_upload = []; + +const dragForm = document.querySelector("#drag-form"); +const dragText = document.querySelector("#drag_text"); +const dragCloud = document.querySelector("#drag-cloud"); +const dragInput = document.querySelector("#file-input"); +const dragZone = document.querySelector("#drag-area"); +const dragWarper = document.querySelector("#drag-warper"); + +// Displays the Warning message +function showToast(s, c) { + var x = document.querySelector("#snackbar"); + var text = document.createTextNode(s); + x.style.backgroundColor = c; + x.textContent = ""; + x.appendChild(text); + x.className = "show"; + setTimeout(function () { + x.className = x.className.replace("show", ""); + }, 3000); +} + +// Form click event +form.addEventListener("click", () => { + fileInput.click(); +}); + +fileInput.onchange = ({ target }) => { + let file = target.files; + if (file.length === 1) { + if (!allowed_EXT.exec(file[0].name)) { + showToast("Only Image files are allowed", "#fff"); + } else { + if (!files_name_upload.includes(file[0].name)) { + files_name_upload.push(file[0].name); + uploadFile(file[0].name); + } } + } else { + showToast("Multiple file uploading is forbidden", "#fff"); + } +}; + +dropArea.addEventListener("dragover", (event) => { + event.preventDefault(); + dragText.textContent = "Release to Upload File"; + dragCloud.style.color = "#000"; + dragForm.style.borderColor = "#000"; + dragText.style.fontSize = "18px"; + dragText.style.color = "#000"; +}); + +dropArea.addEventListener("dragleave", () => { + dragText.textContent = "Click Or Drag and Drop File to Upload"; + dragCloud.style.color = "#000"; + dragForm.style.borderColor = "#000"; + dragText.style.fontSize = "18px"; + dragText.style.color = "#000"; +}); + +//If user drop File on DropArea +dropArea.addEventListener("drop", (event) => { + event.preventDefault(); + var all_drop_files = event.dataTransfer.files; + + if (all_drop_files.length === 1) { + if (!allowed_EXT.exec(all_drop_files[0].name)) { + showToast("Only Image files are allowed", "#fff"); + } else { + if (!files_name_upload.includes(all_drop_files[0].name)) { + files_name_upload.push(all_drop_files[0].name); + uploadFile(all_drop_files[0]); + fileInput.files = all_drop_files; + fileInput.dispatchEvent(new Event("change")); + } + } + } else { + showToast("Multiple file uploading is forbidden", "#fff"); + } + dragText.textContent = "Click Or Drag and Drop File to Upload"; + dragCloud.style.color = "#000"; + dragForm.style.borderColor = "#000"; + dragText.style.fontSize = "18px"; + dragText.style.color = "#000"; +}); + +function uploadFile(file) { + let uploadArea = document.querySelector(".uploaded-area"); + uploadArea.style.display = "block"; + uploadArea.innerHTML = ` +
  • +
    + preview +
    +

    ${typeof file === "string"?file:file.name} • Uploaded

    +
    +
    + +
  • `; } -input.addEventListener('change', previewPhoto); -// --------------- uploading image ---------------- - -choose_btns.forEach((btn) => { - if(btn.classList.contains("upload-btn")) { - btn.querySelector("button").addEventListener("click", () => { - const img = btn.querySelector("img"); - const src = img.getAttribute('src'); - const alt = img.getAttribute('alt'); - - selected_edible = { src, alt }; - screens[1].classList.add("up1"); - game_container.style.height = "100vh"; - startGame(); - displayChange(); - choose_edible.play(); - }); - return; + +const previewPhoto = () => { + const file = fileInput.files; + if (file) { + const fileReader = new FileReader(); + const preview = document.querySelector(".file-preview"); + fileReader.onload = (event) => { + preview.setAttribute("src", event.target.result); + const play_on_upload_btn = document.querySelector("#upload-btn"); + play_on_upload_btn.style.display = "block"; + }; + fileReader.readAsDataURL(file[0]); } - btn.addEventListener("click", () => { - const img = btn.querySelector("img"); - const src = img.getAttribute("src"); - const alt = img.getAttribute("alt"); - selected_edible = { src, alt }; - screens[1].classList.add("up1"); - game_container.style.height = "100vh"; - startGame(); - displayChange(); - choose_edible.play(); - }); +}; +fileInput.addEventListener("change", previewPhoto); + +document.querySelector("#upload-btn").addEventListener("click", () => { + const img = document.querySelector(".file-preview"); + const src = img.getAttribute("src"); + const alt = img.getAttribute("alt"); + selected_edible = { src, alt }; + screens[1].classList.add("up1"); + game_container.style.height = "100vh"; + startGame(); + displayChange(); + choose_edible.play(); }); +// --------------- Uploading Image End ---------------- + function chooseGameplayTime() { document.getElementById("time").style.display = "none"; document.getElementById("gameplayTime").style.display = "flex"; From fc0bedb93e41eb3b1d95930031617ca3eb904929 Mon Sep 17 00:00:00 2001 From: Neeraj Date: Mon, 22 Jan 2024 23:17:28 +0530 Subject: [PATCH 2/7] [ISSUE - 219] Added Drag & Drop Feature and Redesigned the Upload Section --- assets/main.css | 47 ++++++++++++++++++++++++----------------------- assets/main.js | 3 --- 2 files changed, 24 insertions(+), 26 deletions(-) diff --git a/assets/main.css b/assets/main.css index 99f60ab..0a0d784 100644 --- a/assets/main.css +++ b/assets/main.css @@ -616,7 +616,7 @@ section .details-upload span { } .uploaded-area::-webkit-scrollbar { - width: 0px; + display:none; } .uploaded-area .row-upload .content-upload { @@ -747,33 +747,34 @@ section .details-upload span { } } -@media (max-width: 768px) { - .upload-btn { - width: 30vw !important; - } -} +/* Responsive Upload Edible Section */ -@media screen and (max-width: 415px) { +@media (min-width: 320px) and (max-width: 450px) { .upload-btn { - width: 40vw !important; + width: 60vw !important; } -} - -@media screen and (max-width: 375px) { - .upload-btn { - width: 50vw !important; + .wrapper{ + width: 90%; + min-width: 90%; } -} - -@media screen and (max-width: 320px) { - .upload-btn { - width: 60vw !important; + .container-upload h5{ + margin-bottom: 3rem; } -} - -@media screen and (max-width: 280px) { - .upload-btn { - width: 70vw !important; + .container-upload h1{ + font-size: 1.5rem; + } + .container-upload h3{ + font-size: .7rem; + } + .name{ + font-size: 14px; + } + .uploaded-area .row-upload .details-upload{ + margin: 0; + padding: 0 10px; + } + .row-upload i{ + display:none; } } diff --git a/assets/main.js b/assets/main.js index e912c24..bcc6d61 100644 --- a/assets/main.js +++ b/assets/main.js @@ -262,7 +262,6 @@ fileInput.onchange = ({ target }) => { dropArea.addEventListener("dragover", (event) => { event.preventDefault(); dragText.textContent = "Release to Upload File"; - dragCloud.style.color = "#000"; dragForm.style.borderColor = "#000"; dragText.style.fontSize = "18px"; dragText.style.color = "#000"; @@ -270,7 +269,6 @@ dropArea.addEventListener("dragover", (event) => { dropArea.addEventListener("dragleave", () => { dragText.textContent = "Click Or Drag and Drop File to Upload"; - dragCloud.style.color = "#000"; dragForm.style.borderColor = "#000"; dragText.style.fontSize = "18px"; dragText.style.color = "#000"; @@ -296,7 +294,6 @@ dropArea.addEventListener("drop", (event) => { showToast("Multiple file uploading is forbidden", "#fff"); } dragText.textContent = "Click Or Drag and Drop File to Upload"; - dragCloud.style.color = "#000"; dragForm.style.borderColor = "#000"; dragText.style.fontSize = "18px"; dragText.style.color = "#000"; From ffa027c5fdd3f34ace22158bf830c9afeff39087 Mon Sep 17 00:00:00 2001 From: Neeraj Date: Mon, 22 Jan 2024 23:28:39 +0530 Subject: [PATCH 3/7] [ISSUE - 219] Added Drag & Drop Feature and Redesigned the Upload Section --- assets/main.js | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/assets/main.js b/assets/main.js index bcc6d61..289d138 100644 --- a/assets/main.js +++ b/assets/main.js @@ -300,6 +300,7 @@ dropArea.addEventListener("drop", (event) => { }); function uploadFile(file) { + const fileName = typeof file === "string"?file:file.name; let uploadArea = document.querySelector(".uploaded-area"); uploadArea.style.display = "block"; uploadArea.innerHTML = ` @@ -307,7 +308,7 @@ function uploadFile(file) {
    preview
    -

    ${typeof file === "string"?file:file.name} • Uploaded

    +

    ${fileName.slice(0,fileName.length>=21?21:fileName.length)+(fileName.length>=21?'...':'')} • Uploaded

    From 685a635da1a8fe42c6e52672af724979f51f2902 Mon Sep 17 00:00:00 2001 From: Neeraj Date: Sun, 28 Jan 2024 19:50:26 +0530 Subject: [PATCH 4/7] [ISSUE - 239] Redirecting to the Game Screen --- assets/main.js | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/assets/main.js b/assets/main.js index 289d138..5195c09 100644 --- a/assets/main.js +++ b/assets/main.js @@ -330,6 +330,8 @@ const previewPhoto = () => { }; fileInput.addEventListener("change", previewPhoto); +// Upload Play---- + document.querySelector("#upload-btn").addEventListener("click", () => { const img = document.querySelector(".file-preview"); const src = img.getAttribute("src"); @@ -342,6 +344,20 @@ document.querySelector("#upload-btn").addEventListener("click", () => { choose_edible.play(); }); +document.querySelectorAll(".choose-btn").forEach(button => { + button.addEventListener("click", () => { + const img = button.querySelector("img"); + const src = img.getAttribute("src"); + const alt = img.getAttribute("alt"); + selected_edible = { src, alt }; + screens[1].classList.add("up1"); + game_container.style.height = "100vh"; + startGame(); + displayChange(); + choose_edible.play(); + }); +}); + // --------------- Uploading Image End ---------------- function chooseGameplayTime() { From 3297cff62129351245a54f5ae52b9573549e9e62 Mon Sep 17 00:00:00 2001 From: Neeraj Date: Mon, 5 Feb 2024 22:51:27 +0530 Subject: [PATCH 5/7] [ISSUE - 200] Add transition for the instruction box --- assets/main.css | 138 ++++++++++++++++++++++++++++------------------- assets/main.html | 17 +++--- assets/main.js | 22 +++++--- 3 files changed, 106 insertions(+), 71 deletions(-) diff --git a/assets/main.css b/assets/main.css index d589c4b..7f47d0f 100644 --- a/assets/main.css +++ b/assets/main.css @@ -244,58 +244,93 @@ h3 { align-items: center; } -#instructions, -#instructions2, -#instructions3 { - border: 0.3em solid goldenrod; - background-color: #eaf9d9; - border-radius: 0.5em; + +.instruction-close-btn { + position: absolute; + top: 10px; + right: 10px; + background: none; + border: none; + font-size: 1.5rem; + color: #ff0000; +} + +.instruction-heading{ + box-shadow: inset 0 0 10px 0 #fff; + border-radius: .5rem; + margin: 0 1.5rem; +} + +#instructions { + border-radius: 1rem; position: absolute; z-index: 9; - padding: 0 1rem; - font-family: 'Times New Roman', Times, serif; + padding: 2rem; font-weight: bold; display: none; width: 60vw; margin-bottom: 7rem; margin-top: 1.6rem; - height: 83vh; + height: 85vh; color: #ff1251; flex-direction: column; justify-content: center; - transition: all 0.5s ease-in-out; - animation-name: scaleMenu; - animation-duration: 3s; - animation-iteration-count: 1; - transform: scale(1); overflow-y: auto; overflow-x: none; } -.instruction-heading { - margin-top: 2.5rem; +.abc{ + display: none; + position: fixed; + bottom: 0; + left: 50%; + transform: translateX(-50%); + background-color: #fff; + padding: 20px; + box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1); + animation-duration: 0.5s; + animation-fill-mode: both; } -#instructions ol, -#instructions2 ol, -#instructions3 ol { - margin-top: 0; - margin-bottom: 0; +@keyframes fadeUp { + from { + opacity: 0; + transform: translate(-50%, 100%); + } + to { + opacity: 1; + transform: translate(-50%, 5%); + } } -#instructions ol li, -#instructions2 ol li, -#instructions3 ol li { - text-align: left; - font-weight: 300; +@keyframes fadeDown { + from { + opacity: 1; + transform: translate(-50%, 0); + } + to { + opacity: 0; + transform: translate(-50%, 100%); + } } -li { - margin-top: 10px; +.abc.fade-up { + animation-name: fadeUp; +} + +.abc.fade-down { + animation-name: fadeDown; +} + +.abc ul li{ + text-align: left; + margin-top: 1rem; + font-size: 14px; + list-style:decimal-leading-zero; } span { - position: absolute; + position: absolute; width: 25%; height: 100%; background-color: var(--c); @@ -1482,10 +1517,11 @@ h1 { } /* Additional styling for icons if needed */ -#instructions, -#instructions2, -#instructions3 { - background: linear-gradient(to bottom, #001325, #014588, #0073a1, #07778d); +#instructions { + background: rgba(0, 0, 0, 0.8); + /* background: #fb2e90; */ + backdrop-filter: blur(10px); + box-shadow: 0 0 10px 0 #000; color: white; } @@ -1511,17 +1547,8 @@ h1 { } } -#instructions, -#instructions2, -#instructions3 { - border-width: 8px; - border-style: solid; - animation: colorfulBorder 4s infinite linear; - text-align: center; - /* height: 36em; */ -} -.xy { +/* .xy { border-width: 5px; border-style: solid; animation: colorfulBorder 2s infinite linear; @@ -1577,7 +1604,7 @@ h1 { color: black; text-align: center; } -} +} */ /* responsive instruction box */ @media screen and (max-width:1024px) { @@ -1589,7 +1616,7 @@ h1 { } .instruction-heading { - margin-top: 10rem; + margin-top: 5rem; } } @@ -1602,13 +1629,13 @@ h1 { } .instruction-heading { - margin-top: 10rem; + margin-top: 5rem; } - .xy { + /* .xy { margin-left: 30px; margin-right: 30px; - } + } */ .game-container { margin-top: 3.4rem; @@ -1617,7 +1644,10 @@ h1 { @media screen and (max-width: 676px) { .instruction-heading { - margin-top: 13rem; + margin-top: 5rem; + } + .abc ul li{ + font-size: 12px; } } @@ -1630,12 +1660,12 @@ h1 { } .instruction-heading { - margin-top: 13rem; + margin-top: 7rem; } - #instructions ol, - #instructions2 ol, - #instructions3 ol { + #instructions ul, + #instructions2 ul, + #instructions3 ul { padding: 0 6px; } } @@ -1649,7 +1679,7 @@ h1 { } .instruction-heading { - margin-top: 18rem; + margin-top: 5rem; } } diff --git a/assets/main.html b/assets/main.html index 73c040c..1170ab3 100644 --- a/assets/main.html +++ b/assets/main.html @@ -62,15 +62,14 @@

    Play with your Favourite Edible🎮

    -
    + 🥭 Alrighty, welcome to Click the Edible Game!! 🍉
    + class="instruction-heading">🥭 Alrighty, welcome to Click the Edible Game!! 🍉
    Get ready to unleash your inner produce-picking pro and show those edibles who's boss!
    - Here's how to play:
    - -
      + Here's how to play: +
      • Choose your sidekick -- Will it be Team Fruit, Vegetable, Sweet, Snack or Backery?
      • @@ -93,9 +92,9 @@

        Play with your Favourite Edible🎮

        Keep your eyes peeled and your fingers nimble because once the clock strikes zero or all the lives ❤️ are lost, the game is over and the edibles will dance away. -

    +
    -
    Ready to squash the competition?

    +
    Ready to squash the competition?
    +
    🥭 Alrighty, welcome to Click the Edible Game!! 🍉
    + class="xy instruction-heading">🥭 Alrighty, welcome to Click the Edible Game!! 🍉
    Get ready to unleash your inner produce-picking pro and show those edibles who's boss!
    - Here's how to play: -
      + Here's how to play:
      + +
      1. Choose your sidekick -- Will it be Team Fruit, Vegetable, Sweet, Snack or Backery?
      2. @@ -92,9 +94,9 @@

        Play with your Favourite Edible🎮

        Keep your eyes peeled and your fingers nimble because once the clock strikes zero or all the lives ❤️ are lost, the game is over and the edibles will dance away. -

    +
    -
    Ready to squash the competition?
    +
    Ready to squash the competition?

    🥭 Alrighty, welcome to Click the Edible Game!! 🍉
    Get ready to unleash your inner produce-picking pro and show those edibles @@ -464,6 +465,7 @@
    (Make sure that your image has a transparent background So upload only png f

    Score: 0

    + 🥭 Alrighty, welcome to Click the Edible Game!! 🍉
    Get ready to unleash your inner produce-picking pro and show those edibles diff --git a/assets/main.js b/assets/main.js index 6fa3e11..b174929 100644 --- a/assets/main.js +++ b/assets/main.js @@ -414,19 +414,33 @@ function startGame() { function showInstructions() { var instructionsModal = document.getElementById("instructions"); + var instructionsModal2 = document.getElementById("instructions2"); + var instructionsModal3 = document.getElementById("instructions3"); instructionsModal.style.display = "flex"; + instructionsModal2.style.display = "flex"; + instructionsModal3.style.display = "flex"; // Trigger reflow to ensure the transition is applied void instructionsModal.offsetWidth; instructionsModal.classList.add("show"); + void instructionsModal2.offsetWidth; + instructionsModal2.classList.add("show"); + void instructionsModal3.offsetWidth; + instructionsModal3.classList.add("show"); pauseGame(); } function closeInstructions() { var instructionsModal = document.getElementById("instructions"); instructionsModal.classList.remove("show"); + var instructionsModal2 = document.getElementById("instructions2"); + instructionsModal2.classList.remove("show"); + var instructionsModal3 = document.getElementById("instructions3"); + instructionsModal3.classList.remove("show"); // Add a delay before hiding the instructions to allow the animation to play setTimeout(function() { instructionsModal.style.display = "none"; + instructionsModal2.style.display = "none"; + instructionsModal3.style.display = "none"; if (isRunning == 0) isRunning = 1; }, 500); // Match the duration of the animation