let fiftieth_keypress_or_clicks = false; // Flag to check if it's the first key press let imageElement = null; // To store the image element let num_keypressess_or_clicks = 0; const target_key_pressess_or_clicks = 25; const flagSong = new Audio('assets/graduation.flac'); // Replace with the actual path to your audio file function change_color(){ const random_color = `rgb(${Math.floor(Math.random()*256)},${Math.floor(Math.random()*256)},${Math.floor(Math.random()*256)})`; document.body.style.backgroundColor = random_color; } function display_keypress(key){ const keypress_element = document.createElement('div'); keypress_element.textContent = key; keypress_element.style.position = 'absolute'; keypress_element.style.bottom = '0px'; keypress_element.style.left=`${Math.floor(Math.random()*(window.innerWidth-50))}px`; keypress_element.style.fontSize = '24px'; keypress_element.style.fontWeight = 'bold'; keypress_element.style.color = 'black'; keypress_element.style.opacity = 1; keypress_element.style.zIndex = 1000; // Add that little baby child to our document 🥵 document.body.appendChild(keypress_element); const animation = keypress_element.animate([ {bottom: '0px', opacity: 1}, {bottom: `${window.innerHeight}px`, opacity: 0}, ], { duration:2000, fill: 'forwards' }); animation.onfinish = () => { keypress_element.remove(); }; } function create_or_resize_image() { if (fiftieth_keypress_or_clicks && !imageElement) { // On the first key press, create the image imageElement = document.createElement('img'); imageElement.src = ''; imageElement.style.position = 'absolute'; imageElement.style.left = '50%'; imageElement.style.bottom = '100px'; // Start just above the bottom of the screen imageElement.style.transform = 'translateX(-50%)'; // Center the image imageElement.style.transition = 'transform 0.5s ease-in-out'; // Smooth transition for scaling document.body.appendChild(imageElement); fiftieth_keypress_or_clicks = false; flagSong.play(); } else { // On subsequent key presses, increase the size of the image if (imageElement) { let currentScale = parseFloat(imageElement.style.transform.match(/scale\(([^)]+)\)/)?.[1] || 1); currentScale += 0.01; // Increase the size of the image imageElement.style.transform = `translateX(-50%) scale(${currentScale})`; } } } document.addEventListener('click', (e) => { change_color(); console.log("Number of clicks or keypressses: %s", num_keypressess_or_clicks); num_keypressess_or_clicks++; if (num_keypressess_or_clicks === target_key_pressess_or_clicks) { fiftieth_keypress_or_clicks = true; } create_or_resize_image(); }); document.addEventListener('keypress', (e) => { num_keypressess_or_clicks++; if (num_keypressess_or_clicks === target_key_pressess_or_clicks) { fiftieth_keypress_or_clicks = true; } change_color(); display_keypress(e.key); create_or_resize_image(); });