MMCT TEAM
Server IP : 162.214.80.37  /  Your IP : 216.73.216.83
Web Server : Apache
System : Linux sh013.webhostingservices.com 4.19.286-203.ELK.el7.x86_64 #1 SMP Wed Jun 14 04:33:55 CDT 2023 x86_64
User : imyrqtmy ( 2189)
PHP Version : 8.2.18
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON
Directory (0755) :  /home2/imyrqtmy/public_html/lashadesigns/js/

[  Home  ][  C0mmand  ][  Upload File  ]

Current File : /home2/imyrqtmy/public_html/lashadesigns/js/infinityslide.js
/*以下、jsファイル内の記述のためコピー不要******************************/

//【infiniteslidev2.js】

/*
   infiniteslide.js v2
   version: 2.0.1
   Author: T.Morimoto
   
   Copyright 2017, T.Morimoto
   * Free to use and abuse under the MIT license.
   * http://www.opensource.org/licenses/mit-license.php
   
   https://github.com/woodroots/infiniteslidev2
   */

(function ($) {
    $(window).on("load", function () {
        window.loaded = true;
    });
    $(function () {
        $.fn.infiniteslide = function (options) {
            //option
            var settings = $.extend(
                {
                    speed: 100, //速さ 単位はpx/秒です。
                    direction: "left", //up/down/left/rightから選択
                    pauseonhover: true, //マウスオーバーでストップ
                    responsive: false, //子要素の幅を%で指定しているとき
                    clone: 1,
                },
                options
            );

            var setCss = function (obj, direction) {
                $(obj)
                    .wrap('<div class="infiniteslide_wrap"></div>')
                    .parent()
                    .css({
                        overflow: "hidden",
                    });

                if (direction == "up" || direction == "down") {
                    var d = "column";
                } else {
                    var d = "row";
                }

                $(obj)
                    .css({
                        display: "flex",
                        flexWrap: "nowrap",
                        alignItems: "center",
                        "-ms-flex-align": "center",
                        flexDirection: d,
                    })
                    .children()
                    .css({
                        flex: "none",
                        display: "block",
                    });
            };

            var setClone = function (obj, clone) {
                var $clone = $(obj)
                    .children()
                    .clone(true)
                    .addClass("infiniteslide_clone");
                i = 1;
                while (i <= clone) {
                    $clone.clone(true).appendTo($(obj));
                    i++;
                }
            };

            var getWidth = function (obj) {
                w = 0;
                $(obj)
                    .children(":not(.infiniteslide_clone)")
                    .each(function (key, value) {
                        w = w + $(this).outerWidth(true);
                    });
                return w;
            };
            var getHeight = function (obj) {
                h = 0;
                $(obj)
                    .children(":not(.infiniteslide_clone)")
                    .each(function (key, value) {
                        h = h + $(this).outerHeight(true);
                    });
                return h;
            };

            var getSpeed = function (l, s) {
                return l / s;
            };
            var getNum = function (obj, direction) {
                if (direction == "up" || direction == "down") {
                    var num = getHeight(obj);
                } else {
                    var num = getWidth(obj);
                }
                return num;
            };

            var getTranslate = function (num, direction) {
                if (direction == "up" || direction == "down") {
                    var i = "0,-" + num + "px,0";
                } else {
                    var i = "-" + num + "px,0,0";
                }
                return i;
            };

            var setAnim = function (obj, id, direction, speed) {
                var num = getNum(obj, direction);
                if (direction == "up" || direction == "down") {
                    $(obj)
                        .parent(".infiniteslide_wrap")
                        .css({
                            height: num + "px",
                        });
                }
                var i = getTranslate(num, direction);

                $(obj).attr("data-style", "infiniteslide" + id);

                var css =
                    "@keyframes infiniteslide" +
                    id +
                    "{" +
                    "from {transform:translate3d(0,0,0);}" +
                    "to {transform:translate3d(" +
                    i +
                    ");}" +
                    "}";
                $("<style />")
                    .attr("id", "infiniteslide" + id + "_style")
                    .html(css)
                    .appendTo("head");

                if (direction == "right" || direction == "down") {
                    var reverse = " reverse";
                } else {
                    var reverse = "";
                }

                $(obj).css({
                    animation:
                        "infiniteslide" +
                        id +
                        " " +
                        getSpeed(num, speed) +
                        "s linear 0s infinite" +
                        reverse,
                });
            };
            var setStop = function (obj) {
                $(obj)
                    .on("mouseenter", function () {
                        $(this).css({
                            animationPlayState: "paused",
                        });
                    })
                    .on("mouseleave", function () {
                        $(this).css({
                            animationPlayState: "running",
                        });
                    });
            };

            var setResponsive = function (obj, direction) {
                var num = getNum(obj, direction);
                var i = getTranslate(num, direction);
                return i;
            };

            return this.each(function (key, value) {
                var $this = $(this);
                var num =
                    Date.now() + Math.floor(10000 * Math.random()).toString(16);
                if (settings.pauseonhover == true) {
                    setStop($this);
                }
                var _onload = function () {
                    setCss($this, settings.direction);
                    setClone($this, settings.clone);
                    setAnim($this, num, settings.direction, settings.speed);

                    if (settings.responsive) {
                        $(window).on("resize", function () {
                            var i = setResponsive($this, settings.direction);
                            var styleid = $this.attr("data-style");
                            var stylehtml = $("#" + styleid + "_style").html();

                            var stylehtml_new = stylehtml.replace(
                                /to {transform:translate3d\((.*?)\)/,
                                "to {transform:translate3d(" + i + ")"
                            );
                            $("#" + styleid + "_style").html(stylehtml_new);
                        });
                    }
                };

                if (window.loaded) {
                    _onload();
                } else {
                    $(window).on("load", _onload);
                }
            });
        };
    });
})(jQuery);

MMCT - 2023