Skip to content
GitLab
Explore
Projects
Groups
Snippets
Projects
Groups
Snippets
/
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Menu
Open sidebar
Bootstrap
bootstrap
Commits
4eaeea81
Commit
4eaeea81
authored
12 years ago
by
Jacob Thornton
Browse files
Options
Download
Email Patches
Plain Diff
rebuild and fix test
parent
bcd5097c
No related merge requests found
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
docs/assets/css/bootstrap.css
+4
-4
docs/assets/css/bootstrap.css
docs/assets/js/bootstrap-tooltip.js
+2
-2
docs/assets/js/bootstrap-tooltip.js
docs/assets/js/bootstrap.js
+3
-2
docs/assets/js/bootstrap.js
docs/assets/js/bootstrap.min.js
+1
-1
docs/assets/js/bootstrap.min.js
js/tests/unit/bootstrap-tooltip.js
+5
-5
js/tests/unit/bootstrap-tooltip.js
with
15 additions
and
14 deletions
+15
-14
docs/assets/css/bootstrap.css
+
4
-
4
View file @
4eaeea81
...
...
@@ -4674,15 +4674,15 @@ a.badge:hover {
-webkit-box-shadow
:
inset
0
-1px
0
rgba
(
0
,
0
,
0
,
0.15
);
-moz-box-shadow
:
inset
0
-1px
0
rgba
(
0
,
0
,
0
,
0.15
);
box-shadow
:
inset
0
-1px
0
rgba
(
0
,
0
,
0
,
0.15
);
-webkit-box-sizing
:
border-box
;
-moz-box-sizing
:
border-box
;
-ms-box-sizing
:
border-box
;
box-sizing
:
border-box
;
-webkit-transition
:
width
0.6s
ease
;
-moz-transition
:
width
0.6s
ease
;
-ms-transition
:
width
0.6s
ease
;
-o-transition
:
width
0.6s
ease
;
transition
:
width
0.6s
ease
;
-webkit-box-sizing
:
border-box
;
-moz-box-sizing
:
border-box
;
-ms-box-sizing
:
border-box
;
box-sizing
:
border-box
;
}
.progress-striped
.bar
{
...
...
This diff is collapsed.
Click to expand it.
docs/assets/js/bootstrap-tooltip.js
+
2
-
2
View file @
4eaeea81
...
...
@@ -84,9 +84,9 @@
,
leave
:
function
(
e
)
{
var
self
=
$
(
e
.
currentTarget
)[
this
.
type
](
this
.
_options
).
data
(
this
.
type
)
if
(
this
.
timeout
)
clearTimeout
(
this
.
timeout
)
if
(
!
self
.
options
.
delay
||
!
self
.
options
.
delay
.
hide
)
return
self
.
hide
()
clearTimeout
(
this
.
timeout
)
self
.
hoverState
=
'
out
'
this
.
timeout
=
setTimeout
(
function
()
{
if
(
self
.
hoverState
==
'
out
'
)
self
.
hide
()
...
...
@@ -272,4 +272,4 @@
,
delay
:
0
}
}(
window
.
jQuery
);
\ No newline at end of file
}(
window
.
jQuery
);
This diff is collapsed.
Click to expand it.
docs/assets/js/bootstrap.js
+
3
-
2
View file @
4eaeea81
...
...
@@ -968,9 +968,9 @@
,
leave
:
function
(
e
)
{
var
self
=
$
(
e
.
currentTarget
)[
this
.
type
](
this
.
_options
).
data
(
this
.
type
)
if
(
this
.
timeout
)
clearTimeout
(
this
.
timeout
)
if
(
!
self
.
options
.
delay
||
!
self
.
options
.
delay
.
hide
)
return
self
.
hide
()
clearTimeout
(
this
.
timeout
)
self
.
hoverState
=
'
out
'
this
.
timeout
=
setTimeout
(
function
()
{
if
(
self
.
hoverState
==
'
out
'
)
self
.
hide
()
...
...
@@ -1156,7 +1156,8 @@
,
delay
:
0
}
}(
window
.
jQuery
);
/* ===========================================================
}(
window
.
jQuery
);
/* ===========================================================
* bootstrap-popover.js v2.0.3
* http://twitter.github.com/bootstrap/javascript.html#popovers
* ===========================================================
...
...
This diff is collapsed.
Click to expand it.
docs/assets/js/bootstrap.min.js
+
1
-
1
View file @
4eaeea81
...
...
@@ -3,4 +3,4 @@
* Copyright 2012 Twitter, Inc.
* http://www.apache.org/licenses/LICENSE-2.0.txt
*/
!
function
(
a
){
a
(
function
(){
"
use strict
"
,
a
.
support
.
transition
=
function
(){
var
a
=
function
(){
var
a
=
document
.
createElement
(
"
bootstrap
"
),
b
=
{
WebkitTransition
:
"
webkitTransitionEnd
"
,
MozTransition
:
"
transitionend
"
,
OTransition
:
"
oTransitionEnd
"
,
msTransition
:
"
MSTransitionEnd
"
,
transition
:
"
transitionend
"
},
c
;
for
(
c
in
b
)
if
(
a
.
style
[
c
]
!==
undefined
)
return
b
[
c
]}();
return
a
&&
{
end
:
a
}}()})}(
window
.
jQuery
),
!
function
(
a
){
"
use strict
"
;
var
b
=
'
[data-dismiss="alert"]
'
,
c
=
function
(
c
){
a
(
c
).
on
(
"
click
"
,
b
,
this
.
close
)};
c
.
prototype
.
close
=
function
(
b
){
function
f
(){
e
.
trigger
(
"
closed
"
).
remove
()}
var
c
=
a
(
this
),
d
=
c
.
attr
(
"
data-target
"
),
e
;
d
||
(
d
=
c
.
attr
(
"
href
"
),
d
=
d
&&
d
.
replace
(
/.*
(?=
#
[^\s]
*$
)
/
,
""
)),
e
=
a
(
d
),
b
&&
b
.
preventDefault
(),
e
.
length
||
(
e
=
c
.
hasClass
(
"
alert
"
)?
c
:
c
.
parent
()),
e
.
trigger
(
b
=
a
.
Event
(
"
close
"
));
if
(
b
.
isDefaultPrevented
())
return
;
e
.
removeClass
(
"
in
"
),
a
.
support
.
transition
&&
e
.
hasClass
(
"
fade
"
)?
e
.
on
(
a
.
support
.
transition
.
end
,
f
):
f
()},
a
.
fn
.
alert
=
function
(
b
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
alert
"
);
e
||
d
.
data
(
"
alert
"
,
e
=
new
c
(
this
)),
typeof
b
==
"
string
"
&&
e
[
b
].
call
(
d
)})},
a
.
fn
.
alert
.
Constructor
=
c
,
a
(
function
(){
a
(
"
body
"
).
on
(
"
click.alert.data-api
"
,
b
,
c
.
prototype
.
close
)})}(
window
.
jQuery
),
!
function
(
a
){
"
use strict
"
;
var
b
=
function
(
b
,
c
){
this
.
$element
=
a
(
b
),
this
.
options
=
a
.
extend
({},
a
.
fn
.
button
.
defaults
,
c
)};
b
.
prototype
.
setState
=
function
(
a
){
var
b
=
"
disabled
"
,
c
=
this
.
$element
,
d
=
c
.
data
(),
e
=
c
.
is
(
"
input
"
)?
"
val
"
:
"
html
"
;
a
+=
"
Text
"
,
d
.
resetText
||
c
.
data
(
"
resetText
"
,
c
[
e
]()),
c
[
e
](
d
[
a
]
||
this
.
options
[
a
]),
setTimeout
(
function
(){
a
==
"
loadingText
"
?
c
.
addClass
(
b
).
attr
(
b
,
b
):
c
.
removeClass
(
b
).
removeAttr
(
b
)},
0
)},
b
.
prototype
.
toggle
=
function
(){
var
a
=
this
.
$element
.
parent
(
'
[data-toggle="buttons-radio"]
'
);
a
&&
a
.
find
(
"
.active
"
).
removeClass
(
"
active
"
),
this
.
$element
.
toggleClass
(
"
active
"
)},
a
.
fn
.
button
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
button
"
),
f
=
typeof
c
==
"
object
"
&&
c
;
e
||
d
.
data
(
"
button
"
,
e
=
new
b
(
this
,
f
)),
c
==
"
toggle
"
?
e
.
toggle
():
c
&&
e
.
setState
(
c
)})},
a
.
fn
.
button
.
defaults
=
{
loadingText
:
"
loading...
"
},
a
.
fn
.
button
.
Constructor
=
b
,
a
(
function
(){
a
(
"
body
"
).
on
(
"
click.button.data-api
"
,
"
[data-toggle^=button]
"
,
function
(
b
){
var
c
=
a
(
b
.
target
);
c
.
hasClass
(
"
btn
"
)
||
(
c
=
c
.
closest
(
"
.btn
"
)),
c
.
button
(
"
toggle
"
)})})}(
window
.
jQuery
),
!
function
(
a
){
"
use strict
"
;
var
b
=
function
(
b
,
c
){
this
.
$element
=
a
(
b
),
this
.
options
=
c
,
this
.
options
.
slide
&&
this
.
slide
(
this
.
options
.
slide
),
this
.
options
.
pause
==
"
hover
"
&&
this
.
$element
.
on
(
"
mouseenter
"
,
a
.
proxy
(
this
.
pause
,
this
)).
on
(
"
mouseleave
"
,
a
.
proxy
(
this
.
cycle
,
this
))};
b
.
prototype
=
{
cycle
:
function
(
b
){
return
b
||
(
this
.
paused
=!
1
),
this
.
options
.
interval
&&!
this
.
paused
&&
(
this
.
interval
=
setInterval
(
a
.
proxy
(
this
.
next
,
this
),
this
.
options
.
interval
)),
this
},
to
:
function
(
b
){
var
c
=
this
.
$element
.
find
(
"
.active
"
),
d
=
c
.
parent
().
children
(),
e
=
d
.
index
(
c
),
f
=
this
;
if
(
b
>
d
.
length
-
1
||
b
<
0
)
return
;
return
this
.
sliding
?
this
.
$element
.
one
(
"
slid
"
,
function
(){
f
.
to
(
b
)}):
e
==
b
?
this
.
pause
().
cycle
():
this
.
slide
(
b
>
e
?
"
next
"
:
"
prev
"
,
a
(
d
[
b
]))},
pause
:
function
(
a
){
return
a
||
(
this
.
paused
=!
0
),
clearInterval
(
this
.
interval
),
this
.
interval
=
null
,
this
},
next
:
function
(){
if
(
this
.
sliding
)
return
;
return
this
.
slide
(
"
next
"
)},
prev
:
function
(){
if
(
this
.
sliding
)
return
;
return
this
.
slide
(
"
prev
"
)},
slide
:
function
(
b
,
c
){
var
d
=
this
.
$element
.
find
(
"
.active
"
),
e
=
c
||
d
[
b
](),
f
=
this
.
interval
,
g
=
b
==
"
next
"
?
"
left
"
:
"
right
"
,
h
=
b
==
"
next
"
?
"
first
"
:
"
last
"
,
i
=
this
,
j
=
a
.
Event
(
"
slide
"
);
this
.
sliding
=!
0
,
f
&&
this
.
pause
(),
e
=
e
.
length
?
e
:
this
.
$element
.
find
(
"
.item
"
)[
h
]();
if
(
e
.
hasClass
(
"
active
"
))
return
;
if
(
a
.
support
.
transition
&&
this
.
$element
.
hasClass
(
"
slide
"
)){
this
.
$element
.
trigger
(
j
);
if
(
j
.
isDefaultPrevented
())
return
;
e
.
addClass
(
b
),
e
[
0
].
offsetWidth
,
d
.
addClass
(
g
),
e
.
addClass
(
g
),
this
.
$element
.
one
(
a
.
support
.
transition
.
end
,
function
(){
e
.
removeClass
([
b
,
g
].
join
(
"
"
)).
addClass
(
"
active
"
),
d
.
removeClass
([
"
active
"
,
g
].
join
(
"
"
)),
i
.
sliding
=!
1
,
setTimeout
(
function
(){
i
.
$element
.
trigger
(
"
slid
"
)},
0
)})}
else
{
this
.
$element
.
trigger
(
j
);
if
(
j
.
isDefaultPrevented
())
return
;
d
.
removeClass
(
"
active
"
),
e
.
addClass
(
"
active
"
),
this
.
sliding
=!
1
,
this
.
$element
.
trigger
(
"
slid
"
)}
return
f
&&
this
.
cycle
(),
this
}},
a
.
fn
.
carousel
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
carousel
"
),
f
=
a
.
extend
({},
a
.
fn
.
carousel
.
defaults
,
typeof
c
==
"
object
"
&&
c
);
e
||
d
.
data
(
"
carousel
"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"
number
"
?
e
.
to
(
c
):
typeof
c
==
"
string
"
||
(
c
=
f
.
slide
)?
e
[
c
]():
f
.
interval
&&
e
.
cycle
()})},
a
.
fn
.
carousel
.
defaults
=
{
interval
:
5
e3
,
pause
:
"
hover
"
},
a
.
fn
.
carousel
.
Constructor
=
b
,
a
(
function
(){
a
(
"
body
"
).
on
(
"
click.carousel.data-api
"
,
"
[data-slide]
"
,
function
(
b
){
var
c
=
a
(
this
),
d
,
e
=
a
(
c
.
attr
(
"
data-target
"
)
||
(
d
=
c
.
attr
(
"
href
"
))
&&
d
.
replace
(
/.*
(?=
#
[^\s]
+$
)
/
,
""
)),
f
=!
e
.
data
(
"
modal
"
)
&&
a
.
extend
({},
e
.
data
(),
c
.
data
());
e
.
carousel
(
f
),
b
.
preventDefault
()})})}(
window
.
jQuery
),
!
function
(
a
){
"
use strict
"
;
var
b
=
function
(
b
,
c
){
this
.
$element
=
a
(
b
),
this
.
options
=
a
.
extend
({},
a
.
fn
.
collapse
.
defaults
,
c
),
this
.
options
.
parent
&&
(
this
.
$parent
=
a
(
this
.
options
.
parent
)),
this
.
options
.
toggle
&&
this
.
toggle
()};
b
.
prototype
=
{
constructor
:
b
,
dimension
:
function
(){
var
a
=
this
.
$element
.
hasClass
(
"
width
"
);
return
a
?
"
width
"
:
"
height
"
},
show
:
function
(){
var
b
,
c
,
d
,
e
;
if
(
this
.
transitioning
)
return
;
b
=
this
.
dimension
(),
c
=
a
.
camelCase
([
"
scroll
"
,
b
].
join
(
"
-
"
)),
d
=
this
.
$parent
&&
this
.
$parent
.
find
(
"
> .accordion-group > .in
"
);
if
(
d
&&
d
.
length
){
e
=
d
.
data
(
"
collapse
"
);
if
(
e
&&
e
.
transitioning
)
return
;
d
.
collapse
(
"
hide
"
),
e
||
d
.
data
(
"
collapse
"
,
null
)}
this
.
$element
[
b
](
0
),
this
.
transition
(
"
addClass
"
,
a
.
Event
(
"
show
"
),
"
shown
"
),
this
.
$element
[
b
](
this
.
$element
[
0
][
c
])},
hide
:
function
(){
var
b
;
if
(
this
.
transitioning
)
return
;
b
=
this
.
dimension
(),
this
.
reset
(
this
.
$element
[
b
]()),
this
.
transition
(
"
removeClass
"
,
a
.
Event
(
"
hide
"
),
"
hidden
"
),
this
.
$element
[
b
](
0
)},
reset
:
function
(
a
){
var
b
=
this
.
dimension
();
return
this
.
$element
.
removeClass
(
"
collapse
"
)[
b
](
a
||
"
auto
"
)[
0
].
offsetWidth
,
this
.
$element
[
a
!==
null
?
"
addClass
"
:
"
removeClass
"
](
"
collapse
"
),
this
},
transition
:
function
(
b
,
c
,
d
){
var
e
=
this
,
f
=
function
(){
c
.
type
==
"
show
"
&&
e
.
reset
(),
e
.
transitioning
=
0
,
e
.
$element
.
trigger
(
d
)};
this
.
$element
.
trigger
(
c
);
if
(
c
.
isDefaultPrevented
())
return
;
this
.
transitioning
=
1
,
this
.
$element
[
b
](
"
in
"
),
a
.
support
.
transition
&&
this
.
$element
.
hasClass
(
"
collapse
"
)?
this
.
$element
.
one
(
a
.
support
.
transition
.
end
,
f
):
f
()},
toggle
:
function
(){
this
[
this
.
$element
.
hasClass
(
"
in
"
)?
"
hide
"
:
"
show
"
]()}},
a
.
fn
.
collapse
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
collapse
"
),
f
=
typeof
c
==
"
object
"
&&
c
;
e
||
d
.
data
(
"
collapse
"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"
string
"
&&
e
[
c
]()})},
a
.
fn
.
collapse
.
defaults
=
{
toggle
:
!
0
},
a
.
fn
.
collapse
.
Constructor
=
b
,
a
(
function
(){
a
(
"
body
"
).
on
(
"
click.collapse.data-api
"
,
"
[data-toggle=collapse]
"
,
function
(
b
){
var
c
=
a
(
this
),
d
,
e
=
c
.
attr
(
"
data-target
"
)
||
b
.
preventDefault
()
||
(
d
=
c
.
attr
(
"
href
"
))
&&
d
.
replace
(
/.*
(?=
#
[^\s]
+$
)
/
,
""
),
f
=
a
(
e
).
data
(
"
collapse
"
)?
"
toggle
"
:
c
.
data
();
a
(
e
).
collapse
(
f
)})})}(
window
.
jQuery
),
!
function
(
a
){
function
d
(){
a
(
b
).
parent
().
removeClass
(
"
open
"
)}
"
use strict
"
;
var
b
=
'
[data-toggle="dropdown"]
'
,
c
=
function
(
b
){
var
c
=
a
(
b
).
on
(
"
click.dropdown.data-api
"
,
this
.
toggle
);
a
(
"
html
"
).
on
(
"
click.dropdown.data-api
"
,
function
(){
c
.
parent
().
removeClass
(
"
open
"
)})};
c
.
prototype
=
{
constructor
:
c
,
toggle
:
function
(
b
){
var
c
=
a
(
this
),
e
,
f
,
g
;
if
(
c
.
is
(
"
.disabled, :disabled
"
))
return
;
return
f
=
c
.
attr
(
"
data-target
"
),
f
||
(
f
=
c
.
attr
(
"
href
"
),
f
=
f
&&
f
.
replace
(
/.*
(?=
#
[^\s]
*$
)
/
,
""
)),
e
=
a
(
f
),
e
.
length
||
(
e
=
c
.
parent
()),
g
=
e
.
hasClass
(
"
open
"
),
d
(),
g
||
e
.
toggleClass
(
"
open
"
),
!
1
}},
a
.
fn
.
dropdown
=
function
(
b
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
dropdown
"
);
e
||
d
.
data
(
"
dropdown
"
,
e
=
new
c
(
this
)),
typeof
b
==
"
string
"
&&
e
[
b
].
call
(
d
)})},
a
.
fn
.
dropdown
.
Constructor
=
c
,
a
(
function
(){
a
(
"
html
"
).
on
(
"
click.dropdown.data-api
"
,
d
),
a
(
"
body
"
).
on
(
"
click.dropdown
"
,
"
.dropdown form
"
,
function
(
a
){
a
.
stopPropagation
()}).
on
(
"
click.dropdown.data-api
"
,
b
,
c
.
prototype
.
toggle
)})}(
window
.
jQuery
),
!
function
(
a
){
function
c
(){
var
b
=
this
,
c
=
setTimeout
(
function
(){
b
.
$element
.
off
(
a
.
support
.
transition
.
end
),
d
.
call
(
b
)},
500
);
this
.
$element
.
one
(
a
.
support
.
transition
.
end
,
function
(){
clearTimeout
(
c
),
d
.
call
(
b
)})}
function
d
(
a
){
this
.
$element
.
hide
().
trigger
(
"
hidden
"
),
e
.
call
(
this
)}
function
e
(
b
){
var
c
=
this
,
d
=
this
.
$element
.
hasClass
(
"
fade
"
)?
"
fade
"
:
""
;
if
(
this
.
isShown
&&
this
.
options
.
backdrop
){
var
e
=
a
.
support
.
transition
&&
d
;
this
.
$backdrop
=
a
(
'
<div class="modal-backdrop
'
+
d
+
'
" />
'
).
appendTo
(
document
.
body
),
this
.
options
.
backdrop
!=
"
static
"
&&
this
.
$backdrop
.
click
(
a
.
proxy
(
this
.
hide
,
this
)),
e
&&
this
.
$backdrop
[
0
].
offsetWidth
,
this
.
$backdrop
.
addClass
(
"
in
"
),
e
?
this
.
$backdrop
.
one
(
a
.
support
.
transition
.
end
,
b
):
b
()}
else
!
this
.
isShown
&&
this
.
$backdrop
?(
this
.
$backdrop
.
removeClass
(
"
in
"
),
a
.
support
.
transition
&&
this
.
$element
.
hasClass
(
"
fade
"
)?
this
.
$backdrop
.
one
(
a
.
support
.
transition
.
end
,
a
.
proxy
(
f
,
this
)):
f
.
call
(
this
)):
b
&&
b
()}
function
f
(){
this
.
$backdrop
.
remove
(),
this
.
$backdrop
=
null
}
function
g
(){
var
b
=
this
;
this
.
isShown
&&
this
.
options
.
keyboard
?
a
(
document
).
on
(
"
keyup.dismiss.modal
"
,
function
(
a
){
a
.
which
==
27
&&
b
.
hide
()}):
this
.
isShown
||
a
(
document
).
off
(
"
keyup.dismiss.modal
"
)}
"
use strict
"
;
var
b
=
function
(
b
,
c
){
this
.
options
=
c
,
this
.
$element
=
a
(
b
).
delegate
(
'
[data-dismiss="modal"]
'
,
"
click.dismiss.modal
"
,
a
.
proxy
(
this
.
hide
,
this
))};
b
.
prototype
=
{
constructor
:
b
,
toggle
:
function
(){
return
this
[
this
.
isShown
?
"
hide
"
:
"
show
"
]()},
show
:
function
(){
var
b
=
this
,
c
=
a
.
Event
(
"
show
"
);
this
.
$element
.
trigger
(
c
);
if
(
this
.
isShown
||
c
.
isDefaultPrevented
())
return
;
a
(
"
body
"
).
addClass
(
"
modal-open
"
),
this
.
isShown
=!
0
,
g
.
call
(
this
),
e
.
call
(
this
,
function
(){
var
c
=
a
.
support
.
transition
&&
b
.
$element
.
hasClass
(
"
fade
"
);
b
.
$element
.
parent
().
length
||
b
.
$element
.
appendTo
(
document
.
body
),
b
.
$element
.
show
(),
c
&&
b
.
$element
[
0
].
offsetWidth
,
b
.
$element
.
addClass
(
"
in
"
),
c
?
b
.
$element
.
one
(
a
.
support
.
transition
.
end
,
function
(){
b
.
$element
.
trigger
(
"
shown
"
)}):
b
.
$element
.
trigger
(
"
shown
"
)})},
hide
:
function
(
b
){
b
&&
b
.
preventDefault
();
var
e
=
this
;
b
=
a
.
Event
(
"
hide
"
),
this
.
$element
.
trigger
(
b
);
if
(
!
this
.
isShown
||
b
.
isDefaultPrevented
())
return
;
this
.
isShown
=!
1
,
a
(
"
body
"
).
removeClass
(
"
modal-open
"
),
g
.
call
(
this
),
this
.
$element
.
removeClass
(
"
in
"
),
a
.
support
.
transition
&&
this
.
$element
.
hasClass
(
"
fade
"
)?
c
.
call
(
this
):
d
.
call
(
this
)}},
a
.
fn
.
modal
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
modal
"
),
f
=
a
.
extend
({},
a
.
fn
.
modal
.
defaults
,
d
.
data
(),
typeof
c
==
"
object
"
&&
c
);
e
||
d
.
data
(
"
modal
"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"
string
"
?
e
[
c
]():
f
.
show
&&
e
.
show
()})},
a
.
fn
.
modal
.
defaults
=
{
backdrop
:
!
0
,
keyboard
:
!
0
,
show
:
!
0
},
a
.
fn
.
modal
.
Constructor
=
b
,
a
(
function
(){
a
(
"
body
"
).
on
(
"
click.modal.data-api
"
,
'
[data-toggle="modal"]
'
,
function
(
b
){
var
c
=
a
(
this
),
d
,
e
=
a
(
c
.
attr
(
"
data-target
"
)
||
(
d
=
c
.
attr
(
"
href
"
))
&&
d
.
replace
(
/.*
(?=
#
[^\s]
+$
)
/
,
""
)),
f
=
e
.
data
(
"
modal
"
)?
"
toggle
"
:
a
.
extend
({},
e
.
data
(),
c
.
data
());
b
.
preventDefault
(),
e
.
modal
(
f
)})})}(
window
.
jQuery
),
!
function
(
a
){
"
use strict
"
;
var
b
=
function
(
a
,
b
){
this
.
init
(
"
tooltip
"
,
a
,
b
)};
b
.
prototype
=
{
constructor
:
b
,
init
:
function
(
b
,
c
,
d
){
var
e
,
f
;
this
.
type
=
b
,
this
.
$element
=
a
(
c
),
this
.
options
=
this
.
getOptions
(
d
),
this
.
enabled
=!
0
,
this
.
options
.
trigger
!=
"
manual
"
&&
(
e
=
this
.
options
.
trigger
==
"
hover
"
?
"
mouseenter
"
:
"
focus
"
,
f
=
this
.
options
.
trigger
==
"
hover
"
?
"
mouseleave
"
:
"
blur
"
,
this
.
$element
.
on
(
e
,
this
.
options
.
selector
,
a
.
proxy
(
this
.
enter
,
this
)),
this
.
$element
.
on
(
f
,
this
.
options
.
selector
,
a
.
proxy
(
this
.
leave
,
this
))),
this
.
options
.
selector
?
this
.
_options
=
a
.
extend
({},
this
.
options
,{
trigger
:
"
manual
"
,
selector
:
""
}):
this
.
fixTitle
()},
getOptions
:
function
(
b
){
return
b
=
a
.
extend
({},
a
.
fn
[
this
.
type
].
defaults
,
b
,
this
.
$element
.
data
()),
b
.
delay
&&
typeof
b
.
delay
==
"
number
"
&&
(
b
.
delay
=
{
show
:
b
.
delay
,
hide
:
b
.
delay
}),
b
},
enter
:
function
(
b
){
var
c
=
a
(
b
.
currentTarget
)[
this
.
type
](
this
.
_options
).
data
(
this
.
type
);
if
(
!
c
.
options
.
delay
||!
c
.
options
.
delay
.
show
)
return
c
.
show
();
clearTimeout
(
this
.
timeout
),
c
.
hoverState
=
"
in
"
,
this
.
timeout
=
setTimeout
(
function
(){
c
.
hoverState
==
"
in
"
&&
c
.
show
()},
c
.
options
.
delay
.
show
)},
leave
:
function
(
b
){
var
c
=
a
(
b
.
currentTarget
)[
this
.
type
](
this
.
_options
).
data
(
this
.
type
);
if
(
!
c
.
options
.
delay
||!
c
.
options
.
delay
.
hide
)
return
c
.
hide
();
clearTimeout
(
this
.
timeout
),
c
.
hoverState
=
"
out
"
,
this
.
timeout
=
setTimeout
(
function
(){
c
.
hoverState
==
"
out
"
&&
c
.
hide
()},
c
.
options
.
delay
.
hide
)},
show
:
function
(){
var
a
,
b
,
c
,
d
,
e
,
f
,
g
;
if
(
this
.
hasContent
()
&&
this
.
enabled
){
a
=
this
.
tip
(),
this
.
setContent
(),
this
.
options
.
animation
&&
a
.
addClass
(
"
fade
"
),
f
=
typeof
this
.
options
.
placement
==
"
function
"
?
this
.
options
.
placement
.
call
(
this
,
a
[
0
],
this
.
$element
[
0
]):
this
.
options
.
placement
,
b
=
/in/
.
test
(
f
),
a
.
remove
().
css
({
top
:
0
,
left
:
0
,
display
:
"
block
"
}).
appendTo
(
b
?
this
.
$element
:
document
.
body
),
c
=
this
.
getPosition
(
b
),
d
=
a
[
0
].
offsetWidth
,
e
=
a
[
0
].
offsetHeight
;
switch
(
b
?
f
.
split
(
"
"
)[
1
]:
f
){
case
"
bottom
"
:
g
=
{
top
:
c
.
top
+
c
.
height
,
left
:
c
.
left
+
c
.
width
/
2
-
d
/
2
};
break
;
case
"
top
"
:
g
=
{
top
:
c
.
top
-
e
,
left
:
c
.
left
+
c
.
width
/
2
-
d
/
2
};
break
;
case
"
left
"
:
g
=
{
top
:
c
.
top
+
c
.
height
/
2
-
e
/
2
,
left
:
c
.
left
-
d
};
break
;
case
"
right
"
:
g
=
{
top
:
c
.
top
+
c
.
height
/
2
-
e
/
2
,
left
:
c
.
left
+
c
.
width
}}
a
.
css
(
g
).
addClass
(
f
).
addClass
(
"
in
"
)}},
isHTML
:
function
(
a
){
return
typeof
a
!=
"
string
"
||
a
.
charAt
(
0
)
===
"
<
"
&&
a
.
charAt
(
a
.
length
-
1
)
===
"
>
"
&&
a
.
length
>=
3
||
/^
(?:[^
<
]
*<
[\w\W]
+>
[^
>
]
*$
)
/
.
exec
(
a
)},
setContent
:
function
(){
var
a
=
this
.
tip
(),
b
=
this
.
getTitle
();
a
.
find
(
"
.tooltip-inner
"
)[
this
.
isHTML
(
b
)?
"
html
"
:
"
text
"
](
b
),
a
.
removeClass
(
"
fade in top bottom left right
"
)},
hide
:
function
(){
function
d
(){
var
b
=
setTimeout
(
function
(){
c
.
off
(
a
.
support
.
transition
.
end
).
remove
()},
500
);
c
.
one
(
a
.
support
.
transition
.
end
,
function
(){
clearTimeout
(
b
),
c
.
remove
()})}
var
b
=
this
,
c
=
this
.
tip
();
c
.
removeClass
(
"
in
"
),
a
.
support
.
transition
&&
this
.
$tip
.
hasClass
(
"
fade
"
)?
d
():
c
.
remove
()},
fixTitle
:
function
(){
var
a
=
this
.
$element
;(
a
.
attr
(
"
title
"
)
||
typeof
a
.
attr
(
"
data-original-title
"
)
!=
"
string
"
)
&&
a
.
attr
(
"
data-original-title
"
,
a
.
attr
(
"
title
"
)
||
""
).
removeAttr
(
"
title
"
)},
hasContent
:
function
(){
return
this
.
getTitle
()},
getPosition
:
function
(
b
){
return
a
.
extend
({},
b
?{
top
:
0
,
left
:
0
}:
this
.
$element
.
offset
(),{
width
:
this
.
$element
[
0
].
offsetWidth
,
height
:
this
.
$element
[
0
].
offsetHeight
})},
getTitle
:
function
(){
var
a
,
b
=
this
.
$element
,
c
=
this
.
options
;
return
a
=
b
.
attr
(
"
data-original-title
"
)
||
(
typeof
c
.
title
==
"
function
"
?
c
.
title
.
call
(
b
[
0
]):
c
.
title
),
a
},
tip
:
function
(){
return
this
.
$tip
=
this
.
$tip
||
a
(
this
.
options
.
template
)},
validate
:
function
(){
this
.
$element
[
0
].
parentNode
||
(
this
.
hide
(),
this
.
$element
=
null
,
this
.
options
=
null
)},
enable
:
function
(){
this
.
enabled
=!
0
},
disable
:
function
(){
this
.
enabled
=!
1
},
toggleEnabled
:
function
(){
this
.
enabled
=!
this
.
enabled
},
toggle
:
function
(){
this
[
this
.
tip
().
hasClass
(
"
in
"
)?
"
hide
"
:
"
show
"
]()}},
a
.
fn
.
tooltip
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
tooltip
"
),
f
=
typeof
c
==
"
object
"
&&
c
;
e
||
d
.
data
(
"
tooltip
"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"
string
"
&&
e
[
c
]()})},
a
.
fn
.
tooltip
.
Constructor
=
b
,
a
.
fn
.
tooltip
.
defaults
=
{
animation
:
!
0
,
placement
:
"
top
"
,
selector
:
!
1
,
template
:
'
<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>
'
,
trigger
:
"
hover
"
,
title
:
""
,
delay
:
0
}}(
window
.
jQuery
),
!
function
(
a
){
"
use strict
"
;
var
b
=
function
(
a
,
b
){
this
.
init
(
"
popover
"
,
a
,
b
)};
b
.
prototype
=
a
.
extend
({},
a
.
fn
.
tooltip
.
Constructor
.
prototype
,{
constructor
:
b
,
setContent
:
function
(){
var
a
=
this
.
tip
(),
b
=
this
.
getTitle
(),
c
=
this
.
getContent
();
a
.
find
(
"
.popover-title
"
)[
this
.
isHTML
(
b
)?
"
html
"
:
"
text
"
](
b
),
a
.
find
(
"
.popover-content > *
"
)[
this
.
isHTML
(
c
)?
"
html
"
:
"
text
"
](
c
),
a
.
removeClass
(
"
fade top bottom left right in
"
)},
hasContent
:
function
(){
return
this
.
getTitle
()
||
this
.
getContent
()},
getContent
:
function
(){
var
a
,
b
=
this
.
$element
,
c
=
this
.
options
;
return
a
=
b
.
attr
(
"
data-content
"
)
||
(
typeof
c
.
content
==
"
function
"
?
c
.
content
.
call
(
b
[
0
]):
c
.
content
),
a
},
tip
:
function
(){
return
this
.
$tip
||
(
this
.
$tip
=
a
(
this
.
options
.
template
)),
this
.
$tip
}}),
a
.
fn
.
popover
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
popover
"
),
f
=
typeof
c
==
"
object
"
&&
c
;
e
||
d
.
data
(
"
popover
"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"
string
"
&&
e
[
c
]()})},
a
.
fn
.
popover
.
Constructor
=
b
,
a
.
fn
.
popover
.
defaults
=
a
.
extend
({},
a
.
fn
.
tooltip
.
defaults
,{
placement
:
"
right
"
,
content
:
""
,
template
:
'
<div class="popover"><div class="arrow"></div><div class="popover-inner"><h3 class="popover-title"></h3><div class="popover-content"><p></p></div></div></div>
'
})}(
window
.
jQuery
),
!
function
(
a
){
function
b
(
b
,
c
){
var
d
=
a
.
proxy
(
this
.
process
,
this
),
e
=
a
(
b
).
is
(
"
body
"
)?
a
(
window
):
a
(
b
),
f
;
this
.
options
=
a
.
extend
({},
a
.
fn
.
scrollspy
.
defaults
,
c
),
this
.
$scrollElement
=
e
.
on
(
"
scroll.scroll.data-api
"
,
d
),
this
.
selector
=
(
this
.
options
.
target
||
(
f
=
a
(
b
).
attr
(
"
href
"
))
&&
f
.
replace
(
/.*
(?=
#
[^\s]
+$
)
/
,
""
)
||
""
)
+
"
.nav li > a
"
,
this
.
$body
=
a
(
"
body
"
),
this
.
refresh
(),
this
.
process
()}
"
use strict
"
,
b
.
prototype
=
{
constructor
:
b
,
refresh
:
function
(){
var
b
=
this
,
c
;
this
.
offsets
=
a
([]),
this
.
targets
=
a
([]),
c
=
this
.
$body
.
find
(
this
.
selector
).
map
(
function
(){
var
b
=
a
(
this
),
c
=
b
.
data
(
"
target
"
)
||
b
.
attr
(
"
href
"
),
d
=
/^#
\w
/
.
test
(
c
)
&&
a
(
c
);
return
d
&&
c
.
length
&&
[[
d
.
position
().
top
,
c
]]
||
null
}).
sort
(
function
(
a
,
b
){
return
a
[
0
]
-
b
[
0
]}).
each
(
function
(){
b
.
offsets
.
push
(
this
[
0
]),
b
.
targets
.
push
(
this
[
1
])})},
process
:
function
(){
var
a
=
this
.
$scrollElement
.
scrollTop
()
+
this
.
options
.
offset
,
b
=
this
.
$scrollElement
[
0
].
scrollHeight
||
this
.
$body
[
0
].
scrollHeight
,
c
=
b
-
this
.
$scrollElement
.
height
(),
d
=
this
.
offsets
,
e
=
this
.
targets
,
f
=
this
.
activeTarget
,
g
;
if
(
a
>=
c
)
return
f
!=
(
g
=
e
.
last
()[
0
])
&&
this
.
activate
(
g
);
for
(
g
=
d
.
length
;
g
--
;)
f
!=
e
[
g
]
&&
a
>=
d
[
g
]
&&
(
!
d
[
g
+
1
]
||
a
<=
d
[
g
+
1
])
&&
this
.
activate
(
e
[
g
])},
activate
:
function
(
b
){
var
c
,
d
;
this
.
activeTarget
=
b
,
a
(
this
.
selector
).
parent
(
"
.active
"
).
removeClass
(
"
active
"
),
d
=
this
.
selector
+
'
[data-target="
'
+
b
+
'
"],
'
+
this
.
selector
+
'
[href="
'
+
b
+
'
"]
'
,
c
=
a
(
d
).
parent
(
"
li
"
).
addClass
(
"
active
"
),
c
.
parent
(
"
.dropdown-menu
"
)
&&
(
c
=
c
.
closest
(
"
li.dropdown
"
).
addClass
(
"
active
"
)),
c
.
trigger
(
"
activate
"
)}},
a
.
fn
.
scrollspy
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
scrollspy
"
),
f
=
typeof
c
==
"
object
"
&&
c
;
e
||
d
.
data
(
"
scrollspy
"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"
string
"
&&
e
[
c
]()})},
a
.
fn
.
scrollspy
.
Constructor
=
b
,
a
.
fn
.
scrollspy
.
defaults
=
{
offset
:
10
},
a
(
function
(){
a
(
'
[data-spy="scroll"]
'
).
each
(
function
(){
var
b
=
a
(
this
);
b
.
scrollspy
(
b
.
data
())})})}(
window
.
jQuery
),
!
function
(
a
){
"
use strict
"
;
var
b
=
function
(
b
){
this
.
element
=
a
(
b
)};
b
.
prototype
=
{
constructor
:
b
,
show
:
function
(){
var
b
=
this
.
element
,
c
=
b
.
closest
(
"
ul:not(.dropdown-menu)
"
),
d
=
b
.
attr
(
"
data-target
"
),
e
,
f
,
g
;
d
||
(
d
=
b
.
attr
(
"
href
"
),
d
=
d
&&
d
.
replace
(
/.*
(?=
#
[^\s]
*$
)
/
,
""
));
if
(
b
.
parent
(
"
li
"
).
hasClass
(
"
active
"
))
return
;
e
=
c
.
find
(
"
.active a
"
).
last
()[
0
],
g
=
a
.
Event
(
"
show
"
,{
relatedTarget
:
e
}),
b
.
trigger
(
g
);
if
(
g
.
isDefaultPrevented
())
return
;
f
=
a
(
d
),
this
.
activate
(
b
.
parent
(
"
li
"
),
c
),
this
.
activate
(
f
,
f
.
parent
(),
function
(){
b
.
trigger
({
type
:
"
shown
"
,
relatedTarget
:
e
})})},
activate
:
function
(
b
,
c
,
d
){
function
g
(){
e
.
removeClass
(
"
active
"
).
find
(
"
> .dropdown-menu > .active
"
).
removeClass
(
"
active
"
),
b
.
addClass
(
"
active
"
),
f
?(
b
[
0
].
offsetWidth
,
b
.
addClass
(
"
in
"
)):
b
.
removeClass
(
"
fade
"
),
b
.
parent
(
"
.dropdown-menu
"
)
&&
b
.
closest
(
"
li.dropdown
"
).
addClass
(
"
active
"
),
d
&&
d
()}
var
e
=
c
.
find
(
"
> .active
"
),
f
=
d
&&
a
.
support
.
transition
&&
e
.
hasClass
(
"
fade
"
);
f
?
e
.
one
(
a
.
support
.
transition
.
end
,
g
):
g
(),
e
.
removeClass
(
"
in
"
)}},
a
.
fn
.
tab
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
tab
"
);
e
||
d
.
data
(
"
tab
"
,
e
=
new
b
(
this
)),
typeof
c
==
"
string
"
&&
e
[
c
]()})},
a
.
fn
.
tab
.
Constructor
=
b
,
a
(
function
(){
a
(
"
body
"
).
on
(
"
click.tab.data-api
"
,
'
[data-toggle="tab"], [data-toggle="pill"]
'
,
function
(
b
){
b
.
preventDefault
(),
a
(
this
).
tab
(
"
show
"
)})})}(
window
.
jQuery
),
!
function
(
a
){
"
use strict
"
;
var
b
=
function
(
b
,
c
){
this
.
$element
=
a
(
b
),
this
.
options
=
a
.
extend
({},
a
.
fn
.
typeahead
.
defaults
,
c
),
this
.
matcher
=
this
.
options
.
matcher
||
this
.
matcher
,
this
.
sorter
=
this
.
options
.
sorter
||
this
.
sorter
,
this
.
highlighter
=
this
.
options
.
highlighter
||
this
.
highlighter
,
this
.
updater
=
this
.
options
.
updater
||
this
.
updater
,
this
.
$menu
=
a
(
this
.
options
.
menu
).
appendTo
(
"
body
"
),
this
.
source
=
this
.
options
.
source
,
this
.
shown
=!
1
,
this
.
listen
()};
b
.
prototype
=
{
constructor
:
b
,
select
:
function
(){
var
a
=
this
.
$menu
.
find
(
"
.active
"
).
attr
(
"
data-value
"
);
return
this
.
$element
.
val
(
this
.
updater
(
a
)).
change
(),
this
.
hide
()},
updater
:
function
(
a
){
return
a
},
show
:
function
(){
var
b
=
a
.
extend
({},
this
.
$element
.
offset
(),{
height
:
this
.
$element
[
0
].
offsetHeight
});
return
this
.
$menu
.
css
({
top
:
b
.
top
+
b
.
height
,
left
:
b
.
left
}),
this
.
$menu
.
show
(),
this
.
shown
=!
0
,
this
},
hide
:
function
(){
return
this
.
$menu
.
hide
(),
this
.
shown
=!
1
,
this
},
lookup
:
function
(
b
){
var
c
=
this
,
d
,
e
;
return
this
.
query
=
this
.
$element
.
val
(),
this
.
query
?(
d
=
a
.
grep
(
this
.
source
,
function
(
a
){
return
c
.
matcher
(
a
)}),
d
=
this
.
sorter
(
d
),
d
.
length
?
this
.
render
(
d
.
slice
(
0
,
this
.
options
.
items
)).
show
():
this
.
shown
?
this
.
hide
():
this
):
this
.
shown
?
this
.
hide
():
this
},
matcher
:
function
(
a
){
return
~
a
.
toLowerCase
().
indexOf
(
this
.
query
.
toLowerCase
())},
sorter
:
function
(
a
){
var
b
=
[],
c
=
[],
d
=
[],
e
;
while
(
e
=
a
.
shift
())
e
.
toLowerCase
().
indexOf
(
this
.
query
.
toLowerCase
())?
~
e
.
indexOf
(
this
.
query
)?
c
.
push
(
e
):
d
.
push
(
e
):
b
.
push
(
e
);
return
b
.
concat
(
c
,
d
)},
highlighter
:
function
(
a
){
var
b
=
this
.
query
.
replace
(
/
[\-\[\]
{}()*+?.,
\\\^
$|#
\s]
/g
,
"
\\
$&
"
);
return
a
.
replace
(
new
RegExp
(
"
(
"
+
b
+
"
)
"
,
"
ig
"
),
function
(
a
,
b
){
return
"
<strong>
"
+
b
+
"
</strong>
"
})},
render
:
function
(
b
){
var
c
=
this
;
return
b
=
a
(
b
).
map
(
function
(
b
,
d
){
return
b
=
a
(
c
.
options
.
item
).
attr
(
"
data-value
"
,
d
),
b
.
find
(
"
a
"
).
html
(
c
.
highlighter
(
d
)),
b
[
0
]}),
b
.
first
().
addClass
(
"
active
"
),
this
.
$menu
.
html
(
b
),
this
},
next
:
function
(
b
){
var
c
=
this
.
$menu
.
find
(
"
.active
"
).
removeClass
(
"
active
"
),
d
=
c
.
next
();
d
.
length
||
(
d
=
a
(
this
.
$menu
.
find
(
"
li
"
)[
0
])),
d
.
addClass
(
"
active
"
)},
prev
:
function
(
a
){
var
b
=
this
.
$menu
.
find
(
"
.active
"
).
removeClass
(
"
active
"
),
c
=
b
.
prev
();
c
.
length
||
(
c
=
this
.
$menu
.
find
(
"
li
"
).
last
()),
c
.
addClass
(
"
active
"
)},
listen
:
function
(){
this
.
$element
.
on
(
"
blur
"
,
a
.
proxy
(
this
.
blur
,
this
)).
on
(
"
keypress
"
,
a
.
proxy
(
this
.
keypress
,
this
)).
on
(
"
keyup
"
,
a
.
proxy
(
this
.
keyup
,
this
)),(
a
.
browser
.
webkit
||
a
.
browser
.
msie
)
&&
this
.
$element
.
on
(
"
keydown
"
,
a
.
proxy
(
this
.
keypress
,
this
)),
this
.
$menu
.
on
(
"
click
"
,
a
.
proxy
(
this
.
click
,
this
)).
on
(
"
mouseenter
"
,
"
li
"
,
a
.
proxy
(
this
.
mouseenter
,
this
))},
keyup
:
function
(
a
){
switch
(
a
.
keyCode
){
case
40
:
case
38
:
break
;
case
9
:
case
13
:
if
(
!
this
.
shown
)
return
;
this
.
select
();
break
;
case
27
:
if
(
!
this
.
shown
)
return
;
this
.
hide
();
break
;
default
:
this
.
lookup
()}
a
.
stopPropagation
(),
a
.
preventDefault
()},
keypress
:
function
(
a
){
if
(
!
this
.
shown
)
return
;
switch
(
a
.
keyCode
){
case
9
:
case
13
:
case
27
:
a
.
preventDefault
();
break
;
case
38
:
if
(
a
.
type
!=
"
keydown
"
)
break
;
a
.
preventDefault
(),
this
.
prev
();
break
;
case
40
:
if
(
a
.
type
!=
"
keydown
"
)
break
;
a
.
preventDefault
(),
this
.
next
()}
a
.
stopPropagation
()},
blur
:
function
(
a
){
var
b
=
this
;
setTimeout
(
function
(){
b
.
hide
()},
150
)},
click
:
function
(
a
){
a
.
stopPropagation
(),
a
.
preventDefault
(),
this
.
select
()},
mouseenter
:
function
(
b
){
this
.
$menu
.
find
(
"
.active
"
).
removeClass
(
"
active
"
),
a
(
b
.
currentTarget
).
addClass
(
"
active
"
)}},
a
.
fn
.
typeahead
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
typeahead
"
),
f
=
typeof
c
==
"
object
"
&&
c
;
e
||
d
.
data
(
"
typeahead
"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"
string
"
&&
e
[
c
]()})},
a
.
fn
.
typeahead
.
defaults
=
{
source
:[],
items
:
8
,
menu
:
'
<ul class="typeahead dropdown-menu"></ul>
'
,
item
:
'
<li><a href="#"></a></li>
'
},
a
.
fn
.
typeahead
.
Constructor
=
b
,
a
(
function
(){
a
(
"
body
"
).
on
(
"
focus.typeahead.data-api
"
,
'
[data-provide="typeahead"]
'
,
function
(
b
){
var
c
=
a
(
this
);
if
(
c
.
data
(
"
typeahead
"
))
return
;
b
.
preventDefault
(),
c
.
typeahead
(
c
.
data
())})})}(
window
.
jQuery
);
\ No newline at end of file
!
function
(
a
){
a
(
function
(){
"
use strict
"
,
a
.
support
.
transition
=
function
(){
var
a
=
function
(){
var
a
=
document
.
createElement
(
"
bootstrap
"
),
b
=
{
WebkitTransition
:
"
webkitTransitionEnd
"
,
MozTransition
:
"
transitionend
"
,
OTransition
:
"
oTransitionEnd
"
,
msTransition
:
"
MSTransitionEnd
"
,
transition
:
"
transitionend
"
},
c
;
for
(
c
in
b
)
if
(
a
.
style
[
c
]
!==
undefined
)
return
b
[
c
]}();
return
a
&&
{
end
:
a
}}()})}(
window
.
jQuery
),
!
function
(
a
){
"
use strict
"
;
var
b
=
'
[data-dismiss="alert"]
'
,
c
=
function
(
c
){
a
(
c
).
on
(
"
click
"
,
b
,
this
.
close
)};
c
.
prototype
.
close
=
function
(
b
){
function
f
(){
e
.
trigger
(
"
closed
"
).
remove
()}
var
c
=
a
(
this
),
d
=
c
.
attr
(
"
data-target
"
),
e
;
d
||
(
d
=
c
.
attr
(
"
href
"
),
d
=
d
&&
d
.
replace
(
/.*
(?=
#
[^\s]
*$
)
/
,
""
)),
e
=
a
(
d
),
b
&&
b
.
preventDefault
(),
e
.
length
||
(
e
=
c
.
hasClass
(
"
alert
"
)?
c
:
c
.
parent
()),
e
.
trigger
(
b
=
a
.
Event
(
"
close
"
));
if
(
b
.
isDefaultPrevented
())
return
;
e
.
removeClass
(
"
in
"
),
a
.
support
.
transition
&&
e
.
hasClass
(
"
fade
"
)?
e
.
on
(
a
.
support
.
transition
.
end
,
f
):
f
()},
a
.
fn
.
alert
=
function
(
b
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
alert
"
);
e
||
d
.
data
(
"
alert
"
,
e
=
new
c
(
this
)),
typeof
b
==
"
string
"
&&
e
[
b
].
call
(
d
)})},
a
.
fn
.
alert
.
Constructor
=
c
,
a
(
function
(){
a
(
"
body
"
).
on
(
"
click.alert.data-api
"
,
b
,
c
.
prototype
.
close
)})}(
window
.
jQuery
),
!
function
(
a
){
"
use strict
"
;
var
b
=
function
(
b
,
c
){
this
.
$element
=
a
(
b
),
this
.
options
=
a
.
extend
({},
a
.
fn
.
button
.
defaults
,
c
)};
b
.
prototype
.
setState
=
function
(
a
){
var
b
=
"
disabled
"
,
c
=
this
.
$element
,
d
=
c
.
data
(),
e
=
c
.
is
(
"
input
"
)?
"
val
"
:
"
html
"
;
a
+=
"
Text
"
,
d
.
resetText
||
c
.
data
(
"
resetText
"
,
c
[
e
]()),
c
[
e
](
d
[
a
]
||
this
.
options
[
a
]),
setTimeout
(
function
(){
a
==
"
loadingText
"
?
c
.
addClass
(
b
).
attr
(
b
,
b
):
c
.
removeClass
(
b
).
removeAttr
(
b
)},
0
)},
b
.
prototype
.
toggle
=
function
(){
var
a
=
this
.
$element
.
parent
(
'
[data-toggle="buttons-radio"]
'
);
a
&&
a
.
find
(
"
.active
"
).
removeClass
(
"
active
"
),
this
.
$element
.
toggleClass
(
"
active
"
)},
a
.
fn
.
button
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
button
"
),
f
=
typeof
c
==
"
object
"
&&
c
;
e
||
d
.
data
(
"
button
"
,
e
=
new
b
(
this
,
f
)),
c
==
"
toggle
"
?
e
.
toggle
():
c
&&
e
.
setState
(
c
)})},
a
.
fn
.
button
.
defaults
=
{
loadingText
:
"
loading...
"
},
a
.
fn
.
button
.
Constructor
=
b
,
a
(
function
(){
a
(
"
body
"
).
on
(
"
click.button.data-api
"
,
"
[data-toggle^=button]
"
,
function
(
b
){
var
c
=
a
(
b
.
target
);
c
.
hasClass
(
"
btn
"
)
||
(
c
=
c
.
closest
(
"
.btn
"
)),
c
.
button
(
"
toggle
"
)})})}(
window
.
jQuery
),
!
function
(
a
){
"
use strict
"
;
var
b
=
function
(
b
,
c
){
this
.
$element
=
a
(
b
),
this
.
options
=
c
,
this
.
options
.
slide
&&
this
.
slide
(
this
.
options
.
slide
),
this
.
options
.
pause
==
"
hover
"
&&
this
.
$element
.
on
(
"
mouseenter
"
,
a
.
proxy
(
this
.
pause
,
this
)).
on
(
"
mouseleave
"
,
a
.
proxy
(
this
.
cycle
,
this
))};
b
.
prototype
=
{
cycle
:
function
(
b
){
return
b
||
(
this
.
paused
=!
1
),
this
.
options
.
interval
&&!
this
.
paused
&&
(
this
.
interval
=
setInterval
(
a
.
proxy
(
this
.
next
,
this
),
this
.
options
.
interval
)),
this
},
to
:
function
(
b
){
var
c
=
this
.
$element
.
find
(
"
.active
"
),
d
=
c
.
parent
().
children
(),
e
=
d
.
index
(
c
),
f
=
this
;
if
(
b
>
d
.
length
-
1
||
b
<
0
)
return
;
return
this
.
sliding
?
this
.
$element
.
one
(
"
slid
"
,
function
(){
f
.
to
(
b
)}):
e
==
b
?
this
.
pause
().
cycle
():
this
.
slide
(
b
>
e
?
"
next
"
:
"
prev
"
,
a
(
d
[
b
]))},
pause
:
function
(
a
){
return
a
||
(
this
.
paused
=!
0
),
clearInterval
(
this
.
interval
),
this
.
interval
=
null
,
this
},
next
:
function
(){
if
(
this
.
sliding
)
return
;
return
this
.
slide
(
"
next
"
)},
prev
:
function
(){
if
(
this
.
sliding
)
return
;
return
this
.
slide
(
"
prev
"
)},
slide
:
function
(
b
,
c
){
var
d
=
this
.
$element
.
find
(
"
.active
"
),
e
=
c
||
d
[
b
](),
f
=
this
.
interval
,
g
=
b
==
"
next
"
?
"
left
"
:
"
right
"
,
h
=
b
==
"
next
"
?
"
first
"
:
"
last
"
,
i
=
this
,
j
=
a
.
Event
(
"
slide
"
);
this
.
sliding
=!
0
,
f
&&
this
.
pause
(),
e
=
e
.
length
?
e
:
this
.
$element
.
find
(
"
.item
"
)[
h
]();
if
(
e
.
hasClass
(
"
active
"
))
return
;
if
(
a
.
support
.
transition
&&
this
.
$element
.
hasClass
(
"
slide
"
)){
this
.
$element
.
trigger
(
j
);
if
(
j
.
isDefaultPrevented
())
return
;
e
.
addClass
(
b
),
e
[
0
].
offsetWidth
,
d
.
addClass
(
g
),
e
.
addClass
(
g
),
this
.
$element
.
one
(
a
.
support
.
transition
.
end
,
function
(){
e
.
removeClass
([
b
,
g
].
join
(
"
"
)).
addClass
(
"
active
"
),
d
.
removeClass
([
"
active
"
,
g
].
join
(
"
"
)),
i
.
sliding
=!
1
,
setTimeout
(
function
(){
i
.
$element
.
trigger
(
"
slid
"
)},
0
)})}
else
{
this
.
$element
.
trigger
(
j
);
if
(
j
.
isDefaultPrevented
())
return
;
d
.
removeClass
(
"
active
"
),
e
.
addClass
(
"
active
"
),
this
.
sliding
=!
1
,
this
.
$element
.
trigger
(
"
slid
"
)}
return
f
&&
this
.
cycle
(),
this
}},
a
.
fn
.
carousel
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
carousel
"
),
f
=
a
.
extend
({},
a
.
fn
.
carousel
.
defaults
,
typeof
c
==
"
object
"
&&
c
);
e
||
d
.
data
(
"
carousel
"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"
number
"
?
e
.
to
(
c
):
typeof
c
==
"
string
"
||
(
c
=
f
.
slide
)?
e
[
c
]():
f
.
interval
&&
e
.
cycle
()})},
a
.
fn
.
carousel
.
defaults
=
{
interval
:
5
e3
,
pause
:
"
hover
"
},
a
.
fn
.
carousel
.
Constructor
=
b
,
a
(
function
(){
a
(
"
body
"
).
on
(
"
click.carousel.data-api
"
,
"
[data-slide]
"
,
function
(
b
){
var
c
=
a
(
this
),
d
,
e
=
a
(
c
.
attr
(
"
data-target
"
)
||
(
d
=
c
.
attr
(
"
href
"
))
&&
d
.
replace
(
/.*
(?=
#
[^\s]
+$
)
/
,
""
)),
f
=!
e
.
data
(
"
modal
"
)
&&
a
.
extend
({},
e
.
data
(),
c
.
data
());
e
.
carousel
(
f
),
b
.
preventDefault
()})})}(
window
.
jQuery
),
!
function
(
a
){
"
use strict
"
;
var
b
=
function
(
b
,
c
){
this
.
$element
=
a
(
b
),
this
.
options
=
a
.
extend
({},
a
.
fn
.
collapse
.
defaults
,
c
),
this
.
options
.
parent
&&
(
this
.
$parent
=
a
(
this
.
options
.
parent
)),
this
.
options
.
toggle
&&
this
.
toggle
()};
b
.
prototype
=
{
constructor
:
b
,
dimension
:
function
(){
var
a
=
this
.
$element
.
hasClass
(
"
width
"
);
return
a
?
"
width
"
:
"
height
"
},
show
:
function
(){
var
b
,
c
,
d
,
e
;
if
(
this
.
transitioning
)
return
;
b
=
this
.
dimension
(),
c
=
a
.
camelCase
([
"
scroll
"
,
b
].
join
(
"
-
"
)),
d
=
this
.
$parent
&&
this
.
$parent
.
find
(
"
> .accordion-group > .in
"
);
if
(
d
&&
d
.
length
){
e
=
d
.
data
(
"
collapse
"
);
if
(
e
&&
e
.
transitioning
)
return
;
d
.
collapse
(
"
hide
"
),
e
||
d
.
data
(
"
collapse
"
,
null
)}
this
.
$element
[
b
](
0
),
this
.
transition
(
"
addClass
"
,
a
.
Event
(
"
show
"
),
"
shown
"
),
this
.
$element
[
b
](
this
.
$element
[
0
][
c
])},
hide
:
function
(){
var
b
;
if
(
this
.
transitioning
)
return
;
b
=
this
.
dimension
(),
this
.
reset
(
this
.
$element
[
b
]()),
this
.
transition
(
"
removeClass
"
,
a
.
Event
(
"
hide
"
),
"
hidden
"
),
this
.
$element
[
b
](
0
)},
reset
:
function
(
a
){
var
b
=
this
.
dimension
();
return
this
.
$element
.
removeClass
(
"
collapse
"
)[
b
](
a
||
"
auto
"
)[
0
].
offsetWidth
,
this
.
$element
[
a
!==
null
?
"
addClass
"
:
"
removeClass
"
](
"
collapse
"
),
this
},
transition
:
function
(
b
,
c
,
d
){
var
e
=
this
,
f
=
function
(){
c
.
type
==
"
show
"
&&
e
.
reset
(),
e
.
transitioning
=
0
,
e
.
$element
.
trigger
(
d
)};
this
.
$element
.
trigger
(
c
);
if
(
c
.
isDefaultPrevented
())
return
;
this
.
transitioning
=
1
,
this
.
$element
[
b
](
"
in
"
),
a
.
support
.
transition
&&
this
.
$element
.
hasClass
(
"
collapse
"
)?
this
.
$element
.
one
(
a
.
support
.
transition
.
end
,
f
):
f
()},
toggle
:
function
(){
this
[
this
.
$element
.
hasClass
(
"
in
"
)?
"
hide
"
:
"
show
"
]()}},
a
.
fn
.
collapse
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
collapse
"
),
f
=
typeof
c
==
"
object
"
&&
c
;
e
||
d
.
data
(
"
collapse
"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"
string
"
&&
e
[
c
]()})},
a
.
fn
.
collapse
.
defaults
=
{
toggle
:
!
0
},
a
.
fn
.
collapse
.
Constructor
=
b
,
a
(
function
(){
a
(
"
body
"
).
on
(
"
click.collapse.data-api
"
,
"
[data-toggle=collapse]
"
,
function
(
b
){
var
c
=
a
(
this
),
d
,
e
=
c
.
attr
(
"
data-target
"
)
||
b
.
preventDefault
()
||
(
d
=
c
.
attr
(
"
href
"
))
&&
d
.
replace
(
/.*
(?=
#
[^\s]
+$
)
/
,
""
),
f
=
a
(
e
).
data
(
"
collapse
"
)?
"
toggle
"
:
c
.
data
();
a
(
e
).
collapse
(
f
)})})}(
window
.
jQuery
),
!
function
(
a
){
function
d
(){
a
(
b
).
parent
().
removeClass
(
"
open
"
)}
"
use strict
"
;
var
b
=
'
[data-toggle="dropdown"]
'
,
c
=
function
(
b
){
var
c
=
a
(
b
).
on
(
"
click.dropdown.data-api
"
,
this
.
toggle
);
a
(
"
html
"
).
on
(
"
click.dropdown.data-api
"
,
function
(){
c
.
parent
().
removeClass
(
"
open
"
)})};
c
.
prototype
=
{
constructor
:
c
,
toggle
:
function
(
b
){
var
c
=
a
(
this
),
e
,
f
,
g
;
if
(
c
.
is
(
"
.disabled, :disabled
"
))
return
;
return
f
=
c
.
attr
(
"
data-target
"
),
f
||
(
f
=
c
.
attr
(
"
href
"
),
f
=
f
&&
f
.
replace
(
/.*
(?=
#
[^\s]
*$
)
/
,
""
)),
e
=
a
(
f
),
e
.
length
||
(
e
=
c
.
parent
()),
g
=
e
.
hasClass
(
"
open
"
),
d
(),
g
||
e
.
toggleClass
(
"
open
"
),
!
1
}},
a
.
fn
.
dropdown
=
function
(
b
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
dropdown
"
);
e
||
d
.
data
(
"
dropdown
"
,
e
=
new
c
(
this
)),
typeof
b
==
"
string
"
&&
e
[
b
].
call
(
d
)})},
a
.
fn
.
dropdown
.
Constructor
=
c
,
a
(
function
(){
a
(
"
html
"
).
on
(
"
click.dropdown.data-api
"
,
d
),
a
(
"
body
"
).
on
(
"
click.dropdown
"
,
"
.dropdown form
"
,
function
(
a
){
a
.
stopPropagation
()}).
on
(
"
click.dropdown.data-api
"
,
b
,
c
.
prototype
.
toggle
)})}(
window
.
jQuery
),
!
function
(
a
){
function
c
(){
var
b
=
this
,
c
=
setTimeout
(
function
(){
b
.
$element
.
off
(
a
.
support
.
transition
.
end
),
d
.
call
(
b
)},
500
);
this
.
$element
.
one
(
a
.
support
.
transition
.
end
,
function
(){
clearTimeout
(
c
),
d
.
call
(
b
)})}
function
d
(
a
){
this
.
$element
.
hide
().
trigger
(
"
hidden
"
),
e
.
call
(
this
)}
function
e
(
b
){
var
c
=
this
,
d
=
this
.
$element
.
hasClass
(
"
fade
"
)?
"
fade
"
:
""
;
if
(
this
.
isShown
&&
this
.
options
.
backdrop
){
var
e
=
a
.
support
.
transition
&&
d
;
this
.
$backdrop
=
a
(
'
<div class="modal-backdrop
'
+
d
+
'
" />
'
).
appendTo
(
document
.
body
),
this
.
options
.
backdrop
!=
"
static
"
&&
this
.
$backdrop
.
click
(
a
.
proxy
(
this
.
hide
,
this
)),
e
&&
this
.
$backdrop
[
0
].
offsetWidth
,
this
.
$backdrop
.
addClass
(
"
in
"
),
e
?
this
.
$backdrop
.
one
(
a
.
support
.
transition
.
end
,
b
):
b
()}
else
!
this
.
isShown
&&
this
.
$backdrop
?(
this
.
$backdrop
.
removeClass
(
"
in
"
),
a
.
support
.
transition
&&
this
.
$element
.
hasClass
(
"
fade
"
)?
this
.
$backdrop
.
one
(
a
.
support
.
transition
.
end
,
a
.
proxy
(
f
,
this
)):
f
.
call
(
this
)):
b
&&
b
()}
function
f
(){
this
.
$backdrop
.
remove
(),
this
.
$backdrop
=
null
}
function
g
(){
var
b
=
this
;
this
.
isShown
&&
this
.
options
.
keyboard
?
a
(
document
).
on
(
"
keyup.dismiss.modal
"
,
function
(
a
){
a
.
which
==
27
&&
b
.
hide
()}):
this
.
isShown
||
a
(
document
).
off
(
"
keyup.dismiss.modal
"
)}
"
use strict
"
;
var
b
=
function
(
b
,
c
){
this
.
options
=
c
,
this
.
$element
=
a
(
b
).
delegate
(
'
[data-dismiss="modal"]
'
,
"
click.dismiss.modal
"
,
a
.
proxy
(
this
.
hide
,
this
))};
b
.
prototype
=
{
constructor
:
b
,
toggle
:
function
(){
return
this
[
this
.
isShown
?
"
hide
"
:
"
show
"
]()},
show
:
function
(){
var
b
=
this
,
c
=
a
.
Event
(
"
show
"
);
this
.
$element
.
trigger
(
c
);
if
(
this
.
isShown
||
c
.
isDefaultPrevented
())
return
;
a
(
"
body
"
).
addClass
(
"
modal-open
"
),
this
.
isShown
=!
0
,
g
.
call
(
this
),
e
.
call
(
this
,
function
(){
var
c
=
a
.
support
.
transition
&&
b
.
$element
.
hasClass
(
"
fade
"
);
b
.
$element
.
parent
().
length
||
b
.
$element
.
appendTo
(
document
.
body
),
b
.
$element
.
show
(),
c
&&
b
.
$element
[
0
].
offsetWidth
,
b
.
$element
.
addClass
(
"
in
"
),
c
?
b
.
$element
.
one
(
a
.
support
.
transition
.
end
,
function
(){
b
.
$element
.
trigger
(
"
shown
"
)}):
b
.
$element
.
trigger
(
"
shown
"
)})},
hide
:
function
(
b
){
b
&&
b
.
preventDefault
();
var
e
=
this
;
b
=
a
.
Event
(
"
hide
"
),
this
.
$element
.
trigger
(
b
);
if
(
!
this
.
isShown
||
b
.
isDefaultPrevented
())
return
;
this
.
isShown
=!
1
,
a
(
"
body
"
).
removeClass
(
"
modal-open
"
),
g
.
call
(
this
),
this
.
$element
.
removeClass
(
"
in
"
),
a
.
support
.
transition
&&
this
.
$element
.
hasClass
(
"
fade
"
)?
c
.
call
(
this
):
d
.
call
(
this
)}},
a
.
fn
.
modal
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
modal
"
),
f
=
a
.
extend
({},
a
.
fn
.
modal
.
defaults
,
d
.
data
(),
typeof
c
==
"
object
"
&&
c
);
e
||
d
.
data
(
"
modal
"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"
string
"
?
e
[
c
]():
f
.
show
&&
e
.
show
()})},
a
.
fn
.
modal
.
defaults
=
{
backdrop
:
!
0
,
keyboard
:
!
0
,
show
:
!
0
},
a
.
fn
.
modal
.
Constructor
=
b
,
a
(
function
(){
a
(
"
body
"
).
on
(
"
click.modal.data-api
"
,
'
[data-toggle="modal"]
'
,
function
(
b
){
var
c
=
a
(
this
),
d
,
e
=
a
(
c
.
attr
(
"
data-target
"
)
||
(
d
=
c
.
attr
(
"
href
"
))
&&
d
.
replace
(
/.*
(?=
#
[^\s]
+$
)
/
,
""
)),
f
=
e
.
data
(
"
modal
"
)?
"
toggle
"
:
a
.
extend
({},
e
.
data
(),
c
.
data
());
b
.
preventDefault
(),
e
.
modal
(
f
)})})}(
window
.
jQuery
),
!
function
(
a
){
"
use strict
"
;
var
b
=
function
(
a
,
b
){
this
.
init
(
"
tooltip
"
,
a
,
b
)};
b
.
prototype
=
{
constructor
:
b
,
init
:
function
(
b
,
c
,
d
){
var
e
,
f
;
this
.
type
=
b
,
this
.
$element
=
a
(
c
),
this
.
options
=
this
.
getOptions
(
d
),
this
.
enabled
=!
0
,
this
.
options
.
trigger
!=
"
manual
"
&&
(
e
=
this
.
options
.
trigger
==
"
hover
"
?
"
mouseenter
"
:
"
focus
"
,
f
=
this
.
options
.
trigger
==
"
hover
"
?
"
mouseleave
"
:
"
blur
"
,
this
.
$element
.
on
(
e
,
this
.
options
.
selector
,
a
.
proxy
(
this
.
enter
,
this
)),
this
.
$element
.
on
(
f
,
this
.
options
.
selector
,
a
.
proxy
(
this
.
leave
,
this
))),
this
.
options
.
selector
?
this
.
_options
=
a
.
extend
({},
this
.
options
,{
trigger
:
"
manual
"
,
selector
:
""
}):
this
.
fixTitle
()},
getOptions
:
function
(
b
){
return
b
=
a
.
extend
({},
a
.
fn
[
this
.
type
].
defaults
,
b
,
this
.
$element
.
data
()),
b
.
delay
&&
typeof
b
.
delay
==
"
number
"
&&
(
b
.
delay
=
{
show
:
b
.
delay
,
hide
:
b
.
delay
}),
b
},
enter
:
function
(
b
){
var
c
=
a
(
b
.
currentTarget
)[
this
.
type
](
this
.
_options
).
data
(
this
.
type
);
if
(
!
c
.
options
.
delay
||!
c
.
options
.
delay
.
show
)
return
c
.
show
();
clearTimeout
(
this
.
timeout
),
c
.
hoverState
=
"
in
"
,
this
.
timeout
=
setTimeout
(
function
(){
c
.
hoverState
==
"
in
"
&&
c
.
show
()},
c
.
options
.
delay
.
show
)},
leave
:
function
(
b
){
var
c
=
a
(
b
.
currentTarget
)[
this
.
type
](
this
.
_options
).
data
(
this
.
type
);
this
.
timeout
&&
clearTimeout
(
this
.
timeout
);
if
(
!
c
.
options
.
delay
||!
c
.
options
.
delay
.
hide
)
return
c
.
hide
();
c
.
hoverState
=
"
out
"
,
this
.
timeout
=
setTimeout
(
function
(){
c
.
hoverState
==
"
out
"
&&
c
.
hide
()},
c
.
options
.
delay
.
hide
)},
show
:
function
(){
var
a
,
b
,
c
,
d
,
e
,
f
,
g
;
if
(
this
.
hasContent
()
&&
this
.
enabled
){
a
=
this
.
tip
(),
this
.
setContent
(),
this
.
options
.
animation
&&
a
.
addClass
(
"
fade
"
),
f
=
typeof
this
.
options
.
placement
==
"
function
"
?
this
.
options
.
placement
.
call
(
this
,
a
[
0
],
this
.
$element
[
0
]):
this
.
options
.
placement
,
b
=
/in/
.
test
(
f
),
a
.
remove
().
css
({
top
:
0
,
left
:
0
,
display
:
"
block
"
}).
appendTo
(
b
?
this
.
$element
:
document
.
body
),
c
=
this
.
getPosition
(
b
),
d
=
a
[
0
].
offsetWidth
,
e
=
a
[
0
].
offsetHeight
;
switch
(
b
?
f
.
split
(
"
"
)[
1
]:
f
){
case
"
bottom
"
:
g
=
{
top
:
c
.
top
+
c
.
height
,
left
:
c
.
left
+
c
.
width
/
2
-
d
/
2
};
break
;
case
"
top
"
:
g
=
{
top
:
c
.
top
-
e
,
left
:
c
.
left
+
c
.
width
/
2
-
d
/
2
};
break
;
case
"
left
"
:
g
=
{
top
:
c
.
top
+
c
.
height
/
2
-
e
/
2
,
left
:
c
.
left
-
d
};
break
;
case
"
right
"
:
g
=
{
top
:
c
.
top
+
c
.
height
/
2
-
e
/
2
,
left
:
c
.
left
+
c
.
width
}}
a
.
css
(
g
).
addClass
(
f
).
addClass
(
"
in
"
)}},
isHTML
:
function
(
a
){
return
typeof
a
!=
"
string
"
||
a
.
charAt
(
0
)
===
"
<
"
&&
a
.
charAt
(
a
.
length
-
1
)
===
"
>
"
&&
a
.
length
>=
3
||
/^
(?:[^
<
]
*<
[\w\W]
+>
[^
>
]
*$
)
/
.
exec
(
a
)},
setContent
:
function
(){
var
a
=
this
.
tip
(),
b
=
this
.
getTitle
();
a
.
find
(
"
.tooltip-inner
"
)[
this
.
isHTML
(
b
)?
"
html
"
:
"
text
"
](
b
),
a
.
removeClass
(
"
fade in top bottom left right
"
)},
hide
:
function
(){
function
d
(){
var
b
=
setTimeout
(
function
(){
c
.
off
(
a
.
support
.
transition
.
end
).
remove
()},
500
);
c
.
one
(
a
.
support
.
transition
.
end
,
function
(){
clearTimeout
(
b
),
c
.
remove
()})}
var
b
=
this
,
c
=
this
.
tip
();
c
.
removeClass
(
"
in
"
),
a
.
support
.
transition
&&
this
.
$tip
.
hasClass
(
"
fade
"
)?
d
():
c
.
remove
()},
fixTitle
:
function
(){
var
a
=
this
.
$element
;(
a
.
attr
(
"
title
"
)
||
typeof
a
.
attr
(
"
data-original-title
"
)
!=
"
string
"
)
&&
a
.
attr
(
"
data-original-title
"
,
a
.
attr
(
"
title
"
)
||
""
).
removeAttr
(
"
title
"
)},
hasContent
:
function
(){
return
this
.
getTitle
()},
getPosition
:
function
(
b
){
return
a
.
extend
({},
b
?{
top
:
0
,
left
:
0
}:
this
.
$element
.
offset
(),{
width
:
this
.
$element
[
0
].
offsetWidth
,
height
:
this
.
$element
[
0
].
offsetHeight
})},
getTitle
:
function
(){
var
a
,
b
=
this
.
$element
,
c
=
this
.
options
;
return
a
=
b
.
attr
(
"
data-original-title
"
)
||
(
typeof
c
.
title
==
"
function
"
?
c
.
title
.
call
(
b
[
0
]):
c
.
title
),
a
},
tip
:
function
(){
return
this
.
$tip
=
this
.
$tip
||
a
(
this
.
options
.
template
)},
validate
:
function
(){
this
.
$element
[
0
].
parentNode
||
(
this
.
hide
(),
this
.
$element
=
null
,
this
.
options
=
null
)},
enable
:
function
(){
this
.
enabled
=!
0
},
disable
:
function
(){
this
.
enabled
=!
1
},
toggleEnabled
:
function
(){
this
.
enabled
=!
this
.
enabled
},
toggle
:
function
(){
this
[
this
.
tip
().
hasClass
(
"
in
"
)?
"
hide
"
:
"
show
"
]()}},
a
.
fn
.
tooltip
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
tooltip
"
),
f
=
typeof
c
==
"
object
"
&&
c
;
e
||
d
.
data
(
"
tooltip
"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"
string
"
&&
e
[
c
]()})},
a
.
fn
.
tooltip
.
Constructor
=
b
,
a
.
fn
.
tooltip
.
defaults
=
{
animation
:
!
0
,
placement
:
"
top
"
,
selector
:
!
1
,
template
:
'
<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>
'
,
trigger
:
"
hover
"
,
title
:
""
,
delay
:
0
}}(
window
.
jQuery
),
!
function
(
a
){
"
use strict
"
;
var
b
=
function
(
a
,
b
){
this
.
init
(
"
popover
"
,
a
,
b
)};
b
.
prototype
=
a
.
extend
({},
a
.
fn
.
tooltip
.
Constructor
.
prototype
,{
constructor
:
b
,
setContent
:
function
(){
var
a
=
this
.
tip
(),
b
=
this
.
getTitle
(),
c
=
this
.
getContent
();
a
.
find
(
"
.popover-title
"
)[
this
.
isHTML
(
b
)?
"
html
"
:
"
text
"
](
b
),
a
.
find
(
"
.popover-content > *
"
)[
this
.
isHTML
(
c
)?
"
html
"
:
"
text
"
](
c
),
a
.
removeClass
(
"
fade top bottom left right in
"
)},
hasContent
:
function
(){
return
this
.
getTitle
()
||
this
.
getContent
()},
getContent
:
function
(){
var
a
,
b
=
this
.
$element
,
c
=
this
.
options
;
return
a
=
b
.
attr
(
"
data-content
"
)
||
(
typeof
c
.
content
==
"
function
"
?
c
.
content
.
call
(
b
[
0
]):
c
.
content
),
a
},
tip
:
function
(){
return
this
.
$tip
||
(
this
.
$tip
=
a
(
this
.
options
.
template
)),
this
.
$tip
}}),
a
.
fn
.
popover
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
popover
"
),
f
=
typeof
c
==
"
object
"
&&
c
;
e
||
d
.
data
(
"
popover
"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"
string
"
&&
e
[
c
]()})},
a
.
fn
.
popover
.
Constructor
=
b
,
a
.
fn
.
popover
.
defaults
=
a
.
extend
({},
a
.
fn
.
tooltip
.
defaults
,{
placement
:
"
right
"
,
content
:
""
,
template
:
'
<div class="popover"><div class="arrow"></div><div class="popover-inner"><h3 class="popover-title"></h3><div class="popover-content"><p></p></div></div></div>
'
})}(
window
.
jQuery
),
!
function
(
a
){
function
b
(
b
,
c
){
var
d
=
a
.
proxy
(
this
.
process
,
this
),
e
=
a
(
b
).
is
(
"
body
"
)?
a
(
window
):
a
(
b
),
f
;
this
.
options
=
a
.
extend
({},
a
.
fn
.
scrollspy
.
defaults
,
c
),
this
.
$scrollElement
=
e
.
on
(
"
scroll.scroll.data-api
"
,
d
),
this
.
selector
=
(
this
.
options
.
target
||
(
f
=
a
(
b
).
attr
(
"
href
"
))
&&
f
.
replace
(
/.*
(?=
#
[^\s]
+$
)
/
,
""
)
||
""
)
+
"
.nav li > a
"
,
this
.
$body
=
a
(
"
body
"
),
this
.
refresh
(),
this
.
process
()}
"
use strict
"
,
b
.
prototype
=
{
constructor
:
b
,
refresh
:
function
(){
var
b
=
this
,
c
;
this
.
offsets
=
a
([]),
this
.
targets
=
a
([]),
c
=
this
.
$body
.
find
(
this
.
selector
).
map
(
function
(){
var
b
=
a
(
this
),
c
=
b
.
data
(
"
target
"
)
||
b
.
attr
(
"
href
"
),
d
=
/^#
\w
/
.
test
(
c
)
&&
a
(
c
);
return
d
&&
c
.
length
&&
[[
d
.
position
().
top
,
c
]]
||
null
}).
sort
(
function
(
a
,
b
){
return
a
[
0
]
-
b
[
0
]}).
each
(
function
(){
b
.
offsets
.
push
(
this
[
0
]),
b
.
targets
.
push
(
this
[
1
])})},
process
:
function
(){
var
a
=
this
.
$scrollElement
.
scrollTop
()
+
this
.
options
.
offset
,
b
=
this
.
$scrollElement
[
0
].
scrollHeight
||
this
.
$body
[
0
].
scrollHeight
,
c
=
b
-
this
.
$scrollElement
.
height
(),
d
=
this
.
offsets
,
e
=
this
.
targets
,
f
=
this
.
activeTarget
,
g
;
if
(
a
>=
c
)
return
f
!=
(
g
=
e
.
last
()[
0
])
&&
this
.
activate
(
g
);
for
(
g
=
d
.
length
;
g
--
;)
f
!=
e
[
g
]
&&
a
>=
d
[
g
]
&&
(
!
d
[
g
+
1
]
||
a
<=
d
[
g
+
1
])
&&
this
.
activate
(
e
[
g
])},
activate
:
function
(
b
){
var
c
,
d
;
this
.
activeTarget
=
b
,
a
(
this
.
selector
).
parent
(
"
.active
"
).
removeClass
(
"
active
"
),
d
=
this
.
selector
+
'
[data-target="
'
+
b
+
'
"],
'
+
this
.
selector
+
'
[href="
'
+
b
+
'
"]
'
,
c
=
a
(
d
).
parent
(
"
li
"
).
addClass
(
"
active
"
),
c
.
parent
(
"
.dropdown-menu
"
)
&&
(
c
=
c
.
closest
(
"
li.dropdown
"
).
addClass
(
"
active
"
)),
c
.
trigger
(
"
activate
"
)}},
a
.
fn
.
scrollspy
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
scrollspy
"
),
f
=
typeof
c
==
"
object
"
&&
c
;
e
||
d
.
data
(
"
scrollspy
"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"
string
"
&&
e
[
c
]()})},
a
.
fn
.
scrollspy
.
Constructor
=
b
,
a
.
fn
.
scrollspy
.
defaults
=
{
offset
:
10
},
a
(
function
(){
a
(
'
[data-spy="scroll"]
'
).
each
(
function
(){
var
b
=
a
(
this
);
b
.
scrollspy
(
b
.
data
())})})}(
window
.
jQuery
),
!
function
(
a
){
"
use strict
"
;
var
b
=
function
(
b
){
this
.
element
=
a
(
b
)};
b
.
prototype
=
{
constructor
:
b
,
show
:
function
(){
var
b
=
this
.
element
,
c
=
b
.
closest
(
"
ul:not(.dropdown-menu)
"
),
d
=
b
.
attr
(
"
data-target
"
),
e
,
f
,
g
;
d
||
(
d
=
b
.
attr
(
"
href
"
),
d
=
d
&&
d
.
replace
(
/.*
(?=
#
[^\s]
*$
)
/
,
""
));
if
(
b
.
parent
(
"
li
"
).
hasClass
(
"
active
"
))
return
;
e
=
c
.
find
(
"
.active a
"
).
last
()[
0
],
g
=
a
.
Event
(
"
show
"
,{
relatedTarget
:
e
}),
b
.
trigger
(
g
);
if
(
g
.
isDefaultPrevented
())
return
;
f
=
a
(
d
),
this
.
activate
(
b
.
parent
(
"
li
"
),
c
),
this
.
activate
(
f
,
f
.
parent
(),
function
(){
b
.
trigger
({
type
:
"
shown
"
,
relatedTarget
:
e
})})},
activate
:
function
(
b
,
c
,
d
){
function
g
(){
e
.
removeClass
(
"
active
"
).
find
(
"
> .dropdown-menu > .active
"
).
removeClass
(
"
active
"
),
b
.
addClass
(
"
active
"
),
f
?(
b
[
0
].
offsetWidth
,
b
.
addClass
(
"
in
"
)):
b
.
removeClass
(
"
fade
"
),
b
.
parent
(
"
.dropdown-menu
"
)
&&
b
.
closest
(
"
li.dropdown
"
).
addClass
(
"
active
"
),
d
&&
d
()}
var
e
=
c
.
find
(
"
> .active
"
),
f
=
d
&&
a
.
support
.
transition
&&
e
.
hasClass
(
"
fade
"
);
f
?
e
.
one
(
a
.
support
.
transition
.
end
,
g
):
g
(),
e
.
removeClass
(
"
in
"
)}},
a
.
fn
.
tab
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
tab
"
);
e
||
d
.
data
(
"
tab
"
,
e
=
new
b
(
this
)),
typeof
c
==
"
string
"
&&
e
[
c
]()})},
a
.
fn
.
tab
.
Constructor
=
b
,
a
(
function
(){
a
(
"
body
"
).
on
(
"
click.tab.data-api
"
,
'
[data-toggle="tab"], [data-toggle="pill"]
'
,
function
(
b
){
b
.
preventDefault
(),
a
(
this
).
tab
(
"
show
"
)})})}(
window
.
jQuery
),
!
function
(
a
){
"
use strict
"
;
var
b
=
function
(
b
,
c
){
this
.
$element
=
a
(
b
),
this
.
options
=
a
.
extend
({},
a
.
fn
.
typeahead
.
defaults
,
c
),
this
.
matcher
=
this
.
options
.
matcher
||
this
.
matcher
,
this
.
sorter
=
this
.
options
.
sorter
||
this
.
sorter
,
this
.
highlighter
=
this
.
options
.
highlighter
||
this
.
highlighter
,
this
.
updater
=
this
.
options
.
updater
||
this
.
updater
,
this
.
$menu
=
a
(
this
.
options
.
menu
).
appendTo
(
"
body
"
),
this
.
source
=
this
.
options
.
source
,
this
.
shown
=!
1
,
this
.
listen
()};
b
.
prototype
=
{
constructor
:
b
,
select
:
function
(){
var
a
=
this
.
$menu
.
find
(
"
.active
"
).
attr
(
"
data-value
"
);
return
this
.
$element
.
val
(
this
.
updater
(
a
)).
change
(),
this
.
hide
()},
updater
:
function
(
a
){
return
a
},
show
:
function
(){
var
b
=
a
.
extend
({},
this
.
$element
.
offset
(),{
height
:
this
.
$element
[
0
].
offsetHeight
});
return
this
.
$menu
.
css
({
top
:
b
.
top
+
b
.
height
,
left
:
b
.
left
}),
this
.
$menu
.
show
(),
this
.
shown
=!
0
,
this
},
hide
:
function
(){
return
this
.
$menu
.
hide
(),
this
.
shown
=!
1
,
this
},
lookup
:
function
(
b
){
var
c
=
this
,
d
,
e
;
return
this
.
query
=
this
.
$element
.
val
(),
this
.
query
?(
d
=
a
.
grep
(
this
.
source
,
function
(
a
){
return
c
.
matcher
(
a
)}),
d
=
this
.
sorter
(
d
),
d
.
length
?
this
.
render
(
d
.
slice
(
0
,
this
.
options
.
items
)).
show
():
this
.
shown
?
this
.
hide
():
this
):
this
.
shown
?
this
.
hide
():
this
},
matcher
:
function
(
a
){
return
~
a
.
toLowerCase
().
indexOf
(
this
.
query
.
toLowerCase
())},
sorter
:
function
(
a
){
var
b
=
[],
c
=
[],
d
=
[],
e
;
while
(
e
=
a
.
shift
())
e
.
toLowerCase
().
indexOf
(
this
.
query
.
toLowerCase
())?
~
e
.
indexOf
(
this
.
query
)?
c
.
push
(
e
):
d
.
push
(
e
):
b
.
push
(
e
);
return
b
.
concat
(
c
,
d
)},
highlighter
:
function
(
a
){
var
b
=
this
.
query
.
replace
(
/
[\-\[\]
{}()*+?.,
\\\^
$|#
\s]
/g
,
"
\\
$&
"
);
return
a
.
replace
(
new
RegExp
(
"
(
"
+
b
+
"
)
"
,
"
ig
"
),
function
(
a
,
b
){
return
"
<strong>
"
+
b
+
"
</strong>
"
})},
render
:
function
(
b
){
var
c
=
this
;
return
b
=
a
(
b
).
map
(
function
(
b
,
d
){
return
b
=
a
(
c
.
options
.
item
).
attr
(
"
data-value
"
,
d
),
b
.
find
(
"
a
"
).
html
(
c
.
highlighter
(
d
)),
b
[
0
]}),
b
.
first
().
addClass
(
"
active
"
),
this
.
$menu
.
html
(
b
),
this
},
next
:
function
(
b
){
var
c
=
this
.
$menu
.
find
(
"
.active
"
).
removeClass
(
"
active
"
),
d
=
c
.
next
();
d
.
length
||
(
d
=
a
(
this
.
$menu
.
find
(
"
li
"
)[
0
])),
d
.
addClass
(
"
active
"
)},
prev
:
function
(
a
){
var
b
=
this
.
$menu
.
find
(
"
.active
"
).
removeClass
(
"
active
"
),
c
=
b
.
prev
();
c
.
length
||
(
c
=
this
.
$menu
.
find
(
"
li
"
).
last
()),
c
.
addClass
(
"
active
"
)},
listen
:
function
(){
this
.
$element
.
on
(
"
blur
"
,
a
.
proxy
(
this
.
blur
,
this
)).
on
(
"
keypress
"
,
a
.
proxy
(
this
.
keypress
,
this
)).
on
(
"
keyup
"
,
a
.
proxy
(
this
.
keyup
,
this
)),(
a
.
browser
.
webkit
||
a
.
browser
.
msie
)
&&
this
.
$element
.
on
(
"
keydown
"
,
a
.
proxy
(
this
.
keypress
,
this
)),
this
.
$menu
.
on
(
"
click
"
,
a
.
proxy
(
this
.
click
,
this
)).
on
(
"
mouseenter
"
,
"
li
"
,
a
.
proxy
(
this
.
mouseenter
,
this
))},
keyup
:
function
(
a
){
switch
(
a
.
keyCode
){
case
40
:
case
38
:
break
;
case
9
:
case
13
:
if
(
!
this
.
shown
)
return
;
this
.
select
();
break
;
case
27
:
if
(
!
this
.
shown
)
return
;
this
.
hide
();
break
;
default
:
this
.
lookup
()}
a
.
stopPropagation
(),
a
.
preventDefault
()},
keypress
:
function
(
a
){
if
(
!
this
.
shown
)
return
;
switch
(
a
.
keyCode
){
case
9
:
case
13
:
case
27
:
a
.
preventDefault
();
break
;
case
38
:
if
(
a
.
type
!=
"
keydown
"
)
break
;
a
.
preventDefault
(),
this
.
prev
();
break
;
case
40
:
if
(
a
.
type
!=
"
keydown
"
)
break
;
a
.
preventDefault
(),
this
.
next
()}
a
.
stopPropagation
()},
blur
:
function
(
a
){
var
b
=
this
;
setTimeout
(
function
(){
b
.
hide
()},
150
)},
click
:
function
(
a
){
a
.
stopPropagation
(),
a
.
preventDefault
(),
this
.
select
()},
mouseenter
:
function
(
b
){
this
.
$menu
.
find
(
"
.active
"
).
removeClass
(
"
active
"
),
a
(
b
.
currentTarget
).
addClass
(
"
active
"
)}},
a
.
fn
.
typeahead
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
typeahead
"
),
f
=
typeof
c
==
"
object
"
&&
c
;
e
||
d
.
data
(
"
typeahead
"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"
string
"
&&
e
[
c
]()})},
a
.
fn
.
typeahead
.
defaults
=
{
source
:[],
items
:
8
,
menu
:
'
<ul class="typeahead dropdown-menu"></ul>
'
,
item
:
'
<li><a href="#"></a></li>
'
},
a
.
fn
.
typeahead
.
Constructor
=
b
,
a
(
function
(){
a
(
"
body
"
).
on
(
"
focus.typeahead.data-api
"
,
'
[data-provide="typeahead"]
'
,
function
(
b
){
var
c
=
a
(
this
);
if
(
c
.
data
(
"
typeahead
"
))
return
;
b
.
preventDefault
(),
c
.
typeahead
(
c
.
data
())})})}(
window
.
jQuery
);
\ No newline at end of file
This diff is collapsed.
Click to expand it.
js/tests/unit/bootstrap-tooltip.js
+
5
-
5
View file @
4eaeea81
...
...
@@ -116,16 +116,16 @@ $(function () {
test
(
"
should show tooltip if leave event hasn't occured before delay expires
"
,
function
()
{
var
tooltip
=
$
(
'
<a href="#" rel="tooltip" title="Another tooltip"></a>
'
)
.
appendTo
(
'
#qunit-fixture
'
)
.
tooltip
({
delay
:
20
0
})
.
tooltip
({
delay
:
15
0
})
stop
()
tooltip
.
trigger
(
'
mouseenter
'
)
setTimeout
(
function
()
{
ok
(
!
$
(
"
.tooltip
"
).
is
(
'
.fade.in
'
),
'
tooltip is not faded in
'
)
setTimeout
(
function
()
{
ok
(
!
$
(
"
.tooltip
"
).
is
(
'
.fade.in
'
),
'
tooltip has faded in
'
)
start
()
},
200
)
},
100
)
setTimeout
(
function
()
{
ok
(
$
(
"
.tooltip
"
).
is
(
'
.fade.in
'
),
'
tooltip has faded in
'
)
start
()
},
200
)
})
test
(
"
should detect if title string is html or text: foo
"
,
function
()
{
...
...
This diff is collapsed.
Click to expand it.
Write
Preview
Supports
Markdown
0%
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment
Menu
Explore
Projects
Groups
Snippets