generated from projects/testosmaximus
fix: update insertRickLabel function to enhance click handling and add rainbow animation
This commit is contained in:
parent
8f403680f2
commit
202c5163db
@ -12,13 +12,26 @@ export function insertRickLabel(target: HTMLElement | string = document.body): v
|
||||
cursor: 'pointer',
|
||||
boxShadow: '0 0 5px rgba(0,0,0,0.1)',
|
||||
width: 'fit-content',
|
||||
userSelect: 'none'
|
||||
userSelect: 'none',
|
||||
transition: 'all 0.3s ease'
|
||||
})
|
||||
|
||||
label.onclick = () => {
|
||||
clickCount++
|
||||
label.textContent = `Rickroll Me (${clickCount})`
|
||||
window.open('https://www.youtube.com/watch?v=dQw4w9WgXcQ', '_blank')
|
||||
|
||||
const url =
|
||||
clickCount >= 69
|
||||
? 'https://youtu.be/soKTQx0p7_Q?list=RDsoKTQx0p7_Q'
|
||||
: 'https://www.youtube.com/watch?v=dQw4w9WgXcQ'
|
||||
|
||||
if (clickCount === 69) {
|
||||
// Activate rainbow effect via CSS animation
|
||||
label.style.animation = 'rainbowBackground 3s linear infinite'
|
||||
label.style.color = 'white'
|
||||
}
|
||||
|
||||
window.open(url, '_blank')
|
||||
}
|
||||
|
||||
if (typeof target === 'string') {
|
||||
@ -26,4 +39,22 @@ export function insertRickLabel(target: HTMLElement | string = document.body): v
|
||||
} else {
|
||||
target.appendChild(label)
|
||||
}
|
||||
|
||||
// Inject rainbow animation into page if not already there
|
||||
if (!document.getElementById('rainbow-style')) {
|
||||
const style = document.createElement('style')
|
||||
style.id = 'rainbow-style'
|
||||
style.textContent = `
|
||||
@keyframes rainbowBackground {
|
||||
0% { background: red; }
|
||||
16% { background: orange; }
|
||||
32% { background: yellow; }
|
||||
48% { background: green; }
|
||||
64% { background: blue; }
|
||||
80% { background: indigo; }
|
||||
100% { background: violet; }
|
||||
}
|
||||
`
|
||||
document.head.appendChild(style)
|
||||
}
|
||||
}
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user