// source --> https://desmark.com.ph/wp-content/plugins/sticky-menu-or-anything-on-scroll/assets/js/jq-sticky-anything.js?ver=2.1.1 
/**
 * @preserve Sticky Anything 2.22 | (c) WebFactory Ltd | GPL2 Licensed
 */

console.error(
  "PLEASE NOTE: this is just a notification that the Sticky Menu (or Anything!) plugin is now working in Debug Mode."
);
console.error(
  "Even though this mode will not impact any functionality, do NOT use this mode in production environments!"
);

(function ($) {
  $.fn.stickThis = function (options) {
    var settings = $.extend(
      {
        // Default
        top: 0,
        minscreenwidth: 0,
        maxscreenwidth: 99999,
        zindex: 1,
        legacymode: false,
        dynamicmode: false,
        debugmode: false,
        pushup: "",
        adminbar: false,
      },
      options
    );

    var numElements = $(this).length;
    var numPushElements = $(settings.pushup).length;

    if (numPushElements < 1) {
      // There are no elements on the page with the called selector for the Push-up Element.
      if (settings.debugmode == true && settings.pushup) {
        console.error(
          'STICKY ANYTHING DEBUG: There are no elements with the selector/class/ID you selected for the Push-up element ("' +
            settings.pushup +
            '").'
        );
      }
      // Resetting it to NOTHING.
      settings.pushup = "";
    } else if (numPushElements > 1) {
      // You can't use more than one element to push up the sticky element.
      // Make sure that you use a selector that applies to only ONE SINGLE element on the page.
      // Want to find out quickly where all the elements are that you targeted? Uncomment the next line to debug.
      // $(settings.pushup).css('border','solid 3px #ff0000');
      if (settings.debugmode == true) {
        console.error(
          "STICKY ANYTHING DEBUG: There are " +
            numPushElements +
            ' elements on the page with the selector/class/ID you selected for the push-up element ("' +
            settings.pushup +
            '"). You can select only ONE element to push the sticky element up.'
        );
      }
      // Resetting it to NOTHING.
      settings.pushup = "";
    }

    if (numElements < 1) {
      // There are no elements on the page with the called selector.
      if (settings.debugmode == true) {
        console.error(
          'STICKY ANYTHING DEBUG: There are no elements with the selector/class/ID you selected for the sticky element ("' +
            this.selector +
            '").'
        );
      }
    } else if (numElements > 1) {
      // This is not going to work either. You can't make more than one element sticky. They will only get in eachother's way.
      // Make sure that you use a selector that applies to only ONE SINGLE element on the page.
      // Want to find out quickly where all the elements are that you targeted? Uncomment the next line to debug.
      // $(this).css('border','solid 3px #00ff00');
      if (settings.debugmode == true) {
        console.error(
          "STICKY ANYTHING DEBUG: There There are " +
            numPushElements +
            ' elements with the selector/class/ID you selected for the sticky element ("' +
            this.selector +
            '"). You can only make ONE element sticky.'
        );
      }
    } else {
      if (settings.legacymode == true) {
        // LEGACY MODE
        $(this)
          .addClass("sticky-element-original")
          .addClass("element-is-not-sticky");
        if (settings.dynamicmode != true) {
          // Create a clone of the menu, right next to original (in the DOM) on initial page load
          createClone(settings.top, settings.zindex, settings.adminbar);
        }
        checkElement = setInterval(function () {
          stickItLegacy(
            settings.top,
            settings.minscreenwidth,
            settings.maxscreenwidth,
            settings.zindex,
            settings.pushup,
            settings.dynamicmode,
            settings.adminbar
          );
        }, 10);
      } else {
        // MODERN MODE
        $(this)
          .addClass("sticky-element-original")
          .addClass("element-is-not-sticky");
        orgAssignedStyles = cssStyles($(this)); // All original element styles, assigned by CSS.
        orgInlineStyles = $(".sticky-element-original").attr("style");
        if (orgInlineStyles == null) {
          orgInlineStyles = "";
        }
        createPlaceholder();

        checkElement = setInterval(function () {
          stickIt(
            settings.top,
            settings.minscreenwidth,
            settings.maxscreenwidth,
            settings.zindex,
            settings.pushup,
            settings.adminbar,
            orgAssignedStyles,
            orgInlineStyles
          );
        }, 10);
      }
    }

    return this;
  };

  // The new StickIt function
  function stickIt(
    stickyTop,
    minwidth,
    maxwidth,
    stickyZindex,
    pushup,
    adminbar,
    originalAssignedStyles,
    originalInlineStyles
  ) {
    // We need to check the position of the ACTIVE element.
    // This is the original one when it's not sticky, but when it's sticky, it's the placeholder.
    $listenerElement = $(".sticky-element-active");

    var orgElementPos = $listenerElement.offset();
    orgElementTop = orgElementPos.top;

    if (pushup) {
      var pushElementPos = $(pushup).offset();
      pushElementTop = pushElementPos.top;
    }

    // Calculating actual viewport width
    var e = window,
      a = "inner";
    if (!("innerWidth" in window)) {
      a = "client";
      e = document.documentElement || document.body;
    }
    viewport = e[a + "Width"];

    if (adminbar && $("body").hasClass("admin-bar") && viewport > 600) {
      // below 600, the adminbar is not fixed
      adminBarHeight = $("#wpadminbar").height();
    } else {
      adminBarHeight = 0;
    }

    if (
      $(window).scrollTop() >= orgElementTop - stickyTop - adminBarHeight &&
      viewport >= minwidth &&
      viewport <= maxwidth
    ) {
      // We've scrolled PAST the original position; this is where we need to make the element sticky.

      // Placeholder element should always have same left position as original element (see comment below).
      // The sticky element will NOT have a TOP or the LEFT margin. This is because the left/top reference point of the original
      // element does not consider the margin. So, we're checking the left/top point of the actual original element and then
      // use that position for the sticky element.

      // LEFT POSITION
      coordsOrgElement = $listenerElement.offset();
      leftOrgElement = coordsOrgElement.left; // This is the position REGARDLESS of the margin.

      // WIDTH/HEIGHT
      // The placeholder needs to have the width and height of the original element, WITHOUT the margins but WITH the padding and borders
      // Whatever margins the original has, the placeholder needs to have that too.

      widthPlaceholder = $listenerElement[0].getBoundingClientRect().width;
      if (!widthPlaceholder) {
        widthPlaceholder = $listenerElement.css("width"); // FALLBACK for subpixels
      }
      heightPlaceholder = $listenerElement[0].getBoundingClientRect().height;
      if (!heightPlaceholder) {
        heightPlaceholder = $listenerElement.css("height"); // FALLBACK for subpixels
      }

      // WIDTH/HEIGHT OF STICKY ELEMENT
      // The original element though, needs to have the inner width and height of the original (non-sticky) element
      // No padding, no borders, because that will be applied later anyway, regardless of box-sizing
      widthSticky = $(".sticky-element-original").css("width");
      if (widthSticky == "0px") {
        widthSticky = $(".sticky-element-original")[0].getBoundingClientRect()
          .width;
      }
      heightSticky = $(".sticky-element-original").height();

      // PADDING
      // If padding is percentages, convert to pixels when it becomes sticky
      // Just a leftover from the old method. We will not use padding for the placeholder
      paddingOrgElement = [
        $(".sticky-element-original").css("padding-top"),
        $(".sticky-element-original").css("padding-right"),
        $(".sticky-element-original").css("padding-bottom"),
        $(".sticky-element-original").css("padding-left"),
      ];
      paddingSticky =
        paddingOrgElement[0] +
        " " +
        paddingOrgElement[1] +
        " " +
        paddingOrgElement[2] +
        " " +
        paddingOrgElement[3];

      // MARGIN
      marginOrgElement = [
        $listenerElement.css("margin-top"),
        $listenerElement.css("margin-right"),
        $listenerElement.css("margin-bottom"),
        $listenerElement.css("margin-left"),
      ];
      marginPlaceholder =
        marginOrgElement[0] +
        " " +
        marginOrgElement[1] +
        " " +
        marginOrgElement[2] +
        " " +
        marginOrgElement[3];

      // OTHER ELEMENTS
      // if original has float, display, etc., we need to assign that to the placeholder
      // Though not as important as the width/height/margin/padding

      assignedStyles = "";
      for (var importantStyle in originalAssignedStyles) {
        if (originalAssignedStyles[importantStyle] == "inline") {
          assignedStyles += importantStyle + ":inline-block; ";
        } else {
          assignedStyles +=
            importantStyle +
            ":" +
            originalAssignedStyles[importantStyle] +
            "; ";
        }
      }

      // Fixes bug where height of original element returns zero
      // Is this still needed for the post-2.0 mode??
      elementHeight = 0;
      if (heightPlaceholder < 1) {
        elementHeight = $(".sticky-element-cloned").outerHeight();
      } else {
        elementHeight = $(".sticky-element-original").outerHeight();
      }

      // If scrolled position = pushup-element (top coordinate) - space between top and element - element height - admin bar
      // In other words, if the pushup element hits the bottom of the sticky element
      if (
        pushup &&
        $(window).scrollTop() >
          pushElementTop - stickyTop - elementHeight - adminBarHeight
      ) {
        stickyTopMargin =
          pushElementTop - stickyTop - elementHeight - $(window).scrollTop();
      } else {
        stickyTopMargin = adminBarHeight;
      }

      assignedStyles +=
        "width:" +
        widthPlaceholder +
        "px; height:" +
        heightPlaceholder +
        "px; margin:" +
        marginPlaceholder +
        ";";

      $(".sticky-element-original")
        .removeClass("sticky-element-active")
        .removeClass("element-is-not-sticky")
        .addClass("element-is-sticky")
        .css(
          "cssText",
          originalInlineStyles + "margin-top: " +
            stickyTopMargin +
            "px !important; margin-left: 0 !important"
        )
        .css("position", "fixed")
        .css("left", leftOrgElement + "px")
        .css("top", stickyTop + "px")
        .css("width", widthSticky)
        .css("padding", paddingSticky)
        .css("z-index", stickyZindex);

      if (!$(".sticky-element-placeholder").hasClass("sticky-element-active")) {
        $(".sticky-element-placeholder")
          .addClass("sticky-element-active")
          .attr("style", assignedStyles);
      }
    } else {
      // not scrolled past the menu; only show the original element.
      $(".sticky-element-original")
        .addClass("sticky-element-active")
        .removeClass("element-is-sticky")
        .addClass("element-is-not-sticky")
        .attr("style", originalInlineStyles);
      if ($(".sticky-element-placeholder").hasClass("sticky-element-active")) {
        $(".sticky-element-placeholder")
          .removeClass("sticky-element-active")
          .removeAttr("style")
          .css("width", "0")
          .css("height", "0")
          .css("margin", "0")
          .css("padding", "0");
      }
    }
  }

  function createPlaceholder() {
    $(".sticky-element-original")
      .addClass("sticky-element-active")
      .before(
        '<div class="sticky-element-placeholder" style="width:0; height:0; margin:0; padding:0; visibility:hidden;"></div>'
      );
  }

  // Helper function: get the important CSS rules from an element
  function cssStyles(el) {
    o = {};

    o["display"] = el.css("display");
    o["float"] = el.css("float");
    o["flex"] = el.css("flex");
    o["box-sizing"] = el.css("box-sizing");
    o["clear"] = el.css("clear");
    o["overflow"] = el.css("overflow");
    o["transform"] = el.css("transform");

    // For some reason, this original loop doesn't work with some themes/plugins.
    // importantStyles = ['display','float','flex','box-sizing','clear','overflow','transform'];
    // for(var styleProp in importantStyles) {
    //   o[importantStyles[styleProp]] = el.css(importantStyles[styleProp]);
    // }

    return o;
  }

  // The old StickIt function
  function stickItLegacy(
    stickyTop,
    minwidth,
    maxwidth,
    stickyZindex,
    pushup,
    dynamic,
    adminbar
  ) {
    var orgElementPos = $(".sticky-element-original").offset();
    orgElementTop = orgElementPos.top;

    if (pushup) {
      var pushElementPos = $(pushup).offset();
      pushElementTop = pushElementPos.top;
    }

    // Calculating actual viewport width
    var e = window,
      a = "inner";
    if (!("innerWidth" in window)) {
      a = "client";
      e = document.documentElement || document.body;
    }
    viewport = e[a + "Width"];

    if (adminbar && $("body").hasClass("admin-bar") && viewport > 600) {
      adminBarHeight = $("#wpadminbar").height();
    } else {
      adminBarHeight = 0;
    }

    if (
      $(window).scrollTop() >= orgElementTop - stickyTop - adminBarHeight &&
      viewport >= minwidth &&
      viewport <= maxwidth
    ) {
      // scrolled past the original position; now only show the cloned, sticky element.

      // Cloned element should always have same left position and width as original element.
      orgElement = $(".sticky-element-original");
      coordsOrgElement = orgElement.offset();
      leftOrgElement = coordsOrgElement.left;
      widthOrgElement = orgElement[0].getBoundingClientRect().width;
      if (!widthOrgElement) {
        widthOrgElement = orgElement.css("width"); // FALLBACK for subpixels
      }
      heightOrgElement = orgElement.outerHeight();

      // If padding is percentages, convert to pixels
      paddingOrgElement = [
        orgElement.css("padding-top"),
        orgElement.css("padding-right"),
        orgElement.css("padding-bottom"),
        orgElement.css("padding-left"),
      ];
      paddingCloned =
        paddingOrgElement[0] +
        " " +
        paddingOrgElement[1] +
        " " +
        paddingOrgElement[2] +
        " " +
        paddingOrgElement[3];

      if (dynamic == true && $(".sticky-element-cloned").length < 1) {
        // DYNAMIC MODE: if there is no clone present, create it right now
        createClone(stickyTop, stickyZindex);
      }

      // Fixes bug where height of original element returns zero
      elementHeight = 0;
      if (heightOrgElement < 1) {
        elementHeight = $(".sticky-element-cloned").outerHeight();
      } else {
        elementHeight = $(".sticky-element-original").outerHeight();
      }

      // If scrolled position = pushup-element (top coordinate) - space between top and element - element height - admin bar
      // In other words, if the pushup element hits the bottom of the sticky element
      if (
        pushup &&
        $(window).scrollTop() >
          pushElementTop - stickyTop - elementHeight - adminBarHeight
      ) {
        stickyTopMargin =
          pushElementTop - stickyTop - elementHeight - $(window).scrollTop();
      } else {
        stickyTopMargin = adminBarHeight;
      }

      $(".sticky-element-cloned")
        .css("left", leftOrgElement + "px")
        .css("top", stickyTop + "px")
        .css("width", widthOrgElement)
        .css("margin-top", stickyTopMargin)
        .css("padding", paddingCloned)
        .show();
      $(".sticky-element-original").css("visibility", "hidden");
    } else {
      // not scrolled past the menu; only show the original menu.
      if (dynamic == true) {
        $(".sticky-element-cloned").remove();
      } else {
        $(".sticky-element-cloned").hide();
      }
      $(".sticky-element-original").css("visibility", "visible");
    }
  }

  function createClone(cloneTop, cloneZindex) {
    $(".sticky-element-original")
      .clone()
      .insertAfter($(".sticky-element-original"))
      .addClass("sticky-element-cloned")
      .removeClass("element-is-not-sticky")
      .addClass("element-is-sticky")
      .css("position", "fixed")
      .css("top", cloneTop + "px")
      .css("margin-left", "0")
      .css("z-index", cloneZindex)
      .removeClass("sticky-element-original")
      .hide();
  }
})(jQuery);
// source --> https://desmark.com.ph/wp-content/plugins/woocommerce/assets/js/jquery-blockui/jquery.blockUI.min.js?ver=2.7.0-wc.10.6.1 
/*!
 * jQuery blockUI plugin
 * Version 2.70.0-2014.11.23
 * Requires jQuery v1.7 or later
 *
 * Examples at: http://malsup.com/jquery/block/
 * Copyright (c) 2007-2013 M. Alsup
 * Dual licensed under the MIT and GPL licenses:
 * http://www.opensource.org/licenses/mit-license.php
 * http://www.gnu.org/licenses/gpl.html
 *
 * Thanks to Amir-Hossein Sobhi for some excellent contributions!
 */
!function(){"use strict";function e(e){e.fn._fadeIn=e.fn.fadeIn;var t=e.noop||function(){},o=/MSIE/.test(navigator.userAgent),n=/MSIE 6.0/.test(navigator.userAgent)&&!/MSIE 8.0/.test(navigator.userAgent),i=(document.documentMode,"function"==typeof document.createElement("div").style.setExpression&&document.createElement("div").style.setExpression);e.blockUI=function(e){d(window,e)},e.unblockUI=function(e){a(window,e)},e.growlUI=function(t,o,n,i){var s=e('<div class="growlUI"></div>');t&&s.append("<h1>"+t+"</h1>"),o&&s.append("<h2>"+o+"</h2>"),n===undefined&&(n=3e3);var l=function(t){t=t||{},e.blockUI({message:s,fadeIn:"undefined"!=typeof t.fadeIn?t.fadeIn:700,fadeOut:"undefined"!=typeof t.fadeOut?t.fadeOut:1e3,timeout:"undefined"!=typeof t.timeout?t.timeout:n,centerY:!1,showOverlay:!1,onUnblock:i,css:e.blockUI.defaults.growlCSS})};l();s.css("opacity");s.on("mouseover",function(){l({fadeIn:0,timeout:3e4});var t=e(".blockMsg");t.stop(),t.fadeTo(300,1)}).on("mouseout",function(){e(".blockMsg").fadeOut(1e3)})},e.fn.block=function(t){if(this[0]===window)return e.blockUI(t),this;var o=e.extend({},e.blockUI.defaults,t||{});return this.each(function(){var t=e(this);o.ignoreIfBlocked&&t.data("blockUI.isBlocked")||t.unblock({fadeOut:0})}),this.each(function(){"static"==e.css(this,"position")&&(this.style.position="relative",e(this).data("blockUI.static",!0)),this.style.zoom=1,d(this,t)})},e.fn.unblock=function(t){return this[0]===window?(e.unblockUI(t),this):this.each(function(){a(this,t)})},e.blockUI.version=2.7,e.blockUI.defaults={message:"<h1>Please wait...</h1>",title:null,draggable:!0,theme:!1,css:{padding:0,margin:0,width:"30%",top:"40%",left:"35%",textAlign:"center",color:"#000",border:"3px solid #aaa",backgroundColor:"#fff",cursor:"wait"},themedCSS:{width:"30%",top:"40%",left:"35%"},overlayCSS:{backgroundColor:"#000",opacity:.6,cursor:"wait"},cursorReset:"default",growlCSS:{width:"350px",top:"10px",left:"",right:"10px",border:"none",padding:"5px",opacity:.6,cursor:"default",color:"#fff",backgroundColor:"#000","-webkit-border-radius":"10px","-moz-border-radius":"10px","border-radius":"10px"},iframeSrc:/^https/i.test(window.location.href||"")?"javascript:false":"about:blank",forceIframe:!1,baseZ:1e3,centerX:!0,centerY:!0,allowBodyStretch:!0,bindEvents:!0,constrainTabKey:!0,fadeIn:200,fadeOut:400,timeout:0,showOverlay:!0,focusInput:!0,focusableElements:":input:enabled:visible",onBlock:null,onUnblock:null,onOverlayClick:null,quirksmodeOffsetHack:4,blockMsgClass:"blockMsg",ignoreIfBlocked:!1};var s=null,l=[];function d(d,c){var u,b,h=d==window,k=c&&c.message!==undefined?c.message:undefined;if(!(c=e.extend({},e.blockUI.defaults,c||{})).ignoreIfBlocked||!e(d).data("blockUI.isBlocked")){if(c.overlayCSS=e.extend({},e.blockUI.defaults.overlayCSS,c.overlayCSS||{}),u=e.extend({},e.blockUI.defaults.css,c.css||{}),c.onOverlayClick&&(c.overlayCSS.cursor="pointer"),b=e.extend({},e.blockUI.defaults.themedCSS,c.themedCSS||{}),k=k===undefined?c.message:k,h&&s&&a(window,{fadeOut:0}),k&&"string"!=typeof k&&(k.parentNode||k.jquery)){var y=k.jquery?k[0]:k,m={};e(d).data("blockUI.history",m),m.el=y,m.parent=y.parentNode,m.display=y.style.display,m.position=y.style.position,m.parent&&m.parent.removeChild(y)}e(d).data("blockUI.onUnblock",c.onUnblock);var g,v,I,w,U=c.baseZ;g=o||c.forceIframe?e('<iframe class="blockUI" style="z-index:'+U+++';display:none;border:none;margin:0;padding:0;position:absolute;width:100%;height:100%;top:0;left:0" src="'+c.iframeSrc+'"></iframe>'):e('<div class="blockUI" style="display:none"></div>'),v=c.theme?e('<div class="blockUI blockOverlay ui-widget-overlay" style="z-index:'+U+++';display:none"></div>'):e('<div class="blockUI blockOverlay" style="z-index:'+U+++';display:none;border:none;margin:0;padding:0;width:100%;height:100%;top:0;left:0"></div>'),c.theme&&h?(w='<div class="blockUI '+c.blockMsgClass+' blockPage ui-dialog ui-widget ui-corner-all" style="z-index:'+(U+10)+';display:none;position:fixed">',c.title&&(w+='<div class="ui-widget-header ui-dialog-titlebar ui-corner-all blockTitle">'+(c.title||"&nbsp;")+"</div>"),w+='<div class="ui-widget-content ui-dialog-content"></div>',w+="</div>"):c.theme?(w='<div class="blockUI '+c.blockMsgClass+' blockElement ui-dialog ui-widget ui-corner-all" style="z-index:'+(U+10)+';display:none;position:absolute">',c.title&&(w+='<div class="ui-widget-header ui-dialog-titlebar ui-corner-all blockTitle">'+(c.title||"&nbsp;")+"</div>"),w+='<div class="ui-widget-content ui-dialog-content"></div>',w+="</div>"):w=h?'<div class="blockUI '+c.blockMsgClass+' blockPage" style="z-index:'+(U+10)+';display:none;position:fixed"></div>':'<div class="blockUI '+c.blockMsgClass+' blockElement" style="z-index:'+(U+10)+';display:none;position:absolute"></div>',I=e(w),k&&(c.theme?(I.css(b),I.addClass("ui-widget-content")):I.css(u)),c.theme||v.css(c.overlayCSS),v.css("position",h?"fixed":"absolute"),(o||c.forceIframe)&&g.css("opacity",0);var x=[g,v,I],C=e(h?"body":d);e.each(x,function(){this.appendTo(C)}),c.theme&&c.draggable&&e.fn.draggable&&I.draggable({handle:".ui-dialog-titlebar",cancel:"li"});var S=i&&(!e.support.boxModel||e("object,embed",h?null:d).length>0);if(n||S){if(h&&c.allowBodyStretch&&e.support.boxModel&&e("html,body").css("height","100%"),(n||!e.support.boxModel)&&!h)var E=p(d,"borderTopWidth"),O=p(d,"borderLeftWidth"),T=E?"(0 - "+E+")":0,M=O?"(0 - "+O+")":0;e.each(x,function(e,t){var o=t[0].style;if(o.position="absolute",e<2)h?o.setExpression("height","Math.max(document.body.scrollHeight, document.body.offsetHeight) - (jQuery.support.boxModel?0:"+c.quirksmodeOffsetHack+') + "px"'):o.setExpression("height",'this.parentNode.offsetHeight + "px"'),h?o.setExpression("width",'jQuery.support.boxModel && document.documentElement.clientWidth || document.body.clientWidth + "px"'):o.setExpression("width",'this.parentNode.offsetWidth + "px"'),M&&o.setExpression("left",M),T&&o.setExpression("top",T);else if(c.centerY)h&&o.setExpression("top",'(document.documentElement.clientHeight || document.body.clientHeight) / 2 - (this.offsetHeight / 2) + (blah = document.documentElement.scrollTop ? document.documentElement.scrollTop : document.body.scrollTop) + "px"'),o.marginTop=0;else if(!c.centerY&&h){var n="((document.documentElement.scrollTop ? document.documentElement.scrollTop : document.body.scrollTop) + "+(c.css&&c.css.top?parseInt(c.css.top,10):0)+') + "px"';o.setExpression("top",n)}})}if(k&&(c.theme?I.find(".ui-widget-content").append(k):I.append(k),(k.jquery||k.nodeType)&&e(k).show()),(o||c.forceIframe)&&c.showOverlay&&g.show(),c.fadeIn){var B=c.onBlock?c.onBlock:t,j=c.showOverlay&&!k?B:t,H=k?B:t;c.showOverlay&&v._fadeIn(c.fadeIn,j),k&&I._fadeIn(c.fadeIn,H)}else c.showOverlay&&v.show(),k&&I.show(),c.onBlock&&c.onBlock.bind(I)();if(r(1,d,c),h?(s=I[0],l=e(c.focusableElements,s),c.focusInput&&setTimeout(f,20)):function(e,t,o){var n=e.parentNode,i=e.style,s=(n.offsetWidth-e.offsetWidth)/2-p(n,"borderLeftWidth"),l=(n.offsetHeight-e.offsetHeight)/2-p(n,"borderTopWidth");t&&(i.left=s>0?s+"px":"0");o&&(i.top=l>0?l+"px":"0")}(I[0],c.centerX,c.centerY),c.timeout){var z=setTimeout(function(){h?e.unblockUI(c):e(d).unblock(c)},c.timeout);e(d).data("blockUI.timeout",z)}}}function a(t,o){var n,i,d=t==window,a=e(t),u=a.data("blockUI.history"),f=a.data("blockUI.timeout");f&&(clearTimeout(f),a.removeData("blockUI.timeout")),o=e.extend({},e.blockUI.defaults,o||{}),r(0,t,o),null===o.onUnblock&&(o.onUnblock=a.data("blockUI.onUnblock"),a.removeData("blockUI.onUnblock")),i=d?e(document.body).children().filter(".blockUI").add("body > .blockUI"):a.find(">.blockUI"),o.cursorReset&&(i.length>1&&(i[1].style.cursor=o.cursorReset),i.length>2&&(i[2].style.cursor=o.cursorReset)),d&&(s=l=null),o.fadeOut?(n=i.length,i.stop().fadeOut(o.fadeOut,function(){0==--n&&c(i,u,o,t)})):c(i,u,o,t)}function c(t,o,n,i){var s=e(i);if(!s.data("blockUI.isBlocked")){t.each(function(e,t){this.parentNode&&this.parentNode.removeChild(this)}),o&&o.el&&(o.el.style.display=o.display,o.el.style.position=o.position,o.el.style.cursor="default",o.parent&&o.parent.appendChild(o.el),s.removeData("blockUI.history")),s.data("blockUI.static")&&s.css("position","static"),"function"==typeof n.onUnblock&&n.onUnblock(i,n);var l=e(document.body),d=l.width(),a=l[0].style.width;l.width(d-1).width(d),l[0].style.width=a}}function r(t,o,n){var i=o==window,l=e(o);if((t||(!i||s)&&(i||l.data("blockUI.isBlocked")))&&(l.data("blockUI.isBlocked",t),i&&n.bindEvents&&(!t||n.showOverlay))){var d="mousedown mouseup keydown keypress keyup touchstart touchend touchmove";t?e(document).on(d,n,u):e(document).off(d,u)}}function u(t){if("keydown"===t.type&&t.keyCode&&9==t.keyCode&&s&&t.data.constrainTabKey){var o=l,n=!t.shiftKey&&t.target===o[o.length-1],i=t.shiftKey&&t.target===o[0];if(n||i)return setTimeout(function(){f(i)},10),!1}var d=t.data,a=e(t.target);return a.hasClass("blockOverlay")&&d.onOverlayClick&&d.onOverlayClick(t),a.parents("div."+d.blockMsgClass).length>0||0===a.parents().children().filter("div.blockUI").length}function f(e){if(l){var t=l[!0===e?l.length-1:0];t&&t.trigger("focus")}}function p(t,o){return parseInt(e.css(t,o),10)||0}}"function"==typeof define&&define.amd&&define.amd.jQuery?define(["jquery"],e):e(jQuery)}();