// //-FIX IMAGE RATIOS //-FIX CALENDAR //-ADD SUPPORT PAGE //archive doesn't work constanlt refreshing // var fake_date = new Date("September 19, 2022 23:58:00"); // Date = function(){return fake_date;}; // Date.now = () => fake_date.getTime(); //json sitrgifiy local objects //pre-load images //image placeholder // gameover movie name var playedBefore = false; var sameDay = false; for (var i = 0; i < localStorage.length; i++){ console.log(localStorage.key(i)); } function revealButtons(g = guessNo){ picButtons = document.getElementsByClassName('imageButton'); picButtons[g].classList.add('active'); for (var i = 0; i <= g; i++){ console.log("revealButton guess no " + guessNo); picButtons[i].style.display = "inline"; picButtons[i].classList.remove('active'); } picButtons[g].classList.add('active'); } // document.getElementById("button2").style.display = "none" // document.getElementById("button3").style.display = "none" var movies = ["A Nightmare on Elm Street","Friday the 13th","Event Horizon","Hellraiser","The Cabin in the Woods","American Psycho","It Follows","Candyman","Child's Play","The Texas Chain Saw Massacre","Alien","Halloween"]; var pix = []; // autocomplete(document.getElementById("guess"), movies); var gameBeginning = new Date('September 24, 2022 00:00:00'); var countDownTime = new Date(); var present_date = new Date(); // gameBeginning = new Date(gameBeginning.getTime() + 0 * 60 * 1000); console.log(gameBeginning.getTimezoneOffset()); dayCounter(); console.log("gameBeginning: ",gameBeginning); console.log("now: ",present_date); var textResult = "Horrordle #"+dayCount+"\nšŸ”Ŗ"; console.log(textResult); function dayCounter(){ dayCount = Math.floor((present_date - gameBeginning) / (1000 * 60 * 60 * 24)); return dayCount; } markCalendar(); function markCalendar() { dates = document.getElementsByClassName('calendar__number'); console.log(dates[10].innerHTML); var tag = []; for (var i = 0; i < dates.length; i++) { if (dates[i].innerHTML==dayCount) { dates[i].classList.add('current'); for (var j = 0; j < i; j++) { if (localStorage.getItem('day'+(j+1))) { if (localStorage.getItem('day'+(j+1))=='true') { dates[j].classList.add('won'); } else if (localStorage.getItem('day'+(j+1))=='false') { dates[j].classList.add('lost'); } }else { dates[j].classList.add('past'); dates[j] = document.createElement('a'); //dates[j].setAttribute('href','#'); if(localStorage.getItem("playedToday")){ // dates[j].setAttribute('onclick','getArchive(' + (j+1) +')'); // dates[j] = "" + dates[j] + ""; } } // dates[j] = "" + dates[j] + ""; //tag[j].appendChild(dates[j]); //console.log(tag[j]); console.log(dates[j]); } console.log(dates[i]); } } } var points = "ā¬›ā¬›ā¬›" //check if the user played this before firstCheck(); revealButtons(); function firstCheck(){ guessNo = 0; feedback.textContent = "šŸ©ø " + (3-guessNo) + " guesses remaining"; if(!localStorage.getItem('streak')){localStorage.setItem('streak',0)} if(!localStorage.getItem('firstGuessStat')){localStorage.setItem('firstGuessStat',0)} if(!localStorage.getItem('secondGuessStat')){localStorage.setItem('secondGuessStat',0)} if(!localStorage.getItem('thirdGuessStat')){localStorage.setItem('thirdGuessStat',0)} } textResult = "Horrordle #"+dayCount+"\nšŸ”Ŗ"; function clearGuess() { localStorage.removeItem('firstGuess'); localStorage.removeItem('secondGuess'); localStorage.removeItem('guessNo'); localStorage.removeItem('winningGuess'); localStorage.removeItem("playedToday"); // localStorage.removeItem('result'); document.getElementById("firstGuess").style.display = "none"; document.getElementById("secondGuess").style.display = "none"; document.getElementById("shareResult").style.display = "none"; document.getElementById("guessForm").style.display = "block"; document.getElementById("countDown").style.display = "none" } function checkingGuess() { streakNumber.textContent = localStorage.getItem('streak'); if (localStorage.getItem('day')==dayCount) { playedBefore = true; textResult=localStorage.getItem('result') console.log("played before: ",playedBefore); console.log(localStorage.getItem('firstGuess')); console.log(localStorage.getItem('secondGuess')); if(localStorage.getItem('guessNo')){guessNo=localStorage.getItem('guessNo')}; feedback.textContent = "šŸ©ø " + (3-guessNo) + " guesses remaining"; if(localStorage.getItem('result')) {localStorage.setItem('result', textResult);document.getElementById("resultText").innerHTML =textResult} if(localStorage.getItem('firstGuess')){firstGuess.textContent = "āŒ" + localStorage.getItem('firstGuess');document.getElementById("firstGuess").style.display = "block";} if(localStorage.getItem('secondGuess')){secondGuess.textContent = "āŒ" + localStorage.getItem('secondGuess');document.getElementById("secondGuess").style.display = "block";} if(localStorage.getItem('winningGuess')){revealButtons(2);document.getElementById("feedback").innerHTML = "Next movie will reveal at midnight! šŸ•›";document.getElementById("shareResult").style.display = "block";document.getElementById("countDown").style.display = "block";document.getElementById("guessForm").style.display = "none";document.getElementById("firstGuess").style.display = "none";document.getElementById("secondGuess").style.display = "none";document.getElementById("resultText").style.display="block";}else {document.getElementById("shareResult").style.display = "none";document.getElementById("guessForm").style.display = "block";document.getElementById("resultText").style.display="none";}; secondGuess.textContent = "āŒ" + localStorage.getItem('secondGuess'); revealButtons(); }else { clearGuess(); localStorage.setItem('day', dayCount); } markCalendar(); } checkingGuess(); window.onload = deathOftheDay(); // console.log(dayCount); function deathOftheDay(x=dayCount){ pix = []; movieOfTheDay = movies[x-1]; for (let i = 1; i < 4; i++) { pix.push("images/"+movieOfTheDay+"/"+i+".png"); preloadImage("images/"+movieOfTheDay+"/"+i+".png"); } console.log('Movie: ', movieOfTheDay); console.log('Array: ', pix); showPic(); // picButton = document.getElementsByClassName('picButton'); // picButton.setAttribute('onclick','getImage()'); } function showPic(p=guessNo){ document.getElementById("movieFrame").src = pix[p]; picButtons = document.getElementsByClassName('imageButton'); for (let i=0; i<3; i++){ picButtons[i].classList.remove('active'); } picButtons[p].classList.add('active'); // for (let i = 0; i < 2; i++) { // const element = array[i]; // } } function checkGuess() { console.log("day count:" + dayCount); let myGuess = guess if (myGuess === movieOfTheDay) { if(guessNo==0){localStorage.setItem('firstGuessStat',parseInt(localStorage.getItem('firstGuessStat')) + 1);} if(guessNo==1){localStorage.setItem('secondGuessStat',parseInt(localStorage.getItem('secondGuessStat')) + 1);} if(guessNo==2){localStorage.setItem('thirdGuessStat',parseInt(localStorage.getItem('thirdGuessStat')) + 1);} localStorage.setItem('streak',parseInt(localStorage.getItem('streak')) + 1); localStorage.setItem('day'+dayCount,'true'); // document.getElementById("movieFrame").src = "images/"+movieOfTheDay+"/poster.jpg"; console.log(localStorage.getItem('day'+dayCount)); streakNumber.textContent = " " + localStorage.getItem('streak'); document.getElementById("guessForm").style.display = "none"; document.getElementById("movieName").innerHTML = movieOfTheDay + " āœ…"; document.getElementById("countDown").style.display = "block"; document.getElementById("shareResult").style.display = "block"; localStorage.setItem("winningGuess", guess); localStorage.setItem("playedToday", "yes"); document.getElementById("firstGuess").style.display = "none"; document.getElementById("secondGuess").style.display = "none"; textResult = textResult + "šŸŸ©"; for (var i = 1; i < (3-guessNo); i++) { textResult = textResult + "ā¬›"; } localStorage.setItem('result', textResult); document.getElementById("feedback").innerHTML = "Next movie revealed at midnight! šŸ•›
"; document.getElementById("resultText").innerHTML = textResult; dates[dayCount-1].classList.add('won'); revealButtons(2); } else if(guessNo==1){ guessNo = guessNo + 1; localStorage.setItem('guessNo', guessNo); feedback.textContent = "šŸ©ø " + (3-guessNo) + " guesses remaining"; document.getElementById("movieFrame").src = pix[guessNo]; firstGuess.textContent = "āŒ" + guess; localStorage.setItem('firstGuess', guess); document.getElementById("firstGuess").style.display = "block"; textResult = textResult + "šŸŸ„"; localStorage.setItem('result', textResult); revealButtons(); }else if(guessNo<2){ guessNo = guessNo + 1; localStorage.setItem('guessNo', guessNo); feedback.textContent = "šŸ©ø " + (3-guessNo) + " guesses remaining"; document.getElementById("movieFrame").src = pix[guessNo]; secondGuess.textContent = "āŒ" + guess; localStorage.setItem('secondGuess', guess); document.getElementById("secondGuess").style.display = "block"; textResult = textResult + "šŸŸ„"; localStorage.setItem('result', textResult); revealButtons(); } else{ feedback.textContent = "GAME OVER"; textResult = textResult + "šŸŸ„"; localStorage.setItem('guessNo', guessNo); localStorage.setItem('streak', 0); localStorage.setItem('day'+dayCount,'false'); localStorage.setItem("playedToday", "yes"); dates[dayCount-1].classList.add('lost'); } console.log(textResult); document.getElementById("guessForm").reset(); markCalendar(); } const autoCompleteJS = new autoComplete({ placeHolder: "Search for Movies...", data: { src: movies }, resultItem: { highlight: true, }, events: { input: { selection: (event) => { const selection = event.detail.selection.value; autoCompleteJS.input.value = selection; }, open() { const position = autoCompleteJS.input.getBoundingClientRect().bottom + autoCompleteJS.list.getBoundingClientRect().height > (window.innerHeight || document.documentElement.clientHeight); if (position) { autoCompleteJS.list.style.bottom = autoCompleteJS.input.offsetHeight + 8 + "px"; } else { // autoCompleteJS.list.style.bottom = -autoCompleteJS.list.offsetHeight - 8 + "px"; } }, } } }); autoCompleteJS.input.addEventListener("selection", function (event) { const feedback = event.detail; // Prepare User's Selected Value guess = event.detail.selection.value autoCompleteJS.input.value = guess; // Console log autoComplete data feedback console.log(event.detail.selection.value); }); function copyToClipboard() { navigator.clipboard.writeText(textResult).then(() => { shareResult.value = "copied!"; // Alert the user that the action took place. // Nobody likes hidden stuff being done under the hood! }); } function getArchive(j,d = dayCount){ dates[d-1].classList.remove('current'); d = j; dates[j-1].classList.add('current'); deathOftheDay(j); document.getElementById('guess').value = ""; location.href='#'; //window.open("#"); } submitGuess.addEventListener('click', checkGuess) const labels = [ 'First Guess', 'Second Guess', 'Third Guess', ]; const data = { labels: labels, datasets: [{ label: 'Number of guesses', backgroundColor: ['red','pink','blue'], fontColor: 'white', color:'white', data: [localStorage.getItem('firstGuessStat'), localStorage.getItem('secondGuessStat'), localStorage.getItem('thirdGuessStat')], }] }; Chart.defaults.color='white' Chart.defaults.borderColor='grey' const config = { type: 'bar', data: data, options: { // maintainAspectRatio: false, scales:{ yAxes:{ ticks:{ stepSize:1 } } } } }; var x = setInterval(function() { // countDownTime.setDate(Math.floor((present_date - gameBeginning) / (1000 * 60 * 60 * 24))+2); dayCounter(); dateVariable = present_date.getDate() countDownTime.setDate(dateVariable+1); countDownTime.setHours(0); countDownTime.setMinutes(0); countDownTime.setSeconds(0); var now = new Date(); // console.log("now: ",now); var remainingTime = countDownTime - now; const second = 1000; const minute = second * 60; const hour = minute * 60; const day = hour * 24; hoursLeft = Math.trunc((remainingTime % day) / hour); minutesLeft = Math.trunc((remainingTime % hour) / minute); secondsLeft = Math.trunc((remainingTime % minute) / second); document.getElementById("countDown").innerHTML = hoursLeft + "h " + minutesLeft + "m " + secondsLeft + "s "; //console.log(remainingTime); // console.log(localStorage.getItem('day')); // console.log("day count: " + dayCount); dayCount = Math.floor((now - gameBeginning) / (1000 * 60 * 60 * 24)); if (localStorage.getItem('day')!=dayCount) { window.location.reload(); } }, 1000); const myChart = new Chart( document.getElementById('myChart'), config ); function preloadImage(url) { var img=new Image(); img.src=url; }; //window.localStorage.clear();