!function (i) {
i.fn.theiaStickySidebar = function (t) {
function e(t, e) {
var a = o(t, e);
a || (console.log("TSS: Body width smaller than options.minWidth. Init is delayed."), i(document).on("scroll." + t.namespace, function (t, e) {
return function (a) {
var n = o(t, e);
n && i(this).unbind(a)
}
}(t, e)), i(window).on("resize." + t.namespace, function (t, e) {
return function (a) {
var n = o(t, e);
n && i(this).unbind(a)
}
}(t, e)))
}
function o(t, e) {
return t.initialized === !0 || !(i("body").width() < t.minWidth) && (a(t, e), !0)
}
function a(t, e) {
t.initialized = !0;
var o = i("#theia-sticky-sidebar-stylesheet-" + t.namespace);
0 === o.length && i("head").append(i('')), e.each(function () {
function e() {
a.fixedScrollTop = 0, a.sidebar.css({"min-height": "1px"}), a.stickySidebar.css({
position: "static",
width: "",
transform: "none"
})
}
function o(t) {
var e = t.height();
return t.children().each(function () {
e = Math.max(e, i(this).height())
}), e
}
var a = {};
if (a.sidebar = i(this), a.options = t || {}, a.container = i(a.options.containerSelector), 0 == a.container.length && (a.container = a.sidebar.parent()), a.sidebar.parents().css("-webkit-transform", "none"), a.sidebar.css({
position: a.options.defaultPosition,
overflow: "visible",
"-webkit-box-sizing": "border-box",
"-moz-box-sizing": "border-box",
"box-sizing": "border-box"
}), a.stickySidebar = a.sidebar.find(".theiaStickySidebar"), 0 == a.stickySidebar.length) {
var s = /(?:text|application)\/(?:x-)?(?:javascript|ecmascript)/i;
a.sidebar.find("script").filter(function (i, t) {
return 0 === t.type.length || t.type.match(s)
}).remove(), a.stickySidebar = i("
").addClass("theiaStickySidebar").append(a.sidebar.children()), a.sidebar.append(a.stickySidebar)
}
a.marginBottom = parseInt(a.sidebar.css("margin-bottom")), a.paddingTop = parseInt(a.sidebar.css("padding-top")), a.paddingBottom = parseInt(a.sidebar.css("padding-bottom"));
var r = a.stickySidebar.offset().top, d = a.stickySidebar.outerHeight();
a.stickySidebar.css("padding-top", 1), a.stickySidebar.css("padding-bottom", 1), r -= a.stickySidebar.offset().top, d = a.stickySidebar.outerHeight() - d - r, 0 == r ? (a.stickySidebar.css("padding-top", 0), a.stickySidebarPaddingTop = 0) : a.stickySidebarPaddingTop = 1, 0 == d ? (a.stickySidebar.css("padding-bottom", 0), a.stickySidebarPaddingBottom = 0) : a.stickySidebarPaddingBottom = 1, a.previousScrollTop = null, a.fixedScrollTop = 0, e(), a.onScroll = function (a) {
if (a.stickySidebar.is(":visible")) {
if (i("body").width() < a.options.minWidth)return void e();
if (a.options.disableOnResponsiveLayouts) {
var s = a.sidebar.outerWidth("none" == a.sidebar.css("float"));
if (s + 50 > a.container.width())return void e()
}
var r = i(document).scrollTop(), d = "static";
if (r >= a.sidebar.offset().top + (a.paddingTop - a.options.additionalMarginTop)) {
var c, p = a.paddingTop + t.additionalMarginTop, b = a.paddingBottom + a.marginBottom + t.additionalMarginBottom, l = a.sidebar.offset().top, f = a.sidebar.offset().top + o(a.container), h = 0 + t.additionalMarginTop, g = a.stickySidebar.outerHeight() + p + b < i(window).height();
c = g ? h + a.stickySidebar.outerHeight() : i(window).height() - a.marginBottom - a.paddingBottom - t.additionalMarginBottom;
var u = l - r + a.paddingTop, S = f - r - a.paddingBottom - a.marginBottom, y = a.stickySidebar.offset().top - r, m = a.previousScrollTop - r;
"fixed" == a.stickySidebar.css("position") && "modern" == a.options.sidebarBehavior && (y += m), "stick-to-top" == a.options.sidebarBehavior && (y = t.additionalMarginTop), "stick-to-bottom" == a.options.sidebarBehavior && (y = c - a.stickySidebar.outerHeight()), y = m > 0 ? Math.min(y, h) : Math.max(y, c - a.stickySidebar.outerHeight()), y = Math.max(y, u), y = Math.min(y, S - a.stickySidebar.outerHeight());
var k = a.container.height() == a.stickySidebar.outerHeight();
d = (k || y != h) && (k || y != c - a.stickySidebar.outerHeight()) ? r + y - a.sidebar.offset().top - a.paddingTop <= t.additionalMarginTop ? "static" : "absolute" : "fixed"
}
if ("fixed" == d) {
var v = i(document).scrollLeft();
a.stickySidebar.css({
position: "fixed",
width: n(a.stickySidebar) + "px",
transform: "translateY(" + y + "px)",
left: a.sidebar.offset().left + parseInt(a.sidebar.css("padding-left")) - v + "px",
top: "0px"
})
} else if ("absolute" == d) {
var x = {};
"absolute" != a.stickySidebar.css("position") && (x.position = "absolute", x.transform = "translateY(" + (r + y - a.sidebar.offset().top - a.stickySidebarPaddingTop - a.stickySidebarPaddingBottom) + "px)", x.top = "0px"), x.width = n(a.stickySidebar) + "px", x.left = "", a.stickySidebar.css(x)
} else"static" == d && e();
"static" != d && 1 == a.options.updateSidebarHeight && a.sidebar.css({"min-height": a.stickySidebar.outerHeight() + a.stickySidebar.offset().top - a.sidebar.offset().top + a.paddingBottom}), a.previousScrollTop = r
}
}, a.onScroll(a), i(document).on("scroll." + a.options.namespace, function (i) {
return function () {
i.onScroll(i)
}
}(a)), i(window).on("resize." + a.options.namespace, function (i) {
return function () {
i.stickySidebar.css({position: "static"}), i.onScroll(i)
}
}(a)), "undefined" != typeof ResizeSensor && new ResizeSensor(a.stickySidebar[0], function (i) {
return function () {
i.onScroll(i)
}
}(a))
})
}
function n(i) {
var t;
try {
t = i[0].getBoundingClientRect().width
} catch (i) {
}
return "undefined" == typeof t && (t = i.width()), t
}
var s = {
containerSelector: "",
additionalMarginTop: 0,
additionalMarginBottom: 0,
updateSidebarHeight: !0,
minWidth: 0,
disableOnResponsiveLayouts: !0,
sidebarBehavior: "modern",
defaultPosition: "relative",
namespace: "TSS"
};
return t = i.extend(s, t), t.additionalMarginTop = parseInt(t.additionalMarginTop) || 0, t.additionalMarginBottom = parseInt(t.additionalMarginBottom) || 0, e(t, this), this
}
}(jQuery);
//# sourceMappingURL=maps/theia-sticky-sidebar.min.js.map