2022-07-19 14:25:29 +00:00
|
|
|
gsap.registerPlugin(DrawSVGPlugin);
|
|
|
|
|
gsap.registerPlugin(CustomEase);
|
|
|
|
|
|
2022-09-02 13:59:11 +00:00
|
|
|
var bodyRect = document.body.getBoundingClientRect();
|
|
|
|
|
|
|
|
|
|
var sections = [
|
|
|
|
|
"pitch",
|
|
|
|
|
"products",
|
|
|
|
|
"infographics",
|
|
|
|
|
"bitcoin",
|
|
|
|
|
"be-your-own",
|
|
|
|
|
"powered-by",
|
|
|
|
|
"support",
|
|
|
|
|
"dev",
|
|
|
|
|
"community"
|
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
//////////////////////////////////////////
|
|
|
|
|
// AUTO APPLY URL ANCHORS
|
|
|
|
|
|
|
|
|
|
setTimeout(function() {
|
|
|
|
|
|
|
|
|
|
// timeout to allow initial load to redirect to anchor
|
|
|
|
|
// TODO: maybe apply the scroll-behavior: smooth to HTML after a timeout
|
|
|
|
|
|
|
|
|
|
sections.forEach(slug => {
|
|
|
|
|
ScrollTrigger.create({
|
|
|
|
|
trigger: "#" + slug,
|
|
|
|
|
start: "top center",
|
|
|
|
|
end: "bottom center",
|
|
|
|
|
markers: {startColor: "white", endColor: "white"},
|
|
|
|
|
onEnter: () => { window.location.href = "#" + slug; },
|
|
|
|
|
onEnterBack: () => { window.location.href = "#" + slug; }
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
}, 2000);
|
|
|
|
|
|
|
|
|
|
|
2022-07-19 14:25:29 +00:00
|
|
|
//////////////////////////////////////////
|
|
|
|
|
// MENU
|
|
|
|
|
|
2022-09-02 13:59:11 +00:00
|
|
|
let menuOpen = document.getElementById("menu-open"),
|
|
|
|
|
menuClose = document.getElementById("menu-close"),
|
|
|
|
|
openedMenuArray = gsap.utils.toArray(".opened-menu"),
|
|
|
|
|
closedMenuArray = gsap.utils.toArray(".closed-menu");
|
2022-07-19 14:25:29 +00:00
|
|
|
|
|
|
|
|
menuOpen.addEventListener("click", () => openMenu());
|
|
|
|
|
menuClose.addEventListener("click", () => closeMenu());
|
|
|
|
|
|
|
|
|
|
function openMenu() {
|
2022-09-02 13:59:11 +00:00
|
|
|
gsap.to("#menu", { y: "0vh" });
|
|
|
|
|
gsap.to("main", { y: "0vh" });
|
|
|
|
|
gsap.to(openedMenuArray, { x: "0", opacity: 1, width: "auto" });
|
|
|
|
|
gsap.to(closedMenuArray, { x: "3rem", opacity: 0, width: 0 });
|
|
|
|
|
gsap.to("html", { overflow: "hidden"});
|
2022-07-19 14:25:29 +00:00
|
|
|
}
|
|
|
|
|
function closeMenu() {
|
2022-09-02 13:59:11 +00:00
|
|
|
gsap.to("#menu", { y: "-100vh" });
|
|
|
|
|
gsap.to("main", { y: "-100vh" });
|
|
|
|
|
gsap.to(closedMenuArray, { x: "0", opacity: 1, width: "auto" });
|
|
|
|
|
gsap.to(openedMenuArray, { x: "3rem", opacity: 0, width: 0 });
|
|
|
|
|
gsap.to("html", { overflow: "overlay"});
|
2022-07-19 14:25:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//////////////////////////////////////////
|
|
|
|
|
// HERO
|
|
|
|
|
|
|
|
|
|
gsap.from("#hero-image", {
|
|
|
|
|
duration: 0.5,
|
|
|
|
|
y: "-10rem",
|
|
|
|
|
opacity: 0,
|
|
|
|
|
delay: 0.5,
|
|
|
|
|
});
|
|
|
|
|
gsap.from("#logo", { duration: 0.5, y: "-5rem", opacity: 0, delay: 0.75 });
|
|
|
|
|
//gsap.config({trialWarn: false});
|
|
|
|
|
|
|
|
|
|
// create the smooth scroller FIRST!
|
|
|
|
|
// ScrollSmoother.create({
|
|
|
|
|
// smooth: 2, // seconds it takes to "catch up" to native scroll position
|
|
|
|
|
// effects: true, // look for data-speed and data-lag attributes on elements and animate accordingly
|
|
|
|
|
// wrapper: '.scroll_track',
|
|
|
|
|
// content: '.scroll_track_content'
|
|
|
|
|
// });
|
|
|
|
|
|
2022-09-02 13:59:11 +00:00
|
|
|
// backdrop-filter: blur(10px);
|
|
|
|
|
//background-color: rgba(0,0,0,0.1);
|
|
|
|
|
|
|
|
|
|
gsap.to(
|
|
|
|
|
"header",
|
|
|
|
|
{
|
|
|
|
|
duration: 0.5,
|
|
|
|
|
backgroundColor: "rgba(0,0,0,0.1)",
|
|
|
|
|
backdropFilter: "blur(10px)",
|
|
|
|
|
scrollTrigger: {
|
|
|
|
|
trigger: "#hero-image",
|
|
|
|
|
scrub: true,
|
|
|
|
|
start: "center top", // "triggerElement page"
|
|
|
|
|
end: "bottom top", // "triggerElement page"
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
);
|
2022-07-19 14:25:29 +00:00
|
|
|
|
|
|
|
|
//////////////////////////////////////////
|
|
|
|
|
// PITCH
|
|
|
|
|
|
|
|
|
|
gsap.from("#pitch h1", {
|
|
|
|
|
duration: 0.5,
|
|
|
|
|
y: "5rem",
|
|
|
|
|
scale: 0.8,
|
|
|
|
|
opacity: 0,
|
|
|
|
|
delay: 0.75,
|
|
|
|
|
scrollTrigger: "#pitch h1",
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// gsap.from("#xyz", {
|
|
|
|
|
// duration: 1, drawSVG: "false",
|
|
|
|
|
// scrollTrigger: '#xyz'
|
|
|
|
|
// })
|
|
|
|
|
|
2022-07-28 11:55:52 +00:00
|
|
|
gsap.from("#hero-to-pitch path:first-child", {
|
2022-09-02 13:59:11 +00:00
|
|
|
drawSVG: 0,
|
|
|
|
|
ease: "none",
|
|
|
|
|
scrollTrigger: {
|
|
|
|
|
trigger: "#hero-to-pitch",
|
|
|
|
|
scrub: true,
|
|
|
|
|
start: "top center",
|
|
|
|
|
end: "bottom center",
|
|
|
|
|
},
|
|
|
|
|
});
|
2022-07-28 11:55:52 +00:00
|
|
|
|
2022-09-02 13:59:11 +00:00
|
|
|
gsap.from("#products-to-info path:first-child", {
|
|
|
|
|
drawSVG: 0,
|
|
|
|
|
ease: "none",
|
|
|
|
|
scrollTrigger: {
|
|
|
|
|
trigger: "#products-to-info path:first-child",
|
|
|
|
|
scrub: true,
|
|
|
|
|
start: "top center",
|
|
|
|
|
end: "bottom center",
|
|
|
|
|
},
|
|
|
|
|
});
|
2022-07-28 11:55:52 +00:00
|
|
|
|
2022-09-02 13:59:11 +00:00
|
|
|
gsap.from("#products-to-info path:nth-child(2)", {
|
|
|
|
|
drawSVG: 0,
|
|
|
|
|
ease: "none",
|
|
|
|
|
scrollTrigger: {
|
|
|
|
|
trigger: "#products-to-info path:nth-child(2)",
|
|
|
|
|
scrub: true,
|
|
|
|
|
start: "top center",
|
|
|
|
|
end: "bottom center",
|
|
|
|
|
},
|
|
|
|
|
});
|
2022-07-28 11:55:52 +00:00
|
|
|
|
2022-09-02 13:59:11 +00:00
|
|
|
gsap.from("#bitcoin-to-be path", {
|
|
|
|
|
drawSVG: 0,
|
|
|
|
|
ease: "none",
|
|
|
|
|
scrollTrigger: {
|
|
|
|
|
trigger: "#bitcoin-to-be path",
|
|
|
|
|
scrub: true,
|
|
|
|
|
start: "top center",
|
|
|
|
|
end: "bottom center",
|
|
|
|
|
},
|
|
|
|
|
});
|
2022-07-19 14:25:29 +00:00
|
|
|
|
|
|
|
|
let imgs = gsap.utils.toArray(".pseudoservice"),
|
2022-09-02 13:59:11 +00:00
|
|
|
next = 1.5, // time to change
|
|
|
|
|
itemHeight = document
|
|
|
|
|
.querySelector(".pseudoservice")
|
|
|
|
|
.getBoundingClientRect().height,
|
|
|
|
|
listHeight = document
|
|
|
|
|
.querySelector(".pseudoservices")
|
|
|
|
|
.getBoundingClientRect().height,
|
|
|
|
|
windowHeight = document.getElementById("ticker__window").clientHeight,
|
|
|
|
|
kerplunk = CustomEase.create(
|
|
|
|
|
"custom",
|
|
|
|
|
"M0,0 C0.126,0.382 0.066,0.863 0.198,1.036 0.25,1.104 0.264,0.982 0.326,0.982 0.344,0.982 0.489,0.998 0.516,1 0.65,1.007 0.863,1 1,1 "
|
|
|
|
|
),
|
|
|
|
|
kerplunk2 = CustomEase.create(
|
|
|
|
|
"custom",
|
|
|
|
|
"M0,0 C0.126,0.382 0.178,0.802 0.288,1.052 0.303,1.088 0.372,0.99 0.434,0.99 0.502,0.99 0.497,1 0.524,1 0.664,1 0.863,1 1,1 "
|
|
|
|
|
);
|
2022-07-19 14:25:29 +00:00
|
|
|
|
|
|
|
|
function crossfade() {
|
|
|
|
|
var action = gsap
|
|
|
|
|
.timeline()
|
|
|
|
|
.to(imgs, { y: "-=" + itemHeight, duration: 1, ease: kerplunk2 })
|
|
|
|
|
.to(imgs[0], { y: "+=" + listHeight, duration: 0 }); // the first to the end
|
|
|
|
|
|
|
|
|
|
imgs.push(imgs.shift()); // the first (shift) to the end (push) from the array
|
|
|
|
|
//console.log(imgs);
|
|
|
|
|
//console.log(itemHeight);
|
|
|
|
|
|
|
|
|
|
// start endless run
|
|
|
|
|
gsap.delayedCall(next, crossfade);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// start the crossfade after next = 3 sec
|
|
|
|
|
gsap.delayedCall(next, crossfade);
|
|
|
|
|
|
|
|
|
|
//Librarys
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
var imagesLoaded = require('imagesloaded');
|
|
|
|
|
import barba from '@barba/core';
|
|
|
|
|
import LocomotiveScroll from 'locomotive-scroll';
|
|
|
|
|
import { gsap } from "gsap";
|
|
|
|
|
import { Draggable } from "gsap/Draggable";
|
|
|
|
|
import { ScrollToPlugin } from "gsap/ScrollToPlugin";
|
|
|
|
|
import { ScrollTrigger } from "gsap/ScrollTrigger";
|
|
|
|
|
import { InertiaPlugin } from "gsap/InertiaPlugin";
|
|
|
|
|
import { SplitText } from "gsap/SplitText";
|
|
|
|
|
|
|
|
|
|
gsap.registerPlugin(Draggable, ScrollToPlugin, ScrollTrigger, InertiaPlugin, SplitText);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Locomotive Scroll
|
|
|
|
|
const scroll = new LocomotiveScroll({
|
|
|
|
|
el: document.querySelector('[data-scroll-container]'),
|
|
|
|
|
smooth: true,
|
|
|
|
|
tablet: {
|
|
|
|
|
breakpoint: 961
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Use Locomotive Scroll with ScrollTrigger
|
|
|
|
|
scroll.on("scroll", ScrollTrigger.update);
|
|
|
|
|
|
|
|
|
|
ScrollTrigger.scrollerProxy(".locomotive", {
|
|
|
|
|
scrollTop(value) {
|
|
|
|
|
return arguments.length ? scroll.scrollTo(value, 0, 0) : scroll.scroll.instance.scroll.y;
|
|
|
|
|
},
|
|
|
|
|
getBoundingClientRect() {
|
|
|
|
|
return {top: 0, left: 0, width: window.innerWidth, height: window.innerHeight};
|
|
|
|
|
},
|
|
|
|
|
pinType: document.querySelector(".locomotive").style.transform ? "transform" : "fixed"
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Mobile Menu Toggle
|
|
|
|
|
const menuIcon = document.querySelector('.navBtnContainer');
|
|
|
|
|
const mobileNav = document.querySelector('.mobileNav');
|
|
|
|
|
|
|
|
|
|
const menuToggle = function () {
|
|
|
|
|
menuIcon.addEventListener(`click`, function() {
|
|
|
|
|
if(this.classList.contains(`active`)) {
|
|
|
|
|
this.classList.remove(`active`);
|
|
|
|
|
mobileNav.classList.remove(`active`);
|
|
|
|
|
} else {
|
|
|
|
|
this.classList.add(`active`);
|
|
|
|
|
mobileNav.classList.add(`active`);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
menuToggle();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Custom cursor
|
|
|
|
|
const cursorAnimate = function () {
|
|
|
|
|
const cursors = document.querySelector('.cursors')
|
|
|
|
|
const cursor = cursors.querySelector('.cursor')
|
|
|
|
|
const cursorLinks = document.querySelectorAll('a, video, .resumeItem')
|
|
|
|
|
let cursorX = 0
|
|
|
|
|
let cursorY = 0
|
|
|
|
|
let aimX = 0
|
|
|
|
|
let aimY = 0
|
|
|
|
|
let speed = 0.2
|
|
|
|
|
|
|
|
|
|
const cursorEase = function () {
|
|
|
|
|
cursorX += (aimX - cursorX) * speed
|
|
|
|
|
cursorY += (aimY - cursorY) * speed
|
|
|
|
|
|
|
|
|
|
cursor.style.left = cursorX + "px"
|
|
|
|
|
cursor.style.top = cursorY + "px"
|
|
|
|
|
|
|
|
|
|
requestAnimationFrame(cursorEase)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
cursorEase()
|
|
|
|
|
|
|
|
|
|
document.addEventListener('mousemove', function (event) {
|
|
|
|
|
aimX = event.pageX
|
|
|
|
|
aimY = event.pageY
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
cursorLinks.forEach(cursorLink => {
|
|
|
|
|
cursorLink.addEventListener('mouseover', function () {
|
|
|
|
|
cursor.classList.add(`hover`)
|
|
|
|
|
})
|
|
|
|
|
cursorLink.addEventListener('mouseout', function () {
|
|
|
|
|
cursor.classList.remove(`hover`)
|
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Scroll Trigger Hero Image
|
|
|
|
|
const heroImgInnerAnimate = function () {
|
|
|
|
|
const heroImgInner = document.querySelectorAll('.heroImgInner');
|
|
|
|
|
heroImgInner.forEach(function (heroImgInner){
|
|
|
|
|
gsap.to(heroImgInner, {
|
|
|
|
|
scrollTrigger: {
|
|
|
|
|
trigger: heroImgInner,
|
|
|
|
|
scroller: ".locomotive",
|
|
|
|
|
start: "top bottom",
|
|
|
|
|
end: "bottom top",
|
|
|
|
|
scrub: 1,
|
|
|
|
|
},
|
|
|
|
|
y: "-43.75%",
|
|
|
|
|
ease: "none"
|
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Footer Marquee
|
|
|
|
|
const footerMarqueeAnimate = function () {
|
|
|
|
|
const footerMarquee = document.querySelector('.footerMarqueeItem');
|
|
|
|
|
const footerMarqueeTrack = document.querySelector('.footerMarqueeTrack');
|
|
|
|
|
const footerMarqueeItemWidth = footerMarquee.offsetWidth;
|
|
|
|
|
//console.log(footerMarqueeItemWidth);
|
|
|
|
|
const footerMarqueeTL = gsap.timeline({repeat:-1, defaults:{ease:"none"}});
|
|
|
|
|
footerMarqueeTL.to(footerMarqueeTrack,{x:-footerMarqueeItemWidth, duration:20});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Scroll Trigger Marquee
|
|
|
|
|
const marqueeAnimate = function () {
|
|
|
|
|
const marquee = document.querySelectorAll('.marqueeTrack');
|
|
|
|
|
marquee.forEach(function (marquee){
|
|
|
|
|
gsap.to(marquee, {
|
|
|
|
|
scrollTrigger: {
|
|
|
|
|
trigger: marquee,
|
|
|
|
|
scroller: ".locomotive",
|
|
|
|
|
start: "top bottom",
|
|
|
|
|
end: "bottom top",
|
|
|
|
|
scrub: 1,
|
|
|
|
|
},
|
|
|
|
|
x: "-33.33%",
|
|
|
|
|
ease: "none"
|
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Scroll Trigger Spin
|
|
|
|
|
const spinTextAnimate = function () {
|
|
|
|
|
const spinText = document.querySelectorAll('.spinText');
|
|
|
|
|
spinText.forEach(function (spinText){
|
|
|
|
|
gsap.to(spinText, {
|
|
|
|
|
scrollTrigger: {
|
|
|
|
|
trigger: spinText,
|
|
|
|
|
scroller: ".locomotive",
|
|
|
|
|
start: "top bottom",
|
|
|
|
|
end: "bottom top",
|
|
|
|
|
scrub: 1,
|
|
|
|
|
},
|
|
|
|
|
rotation:360,
|
|
|
|
|
ease: "none"
|
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Work Experience Dropdown
|
|
|
|
|
const experienceToggle = function () {
|
|
|
|
|
const resumeItems = document.querySelectorAll('.resumeItem');
|
|
|
|
|
resumeItems.forEach(function (item) {
|
|
|
|
|
let jobTitleHeight = item.offsetHeight;
|
|
|
|
|
item.addEventListener('click', function () {
|
|
|
|
|
let jobDescHeight = this.children[4].offsetHeight;
|
|
|
|
|
if(this.classList.contains('active')) {
|
|
|
|
|
this.classList.remove('active')
|
|
|
|
|
this.style.height = jobTitleHeight + "px"
|
|
|
|
|
} else {
|
|
|
|
|
this.classList.add('active')
|
|
|
|
|
this.style.height = jobTitleHeight + jobDescHeight + "px"
|
|
|
|
|
}
|
|
|
|
|
setTimeout(function () { scroll.update(); }, 1000)
|
|
|
|
|
})
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
experienceToggle();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Update scroll height after Images Load
|
|
|
|
|
imagesLoaded( 'body', function() {
|
|
|
|
|
scroll.update();
|
|
|
|
|
cursorAnimate();
|
|
|
|
|
footerMarqueeAnimate();
|
|
|
|
|
marqueeAnimate();
|
|
|
|
|
spinTextAnimate();
|
|
|
|
|
ScrollTrigger.matchMedia({
|
|
|
|
|
"(min-width: 960px)": function() {
|
|
|
|
|
heroImgInnerAnimate();
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Barba
|
|
|
|
|
|
|
|
|
|
const transitionPanel1 = document.querySelector('#transitionPanel1');
|
|
|
|
|
const loadPanel = document.querySelector('.loadPanel');
|
|
|
|
|
|
|
|
|
|
barba.hooks.after(() => {
|
|
|
|
|
marqueeAnimate();
|
|
|
|
|
spinTextAnimate();
|
|
|
|
|
experienceToggle();
|
|
|
|
|
cursorAnimate();
|
|
|
|
|
ScrollTrigger.matchMedia({
|
|
|
|
|
"(min-width: 960px)": function() {
|
|
|
|
|
heroImgInnerAnimate();
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
scroll.update();
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
barba.init({
|
|
|
|
|
|
|
|
|
|
transitions: [{
|
|
|
|
|
name: 'default',
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
once({ next }) {
|
|
|
|
|
|
|
|
|
|
return new Promise(resolve => {
|
|
|
|
|
|
|
|
|
|
const timeline = gsap.timeline({
|
|
|
|
|
onComplete() {
|
|
|
|
|
deleteSplit();
|
|
|
|
|
scroll.update();
|
|
|
|
|
resolve();
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
const splitHeadline = new SplitText('h1', {type:'words'})
|
|
|
|
|
function deleteSplit() {
|
|
|
|
|
splitHeadline.revert()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
timeline
|
|
|
|
|
.set('.load-content', {opacity: 0})
|
|
|
|
|
.set('main', {y: 200, opacity: 0})
|
|
|
|
|
.set('header', {y: -100, opacity: 0})
|
|
|
|
|
.set(splitHeadline.words, {opacity: 0, y: 48})
|
|
|
|
|
.to('.load-content', {duration: 1, opacity: 1}, 0.5)
|
|
|
|
|
.to('.loadPanel', {duration: 1, height: 0, ease: "power4.inOut"}, '+=1')
|
|
|
|
|
.to('.load-content', {duration: 1, opacity: 0}, '-=1')
|
|
|
|
|
.to('header', {duration: 1, y: 0, opacity: 1, ease: "power4.out"}, '-=0.5')
|
|
|
|
|
.to('main', {duration: 1, y: 0, opacity: 1, ease: "power4.out"}, '-=1')
|
|
|
|
|
.to(splitHeadline.words, {duration: 1, y: 0, opacity: 1, ease: "power3.out", stagger: 0.04}, '-=1')
|
|
|
|
|
.set('.loadPanel', {opacity: 0, display:'none'})
|
|
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
leave({ current, next, trigger }) {
|
|
|
|
|
|
|
|
|
|
return new Promise(resolve => {
|
|
|
|
|
|
|
|
|
|
const timeline = gsap.timeline({
|
|
|
|
|
onComplete() {
|
|
|
|
|
resolve();
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
transitionPanel1.classList.add(`active`);
|
|
|
|
|
mobileNav.classList.remove(`active`);
|
|
|
|
|
menuIcon.classList.remove(`active`);
|
|
|
|
|
|
|
|
|
|
timeline
|
|
|
|
|
.to('footer', {duration: 0.5, opacity: 0}, 0)
|
|
|
|
|
.to(current.container, {duration: 0.5, opacity: 0}, 0)
|
|
|
|
|
.to(current.container, {display: 'none'})
|
|
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
beforeEnter({ current, next, trigger }) {
|
|
|
|
|
|
|
|
|
|
scroll.scrollTo(0, 0);
|
|
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
enter({ current, next, trigger }) {
|
|
|
|
|
|
|
|
|
|
imagesLoaded( 'body', function() {
|
|
|
|
|
scroll.update();
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
return new Promise(resolve => {
|
|
|
|
|
|
|
|
|
|
const timeline = gsap.timeline({
|
|
|
|
|
onComplete() {
|
|
|
|
|
transitionPanel1.classList.remove(`active`);
|
|
|
|
|
resolve();
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
timeline
|
|
|
|
|
.set(current.container, {opacity: 0})
|
|
|
|
|
.set(next.container, {opacity: 0})
|
|
|
|
|
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
afterEnter({ current, next, trigger }) {
|
|
|
|
|
|
|
|
|
|
return new Promise(resolve => {
|
|
|
|
|
|
|
|
|
|
const timeline = gsap.timeline({
|
|
|
|
|
onComplete() {
|
|
|
|
|
resolve();
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
timeline
|
|
|
|
|
.to(next.container, {duration: 1, opacity: 1}, 0.5)
|
|
|
|
|
.to('footer', {duration: 1, opacity: 1}, 0.5)
|
|
|
|
|
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}],
|
|
|
|
|
|
|
|
|
|
views: [{}],
|
|
|
|
|
|
|
|
|
|
//debug: true
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
*/
|