Game "Are you sure?"

HTML
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <meta http-equiv="X-UA-Compatible" content="ie=edge" /> <title>Are you sure?</title> <link rel="stylesheet" href="css/style.css" /> <script defer src="js/main.js"></script> </head> <body> <div id="wrap" class="stuf"> <div id="head"> <h1>Are you sure?</h1> </div> <div id="wimg"> <span id="stat"></span> <div id="imag"></div> <div id="ques"></div> <span id="seco"></span> </div> <div id="main"></div> <div id="dots"></div> <div id="mess" class="stuf"> <div id="star"></div> <button class="btn" id="starBtn"></button> </div> </div> </body> </html>
CSS
:root { --c1: #8b434e; --c2: #bf8b93; --c3: #eba1c1; --c4: #efb9c4; --c5: #f7d5dd; --Display: none; --BRadius: 10px; --BShadowS: 0 0 0 1px; --BShadowC1: var(--c5); --BShadowC2: var(--c2); --BShadowC3: var(--c1); --BShadowC4: 0 0 2px 2px rgba(0, 0, 0, 0.8); --Binset: inset; --H1color: var(--c5); --BgColor1: var(--c1); --BgColor2: var(--c4); --BtnHover: var(--c3); --BtnHoCol: var(--c1); --colorYE: #44ff00; --colorYD: #248400; --colorNo: #f45f77; } * { box-sizing: border-box; margin: 0; padding: 0; } html, body { height: 100%; } body { font: 16px/1.5 "Segoe UI", Tahoma, Geneva, Verdana, sans-serif; overflow-x: hidden; background: url(""), radial-gradient( ellipse farthest-side at center center, #822f5a 3%, #5a0732 41%, #000 100% ); } h1, #seco, #stat { font-size: 1.5em; text-align: center; font-weight: 900; color: var(--c4); display: block; letter-spacing: 0.1em; text-shadow: 0 -1px 0 #eee, 0 1px 0 #333; z-index: 2; } #seco, #stat { color: var(--c1); margin: 0.5em; max-width: 100px; } .stuf { background: linear-gradient(to top, var(--c1) 0%, var(--c3) 100%); } @keyframes antianim { 0% { background-position: 0 0; } 100% { background-position: 500px 1000px; } } #wrap { width: 100%; min-height: -webkit-max-content; min-height: -moz-max-content; min-height: max-content; display: block; position: relative; margin: 0 auto; overflow-x: hidden; height: 100%; box-shadow: var(--BShadowS) var(--BShadowC1) var(--Binset), var(--BShadowS) var(--BShadowC2) var(--Binset), var(--BShadowS) var(--BShadowC3), var(--BShadowC4); } #wimg { margin: 0 auto; min-height: 30%; position: relative; overflow: hidden; box-shadow: 0 0 0 1px #fff inset; box-shadow: var(--BShadowS) var(--BShadowC1) var(--Binset), var(--BShadowS) var(--BShadowC2) var(--Binset), var(--BShadowS) var(--BShadowC3); will-change: background-image; image-rendering: crisp-edges; background: linear-gradient(to top, var(--c1) 0%, var(--c3) 100%); width: 100%; display: flex; justify-content: space-between; } #chip { fill: #02d002 !important; color: #104600; } #imag { position: absolute; bottom: 0; overflow: hidden; display: block; min-height: 100%; height: 100%; width: 100%; background-image: url("data:image/svg+xml,%3Csvg width='92.604mm' height='105.83mm' version='1.1' viewBox='0 0 92.604 105.83' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath id='chip' d='m25.886 7.7881e-4c-16.845 0.13018-32.668 16.548-22.878 26.515 59.887 0-3.3936 61.583 29.042 79.317h35.76c0.9475-1.1858-0.04524-2.5285-1.0727-3.4475-0.71948-0.65522-1.5249-1.2492-2.3373-1.8272 5.6894-22.464 3.5565-26.372 7.5658-24.622 2.0623 0.90068 5.1204 0.51172 6.8422-0.9467 1.3892-1.4963-0.35638-3.269-1.7275-4.3167-1.1061-0.92679-2.8808-1.4003-3.5343-2.594-1.288-2.3528-1.8011-5.3223-0.80133-7.7718 1.5961-3.9102 3.9936-6.4123 7.7118-9.1262 3.8024-2.7756 7.1358-2.1481 11.205-6.0495 2.7747-3.7133-1.2573-5.9538-3.2673-8.0837-3.5311-3.7416-14.022-6.7395-14.022-6.7395-0.82182-3.8942-4.9241-2.8911-5.4427 0.45396-4.3243-4.1815-8.6658-3.185-8.2872 2.2434 0.56482 2.1829-2.0211 8.9155-5.7812 12.552-5.1694 6.6425-11.446 12.141-16.632 18.811-1.6454 1.9896-3.0142 3.8596-4.1537 5.6269-0.99747 0.36557-1.2887 0.04843-0.40675-1.5068 3.8935-6.8659 29.297-41.243 9.7339-61.16-5.1964-5.2905-11.423-7.3746-17.515-7.3275zm49.208 36.16c0.70077-0.0042 1.4739 0.08918 2.2696 0.27464 6.1164 2.2537 3.0369 4.9386-1.2308 4.0038-4.0654-0.74682-5.1689-4.2217-1.0388-4.2785z' color='%23000000' fill='%23f7d5dd' stroke-width='.092389' style='text-indent:0;text-transform:none'/%3E%3C/svg%3E%0A"); background-size: contain; background-position: center 10px; background-repeat: no-repeat; z-index: 1; } #imag img { max-height: 100%; max-width: 100%; overflow: hidden; margin: 0 auto; position: relative; display: block; height: 100%; -o-object-fit: cover; object-fit: cover; image-rendering: crisp-edges; } #ques { min-height: 1em; background: var(--BtnHover); text-align: center; font-weight: 700; color: var(--BtnHoCol); position: absolute; bottom: 0; display: block; width: 100%; box-shadow: var(--BShadowS) var(--BShadowC1) var(--Binset), var(--BShadowS) var(--BShadowC2) var(--Binset), var(--BShadowS) var(--BShadowC3); z-index: 1; padding: 0 0.5em; } #main { position: relative; display: -ms-grid; display: grid; grid-template-columns: repeat(1, 1fr); -webkit-align-content: center; -ms-flex-line-pack: center; align-content: center; -webkit-box-align: center; -webkit-align-items: center; -ms-flex-align: center; align-items: center; padding: 1em; gap: 1em; overflow: hidden; } #mess { height: 240px; width: 300px; display: block; position: absolute; text-align: center; left: 50%; top: 50%; -webkit-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); transform: translate(-50%, -50%); -webkit-border-radius: var(--BRadius); border-radius: var(--BRadius); box-shadow: var(--BShadowS) var(--BShadowC1) var(--Binset), var(--BShadowS) var(--BShadowC2) var(--Binset), var(--BShadowS) var(--BShadowC3); z-index: 9; } #star { display: inline-block; position: relative; padding: 2em; color: #eee; font-weight: inherit; } #starBtn { width: 10em; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); text-transform: uppercase; } .tips { will-change: transform, background-color; text-transform: uppercase; } .tips:before { text-align: center; position: absolute; left: 0; top: 0; display: inline-block; font-size: inherit; padding: 1em; border-radius: var(--BRadius); box-sizing: border-box; box-shadow: inherit; } .tips.sele.nno { background-color: #ff724b; } .tips:not(.sele).yyes { -webkit-animation: backgrnd 0.2s alternate infinite; animation: backgrnd 0.2s alternate infinite; } .btn.tips.sele.yyes { background-color: #d8f546; } @-webkit-keyframes backgrnd { 0% { background-color: #003a00; } 100% { background-color: #d8f546; } } @keyframes backgrnd { 0% { background-color: #003a00; } 100% { background-color: #d8f546; } } .tips:nth-of-type(odd).trans { transform: translateX(-122%); } .tips:nth-of-type(even).trans { transform: translateX(122%); } .tips:nth-of-type(1):before { content: "A"; } .tips:nth-of-type(2):before { content: "B"; } .tips:nth-of-type(3):before { content: "C"; } .tips:nth-of-type(4):before { content: "D"; } .tips:nth-of-type(5):before { content: "E"; } .tips:nth-of-type(6):before { content: "F"; } .tips:nth-of-type(7):before { content: "G"; } .tips:nth-of-type(8):before { content: "H"; } .tips:nth-of-type(1) { transition: transform 1s linear 0.6s, 0.2s; } .tips:nth-of-type(2) { transition: transform 1s linear 0.6s, 0.3s; } .tips:nth-of-type(3) { transition: transform 1s linear 0.6s, 0.4s; } .tips:nth-of-type(4) { transition: transform 1s linear 0.6s, 0.5s; } .tips:nth-of-type(5) { transition: transform 1s linear 0.6s, 0.2s; } .tips:nth-of-type(6) { transition: transform 1s linear 0.6s, 0.3s; } .tips:nth-of-type(7) { transition: transform 1s linear 0.6s, 0.4s; } .tips:nth-of-type(8) { transition: transform 1s linear 0.6s, 0.5s; } #mess.hide { opacity: 0; z-index: -1; } .btn { color: var(--BtnHoCol); background: var(--BtnHover); font-weight: 900; cursor: pointer; position: relative; display: inline-block; box-shadow: var(--BShadowS) var(--BShadowC1) var(--Binset), var(--BShadowS) var(--BShadowC2) var(--Binset), var(--BShadowS) var(--BShadowC3); -webkit-border-radius: var(--BRadius); border-radius: var(--BRadius); overflow: hidden; padding: 1em; -webkit-touch-callout: none; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; -webkit-appearance: none; -moz-appearance: none; border: 0; text-decoration: none; text-shadow: 0px 1px 0px #eee; } .btn:hover:enabled, .btn:focus:enabled { background: linear-gradient(to top, var(--c1) 0%, var(--c3) 100%); color: var(--c5); text-shadow: 0px 1px 0px #333, 0px 1px 10px #fff; } .btn:focus { outline: 0; } .btn:active:enabled { transform: scale(0.99); } .btn::-moz-focus-inner { border: 0; } .btn { -webkit-tap-highlight-color: rgba(0, 0, 0, 0); -webkit-tap-highlight-color: transparent; } @media screen and (min-width: 768px) { #wrap { width: 700px; min-width: 450px; } #main { grid-template-columns: repeat(2, 1fr); } }
JAVASCRIPT
(function() { "use strict"; //ALL QUESTIONS arr const questions = [ { id: 1, que: "IC chips used in computers are usually made of:", yes: 1, ch1: "Lead", ch2: "Silicon", ch3: "Chromium", ch4: "Potato" }, { id: 2, que: "WWW stands for ?", yes: 0, ch1: "World Wide Web", ch2: "Chipmunk", ch3: "Children", ch4: "Wide World Web" }, { id: 3, que: "If a computer has more than one processor then it is known as ?", yes: 0, ch1: "Multiprocessor", ch2: "Silicon", ch3: "Brouhaha", ch4: "Doozy" }, { id: 4, que: "Full form of URL is ?", yes: 1, ch1: "Multiprocessor", ch2: "Uniform Resource Locator", ch3: "Snollygoster", ch4: "Uniform Registered Link" }, { id: 5, que: "What is the Italian word for pie? ", yes: 2, ch1: "Comeuppance", ch2: "Cakes", ch3: "Pizza", ch4: "Jazz" }, { id: 6, que: "Which Russian town suffered an infamous nuclear disaster in 1986? ", yes: 1, ch1: "Donnybrook", ch2: "Chernobyl", ch3: "Pinocchio", ch4: "Nincompoop" }, { id: 8, que: "What do you see in this picture?", img: "https://i.ibb.co/1f0hNdv/car1920x1080.png", yes: 2, ch1: "fish", ch2: "direction", ch3: "Car", ch4: "umbrella", ch5: "something", ch6: "Interesting" }, { id: 9, que: "Second generation of computers consist of which of following ?", yes: 1, ch1: "Speedy Gonzalez", ch2: "Transistors", ch3: "Vaccum Tubes", ch4: "Diodes" }, { id: 10, que: "MPG is an file extension of which type of files ?", yes: 3, ch1: "Image", ch2: "Audio", ch3: "Flash", ch4: "Video" } ]; let star; let starBtn; let getBody; let getMainDiv; let getImagDiv; let getQuestio; let transwer; let score = 0; let getMessage; let question = 0; let stat; let seco; let seconds = 30; let tim = 0; function CreateElem(e, className, id, text, src) { if (!this instanceof CreateElem) return new CreateElem(e, className, id); e = document.createElement(e); if (id) e.id = id; if (className) e.className = className; if (text) e.innerText = text; if (src) { e.src = src; e.setAttribute("alt", "img"); } return e; } function remElements(elementId) { let element = document.getElementById(elementId); if (element) { if (element.children.length) { while (element.firstChild) { element.removeChild(element.firstChild); } } else { element.parentNode.removeChild(element); } } return; } function inits() { getBody = document.getElementsByTagName("body")[0]; //GET ELEMS <body> getMainDiv = document.getElementById("main"); //GET ELEMS #main getImagDiv = document.getElementById("imag"); //GET ELEMS #imag getQuestio = document.getElementById("ques"); //GET ELEMS #ques getMessage = document.getElementById("mess"); //GET ELEMS #mess starBtn = document.getElementById("starBtn"); //GET ELEMS #starBtn star = document.getElementById("star"); //GET ELEMS #star stat = document.getElementById("stat"); //GET ELEMS #stat seco = document.getElementById("seco"); getMainDiv.addEventListener("mouseup", loopElems); } function loded() { getBody.className = ""; starBtn.innerHTML = "start"; starBtn.addEventListener("click", start); [question, score] = [+readValue()[0], +readValue()[1]]; updateStat(); if (question > 0) starBtn.innerText = "continue"; } function addQuestions(question) { const { id, que, img, yes, ...rest } = questions[question]; //destructure variables const answer = Object.keys(rest)[yes]; //the real answer variable transwer = answer; if (typeof img !== "undefined") { let imgSrc; if (img.indexOf("href") !== -1) { imgSrc = "img/" + (img || "d.png"); } else { imgSrc = img; } let im = new CreateElem("img", "img", "img", "", imgSrc); getImagDiv.appendChild(im); } let qu = new CreateElem("span", "q", "q", que); let lenthOfRes = Object.keys(rest).length; let ans = []; for (let i = 0; i < lenthOfRes; i++) { ans.push( new CreateElem( "button", "btn tips trans", Object.keys(rest)[i], rest[Object.keys(rest)[i]] ) ); } ans.map(el => getMainDiv.appendChild(el)); getQuestio.appendChild(qu); } function show() { let elems = [...document.getElementsByClassName("tips")]; for (let i = elems.length - 1; i >= 0; i--) { elems[i].classList.toggle("trans"); } } function updateStat() { let va = question; stat.innerText = va + 1 + "/" + questions.length; } function start() { addQuestions(question); setTimeout(show, 500); hide.call(mess); countdown(); updateStat(); } function loopElems(elem) { clearTimeout(tim); if (!elem.target.classList.contains("tips")) return; sele.call(elem.target); const getAllansw = [...document.getElementsByClassName("tips")]; getAllansw.forEach(element => { if (element.id !== transwer) { nno.call(element); } else { yyes.call(element); } element.disabled = true; element.style.pointerEvents = "none"; }); let elems = document.getElementById("id" + question); if (elem.target.id === transwer) { sele.bind(elems); score++; } else { nno.bind(elems); } nextQuest(); } function nextQuest() { window.navigator.vibrate(30); seconds = 30; question++; if (question < questions.length) createItem(question, score); setTimeout(() => { show(); setTimeout(() => { remElements("img"); remElements("q"); remElements("main"); if (question === questions.length) { question = 0; star.innerText = "Your score: " + score + "/" + questions.length; if (questions.length === score) { star.innerText += "\nvictory"; starBtn.innerText = "Repeat"; } else { starBtn.innerText = "Improve"; } getMessage.classList.remove("hide"); score = 0; createItem(question, score); } if (question > 0) start(); }, 0); }, 1500); } function hide() { this.classList.add("hide"); } function sele() { this.classList.add("sele"); } function yyes() { this.classList.add("yyes"); } function nno() { if (typeof this !== "undefined") { this.classList.add("nno"); } } function createItem(q, s) { if (storageAvailable("localStorage")) { localStorage.setItem("valueOfWhoDaHelQuestion", q); localStorage.setItem("valueOfWhoDaHelTrueAnsw", s); } else console.log("No localstorage"); } function readValue() { if (storageAvailable("localStorage")) { let x = localStorage.getItem("valueOfWhoDaHelQuestion"); let a = localStorage.getItem("valueOfWhoDaHelTrueAnsw"); return [x, a]; } else console.log("No localstorage"); } function storageAvailable(type) { try { var storage = window[type], x = "__storage_test__"; storage.setItem(x, x); storage.removeItem(x); return true; } catch (e) { return false; } } function countdown() { seco.innerText = seconds; if (seconds-- > 0) { tim = setTimeout(() => { countdown(); }, 1000); } else { nextQuest(); clearTimeout(tim); } } document.addEventListener("DOMContentLoaded", inits); window.addEventListener("load", loded); })();
Expand for more options Login