145 lines
4.2 KiB
JavaScript
145 lines
4.2 KiB
JavaScript
|
//--------------Flip the img tags when scrolling --------------------//
|
||
|
|
||
|
let lastScrollTop = 0;
|
||
|
|
||
|
window.addEventListener(
|
||
|
"scroll",
|
||
|
function () {
|
||
|
let st = window.pageYOffset || document.documentElement.scrollTop;
|
||
|
let elements = document.body.getElementsByTagName("img");
|
||
|
|
||
|
if (st > lastScrollTop) {
|
||
|
// downscroll
|
||
|
for (let i = 0; i < elements.length; i++) {
|
||
|
elements[i].style.transform = "scaleX(-1)";
|
||
|
}
|
||
|
} else {
|
||
|
// upscroll
|
||
|
for (let i = 0; i < elements.length; i++) {
|
||
|
elements[i].style.transform = "scaleX(1)";
|
||
|
}
|
||
|
}
|
||
|
lastScrollTop = st <= 0 ? 0 : st; // For Mobile or negative scrolling
|
||
|
},
|
||
|
false
|
||
|
);
|
||
|
//-------------------------------------------// Define the CSS for the melting animation
|
||
|
var style = document.createElement("style");
|
||
|
style.innerHTML = `
|
||
|
@keyframes melt {
|
||
|
0% { transform: translateY(0); }
|
||
|
100% { transform: translateY(100px); opacity: 0; }
|
||
|
}
|
||
|
.melting {
|
||
|
animation: melt 2s linear forwards;
|
||
|
}
|
||
|
`;
|
||
|
document.head.appendChild(style);
|
||
|
|
||
|
// Initialize an array of text element types (tags) to rotate
|
||
|
var textElementTypes = [
|
||
|
"p",
|
||
|
"h1",
|
||
|
"li",
|
||
|
"h2",
|
||
|
"span",
|
||
|
"img",
|
||
|
"h3",
|
||
|
"a",
|
||
|
"h4",
|
||
|
"div",
|
||
|
"h5",
|
||
|
"h6",
|
||
|
];
|
||
|
|
||
|
// Initialize a variable to keep track of the current text element type
|
||
|
var currentElementType = 0;
|
||
|
|
||
|
// Initialize a variable to keep track of the click count
|
||
|
var clickCountMelt = 0;
|
||
|
|
||
|
// Function to add 'melting' class to the specified text element type
|
||
|
function meltText() {
|
||
|
var elements = document.querySelectorAll(
|
||
|
textElementTypes[currentElementType]
|
||
|
);
|
||
|
elements.forEach(function (element) {
|
||
|
element.classList.add("melting");
|
||
|
});
|
||
|
|
||
|
// Increment the click count
|
||
|
clickCountMelt++;
|
||
|
|
||
|
// Check if every 3rd click
|
||
|
if (clickCountMelt % 3 === 0) {
|
||
|
// Remove 'melting' class from all elements
|
||
|
elements.forEach(function (element) {
|
||
|
element.classList.remove("melting");
|
||
|
});
|
||
|
} else {
|
||
|
// Increment the currentElementType and wrap around if needed
|
||
|
currentElementType = (currentElementType + 1) % textElementTypes.length;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Add an event listener to the entire document
|
||
|
document.addEventListener("click", meltText);
|
||
|
|
||
|
//--------------------------------------------Load something on 7th click-----------//
|
||
|
// Initialize a counter for the number of clicks
|
||
|
let clickCountReload = 0;
|
||
|
// Define the maximum number of clicks required
|
||
|
const maxClicksReload = 5;
|
||
|
// Define the predefined link to load
|
||
|
const predefinedLink = "#";
|
||
|
// Function to handle the click event
|
||
|
function handleButtonClick() {
|
||
|
clickCountReload++;
|
||
|
// Check if the required number of clicks is reached
|
||
|
if (clickCountReload >= maxClicksReload) {
|
||
|
// Load the predefined link
|
||
|
window.location.href = predefinedLink;
|
||
|
// Remove the melting class from all elements
|
||
|
elements.forEach(function (element) {
|
||
|
element.classList.remove("melting");
|
||
|
});
|
||
|
// Reset the counter
|
||
|
clickCountReload = 0;
|
||
|
}
|
||
|
}
|
||
|
// Add an event listener to the entire document
|
||
|
document.addEventListener("click", handleButtonClick);
|
||
|
//----------------------------------------Changing Place holder texts ---------//
|
||
|
// Function to check if the user has scrolled to the bottom
|
||
|
function isScrolledToBottom() {
|
||
|
const windowHeight = window.innerHeight;
|
||
|
const documentHeight = document.documentElement.scrollHeight;
|
||
|
const scrollPosition = window.scrollY;
|
||
|
|
||
|
// Consider a small buffer (e.g., 10 pixels) to account for minor discrepancies
|
||
|
return scrollPosition + windowHeight >= documentHeight - 10;
|
||
|
}
|
||
|
|
||
|
// Function to replace the placeholder value of a textarea
|
||
|
function replacePlaceholderOnScroll() {
|
||
|
const textarea = document.getElementById("message");
|
||
|
const placeholderText = "Please help me. This is not fun.";
|
||
|
|
||
|
if (isScrolledToBottom()) {
|
||
|
textarea.placeholder = placeholderText;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Add an event listener to the window's scroll event
|
||
|
window.addEventListener("scroll", replacePlaceholderOnScroll);
|
||
|
|
||
|
//--------------Set time out for Nth page ----------------//
|
||
|
|
||
|
setTimeout(function() {
|
||
|
window.location.reload();
|
||
|
}, 7000);
|
||
|
|
||
|
if(document.getElementById("sevenSeconds")) {
|
||
|
setTimeout()
|
||
|
}
|