You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

6878 lines
379 KiB

/*! jQuery Mobile 1.4.5 | Git HEADhash: 68e55e7 <> 2014-10-31T17:33:30Z | (c) 2010, 2014 jQuery Foundation, Inc. | jquery.org/license */
!(function (a, b, c) {
"function" == typeof define && define.amd
? define(["jquery"], function (d) {
return c(d, a, b), d.mobile;
})
: c(a.jQuery, a, b);
})(this, document, function (a, b, c) {
!(function (a) {
a.mobile = {};
})(a),
(function (a, b) {
function d(b, c) {
var d,
f,
g,
h = b.nodeName.toLowerCase();
return "area" === h
? ((d = b.parentNode), (f = d.name), b.href && f && "map" === d.nodeName.toLowerCase() ? ((g = a("img[usemap=#" + f + "]")[0]), !!g && e(g)) : !1)
: (/input|select|textarea|button|object/.test(h) ? !b.disabled : "a" === h ? b.href || c : c) && e(b);
}
function e(b) {
return (
a.expr.filters.visible(b) &&
!a(b)
.parents()
.addBack()
.filter(function () {
return "hidden" === a.css(this, "visibility");
}).length
);
}
var f = 0,
g = /^ui-id-\d+$/;
(a.ui = a.ui || {}),
a.extend(a.ui, {
version: "c0ab71056b936627e8a7821f03c044aec6280a40",
keyCode: {
BACKSPACE: 8,
COMMA: 188,
DELETE: 46,
DOWN: 40,
END: 35,
ENTER: 13,
ESCAPE: 27,
HOME: 36,
LEFT: 37,
PAGE_DOWN: 34,
PAGE_UP: 33,
PERIOD: 190,
RIGHT: 39,
SPACE: 32,
TAB: 9,
UP: 38,
},
}),
a.fn.extend({
focus: (function (b) {
return function (c, d) {
return "number" == typeof c
? this.each(function () {
var b = this;
setTimeout(function () {
a(b).focus(), d && d.call(b);
}, c);
})
: b.apply(this, arguments);
};
})(a.fn.focus),
scrollParent: function () {
var b;
return (
(b =
(a.ui.ie && /(static|relative)/.test(this.css("position"))) || /absolute/.test(this.css("position"))
? this.parents()
.filter(function () {
return /(relative|absolute|fixed)/.test(a.css(this, "position")) && /(auto|scroll)/.test(a.css(this, "overflow") + a.css(this, "overflow-y") + a.css(this, "overflow-x"));
})
.eq(0)
: this.parents()
.filter(function () {
return /(auto|scroll)/.test(a.css(this, "overflow") + a.css(this, "overflow-y") + a.css(this, "overflow-x"));
})
.eq(0)),
/fixed/.test(this.css("position")) || !b.length ? a(this[0].ownerDocument || c) : b
);
},
uniqueId: function () {
return this.each(function () {
this.id || (this.id = "ui-id-" + ++f);
});
},
removeUniqueId: function () {
return this.each(function () {
g.test(this.id) && a(this).removeAttr("id");
});
},
}),
a.extend(a.expr[":"], {
data: a.expr.createPseudo
? a.expr.createPseudo(function (b) {
return function (c) {
return !!a.data(c, b);
};
})
: function (b, c, d) {
return !!a.data(b, d[3]);
},
focusable: function (b) {
return d(b, !isNaN(a.attr(b, "tabindex")));
},
tabbable: function (b) {
var c = a.attr(b, "tabindex"),
e = isNaN(c);
return (e || c >= 0) && d(b, !e);
},
}),
a("<a>").outerWidth(1).jquery ||
a.each(["Width", "Height"], function (c, d) {
function e(b, c, d, e) {
return (
a.each(f, function () {
(c -= parseFloat(a.css(b, "padding" + this)) || 0), d && (c -= parseFloat(a.css(b, "border" + this + "Width")) || 0), e && (c -= parseFloat(a.css(b, "margin" + this)) || 0);
}),
c
);
}
var f = "Width" === d ? ["Left", "Right"] : ["Top", "Bottom"],
g = d.toLowerCase(),
h = { innerWidth: a.fn.innerWidth, innerHeight: a.fn.innerHeight, outerWidth: a.fn.outerWidth, outerHeight: a.fn.outerHeight };
(a.fn["inner" + d] = function (c) {
return c === b
? h["inner" + d].call(this)
: this.each(function () {
a(this).css(g, e(this, c) + "px");
});
}),
(a.fn["outer" + d] = function (b, c) {
return "number" != typeof b
? h["outer" + d].call(this, b)
: this.each(function () {
a(this).css(g, e(this, b, !0, c) + "px");
});
});
}),
a.fn.addBack ||
(a.fn.addBack = function (a) {
return this.add(null == a ? this.prevObject : this.prevObject.filter(a));
}),
a("<a>").data("a-b", "a").removeData("a-b").data("a-b") &&
(a.fn.removeData = (function (b) {
return function (c) {
return arguments.length ? b.call(this, a.camelCase(c)) : b.call(this);
};
})(a.fn.removeData)),
(a.ui.ie = !!/msie [\w.]+/.exec(navigator.userAgent.toLowerCase())),
(a.support.selectstart = "onselectstart" in c.createElement("div")),
a.fn.extend({
disableSelection: function () {
return this.bind((a.support.selectstart ? "selectstart" : "mousedown") + ".ui-disableSelection", function (a) {
a.preventDefault();
});
},
enableSelection: function () {
return this.unbind(".ui-disableSelection");
},
zIndex: function (d) {
if (d !== b) return this.css("zIndex", d);
if (this.length)
for (var e, f, g = a(this[0]); g.length && g[0] !== c;) {
if (((e = g.css("position")), ("absolute" === e || "relative" === e || "fixed" === e) && ((f = parseInt(g.css("zIndex"), 10)), !isNaN(f) && 0 !== f))) return f;
g = g.parent();
}
return 0;
},
}),
(a.ui.plugin = {
add: function (b, c, d) {
var e,
f = a.ui[b].prototype;
for (e in d) (f.plugins[e] = f.plugins[e] || []), f.plugins[e].push([c, d[e]]);
},
call: function (a, b, c, d) {
var e,
f = a.plugins[b];
if (f && (d || (a.element[0].parentNode && 11 !== a.element[0].parentNode.nodeType))) for (e = 0; e < f.length; e++) a.options[f[e][0]] && f[e][1].apply(a.element, c);
},
});
})(a),
(function (a, b) {
var d = function (b, c) {
var d = b.parent(),
e = [],
f = function () {
var b = a(this),
c =
a.mobile.toolbar && b.data("mobile-toolbar")
? b.toolbar("option")
: { position: b.attr("data-" + a.mobile.ns + "position"), updatePagePadding: b.attr("data-" + a.mobile.ns + "update-page-padding") !== !1 };
return !("fixed" === c.position && c.updatePagePadding === !0);
},
g = d.children(":jqmData(role='header')").filter(f),
h = b.children(":jqmData(role='header')"),
i = d.children(":jqmData(role='footer')").filter(f),
j = b.children(":jqmData(role='footer')");
return (
0 === h.length && g.length > 0 && (e = e.concat(g.toArray())),
0 === j.length && i.length > 0 && (e = e.concat(i.toArray())),
a.each(e, function (b, d) {
c -= a(d).outerHeight();
}),
Math.max(0, c)
);
};
a.extend(a.mobile, {
window: a(b),
document: a(c),
keyCode: a.ui.keyCode,
behaviors: {},
silentScroll: function (c) {
"number" !== a.type(c) && (c = a.mobile.defaultHomeScroll),
(a.event.special.scrollstart.enabled = !1),
setTimeout(function () {
b.scrollTo(0, c), a.mobile.document.trigger("silentscroll", { x: 0, y: c });
}, 20),
setTimeout(function () {
a.event.special.scrollstart.enabled = !0;
}, 150);
},
getClosestBaseUrl: function (b) {
var c = a(b).closest(".ui-page").jqmData("url"),
d = a.mobile.path.documentBase.hrefNoHash;
return (a.mobile.dynamicBaseEnabled && c && a.mobile.path.isPath(c)) || (c = d), a.mobile.path.makeUrlAbsolute(c, d);
},
removeActiveLinkClass: function (b) {
!a.mobile.activeClickedLink || (a.mobile.activeClickedLink.closest("." + a.mobile.activePageClass).length && !b) || a.mobile.activeClickedLink.removeClass(a.mobile.activeBtnClass),
(a.mobile.activeClickedLink = null);
},
getInheritedTheme: function (a, b) {
for (var c, d, e = a[0], f = "", g = /ui-(bar|body|overlay)-([a-z])\b/; e && ((c = e.className || ""), !(c && (d = g.exec(c)) && (f = d[2])));) e = e.parentNode;
return f || b || "a";
},
enhanceable: function (a) {
return this.haveParents(a, "enhance");
},
hijackable: function (a) {
return this.haveParents(a, "ajax");
},
haveParents: function (b, c) {
if (!a.mobile.ignoreContentEnabled) return b;
var d,
e,
f,
g,
h,
i = b.length,
j = a();
for (g = 0; i > g; g++) {
for (e = b.eq(g), f = !1, d = b[g]; d;) {
if (((h = d.getAttribute ? d.getAttribute("data-" + a.mobile.ns + c) : ""), "false" === h)) {
f = !0;
break;
}
d = d.parentNode;
}
f || (j = j.add(e));
}
return j;
},
getScreenHeight: function () {
return b.innerHeight || a.mobile.window.height();
},
resetActivePageHeight: function (b) {
var c = a("." + a.mobile.activePageClass),
e = c.height(),
f = c.outerHeight(!0);
(b = d(c, "number" == typeof b ? b : a.mobile.getScreenHeight())), c.css("min-height", ""), c.height() < b && c.css("min-height", b - (f - e));
},
}),
(a.addDependents = function (b, c) {
var d = a(b),
e = d.jqmData("dependents") || a();
d.jqmData("dependents", a(e).add(c));
}),
a.fn.extend({
removeWithDependents: function () {
a.removeWithDependents(this);
},
enhanceWithin: function () {
var b,
c = {},
d = a.mobile.page.prototype.keepNativeSelector(),
e = this;
a.mobile.nojs && a.mobile.nojs(this),
a.mobile.links && a.mobile.links(this),
a.mobile.degradeInputsWithin && a.mobile.degradeInputsWithin(this),
a.fn.buttonMarkup && this.find(a.fn.buttonMarkup.initSelector).not(d).jqmEnhanceable().buttonMarkup(),
a.fn.fieldcontain && this.find(":jqmData(role='fieldcontain')").not(d).jqmEnhanceable().fieldcontain(),
a.each(a.mobile.widgets, function (b, f) {
if (f.initSelector) {
var g = a.mobile.enhanceable(e.find(f.initSelector));
g.length > 0 && (g = g.not(d)), g.length > 0 && (c[f.prototype.widgetName] = g);
}
});
for (b in c) c[b][b]();
return this;
},
addDependents: function (b) {
a.addDependents(this, b);
},
getEncodedText: function () {
return a("<a>").text(this.text()).html();
},
jqmEnhanceable: function () {
return a.mobile.enhanceable(this);
},
jqmHijackable: function () {
return a.mobile.hijackable(this);
},
}),
(a.removeWithDependents = function (b) {
var c = a(b);
(c.jqmData("dependents") || a()).remove(), c.remove();
}),
(a.addDependents = function (b, c) {
var d = a(b),
e = d.jqmData("dependents") || a();
d.jqmData("dependents", a(e).add(c));
}),
(a.find.matches = function (b, c) {
return a.find(b, null, null, c);
}),
(a.find.matchesSelector = function (b, c) {
return a.find(c, null, null, [b]).length > 0;
});
})(a, this),
(function (a) {
a.extend(a.mobile, {
version: "1.4.5",
subPageUrlKey: "ui-page",
hideUrlBar: !0,
keepNative: ":jqmData(role='none'), :jqmData(role='nojs')",
activePageClass: "ui-page-active",
activeBtnClass: "ui-btn-active",
focusClass: "ui-focus",
ajaxEnabled: !0,
hashListeningEnabled: !0,
linkBindingEnabled: !0,
defaultPageTransition: "fade",
maxTransitionWidth: !1,
minScrollBack: 0,
defaultDialogTransition: "pop",
pageLoadErrorMessage: "Error Loading Page",
pageLoadErrorMessageTheme: "a",
phonegapNavigationEnabled: !1,
autoInitializePage: !0,
pushStateEnabled: !0,
ignoreContentEnabled: !1,
buttonMarkup: { hoverDelay: 200 },
dynamicBaseEnabled: !0,
pageContainer: a(),
allowCrossDomainPages: !1,
dialogHashKey: "&ui-state=dialog",
});
})(a, this),
(function (a, b) {
var c = 0,
d = Array.prototype.slice,
e = a.cleanData;
(a.cleanData = function (b) {
for (var c, d = 0; null != (c = b[d]); d++)
try {
a(c).triggerHandler("remove");
} catch (f) { }
e(b);
}),
(a.widget = function (b, c, d) {
var e,
f,
g,
h,
i = {},
j = b.split(".")[0];
return (
(b = b.split(".")[1]),
(e = j + "-" + b),
d || ((d = c), (c = a.Widget)),
(a.expr[":"][e.toLowerCase()] = function (b) {
return !!a.data(b, e);
}),
(a[j] = a[j] || {}),
(f = a[j][b]),
(g = a[j][b] =
function (a, b) {
return this._createWidget ? void (arguments.length && this._createWidget(a, b)) : new g(a, b);
}),
a.extend(g, f, { version: d.version, _proto: a.extend({}, d), _childConstructors: [] }),
(h = new c()),
(h.options = a.widget.extend({}, h.options)),
a.each(d, function (b, d) {
return a.isFunction(d)
? void (i[b] = (function () {
var a = function () {
return c.prototype[b].apply(this, arguments);
},
e = function (a) {
return c.prototype[b].apply(this, a);
};
return function () {
var b,
c = this._super,
f = this._superApply;
return (this._super = a), (this._superApply = e), (b = d.apply(this, arguments)), (this._super = c), (this._superApply = f), b;
};
})())
: void (i[b] = d);
}),
(g.prototype = a.widget.extend(h, { widgetEventPrefix: f ? h.widgetEventPrefix || b : b }, i, { constructor: g, namespace: j, widgetName: b, widgetFullName: e })),
f
? (a.each(f._childConstructors, function (b, c) {
var d = c.prototype;
a.widget(d.namespace + "." + d.widgetName, g, c._proto);
}),
delete f._childConstructors)
: c._childConstructors.push(g),
a.widget.bridge(b, g),
g
);
}),
(a.widget.extend = function (c) {
for (var e, f, g = d.call(arguments, 1), h = 0, i = g.length; i > h; h++)
for (e in g[h]) (f = g[h][e]), g[h].hasOwnProperty(e) && f !== b && (c[e] = a.isPlainObject(f) ? (a.isPlainObject(c[e]) ? a.widget.extend({}, c[e], f) : a.widget.extend({}, f)) : f);
return c;
}),
(a.widget.bridge = function (c, e) {
var f = e.prototype.widgetFullName || c;
a.fn[c] = function (g) {
var h = "string" == typeof g,
i = d.call(arguments, 1),
j = this;
return (
(g = !h && i.length ? a.widget.extend.apply(null, [g].concat(i)) : g),
this.each(
h
? function () {
var d,
e = a.data(this, f);
return "instance" === g
? ((j = e), !1)
: e
? a.isFunction(e[g]) && "_" !== g.charAt(0)
? ((d = e[g].apply(e, i)), d !== e && d !== b ? ((j = d && d.jquery ? j.pushStack(d.get()) : d), !1) : void 0)
: a.error("no such method '" + g + "' for " + c + " widget instance")
: a.error("cannot call methods on " + c + " prior to initialization; attempted to call method '" + g + "'");
}
: function () {
var b = a.data(this, f);
b ? b.option(g || {})._init() : a.data(this, f, new e(g, this));
}
),
j
);
};
}),
(a.Widget = function () { }),
(a.Widget._childConstructors = []),
(a.Widget.prototype = {
widgetName: "widget",
widgetEventPrefix: "",
defaultElement: "<div>",
options: { disabled: !1, create: null },
_createWidget: function (b, d) {
(d = a(d || this.defaultElement || this)[0]),
(this.element = a(d)),
(this.uuid = c++),
(this.eventNamespace = "." + this.widgetName + this.uuid),
(this.options = a.widget.extend({}, this.options, this._getCreateOptions(), b)),
(this.bindings = a()),
(this.hoverable = a()),
(this.focusable = a()),
d !== this &&
(a.data(d, this.widgetFullName, this),
this._on(!0, this.element, {
remove: function (a) {
a.target === d && this.destroy();
},
}),
(this.document = a(d.style ? d.ownerDocument : d.document || d)),
(this.window = a(this.document[0].defaultView || this.document[0].parentWindow))),
this._create(),
this._trigger("create", null, this._getCreateEventData()),
this._init();
},
_getCreateOptions: a.noop,
_getCreateEventData: a.noop,
_create: a.noop,
_init: a.noop,
destroy: function () {
this._destroy(),
this.element.unbind(this.eventNamespace).removeData(this.widgetFullName).removeData(a.camelCase(this.widgetFullName)),
this.widget()
.unbind(this.eventNamespace)
.removeAttr("aria-disabled")
.removeClass(this.widgetFullName + "-disabled ui-state-disabled"),
this.bindings.unbind(this.eventNamespace),
this.hoverable.removeClass("ui-state-hover"),
this.focusable.removeClass("ui-state-focus");
},
_destroy: a.noop,
widget: function () {
return this.element;
},
option: function (c, d) {
var e,
f,
g,
h = c;
if (0 === arguments.length) return a.widget.extend({}, this.options);
if ("string" == typeof c)
if (((h = {}), (e = c.split(".")), (c = e.shift()), e.length)) {
for (f = h[c] = a.widget.extend({}, this.options[c]), g = 0; g < e.length - 1; g++) (f[e[g]] = f[e[g]] || {}), (f = f[e[g]]);
if (((c = e.pop()), d === b)) return f[c] === b ? null : f[c];
f[c] = d;
} else {
if (d === b) return this.options[c] === b ? null : this.options[c];
h[c] = d;
}
return this._setOptions(h), this;
},
_setOptions: function (a) {
var b;
for (b in a) this._setOption(b, a[b]);
return this;
},
_setOption: function (a, b) {
return (
(this.options[a] = b),
"disabled" === a && (this.widget().toggleClass(this.widgetFullName + "-disabled", !!b), this.hoverable.removeClass("ui-state-hover"), this.focusable.removeClass("ui-state-focus")),
this
);
},
enable: function () {
return this._setOptions({ disabled: !1 });
},
disable: function () {
return this._setOptions({ disabled: !0 });
},
_on: function (b, c, d) {
var e,
f = this;
"boolean" != typeof b && ((d = c), (c = b), (b = !1)),
d ? ((c = e = a(c)), (this.bindings = this.bindings.add(c))) : ((d = c), (c = this.element), (e = this.widget())),
a.each(d, function (d, g) {
function h() {
return b || (f.options.disabled !== !0 && !a(this).hasClass("ui-state-disabled")) ? ("string" == typeof g ? f[g] : g).apply(f, arguments) : void 0;
}
"string" != typeof g && (h.guid = g.guid = g.guid || h.guid || a.guid++);
var i = d.match(/^(\w+)\s*(.*)$/),
j = i[1] + f.eventNamespace,
k = i[2];
k ? e.delegate(k, j, h) : c.bind(j, h);
});
},
_off: function (a, b) {
(b = (b || "").split(" ").join(this.eventNamespace + " ") + this.eventNamespace), a.unbind(b).undelegate(b);
},
_delay: function (a, b) {
function c() {
return ("string" == typeof a ? d[a] : a).apply(d, arguments);
}
var d = this;
return setTimeout(c, b || 0);
},
_hoverable: function (b) {
(this.hoverable = this.hoverable.add(b)),
this._on(b, {
mouseenter: function (b) {
a(b.currentTarget).addClass("ui-state-hover");
},
mouseleave: function (b) {
a(b.currentTarget).removeClass("ui-state-hover");
},
});
},
_focusable: function (b) {
(this.focusable = this.focusable.add(b)),
this._on(b, {
focusin: function (b) {
a(b.currentTarget).addClass("ui-state-focus");
},
focusout: function (b) {
a(b.currentTarget).removeClass("ui-state-focus");
},
});
},
_trigger: function (b, c, d) {
var e,
f,
g = this.options[b];
if (((d = d || {}), (c = a.Event(c)), (c.type = (b === this.widgetEventPrefix ? b : this.widgetEventPrefix + b).toLowerCase()), (c.target = this.element[0]), (f = c.originalEvent)))
for (e in f) e in c || (c[e] = f[e]);
return this.element.trigger(c, d), !((a.isFunction(g) && g.apply(this.element[0], [c].concat(d)) === !1) || c.isDefaultPrevented());
},
}),
a.each({ show: "fadeIn", hide: "fadeOut" }, function (b, c) {
a.Widget.prototype["_" + b] = function (d, e, f) {
"string" == typeof e && (e = { effect: e });
var g,
h = e ? (e === !0 || "number" == typeof e ? c : e.effect || c) : b;
(e = e || {}),
"number" == typeof e && (e = { duration: e }),
(g = !a.isEmptyObject(e)),
(e.complete = f),
e.delay && d.delay(e.delay),
g && a.effects && a.effects.effect[h]
? d[b](e)
: h !== b && d[h]
? d[h](e.duration, e.easing, f)
: d.queue(function (c) {
a(this)[b](), f && f.call(d[0]), c();
});
};
});
})(a),
(function (a, b, c) {
var d = {},
e = a.find,
f = /(?:\{[\s\S]*\}|\[[\s\S]*\])$/,
g = /:jqmData\(([^)]*)\)/g;
a.extend(a.mobile, {
ns: "",
getAttribute: function (b, c) {
var d;
(b = b.jquery ? b[0] : b), b && b.getAttribute && (d = b.getAttribute("data-" + a.mobile.ns + c));
try {
d = "true" === d ? !0 : "false" === d ? !1 : "null" === d ? null : +d + "" === d ? +d : f.test(d) ? JSON.parse(d) : d;
} catch (e) { }
return d;
},
nsNormalizeDict: d,
nsNormalize: function (b) {
return d[b] || (d[b] = a.camelCase(a.mobile.ns + b));
},
closestPageData: function (a) {
return a.closest(":jqmData(role='page'), :jqmData(role='dialog')").data("mobile-page");
},
}),
(a.fn.jqmData = function (b, d) {
var e;
return "undefined" != typeof b && (b && (b = a.mobile.nsNormalize(b)), (e = arguments.length < 2 || d === c ? this.data(b) : this.data(b, d))), e;
}),
(a.jqmData = function (b, c, d) {
var e;
return "undefined" != typeof c && (e = a.data(b, c ? a.mobile.nsNormalize(c) : c, d)), e;
}),
(a.fn.jqmRemoveData = function (b) {
return this.removeData(a.mobile.nsNormalize(b));
}),
(a.jqmRemoveData = function (b, c) {
return a.removeData(b, a.mobile.nsNormalize(c));
}),
(a.find = function (b, c, d, f) {
return b.indexOf(":jqmData") > -1 && (b = b.replace(g, "[data-" + (a.mobile.ns || "") + "$1]")), e.call(this, b, c, d, f);
}),
a.extend(a.find, e);
})(a, this),
(function (a) {
var b = /[A-Z]/g,
c = function (a) {
return "-" + a.toLowerCase();
};
a.extend(a.Widget.prototype, {
_getCreateOptions: function () {
var d,
e,
f = this.element[0],
g = {};
if (!a.mobile.getAttribute(f, "defaults")) for (d in this.options) (e = a.mobile.getAttribute(f, d.replace(b, c))), null != e && (g[d] = e);
return g;
},
}),
(a.mobile.widget = a.Widget);
})(a),
(function (a, b, d) {
"$:nomunge";
function e(a) {
return (a = a || location.href), "#" + a.replace(/^[^#]*#?(.*)$/, "$1");
}
var f,
g = "hashchange",
h = c,
i = a.event.special,
j = h.documentMode,
k = "on" + g in b && (j === d || j > 7);
(a.fn[g] = function (a) {
return a ? this.bind(g, a) : this.trigger(g);
}),
(a.fn[g].delay = 50),
(i[g] = a.extend(i[g], {
setup: function () {
return k ? !1 : void a(f.start);
},
teardown: function () {
return k ? !1 : void a(f.stop);
},
})),
(f = (function () {
function c() {
var d = e(),
h = n(j);
d !== j ? (m((j = d), h), a(b).trigger(g)) : h !== j && (location.href = location.href.replace(/#.*/, "") + h), (f = setTimeout(c, a.fn[g].delay));
}
var f,
i = {},
j = e(),
l = function (a) {
return a;
},
m = l,
n = l;
return (
(i.start = function () {
f || c();
}),
(i.stop = function () {
f && clearTimeout(f), (f = d);
}),
b.attachEvent &&
!b.addEventListener &&
!k &&
(function () {
var b, d;
(i.start = function () {
b ||
((d = a.fn[g].src),
(d = d && d + e()),
(b = a('<iframe tabindex="-1" title="empty"/>')
.hide()
.one("load", function () {
d || m(e()), c();
})
.attr("src", d || "javascript:0")
.insertAfter("body")[0].contentWindow),
(h.onpropertychange = function () {
try {
"title" === event.propertyName && (b.document.title = h.title);
} catch (a) { }
}));
}),
(i.stop = l),
(n = function () {
return e(b.location.href);
}),
(m = function (c, d) {
var e = b.document,
f = a.fn[g].domain;
c !== d && ((e.title = h.title), e.open(), f && e.write('<script>document.domain="' + f + '"</script>'), e.close(), (b.location.hash = c));
});
})(),
i
);
})());
})(a, this),
(function (a) {
(b.matchMedia =
b.matchMedia ||
(function (a) {
var b,
c = a.documentElement,
d = c.firstElementChild || c.firstChild,
e = a.createElement("body"),
f = a.createElement("div");
return (
(f.id = "mq-test-1"),
(f.style.cssText = "position:absolute;top:-100em"),
(e.style.background = "none"),
e.appendChild(f),
function (a) {
return (f.innerHTML = '&shy;<style media="' + a + '"> #mq-test-1 { width: 42px; }</style>'), c.insertBefore(e, d), (b = 42 === f.offsetWidth), c.removeChild(e), { matches: b, media: a };
}
);
})(c)),
(a.mobile.media = function (a) {
return b.matchMedia(a).matches;
});
})(a),
(function (a) {
var b = { touch: "ontouchend" in c };
(a.mobile.support = a.mobile.support || {}), a.extend(a.support, b), a.extend(a.mobile.support, b);
})(a),
(function (a) {
a.extend(a.support, { orientation: "orientation" in b && "onorientationchange" in b });
})(a),
(function (a, d) {
function e(a) {
var b,
c = a.charAt(0).toUpperCase() + a.substr(1),
e = (a + " " + o.join(c + " ") + c).split(" ");
for (b in e) if (n[e[b]] !== d) return !0;
}
function f() {
var c = b,
d = !(!c.document.createElementNS || !c.document.createElementNS("http://www.w3.org/2000/svg", "svg").createSVGRect || (c.opera && -1 === navigator.userAgent.indexOf("Chrome"))),
e = function (b) {
(b && d) || a("html").addClass("ui-nosvg");
},
f = new c.Image();
(f.onerror = function () {
e(!1);
}),
(f.onload = function () {
e(1 === f.width && 1 === f.height);
}),
(f.src = "data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///ywAAAAAAQABAAACAUwAOw==");
}
function g() {
var e,
f,
g,
h = "transform-3d",
i = a.mobile.media("(-" + o.join("-" + h + "),(-") + "-" + h + "),(" + h + ")");
if (i) return !!i;
(e = c.createElement("div")), (f = { MozTransform: "-moz-transform", transform: "transform" }), m.append(e);
for (g in f) e.style[g] !== d && ((e.style[g] = "translate3d( 100px, 1px, 1px )"), (i = b.getComputedStyle(e).getPropertyValue(f[g])));
return !!i && "none" !== i;
}
function h() {
var b,
c,
d = location.protocol + "//" + location.host + location.pathname + "ui-dir/",
e = a("head base"),
f = null,
g = "";
return (
e.length ? (g = e.attr("href")) : (e = f = a("<base>", { href: d }).appendTo("head")),
(b = a("<a href='testurl' />").prependTo(m)),
(c = b[0].href),
(e[0].href = g || location.pathname),
f && f.remove(),
0 === c.indexOf(d)
);
}
function i() {
var a,
d = c.createElement("x"),
e = c.documentElement,
f = b.getComputedStyle;
return "pointerEvents" in d.style
? ((d.style.pointerEvents = "auto"), (d.style.pointerEvents = "x"), e.appendChild(d), (a = f && "auto" === f(d, "").pointerEvents), e.removeChild(d), !!a)
: !1;
}
function j() {
var a = c.createElement("div");
return "undefined" != typeof a.getBoundingClientRect;
}
function k() {
var a = b,
c = navigator.userAgent,
d = navigator.platform,
e = c.match(/AppleWebKit\/([0-9]+)/),
f = !!e && e[1],
g = c.match(/Fennec\/([0-9]+)/),
h = !!g && g[1],
i = c.match(/Opera Mobi\/([0-9]+)/),
j = !!i && i[1];
return ((d.indexOf("iPhone") > -1 || d.indexOf("iPad") > -1 || d.indexOf("iPod") > -1) && f && 534 > f) ||
(a.operamini && "[object OperaMini]" === {}.toString.call(a.operamini)) ||
(i && 7458 > j) ||
(c.indexOf("Android") > -1 && f && 533 > f) ||
(h && 6 > h) ||
("palmGetResource" in b && f && 534 > f) ||
(c.indexOf("MeeGo") > -1 && c.indexOf("NokiaBrowser/8.5.0") > -1)
? !1
: !0;
}
var l,
m = a("<body>").prependTo("html"),
n = m[0].style,
o = ["Webkit", "Moz", "O"],
p = "palmGetResource" in b,
q = b.operamini && "[object OperaMini]" === {}.toString.call(b.operamini),
r = b.blackberry && !e("-webkit-transform");
a.extend(a.mobile, { browser: {} }),
(a.mobile.browser.oldIE = (function () {
var a = 3,
b = c.createElement("div"),
d = b.all || [];
do b.innerHTML = "<!--[if gt IE " + ++a + "]><br><![endif]-->";
while (d[0]);
return a > 4 ? a : !a;
})()),
a.extend(a.support, {
pushState: "pushState" in history && "replaceState" in history && !(b.navigator.userAgent.indexOf("Firefox") >= 0 && b.top !== b) && -1 === b.navigator.userAgent.search(/CriOS/),
mediaquery: a.mobile.media("only all"),
cssPseudoElement: !!e("content"),
touchOverflow: !!e("overflowScrolling"),
cssTransform3d: g(),
boxShadow: !!e("boxShadow") && !r,
fixedPosition: k(),
scrollTop: ("pageXOffset" in b || "scrollTop" in c.documentElement || "scrollTop" in m[0]) && !p && !q,
dynamicBaseTag: h(),
cssPointerEvents: i(),
boundingRect: j(),
inlineSVG: f,
}),
m.remove(),
(l = (function () {
var a = b.navigator.userAgent;
return a.indexOf("Nokia") > -1 && (a.indexOf("Symbian/3") > -1 || a.indexOf("Series60/5") > -1) && a.indexOf("AppleWebKit") > -1 && a.match(/(BrowserNG|NokiaBrowser)\/7\.[0-3]/);
})()),
(a.mobile.gradeA = function () {
return (
((a.support.mediaquery && a.support.cssPseudoElement) || (a.mobile.browser.oldIE && a.mobile.browser.oldIE >= 8)) &&
(a.support.boundingRect || null !== a.fn.jquery.match(/1\.[0-7+]\.[0-9+]?/))
);
}),
(a.mobile.ajaxBlacklist = (b.blackberry && !b.WebKitPoint) || q || l),
l &&
a(function () {
a("head link[rel='stylesheet']").attr("rel", "alternate stylesheet").attr("rel", "stylesheet");
}),
a.support.boxShadow || a("html").addClass("ui-noboxshadow");
})(a),
(function (a, b) {
var c,
d = a.mobile.window,
e = function () { };
(a.event.special.beforenavigate = {
setup: function () {
d.on("navigate", e);
},
teardown: function () {
d.off("navigate", e);
},
}),
(a.event.special.navigate = c =
{
bound: !1,
pushStateEnabled: !0,
originalEventName: b,
isPushStateEnabled: function () {
return a.support.pushState && a.mobile.pushStateEnabled === !0 && this.isHashChangeEnabled();
},
isHashChangeEnabled: function () {
return a.mobile.hashListeningEnabled === !0;
},
popstate: function (b) {
var c = new a.Event("navigate"),
e = new a.Event("beforenavigate"),
f = b.originalEvent.state || {};
(e.originalEvent = b),
d.trigger(e),
e.isDefaultPrevented() ||
(b.historyState && a.extend(f, b.historyState),
(c.originalEvent = b),
setTimeout(function () {
d.trigger(c, { state: f });
}, 0));
},
hashchange: function (b) {
var c = new a.Event("navigate"),
e = new a.Event("beforenavigate");
(e.originalEvent = b), d.trigger(e), e.isDefaultPrevented() || ((c.originalEvent = b), d.trigger(c, { state: b.hashchangeState || {} }));
},
setup: function () {
c.bound ||
((c.bound = !0),
c.isPushStateEnabled()
? ((c.originalEventName = "popstate"), d.bind("popstate.navigate", c.popstate))
: c.isHashChangeEnabled() && ((c.originalEventName = "hashchange"), d.bind("hashchange.navigate", c.hashchange)));
},
});
})(a),
(function (a, c) {
var d,
e,
f = "&ui-state=dialog";
(a.mobile.path = d =
{
uiStateKey: "&ui-state",
urlParseRE:
/^\s*(((([^:\/#\?]+:)?(?:(\/\/)((?:(([^:@\/#\?]+)(?:\:([^:@\/#\?]+))?)@)?(([^:\/#\?\]\[]+|\[[^\/\]@#?]+\])(?:\:([0-9]+))?))?)?)?((\/?(?:[^\/\?#]+\/+)*)([^\?#]*)))?(\?[^#]+)?)(#.*)?/,
getLocation: function (a) {
var b = this.parseUrl(a || location.href),
c = a ? b : location,
d = b.hash;
return (d = "#" === d ? "" : d), c.protocol + b.doubleSlash + c.host + ("" !== c.protocol && "/" !== c.pathname.substring(0, 1) ? "/" : "") + c.pathname + c.search + d;
},
getDocumentUrl: function (b) {
return b ? a.extend({}, d.documentUrl) : d.documentUrl.href;
},
parseLocation: function () {
return this.parseUrl(this.getLocation());
},
parseUrl: function (b) {
if ("object" === a.type(b)) return b;
var c = d.urlParseRE.exec(b || "") || [];
return {
href: c[0] || "",
hrefNoHash: c[1] || "",
hrefNoSearch: c[2] || "",
domain: c[3] || "",
protocol: c[4] || "",
doubleSlash: c[5] || "",
authority: c[6] || "",
username: c[8] || "",
password: c[9] || "",
host: c[10] || "",
hostname: c[11] || "",
port: c[12] || "",
pathname: c[13] || "",
directory: c[14] || "",
filename: c[15] || "",
search: c[16] || "",
hash: c[17] || "",
};
},
makePathAbsolute: function (a, b) {
var c, d, e, f;
if (a && "/" === a.charAt(0)) return a;
for (a = a || "", b = b ? b.replace(/^\/|(\/[^\/]*|[^\/]+)$/g, "") : "", c = b ? b.split("/") : [], d = a.split("/"), e = 0; e < d.length; e++)
switch ((f = d[e])) {
case ".":
break;
case "..":
c.length && c.pop();
break;
default:
c.push(f);
}
return "/" + c.join("/");
},
isSameDomain: function (a, b) {
return d.parseUrl(a).domain.toLowerCase() === d.parseUrl(b).domain.toLowerCase();
},
isRelativeUrl: function (a) {
return "" === d.parseUrl(a).protocol;
},
isAbsoluteUrl: function (a) {
return "" !== d.parseUrl(a).protocol;
},
makeUrlAbsolute: function (a, b) {
if (!d.isRelativeUrl(a)) return a;
b === c && (b = this.documentBase);
var e = d.parseUrl(a),
f = d.parseUrl(b),
g = e.protocol || f.protocol,
h = e.protocol ? e.doubleSlash : e.doubleSlash || f.doubleSlash,
i = e.authority || f.authority,
j = "" !== e.pathname,
k = d.makePathAbsolute(e.pathname || f.filename, f.pathname),
l = e.search || (!j && f.search) || "",
m = e.hash;
return g + h + i + k + l + m;
},
addSearchParams: function (b, c) {
var e = d.parseUrl(b),
f = "object" == typeof c ? a.param(c) : c,
g = e.search || "?";
return e.hrefNoSearch + g + ("?" !== g.charAt(g.length - 1) ? "&" : "") + f + (e.hash || "");
},
convertUrlToDataUrl: function (a) {
var c = a,
e = d.parseUrl(a);
return (
d.isEmbeddedPage(e)
? (c = e.hash.split(f)[0].replace(/^#/, "").replace(/\?.*$/, ""))
: d.isSameDomain(e, this.documentBase) && (c = e.hrefNoHash.replace(this.documentBase.domain, "").split(f)[0]),
b.decodeURIComponent(c)
);
},
get: function (a) {
return a === c && (a = d.parseLocation().hash), d.stripHash(a).replace(/[^\/]*\.[^\/*]+$/, "");
},
set: function (a) {
location.hash = a;
},
isPath: function (a) {
return /\//.test(a);
},
clean: function (a) {
return a.replace(this.documentBase.domain, "");
},
stripHash: function (a) {
return a.replace(/^#/, "");
},
stripQueryParams: function (a) {
return a.replace(/\?.*$/, "");
},
cleanHash: function (a) {
return d.stripHash(a.replace(/\?.*$/, "").replace(f, ""));
},
isHashValid: function (a) {
return /^#[^#]+$/.test(a);
},
isExternal: function (a) {
var b = d.parseUrl(a);
return !(!b.protocol || b.domain.toLowerCase() === this.documentUrl.domain.toLowerCase());
},
hasProtocol: function (a) {
return /^(:?\w+:)/.test(a);
},
isEmbeddedPage: function (a) {
var b = d.parseUrl(a);
return "" !== b.protocol
? !this.isPath(b.hash) && b.hash && (b.hrefNoHash === this.documentUrl.hrefNoHash || (this.documentBaseDiffers && b.hrefNoHash === this.documentBase.hrefNoHash))
: /^#/.test(b.href);
},
squash: function (a, b) {
var c,
e,
f,
g,
h,
i = this.isPath(a),
j = this.parseUrl(a),
k = j.hash,
l = "";
return (
b || (i ? (b = d.getLocation()) : ((h = d.getDocumentUrl(!0)), (b = d.isPath(h.hash) ? d.squash(h.href) : h.href))),
(e = i ? d.stripHash(a) : a),
(e = d.isPath(j.hash) ? d.stripHash(j.hash) : e),
(g = e.indexOf(this.uiStateKey)),
g > -1 && ((l = e.slice(g)), (e = e.slice(0, g))),
(c = d.makeUrlAbsolute(e, b)),
(f = this.parseUrl(c).search),
i
? ((d.isPath(k) || 0 === k.replace("#", "").indexOf(this.uiStateKey)) && (k = ""),
l && -1 === k.indexOf(this.uiStateKey) && (k += l),
-1 === k.indexOf("#") && "" !== k && (k = "#" + k),
(c = d.parseUrl(c)),
(c = c.protocol + c.doubleSlash + c.host + c.pathname + f + k))
: (c += c.indexOf("#") > -1 ? l : "#" + l),
c
);
},
isPreservableHash: function (a) {
return 0 === a.replace("#", "").indexOf(this.uiStateKey);
},
hashToSelector: function (a) {
var b = "#" === a.substring(0, 1);
return b && (a = a.substring(1)), (b ? "#" : "") + a.replace(/([!"#$%&'()*+,./:;<=>?@[\]^`{|}~])/g, "\\$1");
},
getFilePath: function (a) {
return a && a.split(f)[0];
},
isFirstPageUrl: function (b) {
var e = d.parseUrl(d.makeUrlAbsolute(b, this.documentBase)),
f = e.hrefNoHash === this.documentUrl.hrefNoHash || (this.documentBaseDiffers && e.hrefNoHash === this.documentBase.hrefNoHash),
g = a.mobile.firstPage,
h = g && g[0] ? g[0].id : c;
return f && (!e.hash || "#" === e.hash || (h && e.hash.replace(/^#/, "") === h));
},
isPermittedCrossDomainRequest: function (b, c) {
return a.mobile.allowCrossDomainPages && ("file:" === b.protocol || "content:" === b.protocol) && -1 !== c.search(/^https?:/);
},
}),
(d.documentUrl = d.parseLocation()),
(e = a("head").find("base")),
(d.documentBase = e.length ? d.parseUrl(d.makeUrlAbsolute(e.attr("href"), d.documentUrl.href)) : d.documentUrl),
(d.documentBaseDiffers = d.documentUrl.hrefNoHash !== d.documentBase.hrefNoHash),
(d.getDocumentBase = function (b) {
return b ? a.extend({}, d.documentBase) : d.documentBase.href;
}),
a.extend(a.mobile, { getDocumentUrl: d.getDocumentUrl, getDocumentBase: d.getDocumentBase });
})(a),
(function (a, b) {
(a.mobile.History = function (a, b) {
(this.stack = a || []), (this.activeIndex = b || 0);
}),
a.extend(a.mobile.History.prototype, {
getActive: function () {
return this.stack[this.activeIndex];
},
getLast: function () {
return this.stack[this.previousIndex];
},
getNext: function () {
return this.stack[this.activeIndex + 1];
},
getPrev: function () {
return this.stack[this.activeIndex - 1];
},
add: function (a, b) {
(b = b || {}),
this.getNext() && this.clearForward(),
b.hash && -1 === b.hash.indexOf("#") && (b.hash = "#" + b.hash),
(b.url = a),
this.stack.push(b),
(this.activeIndex = this.stack.length - 1);
},
clearForward: function () {
this.stack = this.stack.slice(0, this.activeIndex + 1);
},
find: function (a, b, c) {
b = b || this.stack;
var d,
e,
f,
g = b.length;
for (e = 0; g > e; e++) if (((d = b[e]), (decodeURIComponent(a) === decodeURIComponent(d.url) || decodeURIComponent(a) === decodeURIComponent(d.hash)) && ((f = e), c))) return f;
return f;
},
closest: function (a) {
var c,
d = this.activeIndex;
return (c = this.find(a, this.stack.slice(0, d))), c === b && ((c = this.find(a, this.stack.slice(d), !0)), (c = c === b ? c : c + d)), c;
},
direct: function (c) {
var d = this.closest(c.url),
e = this.activeIndex;
d !== b && ((this.activeIndex = d), (this.previousIndex = e)),
e > d
? (c.present || c.back || a.noop)(this.getActive(), "back")
: d > e
? (c.present || c.forward || a.noop)(this.getActive(), "forward")
: d === b && c.missing && c.missing(this.getActive());
},
});
})(a),
(function (a) {
var d = a.mobile.path,
e = location.href;
(a.mobile.Navigator = function (b) {
(this.history = b), (this.ignoreInitialHashChange = !0), a.mobile.window.bind({ "popstate.history": a.proxy(this.popstate, this), "hashchange.history": a.proxy(this.hashchange, this) });
}),
a.extend(a.mobile.Navigator.prototype, {
squash: function (e, f) {
var g,
h,
i = d.isPath(e) ? d.stripHash(e) : e;
return (h = d.squash(e)), (g = a.extend({ hash: i, url: h }, f)), b.history.replaceState(g, g.title || c.title, h), g;
},
hash: function (a, b) {
var c, e, f, g;
return (
(c = d.parseUrl(a)),
(e = d.parseLocation()),
e.pathname + e.search === c.pathname + c.search
? (f = c.hash ? c.hash : c.pathname + c.search)
: d.isPath(a)
? ((g = d.parseUrl(b)), (f = g.pathname + g.search + (d.isPreservableHash(g.hash) ? g.hash.replace("#", "") : "")))
: (f = a),
f
);
},
go: function (e, f, g) {
var h,
i,
j,
k,
l = a.event.special.navigate.isPushStateEnabled();
(i = d.squash(e)),
(j = this.hash(e, i)),
g && j !== d.stripHash(d.parseLocation().hash) && (this.preventNextHashChange = g),
(this.preventHashAssignPopState = !0),
(b.location.hash = j),
(this.preventHashAssignPopState = !1),
(h = a.extend({ url: i, hash: j, title: c.title }, f)),
l && ((k = new a.Event("popstate")), (k.originalEvent = { type: "popstate", state: null }), this.squash(e, h), g || ((this.ignorePopState = !0), a.mobile.window.trigger(k))),
this.history.add(h.url, h);
},
popstate: function (b) {
var c, f;
if (a.event.special.navigate.isPushStateEnabled())
return this.preventHashAssignPopState
? ((this.preventHashAssignPopState = !1), void b.stopImmediatePropagation())
: this.ignorePopState
? void (this.ignorePopState = !1)
: !b.originalEvent.state && 1 === this.history.stack.length && this.ignoreInitialHashChange && ((this.ignoreInitialHashChange = !1), location.href === e)
? void b.preventDefault()
: ((c = d.parseLocation().hash),
!b.originalEvent.state && c
? ((f = this.squash(c)), this.history.add(f.url, f), void (b.historyState = f))
: void this.history.direct({
url: (b.originalEvent.state || {}).url || c,
present: function (c, d) {
(b.historyState = a.extend({}, c)), (b.historyState.direction = d);
},
}));
},
hashchange: function (b) {
var e, f;
if (a.event.special.navigate.isHashChangeEnabled() && !a.event.special.navigate.isPushStateEnabled()) {
if (this.preventNextHashChange) return (this.preventNextHashChange = !1), void b.stopImmediatePropagation();
(e = this.history),
(f = d.parseLocation().hash),
this.history.direct({
url: f,
present: function (c, d) {
(b.hashchangeState = a.extend({}, c)), (b.hashchangeState.direction = d);
},
missing: function () {
e.add(f, { hash: f, title: c.title });
},
});
}
},
});
})(a),
(function (a) {
(a.mobile.navigate = function (b, c, d) {
a.mobile.navigate.navigator.go(b, c, d);
}),
(a.mobile.navigate.history = new a.mobile.History()),
(a.mobile.navigate.navigator = new a.mobile.Navigator(a.mobile.navigate.history));
var b = a.mobile.path.parseLocation();
a.mobile.navigate.history.add(b.href, { hash: b.hash });
})(a),
(function (a, b) {
var d = { animation: {}, transition: {} },
e = c.createElement("a"),
f = ["", "webkit-", "moz-", "o-"];
a.each(["animation", "transition"], function (c, g) {
var h = 0 === c ? g + "-name" : g;
a.each(f, function (c, f) {
return e.style[a.camelCase(f + h)] !== b ? ((d[g].prefix = f), !1) : void 0;
}),
(d[g].duration = a.camelCase(d[g].prefix + g + "-duration")),
(d[g].event = a.camelCase(d[g].prefix + g + "-end")),
"" === d[g].prefix && (d[g].event = d[g].event.toLowerCase());
}),
(a.support.cssTransitions = d.transition.prefix !== b),
(a.support.cssAnimations = d.animation.prefix !== b),
a(e).remove(),
(a.fn.animationComplete = function (e, f, g) {
var h,
i,
j = this,
k = function () {
clearTimeout(h), e.apply(this, arguments);
},
l = f && "animation" !== f ? "transition" : "animation";
return (a.support.cssTransitions && "transition" === l) || (a.support.cssAnimations && "animation" === l)
? (g === b && (a(this).context !== c && (i = 3e3 * parseFloat(a(this).css(d[l].duration))), (0 === i || i === b || isNaN(i)) && (i = a.fn.animationComplete.defaultDuration)),
(h = setTimeout(function () {
a(j).off(d[l].event, k), e.apply(j);
}, i)),
a(this).one(d[l].event, k))
: (setTimeout(a.proxy(e, this), 0), a(this));
}),
(a.fn.animationComplete.defaultDuration = 1e3);
})(a),
(function (a, b, c, d) {
function e(a) {
for (; a && "undefined" != typeof a.originalEvent;) a = a.originalEvent;
return a;
}
function f(b, c) {
var f,
g,
h,
i,
j,
k,
l,
m,
n,
o = b.type;
if (((b = a.Event(b)), (b.type = c), (f = b.originalEvent), (g = a.event.props), o.search(/^(mouse|click)/) > -1 && (g = E), f)) for (l = g.length, i; l;) (i = g[--l]), (b[i] = f[i]);
if (
(o.search(/mouse(down|up)|click/) > -1 && !b.which && (b.which = 1),
-1 !== o.search(/^touch/) && ((h = e(f)), (o = h.touches), (j = h.changedTouches), (k = o && o.length ? o[0] : j && j.length ? j[0] : d)))
)
for (m = 0, n = C.length; n > m; m++) (i = C[m]), (b[i] = k[i]);
return b;
}
function g(b) {
for (var c, d, e = {}; b;) {
c = a.data(b, z);
for (d in c) c[d] && (e[d] = e.hasVirtualBinding = !0);
b = b.parentNode;
}
return e;
}
function h(b, c) {
for (var d; b;) {
if (((d = a.data(b, z)), d && (!c || d[c]))) return b;
b = b.parentNode;
}
return null;
}
function i() {
M = !1;
}
function j() {
M = !0;
}
function k() {
(Q = 0), (K.length = 0), (L = !1), j();
}
function l() {
i();
}
function m() {
n(),
(G = setTimeout(function () {
(G = 0), k();
}, a.vmouse.resetTimerDuration));
}
function n() {
G && (clearTimeout(G), (G = 0));
}
function o(b, c, d) {
var e;
return ((d && d[b]) || (!d && h(c.target, b))) && ((e = f(c, b)), a(c.target).trigger(e)), e;
}
function p(b) {
var c,
d = a.data(b.target, A);
L ||
(Q && Q === d) ||
((c = o("v" + b.type, b)),
c && (c.isDefaultPrevented() && b.preventDefault(), c.isPropagationStopped() && b.stopPropagation(), c.isImmediatePropagationStopped() && b.stopImmediatePropagation()));
}
function q(b) {
var c,
d,
f,
h = e(b).touches;
h &&
1 === h.length &&
((c = b.target),
(d = g(c)),
d.hasVirtualBinding && ((Q = P++), a.data(c, A, Q), n(), l(), (J = !1), (f = e(b).touches[0]), (H = f.pageX), (I = f.pageY), o("vmouseover", b, d), o("vmousedown", b, d)));
}
function r(a) {
M || (J || o("vmousecancel", a, g(a.target)), (J = !0), m());
}
function s(b) {
if (!M) {
var c = e(b).touches[0],
d = J,
f = a.vmouse.moveDistanceThreshold,
h = g(b.target);
(J = J || Math.abs(c.pageX - H) > f || Math.abs(c.pageY - I) > f), J && !d && o("vmousecancel", b, h), o("vmousemove", b, h), m();
}
}
function t(a) {
if (!M) {
j();
var b,
c,
d = g(a.target);
o("vmouseup", a, d),
J || ((b = o("vclick", a, d)), b && b.isDefaultPrevented() && ((c = e(a).changedTouches[0]), K.push({ touchID: Q, x: c.clientX, y: c.clientY }), (L = !0))),
o("vmouseout", a, d),
(J = !1),
m();
}
}
function u(b) {
var c,
d = a.data(b, z);
if (d) for (c in d) if (d[c]) return !0;
return !1;
}
function v() { }
function w(b) {
var c = b.substr(1);
return {
setup: function () {
u(this) || a.data(this, z, {});
var d = a.data(this, z);
(d[b] = !0),
(F[b] = (F[b] || 0) + 1),
1 === F[b] && O.bind(c, p),
a(this).bind(c, v),
N && ((F.touchstart = (F.touchstart || 0) + 1), 1 === F.touchstart && O.bind("touchstart", q).bind("touchend", t).bind("touchmove", s).bind("scroll", r));
},
teardown: function () {
--F[b], F[b] || O.unbind(c, p), N && (--F.touchstart, F.touchstart || O.unbind("touchstart", q).unbind("touchmove", s).unbind("touchend", t).unbind("scroll", r));
var d = a(this),
e = a.data(this, z);
e && (e[b] = !1), d.unbind(c, v), u(this) || d.removeData(z);
},
};
}
var x,
y,
z = "virtualMouseBindings",
A = "virtualTouchID",
B = "vmouseover vmousedown vmousemove vmouseup vclick vmouseout vmousecancel".split(" "),
C = "clientX clientY pageX pageY screenX screenY".split(" "),
D = a.event.mouseHooks ? a.event.mouseHooks.props : [],
E = a.event.props.concat(D),
F = {},
G = 0,
H = 0,
I = 0,
J = !1,
K = [],
L = !1,
M = !1,
N = "addEventListener" in c,
O = a(c),
P = 1,
Q = 0;
for (a.vmouse = { moveDistanceThreshold: 10, clickDistanceThreshold: 10, resetTimerDuration: 1500 }, y = 0; y < B.length; y++) a.event.special[B[y]] = w(B[y]);
N &&
c.addEventListener(
"click",
function (b) {
var c,
d,
e,
f,
g,
h,
i = K.length,
j = b.target;
if (i)
for (c = b.clientX, d = b.clientY, x = a.vmouse.clickDistanceThreshold, e = j; e;) {
for (f = 0; i > f; f++)
if (((g = K[f]), (h = 0), (e === j && Math.abs(g.x - c) < x && Math.abs(g.y - d) < x) || a.data(e, A) === g.touchID)) return b.preventDefault(), void b.stopPropagation();
e = e.parentNode;
}
},
!0
);
})(a, b, c),
(function (a, b, d) {
function e(b, c, e, f) {
var g = e.type;
(e.type = c), f ? a.event.trigger(e, d, b) : a.event.dispatch.call(b, e), (e.type = g);
}
var f = a(c),
g = a.mobile.support.touch,
h = "touchmove scroll",
i = g ? "touchstart" : "mousedown",
j = g ? "touchend" : "mouseup",
k = g ? "touchmove" : "mousemove";
a.each("touchstart touchmove touchend tap taphold swipe swipeleft swiperight scrollstart scrollstop".split(" "), function (b, c) {
(a.fn[c] = function (a) {
return a ? this.bind(c, a) : this.trigger(c);
}),
a.attrFn && (a.attrFn[c] = !0);
}),
(a.event.special.scrollstart = {
enabled: !0,
setup: function () {
function b(a, b) {
(c = b), e(f, c ? "scrollstart" : "scrollstop", a);
}
var c,
d,
f = this,
g = a(f);
g.bind(h, function (e) {
a.event.special.scrollstart.enabled &&
(c || b(e, !0),
clearTimeout(d),
(d = setTimeout(function () {
b(e, !1);
}, 50)));
});
},
teardown: function () {
a(this).unbind(h);
},
}),
(a.event.special.tap = {
tapholdThreshold: 750,
emitTapOnTaphold: !0,
setup: function () {
var b = this,
c = a(b),
d = !1;
c.bind("vmousedown", function (g) {
function h() {
clearTimeout(k);
}
function i() {
h(), c.unbind("vclick", j).unbind("vmouseup", h), f.unbind("vmousecancel", i);
}
function j(a) {
i(), d || l !== a.target ? d && a.preventDefault() : e(b, "tap", a);
}
if (((d = !1), g.which && 1 !== g.which)) return !1;
var k,
l = g.target;
c.bind("vmouseup", h).bind("vclick", j),
f.bind("vmousecancel", i),
(k = setTimeout(function () {
a.event.special.tap.emitTapOnTaphold || (d = !0), e(b, "taphold", a.Event("taphold", { target: l }));
}, a.event.special.tap.tapholdThreshold));
});
},
teardown: function () {
a(this).unbind("vmousedown").unbind("vclick").unbind("vmouseup"), f.unbind("vmousecancel");
},
}),
(a.event.special.swipe = {
scrollSupressionThreshold: 30,
durationThreshold: 1e3,
horizontalDistanceThreshold: 30,
verticalDistanceThreshold: 30,
getLocation: function (a) {
var c = b.pageXOffset,
d = b.pageYOffset,
e = a.clientX,
f = a.clientY;
return (
(0 === a.pageY && Math.floor(f) > Math.floor(a.pageY)) || (0 === a.pageX && Math.floor(e) > Math.floor(a.pageX))
? ((e -= c), (f -= d))
: (f < a.pageY - d || e < a.pageX - c) && ((e = a.pageX - c), (f = a.pageY - d)),
{ x: e, y: f }
);
},
start: function (b) {
var c = b.originalEvent.touches ? b.originalEvent.touches[0] : b,
d = a.event.special.swipe.getLocation(c);
return { time: new Date().getTime(), coords: [d.x, d.y], origin: a(b.target) };
},
stop: function (b) {
var c = b.originalEvent.touches ? b.originalEvent.touches[0] : b,
d = a.event.special.swipe.getLocation(c);
return { time: new Date().getTime(), coords: [d.x, d.y] };
},
handleSwipe: function (b, c, d, f) {
if (
c.time - b.time < a.event.special.swipe.durationThreshold &&
Math.abs(b.coords[0] - c.coords[0]) > a.event.special.swipe.horizontalDistanceThreshold &&
Math.abs(b.coords[1] - c.coords[1]) < a.event.special.swipe.verticalDistanceThreshold
) {
var g = b.coords[0] > c.coords[0] ? "swipeleft" : "swiperight";
return e(d, "swipe", a.Event("swipe", { target: f, swipestart: b, swipestop: c }), !0), e(d, g, a.Event(g, { target: f, swipestart: b, swipestop: c }), !0), !0;
}
return !1;
},
eventInProgress: !1,
setup: function () {
var b,
c = this,
d = a(c),
e = {};
(b = a.data(this, "mobile-events")),
b || ((b = { length: 0 }), a.data(this, "mobile-events", b)),
b.length++,
(b.swipe = e),
(e.start = function (b) {
if (!a.event.special.swipe.eventInProgress) {
a.event.special.swipe.eventInProgress = !0;
var d,
g = a.event.special.swipe.start(b),
h = b.target,
i = !1;
(e.move = function (b) {
g &&
!b.isDefaultPrevented() &&
((d = a.event.special.swipe.stop(b)),
i || ((i = a.event.special.swipe.handleSwipe(g, d, c, h)), i && (a.event.special.swipe.eventInProgress = !1)),
Math.abs(g.coords[0] - d.coords[0]) > a.event.special.swipe.scrollSupressionThreshold && b.preventDefault());
}),
(e.stop = function () {
(i = !0), (a.event.special.swipe.eventInProgress = !1), f.off(k, e.move), (e.move = null);
}),
f.on(k, e.move).one(j, e.stop);
}
}),
d.on(i, e.start);
},
teardown: function () {
var b, c;
(b = a.data(this, "mobile-events")),
b && ((c = b.swipe), delete b.swipe, b.length--, 0 === b.length && a.removeData(this, "mobile-events")),
c && (c.start && a(this).off(i, c.start), c.move && f.off(k, c.move), c.stop && f.off(j, c.stop));
},
}),
a.each({ scrollstop: "scrollstart", taphold: "tap", swipeleft: "swipe.left", swiperight: "swipe.right" }, function (b, c) {
a.event.special[b] = {
setup: function () {
a(this).bind(c, a.noop);
},
teardown: function () {
a(this).unbind(c);
},
};
});
})(a, this),
(function (a) {
a.event.special.throttledresize = {
setup: function () {
a(this).bind("resize", f);
},
teardown: function () {
a(this).unbind("resize", f);
},
};
var b,
c,
d,
e = 250,
f = function () {
(c = new Date().getTime()), (d = c - g), d >= e ? ((g = c), a(this).trigger("throttledresize")) : (b && clearTimeout(b), (b = setTimeout(f, e - d)));
},
g = 0;
})(a),
(function (a, b) {
function d() {
var a = e();
a !== f && ((f = a), l.trigger(m));
}
var e,
f,
g,
h,
i,
j,
k,
l = a(b),
m = "orientationchange",
n = { 0: !0, 180: !0 };
a.support.orientation &&
((i = b.innerWidth || l.width()), (j = b.innerHeight || l.height()), (k = 50), (g = i > j && i - j > k), (h = n[b.orientation]), ((g && h) || (!g && !h)) && (n = { "-90": !0, 90: !0 })),
(a.event.special.orientationchange = a.extend({}, a.event.special.orientationchange, {
setup: function () {
return a.support.orientation && !a.event.special.orientationchange.disabled ? !1 : ((f = e()), void l.bind("throttledresize", d));
},
teardown: function () {
return a.support.orientation && !a.event.special.orientationchange.disabled ? !1 : void l.unbind("throttledresize", d);
},
add: function (a) {
var b = a.handler;
a.handler = function (a) {
return (a.orientation = e()), b.apply(this, arguments);
};
},
})),
(a.event.special.orientationchange.orientation = e =
function () {
var d = !0,
e = c.documentElement;
return (d = a.support.orientation ? n[b.orientation] : e && e.clientWidth / e.clientHeight < 1.1), d ? "portrait" : "landscape";
}),
(a.fn[m] = function (a) {
return a ? this.bind(m, a) : this.trigger(m);
}),
a.attrFn && (a.attrFn[m] = !0);
})(a, this),
(function (a) {
var b = a("head").children("base"),
c = {
element: b.length ? b : a("<base>", { href: a.mobile.path.documentBase.hrefNoHash }).prependTo(a("head")),
linkSelector: "[src], link[href], a[rel='external'], :jqmData(ajax='false'), a[target]",
set: function (b) {
a.mobile.dynamicBaseEnabled && a.support.dynamicBaseTag && c.element.attr("href", a.mobile.path.makeUrlAbsolute(b, a.mobile.path.documentBase));
},
rewrite: function (b, d) {
var e = a.mobile.path.get(b);
d.find(c.linkSelector).each(function (b, c) {
var d = a(c).is("[href]") ? "href" : a(c).is("[src]") ? "src" : "action",
f = a.mobile.path.parseLocation(),
g = a(c).attr(d);
(g = g.replace(f.protocol + f.doubleSlash + f.host + f.pathname, "")), /^(\w+:|#|\/)/.test(g) || a(c).attr(d, e + g);
});
},
reset: function () {
c.element.attr("href", a.mobile.path.documentBase.hrefNoSearch);
},
};
a.mobile.base = c;
})(a),
(function (a, b) {
a.mobile.widgets = {};
var c = a.widget,
d = a.mobile.keepNative;
(a.widget = (function (c) {
return function () {
var d = c.apply(this, arguments),
e = d.prototype.widgetName;
return (d.initSelector = d.prototype.initSelector !== b ? d.prototype.initSelector : ":jqmData(role='" + e + "')"), (a.mobile.widgets[e] = d), d;
};
})(a.widget)),
a.extend(a.widget, c),
a.mobile.document.on("create", function (b) {
a(b.target).enhanceWithin();
}),
a.widget("mobile.page", {
options: { theme: "a", domCache: !1, keepNativeDefault: a.mobile.keepNative, contentTheme: null, enhanced: !1 },
_createWidget: function () {
a.Widget.prototype._createWidget.apply(this, arguments), this._trigger("init");
},
_create: function () {
return this._trigger("beforecreate") === !1
? !1
: (this.options.enhanced || this._enhance(),
this._on(this.element, { pagebeforehide: "removeContainerBackground", pagebeforeshow: "_handlePageBeforeShow" }),
this.element.enhanceWithin(),
void ("dialog" === a.mobile.getAttribute(this.element[0], "role") && a.mobile.dialog && this.element.dialog()));
},
_enhance: function () {
var c = "data-" + a.mobile.ns,
d = this;
this.options.role && this.element.attr("data-" + a.mobile.ns + "role", this.options.role),
this.element.attr("tabindex", "0").addClass("ui-page ui-page-theme-" + this.options.theme),
this.element.find("[" + c + "role='content']").each(function () {
var e = a(this),
f = this.getAttribute(c + "theme") || b;
(d.options.contentTheme = f || d.options.contentTheme || (d.options.dialog && d.options.theme) || ("dialog" === d.element.jqmData("role") && d.options.theme)),
e.addClass("ui-content"),
d.options.contentTheme && e.addClass("ui-body-" + d.options.contentTheme),
e.attr("role", "main").addClass("ui-content");
});
},
bindRemove: function (b) {
var c = this.element;
!c.data("mobile-page").options.domCache &&
c.is(":jqmData(external-page='true')") &&
c.bind(
"pagehide.remove",
b ||
function (b, c) {
if (!c.samePage) {
var d = a(this),
e = new a.Event("pageremove");
d.trigger(e), e.isDefaultPrevented() || d.removeWithDependents();
}
}
);
},
_setOptions: function (c) {
c.theme !== b && this.element.removeClass("ui-page-theme-" + this.options.theme).addClass("ui-page-theme-" + c.theme),
c.contentTheme !== b &&
this.element
.find("[data-" + a.mobile.ns + "='content']")
.removeClass("ui-body-" + this.options.contentTheme)
.addClass("ui-body-" + c.contentTheme);
},
_handlePageBeforeShow: function () {
this.setContainerBackground();
},
removeContainerBackground: function () {
this.element.closest(":mobile-pagecontainer").pagecontainer({ theme: "none" });
},
setContainerBackground: function (a) {
this.element.parent().pagecontainer({ theme: a || this.options.theme });
},
keepNativeSelector: function () {
var b = this.options,
c = a.trim(b.keepNative || ""),
e = a.trim(a.mobile.keepNative),
f = a.trim(b.keepNativeDefault),
g = d === e ? "" : e,
h = "" === g ? f : "";
return (c ? [c] : [])
.concat(g ? [g] : [])
.concat(h ? [h] : [])
.join(", ");
},
});
})(a),
(function (a, d) {
a.widget("mobile.pagecontainer", {
options: { theme: "a" },
initSelector: !1,
_create: function () {
this._trigger("beforecreate"),
(this.setLastScrollEnabled = !0),
this._on(this.window, { navigate: "_disableRecordScroll", scrollstop: "_delayedRecordScroll" }),
this._on(this.window, { navigate: "_filterNavigateEvents" }),
this._on({ pagechange: "_afterContentChange" }),
this.window.one(
"navigate",
a.proxy(function () {
this.setLastScrollEnabled = !0;
}, this)
);
},
_setOptions: function (a) {
a.theme !== d && "none" !== a.theme
? this.element.removeClass("ui-overlay-" + this.options.theme).addClass("ui-overlay-" + a.theme)
: a.theme !== d && this.element.removeClass("ui-overlay-" + this.options.theme),
this._super(a);
},
_disableRecordScroll: function () {
this.setLastScrollEnabled = !1;
},
_enableRecordScroll: function () {
this.setLastScrollEnabled = !0;
},
_afterContentChange: function () {
(this.setLastScrollEnabled = !0), this._off(this.window, "scrollstop"), this._on(this.window, { scrollstop: "_delayedRecordScroll" });
},
_recordScroll: function () {
if (this.setLastScrollEnabled) {
var a,
b,
c,
d = this._getActiveHistory();
d && ((a = this._getScroll()), (b = this._getMinScroll()), (c = this._getDefaultScroll()), (d.lastScroll = b > a ? c : a));
}
},
_delayedRecordScroll: function () {
setTimeout(a.proxy(this, "_recordScroll"), 100);
},
_getScroll: function () {
return this.window.scrollTop();
},
_getMinScroll: function () {
return a.mobile.minScrollBack;
},
_getDefaultScroll: function () {
return a.mobile.defaultHomeScroll;
},
_filterNavigateEvents: function (b, c) {
var d;
(b.originalEvent && b.originalEvent.isDefaultPrevented()) ||
((d = b.originalEvent.type.indexOf("hashchange") > -1 ? c.state.hash : c.state.url),
d || (d = this._getHash()),
(d && "#" !== d && 0 !== d.indexOf("#" + a.mobile.path.uiStateKey)) || (d = location.href),
this._handleNavigate(d, c.state));
},
_getHash: function () {
return a.mobile.path.parseLocation().hash;
},
getActivePage: function () {
return this.activePage;
},
_getInitialContent: function () {
return a.mobile.firstPage;
},
_getHistory: function () {
return a.mobile.navigate.history;
},
_getActiveHistory: function () {
return this._getHistory().getActive();
},
_getDocumentBase: function () {
return a.mobile.path.documentBase;
},
back: function () {
this.go(-1);
},
forward: function () {
this.go(1);
},
go: function (c) {
if (a.mobile.hashListeningEnabled) b.history.go(c);
else {
var d = a.mobile.navigate.history.activeIndex,
e = d + parseInt(c, 10),
f = a.mobile.navigate.history.stack[e].url,
g = c >= 1 ? "forward" : "back";
(a.mobile.navigate.history.activeIndex = e), (a.mobile.navigate.history.previousIndex = d), this.change(f, { direction: g, changeHash: !1, fromHashChange: !0 });
}
},
_handleDestination: function (b) {
var c;
return (
"string" === a.type(b) && (b = a.mobile.path.stripHash(b)),
b && ((c = this._getHistory()), (b = a.mobile.path.isPath(b) ? b : a.mobile.path.makeUrlAbsolute("#" + b, this._getDocumentBase()))),
b || this._getInitialContent()
);
},
_transitionFromHistory: function (a, b) {
var c = this._getHistory(),
d = "back" === a ? c.getLast() : c.getActive();
return (d && d.transition) || b;
},
_handleDialog: function (b, c) {
var d,
e,
f = this.getActivePage();
return f && !f.data("mobile-dialog")
? ("back" === c.direction ? this.back() : this.forward(), !1)
: ((d = c.pageUrl), (e = this._getActiveHistory()), a.extend(b, { role: e.role, transition: this._transitionFromHistory(c.direction, b.transition), reverse: "back" === c.direction }), d);
},
_handleNavigate: function (b, c) {
var d = a.mobile.path.stripHash(b),
e = this._getHistory(),
f = 0 === e.stack.length ? "none" : this._transitionFromHistory(c.direction),
g = { changeHash: !1, fromHashChange: !0, reverse: "back" === c.direction };
a.extend(g, c, { transition: f }),
(e.activeIndex > 0 && d.indexOf(a.mobile.dialogHashKey) > -1 && ((d = this._handleDialog(g, c)), d === !1)) || this._changeContent(this._handleDestination(d), g);
},
_changeContent: function (b, c) {
a.mobile.changePage(b, c);
},
_getBase: function () {
return a.mobile.base;
},
_getNs: function () {
return a.mobile.ns;
},
_enhance: function (a, b) {
return a.page({ role: b });
},
_include: function (a, b) {
a.appendTo(this.element), this._enhance(a, b.role), a.page("bindRemove");
},
_find: function (b) {
var c,
d = this._createFileUrl(b),
e = this._createDataUrl(b),
f = this._getInitialContent();
return (
(c = this.element.children("[data-" + this._getNs() + "url='" + a.mobile.path.hashToSelector(e) + "']")),
0 === c.length &&
e &&
!a.mobile.path.isPath(e) &&
(c = this.element
.children(a.mobile.path.hashToSelector("#" + e))
.attr("data-" + this._getNs() + "url", e)
.jqmData("url", e)),
0 === c.length && a.mobile.path.isFirstPageUrl(d) && f && f.parent().length && (c = a(f)),
c
);
},
_parse: function (b, c) {
var d,
e = a("<div></div>");
return (
(e.get(0).innerHTML = b),
(d = e.find(":jqmData(role='page'), :jqmData(role='dialog')").first()),
d.length || (d = a("<div data-" + this._getNs() + "role='page'>" + (b.split(/<\/?body[^>]*>/gim)[1] || "") + "</div>")),
d.attr("data-" + this._getNs() + "url", this._createDataUrl(c)).attr("data-" + this._getNs() + "external-page", !0),
d
);
},
_setLoadedTitle: function (b, c) {
var d = c.match(/<title[^>]*>([^<]*)/) && RegExp.$1;
d && !b.jqmData("title") && ((d = a("<div>" + d + "</div>").text()), b.jqmData("title", d));
},
_isRewritableBaseTag: function () {
return a.mobile.dynamicBaseEnabled && !a.support.dynamicBaseTag;
},
_createDataUrl: function (b) {
return a.mobile.path.convertUrlToDataUrl(b);
},
_createFileUrl: function (b) {
return a.mobile.path.getFilePath(b);
},
_triggerWithDeprecated: function (b, c, d) {
var e = a.Event("page" + b),
f = a.Event(this.widgetName + b);
return (d || this.element).trigger(e, c), this._trigger(b, f, c), { deprecatedEvent: e, event: f };
},
_getTransitionHandler: function (b) {
return (b = a.mobile._maybeDegradeTransition(b)), a.mobile.transitionHandlers[b] || a.mobile.defaultTransitionHandler;
},
_triggerCssTransitionEvents: function (b, c, d) {
var e = !1;
(d = d || ""),
c && (b[0] === c[0] && (e = !0), this._triggerWithDeprecated(d + "hide", { nextPage: b, toPage: b, prevPage: c, samePage: e }, c)),
this._triggerWithDeprecated(d + "show", { prevPage: c || a(""), toPage: b }, b);
},
_cssTransition: function (b, c, d) {
var e,
f,
g = d.transition,
h = d.reverse,
i = d.deferred;
this._triggerCssTransitionEvents(b, c, "before"),
// this._hideLoading(),
(e = this._getTransitionHandler(g)),
(f = new e(g, h, b, c).transition()),
f.done(
a.proxy(function () {
this._triggerCssTransitionEvents(b, c);
}, this)
),
f.done(function () {
i.resolve.apply(i, arguments);
});
},
_releaseTransitionLock: function () {
(f = !1), e.length > 0 && a.mobile.changePage.apply(null, e.pop());
},
_removeActiveLinkClass: function (b) {
a.mobile.removeActiveLinkClass(b);
},
_loadUrl: function (b, c, d) {
(d.target = b),
(d.deferred = a.Deferred()),
this.load(b, d),
d.deferred.done(
a.proxy(function (a, b, d) {
(f = !1), (b.absUrl = c.absUrl), this.transition(d, c, b);
}, this)
),
d.deferred.fail(
a.proxy(function () {
this._removeActiveLinkClass(!0), this._releaseTransitionLock(), this._triggerWithDeprecated("changefailed", c);
}, this)
);
},
_triggerPageBeforeChange: function (b, c, d) {
var e;
return (
(c.prevPage = this.activePage),
a.extend(c, { toPage: b, options: d }),
(c.absUrl = "string" === a.type(b) ? a.mobile.path.makeUrlAbsolute(b, this._findBaseWithDefault()) : d.absUrl),
(e = this._triggerWithDeprecated("beforechange", c)),
e.event.isDefaultPrevented() || e.deprecatedEvent.isDefaultPrevented() ? !1 : !0
);
},
change: function (b, c) {
if (f) return void e.unshift(arguments);
var d = a.extend({}, a.mobile.changePage.defaults, c),
g = {};
(d.fromPage = d.fromPage || this.activePage),
this._triggerPageBeforeChange(b, g, d) && ((b = g.toPage), "string" === a.type(b) ? ((f = !0), this._loadUrl(b, g, d)) : this.transition(b, g, d));
},
transition: function (b, g, h) {
var i, j, k, l, m, n, o, p, q, r, s, t, u, v;
if (f) return void e.unshift([b, h]);
if (
this._triggerPageBeforeChange(b, g, h) &&
((g.prevPage = h.fromPage), (v = this._triggerWithDeprecated("beforetransition", g)), !v.deprecatedEvent.isDefaultPrevented() && !v.event.isDefaultPrevented())
) {
if (
((f = !0),
b[0] !== a.mobile.firstPage[0] || h.dataUrl || (h.dataUrl = a.mobile.path.documentUrl.hrefNoHash),
(i = h.fromPage),
(j = (h.dataUrl && a.mobile.path.convertUrlToDataUrl(h.dataUrl)) || b.jqmData("url")),
(k = j),
(l = a.mobile.path.getFilePath(j)),
(m = a.mobile.navigate.history.getActive()),
(n = 0 === a.mobile.navigate.history.activeIndex),
(o = 0),
(p = c.title),
(q = ("dialog" === h.role || "dialog" === b.jqmData("role")) && b.jqmData("dialog") !== !0),
i && i[0] === b[0] && !h.allowSamePageTransition)
)
return (f = !1), this._triggerWithDeprecated("transition", g), this._triggerWithDeprecated("change", g), void (h.fromHashChange && a.mobile.navigate.history.direct({ url: j }));
b.page({ role: h.role }), h.fromHashChange && (o = "back" === h.direction ? -1 : 1);
try {
c.activeElement && "body" !== c.activeElement.nodeName.toLowerCase() ? a(c.activeElement).blur() : a("input:focus, textarea:focus, select:focus").blur();
} catch (w) { }
(r = !1),
q &&
m &&
(m.url &&
m.url.indexOf(a.mobile.dialogHashKey) > -1 &&
this.activePage &&
!this.activePage.hasClass("ui-dialog") &&
a.mobile.navigate.history.activeIndex > 0 &&
((h.changeHash = !1), (r = !0)),
(j = m.url || ""),
(j += !r && j.indexOf("#") > -1 ? a.mobile.dialogHashKey : "#" + a.mobile.dialogHashKey)),
(s = m ? b.jqmData("title") || b.children(":jqmData(role='header')").find(".ui-title").text() : p),
s && p === c.title && (p = s),
b.jqmData("title") || b.jqmData("title", p),
(h.transition = h.transition || (o && !n ? m.transition : d) || (q ? a.mobile.defaultDialogTransition : a.mobile.defaultPageTransition)),
!o && r && (a.mobile.navigate.history.getActive().pageUrl = k),
j &&
!h.fromHashChange &&
(!a.mobile.path.isPath(j) && j.indexOf("#") < 0 && (j = "#" + j),
(t = { transition: h.transition, title: p, pageUrl: k, role: h.role }),
h.changeHash !== !1 && a.mobile.hashListeningEnabled ? a.mobile.navigate(this.window[0].encodeURI(j), t, !0) : b[0] !== a.mobile.firstPage[0] && a.mobile.navigate.history.add(j, t)),
(c.title = p),
(a.mobile.activePage = b),
(this.activePage = b),
(h.reverse = h.reverse || 0 > o),
(u = a.Deferred()),
this._cssTransition(b, i, { transition: h.transition, reverse: h.reverse, deferred: u }),
u.done(
a.proxy(function (c, d, e, f, i) {
a.mobile.removeActiveLinkClass(),
h.duplicateCachedPage && h.duplicateCachedPage.remove(),
i || a.mobile.focusPage(b),
this._releaseTransitionLock(),
this._triggerWithDeprecated("transition", g),
this._triggerWithDeprecated("change", g);
}, this)
);
}
},
_findBaseWithDefault: function () {
var b = this.activePage && a.mobile.getClosestBaseUrl(this.activePage);
return b || a.mobile.path.documentBase.hrefNoHash;
},
}),
(a.mobile.navreadyDeferred = a.Deferred());
var e = [],
f = !1;
})(a),
(function (a, d) {
function e(a) {
for (; a && ("string" != typeof a.nodeName || "a" !== a.nodeName.toLowerCase());) a = a.parentNode;
return a;
}
var f = a.Deferred(),
g = a.Deferred(),
h = function () {
g.resolve(), (g = null);
},
i = a.mobile.path.documentUrl,
j = null;
(a.mobile.loadPage = function (b, c) {
var d;
return (c = c || {}), (d = c.pageContainer || a.mobile.pageContainer), (c.deferred = a.Deferred()), d.pagecontainer("load", b, c), c.deferred.promise();
}),
(a.mobile.back = function () {
var c = b.navigator;
this.phonegapNavigationEnabled && c && c.app && c.app.backHistory ? c.app.backHistory() : a.mobile.pageContainer.pagecontainer("back");
}),
(a.mobile.focusPage = function (a) {
var b = a.find("[autofocus]"),
c = a.find(".ui-title:eq(0)");
return b.length ? void b.focus() : void (c.length ? c.focus() : a.focus());
}),
(a.mobile._maybeDegradeTransition =
a.mobile._maybeDegradeTransition ||
function (a) {
return a;
}),
(a.mobile.changePage = function (b, c) {
a.mobile.pageContainer.pagecontainer("change", b, c);
}),
(a.mobile.changePage.defaults = {
transition: d,
reverse: !1,
changeHash: !0,
fromHashChange: !1,
role: d,
duplicateCachedPage: d,
pageContainer: d,
showLoadMsg: !0,
dataUrl: d,
fromPage: d,
allowSamePageTransition: !1,
}),
(a.mobile._registerInternalEvents = function () {
var c = function (b, c) {
var d,
e,
f,
g,
h = !0;
return !a.mobile.ajaxEnabled || b.is(":jqmData(ajax='false')") || !b.jqmHijackable().length || b.attr("target")
? !1
: ((d = (j && j.attr("formaction")) || b.attr("action")),
(g = (b.attr("method") || "get").toLowerCase()),
d || ((d = a.mobile.getClosestBaseUrl(b)), "get" === g && (d = a.mobile.path.parseUrl(d).hrefNoSearch), d === a.mobile.path.documentBase.hrefNoHash && (d = i.hrefNoSearch)),
(d = a.mobile.path.makeUrlAbsolute(d, a.mobile.getClosestBaseUrl(b))),
a.mobile.path.isExternal(d) && !a.mobile.path.isPermittedCrossDomainRequest(i, d)
? !1
: (c ||
((e = b.serializeArray()),
j &&
j[0].form === b[0] &&
((f = j.attr("name")),
f &&
(a.each(e, function (a, b) {
return b.name === f ? ((f = ""), !1) : void 0;
}),
f && e.push({ name: f, value: j.attr("value") }))),
(h = { url: d, options: { type: g, data: a.param(e), transition: b.jqmData("transition"), reverse: "reverse" === b.jqmData("direction"), reloadPage: !0 } })),
h));
};
a.mobile.document.delegate("form", "submit", function (b) {
var d;
b.isDefaultPrevented() || ((d = c(a(this))), d && (a.mobile.changePage(d.url, d.options), b.preventDefault()));
}),
a.mobile.document.bind("vclick", function (b) {
var d,
f,
g = b.target,
h = !1;
if (!(b.which > 1) && a.mobile.linkBindingEnabled) {
if (((j = a(g)), a.data(g, "mobile-button"))) {
if (!c(a(g).closest("form"), !0)) return;
g.parentNode && (g = g.parentNode);
} else {
if (((g = e(g)), !g || "#" === a.mobile.path.parseUrl(g.getAttribute("href") || "#").hash)) return;
if (!a(g).jqmHijackable().length) return;
}
~g.className.indexOf("ui-link-inherit") ? g.parentNode && (f = a.data(g.parentNode, "buttonElements")) : (f = a.data(g, "buttonElements")),
f ? (g = f.outer) : (h = !0),
(d = a(g)),
h && (d = d.closest(".ui-btn")),
d.length > 0 &&
!d.hasClass("ui-state-disabled") &&
(a.mobile.removeActiveLinkClass(!0), (a.mobile.activeClickedLink = d), a.mobile.activeClickedLink.addClass(a.mobile.activeBtnClass));
}
}),
a.mobile.document.bind("click", function (c) {
if (a.mobile.linkBindingEnabled && !c.isDefaultPrevented()) {
var f,
g,
h,
j,
k,
l,
m,
n = e(c.target),
o = a(n),
p = function () {
b.setTimeout(function () {
a.mobile.removeActiveLinkClass(!0);
}, 200);
};
if ((a.mobile.activeClickedLink && a.mobile.activeClickedLink[0] === c.target.parentNode && p(), n && !(c.which > 1) && o.jqmHijackable().length)) {
if (o.is(":jqmData(rel='back')")) return a.mobile.back(), !1;
if (((f = a.mobile.getClosestBaseUrl(o)), (g = a.mobile.path.makeUrlAbsolute(o.attr("href") || "#", f)), !a.mobile.ajaxEnabled && !a.mobile.path.isEmbeddedPage(g))) return void p();
if (!(-1 === g.search("#") || (a.mobile.path.isExternal(g) && a.mobile.path.isAbsoluteUrl(g)))) {
if (((g = g.replace(/[^#]*#/, "")), !g)) return void c.preventDefault();
g = a.mobile.path.isPath(g) ? a.mobile.path.makeUrlAbsolute(g, f) : a.mobile.path.makeUrlAbsolute("#" + g, i.hrefNoHash);
}
if (
((h = o.is("[rel='external']") || o.is(":jqmData(ajax='false')") || o.is("[target]")),
(j = h || (a.mobile.path.isExternal(g) && !a.mobile.path.isPermittedCrossDomainRequest(i, g))))
)
return void p();
(k = o.jqmData("transition")),
(l = "reverse" === o.jqmData("direction") || o.jqmData("back")),
(m = o.attr("data-" + a.mobile.ns + "rel") || d),
a.mobile.changePage(g, { transition: k, reverse: l, role: m, link: o }),
c.preventDefault();
}
}
}),
a.mobile.document.delegate(".ui-page", "pageshow.prefetch", function () {
var b = [];
a(this)
.find("a:jqmData(prefetch)")
.each(function () {
var c = a(this),
d = c.attr("href");
d && -1 === a.inArray(d, b) && (b.push(d), a.mobile.loadPage(d, { role: c.attr("data-" + a.mobile.ns + "rel"), prefetch: !0 }));
});
}),
a.mobile.pageContainer.pagecontainer(),
a.mobile.document.bind("pageshow", function () {
g ? g.done(a.mobile.resetActivePageHeight) : a.mobile.resetActivePageHeight();
}),
a.mobile.window.bind("throttledresize", a.mobile.resetActivePageHeight);
}),
a(function () {
f.resolve();
}),
"complete" === c.readyState ? h() : a.mobile.window.load(h),
a.when(f, a.mobile.navreadyDeferred).done(function () {
a.mobile._registerInternalEvents();
});
})(a),
(function (a, b) {
(a.mobile.Transition = function () {
this.init.apply(this, arguments);
}),
a.extend(a.mobile.Transition.prototype, {
toPreClass: " ui-page-pre-in",
init: function (b, c, d, e) {
a.extend(this, { name: b, reverse: c, $to: d, $from: e, deferred: new a.Deferred() });
},
cleanFrom: function () {
this.$from.removeClass(a.mobile.activePageClass + " out in reverse " + this.name).height("");
},
beforeDoneIn: function () { },
beforeDoneOut: function () { },
beforeStartOut: function () { },
doneIn: function () {
this.beforeDoneIn(),
this.$to.removeClass("out in reverse " + this.name).height(""),
this.toggleViewportClass(),
a.mobile.window.scrollTop() !== this.toScroll && this.scrollPage(),
this.sequential || this.$to.addClass(a.mobile.activePageClass),
this.deferred.resolve(this.name, this.reverse, this.$to, this.$from, !0);
},
doneOut: function (a, b, c, d) {
this.beforeDoneOut(), this.startIn(a, b, c, d);
},
hideIn: function (a) {
this.$to.css("z-index", -10), a.call(this), this.$to.css("z-index", "");
},
scrollPage: function () {
(a.event.special.scrollstart.enabled = !1),
(a.mobile.hideUrlBar || this.toScroll !== a.mobile.defaultHomeScroll) && b.scrollTo(0, this.toScroll),
setTimeout(function () {
a.event.special.scrollstart.enabled = !0;
}, 150);
},
startIn: function (b, c, d, e) {
this.hideIn(function () {
this.$to.addClass(a.mobile.activePageClass + this.toPreClass), e || a.mobile.focusPage(this.$to), this.$to.height(b + this.toScroll), d || this.scrollPage();
}),
this.$to.removeClass(this.toPreClass).addClass(this.name + " in " + c),
d
? this.doneIn()
: this.$to.animationComplete(
a.proxy(function () {
this.doneIn();
}, this)
);
},
startOut: function (b, c, d) {
this.beforeStartOut(b, c, d), this.$from.height(b + a.mobile.window.scrollTop()).addClass(this.name + " out" + c);
},
transition: function () {
var b,
c = this.reverse ? " reverse" : "",
d = a.mobile.getScreenHeight(),
e = a.mobile.maxTransitionWidth !== !1 && a.mobile.window.width() > a.mobile.maxTransitionWidth;
return (
(this.toScroll = a.mobile.navigate.history.getActive().lastScroll || a.mobile.defaultHomeScroll),
(b =
!a.support.cssTransitions ||
!a.support.cssAnimations ||
e ||
!this.name ||
"none" === this.name ||
Math.max(a.mobile.window.scrollTop(), this.toScroll) > a.mobile.getMaxScrollForTransition()),
this.toggleViewportClass(),
this.$from && !b ? this.startOut(d, c, b) : this.doneOut(d, c, b, !0),
this.deferred.promise()
);
},
});
})(a, this),
(function (a) {
(a.mobile.SerialTransition = function () {
this.init.apply(this, arguments);
}),
a.extend(a.mobile.SerialTransition.prototype, a.mobile.Transition.prototype, {
sequential: !0,
beforeDoneOut: function () {
this.$from && this.cleanFrom();
},
beforeStartOut: function (b, c, d) {
this.$from.animationComplete(
a.proxy(function () {
this.doneOut(b, c, d);
}, this)
);
},
});
})(a),
(function (a) {
(a.mobile.ConcurrentTransition = function () {
this.init.apply(this, arguments);
}),
a.extend(a.mobile.ConcurrentTransition.prototype, a.mobile.Transition.prototype, {
sequential: !1,
beforeDoneIn: function () {
this.$from && this.cleanFrom();
},
beforeStartOut: function (a, b, c) {
this.doneOut(a, b, c);
},
});
})(a),
(function (a) {
var b = function () {
return 3 * a.mobile.getScreenHeight();
};
(a.mobile.transitionHandlers = { sequential: a.mobile.SerialTransition, simultaneous: a.mobile.ConcurrentTransition }),
(a.mobile.defaultTransitionHandler = a.mobile.transitionHandlers.sequential),
(a.mobile.transitionFallbacks = {}),
(a.mobile._maybeDegradeTransition = function (b) {
return b && !a.support.cssTransform3d && a.mobile.transitionFallbacks[b] && (b = a.mobile.transitionFallbacks[b]), b;
}),
(a.mobile.getMaxScrollForTransition = a.mobile.getMaxScrollForTransition || b);
})(a),
(function (a) {
a.mobile.transitionFallbacks.flip = "fade";
})(a, this),
(function (a) {
a.mobile.transitionFallbacks.flow = "fade";
})(a, this),
(function (a) {
a.mobile.transitionFallbacks.pop = "fade";
})(a, this),
(function (a) {
(a.mobile.transitionHandlers.slide = a.mobile.transitionHandlers.simultaneous), (a.mobile.transitionFallbacks.slide = "fade");
})(a, this),
(function (a) {
a.mobile.transitionFallbacks.slidedown = "fade";
})(a, this),
(function (a) {
a.mobile.transitionFallbacks.slidefade = "fade";
})(a, this),
(function (a) {
a.mobile.transitionFallbacks.slideup = "fade";
})(a, this),
(function (a) {
a.mobile.transitionFallbacks.turn = "fade";
})(a, this),
(function (a) {
(a.mobile.degradeInputs = { color: !1, date: !1, datetime: !1, "datetime-local": !1, email: !1, month: !1, number: !1, range: "number", search: "text", tel: !1, time: !1, url: !1, week: !1 }),
(a.mobile.page.prototype.options.degradeInputs = a.mobile.degradeInputs),
(a.mobile.degradeInputsWithin = function (b) {
(b = a(b)),
b
.find("input")
.not(a.mobile.page.prototype.keepNativeSelector())
.each(function () {
var b,
c,
d,
e,
f = a(this),
g = this.getAttribute("type"),
h = a.mobile.degradeInputs[g] || "text";
a.mobile.degradeInputs[g] &&
((b = a("<div>").html(f.clone()).html()),
(c = b.indexOf(" type=") > -1),
(d = c ? /\s+type=["']?\w+['"]?/ : /\/?>/),
(e = ' type="' + h + '" data-' + a.mobile.ns + 'type="' + g + '"' + (c ? "" : ">")),
f.replaceWith(b.replace(d, e)));
});
});
})(a),
(function (a, b, c) {
a.widget("mobile.page", a.mobile.page, {
options: { closeBtn: "left", closeBtnText: "Close", overlayTheme: "a", corners: !0, dialog: !1 },
_create: function () {
this._super(), this.options.dialog && (a.extend(this, { _inner: this.element.children(), _headerCloseButton: null }), this.options.enhanced || this._setCloseBtn(this.options.closeBtn));
},
_enhance: function () {
this._super(),
this.options.dialog &&
this.element.addClass("ui-dialog").wrapInner(a("<div/>", { role: "dialog", class: "ui-dialog-contain ui-overlay-shadow" + (this.options.corners ? " ui-corner-all" : "") }));
},
_setOptions: function (b) {
var d,
e,
f = this.options;
b.corners !== c && this._inner.toggleClass("ui-corner-all", !!b.corners),
b.overlayTheme !== c && a.mobile.activePage[0] === this.element[0] && ((f.overlayTheme = b.overlayTheme), this._handlePageBeforeShow()),
b.closeBtnText !== c && ((d = f.closeBtn), (e = b.closeBtnText)),
b.closeBtn !== c && (d = b.closeBtn),
d && this._setCloseBtn(d, e),
this._super(b);
},
_handlePageBeforeShow: function () {
this.options.overlayTheme && this.options.dialog ? (this.removeContainerBackground(), this.setContainerBackground(this.options.overlayTheme)) : this._super();
},
_setCloseBtn: function (b, c) {
var d,
e = this._headerCloseButton;
(b = "left" === b ? "left" : "right" === b ? "right" : "none"),
"none" === b
? e && (e.remove(), (e = null))
: e
? (e.removeClass("ui-btn-left ui-btn-right").addClass("ui-btn-" + b), c && e.text(c))
: ((d = this._inner.find(":jqmData(role='header')").first()),
(e = a("<a></a>", { href: "#", class: "ui-btn ui-corner-all ui-icon-delete ui-btn-icon-notext ui-btn-" + b })
.attr("data-" + a.mobile.ns + "rel", "back")
.text(c || this.options.closeBtnText || "")
.prependTo(d))),
(this._headerCloseButton = e);
},
});
})(a, this),
(function (a, b, c) {
a.widget("mobile.dialog", {
options: { closeBtn: "left", closeBtnText: "Close", overlayTheme: "a", corners: !0 },
_handlePageBeforeShow: function () {
(this._isCloseable = !0), this.options.overlayTheme && this.element.page("removeContainerBackground").page("setContainerBackground", this.options.overlayTheme);
},
_handlePageBeforeHide: function () {
this._isCloseable = !1;
},
_handleVClickSubmit: function (b) {
var c,
d = a(b.target).closest("vclick" === b.type ? "a" : "form");
d.length &&
!d.jqmData("transition") &&
((c = {}),
(c["data-" + a.mobile.ns + "transition"] = (a.mobile.navigate.history.getActive() || {}).transition || a.mobile.defaultDialogTransition),
(c["data-" + a.mobile.ns + "direction"] = "reverse"),
d.attr(c));
},
_create: function () {
var b = this.element,
c = this.options;
b.addClass("ui-dialog").wrapInner(a("<div/>", { role: "dialog", class: "ui-dialog-contain ui-overlay-shadow" + (c.corners ? " ui-corner-all" : "") })),
a.extend(this, { _isCloseable: !1, _inner: b.children(), _headerCloseButton: null }),
this._on(b, { vclick: "_handleVClickSubmit", submit: "_handleVClickSubmit", pagebeforeshow: "_handlePageBeforeShow", pagebeforehide: "_handlePageBeforeHide" }),
this._setCloseBtn(c.closeBtn);
},
_setOptions: function (b) {
var d,
e,
f = this.options;
b.corners !== c && this._inner.toggleClass("ui-corner-all", !!b.corners),
b.overlayTheme !== c && a.mobile.activePage[0] === this.element[0] && ((f.overlayTheme = b.overlayTheme), this._handlePageBeforeShow()),
b.closeBtnText !== c && ((d = f.closeBtn), (e = b.closeBtnText)),
b.closeBtn !== c && (d = b.closeBtn),
d && this._setCloseBtn(d, e),
this._super(b);
},
_setCloseBtn: function (b, c) {
var d,
e = this._headerCloseButton;
(b = "left" === b ? "left" : "right" === b ? "right" : "none"),
"none" === b
? e && (e.remove(), (e = null))
: e
? (e.removeClass("ui-btn-left ui-btn-right").addClass("ui-btn-" + b), c && e.text(c))
: ((d = this._inner.find(":jqmData(role='header')").first()),
(e = a("<a></a>", { role: "button", href: "#", class: "ui-btn ui-corner-all ui-icon-delete ui-btn-icon-notext ui-btn-" + b })
.text(c || this.options.closeBtnText || "")
.prependTo(d)),
this._on(e, { click: "close" })),
(this._headerCloseButton = e);
},
close: function () {
var b = a.mobile.navigate.history;
this._isCloseable && ((this._isCloseable = !1), a.mobile.hashListeningEnabled && b.activeIndex > 0 ? a.mobile.back() : a.mobile.pageContainer.pagecontainer("back"));
},
});
})(a, this),
(function (a, b) {
var c = /([A-Z])/g,
d = function (a) {
return "ui-btn-icon-" + (null === a ? "left" : a);
};
a.widget("mobile.collapsible", {
options: {
enhanced: !1,
expandCueText: null,
collapseCueText: null,
collapsed: !0,
heading: "h1,h2,h3,h4,h5,h6,legend",
collapsedIcon: null,
expandedIcon: null,
iconpos: null,
theme: null,
contentTheme: null,
inset: null,
corners: null,
mini: null,
},
_create: function () {
var b = this.element,
c = {
accordion: b.closest(":jqmData(role='collapsible-set'),:jqmData(role='collapsibleset')" + (a.mobile.collapsibleset ? ", :mobile-collapsibleset" : "")).addClass("ui-collapsible-set"),
};
(this._ui = c),
(this._renderedOptions = this._getOptions(this.options)),
this.options.enhanced
? ((c.heading = this.element.children(".ui-collapsible-heading")),
(c.content = c.heading.next()),
(c.anchor = c.heading.children()),
(c.status = c.anchor.children(".ui-collapsible-heading-status")))
: this._enhance(b, c),
this._on(c.heading, {
tap: function () {
c.heading.find("a").first().addClass(a.mobile.activeBtnClass);
},
click: function (a) {
this._handleExpandCollapse(!c.heading.hasClass("ui-collapsible-heading-collapsed")), a.preventDefault(), a.stopPropagation();
},
});
},
_getOptions: function (b) {
var d,
e = this._ui.accordion,
f = this._ui.accordionWidget;
(b = a.extend({}, b)), e.length && !f && (this._ui.accordionWidget = f = e.data("mobile-collapsibleset"));
for (d in b)
(b[d] = null != b[d] ? b[d] : f ? f.options[d] : e.length ? a.mobile.getAttribute(e[0], d.replace(c, "-$1").toLowerCase()) : null),
null == b[d] && (b[d] = a.mobile.collapsible.defaults[d]);
return b;
},
_themeClassFromOption: function (a, b) {
return b ? ("none" === b ? "" : a + b) : "";
},
_enhance: function (b, c) {
var e,
f = this._renderedOptions,
g = this._themeClassFromOption("ui-body-", f.contentTheme);
return (
b.addClass("ui-collapsible " + (f.inset ? "ui-collapsible-inset " : "") + (f.inset && f.corners ? "ui-corner-all " : "") + (g ? "ui-collapsible-themed-content " : "")),
(c.originalHeading = b.children(this.options.heading).first()),
(c.content = b.wrapInner("<div class='ui-collapsible-content " + g + "'></div>").children(".ui-collapsible-content")),
(c.heading = c.originalHeading),
c.heading.is("legend") &&
((c.heading = a("<div role='heading'>" + c.heading.html() + "</div>")),
(c.placeholder = a("<div><!-- placeholder for legend --></div>").insertBefore(c.originalHeading)),
c.originalHeading.remove()),
(e = f.collapsed ? (f.collapsedIcon ? "ui-icon-" + f.collapsedIcon : "") : f.expandedIcon ? "ui-icon-" + f.expandedIcon : ""),
(c.status = a("<span class='ui-collapsible-heading-status'></span>")),
(c.anchor = c.heading
.detach()
.addClass("ui-collapsible-heading")
.append(c.status)
.wrapInner("<a href='#' class='ui-collapsible-heading-toggle'></a>")
.find("a")
.first()
.addClass("ui-btn " + (e ? e + " " : "") + (e ? d(f.iconpos) + " " : "") + this._themeClassFromOption("ui-btn-", f.theme) + " " + (f.mini ? "ui-mini " : ""))),
c.heading.insertBefore(c.content),
this._handleExpandCollapse(this.options.collapsed),
c
);
},
refresh: function () {
this._applyOptions(this.options), (this._renderedOptions = this._getOptions(this.options));
},
_applyOptions: function (a) {
var c,
e,
f,
g,
h,
i = this.element,
j = this._renderedOptions,
k = this._ui,
l = k.anchor,
m = k.status,
n = this._getOptions(a);
a.collapsed !== b && this._handleExpandCollapse(a.collapsed),
(c = i.hasClass("ui-collapsible-collapsed")),
c ? n.expandCueText !== b && m.text(n.expandCueText) : n.collapseCueText !== b && m.text(n.collapseCueText),
(h = n.collapsedIcon !== b ? n.collapsedIcon !== !1 : j.collapsedIcon !== !1),
(n.iconpos !== b || n.collapsedIcon !== b || n.expandedIcon !== b) &&
(l.removeClass(
[d(j.iconpos)]
.concat(j.expandedIcon ? ["ui-icon-" + j.expandedIcon] : [])
.concat(j.collapsedIcon ? ["ui-icon-" + j.collapsedIcon] : [])
.join(" ")
),
h &&
l.addClass(
[d(n.iconpos !== b ? n.iconpos : j.iconpos)]
.concat(c ? ["ui-icon-" + (n.collapsedIcon !== b ? n.collapsedIcon : j.collapsedIcon)] : ["ui-icon-" + (n.expandedIcon !== b ? n.expandedIcon : j.expandedIcon)])
.join(" ")
)),
n.theme !== b && ((f = this._themeClassFromOption("ui-btn-", j.theme)), (e = this._themeClassFromOption("ui-btn-", n.theme)), l.removeClass(f).addClass(e)),
n.contentTheme !== b && ((f = this._themeClassFromOption("ui-body-", j.contentTheme)), (e = this._themeClassFromOption("ui-body-", n.contentTheme)), k.content.removeClass(f).addClass(e)),
n.inset !== b && (i.toggleClass("ui-collapsible-inset", n.inset), (g = !(!n.inset || (!n.corners && !j.corners)))),
n.corners !== b && (g = !(!n.corners || (!n.inset && !j.inset))),
g !== b && i.toggleClass("ui-corner-all", g),
n.mini !== b && l.toggleClass("ui-mini", n.mini);
},
_setOptions: function (a) {
this._applyOptions(a), this._super(a), (this._renderedOptions = this._getOptions(this.options));
},
_handleExpandCollapse: function (b) {
var c = this._renderedOptions,
d = this._ui;
d.status.text(b ? c.expandCueText : c.collapseCueText),
d.heading
.toggleClass("ui-collapsible-heading-collapsed", b)
.find("a")
.first()
.toggleClass("ui-icon-" + c.expandedIcon, !b)
.toggleClass("ui-icon-" + c.collapsedIcon, b || c.expandedIcon === c.collapsedIcon)
.removeClass(a.mobile.activeBtnClass),
this.element.toggleClass("ui-collapsible-collapsed", b),
d.content.toggleClass("ui-collapsible-content-collapsed", b).attr("aria-hidden", b).trigger("updatelayout"),
(this.options.collapsed = b),
this._trigger(b ? "collapse" : "expand");
},
expand: function () {
this._handleExpandCollapse(!1);
},
collapse: function () {
this._handleExpandCollapse(!0);
},
_destroy: function () {
var a = this._ui,
b = this.options;
b.enhanced ||
(a.placeholder
? (a.originalHeading.insertBefore(a.placeholder), a.placeholder.remove(), a.heading.remove())
: (a.status.remove(), a.heading.removeClass("ui-collapsible-heading ui-collapsible-heading-collapsed").children().contents().unwrap()),
a.anchor.contents().unwrap(),
a.content.contents().unwrap(),
this.element.removeClass("ui-collapsible ui-collapsible-collapsed ui-collapsible-themed-content ui-collapsible-inset ui-corner-all"));
},
}),
(a.mobile.collapsible.defaults = {
expandCueText: " click to expand contents",
collapseCueText: " click to collapse contents",
collapsedIcon: "plus",
contentTheme: "inherit",
expandedIcon: "minus",
iconpos: "left",
inset: !0,
corners: !0,
theme: "inherit",
mini: !1,
});
})(a),
(function (a) {
function b(b) {
var d,
e = b.length,
f = [];
for (d = 0; e > d; d++) b[d].className.match(c) || f.push(b[d]);
return a(f);
}
var c = /\bui-screen-hidden\b/;
a.mobile.behaviors.addFirstLastClasses = {
_getVisibles: function (a, c) {
var d;
return c ? (d = b(a)) : ((d = a.filter(":visible")), 0 === d.length && (d = b(a))), d;
},
_addFirstLastClasses: function (a, b, c) {
a.removeClass("ui-first-child ui-last-child"), b.eq(0).addClass("ui-first-child").end().last().addClass("ui-last-child"), c || this.element.trigger("updatelayout");
},
_removeFirstLastClasses: function (a) {
a.removeClass("ui-first-child ui-last-child");
},
};
})(a),
(function (a, b) {
var c = ":mobile-collapsible, " + a.mobile.collapsible.initSelector;
a.widget(
"mobile.collapsibleset",
a.extend(
{
initSelector: ":jqmData(role='collapsible-set'),:jqmData(role='collapsibleset')",
options: a.extend({ enhanced: !1 }, a.mobile.collapsible.defaults),
_handleCollapsibleExpand: function (b) {
var c = a(b.target).closest(".ui-collapsible");
c.parent().is(":mobile-collapsibleset, :jqmData(role='collapsible-set')") && c.siblings(".ui-collapsible:not(.ui-collapsible-collapsed)").collapsible("collapse");
},
_create: function () {
var b = this.element,
c = this.options;
a.extend(this, { _classes: "" }),
c.enhanced ||
(b.addClass("ui-collapsible-set " + this._themeClassFromOption("ui-group-theme-", c.theme) + " " + (c.corners && c.inset ? "ui-corner-all " : "")),
this.element.find(a.mobile.collapsible.initSelector).collapsible()),
this._on(b, { collapsibleexpand: "_handleCollapsibleExpand" });
},
_themeClassFromOption: function (a, b) {
return b ? ("none" === b ? "" : a + b) : "";
},
_init: function () {
this._refresh(!0), this.element.children(c).filter(":jqmData(collapsed='false')").collapsible("expand");
},
_setOptions: function (a) {
var c,
d,
e = this.element,
f = this._themeClassFromOption("ui-group-theme-", a.theme);
return (
f && e.removeClass(this._themeClassFromOption("ui-group-theme-", this.options.theme)).addClass(f),
a.inset !== b && (d = !(!a.inset || (!a.corners && !this.options.corners))),
a.corners !== b && (d = !(!a.corners || (!a.inset && !this.options.inset))),
d !== b && e.toggleClass("ui-corner-all", d),
(c = this._super(a)),
this.element.children(":mobile-collapsible").collapsible("refresh"),
c
);
},
_destroy: function () {
var a = this.element;
this._removeFirstLastClasses(a.children(c)),
a
.removeClass("ui-collapsible-set ui-corner-all " + this._themeClassFromOption("ui-group-theme-", this.options.theme))
.children(":mobile-collapsible")
.collapsible("destroy");
},
_refresh: function (b) {
var d = this.element.children(c);
this.element.find(a.mobile.collapsible.initSelector).not(".ui-collapsible").collapsible(), this._addFirstLastClasses(d, this._getVisibles(d, b), b);
},
refresh: function () {
this._refresh(!1);
},
},
a.mobile.behaviors.addFirstLastClasses
)
);
})(a),
(function (a) {
a.fn.fieldcontain = function () {
return this.addClass("ui-field-contain");
};
})(a),
(function (a) {
a.fn.grid = function (b) {
return this.each(function () {
var c,
d,
e = a(this),
f = a.extend({ grid: null }, b),
g = e.children(),
h = { solo: 1, a: 2, b: 3, c: 4, d: 5 },
i = f.grid;
if (!i)
if (g.length <= 5) for (d in h) h[d] === g.length && (i = d);
else (i = "a"), e.addClass("ui-grid-duo");
(c = h[i]),
e.addClass("ui-grid-" + i),
g.filter(":nth-child(" + c + "n+1)").addClass("ui-block-a"),
c > 1 && g.filter(":nth-child(" + c + "n+2)").addClass("ui-block-b"),
c > 2 && g.filter(":nth-child(" + c + "n+3)").addClass("ui-block-c"),
c > 3 && g.filter(":nth-child(" + c + "n+4)").addClass("ui-block-d"),
c > 4 && g.filter(":nth-child(" + c + "n+5)").addClass("ui-block-e");
});
};
})(a),
(function (a, b) {
a.widget("mobile.navbar", {
options: { iconpos: "top", grid: null },
_create: function () {
var d = this.element,
e = d.find("a, button"),
f = e.filter(":jqmData(icon)").length ? this.options.iconpos : b;
d.addClass("ui-navbar").attr("role", "navigation").find("ul").jqmEnhanceable().grid({ grid: this.options.grid }),
e.each(function () {
var b = a.mobile.getAttribute(this, "icon"),
c = a.mobile.getAttribute(this, "theme"),
d = "ui-btn";
c && (d += " ui-btn-" + c), b && (d += " ui-icon-" + b + " ui-btn-icon-" + f), a(this).addClass(d);
}),
d.delegate("a", "vclick", function () {
var b = a(this);
b.hasClass("ui-state-disabled") ||
b.hasClass("ui-disabled") ||
b.hasClass(a.mobile.activeBtnClass) ||
(e.removeClass(a.mobile.activeBtnClass),
b.addClass(a.mobile.activeBtnClass),
a(c).one("pagehide", function () {
b.removeClass(a.mobile.activeBtnClass);
}));
}),
d.closest(".ui-page").bind("pagebeforeshow", function () {
e.filter(".ui-state-persist").addClass(a.mobile.activeBtnClass);
});
},
});
})(a),
(function (a) {
var b = a.mobile.getAttribute;
a.widget(
"mobile.listview",
a.extend(
{
options: { theme: null, countTheme: null, dividerTheme: null, icon: "carat-r", splitIcon: "carat-r", splitTheme: null, corners: !0, shadow: !0, inset: !1 },
_create: function () {
var a = this,
b = "";
(b += a.options.inset ? " ui-listview-inset" : ""),
a.options.inset && ((b += a.options.corners ? " ui-corner-all" : ""), (b += a.options.shadow ? " ui-shadow" : "")),
a.element.addClass(" ui-listview" + b),
a.refresh(!0);
},
_findFirstElementByTagName: function (a, b, c, d) {
var e = {};
for (e[c] = e[d] = !0; a;) {
if (e[a.nodeName]) return a;
a = a[b];
}
return null;
},
_addThumbClasses: function (b) {
var c,
d,
e = b.length;
for (c = 0; e > c; c++)
(d = a(this._findFirstElementByTagName(b[c].firstChild, "nextSibling", "img", "IMG"))),
d.length && a(this._findFirstElementByTagName(d[0].parentNode, "parentNode", "li", "LI")).addClass(d.hasClass("ui-li-icon") ? "ui-li-has-icon" : "ui-li-has-thumb");
},
_getChildrenByTagName: function (b, c, d) {
var e = [],
f = {};
for (f[c] = f[d] = !0, b = b.firstChild; b;) f[b.nodeName] && e.push(b), (b = b.nextSibling);
return a(e);
},
_beforeListviewRefresh: a.noop,
_afterListviewRefresh: a.noop,
refresh: function (c) {
var d,
e,
f,
g,
h,
i,
j,
k,
l,
m,
n,
o,
p,
q,
r,
s,
t,
u,
v,
w,
x = this.options,
y = this.element,
z = !!a.nodeName(y[0], "ol"),
A = y.attr("start"),
B = {},
C = y.find(".ui-li-count"),
D = b(y[0], "counttheme") || this.options.countTheme,
E = D ? "ui-body-" + D : "ui-body-inherit";
for (
x.theme && y.addClass("ui-group-theme-" + x.theme),
z && (A || 0 === A) && ((n = parseInt(A, 10) - 1), y.css("counter-reset", "listnumbering " + n)),
this._beforeListviewRefresh(),
w = this._getChildrenByTagName(y[0], "li", "LI"),
e = 0,
f = w.length;
f > e;
e++
)
(g = w.eq(e)),
(h = ""),
(c || g[0].className.search(/\bui-li-static\b|\bui-li-divider\b/) < 0) &&
((l = this._getChildrenByTagName(g[0], "a", "A")),
(m = "list-divider" === b(g[0], "role")),
(p = g.attr("value")),
(i = b(g[0], "theme")),
l.length && l[0].className.search(/\bui-btn\b/) < 0 && !m
? ((j = b(g[0], "icon")),
(k = j === !1 ? !1 : j || x.icon),
l.removeClass("ui-link"),
(d = "ui-btn"),
i && (d += " ui-btn-" + i),
l.length > 1
? ((h = "ui-li-has-alt"),
(q = l.last()),
(r = b(q[0], "theme") || x.splitTheme || b(g[0], "theme", !0)),
(s = r ? " ui-btn-" + r : ""),
(t = b(q[0], "icon") || b(g[0], "icon") || x.splitIcon),
(u = "ui-btn ui-btn-icon-notext ui-icon-" + t + s),
q.attr("title", a.trim(q.getEncodedText())).addClass(u).empty(),
(l = l.first()))
: k && (d += " ui-btn-icon-right ui-icon-" + k),
l.addClass(d))
: m
? ((v = b(g[0], "theme") || x.dividerTheme || x.theme), (h = "ui-li-divider ui-bar-" + (v ? v : "inherit")), g.attr("role", "heading"))
: l.length <= 0 && (h = "ui-li-static ui-body-" + (i ? i : "inherit")),
z && p && ((o = parseInt(p, 10) - 1), g.css("counter-reset", "listnumbering " + o))),
B[h] || (B[h] = []),
B[h].push(g[0]);
for (h in B) a(B[h]).addClass(h);
C.each(function () {
a(this).closest("li").addClass("ui-li-has-count");
}),
E && C.not("[class*='ui-body-']").addClass(E),
this._addThumbClasses(w),
this._addThumbClasses(w.find(".ui-btn")),
this._afterListviewRefresh(),
this._addFirstLastClasses(w, this._getVisibles(w, c), c);
},
},
a.mobile.behaviors.addFirstLastClasses
)
);
})(a),
(function (a) {
function b(b) {
var c = a.trim(b.text()) || null;
return c ? (c = c.slice(0, 1).toUpperCase()) : null;
}
a.widget("mobile.listview", a.mobile.listview, {
options: { autodividers: !1, autodividersSelector: b },
_beforeListviewRefresh: function () {
this.options.autodividers && (this._replaceDividers(), this._superApply(arguments));
},
_replaceDividers: function () {
var b,
d,
e,
f,
g,
h = null,
i = this.element;
for (i.children("li:jqmData(role='list-divider')").remove(), d = i.children("li"), b = 0; b < d.length; b++)
(e = d[b]),
(f = this.options.autodividersSelector(a(e))),
f && h !== f && ((g = c.createElement("li")), g.appendChild(c.createTextNode(f)), g.setAttribute("data-" + a.mobile.ns + "role", "list-divider"), e.parentNode.insertBefore(g, e)),
(h = f);
},
});
})(a),
(function (a) {
var b = /(^|\s)ui-li-divider($|\s)/,
c = /(^|\s)ui-screen-hidden($|\s)/;
a.widget("mobile.listview", a.mobile.listview, {
options: { hideDividers: !1 },
_afterListviewRefresh: function () {
var a,
d,
e,
f = !0;
if ((this._superApply(arguments), this.options.hideDividers))
for (a = this._getChildrenByTagName(this.element[0], "li", "LI"), d = a.length - 1; d > -1; d--)
(e = a[d]), e.className.match(b) ? (f && (e.className = e.className + " ui-screen-hidden"), (f = !0)) : e.className.match(c) || (f = !1);
},
});
})(a),
(function (a) {
a.mobile.nojs = function (b) {
a(":jqmData(role='nojs')", b).addClass("ui-nojs");
};
})(a),
(function (a) {
a.mobile.behaviors.formReset = {
_handleFormReset: function () {
this._on(this.element.closest("form"), {
reset: function () {
this._delay("_reset");
},
});
},
};
})(a),
(function (a, b) {
var c = a.mobile.path.hashToSelector;
a.widget(
"mobile.checkboxradio",
a.extend(
{
initSelector: "input:not( :jqmData(role='flipswitch' ) )[type='checkbox'],input[type='radio']:not( :jqmData(role='flipswitch' ))",
options: { theme: "inherit", mini: !1, wrapperClass: null, enhanced: !1, iconpos: "left" },
_create: function () {
var b = this.element,
c = this.options,
d = function (a, b) {
return a.jqmData(b) || a.closest("form, fieldset").jqmData(b);
},
e = this.options.enhanced ? { element: this.element.siblings("label"), isParent: !1 } : this._findLabel(),
f = b[0].type,
g = "ui-" + f + "-on",
h = "ui-" + f + "-off";
("checkbox" === f || "radio" === f) &&
(this.element[0].disabled && (this.options.disabled = !0),
(c.iconpos = d(b, "iconpos") || e.element.attr("data-" + a.mobile.ns + "iconpos") || c.iconpos),
(c.mini = d(b, "mini") || c.mini),
a.extend(this, { input: b, label: e.element, labelIsParent: e.isParent, inputtype: f, checkedClass: g, uncheckedClass: h }),
this.options.enhanced || this._enhance(),
this._on(e.element, { vmouseover: "_handleLabelVMouseOver", vclick: "_handleLabelVClick" }),
this._on(b, { vmousedown: "_cacheVals", vclick: "_handleInputVClick", focus: "_handleInputFocus", blur: "_handleInputBlur" }),
this._handleFormReset(),
this.refresh());
},
_findLabel: function () {
var b,
d,
e,
f = this.element,
g = f[0].labels;
return (
g && g.length > 0
? ((d = a(g[0])), (e = a.contains(d[0], f[0])))
: ((b = f.closest("label")),
(e = b.length > 0),
(d = e
? b
: a(this.document[0].getElementsByTagName("label"))
.filter("[for='" + c(f[0].id) + "']")
.first())),
{ element: d, isParent: e }
);
},
_enhance: function () {
this.label.addClass("ui-btn ui-corner-all"),
this.labelIsParent ? this.input.add(this.label).wrapAll(this._wrapper()) : (this.element.wrap(this._wrapper()), this.element.parent().prepend(this.label)),
this._setOptions({ theme: this.options.theme, iconpos: this.options.iconpos, mini: this.options.mini });
},
_wrapper: function () {
return a("<div class='" + (this.options.wrapperClass ? this.options.wrapperClass : "") + " ui-" + this.inputtype + (this.options.disabled ? " ui-state-disabled" : "") + "' ></div>");
},
_handleInputFocus: function () {
this.label.addClass(a.mobile.focusClass);
},
_handleInputBlur: function () {
this.label.removeClass(a.mobile.focusClass);
},
_handleInputVClick: function () {
this.element.prop("checked", this.element.is(":checked")), this._getInputSet().not(this.element).prop("checked", !1), this._updateAll(!0);
},
_handleLabelVMouseOver: function (a) {
this.label.parent().hasClass("ui-state-disabled") && a.stopPropagation();
},
_handleLabelVClick: function (a) {
var b = this.element;
return b.is(":disabled")
? void a.preventDefault()
: (this._cacheVals(),
b.prop("checked", ("radio" === this.inputtype && !0) || !b.prop("checked")),
b.triggerHandler("click"),
this._getInputSet().not(b).prop("checked", !1),
this._updateAll(),
!1);
},
_cacheVals: function () {
this._getInputSet().each(function () {
a(this).attr("data-" + a.mobile.ns + "cacheVal", this.checked);
});
},
_getInputSet: function () {
var b,
d,
e = this.element[0],
f = e.name,
g = e.form,
h = this.element.parents().last().get(0),
i = this.element;
return (
f &&
"radio" === this.inputtype &&
h &&
((b = "input[type='radio'][name='" + c(f) + "']"),
g
? ((d = g.getAttribute("id")),
d && (i = a(b + "[form='" + c(d) + "']", h)),
(i = a(g)
.find(b)
.filter(function () {
return this.form === g;
})
.add(i)))
: (i = a(b, h).filter(function () {
return !this.form;
}))),
i
);
},
_updateAll: function (b) {
var c = this;
this._getInputSet()
.each(function () {
var d = a(this);
(!this.checked && "checkbox" !== c.inputtype) || b || d.trigger("change");
})
.checkboxradio("refresh");
},
_reset: function () {
this.refresh();
},
_hasIcon: function () {
var b,
c,
d = a.mobile.controlgroup;
return d && ((b = this.element.closest(":mobile-controlgroup," + d.prototype.initSelector)), b.length > 0)
? ((c = a.data(b[0], "mobile-controlgroup")), "horizontal" !== (c ? c.options.type : b.attr("data-" + a.mobile.ns + "type")))
: !0;
},
refresh: function () {
var b = this.element[0].checked,
c = a.mobile.activeBtnClass,
d = "ui-btn-icon-" + this.options.iconpos,
e = [],
f = [];
this._hasIcon() ? (f.push(c), e.push(d)) : (f.push(d), (b ? e : f).push(c)),
b ? (e.push(this.checkedClass), f.push(this.uncheckedClass)) : (e.push(this.uncheckedClass), f.push(this.checkedClass)),
this.widget().toggleClass("ui-state-disabled", this.element.prop("disabled")),
this.label.addClass(e.join(" ")).removeClass(f.join(" "));
},
widget: function () {
return this.label.parent();
},
_setOptions: function (a) {
var c = this.label,
d = this.options,
e = this.widget(),
f = this._hasIcon();
a.disabled !== b && (this.input.prop("disabled", !!a.disabled), e.toggleClass("ui-state-disabled", !!a.disabled)),
a.mini !== b && e.toggleClass("ui-mini", !!a.mini),
a.theme !== b && c.removeClass("ui-btn-" + d.theme).addClass("ui-btn-" + a.theme),
a.wrapperClass !== b && e.removeClass(d.wrapperClass).addClass(a.wrapperClass),
a.iconpos !== b && f ? c.removeClass("ui-btn-icon-" + d.iconpos).addClass("ui-btn-icon-" + a.iconpos) : f || c.removeClass("ui-btn-icon-" + d.iconpos),
this._super(a);
},
},
a.mobile.behaviors.formReset
)
);
})(a),
(function (a, b) {
a.widget("mobile.button", {
initSelector: "input[type='button'], input[type='submit'], input[type='reset']",
options: { theme: null, icon: null, iconpos: "left", iconshadow: !1, corners: !0, shadow: !0, inline: null, mini: null, wrapperClass: null, enhanced: !1 },
_create: function () {
this.element.is(":disabled") && (this.options.disabled = !0),
this.options.enhanced || this._enhance(),
a.extend(this, { wrapper: this.element.parent() }),
this._on({
focus: function () {
this.widget().addClass(a.mobile.focusClass);
},
blur: function () {
this.widget().removeClass(a.mobile.focusClass);
},
}),
this.refresh(!0);
},
_enhance: function () {
this.element.wrap(this._button());
},
_button: function () {
var b = this.options,
c = this._getIconClasses(this.options);
return a(
"<div class='ui-btn ui-input-btn" +
(b.wrapperClass ? " " + b.wrapperClass : "") +
(b.theme ? " ui-btn-" + b.theme : "") +
(b.corners ? " ui-corner-all" : "") +
(b.shadow ? " ui-shadow" : "") +
(b.inline ? " ui-btn-inline" : "") +
(b.mini ? " ui-mini" : "") +
(b.disabled ? " ui-state-disabled" : "") +
(c ? " " + c : "") +
"' >" +
this.element.val() +
"</div>"
);
},
widget: function () {
return this.wrapper;
},
_destroy: function () {
this.element.insertBefore(this.wrapper), this.wrapper.remove();
},
_getIconClasses: function (a) {
return a.icon ? "ui-icon-" + a.icon + (a.iconshadow ? " ui-shadow-icon" : "") + " ui-btn-icon-" + a.iconpos : "";
},
_setOptions: function (c) {
var d = this.widget();
c.theme !== b && d.removeClass(this.options.theme).addClass("ui-btn-" + c.theme),
c.corners !== b && d.toggleClass("ui-corner-all", c.corners),
c.shadow !== b && d.toggleClass("ui-shadow", c.shadow),
c.inline !== b && d.toggleClass("ui-btn-inline", c.inline),
c.mini !== b && d.toggleClass("ui-mini", c.mini),
c.disabled !== b && (this.element.prop("disabled", c.disabled), d.toggleClass("ui-state-disabled", c.disabled)),
(c.icon !== b || c.iconshadow !== b || c.iconpos !== b) && d.removeClass(this._getIconClasses(this.options)).addClass(this._getIconClasses(a.extend({}, this.options, c))),
this._super(c);
},
refresh: function (b) {
var c,
d = this.element.prop("disabled");
this.options.icon && "notext" === this.options.iconpos && this.element.attr("title") && this.element.attr("title", this.element.val()),
b || ((c = this.element.detach()), a(this.wrapper).text(this.element.val()).append(c)),
this.options.disabled !== d && this._setOptions({ disabled: d });
},
});
})(a),
(function (a) {
var b = a("meta[name=viewport]"),
c = b.attr("content"),
d = c + ",maximum-scale=1, user-scalable=no",
e = c + ",maximum-scale=10, user-scalable=yes",
f = /(user-scalable[\s]*=[\s]*no)|(maximum-scale[\s]*=[\s]*1)[$,\s]/.test(c);
a.mobile.zoom = a.extend(
{},
{
enabled: !f,
locked: !1,
disable: function (c) {
f || a.mobile.zoom.locked || (b.attr("content", d), (a.mobile.zoom.enabled = !1), (a.mobile.zoom.locked = c || !1));
},
enable: function (c) {
f || (a.mobile.zoom.locked && c !== !0) || (b.attr("content", e), (a.mobile.zoom.enabled = !0), (a.mobile.zoom.locked = !1));
},
restore: function () {
f || (b.attr("content", c), (a.mobile.zoom.enabled = !0));
},
}
);
})(a),
(function (a, b) {
a.widget("mobile.textinput", {
initSelector:
"input[type='text'],input[type='search'],:jqmData(type='search'),input[type='number'],:jqmData(type='number'),input[type='password'],input[type='email'],input[type='url'],input[type='tel'],textarea,input[type='time'],input[type='date'],input[type='month'],input[type='week'],input[type='datetime'],input[type='datetime-local'],input[type='color'],input:not([type]),input[type='file']",
options: {
theme: null,
corners: !0,
mini: !1,
preventFocusZoom: /iPhone|iPad|iPod/.test(navigator.platform) && navigator.userAgent.indexOf("AppleWebKit") > -1,
wrapperClass: "",
enhanced: !1,
},
refresh: function () {
this.setOptions({ disabled: this.element.is(":disabled") });
},
widget: function () {
return this.inputNeedsWrap ? this.element.parent() : this.element;
},
_classesFromOptions: function () {
var a = this.options,
b = [];
return (
b.push("ui-body-" + (null === a.theme ? "inherit" : a.theme)),
a.corners && b.push("ui-corner-all"),
a.mini && b.push("ui-mini"),
a.disabled && b.push("ui-state-disabled"),
a.wrapperClass && b.push(a.wrapperClass),
b
);
},
_autoCorrect: function () {
"undefined" == typeof this.element[0].autocorrect || a.support.touchOverflow || (this.element[0].setAttribute("autocorrect", "off"), this.element[0].setAttribute("autocomplete", "off"));
},
_handleBlur: function () {
this.widget().removeClass(a.mobile.focusClass), this.options.preventFocusZoom && a.mobile.zoom.enable(!0);
},
_handleFocus: function () {
this.options.preventFocusZoom && a.mobile.zoom.disable(!0), this.widget().addClass(a.mobile.focusClass);
},
_setOptions: function (a) {
var c = this.widget();
this._super(a),
(a.disabled !== b || a.mini !== b || a.corners !== b || a.theme !== b || a.wrapperClass !== b) &&
(c.removeClass(this.classes.join(" ")), (this.classes = this._classesFromOptions()), c.addClass(this.classes.join(" "))),
a.disabled !== b && this.element.prop("disabled", !!a.disabled);
},
});
})(a),
(function (a, d) {
a.widget(
"mobile.slider",
a.extend(
{
initSelector: "input[type='range'], :jqmData(type='range'), :jqmData(role='slider')",
widgetEventPrefix: "slide",
options: { theme: null, trackTheme: null, corners: !0, mini: !1, highlight: !1 },
_create: function () {
var e,
f,
g,
h,
i,
j,
k,
l,
m,
n,
o = this,
p = this.element,
q = this.options.trackTheme || a.mobile.getAttribute(p[0], "theme"),
r = q ? " ui-bar-" + q : " ui-bar-inherit",
s = this.options.corners || p.jqmData("corners") ? " ui-corner-all" : "",
t = this.options.mini || p.jqmData("mini") ? " ui-mini" : "",
u = p[0].nodeName.toLowerCase(),
v = "select" === u,
w = p.parent().is(":jqmData(role='rangeslider')"),
x = v ? "ui-slider-switch" : "",
y = p.attr("id"),
z = a("[for='" + y + "']"),
A = z.attr("id") || y + "-label",
B = v ? 0 : parseFloat(p.attr("min")),
C = v ? p.find("option").length - 1 : parseFloat(p.attr("max")),
D = b.parseFloat(p.attr("step") || 1),
E = c.createElement("a"),
F = a(E),
G = c.createElement("div"),
H = a(G),
I =
this.options.highlight && !v
? (function () {
var b = c.createElement("div");
return (b.className = "ui-slider-bg " + a.mobile.activeBtnClass), a(b).prependTo(H);
})()
: !1;
if (
(z.attr("id", A),
(this.isToggleSwitch = v),
E.setAttribute("href", "#"),
G.setAttribute("role", "application"),
(G.className = [this.isToggleSwitch ? "ui-slider ui-slider-track ui-shadow-inset " : "ui-slider-track ui-shadow-inset ", x, r, s, t].join("")),
(E.className = "ui-slider-handle"),
G.appendChild(E),
F.attr({ role: "slider", "aria-valuemin": B, "aria-valuemax": C, "aria-valuenow": this._value(), "aria-valuetext": this._value(), title: this._value(), "aria-labelledby": A }),
a.extend(this, { slider: H, handle: F, control: p, type: u, step: D, max: C, min: B, valuebg: I, isRangeslider: w, dragging: !1, beforeStart: null, userModified: !1, mouseMoved: !1 }),
v)
) {
for (
k = p.attr("tabindex"),
k && F.attr("tabindex", k),
p.attr("tabindex", "-1").focus(function () {
a(this).blur(), F.focus();
}),
f = c.createElement("div"),
f.className = "ui-slider-inneroffset",
g = 0,
h = G.childNodes.length;
h > g;
g++
)
f.appendChild(G.childNodes[g]);
for (G.appendChild(f), F.addClass("ui-slider-handle-snapping"), e = p.find("option"), i = 0, j = e.length; j > i; i++)
(l = i ? "a" : "b"),
(m = i ? " " + a.mobile.activeBtnClass : ""),
(n = c.createElement("span")),
(n.className = ["ui-slider-label ui-slider-label-", l, m].join("")),
n.setAttribute("role", "img"),
n.appendChild(c.createTextNode(e[i].innerHTML)),
a(n).prependTo(H);
o._labels = a(".ui-slider-label", H);
}
p.addClass(v ? "ui-slider-switch" : "ui-slider-input"),
this._on(p, { change: "_controlChange", keyup: "_controlKeyup", blur: "_controlBlur", vmouseup: "_controlVMouseUp" }),
H.bind("vmousedown", a.proxy(this._sliderVMouseDown, this)).bind("vclick", !1),
this._on(c, { vmousemove: "_preventDocumentDrag" }),
this._on(H.add(c), { vmouseup: "_sliderVMouseUp" }),
H.insertAfter(p),
v || w || ((f = this.options.mini ? "<div class='ui-slider ui-mini'>" : "<div class='ui-slider'>"), p.add(H).wrapAll(f)),
this._on(this.handle, { vmousedown: "_handleVMouseDown", keydown: "_handleKeydown", keyup: "_handleKeyup" }),
this.handle.bind("vclick", !1),
this._handleFormReset(),
this.refresh(d, d, !0);
},
_setOptions: function (a) {
a.theme !== d && this._setTheme(a.theme),
a.trackTheme !== d && this._setTrackTheme(a.trackTheme),
a.corners !== d && this._setCorners(a.corners),
a.mini !== d && this._setMini(a.mini),
a.highlight !== d && this._setHighlight(a.highlight),
a.disabled !== d && this._setDisabled(a.disabled),
this._super(a);
},
_controlChange: function (a) {
return this._trigger("controlchange", a) === !1 ? !1 : void (this.mouseMoved || this.refresh(this._value(), !0));
},
_controlKeyup: function () {
this.refresh(this._value(), !0, !0);
},
_controlBlur: function () {
this.refresh(this._value(), !0);
},
_controlVMouseUp: function () {
this._checkedRefresh();
},
_handleVMouseDown: function () {
this.handle.focus();
},
_handleKeydown: function (b) {
var c = this._value();
if (!this.options.disabled) {
switch (b.keyCode) {
case a.mobile.keyCode.HOME:
case a.mobile.keyCode.END:
case a.mobile.keyCode.PAGE_UP:
case a.mobile.keyCode.PAGE_DOWN:
case a.mobile.keyCode.UP:
case a.mobile.keyCode.RIGHT:
case a.mobile.keyCode.DOWN:
case a.mobile.keyCode.LEFT:
b.preventDefault(), this._keySliding || ((this._keySliding = !0), this.handle.addClass("ui-state-active"));
}
switch (b.keyCode) {
case a.mobile.keyCode.HOME:
this.refresh(this.min);
break;
case a.mobile.keyCode.END:
this.refresh(this.max);
break;
case a.mobile.keyCode.PAGE_UP:
case a.mobile.keyCode.UP:
case a.mobile.keyCode.RIGHT:
this.refresh(c + this.step);
break;
case a.mobile.keyCode.PAGE_DOWN:
case a.mobile.keyCode.DOWN:
case a.mobile.keyCode.LEFT:
this.refresh(c - this.step);
}
}
},
_handleKeyup: function () {
this._keySliding && ((this._keySliding = !1), this.handle.removeClass("ui-state-active"));
},
_sliderVMouseDown: function (a) {
return this.options.disabled || (1 !== a.which && 0 !== a.which && a.which !== d)
? !1
: this._trigger("beforestart", a) === !1
? !1
: ((this.dragging = !0),
(this.userModified = !1),
(this.mouseMoved = !1),
this.isToggleSwitch && (this.beforeStart = this.element[0].selectedIndex),
this.refresh(a),
this._trigger("start"),
!1);
},
_sliderVMouseUp: function () {
return this.dragging
? ((this.dragging = !1),
this.isToggleSwitch &&
(this.handle.addClass("ui-slider-handle-snapping"),
this.refresh(this.mouseMoved ? (this.userModified ? (0 === this.beforeStart ? 1 : 0) : this.beforeStart) : 0 === this.beforeStart ? 1 : 0)),
(this.mouseMoved = !1),
this._trigger("stop"),
!1)
: void 0;
},
_preventDocumentDrag: function (a) {
return this._trigger("drag", a) === !1
? !1
: this.dragging && !this.options.disabled
? ((this.mouseMoved = !0),
this.isToggleSwitch && this.handle.removeClass("ui-slider-handle-snapping"),
this.refresh(a),
(this.userModified = this.beforeStart !== this.element[0].selectedIndex),
!1)
: void 0;
},
_checkedRefresh: function () {
this.value !== this._value() && this.refresh(this._value());
},
_value: function () {
return this.isToggleSwitch ? this.element[0].selectedIndex : parseFloat(this.element.val());
},
_reset: function () {
this.refresh(d, !1, !0);
},
refresh: function (b, d, e) {
var f,
g,
h,
i,
j,
k,
l,
m,
n,
o,
p,
q,
r,
s,
t,
u,
v,
w,
x,
y,
z = this,
A = a.mobile.getAttribute(this.element[0], "theme"),
B = this.options.theme || A,
C = B ? " ui-btn-" + B : "",
D = this.options.trackTheme || A,
E = D ? " ui-bar-" + D : " ui-bar-inherit",
F = this.options.corners ? " ui-corner-all" : "",
G = this.options.mini ? " ui-mini" : "";
if (
((z.slider[0].className = [this.isToggleSwitch ? "ui-slider ui-slider-switch ui-slider-track ui-shadow-inset" : "ui-slider-track ui-shadow-inset", E, F, G].join("")),
(this.options.disabled || this.element.prop("disabled")) && this.disable(),
(this.value = this._value()),
this.options.highlight &&
!this.isToggleSwitch &&
0 === this.slider.find(".ui-slider-bg").length &&
(this.valuebg = (function () {
var b = c.createElement("div");
return (b.className = "ui-slider-bg " + a.mobile.activeBtnClass), a(b).prependTo(z.slider);
})()),
this.handle.addClass("ui-btn" + C + " ui-shadow"),
(l = this.element),
(m = !this.isToggleSwitch),
(n = m ? [] : l.find("option")),
(o = m ? parseFloat(l.attr("min")) : 0),
(p = m ? parseFloat(l.attr("max")) : n.length - 1),
(q = m && parseFloat(l.attr("step")) > 0 ? parseFloat(l.attr("step")) : 1),
"object" == typeof b)
) {
if (((h = b), (i = 8), (f = this.slider.offset().left), (g = this.slider.width()), (j = g / ((p - o) / q)), !this.dragging || h.pageX < f - i || h.pageX > f + g + i)) return;
k = j > 1 ? ((h.pageX - f) / g) * 100 : Math.round(((h.pageX - f) / g) * 100);
} else null == b && (b = m ? parseFloat(l.val() || 0) : l[0].selectedIndex), (k = ((parseFloat(b) - o) / (p - o)) * 100);
if (
!isNaN(k) &&
((r = (k / 100) * (p - o) + o),
(s = (r - o) % q),
(t = r - s),
2 * Math.abs(s) >= q && (t += s > 0 ? q : -q),
(u = 100 / ((p - o) / q)),
(r = parseFloat(t.toFixed(5))),
"undefined" == typeof j && (j = g / ((p - o) / q)),
j > 1 && m && (k = (r - o) * u * (1 / q)),
0 > k && (k = 0),
k > 100 && (k = 100),
o > r && (r = o),
r > p && (r = p),
this.handle.css("left", k + "%"),
this.handle[0].setAttribute("aria-valuenow", m ? r : n.eq(r).attr("value")),
this.handle[0].setAttribute("aria-valuetext", m ? r : n.eq(r).getEncodedText()),
this.handle[0].setAttribute("title", m ? r : n.eq(r).getEncodedText()),
this.valuebg && this.valuebg.css("width", k + "%"),
this._labels &&
((v = (this.handle.width() / this.slider.width()) * 100),
(w = k && v + ((100 - v) * k) / 100),
(x = 100 === k ? 0 : Math.min(v + 100 - w, 100)),
this._labels.each(function () {
var b = a(this).hasClass("ui-slider-label-a");
a(this).width((b ? w : x) + "%");
})),
!e)
) {
if (((y = !1), m ? ((y = parseFloat(l.val()) !== r), l.val(r)) : ((y = l[0].selectedIndex !== r), (l[0].selectedIndex = r)), this._trigger("beforechange", b) === !1)) return !1;
!d && y && l.trigger("change");
}
},
_setHighlight: function (a) {
(a = !!a), a ? ((this.options.highlight = !!a), this.refresh()) : this.valuebg && (this.valuebg.remove(), (this.valuebg = !1));
},
_setTheme: function (a) {
this.handle.removeClass("ui-btn-" + this.options.theme).addClass("ui-btn-" + a);
var b = this.options.theme ? this.options.theme : "inherit",
c = a ? a : "inherit";
this.control.removeClass("ui-body-" + b).addClass("ui-body-" + c);
},
_setTrackTheme: function (a) {
var b = this.options.trackTheme ? this.options.trackTheme : "inherit",
c = a ? a : "inherit";
this.slider.removeClass("ui-body-" + b).addClass("ui-body-" + c);
},
_setMini: function (a) {
(a = !!a), this.isToggleSwitch || this.isRangeslider || (this.slider.parent().toggleClass("ui-mini", a), this.element.toggleClass("ui-mini", a)), this.slider.toggleClass("ui-mini", a);
},
_setCorners: function (a) {
this.slider.toggleClass("ui-corner-all", a), this.isToggleSwitch || this.control.toggleClass("ui-corner-all", a);
},
_setDisabled: function (a) {
(a = !!a), this.element.prop("disabled", a), this.slider.toggleClass("ui-state-disabled", a).attr("aria-disabled", a), this.element.toggleClass("ui-state-disabled", a);
},
},
a.mobile.behaviors.formReset
)
);
})(a),
(function (a) {
function b() {
return c || (c = a("<div></div>", { class: "ui-slider-popup ui-shadow ui-corner-all" })), c.clone();
}
var c;
a.widget("mobile.slider", a.mobile.slider, {
options: { popupEnabled: !1, showValue: !1 },
_create: function () {
this._super(),
a.extend(this, { _currentValue: null, _popup: null, _popupVisible: !1 }),
this._setOption("popupEnabled", this.options.popupEnabled),
this._on(this.handle, { vmousedown: "_showPopup" }),
this._on(this.slider.add(this.document), { vmouseup: "_hidePopup" }),
this._refresh();
},
_positionPopup: function () {
var a = this.handle.offset();
this._popup.offset({ left: a.left + (this.handle.width() - this._popup.width()) / 2, top: a.top - this._popup.outerHeight() - 5 });
},
_setOption: function (a, c) {
this._super(a, c),
"showValue" === a
? this.handle.html(c && !this.options.mini ? this._value() : "")
: "popupEnabled" === a &&
c &&
!this._popup &&
(this._popup = b()
.addClass("ui-body-" + (this.options.theme || "a"))
.hide()
.insertBefore(this.element));
},
refresh: function () {
this._super.apply(this, arguments), this._refresh();
},
_refresh: function () {
var a,
b = this.options;
b.popupEnabled && this.handle.removeAttr("title"),
(a = this._value()),
a !== this._currentValue &&
((this._currentValue = a), b.popupEnabled && this._popup && (this._positionPopup(), this._popup.html(a)), b.showValue && !this.options.mini && this.handle.html(a));
},
_showPopup: function () {
this.options.popupEnabled && !this._popupVisible && (this.handle.html(""), this._popup.show(), this._positionPopup(), (this._popupVisible = !0));
},
_hidePopup: function () {
var a = this.options;
a.popupEnabled && this._popupVisible && (a.showValue && !a.mini && this.handle.html(this._value()), this._popup.hide(), (this._popupVisible = !1));
},
});
})(a),
(function (a, b) {
a.widget(
"mobile.flipswitch",
a.extend(
{
options: { onText: "On", offText: "Off", theme: null, enhanced: !1, wrapperClass: null, corners: !0, mini: !1 },
_create: function () {
this.options.enhanced
? a.extend(this, {
flipswitch: this.element.parent(),
on: this.element.find(".ui-flipswitch-on").eq(0),
off: this.element.find(".ui-flipswitch-off").eq(0),
type: this.element.get(0).tagName,
})
: this._enhance(),
this._handleFormReset(),
(this._originalTabIndex = this.element.attr("tabindex")),
null != this._originalTabIndex && this.on.attr("tabindex", this._originalTabIndex),
this.element.attr("tabindex", "-1"),
this._on({ focus: "_handleInputFocus" }),
this.element.is(":disabled") && this._setOptions({ disabled: !0 }),
this._on(this.flipswitch, { click: "_toggle", swipeleft: "_left", swiperight: "_right" }),
this._on(this.on, { keydown: "_keydown" }),
this._on({ change: "refresh" });
},
_handleInputFocus: function () {
this.on.focus();
},
widget: function () {
return this.flipswitch;
},
_left: function () {
this.flipswitch.removeClass("ui-flipswitch-active"), "SELECT" === this.type ? (this.element.get(0).selectedIndex = 0) : this.element.prop("checked", !1), this.element.trigger("change");
},
_right: function () {
this.flipswitch.addClass("ui-flipswitch-active"), "SELECT" === this.type ? (this.element.get(0).selectedIndex = 1) : this.element.prop("checked", !0), this.element.trigger("change");
},
_enhance: function () {
var b = a("<div>"),
c = this.options,
d = this.element,
e = c.theme ? c.theme : "inherit",
f = a("<a></a>", { href: "#" }),
g = a("<span></span>"),
h = d.get(0).tagName,
i = "INPUT" === h ? c.onText : d.find("option").eq(1).text(),
j = "INPUT" === h ? c.offText : d.find("option").eq(0).text();
f.addClass("ui-flipswitch-on ui-btn ui-shadow ui-btn-inherit").text(i),
g.addClass("ui-flipswitch-off").text(j),
b
.addClass(
"ui-flipswitch ui-shadow-inset ui-bar-" +
e +
" " +
(c.wrapperClass ? c.wrapperClass : "") +
" " +
(d.is(":checked") || d.find("option").eq(1).is(":selected") ? "ui-flipswitch-active" : "") +
(d.is(":disabled") ? " ui-state-disabled" : "") +
(c.corners ? " ui-corner-all" : "") +
(c.mini ? " ui-mini" : "")
)
.append(f, g),
d.addClass("ui-flipswitch-input").after(b).appendTo(b),
a.extend(this, { flipswitch: b, on: f, off: g, type: h });
},
_reset: function () {
this.refresh();
},
refresh: function () {
var a,
b = this.flipswitch.hasClass("ui-flipswitch-active") ? "_right" : "_left";
(a = "SELECT" === this.type ? (this.element.get(0).selectedIndex > 0 ? "_right" : "_left") : this.element.prop("checked") ? "_right" : "_left"), a !== b && this[a]();
},
_toggle: function () {
var a = this.flipswitch.hasClass("ui-flipswitch-active") ? "_left" : "_right";
this[a]();
},
_keydown: function (b) {
b.which === a.mobile.keyCode.LEFT ? this._left() : b.which === a.mobile.keyCode.RIGHT ? this._right() : b.which === a.mobile.keyCode.SPACE && (this._toggle(), b.preventDefault());
},
_setOptions: function (a) {
if (a.theme !== b) {
var c = a.theme ? a.theme : "inherit",
d = a.theme ? a.theme : "inherit";
this.widget()
.removeClass("ui-bar-" + c)
.addClass("ui-bar-" + d);
}
a.onText !== b && this.on.text(a.onText),
a.offText !== b && this.off.text(a.offText),
a.disabled !== b && this.widget().toggleClass("ui-state-disabled", a.disabled),
a.mini !== b && this.widget().toggleClass("ui-mini", a.mini),
a.corners !== b && this.widget().toggleClass("ui-corner-all", a.corners),
this._super(a);
},
_destroy: function () {
this.options.enhanced ||
(null != this._originalTabIndex ? this.element.attr("tabindex", this._originalTabIndex) : this.element.removeAttr("tabindex"),
this.on.remove(),
this.off.remove(),
this.element.unwrap(),
this.flipswitch.remove(),
this.removeClass("ui-flipswitch-input"));
},
},
a.mobile.behaviors.formReset
)
);
})(a),
(function (a, b) {
a.widget(
"mobile.rangeslider",
a.extend(
{
options: { theme: null, trackTheme: null, corners: !0, mini: !1, highlight: !0 },
_create: function () {
var b = this.element,
c = this.options.mini ? "ui-rangeslider ui-mini" : "ui-rangeslider",
d = b.find("input").first(),
e = b.find("input").last(),
f = b.find("label").first(),
g = a.data(d.get(0), "mobile-slider") || a.data(d.slider().get(0), "mobile-slider"),
h = a.data(e.get(0), "mobile-slider") || a.data(e.slider().get(0), "mobile-slider"),
i = g.slider,
j = h.slider,
k = g.handle,
l = a("<div class='ui-rangeslider-sliders' />").appendTo(b);
d.addClass("ui-rangeslider-first"),
e.addClass("ui-rangeslider-last"),
b.addClass(c),
i.appendTo(l),
j.appendTo(l),
f.insertBefore(b),
k.prependTo(j),
a.extend(this, { _inputFirst: d, _inputLast: e, _sliderFirst: i, _sliderLast: j, _label: f, _targetVal: null, _sliderTarget: !1, _sliders: l, _proxy: !1 }),
this.refresh(),
this._on(this.element.find("input.ui-slider-input"), {
slidebeforestart: "_slidebeforestart",
slidestop: "_slidestop",
slidedrag: "_slidedrag",
slidebeforechange: "_change",
blur: "_change",
keyup: "_change",
}),
this._on({ mousedown: "_change" }),
this._on(this.element.closest("form"), { reset: "_handleReset" }),
this._on(k, { vmousedown: "_dragFirstHandle" });
},
_handleReset: function () {
var a = this;
setTimeout(function () {
a._updateHighlight();
}, 0);
},
_dragFirstHandle: function (b) {
return (
(a.data(this._inputFirst.get(0), "mobile-slider").dragging = !0),
a.data(this._inputFirst.get(0), "mobile-slider").refresh(b),
a.data(this._inputFirst.get(0), "mobile-slider")._trigger("start"),
!1
);
},
_slidedrag: function (b) {
var c = a(b.target).is(this._inputFirst),
d = c ? this._inputLast : this._inputFirst;
return (
(this._sliderTarget = !1),
("first" === this._proxy && c) || ("last" === this._proxy && !c) ? ((a.data(d.get(0), "mobile-slider").dragging = !0), a.data(d.get(0), "mobile-slider").refresh(b), !1) : void 0
);
},
_slidestop: function (b) {
var c = a(b.target).is(this._inputFirst);
(this._proxy = !1), this.element.find("input").trigger("vmouseup"), this._sliderFirst.css("z-index", c ? 1 : "");
},
_slidebeforestart: function (b) {
(this._sliderTarget = !1), a(b.originalEvent.target).hasClass("ui-slider-track") && ((this._sliderTarget = !0), (this._targetVal = a(b.target).val()));
},
_setOptions: function (a) {
a.theme !== b && this._setTheme(a.theme),
a.trackTheme !== b && this._setTrackTheme(a.trackTheme),
a.mini !== b && this._setMini(a.mini),
a.highlight !== b && this._setHighlight(a.highlight),
a.disabled !== b && this._setDisabled(a.disabled),
this._super(a),
this.refresh();
},
refresh: function () {
var a = this.element,
b = this.options;
(this._inputFirst.is(":disabled") || this._inputLast.is(":disabled")) && (this.options.disabled = !0),
a.find("input").slider({ theme: b.theme, trackTheme: b.trackTheme, disabled: b.disabled, corners: b.corners, mini: b.mini, highlight: b.highlight }).slider("refresh"),
this._updateHighlight();
},
_change: function (b) {
if ("keyup" === b.type) return this._updateHighlight(), !1;
var c = this,
d = parseFloat(this._inputFirst.val(), 10),
e = parseFloat(this._inputLast.val(), 10),
f = a(b.target).hasClass("ui-rangeslider-first"),
g = f ? this._inputFirst : this._inputLast,
h = f ? this._inputLast : this._inputFirst;
if (this._inputFirst.val() > this._inputLast.val() && "mousedown" === b.type && !a(b.target).hasClass("ui-slider-handle")) g.blur();
else if ("mousedown" === b.type) return;
return (
d > e && !this._sliderTarget
? (g.val(f ? e : d).slider("refresh"), this._trigger("normalize"))
: d > e &&
(g.val(this._targetVal).slider("refresh"),
setTimeout(function () {
h.val(f ? d : e).slider("refresh"), a.data(h.get(0), "mobile-slider").handle.focus(), c._sliderFirst.css("z-index", f ? "" : 1), c._trigger("normalize");
}, 0),
(this._proxy = f ? "first" : "last")),
d === e
? (a.data(g.get(0), "mobile-slider").handle.css("z-index", 1), a.data(h.get(0), "mobile-slider").handle.css("z-index", 0))
: (a.data(h.get(0), "mobile-slider").handle.css("z-index", ""), a.data(g.get(0), "mobile-slider").handle.css("z-index", "")),
this._updateHighlight(),
d >= e ? !1 : void 0
);
},
_updateHighlight: function () {
var b = parseInt(a.data(this._inputFirst.get(0), "mobile-slider").handle.get(0).style.left, 10),
c = parseInt(a.data(this._inputLast.get(0), "mobile-slider").handle.get(0).style.left, 10),
d = c - b;
this.element.find(".ui-slider-bg").css({ "margin-left": b + "%", width: d + "%" });
},
_setTheme: function (a) {
this._inputFirst.slider("option", "theme", a), this._inputLast.slider("option", "theme", a);
},
_setTrackTheme: function (a) {
this._inputFirst.slider("option", "trackTheme", a), this._inputLast.slider("option", "trackTheme", a);
},
_setMini: function (a) {
this._inputFirst.slider("option", "mini", a), this._inputLast.slider("option", "mini", a), this.element.toggleClass("ui-mini", !!a);
},
_setHighlight: function (a) {
this._inputFirst.slider("option", "highlight", a), this._inputLast.slider("option", "highlight", a);
},
_setDisabled: function (a) {
this._inputFirst.prop("disabled", a), this._inputLast.prop("disabled", a);
},
_destroy: function () {
this._label.prependTo(this.element),
this.element.removeClass("ui-rangeslider ui-mini"),
this._inputFirst.after(this._sliderFirst),
this._inputLast.after(this._sliderLast),
this._sliders.remove(),
this.element.find("input").removeClass("ui-rangeslider-first ui-rangeslider-last").slider("destroy");
},
},
a.mobile.behaviors.formReset
)
);
})(a),
(function (a, b) {
a.widget("mobile.textinput", a.mobile.textinput, {
options: { clearBtn: !1, clearBtnText: "Clear text" },
_create: function () {
this._super(), this.isSearch && (this.options.clearBtn = !0), this.options.clearBtn && this.inputNeedsWrap && this._addClearBtn();
},
clearButton: function () {
return a("<a href='#' tabindex='-1' aria-hidden='true' class='ui-input-clear ui-btn ui-icon-delete ui-btn-icon-notext ui-corner-all'></a>")
.attr("title", this.options.clearBtnText)
.text(this.options.clearBtnText);
},
_clearBtnClick: function (a) {
this.element.val("").focus().trigger("change"), this._clearBtn.addClass("ui-input-clear-hidden"), a.preventDefault();
},
_addClearBtn: function () {
this.options.enhanced || this._enhanceClear(), a.extend(this, { _clearBtn: this.widget().find("a.ui-input-clear") }), this._bindClearEvents(), this._toggleClear();
},
_enhanceClear: function () {
this.clearButton().appendTo(this.widget()), this.widget().addClass("ui-input-has-clear");
},
_bindClearEvents: function () {
this._on(this._clearBtn, { click: "_clearBtnClick" }),
this._on({ keyup: "_toggleClear", change: "_toggleClear", input: "_toggleClear", focus: "_toggleClear", blur: "_toggleClear", cut: "_toggleClear", paste: "_toggleClear" });
},
_unbindClear: function () {
this._off(this._clearBtn, "click"), this._off(this.element, "keyup change input focus blur cut paste");
},
_setOptions: function (a) {
this._super(a),
a.clearBtn === b || this.element.is("textarea, :jqmData(type='range')") || (a.clearBtn ? this._addClearBtn() : this._destroyClear()),
a.clearBtnText !== b && this._clearBtn !== b && this._clearBtn.text(a.clearBtnText).attr("title", a.clearBtnText);
},
_toggleClear: function () {
this._delay("_toggleClearClass", 0);
},
_toggleClearClass: function () {
this._clearBtn.toggleClass("ui-input-clear-hidden", !this.element.val());
},
_destroyClear: function () {
this.widget().removeClass("ui-input-has-clear"), this._unbindClear(), this._clearBtn.remove();
},
_destroy: function () {
this._super(), this.options.clearBtn && this._destroyClear();
},
});
})(a),
(function (a, b) {
a.widget("mobile.textinput", a.mobile.textinput, {
options: { autogrow: !0, keyupTimeoutBuffer: 100 },
_create: function () {
this._super(), this.options.autogrow && this.isTextarea && this._autogrow();
},
_autogrow: function () {
this.element.addClass("ui-textinput-autogrow"),
this._on({ keyup: "_timeout", change: "_timeout", input: "_timeout", paste: "_timeout" }),
this._on(!0, this.document, { pageshow: "_handleShow", popupbeforeposition: "_handleShow", updatelayout: "_handleShow", panelopen: "_handleShow" });
},
_handleShow: function (b) {
a.contains(b.target, this.element[0]) &&
this.element.is(":visible") &&
("popupbeforeposition" !== b.type &&
this.element.addClass("ui-textinput-autogrow-resize").animationComplete(
a.proxy(function () {
this.element.removeClass("ui-textinput-autogrow-resize");
}, this),
"transition"
),
this._prepareHeightUpdate());
},
_unbindAutogrow: function () {
this.element.removeClass("ui-textinput-autogrow"), this._off(this.element, "keyup change input paste"), this._off(this.document, "pageshow popupbeforeposition updatelayout panelopen");
},
keyupTimeout: null,
_prepareHeightUpdate: function (a) {
this.keyupTimeout && clearTimeout(this.keyupTimeout), a === b ? this._updateHeight() : (this.keyupTimeout = this._delay("_updateHeight", a));
},
_timeout: function () {
this._prepareHeightUpdate(this.options.keyupTimeoutBuffer);
},
_updateHeight: function () {
var a,
b,
c,
d,
e,
f,
g,
h,
i,
j = this.window.scrollTop();
(this.keyupTimeout = 0),
"onpage" in this.element[0] || this.element.css({ height: 0, "min-height": 0, "max-height": 0 }),
(d = this.element[0].scrollHeight),
(e = this.element[0].clientHeight),
(f = parseFloat(this.element.css("border-top-width"))),
(g = parseFloat(this.element.css("border-bottom-width"))),
(h = f + g),
(i = d + h + 15),
0 === e && ((a = parseFloat(this.element.css("padding-top"))), (b = parseFloat(this.element.css("padding-bottom"))), (c = a + b), (i += c)),
this.element.css({ height: i, "min-height": "", "max-height": "" }),
this.window.scrollTop(j);
},
refresh: function () {
this.options.autogrow && this.isTextarea && this._updateHeight();
},
_setOptions: function (a) {
this._super(a), a.autogrow !== b && this.isTextarea && (a.autogrow ? this._autogrow() : this._unbindAutogrow());
},
});
})(a),
(function (a) {
a.widget(
"mobile.selectmenu",
a.extend(
{
initSelector: "select:not( :jqmData(role='slider')):not( :jqmData(role='flipswitch') )",
options: {
theme: null,
icon: "carat-d",
iconpos: "right",
inline: !1,
corners: !0,
shadow: !0,
iconshadow: !1,
overlayTheme: null,
dividerTheme: null,
hidePlaceholderMenuItems: !0,
closeText: "Close",
nativeMenu: !0,
preventFocusZoom: /iPhone|iPad|iPod/.test(navigator.platform) && navigator.userAgent.indexOf("AppleWebKit") > -1,
mini: !1,
},
_button: function () {
return a("<div/>");
},
_setDisabled: function (a) {
return this.element.attr("disabled", a), this.button.attr("aria-disabled", a), this._setOption("disabled", a);
},
_focusButton: function () {
var a = this;
setTimeout(function () {
a.button.focus();
}, 40);
},
_selectOptions: function () {
return this.select.find("option");
},
_preExtension: function () {
var b = this.options.inline || this.element.jqmData("inline"),
c = this.options.mini || this.element.jqmData("mini"),
d = "";
~this.element[0].className.indexOf("ui-btn-left") && (d = " ui-btn-left"),
~this.element[0].className.indexOf("ui-btn-right") && (d = " ui-btn-right"),
b && (d += " ui-btn-inline"),
c && (d += " ui-mini"),
(this.select = this.element.removeClass("ui-btn-left ui-btn-right").wrap("<div class='ui-select" + d + "'>")),
(this.selectId = this.select.attr("id") || "select-" + this.uuid),
(this.buttonId = this.selectId + "-button"),
(this.label = a("label[for='" + this.selectId + "']")),
(this.isMultiple = this.select[0].multiple);
},
_destroy: function () {
var a = this.element.parents(".ui-select");
a.length > 0 && (a.is(".ui-btn-left, .ui-btn-right") && this.element.addClass(a.hasClass("ui-btn-left") ? "ui-btn-left" : "ui-btn-right"), this.element.insertAfter(a), a.remove());
},
_create: function () {
this._preExtension(), (this.button = this._button());
var c = this,
d = this.options,
e = d.icon ? d.iconpos || this.select.jqmData("iconpos") : !1,
f = this.button
.insertBefore(this.select)
.attr("id", this.buttonId)
.addClass(
"ui-btn" +
(d.icon ? " ui-icon-" + d.icon + " ui-btn-icon-" + e + (d.iconshadow ? " ui-shadow-icon" : "") : "") +
(d.theme ? " ui-btn-" + d.theme : "") +
(d.corners ? " ui-corner-all" : "") +
(d.shadow ? " ui-shadow" : "")
);
this.setButtonText(),
d.nativeMenu && b.opera && b.opera.version && f.addClass("ui-select-nativeonly"),
this.isMultiple && (this.buttonCount = a("<span>").addClass("ui-li-count ui-body-inherit").hide().appendTo(f.addClass("ui-li-has-count"))),
(d.disabled || this.element.attr("disabled")) && this.disable(),
this.select.change(function () {
c.refresh(),
d.nativeMenu &&
c._delay(function () {
c.select.blur();
});
}),
this._handleFormReset(),
this._on(this.button, { keydown: "_handleKeydown" }),
this.build();
},
build: function () {
var b = this;
this.select
.appendTo(b.button)
.bind("vmousedown", function () {
b.button.addClass(a.mobile.activeBtnClass);
})
.bind("focus", function () {
b.button.addClass(a.mobile.focusClass);
})
.bind("blur", function () {
b.button.removeClass(a.mobile.focusClass);
})
.bind("focus vmouseover", function () {
b.button.trigger("vmouseover");
})
.bind("vmousemove", function () {
b.button.removeClass(a.mobile.activeBtnClass);
})
.bind("change blur vmouseout", function () {
b.button.trigger("vmouseout").removeClass(a.mobile.activeBtnClass);
}),
b.button.bind("vmousedown", function () {
b.options.preventFocusZoom && a.mobile.zoom.disable(!0);
}),
b.label.bind("click focus", function () {
b.options.preventFocusZoom && a.mobile.zoom.disable(!0);
}),
b.select.bind("focus", function () {
b.options.preventFocusZoom && a.mobile.zoom.disable(!0);
}),
b.button.bind("mouseup", function () {
b.options.preventFocusZoom &&
setTimeout(function () {
a.mobile.zoom.enable(!0);
}, 0);
}),
b.select.bind("blur", function () {
b.options.preventFocusZoom && a.mobile.zoom.enable(!0);
});
},
selected: function () {
return this._selectOptions().filter(":selected");
},
selectedIndices: function () {
var a = this;
return this.selected()
.map(function () {
return a._selectOptions().index(this);
})
.get();
},
setButtonText: function () {
var b = this,
d = this.selected(),
e = this.placeholder,
f = a(c.createElement("span"));
this.button
.children("span")
.not(".ui-li-count")
.remove()
.end()
.end()
.prepend(
(function () {
return (
(e = d.length
? d
.map(function () {
return a(this).text();
})
.get()
.join(", ")
: b.placeholder),
e ? f.text(e) : f.html("&#160;"),
f.addClass(b.select.attr("class")).addClass(d.attr("class")).removeClass("ui-screen-hidden")
);
})()
);
},
setButtonCount: function () {
var a = this.selected();
this.isMultiple && this.buttonCount[a.length > 1 ? "show" : "hide"]().text(a.length);
},
_handleKeydown: function () {
this._delay("_refreshButton");
},
_reset: function () {
this.refresh();
},
_refreshButton: function () {
this.setButtonText(), this.setButtonCount();
},
refresh: function () {
this._refreshButton();
},
open: a.noop,
close: a.noop,
disable: function () {
this._setDisabled(!0), this.button.addClass("ui-state-disabled");
},
enable: function () {
this._setDisabled(!1), this.button.removeClass("ui-state-disabled");
},
},
a.mobile.behaviors.formReset
)
);
})(a),
(function (a) {
a.mobile.links = function (b) {
a(b)
.find("a")
.jqmEnhanceable()
.filter(":jqmData(rel='popup')[href][href!='']")
.each(function () {
var a = this,
b = a.getAttribute("href").substring(1);
b && (a.setAttribute("aria-haspopup", !0), a.setAttribute("aria-owns", b), a.setAttribute("aria-expanded", !1));
})
.end()
.not(".ui-btn, :jqmData(role='none'), :jqmData(role='nojs')")
.addClass("ui-link");
};
})(a),
(function (a, c) {
function d(a, b, c, d) {
var e = d;
return (e = b > a ? c + (a - b) / 2 : Math.min(Math.max(c, d - b / 2), c + a - b));
}
function e(a) {
return { x: a.scrollLeft(), y: a.scrollTop(), cx: a[0].innerWidth || a.width(), cy: a[0].innerHeight || a.height() };
}
a.widget("mobile.popup", {
options: {
wrapperClass: null,
theme: null,
overlayTheme: null,
shadow: !0,
corners: !0,
transition: "none",
positionTo: "origin",
tolerance: null,
closeLinkSelector: "a:jqmData(rel='back')",
closeLinkEvents: "click.popup",
navigateEvents: "navigate.popup",
closeEvents: "navigate.popup pagebeforechange.popup",
dismissible: !0,
enhanced: !1,
history: !a.mobile.browser.oldIE,
},
_handleDocumentVmousedown: function (b) {
this._isOpen && a.contains(this._ui.container[0], b.target) && this._ignoreResizeEvents();
},
_create: function () {
var b = this.element,
c = b.attr("id"),
d = this.options;
(d.history = d.history && a.mobile.ajaxEnabled && a.mobile.hashListeningEnabled),
this._on(this.document, { vmousedown: "_handleDocumentVmousedown" }),
a.extend(this, {
_scrollTop: 0,
_page: b.closest(".ui-page"),
_ui: null,
_fallbackTransition: "",
_currentTransition: !1,
_prerequisites: null,
_isOpen: !1,
_tolerance: null,
_resizeData: null,
_ignoreResizeTo: 0,
_orientationchangeInProgress: !1,
}),
0 === this._page.length && (this._page = a("body")),
d.enhanced
? (this._ui = { container: b.parent(), screen: b.parent().prev(), placeholder: a(this.document[0].getElementById(c + "-placeholder")) })
: ((this._ui = this._enhance(b, c)), this._applyTransition(d.transition)),
(this._setTolerance(d.tolerance)._ui.focusElement = this._ui.container),
this._on(this._ui.screen, { vclick: "_eatEventAndClose" }),
this._on(this.window, { orientationchange: a.proxy(this, "_handleWindowOrientationchange"), resize: a.proxy(this, "_handleWindowResize"), keyup: a.proxy(this, "_handleWindowKeyUp") }),
this._on(this.document, { focusin: "_handleDocumentFocusIn" });
},
_enhance: function (b, c) {
var d = this.options,
e = d.wrapperClass,
f = {
screen: a("<div class='ui-screen-hidden ui-popup-screen " + this._themeClassFromOption("ui-overlay-", d.overlayTheme) + "'></div>"),
placeholder: a("<div style='display: none;'><!-- placeholder --></div>"),
container: a("<div class='ui-popup-container ui-popup-hidden ui-popup-truncate" + (e ? " " + e : "") + "'></div>"),
},
g = this.document[0].createDocumentFragment();
return (
g.appendChild(f.screen[0]),
g.appendChild(f.container[0]),
c && (f.screen.attr("id", c + "-screen"), f.container.attr("id", c + "-popup"), f.placeholder.attr("id", c + "-placeholder").html("<!-- placeholder for " + c + " -->")),
this._page[0].appendChild(g),
f.placeholder.insertAfter(b),
b
.detach()
.addClass("ui-popup " + this._themeClassFromOption("ui-body-", d.theme) + " " + (d.shadow ? "ui-overlay-shadow " : "") + (d.corners ? "ui-corner-all " : ""))
.appendTo(f.container),
f
);
},
_eatEventAndClose: function (a) {
return a.preventDefault(), a.stopImmediatePropagation(), this.options.dismissible && this.close(), !1;
},
_resizeScreen: function () {
var a = this._ui.screen,
b = this._ui.container.outerHeight(!0),
c = a.removeAttr("style").height(),
d = this.document.height() - 1;
d > c ? a.height(d) : b > c && a.height(b);
},
_handleWindowKeyUp: function (b) {
return this._isOpen && b.keyCode === a.mobile.keyCode.ESCAPE ? this._eatEventAndClose(b) : void 0;
},
_expectResizeEvent: function () {
var a = e(this.window);
if (this._resizeData) {
if (
a.x === this._resizeData.windowCoordinates.x &&
a.y === this._resizeData.windowCoordinates.y &&
a.cx === this._resizeData.windowCoordinates.cx &&
a.cy === this._resizeData.windowCoordinates.cy
)
return !1;
clearTimeout(this._resizeData.timeoutId);
}
return (this._resizeData = { timeoutId: this._delay("_resizeTimeout", 200), windowCoordinates: a }), !0;
},
_resizeTimeout: function () {
this._isOpen
? this._expectResizeEvent() ||
(this._ui.container.hasClass("ui-popup-hidden") &&
(this._ui.container.removeClass("ui-popup-hidden ui-popup-truncate"), this.reposition({ positionTo: "window" }), this._ignoreResizeEvents()),
this._resizeScreen(),
(this._resizeData = null),
(this._orientationchangeInProgress = !1))
: ((this._resizeData = null), (this._orientationchangeInProgress = !1));
},
_stopIgnoringResizeEvents: function () {
this._ignoreResizeTo = 0;
},
_ignoreResizeEvents: function () {
this._ignoreResizeTo && clearTimeout(this._ignoreResizeTo), (this._ignoreResizeTo = this._delay("_stopIgnoringResizeEvents", 1e3));
},
_handleWindowResize: function () {
this._isOpen &&
0 === this._ignoreResizeTo &&
((!this._expectResizeEvent() && !this._orientationchangeInProgress) ||
this._ui.container.hasClass("ui-popup-hidden") ||
this._ui.container.addClass("ui-popup-hidden ui-popup-truncate").removeAttr("style"));
},
_handleWindowOrientationchange: function () {
!this._orientationchangeInProgress && this._isOpen && 0 === this._ignoreResizeTo && (this._expectResizeEvent(), (this._orientationchangeInProgress = !0));
},
_handleDocumentFocusIn: function (b) {
var c,
d = b.target,
e = this._ui;
if (this._isOpen) {
if (d !== e.container[0]) {
if (((c = a(d)), !a.contains(e.container[0], d)))
return (
a(this.document[0].activeElement).one(
"focus",
a.proxy(function () {
this._safelyBlur(d);
}, this)
),
e.focusElement.focus(),
b.preventDefault(),
b.stopImmediatePropagation(),
!1
);
e.focusElement[0] === e.container[0] && (e.focusElement = c);
}
this._ignoreResizeEvents();
}
},
_themeClassFromOption: function (a, b) {
return b ? ("none" === b ? "" : a + b) : a + "inherit";
},
_applyTransition: function (b) {
return (
b &&
(this._ui.container.removeClass(this._fallbackTransition),
"none" !== b &&
((this._fallbackTransition = a.mobile._maybeDegradeTransition(b)),
"none" === this._fallbackTransition && (this._fallbackTransition = ""),
this._ui.container.addClass(this._fallbackTransition))),
this
);
},
_setOptions: function (a) {
var b = this.options,
d = this.element,
e = this._ui.screen;
return (
a.wrapperClass !== c && this._ui.container.removeClass(b.wrapperClass).addClass(a.wrapperClass),
a.theme !== c && d.removeClass(this._themeClassFromOption("ui-body-", b.theme)).addClass(this._themeClassFromOption("ui-body-", a.theme)),
a.overlayTheme !== c &&
(e.removeClass(this._themeClassFromOption("ui-overlay-", b.overlayTheme)).addClass(this._themeClassFromOption("ui-overlay-", a.overlayTheme)), this._isOpen && e.addClass("in")),
a.shadow !== c && d.toggleClass("ui-overlay-shadow", a.shadow),
a.corners !== c && d.toggleClass("ui-corner-all", a.corners),
a.transition !== c && (this._currentTransition || this._applyTransition(a.transition)),
a.tolerance !== c && this._setTolerance(a.tolerance),
a.disabled !== c && a.disabled && this.close(),
this._super(a)
);
},
_setTolerance: function (b) {
var d,
e = { t: 30, r: 15, b: 30, l: 15 };
if (b !== c)
switch (
((d = String(b).split(",")),
a.each(d, function (a, b) {
d[a] = parseInt(b, 10);
}),
d.length)
) {
case 1:
isNaN(d[0]) || (e.t = e.r = e.b = e.l = d[0]);
break;
case 2:
isNaN(d[0]) || (e.t = e.b = d[0]), isNaN(d[1]) || (e.l = e.r = d[1]);
break;
case 4:
isNaN(d[0]) || (e.t = d[0]), isNaN(d[1]) || (e.r = d[1]), isNaN(d[2]) || (e.b = d[2]), isNaN(d[3]) || (e.l = d[3]);
}
return (this._tolerance = e), this;
},
_clampPopupWidth: function (a) {
var b,
c = e(this.window),
d = { x: this._tolerance.l, y: c.y + this._tolerance.t, cx: c.cx - this._tolerance.l - this._tolerance.r, cy: c.cy - this._tolerance.t - this._tolerance.b };
return a || this._ui.container.css("max-width", d.cx), (b = { cx: this._ui.container.outerWidth(!0), cy: this._ui.container.outerHeight(!0) }), { rc: d, menuSize: b };
},
_calculateFinalLocation: function (a, b) {
var c,
e = b.rc,
f = b.menuSize;
return (c = { left: d(e.cx, f.cx, e.x, a.x), top: d(e.cy, f.cy, e.y, a.y) }), (c.top = Math.max(0, c.top)), (c.top -= Math.min(c.top, Math.max(0, c.top + f.cy - this.document.height()))), c;
},
_placementCoords: function (a) {
return this._calculateFinalLocation(a, this._clampPopupWidth());
},
_createPrerequisites: function (b, c, d) {
var e,
f = this;
(e = { screen: a.Deferred(), container: a.Deferred() }),
e.screen.then(function () {
e === f._prerequisites && b();
}),
e.container.then(function () {
e === f._prerequisites && c();
}),
a.when(e.screen, e.container).done(function () {
e === f._prerequisites && ((f._prerequisites = null), d());
}),
(f._prerequisites = e);
},
_animate: function (b) {
return (
this._ui.screen.removeClass(b.classToRemove).addClass(b.screenClassToAdd),
b.prerequisites.screen.resolve(),
b.transition && "none" !== b.transition && (b.applyTransition && this._applyTransition(b.transition), this._fallbackTransition)
? void this._ui.container.addClass(b.containerClassToAdd).removeClass(b.classToRemove).animationComplete(a.proxy(b.prerequisites.container, "resolve"))
: (this._ui.container.removeClass(b.classToRemove), void b.prerequisites.container.resolve())
);
},
_desiredCoords: function (b) {
var c,
d = null,
f = e(this.window),
g = b.x,
h = b.y,
i = b.positionTo;
if (i && "origin" !== i)
if ("window" === i) (g = f.cx / 2 + f.x), (h = f.cy / 2 + f.y);
else {
try {
d = a(i);
} catch (j) {
d = null;
}
d && (d.filter(":visible"), 0 === d.length && (d = null));
}
return (
d && ((c = d.offset()), (g = c.left + d.outerWidth() / 2), (h = c.top + d.outerHeight() / 2)),
("number" !== a.type(g) || isNaN(g)) && (g = f.cx / 2 + f.x),
("number" !== a.type(h) || isNaN(h)) && (h = f.cy / 2 + f.y),
{ x: g, y: h }
);
},
_reposition: function (a) {
(a = { x: a.x, y: a.y, positionTo: a.positionTo }), this._trigger("beforeposition", c, a), this._ui.container.offset(this._placementCoords(this._desiredCoords(a)));
},
reposition: function (a) {
this._isOpen && this._reposition(a);
},
_safelyBlur: function (b) {
b !== this.window[0] && "body" !== b.nodeName.toLowerCase() && a(b).blur();
},
_openPrerequisitesComplete: function () {
var b = this.element.attr("id"),
c = this._ui.container.find(":focusable").first();
this._ui.container.addClass("ui-popup-active"),
(this._isOpen = !0),
this._resizeScreen(),
a.contains(this._ui.container[0], this.document[0].activeElement) || this._safelyBlur(this.document[0].activeElement),
c.length > 0 && (this._ui.focusElement = c),
this._ignoreResizeEvents(),
b && this.document.find("[aria-haspopup='true'][aria-owns='" + b + "']").attr("aria-expanded", !0),
this._trigger("afteropen");
},
_open: function (b) {
var c = a.extend({}, this.options, b),
d = (function () {
var a = navigator.userAgent,
b = a.match(/AppleWebKit\/([0-9\.]+)/),
c = !!b && b[1],
d = a.match(/Android (\d+(?:\.\d+))/),
e = !!d && d[1],
f = a.indexOf("Chrome") > -1;
return null !== d && "4.0" === e && c && c > 534.13 && !f ? !0 : !1;
})();
this._createPrerequisites(a.noop, a.noop, a.proxy(this, "_openPrerequisitesComplete")),
(this._currentTransition = c.transition),
this._applyTransition(c.transition),
this._ui.screen.removeClass("ui-screen-hidden"),
this._ui.container.removeClass("ui-popup-truncate"),
this._reposition(c),
this._ui.container.removeClass("ui-popup-hidden"),
this.options.overlayTheme && d && this.element.closest(".ui-page").addClass("ui-popup-open"),
this._animate({
additionalCondition: !0,
transition: c.transition,
classToRemove: "",
screenClassToAdd: "in",
containerClassToAdd: "in",
applyTransition: !1,
prerequisites: this._prerequisites,
});
},
_closePrerequisiteScreen: function () {
this._ui.screen.removeClass("out").addClass("ui-screen-hidden");
},
_closePrerequisiteContainer: function () {
this._ui.container.removeClass("reverse out").addClass("ui-popup-hidden ui-popup-truncate").removeAttr("style");
},
_closePrerequisitesDone: function () {
var b = this._ui.container,
d = this.element.attr("id");
(a.mobile.popup.active = c),
a(":focus", b[0]).add(b[0]).blur(),
d && this.document.find("[aria-haspopup='true'][aria-owns='" + d + "']").attr("aria-expanded", !1),
this._trigger("afterclose");
},
_close: function (b) {
this._ui.container.removeClass("ui-popup-active"),
this._page.removeClass("ui-popup-open"),
(this._isOpen = !1),
this._createPrerequisites(a.proxy(this, "_closePrerequisiteScreen"), a.proxy(this, "_closePrerequisiteContainer"), a.proxy(this, "_closePrerequisitesDone")),
this._animate({
additionalCondition: this._ui.screen.hasClass("in"),
transition: b ? "none" : this._currentTransition,
classToRemove: "in",
screenClassToAdd: "out",
containerClassToAdd: "reverse out",
applyTransition: !0,
prerequisites: this._prerequisites,
});
},
_unenhance: function () {
this.options.enhanced ||
(this._setOptions({ theme: a.mobile.popup.prototype.options.theme }),
this.element.detach().insertAfter(this._ui.placeholder).removeClass("ui-popup ui-overlay-shadow ui-corner-all ui-body-inherit"),
this._ui.screen.remove(),
this._ui.container.remove(),
this._ui.placeholder.remove());
},
_destroy: function () {
return a.mobile.popup.active === this ? (this.element.one("popupafterclose", a.proxy(this, "_unenhance")), this.close()) : this._unenhance(), this;
},
_closePopup: function (c, d) {
var e,
f,
g = this.options,
h = !1;
(c && c.isDefaultPrevented()) ||
a.mobile.popup.active !== this ||
(b.scrollTo(0, this._scrollTop),
c &&
"pagebeforechange" === c.type &&
d &&
((e = "string" == typeof d.toPage ? d.toPage : d.toPage.jqmData("url")),
(e = a.mobile.path.parseUrl(e)),
(f = e.pathname + e.search + e.hash),
this._myUrl !== a.mobile.path.makeUrlAbsolute(f) ? (h = !0) : c.preventDefault()),
this.window.off(g.closeEvents),
this.element.undelegate(g.closeLinkSelector, g.closeLinkEvents),
this._close(h));
},
_bindContainerClose: function () {
this.window.on(this.options.closeEvents, a.proxy(this, "_closePopup"));
},
widget: function () {
return this._ui.container;
},
open: function (b) {
var c,
d,
e,
f,
g,
h,
i = this,
j = this.options;
return a.mobile.popup.active || j.disabled
? this
: ((a.mobile.popup.active = this),
(this._scrollTop = this.window.scrollTop()),
j.history
? ((h = a.mobile.navigate.history),
(d = a.mobile.dialogHashKey),
(e = a.mobile.activePage),
(f = e ? e.hasClass("ui-dialog") : !1),
(this._myUrl = c = h.getActive().url),
(g = c.indexOf(d) > -1 && !f && h.activeIndex > 0)
? (i._open(b), i._bindContainerClose(), this)
: (-1 !== c.indexOf(d) || f ? (c = a.mobile.path.parseLocation().hash + d) : (c += c.indexOf("#") > -1 ? d : "#" + d),
this.window.one("beforenavigate", function (a) {
a.preventDefault(), i._open(b), i._bindContainerClose();
}),
(this.urlAltered = !0),
a.mobile.navigate(c, { role: "dialog" }),
this))
: (i._open(b),
i._bindContainerClose(),
i.element.delegate(j.closeLinkSelector, j.closeLinkEvents, function (a) {
i.close(), a.preventDefault();
}),
this));
},
close: function () {
return a.mobile.popup.active !== this
? this
: ((this._scrollTop = this.window.scrollTop()), this.options.history && this.urlAltered ? (a.mobile.back(), (this.urlAltered = !1)) : this._closePopup(), this);
},
}),
(a.mobile.popup.handleLink = function (b) {
var c,
d = a.mobile.path,
e = a(d.hashToSelector(d.parseUrl(b.attr("href")).hash)).first();
e.length > 0 &&
e.data("mobile-popup") &&
((c = b.offset()), e.popup("open", { x: c.left + b.outerWidth() / 2, y: c.top + b.outerHeight() / 2, transition: b.jqmData("transition"), positionTo: b.jqmData("position-to") })),
setTimeout(function () {
b.removeClass(a.mobile.activeBtnClass);
}, 300);
}),
a.mobile.document.on("pagebeforechange", function (b, c) {
"popup" === c.options.role && (a.mobile.popup.handleLink(c.options.link), b.preventDefault());
});
})(a),
(function (a, b) {
var d = ".ui-disabled,.ui-state-disabled,.ui-li-divider,.ui-screen-hidden,:jqmData(role='placeholder')",
e = function (a, b, c) {
var e = a[c + "All"]().not(d).first();
e.length && (b.blur().attr("tabindex", "-1"), e.find("a").first().focus());
};
a.widget("mobile.selectmenu", a.mobile.selectmenu, {
_create: function () {
var a = this.options;
return (a.nativeMenu = a.nativeMenu || this.element.parents(":jqmData(role='popup'),:mobile-popup").length > 0), this._super();
},
_handleSelectFocus: function () {
this.element.blur(), this.button.focus();
},
_handleKeydown: function (a) {
this._super(a), this._handleButtonVclickKeydown(a);
},
_handleButtonVclickKeydown: function (b) {
this.options.disabled ||
this.isOpen ||
this.options.nativeMenu ||
(("vclick" === b.type || (b.keyCode && (b.keyCode === a.mobile.keyCode.ENTER || b.keyCode === a.mobile.keyCode.SPACE))) &&
(this._decideFormat(),
"overlay" === this.menuType
? this.button.attr("href", "#" + this.popupId).attr("data-" + (a.mobile.ns || "") + "rel", "popup")
: this.button.attr("href", "#" + this.dialogId).attr("data-" + (a.mobile.ns || "") + "rel", "dialog"),
(this.isOpen = !0)));
},
_handleListFocus: function (b) {
var c = "focusin" === b.type ? { tabindex: "0", event: "vmouseover" } : { tabindex: "-1", event: "vmouseout" };
a(b.target).attr("tabindex", c.tabindex).trigger(c.event);
},
_handleListKeydown: function (b) {
var c = a(b.target),
d = c.closest("li");
switch (b.keyCode) {
case 38:
return e(d, c, "prev"), !1;
case 40:
return e(d, c, "next"), !1;
case 13:
case 32:
return c.trigger("click"), !1;
}
},
_handleMenuPageHide: function () {
this._delayedTrigger(), this.thisPage.page("bindRemove");
},
_handleHeaderCloseClick: function () {
return "overlay" === this.menuType ? (this.close(), !1) : void 0;
},
_handleListItemClick: function (b) {
var c = a(b.target).closest("li"),
d = this.select[0].selectedIndex,
e = a.mobile.getAttribute(c, "option-index"),
f = this._selectOptions().eq(e)[0];
(f.selected = this.isMultiple ? !f.selected : !0),
this.isMultiple && c.find("a").toggleClass("ui-checkbox-on", f.selected).toggleClass("ui-checkbox-off", !f.selected),
this.isMultiple || d === e || (this._triggerChange = !0),
this.isMultiple ? (this.select.trigger("change"), this.list.find("li:not(.ui-li-divider)").eq(e).find("a").first().focus()) : this.close(),
b.preventDefault();
},
build: function () {
var c,
d,
e,
f,
g,
h,
i,
j,
k,
l,
m,
n,
o,
p,
q,
r,
s,
t,
u,
v = this.options;
return v.nativeMenu
? this._super()
: ((c = this.selectId),
(d = c + "-listbox"),
(e = c + "-dialog"),
(f = this.label),
(g = this.element.closest(".ui-page")),
(h = this.element[0].multiple),
(i = c + "-menu"),
(j = v.theme ? " data-" + a.mobile.ns + "theme='" + v.theme + "'" : ""),
(k = v.overlayTheme || v.theme || null),
(l = k ? " data-" + a.mobile.ns + "overlay-theme='" + k + "'" : ""),
(m = v.dividerTheme && h ? " data-" + a.mobile.ns + "divider-theme='" + v.dividerTheme + "'" : ""),
(n = a(
"<div data-" +
a.mobile.ns +
"role='dialog' class='ui-selectmenu' id='" +
e +
"'" +
j +
l +
"><div data-" +
a.mobile.ns +
"role='header'><div class='ui-title'></div></div><div data-" +
a.mobile.ns +
"role='content'></div></div>"
)),
(o = a("<div" + j + l + " id='" + d + "' class='ui-selectmenu'></div>")
.insertAfter(this.select)
.popup()),
(p = a("<ul class='ui-selectmenu-list' id='" + i + "' role='listbox' aria-labelledby='" + this.buttonId + "'" + j + m + "></ul>").appendTo(o)),
(q = a("<div class='ui-header ui-bar-" + (v.theme ? v.theme : "inherit") + "'></div>").prependTo(o)),
(r = a("<h1 class='ui-title'></h1>").appendTo(q)),
this.isMultiple && (u = a("<a>", { role: "button", text: v.closeText, href: "#", class: "ui-btn ui-corner-all ui-btn-left ui-btn-icon-notext ui-icon-delete" }).appendTo(q)),
a.extend(this, {
selectId: c,
menuId: i,
popupId: d,
dialogId: e,
thisPage: g,
menuPage: n,
label: f,
isMultiple: h,
theme: v.theme,
listbox: o,
list: p,
header: q,
headerTitle: r,
headerClose: u,
menuPageContent: s,
menuPageClose: t,
placeholder: "",
}),
this.refresh(),
this._origTabIndex === b && (this._origTabIndex = null === this.select[0].getAttribute("tabindex") ? !1 : this.select.attr("tabindex")),
this.select.attr("tabindex", "-1"),
this._on(this.select, { focus: "_handleSelectFocus" }),
this._on(this.button, { vclick: "_handleButtonVclickKeydown" }),
this.list.attr("role", "listbox"),
this._on(this.list, {
focusin: "_handleListFocus",
focusout: "_handleListFocus",
keydown: "_handleListKeydown",
"click li:not(.ui-disabled,.ui-state-disabled,.ui-li-divider)": "_handleListItemClick",
}),
this._on(this.menuPage, { pagehide: "_handleMenuPageHide" }),
this._on(this.listbox, { popupafterclose: "_popupClosed" }),
this.isMultiple && this._on(this.headerClose, { click: "_handleHeaderCloseClick" }),
this);
},
_popupClosed: function () {
this.close(), this._delayedTrigger();
},
_delayedTrigger: function () {
this._triggerChange && this.element.trigger("change"), (this._triggerChange = !1);
},
_isRebuildRequired: function () {
var a = this.list.find("li"),
b = this._selectOptions().not(".ui-screen-hidden");
return b.text() !== a.text();
},
selected: function () {
return this._selectOptions().filter(":selected:not( :jqmData(placeholder='true') )");
},
refresh: function (b) {
var c, d;
return this.options.nativeMenu
? this._super(b)
: ((c = this),
(b || this._isRebuildRequired()) && c._buildList(),
(d = this.selectedIndices()),
c.setButtonText(),
c.setButtonCount(),
void c.list
.find("li:not(.ui-li-divider)")
.find("a")
.removeClass(a.mobile.activeBtnClass)
.end()
.attr("aria-selected", !1)
.each(function (b) {
var e = a(this);
a.inArray(b, d) > -1
? (e.attr("aria-selected", !0),
c.isMultiple
? e.find("a").removeClass("ui-checkbox-off").addClass("ui-checkbox-on")
: e.hasClass("ui-screen-hidden")
? e.next().find("a").addClass(a.mobile.activeBtnClass)
: e.find("a").addClass(a.mobile.activeBtnClass))
: c.isMultiple && e.find("a").removeClass("ui-checkbox-on").addClass("ui-checkbox-off");
}));
},
close: function () {
if (!this.options.disabled && this.isOpen) {
var a = this;
"page" === a.menuType ? (a.menuPage.dialog("close"), a.list.appendTo(a.listbox)) : a.listbox.popup("close"), a._focusButton(), (a.isOpen = !1);
}
},
open: function () {
this.button.click();
},
_focusMenuItem: function () {
var b = this.list.find("a." + a.mobile.activeBtnClass);
0 === b.length && (b = this.list.find("li:not(" + d + ") a.ui-btn")), b.first().focus();
},
_decideFormat: function () {
var b = this,
c = this.window,
d = b.list.parent(),
e = d.outerHeight(),
f = c.scrollTop(),
g = b.button.offset().top,
h = c.height();
e > h - 80 || !a.support.scrollTop
? (b.menuPage.appendTo(a.mobile.pageContainer).page(),
(b.menuPageContent = b.menuPage.find(".ui-content")),
(b.menuPageClose = b.menuPage.find(".ui-header a")),
b.thisPage.unbind("pagehide.remove"),
0 === f &&
g > h &&
b.thisPage.one("pagehide", function () {
a(this).jqmData("lastScroll", g);
}),
b.menuPage.one({ pageshow: a.proxy(this, "_focusMenuItem"), pagehide: a.proxy(this, "close") }),
(b.menuType = "page"),
b.menuPageContent.append(b.list),
b.menuPage.find("div .ui-title").text(b.label.getEncodedText() || b.placeholder))
: ((b.menuType = "overlay"), b.listbox.one({ popupafteropen: a.proxy(this, "_focusMenuItem") }));
},
_buildList: function () {
var b,
d,
e,
f,
g,
h,
i,
j,
k,
l,
m,
n,
o,
p,
q = this,
r = this.options,
s = this.placeholder,
t = !0,
u = "false",
v = "data-" + a.mobile.ns,
w = v + "option-index",
x = v + "icon",
y = v + "role",
z = v + "placeholder",
A = c.createDocumentFragment(),
B = !1;
for (q.list.empty().filter(".ui-listview").listview("destroy"), b = this._selectOptions(), d = b.length, e = this.select[0], g = 0; d > g; g++, B = !1)
(h = b[g]),
(i = a(h)),
i.hasClass("ui-screen-hidden") ||
((j = h.parentNode),
(m = []),
(k = i.text()),
(l = c.createElement("a")),
l.setAttribute("href", "#"),
l.appendChild(c.createTextNode(k)),
j !== e &&
"optgroup" === j.nodeName.toLowerCase() &&
((n = j.getAttribute("label")),
n !== f &&
((o = c.createElement("li")),
o.setAttribute(y, "list-divider"),
o.setAttribute("role", "option"),
o.setAttribute("tabindex", "-1"),
o.appendChild(c.createTextNode(n)),
A.appendChild(o),
(f = n))),
!t ||
(h.getAttribute("value") && 0 !== k.length && !i.jqmData("placeholder")) ||
((t = !1),
(B = !0),
null === h.getAttribute(z) && (this._removePlaceholderAttr = !0),
h.setAttribute(z, !0),
r.hidePlaceholderMenuItems && m.push("ui-screen-hidden"),
s !== k && (s = q.placeholder = k)),
(p = c.createElement("li")),
h.disabled && (m.push("ui-state-disabled"), p.setAttribute("aria-disabled", !0)),
p.setAttribute(w, g),
p.setAttribute(x, u),
B && p.setAttribute(z, !0),
(p.className = m.join(" ")),
p.setAttribute("role", "option"),
l.setAttribute("tabindex", "-1"),
this.isMultiple && a(l).addClass("ui-btn ui-checkbox-off ui-btn-icon-right"),
p.appendChild(l),
A.appendChild(p));
q.list[0].appendChild(A), this.isMultiple || s.length ? this.headerTitle.text(this.placeholder) : this.header.addClass("ui-screen-hidden"), q.list.listview();
},
_button: function () {
return this.options.nativeMenu ? this._super() : a("<a>", { href: "#", role: "button", id: this.buttonId, "aria-haspopup": "true", "aria-owns": this.menuId });
},
_destroy: function () {
this.options.nativeMenu ||
(this.close(),
this._origTabIndex !== b && (this._origTabIndex !== !1 ? this.select.attr("tabindex", this._origTabIndex) : this.select.removeAttr("tabindex")),
this._removePlaceholderAttr && this._selectOptions().removeAttr("data-" + a.mobile.ns + "placeholder"),
this.listbox.remove(),
this.menuPage.remove()),
this._super();
},
});
})(a),
(function (a, b) {
function c(a, b) {
var c = b ? b : [];
return (
c.push("ui-btn"),
a.theme && c.push("ui-btn-" + a.theme),
a.icon && ((c = c.concat(["ui-icon-" + a.icon, "ui-btn-icon-" + a.iconpos])), a.iconshadow && c.push("ui-shadow-icon")),
a.inline && c.push("ui-btn-inline"),
a.shadow && c.push("ui-shadow"),
a.corners && c.push("ui-corner-all"),
a.mini && c.push("ui-mini"),
c
);
}
function d(a) {
var c,
d,
e,
g = !1,
h = !0,
i = { icon: "", inline: !1, shadow: !1, corners: !1, iconshadow: !1, mini: !1 },
j = [];
for (a = a.split(" "), c = 0; c < a.length; c++)
(e = !0),
(d = f[a[c]]),
d !== b
? ((e = !1), (i[d] = !0))
: 0 === a[c].indexOf("ui-btn-icon-")
? ((e = !1), (h = !1), (i.iconpos = a[c].substring(12)))
: 0 === a[c].indexOf("ui-icon-")
? ((e = !1), (i.icon = a[c].substring(8)))
: 0 === a[c].indexOf("ui-btn-") && 8 === a[c].length
? ((e = !1), (i.theme = a[c].substring(7)))
: "ui-btn" === a[c] && ((e = !1), (g = !0)),
e && j.push(a[c]);
return h && (i.icon = ""), { options: i, unknownClasses: j, alreadyEnhanced: g };
}
function e(a) {
return "-" + a.toLowerCase();
}
var f = { "ui-shadow": "shadow", "ui-corner-all": "corners", "ui-btn-inline": "inline", "ui-shadow-icon": "iconshadow", "ui-mini": "mini" },
g = function () {
var c = a.mobile.getAttribute.apply(this, arguments);
return null == c ? b : c;
},
h = /[A-Z]/g;
(a.fn.buttonMarkup = function (f, i) {
var j,
k,
l,
m,
n,
o = a.fn.buttonMarkup.defaults;
for (j = 0; j < this.length; j++) {
if (((l = this[j]), (k = i ? { alreadyEnhanced: !1, unknownClasses: [] } : d(l.className)), (m = a.extend({}, k.alreadyEnhanced ? k.options : {}, f)), !k.alreadyEnhanced))
for (n in o) m[n] === b && (m[n] = g(l, n.replace(h, e)));
(l.className = c(a.extend({}, o, m), k.unknownClasses).join(" ")), "button" !== l.tagName.toLowerCase() && l.setAttribute("role", "button");
}
return this;
}),
(a.fn.buttonMarkup.defaults = { icon: "", iconpos: "left", theme: null, inline: !1, shadow: !0, corners: !0, iconshadow: !1, mini: !1 }),
a.extend(a.fn.buttonMarkup, { initSelector: "a:jqmData(role='button'), .ui-bar > a, .ui-bar > :jqmData(role='controlgroup') > a, button:not(:jqmData(role='navbar') button)" });
})(a),
(function (a, b) {
a.widget(
"mobile.controlgroup",
a.extend(
{
options: { enhanced: !1, theme: null, shadow: !1, corners: !0, excludeInvisible: !0, type: "vertical", mini: !1 },
_create: function () {
var b = this.element,
c = this.options,
d = a.mobile.page.prototype.keepNativeSelector();
a.fn.buttonMarkup && this.element.find(a.fn.buttonMarkup.initSelector).not(d).buttonMarkup(),
a.each(
this._childWidgets,
a.proxy(function (b, c) {
a.mobile[c] && this.element.find(a.mobile[c].initSelector).not(d)[c]();
}, this)
),
a.extend(this, { _ui: null, _initialRefresh: !0 }),
(this._ui = c.enhanced ? { groupLegend: b.children(".ui-controlgroup-label").children(), childWrapper: b.children(".ui-controlgroup-controls") } : this._enhance());
},
_childWidgets: ["checkboxradio", "selectmenu", "button"],
_themeClassFromOption: function (a) {
return a ? ("none" === a ? "" : "ui-group-theme-" + a) : "";
},
_enhance: function () {
var b = this.element,
c = this.options,
d = {
groupLegend: b.children("legend"),
childWrapper: b
.addClass(
"ui-controlgroup ui-controlgroup-" +
("horizontal" === c.type ? "horizontal" : "vertical") +
" " +
this._themeClassFromOption(c.theme) +
" " +
(c.corners ? "ui-corner-all " : "") +
(c.mini ? "ui-mini " : "")
)
.wrapInner("<div class='ui-controlgroup-controls " + (c.shadow === !0 ? "ui-shadow" : "") + "'></div>")
.children(),
};
return d.groupLegend.length > 0 && a("<div role='heading' class='ui-controlgroup-label'></div>").append(d.groupLegend).prependTo(b), d;
},
_init: function () {
this.refresh();
},
_setOptions: function (a) {
var c,
d,
e = this.element;
return (
a.type !== b && (e.removeClass("ui-controlgroup-horizontal ui-controlgroup-vertical").addClass("ui-controlgroup-" + ("horizontal" === a.type ? "horizontal" : "vertical")), (c = !0)),
a.theme !== b && e.removeClass(this._themeClassFromOption(this.options.theme)).addClass(this._themeClassFromOption(a.theme)),
a.corners !== b && e.toggleClass("ui-corner-all", a.corners),
a.mini !== b && e.toggleClass("ui-mini", a.mini),
a.shadow !== b && this._ui.childWrapper.toggleClass("ui-shadow", a.shadow),
a.excludeInvisible !== b && ((this.options.excludeInvisible = a.excludeInvisible), (c = !0)),
(d = this._super(a)),
c && this.refresh(),
d
);
},
container: function () {
return this._ui.childWrapper;
},
refresh: function () {
var b = this.container(),
c = b.find(".ui-btn").not(".ui-slider-handle"),
d = this._initialRefresh;
a.mobile.checkboxradio && b.find(":mobile-checkboxradio").checkboxradio("refresh"),
this._addFirstLastClasses(c, this.options.excludeInvisible ? this._getVisibles(c, d) : c, d),
(this._initialRefresh = !1);
},
_destroy: function () {
var a,
b,
c = this.options;
return c.enhanced
? this
: ((a = this._ui),
(b = this.element
.removeClass("ui-controlgroup ui-controlgroup-horizontal ui-controlgroup-vertical ui-corner-all ui-mini " + this._themeClassFromOption(c.theme))
.find(".ui-btn")
.not(".ui-slider-handle")),
this._removeFirstLastClasses(b),
a.groupLegend.unwrap(),
void a.childWrapper.children().unwrap());
},
},
a.mobile.behaviors.addFirstLastClasses
)
);
})(a),
(function (a, b) {
a.widget("mobile.toolbar", {
initSelector: ":jqmData(role='footer'), :jqmData(role='header')",
options: { theme: null, addBackBtn: !1, backBtnTheme: null, backBtnText: "Back" },
_create: function () {
var b,
c,
d = this.element.is(":jqmData(role='header')") ? "header" : "footer",
e = this.element.closest(".ui-page");
0 === e.length && ((e = !1), this._on(this.document, { pageshow: "refresh" })),
a.extend(this, { role: d, page: e, leftbtn: b, rightbtn: c }),
this.element.attr("role", "header" === d ? "banner" : "contentinfo").addClass("ui-" + d),
this.refresh(),
this._setOptions(this.options);
},
_setOptions: function (a) {
if (
(a.addBackBtn !== b && this._updateBackButton(),
null != a.backBtnTheme && this.element.find(".ui-toolbar-back-btn").addClass("ui-btn ui-btn-" + a.backBtnTheme),
a.backBtnText !== b && this.element.find(".ui-toolbar-back-btn .ui-btn-text").text(a.backBtnText),
a.theme !== b)
) {
var c = this.options.theme ? this.options.theme : "inherit",
d = a.theme ? a.theme : "inherit";
this.element.removeClass("ui-bar-" + c).addClass("ui-bar-" + d);
}
this._super(a);
},
refresh: function () {
"header" === this.role && this._addHeaderButtonClasses(),
this.page || (this._setRelative(), "footer" === this.role ? this.element.appendTo("body") : "header" === this.role && this._updateBackButton()),
this._addHeadingClasses(),
this._btnMarkup();
},
_setRelative: function () {
a("[data-" + a.mobile.ns + "role='page']").css({ position: "relative" });
},
_btnMarkup: function () {
this.element
.children("a")
.filter(":not([data-" + a.mobile.ns + "role='none'])")
.attr("data-" + a.mobile.ns + "role", "button"),
this.element.trigger("create");
},
_addHeaderButtonClasses: function () {
var a = this.element.children("a, button");
(this.leftbtn = a.hasClass("ui-btn-left") && !a.hasClass("ui-toolbar-back-btn")),
(this.rightbtn = a.hasClass("ui-btn-right")),
(this.leftbtn = this.leftbtn || a.eq(0).not(".ui-btn-right,.ui-toolbar-back-btn").addClass("ui-btn-left").length),
(this.rightbtn = this.rightbtn || a.eq(1).addClass("ui-btn-right").length);
},
_updateBackButton: function () {
var b,
c = this.options,
d = c.backBtnTheme || c.theme;
(b = this._backButton = this._backButton || {}),
this.options.addBackBtn &&
"header" === this.role &&
a(".ui-page").length > 1 &&
(this.page
? this.page[0].getAttribute("data-" + a.mobile.ns + "url") !== a.mobile.path.stripHash(location.hash)
: a.mobile.navigate && a.mobile.navigate.history && a.mobile.navigate.history.activeIndex > 0) &&
!this.leftbtn
? b.attached ||
((this.backButton = b.element =
(
b.element ||
a(
"<a role='button' href='javascript:void(0);' class='ui-btn ui-corner-all ui-shadow ui-btn-left " +
(d ? "ui-btn-" + d + " " : "") +
"ui-toolbar-back-btn ui-icon-carat-l ui-btn-icon-left' data-" +
a.mobile.ns +
"rel='back'>" +
c.backBtnText +
"</a>"
)
).prependTo(this.element)),
(b.attached = !0))
: b.element && (b.element.detach(), (b.attached = !1));
},
_addHeadingClasses: function () {
this.element.children("h1, h2, h3, h4, h5, h6").addClass("ui-title").attr({ role: "heading", "aria-level": "1" });
},
_destroy: function () {
var a;
this.element.children("h1, h2, h3, h4, h5, h6").removeClass("ui-title").removeAttr("role").removeAttr("aria-level"),
"header" === this.role && (this.element.children("a, button").removeClass("ui-btn-left ui-btn-right ui-btn ui-shadow ui-corner-all"), this.backButton && this.backButton.remove()),
(a = this.options.theme ? this.options.theme : "inherit"),
this.element.removeClass("ui-bar-" + a),
this.element.removeClass("ui-" + this.role).removeAttr("role");
},
});
})(a),
(function (a, b) {
a.widget("mobile.toolbar", a.mobile.toolbar, {
options: {
position: null,
visibleOnPageShow: !0,
disablePageZoom: !0,
transition: "slide",
fullscreen: !1,
tapToggle: !0,
tapToggleBlacklist: "a, button, input, select, textarea, .ui-header-fixed, .ui-footer-fixed, .ui-flipswitch, .ui-popup, .ui-panel, .ui-panel-dismiss-open",
hideDuringFocus: "input, textarea, select",
updatePagePadding: !0,
trackPersistentToolbars: !0,
supportBlacklist: function () {
return !a.support.fixedPosition;
},
},
_create: function () {
this._super(), (this.pagecontainer = a(":mobile-pagecontainer")), "fixed" !== this.options.position || this.options.supportBlacklist() || this._makeFixed();
},
_makeFixed: function () {
this.element.addClass("ui-" + this.role + "-fixed"), this.updatePagePadding(), this._addTransitionClass(), this._bindPageEvents(), this._bindToggleHandlers();
},
_setOptions: function (c) {
if (("fixed" === c.position && "fixed" !== this.options.position && this._makeFixed(), "fixed" === this.options.position && !this.options.supportBlacklist())) {
var d = this.page ? this.page : a(".ui-page-active").length > 0 ? a(".ui-page-active") : a(".ui-page").eq(0);
c.fullscreen !== b &&
(c.fullscreen
? (this.element.addClass("ui-" + this.role + "-fullscreen"), d.addClass("ui-page-" + this.role + "-fullscreen"))
: (this.element.removeClass("ui-" + this.role + "-fullscreen"), d.removeClass("ui-page-" + this.role + "-fullscreen").addClass("ui-page-" + this.role + "-fixed")));
}
this._super(c);
},
_addTransitionClass: function () {
var a = this.options.transition;
a && "none" !== a && ("slide" === a && (a = this.element.hasClass("ui-header") ? "slidedown" : "slideup"), this.element.addClass(a));
},
_bindPageEvents: function () {
var a = this.page ? this.element.closest(".ui-page") : this.document;
this._on(a, {
pagebeforeshow: "_handlePageBeforeShow",
webkitAnimationStart: "_handleAnimationStart",
animationstart: "_handleAnimationStart",
updatelayout: "_handleAnimationStart",
pageshow: "_handlePageShow",
pagebeforehide: "_handlePageBeforeHide",
});
},
_handlePageBeforeShow: function () {
var b = this.options;
b.disablePageZoom && a.mobile.zoom.disable(!0), b.visibleOnPageShow || this.hide(!0);
},
_handleAnimationStart: function () {
this.options.updatePagePadding && this.updatePagePadding(this.page ? this.page : ".ui-page-active");
},
_handlePageShow: function () {
this.updatePagePadding(this.page ? this.page : ".ui-page-active"), this.options.updatePagePadding && this._on(this.window, { throttledresize: "updatePagePadding" });
},
_handlePageBeforeHide: function (b, c) {
var d,
e,
f,
g,
h = this.options;
h.disablePageZoom && a.mobile.zoom.enable(!0),
h.updatePagePadding && this._off(this.window, "throttledresize"),
h.trackPersistentToolbars &&
((d = a(".ui-footer-fixed:jqmData(id)", this.page)),
(e = a(".ui-header-fixed:jqmData(id)", this.page)),
(f = (d.length && c.nextPage && a(".ui-footer-fixed:jqmData(id='" + d.jqmData("id") + "')", c.nextPage)) || a()),
(g = (e.length && c.nextPage && a(".ui-header-fixed:jqmData(id='" + e.jqmData("id") + "')", c.nextPage)) || a()),
(f.length || g.length) &&
(f.add(g).appendTo(a.mobile.pageContainer),
c.nextPage.one("pageshow", function () {
g.prependTo(this), f.appendTo(this);
})));
},
_visible: !0,
updatePagePadding: function (c) {
var d = this.element,
e = "header" === this.role,
f = parseFloat(d.css(e ? "top" : "bottom"));
this.options.fullscreen ||
((c = (c && c.type === b && c) || this.page || d.closest(".ui-page")), (c = this.page ? this.page : ".ui-page-active"), a(c).css("padding-" + (e ? "top" : "bottom"), d.outerHeight() + f));
},
_useTransition: function (b) {
var c = this.window,
d = this.element,
e = c.scrollTop(),
f = d.height(),
g = this.page ? d.closest(".ui-page").height() : a(".ui-page-active").height(),
h = a.mobile.getScreenHeight();
return (
!b &&
((this.options.transition &&
"none" !== this.options.transition &&
(("header" === this.role && !this.options.fullscreen && e > f) || ("footer" === this.role && !this.options.fullscreen && g - f > e + h))) ||
this.options.fullscreen)
);
},
show: function (a) {
var b = "ui-fixed-hidden",
c = this.element;
this._useTransition(a)
? c
.removeClass("out " + b)
.addClass("in")
.animationComplete(function () {
c.removeClass("in");
})
: c.removeClass(b),
(this._visible = !0);
},
hide: function (a) {
var b = "ui-fixed-hidden",
c = this.element,
d = "out" + ("slide" === this.options.transition ? " reverse" : "");
this._useTransition(a)
? c
.addClass(d)
.removeClass("in")
.animationComplete(function () {
c.addClass(b).removeClass(d);
})
: c.addClass(b).removeClass(d),
(this._visible = !1);
},
toggle: function () {
this[this._visible ? "hide" : "show"]();
},
_bindToggleHandlers: function () {
var b,
c,
d = this,
e = d.options,
f = !0,
g = this.page ? this.page : a(".ui-page");
g.bind("vclick", function (b) {
e.tapToggle && !a(b.target).closest(e.tapToggleBlacklist).length && d.toggle();
}).bind("focusin focusout", function (g) {
screen.width < 1025 &&
a(g.target).is(e.hideDuringFocus) &&
!a(g.target).closest(".ui-header-fixed, .ui-footer-fixed").length &&
("focusout" !== g.type || f
? "focusin" === g.type &&
f &&
(clearTimeout(b),
(f = !1),
(c = setTimeout(function () {
d.hide();
}, 0)))
: ((f = !0),
clearTimeout(c),
(b = setTimeout(function () {
d.show();
}, 0))));
});
},
_setRelative: function () {
"fixed" !== this.options.position && a("[data-" + a.mobile.ns + "role='page']").css({ position: "relative" });
},
_destroy: function () {
var b,
c,
d,
e,
f,
g = this.pagecontainer.pagecontainer("getActivePage");
this._super(),
"fixed" === this.options.position &&
((d =
a("body>.ui-" + this.role + "-fixed")
.add(g.find(".ui-" + this.options.role + "-fixed"))
.not(this.element).length > 0),
(f =
a("body>.ui-" + this.role + "-fixed")
.add(g.find(".ui-" + this.options.role + "-fullscreen"))
.not(this.element).length > 0),
(c = "ui-header-fixed ui-footer-fixed ui-header-fullscreen in out ui-footer-fullscreen fade slidedown slideup ui-fixed-hidden"),
this.element.removeClass(c),
f || (b = "ui-page-" + this.role + "-fullscreen"),
d || ((e = "header" === this.role), (b += " ui-page-" + this.role + "-fixed"), g.css("padding-" + (e ? "top" : "bottom"), "")),
g.removeClass(b));
},
});
})(a),
(function (a) {
a.widget("mobile.toolbar", a.mobile.toolbar, {
_makeFixed: function () {
this._super(), this._workarounds();
},
_workarounds: function () {
var a = navigator.userAgent,
b = navigator.platform,
c = a.match(/AppleWebKit\/([0-9]+)/),
d = !!c && c[1],
e = null,
f = this;
if (b.indexOf("iPhone") > -1 || b.indexOf("iPad") > -1 || b.indexOf("iPod") > -1) e = "ios";
else {
if (!(a.indexOf("Android") > -1)) return;
e = "android";
}
if ("ios" === e) f._bindScrollWorkaround();
else {
if (!("android" === e && d && 534 > d)) return;
f._bindScrollWorkaround(), f._bindListThumbWorkaround();
}
},
_viewportOffset: function () {
var a = this.element,
b = a.hasClass("ui-header"),
c = Math.abs(a.offset().top - this.window.scrollTop());
return b || (c = Math.round(c - this.window.height() + a.outerHeight()) - 60), c;
},
_bindScrollWorkaround: function () {
var a = this;
this._on(this.window, {
scrollstop: function () {
var b = a._viewportOffset();
b > 2 && a._visible && a._triggerRedraw();
},
});
},
_bindListThumbWorkaround: function () {
this.element.closest(".ui-page").addClass("ui-android-2x-fixed");
},
_triggerRedraw: function () {
var b = parseFloat(a(".ui-page-active").css("padding-bottom"));
a(".ui-page-active").css("padding-bottom", b + 1 + "px"),
setTimeout(function () {
a(".ui-page-active").css("padding-bottom", b + "px");
}, 0);
},
destroy: function () {
this._super(), this.element.closest(".ui-page-active").removeClass("ui-android-2x-fix");
},
});
})(a),
(function (a, b) {
function c() {
var a = e.clone(),
b = a.eq(0),
c = a.eq(1),
d = c.children();
return { arEls: c.add(b), gd: b, ct: c, ar: d };
}
var d = a.mobile.browser.oldIE && a.mobile.browser.oldIE <= 8,
e = a("<div class='ui-popup-arrow-guide'></div><div class='ui-popup-arrow-container" + (d ? " ie" : "") + "'><div class='ui-popup-arrow'></div></div>");
a.widget("mobile.popup", a.mobile.popup, {
options: { arrow: "" },
_create: function () {
var a,
b = this._super();
return this.options.arrow && (this._ui.arrow = a = this._addArrow()), b;
},
_addArrow: function () {
var a,
b = this.options,
d = c();
return (a = this._themeClassFromOption("ui-body-", b.theme)), d.ar.addClass(a + (b.shadow ? " ui-overlay-shadow" : "")), d.arEls.hide().appendTo(this.element), d;
},
_unenhance: function () {
var a = this._ui.arrow;
return a && a.arEls.remove(), this._super();
},
_tryAnArrow: function (a, b, c, d, e) {
var f,
g,
h,
i = {},
j = {};
return d.arFull[a.dimKey] > d.guideDims[a.dimKey]
? e
: ((i[a.fst] =
c[a.fst] + (d.arHalf[a.oDimKey] + d.menuHalf[a.oDimKey]) * a.offsetFactor - d.contentBox[a.fst] + (d.clampInfo.menuSize[a.oDimKey] - d.contentBox[a.oDimKey]) * a.arrowOffsetFactor),
(i[a.snd] = c[a.snd]),
(f = d.result || this._calculateFinalLocation(i, d.clampInfo)),
(g = { x: f.left, y: f.top }),
(j[a.fst] = g[a.fst] + d.contentBox[a.fst] + a.tipOffset),
(j[a.snd] = Math.max(f[a.prop] + d.guideOffset[a.prop] + d.arHalf[a.dimKey], Math.min(f[a.prop] + d.guideOffset[a.prop] + d.guideDims[a.dimKey] - d.arHalf[a.dimKey], c[a.snd]))),
(h = Math.abs(c.x - j.x) + Math.abs(c.y - j.y)),
(!e || h < e.diff) && ((j[a.snd] -= d.arHalf[a.dimKey] + f[a.prop] + d.contentBox[a.snd]), (e = { dir: b, diff: h, result: f, posProp: a.prop, posVal: j[a.snd] })),
e);
},
_getPlacementState: function (a) {
var b,
c,
d = this._ui.arrow,
e = { clampInfo: this._clampPopupWidth(!a), arFull: { cx: d.ct.width(), cy: d.ct.height() }, guideDims: { cx: d.gd.width(), cy: d.gd.height() }, guideOffset: d.gd.offset() };
return (
(b = this.element.offset()),
d.gd.css({ left: 0, top: 0, right: 0, bottom: 0 }),
(c = d.gd.offset()),
(e.contentBox = { x: c.left - b.left, y: c.top - b.top, cx: d.gd.width(), cy: d.gd.height() }),
d.gd.removeAttr("style"),
(e.guideOffset = { left: e.guideOffset.left - b.left, top: e.guideOffset.top - b.top }),
(e.arHalf = { cx: e.arFull.cx / 2, cy: e.arFull.cy / 2 }),
(e.menuHalf = { cx: e.clampInfo.menuSize.cx / 2, cy: e.clampInfo.menuSize.cy / 2 }),
e
);
},
_placementCoords: function (b) {
var c,
e,
f,
g,
h,
i = this.options.arrow,
j = this._ui.arrow;
return j
? (j.arEls.show(),
(h = {}),
(c = this._getPlacementState(!0)),
(f = {
l: { fst: "x", snd: "y", prop: "top", dimKey: "cy", oDimKey: "cx", offsetFactor: 1, tipOffset: -c.arHalf.cx, arrowOffsetFactor: 0 },
r: { fst: "x", snd: "y", prop: "top", dimKey: "cy", oDimKey: "cx", offsetFactor: -1, tipOffset: c.arHalf.cx + c.contentBox.cx, arrowOffsetFactor: 1 },
b: { fst: "y", snd: "x", prop: "left", dimKey: "cx", oDimKey: "cy", offsetFactor: -1, tipOffset: c.arHalf.cy + c.contentBox.cy, arrowOffsetFactor: 1 },
t: { fst: "y", snd: "x", prop: "left", dimKey: "cx", oDimKey: "cy", offsetFactor: 1, tipOffset: -c.arHalf.cy, arrowOffsetFactor: 0 },
}),
a.each(
(i === !0 ? "l,t,r,b" : i).split(","),
a.proxy(function (a, d) {
e = this._tryAnArrow(f[d], d, b, c, e);
}, this)
),
e
? (j.ct
.removeClass("ui-popup-arrow-l ui-popup-arrow-t ui-popup-arrow-r ui-popup-arrow-b")
.addClass("ui-popup-arrow-" + e.dir)
.removeAttr("style")
.css(e.posProp, e.posVal)
.show(),
d || ((g = this.element.offset()), (h[f[e.dir].fst] = j.ct.offset()), (h[f[e.dir].snd] = { left: g.left + c.contentBox.x, top: g.top + c.contentBox.y })),
e.result)
: (j.arEls.hide(), this._super(b)))
: this._super(b);
},
_setOptions: function (a) {
var c,
d = this.options.theme,
e = this._ui.arrow,
f = this._super(a);
if (a.arrow !== b) {
if (!e && a.arrow) return void (this._ui.arrow = this._addArrow());
e && !a.arrow && (e.arEls.remove(), (this._ui.arrow = null));
}
return (
(e = this._ui.arrow),
e &&
(a.theme !== b && ((d = this._themeClassFromOption("ui-body-", d)), (c = this._themeClassFromOption("ui-body-", a.theme)), e.ar.removeClass(d).addClass(c)),
a.shadow !== b && e.ar.toggleClass("ui-overlay-shadow", a.shadow)),
f
);
},
_destroy: function () {
var a = this._ui.arrow;
return a && a.arEls.remove(), this._super();
},
});
})(a),
(function (a, c) {
a.widget("mobile.panel", {
options: {
classes: {
panel: "ui-panel",
panelOpen: "ui-panel-open",
panelClosed: "ui-panel-closed",
panelFixed: "ui-panel-fixed",
panelInner: "ui-panel-inner",
modal: "ui-panel-dismiss",
modalOpen: "ui-panel-dismiss-open",
pageContainer: "ui-panel-page-container",
pageWrapper: "ui-panel-wrapper",
pageFixedToolbar: "ui-panel-fixed-toolbar",
pageContentPrefix: "ui-panel-page-content",
animate: "ui-panel-animate",
},
animate: !0,
theme: null,
position: "left",
dismissible: !0,
display: "reveal",
swipeClose: !0,
positionFixed: !1,
},
_closeLink: null,
_parentPage: null,
_page: null,
_modal: null,
_panelInner: null,
_wrapper: null,
_fixedToolbars: null,
_create: function () {
var b = this.element,
c = b.closest(".ui-page, :jqmData(role='page')");
a.extend(this, {
_closeLink: b.find(":jqmData(rel='close')"),
_parentPage: c.length > 0 ? c : !1,
_openedPage: null,
_page: this._getPage,
_panelInner: this._getPanelInner(),
_fixedToolbars: this._getFixedToolbars,
}),
"overlay" !== this.options.display && this._getWrapper(),
this._addPanelClasses(),
a.support.cssTransform3d && this.options.animate && this.element.addClass(this.options.classes.animate),
this._bindUpdateLayout(),
this._bindCloseEvents(),
this._bindLinkListeners(),
this._bindPageEvents(),
this.options.dismissible && this._createModal(),
this._bindSwipeEvents();
},
_getPanelInner: function () {
var a = this.element.find("." + this.options.classes.panelInner);
return (
0 === a.length &&
(a = this.element
.children()
.wrapAll("<div class='" + this.options.classes.panelInner + "' />")
.parent()),
a
);
},
_createModal: function () {
var b = this,
c = b._parentPage ? b._parentPage.parent() : b.element.parent();
b._modal = a("<div class='" + b.options.classes.modal + "'></div>")
.on("mousedown", function () {
b.close();
})
.appendTo(c);
},
_getPage: function () {
var b = this._openedPage || this._parentPage || a("." + a.mobile.activePageClass);
return b;
},
_getWrapper: function () {
var a = this._page().find("." + this.options.classes.pageWrapper);
0 === a.length &&
(a = this._page()
.children(".ui-header:not(.ui-header-fixed), .ui-content:not(.ui-popup), .ui-footer:not(.ui-footer-fixed)")
.wrapAll("<div class='" + this.options.classes.pageWrapper + "'></div>")
.parent()),
(this._wrapper = a);
},
_getFixedToolbars: function () {
var b = a("body").children(".ui-header-fixed, .ui-footer-fixed"),
c = this._page().find(".ui-header-fixed, .ui-footer-fixed"),
d = b.add(c).addClass(this.options.classes.pageFixedToolbar);
return d;
},
_getPosDisplayClasses: function (a) {
return a + "-position-" + this.options.position + " " + a + "-display-" + this.options.display;
},
_getPanelClasses: function () {
var a =
this.options.classes.panel +
" " +
this._getPosDisplayClasses(this.options.classes.panel) +
" " +
this.options.classes.panelClosed +
" ui-body-" +
(this.options.theme ? this.options.theme : "inherit");
return this.options.positionFixed && (a += " " + this.options.classes.panelFixed), a;
},
_addPanelClasses: function () {
this.element.addClass(this._getPanelClasses());
},
_handleCloseClick: function (a) {
a.isDefaultPrevented() || this.close();
},
_bindCloseEvents: function () {
this._on(this._closeLink, { click: "_handleCloseClick" }), this._on({ "click a:jqmData(ajax='false')": "_handleCloseClick" });
},
_positionPanel: function (b) {
var c = this,
d = c._panelInner.outerHeight(),
e = d > a.mobile.getScreenHeight();
e || !c.options.positionFixed ? (e && (c._unfixPanel(), a.mobile.resetActivePageHeight(d)), b && this.window[0].scrollTo(0, a.mobile.defaultHomeScroll)) : c._fixPanel();
},
_bindFixListener: function () {
this._on(a(b), { throttledresize: "_positionPanel" });
},
_unbindFixListener: function () {
this._off(a(b), "throttledresize");
},
_unfixPanel: function () {
this.options.positionFixed && a.support.fixedPosition && this.element.removeClass(this.options.classes.panelFixed);
},
_fixPanel: function () {
this.options.positionFixed && a.support.fixedPosition && this.element.addClass(this.options.classes.panelFixed);
},
_bindUpdateLayout: function () {
var a = this;
a.element.on("updatelayout", function () {
a._open && a._positionPanel();
});
},
_bindLinkListeners: function () {
this._on("body", { "click a": "_handleClick" });
},
_handleClick: function (b) {
var d,
e = this.element.attr("id");
b.currentTarget.href.split("#")[1] === e &&
e !== c &&
(b.preventDefault(),
(d = a(b.target)),
d.hasClass("ui-btn") &&
(d.addClass(a.mobile.activeBtnClass),
this.element.one("panelopen panelclose", function () {
d.removeClass(a.mobile.activeBtnClass);
})),
this.toggle());
},
_bindSwipeEvents: function () {
var a = this,
b = a._modal ? a.element.add(a._modal) : a.element;
a.options.swipeClose &&
("left" === a.options.position
? b.on("swipeleft.panel", function () {
a.close();
})
: b.on("swiperight.panel", function () {
a.close();
}));
},
_bindPageEvents: function () {
var a = this;
this.document
.on("panelbeforeopen", function (b) {
a._open && b.target !== a.element[0] && a.close();
})
.on("keyup.panel", function (b) {
27 === b.keyCode && a._open && a.close();
}),
this._parentPage ||
"overlay" === this.options.display ||
this._on(this.document, {
pageshow: function () {
(this._openedPage = null), this._getWrapper();
},
}),
a._parentPage
? this.document.on("pagehide", ":jqmData(role='page')", function () {
a._open && a.close(!0);
})
: this.document.on("pagebeforehide", function () {
a._open && a.close(!0);
});
},
_open: !1,
_pageContentOpenClasses: null,
_modalOpenClasses: null,
open: function (b) {
if (!this._open) {
var c = this,
d = c.options,
e = function () {
c._off(c.document, "panelclose"),
c._page().jqmData("panel", "open"),
a.support.cssTransform3d && d.animate && "overlay" !== d.display && (c._wrapper.addClass(d.classes.animate), c._fixedToolbars().addClass(d.classes.animate)),
!b && a.support.cssTransform3d && d.animate ? (c._wrapper || c.element).animationComplete(f, "transition") : setTimeout(f, 0),
d.theme &&
"overlay" !== d.display &&
c
._page()
.parent()
.addClass(d.classes.pageContainer + "-themed " + d.classes.pageContainer + "-" + d.theme),
c.element.removeClass(d.classes.panelClosed).addClass(d.classes.panelOpen),
c._positionPanel(!0),
(c._pageContentOpenClasses = c._getPosDisplayClasses(d.classes.pageContentPrefix)),
"overlay" !== d.display &&
(c._page().parent().addClass(d.classes.pageContainer), c._wrapper.addClass(c._pageContentOpenClasses), c._fixedToolbars().addClass(c._pageContentOpenClasses)),
(c._modalOpenClasses = c._getPosDisplayClasses(d.classes.modal) + " " + d.classes.modalOpen),
c._modal && c._modal.addClass(c._modalOpenClasses).height(Math.max(c._modal.height(), c.document.height()));
},
f = function () {
c._open &&
("overlay" !== d.display && (c._wrapper.addClass(d.classes.pageContentPrefix + "-open"), c._fixedToolbars().addClass(d.classes.pageContentPrefix + "-open")),
c._bindFixListener(),
c._trigger("open"),
(c._openedPage = c._page()));
};
c._trigger("beforeopen"), "open" === c._page().jqmData("panel") ? c._on(c.document, { panelclose: e }) : e(), (c._open = !0);
}
},
close: function (b) {
if (this._open) {
var c = this,
d = this.options,
e = function () {
c.element.removeClass(d.classes.panelOpen),
"overlay" !== d.display && (c._wrapper.removeClass(c._pageContentOpenClasses), c._fixedToolbars().removeClass(c._pageContentOpenClasses)),
!b && a.support.cssTransform3d && d.animate ? (c._wrapper || c.element).animationComplete(f, "transition") : setTimeout(f, 0),
c._modal && c._modal.removeClass(c._modalOpenClasses).height("");
},
f = function () {
d.theme &&
"overlay" !== d.display &&
c
._page()
.parent()
.removeClass(d.classes.pageContainer + "-themed " + d.classes.pageContainer + "-" + d.theme),
c.element.addClass(d.classes.panelClosed),
"overlay" !== d.display &&
(c._page().parent().removeClass(d.classes.pageContainer),
c._wrapper.removeClass(d.classes.pageContentPrefix + "-open"),
c._fixedToolbars().removeClass(d.classes.pageContentPrefix + "-open")),
a.support.cssTransform3d && d.animate && "overlay" !== d.display && (c._wrapper.removeClass(d.classes.animate), c._fixedToolbars().removeClass(d.classes.animate)),
c._fixPanel(),
c._unbindFixListener(),
a.mobile.resetActivePageHeight(),
c._page().jqmRemoveData("panel"),
c._trigger("close"),
(c._openedPage = null);
};
c._trigger("beforeclose"), e(), (c._open = !1);
}
},
toggle: function () {
this[this._open ? "close" : "open"]();
},
_destroy: function () {
var b,
c = this.options,
d = a("body > :mobile-panel").length + a.mobile.activePage.find(":mobile-panel").length > 1;
"overlay" !== c.display &&
((b = a("body > :mobile-panel").add(a.mobile.activePage.find(":mobile-panel"))),
0 === b.not(".ui-panel-display-overlay").not(this.element).length && this._wrapper.children().unwrap(),
this._open &&
(this._fixedToolbars().removeClass(c.classes.pageContentPrefix + "-open"),
a.support.cssTransform3d && c.animate && this._fixedToolbars().removeClass(c.classes.animate),
this._page().parent().removeClass(c.classes.pageContainer),
c.theme &&
this._page()
.parent()
.removeClass(c.classes.pageContainer + "-themed " + c.classes.pageContainer + "-" + c.theme))),
d || this.document.off("panelopen panelclose"),
this._open && this._page().jqmRemoveData("panel"),
this._panelInner.children().unwrap(),
this.element
.removeClass([this._getPanelClasses(), c.classes.panelOpen, c.classes.animate].join(" "))
.off("swipeleft.panel swiperight.panel")
.off("panelbeforeopen")
.off("panelhide")
.off("keyup.panel")
.off("updatelayout"),
this._modal && this._modal.remove();
},
});
})(a),
(function (a, b) {
a.widget("mobile.table", {
options: { classes: { table: "ui-table" }, enhanced: !1 },
_create: function () {
this.options.enhanced || this.element.addClass(this.options.classes.table), a.extend(this, { headers: b, allHeaders: b }), this._refresh(!0);
},
_setHeaders: function () {
var a = this.element.find("thead tr");
(this.headers = this.element.find("tr:eq(0)").children()), (this.allHeaders = this.headers.add(a.children()));
},
refresh: function () {
this._refresh();
},
rebuild: a.noop,
_refresh: function () {
var b = this.element,
c = b.find("thead tr");
this._setHeaders(),
c.each(function () {
var d = 0;
a(this)
.children()
.each(function () {
var e,
f = parseInt(this.getAttribute("colspan"), 10),
g = ":nth-child(" + (d + 1) + ")";
if ((this.setAttribute("data-" + a.mobile.ns + "colstart", d + 1), f)) for (e = 0; f - 1 > e; e++) d++, (g += ", :nth-child(" + (d + 1) + ")");
a(this).jqmData("cells", b.find("tr").not(c.eq(0)).not(this).children(g)), d++;
});
});
},
});
})(a),
(function (a) {
a.widget("mobile.table", a.mobile.table, {
options: {
mode: "columntoggle",
columnBtnTheme: null,
columnPopupTheme: null,
columnBtnText: "Columns...",
classes: a.extend(a.mobile.table.prototype.options.classes, {
popup: "ui-table-columntoggle-popup",
columnBtn: "ui-table-columntoggle-btn",
priorityPrefix: "ui-table-priority-",
columnToggleTable: "ui-table-columntoggle",
}),
},
_create: function () {
this._super(),
"columntoggle" === this.options.mode &&
(a.extend(this, { _menu: null }),
this.options.enhanced
? ((this._menu = a(this.document[0].getElementById(this._id() + "-popup"))
.children()
.first()),
this._addToggles(this._menu, !0))
: ((this._menu = this._enhanceColToggle()), this.element.addClass(this.options.classes.columnToggleTable)),
this._setupEvents(),
this._setToggleState());
},
_id: function () {
return this.element.attr("id") || this.widgetName + this.uuid;
},
_setupEvents: function () {
this._on(this.window, { throttledresize: "_setToggleState" }), this._on(this._menu, { "change input": "_menuInputChange" });
},
_addToggles: function (b, c) {
var d,
e = 0,
f = this.options,
g = b.controlgroup("container");
c ? (d = b.find("input")) : g.empty(),
this.headers.not("td").each(function () {
var b,
h,
i = a(this),
j = a.mobile.getAttribute(this, "priority");
j &&
((h = i.add(i.jqmData("cells"))),
h.addClass(f.classes.priorityPrefix + j),
(b = (
c
? d.eq(e++)
: a("<label><input type='checkbox' checked />" + (i.children("abbr").first().attr("title") || i.text()) + "</label>")
.appendTo(g)
.children(0)
.checkboxradio({ theme: f.columnPopupTheme })
)
.jqmData("header", i)
.jqmData("cells", h)),
i.jqmData("input", b));
}),
c || b.controlgroup("refresh");
},
_menuInputChange: function (b) {
var c = a(b.target),
d = c[0].checked;
c.jqmData("cells").toggleClass("ui-table-cell-hidden", !d).toggleClass("ui-table-cell-visible", d);
},
_unlockCells: function (a) {
a.removeClass("ui-table-cell-hidden ui-table-cell-visible");
},
_enhanceColToggle: function () {
var b,
c,
d,
e,
f = this.element,
g = this.options,
h = a.mobile.ns,
i = this.document[0].createDocumentFragment();
return (
(b = this._id() + "-popup"),
(c = a(
"<a href='#" +
b +
"' class='" +
g.classes.columnBtn +
" ui-btn ui-btn-" +
(g.columnBtnTheme || "a") +
" ui-corner-all ui-shadow ui-mini' data-" +
h +
"rel='popup'>" +
g.columnBtnText +
"</a>"
)),
(d = a("<div class='" + g.classes.popup + "' id='" + b + "'></div>")),
(e = a("<fieldset></fieldset>").controlgroup()),
this._addToggles(e, !1),
e.appendTo(d),
i.appendChild(d[0]),
i.appendChild(c[0]),
f.before(i),
d.popup(),
e
);
},
rebuild: function () {
this._super(), "columntoggle" === this.options.mode && this._refresh(!1);
},
_refresh: function (b) {
var c, d, e;
if ((this._super(b), !b && "columntoggle" === this.options.mode))
for (
c = this.headers,
d = [],
this._menu.find("input").each(function () {
var b = a(this),
e = b.jqmData("header"),
f = c.index(e[0]);
f > -1 && !b.prop("checked") && d.push(f);
}),
this._unlockCells(this.element.find(".ui-table-cell-hidden, .ui-table-cell-visible")),
this._addToggles(this._menu, b),
e = d.length - 1;
e > -1;
e--
)
c.eq(d[e]).jqmData("input").prop("checked", !1).checkboxradio("refresh").trigger("change");
},
_setToggleState: function () {
this._menu.find("input").each(function () {
var b = a(this);
(this.checked = "table-cell" === b.jqmData("cells").eq(0).css("display")), b.checkboxradio("refresh");
});
},
_destroy: function () {
this._super();
},
});
})(a),
(function (a) {
a.widget("mobile.table", a.mobile.table, {
options: { mode: "reflow", classes: a.extend(a.mobile.table.prototype.options.classes, { reflowTable: "ui-table-reflow", cellLabels: "ui-table-cell-label" }) },
_create: function () {
this._super(), "reflow" === this.options.mode && (this.options.enhanced || (this.element.addClass(this.options.classes.reflowTable), this._updateReflow()));
},
rebuild: function () {
this._super(), "reflow" === this.options.mode && this._refresh(!1);
},
_refresh: function (a) {
this._super(a), a || "reflow" !== this.options.mode || this._updateReflow();
},
_updateReflow: function () {
var b = this,
c = this.options;
a(b.allHeaders.get().reverse()).each(function () {
var d,
e,
f = a(this).jqmData("cells"),
g = a.mobile.getAttribute(this, "colstart"),
h = f.not(this).filter("thead th").length && " ui-table-cell-label-top",
i = a(this).clone().contents();
i.length > 0 &&
(h
? ((d = parseInt(this.getAttribute("colspan"), 10)), (e = ""), d && (e = "td:nth-child(" + d + "n + " + g + ")"), b._addLabels(f.filter(e), c.classes.cellLabels + h, i))
: b._addLabels(f, c.classes.cellLabels, i));
});
},
_addLabels: function (b, c, d) {
1 === d.length && "abbr" === d[0].nodeName.toLowerCase() && (d = d.eq(0).attr("title")), b.not(":has(b." + c + ")").prepend(a("<b class='" + c + "'></b>").append(d));
},
});
})(a),
(function (a, c) {
var d = function (b, c) {
return -1 === ("" + (a.mobile.getAttribute(this, "filtertext") || a(this).text())).toLowerCase().indexOf(c);
};
a.widget("mobile.filterable", {
initSelector: ":jqmData(filter='true')",
options: {
filterReveal: !1,
filterCallback: d,
enhanced: !1,
input: null,
children: "> li, > option, > optgroup option, > tbody tr, > .ui-controlgroup-controls > .ui-btn, > .ui-controlgroup-controls > .ui-checkbox, > .ui-controlgroup-controls > .ui-radio",
},
_create: function () {
var b = this.options;
a.extend(this, { _search: null, _timer: 0 }), this._setInput(b.input), b.enhanced || this._filterItems(((this._search && this._search.val()) || "").toLowerCase());
},
_onKeyUp: function () {
var c,
d,
e = this._search;
if (e) {
if (((c = e.val().toLowerCase()), (d = a.mobile.getAttribute(e[0], "lastval") + ""), d && d === c)) return;
this._timer && (b.clearTimeout(this._timer), (this._timer = 0)),
(this._timer = this._delay(function () {
return this._trigger("beforefilter", null, { input: e }) === !1 ? !1 : (e[0].setAttribute("data-" + a.mobile.ns + "lastval", c), this._filterItems(c), void (this._timer = 0));
}, 250));
}
},
_getFilterableItems: function () {
var b = this.element,
c = this.options.children,
d = c ? (a.isFunction(c) ? c() : c.nodeName ? a(c) : c.jquery ? c : this.element.find(c)) : { length: 0 };
return 0 === d.length && (d = b.children()), d;
},
_filterItems: function (b) {
var c,
e,
f,
g,
h = [],
i = [],
j = this.options,
k = this._getFilterableItems();
if (null != b) for (e = j.filterCallback || d, f = k.length, c = 0; f > c; c++) (g = e.call(k[c], c, b) ? i : h), g.push(k[c]);
0 === i.length ? k[j.filterReveal && 0 === b.length ? "addClass" : "removeClass"]("ui-screen-hidden") : (a(i).addClass("ui-screen-hidden"), a(h).removeClass("ui-screen-hidden")),
this._refreshChildWidget(),
this._trigger("filter", null, { items: k });
},
_refreshChildWidget: function () {
var b,
c,
d = ["collapsibleset", "selectmenu", "controlgroup", "listview"];
for (c = d.length - 1; c > -1; c--) (b = d[c]), a.mobile[b] && ((b = this.element.data("mobile-" + b)), b && a.isFunction(b.refresh) && b.refresh());
},
_setInput: function (c) {
var d = this._search;
this._timer && (b.clearTimeout(this._timer), (this._timer = 0)),
d && (this._off(d, "keyup change input"), (d = null)),
c &&
((d = c.jquery ? c : c.nodeName ? a(c) : this.document.find(c)),
this._on(d, { keydown: "_onKeyDown", keypress: "_onKeyPress", keyup: "_onKeyUp", change: "_onKeyUp", input: "_onKeyUp" })),
(this._search = d);
},
_onKeyDown: function (b) {
b.keyCode === a.ui.keyCode.ENTER && (b.preventDefault(), (this._preventKeyPress = !0));
},
_onKeyPress: function (a) {
this._preventKeyPress && (a.preventDefault(), (this._preventKeyPress = !1));
},
_setOptions: function (a) {
var b = !(a.filterReveal === c && a.filterCallback === c && a.children === c);
this._super(a), a.input !== c && (this._setInput(a.input), (b = !0)), b && this.refresh();
},
_destroy: function () {
var a = this.options,
b = this._getFilterableItems();
a.enhanced ? b.toggleClass("ui-screen-hidden", a.filterReveal) : b.removeClass("ui-screen-hidden");
},
refresh: function () {
this._timer && (b.clearTimeout(this._timer), (this._timer = 0)), this._filterItems(((this._search && this._search.val()) || "").toLowerCase());
},
});
})(a),
(function (a, b) {
var c = function (a, b) {
return function (c) {
b.call(this, c), a._syncTextInputOptions(c);
};
},
d = /(^|\s)ui-li-divider(\s|$)/,
e = a.mobile.filterable.prototype.options.filterCallback;
(a.mobile.filterable.prototype.options.filterCallback = function (a, b) {
return !this.className.match(d) && e.call(this, a, b);
}),
a.widget("mobile.filterable", a.mobile.filterable, {
options: { filterPlaceholder: "Filter items...", filterTheme: null },
_create: function () {
var b,
c,
d = this.element,
e = ["collapsibleset", "selectmenu", "controlgroup", "listview"],
f = {};
for (this._super(), a.extend(this, { _widget: null }), b = e.length - 1; b > -1; b--)
if (((c = e[b]), a.mobile[c])) {
if (this._setWidget(d.data("mobile-" + c))) break;
f[c + "create"] = "_handleCreate";
}
this._widget || this._on(d, f);
},
_handleCreate: function (a) {
this._setWidget(this.element.data("mobile-" + a.type.substring(0, a.type.length - 6)));
},
_trigger: function (a, b, c) {
return this._widget && "mobile-listview" === this._widget.widgetFullName && "beforefilter" === a && this._widget._trigger("beforefilter", b, c), this._super(a, b, c);
},
_setWidget: function (a) {
return (
!this._widget && a && ((this._widget = a), (this._widget._setOptions = c(this, this._widget._setOptions))),
this._widget &&
(this._syncTextInputOptions(this._widget.options), "listview" === this._widget.widgetName && ((this._widget.options.hideDividers = !0), this._widget.element.listview("refresh"))),
!!this._widget
);
},
_isSearchInternal: function () {
return this._search && this._search.jqmData("ui-filterable-" + this.uuid + "-internal");
},
_setInput: function (b) {
var c = this.options,
d = !0,
e = {};
if (!b) {
if (this._isSearchInternal()) return;
(d = !1),
(b = a("<input data-" + a.mobile.ns + "type='search' placeholder='" + c.filterPlaceholder + "'></input>").jqmData("ui-filterable-" + this.uuid + "-internal", !0)),
a("<form class='ui-filterable'></form>")
.append(b)
.submit(function (a) {
a.preventDefault(), b.blur();
})
.insertBefore(this.element),
a.mobile.textinput && (null != this.options.filterTheme && (e.theme = c.filterTheme), b.textinput(e));
}
this._super(b), this._isSearchInternal() && d && this._search.attr("placeholder", this.options.filterPlaceholder);
},
_setOptions: function (c) {
var d = this._super(c);
return (
c.filterPlaceholder !== b && this._isSearchInternal() && this._search.attr("placeholder", c.filterPlaceholder),
c.filterTheme !== b && this._search && a.mobile.textinput && this._search.textinput("option", "theme", c.filterTheme),
d
);
},
_refreshChildWidget: function () {
(this._refreshingChildWidget = !0), this._superApply(arguments), (this._refreshingChildWidget = !1);
},
refresh: function () {
this._refreshingChildWidget || this._superApply(arguments);
},
_destroy: function () {
this._isSearchInternal() && this._search.remove(), this._super();
},
_syncTextInputOptions: function (c) {
var d,
e = {};
if (this._isSearchInternal() && a.mobile.textinput) {
for (d in a.mobile.textinput.prototype.options) c[d] !== b && (e[d] = "theme" === d && null != this.options.filterTheme ? this.options.filterTheme : c[d]);
this._search.textinput("option", e);
}
},
}),
a.widget("mobile.listview", a.mobile.listview, {
options: { filter: !1 },
_create: function () {
return this.options.filter !== !0 || this.element.data("mobile-filterable") || this.element.filterable(), this._super();
},
refresh: function () {
var a;
this._superApply(arguments), this.options.filter === !0 && ((a = this.element.data("mobile-filterable")), a && a.refresh());
},
});
})(a),
(function (a, b) {
function c() {
return ++e;
}
function d(a) {
return a.hash.length > 1 && decodeURIComponent(a.href.replace(f, "")) === decodeURIComponent(location.href.replace(f, ""));
}
var e = 0,
f = /#.*$/;
a.widget("ui.tabs", {
version: "fadf2b312a05040436451c64bbfaf4814bc62c56",
delay: 300,
options: { active: null, collapsible: !1, event: "click", heightStyle: "content", hide: null, show: null, activate: null, beforeActivate: null, beforeLoad: null, load: null },
_create: function () {
var b = this,
c = this.options;
(this.running = !1),
this.element
.addClass("ui-tabs ui-widget ui-widget-content ui-corner-all")
.toggleClass("ui-tabs-collapsible", c.collapsible)
.delegate(".ui-tabs-nav > li", "mousedown" + this.eventNamespace, function (b) {
a(this).is(".ui-state-disabled") && b.preventDefault();
})
.delegate(".ui-tabs-anchor", "focus" + this.eventNamespace, function () {
a(this).closest("li").is(".ui-state-disabled") && this.blur();
}),
this._processTabs(),
(c.active = this._initialActive()),
a.isArray(c.disabled) &&
(c.disabled = a
.unique(
c.disabled.concat(
a.map(this.tabs.filter(".ui-state-disabled"), function (a) {
return b.tabs.index(a);
})
)
)
.sort()),
(this.active = this.options.active !== !1 && this.anchors.length ? this._findActive(c.active) : a()),
this._refresh(),
this.active.length && this.load(c.active);
},
_initialActive: function () {
var b = this.options.active,
c = this.options.collapsible,
d = location.hash.substring(1);
return (
null === b &&
(d &&
this.tabs.each(function (c, e) {
return a(e).attr("aria-controls") === d ? ((b = c), !1) : void 0;
}),
null === b && (b = this.tabs.index(this.tabs.filter(".ui-tabs-active"))),
(null === b || -1 === b) && (b = this.tabs.length ? 0 : !1)),
b !== !1 && ((b = this.tabs.index(this.tabs.eq(b))), -1 === b && (b = c ? !1 : 0)),
!c && b === !1 && this.anchors.length && (b = 0),
b
);
},
_getCreateEventData: function () {
return { tab: this.active, panel: this.active.length ? this._getPanelForTab(this.active) : a() };
},
_tabKeydown: function (b) {
var c = a(this.document[0].activeElement).closest("li"),
d = this.tabs.index(c),
e = !0;
if (!this._handlePageNav(b)) {
switch (b.keyCode) {
case a.ui.keyCode.RIGHT:
case a.ui.keyCode.DOWN:
d++;
break;
case a.ui.keyCode.UP:
case a.ui.keyCode.LEFT:
(e = !1), d--;
break;
case a.ui.keyCode.END:
d = this.anchors.length - 1;
break;
case a.ui.keyCode.HOME:
d = 0;
break;
case a.ui.keyCode.SPACE:
return b.preventDefault(), clearTimeout(this.activating), void this._activate(d);
case a.ui.keyCode.ENTER:
return b.preventDefault(), clearTimeout(this.activating), void this._activate(d === this.options.active ? !1 : d);
default:
return;
}
b.preventDefault(),
clearTimeout(this.activating),
(d = this._focusNextTab(d, e)),
b.ctrlKey ||
(c.attr("aria-selected", "false"),
this.tabs.eq(d).attr("aria-selected", "true"),
(this.activating = this._delay(function () {
this.option("active", d);
}, this.delay)));
}
},
_panelKeydown: function (b) {
this._handlePageNav(b) || (b.ctrlKey && b.keyCode === a.ui.keyCode.UP && (b.preventDefault(), this.active.focus()));
},
_handlePageNav: function (b) {
return b.altKey && b.keyCode === a.ui.keyCode.PAGE_UP
? (this._activate(this._focusNextTab(this.options.active - 1, !1)), !0)
: b.altKey && b.keyCode === a.ui.keyCode.PAGE_DOWN
? (this._activate(this._focusNextTab(this.options.active + 1, !0)), !0)
: void 0;
},
_findNextTab: function (b, c) {
function d() {
return b > e && (b = 0), 0 > b && (b = e), b;
}
for (var e = this.tabs.length - 1; -1 !== a.inArray(d(), this.options.disabled);) b = c ? b + 1 : b - 1;
return b;
},
_focusNextTab: function (a, b) {
return (a = this._findNextTab(a, b)), this.tabs.eq(a).focus(), a;
},
_setOption: function (a, b) {
return "active" === a
? void this._activate(b)
: "disabled" === a
? void this._setupDisabled(b)
: (this._super(a, b),
"collapsible" === a && (this.element.toggleClass("ui-tabs-collapsible", b), b || this.options.active !== !1 || this._activate(0)),
"event" === a && this._setupEvents(b),
void ("heightStyle" === a && this._setupHeightStyle(b)));
},
_tabId: function (a) {
return a.attr("aria-controls") || "ui-tabs-" + c();
},
_sanitizeSelector: function (a) {
return a ? a.replace(/[!"$%&'()*+,.\/:;<=>?@\[\]\^`{|}~]/g, "\\$&") : "";
},
refresh: function () {
var b = this.options,
c = this.tablist.children(":has(a[href])");
(b.disabled = a.map(c.filter(".ui-state-disabled"), function (a) {
return c.index(a);
})),
this._processTabs(),
b.active !== !1 && this.anchors.length
? this.active.length && !a.contains(this.tablist[0], this.active[0])
? this.tabs.length === b.disabled.length
? ((b.active = !1), (this.active = a()))
: this._activate(this._findNextTab(Math.max(0, b.active - 1), !1))
: (b.active = this.tabs.index(this.active))
: ((b.active = !1), (this.active = a())),
this._refresh();
},
_refresh: function () {
this._setupDisabled(this.options.disabled),
this._setupEvents(this.options.event),
this._setupHeightStyle(this.options.heightStyle),
this.tabs.not(this.active).attr({ "aria-selected": "false", tabIndex: -1 }),
this.panels.not(this._getPanelForTab(this.active)).hide().attr({ "aria-expanded": "false", "aria-hidden": "true" }),
this.active.length
? (this.active.addClass("ui-tabs-active ui-state-active").attr({ "aria-selected": "true", tabIndex: 0 }),
this._getPanelForTab(this.active).show().attr({ "aria-expanded": "true", "aria-hidden": "false" }))
: this.tabs.eq(0).attr("tabIndex", 0);
},
_processTabs: function () {
var b = this;
(this.tablist = this._getList().addClass("ui-tabs-nav ui-helper-reset ui-helper-clearfix ui-widget-header ui-corner-all").attr("role", "tablist")),
(this.tabs = this.tablist.find("> li:has(a[href])").addClass("ui-state-default ui-corner-top").attr({ role: "tab", tabIndex: -1 })),
(this.anchors = this.tabs
.map(function () {
return a("a", this)[0];
})
.addClass("ui-tabs-anchor")
.attr({ role: "presentation", tabIndex: -1 })),
(this.panels = a()),
this.anchors.each(function (c, e) {
var f,
g,
h,
i = a(e).uniqueId().attr("id"),
j = a(e).closest("li"),
k = j.attr("aria-controls");
d(e)
? ((f = e.hash), (g = b.element.find(b._sanitizeSelector(f))))
: ((h = b._tabId(j)), (f = "#" + h), (g = b.element.find(f)), g.length || ((g = b._createPanel(h)), g.insertAfter(b.panels[c - 1] || b.tablist)), g.attr("aria-live", "polite")),
g.length && (b.panels = b.panels.add(g)),
k && j.data("ui-tabs-aria-controls", k),
j.attr({ "aria-controls": f.substring(1), "aria-labelledby": i }),
g.attr("aria-labelledby", i);
}),
this.panels.addClass("ui-tabs-panel ui-widget-content ui-corner-bottom").attr("role", "tabpanel");
},
_getList: function () {
return this.element.find("ol,ul").eq(0);
},
_createPanel: function (b) {
return a("<div>").attr("id", b).addClass("ui-tabs-panel ui-widget-content ui-corner-bottom").data("ui-tabs-destroy", !0);
},
_setupDisabled: function (b) {
a.isArray(b) && (b.length ? b.length === this.anchors.length && (b = !0) : (b = !1));
for (var c, d = 0; (c = this.tabs[d]); d++)
b === !0 || -1 !== a.inArray(d, b) ? a(c).addClass("ui-state-disabled").attr("aria-disabled", "true") : a(c).removeClass("ui-state-disabled").removeAttr("aria-disabled");
this.options.disabled = b;
},
_setupEvents: function (b) {
var c = {
click: function (a) {
a.preventDefault();
},
};
b &&
a.each(b.split(" "), function (a, b) {
c[b] = "_eventHandler";
}),
this._off(this.anchors.add(this.tabs).add(this.panels)),
this._on(this.anchors, c),
this._on(this.tabs, { keydown: "_tabKeydown" }),
this._on(this.panels, { keydown: "_panelKeydown" }),
this._focusable(this.tabs),
this._hoverable(this.tabs);
},
_setupHeightStyle: function (b) {
var c,
d = this.element.parent();
"fill" === b
? ((c = d.height()),
(c -= this.element.outerHeight() - this.element.height()),
this.element.siblings(":visible").each(function () {
var b = a(this),
d = b.css("position");
"absolute" !== d && "fixed" !== d && (c -= b.outerHeight(!0));
}),
this.element
.children()
.not(this.panels)
.each(function () {
c -= a(this).outerHeight(!0);
}),
this.panels
.each(function () {
a(this).height(Math.max(0, c - a(this).innerHeight() + a(this).height()));
})
.css("overflow", "auto"))
: "auto" === b &&
((c = 0),
this.panels
.each(function () {
c = Math.max(c, a(this).height("").height());
})
.height(c));
},
_eventHandler: function (b) {
var c = this.options,
d = this.active,
e = a(b.currentTarget),
f = e.closest("li"),
g = f[0] === d[0],
h = g && c.collapsible,
i = h ? a() : this._getPanelForTab(f),
j = d.length ? this._getPanelForTab(d) : a(),
k = { oldTab: d, oldPanel: j, newTab: h ? a() : f, newPanel: i };
b.preventDefault(),
f.hasClass("ui-state-disabled") ||
f.hasClass("ui-tabs-loading") ||
this.running ||
(g && !c.collapsible) ||
this._trigger("beforeActivate", b, k) === !1 ||
((c.active = h ? !1 : this.tabs.index(f)),
(this.active = g ? a() : f),
this.xhr && this.xhr.abort(),
j.length || i.length || a.error("jQuery UI Tabs: Mismatching fragment identifier."),
i.length && this.load(this.tabs.index(f), b),
this._toggle(b, k));
},
_toggle: function (b, c) {
function d() {
(f.running = !1), f._trigger("activate", b, c);
}
function e() {
c.newTab.closest("li").addClass("ui-tabs-active ui-state-active"), g.length && f.options.show ? f._show(g, f.options.show, d) : (g.show(), d());
}
var f = this,
g = c.newPanel,
h = c.oldPanel;
(this.running = !0),
h.length && this.options.hide
? this._hide(h, this.options.hide, function () {
c.oldTab.closest("li").removeClass("ui-tabs-active ui-state-active"), e();
})
: (c.oldTab.closest("li").removeClass("ui-tabs-active ui-state-active"), h.hide(), e()),
h.attr({ "aria-expanded": "false", "aria-hidden": "true" }),
c.oldTab.attr("aria-selected", "false"),
g.length && h.length
? c.oldTab.attr("tabIndex", -1)
: g.length &&
this.tabs
.filter(function () {
return 0 === a(this).attr("tabIndex");
})
.attr("tabIndex", -1),
g.attr({ "aria-expanded": "true", "aria-hidden": "false" }),
c.newTab.attr({ "aria-selected": "true", tabIndex: 0 });
},
_activate: function (b) {
var c,
d = this._findActive(b);
d[0] !== this.active[0] && (d.length || (d = this.active), (c = d.find(".ui-tabs-anchor")[0]), this._eventHandler({ target: c, currentTarget: c, preventDefault: a.noop }));
},
_findActive: function (b) {
return b === !1 ? a() : this.tabs.eq(b);
},
_getIndex: function (a) {
return "string" == typeof a && (a = this.anchors.index(this.anchors.filter("[href$='" + a + "']"))), a;
},
_destroy: function () {
this.xhr && this.xhr.abort(),
this.element.removeClass("ui-tabs ui-widget ui-widget-content ui-corner-all ui-tabs-collapsible"),
this.tablist.removeClass("ui-tabs-nav ui-helper-reset ui-helper-clearfix ui-widget-header ui-corner-all").removeAttr("role"),
this.anchors.removeClass("ui-tabs-anchor").removeAttr("role").removeAttr("tabIndex").removeUniqueId(),
this.tabs.add(this.panels).each(function () {
a.data(this, "ui-tabs-destroy")
? a(this).remove()
: a(this)
.removeClass("ui-state-default ui-state-active ui-state-disabled ui-corner-top ui-corner-bottom ui-widget-content ui-tabs-active ui-tabs-panel")
.removeAttr("tabIndex")
.removeAttr("aria-live")
.removeAttr("aria-busy")
.removeAttr("aria-selected")
.removeAttr("aria-labelledby")
.removeAttr("aria-hidden")
.removeAttr("aria-expanded")
.removeAttr("role");
}),
this.tabs.each(function () {
var b = a(this),
c = b.data("ui-tabs-aria-controls");
c ? b.attr("aria-controls", c).removeData("ui-tabs-aria-controls") : b.removeAttr("aria-controls");
}),
this.panels.show(),
"content" !== this.options.heightStyle && this.panels.css("height", "");
},
enable: function (c) {
var d = this.options.disabled;
d !== !1 &&
(c === b
? (d = !1)
: ((c = this._getIndex(c)),
(d = a.isArray(d)
? a.map(d, function (a) {
return a !== c ? a : null;
})
: a.map(this.tabs, function (a, b) {
return b !== c ? b : null;
}))),
this._setupDisabled(d));
},
disable: function (c) {
var d = this.options.disabled;
if (d !== !0) {
if (c === b) d = !0;
else {
if (((c = this._getIndex(c)), -1 !== a.inArray(c, d))) return;
d = a.isArray(d) ? a.merge([c], d).sort() : [c];
}
this._setupDisabled(d);
}
},
load: function (b, c) {
b = this._getIndex(b);
var e = this,
f = this.tabs.eq(b),
g = f.find(".ui-tabs-anchor"),
h = this._getPanelForTab(f),
i = { tab: f, panel: h };
d(g[0]) ||
((this.xhr = a.ajax(this._ajaxSettings(g, c, i))),
this.xhr &&
"canceled" !== this.xhr.statusText &&
(f.addClass("ui-tabs-loading"),
h.attr("aria-busy", "true"),
this.xhr
.success(function (a) {
setTimeout(function () {
h.html(a), e._trigger("load", c, i);
}, 1);
})
.complete(function (a, b) {
setTimeout(function () {
"abort" === b && e.panels.stop(!1, !0), f.removeClass("ui-tabs-loading"), h.removeAttr("aria-busy"), a === e.xhr && delete e.xhr;
}, 1);
})));
},
_ajaxSettings: function (b, c, d) {
var e = this;
return {
url: b.attr("href"),
beforeSend: function (b, f) {
return e._trigger("beforeLoad", c, a.extend({ jqXHR: b, ajaxSettings: f }, d));
},
};
},
_getPanelForTab: function (b) {
var c = a(b).attr("aria-controls");
return this.element.find(this._sanitizeSelector("#" + c));
},
});
})(a),
(function () { })(a),
(function (a, b) {
function c(a) {
(e = a.originalEvent),
(i = e.accelerationIncludingGravity),
(f = Math.abs(i.x)),
(g = Math.abs(i.y)),
(h = Math.abs(i.z)),
!b.orientation && (f > 7 || (((h > 6 && 8 > g) || (8 > h && g > 6)) && f > 5)) ? d.enabled && d.disable() : d.enabled || d.enable();
}
a.mobile.iosorientationfixEnabled = !0;
var d,
e,
f,
g,
h,
i,
j = navigator.userAgent;
return /iPhone|iPad|iPod/.test(navigator.platform) && /OS [1-5]_[0-9_]* like Mac OS X/i.test(j) && j.indexOf("AppleWebKit") > -1
? ((d = a.mobile.zoom),
void a.mobile.document.on("mobileinit", function () {
a.mobile.iosorientationfixEnabled && a.mobile.window.bind("orientationchange.iosorientationfix", d.enable).bind("devicemotion.iosorientationfix", c);
}))
: void (a.mobile.iosorientationfixEnabled = !1);
})(a, this),
(function (a, b, d) {
function e() {
f.removeClass("ui-mobile-rendering");
}
var f = a("html"),
g = a.mobile.window;
a(b.document).trigger("mobileinit"),
a.mobile.gradeA() &&
(a.mobile.ajaxBlacklist && (a.mobile.ajaxEnabled = !1),
f.addClass("ui-mobile ui-mobile-rendering"),
setTimeout(e, 5e3),
a.extend(a.mobile, {
initializePage: function () {
var b = a.mobile.path,
f = a(":jqmData(role='page'), :jqmData(role='dialog')"),
h = b.stripHash(b.stripQueryParams(b.parseLocation().hash)),
i = a.mobile.path.parseLocation(),
j = h ? c.getElementById(h) : d;
f.length ||
(f = a("body")
.wrapInner("<div data-" + a.mobile.ns + "role='page'></div>")
.children(0)),
f.each(function () {
var c = a(this);
c[0].getAttribute("data-" + a.mobile.ns + "url") || c.attr("data-" + a.mobile.ns + "url", c.attr("id") || b.convertUrlToDataUrl(i.pathname + i.search));
}),
e(),
a.mobile.hashListeningEnabled && a.mobile.path.isHashValid(location.hash) && (a(j).is(":jqmData(role='page')") || a.mobile.path.isPath(h) || h === a.mobile.dialogHashKey)
? a.event.special.navigate.isPushStateEnabled()
? ((a.mobile.navigate.history.stack = []), a.mobile.navigate(a.mobile.path.isPath(location.hash) ? location.hash : location.href))
: g.trigger("hashchange", [!0])
: (a.event.special.navigate.isPushStateEnabled() && a.mobile.navigate.navigator.squash(b.parseLocation().href),
a.mobile.changePage(a.mobile.firstPage, { transition: "none", reverse: !0, changeHash: !1, fromHashChange: !0 }));
},
}),
a(function () {
a.support.inlineSVG(),
a.mobile.hideUrlBar && b.scrollTo(0, 1),
(a.mobile.defaultHomeScroll = a.support.scrollTop && 1 !== a.mobile.window.scrollTop() ? 1 : 0),
a.mobile.autoInitializePage && a.mobile.initializePage(),
a.mobile.hideUrlBar && g.load(a.mobile.silentScroll),
a.support.cssPointerEvents ||
a.mobile.document.delegate(".ui-state-disabled,.ui-disabled", "vclick", function (a) {
a.preventDefault(), a.stopImmediatePropagation();
});
}));
})(a, this);
});
//# sourceMappingURL=jquery.mobile-1.4.5.min.map