swc/crates/swc_ecma_minifier/tests/projects/refs/jquery.mobile-1.4.2.js
2021-11-10 19:00:54 +09:00

20563 lines
766 KiB
JavaScript

/*!
* jQuery Mobile 1.4.2
* Git HEAD hash: 9d9a42a27d0c693e8b5569c3a10d771916af5045 <> Date: Fri Feb 28 2014 17:32:01 UTC
* http://jquerymobile.com
*
* Copyright 2010, 2014 jQuery Foundation, Inc. and other contributors
* Released under the MIT license.
* http://jquery.org/license
*
*/
!(function (
root, doc, factory
) {
"function" == typeof define && define.amd
? define(
["jquery",],
function (
$
) {
return factory(
$,
root,
doc
), $.mobile;
}
)
: factory(
root.jQuery,
root,
doc
);
})(
this,
document,
function (
jQuery, window, document, undefined
) {
(jQuery.mobile = {
}),
(function (
$, window, undefined
) {
$.extend(
$.mobile,
{
version: "1.4.2",
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: $(
),
allowCrossDomainPages: !1,
dialogHashKey: "&ui-state=dialog",
}
);
})(
jQuery
),
(function (
$, window, undefined
) {
var nsNormalizeDict = {
},
oldFind = $.find,
rbrace = /(?:\{[\s\S]*\}|\[[\s\S]*\])$/,
jqmDataRE = /:jqmData\(([^)]*)\)/g;
$.extend(
$.mobile,
{
ns: "",
getAttribute: function (
element, key
) {
var data;
(element = element.jquery ? element[0] : element) &&
element.getAttribute &&
(data = element.getAttribute(
"data-" + $.mobile.ns + key
));
try {
data =
"true" === data ||
("false" !== data &&
("null" === data
? null
: +data + "" === data
? +data
: rbrace.test(
data
)
? JSON.parse(
data
)
: data));
} catch (err) {}
return data;
},
nsNormalizeDict: nsNormalizeDict,
nsNormalize: function (
prop
) {
return (
nsNormalizeDict[prop] ||
(nsNormalizeDict[prop] = $.camelCase(
$.mobile.ns + prop
))
);
},
closestPageData: function (
$target
) {
return $target
.closest(
":jqmData(role='page'), :jqmData(role='dialog')"
)
.data(
"mobile-page"
);
},
}
),
($.fn.jqmData = function (
prop, value
) {
var result;
return (
void 0 !== prop &&
(prop && (prop = $.mobile.nsNormalize(
prop
)),
(result =
arguments.length < 2 || undefined === value
? this.data(
prop
)
: this.data(
prop,
value
))),
result
);
}),
($.jqmData = function (
elem, prop, value
) {
var result;
return (
void 0 !== prop &&
(result = $.data(
elem,
prop
? $.mobile.nsNormalize(
prop
)
: prop,
value,
)),
result
);
}),
($.fn.jqmRemoveData = function (
prop
) {
return this.removeData(
$.mobile.nsNormalize(
prop
)
);
}),
($.jqmRemoveData = function (
elem, prop
) {
return $.removeData(
elem,
$.mobile.nsNormalize(
prop
)
);
}),
($.find = function (
selector, context, ret, extra
) {
return (
selector.indexOf(
":jqmData"
) > -1 &&
(selector = selector.replace(
jqmDataRE,
"[data-" + ($.mobile.ns || "") + "$1]",
)),
oldFind.call(
this,
selector,
context,
ret,
extra
)
);
}),
$.extend(
$.find,
oldFind
);
})(
jQuery
),
/*!
* jQuery UI Core c0ab71056b936627e8a7821f03c044aec6280a40
* http://jqueryui.com
*
* Copyright 2013 jQuery Foundation and other contributors
* Released under the MIT license.
* http://jquery.org/license
*
* http://api.jqueryui.com/category/ui-core/
*/
(function (
$, undefined
) {
var orig,
removeData,
uuid = 0,
runiqueId = /^ui-id-\d+$/;
function focusable(
element, isTabIndexNotNaN
) {
var map,
mapName,
img,
nodeName = element.nodeName.toLowerCase(
);
return "area" === nodeName
? ((mapName = (map = element.parentNode).name),
!(
!element.href ||
!mapName ||
"map" !== map.nodeName.toLowerCase(
)
) &&
!!(img = $(
"img[usemap=#" + mapName + "]"
)[0]) &&
visible(
img
))
: (/input|select|textarea|button|object/.test(
nodeName
)
? !element.disabled
: ("a" === nodeName && element.href) || isTabIndexNotNaN) &&
visible(
element
);
}
function visible(
element
) {
return (
$.expr.filters.visible(
element
) &&
!$(
element
)
.parents(
)
.addBack(
)
.filter(
function (
) {
return "hidden" === $.css(
this,
"visibility"
);
}
).length
);
}
($.ui = $.ui || {
}),
$.extend(
$.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,
},
}
),
$.fn.extend(
{
focus:
((orig = $.fn.focus),
function (
delay, fn
) {
return "number" == typeof delay
? this.each(
function (
) {
var elem = this;
setTimeout(
function (
) {
$(
elem
).focus(
), fn && fn.call(
elem
);
},
delay
);
}
)
: orig.apply(
this,
arguments
);
}),
scrollParent: function (
) {
var scrollParent;
return (
(scrollParent =
($.ui.ie && /(static|relative)/.test(
this.css(
"position"
)
)) ||
/absolute/.test(
this.css(
"position"
)
)
? this.parents(
)
.filter(
function (
) {
return (
/(relative|absolute|fixed)/.test(
$.css(
this,
"position"
),
) &&
/(auto|scroll)/.test(
$.css(
this,
"overflow"
) +
$.css(
this,
"overflow-y"
) +
$.css(
this,
"overflow-x"
),
)
);
}
)
.eq(
0
)
: this.parents(
)
.filter(
function (
) {
return /(auto|scroll)/.test(
$.css(
this,
"overflow"
) +
$.css(
this,
"overflow-y"
) +
$.css(
this,
"overflow-x"
),
);
}
)
.eq(
0
)),
/fixed/.test(
this.css(
"position"
)
) || !scrollParent.length
? $(
this[0].ownerDocument || document
)
: scrollParent
);
},
uniqueId: function (
) {
return this.each(
function (
) {
this.id || (this.id = "ui-id-" + ++uuid);
}
);
},
removeUniqueId: function (
) {
return this.each(
function (
) {
runiqueId.test(
this.id
) && $(
this
).removeAttr(
"id"
);
}
);
},
}
),
$.extend(
$.expr[":"],
{
data: $.expr.createPseudo
? $.expr.createPseudo(
function (
dataName
) {
return function (
elem
) {
return !!$.data(
elem,
dataName
);
};
}
)
: function (
elem, i, match
) {
return !!$.data(
elem,
match[3]
);
},
focusable: function (
element
) {
return focusable(
element,
!isNaN(
$.attr(
element,
"tabindex"
)
)
);
},
tabbable: function (
element
) {
var tabIndex = $.attr(
element,
"tabindex"
),
isTabIndexNaN = isNaN(
tabIndex
);
return (
(isTabIndexNaN || tabIndex >= 0) &&
focusable(
element,
!isTabIndexNaN
)
);
},
}
),
$(
"<a>"
).outerWidth(
1
).jquery ||
$.each(
["Width", "Height",],
function (
i, name
) {
var side = "Width" === name ? ["Left", "Right",] : ["Top", "Bottom",],
type = name.toLowerCase(
),
orig = {
innerWidth: $.fn.innerWidth,
innerHeight: $.fn.innerHeight,
outerWidth: $.fn.outerWidth,
outerHeight: $.fn.outerHeight,
};
function reduce(
elem, size, border, margin
) {
return (
$.each(
side,
function (
) {
(size -= parseFloat(
$.css(
elem,
"padding" + this
)
) || 0),
border &&
(size -=
parseFloat(
$.css(
elem,
"border" + this + "Width"
)
) ||
0),
margin &&
(size -= parseFloat(
$.css(
elem,
"margin" + this
)
) || 0);
}
),
size
);
}
($.fn["inner" + name] = function (
size
) {
return undefined === size
? orig["inner" + name].call(
this
)
: this.each(
function (
) {
$(
this
).css(
type,
reduce(
this,
size
) + "px"
);
}
);
}),
($.fn["outer" + name] = function (
size, margin
) {
return "number" != typeof size
? orig["outer" + name].call(
this,
size
)
: this.each(
function (
) {
$(
this
).css(
type,
reduce(
this,
size,
!0,
margin
) + "px"
);
}
);
});
}
),
$.fn.addBack ||
($.fn.addBack = function (
selector
) {
return this.add(
null == selector
? this.prevObject
: this.prevObject.filter(
selector
),
);
}),
$(
"<a>"
).data(
"a-b",
"a"
).removeData(
"a-b"
).data(
"a-b"
) &&
($.fn.removeData =
((removeData = $.fn.removeData),
function (
key
) {
return arguments.length
? removeData.call(
this,
$.camelCase(
key
)
)
: removeData.call(
this
);
})),
($.ui.ie = !!/msie [\w.]+/.exec(
navigator.userAgent.toLowerCase(
)
)),
($.support.selectstart =
"onselectstart" in document.createElement(
"div"
)),
$.fn.extend(
{
disableSelection: function (
) {
return this.bind(
($.support.selectstart ? "selectstart" : "mousedown") +
".ui-disableSelection",
function (
event
) {
event.preventDefault(
);
},
);
},
enableSelection: function (
) {
return this.unbind(
".ui-disableSelection"
);
},
zIndex: function (
zIndex
) {
if (undefined !== zIndex) return this.css(
"zIndex",
zIndex
);
if (this.length)
for (
var position, value, elem = $(
this[0]
);
elem.length && elem[0] !== document;
) {
if (
("absolute" === (position = elem.css(
"position"
)) ||
"relative" === position ||
"fixed" === position) &&
((value = parseInt(
elem.css(
"zIndex"
),
10
)),
!isNaN(
value
) && 0 !== value)
)
return value;
elem = elem.parent(
);
}
return 0;
},
}
),
($.ui.plugin = {
add: function (
module, option, set
) {
var i,
proto = $.ui[module].prototype;
for (i in set)
(proto.plugins[i] = proto.plugins[i] || []),
proto.plugins[i].push(
[option, set[i],]
);
},
call: function (
instance, name, args, allowDisconnected
) {
var i,
set = instance.plugins[name];
if (
set &&
(allowDisconnected ||
(instance.element[0].parentNode &&
11 !== instance.element[0].parentNode.nodeType))
)
for (i = 0; i < set.length; i++)
instance.options[set[i][0]] &&
set[i][1].apply(
instance.element,
args
);
},
});
})(
jQuery
),
(function (
$, window, undefined
) {
$.extend(
$.mobile,
{
window: $(
window
),
document: $(
document
),
keyCode: $.ui.keyCode,
behaviors: {
},
silentScroll: function (
ypos
) {
"number" !== $.type(
ypos
) && (ypos = $.mobile.defaultHomeScroll),
($.event.special.scrollstart.enabled = !1),
setTimeout(
function (
) {
window.scrollTo(
0,
ypos
),
$.mobile.document.trigger(
"silentscroll",
{
x: 0,
y: ypos,
}
);
},
20
),
setTimeout(
function (
) {
$.event.special.scrollstart.enabled = !0;
},
150
);
},
getClosestBaseUrl: function (
ele
) {
var url = $(
ele
).closest(
".ui-page"
).jqmData(
"url"
),
base = $.mobile.path.documentBase.hrefNoHash;
return (
($.mobile.dynamicBaseEnabled && url && $.mobile.path.isPath(
url
)) ||
(url = base),
$.mobile.path.makeUrlAbsolute(
url,
base
)
);
},
removeActiveLinkClass: function (
forceRemoval
) {
!$.mobile.activeClickedLink ||
($.mobile.activeClickedLink.closest(
"." + $.mobile.activePageClass
)
.length &&
!forceRemoval) ||
$.mobile.activeClickedLink.removeClass(
$.mobile.activeBtnClass
),
($.mobile.activeClickedLink = null);
},
getInheritedTheme: function (
el, defaultTheme
) {
for (
var c,
m,
e = el[0],
ltr = "",
re = /ui-(bar|body|overlay)-([a-z])\b/;
e && !((c = e.className || "") && (m = re.exec(
c
)) && (ltr = m[2]));
)
e = e.parentNode;
return ltr || defaultTheme || "a";
},
enhanceable: function (
elements
) {
return this.haveParents(
elements,
"enhance"
);
},
hijackable: function (
elements
) {
return this.haveParents(
elements,
"ajax"
);
},
haveParents: function (
elements, attr
) {
if (!$.mobile.ignoreContentEnabled) return elements;
var e,
$element,
excluded,
i,
count = elements.length,
$newSet = $(
);
for (i = 0; i < count; i++) {
for (
$element = elements.eq(
i
), excluded = !1, e = elements[i];
e;
) {
if (
"false" ===
(e.getAttribute
? e.getAttribute(
"data-" + $.mobile.ns + attr
)
: "")
) {
excluded = !0;
break;
}
e = e.parentNode;
}
excluded || ($newSet = $newSet.add(
$element
));
}
return $newSet;
},
getScreenHeight: function (
) {
return window.innerHeight || $.mobile.window.height(
);
},
resetActivePageHeight: function (
height
) {
var page = $(
"." + $.mobile.activePageClass
),
pageHeight = page.height(
),
pageOuterHeight = page.outerHeight(
!0
);
(height = (function (
page, desiredHeight
) {
var pageParent = page.parent(
),
toolbarsAffectingHeight = [],
externalHeaders = pageParent.children(
":jqmData(role='header')"
),
internalHeaders = page.children(
":jqmData(role='header')"
),
externalFooters = pageParent.children(
":jqmData(role='footer')"
),
internalFooters = page.children(
":jqmData(role='footer')"
);
return (
0 === internalHeaders.length &&
externalHeaders.length > 0 &&
(toolbarsAffectingHeight = toolbarsAffectingHeight.concat(
externalHeaders.toArray(
),
)),
0 === internalFooters.length &&
externalFooters.length > 0 &&
(toolbarsAffectingHeight = toolbarsAffectingHeight.concat(
externalFooters.toArray(
),
)),
$.each(
toolbarsAffectingHeight,
function (
index, value
) {
desiredHeight -= $(
value
).outerHeight(
);
}
),
Math.max(
0,
desiredHeight
)
);
})(
page,
"number" == typeof height
? height
: $.mobile.getScreenHeight(
),
)),
page.css(
"min-height",
height - (pageOuterHeight - pageHeight)
);
},
loading: function (
) {
var loader =
this.loading._widget ||
$(
$.mobile.loader.prototype.defaultHtml
).loader(
),
returnValue = loader.loader.apply(
loader,
arguments
);
return (this.loading._widget = loader), returnValue;
},
}
),
($.addDependents = function (
elem, newDependents
) {
var $elem = $(
elem
),
dependents = $elem.jqmData(
"dependents"
) || $(
);
$elem.jqmData(
"dependents",
$(
dependents
).add(
newDependents
)
);
}),
$.fn.extend(
{
removeWithDependents: function (
) {
$.removeWithDependents(
this
);
},
enhanceWithin: function (
) {
var index,
widgetElements = {
},
keepNative = $.mobile.page.prototype.keepNativeSelector(
),
that = this;
for (index in ($.mobile.nojs && $.mobile.nojs(
this
),
$.mobile.links && $.mobile.links(
this
),
$.mobile.degradeInputsWithin && $.mobile.degradeInputsWithin(
this
),
$.fn.buttonMarkup &&
this.find(
$.fn.buttonMarkup.initSelector
)
.not(
keepNative
)
.jqmEnhanceable(
)
.buttonMarkup(
),
$.fn.fieldcontain &&
this.find(
":jqmData(role='fieldcontain')"
)
.not(
keepNative
)
.jqmEnhanceable(
)
.fieldcontain(
),
$.each(
$.mobile.widgets,
function (
name, constructor
) {
if (constructor.initSelector) {
var elements = $.mobile.enhanceable(
that.find(
constructor.initSelector
),
);
elements.length > 0 && (elements = elements.not(
keepNative
)),
elements.length > 0 &&
(widgetElements[
constructor.prototype.widgetName
] = elements);
}
}
),
widgetElements))
widgetElements[index][index](
);
return this;
},
addDependents: function (
newDependents
) {
$.addDependents(
this,
newDependents
);
},
getEncodedText: function (
) {
return $(
"<a>"
).text(
this.text(
)
).html(
);
},
jqmEnhanceable: function (
) {
return $.mobile.enhanceable(
this
);
},
jqmHijackable: function (
) {
return $.mobile.hijackable(
this
);
},
}
),
($.removeWithDependents = function (
nativeElement
) {
var element = $(
nativeElement
);
(element.jqmData(
"dependents"
) || $(
)).remove(
), element.remove(
);
}),
($.addDependents = function (
nativeElement, newDependents
) {
var element = $(
nativeElement
),
dependents = element.jqmData(
"dependents"
) || $(
);
element.jqmData(
"dependents",
$(
dependents
).add(
newDependents
)
);
}),
($.find.matches = function (
expr, set
) {
return $.find(
expr,
null,
null,
set
);
}),
($.find.matchesSelector = function (
node, expr
) {
return $.find(
expr,
null,
null,
[node,]
).length > 0;
});
})(
jQuery,
this
),
/*!
* jQuery UI Widget c0ab71056b936627e8a7821f03c044aec6280a40
* http://jqueryui.com
*
* Copyright 2013 jQuery Foundation and other contributors
* Released under the MIT license.
* http://jquery.org/license
*
* http://api.jqueryui.com/jQuery.widget/
*/
(function (
$, undefined
) {
var uuid = 0,
slice = Array.prototype.slice,
_cleanData = $.cleanData;
($.cleanData = function (
elems
) {
for (var elem, i = 0; null != (elem = elems[i]); i++)
try {
$(
elem
).triggerHandler(
"remove"
);
} catch (e) {}
_cleanData(
elems
);
}),
($.widget = function (
name, base, prototype
) {
var fullName,
existingConstructor,
constructor,
basePrototype,
proxiedPrototype = {
},
namespace = name.split(
"."
)[0];
return (
(name = name.split(
"."
)[1]),
(fullName = namespace + "-" + name),
prototype || ((prototype = base), (base = $.Widget)),
($.expr[":"][fullName.toLowerCase(
)] = function (
elem
) {
return !!$.data(
elem,
fullName
);
}),
($[namespace] = $[namespace] || {
}),
(existingConstructor = $[namespace][name]),
(constructor = $[namespace][name] = function (
options, element
) {
if (!this._createWidget) return new constructor(
options,
element
);
arguments.length && this._createWidget(
options,
element
);
}),
$.extend(
constructor,
existingConstructor,
{
version: prototype.version,
_proto: $.extend(
{
},
prototype
),
_childConstructors: [],
}
),
((basePrototype = new base(
)).options = $.widget.extend(
{
},
basePrototype.options,
)),
$.each(
prototype,
function (
prop, value
) {
var _super, _superApply;
$.isFunction(
value
)
? (proxiedPrototype[prop] =
((_super = function (
) {
return base.prototype[prop].apply(
this,
arguments
);
}),
(_superApply = function (
args
) {
return base.prototype[prop].apply(
this,
args
);
}),
function (
) {
var returnValue,
__super = this._super,
__superApply = this._superApply;
return (
(this._super = _super),
(this._superApply = _superApply),
(returnValue = value.apply(
this,
arguments
)),
(this._super = __super),
(this._superApply = __superApply),
returnValue
);
}))
: (proxiedPrototype[prop] = value);
}
),
(constructor.prototype = $.widget.extend(
basePrototype,
{
widgetEventPrefix:
(existingConstructor && basePrototype.widgetEventPrefix) ||
name,
},
proxiedPrototype,
{
constructor: constructor,
namespace: namespace,
widgetName: name,
widgetFullName: fullName,
},
)),
existingConstructor
? ($.each(
existingConstructor._childConstructors,
function (
i, child
) {
var childPrototype = child.prototype;
$.widget(
childPrototype.namespace +
"." +
childPrototype.widgetName,
constructor,
child._proto,
);
},
),
delete existingConstructor._childConstructors)
: base._childConstructors.push(
constructor
),
$.widget.bridge(
name,
constructor
),
constructor
);
}),
($.widget.extend = function (
target
) {
for (
var key,
value,
input = slice.call(
arguments,
1
),
inputIndex = 0,
inputLength = input.length;
inputIndex < inputLength;
inputIndex++
)
for (key in input[inputIndex])
(value = input[inputIndex][key]),
input[inputIndex].hasOwnProperty(
key
) &&
undefined !== value &&
($.isPlainObject(
value
)
? (target[key] = $.isPlainObject(
target[key]
)
? $.widget.extend(
{
},
target[key],
value
)
: $.widget.extend(
{
},
value
))
: (target[key] = value));
return target;
}),
($.widget.bridge = function (
name, object
) {
var fullName = object.prototype.widgetFullName || name;
$.fn[name] = function (
options
) {
var isMethodCall = "string" == typeof options,
args = slice.call(
arguments,
1
),
returnValue = this;
return (
(options =
!isMethodCall && args.length
? $.widget.extend.apply(
null,
[options,].concat(
args
)
)
: options),
isMethodCall
? this.each(
function (
) {
var methodValue,
instance = $.data(
this,
fullName
);
return "instance" === options
? ((returnValue = instance), !1)
: instance
? $.isFunction(
instance[options]
) &&
"_" !== options.charAt(
0
)
? (methodValue = instance[options].apply(
instance,
args,
)) !== instance && undefined !== methodValue
? ((returnValue =
methodValue && methodValue.jquery
? returnValue.pushStack(
methodValue.get(
)
)
: methodValue),
!1)
: void 0
: $.error(
"no such method '" +
options +
"' for " +
name +
" widget instance",
)
: $.error(
"cannot call methods on " +
name +
" prior to initialization; attempted to call method '" +
options +
"'",
);
}
)
: this.each(
function (
) {
var instance = $.data(
this,
fullName
);
instance
? instance.option(
options || {
}
)._init(
)
: $.data(
this,
fullName,
new object(
options,
this
)
);
}
),
returnValue
);
};
}),
($.Widget = function (
) {}),
($.Widget._childConstructors = []),
($.Widget.prototype = {
widgetName: "widget",
widgetEventPrefix: "",
defaultElement: "<div>",
options: {
disabled: !1,
create: null,
},
_createWidget: function (
options, element
) {
(element = $(
element || this.defaultElement || this
)[0]),
(this.element = $(
element
)),
(this.uuid = uuid++),
(this.eventNamespace = "." + this.widgetName + this.uuid),
(this.options = $.widget.extend(
{
},
this.options,
this._getCreateOptions(
),
options,
)),
(this.bindings = $(
)),
(this.hoverable = $(
)),
(this.focusable = $(
)),
element !== this &&
($.data(
element,
this.widgetFullName,
this
),
this._on(
!0,
this.element,
{
remove: function (
event
) {
event.target === element && this.destroy(
);
},
}
),
(this.document = $(
element.style
? element.ownerDocument
: element.document || element,
)),
(this.window = $(
this.document[0].defaultView || this.document[0].parentWindow,
))),
this._create(
),
this._trigger(
"create",
null,
this._getCreateEventData(
)
),
this._init(
);
},
_getCreateOptions: $.noop,
_getCreateEventData: $.noop,
_create: $.noop,
_init: $.noop,
destroy: function (
) {
this._destroy(
),
this.element
.unbind(
this.eventNamespace
)
.removeData(
this.widgetFullName
)
.removeData(
$.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: $.noop,
widget: function (
) {
return this.element;
},
option: function (
key, value
) {
var parts,
curOption,
i,
options = key;
if (0 === arguments.length)
return $.widget.extend(
{
},
this.options
);
if ("string" == typeof key)
if (
((options = {
}),
(parts = key.split(
"."
)),
(key = parts.shift(
)),
parts.length)
) {
for (
curOption = options[key] = $.widget.extend(
{
},
this.options[key],
),
i = 0;
i < parts.length - 1;
i++
)
(curOption[parts[i]] = curOption[parts[i]] || {
}),
(curOption = curOption[parts[i]]);
if (((key = parts.pop(
)), undefined === value))
return undefined === curOption[key] ? null : curOption[key];
curOption[key] = value;
} else {
if (undefined === value)
return undefined === this.options[key]
? null
: this.options[key];
options[key] = value;
}
return this._setOptions(
options
), this;
},
_setOptions: function (
options
) {
var key;
for (key in options) this._setOption(
key,
options[key]
);
return this;
},
_setOption: function (
key, value
) {
return (
(this.options[key] = value),
"disabled" === key &&
(this.widget(
).toggleClass(
this.widgetFullName + "-disabled",
!!value,
),
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 (
suppressDisabledCheck, element, handlers
) {
var delegateElement,
instance = this;
"boolean" != typeof suppressDisabledCheck &&
((handlers = element),
(element = suppressDisabledCheck),
(suppressDisabledCheck = !1)),
handlers
? ((element = delegateElement = $(
element
)),
(this.bindings = this.bindings.add(
element
)))
: ((handlers = element),
(element = this.element),
(delegateElement = this.widget(
))),
$.each(
handlers,
function (
event, handler
) {
function handlerProxy(
) {
if (
suppressDisabledCheck ||
(!0 !== instance.options.disabled &&
!$(
this
).hasClass(
"ui-state-disabled"
))
)
return ("string" == typeof handler
? instance[handler]
: handler
).apply(
instance,
arguments
);
}
"string" != typeof handler &&
(handlerProxy.guid = handler.guid =
handler.guid || handlerProxy.guid || $.guid++);
var match = event.match(
/^(\w+)\s*(.*)$/
),
eventName = match[1] + instance.eventNamespace,
selector = match[2];
selector
? delegateElement.delegate(
selector,
eventName,
handlerProxy
)
: element.bind(
eventName,
handlerProxy
);
}
);
},
_off: function (
element, eventName
) {
(eventName =
(eventName || "").split(
" "
).join(
this.eventNamespace + " "
) +
this.eventNamespace),
element.unbind(
eventName
).undelegate(
eventName
);
},
_delay: function (
handler, delay
) {
var instance = this;
return setTimeout(
function (
) {
return ("string" == typeof handler
? instance[handler]
: handler
).apply(
instance,
arguments
);
},
delay || 0
);
},
_hoverable: function (
element
) {
(this.hoverable = this.hoverable.add(
element
)),
this._on(
element,
{
mouseenter: function (
event
) {
$(
event.currentTarget
).addClass(
"ui-state-hover"
);
},
mouseleave: function (
event
) {
$(
event.currentTarget
).removeClass(
"ui-state-hover"
);
},
}
);
},
_focusable: function (
element
) {
(this.focusable = this.focusable.add(
element
)),
this._on(
element,
{
focusin: function (
event
) {
$(
event.currentTarget
).addClass(
"ui-state-focus"
);
},
focusout: function (
event
) {
$(
event.currentTarget
).removeClass(
"ui-state-focus"
);
},
}
);
},
_trigger: function (
type, event, data
) {
var prop,
orig,
callback = this.options[type];
if (
((data = data || {
}),
((event = $.Event(
event
)).type = (type === this.widgetEventPrefix
? type
: this.widgetEventPrefix + type
).toLowerCase(
)),
(event.target = this.element[0]),
(orig = event.originalEvent))
)
for (prop in orig) prop in event || (event[prop] = orig[prop]);
return (
this.element.trigger(
event,
data
),
!(
($.isFunction(
callback
) &&
!1 ===
callback.apply(
this.element[0],
[event,].concat(
data
)
)) ||
event.isDefaultPrevented(
)
)
);
},
}),
$.each(
{
show: "fadeIn",
hide: "fadeOut",
},
function (
method, defaultEffect
) {
$.Widget.prototype["_" + method] = function (
element,
options,
callback,
) {
"string" == typeof options && (options = {
effect: options,
});
var hasOptions,
effectName = options
? !0 === options || "number" == typeof options
? defaultEffect
: options.effect || defaultEffect
: method;
"number" == typeof (options = options || {
}) &&
(options = {
duration: options,
}),
(hasOptions = !$.isEmptyObject(
options
)),
(options.complete = callback),
options.delay && element.delay(
options.delay
),
hasOptions && $.effects && $.effects.effect[effectName]
? element[method](
options
)
: effectName !== method && element[effectName]
? element[effectName](
options.duration,
options.easing,
callback,
)
: element.queue(
function (
next
) {
$(
this
)[method](
),
callback && callback.call(
element[0]
),
next(
);
}
);
};
},
);
})(
jQuery
),
(function (
$, undefined
) {
var rcapitals = /[A-Z]/g,
replaceFunction = function (
c
) {
return "-" + c.toLowerCase(
);
};
$.extend(
$.Widget.prototype,
{
_getCreateOptions: function (
) {
var option,
value,
elem = this.element[0],
options = {
};
if (!$.mobile.getAttribute(
elem,
"defaults"
))
for (option in this.options)
null !=
(value = $.mobile.getAttribute(
elem,
option.replace(
rcapitals,
replaceFunction
),
)) && (options[option] = value);
return options;
},
}
),
($.mobile.widget = $.Widget);
})(
jQuery
),
(function (
$
) {
var $html = $(
"html"
);
$.widget(
"mobile.loader",
{
options: {
theme: "a",
textVisible: !1,
html: "",
text: "loading",
},
defaultHtml:
"<div class='ui-loader'><span class='ui-icon-loading'></span><h1></h1></div>",
fakeFixLoader: function (
) {
var activeBtn = $(
"." + $.mobile.activeBtnClass
).first(
);
this.element.css(
{
top:
($.support.scrollTop &&
this.window.scrollTop(
) + this.window.height(
) / 2) ||
(activeBtn.length && activeBtn.offset(
).top) ||
100,
}
);
},
checkLoaderPosition: function (
) {
var offset = this.element.offset(
),
scrollTop = this.window.scrollTop(
),
screenHeight = $.mobile.getScreenHeight(
);
(offset.top < scrollTop || offset.top - scrollTop > screenHeight) &&
(this.element.addClass(
"ui-loader-fakefix"
),
this.fakeFixLoader(
),
this.window
.unbind(
"scroll",
this.checkLoaderPosition
)
.bind(
"scroll",
$.proxy(
this.fakeFixLoader,
this
)
));
},
resetHtml: function (
) {
this.element.html(
$(
this.defaultHtml
).html(
)
);
},
show: function (
theme, msgText, textonly
) {
var textVisible, message, loadSettings;
this.resetHtml(
),
"object" === $.type(
theme
)
? (theme = (loadSettings = $.extend(
{
},
this.options,
theme
))
.theme)
: ((loadSettings = this.options),
(theme = theme || loadSettings.theme)),
(message =
msgText || (!1 === loadSettings.text ? "" : loadSettings.text)),
$html.addClass(
"ui-loading"
),
(textVisible = loadSettings.textVisible),
this.element.attr(
"class",
"ui-loader ui-corner-all ui-body-" +
theme +
" ui-loader-" +
(textVisible || msgText || theme.text ? "verbose" : "default") +
(loadSettings.textonly || textonly
? " ui-loader-textonly"
: ""),
),
loadSettings.html
? this.element.html(
loadSettings.html
)
: this.element.find(
"h1"
).text(
message
),
this.element.appendTo(
$.mobile.pageContainer
),
this.checkLoaderPosition(
),
this.window.bind(
"scroll",
$.proxy(
this.checkLoaderPosition,
this
)
);
},
hide: function (
) {
$html.removeClass(
"ui-loading"
),
this.options.text && this.element.removeClass(
"ui-loader-fakefix"
),
$.mobile.window.unbind(
"scroll",
this.fakeFixLoader
),
$.mobile.window.unbind(
"scroll",
this.checkLoaderPosition
);
},
}
);
})(
jQuery
),
/*!
* jQuery hashchange event - v1.3 - 7/21/2010
* http://benalman.com/projects/jquery-hashchange-plugin/
*
* Copyright (c) 2010 "Cowboy" Ben Alman
* Dual licensed under the MIT and GPL licenses.
* http://benalman.com/about/license/
*/
(function (
$, window, undefined
) {
var fake_onhashchange,
doc = document,
special = $.event.special,
doc_mode = doc.documentMode,
supports_onhashchange =
"onhashchange" in window && (undefined === doc_mode || doc_mode > 7);
function get_fragment(
url
) {
return (
"#" + (url = url || location.href).replace(
/^[^#]*#?(.*)$/,
"$1"
)
);
}
($.fn.hashchange = function (
fn
) {
return fn
? this.bind(
"hashchange",
fn
)
: this.trigger(
"hashchange"
);
}),
($.fn.hashchange.delay = 50),
(special.hashchange = $.extend(
special.hashchange,
{
setup: function (
) {
if (supports_onhashchange) return !1;
$(
fake_onhashchange.start
);
},
teardown: function (
) {
if (supports_onhashchange) return !1;
$(
fake_onhashchange.stop
);
},
}
)),
(fake_onhashchange = (function (
) {
var timeout_id,
iframe,
iframe_src,
self = {
},
last_hash = get_fragment(
),
fn_retval = function (
val
) {
return val;
},
history_set = fn_retval,
history_get = fn_retval;
function poll(
) {
var hash = get_fragment(
),
history_hash = history_get(
last_hash
);
hash !== last_hash
? (history_set(
(last_hash = hash),
history_hash
),
$(
window
).trigger(
"hashchange"
))
: history_hash !== last_hash &&
(location.href =
location.href.replace(
/#.*/,
""
) + history_hash),
(timeout_id = setTimeout(
poll,
$.fn.hashchange.delay
));
}
return (
(self.start = function (
) {
timeout_id || poll(
);
}),
(self.stop = function (
) {
timeout_id && clearTimeout(
timeout_id
), (timeout_id = undefined);
}),
window.attachEvent &&
!window.addEventListener &&
!supports_onhashchange &&
((self.start = function (
) {
iframe ||
((iframe_src =
(iframe_src = $.fn.hashchange.src) &&
iframe_src + get_fragment(
)),
(iframe = $(
'<iframe tabindex="-1" title="empty"/>'
)
.hide(
)
.one(
"load",
function (
) {
iframe_src || history_set(
get_fragment(
)
), poll(
);
}
)
.attr(
"src",
iframe_src || "javascript:0"
)
.insertAfter(
"body"
)[0].contentWindow),
(doc.onpropertychange = function (
) {
try {
"title" === event.propertyName &&
(iframe.document.title = doc.title);
} catch (e) {}
}));
}),
(self.stop = fn_retval),
(history_get = function (
) {
return get_fragment(
iframe.location.href
);
}),
(history_set = function (
hash, history_hash
) {
var iframe_doc = iframe.document,
domain = $.fn.hashchange.domain;
hash !== history_hash &&
((iframe_doc.title = doc.title),
iframe_doc.open(
),
domain &&
iframe_doc.write(
'<script>document.domain="' + domain + '"</script>',
),
iframe_doc.close(
),
(iframe.location.hash = hash));
})),
self
);
})(
));
})(
jQuery,
this
),
(function (
$, undefined
) {
var doc, bool, docElem, refNode, fakeBody, div;
/*! matchMedia() polyfill - Test a CSS media type/query in JS. Authors & copyright (c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas. Dual MIT/BSD license */
(window.matchMedia =
window.matchMedia ||
((docElem = (doc = document).documentElement),
(refNode = docElem.firstElementChild || docElem.firstChild),
(fakeBody = doc.createElement(
"body"
)),
((div = doc.createElement(
"div"
)).id = "mq-test-1"),
(div.style.cssText = "position:absolute;top:-100em"),
(fakeBody.style.background = "none"),
fakeBody.appendChild(
div
),
function (
q
) {
return (
(div.innerHTML =
'&shy;<style media="' +
q +
'"> #mq-test-1 { width: 42px; }</style>'),
docElem.insertBefore(
fakeBody,
refNode
),
(bool = 42 === div.offsetWidth),
docElem.removeChild(
fakeBody
),
{
matches: bool,
media: q,
}
);
})),
($.mobile.media = function (
q
) {
return window.matchMedia(
q
).matches;
});
})(
jQuery
),
(function (
$, undefined
) {
var support = {
touch: "ontouchend" in document,
};
($.mobile.support = $.mobile.support || {
}),
$.extend(
$.support,
support
),
$.extend(
$.mobile.support,
support
);
})(
jQuery
),
(function (
$, undefined
) {
$.extend(
$.support,
{
orientation: "orientation" in window && "onorientationchange" in window,
}
);
})(
jQuery
),
(function (
$, undefined
) {
function propExists(
prop
) {
var v,
uc_prop = prop.charAt(
0
).toUpperCase(
) + prop.substr(
1
),
props = (prop + " " + vendors.join(
uc_prop + " "
) + uc_prop).split(
" ",
);
for (v in props) if (undefined !== fbCSS[props[v]]) return !0;
}
var nokiaLTE7_3,
supports,
element,
documentElement,
getComputedStyle,
rebase,
fauxBase,
base,
fauxEle,
href,
w,
ua,
platform,
wkmatch,
wkversion,
ffmatch,
ffversion,
operammobilematch,
omversion,
fakeBody = $(
"<body>"
).prependTo(
"html"
),
fbCSS = fakeBody[0].style,
vendors = ["Webkit", "Moz", "O",],
webos = "palmGetResource" in window,
operamini =
window.operamini &&
"[object OperaMini]" === {
}.toString.call(
window.operamini
),
bb = window.blackberry && !propExists(
"-webkit-transform"
);
$.extend(
$.mobile,
{
browser: {
},
}
),
($.mobile.browser.oldIE = (function (
) {
var v = 3,
div = document.createElement(
"div"
),
a = div.all || [];
do {
div.innerHTML = "\x3c!--[if gt IE " + ++v + "]><br><![endif]--\x3e";
} while (a[0]);
return v > 4 ? v : !v;
})(
)),
$.extend(
$.support,
{
pushState:
"pushState" in history &&
"replaceState" in history &&
!(
window.navigator.userAgent.indexOf(
"Firefox"
) >= 0 &&
window.top !== window
) &&
-1 === window.navigator.userAgent.search(
/CriOS/
),
mediaquery: $.mobile.media(
"only all"
),
cssPseudoElement: !!propExists(
"content"
),
touchOverflow: !!propExists(
"overflowScrolling"
),
cssTransform3d: (function (
) {
var el,
transforms,
t,
mqProp = "transform-3d",
ret = $.mobile.media(
"(-" +
vendors.join(
"-" + mqProp + "),(-"
) +
"-" +
mqProp +
"),(" +
mqProp +
")",
);
if (ret) return !!ret;
for (t in ((el = document.createElement(
"div"
)),
(transforms = {
MozTransform: "-moz-transform",
transform: "transform",
}),
fakeBody.append(
el
),
transforms))
undefined !== el.style[t] &&
((el.style[t] = "translate3d( 100px, 1px, 1px )"),
(ret = window
.getComputedStyle(
el
)
.getPropertyValue(
transforms[t]
)));
return !!ret && "none" !== ret;
})(
),
boxShadow: !!propExists(
"boxShadow"
) && !bb,
fixedPosition:
((w = window),
(ua = navigator.userAgent),
(platform = navigator.platform),
(wkmatch = ua.match(
/AppleWebKit\/([0-9]+)/
)),
(wkversion = !!wkmatch && wkmatch[1]),
(ffmatch = ua.match(
/Fennec\/([0-9]+)/
)),
(ffversion = !!ffmatch && ffmatch[1]),
(operammobilematch = ua.match(
/Opera Mobi\/([0-9]+)/
)),
(omversion = !!operammobilematch && operammobilematch[1]),
!(
((platform.indexOf(
"iPhone"
) > -1 ||
platform.indexOf(
"iPad"
) > -1 ||
platform.indexOf(
"iPod"
) > -1) &&
wkversion &&
wkversion < 534) ||
(w.operamini &&
"[object OperaMini]" === {
}.toString.call(
w.operamini
)) ||
(operammobilematch && omversion < 7458) ||
(ua.indexOf(
"Android"
) > -1 && wkversion && wkversion < 533) ||
(ffversion && ffversion < 6) ||
("palmGetResource" in window && wkversion && wkversion < 534) ||
(ua.indexOf(
"MeeGo"
) > -1 &&
ua.indexOf(
"NokiaBrowser/8.5.0"
) > -1)
)),
scrollTop:
("pageXOffset" in window ||
"scrollTop" in document.documentElement ||
"scrollTop" in fakeBody[0]) &&
!webos &&
!operamini,
dynamicBaseTag:
((fauxBase =
location.protocol +
"//" +
location.host +
location.pathname +
"ui-dir/"),
(base = $(
"head base"
)),
(fauxEle = null),
(href = ""),
base.length
? (href = base.attr(
"href"
))
: (base = fauxEle = $(
"<base>",
{
href: fauxBase,
}
).appendTo(
"head",
)),
(rebase = $(
"<a href='testurl' />"
).prependTo(
fakeBody
)[0].href),
(base[0].href = href || location.pathname),
fauxEle && fauxEle.remove(
),
0 === rebase.indexOf(
fauxBase
)),
cssPointerEvents:
((element = document.createElement(
"x"
)),
(documentElement = document.documentElement),
(getComputedStyle = window.getComputedStyle),
"pointerEvents" in element.style &&
((element.style.pointerEvents = "auto"),
(element.style.pointerEvents = "x"),
documentElement.appendChild(
element
),
(supports =
getComputedStyle &&
"auto" === getComputedStyle(
element,
""
).pointerEvents),
documentElement.removeChild(
element
),
!!supports)),
boundingRect:
void 0 !== document.createElement(
"div"
).getBoundingClientRect,
inlineSVG: function (
) {
var w = window,
svg = !(
!w.document.createElementNS ||
!w.document.createElementNS(
"http://www.w3.org/2000/svg",
"svg"
)
.createSVGRect ||
(w.opera && -1 === navigator.userAgent.indexOf(
"Chrome"
))
),
support = function (
data
) {
(data && svg) || $(
"html"
).addClass(
"ui-nosvg"
);
},
img = new w.Image(
);
(img.onerror = function (
) {
support(
!1
);
}),
(img.onload = function (
) {
support(
1 === img.width && 1 === img.height
);
}),
(img.src =
"");
},
}
),
fakeBody.remove(
),
(nokiaLTE7_3 = (function (
) {
var ua = window.navigator.userAgent;
return (
ua.indexOf(
"Nokia"
) > -1 &&
(ua.indexOf(
"Symbian/3"
) > -1 || ua.indexOf(
"Series60/5"
) > -1) &&
ua.indexOf(
"AppleWebKit"
) > -1 &&
ua.match(
/(BrowserNG|NokiaBrowser)\/7\.[0-3]/
)
);
})(
)),
($.mobile.gradeA = function (
) {
return (
(($.support.mediaquery && $.support.cssPseudoElement) ||
($.mobile.browser.oldIE && $.mobile.browser.oldIE >= 8)) &&
($.support.boundingRect ||
null !== $.fn.jquery.match(
/1\.[0-7+]\.[0-9+]?/
))
);
}),
($.mobile.ajaxBlacklist =
(window.blackberry && !window.WebKitPoint) ||
operamini ||
nokiaLTE7_3),
nokiaLTE7_3 &&
$(
function (
) {
$(
"head link[rel='stylesheet']"
)
.attr(
"rel",
"alternate stylesheet"
)
.attr(
"rel",
"stylesheet"
);
}
),
$.support.boxShadow || $(
"html"
).addClass(
"ui-noboxshadow"
);
})(
jQuery
),
(function (
$, undefined
) {
var self,
$win = $.mobile.window,
dummyFnToInitNavigate = function (
) {};
($.event.special.beforenavigate = {
setup: function (
) {
$win.on(
"navigate",
dummyFnToInitNavigate
);
},
teardown: function (
) {
$win.off(
"navigate",
dummyFnToInitNavigate
);
},
}),
($.event.special.navigate = self = {
bound: !1,
pushStateEnabled: !0,
originalEventName: void 0,
isPushStateEnabled: function (
) {
return (
$.support.pushState &&
!0 === $.mobile.pushStateEnabled &&
this.isHashChangeEnabled(
)
);
},
isHashChangeEnabled: function (
) {
return !0 === $.mobile.hashListeningEnabled;
},
popstate: function (
event
) {
var newEvent = new $.Event(
"navigate"
),
beforeNavigate = new $.Event(
"beforenavigate"
),
state = event.originalEvent.state || {
};
(beforeNavigate.originalEvent = event),
$win.trigger(
beforeNavigate
),
beforeNavigate.isDefaultPrevented(
) ||
(event.historyState && $.extend(
state,
event.historyState
),
(newEvent.originalEvent = event),
setTimeout(
function (
) {
$win.trigger(
newEvent,
{
state: state,
}
);
},
0
));
},
hashchange: function (
event
) {
var newEvent = new $.Event(
"navigate"
),
beforeNavigate = new $.Event(
"beforenavigate"
);
(beforeNavigate.originalEvent = event),
$win.trigger(
beforeNavigate
),
beforeNavigate.isDefaultPrevented(
) ||
((newEvent.originalEvent = event),
$win.trigger(
newEvent,
{
state: event.hashchangeState || {
},
}
));
},
setup: function (
) {
self.bound ||
((self.bound = !0),
self.isPushStateEnabled(
)
? ((self.originalEventName = "popstate"),
$win.bind(
"popstate.navigate",
self.popstate
))
: self.isHashChangeEnabled(
) &&
((self.originalEventName = "hashchange"),
$win.bind(
"hashchange.navigate",
self.hashchange
)));
},
});
})(
jQuery
),
(function (
$, undefined
) {
var path, $base;
($.mobile.path = path = {
uiStateKey: "&ui-state",
urlParseRE: /^\s*(((([^:\/#\?]+:)?(?:(\/\/)((?:(([^:@\/#\?]+)(?:\:([^:@\/#\?]+))?)@)?(([^:\/#\?\]\[]+|\[[^\/\]@#?]+\])(?:\:([0-9]+))?))?)?)?((\/?(?:[^\/\?#]+\/+)*)([^\?#]*)))?(\?[^#]+)?)(#.*)?/,
getLocation: function (
url
) {
var uri = url
? this.parseUrl(
url
)
: location,
hash = this.parseUrl(
url || location.href
).hash;
return (
(hash = "#" === hash ? "" : hash),
uri.protocol + "//" + uri.host + uri.pathname + uri.search + hash
);
},
getDocumentUrl: function (
asParsedObject
) {
return asParsedObject
? $.extend(
{
},
path.documentUrl
)
: path.documentUrl.href;
},
parseLocation: function (
) {
return this.parseUrl(
this.getLocation(
)
);
},
parseUrl: function (
url
) {
if ("object" === $.type(
url
)) return url;
var matches = path.urlParseRE.exec(
url || ""
) || [];
return {
href: matches[0] || "",
hrefNoHash: matches[1] || "",
hrefNoSearch: matches[2] || "",
domain: matches[3] || "",
protocol: matches[4] || "",
doubleSlash: matches[5] || "",
authority: matches[6] || "",
username: matches[8] || "",
password: matches[9] || "",
host: matches[10] || "",
hostname: matches[11] || "",
port: matches[12] || "",
pathname: matches[13] || "",
directory: matches[14] || "",
filename: matches[15] || "",
search: matches[16] || "",
hash: matches[17] || "",
};
},
makePathAbsolute: function (
relPath, absPath
) {
var absStack, relStack, i, d;
if (relPath && "/" === relPath.charAt(
0
)) return relPath;
for (
relPath = relPath || "",
absStack = (absPath = absPath
? absPath.replace(
/^\/|(\/[^\/]*|[^\/]+)$/g,
""
)
: "")
? absPath.split(
"/"
)
: [],
relStack = relPath.split(
"/"
),
i = 0;
i < relStack.length;
i++
)
switch ((d = relStack[i])) {
case ".":
break;
case "..":
absStack.length && absStack.pop(
);
break;
default:
absStack.push(
d
);
}
return "/" + absStack.join(
"/"
);
},
isSameDomain: function (
absUrl1, absUrl2
) {
return (
path.parseUrl(
absUrl1
).domain === path.parseUrl(
absUrl2
).domain
);
},
isRelativeUrl: function (
url
) {
return "" === path.parseUrl(
url
).protocol;
},
isAbsoluteUrl: function (
url
) {
return "" !== path.parseUrl(
url
).protocol;
},
makeUrlAbsolute: function (
relUrl, absUrl
) {
if (!path.isRelativeUrl(
relUrl
)) return relUrl;
undefined === absUrl && (absUrl = this.documentBase);
var relObj = path.parseUrl(
relUrl
),
absObj = path.parseUrl(
absUrl
),
protocol = relObj.protocol || absObj.protocol,
doubleSlash = relObj.protocol
? relObj.doubleSlash
: relObj.doubleSlash || absObj.doubleSlash,
authority = relObj.authority || absObj.authority,
hasPath = "" !== relObj.pathname;
return (
protocol +
doubleSlash +
authority +
path.makePathAbsolute(
relObj.pathname || absObj.filename,
absObj.pathname,
) +
(relObj.search || (!hasPath && absObj.search) || "") +
relObj.hash
);
},
addSearchParams: function (
url, params
) {
var u = path.parseUrl(
url
),
p = "object" == typeof params
? $.param(
params
)
: params,
s = u.search || "?";
return (
u.hrefNoSearch +
s +
("?" !== s.charAt(
s.length - 1
)
? "&"
: "") +
p +
(u.hash || "")
);
},
convertUrlToDataUrl: function (
absUrl
) {
var u = path.parseUrl(
absUrl
);
return path.isEmbeddedPage(
u
)
? u.hash
.split(
"&ui-state=dialog"
)[0]
.replace(
/^#/,
""
)
.replace(
/\?.*$/,
""
)
: path.isSameDomain(
u,
this.documentBase
)
? u.hrefNoHash
.replace(
this.documentBase.domain,
""
)
.split(
"&ui-state=dialog"
)[0]
: window.decodeURIComponent(
absUrl
);
},
get: function (
newPath
) {
return (
undefined === newPath && (newPath = path.parseLocation(
).hash),
path.stripHash(
newPath
).replace(
/[^\/]*\.[^\/*]+$/,
""
)
);
},
set: function (
path
) {
location.hash = path;
},
isPath: function (
url
) {
return /\//.test(
url
);
},
clean: function (
url
) {
return url.replace(
this.documentBase.domain,
""
);
},
stripHash: function (
url
) {
return url.replace(
/^#/,
""
);
},
stripQueryParams: function (
url
) {
return url.replace(
/\?.*$/,
""
);
},
cleanHash: function (
hash
) {
return path.stripHash(
hash.replace(
/\?.*$/,
""
).replace(
"&ui-state=dialog",
""
),
);
},
isHashValid: function (
hash
) {
return /^#[^#]+$/.test(
hash
);
},
isExternal: function (
url
) {
var u = path.parseUrl(
url
);
return !(!u.protocol || u.domain === this.documentUrl.domain);
},
hasProtocol: function (
url
) {
return /^(:?\w+:)/.test(
url
);
},
isEmbeddedPage: function (
url
) {
var u = path.parseUrl(
url
);
return "" !== u.protocol
? !this.isPath(
u.hash
) &&
u.hash &&
(u.hrefNoHash === this.documentUrl.hrefNoHash ||
(this.documentBaseDiffers &&
u.hrefNoHash === this.documentBase.hrefNoHash))
: /^#/.test(
u.href
);
},
squash: function (
url, resolutionUrl
) {
var href,
cleanedUrl,
search,
stateIndex,
isPath = this.isPath(
url
),
uri = this.parseUrl(
url
),
preservedHash = uri.hash,
uiState = "";
return (
(resolutionUrl =
resolutionUrl ||
(path.isPath(
url
)
? path.getLocation(
)
: path.getDocumentUrl(
))),
(cleanedUrl = isPath
? path.stripHash(
url
)
: url),
(stateIndex = (cleanedUrl = path.isPath(
uri.hash
)
? path.stripHash(
uri.hash
)
: cleanedUrl).indexOf(
this.uiStateKey
)) > -1 &&
((uiState = cleanedUrl.slice(
stateIndex
)),
(cleanedUrl = cleanedUrl.slice(
0,
stateIndex
))),
(href = path.makeUrlAbsolute(
cleanedUrl,
resolutionUrl
)),
(search = this.parseUrl(
href
).search),
isPath
? ((path.isPath(
preservedHash
) ||
0 ===
preservedHash.replace(
"#",
""
).indexOf(
this.uiStateKey
)) &&
(preservedHash = ""),
uiState &&
-1 === preservedHash.indexOf(
this.uiStateKey
) &&
(preservedHash += uiState),
-1 === preservedHash.indexOf(
"#"
) &&
"" !== preservedHash &&
(preservedHash = "#" + preservedHash),
(href =
(href = path.parseUrl(
href
)).protocol +
"//" +
href.host +
href.pathname +
search +
preservedHash))
: (href += href.indexOf(
"#"
) > -1
? uiState
: "#" + uiState),
href
);
},
isPreservableHash: function (
hash
) {
return 0 === hash.replace(
"#",
""
).indexOf(
this.uiStateKey
);
},
hashToSelector: function (
hash
) {
var hasHash = "#" === hash.substring(
0,
1
);
return (
hasHash && (hash = hash.substring(
1
)),
(hasHash ? "#" : "") +
hash.replace(
/([!"#$%&'()*+,./:;<=>?@[\]^`{|}~])/g,
"\\$1"
)
);
},
getFilePath: function (
path
) {
var splitkey = "&" + $.mobile.subPageUrlKey;
return path && path.split(
splitkey
)[0].split(
"&ui-state=dialog"
)[0];
},
isFirstPageUrl: function (
url
) {
var u = path.parseUrl(
path.makeUrlAbsolute(
url,
this.documentBase
)
),
samePath =
u.hrefNoHash === this.documentUrl.hrefNoHash ||
(this.documentBaseDiffers &&
u.hrefNoHash === this.documentBase.hrefNoHash),
fp = $.mobile.firstPage,
fpId = fp && fp[0] ? fp[0].id : undefined;
return (
samePath &&
(!u.hash ||
"#" === u.hash ||
(fpId && u.hash.replace(
/^#/,
""
) === fpId))
);
},
isPermittedCrossDomainRequest: function (
docUrl, reqUrl
) {
return (
$.mobile.allowCrossDomainPages &&
("file:" === docUrl.protocol || "content:" === docUrl.protocol) &&
-1 !== reqUrl.search(
/^https?:/
)
);
},
}),
(path.documentUrl = path.parseLocation(
)),
($base = $(
"head"
).find(
"base"
)),
(path.documentBase = $base.length
? path.parseUrl(
path.makeUrlAbsolute(
$base.attr(
"href"
),
path.documentUrl.href
),
)
: path.documentUrl),
(path.documentBaseDiffers =
path.documentUrl.hrefNoHash !== path.documentBase.hrefNoHash),
(path.getDocumentBase = function (
asParsedObject
) {
return asParsedObject
? $.extend(
{
},
path.documentBase
)
: path.documentBase.href;
}),
$.extend(
$.mobile,
{
getDocumentUrl: path.getDocumentUrl,
getDocumentBase: path.getDocumentBase,
}
);
})(
jQuery
),
(function (
$, undefined
) {
($.mobile.History = function (
stack, index
) {
(this.stack = stack || []), (this.activeIndex = index || 0);
}),
$.extend(
$.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 (
url, data
) {
(data = data || {
}),
this.getNext(
) && this.clearForward(
),
data.hash &&
-1 === data.hash.indexOf(
"#"
) &&
(data.hash = "#" + data.hash),
(data.url = url),
this.stack.push(
data
),
(this.activeIndex = this.stack.length - 1);
},
clearForward: function (
) {
this.stack = this.stack.slice(
0,
this.activeIndex + 1
);
},
find: function (
url, stack, earlyReturn
) {
var entry,
i,
index,
length = (stack = stack || this.stack).length;
for (i = 0; i < length; i++)
if (
((entry = stack[i]),
(decodeURIComponent(
url
) === decodeURIComponent(
entry.url
) ||
decodeURIComponent(
url
) === decodeURIComponent(
entry.hash
)) &&
((index = i), earlyReturn))
)
return index;
return index;
},
closest: function (
url
) {
var closest,
a = this.activeIndex;
return (
undefined ===
(closest = this.find(
url,
this.stack.slice(
0,
a
)
)) &&
(closest =
undefined ===
(closest = this.find(
url,
this.stack.slice(
a
),
!0
))
? closest
: closest + a),
closest
);
},
direct: function (
opts
) {
var newActiveIndex = this.closest(
opts.url
),
a = this.activeIndex;
undefined !== newActiveIndex &&
((this.activeIndex = newActiveIndex), (this.previousIndex = a)),
newActiveIndex < a
? (opts.present || opts.back || $.noop)(
this.getActive(
),
"back",
)
: newActiveIndex > a
? (opts.present || opts.forward || $.noop)(
this.getActive(
),
"forward",
)
: undefined === newActiveIndex &&
opts.missing &&
opts.missing(
this.getActive(
)
);
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
var path = $.mobile.path,
initialHref = location.href;
($.mobile.Navigator = function (
history
) {
(this.history = history),
(this.ignoreInitialHashChange = !0),
$.mobile.window.bind(
{
"popstate.history": $.proxy(
this.popstate,
this
),
"hashchange.history": $.proxy(
this.hashchange,
this
),
}
);
}),
$.extend(
$.mobile.Navigator.prototype,
{
squash: function (
url, data
) {
var state,
href,
hash = path.isPath(
url
)
? path.stripHash(
url
)
: url;
return (
(href = path.squash(
url
)),
(state = $.extend(
{
hash: hash,
url: href,
},
data
)),
window.history.replaceState(
state,
state.title || document.title,
href,
),
state
);
},
hash: function (
url, href
) {
var parsed, loc, resolved;
return (
(parsed = path.parseUrl(
url
)),
(loc = path.parseLocation(
)).pathname + loc.search ===
parsed.pathname + parsed.search
? parsed.hash
? parsed.hash
: parsed.pathname + parsed.search
: path.isPath(
url
)
? (resolved = path.parseUrl(
href
)).pathname +
resolved.search +
(path.isPreservableHash(
resolved.hash
)
? resolved.hash.replace(
"#",
""
)
: "")
: url
);
},
go: function (
url, data, noEvents
) {
var state,
href,
hash,
popstateEvent,
isPopStateEvent = $.event.special.navigate.isPushStateEnabled(
);
(href = path.squash(
url
)),
(hash = this.hash(
url,
href
)),
noEvents &&
hash !== path.stripHash(
path.parseLocation(
).hash
) &&
(this.preventNextHashChange = noEvents),
(this.preventHashAssignPopState = !0),
(window.location.hash = hash),
(this.preventHashAssignPopState = !1),
(state = $.extend(
{
url: href,
hash: hash,
title: document.title,
},
data,
)),
isPopStateEvent &&
(((popstateEvent = new $.Event(
"popstate"
)).originalEvent = {
type: "popstate",
state: null,
}),
this.squash(
url,
state
),
noEvents ||
((this.ignorePopState = !0),
$.mobile.window.trigger(
popstateEvent
))),
this.history.add(
state.url,
state
);
},
popstate: function (
event
) {
var hash, state;
if ($.event.special.navigate.isPushStateEnabled(
)) {
if (this.preventHashAssignPopState)
return (
(this.preventHashAssignPopState = !1),
void event.stopImmediatePropagation(
)
);
if (this.ignorePopState) this.ignorePopState = !1;
else if (
event.originalEvent.state ||
1 !== this.history.stack.length ||
!this.ignoreInitialHashChange ||
((this.ignoreInitialHashChange = !1),
location.href !== initialHref)
) {
if (
((hash = path.parseLocation(
).hash),
!event.originalEvent.state && hash)
)
return (
(state = this.squash(
hash
)),
this.history.add(
state.url,
state
),
void (event.historyState = state)
);
this.history.direct(
{
url: (event.originalEvent.state || {
}).url || hash,
present: function (
historyEntry, direction
) {
(event.historyState = $.extend(
{
},
historyEntry
)),
(event.historyState.direction = direction);
},
}
);
} else event.preventDefault(
);
}
},
hashchange: function (
event
) {
var history, hash;
if (
$.event.special.navigate.isHashChangeEnabled(
) &&
!$.event.special.navigate.isPushStateEnabled(
)
) {
if (this.preventNextHashChange)
return (
(this.preventNextHashChange = !1),
void event.stopImmediatePropagation(
)
);
(history = this.history),
(hash = path.parseLocation(
).hash),
this.history.direct(
{
url: hash,
present: function (
historyEntry, direction
) {
(event.hashchangeState = $.extend(
{
},
historyEntry
)),
(event.hashchangeState.direction = direction);
},
missing: function (
) {
history.add(
hash,
{
hash: hash,
title: document.title,
}
);
},
}
);
}
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
($.mobile.navigate = function (
url, data, noEvents
) {
$.mobile.navigate.navigator.go(
url,
data,
noEvents
);
}),
($.mobile.navigate.history = new $.mobile.History(
)),
($.mobile.navigate.navigator = new $.mobile.Navigator(
$.mobile.navigate.history,
));
var loc = $.mobile.path.parseLocation(
);
$.mobile.navigate.history.add(
loc.href,
{
hash: loc.hash,
}
);
})(
jQuery
),
(function (
$, undefined
) {
var props = {
animation: {
},
transition: {
},
},
testElement = document.createElement(
"a"
),
vendorPrefixes = ["", "webkit-", "moz-", "o-",];
$.each(
["animation", "transition",],
function (
i, test
) {
var testName = 0 === i ? test + "-name" : test;
$.each(
vendorPrefixes,
function (
j, prefix
) {
if (undefined !== testElement.style[$.camelCase(
prefix + testName
)])
return (props[test].prefix = prefix), !1;
}
),
(props[test].duration = $.camelCase(
props[test].prefix + test + "-duration",
)),
(props[test].event = $.camelCase(
props[test].prefix + test + "-end"
)),
"" === props[test].prefix &&
(props[test].event = props[test].event.toLowerCase(
));
}
),
($.support.cssTransitions = undefined !== props.transition.prefix),
($.support.cssAnimations = undefined !== props.animation.prefix),
$(
testElement
).remove(
),
($.fn.animationComplete = function (
callback, type, fallbackTime
) {
var timer,
duration,
that = this,
animationType =
type && "animation" !== type ? "transition" : "animation";
return ($.support.cssTransitions && "transition" === animationType) ||
($.support.cssAnimations && "animation" === animationType)
? (undefined === fallbackTime &&
($(
this
).context !== document &&
(duration =
3e3 *
parseFloat(
$(
this
).css(
props[animationType].duration
)
)),
(0 === duration || undefined === duration || isNaN(
duration
)) &&
(duration = $.fn.animationComplete.defaultDuration)),
(timer = setTimeout(
function (
) {
$(
that
).off(
props[animationType].event
), callback.apply(
that
);
},
duration
)),
$(
this
).one(
props[animationType].event,
function (
) {
clearTimeout(
timer
), callback.call(
this,
arguments
);
}
))
: (setTimeout(
$.proxy(
callback,
this
),
0
), $(
this
));
}),
($.fn.animationComplete.defaultDuration = 1e3);
})(
jQuery
),
(function (
$, window, document, undefined
) {
var threshold,
i,
dataPropertyName = "virtualMouseBindings",
virtualEventNames = "vmouseover vmousedown vmousemove vmouseup vclick vmouseout vmousecancel".split(
" ",
),
touchEventProps = "clientX clientY pageX pageY screenX screenY".split(
" ",
),
mouseHookProps = $.event.mouseHooks ? $.event.mouseHooks.props : [],
mouseEventProps = $.event.props.concat(
mouseHookProps
),
activeDocHandlers = {
},
resetTimerID = 0,
startX = 0,
startY = 0,
didScroll = !1,
clickBlockList = [],
blockMouseTriggers = !1,
blockTouchTriggers = !1,
eventCaptureSupported = "addEventListener" in document,
$document = $(
document
),
nextTouchID = 1,
lastTouchID = 0;
function getNativeEvent(
event
) {
for (; event && void 0 !== event.originalEvent; )
event = event.originalEvent;
return event;
}
function getVirtualBindingFlags(
element
) {
for (var b, k, flags = {
}; element; ) {
for (k in (b = $.data(
element,
dataPropertyName
)))
b[k] && (flags[k] = flags.hasVirtualBinding = !0);
element = element.parentNode;
}
return flags;
}
function disableTouchBindings(
) {
blockTouchTriggers = !0;
}
function disableMouseBindings(
) {
blockTouchTriggers = !1;
}
function startResetTimer(
) {
clearResetTimer(
),
(resetTimerID = setTimeout(
function (
) {
(resetTimerID = 0),
(lastTouchID = 0),
(clickBlockList.length = 0),
(blockMouseTriggers = !1),
disableTouchBindings(
);
},
$.vmouse.resetTimerDuration
));
}
function clearResetTimer(
) {
resetTimerID && (clearTimeout(
resetTimerID
), (resetTimerID = 0));
}
function triggerVirtualEvent(
eventType, event, flags
) {
var ve;
return (
((flags && flags[eventType]) ||
(!flags &&
(function (
element, eventType
) {
for (var b; element; ) {
if (
(b = $.data(
element,
dataPropertyName
)) &&
(!eventType || b[eventType])
)
return element;
element = element.parentNode;
}
return null;
})(
event.target,
eventType
))) &&
((ve = (function (
event, eventType
) {
var oe,
props,
ne,
prop,
ct,
touch,
i,
j,
len,
t = event.type;
if (
(((event = $.Event(
event
)).type = eventType),
(oe = event.originalEvent),
(props = $.event.props),
t.search(
/^(mouse|click)/
) > -1 && (props = mouseEventProps),
oe)
)
for (i = props.length; i; )
event[(prop = props[--i])] = oe[prop];
if (
(t.search(
/mouse(down|up)|click/
) > -1 &&
!event.which &&
(event.which = 1),
-1 !== t.search(
/^touch/
) &&
((t = (ne = getNativeEvent(
oe
)).touches),
(ct = ne.changedTouches),
(touch =
t && t.length ? t[0] : ct && ct.length ? ct[0] : void 0)))
)
for (j = 0, len = touchEventProps.length; j < len; j++)
event[(prop = touchEventProps[j])] = touch[prop];
return event;
})(
event,
eventType
)),
$(
event.target
).trigger(
ve
)),
ve
);
}
function mouseEventCallback(
event
) {
var ve,
touchID = $.data(
event.target,
"virtualTouchID"
);
blockMouseTriggers ||
(lastTouchID && lastTouchID === touchID) ||
((ve = triggerVirtualEvent(
"v" + event.type,
event
)) &&
(ve.isDefaultPrevented(
) && event.preventDefault(
),
ve.isPropagationStopped(
) && event.stopPropagation(
),
ve.isImmediatePropagationStopped(
) &&
event.stopImmediatePropagation(
)));
}
function handleTouchStart(
event
) {
var target,
flags,
t,
touches = getNativeEvent(
event
).touches;
touches &&
1 === touches.length &&
(flags = getVirtualBindingFlags(
(target = event.target)
))
.hasVirtualBinding &&
((lastTouchID = nextTouchID++),
$.data(
target,
"virtualTouchID",
lastTouchID
),
clearResetTimer(
),
disableMouseBindings(
),
(didScroll = !1),
(t = getNativeEvent(
event
).touches[0]),
(startX = t.pageX),
(startY = t.pageY),
triggerVirtualEvent(
"vmouseover",
event,
flags
),
triggerVirtualEvent(
"vmousedown",
event,
flags
));
}
function handleScroll(
event
) {
blockTouchTriggers ||
(didScroll ||
triggerVirtualEvent(
"vmousecancel",
event,
getVirtualBindingFlags(
event.target
),
),
(didScroll = !0),
startResetTimer(
));
}
function handleTouchMove(
event
) {
if (!blockTouchTriggers) {
var t = getNativeEvent(
event
).touches[0],
didCancel = didScroll,
moveThreshold = $.vmouse.moveDistanceThreshold,
flags = getVirtualBindingFlags(
event.target
);
(didScroll =
didScroll ||
Math.abs(
t.pageX - startX
) > moveThreshold ||
Math.abs(
t.pageY - startY
) > moveThreshold) &&
!didCancel &&
triggerVirtualEvent(
"vmousecancel",
event,
flags
),
triggerVirtualEvent(
"vmousemove",
event,
flags
),
startResetTimer(
);
}
}
function handleTouchEnd(
event
) {
if (!blockTouchTriggers) {
disableTouchBindings(
);
var ve,
t,
flags = getVirtualBindingFlags(
event.target
);
triggerVirtualEvent(
"vmouseup",
event,
flags
),
didScroll ||
((ve = triggerVirtualEvent(
"vclick",
event,
flags
)) &&
ve.isDefaultPrevented(
) &&
((t = getNativeEvent(
event
).changedTouches[0]),
clickBlockList.push(
{
touchID: lastTouchID,
x: t.clientX,
y: t.clientY,
}
),
(blockMouseTriggers = !0))),
triggerVirtualEvent(
"vmouseout",
event,
flags
),
(didScroll = !1),
startResetTimer(
);
}
}
function hasVirtualBindings(
ele
) {
var k,
bindings = $.data(
ele,
dataPropertyName
);
if (bindings) for (k in bindings) if (bindings[k]) return !0;
return !1;
}
function dummyMouseHandler(
) {}
function getSpecialEventObject(
eventType
) {
var realType = eventType.substr(
1
);
return {
setup: function (
) {
hasVirtualBindings(
this
) || $.data(
this,
dataPropertyName,
{
}
),
($.data(
this,
dataPropertyName
)[eventType] = !0),
(activeDocHandlers[eventType] =
(activeDocHandlers[eventType] || 0) + 1),
1 === activeDocHandlers[eventType] &&
$document.bind(
realType,
mouseEventCallback
),
$(
this
).bind(
realType,
dummyMouseHandler
),
eventCaptureSupported &&
((activeDocHandlers.touchstart =
(activeDocHandlers.touchstart || 0) + 1),
1 === activeDocHandlers.touchstart &&
$document
.bind(
"touchstart",
handleTouchStart
)
.bind(
"touchend",
handleTouchEnd
)
.bind(
"touchmove",
handleTouchMove
)
.bind(
"scroll",
handleScroll
));
},
teardown: function (
) {
--activeDocHandlers[eventType],
activeDocHandlers[eventType] ||
$document.unbind(
realType,
mouseEventCallback
),
eventCaptureSupported &&
(--activeDocHandlers.touchstart,
activeDocHandlers.touchstart ||
$document
.unbind(
"touchstart",
handleTouchStart
)
.unbind(
"touchmove",
handleTouchMove
)
.unbind(
"touchend",
handleTouchEnd
)
.unbind(
"scroll",
handleScroll
));
var $this = $(
this
),
bindings = $.data(
this,
dataPropertyName
);
bindings && (bindings[eventType] = !1),
$this.unbind(
realType,
dummyMouseHandler
),
hasVirtualBindings(
this
) || $this.removeData(
dataPropertyName
);
},
};
}
for (
$.vmouse = {
moveDistanceThreshold: 10,
clickDistanceThreshold: 10,
resetTimerDuration: 1500,
},
i = 0;
i < virtualEventNames.length;
i++
)
$.event.special[virtualEventNames[i]] = getSpecialEventObject(
virtualEventNames[i],
);
eventCaptureSupported &&
document.addEventListener(
"click",
function (
e
) {
var x,
y,
ele,
i,
o,
cnt = clickBlockList.length,
target = e.target;
if (cnt)
for (
x = e.clientX,
y = e.clientY,
threshold = $.vmouse.clickDistanceThreshold,
ele = target;
ele;
) {
for (i = 0; i < cnt; i++)
if (
((o = clickBlockList[i]),
0,
(ele === target &&
Math.abs(
o.x - x
) < threshold &&
Math.abs(
o.y - y
) < threshold) ||
$.data(
ele,
"virtualTouchID"
) === o.touchID)
)
return e.preventDefault(
), void e.stopPropagation(
);
ele = ele.parentNode;
}
},
!0,
);
})(
jQuery,
0,
document
),
(function (
$, window, undefined
) {
var $document = $(
document
),
supportTouch = $.mobile.support.touch,
touchStartEvent = supportTouch ? "touchstart" : "mousedown",
touchStopEvent = supportTouch ? "touchend" : "mouseup",
touchMoveEvent = supportTouch ? "touchmove" : "mousemove";
function triggerCustomEvent(
obj, eventType, event, bubble
) {
var originalType = event.type;
(event.type = eventType),
bubble
? $.event.trigger(
event,
undefined,
obj
)
: $.event.dispatch.call(
obj,
event
),
(event.type = originalType);
}
$.each(
"touchstart touchmove touchend tap taphold swipe swipeleft swiperight scrollstart scrollstop".split(
" ",
),
function (
i, name
) {
($.fn[name] = function (
fn
) {
return fn
? this.bind(
name,
fn
)
: this.trigger(
name
);
}),
$.attrFn && ($.attrFn[name] = !0);
},
),
($.event.special.scrollstart = {
enabled: !0,
setup: function (
) {
var scrolling,
timer,
thisObject = this;
function trigger(
event, state
) {
triggerCustomEvent(
thisObject,
(scrolling = state) ? "scrollstart" : "scrollstop",
event,
);
}
$(
thisObject
).bind(
"touchmove scroll",
function (
event
) {
$.event.special.scrollstart.enabled &&
(scrolling || trigger(
event,
!0
),
clearTimeout(
timer
),
(timer = setTimeout(
function (
) {
trigger(
event,
!1
);
},
50
)));
}
);
},
teardown: function (
) {
$(
this
).unbind(
"touchmove scroll"
);
},
}),
($.event.special.tap = {
tapholdThreshold: 750,
emitTapOnTaphold: !0,
setup: function (
) {
var thisObject = this,
$this = $(
thisObject
),
isTaphold = !1;
$this.bind(
"vmousedown",
function (
event
) {
if (((isTaphold = !1), event.which && 1 !== event.which))
return !1;
var timer,
origTarget = event.target;
function clearTapTimer(
) {
clearTimeout(
timer
);
}
function clearTapHandlers(
) {
clearTapTimer(
),
$this
.unbind(
"vclick",
clickHandler
)
.unbind(
"vmouseup",
clearTapTimer
),
$document.unbind(
"vmousecancel",
clearTapHandlers
);
}
function clickHandler(
event
) {
clearTapHandlers(
),
isTaphold || origTarget !== event.target
? isTaphold && event.stopPropagation(
)
: triggerCustomEvent(
thisObject,
"tap",
event
);
}
$this
.bind(
"vmouseup",
clearTapTimer
)
.bind(
"vclick",
clickHandler
),
$document.bind(
"vmousecancel",
clearTapHandlers
),
(timer = setTimeout(
function (
) {
$.event.special.tap.emitTapOnTaphold || (isTaphold = !0),
triggerCustomEvent(
thisObject,
"taphold",
$.Event(
"taphold",
{
target: origTarget,
}
),
);
},
$.event.special.tap.tapholdThreshold
));
}
);
},
teardown: function (
) {
$(
this
).unbind(
"vmousedown"
).unbind(
"vclick"
).unbind(
"vmouseup"
),
$document.unbind(
"vmousecancel"
);
},
}),
($.event.special.swipe = {
scrollSupressionThreshold: 30,
durationThreshold: 1e3,
horizontalDistanceThreshold: 30,
verticalDistanceThreshold: 30,
getLocation: function (
event
) {
var winPageX = window.pageXOffset,
winPageY = window.pageYOffset,
x = event.clientX,
y = event.clientY;
return (
(0 === event.pageY && Math.floor(
y
) > Math.floor(
event.pageY
)) ||
(0 === event.pageX && Math.floor(
x
) > Math.floor(
event.pageX
))
? ((x -= winPageX), (y -= winPageY))
: (y < event.pageY - winPageY || x < event.pageX - winPageX) &&
((x = event.pageX - winPageX), (y = event.pageY - winPageY)),
{
x: x,
y: y,
}
);
},
start: function (
event
) {
var data = event.originalEvent.touches
? event.originalEvent.touches[0]
: event,
location = $.event.special.swipe.getLocation(
data
);
return {
time: new Date(
).getTime(
),
coords: [location.x, location.y,],
origin: $(
event.target
),
};
},
stop: function (
event
) {
var data = event.originalEvent.touches
? event.originalEvent.touches[0]
: event,
location = $.event.special.swipe.getLocation(
data
);
return {
time: new Date(
).getTime(
),
coords: [location.x, location.y,],
};
},
handleSwipe: function (
start, stop, thisObject, origTarget
) {
if (
stop.time - start.time <
$.event.special.swipe.durationThreshold &&
Math.abs(
start.coords[0] - stop.coords[0]
) >
$.event.special.swipe.horizontalDistanceThreshold &&
Math.abs(
start.coords[1] - stop.coords[1]
) <
$.event.special.swipe.verticalDistanceThreshold
) {
var direction =
start.coords[0] > stop.coords[0] ? "swipeleft" : "swiperight";
return (
triggerCustomEvent(
thisObject,
"swipe",
$.Event(
"swipe",
{
target: origTarget,
swipestart: start,
swipestop: stop,
}
),
!0,
),
triggerCustomEvent(
thisObject,
direction,
$.Event(
direction,
{
target: origTarget,
swipestart: start,
swipestop: stop,
}
),
!0,
),
!0
);
}
return !1;
},
eventInProgress: !1,
setup: function (
) {
var events,
thisObject = this,
$this = $(
thisObject
),
context = {
};
(events = $.data(
this,
"mobile-events"
)) ||
((events = {
length: 0,
}), $.data(
this,
"mobile-events",
events
)),
events.length++,
(events.swipe = context),
(context.start = function (
event
) {
if (!$.event.special.swipe.eventInProgress) {
$.event.special.swipe.eventInProgress = !0;
var stop,
start = $.event.special.swipe.start(
event
),
origTarget = event.target,
emitted = !1;
(context.move = function (
event
) {
start &&
((stop = $.event.special.swipe.stop(
event
)),
emitted ||
((emitted = $.event.special.swipe.handleSwipe(
start,
stop,
thisObject,
origTarget,
)) &&
($.event.special.swipe.eventInProgress = !1)),
Math.abs(
start.coords[0] - stop.coords[0]
) >
$.event.special.swipe.scrollSupressionThreshold &&
event.preventDefault(
));
}),
(context.stop = function (
) {
(emitted = !0),
($.event.special.swipe.eventInProgress = !1),
$document.off(
touchMoveEvent,
context.move
),
(context.move = null);
}),
$document
.on(
touchMoveEvent,
context.move
)
.one(
touchStopEvent,
context.stop
);
}
}),
$this.on(
touchStartEvent,
context.start
);
},
teardown: function (
) {
var events, context;
(events = $.data(
this,
"mobile-events"
)) &&
((context = events.swipe),
delete events.swipe,
events.length--,
0 === events.length && $.removeData(
this,
"mobile-events"
)),
context &&
(context.start && $(
this
).off(
touchStartEvent,
context.start
),
context.move && $document.off(
touchMoveEvent,
context.move
),
context.stop && $document.off(
touchStopEvent,
context.stop
));
},
}),
$.each(
{
scrollstop: "scrollstart",
taphold: "tap",
swipeleft: "swipe",
swiperight: "swipe",
},
function (
event, sourceEvent
) {
$.event.special[event] = {
setup: function (
) {
$(
this
).bind(
sourceEvent,
$.noop
);
},
teardown: function (
) {
$(
this
).unbind(
sourceEvent
);
},
};
},
);
})(
jQuery,
this
),
(function (
$
) {
$.event.special.throttledresize = {
setup: function (
) {
$(
this
).bind(
"resize",
handler
);
},
teardown: function (
) {
$(
this
).unbind(
"resize",
handler
);
},
};
var heldCall,
curr,
diff,
handler = function (
) {
(curr = new Date(
).getTime(
)),
(diff = curr - lastCall) >= 250
? ((lastCall = curr), $(
this
).trigger(
"throttledresize"
))
: (heldCall && clearTimeout(
heldCall
),
(heldCall = setTimeout(
handler,
250 - diff
)));
},
lastCall = 0;
})(
jQuery
),
(function (
$, window
) {
var get_orientation,
last_orientation,
initial_orientation_is_landscape,
initial_orientation_is_default,
ww,
wh,
win = $(
window
),
event_name = "orientationchange",
portrait_map = {
0: !0,
180: !0,
};
function handler(
) {
var orientation = get_orientation(
);
orientation !== last_orientation &&
((last_orientation = orientation), win.trigger(
event_name
));
}
$.support.orientation &&
(50,
(initial_orientation_is_landscape =
(ww = window.innerWidth || win.width(
)) >
(wh = window.innerHeight || win.height(
)) && ww - wh > 50),
(initial_orientation_is_default = portrait_map[window.orientation]),
((initial_orientation_is_landscape && initial_orientation_is_default) ||
(!initial_orientation_is_landscape &&
!initial_orientation_is_default)) &&
(portrait_map = {
"-90": !0,
90: !0,
})),
($.event.special.orientationchange = $.extend(
{
},
$.event.special.orientationchange,
{
setup: function (
) {
if (
$.support.orientation &&
!$.event.special.orientationchange.disabled
)
return !1;
(last_orientation = get_orientation(
)),
win.bind(
"throttledresize",
handler
);
},
teardown: function (
) {
if (
$.support.orientation &&
!$.event.special.orientationchange.disabled
)
return !1;
win.unbind(
"throttledresize",
handler
);
},
add: function (
handleObj
) {
var old_handler = handleObj.handler;
handleObj.handler = function (
event
) {
return (
(event.orientation = get_orientation(
)),
old_handler.apply(
this,
arguments
)
);
};
},
},
)),
($.event.special.orientationchange.orientation = get_orientation = function (
) {
var elem = document.documentElement;
return (
$.support.orientation
? portrait_map[window.orientation]
: elem && elem.clientWidth / elem.clientHeight < 1.1
)
? "portrait"
: "landscape";
}),
($.fn[event_name] = function (
fn
) {
return fn
? this.bind(
event_name,
fn
)
: this.trigger(
event_name
);
}),
$.attrFn && ($.attrFn[event_name] = !0);
})(
jQuery,
this
),
(function (
$, undefined
) {
var baseElement = $(
"head"
).children(
"base"
),
base = {
element: baseElement.length
? baseElement
: $(
"<base>",
{
href: $.mobile.path.documentBase.hrefNoHash,
}
).prependTo(
$(
"head"
)
),
linkSelector:
"[src], link[href], a[rel='external'], :jqmData(ajax='false'), a[target]",
set: function (
href
) {
$.mobile.dynamicBaseEnabled &&
$.support.dynamicBaseTag &&
base.element.attr(
"href",
$.mobile.path.makeUrlAbsolute(
href,
$.mobile.path.documentBase
),
);
},
rewrite: function (
href, page
) {
var newPath = $.mobile.path.get(
href
);
page.find(
base.linkSelector
).each(
function (
i, link
) {
var thisAttr = $(
link
).is(
"[href]"
)
? "href"
: $(
link
).is(
"[src]"
)
? "src"
: "action",
thisUrl = $(
link
).attr(
thisAttr
);
(thisUrl = thisUrl.replace(
location.protocol + "//" + location.host + location.pathname,
"",
)),
/^(\w+:|#|\/)/.test(
thisUrl
) ||
$(
link
).attr(
thisAttr,
newPath + thisUrl
);
}
);
},
reset: function (
) {
base.element.attr(
"href",
$.mobile.path.documentBase.hrefNoSearch
);
},
};
$.mobile.base = base;
})(
jQuery
),
(function (
$, undefined
) {
$.mobile.widgets = {
};
var orig,
originalWidget = $.widget,
keepNativeFactoryDefault = $.mobile.keepNative;
($.widget =
((orig = $.widget),
function (
) {
var constructor = orig.apply(
this,
arguments
),
name = constructor.prototype.widgetName;
return (
(constructor.initSelector =
void 0 !== constructor.prototype.initSelector
? constructor.prototype.initSelector
: ":jqmData(role='" + name + "')"),
($.mobile.widgets[name] = constructor),
constructor
);
})),
$.extend(
$.widget,
originalWidget
),
$.mobile.document.on(
"create",
function (
event
) {
$(
event.target
).enhanceWithin(
);
}
),
$.widget(
"mobile.page",
{
options: {
theme: "a",
domCache: !1,
keepNativeDefault: $.mobile.keepNative,
contentTheme: null,
enhanced: !1,
},
_createWidget: function (
) {
$.Widget.prototype._createWidget.apply(
this,
arguments
),
this._trigger(
"init"
);
},
_create: function (
) {
if (!1 === this._trigger(
"beforecreate"
)) return !1;
this.options.enhanced || this._enhance(
),
this._on(
this.element,
{
pagebeforehide: "removeContainerBackground",
pagebeforeshow: "_handlePageBeforeShow",
}
),
this.element.enhanceWithin(
),
"dialog" === $.mobile.getAttribute(
this.element[0],
"role"
) &&
$.mobile.dialog &&
this.element.dialog(
);
},
_enhance: function (
) {
var attrPrefix = "data-" + $.mobile.ns,
self = this;
this.options.role &&
this.element.attr(
"data-" + $.mobile.ns + "role",
this.options.role,
),
this.element
.attr(
"tabindex",
"0"
)
.addClass(
"ui-page ui-page-theme-" + this.options.theme
),
this.element
.find(
"[" + attrPrefix + "role='content']"
)
.each(
function (
) {
var $this = $(
this
),
theme =
this.getAttribute(
attrPrefix + "theme"
) || undefined;
(self.options.contentTheme =
theme ||
self.options.contentTheme ||
(self.options.dialog && self.options.theme) ||
("dialog" === self.element.jqmData(
"role"
) &&
self.options.theme)),
$this.addClass(
"ui-content"
),
self.options.contentTheme &&
$this.addClass(
"ui-body-" + self.options.contentTheme
),
$this.attr(
"role",
"main"
).addClass(
"ui-content"
);
}
);
},
bindRemove: function (
callback
) {
var page = this.element;
!page.data(
"mobile-page"
).options.domCache &&
page.is(
":jqmData(external-page='true')"
) &&
page.bind(
"pagehide.remove",
callback ||
function (
e, data
) {
if (!data.samePage) {
var $this = $(
this
),
prEvent = new $.Event(
"pageremove"
);
$this.trigger(
prEvent
),
prEvent.isDefaultPrevented(
) ||
$this.removeWithDependents(
);
}
},
);
},
_setOptions: function (
o
) {
undefined !== o.theme &&
this.element
.removeClass(
"ui-page-theme-" + this.options.theme
)
.addClass(
"ui-page-theme-" + o.theme
),
undefined !== o.contentTheme &&
this.element
.find(
"[data-" + $.mobile.ns + "='content']"
)
.removeClass(
"ui-body-" + this.options.contentTheme
)
.addClass(
"ui-body-" + o.contentTheme
);
},
_handlePageBeforeShow: function (
) {
this.setContainerBackground(
);
},
removeContainerBackground: function (
) {
this.element
.closest(
":mobile-pagecontainer"
)
.pagecontainer(
{
theme: "none",
}
);
},
setContainerBackground: function (
theme
) {
this.element
.parent(
)
.pagecontainer(
{
theme: theme || this.options.theme,
}
);
},
keepNativeSelector: function (
) {
var options = this.options,
keepNative = $.trim(
options.keepNative || ""
),
globalValue = $.trim(
$.mobile.keepNative
),
optionValue = $.trim(
options.keepNativeDefault
),
newDefault =
keepNativeFactoryDefault === globalValue ? "" : globalValue,
oldDefault = "" === newDefault ? optionValue : "";
return (keepNative ? [keepNative,] : [])
.concat(
newDefault ? [newDefault,] : []
)
.concat(
oldDefault ? [oldDefault,] : []
)
.join(
", "
);
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
$.widget(
"mobile.pagecontainer",
{
options: {
theme: "a",
},
initSelector: !1,
_create: function (
) {
(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",
$.proxy(
function (
) {
this.setLastScrollEnabled = !0;
},
this
),
);
},
_setOptions: function (
options
) {
undefined !== options.theme && "none" !== options.theme
? this.element
.removeClass(
"ui-overlay-" + this.options.theme
)
.addClass(
"ui-overlay-" + options.theme
)
: undefined !== options.theme &&
this.element.removeClass(
"ui-overlay-" + this.options.theme
),
this._super(
options
);
},
_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 currentScroll,
minScroll,
defaultScroll,
active = this._getActiveHistory(
);
active &&
((currentScroll = this._getScroll(
)),
(minScroll = this._getMinScroll(
)),
(defaultScroll = this._getDefaultScroll(
)),
(active.lastScroll =
currentScroll < minScroll ? defaultScroll : currentScroll));
}
},
_delayedRecordScroll: function (
) {
setTimeout(
$.proxy(
this,
"_recordScroll"
),
100
);
},
_getScroll: function (
) {
return this.window.scrollTop(
);
},
_getMinScroll: function (
) {
return $.mobile.minScrollBack;
},
_getDefaultScroll: function (
) {
return $.mobile.defaultHomeScroll;
},
_filterNavigateEvents: function (
e, data
) {
var url;
(e.originalEvent && e.originalEvent.isDefaultPrevented(
)) ||
((url =
e.originalEvent.type.indexOf(
"hashchange"
) > -1
? data.state.hash
: data.state.url) || (url = this._getHash(
)),
(url &&
"#" !== url &&
0 !== url.indexOf(
"#" + $.mobile.path.uiStateKey
)) ||
(url = location.href),
this._handleNavigate(
url,
data.state
));
},
_getHash: function (
) {
return $.mobile.path.parseLocation(
).hash;
},
getActivePage: function (
) {
return this.activePage;
},
_getInitialContent: function (
) {
return $.mobile.firstPage;
},
_getHistory: function (
) {
return $.mobile.navigate.history;
},
_getActiveHistory: function (
) {
return $.mobile.navigate.history.getActive(
);
},
_getDocumentBase: function (
) {
return $.mobile.path.documentBase;
},
back: function (
) {
this.go(
-1
);
},
forward: function (
) {
this.go(
1
);
},
go: function (
steps
) {
if ($.mobile.hashListeningEnabled) window.history.go(
steps
);
else {
var activeIndex = $.mobile.navigate.history.activeIndex,
index = activeIndex + parseInt(
steps,
10
),
url = $.mobile.navigate.history.stack[index].url,
direction = steps >= 1 ? "forward" : "back";
($.mobile.navigate.history.activeIndex = index),
($.mobile.navigate.history.previousIndex = activeIndex),
this.change(
url,
{
direction: direction,
changeHash: !1,
fromHashChange: !0,
}
);
}
},
_handleDestination: function (
to
) {
var history;
return (
"string" === $.type(
to
) && (to = $.mobile.path.stripHash(
to
)),
to &&
((history = this._getHistory(
)),
(to = $.mobile.path.isPath(
to
)
? to
: $.mobile.path.makeUrlAbsolute(
"#" + to,
this._getDocumentBase(
),
)) ===
$.mobile.path.makeUrlAbsolute(
"#" + history.initialDst,
this._getDocumentBase(
),
) &&
history.stack.length &&
history.stack[0].url !==
history.initialDst.replace(
$.mobile.dialogHashKey,
""
) &&
(to = this._getInitialContent(
))),
to || this._getInitialContent(
)
);
},
_handleDialog: function (
changePageOptions, data
) {
var to,
active,
activeContent = this.getActivePage(
);
return activeContent && !activeContent.hasClass(
"ui-dialog"
)
? ("back" === data.direction
? this.back(
)
: this.forward(
), !1)
: ((to = data.pageUrl),
(active = this._getActiveHistory(
)),
$.extend(
changePageOptions,
{
role: active.role,
transition: active.transition,
reverse: "back" === data.direction,
}
),
to);
},
_handleNavigate: function (
url, data
) {
var to = $.mobile.path.stripHash(
url
),
history = this._getHistory(
),
transition = 0 === history.stack.length ? "none" : undefined,
changePageOptions = {
changeHash: !1,
fromHashChange: !0,
reverse: "back" === data.direction,
};
$.extend(
changePageOptions,
data,
{
transition: (history.getLast(
) || {
}).transition || transition,
}
),
(history.activeIndex > 0 &&
to.indexOf(
$.mobile.dialogHashKey
) > -1 &&
history.initialDst !== to &&
!1 === (to = this._handleDialog(
changePageOptions,
data
))) ||
this._changeContent(
this._handleDestination(
to
),
changePageOptions,
);
},
_changeContent: function (
to, opts
) {
$.mobile.changePage(
to,
opts
);
},
_getBase: function (
) {
return $.mobile.base;
},
_getNs: function (
) {
return $.mobile.ns;
},
_enhance: function (
content, role
) {
return content.page(
{
role: role,
}
);
},
_include: function (
page, settings
) {
page.appendTo(
this.element
),
this._enhance(
page,
settings.role
),
page.page(
"bindRemove"
);
},
_find: function (
absUrl
) {
var page,
fileUrl = this._createFileUrl(
absUrl
),
dataUrl = this._createDataUrl(
absUrl
),
initialContent = this._getInitialContent(
);
return (
0 ===
(page = this.element.children(
"[data-" + this._getNs(
) + "url='" + dataUrl + "']",
)).length &&
dataUrl &&
!$.mobile.path.isPath(
dataUrl
) &&
(page = this.element
.children(
$.mobile.path.hashToSelector(
"#" + dataUrl
)
)
.attr(
"data-" + this._getNs(
) + "url",
dataUrl
)
.jqmData(
"url",
dataUrl
)),
0 === page.length &&
$.mobile.path.isFirstPageUrl(
fileUrl
) &&
initialContent &&
initialContent.parent(
).length &&
(page = $(
initialContent
)),
page
);
},
_getLoader: function (
) {
return $.mobile.loading(
);
},
_showLoading: function (
delay, theme, msg, textonly
) {
this._loadMsg ||
(this._loadMsg = setTimeout(
$.proxy(
function (
) {
this._getLoader(
).loader(
"show",
theme,
msg,
textonly
),
(this._loadMsg = 0);
},
this
),
delay,
));
},
_hideLoading: function (
) {
clearTimeout(
this._loadMsg
),
(this._loadMsg = 0),
this._getLoader(
).loader(
"hide"
);
},
_showError: function (
) {
this._hideLoading(
),
this._showLoading(
0,
$.mobile.pageLoadErrorMessageTheme,
$.mobile.pageLoadErrorMessage,
!0,
),
setTimeout(
$.proxy(
this,
"_hideLoading"
),
1500
);
},
_parse: function (
html, fileUrl
) {
var page,
all = $(
"<div></div>"
);
return (
(all.get(
0
).innerHTML = html),
(page = all
.find(
":jqmData(role='page'), :jqmData(role='dialog')"
)
.first(
)).length ||
(page = $(
"<div data-" +
this._getNs(
) +
"role='page'>" +
(html.split(
/<\/?body[^>]*>/gim
)[1] || "") +
"</div>",
)),
page
.attr(
"data-" + this._getNs(
) + "url",
$.mobile.path.convertUrlToDataUrl(
fileUrl
),
)
.attr(
"data-" + this._getNs(
) + "external-page",
!0
),
page
);
},
_setLoadedTitle: function (
page, html
) {
var newPageTitle = html.match(
/<title[^>]*>([^<]*)/
) && RegExp.$1;
newPageTitle &&
!page.jqmData(
"title"
) &&
((newPageTitle = $(
"<div>" + newPageTitle + "</div>"
).text(
)),
page.jqmData(
"title",
newPageTitle
));
},
_isRewritableBaseTag: function (
) {
return $.mobile.dynamicBaseEnabled && !$.support.dynamicBaseTag;
},
_createDataUrl: function (
absoluteUrl
) {
return $.mobile.path.convertUrlToDataUrl(
absoluteUrl
);
},
_createFileUrl: function (
absoluteUrl
) {
return $.mobile.path.getFilePath(
absoluteUrl
);
},
_triggerWithDeprecated: function (
name, data, page
) {
var deprecatedEvent = $.Event(
"page" + name
),
newEvent = $.Event(
this.widgetName + name
);
return (
(page || this.element).trigger(
deprecatedEvent,
data
),
this.element.trigger(
newEvent,
data
),
{
deprecatedEvent: deprecatedEvent,
event: newEvent,
}
);
},
_loadSuccess: function (
absUrl, triggerData, settings, deferred
) {
var fileUrl = this._createFileUrl(
absUrl
),
dataUrl = this._createDataUrl(
absUrl
);
return $.proxy(
function (
html, textStatus, xhr
) {
var content,
pageElemRegex = new RegExp(
"(<[^>]+\\bdata-" +
this._getNs(
) +
"role=[\"']?page[\"']?[^>]*>)",
),
dataUrlRegex = new RegExp(
"\\bdata-" + this._getNs(
) + "url=[\"']?([^\"'>]*)[\"']?",
);
pageElemRegex.test(
html
) &&
RegExp.$1 &&
dataUrlRegex.test(
RegExp.$1
) &&
RegExp.$1 &&
(fileUrl = $.mobile.path.getFilePath(
$(
"<div>" + RegExp.$1 + "</div>"
).text(
),
)),
undefined === settings.prefetch && this._getBase(
).set(
fileUrl
),
(content = this._parse(
html,
fileUrl
)),
this._setLoadedTitle(
content,
html
),
(triggerData.xhr = xhr),
(triggerData.textStatus = textStatus),
(triggerData.page = content),
(triggerData.content = content),
this._trigger(
"load",
undefined,
triggerData
) &&
(this._isRewritableBaseTag(
) &&
content &&
this._getBase(
).rewrite(
fileUrl,
content
),
this._include(
content,
settings
),
absUrl.indexOf(
"&" + $.mobile.subPageUrlKey
) > -1 &&
(content = this.element.children(
"[data-" + this._getNs(
) + "url='" + dataUrl + "']",
)),
settings.showLoadMsg && this._hideLoading(
),
this.element.trigger(
"pageload"
),
deferred.resolve(
absUrl,
settings,
content
));
},
this
);
},
_loadDefaults: {
type: "get",
data: undefined,
reloadPage: !1,
reload: !1,
role: undefined,
showLoadMsg: !1,
loadMsgDelay: 50,
},
load: function (
url, options
) {
var content,
fileUrl,
dataUrl,
pblEvent,
triggerData,
deferred = (options && options.deferred) || $.Deferred(
),
settings = $.extend(
{
},
this._loadDefaults,
options
),
absUrl = $.mobile.path.makeUrlAbsolute(
url,
this._findBaseWithDefault(
),
);
if (
((settings.reload = settings.reloadPage),
settings.data &&
"get" === settings.type &&
((absUrl = $.mobile.path.addSearchParams(
absUrl,
settings.data
)),
(settings.data = undefined)),
settings.data && "post" === settings.type && (settings.reload = !0),
(fileUrl = this._createFileUrl(
absUrl
)),
(dataUrl = this._createDataUrl(
absUrl
)),
0 !== (content = this._find(
absUrl
)).length ||
!$.mobile.path.isEmbeddedPage(
fileUrl
) ||
$.mobile.path.isFirstPageUrl(
fileUrl
))
) {
if ((this._getBase(
).reset(
), content.length && !settings.reload))
return (
this._enhance(
content,
settings.role
),
deferred.resolve(
absUrl,
settings,
content
),
void (settings.prefetch || this._getBase(
).set(
url
))
);
(triggerData = {
url: url,
absUrl: absUrl,
dataUrl: dataUrl,
deferred: deferred,
options: settings,
}),
(pblEvent = this._triggerWithDeprecated(
"beforeload",
triggerData,
)).deprecatedEvent.isDefaultPrevented(
) ||
pblEvent.event.isDefaultPrevented(
) ||
(settings.showLoadMsg &&
this._showLoading(
settings.loadMsgDelay
),
undefined === settings.prefetch && this._getBase(
).reset(
),
$.mobile.allowCrossDomainPages ||
$.mobile.path.isSameDomain(
$.mobile.path.documentUrl,
absUrl
)
? $.ajax(
{
url: fileUrl,
type: settings.type,
data: settings.data,
contentType: settings.contentType,
dataType: "html",
success: this._loadSuccess(
absUrl,
triggerData,
settings,
deferred,
),
error: this._loadError(
absUrl,
triggerData,
settings,
deferred,
),
}
)
: deferred.reject(
absUrl,
settings
));
} else deferred.reject(
absUrl,
settings
);
},
_loadError: function (
absUrl, triggerData, settings, deferred
) {
return $.proxy(
function (
xhr, textStatus, errorThrown
) {
this._getBase(
).set(
$.mobile.path.get(
)
),
(triggerData.xhr = xhr),
(triggerData.textStatus = textStatus),
(triggerData.errorThrown = errorThrown);
var plfEvent = this._triggerWithDeprecated(
"loadfailed",
triggerData,
);
plfEvent.deprecatedEvent.isDefaultPrevented(
) ||
plfEvent.event.isDefaultPrevented(
) ||
(settings.showLoadMsg && this._showError(
),
deferred.reject(
absUrl,
settings
));
},
this
);
},
_getTransitionHandler: function (
transition
) {
return (
(transition = $.mobile._maybeDegradeTransition(
transition
)),
$.mobile.transitionHandlers[transition] ||
$.mobile.defaultTransitionHandler
);
},
_triggerCssTransitionEvents: function (
to, from, prefix
) {
var samePage = !1;
(prefix = prefix || ""),
from &&
(to[0] === from[0] && (samePage = !0),
this._triggerWithDeprecated(
prefix + "hide",
{
nextPage: to,
samePage: samePage,
},
from,
)),
this._triggerWithDeprecated(
prefix + "show",
{
prevPage: from || $(
""
),
},
to,
);
},
_cssTransition: function (
to, from, options
) {
var promise,
transition = options.transition,
reverse = options.reverse,
deferred = options.deferred;
this._triggerCssTransitionEvents(
to,
from,
"before"
),
this._hideLoading(
),
(promise = new (this._getTransitionHandler(
transition
))(
transition,
reverse,
to,
from,
).transition(
)).done(
function (
) {
deferred.resolve.apply(
deferred,
arguments
);
}
),
promise.done(
$.proxy(
function (
) {
this._triggerCssTransitionEvents(
to,
from
);
},
this
),
);
},
_releaseTransitionLock: function (
) {
(isPageTransitioning = !1),
pageTransitionQueue.length > 0 &&
$.mobile.changePage.apply(
null,
pageTransitionQueue.pop(
)
);
},
_removeActiveLinkClass: function (
force
) {
$.mobile.removeActiveLinkClass(
force
);
},
_loadUrl: function (
to, triggerData, settings
) {
(settings.target = to),
(settings.deferred = $.Deferred(
)),
this.load(
to,
settings
),
settings.deferred.done(
$.proxy(
function (
url, options, content
) {
(isPageTransitioning = !1),
(options.absUrl = triggerData.absUrl),
this.transition(
content,
triggerData,
options
);
},
this
),
),
settings.deferred.fail(
$.proxy(
function (
) {
this._removeActiveLinkClass(
!0
),
this._releaseTransitionLock(
),
this._triggerWithDeprecated(
"changefailed",
triggerData
);
},
this
),
);
},
_triggerPageBeforeChange: function (
to, triggerData, settings
) {
var pbcEvent = new $.Event(
"pagebeforechange"
);
return (
$.extend(
triggerData,
{
toPage: to,
options: settings,
}
),
"string" === $.type(
to
)
? (triggerData.absUrl = $.mobile.path.makeUrlAbsolute(
to,
this._findBaseWithDefault(
),
))
: (triggerData.absUrl = settings.absUrl),
this.element.trigger(
pbcEvent,
triggerData
),
!pbcEvent.isDefaultPrevented(
)
);
},
change: function (
to, options
) {
if (isPageTransitioning) pageTransitionQueue.unshift(
arguments
);
else {
var settings = $.extend(
{
},
$.mobile.changePage.defaults,
options
),
triggerData = {
};
(settings.fromPage = settings.fromPage || this.activePage),
this._triggerPageBeforeChange(
to,
triggerData,
settings
) &&
((to = triggerData.toPage),
"string" === $.type(
to
)
? ((isPageTransitioning = !0),
this._loadUrl(
to,
triggerData,
settings
))
: this.transition(
to,
triggerData,
settings
));
}
},
transition: function (
toPage, triggerData, settings
) {
var fromPage,
url,
pageUrl,
active,
activeIsInitialPage,
historyDir,
pageTitle,
isDialog,
alreadyThere,
newPageTitle,
params,
cssTransitionDeferred,
beforeTransition;
if (isPageTransitioning)
pageTransitionQueue.unshift(
[toPage, settings,]
);
else if (
this._triggerPageBeforeChange(
toPage,
triggerData,
settings
) &&
!(beforeTransition = this._triggerWithDeprecated(
"beforetransition",
triggerData,
)).deprecatedEvent.isDefaultPrevented(
) &&
!beforeTransition.event.isDefaultPrevented(
)
) {
if (
((isPageTransitioning = !0),
toPage[0] !== $.mobile.firstPage[0] ||
settings.dataUrl ||
(settings.dataUrl = $.mobile.path.documentUrl.hrefNoHash),
(fromPage = settings.fromPage),
(pageUrl = url =
(settings.dataUrl &&
$.mobile.path.convertUrlToDataUrl(
settings.dataUrl
)) ||
toPage.jqmData(
"url"
)),
$.mobile.path.getFilePath(
url
),
(active = $.mobile.navigate.history.getActive(
)),
(activeIsInitialPage =
0 === $.mobile.navigate.history.activeIndex),
(historyDir = 0),
(pageTitle = document.title),
(isDialog =
("dialog" === settings.role ||
"dialog" === toPage.jqmData(
"role"
)) &&
!0 !== toPage.jqmData(
"dialog"
)),
fromPage &&
fromPage[0] === toPage[0] &&
!settings.allowSamePageTransition)
)
return (
(isPageTransitioning = !1),
this._triggerWithDeprecated(
"transition",
triggerData
),
this.element.trigger(
"pagechange",
triggerData
),
void (
settings.fromHashChange &&
$.mobile.navigate.history.direct(
{
url: url,
}
)
)
);
toPage.page(
{
role: settings.role,
}
),
settings.fromHashChange &&
(historyDir = "back" === settings.direction ? -1 : 1);
try {
document.activeElement &&
"body" !== document.activeElement.nodeName.toLowerCase(
)
? $(
document.activeElement
).blur(
)
: $(
"input:focus, textarea:focus, select:focus"
).blur(
);
} catch (e) {}
(alreadyThere = !1),
isDialog &&
active &&
(active.url &&
active.url.indexOf(
$.mobile.dialogHashKey
) > -1 &&
this.activePage &&
!this.activePage.hasClass(
"ui-dialog"
) &&
$.mobile.navigate.history.activeIndex > 0 &&
((settings.changeHash = !1), (alreadyThere = !0)),
(url = active.url || ""),
!alreadyThere && url.indexOf(
"#"
) > -1
? (url += $.mobile.dialogHashKey)
: (url += "#" + $.mobile.dialogHashKey),
0 === $.mobile.navigate.history.activeIndex &&
url === $.mobile.navigate.history.initialDst &&
(url += $.mobile.dialogHashKey)),
(newPageTitle = active
? toPage.jqmData(
"title"
) ||
toPage
.children(
":jqmData(role='header')"
)
.find(
".ui-title"
)
.text(
)
: pageTitle) &&
pageTitle === document.title &&
(pageTitle = newPageTitle),
toPage.jqmData(
"title"
) || toPage.jqmData(
"title",
pageTitle
),
(settings.transition =
settings.transition ||
(historyDir && !activeIsInitialPage
? active.transition
: undefined) ||
(isDialog
? $.mobile.defaultDialogTransition
: $.mobile.defaultPageTransition)),
!historyDir &&
alreadyThere &&
($.mobile.navigate.history.getActive(
).pageUrl = pageUrl),
url &&
!settings.fromHashChange &&
(!$.mobile.path.isPath(
url
) &&
url.indexOf(
"#"
) < 0 &&
(url = "#" + url),
(params = {
transition: settings.transition,
title: pageTitle,
pageUrl: pageUrl,
role: settings.role,
}),
!1 !== settings.changeHash && $.mobile.hashListeningEnabled
? $.mobile.navigate(
url,
params,
!0
)
: toPage[0] !== $.mobile.firstPage[0] &&
$.mobile.navigate.history.add(
url,
params
)),
(document.title = pageTitle),
($.mobile.activePage = toPage),
(this.activePage = toPage),
(settings.reverse = settings.reverse || historyDir < 0),
(cssTransitionDeferred = $.Deferred(
)),
this._cssTransition(
toPage,
fromPage,
{
transition: settings.transition,
reverse: settings.reverse,
deferred: cssTransitionDeferred,
}
),
cssTransitionDeferred.done(
$.proxy(
function (
name, reverse, $to, $from, alreadyFocused
) {
$.mobile.removeActiveLinkClass(
),
settings.duplicateCachedPage &&
settings.duplicateCachedPage.remove(
),
alreadyFocused || $.mobile.focusPage(
toPage
),
this._releaseTransitionLock(
),
this.element.trigger(
"pagechange",
triggerData
),
this._triggerWithDeprecated(
"transition",
triggerData
);
},
this
),
);
}
},
_findBaseWithDefault: function (
) {
return (
(this.activePage && $.mobile.getClosestBaseUrl(
this.activePage
)) ||
$.mobile.path.documentBase.hrefNoHash
);
},
}
),
($.mobile.navreadyDeferred = $.Deferred(
));
var pageTransitionQueue = [],
isPageTransitioning = !1;
})(
jQuery
),
(function (
$, undefined
) {
var domreadyDeferred = $.Deferred(
),
loadDeferred = $.Deferred(
),
documentUrl = $.mobile.path.documentUrl,
$lastVClicked = null;
function findClosestLink(
ele
) {
for (
;
ele &&
("string" != typeof ele.nodeName ||
"a" !== ele.nodeName.toLowerCase(
));
)
ele = ele.parentNode;
return ele;
}
($.mobile.loadPage = function (
url, opts
) {
var container;
return (
(container =
(opts = opts || {
}).pageContainer || $.mobile.pageContainer),
(opts.deferred = $.Deferred(
)),
container.pagecontainer(
"load",
url,
opts
),
opts.deferred.promise(
)
);
}),
($.mobile.back = function (
) {
var nav = window.navigator;
this.phonegapNavigationEnabled &&
nav &&
nav.app &&
nav.app.backHistory
? nav.app.backHistory(
)
: $.mobile.pageContainer.pagecontainer(
"back"
);
}),
($.mobile.focusPage = function (
page
) {
var autofocus = page.find(
"[autofocus]"
),
pageTitle = page.find(
".ui-title:eq(0)"
);
autofocus.length
? autofocus.focus(
)
: pageTitle.length
? pageTitle.focus(
)
: page.focus(
);
}),
($.mobile._maybeDegradeTransition =
$.mobile._maybeDegradeTransition ||
function (
transition
) {
return transition;
}),
($.mobile.changePage = function (
to, options
) {
$.mobile.pageContainer.pagecontainer(
"change",
to,
options
);
}),
($.mobile.changePage.defaults = {
transition: undefined,
reverse: !1,
changeHash: !0,
fromHashChange: !1,
role: undefined,
duplicateCachedPage: undefined,
pageContainer: undefined,
showLoadMsg: !0,
dataUrl: undefined,
fromPage: undefined,
allowSamePageTransition: !1,
}),
($.mobile._registerInternalEvents = function (
) {
var getAjaxFormData = function (
$form, calculateOnly
) {
var url,
formData,
vclickedName,
method,
ret = !0;
return (
!(
!$.mobile.ajaxEnabled ||
$form.is(
":jqmData(ajax='false')"
) ||
!$form.jqmHijackable(
).length ||
$form.attr(
"target"
)
) &&
((url =
($lastVClicked && $lastVClicked.attr(
"formaction"
)) ||
$form.attr(
"action"
)),
(method = ($form.attr(
"method"
) || "get").toLowerCase(
)),
url ||
((url = $.mobile.getClosestBaseUrl(
$form
)),
"get" === method &&
(url = $.mobile.path.parseUrl(
url
).hrefNoSearch),
url === $.mobile.path.documentBase.hrefNoHash &&
(url = documentUrl.hrefNoSearch)),
(url = $.mobile.path.makeUrlAbsolute(
url,
$.mobile.getClosestBaseUrl(
$form
),
)),
!(
$.mobile.path.isExternal(
url
) &&
!$.mobile.path.isPermittedCrossDomainRequest(
documentUrl,
url
)
) &&
(calculateOnly ||
((formData = $form.serializeArray(
)),
$lastVClicked &&
$lastVClicked[0].form === $form[0] &&
(vclickedName = $lastVClicked.attr(
"name"
)) &&
($.each(
formData,
function (
key, value
) {
if (value.name === vclickedName)
return (vclickedName = ""), !1;
}
),
vclickedName &&
formData.push(
{
name: vclickedName,
value: $lastVClicked.attr(
"value"
),
}
)),
(ret = {
url: url,
options: {
type: method,
data: $.param(
formData
),
transition: $form.jqmData(
"transition"
),
reverse: "reverse" === $form.jqmData(
"direction"
),
reloadPage: !0,
},
})),
ret))
);
};
$.mobile.document.delegate(
"form",
"submit",
function (
event
) {
var formData;
event.isDefaultPrevented(
) ||
((formData = getAjaxFormData(
$(
this
)
)) &&
($.mobile.changePage(
formData.url,
formData.options
),
event.preventDefault(
)));
}
),
$.mobile.document.bind(
"vclick",
function (
event
) {
var $btn,
btnEls,
target = event.target,
needClosest = !1;
if (!(event.which > 1) && $.mobile.linkBindingEnabled) {
if (
(($lastVClicked = $(
target
)), $.data(
target,
"mobile-button"
))
) {
if (!getAjaxFormData(
$(
target
).closest(
"form"
),
!0
)) return;
target.parentNode && (target = target.parentNode);
} else {
if (
!(target = findClosestLink(
target
)) ||
"#" ===
$.mobile.path.parseUrl(
target.getAttribute(
"href"
) || "#"
)
.hash
)
return;
if (!$(
target
).jqmHijackable(
).length) return;
}
~target.className.indexOf(
"ui-link-inherit"
)
? target.parentNode &&
(btnEls = $.data(
target.parentNode,
"buttonElements"
))
: (btnEls = $.data(
target,
"buttonElements"
)),
btnEls ? (target = btnEls.outer) : (needClosest = !0),
($btn = $(
target
)),
needClosest && ($btn = $btn.closest(
".ui-btn"
)),
$btn.length > 0 &&
!$btn.hasClass(
"ui-state-disabled"
) &&
($.mobile.removeActiveLinkClass(
!0
),
($.mobile.activeClickedLink = $btn),
$.mobile.activeClickedLink.addClass(
$.mobile.activeBtnClass,
));
}
}
),
$.mobile.document.bind(
"click",
function (
event
) {
if ($.mobile.linkBindingEnabled && !event.isDefaultPrevented(
)) {
var baseUrl,
href,
transition,
reverse,
role,
link = findClosestLink(
event.target
),
$link = $(
link
),
httpCleanup = function (
) {
window.setTimeout(
function (
) {
$.mobile.removeActiveLinkClass(
!0
);
},
200
);
};
if (
($.mobile.activeClickedLink &&
$.mobile.activeClickedLink[0] === event.target.parentNode &&
httpCleanup(
),
link && !(event.which > 1) && $link.jqmHijackable(
).length)
) {
if ($link.is(
":jqmData(rel='back')"
))
return $.mobile.back(
), !1;
if (
((baseUrl = $.mobile.getClosestBaseUrl(
$link
)),
(href = $.mobile.path.makeUrlAbsolute(
$link.attr(
"href"
) || "#",
baseUrl,
)),
$.mobile.ajaxEnabled || $.mobile.path.isEmbeddedPage(
href
))
) {
if (-1 !== href.search(
"#"
)) {
if (!(href = href.replace(
/[^#]*#/,
""
)))
return void event.preventDefault(
);
href = $.mobile.path.isPath(
href
)
? $.mobile.path.makeUrlAbsolute(
href,
baseUrl
)
: $.mobile.path.makeUrlAbsolute(
"#" + href,
documentUrl.hrefNoHash,
);
}
$link.is(
"[rel='external']"
) ||
$link.is(
":jqmData(ajax='false')"
) ||
$link.is(
"[target]"
) ||
($.mobile.path.isExternal(
href
) &&
!$.mobile.path.isPermittedCrossDomainRequest(
documentUrl,
href,
))
? httpCleanup(
)
: ((transition = $link.jqmData(
"transition"
)),
(reverse =
"reverse" === $link.jqmData(
"direction"
) ||
$link.jqmData(
"back"
)),
(role =
$link.attr(
"data-" + $.mobile.ns + "rel"
) ||
undefined),
$.mobile.changePage(
href,
{
transition: transition,
reverse: reverse,
role: role,
link: $link,
}
),
event.preventDefault(
));
} else httpCleanup(
);
}
}
}
),
$.mobile.document.delegate(
".ui-page",
"pageshow.prefetch",
function (
) {
var urls = [];
$(
this
)
.find(
"a:jqmData(prefetch)"
)
.each(
function (
) {
var $link = $(
this
),
url = $link.attr(
"href"
);
url &&
-1 === $.inArray(
url,
urls
) &&
(urls.push(
url
),
$.mobile.loadPage(
url,
{
role: $link.attr(
"data-" + $.mobile.ns + "rel"
),
prefetch: !0,
}
));
}
);
},
),
$.mobile.pageContainer.pagecontainer(
),
$.mobile.document.bind(
"pageshow",
function (
) {
loadDeferred
? loadDeferred.done(
$.mobile.resetActivePageHeight
)
: $.mobile.resetActivePageHeight(
);
}
),
$.mobile.window.bind(
"throttledresize",
$.mobile.resetActivePageHeight,
);
}),
$(
function (
) {
domreadyDeferred.resolve(
);
}
),
$.mobile.window.load(
function (
) {
loadDeferred.resolve(
), (loadDeferred = null);
}
),
$.when(
domreadyDeferred,
$.mobile.navreadyDeferred
).done(
function (
) {
$.mobile._registerInternalEvents(
);
}
);
})(
jQuery
),
(function (
$, window, undefined
) {
($.mobile.Transition = function (
) {
this.init.apply(
this,
arguments
);
}),
$.extend(
$.mobile.Transition.prototype,
{
toPreClass: " ui-page-pre-in",
init: function (
name, reverse, $to, $from
) {
$.extend(
this,
{
name: name,
reverse: reverse,
$to: $to,
$from: $from,
deferred: new $.Deferred(
),
}
);
},
cleanFrom: function (
) {
this.$from
.removeClass(
$.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(
),
$.mobile.window.scrollTop(
) !== this.toScroll &&
this.scrollPage(
),
this.sequential || this.$to.addClass(
$.mobile.activePageClass
),
this.deferred.resolve(
this.name,
this.reverse,
this.$to,
this.$from,
!0,
);
},
doneOut: function (
screenHeight, reverseClass, none, preventFocus
) {
this.beforeDoneOut(
),
this.startIn(
screenHeight,
reverseClass,
none,
preventFocus
);
},
hideIn: function (
callback
) {
this.$to.css(
"z-index",
-10
),
callback.call(
this
),
this.$to.css(
"z-index",
""
);
},
scrollPage: function (
) {
($.event.special.scrollstart.enabled = !1),
($.mobile.hideUrlBar ||
this.toScroll !== $.mobile.defaultHomeScroll) &&
window.scrollTo(
0,
this.toScroll
),
setTimeout(
function (
) {
$.event.special.scrollstart.enabled = !0;
},
150
);
},
startIn: function (
screenHeight, reverseClass, none, preventFocus
) {
this.hideIn(
function (
) {
this.$to.addClass(
$.mobile.activePageClass + this.toPreClass
),
preventFocus || $.mobile.focusPage(
this.$to
),
this.$to.height(
screenHeight + this.toScroll
),
none || this.scrollPage(
);
}
),
this.$to
.removeClass(
this.toPreClass
)
.addClass(
this.name + " in " + reverseClass
),
none
? this.doneIn(
)
: this.$to.animationComplete(
$.proxy(
function (
) {
this.doneIn(
);
},
this
),
);
},
startOut: function (
screenHeight, reverseClass, none
) {
this.beforeStartOut(
screenHeight,
reverseClass,
none
),
this.$from
.height(
screenHeight + $.mobile.window.scrollTop(
)
)
.addClass(
this.name + " out" + reverseClass
);
},
toggleViewportClass: function (
) {
$.mobile.pageContainer.toggleClass(
"ui-mobile-viewport-transitioning viewport-" + this.name,
);
},
transition: function (
) {
var none,
reverseClass = this.reverse ? " reverse" : "",
screenHeight = $.mobile.getScreenHeight(
),
maxTransitionOverride =
!1 !== $.mobile.maxTransitionWidth &&
$.mobile.window.width(
) > $.mobile.maxTransitionWidth;
return (
(this.toScroll =
$.mobile.navigate.history.getActive(
).lastScroll ||
$.mobile.defaultHomeScroll),
(none =
!$.support.cssTransitions ||
!$.support.cssAnimations ||
maxTransitionOverride ||
!this.name ||
"none" === this.name ||
Math.max(
$.mobile.window.scrollTop(
),
this.toScroll
) >
$.mobile.getMaxScrollForTransition(
)),
this.toggleViewportClass(
),
this.$from && !none
? this.startOut(
screenHeight,
reverseClass,
none
)
: this.doneOut(
screenHeight,
reverseClass,
none,
!0
),
this.deferred.promise(
)
);
},
}
);
})(
jQuery,
this
),
(function (
$
) {
($.mobile.SerialTransition = function (
) {
this.init.apply(
this,
arguments
);
}),
$.extend(
$.mobile.SerialTransition.prototype,
$.mobile.Transition.prototype,
{
sequential: !0,
beforeDoneOut: function (
) {
this.$from && this.cleanFrom(
);
},
beforeStartOut: function (
screenHeight, reverseClass, none
) {
this.$from.animationComplete(
$.proxy(
function (
) {
this.doneOut(
screenHeight,
reverseClass,
none
);
},
this
),
);
},
},
);
})(
jQuery
),
(function (
$
) {
($.mobile.ConcurrentTransition = function (
) {
this.init.apply(
this,
arguments
);
}),
$.extend(
$.mobile.ConcurrentTransition.prototype,
$.mobile.Transition.prototype,
{
sequential: !1,
beforeDoneIn: function (
) {
this.$from && this.cleanFrom(
);
},
beforeStartOut: function (
screenHeight, reverseClass, none
) {
this.doneOut(
screenHeight,
reverseClass,
none
);
},
},
);
})(
jQuery
),
(function (
$
) {
($.mobile.transitionHandlers = {
sequential: $.mobile.SerialTransition,
simultaneous: $.mobile.ConcurrentTransition,
}),
($.mobile.defaultTransitionHandler =
$.mobile.transitionHandlers.sequential),
($.mobile.transitionFallbacks = {
}),
($.mobile._maybeDegradeTransition = function (
transition
) {
return (
transition &&
!$.support.cssTransform3d &&
$.mobile.transitionFallbacks[transition] &&
(transition = $.mobile.transitionFallbacks[transition]),
transition
);
}),
($.mobile.getMaxScrollForTransition =
$.mobile.getMaxScrollForTransition ||
function (
) {
return 3 * $.mobile.getScreenHeight(
);
});
})(
jQuery
),
(function (
$, window, undefined
) {
$.mobile.transitionFallbacks.flip = "fade";
})(
jQuery
),
(function (
$, window, undefined
) {
$.mobile.transitionFallbacks.flow = "fade";
})(
jQuery
),
(function (
$, window, undefined
) {
$.mobile.transitionFallbacks.pop = "fade";
})(
jQuery
),
(function (
$, window, undefined
) {
($.mobile.transitionHandlers.slide =
$.mobile.transitionHandlers.simultaneous),
($.mobile.transitionFallbacks.slide = "fade");
})(
jQuery
),
(function (
$, window, undefined
) {
$.mobile.transitionFallbacks.slidedown = "fade";
})(
jQuery
),
(function (
$, window, undefined
) {
$.mobile.transitionFallbacks.slidefade = "fade";
})(
jQuery
),
(function (
$, window, undefined
) {
$.mobile.transitionFallbacks.slideup = "fade";
})(
jQuery
),
(function (
$, window, undefined
) {
$.mobile.transitionFallbacks.turn = "fade";
})(
jQuery
),
(function (
$, undefined
) {
($.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,
}),
($.mobile.page.prototype.options.degradeInputs =
$.mobile.degradeInputs),
($.mobile.degradeInputsWithin = function (
target
) {
(target = $(
target
))
.find(
"input"
)
.not(
$.mobile.page.prototype.keepNativeSelector(
)
)
.each(
function (
) {
var html,
hasType,
findstr,
repstr,
element = $(
this
),
type = this.getAttribute(
"type"
),
optType = $.mobile.degradeInputs[type] || "text";
$.mobile.degradeInputs[type] &&
((findstr = (hasType =
(html = $(
"<div>"
).html(
element.clone(
)
).html(
)).indexOf(
" type=",
) > -1)
? /\s+type=["']?\w+['"]?/
: /\/?>/),
(repstr =
' type="' +
optType +
'" data-' +
$.mobile.ns +
'type="' +
type +
'"' +
(hasType ? "" : ">")),
element.replaceWith(
html.replace(
findstr,
repstr
)
));
}
);
});
})(
jQuery
),
(function (
$, window, undefined
) {
$.widget(
"mobile.page",
$.mobile.page,
{
options: {
closeBtn: "left",
closeBtnText: "Close",
overlayTheme: "a",
corners: !0,
dialog: !1,
},
_create: function (
) {
this._super(
),
this.options.dialog &&
($.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(
$(
"<div/>",
{
role: "dialog",
class:
"ui-dialog-contain ui-overlay-shadow" +
(this.options.corners ? " ui-corner-all" : ""),
}
),
);
},
_setOptions: function (
options
) {
var closeButtonLocation,
closeButtonText,
currentOpts = this.options;
undefined !== options.corners &&
this._inner.toggleClass(
"ui-corner-all",
!!options.corners
),
undefined !== options.overlayTheme &&
$.mobile.activePage[0] === this.element[0] &&
((currentOpts.overlayTheme = options.overlayTheme),
this._handlePageBeforeShow(
)),
undefined !== options.closeBtnText &&
((closeButtonLocation = currentOpts.closeBtn),
(closeButtonText = options.closeBtnText)),
undefined !== options.closeBtn &&
(closeButtonLocation = options.closeBtn),
closeButtonLocation &&
this._setCloseBtn(
closeButtonLocation,
closeButtonText
),
this._super(
options
);
},
_handlePageBeforeShow: function (
) {
this.options.overlayTheme && this.options.dialog
? (this.removeContainerBackground(
),
this.setContainerBackground(
this.options.overlayTheme
))
: this._super(
);
},
_setCloseBtn: function (
location, text
) {
var dst,
btn = this._headerCloseButton;
"none" ===
(location =
"left" === location
? "left"
: "right" === location
? "right"
: "none")
? btn && (btn.remove(
), (btn = null))
: btn
? (btn
.removeClass(
"ui-btn-left ui-btn-right"
)
.addClass(
"ui-btn-" + location
),
text && btn.text(
text
))
: ((dst = this._inner.find(
":jqmData(role='header')"
).first(
)),
(btn = $(
"<a></a>",
{
href: "#",
class:
"ui-btn ui-corner-all ui-icon-delete ui-btn-icon-notext ui-btn-" +
location,
}
)
.attr(
"data-" + $.mobile.ns + "rel",
"back"
)
.text(
text || this.options.closeBtnText || ""
)
.prependTo(
dst
))),
(this._headerCloseButton = btn);
},
}
);
})(
jQuery
),
(function (
$, window, undefined
) {
$.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 (
event
) {
var attrs,
$target = $(
event.target
).closest(
"vclick" === event.type ? "a" : "form",
);
$target.length &&
!$target.jqmData(
"transition"
) &&
(((attrs = {
})["data-" + $.mobile.ns + "transition"] =
($.mobile.navigate.history.getActive(
) || {
}).transition ||
$.mobile.defaultDialogTransition),
(attrs["data-" + $.mobile.ns + "direction"] = "reverse"),
$target.attr(
attrs
));
},
_create: function (
) {
var elem = this.element,
opts = this.options;
elem
.addClass(
"ui-dialog"
)
.wrapInner(
$(
"<div/>",
{
role: "dialog",
class:
"ui-dialog-contain ui-overlay-shadow" +
(opts.corners ? " ui-corner-all" : ""),
}
),
),
$.extend(
this,
{
_isCloseable: !1,
_inner: elem.children(
),
_headerCloseButton: null,
}
),
this._on(
elem,
{
vclick: "_handleVClickSubmit",
submit: "_handleVClickSubmit",
pagebeforeshow: "_handlePageBeforeShow",
pagebeforehide: "_handlePageBeforeHide",
}
),
this._setCloseBtn(
opts.closeBtn
);
},
_setOptions: function (
options
) {
var closeButtonLocation,
closeButtonText,
currentOpts = this.options;
undefined !== options.corners &&
this._inner.toggleClass(
"ui-corner-all",
!!options.corners
),
undefined !== options.overlayTheme &&
$.mobile.activePage[0] === this.element[0] &&
((currentOpts.overlayTheme = options.overlayTheme),
this._handlePageBeforeShow(
)),
undefined !== options.closeBtnText &&
((closeButtonLocation = currentOpts.closeBtn),
(closeButtonText = options.closeBtnText)),
undefined !== options.closeBtn &&
(closeButtonLocation = options.closeBtn),
closeButtonLocation &&
this._setCloseBtn(
closeButtonLocation,
closeButtonText
),
this._super(
options
);
},
_setCloseBtn: function (
location, text
) {
var dst,
btn = this._headerCloseButton;
"none" ===
(location =
"left" === location
? "left"
: "right" === location
? "right"
: "none")
? btn && (btn.remove(
), (btn = null))
: btn
? (btn
.removeClass(
"ui-btn-left ui-btn-right"
)
.addClass(
"ui-btn-" + location
),
text && btn.text(
text
))
: ((dst = this._inner.find(
":jqmData(role='header')"
).first(
)),
(btn = $(
"<a></a>",
{
role: "button",
href: "#",
class:
"ui-btn ui-corner-all ui-icon-delete ui-btn-icon-notext ui-btn-" +
location,
}
)
.text(
text || this.options.closeBtnText || ""
)
.prependTo(
dst
)),
this._on(
btn,
{
click: "close",
}
)),
(this._headerCloseButton = btn);
},
close: function (
) {
var hist = $.mobile.navigate.history;
this._isCloseable &&
((this._isCloseable = !1),
$.mobile.hashListeningEnabled && hist.activeIndex > 0
? $.mobile.back(
)
: $.mobile.pageContainer.pagecontainer(
"back"
));
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
var rInitialLetter = /([A-Z])/g,
iconposClass = function (
iconpos
) {
return "ui-btn-icon-" + (null === iconpos ? "left" : iconpos);
};
$.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 elem = this.element,
ui = {
accordion: elem
.closest(
":jqmData(role='collapsible-set'),:jqmData(role='collapsibleset')" +
($.mobile.collapsibleset ? ", :mobile-collapsibleset" : ""),
)
.addClass(
"ui-collapsible-set"
),
};
(this._ui = ui),
(this._renderedOptions = this._getOptions(
this.options
)),
this.options.enhanced
? ((ui.heading = $(
".ui-collapsible-heading",
this.element[0]
)),
(ui.content = ui.heading.next(
)),
(ui.anchor = $(
"a",
ui.heading[0]
).first(
)),
(ui.status = ui.anchor.children(
".ui-collapsible-heading-status",
)))
: this._enhance(
elem,
ui
),
this._on(
ui.heading,
{
tap: function (
) {
ui.heading.find(
"a"
).first(
).addClass(
$.mobile.activeBtnClass
);
},
click: function (
event
) {
this._handleExpandCollapse(
!ui.heading.hasClass(
"ui-collapsible-heading-collapsed"
),
),
event.preventDefault(
),
event.stopPropagation(
);
},
}
);
},
_getOptions: function (
options
) {
var key,
accordion = this._ui.accordion,
accordionWidget = this._ui.accordionWidget;
for (key in ((options = $.extend(
{
},
options
)),
accordion.length &&
!accordionWidget &&
(this._ui.accordionWidget = accordionWidget = accordion.data(
"mobile-collapsibleset",
)),
options))
(options[key] =
null != options[key]
? options[key]
: accordionWidget
? accordionWidget.options[key]
: accordion.length
? $.mobile.getAttribute(
accordion[0],
key.replace(
rInitialLetter,
"-$1"
).toLowerCase(
),
)
: null),
null == options[key] &&
(options[key] = $.mobile.collapsible.defaults[key]);
return options;
},
_themeClassFromOption: function (
prefix, value
) {
return value ? ("none" === value ? "" : prefix + value) : "";
},
_enhance: function (
elem, ui
) {
var iconclass,
opts = this._renderedOptions,
contentThemeClass = this._themeClassFromOption(
"ui-body-",
opts.contentTheme,
);
return (
elem.addClass(
"ui-collapsible " +
(opts.inset ? "ui-collapsible-inset " : "") +
(opts.inset && opts.corners ? "ui-corner-all " : "") +
(contentThemeClass ? "ui-collapsible-themed-content " : ""),
),
(ui.originalHeading = elem.children(
this.options.heading
).first(
)),
(ui.content = elem
.wrapInner(
"<div class='ui-collapsible-content " +
contentThemeClass +
"'></div>",
)
.children(
".ui-collapsible-content"
)),
(ui.heading = ui.originalHeading),
ui.heading.is(
"legend"
) &&
((ui.heading = $(
"<div role='heading'>" + ui.heading.html(
) + "</div>",
)),
(ui.placeholder = $(
"<div>\x3c!-- placeholder for legend --\x3e</div>",
).insertBefore(
ui.originalHeading
)),
ui.originalHeading.remove(
)),
(iconclass = opts.collapsed
? opts.collapsedIcon
? "ui-icon-" + opts.collapsedIcon
: ""
: opts.expandedIcon
? "ui-icon-" + opts.expandedIcon
: ""),
(ui.status = $(
"<span class='ui-collapsible-heading-status'></span>",
)),
(ui.anchor = ui.heading
.detach(
)
.addClass(
"ui-collapsible-heading"
)
.append(
ui.status
)
.wrapInner(
"<a href='#' class='ui-collapsible-heading-toggle'></a>",
)
.find(
"a"
)
.first(
)
.addClass(
"ui-btn " +
(iconclass ? iconclass + " " : "") +
(iconclass
? iconposClass(
opts.iconpos
) + " "
: "") +
this._themeClassFromOption(
"ui-btn-",
opts.theme
) +
" " +
(opts.mini ? "ui-mini " : ""),
)),
ui.heading.insertBefore(
ui.content
),
this._handleExpandCollapse(
this.options.collapsed
),
ui
);
},
refresh: function (
) {
this._applyOptions(
this.options
),
(this._renderedOptions = this._getOptions(
this.options
));
},
_applyOptions: function (
options
) {
var isCollapsed,
newTheme,
oldTheme,
hasCorners,
hasIcon,
elem = this.element,
currentOpts = this._renderedOptions,
ui = this._ui,
anchor = ui.anchor,
status = ui.status,
opts = this._getOptions(
options
);
undefined !== options.collapsed &&
this._handleExpandCollapse(
options.collapsed
),
(isCollapsed = elem.hasClass(
"ui-collapsible-collapsed"
))
? undefined !== opts.expandCueText &&
status.text(
opts.expandCueText
)
: undefined !== opts.collapseCueText &&
status.text(
opts.collapseCueText
),
(hasIcon =
undefined !== opts.collapsedIcon
? !1 !== opts.collapsedIcon
: !1 !== currentOpts.collapsedIcon),
(undefined === opts.iconpos &&
undefined === opts.collapsedIcon &&
undefined === opts.expandedIcon) ||
(anchor.removeClass(
[iconposClass(
currentOpts.iconpos
),]
.concat(
currentOpts.expandedIcon
? ["ui-icon-" + currentOpts.expandedIcon,]
: [],
)
.concat(
currentOpts.collapsedIcon
? ["ui-icon-" + currentOpts.collapsedIcon,]
: [],
)
.join(
" "
),
),
hasIcon &&
anchor.addClass(
[
iconposClass(
undefined !== opts.iconpos
? opts.iconpos
: currentOpts.iconpos,
),
]
.concat(
isCollapsed
? [
"ui-icon-" +
(undefined !== opts.collapsedIcon
? opts.collapsedIcon
: currentOpts.collapsedIcon),
]
: [
"ui-icon-" +
(undefined !== opts.expandedIcon
? opts.expandedIcon
: currentOpts.expandedIcon),
],
)
.join(
" "
),
)),
undefined !== opts.theme &&
((oldTheme = this._themeClassFromOption(
"ui-btn-",
currentOpts.theme,
)),
(newTheme = this._themeClassFromOption(
"ui-btn-",
opts.theme
)),
anchor.removeClass(
oldTheme
).addClass(
newTheme
)),
undefined !== opts.contentTheme &&
((oldTheme = this._themeClassFromOption(
"ui-body-",
currentOpts.contentTheme,
)),
(newTheme = this._themeClassFromOption(
"ui-body-",
opts.contentTheme,
)),
ui.content.removeClass(
oldTheme
).addClass(
newTheme
)),
undefined !== opts.inset &&
(elem.toggleClass(
"ui-collapsible-inset",
opts.inset
),
(hasCorners = !(
!opts.inset ||
(!opts.corners && !currentOpts.corners)
))),
undefined !== opts.corners &&
(hasCorners = !(
!opts.corners ||
(!opts.inset && !currentOpts.inset)
)),
undefined !== hasCorners &&
elem.toggleClass(
"ui-corner-all",
hasCorners
),
undefined !== opts.mini && anchor.toggleClass(
"ui-mini",
opts.mini
);
},
_setOptions: function (
options
) {
this._applyOptions(
options
),
this._super(
options
),
(this._renderedOptions = this._getOptions(
this.options
));
},
_handleExpandCollapse: function (
isCollapse
) {
var opts = this._renderedOptions,
ui = this._ui;
ui.status.text(
isCollapse ? opts.expandCueText : opts.collapseCueText,
),
ui.heading
.toggleClass(
"ui-collapsible-heading-collapsed",
isCollapse
)
.find(
"a"
)
.first(
)
.toggleClass(
"ui-icon-" + opts.expandedIcon,
!isCollapse
)
.toggleClass(
"ui-icon-" + opts.collapsedIcon,
isCollapse || opts.expandedIcon === opts.collapsedIcon,
)
.removeClass(
$.mobile.activeBtnClass
),
this.element.toggleClass(
"ui-collapsible-collapsed",
isCollapse
),
ui.content
.toggleClass(
"ui-collapsible-content-collapsed",
isCollapse
)
.attr(
"aria-hidden",
isCollapse
)
.trigger(
"updatelayout"
),
(this.options.collapsed = isCollapse),
this._trigger(
isCollapse ? "collapse" : "expand"
);
},
expand: function (
) {
this._handleExpandCollapse(
!1
);
},
collapse: function (
) {
this._handleExpandCollapse(
!0
);
},
_destroy: function (
) {
var ui = this._ui;
this.options.enhanced ||
(ui.placeholder
? (ui.originalHeading.insertBefore(
ui.placeholder
),
ui.placeholder.remove(
),
ui.heading.remove(
))
: (ui.status.remove(
),
ui.heading
.removeClass(
"ui-collapsible-heading ui-collapsible-heading-collapsed",
)
.children(
)
.contents(
)
.unwrap(
)),
ui.anchor.contents(
).unwrap(
),
ui.content.contents(
).unwrap(
),
this.element.removeClass(
"ui-collapsible ui-collapsible-collapsed ui-collapsible-themed-content ui-collapsible-inset ui-corner-all",
));
},
}
),
($.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,
});
})(
jQuery
),
(function (
$, undefined
) {
$.mobile.behaviors.addFirstLastClasses = {
_getVisibles: function (
$els, create
) {
var visibles;
return (
(create || 0 === (visibles = $els.filter(
":visible"
)).length) &&
(visibles = $els.not(
".ui-screen-hidden"
)),
visibles
);
},
_addFirstLastClasses: function (
$els, $visibles, create
) {
$els.removeClass(
"ui-first-child ui-last-child"
),
$visibles
.eq(
0
)
.addClass(
"ui-first-child"
)
.end(
)
.last(
)
.addClass(
"ui-last-child"
),
create || this.element.trigger(
"updatelayout"
);
},
_removeFirstLastClasses: function (
$els
) {
$els.removeClass(
"ui-first-child ui-last-child"
);
},
};
})(
jQuery
),
(function (
$, undefined
) {
var childCollapsiblesSelector =
":mobile-collapsible, " + $.mobile.collapsible.initSelector;
$.widget(
"mobile.collapsibleset",
$.extend(
{
initSelector:
":jqmData(role='collapsible-set'),:jqmData(role='collapsibleset')",
options: $.extend(
{
enhanced: !1,
},
$.mobile.collapsible.defaults
),
_handleCollapsibleExpand: function (
event
) {
var closestCollapsible = $(
event.target
).closest(
".ui-collapsible",
);
closestCollapsible
.parent(
)
.is(
":mobile-collapsibleset, :jqmData(role='collapsible-set')",
) &&
closestCollapsible
.siblings(
".ui-collapsible:not(.ui-collapsible-collapsed)"
)
.collapsible(
"collapse"
);
},
_create: function (
) {
var elem = this.element,
opts = this.options;
$.extend(
this,
{
_classes: "",
}
),
opts.enhanced ||
(elem.addClass(
"ui-collapsible-set " +
this._themeClassFromOption(
"ui-group-theme-",
opts.theme,
) +
" " +
(opts.corners && opts.inset ? "ui-corner-all " : ""),
),
this.element
.find(
$.mobile.collapsible.initSelector
)
.collapsible(
)),
this._on(
elem,
{
collapsibleexpand: "_handleCollapsibleExpand",
}
);
},
_themeClassFromOption: function (
prefix, value
) {
return value ? ("none" === value ? "" : prefix + value) : "";
},
_init: function (
) {
this._refresh(
!0
),
this.element
.children(
childCollapsiblesSelector
)
.filter(
":jqmData(collapsed='false')"
)
.collapsible(
"expand"
);
},
_setOptions: function (
options
) {
var ret,
hasCorners,
elem = this.element,
themeClass = this._themeClassFromOption(
"ui-group-theme-",
options.theme,
);
return (
themeClass &&
elem
.removeClass(
this._themeClassFromOption(
"ui-group-theme-",
this.options.theme,
),
)
.addClass(
themeClass
),
undefined !== options.inset &&
(hasCorners = !(
!options.inset ||
(!options.corners && !this.options.corners)
)),
undefined !== options.corners &&
(hasCorners = !(
!options.corners ||
(!options.inset && !this.options.inset)
)),
undefined !== hasCorners &&
elem.toggleClass(
"ui-corner-all",
hasCorners
),
(ret = this._super(
options
)),
this.element
.children(
":mobile-collapsible"
)
.collapsible(
"refresh"
),
ret
);
},
_destroy: function (
) {
var el = this.element;
this._removeFirstLastClasses(
el.children(
childCollapsiblesSelector
),
),
el
.removeClass(
"ui-collapsible-set ui-corner-all " +
this._themeClassFromOption(
"ui-group-theme-",
this.options.theme,
),
)
.children(
":mobile-collapsible"
)
.collapsible(
"destroy"
);
},
_refresh: function (
create
) {
var collapsiblesInSet = this.element.children(
childCollapsiblesSelector,
);
this.element
.find(
$.mobile.collapsible.initSelector
)
.not(
".ui-collapsible"
)
.collapsible(
),
this._addFirstLastClasses(
collapsiblesInSet,
this._getVisibles(
collapsiblesInSet,
create
),
create,
);
},
refresh: function (
) {
this._refresh(
!1
);
},
},
$.mobile.behaviors.addFirstLastClasses,
),
);
})(
jQuery
),
(function (
$, undefined
) {
$.fn.fieldcontain = function (
) {
return this.addClass(
"ui-field-contain"
);
};
})(
jQuery
),
(function (
$, undefined
) {
$.fn.grid = function (
options
) {
return this.each(
function (
) {
var iterator,
letter,
$this = $(
this
),
o = $.extend(
{
grid: null,
},
options
),
$kids = $this.children(
),
gridCols = {
solo: 1,
a: 2,
b: 3,
c: 4,
d: 5,
},
grid = o.grid;
if (!grid)
if ($kids.length <= 5)
for (letter in gridCols)
gridCols[letter] === $kids.length && (grid = letter);
else (grid = "a"), $this.addClass(
"ui-grid-duo"
);
(iterator = gridCols[grid]),
$this.addClass(
"ui-grid-" + grid
),
$kids
.filter(
":nth-child(" + iterator + "n+1)"
)
.addClass(
"ui-block-a"
),
iterator > 1 &&
$kids
.filter(
":nth-child(" + iterator + "n+2)"
)
.addClass(
"ui-block-b"
),
iterator > 2 &&
$kids
.filter(
":nth-child(" + iterator + "n+3)"
)
.addClass(
"ui-block-c"
),
iterator > 3 &&
$kids
.filter(
":nth-child(" + iterator + "n+4)"
)
.addClass(
"ui-block-d"
),
iterator > 4 &&
$kids
.filter(
":nth-child(" + iterator + "n+5)"
)
.addClass(
"ui-block-e"
);
}
);
};
})(
jQuery
),
(function (
$, undefined
) {
$.widget(
"mobile.navbar",
{
options: {
iconpos: "top",
grid: null,
},
_create: function (
) {
var $navbar = this.element,
$navbtns = $navbar.find(
"a"
),
iconpos = $navbtns.filter(
":jqmData(icon)"
).length
? this.options.iconpos
: undefined;
$navbar
.addClass(
"ui-navbar"
)
.attr(
"role",
"navigation"
)
.find(
"ul"
)
.jqmEnhanceable(
)
.grid(
{
grid: this.options.grid,
}
),
$navbtns.each(
function (
) {
var icon = $.mobile.getAttribute(
this,
"icon"
),
theme = $.mobile.getAttribute(
this,
"theme"
),
classes = "ui-btn";
theme && (classes += " ui-btn-" + theme),
icon &&
(classes += " ui-icon-" + icon + " ui-btn-icon-" + iconpos),
$(
this
).addClass(
classes
);
}
),
$navbar.delegate(
"a",
"vclick",
function (
) {
var activeBtn = $(
this
);
activeBtn.hasClass(
"ui-state-disabled"
) ||
activeBtn.hasClass(
"ui-disabled"
) ||
activeBtn.hasClass(
$.mobile.activeBtnClass
) ||
($navbtns.removeClass(
$.mobile.activeBtnClass
),
activeBtn.addClass(
$.mobile.activeBtnClass
),
$(
document
).one(
"pagehide",
function (
) {
activeBtn.removeClass(
$.mobile.activeBtnClass
);
}
));
}
),
$navbar.closest(
".ui-page"
).bind(
"pagebeforeshow",
function (
) {
$navbtns
.filter(
".ui-state-persist"
)
.addClass(
$.mobile.activeBtnClass
);
}
);
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
var getAttr = $.mobile.getAttribute;
$.widget(
"mobile.listview",
$.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 t = this,
listviewClasses = "";
(listviewClasses += t.options.inset ? " ui-listview-inset" : ""),
t.options.inset &&
((listviewClasses += t.options.corners
? " ui-corner-all"
: ""),
(listviewClasses += t.options.shadow ? " ui-shadow" : "")),
t.element.addClass(
" ui-listview" + listviewClasses
),
t.refresh(
!0
);
},
_findFirstElementByTagName: function (
ele,
nextProp,
lcName,
ucName,
) {
var dict = {
};
for (dict[lcName] = dict[ucName] = !0; ele; ) {
if (dict[ele.nodeName]) return ele;
ele = ele[nextProp];
}
return null;
},
_addThumbClasses: function (
containers
) {
var i,
img,
len = containers.length;
for (i = 0; i < len; i++)
(img = $(
this._findFirstElementByTagName(
containers[i].firstChild,
"nextSibling",
"img",
"IMG",
),
)).length &&
$(
this._findFirstElementByTagName(
img[0].parentNode,
"parentNode",
"li",
"LI",
),
).addClass(
img.hasClass(
"ui-li-icon"
)
? "ui-li-has-icon"
: "ui-li-has-thumb",
);
},
_getChildrenByTagName: function (
ele, lcName, ucName
) {
var results = [],
dict = {
};
for (
dict[lcName] = dict[ucName] = !0, ele = ele.firstChild;
ele;
)
dict[ele.nodeName] && results.push(
ele
),
(ele = ele.nextSibling);
return $(
results
);
},
_beforeListviewRefresh: $.noop,
_afterListviewRefresh: $.noop,
refresh: function (
create
) {
var buttonClass,
pos,
numli,
item,
itemClass,
itemTheme,
itemIcon,
icon,
a,
isDivider,
startCount,
newStartCount,
value,
last,
splittheme,
splitThemeClass,
altButtonClass,
li,
o = this.options,
$list = this.element,
ol = !!$.nodeName(
$list[0],
"ol"
),
start = $list.attr(
"start"
),
itemClassDict = {
},
countBubbles = $list.find(
".ui-li-count"
),
countTheme =
getAttr(
$list[0],
"counttheme"
) || this.options.countTheme,
countThemeClass = countTheme
? "ui-body-" + countTheme
: "ui-body-inherit";
for (
o.theme && $list.addClass(
"ui-group-theme-" + o.theme
),
ol &&
(start || 0 === start) &&
((startCount = parseInt(
start,
10
) - 1),
$list.css(
"counter-reset",
"listnumbering " + startCount
)),
this._beforeListviewRefresh(
),
pos = 0,
numli = (li = this._getChildrenByTagName(
$list[0],
"li",
"LI",
)).length;
pos < numli;
pos++
)
(item = li.eq(
pos
)),
(itemClass = ""),
(create ||
item[0].className.search(
/\bui-li-static\b|\bui-li-divider\b/,
) < 0) &&
((a = this._getChildrenByTagName(
item[0],
"a",
"A"
)),
(isDivider = "list-divider" === getAttr(
item[0],
"role"
)),
(value = item.attr(
"value"
)),
(itemTheme = getAttr(
item[0],
"theme"
)),
a.length &&
a[0].className.search(
/\bui-btn\b/
) < 0 &&
!isDivider
? ((icon =
!1 !== (itemIcon = getAttr(
item[0],
"icon"
)) &&
(itemIcon || o.icon)),
a.removeClass(
"ui-link"
),
(buttonClass = "ui-btn"),
itemTheme && (buttonClass += " ui-btn-" + itemTheme),
a.length > 1
? ((itemClass = "ui-li-has-alt"),
(last = a.last(
)),
(splitThemeClass = (splittheme =
getAttr(
last[0],
"theme"
) ||
o.splitTheme ||
getAttr(
item[0],
"theme",
!0
))
? " ui-btn-" + splittheme
: ""),
(altButtonClass =
"ui-btn ui-btn-icon-notext ui-icon-" +
(getAttr(
last[0],
"icon"
) ||
getAttr(
item[0],
"icon"
) ||
o.splitIcon) +
splitThemeClass),
last
.attr(
"title",
$.trim(
last.getEncodedText(
)
)
)
.addClass(
altButtonClass
)
.empty(
))
: icon &&
(buttonClass +=
" ui-btn-icon-right ui-icon-" + icon),
a.first(
).addClass(
buttonClass
))
: isDivider
? ((itemClass =
"ui-li-divider ui-bar-" +
(getAttr(
item[0],
"theme"
) ||
o.dividerTheme ||
o.theme ||
"inherit")),
item.attr(
"role",
"heading"
))
: a.length <= 0 &&
(itemClass =
"ui-li-static ui-body-" + (itemTheme || "inherit")),
ol &&
value &&
((newStartCount = parseInt(
value,
10
) - 1),
item.css(
"counter-reset",
"listnumbering " + newStartCount,
))),
itemClassDict[itemClass] || (itemClassDict[itemClass] = []),
itemClassDict[itemClass].push(
item[0]
);
for (itemClass in itemClassDict)
$(
itemClassDict[itemClass]
).addClass(
itemClass
);
countBubbles.each(
function (
) {
$(
this
).closest(
"li"
).addClass(
"ui-li-has-count"
);
}
),
countThemeClass && countBubbles.addClass(
countThemeClass
),
this._addThumbClasses(
li
),
this._addThumbClasses(
li.find(
".ui-btn"
)
),
this._afterListviewRefresh(
),
this._addFirstLastClasses(
li,
this._getVisibles(
li,
create
),
create,
);
},
},
$.mobile.behaviors.addFirstLastClasses,
),
);
})(
jQuery
),
(function (
$, undefined
) {
$.widget(
"mobile.listview",
$.mobile.listview,
{
options: {
autodividers: !1,
autodividersSelector: function (
elt
) {
var text = $.trim(
elt.text(
)
) || null;
return text
? (text = text.slice(
0,
1
).toUpperCase(
))
: null;
},
},
_beforeListviewRefresh: function (
) {
this.options.autodividers &&
(this._replaceDividers(
), this._superApply(
arguments
));
},
_replaceDividers: function (
) {
var i,
lis,
li,
dividerText,
divider,
lastDividerText = null,
list = this.element;
for (
list.children(
"li:jqmData(role='list-divider')"
).remove(
),
lis = list.children(
"li"
),
i = 0;
i < lis.length;
i++
)
(li = lis[i]),
(dividerText = this.options.autodividersSelector(
$(
li
)
)) &&
lastDividerText !== dividerText &&
((divider = document.createElement(
"li"
)).appendChild(
document.createTextNode(
dividerText
),
),
divider.setAttribute(
"data-" + $.mobile.ns + "role",
"list-divider",
),
li.parentNode.insertBefore(
divider,
li
)),
(lastDividerText = dividerText);
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
var rdivider = /(^|\s)ui-li-divider($|\s)/,
rhidden = /(^|\s)ui-screen-hidden($|\s)/;
$.widget(
"mobile.listview",
$.mobile.listview,
{
options: {
hideDividers: !1,
},
_afterListviewRefresh: function (
) {
var items,
idx,
item,
hideDivider = !0;
if ((this._superApply(
arguments
), this.options.hideDividers))
for (
idx =
(items = this._getChildrenByTagName(
this.element[0],
"li",
"LI",
)).length - 1;
idx > -1;
idx--
)
(item = items[idx]).className.match(
rdivider
)
? (hideDivider &&
(item.className = item.className + " ui-screen-hidden"),
(hideDivider = !0))
: item.className.match(
rhidden
) || (hideDivider = !1);
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
$.mobile.nojs = function (
target
) {
$(
":jqmData(role='nojs')",
target
).addClass(
"ui-nojs"
);
};
})(
jQuery
),
(function (
$, undefined
) {
$.mobile.behaviors.formReset = {
_handleFormReset: function (
) {
this._on(
this.element.closest(
"form"
),
{
reset: function (
) {
this._delay(
"_reset"
);
},
}
);
},
};
})(
jQuery
),
(function (
$, undefined
) {
var escapeId = $.mobile.path.hashToSelector;
$.widget(
"mobile.checkboxradio",
$.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 input = this.element,
o = this.options,
inheritAttr = function (
input, dataAttr
) {
return (
input.jqmData(
dataAttr
) ||
input.closest(
"form, fieldset"
).jqmData(
dataAttr
)
);
},
parentLabel = input.closest(
"label"
),
label = parentLabel.length
? parentLabel
: input
.closest(
"form, fieldset, :jqmData(role='page'), :jqmData(role='dialog')",
)
.find(
"label"
)
.filter(
"[for='" + escapeId(
input[0].id
) + "']"
)
.first(
),
inputtype = input[0].type,
checkedClass = "ui-" + inputtype + "-on",
uncheckedClass = "ui-" + inputtype + "-off";
("checkbox" !== inputtype && "radio" !== inputtype) ||
(this.element[0].disabled && (this.options.disabled = !0),
(o.iconpos =
inheritAttr(
input,
"iconpos"
) ||
label.attr(
"data-" + $.mobile.ns + "iconpos"
) ||
o.iconpos),
(o.mini = inheritAttr(
input,
"mini"
) || o.mini),
$.extend(
this,
{
input: input,
label: label,
parentLabel: parentLabel,
inputtype: inputtype,
checkedClass: checkedClass,
uncheckedClass: uncheckedClass,
}
),
this.options.enhanced || this._enhance(
),
this._on(
label,
{
vmouseover: "_handleLabelVMouseOver",
vclick: "_handleLabelVClick",
}
),
this._on(
input,
{
vmousedown: "_cacheVals",
vclick: "_handleInputVClick",
focus: "_handleInputFocus",
blur: "_handleInputBlur",
}
),
this._handleFormReset(
),
this.refresh(
));
},
_enhance: function (
) {
this.label.addClass(
"ui-btn ui-corner-all"
),
this.parentLabel.length > 0
? 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 $(
"<div class='" +
(this.options.wrapperClass ? this.options.wrapperClass : "") +
" ui-" +
this.inputtype +
(this.options.disabled ? " ui-state-disabled" : "") +
"' ></div>",
);
},
_handleInputFocus: function (
) {
this.label.addClass(
$.mobile.focusClass
);
},
_handleInputBlur: function (
) {
this.label.removeClass(
$.mobile.focusClass
);
},
_handleInputVClick: function (
) {
this.element.prop(
"checked",
this.element.is(
":checked"
)
),
this._getInputSet(
).not(
this.element
).prop(
"checked",
!1
),
this._updateAll(
);
},
_handleLabelVMouseOver: function (
event
) {
this.label.parent(
).hasClass(
"ui-state-disabled"
) &&
event.stopPropagation(
);
},
_handleLabelVClick: function (
event
) {
var input = this.element;
if (!input.is(
":disabled"
))
return (
this._cacheVals(
),
input.prop(
"checked",
"radio" === this.inputtype || !input.prop(
"checked"
),
),
input.triggerHandler(
"click"
),
this._getInputSet(
).not(
input
).prop(
"checked",
!1
),
this._updateAll(
),
!1
);
event.preventDefault(
);
},
_cacheVals: function (
) {
this._getInputSet(
).each(
function (
) {
$(
this
).attr(
"data-" + $.mobile.ns + "cacheVal",
this.checked
);
}
);
},
_getInputSet: function (
) {
var selector,
formId,
radio = this.element[0],
name = radio.name,
form = radio.form,
doc = this.element.parents(
).last(
).get(
0
),
radios = this.element;
return (
name &&
"radio" === this.inputtype &&
doc &&
((selector =
"input[type='radio'][name='" + escapeId(
name
) + "']"),
form
? ((formId = form.id) &&
(radios = $(
selector + "[form='" + escapeId(
formId
) + "']",
doc,
)),
(radios = $(
form
)
.find(
selector
)
.filter(
function (
) {
return this.form === form;
}
)
.add(
radios
)))
: (radios = $(
selector,
doc
).filter(
function (
) {
return !this.form;
}
))),
radios
);
},
_updateAll: function (
) {
var self = this;
this._getInputSet(
)
.each(
function (
) {
var $this = $(
this
);
(this.checked || "checkbox" === self.inputtype) &&
$this.trigger(
"change"
);
}
)
.checkboxradio(
"refresh"
);
},
_reset: function (
) {
this.refresh(
);
},
_hasIcon: function (
) {
var controlgroup,
controlgroupWidget,
controlgroupConstructor = $.mobile.controlgroup;
return (
!(
controlgroupConstructor &&
(controlgroup = this.element.closest(
":mobile-controlgroup," +
controlgroupConstructor.prototype.initSelector,
)).length > 0
) ||
"horizontal" !==
((controlgroupWidget = $.data(
controlgroup[0],
"mobile-controlgroup",
))
? controlgroupWidget.options.type
: controlgroup.attr(
"data-" + $.mobile.ns + "type"
))
);
},
refresh: function (
) {
var hasIcon = this._hasIcon(
),
isChecked = this.element[0].checked,
active = $.mobile.activeBtnClass,
iconposClass = "ui-btn-icon-" + this.options.iconpos,
addClasses = [],
removeClasses = [];
hasIcon
? (removeClasses.push(
active
), addClasses.push(
iconposClass
))
: (removeClasses.push(
iconposClass
),
(isChecked ? addClasses : removeClasses).push(
active
)),
isChecked
? (addClasses.push(
this.checkedClass
),
removeClasses.push(
this.uncheckedClass
))
: (addClasses.push(
this.uncheckedClass
),
removeClasses.push(
this.checkedClass
)),
this.label
.addClass(
addClasses.join(
" "
)
)
.removeClass(
removeClasses.join(
" "
)
);
},
widget: function (
) {
return this.label.parent(
);
},
_setOptions: function (
options
) {
var label = this.label,
currentOptions = this.options,
outer = this.widget(
),
hasIcon = this._hasIcon(
);
undefined !== options.disabled &&
(this.input.prop(
"disabled",
!!options.disabled
),
outer.toggleClass(
"ui-state-disabled",
!!options.disabled
)),
undefined !== options.mini &&
outer.toggleClass(
"ui-mini",
!!options.mini
),
undefined !== options.theme &&
label
.removeClass(
"ui-btn-" + currentOptions.theme
)
.addClass(
"ui-btn-" + options.theme
),
undefined !== options.wrapperClass &&
outer
.removeClass(
currentOptions.wrapperClass
)
.addClass(
options.wrapperClass
),
undefined !== options.iconpos && hasIcon
? label
.removeClass(
"ui-btn-icon-" + currentOptions.iconpos
)
.addClass(
"ui-btn-icon-" + options.iconpos
)
: hasIcon ||
label.removeClass(
"ui-btn-icon-" + currentOptions.iconpos
),
this._super(
options
);
},
},
$.mobile.behaviors.formReset,
),
);
})(
jQuery
),
(function (
$, undefined
) {
$.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(
),
$.extend(
this,
{
wrapper: this.element.parent(
),
}
),
this._on(
{
focus: function (
) {
this.widget(
).addClass(
$.mobile.focusClass
);
},
blur: function (
) {
this.widget(
).removeClass(
$.mobile.focusClass
);
},
}
),
this.refresh(
!0
);
},
_enhance: function (
) {
this.element.wrap(
this._button(
)
);
},
_button: function (
) {
var options = this.options,
iconClasses = this._getIconClasses(
this.options
);
return $(
"<div class='ui-btn ui-input-btn" +
(options.wrapperClass ? " " + options.wrapperClass : "") +
(options.theme ? " ui-btn-" + options.theme : "") +
(options.corners ? " ui-corner-all" : "") +
(options.shadow ? " ui-shadow" : "") +
(options.inline ? " ui-btn-inline" : "") +
(options.mini ? " ui-mini" : "") +
(options.disabled ? " ui-state-disabled" : "") +
(iconClasses ? " " + iconClasses : "") +
"' >" +
this.element.val(
) +
"</div>",
);
},
widget: function (
) {
return this.wrapper;
},
_destroy: function (
) {
this.element.insertBefore(
this.button
), this.button.remove(
);
},
_getIconClasses: function (
options
) {
return options.icon
? "ui-icon-" +
options.icon +
(options.iconshadow ? " ui-shadow-icon" : "") +
" ui-btn-icon-" +
options.iconpos
: "";
},
_setOptions: function (
options
) {
var outer = this.widget(
);
undefined !== options.theme &&
outer
.removeClass(
this.options.theme
)
.addClass(
"ui-btn-" + options.theme
),
undefined !== options.corners &&
outer.toggleClass(
"ui-corner-all",
options.corners
),
undefined !== options.shadow &&
outer.toggleClass(
"ui-shadow",
options.shadow
),
undefined !== options.inline &&
outer.toggleClass(
"ui-btn-inline",
options.inline
),
undefined !== options.mini &&
outer.toggleClass(
"ui-mini",
options.mini
),
undefined !== options.disabled &&
(this.element.prop(
"disabled",
options.disabled
),
outer.toggleClass(
"ui-state-disabled",
options.disabled
)),
(undefined === options.icon &&
undefined === options.iconshadow &&
undefined === options.iconpos) ||
outer
.removeClass(
this._getIconClasses(
this.options
)
)
.addClass(
this._getIconClasses(
$.extend(
{
},
this.options,
options
)
),
),
this._super(
options
);
},
refresh: function (
create
) {
var originalElement,
isDisabled = this.element.prop(
"disabled"
);
this.options.icon &&
"notext" === this.options.iconpos &&
this.element.attr(
"title"
) &&
this.element.attr(
"title",
this.element.val(
)
),
create ||
((originalElement = this.element.detach(
)),
$(
this.wrapper
).text(
this.element.val(
)
).append(
originalElement
)),
this.options.disabled !== isDisabled &&
this._setOptions(
{
disabled: isDisabled,
}
);
},
}
);
})(
jQuery
),
(function (
$
) {
var meta = $(
"meta[name=viewport]"
),
initialContent = meta.attr(
"content"
),
disabledZoom = initialContent + ",maximum-scale=1, user-scalable=no",
enabledZoom = initialContent + ",maximum-scale=10, user-scalable=yes",
disabledInitially = /(user-scalable[\s]*=[\s]*no)|(maximum-scale[\s]*=[\s]*1)[$,\s]/.test(
initialContent,
);
$.mobile.zoom = $.extend(
{
},
{
enabled: !disabledInitially,
locked: !1,
disable: function (
lock
) {
disabledInitially ||
$.mobile.zoom.locked ||
(meta.attr(
"content",
disabledZoom
),
($.mobile.zoom.enabled = !1),
($.mobile.zoom.locked = lock || !1));
},
enable: function (
unlock
) {
disabledInitially ||
($.mobile.zoom.locked && !0 !== unlock) ||
(meta.attr(
"content",
enabledZoom
),
($.mobile.zoom.enabled = !0),
($.mobile.zoom.locked = !1));
},
restore: function (
) {
disabledInitially ||
(meta.attr(
"content",
initialContent
),
($.mobile.zoom.enabled = !0));
},
},
);
})(
jQuery
),
(function (
$, undefined
) {
$.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,
},
_create: function (
) {
var options = this.options,
isSearch = this.element.is(
"[type='search'], :jqmData(type='search')",
),
isTextarea = "TEXTAREA" === this.element[0].tagName,
isRange = this.element.is(
"[data-" + ($.mobile.ns || "") + "type='range']",
),
inputNeedsWrap =
(this.element.is(
"input"
) ||
this.element.is(
"[data-" + ($.mobile.ns || "") + "type='search']",
)) &&
!isRange;
this.element.prop(
"disabled"
) && (options.disabled = !0),
$.extend(
this,
{
classes: this._classesFromOptions(
),
isSearch: isSearch,
isTextarea: isTextarea,
isRange: isRange,
inputNeedsWrap: inputNeedsWrap,
}
),
this._autoCorrect(
),
options.enhanced || this._enhance(
),
this._on(
{
focus: "_handleFocus",
blur: "_handleBlur",
}
);
},
refresh: function (
) {
this.setOptions(
{
disabled: this.element.is(
":disabled"
),
}
);
},
_enhance: function (
) {
var elementClasses = [];
this.isTextarea && elementClasses.push(
"ui-input-text"
),
(this.isTextarea || this.isRange) &&
elementClasses.push(
"ui-shadow-inset"
),
this.inputNeedsWrap
? this.element.wrap(
this._wrap(
)
)
: (elementClasses = elementClasses.concat(
this.classes
)),
this.element.addClass(
elementClasses.join(
" "
)
);
},
widget: function (
) {
return this.inputNeedsWrap
? this.element.parent(
)
: this.element;
},
_classesFromOptions: function (
) {
var options = this.options,
classes = [];
return (
classes.push(
"ui-body-" + (null === options.theme ? "inherit" : options.theme),
),
options.corners && classes.push(
"ui-corner-all"
),
options.mini && classes.push(
"ui-mini"
),
options.disabled && classes.push(
"ui-state-disabled"
),
options.wrapperClass && classes.push(
options.wrapperClass
),
classes
);
},
_wrap: function (
) {
return $(
"<div class='" +
(this.isSearch ? "ui-input-search " : "ui-input-text ") +
this.classes.join(
" "
) +
" ui-shadow-inset'></div>",
);
},
_autoCorrect: function (
) {
void 0 === this.element[0].autocorrect ||
$.support.touchOverflow ||
(this.element[0].setAttribute(
"autocorrect",
"off"
),
this.element[0].setAttribute(
"autocomplete",
"off"
));
},
_handleBlur: function (
) {
this.widget(
).removeClass(
$.mobile.focusClass
),
this.options.preventFocusZoom && $.mobile.zoom.enable(
!0
);
},
_handleFocus: function (
) {
this.options.preventFocusZoom && $.mobile.zoom.disable(
!0
),
this.widget(
).addClass(
$.mobile.focusClass
);
},
_setOptions: function (
options
) {
var outer = this.widget(
);
this._super(
options
),
(undefined === options.disabled &&
undefined === options.mini &&
undefined === options.corners &&
undefined === options.theme &&
undefined === options.wrapperClass) ||
(outer.removeClass(
this.classes.join(
" "
)
),
(this.classes = this._classesFromOptions(
)),
outer.addClass(
this.classes.join(
" "
)
)),
undefined !== options.disabled &&
this.element.prop(
"disabled",
!!options.disabled
);
},
_destroy: function (
) {
this.options.enhanced ||
(this.inputNeedsWrap && this.element.unwrap(
),
this.element.removeClass(
"ui-input-text " + this.classes.join(
" "
),
));
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
$.widget(
"mobile.slider",
$.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 options,
wrapper,
j,
length,
i,
optionsCount,
origTabIndex,
side,
activeClass,
sliderImg,
bg,
control = this.element,
trackTheme =
this.options.trackTheme ||
$.mobile.getAttribute(
control[0],
"theme"
),
trackThemeClass = trackTheme
? " ui-bar-" + trackTheme
: " ui-bar-inherit",
cornerClass =
this.options.corners || control.jqmData(
"corners"
)
? " ui-corner-all"
: "",
miniClass =
this.options.mini || control.jqmData(
"mini"
)
? " ui-mini"
: "",
cType = control[0].nodeName.toLowerCase(
),
isToggleSwitch = "select" === cType,
isRangeslider = control
.parent(
)
.is(
":jqmData(role='rangeslider')"
),
selectClass = isToggleSwitch ? "ui-slider-switch" : "",
controlID = control.attr(
"id"
),
$label = $(
"[for='" + controlID + "']"
),
labelID = $label.attr(
"id"
) || controlID + "-label",
min = isToggleSwitch
? 0
: parseFloat(
control.attr(
"min"
)
),
max = isToggleSwitch
? control.find(
"option"
).length - 1
: parseFloat(
control.attr(
"max"
)
),
step = window.parseFloat(
control.attr(
"step"
) || 1
),
domHandle = document.createElement(
"a"
),
handle = $(
domHandle
),
domSlider = document.createElement(
"div"
),
slider = $(
domSlider
),
valuebg =
!(!this.options.highlight || isToggleSwitch) &&
(((bg = document.createElement(
"div"
)).className =
"ui-slider-bg " + $.mobile.activeBtnClass),
$(
bg
).prependTo(
slider
));
if (
($label.attr(
"id",
labelID
),
(this.isToggleSwitch = isToggleSwitch),
domHandle.setAttribute(
"href",
"#"
),
domSlider.setAttribute(
"role",
"application"
),
(domSlider.className = [
this.isToggleSwitch
? "ui-slider ui-slider-track ui-shadow-inset "
: "ui-slider-track ui-shadow-inset ",
selectClass,
trackThemeClass,
cornerClass,
miniClass,
].join(
""
)),
(domHandle.className = "ui-slider-handle"),
domSlider.appendChild(
domHandle
),
handle.attr(
{
role: "slider",
"aria-valuemin": min,
"aria-valuemax": max,
"aria-valuenow": this._value(
),
"aria-valuetext": this._value(
),
title: this._value(
),
"aria-labelledby": labelID,
}
),
$.extend(
this,
{
slider: slider,
handle: handle,
control: control,
type: cType,
step: step,
max: max,
min: min,
valuebg: valuebg,
isRangeslider: isRangeslider,
dragging: !1,
beforeStart: null,
userModified: !1,
mouseMoved: !1,
}
),
isToggleSwitch)
) {
for (
(origTabIndex = control.attr(
"tabindex"
)) &&
handle.attr(
"tabindex",
origTabIndex
),
control.attr(
"tabindex",
"-1"
).focus(
function (
) {
$(
this
).blur(
), handle.focus(
);
}
),
(wrapper = document.createElement(
"div"
)).className =
"ui-slider-inneroffset",
j = 0,
length = domSlider.childNodes.length;
j < length;
j++
)
wrapper.appendChild(
domSlider.childNodes[j]
);
for (
domSlider.appendChild(
wrapper
),
handle.addClass(
"ui-slider-handle-snapping"
),
i = 0,
optionsCount = (options = control.find(
"option"
)).length;
i < optionsCount;
i++
)
(side = i ? "a" : "b"),
(activeClass = i ? " " + $.mobile.activeBtnClass : ""),
((sliderImg = document.createElement(
"span"
)).className = [
"ui-slider-label ui-slider-label-",
side,
activeClass,
].join(
""
)),
sliderImg.setAttribute(
"role",
"img"
),
sliderImg.appendChild(
document.createTextNode(
options[i].innerHTML
),
),
$(
sliderImg
).prependTo(
slider
);
this._labels = $(
".ui-slider-label",
slider
);
}
control.addClass(
isToggleSwitch ? "ui-slider-switch" : "ui-slider-input",
),
this._on(
control,
{
change: "_controlChange",
keyup: "_controlKeyup",
blur: "_controlBlur",
vmouseup: "_controlVMouseUp",
}
),
slider
.bind(
"vmousedown",
$.proxy(
this._sliderVMouseDown,
this
)
)
.bind(
"vclick",
!1
),
this._on(
document,
{
vmousemove: "_preventDocumentDrag",
}
),
this._on(
slider.add(
document
),
{
vmouseup: "_sliderVMouseUp",
}
),
slider.insertAfter(
control
),
isToggleSwitch ||
isRangeslider ||
((wrapper = this.options.mini
? "<div class='ui-slider ui-mini'>"
: "<div class='ui-slider'>"),
control.add(
slider
).wrapAll(
wrapper
)),
this._on(
this.handle,
{
vmousedown: "_handleVMouseDown",
keydown: "_handleKeydown",
keyup: "_handleKeyup",
}
),
this.handle.bind(
"vclick",
!1
),
this._handleFormReset(
),
this.refresh(
undefined,
undefined,
!0
);
},
_setOptions: function (
options
) {
undefined !== options.theme && this._setTheme(
options.theme
),
undefined !== options.trackTheme &&
this._setTrackTheme(
options.trackTheme
),
undefined !== options.corners &&
this._setCorners(
options.corners
),
undefined !== options.mini && this._setMini(
options.mini
),
undefined !== options.highlight &&
this._setHighlight(
options.highlight
),
undefined !== options.disabled &&
this._setDisabled(
options.disabled
),
this._super(
options
);
},
_controlChange: function (
event
) {
if (!1 === this._trigger(
"controlchange",
event
)) return !1;
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 (
event
) {
var index = this._value(
);
if (!this.options.disabled) {
switch (event.keyCode) {
case $.mobile.keyCode.HOME:
case $.mobile.keyCode.END:
case $.mobile.keyCode.PAGE_UP:
case $.mobile.keyCode.PAGE_DOWN:
case $.mobile.keyCode.UP:
case $.mobile.keyCode.RIGHT:
case $.mobile.keyCode.DOWN:
case $.mobile.keyCode.LEFT:
event.preventDefault(
),
this._keySliding ||
((this._keySliding = !0),
this.handle.addClass(
"ui-state-active"
));
}
switch (event.keyCode) {
case $.mobile.keyCode.HOME:
this.refresh(
this.min
);
break;
case $.mobile.keyCode.END:
this.refresh(
this.max
);
break;
case $.mobile.keyCode.PAGE_UP:
case $.mobile.keyCode.UP:
case $.mobile.keyCode.RIGHT:
this.refresh(
index + this.step
);
break;
case $.mobile.keyCode.PAGE_DOWN:
case $.mobile.keyCode.DOWN:
case $.mobile.keyCode.LEFT:
this.refresh(
index - this.step
);
}
}
},
_handleKeyup: function (
) {
this._keySliding &&
((this._keySliding = !1),
this.handle.removeClass(
"ui-state-active"
));
},
_sliderVMouseDown: function (
event
) {
return (
this.options.disabled ||
(1 !== event.which &&
0 !== event.which &&
undefined !== event.which) ||
!1 === this._trigger(
"beforestart",
event
) ||
((this.dragging = !0),
(this.userModified = !1),
(this.mouseMoved = !1),
this.isToggleSwitch &&
(this.beforeStart = this.element[0].selectedIndex),
this.refresh(
event
),
this._trigger(
"start"
)),
!1
);
},
_sliderVMouseUp: function (
) {
if (this.dragging)
return (
(this.dragging = !1),
this.isToggleSwitch &&
(this.handle.addClass(
"ui-slider-handle-snapping"
),
this.mouseMoved
? this.userModified
? this.refresh(
0 === this.beforeStart ? 1 : 0
)
: this.refresh(
this.beforeStart
)
: this.refresh(
0 === this.beforeStart ? 1 : 0
)),
(this.mouseMoved = !1),
this._trigger(
"stop"
),
!1
);
},
_preventDocumentDrag: function (
event
) {
return (
!1 !== this._trigger(
"drag",
event
) &&
(this.dragging && !this.options.disabled
? ((this.mouseMoved = !0),
this.isToggleSwitch &&
this.handle.removeClass(
"ui-slider-handle-snapping"
),
this.refresh(
event
),
(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(
undefined,
!1,
!0
);
},
refresh: function (
val, isfromControl, preventInputUpdate
) {
var left,
width,
data,
pxStep,
percent,
control,
isInput,
optionElements,
min,
max,
step,
newval,
valModStep,
alignValue,
percentPerStep,
handlePercent,
aPercent,
bPercent,
valueChanged,
bg,
self = this,
parentTheme = $.mobile.getAttribute(
this.element[0],
"theme"
),
theme = this.options.theme || parentTheme,
themeClass = theme ? " ui-btn-" + theme : "",
trackTheme = this.options.trackTheme || parentTheme,
trackThemeClass = trackTheme
? " ui-bar-" + trackTheme
: " ui-bar-inherit",
cornerClass = this.options.corners ? " ui-corner-all" : "",
miniClass = this.options.mini ? " ui-mini" : "";
if (
((self.slider[0].className = [
this.isToggleSwitch
? "ui-slider ui-slider-switch ui-slider-track ui-shadow-inset"
: "ui-slider-track ui-shadow-inset",
trackThemeClass,
cornerClass,
miniClass,
].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 =
(((bg = document.createElement(
"div"
)).className =
"ui-slider-bg " + $.mobile.activeBtnClass),
$(
bg
).prependTo(
self.slider
))),
this.handle.addClass(
"ui-btn" + themeClass + " ui-shadow"
),
(control = this.element),
(optionElements = (isInput = !this.isToggleSwitch)
? []
: control.find(
"option"
)),
(min = isInput
? parseFloat(
control.attr(
"min"
)
)
: 0),
(max = isInput
? parseFloat(
control.attr(
"max"
)
)
: optionElements.length - 1),
(step =
isInput && parseFloat(
control.attr(
"step"
)
) > 0
? parseFloat(
control.attr(
"step"
)
)
: 1),
"object" == typeof val)
) {
if (
((data = val),
8,
(left = this.slider.offset(
).left),
(pxStep =
(width = this.slider.width(
)) / ((max - min) / step)),
!this.dragging ||
data.pageX < left - 8 ||
data.pageX > left + width + 8)
)
return;
percent =
pxStep > 1
? ((data.pageX - left) / width) * 100
: Math.round(
((data.pageX - left) / width) * 100
);
} else
null == val &&
(val = isInput
? parseFloat(
control.val(
) || 0
)
: control[0].selectedIndex),
(percent = ((parseFloat(
val
) - min) / (max - min)) * 100);
if (
!isNaN(
percent
) &&
((alignValue =
(newval = (percent / 100) * (max - min) + min) -
(valModStep = (newval - min) % step)),
2 * Math.abs(
valModStep
) >= step &&
(alignValue += valModStep > 0 ? step : -step),
(percentPerStep = 100 / ((max - min) / step)),
(newval = parseFloat(
alignValue.toFixed(
5
)
)),
void 0 === pxStep && (pxStep = width / ((max - min) / step)),
pxStep > 1 &&
isInput &&
(percent = (newval - min) * percentPerStep * (1 / step)),
percent < 0 && (percent = 0),
percent > 100 && (percent = 100),
newval < min && (newval = min),
newval > max && (newval = max),
this.handle.css(
"left",
percent + "%"
),
this.handle[0].setAttribute(
"aria-valuenow",
isInput
? newval
: optionElements.eq(
newval
).attr(
"value"
),
),
this.handle[0].setAttribute(
"aria-valuetext",
isInput
? newval
: optionElements.eq(
newval
).getEncodedText(
),
),
this.handle[0].setAttribute(
"title",
isInput
? newval
: optionElements.eq(
newval
).getEncodedText(
),
),
this.valuebg && this.valuebg.css(
"width",
percent + "%"
),
this._labels &&
((handlePercent =
(this.handle.width(
) / this.slider.width(
)) * 100),
(aPercent =
percent &&
handlePercent + ((100 - handlePercent) * percent) / 100),
(bPercent =
100 === percent
? 0
: Math.min(
handlePercent + 100 - aPercent,
100
)),
this._labels.each(
function (
) {
var ab = $(
this
).hasClass(
"ui-slider-label-a"
);
$(
this
).width(
(ab ? aPercent : bPercent) + "%"
);
}
)),
!preventInputUpdate)
) {
if (
((valueChanged = !1),
isInput
? ((valueChanged = control.val(
) !== newval),
control.val(
newval
))
: ((valueChanged = control[0].selectedIndex !== newval),
(control[0].selectedIndex = newval)),
!1 === this._trigger(
"beforechange",
val
))
)
return !1;
!isfromControl && valueChanged && control.trigger(
"change"
);
}
},
_setHighlight: function (
value
) {
(value = !!value)
? ((this.options.highlight = !!value), this.refresh(
))
: this.valuebg && (this.valuebg.remove(
), (this.valuebg = !1));
},
_setTheme: function (
value
) {
this.handle
.removeClass(
"ui-btn-" + this.options.theme
)
.addClass(
"ui-btn-" + value
);
var currentTheme = this.options.theme
? this.options.theme
: "inherit",
newTheme = value || "inherit";
this.control
.removeClass(
"ui-body-" + currentTheme
)
.addClass(
"ui-body-" + newTheme
);
},
_setTrackTheme: function (
value
) {
var currentTrackTheme = this.options.trackTheme
? this.options.trackTheme
: "inherit",
newTrackTheme = value || "inherit";
this.slider
.removeClass(
"ui-body-" + currentTrackTheme
)
.addClass(
"ui-body-" + newTrackTheme
);
},
_setMini: function (
value
) {
(value = !!value),
this.isToggleSwitch ||
this.isRangeslider ||
(this.slider.parent(
).toggleClass(
"ui-mini",
value
),
this.element.toggleClass(
"ui-mini",
value
)),
this.slider.toggleClass(
"ui-mini",
value
);
},
_setCorners: function (
value
) {
this.slider.toggleClass(
"ui-corner-all",
value
),
this.isToggleSwitch ||
this.control.toggleClass(
"ui-corner-all",
value
);
},
_setDisabled: function (
value
) {
(value = !!value),
this.element.prop(
"disabled",
value
),
this.slider
.toggleClass(
"ui-state-disabled",
value
)
.attr(
"aria-disabled",
value
);
},
},
$.mobile.behaviors.formReset,
),
);
})(
jQuery
),
(function (
$, undefined
) {
var popup;
$.widget(
"mobile.slider",
$.mobile.slider,
{
options: {
popupEnabled: !1,
showValue: !1,
},
_create: function (
) {
this._super(
),
$.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 dstOffset = this.handle.offset(
);
this._popup.offset(
{
left:
dstOffset.left + (this.handle.width(
) - this._popup.width(
)) / 2,
top: dstOffset.top - this._popup.outerHeight(
) - 5,
}
);
},
_setOption: function (
key, value
) {
this._super(
key,
value
),
"showValue" === key
? this.handle.html(
value && !this.options.mini
? this._value(
)
: "",
)
: "popupEnabled" === key &&
value &&
!this._popup &&
(this._popup = (popup ||
(popup = $(
"<div></div>",
{
class: "ui-slider-popup ui-shadow ui-corner-all",
}
)),
popup.clone(
))
.addClass(
"ui-body-" + (this.options.theme || "a")
)
.hide(
)
.insertBefore(
this.element
));
},
refresh: function (
) {
this._super.apply(
this,
arguments
), this._refresh(
);
},
_refresh: function (
) {
var newValue,
o = this.options;
o.popupEnabled && this.handle.removeAttr(
"title"
),
(newValue = this._value(
)) !== this._currentValue &&
((this._currentValue = newValue),
o.popupEnabled && this._popup
? (this._positionPopup(
), this._popup.html(
newValue
))
: o.showValue &&
!this.options.mini &&
this.handle.html(
newValue
));
},
_showPopup: function (
) {
this.options.popupEnabled &&
!this._popupVisible &&
(this.handle.html(
""
),
this._popup.show(
),
this._positionPopup(
),
(this._popupVisible = !0));
},
_hidePopup: function (
) {
var o = this.options;
o.popupEnabled &&
this._popupVisible &&
(o.showValue && !o.mini && this.handle.html(
this._value(
)
),
this._popup.hide(
),
(this._popupVisible = !1));
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
$.widget(
"mobile.flipswitch",
$.extend(
{
options: {
onText: "On",
offText: "Off",
theme: null,
enhanced: !1,
wrapperClass: null,
corners: !0,
mini: !1,
},
_create: function (
) {
this.options.enhanced
? $.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 flipswitch = $(
"<div>"
),
options = this.options,
element = this.element,
theme = options.theme ? options.theme : "inherit",
on = $(
"<a></a>",
{
href: "#",
}
),
off = $(
"<span></span>"
),
type = element.get(
0
).tagName,
onText =
"INPUT" === type
? options.onText
: element.find(
"option"
).eq(
1
).text(
),
offText =
"INPUT" === type
? options.offText
: element.find(
"option"
).eq(
0
).text(
);
on
.addClass(
"ui-flipswitch-on ui-btn ui-shadow ui-btn-inherit"
)
.text(
onText
),
off.addClass(
"ui-flipswitch-off"
).text(
offText
),
flipswitch
.addClass(
"ui-flipswitch ui-shadow-inset ui-bar-" +
theme +
" " +
(options.wrapperClass ? options.wrapperClass : "") +
" " +
(element.is(
":checked"
) ||
element.find(
"option"
).eq(
1
).is(
":selected"
)
? "ui-flipswitch-active"
: "") +
(element.is(
":disabled"
)
? " ui-state-disabled"
: "") +
(options.corners ? " ui-corner-all" : "") +
(options.mini ? " ui-mini" : ""),
)
.append(
on,
off
),
element
.addClass(
"ui-flipswitch-input"
)
.after(
flipswitch
)
.appendTo(
flipswitch
),
$.extend(
this,
{
flipswitch: flipswitch,
on: on,
off: off,
type: type,
}
);
},
_reset: function (
) {
this.refresh(
);
},
refresh: function (
) {
var direction,
existingDirection = this.flipswitch.hasClass(
"ui-flipswitch-active",
)
? "_right"
: "_left";
(direction =
"SELECT" === this.type
? this.element.get(
0
).selectedIndex > 0
? "_right"
: "_left"
: this.element.prop(
"checked"
)
? "_right"
: "_left") !== existingDirection && this[direction](
);
},
_toggle: function (
) {
this[
this.flipswitch.hasClass(
"ui-flipswitch-active"
)
? "_left"
: "_right"
](
);
},
_keydown: function (
e
) {
e.which === $.mobile.keyCode.LEFT
? this._left(
)
: e.which === $.mobile.keyCode.RIGHT
? this._right(
)
: e.which === $.mobile.keyCode.SPACE &&
(this._toggle(
), e.preventDefault(
));
},
_setOptions: function (
options
) {
if (undefined !== options.theme) {
var currentTheme = options.theme ? options.theme : "inherit",
newTheme = options.theme ? options.theme : "inherit";
this.widget(
)
.removeClass(
"ui-bar-" + currentTheme
)
.addClass(
"ui-bar-" + newTheme
);
}
undefined !== options.onText && this.on.text(
options.onText
),
undefined !== options.offText && this.off.text(
options.offText
),
undefined !== options.disabled &&
this.widget(
).toggleClass(
"ui-state-disabled",
options.disabled,
),
undefined !== options.mini &&
this.widget(
).toggleClass(
"ui-mini",
options.mini
),
undefined !== options.corners &&
this.widget(
).toggleClass(
"ui-corner-all",
options.corners
),
this._super(
options
);
},
_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"
));
},
},
$.mobile.behaviors.formReset,
),
);
})(
jQuery
),
(function (
$, undefined
) {
$.widget(
"mobile.rangeslider",
$.extend(
{
options: {
theme: null,
trackTheme: null,
corners: !0,
mini: !1,
highlight: !0,
},
_create: function (
) {
var $el = this.element,
elClass = this.options.mini
? "ui-rangeslider ui-mini"
: "ui-rangeslider",
_inputFirst = $el.find(
"input"
).first(
),
_inputLast = $el.find(
"input"
).last(
),
_label = $el.find(
"label"
).first(
),
_sliderWidgetFirst =
$.data(
_inputFirst.get(
0
),
"mobile-slider"
) ||
$.data(
_inputFirst.slider(
).get(
0
),
"mobile-slider"
),
_sliderWidgetLast =
$.data(
_inputLast.get(
0
),
"mobile-slider"
) ||
$.data(
_inputLast.slider(
).get(
0
),
"mobile-slider"
),
_sliderFirst = _sliderWidgetFirst.slider,
_sliderLast = _sliderWidgetLast.slider,
firstHandle = _sliderWidgetFirst.handle,
_sliders = $(
"<div class='ui-rangeslider-sliders' />"
).appendTo(
$el,
);
_inputFirst.addClass(
"ui-rangeslider-first"
),
_inputLast.addClass(
"ui-rangeslider-last"
),
$el.addClass(
elClass
),
_sliderFirst.appendTo(
_sliders
),
_sliderLast.appendTo(
_sliders
),
_label.insertBefore(
$el
),
firstHandle.prependTo(
_sliderLast
),
$.extend(
this,
{
_inputFirst: _inputFirst,
_inputLast: _inputLast,
_sliderFirst: _sliderFirst,
_sliderLast: _sliderLast,
_label: _label,
_targetVal: null,
_sliderTarget: !1,
_sliders: _sliders,
_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(
firstHandle,
{
vmousedown: "_dragFirstHandle",
}
);
},
_handleReset: function (
) {
var self = this;
setTimeout(
function (
) {
self._updateHighlight(
);
},
0
);
},
_dragFirstHandle: function (
event
) {
return (
($.data(
this._inputFirst.get(
0
),
"mobile-slider",
).dragging = !0),
$.data(
this._inputFirst.get(
0
),
"mobile-slider"
).refresh(
event
),
!1
);
},
_slidedrag: function (
event
) {
var first = $(
event.target
).is(
this._inputFirst
),
otherSlider = first ? this._inputLast : this._inputFirst;
if (
((this._sliderTarget = !1),
("first" === this._proxy && first) ||
("last" === this._proxy && !first))
)
return (
($.data(
otherSlider.get(
0
),
"mobile-slider"
).dragging = !0),
$.data(
otherSlider.get(
0
),
"mobile-slider"
).refresh(
event
),
!1
);
},
_slidestop: function (
event
) {
var first = $(
event.target
).is(
this._inputFirst
);
(this._proxy = !1),
this.element.find(
"input"
).trigger(
"vmouseup"
),
this._sliderFirst.css(
"z-index",
first ? 1 : ""
);
},
_slidebeforestart: function (
event
) {
(this._sliderTarget = !1),
$(
event.originalEvent.target
).hasClass(
"ui-slider-track"
) &&
((this._sliderTarget = !0),
(this._targetVal = $(
event.target
).val(
)));
},
_setOptions: function (
options
) {
undefined !== options.theme && this._setTheme(
options.theme
),
undefined !== options.trackTheme &&
this._setTrackTheme(
options.trackTheme
),
undefined !== options.mini && this._setMini(
options.mini
),
undefined !== options.highlight &&
this._setHighlight(
options.highlight
),
this._super(
options
),
this.refresh(
);
},
refresh: function (
) {
var $el = this.element,
o = this.options;
(this._inputFirst.is(
":disabled"
) ||
this._inputLast.is(
":disabled"
)) &&
(this.options.disabled = !0),
$el
.find(
"input"
)
.slider(
{
theme: o.theme,
trackTheme: o.trackTheme,
disabled: o.disabled,
corners: o.corners,
mini: o.mini,
highlight: o.highlight,
}
)
.slider(
"refresh"
),
this._updateHighlight(
);
},
_change: function (
event
) {
if ("keyup" === event.type) return this._updateHighlight(
), !1;
var self = this,
min = parseFloat(
this._inputFirst.val(
),
10
),
max = parseFloat(
this._inputLast.val(
),
10
),
first = $(
event.target
).hasClass(
"ui-rangeslider-first"
),
thisSlider = first ? this._inputFirst : this._inputLast,
otherSlider = first ? this._inputLast : this._inputFirst;
if (
this._inputFirst.val(
) > this._inputLast.val(
) &&
"mousedown" === event.type &&
!$(
event.target
).hasClass(
"ui-slider-handle"
)
)
thisSlider.blur(
);
else if ("mousedown" === event.type) return;
return (
min > max && !this._sliderTarget
? (thisSlider.val(
first ? max : min
).slider(
"refresh"
),
this._trigger(
"normalize"
))
: min > max &&
(thisSlider.val(
this._targetVal
).slider(
"refresh"
),
setTimeout(
function (
) {
otherSlider.val(
first ? min : max
).slider(
"refresh"
),
$.data(
otherSlider.get(
0
),
"mobile-slider",
).handle.focus(
),
self._sliderFirst.css(
"z-index",
first ? "" : 1
),
self._trigger(
"normalize"
);
},
0
),
(this._proxy = first ? "first" : "last")),
min === max
? ($.data(
thisSlider.get(
0
),
"mobile-slider"
).handle.css(
"z-index",
1,
),
$.data(
otherSlider.get(
0
),
"mobile-slider"
).handle.css(
"z-index",
0,
))
: ($.data(
otherSlider.get(
0
),
"mobile-slider"
).handle.css(
"z-index",
"",
),
$.data(
thisSlider.get(
0
),
"mobile-slider"
).handle.css(
"z-index",
"",
)),
this._updateHighlight(
),
!(min >= max) && void 0
);
},
_updateHighlight: function (
) {
var min = parseInt(
$.data(
this._inputFirst.get(
0
),
"mobile-slider"
).handle.get(
0
)
.style.left,
10,
),
width =
parseInt(
$.data(
this._inputLast.get(
0
),
"mobile-slider"
).handle.get(
0,
).style.left,
10,
) - min;
this.element
.find(
".ui-slider-bg"
)
.css(
{
"margin-left": min + "%",
width: width + "%",
}
);
},
_setTheme: function (
value
) {
this._inputFirst.slider(
"option",
"theme",
value
),
this._inputLast.slider(
"option",
"theme",
value
);
},
_setTrackTheme: function (
value
) {
this._inputFirst.slider(
"option",
"trackTheme",
value
),
this._inputLast.slider(
"option",
"trackTheme",
value
);
},
_setMini: function (
value
) {
this._inputFirst.slider(
"option",
"mini",
value
),
this._inputLast.slider(
"option",
"mini",
value
),
this.element.toggleClass(
"ui-mini",
!!value
);
},
_setHighlight: function (
value
) {
this._inputFirst.slider(
"option",
"highlight",
value
),
this._inputLast.slider(
"option",
"highlight",
value
);
},
_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"
);
},
},
$.mobile.behaviors.formReset,
),
);
})(
jQuery
),
(function (
$, undefined
) {
$.widget(
"mobile.textinput",
$.mobile.textinput,
{
options: {
clearBtn: !1,
clearBtnText: "Clear text",
},
_create: function (
) {
this._super(
),
(this.options.clearBtn || this.isSearch) && this._addClearBtn(
);
},
clearButton: function (
) {
return $(
"<a href='#' class='ui-input-clear ui-btn ui-icon-delete ui-btn-icon-notext ui-corner-all' title='" +
this.options.clearBtnText +
"'>" +
this.options.clearBtnText +
"</a>",
);
},
_clearBtnClick: function (
event
) {
this.element.val(
""
).focus(
).trigger(
"change"
),
this._clearBtn.addClass(
"ui-input-clear-hidden"
),
event.preventDefault(
);
},
_addClearBtn: function (
) {
this.options.enhanced || this._enhanceClear(
),
$.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 (
options
) {
this._super(
options
),
undefined === options.clearBtn ||
this.element.is(
"textarea, :jqmData(type='range')"
) ||
(options.clearBtn
? this._addClearBtn(
)
: this._destroyClear(
)),
undefined !== options.clearBtnText &&
undefined !== this._clearBtn &&
this._clearBtn
.text(
options.clearBtnText
)
.attr(
"title",
options.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._destroyClear(
);
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
$.widget(
"mobile.textinput",
$.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 (
event
) {
$.contains(
event.target,
this.element[0]
) &&
this.element.is(
":visible"
) &&
("popupbeforeposition" !== event.type &&
this.element
.addClass(
"ui-textinput-autogrow-resize"
)
.animationComplete(
$.proxy(
function (
) {
this.element.removeClass(
"ui-textinput-autogrow-resize"
);
},
this
),
"transition",
),
this._timeout(
));
},
_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 (
delay
) {
this.keyupTimeout && clearTimeout(
this.keyupTimeout
),
undefined === delay
? this._updateHeight(
)
: (this.keyupTimeout = this._delay(
"_updateHeight",
delay
));
},
_timeout: function (
) {
this._prepareHeightUpdate(
this.options.keyupTimeoutBuffer
);
},
_updateHeight: function (
) {
var scrollHeight,
clientHeight,
height,
scrollTop = this.window.scrollTop(
);
(this.keyupTimeout = 0),
"onpage" in this.element[0] ||
this.element.css(
{
height: 0,
"min-height": 0,
"max-height": 0,
}
),
(scrollHeight = this.element[0].scrollHeight),
(clientHeight = this.element[0].clientHeight),
(height =
scrollHeight +
(parseFloat(
this.element.css(
"border-top-width"
)
) +
parseFloat(
this.element.css(
"border-bottom-width"
)
)) +
15),
0 === clientHeight &&
(height +=
parseFloat(
this.element.css(
"padding-top"
)
) +
parseFloat(
this.element.css(
"padding-bottom"
)
)),
this.element.css(
{
height: height,
"min-height": "",
"max-height": "",
}
),
this.window.scrollTop(
scrollTop
);
},
refresh: function (
) {
this.options.autogrow && this.isTextarea && this._updateHeight(
);
},
_setOptions: function (
options
) {
this._super(
options
),
undefined !== options.autogrow &&
this.isTextarea &&
(options.autogrow
? this._autogrow(
)
: this._unbindAutogrow(
));
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
$.widget(
"mobile.selectmenu",
$.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 $(
"<div/>"
);
},
_setDisabled: function (
value
) {
return (
this.element.attr(
"disabled",
value
),
this.button.attr(
"aria-disabled",
value
),
this._setOption(
"disabled",
value
)
);
},
_focusButton: function (
) {
var self = this;
setTimeout(
function (
) {
self.button.focus(
);
},
40
);
},
_selectOptions: function (
) {
return this.select.find(
"option"
);
},
_preExtension: function (
) {
var inline =
this.options.inline || this.element.jqmData(
"inline"
),
mini = this.options.mini || this.element.jqmData(
"mini"
),
classes = "";
~this.element[0].className.indexOf(
"ui-btn-left"
) &&
(classes = " ui-btn-left"),
~this.element[0].className.indexOf(
"ui-btn-right"
) &&
(classes = " ui-btn-right"),
inline && (classes += " ui-btn-inline"),
mini && (classes += " ui-mini"),
(this.select = this.element
.removeClass(
"ui-btn-left ui-btn-right"
)
.wrap(
"<div class='ui-select" + classes + "'>"
)),
(this.selectId =
this.select.attr(
"id"
) || "select-" + this.uuid),
(this.buttonId = this.selectId + "-button"),
(this.label = $(
"label[for='" + this.selectId + "']"
)),
(this.isMultiple = this.select[0].multiple);
},
_destroy: function (
) {
var wrapper = this.element.parents(
".ui-select"
);
wrapper.length > 0 &&
(wrapper.is(
".ui-btn-left, .ui-btn-right"
) &&
this.element.addClass(
wrapper.hasClass(
"ui-btn-left"
)
? "ui-btn-left"
: "ui-btn-right",
),
this.element.insertAfter(
wrapper
),
wrapper.remove(
));
},
_create: function (
) {
this._preExtension(
), (this.button = this._button(
));
var self = this,
options = this.options,
iconpos =
!!options.icon &&
(options.iconpos || this.select.jqmData(
"iconpos"
)),
button = this.button
.insertBefore(
this.select
)
.attr(
"id",
this.buttonId
)
.addClass(
"ui-btn" +
(options.icon
? " ui-icon-" +
options.icon +
" ui-btn-icon-" +
iconpos +
(options.iconshadow ? " ui-shadow-icon" : "")
: "") +
(options.theme ? " ui-btn-" + options.theme : "") +
(options.corners ? " ui-corner-all" : "") +
(options.shadow ? " ui-shadow" : ""),
);
this.setButtonText(
),
options.nativeMenu &&
window.opera &&
window.opera.version &&
button.addClass(
"ui-select-nativeonly"
),
this.isMultiple &&
(this.buttonCount = $(
"<span>"
)
.addClass(
"ui-li-count ui-body-inherit"
)
.hide(
)
.appendTo(
button.addClass(
"ui-li-has-count"
)
)),
(options.disabled || this.element.attr(
"disabled"
)) &&
this.disable(
),
this.select.change(
function (
) {
self.refresh(
), options.nativeMenu && this.blur(
);
}
),
this._handleFormReset(
),
this._on(
this.button,
{
keydown: "_handleKeydown",
}
),
this.build(
);
},
build: function (
) {
var self = this;
this.select
.appendTo(
self.button
)
.bind(
"vmousedown",
function (
) {
self.button.addClass(
$.mobile.activeBtnClass
);
}
)
.bind(
"focus",
function (
) {
self.button.addClass(
$.mobile.focusClass
);
}
)
.bind(
"blur",
function (
) {
self.button.removeClass(
$.mobile.focusClass
);
}
)
.bind(
"focus vmouseover",
function (
) {
self.button.trigger(
"vmouseover"
);
}
)
.bind(
"vmousemove",
function (
) {
self.button.removeClass(
$.mobile.activeBtnClass
);
}
)
.bind(
"change blur vmouseout",
function (
) {
self.button
.trigger(
"vmouseout"
)
.removeClass(
$.mobile.activeBtnClass
);
}
),
self.button.bind(
"vmousedown",
function (
) {
self.options.preventFocusZoom && $.mobile.zoom.disable(
!0
);
}
),
self.label.bind(
"click focus",
function (
) {
self.options.preventFocusZoom && $.mobile.zoom.disable(
!0
);
}
),
self.select.bind(
"focus",
function (
) {
self.options.preventFocusZoom && $.mobile.zoom.disable(
!0
);
}
),
self.button.bind(
"mouseup",
function (
) {
self.options.preventFocusZoom &&
setTimeout(
function (
) {
$.mobile.zoom.enable(
!0
);
},
0
);
}
),
self.select.bind(
"blur",
function (
) {
self.options.preventFocusZoom && $.mobile.zoom.enable(
!0
);
}
);
},
selected: function (
) {
return this._selectOptions(
).filter(
":selected"
);
},
selectedIndices: function (
) {
var self = this;
return this.selected(
)
.map(
function (
) {
return self._selectOptions(
).index(
this
);
}
)
.get(
);
},
setButtonText: function (
) {
var self = this,
selected = this.selected(
),
text = this.placeholder,
span = $(
document.createElement(
"span"
)
);
this.button
.children(
"span"
)
.not(
".ui-li-count"
)
.remove(
)
.end(
)
.end(
)
.prepend(
((text = selected.length
? selected
.map(
function (
) {
return $(
this
).text(
);
}
)
.get(
)
.join(
", "
)
: self.placeholder)
? span.text(
text
)
: span.html(
"&#160;"
),
span
.addClass(
self.select.attr(
"class"
)
)
.addClass(
selected.attr(
"class"
)
)
.removeClass(
"ui-screen-hidden"
)),
);
},
setButtonCount: function (
) {
var selected = this.selected(
);
this.isMultiple &&
this.buttonCount[selected.length > 1 ? "show" : "hide"](
).text(
selected.length,
);
},
_handleKeydown: function (
) {
this._delay(
"_refreshButton"
);
},
_reset: function (
) {
this.refresh(
);
},
_refreshButton: function (
) {
this.setButtonText(
), this.setButtonCount(
);
},
refresh: function (
) {
this._refreshButton(
);
},
open: $.noop,
close: $.noop,
disable: function (
) {
this._setDisabled(
!0
), this.button.addClass(
"ui-state-disabled"
);
},
enable: function (
) {
this._setDisabled(
!1
),
this.button.removeClass(
"ui-state-disabled"
);
},
},
$.mobile.behaviors.formReset,
),
);
})(
jQuery
),
(function (
$, undefined
) {
$.mobile.links = function (
target
) {
$(
target
)
.find(
"a"
)
.jqmEnhanceable(
)
.filter(
":jqmData(rel='popup')[href][href!='']"
)
.each(
function (
) {
var idref = this.getAttribute(
"href"
).substring(
1
);
idref &&
(this.setAttribute(
"aria-haspopup",
!0
),
this.setAttribute(
"aria-owns",
idref
),
this.setAttribute(
"aria-expanded",
!1
));
}
)
.end(
)
.not(
".ui-btn, :jqmData(role='none'), :jqmData(role='nojs')"
)
.addClass(
"ui-link"
);
};
})(
jQuery
),
(function (
$, undefined
) {
function fitSegmentInsideSegment(
windowSize,
segmentSize,
offset,
desired,
) {
return windowSize < segmentSize
? offset + (windowSize - segmentSize) / 2
: Math.min(
Math.max(
offset,
desired - segmentSize / 2
),
offset + windowSize - segmentSize,
);
}
function getWindowCoordinates(
theWindow
) {
return {
x: theWindow.scrollLeft(
),
y: theWindow.scrollTop(
),
cx: theWindow[0].innerWidth || theWindow.width(
),
cy: theWindow[0].innerHeight || theWindow.height(
),
};
}
$.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: !$.mobile.browser.oldIE,
},
_create: function (
) {
var theElement = this.element,
myId = theElement.attr(
"id"
),
currentOptions = this.options;
(currentOptions.history =
currentOptions.history &&
$.mobile.ajaxEnabled &&
$.mobile.hashListeningEnabled),
$.extend(
this,
{
_scrollTop: 0,
_page: theElement.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 = $(
"body"
)),
currentOptions.enhanced
? (this._ui = {
container: theElement.parent(
),
screen: theElement.parent(
).prev(
),
placeholder: $(
this.document[0].getElementById(
myId + "-placeholder"
),
),
})
: ((this._ui = this._enhance(
theElement,
myId
)),
this._applyTransition(
currentOptions.transition
)),
(this._setTolerance(
currentOptions.tolerance,
)._ui.focusElement = this._ui.container),
this._on(
this._ui.screen,
{
vclick: "_eatEventAndClose",
}
),
this._on(
this.window,
{
orientationchange: $.proxy(
this,
"_handleWindowOrientationchange",
),
resize: $.proxy(
this,
"_handleWindowResize"
),
keyup: $.proxy(
this,
"_handleWindowKeyUp"
),
}
),
this._on(
this.document,
{
focusin: "_handleDocumentFocusIn",
}
);
},
_enhance: function (
theElement, myId
) {
var currentOptions = this.options,
wrapperClass = currentOptions.wrapperClass,
ui = {
screen: $(
"<div class='ui-screen-hidden ui-popup-screen " +
this._themeClassFromOption(
"ui-overlay-",
currentOptions.overlayTheme,
) +
"'></div>",
),
placeholder: $(
"<div style='display: none;'>\x3c!-- placeholder --\x3e</div>",
),
container: $(
"<div class='ui-popup-container ui-popup-hidden ui-popup-truncate" +
(wrapperClass ? " " + wrapperClass : "") +
"'></div>",
),
},
fragment = this.document[0].createDocumentFragment(
);
return (
fragment.appendChild(
ui.screen[0]
),
fragment.appendChild(
ui.container[0]
),
myId &&
(ui.screen.attr(
"id",
myId + "-screen"
),
ui.container.attr(
"id",
myId + "-popup"
),
ui.placeholder
.attr(
"id",
myId + "-placeholder"
)
.html(
"\x3c!-- placeholder for " + myId + " --\x3e"
)),
this._page[0].appendChild(
fragment
),
ui.placeholder.insertAfter(
theElement
),
theElement
.detach(
)
.addClass(
"ui-popup " +
this._themeClassFromOption(
"ui-body-",
currentOptions.theme
) +
" " +
(currentOptions.shadow ? "ui-overlay-shadow " : "") +
(currentOptions.corners ? "ui-corner-all " : ""),
)
.appendTo(
ui.container
),
ui
);
},
_eatEventAndClose: function (
theEvent
) {
return (
theEvent.preventDefault(
),
theEvent.stopImmediatePropagation(
),
this.options.dismissible && this.close(
),
!1
);
},
_resizeScreen: function (
) {
var screen = this._ui.screen,
popupHeight = this._ui.container.outerHeight(
!0
),
screenHeight = screen.removeAttr(
"style"
).height(
),
documentHeight = this.document.height(
) - 1;
screenHeight < documentHeight
? screen.height(
documentHeight
)
: popupHeight > screenHeight && screen.height(
popupHeight
);
},
_handleWindowKeyUp: function (
theEvent
) {
if (this._isOpen && theEvent.keyCode === $.mobile.keyCode.ESCAPE)
return this._eatEventAndClose(
theEvent
);
},
_expectResizeEvent: function (
) {
var windowCoordinates = getWindowCoordinates(
this.window
);
if (this._resizeData) {
if (
windowCoordinates.x === this._resizeData.windowCoordinates.x &&
windowCoordinates.y === this._resizeData.windowCoordinates.y &&
windowCoordinates.cx === this._resizeData.windowCoordinates.cx &&
windowCoordinates.cy === this._resizeData.windowCoordinates.cy
)
return !1;
clearTimeout(
this._resizeData.timeoutId
);
}
return (
(this._resizeData = {
timeoutId: this._delay(
"_resizeTimeout",
200
),
windowCoordinates: windowCoordinates,
}),
!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 (
theEvent
) {
var target,
targetElement = theEvent.target,
ui = this._ui;
if (this._isOpen) {
if (targetElement !== ui.container[0]) {
if (
0 ===
(target = $(
targetElement
)).parents(
).filter(
ui.container[0]
)
.length
)
return (
$(
this.document[0].activeElement
).one(
"focus",
function (
) {
target.blur(
);
}
),
ui.focusElement.focus(
),
theEvent.preventDefault(
),
theEvent.stopImmediatePropagation(
),
!1
);
ui.focusElement[0] === ui.container[0] &&
(ui.focusElement = target);
}
this._ignoreResizeEvents(
);
}
},
_themeClassFromOption: function (
prefix, value
) {
return value
? "none" === value
? ""
: prefix + value
: prefix + "inherit";
},
_applyTransition: function (
value
) {
return (
value &&
(this._ui.container.removeClass(
this._fallbackTransition
),
"none" !== value &&
((this._fallbackTransition = $.mobile._maybeDegradeTransition(
value,
)),
"none" === this._fallbackTransition &&
(this._fallbackTransition = ""),
this._ui.container.addClass(
this._fallbackTransition
))),
this
);
},
_setOptions: function (
newOptions
) {
var currentOptions = this.options,
theElement = this.element,
screen = this._ui.screen;
return (
undefined !== newOptions.wrapperClass &&
this._ui.container
.removeClass(
currentOptions.wrapperClass
)
.addClass(
newOptions.wrapperClass
),
undefined !== newOptions.theme &&
theElement
.removeClass(
this._themeClassFromOption(
"ui-body-",
currentOptions.theme
),
)
.addClass(
this._themeClassFromOption(
"ui-body-",
newOptions.theme
),
),
undefined !== newOptions.overlayTheme &&
(screen
.removeClass(
this._themeClassFromOption(
"ui-overlay-",
currentOptions.overlayTheme,
),
)
.addClass(
this._themeClassFromOption(
"ui-overlay-",
newOptions.overlayTheme,
),
),
this._isOpen && screen.addClass(
"in"
)),
undefined !== newOptions.shadow &&
theElement.toggleClass(
"ui-overlay-shadow",
newOptions.shadow
),
undefined !== newOptions.corners &&
theElement.toggleClass(
"ui-corner-all",
newOptions.corners
),
undefined !== newOptions.transition &&
(this._currentTransition ||
this._applyTransition(
newOptions.transition
)),
undefined !== newOptions.tolerance &&
this._setTolerance(
newOptions.tolerance
),
undefined !== newOptions.disabled &&
newOptions.disabled &&
this.close(
),
this._super(
newOptions
)
);
},
_setTolerance: function (
value
) {
var ar,
tol = {
t: 30,
r: 15,
b: 30,
l: 15,
};
if (undefined !== value)
switch (
((ar = String(
value
).split(
","
)),
$.each(
ar,
function (
idx, val
) {
ar[idx] = parseInt(
val,
10
);
}
),
ar.length)
) {
case 1:
isNaN(
ar[0]
) || (tol.t = tol.r = tol.b = tol.l = ar[0]);
break;
case 2:
isNaN(
ar[0]
) || (tol.t = tol.b = ar[0]),
isNaN(
ar[1]
) || (tol.l = tol.r = ar[1]);
break;
case 4:
isNaN(
ar[0]
) || (tol.t = ar[0]),
isNaN(
ar[1]
) || (tol.r = ar[1]),
isNaN(
ar[2]
) || (tol.b = ar[2]),
isNaN(
ar[3]
) || (tol.l = ar[3]);
}
return (this._tolerance = tol), this;
},
_clampPopupWidth: function (
infoOnly
) {
var windowCoordinates = getWindowCoordinates(
this.window
),
rectangle = {
x: this._tolerance.l,
y: windowCoordinates.y + this._tolerance.t,
cx: windowCoordinates.cx - this._tolerance.l - this._tolerance.r,
cy: windowCoordinates.cy - this._tolerance.t - this._tolerance.b,
};
return (
infoOnly || this._ui.container.css(
"max-width",
rectangle.cx
),
{
rc: rectangle,
menuSize: {
cx: this._ui.container.outerWidth(
!0
),
cy: this._ui.container.outerHeight(
!0
),
},
}
);
},
_calculateFinalLocation: function (
desired, clampInfo
) {
var returnValue,
rectangle = clampInfo.rc,
menuSize = clampInfo.menuSize;
return (
((returnValue = {
left: fitSegmentInsideSegment(
rectangle.cx,
menuSize.cx,
rectangle.x,
desired.x,
),
top: fitSegmentInsideSegment(
rectangle.cy,
menuSize.cy,
rectangle.y,
desired.y,
),
}).top = Math.max(
0,
returnValue.top
)),
(returnValue.top -= Math.min(
returnValue.top,
Math.max(
0,
returnValue.top + menuSize.cy - this.document.height(
),
),
)),
returnValue
);
},
_placementCoords: function (
desired
) {
return this._calculateFinalLocation(
desired,
this._clampPopupWidth(
)
);
},
_createPrerequisites: function (
screenPrerequisite,
containerPrerequisite,
whenDone,
) {
var prerequisites,
self = this;
(prerequisites = {
screen: $.Deferred(
),
container: $.Deferred(
),
}).screen.then(
function (
) {
prerequisites === self._prerequisites && screenPrerequisite(
);
}
),
prerequisites.container.then(
function (
) {
prerequisites === self._prerequisites && containerPrerequisite(
);
}
),
$.when(
prerequisites.screen,
prerequisites.container
).done(
function (
) {
prerequisites === self._prerequisites &&
((self._prerequisites = null), whenDone(
));
},
),
(self._prerequisites = prerequisites);
},
_animate: function (
args
) {
this._ui.screen
.removeClass(
args.classToRemove
)
.addClass(
args.screenClassToAdd
),
args.prerequisites.screen.resolve(
),
args.transition &&
"none" !== args.transition &&
(args.applyTransition && this._applyTransition(
args.transition
),
this._fallbackTransition)
? this._ui.container
.addClass(
args.containerClassToAdd
)
.removeClass(
args.classToRemove
)
.animationComplete(
$.proxy(
args.prerequisites.container,
"resolve"
),
)
: (this._ui.container.removeClass(
args.classToRemove
),
args.prerequisites.container.resolve(
));
},
_desiredCoords: function (
openOptions
) {
var offset,
dst = null,
windowCoordinates = getWindowCoordinates(
this.window
),
x = openOptions.x,
y = openOptions.y,
pTo = openOptions.positionTo;
if (pTo && "origin" !== pTo)
if ("window" === pTo)
(x = windowCoordinates.cx / 2 + windowCoordinates.x),
(y = windowCoordinates.cy / 2 + windowCoordinates.y);
else {
try {
dst = $(
pTo
);
} catch (err) {
dst = null;
}
dst && (dst.filter(
":visible"
), 0 === dst.length && (dst = null));
}
return (
dst &&
((x = (offset = dst.offset(
)).left + dst.outerWidth(
) / 2),
(y = offset.top + dst.outerHeight(
) / 2)),
("number" !== $.type(
x
) || isNaN(
x
)) &&
(x = windowCoordinates.cx / 2 + windowCoordinates.x),
("number" !== $.type(
y
) || isNaN(
y
)) &&
(y = windowCoordinates.cy / 2 + windowCoordinates.y),
{
x: x,
y: y,
}
);
},
_reposition: function (
openOptions
) {
(openOptions = {
x: openOptions.x,
y: openOptions.y,
positionTo: openOptions.positionTo,
}),
this._trigger(
"beforeposition",
undefined,
openOptions
),
this._ui.container.offset(
this._placementCoords(
this._desiredCoords(
openOptions
)
),
);
},
reposition: function (
openOptions
) {
this._isOpen && this._reposition(
openOptions
);
},
_openPrerequisitesComplete: function (
) {
var id = this.element.attr(
"id"
);
this._ui.container.addClass(
"ui-popup-active"
),
(this._isOpen = !0),
this._resizeScreen(
),
this._ui.container.attr(
"tabindex",
"0"
).focus(
),
this._ignoreResizeEvents(
),
id &&
this.document
.find(
"[aria-haspopup='true'][aria-owns='" + id + "']"
)
.attr(
"aria-expanded",
!0
),
this._trigger(
"afteropen"
);
},
_open: function (
options
) {
var ua,
wkmatch,
wkversion,
androidmatch,
andversion,
chromematch,
openOptions = $.extend(
{
},
this.options,
options
),
androidBlacklist =
((ua = navigator.userAgent),
(wkmatch = ua.match(
/AppleWebKit\/([0-9\.]+)/
)),
(wkversion = !!wkmatch && wkmatch[1]),
(androidmatch = ua.match(
/Android (\d+(?:\.\d+))/
)),
(andversion = !!androidmatch && androidmatch[1]),
(chromematch = ua.indexOf(
"Chrome"
) > -1),
!(
!(
null !== androidmatch &&
"4.0" === andversion &&
wkversion &&
wkversion > 534.13
) || chromematch
));
this._createPrerequisites(
$.noop,
$.noop,
$.proxy(
this,
"_openPrerequisitesComplete"
),
),
(this._currentTransition = openOptions.transition),
this._applyTransition(
openOptions.transition
),
this._ui.screen.removeClass(
"ui-screen-hidden"
),
this._ui.container.removeClass(
"ui-popup-truncate"
),
this._reposition(
openOptions
),
this._ui.container.removeClass(
"ui-popup-hidden"
),
this.options.overlayTheme &&
androidBlacklist &&
this.element.closest(
".ui-page"
).addClass(
"ui-popup-open"
),
this._animate(
{
additionalCondition: !0,
transition: openOptions.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 container = this._ui.container,
id = this.element.attr(
"id"
);
container.removeAttr(
"tabindex"
),
($.mobile.popup.active = undefined),
$(
":focus",
container[0]
).add(
container[0]
).blur(
),
id &&
this.document
.find(
"[aria-haspopup='true'][aria-owns='" + id + "']"
)
.attr(
"aria-expanded",
!1
),
this._trigger(
"afterclose"
);
},
_close: function (
immediate
) {
this._ui.container.removeClass(
"ui-popup-active"
),
this._page.removeClass(
"ui-popup-open"
),
(this._isOpen = !1),
this._createPrerequisites(
$.proxy(
this,
"_closePrerequisiteScreen"
),
$.proxy(
this,
"_closePrerequisiteContainer"
),
$.proxy(
this,
"_closePrerequisitesDone"
),
),
this._animate(
{
additionalCondition: this._ui.screen.hasClass(
"in"
),
transition: immediate ? "none" : this._currentTransition,
classToRemove: "in",
screenClassToAdd: "out",
containerClassToAdd: "reverse out",
applyTransition: !0,
prerequisites: this._prerequisites,
}
);
},
_unenhance: function (
) {
this.options.enhanced ||
(this._setOptions(
{
theme: $.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 (
$.mobile.popup.active === this
? (this.element.one(
"popupafterclose",
$.proxy(
this,
"_unenhance"
),
),
this.close(
))
: this._unenhance(
),
this
);
},
_closePopup: function (
theEvent, data
) {
var parsedDst,
toUrl,
currentOptions = this.options,
immediate = !1;
(theEvent && theEvent.isDefaultPrevented(
)) ||
$.mobile.popup.active !== this ||
(window.scrollTo(
0,
this._scrollTop
),
theEvent &&
"pagebeforechange" === theEvent.type &&
data &&
((parsedDst =
"string" == typeof data.toPage
? data.toPage
: data.toPage.jqmData(
"url"
)),
(toUrl =
(parsedDst = $.mobile.path.parseUrl(
parsedDst
)).pathname +
parsedDst.search +
parsedDst.hash),
this._myUrl !== $.mobile.path.makeUrlAbsolute(
toUrl
)
? (immediate = !0)
: theEvent.preventDefault(
)),
this.window.off(
currentOptions.closeEvents
),
this.element.undelegate(
currentOptions.closeLinkSelector,
currentOptions.closeLinkEvents,
),
this._close(
immediate
));
},
_bindContainerClose: function (
) {
this.window.on(
this.options.closeEvents,
$.proxy(
this,
"_closePopup"
),
);
},
widget: function (
) {
return this._ui.container;
},
open: function (
options
) {
var url,
hashkey,
activePage,
currentIsDialog,
urlHistory,
self = this,
currentOptions = this.options;
return $.mobile.popup.active || currentOptions.disabled
? this
: (($.mobile.popup.active = this),
(this._scrollTop = this.window.scrollTop(
)),
currentOptions.history
? ((urlHistory = $.mobile.navigate.history),
(hashkey = $.mobile.dialogHashKey),
(currentIsDialog =
!!(activePage = $.mobile.activePage) &&
activePage.hasClass(
"ui-dialog"
)),
(this._myUrl = url = urlHistory.getActive(
).url),
url.indexOf(
hashkey
) > -1 &&
!currentIsDialog &&
urlHistory.activeIndex > 0
? (self._open(
options
), self._bindContainerClose(
), this)
: (-1 !== url.indexOf(
hashkey
) || currentIsDialog
? (url = $.mobile.path.parseLocation(
).hash + hashkey)
: (url +=
url.indexOf(
"#"
) > -1
? hashkey
: "#" + hashkey),
0 === urlHistory.activeIndex &&
url === urlHistory.initialDst &&
(url += hashkey),
this.window.one(
"beforenavigate",
function (
theEvent
) {
theEvent.preventDefault(
),
self._open(
options
),
self._bindContainerClose(
);
}
),
(this.urlAltered = !0),
$.mobile.navigate(
url,
{
role: "dialog",
}
),
this))
: (self._open(
options
),
self._bindContainerClose(
),
self.element.delegate(
currentOptions.closeLinkSelector,
currentOptions.closeLinkEvents,
function (
theEvent
) {
self.close(
), theEvent.preventDefault(
);
},
),
this));
},
close: function (
) {
return (
$.mobile.popup.active !== this ||
((this._scrollTop = this.window.scrollTop(
)),
this.options.history && this.urlAltered
? ($.mobile.back(
), (this.urlAltered = !1))
: this._closePopup(
)),
this
);
},
}
),
($.mobile.popup.handleLink = function (
$link
) {
var offset,
path = $.mobile.path,
popup = $(
path.hashToSelector(
path.parseUrl(
$link.attr(
"href"
)
).hash
),
).first(
);
popup.length > 0 &&
popup.data(
"mobile-popup"
) &&
((offset = $link.offset(
)),
popup.popup(
"open",
{
x: offset.left + $link.outerWidth(
) / 2,
y: offset.top + $link.outerHeight(
) / 2,
transition: $link.jqmData(
"transition"
),
positionTo: $link.jqmData(
"position-to"
),
}
)),
setTimeout(
function (
) {
$link.removeClass(
$.mobile.activeBtnClass
);
},
300
);
}),
$.mobile.document.on(
"pagebeforechange",
function (
theEvent, data
) {
"popup" === data.options.role &&
($.mobile.popup.handleLink(
data.options.link
),
theEvent.preventDefault(
));
}
);
})(
jQuery
),
(function (
$, undefined
) {
var unfocusableItemSelector =
".ui-disabled,.ui-state-disabled,.ui-li-divider,.ui-screen-hidden,:jqmData(role='placeholder')",
goToAdjacentItem = function (
item, target, direction
) {
var adjacent = item[direction + "All"](
)
.not(
unfocusableItemSelector
)
.first(
);
adjacent.length &&
(target.blur(
).attr(
"tabindex",
"-1"
),
adjacent.find(
"a"
).first(
).focus(
));
};
$.widget(
"mobile.selectmenu",
$.mobile.selectmenu,
{
_create: function (
) {
var o = this.options;
return (
(o.nativeMenu =
o.nativeMenu ||
this.element.parents(
":jqmData(role='popup'),:mobile-popup"
)
.length > 0),
this._super(
)
);
},
_handleSelectFocus: function (
) {
this.element.blur(
), this.button.focus(
);
},
_handleKeydown: function (
event
) {
this._super(
event
), this._handleButtonVclickKeydown(
event
);
},
_handleButtonVclickKeydown: function (
event
) {
this.options.disabled ||
this.isOpen ||
(("vclick" === event.type ||
(event.keyCode &&
(event.keyCode === $.mobile.keyCode.ENTER ||
event.keyCode === $.mobile.keyCode.SPACE))) &&
(this._decideFormat(
),
"overlay" === this.menuType
? this.button
.attr(
"href",
"#" + this.popupId
)
.attr(
"data-" + ($.mobile.ns || "") + "rel",
"popup"
)
: this.button
.attr(
"href",
"#" + this.dialogId
)
.attr(
"data-" + ($.mobile.ns || "") + "rel",
"dialog"
),
(this.isOpen = !0)));
},
_handleListFocus: function (
e
) {
var params =
"focusin" === e.type
? {
tabindex: "0",
event: "vmouseover",
}
: {
tabindex: "-1",
event: "vmouseout",
};
$(
e.target
).attr(
"tabindex",
params.tabindex
).trigger(
params.event
);
},
_handleListKeydown: function (
event
) {
var target = $(
event.target
),
li = target.closest(
"li"
);
switch (event.keyCode) {
case 38:
return goToAdjacentItem(
li,
target,
"prev"
), !1;
case 40:
return goToAdjacentItem(
li,
target,
"next"
), !1;
case 13:
case 32:
return target.trigger(
"click"
), !1;
}
},
_handleMenuPageHide: function (
) {
this.thisPage.page(
"bindRemove"
);
},
_handleHeaderCloseClick: function (
) {
if ("overlay" === this.menuType) return this.close(
), !1;
},
build: function (
) {
var selectId,
popupId,
dialogId,
label,
thisPage,
isMultiple,
menuId,
themeAttr,
overlayTheme,
overlayThemeAttr,
dividerThemeAttr,
menuPage,
listbox,
list,
header,
headerTitle,
headerClose,
self,
o = this.options;
return o.nativeMenu
? this._super(
)
: ((self = this),
(popupId = (selectId = this.selectId) + "-listbox"),
(dialogId = selectId + "-dialog"),
(label = this.label),
(thisPage = this.element.closest(
".ui-page"
)),
(isMultiple = this.element[0].multiple),
(menuId = selectId + "-menu"),
(themeAttr = o.theme
? " data-" + $.mobile.ns + "theme='" + o.theme + "'"
: ""),
(overlayThemeAttr = (overlayTheme =
o.overlayTheme || o.theme || null)
? " data-" +
$.mobile.ns +
"overlay-theme='" +
overlayTheme +
"'"
: ""),
(dividerThemeAttr =
o.dividerTheme && isMultiple
? " data-" +
$.mobile.ns +
"divider-theme='" +
o.dividerTheme +
"'"
: ""),
(menuPage = $(
"<div data-" +
$.mobile.ns +
"role='dialog' class='ui-selectmenu' id='" +
dialogId +
"'" +
themeAttr +
overlayThemeAttr +
"><div data-" +
$.mobile.ns +
"role='header'><div class='ui-title'>" +
label.getEncodedText(
) +
"</div></div><div data-" +
$.mobile.ns +
"role='content'></div></div>",
)),
(listbox = $(
"<div id='" + popupId + "' class='ui-selectmenu'></div>",
)
.insertAfter(
this.select
)
.popup(
{
theme: o.overlayTheme,
}
)),
(list = $(
"<ul class='ui-selectmenu-list' id='" +
menuId +
"' role='listbox' aria-labelledby='" +
this.buttonId +
"'" +
themeAttr +
dividerThemeAttr +
"></ul>",
).appendTo(
listbox
)),
(header = $(
"<div class='ui-header ui-bar-" +
(o.theme ? o.theme : "inherit") +
"'></div>",
).prependTo(
listbox
)),
(headerTitle = $(
"<h1 class='ui-title'></h1>"
).appendTo(
header
)),
this.isMultiple &&
(headerClose = $(
"<a>",
{
role: "button",
text: o.closeText,
href: "#",
class:
"ui-btn ui-corner-all ui-btn-left ui-btn-icon-notext ui-icon-delete",
}
).appendTo(
header
)),
$.extend(
this,
{
selectId: selectId,
menuId: menuId,
popupId: popupId,
dialogId: dialogId,
thisPage: thisPage,
menuPage: menuPage,
label: label,
isMultiple: isMultiple,
theme: o.theme,
listbox: listbox,
list: list,
header: header,
headerTitle: headerTitle,
headerClose: headerClose,
menuPageContent: undefined,
menuPageClose: undefined,
placeholder: "",
}
),
this.refresh(
),
undefined === this._origTabIndex &&
(this._origTabIndex =
null !== this.select[0].getAttribute(
"tabindex"
) &&
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",
}
),
this.list.delegate(
"li:not(.ui-disabled,.ui-state-disabled,.ui-li-divider)",
"click",
function (
event
) {
var oldIndex = self.select[0].selectedIndex,
newIndex = $.mobile.getAttribute(
this,
"option-index"
),
option = self._selectOptions(
).eq(
newIndex
)[0];
(option.selected = !self.isMultiple || !option.selected),
self.isMultiple &&
$(
this
)
.find(
"a"
)
.toggleClass(
"ui-checkbox-on",
option.selected
)
.toggleClass(
"ui-checkbox-off",
!option.selected
),
(self.isMultiple || oldIndex !== newIndex) &&
self.select.trigger(
"change"
),
self.isMultiple
? self.list
.find(
"li:not(.ui-li-divider)"
)
.eq(
newIndex
)
.find(
"a"
)
.first(
)
.focus(
)
: self.close(
),
event.preventDefault(
);
},
),
this._on(
this.menuPage,
{
pagehide: "_handleMenuPageHide",
}
),
this._on(
this.listbox,
{
popupafterclose: "close",
}
),
this.isMultiple &&
this._on(
this.headerClose,
{
click: "_handleHeaderCloseClick",
}
),
this);
},
_isRebuildRequired: function (
) {
var list = this.list.find(
"li"
);
return (
this._selectOptions(
).not(
".ui-screen-hidden"
).text(
) !==
list.text(
)
);
},
selected: function (
) {
return this._selectOptions(
).filter(
":selected:not( :jqmData(placeholder='true') )",
);
},
refresh: function (
force
) {
var self, indices;
if (this.options.nativeMenu) return this._super(
force
);
(self = this),
(force || this._isRebuildRequired(
)) && self._buildList(
),
(indices = this.selectedIndices(
)),
self.setButtonText(
),
self.setButtonCount(
),
self.list
.find(
"li:not(.ui-li-divider)"
)
.find(
"a"
)
.removeClass(
$.mobile.activeBtnClass
)
.end(
)
.attr(
"aria-selected",
!1
)
.each(
function (
i
) {
if ($.inArray(
i,
indices
) > -1) {
var item = $(
this
);
item.attr(
"aria-selected",
!0
),
self.isMultiple
? item
.find(
"a"
)
.removeClass(
"ui-checkbox-off"
)
.addClass(
"ui-checkbox-on"
)
: item.hasClass(
"ui-screen-hidden"
)
? item.next(
).find(
"a"
).addClass(
$.mobile.activeBtnClass
)
: item.find(
"a"
).addClass(
$.mobile.activeBtnClass
);
}
}
);
},
close: function (
) {
if (!this.options.disabled && this.isOpen) {
"page" === this.menuType
? (this.menuPage.dialog(
"close"
),
this.list.appendTo(
this.listbox
))
: this.listbox.popup(
"close"
),
this._focusButton(
),
(this.isOpen = !1);
}
},
open: function (
) {
this.button.click(
);
},
_focusMenuItem: function (
) {
var selector = this.list.find(
"a." + $.mobile.activeBtnClass
);
0 === selector.length &&
(selector = this.list.find(
"li:not(" + unfocusableItemSelector + ") a.ui-btn",
)),
selector.first(
).focus(
);
},
_decideFormat: function (
) {
var $window = this.window,
menuHeight = this.list.parent(
).outerHeight(
),
scrollTop = $window.scrollTop(
),
btnOffset = this.button.offset(
).top,
screenHeight = $window.height(
);
menuHeight > screenHeight - 80 || !$.support.scrollTop
? (this.menuPage.appendTo(
$.mobile.pageContainer
).page(
),
(this.menuPageContent = this.menuPage.find(
".ui-content"
)),
(this.menuPageClose = this.menuPage.find(
".ui-header a"
)),
this.thisPage.unbind(
"pagehide.remove"
),
0 === scrollTop &&
btnOffset > screenHeight &&
this.thisPage.one(
"pagehide",
function (
) {
$(
this
).jqmData(
"lastScroll",
btnOffset
);
}
),
this.menuPage.one(
{
pageshow: $.proxy(
this,
"_focusMenuItem"
),
pagehide: $.proxy(
this,
"close"
),
}
),
(this.menuType = "page"),
this.menuPageContent.append(
this.list
),
this.menuPage.find(
"div .ui-title"
).text(
this.label.text(
)
))
: ((this.menuType = "overlay"),
this.listbox.one(
{
popupafteropen: $.proxy(
this,
"_focusMenuItem"
),
}
));
},
_buildList: function (
) {
var $options,
numOptions,
select,
optGroup,
i,
option,
$option,
parent,
text,
anchor,
classes,
optLabel,
divider,
item,
o = this.options,
placeholder = this.placeholder,
needPlaceholder = !0,
dataPrefix = "data-" + $.mobile.ns,
dataIndexAttr = dataPrefix + "option-index",
dataIconAttr = dataPrefix + "icon",
dataRoleAttr = dataPrefix + "role",
dataPlaceholderAttr = dataPrefix + "placeholder",
fragment = document.createDocumentFragment(
),
isPlaceholderItem = !1;
for (
this.list.empty(
).filter(
".ui-listview"
).listview(
"destroy"
),
numOptions = ($options = this._selectOptions(
)).length,
select = this.select[0],
i = 0;
i < numOptions;
i++, isPlaceholderItem = !1
)
(option = $options[i]),
($option = $(
option
)).hasClass(
"ui-screen-hidden"
) ||
((parent = option.parentNode),
(text = $option.text(
)),
(classes = []),
(anchor = document.createElement(
"a"
)).setAttribute(
"href",
"#",
),
anchor.appendChild(
document.createTextNode(
text
)
),
parent !== select &&
"optgroup" === parent.nodeName.toLowerCase(
) &&
(optLabel = parent.getAttribute(
"label"
)) !== optGroup &&
((divider = document.createElement(
"li"
)).setAttribute(
dataRoleAttr,
"list-divider",
),
divider.setAttribute(
"role",
"option"
),
divider.setAttribute(
"tabindex",
"-1"
),
divider.appendChild(
document.createTextNode(
optLabel
)
),
fragment.appendChild(
divider
),
(optGroup = optLabel)),
!needPlaceholder ||
(option.getAttribute(
"value"
) &&
0 !== text.length &&
!$option.jqmData(
"placeholder"
)) ||
((needPlaceholder = !1),
(isPlaceholderItem = !0),
null === option.getAttribute(
dataPlaceholderAttr
) &&
(this._removePlaceholderAttr = !0),
option.setAttribute(
dataPlaceholderAttr,
!0
),
o.hidePlaceholderMenuItems &&
classes.push(
"ui-screen-hidden"
),
placeholder !== text &&
(placeholder = this.placeholder = text)),
(item = document.createElement(
"li"
)),
option.disabled &&
(classes.push(
"ui-state-disabled"
),
item.setAttribute(
"aria-disabled",
!0
)),
item.setAttribute(
dataIndexAttr,
i
),
item.setAttribute(
dataIconAttr,
"false"
),
isPlaceholderItem && item.setAttribute(
dataPlaceholderAttr,
!0
),
(item.className = classes.join(
" "
)),
item.setAttribute(
"role",
"option"
),
anchor.setAttribute(
"tabindex",
"-1"
),
this.isMultiple &&
$(
anchor
).addClass(
"ui-btn ui-checkbox-off ui-btn-icon-right",
),
item.appendChild(
anchor
),
fragment.appendChild(
item
));
this.list[0].appendChild(
fragment
),
this.isMultiple || placeholder.length
? this.headerTitle.text(
this.placeholder
)
: this.header.addClass(
"ui-screen-hidden"
),
this.list.listview(
);
},
_button: function (
) {
return this.options.nativeMenu
? this._super(
)
: $(
"<a>",
{
href: "#",
role: "button",
id: this.buttonId,
"aria-haspopup": "true",
"aria-owns": this.menuId,
}
);
},
_destroy: function (
) {
this.options.nativeMenu ||
(this.close(
),
undefined !== this._origTabIndex &&
(!1 !== this._origTabIndex
? this.select.attr(
"tabindex",
this._origTabIndex
)
: this.select.removeAttr(
"tabindex"
)),
this._removePlaceholderAttr &&
this._selectOptions(
).removeAttr(
"data-" + $.mobile.ns + "placeholder",
),
this.listbox.remove(
),
this.menuPage.remove(
)),
this._super(
);
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
var reverseBoolOptionMap = {
"ui-shadow": "shadow",
"ui-corner-all": "corners",
"ui-btn-inline": "inline",
"ui-shadow-icon": "iconshadow",
"ui-mini": "mini",
},
getAttrFixed = function (
) {
var ret = $.mobile.getAttribute.apply(
this,
arguments
);
return null == ret ? undefined : ret;
},
capitalLettersRE = /[A-Z]/g;
function optionsToClasses(
options, existingClasses
) {
var classes = existingClasses || [];
return (
classes.push(
"ui-btn"
),
options.theme && classes.push(
"ui-btn-" + options.theme
),
options.icon &&
((classes = classes.concat(
[
"ui-icon-" + options.icon,
"ui-btn-icon-" + options.iconpos,
]
)),
options.iconshadow && classes.push(
"ui-shadow-icon"
)),
options.inline && classes.push(
"ui-btn-inline"
),
options.shadow && classes.push(
"ui-shadow"
),
options.corners && classes.push(
"ui-corner-all"
),
options.mini && classes.push(
"ui-mini"
),
classes
);
}
function classNameToOptions(
classes
) {
var idx,
map,
unknownClass,
alreadyEnhanced = !1,
noIcon = !0,
o = {
icon: "",
inline: !1,
shadow: !1,
corners: !1,
iconshadow: !1,
mini: !1,
},
unknownClasses = [];
for (classes = classes.split(
" "
), idx = 0; idx < classes.length; idx++)
(unknownClass = !0),
undefined !== (map = reverseBoolOptionMap[classes[idx]])
? ((unknownClass = !1), (o[map] = !0))
: 0 === classes[idx].indexOf(
"ui-btn-icon-"
)
? ((unknownClass = !1),
(noIcon = !1),
(o.iconpos = classes[idx].substring(
12
)))
: 0 === classes[idx].indexOf(
"ui-icon-"
)
? ((unknownClass = !1), (o.icon = classes[idx].substring(
8
)))
: 0 === classes[idx].indexOf(
"ui-btn-"
) &&
8 === classes[idx].length
? ((unknownClass = !1), (o.theme = classes[idx].substring(
7
)))
: "ui-btn" === classes[idx] &&
((unknownClass = !1), (alreadyEnhanced = !0)),
unknownClass && unknownClasses.push(
classes[idx]
);
return (
noIcon && (o.icon = ""),
{
options: o,
unknownClasses: unknownClasses,
alreadyEnhanced: alreadyEnhanced,
}
);
}
function camelCase2Hyphenated(
c
) {
return "-" + c.toLowerCase(
);
}
($.fn.buttonMarkup = function (
options, overwriteClasses
) {
var idx,
data,
el,
retrievedOptions,
optionKey,
defaults = $.fn.buttonMarkup.defaults;
for (idx = 0; idx < this.length; idx++) {
if (
((el = this[idx]),
(data = overwriteClasses
? {
alreadyEnhanced: !1,
unknownClasses: [],
}
: classNameToOptions(
el.className
)),
(retrievedOptions = $.extend(
{
},
data.alreadyEnhanced
? data.options
: {
},
options,
)),
!data.alreadyEnhanced)
)
for (optionKey in defaults)
undefined === retrievedOptions[optionKey] &&
(retrievedOptions[optionKey] = getAttrFixed(
el,
optionKey.replace(
capitalLettersRE,
camelCase2Hyphenated
),
));
(el.className = optionsToClasses(
$.extend(
{
},
defaults,
retrievedOptions
),
data.unknownClasses,
).join(
" "
)),
"button" !== el.tagName.toLowerCase(
) &&
el.setAttribute(
"role",
"button"
);
}
return this;
}),
($.fn.buttonMarkup.defaults = {
icon: "",
iconpos: "left",
theme: null,
inline: !1,
shadow: !0,
corners: !0,
iconshadow: !1,
mini: !1,
}),
$.extend(
$.fn.buttonMarkup,
{
initSelector:
"a:jqmData(role='button'), .ui-bar > a, .ui-bar > :jqmData(role='controlgroup') > a, button",
}
);
})(
jQuery
),
(function (
$, undefined
) {
$.widget(
"mobile.controlgroup",
$.extend(
{
options: {
enhanced: !1,
theme: null,
shadow: !1,
corners: !0,
excludeInvisible: !0,
type: "vertical",
mini: !1,
},
_create: function (
) {
var elem = this.element,
opts = this.options;
$.fn.buttonMarkup &&
this.element
.find(
$.fn.buttonMarkup.initSelector
)
.buttonMarkup(
),
$.each(
this._childWidgets,
$.proxy(
function (
number, widgetName
) {
$.mobile[widgetName] &&
this.element
.find(
$.mobile[widgetName].initSelector
)
.not(
$.mobile.page.prototype.keepNativeSelector(
)
)
[widgetName](
);
},
this
),
),
$.extend(
this,
{
_ui: null,
_initialRefresh: !0,
}
),
opts.enhanced
? (this._ui = {
groupLegend: elem
.children(
".ui-controlgroup-label"
)
.children(
),
childWrapper: elem.children(
".ui-controlgroup-controls"
),
})
: (this._ui = this._enhance(
));
},
_childWidgets: ["checkboxradio", "selectmenu", "button",],
_themeClassFromOption: function (
value
) {
return value
? "none" === value
? ""
: "ui-group-theme-" + value
: "";
},
_enhance: function (
) {
var elem = this.element,
opts = this.options,
ui = {
groupLegend: elem.children(
"legend"
),
childWrapper: elem
.addClass(
"ui-controlgroup ui-controlgroup-" +
("horizontal" === opts.type
? "horizontal"
: "vertical") +
" " +
this._themeClassFromOption(
opts.theme
) +
" " +
(opts.corners ? "ui-corner-all " : "") +
(opts.mini ? "ui-mini " : ""),
)
.wrapInner(
"<div class='ui-controlgroup-controls " +
(!0 === opts.shadow ? "ui-shadow" : "") +
"'></div>",
)
.children(
),
};
return (
ui.groupLegend.length > 0 &&
$(
"<div role='heading' class='ui-controlgroup-label'></div>"
)
.append(
ui.groupLegend
)
.prependTo(
elem
),
ui
);
},
_init: function (
) {
this.refresh(
);
},
_setOptions: function (
options
) {
var callRefresh,
returnValue,
elem = this.element;
return (
undefined !== options.type &&
(elem
.removeClass(
"ui-controlgroup-horizontal ui-controlgroup-vertical",
)
.addClass(
"ui-controlgroup-" +
("horizontal" === options.type
? "horizontal"
: "vertical"),
),
(callRefresh = !0)),
undefined !== options.theme &&
elem
.removeClass(
this._themeClassFromOption(
this.options.theme
)
)
.addClass(
this._themeClassFromOption(
options.theme
)
),
undefined !== options.corners &&
elem.toggleClass(
"ui-corner-all",
options.corners
),
undefined !== options.mini &&
elem.toggleClass(
"ui-mini",
options.mini
),
undefined !== options.shadow &&
this._ui.childWrapper.toggleClass(
"ui-shadow",
options.shadow,
),
undefined !== options.excludeInvisible &&
((this.options.excludeInvisible = options.excludeInvisible),
(callRefresh = !0)),
(returnValue = this._super(
options
)),
callRefresh && this.refresh(
),
returnValue
);
},
container: function (
) {
return this._ui.childWrapper;
},
refresh: function (
) {
var $el = this.container(
),
els = $el.find(
".ui-btn"
).not(
".ui-slider-handle"
),
create = this._initialRefresh;
$.mobile.checkboxradio &&
$el.find(
":mobile-checkboxradio"
).checkboxradio(
"refresh"
),
this._addFirstLastClasses(
els,
this.options.excludeInvisible
? this._getVisibles(
els,
create
)
: els,
create,
),
(this._initialRefresh = !1);
},
_destroy: function (
) {
var ui,
buttons,
opts = this.options;
if (opts.enhanced) return this;
(ui = this._ui),
(buttons = this.element
.removeClass(
"ui-controlgroup ui-controlgroup-horizontal ui-controlgroup-vertical ui-corner-all ui-mini " +
this._themeClassFromOption(
opts.theme
),
)
.find(
".ui-btn"
)
.not(
".ui-slider-handle"
)),
this._removeFirstLastClasses(
buttons
),
ui.groupLegend.unwrap(
),
ui.childWrapper.children(
).unwrap(
);
},
},
$.mobile.behaviors.addFirstLastClasses,
),
);
})(
jQuery
),
(function (
$, undefined
) {
$.widget(
"mobile.toolbar",
{
initSelector: ":jqmData(role='footer'), :jqmData(role='header')",
options: {
theme: null,
addBackBtn: !1,
backBtnTheme: null,
backBtnText: "Back",
},
_create: function (
) {
var role = this.element.is(
":jqmData(role='header')"
)
? "header"
: "footer",
page = this.element.closest(
".ui-page"
);
0 === page.length &&
((page = !1), this._on(
this.document,
{
pageshow: "refresh",
}
)),
$.extend(
this,
{
role: role,
page: page,
leftbtn: undefined,
rightbtn: undefined,
}
),
this.element
.attr(
"role",
"header" === role ? "banner" : "contentinfo"
)
.addClass(
"ui-" + role
),
this.refresh(
),
this._setOptions(
this.options
);
},
_setOptions: function (
o
) {
if (
(undefined !== o.addBackBtn &&
(this.options.addBackBtn &&
"header" === this.role &&
$(
".ui-page"
).length > 1 &&
this.page[0].getAttribute(
"data-" + $.mobile.ns + "url"
) !==
$.mobile.path.stripHash(
location.hash
) &&
!this.leftbtn
? this._addBackButton(
)
: this.element.find(
".ui-toolbar-back-btn"
).remove(
)),
null != o.backBtnTheme &&
this.element
.find(
".ui-toolbar-back-btn"
)
.addClass(
"ui-btn ui-btn-" + o.backBtnTheme
),
undefined !== o.backBtnText &&
this.element
.find(
".ui-toolbar-back-btn .ui-btn-text"
)
.text(
o.backBtnText
),
undefined !== o.theme)
) {
var currentTheme = this.options.theme
? this.options.theme
: "inherit",
newTheme = o.theme ? o.theme : "inherit";
this.element
.removeClass(
"ui-bar-" + currentTheme
)
.addClass(
"ui-bar-" + newTheme
);
}
this._super(
o
);
},
refresh: function (
) {
"header" === this.role && this._addHeaderButtonClasses(
),
this.page ||
(this._setRelative(
),
"footer" === this.role && this.element.appendTo(
"body"
)),
this._addHeadingClasses(
),
this._btnMarkup(
);
},
_setRelative: function (
) {
$(
"[data-" + $.mobile.ns + "role='page']"
).css(
{
position: "relative",
}
);
},
_btnMarkup: function (
) {
this.element
.children(
"a"
)
.filter(
":not([data-" + $.mobile.ns + "role='none'])"
)
.attr(
"data-" + $.mobile.ns + "role",
"button"
),
this.element.trigger(
"create"
);
},
_addHeaderButtonClasses: function (
) {
var $headeranchors = this.element.children(
"a, button"
);
(this.leftbtn = $headeranchors.hasClass(
"ui-btn-left"
)),
(this.rightbtn = $headeranchors.hasClass(
"ui-btn-right"
)),
(this.leftbtn =
this.leftbtn ||
$headeranchors.eq(
0
).not(
".ui-btn-right"
).addClass(
"ui-btn-left"
)
.length),
(this.rightbtn =
this.rightbtn ||
$headeranchors.eq(
1
).addClass(
"ui-btn-right"
).length);
},
_addBackButton: function (
) {
var options = this.options,
theme = options.backBtnTheme || options.theme;
$(
"<a role='button' href='javascript:void(0);' class='ui-btn ui-corner-all ui-shadow ui-btn-left " +
(theme ? "ui-btn-" + theme + " " : "") +
"ui-toolbar-back-btn ui-icon-carat-l ui-btn-icon-left' data-" +
$.mobile.ns +
"rel='back'>" +
options.backBtnText +
"</a>",
).prependTo(
this.element
);
},
_addHeadingClasses: function (
) {
this.element
.children(
"h1, h2, h3, h4, h5, h6"
)
.addClass(
"ui-title"
)
.attr(
{
role: "heading",
"aria-level": "1",
}
);
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
$.widget(
"mobile.toolbar",
$.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 !$.support.fixedPosition;
},
},
_create: function (
) {
this._super(
),
"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 (
o
) {
if (
("fixed" === o.position &&
"fixed" !== this.options.position &&
this._makeFixed(
),
"fixed" === this.options.position &&
!this.options.supportBlacklist(
))
) {
var $page = this.page
? this.page
: $(
".ui-page-active"
).length > 0
? $(
".ui-page-active"
)
: $(
".ui-page"
).eq(
0
);
undefined !== o.fullscreen &&
(o.fullscreen
? (this.element.addClass(
"ui-" + this.role + "-fullscreen"
),
$page.addClass(
"ui-page-" + this.role + "-fullscreen"
))
: (this.element.removeClass(
"ui-" + this.role + "-fullscreen"
),
$page
.removeClass(
"ui-page-" + this.role + "-fullscreen"
)
.addClass(
"ui-page-" + this.role + "-fixed"
)));
}
this._super(
o
);
},
_addTransitionClass: function (
) {
var tclass = this.options.transition;
tclass &&
"none" !== tclass &&
("slide" === tclass &&
(tclass = this.element.hasClass(
"ui-header"
)
? "slidedown"
: "slideup"),
this.element.addClass(
tclass
));
},
_bindPageEvents: function (
) {
var page = this.page
? this.element.closest(
".ui-page"
)
: this.document;
this._on(
page,
{
pagebeforeshow: "_handlePageBeforeShow",
webkitAnimationStart: "_handleAnimationStart",
animationstart: "_handleAnimationStart",
updatelayout: "_handleAnimationStart",
pageshow: "_handlePageShow",
pagebeforehide: "_handlePageBeforeHide",
}
);
},
_handlePageBeforeShow: function (
) {
var o = this.options;
o.disablePageZoom && $.mobile.zoom.disable(
!0
),
o.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 (
e, ui
) {
var thisFooter,
thisHeader,
nextFooter,
nextHeader,
o = this.options;
o.disablePageZoom && $.mobile.zoom.enable(
!0
),
o.updatePagePadding && this._off(
this.window,
"throttledresize"
),
o.trackPersistentToolbars &&
((thisFooter = $(
".ui-footer-fixed:jqmData(id)",
this.page
)),
(thisHeader = $(
".ui-header-fixed:jqmData(id)",
this.page
)),
(nextFooter =
(thisFooter.length &&
ui.nextPage &&
$(
".ui-footer-fixed:jqmData(id='" +
thisFooter.jqmData(
"id"
) +
"')",
ui.nextPage,
)) ||
$(
)),
(nextHeader =
(thisHeader.length &&
ui.nextPage &&
$(
".ui-header-fixed:jqmData(id='" +
thisHeader.jqmData(
"id"
) +
"')",
ui.nextPage,
)) ||
$(
)),
(nextFooter.length || nextHeader.length) &&
(nextFooter.add(
nextHeader
).appendTo(
$.mobile.pageContainer
),
ui.nextPage.one(
"pageshow",
function (
) {
nextHeader.prependTo(
this
), nextFooter.appendTo(
this
);
}
)));
},
_visible: !0,
updatePagePadding: function (
tbPage
) {
var $el = this.element,
header = "header" === this.role,
pos = parseFloat(
$el.css(
header ? "top" : "bottom"
)
);
this.options.fullscreen ||
((tbPage =
(tbPage && undefined === tbPage.type && tbPage) ||
this.page ||
$el.closest(
".ui-page"
)),
(tbPage = this.page ? this.page : ".ui-page-active"),
$(
tbPage
).css(
"padding-" + (header ? "top" : "bottom"),
$el.outerHeight(
) + pos,
));
},
_useTransition: function (
notransition
) {
var $win = this.window,
$el = this.element,
scroll = $win.scrollTop(
),
elHeight = $el.height(
),
pHeight = this.page
? $el.closest(
".ui-page"
).height(
)
: $(
".ui-page-active"
).height(
),
viewportHeight = $.mobile.getScreenHeight(
);
return (
!notransition &&
((this.options.transition &&
"none" !== this.options.transition &&
(("header" === this.role &&
!this.options.fullscreen &&
scroll > elHeight) ||
("footer" === this.role &&
!this.options.fullscreen &&
scroll + viewportHeight < pHeight - elHeight))) ||
this.options.fullscreen)
);
},
show: function (
notransition
) {
var $el = this.element;
this._useTransition(
notransition
)
? $el
.removeClass(
"out ui-fixed-hidden"
)
.addClass(
"in"
)
.animationComplete(
function (
) {
$el.removeClass(
"in"
);
}
)
: $el.removeClass(
"ui-fixed-hidden"
),
(this._visible = !0);
},
hide: function (
notransition
) {
var $el = this.element,
outclass =
"out" + ("slide" === this.options.transition ? " reverse" : "");
this._useTransition(
notransition
)
? $el
.addClass(
outclass
)
.removeClass(
"in"
)
.animationComplete(
function (
) {
$el.addClass(
"ui-fixed-hidden"
).removeClass(
outclass
);
}
)
: $el.addClass(
"ui-fixed-hidden"
).removeClass(
outclass
),
(this._visible = !1);
},
toggle: function (
) {
this[this._visible ? "hide" : "show"](
);
},
_bindToggleHandlers: function (
) {
var delayShow,
delayHide,
self = this,
o = self.options,
isVisible = !0;
(this.page
? this.page
: $(
".ui-page"
))
.bind(
"vclick",
function (
e
) {
o.tapToggle &&
!$(
e.target
).closest(
o.tapToggleBlacklist
).length &&
self.toggle(
);
}
)
.bind(
"focusin focusout",
function (
e
) {
screen.width < 1025 &&
$(
e.target
).is(
o.hideDuringFocus
) &&
!$(
e.target
).closest(
".ui-header-fixed, .ui-footer-fixed"
)
.length &&
("focusout" !== e.type || isVisible
? "focusin" === e.type &&
isVisible &&
(clearTimeout(
delayShow
),
(isVisible = !1),
(delayHide = setTimeout(
function (
) {
self.hide(
);
},
0
)))
: ((isVisible = !0),
clearTimeout(
delayHide
),
(delayShow = setTimeout(
function (
) {
self.show(
);
},
0
))));
}
);
},
_setRelative: function (
) {
"fixed" !== this.options.position &&
$(
"[data-" + $.mobile.ns + "role='page']"
).css(
{
position: "relative",
}
);
},
_destroy: function (
) {
var $el = this.element,
header = $el.hasClass(
"ui-header"
);
$el
.closest(
".ui-page"
)
.css(
"padding-" + (header ? "top" : "bottom"),
""
),
$el.removeClass(
"ui-header-fixed ui-footer-fixed ui-header-fullscreen ui-footer-fullscreen in out fade slidedown slideup ui-fixed-hidden",
),
$el
.closest(
".ui-page"
)
.removeClass(
"ui-page-header-fixed ui-page-footer-fixed ui-page-header-fullscreen ui-page-footer-fullscreen",
);
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
$.widget(
"mobile.toolbar",
$.mobile.toolbar,
{
_makeFixed: function (
) {
this._super(
), this._workarounds(
);
},
_workarounds: function (
) {
var ua = navigator.userAgent,
platform = navigator.platform,
wkmatch = ua.match(
/AppleWebKit\/([0-9]+)/
),
wkversion = !!wkmatch && wkmatch[1],
os = null;
if (
platform.indexOf(
"iPhone"
) > -1 ||
platform.indexOf(
"iPad"
) > -1 ||
platform.indexOf(
"iPod"
) > -1
)
os = "ios";
else {
if (!(ua.indexOf(
"Android"
) > -1)) return;
os = "android";
}
if ("ios" === os) this._bindScrollWorkaround(
);
else {
if (!("android" === os && wkversion && wkversion < 534)) return;
this._bindScrollWorkaround(
), this._bindListThumbWorkaround(
);
}
},
_viewportOffset: function (
) {
var $el = this.element,
header = $el.hasClass(
"ui-header"
),
offset = Math.abs(
$el.offset(
).top - this.window.scrollTop(
)
);
return (
header ||
(offset =
Math.round(
offset - this.window.height(
) + $el.outerHeight(
)
) -
60),
offset
);
},
_bindScrollWorkaround: function (
) {
var self = this;
this._on(
this.window,
{
scrollstop: function (
) {
self._viewportOffset(
) > 2 &&
self._visible &&
self._triggerRedraw(
);
},
}
);
},
_bindListThumbWorkaround: function (
) {
this.element.closest(
".ui-page"
).addClass(
"ui-android-2x-fixed"
);
},
_triggerRedraw: function (
) {
var paddingBottom = parseFloat(
$(
".ui-page-active"
).css(
"padding-bottom"
),
);
$(
".ui-page-active"
).css(
"padding-bottom",
paddingBottom + 1 + "px"
),
setTimeout(
function (
) {
$(
".ui-page-active"
).css(
"padding-bottom",
paddingBottom + "px"
);
},
0
);
},
destroy: function (
) {
this._super(
),
this.element
.closest(
".ui-page-active"
)
.removeClass(
"ui-android-2x-fix"
);
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
var ieHack = $.mobile.browser.oldIE && $.mobile.browser.oldIE <= 8,
uiTemplate = $(
"<div class='ui-popup-arrow-guide'></div><div class='ui-popup-arrow-container" +
(ieHack ? " ie" : "") +
"'><div class='ui-popup-arrow'></div></div>",
);
$.widget(
"mobile.popup",
$.mobile.popup,
{
options: {
arrow: "",
},
_create: function (
) {
var ret = this._super(
);
return this.options.arrow && (this._ui.arrow = this._addArrow(
)), ret;
},
_addArrow: function (
) {
var theme,
opts = this.options,
ar = (function (
) {
var clone = uiTemplate.clone(
),
gd = clone.eq(
0
),
ct = clone.eq(
1
),
ar = ct.children(
);
return {
arEls: ct.add(
gd
),
gd: gd,
ct: ct,
ar: ar,
};
})(
);
return (
(theme = this._themeClassFromOption(
"ui-body-",
opts.theme
)),
ar.ar.addClass(
theme + (opts.shadow ? " ui-overlay-shadow" : "")
),
ar.arEls.hide(
).appendTo(
this.element
),
ar
);
},
_unenhance: function (
) {
var ar = this._ui.arrow;
return ar && ar.arEls.remove(
), this._super(
);
},
_tryAnArrow: function (
p, dir, desired, s, best
) {
var result,
r,
diff,
desiredForArrow = {
},
tip = {
};
return (
s.arFull[p.dimKey] > s.guideDims[p.dimKey] ||
((desiredForArrow[p.fst] =
desired[p.fst] +
(s.arHalf[p.oDimKey] + s.menuHalf[p.oDimKey]) * p.offsetFactor -
s.contentBox[p.fst] +
(s.clampInfo.menuSize[p.oDimKey] - s.contentBox[p.oDimKey]) *
p.arrowOffsetFactor),
(desiredForArrow[p.snd] = desired[p.snd]),
(r = {
x: (result =
s.result ||
this._calculateFinalLocation(
desiredForArrow,
s.clampInfo
))
.left,
y: result.top,
}),
(tip[p.fst] = r[p.fst] + s.contentBox[p.fst] + p.tipOffset),
(tip[p.snd] = Math.max(
result[p.prop] + s.guideOffset[p.prop] + s.arHalf[p.dimKey],
Math.min(
result[p.prop] +
s.guideOffset[p.prop] +
s.guideDims[p.dimKey] -
s.arHalf[p.dimKey],
desired[p.snd],
),
)),
(diff =
Math.abs(
desired.x - tip.x
) + Math.abs(
desired.y - tip.y
)),
(!best || diff < best.diff) &&
((tip[p.snd] -=
s.arHalf[p.dimKey] + result[p.prop] + s.contentBox[p.snd]),
(best = {
dir: dir,
diff: diff,
result: result,
posProp: p.prop,
posVal: tip[p.snd],
}))),
best
);
},
_getPlacementState: function (
clamp
) {
var offset,
gdOffset,
ar = this._ui.arrow,
state = {
clampInfo: this._clampPopupWidth(
!clamp
),
arFull: {
cx: ar.ct.width(
),
cy: ar.ct.height(
),
},
guideDims: {
cx: ar.gd.width(
),
cy: ar.gd.height(
),
},
guideOffset: ar.gd.offset(
),
};
return (
(offset = this.element.offset(
)),
ar.gd.css(
{
left: 0,
top: 0,
right: 0,
bottom: 0,
}
),
(gdOffset = ar.gd.offset(
)),
(state.contentBox = {
x: gdOffset.left - offset.left,
y: gdOffset.top - offset.top,
cx: ar.gd.width(
),
cy: ar.gd.height(
),
}),
ar.gd.removeAttr(
"style"
),
(state.guideOffset = {
left: state.guideOffset.left - offset.left,
top: state.guideOffset.top - offset.top,
}),
(state.arHalf = {
cx: state.arFull.cx / 2,
cy: state.arFull.cy / 2,
}),
(state.menuHalf = {
cx: state.clampInfo.menuSize.cx / 2,
cy: state.clampInfo.menuSize.cy / 2,
}),
state
);
},
_placementCoords: function (
desired
) {
var state,
best,
params,
elOffset,
bgRef,
optionValue = this.options.arrow,
ar = this._ui.arrow;
return ar
? (ar.arEls.show(
),
(bgRef = {
}),
(state = this._getPlacementState(
!0
)),
(params = {
l: {
fst: "x",
snd: "y",
prop: "top",
dimKey: "cy",
oDimKey: "cx",
offsetFactor: 1,
tipOffset: -state.arHalf.cx,
arrowOffsetFactor: 0,
},
r: {
fst: "x",
snd: "y",
prop: "top",
dimKey: "cy",
oDimKey: "cx",
offsetFactor: -1,
tipOffset: state.arHalf.cx + state.contentBox.cx,
arrowOffsetFactor: 1,
},
b: {
fst: "y",
snd: "x",
prop: "left",
dimKey: "cx",
oDimKey: "cy",
offsetFactor: -1,
tipOffset: state.arHalf.cy + state.contentBox.cy,
arrowOffsetFactor: 1,
},
t: {
fst: "y",
snd: "x",
prop: "left",
dimKey: "cx",
oDimKey: "cy",
offsetFactor: 1,
tipOffset: -state.arHalf.cy,
arrowOffsetFactor: 0,
},
}),
$.each(
(!0 === optionValue ? "l,t,r,b" : optionValue).split(
","
),
$.proxy(
function (
key, value
) {
best = this._tryAnArrow(
params[value],
value,
desired,
state,
best,
);
},
this
),
),
best
? (ar.ct
.removeClass(
"ui-popup-arrow-l ui-popup-arrow-t ui-popup-arrow-r ui-popup-arrow-b",
)
.addClass(
"ui-popup-arrow-" + best.dir
)
.removeAttr(
"style"
)
.css(
best.posProp,
best.posVal
)
.show(
),
ieHack ||
((elOffset = this.element.offset(
)),
(bgRef[params[best.dir].fst] = ar.ct.offset(
)),
(bgRef[params[best.dir].snd] = {
left: elOffset.left + state.contentBox.x,
top: elOffset.top + state.contentBox.y,
})),
best.result)
: (ar.arEls.hide(
), this._super(
desired
)))
: this._super(
desired
);
},
_setOptions: function (
opts
) {
var newTheme,
oldTheme = this.options.theme,
ar = this._ui.arrow,
ret = this._super(
opts
);
if (undefined !== opts.arrow) {
if (!ar && opts.arrow)
return void (this._ui.arrow = this._addArrow(
));
ar && !opts.arrow && (ar.arEls.remove(
), (this._ui.arrow = null));
}
return (
(ar = this._ui.arrow) &&
(undefined !== opts.theme &&
((oldTheme = this._themeClassFromOption(
"ui-body-",
oldTheme
)),
(newTheme = this._themeClassFromOption(
"ui-body-",
opts.theme
)),
ar.ar.removeClass(
oldTheme
).addClass(
newTheme
)),
undefined !== opts.shadow &&
ar.ar.toggleClass(
"ui-overlay-shadow",
opts.shadow
)),
ret
);
},
_destroy: function (
) {
var ar = this._ui.arrow;
return ar && ar.arEls.remove(
), this._super(
);
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
$.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 el = this.element,
parentPage = el.closest(
".ui-page, :jqmData(role='page')"
);
$.extend(
this,
{
_closeLink: el.find(
":jqmData(rel='close')"
),
_parentPage: parentPage.length > 0 && parentPage,
_openedPage: null,
_page: this._getPage,
_panelInner: this._getPanelInner(
),
_fixedToolbars: this._getFixedToolbars,
}
),
"overlay" !== this.options.display && this._getWrapper(
),
this._addPanelClasses(
),
$.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 panelInner = this.element.find(
"." + this.options.classes.panelInner,
);
return (
0 === panelInner.length &&
(panelInner = this.element
.children(
)
.wrapAll(
"<div class='" + this.options.classes.panelInner + "' />",
)
.parent(
)),
panelInner
);
},
_createModal: function (
) {
var self = this,
target = self._parentPage
? self._parentPage.parent(
)
: self.element.parent(
);
self._modal = $(
"<div class='" + self.options.classes.modal + "'></div>",
)
.on(
"mousedown",
function (
) {
self.close(
);
}
)
.appendTo(
target
);
},
_getPage: function (
) {
return (
this._openedPage ||
this._parentPage ||
$(
"." + $.mobile.activePageClass
)
);
},
_getWrapper: function (
) {
var wrapper = this._page(
).find(
"." + this.options.classes.pageWrapper,
);
0 === wrapper.length &&
(wrapper = 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 = wrapper);
},
_getFixedToolbars: function (
) {
var extFixedToolbars = $(
"body"
).children(
".ui-header-fixed, .ui-footer-fixed",
),
intFixedToolbars = this._page(
).find(
".ui-header-fixed, .ui-footer-fixed",
);
return extFixedToolbars
.add(
intFixedToolbars
)
.addClass(
this.options.classes.pageFixedToolbar
);
},
_getPosDisplayClasses: function (
prefix
) {
return (
prefix +
"-position-" +
this.options.position +
" " +
prefix +
"-display-" +
this.options.display
);
},
_getPanelClasses: function (
) {
var panelClasses =
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 &&
(panelClasses += " " + this.options.classes.panelFixed),
panelClasses
);
},
_addPanelClasses: function (
) {
this.element.addClass(
this._getPanelClasses(
)
);
},
_handleCloseClickAndEatEvent: function (
event
) {
if (!event.isDefaultPrevented(
))
return event.preventDefault(
), this.close(
), !1;
},
_handleCloseClick: function (
event
) {
event.isDefaultPrevented(
) || this.close(
);
},
_bindCloseEvents: function (
) {
this._on(
this._closeLink,
{
click: "_handleCloseClick",
}
),
this._on(
{
"click a:jqmData(ajax='false')": "_handleCloseClick",
}
);
},
_positionPanel: function (
scrollToTop
) {
var panelInnerHeight = this._panelInner.outerHeight(
),
expand = panelInnerHeight > $.mobile.getScreenHeight(
);
expand || !this.options.positionFixed
? (expand &&
(this._unfixPanel(
),
$.mobile.resetActivePageHeight(
panelInnerHeight
)),
scrollToTop &&
this.window[0].scrollTo(
0,
$.mobile.defaultHomeScroll
))
: this._fixPanel(
);
},
_bindFixListener: function (
) {
this._on(
$(
window
),
{
throttledresize: "_positionPanel",
}
);
},
_unbindFixListener: function (
) {
this._off(
$(
window
),
"throttledresize"
);
},
_unfixPanel: function (
) {
this.options.positionFixed &&
$.support.fixedPosition &&
this.element.removeClass(
this.options.classes.panelFixed
);
},
_fixPanel: function (
) {
this.options.positionFixed &&
$.support.fixedPosition &&
this.element.addClass(
this.options.classes.panelFixed
);
},
_bindUpdateLayout: function (
) {
var self = this;
self.element.on(
"updatelayout",
function (
) {
self._open && self._positionPanel(
);
}
);
},
_bindLinkListeners: function (
) {
this._on(
"body",
{
"click a": "_handleClick",
}
);
},
_handleClick: function (
e
) {
var link,
panelId = this.element.attr(
"id"
);
if (
e.currentTarget.href.split(
"#"
)[1] === panelId &&
undefined !== panelId
)
return (
e.preventDefault(
),
(link = $(
e.target
)).hasClass(
"ui-btn"
) &&
(link.addClass(
$.mobile.activeBtnClass
),
this.element.one(
"panelopen panelclose",
function (
) {
link.removeClass(
$.mobile.activeBtnClass
);
}
)),
this.toggle(
),
!1
);
},
_bindSwipeEvents: function (
) {
var self = this,
area = self._modal
? self.element.add(
self._modal
)
: self.element;
self.options.swipeClose &&
("left" === self.options.position
? area.on(
"swipeleft.panel",
function (
) {
self.close(
);
}
)
: area.on(
"swiperight.panel",
function (
) {
self.close(
);
}
));
},
_bindPageEvents: function (
) {
var self = this;
this.document
.on(
"panelbeforeopen",
function (
e
) {
self._open && e.target !== self.element[0] && self.close(
);
}
)
.on(
"keyup.panel",
function (
e
) {
27 === e.keyCode && self._open && self.close(
);
}
),
this._parentPage ||
"overlay" === this.options.display ||
this._on(
this.document,
{
pageshow: "_getWrapper",
}
),
self._parentPage
? this.document.on(
"pagehide",
":jqmData(role='page')",
function (
) {
self._open && self.close(
!0
);
},
)
: this.document.on(
"pagebeforehide",
function (
) {
self._open && self.close(
!0
);
}
);
},
_open: !1,
_pageContentOpenClasses: null,
_modalOpenClasses: null,
open: function (
immediate
) {
if (!this._open) {
var self = this,
o = self.options,
_openPanel = function (
) {
self.document.off(
"panelclose"
),
self._page(
).jqmData(
"panel",
"open"
),
$.support.cssTransform3d &&
o.animate &&
"overlay" !== o.display &&
(self._wrapper.addClass(
o.classes.animate
),
self._fixedToolbars(
).addClass(
o.classes.animate
)),
!immediate && $.support.cssTransform3d && o.animate
? self.element.animationComplete(
complete,
"transition"
)
: setTimeout(
complete,
0
),
o.theme &&
"overlay" !== o.display &&
self
._page(
)
.parent(
)
.addClass(
o.classes.pageContainer +
"-themed " +
o.classes.pageContainer +
"-" +
o.theme,
),
self.element
.removeClass(
o.classes.panelClosed
)
.addClass(
o.classes.panelOpen
),
self._positionPanel(
!0
),
(self._pageContentOpenClasses = self._getPosDisplayClasses(
o.classes.pageContentPrefix,
)),
"overlay" !== o.display &&
(self._page(
).parent(
).addClass(
o.classes.pageContainer
),
self._wrapper.addClass(
self._pageContentOpenClasses
),
self
._fixedToolbars(
)
.addClass(
self._pageContentOpenClasses
)),
(self._modalOpenClasses =
self._getPosDisplayClasses(
o.classes.modal
) +
" " +
o.classes.modalOpen),
self._modal &&
self._modal
.addClass(
self._modalOpenClasses
)
.height(
Math.max(
self._modal.height(
),
self.document.height(
)
),
);
},
complete = function (
) {
"overlay" !== o.display &&
(self._wrapper.addClass(
o.classes.pageContentPrefix + "-open",
),
self
._fixedToolbars(
)
.addClass(
o.classes.pageContentPrefix + "-open"
)),
self._bindFixListener(
),
self._trigger(
"open"
),
(self._openedPage = self._page(
));
};
self._trigger(
"beforeopen"
),
"open" === self._page(
).jqmData(
"panel"
)
? self.document.on(
"panelclose",
function (
) {
_openPanel(
);
}
)
: _openPanel(
),
(self._open = !0);
}
},
close: function (
immediate
) {
if (this._open) {
var self = this,
o = this.options,
complete = function (
) {
o.theme &&
"overlay" !== o.display &&
self
._page(
)
.parent(
)
.removeClass(
o.classes.pageContainer +
"-themed " +
o.classes.pageContainer +
"-" +
o.theme,
),
self.element.addClass(
o.classes.panelClosed
),
"overlay" !== o.display &&
(self._page(
).parent(
).removeClass(
o.classes.pageContainer
),
self._wrapper.removeClass(
o.classes.pageContentPrefix + "-open",
),
self
._fixedToolbars(
)
.removeClass(
o.classes.pageContentPrefix + "-open"
)),
$.support.cssTransform3d &&
o.animate &&
"overlay" !== o.display &&
(self._wrapper.removeClass(
o.classes.animate
),
self._fixedToolbars(
).removeClass(
o.classes.animate
)),
self._fixPanel(
),
self._unbindFixListener(
),
$.mobile.resetActivePageHeight(
),
self._page(
).jqmRemoveData(
"panel"
),
self._trigger(
"close"
),
(self._openedPage = null);
};
self._trigger(
"beforeclose"
),
self.element.removeClass(
o.classes.panelOpen
),
"overlay" !== o.display &&
(self._wrapper.removeClass(
self._pageContentOpenClasses
),
self
._fixedToolbars(
)
.removeClass(
self._pageContentOpenClasses
)),
!immediate && $.support.cssTransform3d && o.animate
? self.element.animationComplete(
complete,
"transition"
)
: setTimeout(
complete,
0
),
self._modal && self._modal.removeClass(
self._modalOpenClasses
),
(self._open = !1);
}
},
toggle: function (
) {
this[this._open ? "close" : "open"](
);
},
_destroy: function (
) {
var o = this.options,
multiplePanels =
$(
"body > :mobile-panel"
).length +
$.mobile.activePage.find(
":mobile-panel"
).length >
1;
"overlay" !== o.display &&
(0 ===
$(
"body > :mobile-panel"
)
.add(
$.mobile.activePage.find(
":mobile-panel"
)
)
.not(
".ui-panel-display-overlay"
)
.not(
this.element
).length && this._wrapper.children(
).unwrap(
),
this._open &&
(this._fixedToolbars(
).removeClass(
o.classes.pageContentPrefix + "-open",
),
$.support.cssTransform3d &&
o.animate &&
this._fixedToolbars(
).removeClass(
o.classes.animate
),
this._page(
).parent(
).removeClass(
o.classes.pageContainer
),
o.theme &&
this._page(
)
.parent(
)
.removeClass(
o.classes.pageContainer +
"-themed " +
o.classes.pageContainer +
"-" +
o.theme,
))),
multiplePanels || this.document.off(
"panelopen panelclose"
),
this._open && this._page(
).jqmRemoveData(
"panel"
),
this._panelInner.children(
).unwrap(
),
this.element
.removeClass(
[
this._getPanelClasses(
),
o.classes.panelOpen,
o.classes.animate,
].join(
" "
),
)
.off(
"swipeleft.panel swiperight.panel"
)
.off(
"panelbeforeopen"
)
.off(
"panelhide"
)
.off(
"keyup.panel"
)
.off(
"updatelayout"
),
this._modal && this._modal.remove(
);
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
$.widget(
"mobile.table",
{
options: {
classes: {
table: "ui-table",
},
enhanced: !1,
},
_create: function (
) {
this.options.enhanced ||
this.element.addClass(
this.options.classes.table
),
$.extend(
this,
{
headers: undefined,
allHeaders: undefined,
}
),
this._refresh(
!0
);
},
_setHeaders: function (
) {
var trs = this.element.find(
"thead tr"
);
(this.headers = this.element.find(
"tr:eq(0)"
).children(
)),
(this.allHeaders = this.headers.add(
trs.children(
)
));
},
refresh: function (
) {
this._refresh(
);
},
rebuild: $.noop,
_refresh: function (
) {
var table = this.element,
trs = table.find(
"thead tr"
);
this._setHeaders(
),
trs.each(
function (
) {
var columnCount = 0;
$(
this
)
.children(
)
.each(
function (
) {
var j,
span = parseInt(
this.getAttribute(
"colspan"
),
10
),
selector = ":nth-child(" + (columnCount + 1) + ")";
if (
(this.setAttribute(
"data-" + $.mobile.ns + "colstart",
columnCount + 1,
),
span)
)
for (j = 0; j < span - 1; j++)
selector += ", :nth-child(" + (++columnCount + 1) + ")";
$(
this
).jqmData(
"cells",
table
.find(
"tr"
)
.not(
trs.eq(
0
)
)
.not(
this
)
.children(
selector
),
),
columnCount++;
}
);
}
);
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
$.widget(
"mobile.table",
$.mobile.table,
{
options: {
mode: "columntoggle",
columnBtnTheme: null,
columnPopupTheme: null,
columnBtnText: "Columns...",
classes: $.extend(
$.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 &&
($.extend(
this,
{
_menu: null,
}
),
this.options.enhanced
? ((this._menu = $(
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 (
menu, keep
) {
var inputs,
checkboxIndex = 0,
opts = this.options,
container = menu.controlgroup(
"container"
);
keep
? (inputs = menu.find(
"input"
))
: container.empty(
),
this.headers.not(
"td"
).each(
function (
) {
var header = $(
this
),
priority = $.mobile.getAttribute(
this,
"priority"
),
cells = header.add(
header.jqmData(
"cells"
)
);
priority &&
(cells.addClass(
opts.classes.priorityPrefix + priority
),
(keep
? inputs.eq(
checkboxIndex++
)
: $(
"<label><input type='checkbox' checked />" +
(header.children(
"abbr"
).first(
).attr(
"title"
) ||
header.text(
)) +
"</label>",
)
.appendTo(
container
)
.children(
0
)
.checkboxradio(
{
theme: opts.columnPopupTheme,
}
)
).jqmData(
"cells",
cells
));
}
),
keep || menu.controlgroup(
"refresh"
);
},
_menuInputChange: function (
evt
) {
var input = $(
evt.target
),
checked = input[0].checked;
input
.jqmData(
"cells"
)
.toggleClass(
"ui-table-cell-hidden",
!checked
)
.toggleClass(
"ui-table-cell-visible",
checked
),
input[0].getAttribute(
"locked"
)
? (input.removeAttr(
"locked"
),
this._unlockCells(
input.jqmData(
"cells"
)
))
: input.attr(
"locked",
!0
);
},
_unlockCells: function (
cells
) {
cells.removeClass(
"ui-table-cell-hidden ui-table-cell-visible"
);
},
_enhanceColToggle: function (
) {
var id,
menuButton,
popup,
menu,
table = this.element,
opts = this.options,
ns = $.mobile.ns,
fragment = this.document[0].createDocumentFragment(
);
return (
(id = this._id(
) + "-popup"),
(menuButton = $(
"<a href='#" +
id +
"' class='" +
opts.classes.columnBtn +
" ui-btn ui-btn-" +
(opts.columnBtnTheme || "a") +
" ui-corner-all ui-shadow ui-mini' data-" +
ns +
"rel='popup'>" +
opts.columnBtnText +
"</a>",
)),
(popup = $(
"<div class='" + opts.classes.popup + "' id='" + id + "'></div>",
)),
(menu = $(
"<fieldset></fieldset>"
).controlgroup(
)),
this._addToggles(
menu,
!1
),
menu.appendTo(
popup
),
fragment.appendChild(
popup[0]
),
fragment.appendChild(
menuButton[0]
),
table.before(
fragment
),
popup.popup(
),
menu
);
},
rebuild: function (
) {
this._super(
),
"columntoggle" === this.options.mode && this._refresh(
!1
);
},
_refresh: function (
create
) {
this._super(
create
),
create ||
"columntoggle" !== this.options.mode ||
(this._unlockCells(
this.element.find(
".ui-table-cell-hidden, .ui-table-cell-visible",
),
),
this._addToggles(
this._menu,
create
),
this._setToggleState(
));
},
_setToggleState: function (
) {
this._menu.find(
"input"
).each(
function (
) {
var checkbox = $(
this
);
(this.checked =
"table-cell" === checkbox.jqmData(
"cells"
).eq(
0
).css(
"display"
)),
checkbox.checkboxradio(
"refresh"
);
}
);
},
_destroy: function (
) {
this._super(
);
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
$.widget(
"mobile.table",
$.mobile.table,
{
options: {
mode: "reflow",
classes: $.extend(
$.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 (
create
) {
this._super(
create
),
create || "reflow" !== this.options.mode || this._updateReflow(
);
},
_updateReflow: function (
) {
var table = this,
opts = this.options;
$(
table.allHeaders.get(
).reverse(
)
).each(
function (
) {
var iteration,
filter,
cells = $(
this
).jqmData(
"cells"
),
colstart = $.mobile.getAttribute(
this,
"colstart"
),
hierarchyClass =
cells.not(
this
).filter(
"thead th"
).length &&
" ui-table-cell-label-top",
text = $(
this
).text(
);
"" !== text &&
(hierarchyClass
? ((filter = ""),
(iteration = parseInt(
this.getAttribute(
"colspan"
),
10
)) &&
(filter =
"td:nth-child(" + iteration + "n + " + colstart + ")"),
table._addLabels(
cells.filter(
filter
),
opts.classes.cellLabels + hierarchyClass,
text,
))
: table._addLabels(
cells,
opts.classes.cellLabels,
text
));
}
);
},
_addLabels: function (
cells, label, text
) {
cells
.not(
":has(b." + label + ")"
)
.prepend(
"<b class='" + label + "'>" + text + "</b>"
);
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
var defaultFilterCallback = function (
index, searchValue
) {
return (
-1 ===
("" + ($.mobile.getAttribute(
this,
"filtertext"
) || $(
this
).text(
)))
.toLowerCase(
)
.indexOf(
searchValue
)
);
};
$.widget(
"mobile.filterable",
{
initSelector: ":jqmData(filter='true')",
options: {
filterReveal: !1,
filterCallback: defaultFilterCallback,
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 opts = this.options;
$.extend(
this,
{
_search: null,
_timer: 0,
}
),
this._setInput(
opts.input
),
opts.enhanced ||
this._filterItems(
((this._search && this._search.val(
)) || "").toLowerCase(
),
);
},
_onKeyUp: function (
) {
var val,
lastval,
search = this._search;
if (search) {
if (
((val = search.val(
).toLowerCase(
)),
(lastval = $.mobile.getAttribute(
search[0],
"lastval"
) + "") &&
lastval === val)
)
return;
this._timer &&
(window.clearTimeout(
this._timer
), (this._timer = 0)),
(this._timer = this._delay(
function (
) {
this._trigger(
"beforefilter",
null,
{
input: search,
}
),
search[0].setAttribute(
"data-" + $.mobile.ns + "lastval",
val,
),
this._filterItems(
val
),
(this._timer = 0);
},
250
));
}
},
_getFilterableItems: function (
) {
var elem = this.element,
children = this.options.children,
items = children
? $.isFunction(
children
)
? children(
)
: children.nodeName
? $(
children
)
: children.jquery
? children
: this.element.find(
children
)
: {
length: 0,
};
return 0 === items.length && (items = elem.children(
)), items;
},
_filterItems: function (
val
) {
var idx,
callback,
length,
show = [],
hide = [],
opts = this.options,
filterItems = this._getFilterableItems(
);
if (null != val)
for (
callback = opts.filterCallback || defaultFilterCallback,
length = filterItems.length,
idx = 0;
idx < length;
idx++
)
(callback.call(
filterItems[idx],
idx,
val
)
? hide
: show).push(
filterItems[idx],
);
0 === hide.length
? filterItems[opts.filterReveal ? "addClass" : "removeClass"](
"ui-screen-hidden",
)
: ($(
hide
).addClass(
"ui-screen-hidden"
),
$(
show
).removeClass(
"ui-screen-hidden"
)),
this._refreshChildWidget(
),
this._trigger(
"filter",
null,
{
items: filterItems,
}
);
},
_refreshChildWidget: function (
) {
var widget,
idx,
recognizedWidgets = [
"collapsibleset",
"selectmenu",
"controlgroup",
"listview",
];
for (idx = recognizedWidgets.length - 1; idx > -1; idx--)
(widget = recognizedWidgets[idx]),
$.mobile[widget] &&
(widget = this.element.data(
"mobile-" + widget
)) &&
$.isFunction(
widget.refresh
) &&
widget.refresh(
);
},
_setInput: function (
selector
) {
var search = this._search;
this._timer && (window.clearTimeout(
this._timer
), (this._timer = 0)),
search &&
(this._off(
search,
"keyup change input"
), (search = null)),
selector &&
((search = selector.jquery
? selector
: selector.nodeName
? $(
selector
)
: this.document.find(
selector
)),
this._on(
search,
{
keyup: "_onKeyUp",
change: "_onKeyUp",
input: "_onKeyUp",
}
)),
(this._search = search);
},
_setOptions: function (
options
) {
var refilter = !(
undefined === options.filterReveal &&
undefined === options.filterCallback &&
undefined === options.children
);
this._super(
options
),
undefined !== options.input &&
(this._setInput(
options.input
), (refilter = !0)),
refilter && this.refresh(
);
},
_destroy: function (
) {
var opts = this.options,
items = this._getFilterableItems(
);
opts.enhanced
? items.toggleClass(
"ui-screen-hidden",
opts.filterReveal
)
: items.removeClass(
"ui-screen-hidden"
);
},
refresh: function (
) {
this._timer && (window.clearTimeout(
this._timer
), (this._timer = 0)),
this._filterItems(
((this._search && this._search.val(
)) || "").toLowerCase(
),
);
},
}
);
})(
jQuery
),
(function (
$, undefined
) {
var rDividerListItem = /(^|\s)ui-li-divider(\s|$)/,
origDefaultFilterCallback =
$.mobile.filterable.prototype.options.filterCallback;
($.mobile.filterable.prototype.options.filterCallback = function (
index,
searchValue,
) {
return (
!this.className.match(
rDividerListItem
) &&
origDefaultFilterCallback.call(
this,
index,
searchValue
)
);
}),
$.widget(
"mobile.filterable",
$.mobile.filterable,
{
options: {
filterPlaceholder: "Filter items...",
filterTheme: null,
},
_create: function (
) {
var idx,
widgetName,
elem = this.element,
recognizedWidgets = [
"collapsibleset",
"selectmenu",
"controlgroup",
"listview",
],
createHandlers = {
};
for (
this._super(
),
$.extend(
this,
{
_widget: null,
}
),
idx = recognizedWidgets.length - 1;
idx > -1;
idx--
)
if (
((widgetName = recognizedWidgets[idx]), $.mobile[widgetName])
) {
if (this._setWidget(
elem.data(
"mobile-" + widgetName
)
)) break;
createHandlers[widgetName + "create"] = "_handleCreate";
}
this._widget || this._on(
elem,
createHandlers
);
},
_handleCreate: function (
evt
) {
this._setWidget(
this.element.data(
"mobile-" + evt.type.substring(
0,
evt.type.length - 6
),
),
);
},
_trigger: function (
type, event, data
) {
this._widget &&
"mobile-listview" === this._widget.widgetFullName &&
"beforefilter" === type &&
this._widget._trigger(
"beforefilter",
event,
data
),
this._super(
type,
event,
data
);
},
_setWidget: function (
widget
) {
var self, orig;
return (
!this._widget &&
widget &&
((this._widget = widget),
(this._widget._setOptions =
((self = this),
(orig = this._widget._setOptions),
function (
options
) {
orig.call(
this,
options
),
self._syncTextInputOptions(
options
);
}))),
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 (
selector
) {
var opts = this.options,
updatePlaceholder = !0,
textinputOpts = {
};
if (!selector) {
if (this._isSearchInternal(
)) return;
(updatePlaceholder = !1),
(selector = $(
"<input data-" +
$.mobile.ns +
"type='search' placeholder='" +
opts.filterPlaceholder +
"'></input>",
).jqmData(
"ui-filterable-" + this.uuid + "-internal",
!0
)),
$(
"<form class='ui-filterable'></form>"
)
.append(
selector
)
.submit(
function (
evt
) {
evt.preventDefault(
), selector.blur(
);
}
)
.insertBefore(
this.element
),
$.mobile.textinput &&
(null != this.options.filterTheme &&
(textinputOpts.theme = opts.filterTheme),
selector.textinput(
textinputOpts
));
}
this._super(
selector
),
this._isSearchInternal(
) &&
updatePlaceholder &&
this._search.attr(
"placeholder",
this.options.filterPlaceholder,
);
},
_setOptions: function (
options
) {
var ret = this._super(
options
);
return (
undefined !== options.filterPlaceholder &&
this._isSearchInternal(
) &&
this._search.attr(
"placeholder",
options.filterPlaceholder
),
undefined !== options.filterTheme &&
this._search &&
$.mobile.textinput &&
this._search.textinput(
"option",
"theme",
options.filterTheme
),
ret
);
},
_destroy: function (
) {
this._isSearchInternal(
) && this._search.remove(
), this._super(
);
},
_syncTextInputOptions: function (
options
) {
var idx,
textinputOptions = {
};
if (this._isSearchInternal(
) && $.mobile.textinput) {
for (idx in $.mobile.textinput.prototype.options)
undefined !== options[idx] &&
("theme" === idx && null != this.options.filterTheme
? (textinputOptions[idx] = this.options.filterTheme)
: (textinputOptions[idx] = options[idx]));
this._search.textinput(
"option",
textinputOptions
);
}
},
}
);
})(
jQuery
),
/*!
* jQuery UI Tabs fadf2b312a05040436451c64bbfaf4814bc62c56
* http://jqueryui.com
*
* Copyright 2013 jQuery Foundation and other contributors
* Released under the MIT license.
* http://jquery.org/license
*
* http://api.jqueryui.com/tabs/
*
* Depends:
* jquery.ui.core.js
* jquery.ui.widget.js
*/
(function (
$, undefined
) {
var tabId = 0,
rhash = /#.*$/;
function isLocal(
anchor
) {
return (
anchor.hash.length > 1 &&
decodeURIComponent(
anchor.href.replace(
rhash,
""
)
) ===
decodeURIComponent(
location.href.replace(
rhash,
""
)
)
);
}
$.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 that = this,
options = this.options;
(this.running = !1),
this.element
.addClass(
"ui-tabs ui-widget ui-widget-content ui-corner-all"
)
.toggleClass(
"ui-tabs-collapsible",
options.collapsible
)
.delegate(
".ui-tabs-nav > li",
"mousedown" + this.eventNamespace,
function (
event
) {
$(
this
).is(
".ui-state-disabled"
) && event.preventDefault(
);
},
)
.delegate(
".ui-tabs-anchor",
"focus" + this.eventNamespace,
function (
) {
$(
this
).closest(
"li"
).is(
".ui-state-disabled"
) && this.blur(
);
},
),
this._processTabs(
),
(options.active = this._initialActive(
)),
$.isArray(
options.disabled
) &&
(options.disabled = $.unique(
options.disabled.concat(
$.map(
this.tabs.filter(
".ui-state-disabled"
),
function (
li
) {
return that.tabs.index(
li
);
}
),
),
).sort(
)),
!1 !== this.options.active && this.anchors.length
? (this.active = this._findActive(
options.active
))
: (this.active = $(
)),
this._refresh(
),
this.active.length && this.load(
options.active
);
},
_initialActive: function (
) {
var active = this.options.active,
collapsible = this.options.collapsible,
locationHash = location.hash.substring(
1
);
return (
null === active &&
(locationHash &&
this.tabs.each(
function (
i, tab
) {
if ($(
tab
).attr(
"aria-controls"
) === locationHash)
return (active = i), !1;
}
),
null === active &&
(active = this.tabs.index(
this.tabs.filter(
".ui-tabs-active"
)
)),
(null !== active && -1 !== active) ||
(active = !!this.tabs.length && 0)),
!1 !== active &&
-1 === (active = this.tabs.index(
this.tabs.eq(
active
)
)) &&
(active = !collapsible && 0),
!collapsible &&
!1 === active &&
this.anchors.length &&
(active = 0),
active
);
},
_getCreateEventData: function (
) {
return {
tab: this.active,
panel: this.active.length
? this._getPanelForTab(
this.active
)
: $(
),
};
},
_tabKeydown: function (
event
) {
var focusedTab = $(
this.document[0].activeElement
).closest(
"li"
),
selectedIndex = this.tabs.index(
focusedTab
),
goingForward = !0;
if (!this._handlePageNav(
event
)) {
switch (event.keyCode) {
case $.ui.keyCode.RIGHT:
case $.ui.keyCode.DOWN:
selectedIndex++;
break;
case $.ui.keyCode.UP:
case $.ui.keyCode.LEFT:
(goingForward = !1), selectedIndex--;
break;
case $.ui.keyCode.END:
selectedIndex = this.anchors.length - 1;
break;
case $.ui.keyCode.HOME:
selectedIndex = 0;
break;
case $.ui.keyCode.SPACE:
return (
event.preventDefault(
),
clearTimeout(
this.activating
),
void this._activate(
selectedIndex
)
);
case $.ui.keyCode.ENTER:
return (
event.preventDefault(
),
clearTimeout(
this.activating
),
void this._activate(
selectedIndex !== this.options.active && selectedIndex,
)
);
default:
return;
}
event.preventDefault(
),
clearTimeout(
this.activating
),
(selectedIndex = this._focusNextTab(
selectedIndex,
goingForward
)),
event.ctrlKey ||
(focusedTab.attr(
"aria-selected",
"false"
),
this.tabs.eq(
selectedIndex
).attr(
"aria-selected",
"true"
),
(this.activating = this._delay(
function (
) {
this.option(
"active",
selectedIndex
);
},
this.delay
)));
}
},
_panelKeydown: function (
event
) {
this._handlePageNav(
event
) ||
(event.ctrlKey &&
event.keyCode === $.ui.keyCode.UP &&
(event.preventDefault(
), this.active.focus(
)));
},
_handlePageNav: function (
event
) {
return event.altKey && event.keyCode === $.ui.keyCode.PAGE_UP
? (this._activate(
this._focusNextTab(
this.options.active - 1,
!1
)
),
!0)
: event.altKey && event.keyCode === $.ui.keyCode.PAGE_DOWN
? (this._activate(
this._focusNextTab(
this.options.active + 1,
!0
)
),
!0)
: void 0;
},
_findNextTab: function (
index, goingForward
) {
var lastTabIndex = this.tabs.length - 1;
for (
;
-1 !==
$.inArray(
(index > lastTabIndex && (index = 0),
index < 0 && (index = lastTabIndex),
index),
this.options.disabled,
);
)
index = goingForward ? index + 1 : index - 1;
return index;
},
_focusNextTab: function (
index, goingForward
) {
return (
(index = this._findNextTab(
index,
goingForward
)),
this.tabs.eq(
index
).focus(
),
index
);
},
_setOption: function (
key, value
) {
"active" !== key
? "disabled" !== key
? (this._super(
key,
value
),
"collapsible" === key &&
(this.element.toggleClass(
"ui-tabs-collapsible",
value
),
value || !1 !== this.options.active || this._activate(
0
)),
"event" === key && this._setupEvents(
value
),
"heightStyle" === key && this._setupHeightStyle(
value
))
: this._setupDisabled(
value
)
: this._activate(
value
);
},
_tabId: function (
tab
) {
return tab.attr(
"aria-controls"
) || "ui-tabs-" + ++tabId;
},
_sanitizeSelector: function (
hash
) {
return hash
? hash.replace(
/[!"$%&'()*+,.\/:;<=>?@\[\]\^`{|}~]/g,
"\\$&"
)
: "";
},
refresh: function (
) {
var options = this.options,
lis = this.tablist.children(
":has(a[href])"
);
(options.disabled = $.map(
lis.filter(
".ui-state-disabled"
),
function (
tab
) {
return lis.index(
tab
);
},
)),
this._processTabs(
),
!1 !== options.active && this.anchors.length
? this.active.length &&
!$.contains(
this.tablist[0],
this.active[0]
)
? this.tabs.length === options.disabled.length
? ((options.active = !1), (this.active = $(
)))
: this._activate(
this._findNextTab(
Math.max(
0,
options.active - 1
),
!1
),
)
: (options.active = this.tabs.index(
this.active
))
: ((options.active = !1), (this.active = $(
))),
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 that = 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",
this
)[0];
}
)
.addClass(
"ui-tabs-anchor"
)
.attr(
{
role: "presentation",
tabIndex: -1,
}
)),
(this.panels = $(
)),
this.anchors.each(
function (
i, anchor
) {
var selector,
panel,
panelId,
anchorId = $(
anchor
).uniqueId(
).attr(
"id"
),
tab = $(
anchor
).closest(
"li"
),
originalAriaControls = tab.attr(
"aria-controls"
);
isLocal(
anchor
)
? ((selector = anchor.hash),
(panel = that.element.find(
that._sanitizeSelector(
selector
)
)))
: ((selector = "#" + (panelId = that._tabId(
tab
))),
(panel = that.element.find(
selector
)).length ||
(panel = that._createPanel(
panelId
)).insertAfter(
that.panels[i - 1] || that.tablist,
),
panel.attr(
"aria-live",
"polite"
)),
panel.length && (that.panels = that.panels.add(
panel
)),
originalAriaControls &&
tab.data(
"ui-tabs-aria-controls",
originalAriaControls
),
tab.attr(
{
"aria-controls": selector.substring(
1
),
"aria-labelledby": anchorId,
}
),
panel.attr(
"aria-labelledby",
anchorId
);
}
),
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 (
id
) {
return $(
"<div>"
)
.attr(
"id",
id
)
.addClass(
"ui-tabs-panel ui-widget-content ui-corner-bottom"
)
.data(
"ui-tabs-destroy",
!0
);
},
_setupDisabled: function (
disabled
) {
$.isArray(
disabled
) &&
(disabled.length
? disabled.length === this.anchors.length && (disabled = !0)
: (disabled = !1));
for (var li, i = 0; (li = this.tabs[i]); i++)
!0 === disabled || -1 !== $.inArray(
i,
disabled
)
? $(
li
)
.addClass(
"ui-state-disabled"
)
.attr(
"aria-disabled",
"true"
)
: $(
li
)
.removeClass(
"ui-state-disabled"
)
.removeAttr(
"aria-disabled"
);
this.options.disabled = disabled;
},
_setupEvents: function (
event
) {
var events = {
click: function (
event
) {
event.preventDefault(
);
},
};
event &&
$.each(
event.split(
" "
),
function (
index, eventName
) {
events[eventName] = "_eventHandler";
}
),
this._off(
this.anchors.add(
this.tabs
).add(
this.panels
)
),
this._on(
this.anchors,
events
),
this._on(
this.tabs,
{
keydown: "_tabKeydown",
}
),
this._on(
this.panels,
{
keydown: "_panelKeydown",
}
),
this._focusable(
this.tabs
),
this._hoverable(
this.tabs
);
},
_setupHeightStyle: function (
heightStyle
) {
var maxHeight,
parent = this.element.parent(
);
"fill" === heightStyle
? ((maxHeight = parent.height(
)),
(maxHeight -= this.element.outerHeight(
) - this.element.height(
)),
this.element.siblings(
":visible"
).each(
function (
) {
var elem = $(
this
),
position = elem.css(
"position"
);
"absolute" !== position &&
"fixed" !== position &&
(maxHeight -= elem.outerHeight(
!0
));
}
),
this.element
.children(
)
.not(
this.panels
)
.each(
function (
) {
maxHeight -= $(
this
).outerHeight(
!0
);
}
),
this.panels
.each(
function (
) {
$(
this
).height(
Math.max(
0,
maxHeight - $(
this
).innerHeight(
) + $(
this
).height(
),
),
);
}
)
.css(
"overflow",
"auto"
))
: "auto" === heightStyle &&
((maxHeight = 0),
this.panels
.each(
function (
) {
maxHeight = Math.max(
maxHeight,
$(
this
).height(
""
).height(
)
);
}
)
.height(
maxHeight
));
},
_eventHandler: function (
event
) {
var options = this.options,
active = this.active,
tab = $(
event.currentTarget
).closest(
"li"
),
clickedIsActive = tab[0] === active[0],
collapsing = clickedIsActive && options.collapsible,
toShow = collapsing
? $(
)
: this._getPanelForTab(
tab
),
toHide = active.length
? this._getPanelForTab(
active
)
: $(
),
eventData = {
oldTab: active,
oldPanel: toHide,
newTab: collapsing
? $(
)
: tab,
newPanel: toShow,
};
event.preventDefault(
),
tab.hasClass(
"ui-state-disabled"
) ||
tab.hasClass(
"ui-tabs-loading"
) ||
this.running ||
(clickedIsActive && !options.collapsible) ||
!1 === this._trigger(
"beforeActivate",
event,
eventData
) ||
((options.active = !collapsing && this.tabs.index(
tab
)),
(this.active = clickedIsActive
? $(
)
: tab),
this.xhr && this.xhr.abort(
),
toHide.length ||
toShow.length ||
$.error(
"jQuery UI Tabs: Mismatching fragment identifier."
),
toShow.length && this.load(
this.tabs.index(
tab
),
event
),
this._toggle(
event,
eventData
));
},
_toggle: function (
event, eventData
) {
var that = this,
toShow = eventData.newPanel,
toHide = eventData.oldPanel;
function complete(
) {
(that.running = !1), that._trigger(
"activate",
event,
eventData
);
}
function show(
) {
eventData.newTab
.closest(
"li"
)
.addClass(
"ui-tabs-active ui-state-active"
),
toShow.length && that.options.show
? that._show(
toShow,
that.options.show,
complete
)
: (toShow.show(
), complete(
));
}
(this.running = !0),
toHide.length && this.options.hide
? this._hide(
toHide,
this.options.hide,
function (
) {
eventData.oldTab
.closest(
"li"
)
.removeClass(
"ui-tabs-active ui-state-active"
),
show(
);
}
)
: (eventData.oldTab
.closest(
"li"
)
.removeClass(
"ui-tabs-active ui-state-active"
),
toHide.hide(
),
show(
)),
toHide.attr(
{
"aria-expanded": "false",
"aria-hidden": "true",
}
),
eventData.oldTab.attr(
"aria-selected",
"false"
),
toShow.length && toHide.length
? eventData.oldTab.attr(
"tabIndex",
-1
)
: toShow.length &&
this.tabs
.filter(
function (
) {
return 0 === $(
this
).attr(
"tabIndex"
);
}
)
.attr(
"tabIndex",
-1
),
toShow.attr(
{
"aria-expanded": "true",
"aria-hidden": "false",
}
),
eventData.newTab.attr(
{
"aria-selected": "true",
tabIndex: 0,
}
);
},
_activate: function (
index
) {
var anchor,
active = this._findActive(
index
);
active[0] !== this.active[0] &&
(active.length || (active = this.active),
(anchor = active.find(
".ui-tabs-anchor"
)[0]),
this._eventHandler(
{
target: anchor,
currentTarget: anchor,
preventDefault: $.noop,
}
));
},
_findActive: function (
index
) {
return !1 === index
? $(
)
: this.tabs.eq(
index
);
},
_getIndex: function (
index
) {
return (
"string" == typeof index &&
(index = this.anchors.index(
this.anchors.filter(
"[href$='" + index + "']"
),
)),
index
);
},
_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 (
) {
$.data(
this,
"ui-tabs-destroy"
)
? $(
this
).remove(
)
: $(
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 li = $(
this
),
prev = li.data(
"ui-tabs-aria-controls"
);
prev
? li
.attr(
"aria-controls",
prev
)
.removeData(
"ui-tabs-aria-controls"
)
: li.removeAttr(
"aria-controls"
);
}
),
this.panels.show(
),
"content" !== this.options.heightStyle &&
this.panels.css(
"height",
""
);
},
enable: function (
index
) {
var disabled = this.options.disabled;
!1 !== disabled &&
(undefined === index
? (disabled = !1)
: ((index = this._getIndex(
index
)),
(disabled = $.isArray(
disabled
)
? $.map(
disabled,
function (
num
) {
return num !== index ? num : null;
}
)
: $.map(
this.tabs,
function (
li, num
) {
return num !== index ? num : null;
}
))),
this._setupDisabled(
disabled
));
},
disable: function (
index
) {
var disabled = this.options.disabled;
if (!0 !== disabled) {
if (undefined === index) disabled = !0;
else {
if (
((index = this._getIndex(
index
)),
-1 !== $.inArray(
index,
disabled
))
)
return;
disabled = $.isArray(
disabled
)
? $.merge(
[index,],
disabled
).sort(
)
: [index,];
}
this._setupDisabled(
disabled
);
}
},
load: function (
index, event
) {
index = this._getIndex(
index
);
var that = this,
tab = this.tabs.eq(
index
),
anchor = tab.find(
".ui-tabs-anchor"
),
panel = this._getPanelForTab(
tab
),
eventData = {
tab: tab,
panel: panel,
};
isLocal(
anchor[0]
) ||
((this.xhr = $.ajax(
this._ajaxSettings(
anchor,
event,
eventData
)
)),
this.xhr &&
"canceled" !== this.xhr.statusText &&
(tab.addClass(
"ui-tabs-loading"
),
panel.attr(
"aria-busy",
"true"
),
this.xhr
.success(
function (
response
) {
setTimeout(
function (
) {
panel.html(
response
),
that._trigger(
"load",
event,
eventData
);
},
1
);
}
)
.complete(
function (
jqXHR, status
) {
setTimeout(
function (
) {
"abort" === status && that.panels.stop(
!1,
!0
),
tab.removeClass(
"ui-tabs-loading"
),
panel.removeAttr(
"aria-busy"
),
jqXHR === that.xhr && delete that.xhr;
},
1
);
}
)));
},
_ajaxSettings: function (
anchor, event, eventData
) {
var that = this;
return {
url: anchor.attr(
"href"
),
beforeSend: function (
jqXHR, settings
) {
return that._trigger(
"beforeLoad",
event,
$.extend(
{
jqXHR: jqXHR,
ajaxSettings: settings,
},
eventData
),
);
},
};
},
_getPanelForTab: function (
tab
) {
var id = $(
tab
).attr(
"aria-controls"
);
return this.element.find(
this._sanitizeSelector(
"#" + id
)
);
},
}
);
})(
jQuery
),
(function (
$, window
) {
$.mobile.iosorientationfixEnabled = !0;
var zoom,
evt,
x,
y,
z,
aig,
ua = navigator.userAgent;
function checkTilt(
e
) {
(evt = e.originalEvent),
(aig = evt.accelerationIncludingGravity),
(x = Math.abs(
aig.x
)),
(y = Math.abs(
aig.y
)),
(z = Math.abs(
aig.z
)),
!window.orientation &&
(x > 7 || (((z > 6 && y < 8) || (z < 8 && y > 6)) && x > 5))
? zoom.enabled && zoom.disable(
)
: zoom.enabled || zoom.enable(
);
}
/iPhone|iPad|iPod/.test(
navigator.platform
) &&
/OS [1-5]_[0-9_]* like Mac OS X/i.test(
ua
) &&
ua.indexOf(
"AppleWebKit"
) > -1
? ((zoom = $.mobile.zoom),
$.mobile.document.on(
"mobileinit",
function (
) {
$.mobile.iosorientationfixEnabled &&
$.mobile.window
.bind(
"orientationchange.iosorientationfix",
zoom.enable
)
.bind(
"devicemotion.iosorientationfix",
checkTilt
);
}
))
: ($.mobile.iosorientationfixEnabled = !1);
})(
jQuery,
this
),
(function (
$, window, undefined
) {
var $html = $(
"html"
),
$window = $.mobile.window;
function hideRenderingClass(
) {
$html.removeClass(
"ui-mobile-rendering"
);
}
$(
window.document
).trigger(
"mobileinit"
),
$.mobile.gradeA(
) &&
($.mobile.ajaxBlacklist && ($.mobile.ajaxEnabled = !1),
$html.addClass(
"ui-mobile ui-mobile-rendering"
),
setTimeout(
hideRenderingClass,
5e3
),
$.extend(
$.mobile,
{
initializePage: function (
) {
var path = $.mobile.path,
$pages = $(
":jqmData(role='page'), :jqmData(role='dialog')"
),
hash = path.stripHash(
path.stripQueryParams(
path.parseLocation(
).hash
),
),
hashPage = document.getElementById(
hash
);
$pages.length ||
($pages = $(
"body"
)
.wrapInner(
"<div data-" + $.mobile.ns + "role='page'></div>"
)
.children(
0
)),
$pages.each(
function (
) {
var $this = $(
this
);
$this[0].getAttribute(
"data-" + $.mobile.ns + "url"
) ||
$this.attr(
"data-" + $.mobile.ns + "url",
$this.attr(
"id"
) || location.pathname + location.search,
);
}
),
($.mobile.firstPage = $pages.first(
)),
($.mobile.pageContainer = $.mobile.firstPage
.parent(
)
.addClass(
"ui-mobile-viewport"
)
.pagecontainer(
)),
$.mobile.navreadyDeferred.resolve(
),
$window.trigger(
"pagecontainercreate"
),
$.mobile.loading(
"show"
),
hideRenderingClass(
),
$.mobile.hashListeningEnabled &&
$.mobile.path.isHashValid(
location.hash
) &&
($(
hashPage
).is(
":jqmData(role='page')"
) ||
$.mobile.path.isPath(
hash
) ||
hash === $.mobile.dialogHashKey)
? $.event.special.navigate.isPushStateEnabled(
)
? (($.mobile.navigate.history.stack = []),
$.mobile.navigate(
$.mobile.path.isPath(
location.hash
)
? location.hash
: location.href,
))
: $window.trigger(
"hashchange",
[!0,]
)
: ($.mobile.path.isHashValid(
location.hash
) &&
($.mobile.navigate.history.initialDst = hash.replace(
"#",
"",
)),
$.event.special.navigate.isPushStateEnabled(
) &&
$.mobile.navigate.navigator.squash(
path.parseLocation(
).href,
),
$.mobile.changePage(
$.mobile.firstPage,
{
transition: "none",
reverse: !0,
changeHash: !1,
fromHashChange: !0,
}
));
},
}
),
$(
function (
) {
$.support.inlineSVG(
),
$.mobile.hideUrlBar && window.scrollTo(
0,
1
),
($.mobile.defaultHomeScroll =
$.support.scrollTop && 1 !== $.mobile.window.scrollTop(
)
? 1
: 0),
$.mobile.autoInitializePage && $.mobile.initializePage(
),
$.mobile.hideUrlBar && $window.load(
$.mobile.silentScroll
),
$.support.cssPointerEvents ||
$.mobile.document.delegate(
".ui-state-disabled,.ui-disabled",
"vclick",
function (
e
) {
e.preventDefault(
), e.stopImmediatePropagation(
);
},
);
}
));
})(
jQuery,
this
);
}
);