(function($) { "use strict"; /* Preloader */ $(window).on('load', function() { var preloaderFadeOutTime = 500; function hidePreloader() { var preloader = $('.spinner-wrapper'); setTimeout(function() { preloader.fadeOut(preloaderFadeOutTime); }, 500); } hidePreloader(); }); /* Navbar Scripts */ // jQuery to collapse the navbar on scroll $(window).on('scroll load', function() { if ($(".navbar").offset().top > 60) { $(".fixed-top").addClass("top-nav-collapse"); } else { $(".fixed-top").removeClass("top-nav-collapse"); } }); // jQuery for page scrolling feature - requires jQuery Easing plugin $(function() { $(document).on('click', 'a.page-scroll', function(event) { var $anchor = $(this); $('html, body').stop().animate({ scrollTop: $($anchor.attr('href')).offset().top }, 600, 'easeInOutExpo'); event.preventDefault(); }); }); // closes the responsive menu on menu item click $(".navbar-nav li a").on("click", function(event) { if (!$(this).parent().hasClass('dropdown')) $(".navbar-collapse").collapse('hide'); }); /* Image Slider - Swiper */ var imageSlider = new Swiper('.image-slider', { autoplay: { delay: 2000, disableOnInteraction: false }, loop: true, spaceBetween: 30, slidesPerView: 5, breakpoints: { // when window is <= 580px 580: { slidesPerView: 1, spaceBetween: 10 }, // when window is <= 768px 768: { slidesPerView: 2, spaceBetween: 20 }, // when window is <= 992px 992: { slidesPerView: 3, spaceBetween: 20 }, // when window is <= 1200px 1200: { slidesPerView: 4, spaceBetween: 20 }, } }); /* Card Slider - Swiper */ var cardSlider = new Swiper('.card-slider', { autoplay: { delay: 4000, disableOnInteraction: false }, loop: true, navigation: { nextEl: '.swiper-button-next', prevEl: '.swiper-button-prev' } }); /* Video Lightbox - Magnific Popup */ $('.popup-youtube, .popup-vimeo').magnificPopup({ disableOn: 700, type: 'iframe', mainClass: 'mfp-fade', removalDelay: 160, preloader: false, fixedContentPos: false, iframe: { patterns: { youtube: { index: 'youtube.com/', id: function(url) { var m = url.match(/[\\?\\&]v=([^\\?\\&]+)/); if ( !m || !m[1] ) return null; return m[1]; }, src: 'https://www.youtube.com/embed/%id%?autoplay=1' }, vimeo: { index: 'vimeo.com/', id: function(url) { var m = url.match(/(https?:\/\/)?(www.)?(player.)?vimeo.com\/([a-z]*\/)*([0-9]{6,11})[?]?.*/); if ( !m || !m[5] ) return null; return m[5]; }, src: 'https://player.vimeo.com/video/%id%?autoplay=1' } } } }); /* Lightbox - Magnific Popup */ $('.popup-with-move-anim').magnificPopup({ type: 'inline', fixedContentPos: false, /* keep it false to avoid html tag shift with margin-right: 17px */ fixedBgPos: true, overflowY: 'auto', closeBtnInside: true, preloader: false, midClick: true, removalDelay: 300, mainClass: 'my-mfp-slide-bottom' }); /* Move Form Fields Label When User Types */ // for input and textarea fields $("input, textarea").keyup(function(){ if ($(this).val() != '') { $(this).addClass('notEmpty'); } else { $(this).removeClass('notEmpty'); } }); /* Request Form */ $("#requestForm").validator().on("submit", function(event) { if (event.isDefaultPrevented()) { // handle the invalid form... rformError(); rsubmitMSG(false, "Please fill all fields!"); } else { // everything looks good! event.preventDefault(); rsubmitForm(); } }); function rsubmitForm() { // initiate variables with form content var name = $("#rname").val(); var email = $("#remail").val(); var phone = $("#rphone").val(); var select = $("#rselect").val(); var terms = $("#rterms").val(); $.ajax({ type: "POST", url: "php/requestform-process.php", data: "name=" + name + "&email=" + email + "&phone=" + phone + "&select=" + select + "&terms=" + terms, success: function(text) { if (text == "success") { rformSuccess(); } else { rformError(); rsubmitMSG(false, text); } } }); } function rformSuccess() { $("#requestForm")[0].reset(); rsubmitMSG(true, "Request Submitted!"); $("input").removeClass('notEmpty'); // resets the field label after submission } function rformError() { $("#requestForm").removeClass().addClass('shake animated').one('webkitAnimationEnd mozAnimationEnd MSAnimationEnd oanimationend animationend', function() { $(this).removeClass(); }); } function rsubmitMSG(valid, msg) { if (valid) { var msgClasses = "h3 text-center tada animated"; } else { var msgClasses = "h3 text-center"; } $("#rmsgSubmit").removeClass().addClass(msgClasses).text(msg); } /* Contact Form */ $("#contactForm").validator().on("submit", function(event) { if (event.isDefaultPrevented()) { // handle the invalid form... cformError(); csubmitMSG(false, "Please fill all fields!"); } else { // everything looks good! event.preventDefault(); csubmitForm(); } }); function csubmitForm() { // initiate variables with form content var name = $("#cname").val(); var email = $("#cemail").val(); var message = $("#cmessage").val(); var terms = $("#cterms").val(); $.ajax({ type: "POST", url: "php/contactform-process.php", data: "name=" + name + "&email=" + email + "&message=" + message + "&terms=" + terms, success: function(text) { if (text == "success") { cformSuccess(); } else { cformError(); csubmitMSG(false, text); } } }); } function cformSuccess() { $("#contactForm")[0].reset(); csubmitMSG(true, "Message Submitted!"); $("input").removeClass('notEmpty'); // resets the field label after submission $("textarea").removeClass('notEmpty'); // resets the field label after submission } function cformError() { $("#contactForm").removeClass().addClass('shake animated').one('webkitAnimationEnd mozAnimationEnd MSAnimationEnd oanimationend animationend', function() { $(this).removeClass(); }); } function csubmitMSG(valid, msg) { if (valid) { var msgClasses = "h3 text-center tada animated"; } else { var msgClasses = "h3 text-center"; } $("#cmsgSubmit").removeClass().addClass(msgClasses).text(msg); } /* Privacy Form */ $("#privacyForm").validator().on("submit", function(event) { if (event.isDefaultPrevented()) { // handle the invalid form... pformError(); psubmitMSG(false, "Please fill all fields!"); } else { // everything looks good! event.preventDefault(); psubmitForm(); } }); function psubmitForm() { // initiate variables with form content var name = $("#pname").val(); var email = $("#pemail").val(); var select = $("#pselect").val(); var terms = $("#pterms").val(); $.ajax({ type: "POST", url: "php/privacyform-process.php", data: "name=" + name + "&email=" + email + "&select=" + select + "&terms=" + terms, success: function(text) { if (text == "success") { pformSuccess(); } else { pformError(); psubmitMSG(false, text); } } }); } function pformSuccess() { $("#privacyForm")[0].reset(); psubmitMSG(true, "Request Submitted!"); $("input").removeClass('notEmpty'); // resets the field label after submission } function pformError() { $("#privacyForm").removeClass().addClass('shake animated').one('webkitAnimationEnd mozAnimationEnd MSAnimationEnd oanimationend animationend', function() { $(this).removeClass(); }); } function psubmitMSG(valid, msg) { if (valid) { var msgClasses = "h3 text-center tada animated"; } else { var msgClasses = "h3 text-center"; } $("#pmsgSubmit").removeClass().addClass(msgClasses).text(msg); } /* Back To Top Button */ // create the back to top button $('body').prepend('Back to Top'); var amountScrolled = 700; $(window).scroll(function() { if ($(window).scrollTop() > amountScrolled) { $('a.back-to-top').fadeIn('500'); } else { $('a.back-to-top').fadeOut('500'); } }); /* Removes Long Focus On Buttons */ $(".button, a, button").mouseup(function() { $(this).blur(); }); const colors = ['#272625','#672f2c','#f54206']; const numLines = 3; var currCount = numLines; const texts = document.querySelectorAll("#textClip text"); const blobs = document.querySelectorAll("#background path"); function colorBlobs() { blobs.forEach(blob => { blob.style.fill = colors[Math.floor(Math.random() * colors.length)]; }); } function nextIteration() { // Change the color of all the blobs colorBlobs(); // Hide the old set of lines let startVal = currCount - numLines; if(startVal < 0) { startVal = texts.length - numLines; } for(let i = startVal; i < startVal + numLines; i++) { texts[i].style.display = "none"; } // Show new set of lines for(let j = currCount; j < currCount + numLines; j++) { texts[j].style.display = "inline"; } currCount += numLines; if(currCount >= texts.length) { currCount = 0; } } // Since all of our blobs are using the same animation, we only // need to listen to one of them blobs[0].addEventListener("animationiteration", nextIteration); colorBlobs(); function fitElementToParent(el, padding) { var timeout = null; function resize() { if (timeout) clearTimeout(timeout); anime.set(el, {scale: 1}); var pad = padding || 0; var parentEl = el.parentNode; var elOffsetWidth = el.offsetWidth - pad; var parentOffsetWidth = parentEl.offsetWidth; var ratio = parentOffsetWidth / elOffsetWidth; timeout = setTimeout(anime.set(el, {scale: ratio}), 10); } resize(); window.addEventListener('resize', resize); } function layeredAnimation() { var transformEls = document.querySelectorAll('.transform-progress'); var layeredAnimationEl = document.querySelector('.layered-animations'); var shapeEls = layeredAnimationEl.querySelectorAll('.shape'); var triangleEl = layeredAnimationEl.querySelector('polygon'); var trianglePoints = triangleEl.getAttribute('points').split(' '); var easings = ['easeInOutQuad', 'easeInOutCirc', 'easeInOutSine', 'spring']; fitElementToParent(layeredAnimationEl); function createKeyframes(value) { var keyframes = []; for (var i = 0; i < 30; i++) keyframes.push({ value: value }); return keyframes; } function animateShape(el) { var circleEl = el.querySelector('circle'); var rectEl = el.querySelector('rect'); var polyEl = el.querySelector('polygon'); var animation = anime.timeline({ targets: el, duration: function() { return anime.random(600, 2200); }, easing: function() { return easings[anime.random(0, easings.length - 1)]; }, complete: function(anim) { animateShape(anim.animatables[0].target); }, }) .add({ translateX: createKeyframes(function(el) { return el.classList.contains('large') ? anime.random(-300, 300) : anime.random(-520, 520); }), translateY: createKeyframes(function(el) { return el.classList.contains('large') ? anime.random(-110, 110) : anime.random(-280, 280); }), rotate: createKeyframes(function() { return anime.random(-180, 180); }), }, 0); if (circleEl) { animation.add({ targets: circleEl, r: createKeyframes(function() { return anime.random(32, 72); }), }, 0); } if (rectEl) { animation.add({ targets: rectEl, width: createKeyframes(function() { return anime.random(64, 120); }), height: createKeyframes(function() { return anime.random(64, 120); }), }, 0); } if (polyEl) { animation.add({ targets: polyEl, points: createKeyframes(function() { var scale = anime.random(72, 180) / 100; return trianglePoints.map(function(p) { return p * scale; }).join(' '); }), }, 0); } } for (var i = 0; i < shapeEls.length; i++) { animateShape(shapeEls[i]); } } layeredAnimation(); var advancedStaggeringAnimation = (function() { var staggerVisualizerEl = document.querySelector('.stagger-visualizer'); var dotsWrapperEl = staggerVisualizerEl.querySelector('.dots-wrapper'); var dotsFragment = document.createDocumentFragment(); var grid = [20, 5]; var cell = 55; var numberOfElements = grid[0] * grid[1]; var animation; var paused = true; fitElementToParent(staggerVisualizerEl, 0); for (var i = 0; i < numberOfElements; i++) { var dotEl = document.createElement('div'); dotEl.classList.add('dot'); dotsFragment.appendChild(dotEl); } dotsWrapperEl.appendChild(dotsFragment); var index = anime.random(0, numberOfElements-1); var nextIndex = 0; anime.set('.stagger-visualizer .cursor', { translateX: anime.stagger(-cell, {grid: grid, from: index, axis: 'x'}), translateY: anime.stagger(-cell, {grid: grid, from: index, axis: 'y'}), translateZ: 0, scale: 1, }); function play() { paused = false; if (animation) animation.pause(); nextIndex = anime.random(0, numberOfElements-1); animation = anime.timeline({ easing: 'easeInOutQuad', complete: play }) .add({ targets: '.stagger-visualizer .cursor', keyframes: [ { scale: .75, duration: 120}, { scale: 2.5, duration: 220}, { scale: 1.5, duration: 450}, ], duration: 300 }) .add({ targets: '.stagger-visualizer .dot', keyframes: [ { translateX: anime.stagger('-2px', {grid: grid, from: index, axis: 'x'}), translateY: anime.stagger('-2px', {grid: grid, from: index, axis: 'y'}), duration: 100 }, { translateX: anime.stagger('4px', {grid: grid, from: index, axis: 'x'}), translateY: anime.stagger('4px', {grid: grid, from: index, axis: 'y'}), scale: anime.stagger([2.6, 1], {grid: grid, from: index}), duration: 225 }, { translateX: 0, translateY: 0, scale: 1, duration: 1200, } ], delay: anime.stagger(80, {grid: grid, from: index}) }, 30) .add({ targets: '.stagger-visualizer .cursor', translateX: { value: anime.stagger(-cell, {grid: grid, from: nextIndex, axis: 'x'}) }, translateY: { value: anime.stagger(-cell, {grid: grid, from: nextIndex, axis: 'y'}) }, scale: 1.5, easing: 'cubicBezier(.075, .2, .165, 1)' }, '-=800') index = nextIndex; } play(); })(); })(jQuery);