wp/wp-content/themes/themeforest-2964855-scrn-responsive-single-page-portfolio/SCRN/js/jquery.sticky.js
author ymh <ymh.work@gmail.com>
Mon, 14 Oct 2019 17:39:30 +0200
changeset 7 cf61fcea0001
parent 0 d970ebf37754
permissions -rwxr-xr-x
resynchronize code repo with production
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     1
// Sticky Plugin
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     2
// =============
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     3
// Author: Anthony Garand
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     4
// Improvements by German M. Bravo (Kronuz) and Ruud Kamphuis (ruudk)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     5
// Improvements by Leonardo C. Daronco (daronco)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     6
// Created: 2/14/2011
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     7
// Date: 2/12/2012
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     8
// Website: http://labs.anthonygarand.com/sticky
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     9
// Description: Makes an element on the page stick on the screen as you scroll
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    10
//              It will only set the 'top' and 'position' of your element, you
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    11
//              might need to adjust the width in some cases.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    12
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    13
(function($) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    14
    var defaults = {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    15
            topSpacing: 0,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    16
            bottomSpacing: 0,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    17
            className: 'is-sticky',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    18
            wrapperClassName: 'sticky-wrapper'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
        },
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    20
        $window = $(window),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    21
        $document = $(document),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    22
        sticked = [],
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    23
        windowHeight = $window.height(),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    24
        scroller = function() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    25
            var scrollTop = $window.scrollTop(),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    26
                documentHeight = $document.height(),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    27
                dwh = documentHeight - windowHeight,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    28
                extra = (scrollTop > dwh) ? dwh - scrollTop : 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    29
            for (var i = 0; i < sticked.length; i++) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    30
                var s = sticked[i],
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    31
                    elementTop = s.stickyWrapper.offset().top,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    32
                    etse = elementTop - s.topSpacing - extra;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    33
                if (scrollTop <= etse) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    34
                    if (s.currentTop !== null) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    35
                        s.stickyElement
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    36
                            .css('position', '')
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    37
                            .css('top', '')
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    38
                            .removeClass(s.className);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    39
                        s.stickyElement.parent().removeClass(s.className);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    40
                        s.currentTop = null;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    41
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    42
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    43
                else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    44
                    var newTop = documentHeight - s.stickyElement.outerHeight()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    45
                        - s.topSpacing - s.bottomSpacing - scrollTop - extra;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    46
                    if (newTop < 0) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    47
                        newTop = newTop + s.topSpacing;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    48
                    } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    49
                        newTop = s.topSpacing;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    50
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    51
                    if (s.currentTop != newTop) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    52
                        s.stickyElement
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    53
                            .css('position', 'fixed')
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    54
                            .css('top', newTop)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    55
                            .addClass(s.className);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    56
                        s.stickyElement.parent().addClass(s.className);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    57
                        s.currentTop = newTop;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    58
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    59
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    60
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    61
        },
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    62
        resizer = function() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    63
            windowHeight = $window.height();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    64
        },
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    65
        methods = {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    66
            init: function(options) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    67
                var o = $.extend(defaults, options);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    68
                return this.each(function() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    69
                    var stickyElement = $(this);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    70
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    71
                    stickyId = stickyElement.attr('id');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    72
                    wrapper = $('<div></div>')
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    73
                        .attr('id', stickyId + '-sticky-wrapper')
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    74
                        .addClass(o.wrapperClassName);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    75
                    stickyElement.wrapAll(wrapper);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    76
                    var stickyWrapper = stickyElement.parent();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    77
                    stickyWrapper.css('height', stickyElement.outerHeight());
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    78
                    sticked.push({
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    79
                        topSpacing: o.topSpacing,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    80
                        bottomSpacing: o.bottomSpacing,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    81
                        stickyElement: stickyElement,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    82
                        currentTop: null,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    83
                        stickyWrapper: stickyWrapper,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    84
                        className: o.className
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    85
                    });
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    86
                });
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    87
            },
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    88
            update: scroller
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    89
        };
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    90
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    91
    // should be more efficient than using $window.scroll(scroller) and $window.resize(resizer):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    92
    if (window.addEventListener) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    93
        window.addEventListener('scroll', scroller, false);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    94
        window.addEventListener('resize', resizer, false);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    95
    } else if (window.attachEvent) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    96
        window.attachEvent('onscroll', scroller);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    97
        window.attachEvent('onresize', resizer);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    98
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    99
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   100
    $.fn.sticky = function(method) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   101
        if (methods[method]) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   102
            return methods[method].apply(this, Array.prototype.slice.call(arguments, 1));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   103
        } else if (typeof method === 'object' || !method ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   104
            return methods.init.apply( this, arguments );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   105
        } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   106
            $.error('Method ' + method + ' does not exist on jQuery.sticky');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   107
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   108
    };
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   109
    $(function() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   110
        setTimeout(scroller, 0);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   111
    });
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   112
})(jQuery);