ok

Mini Shell

Direktori : /home2/selectio/www/renew-right/js/
Upload File :
Current File : /home2/selectio/www/renew-right/js/magiccursor.js

if ($("body").not(".is-mobile").hasClass("tt-magic-cursor")) {
    if ($(window).width() > 1024) {
        $(".magnetic-item").wrap('<div class="magnetic-wrap"></div>');
        
        if ($("a.magnetic-item").length) {
            $("a.magnetic-item").addClass("not-hide-cursor");
        }

        var $mouse = { x: 0, y: 0 }; // Cursor position
        var $pos = { x: 0, y: 0 }; // Cursor position
        var $ratio = 0.15; // delay follow cursor
        var $active = false;
        var $ball = $("#ball");

        var $ballWidth = 34; // Ball default width
        var $ballHeight = 34; // Ball default height
        var $ballScale = 1; // Ball default scale
        var $ballOpacity = 0.5; // Ball default opacity
        var $ballBorderWidth = 2; // Ball default border width

        gsap.set($ball, {  // scale from middle and style ball
            xPercent: -50, 
            yPercent: -50, 
            width: $ballWidth,
            height: $ballHeight,
            borderWidth: $ballBorderWidth, 
            opacity: $ballOpacity 
        });

        document.addEventListener("mousemove", mouseMove);

        function mouseMove(e) {
            $mouse.x = e.clientX;
            $mouse.y = e.clientY;
        }

        gsap.ticker.add(updatePosition);

        function updatePosition() {
            if (!$active) {
                $pos.x += ($mouse.x - $pos.x) * $ratio;
                $pos.y += ($mouse.y - $pos.y) * $ratio;

                gsap.set($ball, { x: $pos.x, y: $pos.y });
            }
        }

        $(".magnetic-wrap").mousemove(function(e) {
            parallaxCursor(e, this, 2); // magnetic ball = low number is more attractive
            callParallax(e, this);
        });

        function callParallax(e, parent) {
            parallaxIt(e, parent, parent.querySelector(".magnetic-item"), 25); // magnetic area = higher number is more attractive
        }

        function parallaxIt(e, parent, target, movement) {
            var boundingRect = parent.getBoundingClientRect();
            var relX = e.clientX - boundingRect.left;
            var relY = e.clientY - boundingRect.top;

            gsap.to(target, {
                duration: 0.3, 
                x: ((relX - boundingRect.width / 2) / boundingRect.width) * movement,
                y: ((relY - boundingRect.height / 2) / boundingRect.height) * movement,
                ease: Power2.easeOut
            });
        }

        function parallaxCursor(e, parent, movement) {
            var rect = parent.getBoundingClientRect();
            var relX = e.clientX - rect.left;
            var relY = e.clientY - rect.top;
            $pos.x = rect.left + rect.width / 2 + (relX - rect.width / 2) / movement;
            $pos.y = rect.top + rect.height / 2 + (relY - rect.height / 2) / movement;
            gsap.to($ball, {duration: 0.3, x: $pos.x, y: $pos.y });
        }


        // Magic cursor behavior
        // ======================

        // Magnetic item hover.
        $(".magnetic-wrap").on("mouseenter", function(e) {
            gsap.to($ball, { duration: 0.3, scale: 2, borderWidth: 1, opacity: $ballOpacity });
            $active = true;
        }).on("mouseleave", function(e) {
            gsap.to($ball, { duration: 0.3, scale: $ballScale, borderWidth: $ballBorderWidth, opacity: $ballOpacity });
            gsap.to(this.querySelector(".magnetic-item"), { duration: 0.3, x: 0, y: 0, clearProps:"all" });
            $active = false;
        });

        // Alternative cursor style on hover.
        $(".cursor-alter, .tt-main-menu-list > li > a, .tt-main-menu-list > li > .tt-submenu-trigger > a")
        .not(".magnetic-item") // omit from selection.
        .on("mouseenter", function() {
            gsap.to($ball, {
                duration: 0.3, 
                borderWidth: 0, 
                opacity: 0.2, 
                backgroundColor: "#CCC", 
                width: "100px", 
                height: "100px", 
            });
        }).on("mouseleave", function() {
            gsap.to($ball, {
                duration: 0.3, 
                borderWidth: $ballBorderWidth, 
                opacity: $ballOpacity, 
                backgroundColor: "transparent", 
                width: $ballWidth, 
                height: $ballHeight, 
                clearProps:"backgroundColor" 
            });
        });

        // Overlay menu caret hover.
        $(".tt-ol-submenu-caret-wrap .magnetic-wrap").on("mouseenter", function() {
            gsap.to($ball, { duration: 0.3, scale: 1.3, borderWidth: $ballBorderWidth });
        }).on("mouseleave", function() {
            gsap.to($ball, { duration: 0.3, scale: $ballScale });
        });

        // Cursor view on hover (data attribute "data-cursor="...").
        $("[data-cursor]").each(function() {
            $(this).on("mouseenter", function() {
                $ball.append('<div class="ball-view"></div>');
                $(".ball-view").append($(this).attr("data-cursor"));
                gsap.to(ball, { duration: 0.3, yPercent: -75, width: 95, height: 95, opacity: 1, borderWidth: 0, backgroundColor: "#FFF" });
                gsap.to(".ball-view", { duration: 0.3, scale: 1, autoAlpha: 1 });
            }).on("mouseleave", function() {
                gsap.to(ball, { duration: 0.3, yPercent: -50, width: $ballWidth, height: $ballHeight, opacity: $ballOpacity, borderWidth: $ballBorderWidth, backgroundColor: "transparent" });
                gsap.to(".ball-view", { duration: 0.3, scale: 0, autoAlpha: 0, clearProps:"all" });
                $ball.find(".ball-view").remove();
            });
            $(this).addClass("not-hide-cursor");
        });

        // Cursor drag on hover (class "cursor-drag"). For Swiper sliders.
        $(".swiper-container").each(function() {
            if ($(this).parent().attr("data-simulate-touch") == "true") {
                if ($(this).parent().hasClass("cursor-drag")) {
                    $(this).on("mouseenter", function() {
                        $ball.append('<div class="ball-drag"></div>');
                        gsap.to($ball, { duration: 0.3, width: 60, height: 60, opacity: 1 });
                    }).on("mouseleave", function() {
                        $ball.find(".ball-drag").remove();
                        gsap.to($ball, { duration: 0.3, width: $ballWidth, height: $ballHeight, opacity: $ballOpacity });
                    });
                    $(this).addClass("not-hide-cursor");

                    // Ignore "data-cursor" on hover.
                    $(this).find("[data-cursor]").on("mouseenter mouseover", function() {
                        $ball.find(".ball-drag").remove();
                        return false;
                    }).on("mouseleave", function() {
                        $ball.append('<div class="ball-drag"></div>');
                        gsap.to($ball, { duration: 0.3, width: 60, height: 60, opacity: 1 });
                    });
                }
            }
        });
        
        // Cursor drag on mouse down / click and hold effect (class "cursor-drag-mouse-down"). For Swiper sliders.
        $(".swiper-container").each(function() {
            if ($(this).parent().attr("data-simulate-touch") == "true") {
                if ($(this).parent().hasClass("cursor-drag-mouse-down")) {
                    $(this).on("mousedown pointerdown", function(e) {
                        if (e.which === 1) { // Affects the left mouse button only!
                            gsap.to($ball, { duration: 0.2, width: 60, height: 60, opacity: 1 });
                            $ball.append('<div class="ball-drag"></div>');
                        }
                    }).on("mouseup pointerup", function() {
                        $ball.find(".ball-drag").remove();
                        if ($(this).find("[data-cursor]:hover").length) {
                        } else {
                            gsap.to($ball, { duration: 0.2, width: $ballWidth, height: $ballHeight, opacity: $ballOpacity });
                        }
                    }).on("mouseleave", function() {
                        $ball.find(".ball-drag").remove();
                        gsap.to($ball, { duration: 0.2, width: $ballWidth, height: $ballHeight, opacity: $ballOpacity });
                    });

                    // Ignore "data-cursor" on mousedown.
                    $(this).find("[data-cursor]").on("mousedown pointerdown", function() {
                        return false;
                    });

                    // Ignore "data-cursor" on hover.
                    $(this).find("[data-cursor]").on("mouseenter mouseover", function() {
                        $ball.find(".ball-drag").remove();
                        return false;
                    });
                }
            }
        });

        // Cursor close on hover.
        $(".cursor-close").each(function() {
            $(this).addClass("ball-close-enabled");
            $(this).on("mouseenter", function() {
                $ball.addClass("ball-close-enabled");
                $ball.append('<div class="ball-close">Close</div>');
                gsap.to($ball, { duration: 0.3, yPercent: -75, width: 80, height: 80, opacity: 1 });
                gsap.from(".ball-close", { duration: 0.3, scale: 0, autoAlpha: 0 });
            }).on("mouseleave click", function() {
                $ball.removeClass("ball-close-enabled");
                gsap.to($ball, { duration: 0.3, yPercent: -50, width: $ballWidth, height: $ballHeight, opacity: $ballOpacity });
                $ball.find(".ball-close").remove();
            });

            // Hover on "cursor-close" inner elements.
            $(".cursor-close a, .cursor-close button, .cursor-close .tt-btn, .cursor-close .hide-cursor")
            .not(".not-hide-cursor") // omit from selection (class "not-hide-cursor" is for global use).
            .on("mouseenter", function() {
                $ball.removeClass("ball-close-enabled");
            }).on("mouseleave", function() {
                $ball.addClass("ball-close-enabled");
            });
        });

        // Portfolio interactive title link hover.
        $(".portfolio-interactive-item").each(function() {
            var $piItem = $(this);
            if ($(this).find(".pi-item-image").length) {
                $piItem.find(".pi-item-title-link").on("mouseenter mouseover", function() {
                    $("#magic-cursor").addClass("portfolio-interactive-hover-on");
                    $piItem.find(".pi-item-image").appendTo($ball);
                    gsap.to($ball, { duration: 0.3, width: "20vw", height: "20vw", opacity: 1 });
                    $ball.find(".pi-item-image video").each(function() {
                        $(this).get(0).play();
                    }); 
                }).on("mouseleave", function() {
                    $("#magic-cursor").removeClass("portfolio-interactive-hover-on");
                    $ball.find(".pi-item-image").appendTo($piItem); 
                    gsap.to($ball, { duration: 0.3, width: $ballWidth, height: $ballHeight, opacity: $ballOpacity });
                    $piItem.find('.pi-item-image video').each(function() {
                        $(this).get(0).pause();
                    }); 
                });
                $(this).find(".pi-item-title-link").addClass("not-hide-cursor");
            }
        });

        // Blog interactive title link hover.
        $(".blog-interactive-item").each(function() {
            var $biItem = $(this);
            if ($biItem.find(".bi-item-image").length) {
                $biItem.find(".bi-item-title a").on("mouseenter mouseover", function() {
                    $("#magic-cursor").addClass("blog-interactive-hover-on");
                    $biItem.find(".bi-item-image").appendTo($ball);
                    gsap.to($ball, { duration: 0.3, width: "20vw", height: "20vw", opacity: 1 });
                }).on("mouseleave", function() {
                    $("#magic-cursor").removeClass("blog-interactive-hover-on");
                    $ball.find(".bi-item-image").appendTo($biItem); 
                    gsap.to($ball, { duration: 0.3, width: $ballWidth, height: $ballHeight, opacity: $ballOpacity });
                });
                $biItem.find(".bi-item-title a").addClass("not-hide-cursor");
                $biItem.addClass("bi-item-image-on");
            }
        });

        // Page nav hover.
        $(".tt-page-nav").each(function() {
            if ($(this).find(".tt-pn-image").length) {
                $(this).find(".tt-pn-link").on("mouseenter mouseover", function() {
                    $("#magic-cursor").addClass("tt-pn-hover-on");
                    $(this).parent().find(".tt-pn-image").appendTo($ball);
                    gsap.to($ball, { duration: 0.3, width: "20vw", height: "20vw", opacity: 1 });
                    $ball.find(".tt-pn-image video").each(function() {
                        $(this).get(0).play();
                    }); 
                }).on("mouseleave", function() {
                    $("#magic-cursor").removeClass("tt-pn-hover-on");
                    $ball.find(".tt-pn-image").appendTo(this);
                    gsap.to($ball, { duration: 0.3, width: $ballWidth, height: $ballHeight, opacity: $ballOpacity });
                    
                    $(this).parent().find('.tt-pn-image video').each(function() {
                        $(this).get(0).pause();
                    }); 
                });
                $(this).find(".tt-pn-link").addClass("not-hide-cursor");
            } else {
                $(this).find(".tt-pn-link").removeClass("not-hide-cursor");
            }
        });

        // Page nav title hover.
        if ($(".tt-pn-image").length) {
            $(".tt-page-nav").each(function() {
                $(this).find(".tt-pn-link").on("mouseenter mouseover", function() {
                    $("#magic-cursor").addClass("tt-page-nav-hover-on");
                    $(this).parent().find(".tt-pn-image").appendTo($ball);					
                    gsap.to($ball, { duration: 0.3, width: "20vw", height: "20vw", opacity: 1 });
                    if ($(".tt-pn-image video").length) {
                        $(".tt-pn-image video").get(0).play();
                    }
                }).on("mouseleave", function() {
                    $("#magic-cursor").removeClass("tt-page-nav-hover-on");
                    $ball.find(".tt-pn-image").appendTo(this);
                    gsap.to($ball, { duration: 0.3, width: $ballWidth, height: $ballHeight, opacity: $ballOpacity });

                    if ($(".tt-pn-image video").length) {
                        $(".tt-pn-image video").get(0).pause();
                    }
                });
            });
            $(".tt-pn-link").addClass("not-hide-cursor");
        } else {
            $(".tt-pn-link").removeClass("not-hide-cursor");
        }

        
        // Show/hide magic cursor
        // =======================

        // Hide on hover.
        $("a, button, .tt-btn, .tt-form-control, .tt-form-radio, .tt-form-check, .hide-cursor") // class "hide-cursor" is for global use.
        .not(".not-hide-cursor") // omit from selection (class "not-hide-cursor" is for global use).
        .not(".cursor-alter") // omit from selection
        .not(".tt-main-menu-list > li > a") // omit from selection
        .not(".tt-main-menu-list > li > .tt-submenu-trigger > a") // omit from selection
        .on("mouseenter", function() {
            gsap.to($ball, { duration: 0.3, scale: 0, opacity: 0 });
        }).on("mouseleave", function() {
            gsap.to($ball, { duration: 0.3, scale: $ballScale, opacity: $ballOpacity });
        });

        // Hide on click.
        $("a")
            .not('[target="_blank"]') // omit from selection.
            .not('[href^="#"]') // omit from selection.
            .not('[href^="mailto"]') // omit from selection.
            .not('[href^="tel"]') // omit from selection.
            .not(".lg-trigger") // omit from selection.
            .on('click', function() {
                gsap.to($ball, { duration: 0.3, scale: 1.3, autoAlpha: 0 });
        });

        // Show/hide on document leave/enter.
        $(document).on("mouseleave", function() {
            gsap.to("#magic-cursor", { duration: 0.3, autoAlpha: 0 });
        }).on("mouseenter", function() {
            gsap.to("#magic-cursor", {duration: 0.3, autoAlpha: 1 });
        });

        // Show as the mouse moves.
        $(document).mousemove(function() {
            gsap.to("#magic-cursor", {duration: 0.3, autoAlpha: 1 });
        });
    }
}

Zerion Mini Shell 1.0