-
Notifications
You must be signed in to change notification settings - Fork 0
/
scrolllentoWP.js
66 lines (59 loc) · 2.6 KB
/
scrolllentoWP.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
function enqueue_lenis_script_based_on_device() {
// Enfileirar o script externo Lenis
wp_enqueue_script('lenis-script', 'https://cdn.jsdelivr.net/gh/studio-freight/[email protected]/bundled/lenis.min.js', array(), null, true);
// Adicionar o código JS personalizado com base na largura da tela
wp_add_inline_script('lenis-script', "
document.addEventListener('DOMContentLoaded', function() {
if (window.innerWidth >= 1000) {
// Configuração para desktop
const lenisDesktop = new Lenis({
duration: 1.2,
easing: (t) => Math.min(1, 1.001 - Math.pow(2, -10 * t)),
orientation: 'vertical',
gestureOrientation: 'vertical',
smoothWheel: true,
wheelMultiplier: 1,
smoothTouch: false,
touchMultiplier: 2,
infinite: false,
});
// Log do valor de scroll no console
lenisDesktop.on('scroll', (e) => {
console.log('Desktop Scroll:', e);
});
// Função para animação de quadro (frame)
function rafDesktop(time) {
lenisDesktop.raf(time);
requestAnimationFrame(rafDesktop);
}
// Inicia a animação de quadro (frame)
requestAnimationFrame(rafDesktop);
} else {
// Configuração para dispositivos móveis
const lenisMobile = new Lenis({
duration: 1.2,
easing: (t) => Math.min(1, 1.001 - Math.pow(2, -10 * t)),
orientation: 'vertical',
gestureOrientation: 'vertical',
smoothWheel: true,
wheelMultiplier: 1,
smoothTouch: true,
touchMultiplier: 2,
infinite: false,
});
// Log do valor de scroll no console
lenisMobile.on('scroll', (e) => {
console.log('Mobile Scroll:', e);
});
// Função para animação de quadro (frame)
function rafMobile(time) {
lenisMobile.raf(time);
requestAnimationFrame(rafMobile);
}
// Inicia a animação de quadro (frame)
requestAnimationFrame(rafMobile);
}
});
");
}
add_action('wp_enqueue_scripts', 'enqueue_lenis_script_based_on_device');