HEX
Server: Apache
System: Linux c037.dattaweb.com 3.10.0-1160.119.1.el7.x86_64 #1 SMP Tue Jun 4 14:43:51 UTC 2024 x86_64
User: c0400220 (20588)
PHP: 7.4.33
Disabled: system, shell, exec, system_exec, shell_exec, mysql_pconnect, passthru, popen, proc_open, proc_close, proc_nice, proc_terminate, proc_get_status, escapeshellarg, escapeshellcmd, eval, dl, imap_mail, libvirt_connect, gnupg_init, unsetenv, apache_setenv, pcntl_exec, pcntl_alarm, pcntl_fork, pcntl_waitpid, pcntl_wait, pcntl_wifexited, pcntl_wifstopped, pcntl_wifsignaled, pcntl_wifcontinued, pcntl_wexitstatus, pcntl_wtermsig, pcntl_wstopsig, pcntl_signal, pcntl_signal_get_handler, pcntl_signal_dispatch, pcntl_get_last_error, pcntl_strerror, pcntl_sigprocmask, pcntl_sigwaitinfo, pcntl_sigtimedwait, pcntl_getpriority, pcntl_setpriority, pcntl_async_signals, opcache_get_status, opcache_reset, opcache_get_configuration
Upload Files
File: /home/c0400220/public_html/wp-content/plugins/aapside-master/assets/js/jquery.smoove.js
/*!
* jQuery Smoove v0.2.11 (http://smoove.js.org/)
* Copyright (c) 2017 Adam Bouqdib
* Licensed under GPL-2.0 (http://abemedia.co.uk/license) 
*/

(function($, window, document) {

  // function for adding vendor prefixes
  function crossBrowser(property, value, prefix) {

    function ucase(string) {
      return string.charAt(0).toUpperCase() + string.slice(1);
    }

    var vendor = ['webkit', 'moz', 'ms', 'o'],
      properties = {};

    for (var i = 0; i < vendor.length; i++) {
      if (prefix) {
        value = value.replace(prefix, '-' + vendor[i] + '-' + prefix);
      }
      properties[ucase(vendor[i]) + ucase(property)] = value;
    }
    properties[property] = value;

    return properties;
  }

  function smooveIt(direction) {
    var height = $(window).height(),
      width = $(window).width();

    for (var i = 0; i < $.fn.smoove.items.length; i++) {
      var $item = $.fn.smoove.items[i],
        params = $item.params;
		
		if(!$item.hasClass('smooved'))
		{	
	      // if direction isn't set, set offset to 0 to avoid hiding objects that are above the fold
	      var offset = (!direction || direction === 'down' && $item.css('opacity') === '1') ? 0 : params.offset,
	        itemtop = $(window).scrollTop() + height - $item.offset().top;

	
	      // offset in %
	      if (typeof offset === 'string' && offset.indexOf('%')) {
	        offset = parseInt(offset) / 100 * height;
	        //console.log('offset '+offset+' | itemTop '+itemtop);
	      }
	      
	      if (itemtop < offset || direction == 'first') {
		      
			  if (!isNaN(params.opacity)) {
			    $item.css({
			      opacity: params.opacity
			    });
			  }
	
	        var transforms = [],
	          properties = ['move', 'move3D', 'moveX', 'moveY', 'moveZ', 'rotate', 'rotate3d', 'rotateX', 'rotateY', 'rotateZ', 'scale', 'scale3d', 'scaleX', 'scaleY', 'skew', 'skewX', 'skewY'];
	
	        for (var p = 0; p < properties.length; p++) {
	          if (typeof params[properties[p]] !== "undefined") {
	            transforms[properties[p]] = params[properties[p]];
	          }
	        }
			
	        var transform = '';
	        for (var t in transforms) {
	          transform += t.replace('move', 'translate') + '(' + transforms[t] + ') ';
	        }
	        
	        if (transform) {
	          $item.css(crossBrowser('transform', transform));
	          $item.parent().css(crossBrowser('perspective', params.perspective));
	          //$item.parent().css(crossBrowser('transformStyle', params.transformstyle));
	
	          if (params.transformOrigin) {
	            $item.css(crossBrowser('transformOrigin', params.transformOrigin));
	          }
	        }
	        
	        if(typeof params.delay !== "undefined" && params.delay > 0)
	        {
		        $item.css('transition-delay', parseInt(params.delay)+'ms');
	        }
	        
	        $item.addClass('first_smooved');
	        
	        /*if($item.hasClass('elementor-widget-image'))
	        {
		        console.log(itemtop + '<' + offset);
	        }*/
	        
	      } else {
		      	if(!$item.hasClass('first_smooved') === true)
			  	{
			      	$item.stop().css('opacity', 1).css(crossBrowser('transform', 'translate(0px, 0px)')).css('transform', '');
				  	$item.addClass('smooved');
				  	$item.parent().addClass('smooved');
				}
				else
				{
					jQuery('body').addClass('has-smoove');
					
					//if(itemtop < offset || jQuery(window).height() >= jQuery(document).height())
					if(itemtop < offset)
					{
						$item.stop().delay(1000).queue(function (next) { 
						    jQuery(this).stop().css('opacity', 1).css(crossBrowser('transform', 'translate(0px, 0px)')).css('transform', '');
						    $item.addClass('smooved');
							$item.parent().addClass('smooved');
							$item.removeClass('first_smooved');
						    next(); 
						});
					}
					else
					{
						$item.stop().delay(1000).queue(function (next) { 
							window.scrollTo(window.scrollX, window.scrollY+1);
						});
						
						$item.removeClass('first_smooved');
					}
				}
	      }
	    }
    }
  }

  function throttle(fn, threshhold, scope) {
    threshhold = threshhold || 250;
    var last, deferTimer;
    return function() {
      var context = scope || this,
        now = +new Date(),
        args = arguments;
      if (last && now < last + threshhold) {
        // hold on to it
        clearTimeout(deferTimer);
        deferTimer = setTimeout(function() {
          last = now;
          fn.apply(context, args);
        }, threshhold);
      } else {
        last = now;
        fn.apply(context, args);
      }
    };
  }

  $.fn.smoove = function(options) {
    $.fn.smoove.init(this, $.extend({}, $.fn.smoove.defaults, options));
    return this;
  };

  $.fn.smoove.items = [];
  $.fn.smoove.loaded = false;

  $.fn.smoove.defaults = {
    offset: '50%',
    opacity: 0,
    delay: '0ms',
    duration: '500ms',
    transition: "",
    transformStyle: 'preserve-3d',
    transformOrigin: false,
    perspective: 1000,
    min_width: 768,
    min_height: false
  };

  $.fn.smoove.init = function(items, settings) {
	  
    items.each(function() {
      var $item = $(this),
        params = $item.params = $.extend({}, settings, $item.data());

      $item.data('top', $item.offset().top);

      params.transition = crossBrowser('transition', params.transition, 'transform');
      $item.css(params.transition);

      $.fn.smoove.items.push($item);
    });

    // add event handlers
    if (!$.fn.smoove.loaded) {
      $.fn.smoove.loaded = true;

      var oldScroll = 0,
        oldHeight = $(window).height(),
        oldWidth = $(window).width(),
        oldDocHeight = $(document).height(),
        resizing;

      // naughty way of avoiding vertical scrollbars when items slide in/out from the side
      if ($('body').width() === $(window).width()) {
        $('body').addClass('smoove-overflow');
      }

      /*$(window).on("orientationchange resize", function() {
        clearTimeout(resizing);
        resizing = setTimeout(function() {
          var height = $(window).height(),
            width = $(window).width(),
            direction = (oldHeight > height) ? direction = 'up' : 'down',
            items = $.fn.smoove.items;

          oldHeight = height;

          // responsive support - reassign position values on resize
          if (oldWidth !== width) {
            for (var i = 0; i < items.length; i++) {
              items[i].css(crossBrowser('transform', '')).css(crossBrowser('transition', ''));
            }

            // wait for responsive magic to finish
            var stillResizing = setInterval(function() {
              var docHeight = $(document).height();
              if (docHeight === oldDocHeight) {
                window.clearInterval(stillResizing);
                for (var i = 0; i < items.length; i++) {
                  items[i].data('top', items[i].offset().top);
                  items[i].css(items[i].params.transition);
                }
                smooveIt(direction);
              }
              oldDocHeight = docHeight;
            }, 500);
          } else {
            //smooveIt(direction);
          }
          oldWidth = width;
        }, 500);
      });*/
      
      //Add iframe handler for Elementor editor
      if($('body').hasClass('elementor-editor-active'))
      {
	      $('iframe#elementor-preview-iframe').ready(function(){
	          smooveIt('first');

	        // throttle scroll handler
	        $(window).on('scroll', throttle(function() {
	          var scrolltop = $(window).scrollTop(),
	            direction = (scrolltop < oldScroll) ? direction = 'up' : 'down';
	          oldScroll = scrolltop;
	          smooveIt(direction);
	        }, 250));
	        
	        window.scrollTo(window.scrollX, window.scrollY+1);
	      });
	   }
	   else
	   {
		   $(window).on('load', function() {
	        smooveIt('first');
			
	        // throttle scroll handler
	        $(window).on('scroll', throttle(function() {
	          var scrolltop = $(window).scrollTop(),
	            direction = (scrolltop < oldScroll) ? direction = 'up' : 'down';
	          oldScroll = scrolltop;
	          smooveIt(direction);
	          
	        }, 250));
	        
	        if(jQuery(window).height() >= jQuery(document).height())
	        {
		        smooveIt('down');
	        }
	        
	        //Firefox hack for firing first event
	        var isFirefox = navigator.userAgent.toLowerCase().indexOf('firefox') > -1;
	        if (isFirefox) {
	        	window.scrollTo(window.scrollX, window.scrollY+1);
	        }
	        
	        //Touch devices hack for firing first event
	        var isTouch = ('ontouchstart' in document.documentElement);
	        if ( isTouch ) {
		        window.scrollTo(window.scrollX, window.scrollY+1);
		    }
	        
	      });
	   }
    }
  };

}(jQuery, window, document));