/*! Waypoints - 4.0.0 Copyright © 2011-2015 Caleb Troughton Licensed under the MIT license. https://github.com/imakewebthings/waypoints/blog/master/licenses.txt */ !(function () { "use strict"; function t(o) { if (!o) throw new Error("No options passed to Waypoint constructor"); if (!o.element) throw new Error("No element option passed to Waypoint constructor"); if (!o.handler) throw new Error("No handler option passed to Waypoint constructor"); (this.key = "waypoint-" + e), (this.options = t.Adapter.extend({}, t.defaults, o)), (this.element = this.options.element), (this.adapter = new t.Adapter(this.element)), (this.callback = o.handler), (this.axis = this.options.horizontal ? "horizontal" : "vertical"), (this.enabled = this.options.enabled), (this.triggerPoint = null), (this.group = t.Group.findOrCreate({ name: this.options.group, axis: this.axis })), (this.context = t.Context.findOrCreateByElement(this.options.context)), t.offsetAliases[this.options.offset] && (this.options.offset = t.offsetAliases[this.options.offset]), this.group.add(this), this.context.add(this), (i[this.key] = this), (e += 1); } var e = 0, i = {}; (t.prototype.queueTrigger = function (t) { this.group.queueTrigger(this, t); }), (t.prototype.trigger = function (t) { this.enabled && this.callback && this.callback.apply(this, t); }), (t.prototype.destroy = function () { this.context.remove(this), this.group.remove(this), delete i[this.key]; }), (t.prototype.disable = function () { return (this.enabled = !1), this; }), (t.prototype.enable = function () { return this.context.refresh(), (this.enabled = !0), this; }), (t.prototype.next = function () { return this.group.next(this); }), (t.prototype.previous = function () { return this.group.previous(this); }), (t.invokeAll = function (t) { var e = []; for (var o in i) e.push(i[o]); for (var n = 0, r = e.length; r > n; n++) e[n][t](); }), (t.destroyAll = function () { t.invokeAll("destroy"); }), (t.disableAll = function () { t.invokeAll("disable"); }), (t.enableAll = function () { t.invokeAll("enable"); }), (t.refreshAll = function () { t.Context.refreshAll(); }), (t.viewportHeight = function () { return window.innerHeight || document.documentElement.clientHeight; }), (t.viewportWidth = function () { return document.documentElement.clientWidth; }), (t.adapters = []), (t.defaults = { context: window, continuous: !0, enabled: !0, group: "default", horizontal: !1, offset: 0 }), (t.offsetAliases = { "bottom-in-view": function () { return this.context.innerHeight() - this.adapter.outerHeight(); }, "right-in-view": function () { return this.context.innerWidth() - this.adapter.outerWidth(); }, }), (window.Waypoint = t); })(), (function () { "use strict"; function t(t) { window.setTimeout(t, 1e3 / 60); } function e(t) { (this.element = t), (this.Adapter = n.Adapter), (this.adapter = new this.Adapter(t)), (this.key = "waypoint-context-" + i), (this.didScroll = !1), (this.didResize = !1), (this.oldScroll = { x: this.adapter.scrollLeft(), y: this.adapter.scrollTop() }), (this.waypoints = { vertical: {}, horizontal: {} }), (t.waypointContextKey = this.key), (o[t.waypointContextKey] = this), (i += 1), this.createThrottledScrollHandler(), this.createThrottledResizeHandler(); } var i = 0, o = {}, n = window.Waypoint, r = window.onload; (e.prototype.add = function (t) { var e = t.options.horizontal ? "horizontal" : "vertical"; (this.waypoints[e][t.key] = t), this.refresh(); }), (e.prototype.checkEmpty = function () { var t = this.Adapter.isEmptyObject(this.waypoints.horizontal), e = this.Adapter.isEmptyObject(this.waypoints.vertical); t && e && (this.adapter.off(".waypoints"), delete o[this.key]); }), (e.prototype.createThrottledResizeHandler = function () { function t() { e.handleResize(), (e.didResize = !1); } var e = this; this.adapter.on("resize.waypoints", function () { e.didResize || ((e.didResize = !0), n.requestAnimationFrame(t)); }); }), (e.prototype.createThrottledScrollHandler = function () { function t() { e.handleScroll(), (e.didScroll = !1); } var e = this; this.adapter.on("scroll.waypoints", function () { (!e.didScroll || n.isTouch) && ((e.didScroll = !0), n.requestAnimationFrame(t)); }); }), (e.prototype.handleResize = function () { n.Context.refreshAll(); }), (e.prototype.handleScroll = function () { var t = {}, e = { horizontal: { newScroll: this.adapter.scrollLeft(), oldScroll: this.oldScroll.x, forward: "right", backward: "left" }, vertical: { newScroll: this.adapter.scrollTop(), oldScroll: this.oldScroll.y, forward: "down", backward: "up" }, }; for (var i in e) { var o = e[i], n = o.newScroll > o.oldScroll ? o.forward : o.backward; for (var r in this.waypoints[i]) { var s = this.waypoints[i][r], a = o.oldScroll < s.triggerPoint, l = o.newScroll >= s.triggerPoint; ((a && l) || (!a && !l)) && (s.queueTrigger(n), (t[s.group.id] = s.group)); } } for (var h in t) t[h].flushTriggers(); this.oldScroll = { x: e.horizontal.newScroll, y: e.vertical.newScroll }; }), (e.prototype.innerHeight = function () { return this.element == this.element.window ? n.viewportHeight() : this.adapter.innerHeight(); }), (e.prototype.remove = function (t) { delete this.waypoints[t.axis][t.key], this.checkEmpty(); }), (e.prototype.innerWidth = function () { return this.element == this.element.window ? n.viewportWidth() : this.adapter.innerWidth(); }), (e.prototype.destroy = function () { var t = []; for (var e in this.waypoints) for (var i in this.waypoints[e]) t.push(this.waypoints[e][i]); for (var o = 0, n = t.length; n > o; o++) t[o].destroy(); }), (e.prototype.refresh = function () { var t, e = this.element == this.element.window, i = e ? void 0 : this.adapter.offset(), o = {}; for (var r in (this.handleScroll(), (t = { horizontal: { contextOffset: e ? 0 : i.left, contextScroll: e ? 0 : this.oldScroll.x, contextDimension: this.innerWidth(), oldScroll: this.oldScroll.x, forward: "right", backward: "left", offsetProp: "left" }, vertical: { contextOffset: e ? 0 : i.top, contextScroll: e ? 0 : this.oldScroll.y, contextDimension: this.innerHeight(), oldScroll: this.oldScroll.y, forward: "down", backward: "up", offsetProp: "top" }, }))) { var s = t[r]; for (var a in this.waypoints[r]) { var l, h, u, c, p = this.waypoints[r][a], d = p.options.offset, f = p.triggerPoint, y = 0, w = null == f; p.element !== p.element.window && (y = p.adapter.offset()[s.offsetProp]), "function" == typeof d ? (d = d.apply(p)) : "string" == typeof d && ((d = parseFloat(d)), p.options.offset.indexOf("%") > -1 && (d = Math.ceil((s.contextDimension * d) / 100))), (l = s.contextScroll - s.contextOffset), (p.triggerPoint = y + l - d), (h = f < s.oldScroll), (u = p.triggerPoint >= s.oldScroll), (c = !h && !u), !w && h && u ? (p.queueTrigger(s.backward), (o[p.group.id] = p.group)) : ((!w && c) || (w && s.oldScroll >= p.triggerPoint)) && (p.queueTrigger(s.forward), (o[p.group.id] = p.group)); } } return ( n.requestAnimationFrame(function () { for (var t in o) o[t].flushTriggers(); }), this ); }), (e.findOrCreateByElement = function (t) { return e.findByElement(t) || new e(t); }), (e.refreshAll = function () { for (var t in o) o[t].refresh(); }), (e.findByElement = function (t) { return o[t.waypointContextKey]; }), (window.onload = function () { r && r(), e.refreshAll(); }), (n.requestAnimationFrame = function (e) { (window.requestAnimationFrame || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame || t).call(window, e); }), (n.Context = e); })(), (function () { "use strict"; function t(t, e) { return t.triggerPoint - e.triggerPoint; } function e(t, e) { return e.triggerPoint - t.triggerPoint; } function i(t) { (this.name = t.name), (this.axis = t.axis), (this.id = this.name + "-" + this.axis), (this.waypoints = []), this.clearTriggerQueues(), (o[this.axis][this.name] = this); } var o = { vertical: {}, horizontal: {} }, n = window.Waypoint; (i.prototype.add = function (t) { this.waypoints.push(t); }), (i.prototype.clearTriggerQueues = function () { this.triggerQueues = { up: [], down: [], left: [], right: [] }; }), (i.prototype.flushTriggers = function () { for (var i in this.triggerQueues) { var o = this.triggerQueues[i], n = "up" === i || "left" === i; o.sort(n ? e : t); for (var r = 0, s = o.length; s > r; r += 1) { var a = o[r]; (a.options.continuous || r === o.length - 1) && a.trigger([i]); } } this.clearTriggerQueues(); }), (i.prototype.next = function (e) { this.waypoints.sort(t); var i = n.Adapter.inArray(e, this.waypoints); return i === this.waypoints.length - 1 ? null : this.waypoints[i + 1]; }), (i.prototype.previous = function (e) { this.waypoints.sort(t); var i = n.Adapter.inArray(e, this.waypoints); return i ? this.waypoints[i - 1] : null; }), (i.prototype.queueTrigger = function (t, e) { this.triggerQueues[e].push(t); }), (i.prototype.remove = function (t) { var e = n.Adapter.inArray(t, this.waypoints); e > -1 && this.waypoints.splice(e, 1); }), (i.prototype.first = function () { return this.waypoints[0]; }), (i.prototype.last = function () { return this.waypoints[this.waypoints.length - 1]; }), (i.findOrCreate = function (t) { return o[t.axis][t.name] || new i(t); }), (n.Group = i); })(), (function () { "use strict"; function t(t) { this.$element = e(t); } var e = window.jQuery, i = window.Waypoint; e.each(["innerHeight", "innerWidth", "off", "offset", "on", "outerHeight", "outerWidth", "scrollLeft", "scrollTop"], function (e, i) { t.prototype[i] = function () { var t = Array.prototype.slice.call(arguments); return this.$element[i].apply(this.$element, t); }; }), e.each(["extend", "inArray", "isEmptyObject"], function (i, o) { t[o] = e[o]; }), i.adapters.push({ name: "jquery", Adapter: t }), (i.Adapter = t); })(), (function () { "use strict"; function t(t) { return function () { var i = [], o = arguments[0]; return ( t.isFunction(arguments[0]) && ((o = t.extend({}, arguments[1])).handler = arguments[0]), this.each(function () { var n = t.extend({}, o, { element: this }); "string" == typeof n.context && (n.context = t(this).closest(n.context)[0]), i.push(new e(n)); }), i ); }; } var e = window.Waypoint; window.jQuery && (window.jQuery.fn.waypoint = t(window.jQuery)), window.Zepto && (window.Zepto.fn.waypoint = t(window.Zepto)); })(), /*! * jquery.counterup.js 1.0 * * Copyright 2013, Benjamin Intal http://gambit.ph @bfintal * Released under the GPL v2 License * * Date: Nov 26, 2013 */ (function (t) { "use strict"; t.fn.counterUp = function (e) { var i, o = t.extend({ time: 400, delay: 10, offset: 100, beginAt: 0, formatter: !1, context: "window", callback: function () {} }, e); return this.each(function () { var e = t(this), n = { time: t(this).data("counterup-time") || o.time, delay: t(this).data("counterup-delay") || o.delay, offset: t(this).data("counterup-offset") || o.offset, beginAt: t(this).data("counterup-beginat") || o.beginAt, context: t(this).data("counterup-context") || o.context, }; e.waypoint( function (r) { !(function () { var r = [], s = n.time / n.delay, a = t(this).attr("data-num") ? t(this).attr("data-num") : e.text(), l = /[0-9]+,[0-9]+/.test(a), h = ((a = a.replace(/,/g, "")).split(".")[1] || []).length; n.beginAt > a && (n.beginAt = a); var u = /[0-9]+:[0-9]+:[0-9]+/.test(a); if (u) { var c = a.split(":"), p = 1; for (i = 0; c.length > 0; ) (i += p * parseInt(c.pop(), 10)), (p *= 60); } for (var d = s; d >= (n.beginAt / a) * s; d--) { var f = parseFloat((a / s) * d).toFixed(h); if (u) { f = parseInt((i / s) * d); var y = parseInt(f / 3600) % 24, w = parseInt(f / 60) % 60, g = parseInt(f % 60, 10); f = (y < 10 ? "0" + y : y) + ":" + (w < 10 ? "0" + w : w) + ":" + (g < 10 ? "0" + g : g); } if (l) for (; /(\d+)(\d{3})/.test(f.toString()); ) f = f.toString().replace(/(\d+)(\d{3})/, "$1,$2"); o.formatter && (f = o.formatter.call(this, f)), r.unshift(f); } e.data("counterup-nums", r), e.text(n.beginAt); e.data("counterup-func", function () { e.data("counterup-nums") ? (e.html(e.data("counterup-nums").shift()), e.data("counterup-nums").length ? setTimeout(e.data("counterup-func"), n.delay) : (e.data("counterup-nums", null), e.data("counterup-func", null), o.callback.call(this))) : o.callback.call(this); }), setTimeout(e.data("counterup-func"), n.delay); })(), this.destroy(); }, { offset: n.offset + "%", context: n.context } ); }); }; })(jQuery);