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
d07e8fec
Commit
d07e8fec
authored
11 years ago
by
Mark Otto
Browse files
Options
Download
Email Patches
Plain Diff
grunt
parent
4bd6a525
No related merge requests found
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
dist/css/bootstrap.css
+3
-3
dist/css/bootstrap.css
dist/js/bootstrap.min.js
+1
-1
dist/js/bootstrap.min.js
docs/assets/js/customize.min.js
+9
-9
docs/assets/js/customize.min.js
docs/assets/js/docs.min.js
+1
-1
docs/assets/js/docs.min.js
with
14 additions
and
14 deletions
+14
-14
dist/css/bootstrap.css
+
3
-
3
View file @
d07e8fec
...
...
@@ -5060,9 +5060,9 @@ button.close {
-moz-transition
:
-moz-transform
.3s
ease-out
;
-o-transition
:
-o-transform
.3s
ease-out
;
transition
:
transform
.3s
ease-out
;
-webkit-transform
:
translate
(
0
,
-25%
);
-ms-transform
:
translate
(
0
,
-25%
);
transform
:
translate
(
0
,
-25%
);
-webkit-transform
:
translate
(
0
,
-25%
);
-ms-transform
:
translate
(
0
,
-25%
);
transform
:
translate
(
0
,
-25%
);
}
.modal.in
.modal-dialog
{
-webkit-transform
:
translate
(
0
,
0
);
...
...
This diff is collapsed.
Click to expand it.
dist/js/bootstrap.min.js
+
1
-
1
View file @
d07e8fec
...
...
@@ -3,4 +3,4 @@
* Copyright 2011-2014 Twitter, Inc.
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
*/
if
(
"
undefined
"
==
typeof
jQuery
)
throw
new
Error
(
"
Bootstrap requires jQuery
"
);
+
function
(
a
){
"
use strict
"
;
function
b
(){
var
a
=
document
.
createElement
(
"
bootstrap
"
),
b
=
{
WebkitTransition
:
"
webkitTransitionEnd
"
,
MozTransition
:
"
transitionend
"
,
OTransition
:
"
oTransitionEnd otransitionend
"
,
transition
:
"
transitionend
"
};
for
(
var
c
in
b
)
if
(
void
0
!==
a
.
style
[
c
])
return
{
end
:
b
[
c
]};
return
!
1
}
a
.
fn
.
emulateTransitionEnd
=
function
(
b
){
var
c
=!
1
,
d
=
this
;
a
(
this
).
one
(
a
.
support
.
transition
.
end
,
function
(){
c
=!
0
});
var
e
=
function
(){
c
||
a
(
d
).
trigger
(
a
.
support
.
transition
.
end
)};
return
setTimeout
(
e
,
b
),
this
},
a
(
function
(){
a
.
support
.
transition
=
b
()})}(
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
c
(){
f
.
trigger
(
"
closed.bs.alert
"
).
remove
()}
var
d
=
a
(
this
),
e
=
d
.
attr
(
"
data-target
"
);
e
||
(
e
=
d
.
attr
(
"
href
"
),
e
=
e
&&
e
.
replace
(
/.*
(?=
#
[^\s]
*$
)
/
,
""
));
var
f
=
a
(
e
);
b
&&
b
.
preventDefault
(),
f
.
length
||
(
f
=
d
.
hasClass
(
"
alert
"
)?
d
:
d
.
parent
()),
f
.
trigger
(
b
=
a
.
Event
(
"
close.bs.alert
"
)),
b
.
isDefaultPrevented
()
||
(
f
.
removeClass
(
"
in
"
),
a
.
support
.
transition
&&
f
.
hasClass
(
"
fade
"
)?
f
.
one
(
a
.
support
.
transition
.
end
,
c
).
emulateTransitionEnd
(
150
):
c
())};
var
d
=
a
.
fn
.
alert
;
a
.
fn
.
alert
=
function
(
b
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
bs.alert
"
);
e
||
d
.
data
(
"
bs.alert
"
,
e
=
new
c
(
this
)),
"
string
"
==
typeof
b
&&
e
[
b
].
call
(
d
)})},
a
.
fn
.
alert
.
Constructor
=
c
,
a
.
fn
.
alert
.
noConflict
=
function
(){
return
a
.
fn
.
alert
=
d
,
this
},
a
(
document
).
on
(
"
click.bs.alert.data-api
"
,
b
,
c
.
prototype
.
close
)}(
jQuery
),
+
function
(
a
){
"
use strict
"
;
var
b
=
function
(
c
,
d
){
this
.
$element
=
a
(
c
),
this
.
options
=
a
.
extend
({},
b
.
DEFAULTS
,
d
),
this
.
isLoading
=!
1
};
b
.
DEFAULTS
=
{
loadingText
:
"
loading...
"
},
b
.
prototype
.
setState
=
function
(
b
){
var
c
=
"
disabled
"
,
d
=
this
.
$element
,
e
=
d
.
is
(
"
input
"
)?
"
val
"
:
"
html
"
,
f
=
d
.
data
();
b
+=
"
Text
"
,
f
.
resetText
||
d
.
data
(
"
resetText
"
,
d
[
e
]()),
d
[
e
](
f
[
b
]
||
this
.
options
[
b
]),
setTimeout
(
a
.
proxy
(
function
(){
"
loadingText
"
==
b
?(
this
.
isLoading
=!
0
,
d
.
addClass
(
c
).
attr
(
c
,
c
)):
this
.
isLoading
&&
(
this
.
isLoading
=!
1
,
d
.
removeClass
(
c
).
removeAttr
(
c
))},
this
),
0
)},
b
.
prototype
.
toggle
=
function
(){
var
a
=!
0
,
b
=
this
.
$element
.
closest
(
'
[data-toggle="buttons"]
'
);
if
(
b
.
length
){
var
c
=
this
.
$element
.
find
(
"
input
"
);
"
radio
"
==
c
.
prop
(
"
type
"
)
&&
(
c
.
prop
(
"
checked
"
)
&&
this
.
$element
.
hasClass
(
"
active
"
)?
a
=!
1
:
b
.
find
(
"
.active
"
).
removeClass
(
"
active
"
)),
a
&&
c
.
prop
(
"
checked
"
,
!
this
.
$element
.
hasClass
(
"
active
"
)).
trigger
(
"
change
"
)}
a
&&
this
.
$element
.
toggleClass
(
"
active
"
)};
var
c
=
a
.
fn
.
button
;
a
.
fn
.
button
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
bs.button
"
),
f
=
"
object
"
==
typeof
c
&&
c
;
e
||
d
.
data
(
"
bs.button
"
,
e
=
new
b
(
this
,
f
)),
"
toggle
"
==
c
?
e
.
toggle
():
c
&&
e
.
setState
(
c
)})},
a
.
fn
.
button
.
Constructor
=
b
,
a
.
fn
.
button
.
noConflict
=
function
(){
return
a
.
fn
.
button
=
c
,
this
},
a
(
document
).
on
(
"
click.bs.button.data-api
"
,
"
[data-toggle^=button]
"
,
function
(
b
){
var
c
=
a
(
b
.
target
);
c
.
hasClass
(
"
btn
"
)
||
(
c
=
c
.
closest
(
"
.btn
"
)),
c
.
button
(
"
toggle
"
),
b
.
preventDefault
()})}(
jQuery
),
+
function
(
a
){
"
use strict
"
;
var
b
=
function
(
b
,
c
){
this
.
$element
=
a
(
b
),
this
.
$indicators
=
this
.
$element
.
find
(
"
.carousel-indicators
"
),
this
.
options
=
c
,
this
.
paused
=
this
.
sliding
=
this
.
interval
=
this
.
$active
=
this
.
$items
=
null
,
"
hover
"
==
this
.
options
.
pause
&&
this
.
$element
.
on
(
"
mouseenter
"
,
a
.
proxy
(
this
.
pause
,
this
)).
on
(
"
mouseleave
"
,
a
.
proxy
(
this
.
cycle
,
this
))};
b
.
DEFAULTS
=
{
interval
:
5
e3
,
pause
:
"
hover
"
,
wrap
:
!
0
},
b
.
prototype
.
cycle
=
function
(
b
){
return
b
||
(
this
.
paused
=!
1
),
this
.
interval
&&
clearInterval
(
this
.
interval
),
this
.
options
.
interval
&&!
this
.
paused
&&
(
this
.
interval
=
setInterval
(
a
.
proxy
(
this
.
next
,
this
),
this
.
options
.
interval
)),
this
},
b
.
prototype
.
getActiveIndex
=
function
(){
return
this
.
$active
=
this
.
$element
.
find
(
"
.item.active
"
),
this
.
$items
=
this
.
$active
.
parent
().
children
(),
this
.
$items
.
index
(
this
.
$active
)},
b
.
prototype
.
to
=
function
(
b
){
var
c
=
this
,
d
=
this
.
getActiveIndex
();
return
b
>
this
.
$items
.
length
-
1
||
0
>
b
?
void
0
:
this
.
sliding
?
this
.
$element
.
one
(
"
slid.bs.carousel
"
,
function
(){
c
.
to
(
b
)}):
d
==
b
?
this
.
pause
().
cycle
():
this
.
slide
(
b
>
d
?
"
next
"
:
"
prev
"
,
a
(
this
.
$items
[
b
]))},
b
.
prototype
.
pause
=
function
(
b
){
return
b
||
(
this
.
paused
=!
0
),
this
.
$element
.
find
(
"
.next, .prev
"
).
length
&&
a
.
support
.
transition
&&
(
this
.
$element
.
trigger
(
a
.
support
.
transition
.
end
),
this
.
cycle
(
!
0
)),
this
.
interval
=
clearInterval
(
this
.
interval
),
this
},
b
.
prototype
.
next
=
function
(){
return
this
.
sliding
?
void
0
:
this
.
slide
(
"
next
"
)},
b
.
prototype
.
prev
=
function
(){
return
this
.
sliding
?
void
0
:
this
.
slide
(
"
prev
"
)},
b
.
prototype
.
slide
=
function
(
b
,
c
){
var
d
=
this
.
$element
.
find
(
"
.item.active
"
),
e
=
c
||
d
[
b
](),
f
=
this
.
interval
,
g
=
"
next
"
==
b
?
"
left
"
:
"
right
"
,
h
=
"
next
"
==
b
?
"
first
"
:
"
last
"
,
i
=
this
;
if
(
!
e
.
length
){
if
(
!
this
.
options
.
wrap
)
return
;
e
=
this
.
$element
.
find
(
"
.item
"
)[
h
]()}
if
(
e
.
hasClass
(
"
active
"
))
return
this
.
sliding
=!
1
;
var
j
=
a
.
Event
(
"
slide.bs.carousel
"
,{
relatedTarget
:
e
[
0
],
direction
:
g
});
return
this
.
$element
.
trigger
(
j
),
j
.
isDefaultPrevented
()?
void
0
:(
this
.
sliding
=!
0
,
f
&&
this
.
pause
(),
this
.
$indicators
.
length
&&
(
this
.
$indicators
.
find
(
"
.active
"
).
removeClass
(
"
active
"
),
this
.
$element
.
one
(
"
slid.bs.carousel
"
,
function
(){
var
b
=
a
(
i
.
$indicators
.
children
()[
i
.
getActiveIndex
()]);
b
&&
b
.
addClass
(
"
active
"
)})),
a
.
support
.
transition
&&
this
.
$element
.
hasClass
(
"
slide
"
)?(
e
.
addClass
(
b
),
e
[
0
].
offsetWidth
,
d
.
addClass
(
g
),
e
.
addClass
(
g
),
d
.
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.bs.carousel
"
)},
0
)}).
emulateTransitionEnd
(
1
e3
*
d
.
css
(
"
transition-duration
"
).
slice
(
0
,
-
1
))):(
d
.
removeClass
(
"
active
"
),
e
.
addClass
(
"
active
"
),
this
.
sliding
=!
1
,
this
.
$element
.
trigger
(
"
slid.bs.carousel
"
)),
f
&&
this
.
cycle
(),
this
)};
var
c
=
a
.
fn
.
carousel
;
a
.
fn
.
carousel
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
bs.carousel
"
),
f
=
a
.
extend
({},
b
.
DEFAULTS
,
d
.
data
(),
"
object
"
==
typeof
c
&&
c
),
g
=
"
string
"
==
typeof
c
?
c
:
f
.
slide
;
e
||
d
.
data
(
"
bs.carousel
"
,
e
=
new
b
(
this
,
f
)),
"
number
"
==
typeof
c
?
e
.
to
(
c
):
g
?
e
[
g
]():
f
.
interval
&&
e
.
pause
().
cycle
()})},
a
.
fn
.
carousel
.
Constructor
=
b
,
a
.
fn
.
carousel
.
noConflict
=
function
(){
return
a
.
fn
.
carousel
=
c
,
this
},
a
(
document
).
on
(
"
click.bs.carousel.data-api
"
,
"
[data-slide], [data-slide-to]
"
,
function
(
b
){
var
c
,
d
=
a
(
this
),
e
=
a
(
d
.
attr
(
"
data-target
"
)
||
(
c
=
d
.
attr
(
"
href
"
))
&&
c
.
replace
(
/.*
(?=
#
[^\s]
+$
)
/
,
""
)),
f
=
a
.
extend
({},
e
.
data
(),
d
.
data
()),
g
=
d
.
attr
(
"
data-slide-to
"
);
g
&&
(
f
.
interval
=!
1
),
e
.
carousel
(
f
),(
g
=
d
.
attr
(
"
data-slide-to
"
))
&&
e
.
data
(
"
bs.carousel
"
).
to
(
g
),
b
.
preventDefault
()}),
a
(
window
).
on
(
"
load
"
,
function
(){
a
(
'
[data-ride="carousel"]
'
).
each
(
function
(){
var
b
=
a
(
this
);
b
.
carousel
(
b
.
data
())})})}(
jQuery
),
+
function
(
a
){
"
use strict
"
;
var
b
=
function
(
c
,
d
){
this
.
$element
=
a
(
c
),
this
.
options
=
a
.
extend
({},
b
.
DEFAULTS
,
d
),
this
.
transitioning
=
null
,
this
.
options
.
parent
&&
(
this
.
$parent
=
a
(
this
.
options
.
parent
)),
this
.
options
.
toggle
&&
this
.
toggle
()};
b
.
DEFAULTS
=
{
toggle
:
!
0
},
b
.
prototype
.
dimension
=
function
(){
var
a
=
this
.
$element
.
hasClass
(
"
width
"
);
return
a
?
"
width
"
:
"
height
"
},
b
.
prototype
.
show
=
function
(){
if
(
!
this
.
transitioning
&&!
this
.
$element
.
hasClass
(
"
in
"
)){
var
b
=
a
.
Event
(
"
show.bs.collapse
"
);
if
(
this
.
$element
.
trigger
(
b
),
!
b
.
isDefaultPrevented
()){
var
c
=
this
.
$parent
&&
this
.
$parent
.
find
(
"
> .panel > .in
"
);
if
(
c
&&
c
.
length
){
var
d
=
c
.
data
(
"
bs.collapse
"
);
if
(
d
&&
d
.
transitioning
)
return
;
c
.
collapse
(
"
hide
"
),
d
||
c
.
data
(
"
bs.collapse
"
,
null
)}
var
e
=
this
.
dimension
();
this
.
$element
.
removeClass
(
"
collapse
"
).
addClass
(
"
collapsing
"
)[
e
](
0
),
this
.
transitioning
=
1
;
var
f
=
function
(){
this
.
$element
.
removeClass
(
"
collapsing
"
).
addClass
(
"
collapse in
"
)[
e
](
"
auto
"
),
this
.
transitioning
=
0
,
this
.
$element
.
trigger
(
"
shown.bs.collapse
"
)};
if
(
!
a
.
support
.
transition
)
return
f
.
call
(
this
);
var
g
=
a
.
camelCase
([
"
scroll
"
,
e
].
join
(
"
-
"
));
this
.
$element
.
one
(
a
.
support
.
transition
.
end
,
a
.
proxy
(
f
,
this
)).
emulateTransitionEnd
(
350
)[
e
](
this
.
$element
[
0
][
g
])}}},
b
.
prototype
.
hide
=
function
(){
if
(
!
this
.
transitioning
&&
this
.
$element
.
hasClass
(
"
in
"
)){
var
b
=
a
.
Event
(
"
hide.bs.collapse
"
);
if
(
this
.
$element
.
trigger
(
b
),
!
b
.
isDefaultPrevented
()){
var
c
=
this
.
dimension
();
this
.
$element
[
c
](
this
.
$element
[
c
]())[
0
].
offsetHeight
,
this
.
$element
.
addClass
(
"
collapsing
"
).
removeClass
(
"
collapse
"
).
removeClass
(
"
in
"
),
this
.
transitioning
=
1
;
var
d
=
function
(){
this
.
transitioning
=
0
,
this
.
$element
.
trigger
(
"
hidden.bs.collapse
"
).
removeClass
(
"
collapsing
"
).
addClass
(
"
collapse
"
)};
return
a
.
support
.
transition
?(
this
.
$element
[
c
](
0
).
one
(
a
.
support
.
transition
.
end
,
a
.
proxy
(
d
,
this
)).
emulateTransitionEnd
(
350
),
void
0
):
d
.
call
(
this
)}}},
b
.
prototype
.
toggle
=
function
(){
this
[
this
.
$element
.
hasClass
(
"
in
"
)?
"
hide
"
:
"
show
"
]()};
var
c
=
a
.
fn
.
collapse
;
a
.
fn
.
collapse
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
bs.collapse
"
),
f
=
a
.
extend
({},
b
.
DEFAULTS
,
d
.
data
(),
"
object
"
==
typeof
c
&&
c
);
!
e
&&
f
.
toggle
&&
"
show
"
==
c
&&
(
c
=!
c
),
e
||
d
.
data
(
"
bs.collapse
"
,
e
=
new
b
(
this
,
f
)),
"
string
"
==
typeof
c
&&
e
[
c
]()})},
a
.
fn
.
collapse
.
Constructor
=
b
,
a
.
fn
.
collapse
.
noConflict
=
function
(){
return
a
.
fn
.
collapse
=
c
,
this
},
a
(
document
).
on
(
"
click.bs.collapse.data-api
"
,
"
[data-toggle=collapse]
"
,
function
(
b
){
var
c
,
d
=
a
(
this
),
e
=
d
.
attr
(
"
data-target
"
)
||
b
.
preventDefault
()
||
(
c
=
d
.
attr
(
"
href
"
))
&&
c
.
replace
(
/.*
(?=
#
[^\s]
+$
)
/
,
""
),
f
=
a
(
e
),
g
=
f
.
data
(
"
bs.collapse
"
),
h
=
g
?
"
toggle
"
:
d
.
data
(),
i
=
d
.
attr
(
"
data-parent
"
),
j
=
i
&&
a
(
i
);
g
&&
g
.
transitioning
||
(
j
&&
j
.
find
(
'
[data-toggle=collapse][data-parent="
'
+
i
+
'
"]
'
).
not
(
d
).
addClass
(
"
collapsed
"
),
d
[
f
.
hasClass
(
"
in
"
)?
"
addClass
"
:
"
removeClass
"
](
"
collapsed
"
)),
f
.
collapse
(
h
)})}(
jQuery
),
+
function
(
a
){
"
use strict
"
;
function
b
(
b
){
a
(
d
).
remove
(),
a
(
e
).
each
(
function
(){
var
d
=
c
(
a
(
this
)),
e
=
{
relatedTarget
:
this
};
d
.
hasClass
(
"
open
"
)
&&
(
d
.
trigger
(
b
=
a
.
Event
(
"
hide.bs.dropdown
"
,
e
)),
b
.
isDefaultPrevented
()
||
d
.
removeClass
(
"
open
"
).
trigger
(
"
hidden.bs.dropdown
"
,
e
))})}
function
c
(
b
){
var
c
=
b
.
attr
(
"
data-target
"
);
c
||
(
c
=
b
.
attr
(
"
href
"
),
c
=
c
&&
/#
[
A-Za-z
]
/
.
test
(
c
)
&&
c
.
replace
(
/.*
(?=
#
[^\s]
*$
)
/
,
""
));
var
d
=
c
&&
a
(
c
);
return
d
&&
d
.
length
?
d
:
b
.
parent
()}
var
d
=
"
.dropdown-backdrop
"
,
e
=
"
[data-toggle=dropdown]
"
,
f
=
function
(
b
){
a
(
b
).
on
(
"
click.bs.dropdown
"
,
this
.
toggle
)};
f
.
prototype
.
toggle
=
function
(
d
){
var
e
=
a
(
this
);
if
(
!
e
.
is
(
"
.disabled, :disabled
"
)){
var
f
=
c
(
e
),
g
=
f
.
hasClass
(
"
open
"
);
if
(
b
(),
!
g
){
"
ontouchstart
"
in
document
.
documentElement
&&!
f
.
closest
(
"
.navbar-nav
"
).
length
&&
a
(
'
<div class="dropdown-backdrop"/>
'
).
insertAfter
(
a
(
this
)).
on
(
"
click
"
,
b
);
var
h
=
{
relatedTarget
:
this
};
if
(
f
.
trigger
(
d
=
a
.
Event
(
"
show.bs.dropdown
"
,
h
)),
d
.
isDefaultPrevented
())
return
;
f
.
toggleClass
(
"
open
"
).
trigger
(
"
shown.bs.dropdown
"
,
h
),
e
.
focus
()}
return
!
1
}},
f
.
prototype
.
keydown
=
function
(
b
){
if
(
/
(
38|40|27
)
/
.
test
(
b
.
keyCode
)){
var
d
=
a
(
this
);
if
(
b
.
preventDefault
(),
b
.
stopPropagation
(),
!
d
.
is
(
"
.disabled, :disabled
"
)){
var
f
=
c
(
d
),
g
=
f
.
hasClass
(
"
open
"
);
if
(
!
g
||
g
&&
27
==
b
.
keyCode
)
return
27
==
b
.
which
&&
f
.
find
(
e
).
focus
(),
d
.
click
();
var
h
=
"
li:not(.divider):visible a
"
,
i
=
f
.
find
(
"
[role=menu]
"
+
h
+
"
, [role=listbox]
"
+
h
);
if
(
i
.
length
){
var
j
=
i
.
index
(
i
.
filter
(
"
:focus
"
));
38
==
b
.
keyCode
&&
j
>
0
&&
j
--
,
40
==
b
.
keyCode
&&
j
<
i
.
length
-
1
&&
j
++
,
~
j
||
(
j
=
0
),
i
.
eq
(
j
).
focus
()}}}};
var
g
=
a
.
fn
.
dropdown
;
a
.
fn
.
dropdown
=
function
(
b
){
return
this
.
each
(
function
(){
var
c
=
a
(
this
),
d
=
c
.
data
(
"
bs.dropdown
"
);
d
||
c
.
data
(
"
bs.dropdown
"
,
d
=
new
f
(
this
)),
"
string
"
==
typeof
b
&&
d
[
b
].
call
(
c
)})},
a
.
fn
.
dropdown
.
Constructor
=
f
,
a
.
fn
.
dropdown
.
noConflict
=
function
(){
return
a
.
fn
.
dropdown
=
g
,
this
},
a
(
document
).
on
(
"
click.bs.dropdown.data-api
"
,
b
).
on
(
"
click.bs.dropdown.data-api
"
,
"
.dropdown form
"
,
function
(
a
){
a
.
stopPropagation
()}).
on
(
"
click.bs.dropdown.data-api
"
,
e
,
f
.
prototype
.
toggle
).
on
(
"
keydown.bs.dropdown.data-api
"
,
e
+
"
, [role=menu], [role=listbox]
"
,
f
.
prototype
.
keydown
)}(
jQuery
),
+
function
(
a
){
"
use strict
"
;
var
b
=
function
(
b
,
c
){
this
.
options
=
c
,
this
.
$element
=
a
(
b
),
this
.
$backdrop
=
this
.
isShown
=
null
,
this
.
options
.
remote
&&
this
.
$element
.
find
(
"
.modal-content
"
).
load
(
this
.
options
.
remote
,
a
.
proxy
(
function
(){
this
.
$element
.
trigger
(
"
loaded.bs.modal
"
)},
this
))};
b
.
DEFAULTS
=
{
backdrop
:
!
0
,
keyboard
:
!
0
,
show
:
!
0
},
b
.
prototype
.
toggle
=
function
(
a
){
return
this
[
this
.
isShown
?
"
hide
"
:
"
show
"
](
a
)},
b
.
prototype
.
show
=
function
(
b
){
var
c
=
this
,
d
=
a
.
Event
(
"
show.bs.modal
"
,{
relatedTarget
:
b
});
this
.
$element
.
trigger
(
d
),
this
.
isShown
||
d
.
isDefaultPrevented
()
||
(
this
.
isShown
=!
0
,
this
.
escape
(),
this
.
$element
.
on
(
"
click.dismiss.modal
"
,
'
[data-dismiss="modal"]
'
,
a
.
proxy
(
this
.
hide
,
this
)),
this
.
backdrop
(
function
(){
var
d
=
a
.
support
.
transition
&&
c
.
$element
.
hasClass
(
"
fade
"
);
c
.
$element
.
parent
().
length
||
c
.
$element
.
appendTo
(
document
.
body
),
c
.
$element
.
show
().
scrollTop
(
0
),
d
&&
c
.
$element
[
0
].
offsetWidth
,
c
.
$element
.
addClass
(
"
in
"
).
attr
(
"
aria-hidden
"
,
!
1
),
c
.
enforceFocus
();
var
e
=
a
.
Event
(
"
shown.bs.modal
"
,{
relatedTarget
:
b
});
d
?
c
.
$element
.
find
(
"
.modal-dialog
"
).
one
(
a
.
support
.
transition
.
end
,
function
(){
c
.
$element
.
focus
().
trigger
(
e
)}).
emulateTransitionEnd
(
300
):
c
.
$element
.
focus
().
trigger
(
e
)}))},
b
.
prototype
.
hide
=
function
(
b
){
b
&&
b
.
preventDefault
(),
b
=
a
.
Event
(
"
hide.bs.modal
"
),
this
.
$element
.
trigger
(
b
),
this
.
isShown
&&!
b
.
isDefaultPrevented
()
&&
(
this
.
isShown
=!
1
,
this
.
escape
(),
a
(
document
).
off
(
"
focusin.bs.modal
"
),
this
.
$element
.
removeClass
(
"
in
"
).
attr
(
"
aria-hidden
"
,
!
0
).
off
(
"
click.dismiss.modal
"
),
a
.
support
.
transition
&&
this
.
$element
.
hasClass
(
"
fade
"
)?
this
.
$element
.
one
(
a
.
support
.
transition
.
end
,
a
.
proxy
(
this
.
hideModal
,
this
)).
emulateTransitionEnd
(
300
):
this
.
hideModal
())},
b
.
prototype
.
enforceFocus
=
function
(){
a
(
document
).
off
(
"
focusin.bs.modal
"
).
on
(
"
focusin.bs.modal
"
,
a
.
proxy
(
function
(
a
){
this
.
$element
[
0
]
===
a
.
target
||
this
.
$element
.
has
(
a
.
target
).
length
||
this
.
$element
.
focus
()},
this
))},
b
.
prototype
.
escape
=
function
(){
this
.
isShown
&&
this
.
options
.
keyboard
?
this
.
$element
.
on
(
"
keyup.dismiss.bs.modal
"
,
a
.
proxy
(
function
(
a
){
27
==
a
.
which
&&
this
.
hide
()},
this
)):
this
.
isShown
||
this
.
$element
.
off
(
"
keyup.dismiss.bs.modal
"
)},
b
.
prototype
.
hideModal
=
function
(){
var
a
=
this
;
this
.
$element
.
hide
(),
this
.
backdrop
(
function
(){
a
.
removeBackdrop
(),
a
.
$element
.
trigger
(
"
hidden.bs.modal
"
)})},
b
.
prototype
.
removeBackdrop
=
function
(){
this
.
$backdrop
&&
this
.
$backdrop
.
remove
(),
this
.
$backdrop
=
null
},
b
.
prototype
.
backdrop
=
function
(
b
){
var
c
=
this
.
$element
.
hasClass
(
"
fade
"
)?
"
fade
"
:
""
;
if
(
this
.
isShown
&&
this
.
options
.
backdrop
){
var
d
=
a
.
support
.
transition
&&
c
;
if
(
this
.
$backdrop
=
a
(
'
<div class="modal-backdrop
'
+
c
+
'
" />
'
).
appendTo
(
document
.
body
),
this
.
$element
.
on
(
"
click.dismiss.modal
"
,
a
.
proxy
(
function
(
a
){
a
.
target
===
a
.
currentTarget
&&
(
"
static
"
==
this
.
options
.
backdrop
?
this
.
$element
[
0
].
focus
.
call
(
this
.
$element
[
0
]):
this
.
hide
.
call
(
this
))},
this
)),
d
&&
this
.
$backdrop
[
0
].
offsetWidth
,
this
.
$backdrop
.
addClass
(
"
in
"
),
!
b
)
return
;
d
?
this
.
$backdrop
.
one
(
a
.
support
.
transition
.
end
,
b
).
emulateTransitionEnd
(
150
):
b
()}
else
!
this
.
isShown
&&
this
.
$backdrop
?(
this
.
$backdrop
.
removeClass
(
"
in
"
),
a
.
support
.
transition
&&
this
.
$element
.
hasClass
(
"
fade
"
)?
this
.
$backdrop
.
one
(
a
.
support
.
transition
.
end
,
b
).
emulateTransitionEnd
(
150
):
b
()):
b
&&
b
()};
var
c
=
a
.
fn
.
modal
;
a
.
fn
.
modal
=
function
(
c
,
d
){
return
this
.
each
(
function
(){
var
e
=
a
(
this
),
f
=
e
.
data
(
"
bs.modal
"
),
g
=
a
.
extend
({},
b
.
DEFAULTS
,
e
.
data
(),
"
object
"
==
typeof
c
&&
c
);
f
||
e
.
data
(
"
bs.modal
"
,
f
=
new
b
(
this
,
g
)),
"
string
"
==
typeof
c
?
f
[
c
](
d
):
g
.
show
&&
f
.
show
(
d
)})},
a
.
fn
.
modal
.
Constructor
=
b
,
a
.
fn
.
modal
.
noConflict
=
function
(){
return
a
.
fn
.
modal
=
c
,
this
},
a
(
document
).
on
(
"
click.bs.modal.data-api
"
,
'
[data-toggle="modal"]
'
,
function
(
b
){
var
c
=
a
(
this
),
d
=
c
.
attr
(
"
href
"
),
e
=
a
(
c
.
attr
(
"
data-target
"
)
||
d
&&
d
.
replace
(
/.*
(?=
#
[^\s]
+$
)
/
,
""
)),
f
=
e
.
data
(
"
bs.modal
"
)?
"
toggle
"
:
a
.
extend
({
remote
:
!
/#/
.
test
(
d
)
&&
d
},
e
.
data
(),
c
.
data
());
c
.
is
(
"
a
"
)
&&
b
.
preventDefault
(),
e
.
modal
(
f
,
this
).
one
(
"
hide
"
,
function
(){
c
.
is
(
"
:visible
"
)
&&
c
.
focus
()})}),
a
(
document
).
on
(
"
show.bs.modal
"
,
"
.modal
"
,
function
(){
a
(
document
.
body
).
addClass
(
"
modal-open
"
)}).
on
(
"
hidden.bs.modal
"
,
"
.modal
"
,
function
(){
a
(
document
.
body
).
removeClass
(
"
modal-open
"
)})}(
jQuery
),
+
function
(
a
){
"
use strict
"
;
var
b
=
function
(
a
,
b
){
this
.
type
=
this
.
options
=
this
.
enabled
=
this
.
timeout
=
this
.
hoverState
=
this
.
$element
=
null
,
this
.
init
(
"
tooltip
"
,
a
,
b
)};
b
.
DEFAULTS
=
{
animation
:
!
0
,
placement
:
"
top
"
,
selector
:
!
1
,
template
:
'
<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>
'
,
trigger
:
"
hover focus
"
,
title
:
""
,
delay
:
0
,
html
:
!
1
,
container
:
!
1
},
b
.
prototype
.
init
=
function
(
b
,
c
,
d
){
this
.
enabled
=!
0
,
this
.
type
=
b
,
this
.
$element
=
a
(
c
),
this
.
options
=
this
.
getOptions
(
d
);
for
(
var
e
=
this
.
options
.
trigger
.
split
(
"
"
),
f
=
e
.
length
;
f
--
;){
var
g
=
e
[
f
];
if
(
"
click
"
==
g
)
this
.
$element
.
on
(
"
click.
"
+
this
.
type
,
this
.
options
.
selector
,
a
.
proxy
(
this
.
toggle
,
this
));
else
if
(
"
manual
"
!=
g
){
var
h
=
"
hover
"
==
g
?
"
mouseenter
"
:
"
focusin
"
,
i
=
"
hover
"
==
g
?
"
mouseleave
"
:
"
focusout
"
;
this
.
$element
.
on
(
h
+
"
.
"
+
this
.
type
,
this
.
options
.
selector
,
a
.
proxy
(
this
.
enter
,
this
)),
this
.
$element
.
on
(
i
+
"
.
"
+
this
.
type
,
this
.
options
.
selector
,
a
.
proxy
(
this
.
leave
,
this
))}}
this
.
options
.
selector
?
this
.
_options
=
a
.
extend
({},
this
.
options
,{
trigger
:
"
manual
"
,
selector
:
""
}):
this
.
fixTitle
()},
b
.
prototype
.
getDefaults
=
function
(){
return
b
.
DEFAULTS
},
b
.
prototype
.
getOptions
=
function
(
b
){
return
b
=
a
.
extend
({},
this
.
getDefaults
(),
this
.
$element
.
data
(),
b
),
b
.
delay
&&
"
number
"
==
typeof
b
.
delay
&&
(
b
.
delay
=
{
show
:
b
.
delay
,
hide
:
b
.
delay
}),
b
},
b
.
prototype
.
getDelegateOptions
=
function
(){
var
b
=
{},
c
=
this
.
getDefaults
();
return
this
.
_options
&&
a
.
each
(
this
.
_options
,
function
(
a
,
d
){
c
[
a
]
!=
d
&&
(
b
[
a
]
=
d
)}),
b
},
b
.
prototype
.
enter
=
function
(
b
){
var
c
=
b
instanceof
this
.
constructor
?
b
:
a
(
b
.
currentTarget
)[
this
.
type
](
this
.
getDelegateOptions
()).
data
(
"
bs.
"
+
this
.
type
);
return
clearTimeout
(
c
.
timeout
),
c
.
hoverState
=
"
in
"
,
c
.
options
.
delay
&&
c
.
options
.
delay
.
show
?(
c
.
timeout
=
setTimeout
(
function
(){
"
in
"
==
c
.
hoverState
&&
c
.
show
()},
c
.
options
.
delay
.
show
),
void
0
):
c
.
show
()},
b
.
prototype
.
leave
=
function
(
b
){
var
c
=
b
instanceof
this
.
constructor
?
b
:
a
(
b
.
currentTarget
)[
this
.
type
](
this
.
getDelegateOptions
()).
data
(
"
bs.
"
+
this
.
type
);
return
clearTimeout
(
c
.
timeout
),
c
.
hoverState
=
"
out
"
,
c
.
options
.
delay
&&
c
.
options
.
delay
.
hide
?(
c
.
timeout
=
setTimeout
(
function
(){
"
out
"
==
c
.
hoverState
&&
c
.
hide
()},
c
.
options
.
delay
.
hide
),
void
0
):
c
.
hide
()},
b
.
prototype
.
show
=
function
(){
var
b
=
a
.
Event
(
"
show.bs.
"
+
this
.
type
);
if
(
this
.
hasContent
()
&&
this
.
enabled
){
if
(
this
.
$element
.
trigger
(
b
),
b
.
isDefaultPrevented
())
return
;
var
c
=
this
,
d
=
this
.
tip
();
this
.
setContent
(),
this
.
options
.
animation
&&
d
.
addClass
(
"
fade
"
);
var
e
=
"
function
"
==
typeof
this
.
options
.
placement
?
this
.
options
.
placement
.
call
(
this
,
d
[
0
],
this
.
$element
[
0
]):
this
.
options
.
placement
,
f
=
/
\s?
auto
?\s?
/i
,
g
=
f
.
test
(
e
);
g
&&
(
e
=
e
.
replace
(
f
,
""
)
||
"
top
"
),
d
.
detach
().
css
({
top
:
0
,
left
:
0
,
display
:
"
block
"
}).
addClass
(
e
),
this
.
options
.
container
?
d
.
appendTo
(
this
.
options
.
container
):
d
.
insertAfter
(
this
.
$element
);
var
h
=
this
.
getPosition
(),
i
=
d
[
0
].
offsetWidth
,
j
=
d
[
0
].
offsetHeight
;
if
(
g
){
var
k
=
this
.
$element
.
parent
(),
l
=
e
,
m
=
document
.
documentElement
.
scrollTop
||
document
.
body
.
scrollTop
,
n
=
"
body
"
==
this
.
options
.
container
?
window
.
innerWidth
:
k
.
outerWidth
(),
o
=
"
body
"
==
this
.
options
.
container
?
window
.
innerHeight
:
k
.
outerHeight
(),
p
=
"
body
"
==
this
.
options
.
container
?
0
:
k
.
offset
().
left
;
e
=
"
bottom
"
==
e
&&
h
.
top
+
h
.
height
+
j
-
m
>
o
?
"
top
"
:
"
top
"
==
e
&&
h
.
top
-
m
-
j
<
0
?
"
bottom
"
:
"
right
"
==
e
&&
h
.
right
+
i
>
n
?
"
left
"
:
"
left
"
==
e
&&
h
.
left
-
i
<
p
?
"
right
"
:
e
,
d
.
removeClass
(
l
).
addClass
(
e
)}
var
q
=
this
.
getCalculatedOffset
(
e
,
h
,
i
,
j
);
this
.
applyPlacement
(
q
,
e
),
this
.
hoverState
=
null
;
var
r
=
function
(){
c
.
$element
.
trigger
(
"
shown.bs.
"
+
c
.
type
)};
a
.
support
.
transition
&&
this
.
$tip
.
hasClass
(
"
fade
"
)?
d
.
one
(
a
.
support
.
transition
.
end
,
r
).
emulateTransitionEnd
(
150
):
r
()}},
b
.
prototype
.
applyPlacement
=
function
(
b
,
c
){
var
d
,
e
=
this
.
tip
(),
f
=
e
[
0
].
offsetWidth
,
g
=
e
[
0
].
offsetHeight
,
h
=
parseInt
(
e
.
css
(
"
margin-top
"
),
10
),
i
=
parseInt
(
e
.
css
(
"
margin-left
"
),
10
);
isNaN
(
h
)
&&
(
h
=
0
),
isNaN
(
i
)
&&
(
i
=
0
),
b
.
top
=
b
.
top
+
h
,
b
.
left
=
b
.
left
+
i
,
a
.
offset
.
setOffset
(
e
[
0
],
a
.
extend
({
using
:
function
(
a
){
e
.
css
({
top
:
Math
.
round
(
a
.
top
),
left
:
Math
.
round
(
a
.
left
)})}},
b
),
0
),
e
.
addClass
(
"
in
"
);
var
j
=
e
[
0
].
offsetWidth
,
k
=
e
[
0
].
offsetHeight
;
if
(
"
top
"
==
c
&&
k
!=
g
&&
(
d
=!
0
,
b
.
top
=
b
.
top
+
g
-
k
),
/bottom|top/
.
test
(
c
)){
var
l
=
0
;
b
.
left
<
0
&&
(
l
=-
2
*
b
.
left
,
b
.
left
=
0
,
e
.
offset
(
b
),
j
=
e
[
0
].
offsetWidth
,
k
=
e
[
0
].
offsetHeight
),
this
.
replaceArrow
(
l
-
f
+
j
,
j
,
"
left
"
)}
else
this
.
replaceArrow
(
k
-
g
,
k
,
"
top
"
);
d
&&
e
.
offset
(
b
)},
b
.
prototype
.
replaceArrow
=
function
(
a
,
b
,
c
){
this
.
arrow
().
css
(
c
,
a
?
50
*
(
1
-
a
/
b
)
+
"
%
"
:
""
)},
b
.
prototype
.
setContent
=
function
(){
var
a
=
this
.
tip
(),
b
=
this
.
getTitle
();
a
.
find
(
"
.tooltip-inner
"
)[
this
.
options
.
html
?
"
html
"
:
"
text
"
](
b
),
a
.
removeClass
(
"
fade in top bottom left right
"
)},
b
.
prototype
.
hide
=
function
(){
function
b
(){
"
in
"
!=
c
.
hoverState
&&
d
.
detach
(),
c
.
$element
.
trigger
(
"
hidden.bs.
"
+
c
.
type
)}
var
c
=
this
,
d
=
this
.
tip
(),
e
=
a
.
Event
(
"
hide.bs.
"
+
this
.
type
);
return
this
.
$element
.
trigger
(
e
),
e
.
isDefaultPrevented
()?
void
0
:(
d
.
removeClass
(
"
in
"
),
a
.
support
.
transition
&&
this
.
$tip
.
hasClass
(
"
fade
"
)?
d
.
one
(
a
.
support
.
transition
.
end
,
b
).
emulateTransitionEnd
(
150
):
b
(),
this
.
hoverState
=
null
,
this
)},
b
.
prototype
.
fixTitle
=
function
(){
var
a
=
this
.
$element
;(
a
.
attr
(
"
title
"
)
||
"
string
"
!=
typeof
a
.
attr
(
"
data-original-title
"
))
&&
a
.
attr
(
"
data-original-title
"
,
a
.
attr
(
"
title
"
)
||
""
).
attr
(
"
title
"
,
""
)},
b
.
prototype
.
hasContent
=
function
(){
return
this
.
getTitle
()},
b
.
prototype
.
getPosition
=
function
(){
var
b
=
this
.
$element
[
0
];
return
a
.
extend
({},
"
function
"
==
typeof
b
.
getBoundingClientRect
?
b
.
getBoundingClientRect
():{
width
:
b
.
offsetWidth
,
height
:
b
.
offsetHeight
},
this
.
$element
.
offset
())},
b
.
prototype
.
getCalculatedOffset
=
function
(
a
,
b
,
c
,
d
){
return
"
bottom
"
==
a
?{
top
:
b
.
top
+
b
.
height
,
left
:
b
.
left
+
b
.
width
/
2
-
c
/
2
}:
"
top
"
==
a
?{
top
:
b
.
top
-
d
,
left
:
b
.
left
+
b
.
width
/
2
-
c
/
2
}:
"
left
"
==
a
?{
top
:
b
.
top
+
b
.
height
/
2
-
d
/
2
,
left
:
b
.
left
-
c
}:{
top
:
b
.
top
+
b
.
height
/
2
-
d
/
2
,
left
:
b
.
left
+
b
.
width
}},
b
.
prototype
.
getTitle
=
function
(){
var
a
,
b
=
this
.
$element
,
c
=
this
.
options
;
return
a
=
b
.
attr
(
"
data-original-title
"
)
||
(
"
function
"
==
typeof
c
.
title
?
c
.
title
.
call
(
b
[
0
]):
c
.
title
)},
b
.
prototype
.
tip
=
function
(){
return
this
.
$tip
=
this
.
$tip
||
a
(
this
.
options
.
template
)},
b
.
prototype
.
arrow
=
function
(){
return
this
.
$arrow
=
this
.
$arrow
||
this
.
tip
().
find
(
"
.tooltip-arrow
"
)},
b
.
prototype
.
validate
=
function
(){
this
.
$element
[
0
].
parentNode
||
(
this
.
hide
(),
this
.
$element
=
null
,
this
.
options
=
null
)},
b
.
prototype
.
enable
=
function
(){
this
.
enabled
=!
0
},
b
.
prototype
.
disable
=
function
(){
this
.
enabled
=!
1
},
b
.
prototype
.
toggleEnabled
=
function
(){
this
.
enabled
=!
this
.
enabled
},
b
.
prototype
.
toggle
=
function
(
b
){
var
c
=
b
?
a
(
b
.
currentTarget
)[
this
.
type
](
this
.
getDelegateOptions
()).
data
(
"
bs.
"
+
this
.
type
):
this
;
c
.
tip
().
hasClass
(
"
in
"
)?
c
.
leave
(
c
):
c
.
enter
(
c
)},
b
.
prototype
.
destroy
=
function
(){
clearTimeout
(
this
.
timeout
),
this
.
hide
().
$element
.
off
(
"
.
"
+
this
.
type
).
removeData
(
"
bs.
"
+
this
.
type
)};
var
c
=
a
.
fn
.
tooltip
;
a
.
fn
.
tooltip
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
bs.tooltip
"
),
f
=
"
object
"
==
typeof
c
&&
c
;(
e
||
"
destroy
"
!=
c
)
&&
(
e
||
d
.
data
(
"
bs.tooltip
"
,
e
=
new
b
(
this
,
f
)),
"
string
"
==
typeof
c
&&
e
[
c
]())})},
a
.
fn
.
tooltip
.
Constructor
=
b
,
a
.
fn
.
tooltip
.
noConflict
=
function
(){
return
a
.
fn
.
tooltip
=
c
,
this
}}(
jQuery
),
+
function
(
a
){
"
use strict
"
;
var
b
=
function
(
a
,
b
){
this
.
init
(
"
popover
"
,
a
,
b
)};
if
(
!
a
.
fn
.
tooltip
)
throw
new
Error
(
"
Popover requires tooltip.js
"
);
b
.
DEFAULTS
=
a
.
extend
({},
a
.
fn
.
tooltip
.
Constructor
.
DEFAULTS
,{
placement
:
"
right
"
,
trigger
:
"
click
"
,
content
:
""
,
template
:
'
<div class="popover"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>
'
}),
b
.
prototype
=
a
.
extend
({},
a
.
fn
.
tooltip
.
Constructor
.
prototype
),
b
.
prototype
.
constructor
=
b
,
b
.
prototype
.
getDefaults
=
function
(){
return
b
.
DEFAULTS
},
b
.
prototype
.
setContent
=
function
(){
var
a
=
this
.
tip
(),
b
=
this
.
getTitle
(),
c
=
this
.
getContent
();
a
.
find
(
"
.popover-title
"
)[
this
.
options
.
html
?
"
html
"
:
"
text
"
](
b
),
a
.
find
(
"
.popover-content
"
)[
this
.
options
.
html
?
"
string
"
==
typeof
c
?
"
html
"
:
"
append
"
:
"
text
"
](
c
),
a
.
removeClass
(
"
fade top bottom left right in
"
),
a
.
find
(
"
.popover-title
"
).
html
()
||
a
.
find
(
"
.popover-title
"
).
hide
()},
b
.
prototype
.
hasContent
=
function
(){
return
this
.
getTitle
()
||
this
.
getContent
()},
b
.
prototype
.
getContent
=
function
(){
var
a
=
this
.
$element
,
b
=
this
.
options
;
return
a
.
attr
(
"
data-content
"
)
||
(
"
function
"
==
typeof
b
.
content
?
b
.
content
.
call
(
a
[
0
]):
b
.
content
)},
b
.
prototype
.
arrow
=
function
(){
return
this
.
$arrow
=
this
.
$arrow
||
this
.
tip
().
find
(
"
.arrow
"
)},
b
.
prototype
.
tip
=
function
(){
return
this
.
$tip
||
(
this
.
$tip
=
a
(
this
.
options
.
template
)),
this
.
$tip
};
var
c
=
a
.
fn
.
popover
;
a
.
fn
.
popover
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
bs.popover
"
),
f
=
"
object
"
==
typeof
c
&&
c
;(
e
||
"
destroy
"
!=
c
)
&&
(
e
||
d
.
data
(
"
bs.popover
"
,
e
=
new
b
(
this
,
f
)),
"
string
"
==
typeof
c
&&
e
[
c
]())})},
a
.
fn
.
popover
.
Constructor
=
b
,
a
.
fn
.
popover
.
noConflict
=
function
(){
return
a
.
fn
.
popover
=
c
,
this
}}(
jQuery
),
+
function
(
a
){
"
use strict
"
;
function
b
(
c
,
d
){
var
e
,
f
=
a
.
proxy
(
this
.
process
,
this
);
this
.
$element
=
a
(
c
).
is
(
"
body
"
)?
a
(
window
):
a
(
c
),
this
.
$body
=
a
(
"
body
"
),
this
.
$scrollElement
=
this
.
$element
.
on
(
"
scroll.bs.scroll-spy.data-api
"
,
f
),
this
.
options
=
a
.
extend
({},
b
.
DEFAULTS
,
d
),
this
.
selector
=
(
this
.
options
.
target
||
(
e
=
a
(
c
).
attr
(
"
href
"
))
&&
e
.
replace
(
/.*
(?=
#
[^\s]
+$
)
/
,
""
)
||
""
)
+
"
.nav li > a
"
,
this
.
offsets
=
a
([]),
this
.
targets
=
a
([]),
this
.
activeTarget
=
null
,
this
.
refresh
(),
this
.
process
()}
b
.
DEFAULTS
=
{
offset
:
10
},
b
.
prototype
.
refresh
=
function
(){
var
b
=
this
.
$element
[
0
]
==
window
?
"
offset
"
:
"
position
"
;
this
.
offsets
=
a
([]),
this
.
targets
=
a
([]);{
var
c
=
this
;
this
.
$body
.
find
(
this
.
selector
).
map
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
target
"
)
||
d
.
attr
(
"
href
"
),
f
=
/^#./
.
test
(
e
)
&&
a
(
e
);
return
f
&&
f
.
length
&&
f
.
is
(
"
:visible
"
)
&&
[[
f
[
b
]().
top
+
(
!
a
.
isWindow
(
c
.
$scrollElement
.
get
(
0
))
&&
c
.
$scrollElement
.
scrollTop
()),
e
]]
||
null
}).
sort
(
function
(
a
,
b
){
return
a
[
0
]
-
b
[
0
]}).
each
(
function
(){
c
.
offsets
.
push
(
this
[
0
]),
c
.
targets
.
push
(
this
[
1
])})}},
b
.
prototype
.
process
=
function
(){
var
a
,
b
=
this
.
$scrollElement
.
scrollTop
()
+
this
.
options
.
offset
,
c
=
this
.
$scrollElement
[
0
].
scrollHeight
||
this
.
$body
[
0
].
scrollHeight
,
d
=
c
-
this
.
$scrollElement
.
height
(),
e
=
this
.
offsets
,
f
=
this
.
targets
,
g
=
this
.
activeTarget
;
if
(
b
>=
d
)
return
g
!=
(
a
=
f
.
last
()[
0
])
&&
this
.
activate
(
a
);
if
(
g
&&
b
<=
e
[
0
])
return
g
!=
(
a
=
f
[
0
])
&&
this
.
activate
(
a
);
for
(
a
=
e
.
length
;
a
--
;)
g
!=
f
[
a
]
&&
b
>=
e
[
a
]
&&
(
!
e
[
a
+
1
]
||
b
<=
e
[
a
+
1
])
&&
this
.
activate
(
f
[
a
])},
b
.
prototype
.
activate
=
function
(
b
){
this
.
activeTarget
=
b
,
a
(
this
.
selector
).
parentsUntil
(
this
.
options
.
target
,
"
.active
"
).
removeClass
(
"
active
"
);
var
c
=
this
.
selector
+
'
[data-target="
'
+
b
+
'
"],
'
+
this
.
selector
+
'
[href="
'
+
b
+
'
"]
'
,
d
=
a
(
c
).
parents
(
"
li
"
).
addClass
(
"
active
"
);
d
.
parent
(
"
.dropdown-menu
"
).
length
&&
(
d
=
d
.
closest
(
"
li.dropdown
"
).
addClass
(
"
active
"
)),
d
.
trigger
(
"
activate.bs.scrollspy
"
)};
var
c
=
a
.
fn
.
scrollspy
;
a
.
fn
.
scrollspy
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
bs.scrollspy
"
),
f
=
"
object
"
==
typeof
c
&&
c
;
e
||
d
.
data
(
"
bs.scrollspy
"
,
e
=
new
b
(
this
,
f
)),
"
string
"
==
typeof
c
&&
e
[
c
]()})},
a
.
fn
.
scrollspy
.
Constructor
=
b
,
a
.
fn
.
scrollspy
.
noConflict
=
function
(){
return
a
.
fn
.
scrollspy
=
c
,
this
},
a
(
window
).
on
(
"
load
"
,
function
(){
a
(
'
[data-spy="scroll"]
'
).
each
(
function
(){
var
b
=
a
(
this
);
b
.
scrollspy
(
b
.
data
())})})}(
jQuery
),
+
function
(
a
){
"
use strict
"
;
var
b
=
function
(
b
){
this
.
element
=
a
(
b
)};
b
.
prototype
.
show
=
function
(){
var
b
=
this
.
element
,
c
=
b
.
closest
(
"
ul:not(.dropdown-menu)
"
),
d
=
b
.
data
(
"
target
"
);
if
(
d
||
(
d
=
b
.
attr
(
"
href
"
),
d
=
d
&&
d
.
replace
(
/.*
(?=
#
[^\s]
*$
)
/
,
""
)),
!
b
.
parent
(
"
li
"
).
hasClass
(
"
active
"
)){
var
e
=
c
.
find
(
"
.active:last a
"
)[
0
],
f
=
a
.
Event
(
"
show.bs.tab
"
,{
relatedTarget
:
e
});
if
(
b
.
trigger
(
f
),
!
f
.
isDefaultPrevented
()){
var
g
=
a
(
d
);
this
.
activate
(
b
.
parent
(
"
li
"
),
c
),
this
.
activate
(
g
,
g
.
parent
(),
function
(){
b
.
trigger
({
type
:
"
shown.bs.tab
"
,
relatedTarget
:
e
})})}}},
b
.
prototype
.
activate
=
function
(
b
,
c
,
d
){
function
e
(){
f
.
removeClass
(
"
active
"
).
find
(
"
> .dropdown-menu > .active
"
).
removeClass
(
"
active
"
),
b
.
addClass
(
"
active
"
),
g
?(
b
[
0
].
offsetWidth
,
b
.
addClass
(
"
in
"
)):
b
.
removeClass
(
"
fade
"
),
b
.
parent
(
"
.dropdown-menu
"
)
&&
b
.
closest
(
"
li.dropdown
"
).
addClass
(
"
active
"
),
d
&&
d
()}
var
f
=
c
.
find
(
"
> .active
"
),
g
=
d
&&
a
.
support
.
transition
&&
f
.
hasClass
(
"
fade
"
);
g
?
f
.
one
(
a
.
support
.
transition
.
end
,
e
).
emulateTransitionEnd
(
150
):
e
(),
f
.
removeClass
(
"
in
"
)};
var
c
=
a
.
fn
.
tab
;
a
.
fn
.
tab
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
bs.tab
"
);
e
||
d
.
data
(
"
bs.tab
"
,
e
=
new
b
(
this
)),
"
string
"
==
typeof
c
&&
e
[
c
]()})},
a
.
fn
.
tab
.
Constructor
=
b
,
a
.
fn
.
tab
.
noConflict
=
function
(){
return
a
.
fn
.
tab
=
c
,
this
},
a
(
document
).
on
(
"
click.bs.tab.data-api
"
,
'
[data-toggle="tab"], [data-toggle="pill"]
'
,
function
(
b
){
b
.
preventDefault
(),
a
(
this
).
tab
(
"
show
"
)})}(
jQuery
),
+
function
(
a
){
"
use strict
"
;
var
b
=
function
(
c
,
d
){
this
.
options
=
a
.
extend
({},
b
.
DEFAULTS
,
d
),
this
.
$window
=
a
(
window
).
on
(
"
scroll.bs.affix.data-api
"
,
a
.
proxy
(
this
.
checkPosition
,
this
)).
on
(
"
click.bs.affix.data-api
"
,
a
.
proxy
(
this
.
checkPositionWithEventLoop
,
this
)),
this
.
$element
=
a
(
c
),
this
.
affixed
=
this
.
unpin
=
this
.
pinnedOffset
=
null
,
this
.
checkPosition
()};
b
.
RESET
=
"
affix affix-top affix-bottom
"
,
b
.
DEFAULTS
=
{
offset
:
0
},
b
.
prototype
.
getPinnedOffset
=
function
(){
if
(
this
.
pinnedOffset
)
return
this
.
pinnedOffset
;
this
.
$element
.
removeClass
(
b
.
RESET
).
addClass
(
"
affix
"
);
var
a
=
this
.
$window
.
scrollTop
(),
c
=
this
.
$element
.
offset
();
return
this
.
pinnedOffset
=
c
.
top
-
a
},
b
.
prototype
.
checkPositionWithEventLoop
=
function
(){
setTimeout
(
a
.
proxy
(
this
.
checkPosition
,
this
),
1
)},
b
.
prototype
.
checkPosition
=
function
(){
if
(
this
.
$element
.
is
(
"
:visible
"
)){
var
c
=
a
(
document
).
height
(),
d
=
this
.
$window
.
scrollTop
(),
e
=
this
.
$element
.
offset
(),
f
=
this
.
options
.
offset
,
g
=
f
.
top
,
h
=
f
.
bottom
;
"
top
"
==
this
.
affixed
&&
(
e
.
top
+=
d
),
"
object
"
!=
typeof
f
&&
(
h
=
g
=
f
),
"
function
"
==
typeof
g
&&
(
g
=
f
.
top
(
this
.
$element
)),
"
function
"
==
typeof
h
&&
(
h
=
f
.
bottom
(
this
.
$element
));
var
i
=
null
!=
this
.
unpin
&&
d
+
this
.
unpin
<=
e
.
top
?
!
1
:
null
!=
h
&&
e
.
top
+
this
.
$element
.
height
()
>=
c
-
h
?
"
bottom
"
:
null
!=
g
&&
g
>=
d
?
"
top
"
:
!
1
;
if
(
this
.
affixed
!==
i
){
this
.
unpin
&&
this
.
$element
.
css
(
"
top
"
,
""
);
var
j
=
"
affix
"
+
(
i
?
"
-
"
+
i
:
""
),
k
=
a
.
Event
(
j
+
"
.bs.affix
"
);
this
.
$element
.
trigger
(
k
),
k
.
isDefaultPrevented
()
||
(
this
.
affixed
=
i
,
this
.
unpin
=
"
bottom
"
==
i
?
this
.
getPinnedOffset
():
null
,
this
.
$element
.
removeClass
(
b
.
RESET
).
addClass
(
j
).
trigger
(
a
.
Event
(
j
.
replace
(
"
affix
"
,
"
affixed
"
))),
"
bottom
"
==
i
&&
this
.
$element
.
offset
({
top
:
c
-
h
-
this
.
$element
.
height
()}))}}};
var
c
=
a
.
fn
.
affix
;
a
.
fn
.
affix
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
bs.affix
"
),
f
=
"
object
"
==
typeof
c
&&
c
;
e
||
d
.
data
(
"
bs.affix
"
,
e
=
new
b
(
this
,
f
)),
"
string
"
==
typeof
c
&&
e
[
c
]()})},
a
.
fn
.
affix
.
Constructor
=
b
,
a
.
fn
.
affix
.
noConflict
=
function
(){
return
a
.
fn
.
affix
=
c
,
this
},
a
(
window
).
on
(
"
load
"
,
function
(){
a
(
'
[data-spy="affix"]
'
).
each
(
function
(){
var
b
=
a
(
this
),
c
=
b
.
data
();
c
.
offset
=
c
.
offset
||
{},
c
.
offsetBottom
&&
(
c
.
offset
.
bottom
=
c
.
offsetBottom
),
c
.
offsetTop
&&
(
c
.
offset
.
top
=
c
.
offsetTop
),
b
.
affix
(
c
)})})}(
jQuery
);
\ No newline at end of file
if
(
"
undefined
"
==
typeof
jQuery
)
throw
new
Error
(
"
Bootstrap requires jQuery
"
);
+
function
(
a
){
"
use strict
"
;
function
b
(){
var
a
=
document
.
createElement
(
"
bootstrap
"
),
b
=
{
WebkitTransition
:
"
webkitTransitionEnd
"
,
MozTransition
:
"
transitionend
"
,
OTransition
:
"
oTransitionEnd otransitionend
"
,
transition
:
"
transitionend
"
};
for
(
var
c
in
b
)
if
(
void
0
!==
a
.
style
[
c
])
return
{
end
:
b
[
c
]};
return
!
1
}
a
.
fn
.
emulateTransitionEnd
=
function
(
b
){
var
c
=!
1
,
d
=
this
;
a
(
this
).
one
(
a
.
support
.
transition
.
end
,
function
(){
c
=!
0
});
var
e
=
function
(){
c
||
a
(
d
).
trigger
(
a
.
support
.
transition
.
end
)};
return
setTimeout
(
e
,
b
),
this
},
a
(
function
(){
a
.
support
.
transition
=
b
()})}(
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
c
(){
f
.
trigger
(
"
closed.bs.alert
"
).
remove
()}
var
d
=
a
(
this
),
e
=
d
.
attr
(
"
data-target
"
);
e
||
(
e
=
d
.
attr
(
"
href
"
),
e
=
e
&&
e
.
replace
(
/.*
(?=
#
[^\s]
*$
)
/
,
""
));
var
f
=
a
(
e
);
b
&&
b
.
preventDefault
(),
f
.
length
||
(
f
=
d
.
hasClass
(
"
alert
"
)?
d
:
d
.
parent
()),
f
.
trigger
(
b
=
a
.
Event
(
"
close.bs.alert
"
)),
b
.
isDefaultPrevented
()
||
(
f
.
removeClass
(
"
in
"
),
a
.
support
.
transition
&&
f
.
hasClass
(
"
fade
"
)?
f
.
one
(
a
.
support
.
transition
.
end
,
c
).
emulateTransitionEnd
(
150
):
c
())};
var
d
=
a
.
fn
.
alert
;
a
.
fn
.
alert
=
function
(
b
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
bs.alert
"
);
e
||
d
.
data
(
"
bs.alert
"
,
e
=
new
c
(
this
)),
"
string
"
==
typeof
b
&&
e
[
b
].
call
(
d
)})},
a
.
fn
.
alert
.
Constructor
=
c
,
a
.
fn
.
alert
.
noConflict
=
function
(){
return
a
.
fn
.
alert
=
d
,
this
},
a
(
document
).
on
(
"
click.bs.alert.data-api
"
,
b
,
c
.
prototype
.
close
)}(
jQuery
),
+
function
(
a
){
"
use strict
"
;
var
b
=
function
(
c
,
d
){
this
.
$element
=
a
(
c
),
this
.
options
=
a
.
extend
({},
b
.
DEFAULTS
,
d
),
this
.
isLoading
=!
1
};
b
.
DEFAULTS
=
{
loadingText
:
"
loading...
"
},
b
.
prototype
.
setState
=
function
(
b
){
var
c
=
"
disabled
"
,
d
=
this
.
$element
,
e
=
d
.
is
(
"
input
"
)?
"
val
"
:
"
html
"
,
f
=
d
.
data
();
b
+=
"
Text
"
,
f
.
resetText
||
d
.
data
(
"
resetText
"
,
d
[
e
]()),
d
[
e
](
f
[
b
]
||
this
.
options
[
b
]),
setTimeout
(
a
.
proxy
(
function
(){
"
loadingText
"
==
b
?(
this
.
isLoading
=!
0
,
d
.
addClass
(
c
).
attr
(
c
,
c
)):
this
.
isLoading
&&
(
this
.
isLoading
=!
1
,
d
.
removeClass
(
c
).
removeAttr
(
c
))},
this
),
0
)},
b
.
prototype
.
toggle
=
function
(){
var
a
=!
0
,
b
=
this
.
$element
.
closest
(
'
[data-toggle="buttons"]
'
);
if
(
b
.
length
){
var
c
=
this
.
$element
.
find
(
"
input
"
);
"
radio
"
==
c
.
prop
(
"
type
"
)
&&
(
c
.
prop
(
"
checked
"
)
&&
this
.
$element
.
hasClass
(
"
active
"
)?
a
=!
1
:
b
.
find
(
"
.active
"
).
removeClass
(
"
active
"
)),
a
&&
c
.
prop
(
"
checked
"
,
!
this
.
$element
.
hasClass
(
"
active
"
)).
trigger
(
"
change
"
)}
a
&&
this
.
$element
.
toggleClass
(
"
active
"
)};
var
c
=
a
.
fn
.
button
;
a
.
fn
.
button
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
bs.button
"
),
f
=
"
object
"
==
typeof
c
&&
c
;
e
||
d
.
data
(
"
bs.button
"
,
e
=
new
b
(
this
,
f
)),
"
toggle
"
==
c
?
e
.
toggle
():
c
&&
e
.
setState
(
c
)})},
a
.
fn
.
button
.
Constructor
=
b
,
a
.
fn
.
button
.
noConflict
=
function
(){
return
a
.
fn
.
button
=
c
,
this
},
a
(
document
).
on
(
"
click.bs.button.data-api
"
,
"
[data-toggle^=button]
"
,
function
(
b
){
var
c
=
a
(
b
.
target
);
c
.
hasClass
(
"
btn
"
)
||
(
c
=
c
.
closest
(
"
.btn
"
)),
c
.
button
(
"
toggle
"
),
b
.
preventDefault
()})}(
jQuery
),
+
function
(
a
){
"
use strict
"
;
var
b
=
function
(
b
,
c
){
this
.
$element
=
a
(
b
),
this
.
$indicators
=
this
.
$element
.
find
(
"
.carousel-indicators
"
),
this
.
options
=
c
,
this
.
paused
=
this
.
sliding
=
this
.
interval
=
this
.
$active
=
this
.
$items
=
null
,
"
hover
"
==
this
.
options
.
pause
&&
this
.
$element
.
on
(
"
mouseenter
"
,
a
.
proxy
(
this
.
pause
,
this
)).
on
(
"
mouseleave
"
,
a
.
proxy
(
this
.
cycle
,
this
))};
b
.
DEFAULTS
=
{
interval
:
5
e3
,
pause
:
"
hover
"
,
wrap
:
!
0
},
b
.
prototype
.
cycle
=
function
(
b
){
return
b
||
(
this
.
paused
=!
1
),
this
.
interval
&&
clearInterval
(
this
.
interval
),
this
.
options
.
interval
&&!
this
.
paused
&&
(
this
.
interval
=
setInterval
(
a
.
proxy
(
this
.
next
,
this
),
this
.
options
.
interval
)),
this
},
b
.
prototype
.
getActiveIndex
=
function
(){
return
this
.
$active
=
this
.
$element
.
find
(
"
.item.active
"
),
this
.
$items
=
this
.
$active
.
parent
().
children
(),
this
.
$items
.
index
(
this
.
$active
)},
b
.
prototype
.
to
=
function
(
b
){
var
c
=
this
,
d
=
this
.
getActiveIndex
();
return
b
>
this
.
$items
.
length
-
1
||
0
>
b
?
void
0
:
this
.
sliding
?
this
.
$element
.
one
(
"
slid.bs.carousel
"
,
function
(){
c
.
to
(
b
)}):
d
==
b
?
this
.
pause
().
cycle
():
this
.
slide
(
b
>
d
?
"
next
"
:
"
prev
"
,
a
(
this
.
$items
[
b
]))},
b
.
prototype
.
pause
=
function
(
b
){
return
b
||
(
this
.
paused
=!
0
),
this
.
$element
.
find
(
"
.next, .prev
"
).
length
&&
a
.
support
.
transition
&&
(
this
.
$element
.
trigger
(
a
.
support
.
transition
.
end
),
this
.
cycle
(
!
0
)),
this
.
interval
=
clearInterval
(
this
.
interval
),
this
},
b
.
prototype
.
next
=
function
(){
return
this
.
sliding
?
void
0
:
this
.
slide
(
"
next
"
)},
b
.
prototype
.
prev
=
function
(){
return
this
.
sliding
?
void
0
:
this
.
slide
(
"
prev
"
)},
b
.
prototype
.
slide
=
function
(
b
,
c
){
var
d
=
this
.
$element
.
find
(
"
.item.active
"
),
e
=
c
||
d
[
b
](),
f
=
this
.
interval
,
g
=
"
next
"
==
b
?
"
left
"
:
"
right
"
,
h
=
"
next
"
==
b
?
"
first
"
:
"
last
"
,
i
=
this
;
if
(
!
e
.
length
){
if
(
!
this
.
options
.
wrap
)
return
;
e
=
this
.
$element
.
find
(
"
.item
"
)[
h
]()}
if
(
e
.
hasClass
(
"
active
"
))
return
this
.
sliding
=!
1
;
var
j
=
a
.
Event
(
"
slide.bs.carousel
"
,{
relatedTarget
:
e
[
0
],
direction
:
g
});
return
this
.
$element
.
trigger
(
j
),
j
.
isDefaultPrevented
()?
void
0
:(
this
.
sliding
=!
0
,
f
&&
this
.
pause
(),
this
.
$indicators
.
length
&&
(
this
.
$indicators
.
find
(
"
.active
"
).
removeClass
(
"
active
"
),
this
.
$element
.
one
(
"
slid.bs.carousel
"
,
function
(){
var
b
=
a
(
i
.
$indicators
.
children
()[
i
.
getActiveIndex
()]);
b
&&
b
.
addClass
(
"
active
"
)})),
a
.
support
.
transition
&&
this
.
$element
.
hasClass
(
"
slide
"
)?(
e
.
addClass
(
b
),
e
[
0
].
offsetWidth
,
d
.
addClass
(
g
),
e
.
addClass
(
g
),
d
.
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.bs.carousel
"
)},
0
)}).
emulateTransitionEnd
(
1
e3
*
d
.
css
(
"
transition-duration
"
).
slice
(
0
,
-
1
))):(
d
.
removeClass
(
"
active
"
),
e
.
addClass
(
"
active
"
),
this
.
sliding
=!
1
,
this
.
$element
.
trigger
(
"
slid.bs.carousel
"
)),
f
&&
this
.
cycle
(),
this
)};
var
c
=
a
.
fn
.
carousel
;
a
.
fn
.
carousel
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
bs.carousel
"
),
f
=
a
.
extend
({},
b
.
DEFAULTS
,
d
.
data
(),
"
object
"
==
typeof
c
&&
c
),
g
=
"
string
"
==
typeof
c
?
c
:
f
.
slide
;
e
||
d
.
data
(
"
bs.carousel
"
,
e
=
new
b
(
this
,
f
)),
"
number
"
==
typeof
c
?
e
.
to
(
c
):
g
?
e
[
g
]():
f
.
interval
&&
e
.
pause
().
cycle
()})},
a
.
fn
.
carousel
.
Constructor
=
b
,
a
.
fn
.
carousel
.
noConflict
=
function
(){
return
a
.
fn
.
carousel
=
c
,
this
},
a
(
document
).
on
(
"
click.bs.carousel.data-api
"
,
"
[data-slide], [data-slide-to]
"
,
function
(
b
){
var
c
,
d
=
a
(
this
),
e
=
a
(
d
.
attr
(
"
data-target
"
)
||
(
c
=
d
.
attr
(
"
href
"
))
&&
c
.
replace
(
/.*
(?=
#
[^\s]
+$
)
/
,
""
)),
f
=
a
.
extend
({},
e
.
data
(),
d
.
data
()),
g
=
d
.
attr
(
"
data-slide-to
"
);
g
&&
(
f
.
interval
=!
1
),
e
.
carousel
(
f
),(
g
=
d
.
attr
(
"
data-slide-to
"
))
&&
e
.
data
(
"
bs.carousel
"
).
to
(
g
),
b
.
preventDefault
()}),
a
(
window
).
on
(
"
load
"
,
function
(){
a
(
'
[data-ride="carousel"]
'
).
each
(
function
(){
var
b
=
a
(
this
);
b
.
carousel
(
b
.
data
())})})}(
jQuery
),
+
function
(
a
){
"
use strict
"
;
var
b
=
function
(
c
,
d
){
this
.
$element
=
a
(
c
),
this
.
options
=
a
.
extend
({},
b
.
DEFAULTS
,
d
),
this
.
transitioning
=
null
,
this
.
options
.
parent
&&
(
this
.
$parent
=
a
(
this
.
options
.
parent
)),
this
.
options
.
toggle
&&
this
.
toggle
()};
b
.
DEFAULTS
=
{
toggle
:
!
0
},
b
.
prototype
.
dimension
=
function
(){
var
a
=
this
.
$element
.
hasClass
(
"
width
"
);
return
a
?
"
width
"
:
"
height
"
},
b
.
prototype
.
show
=
function
(){
if
(
!
this
.
transitioning
&&!
this
.
$element
.
hasClass
(
"
in
"
)){
var
b
=
a
.
Event
(
"
show.bs.collapse
"
);
if
(
this
.
$element
.
trigger
(
b
),
!
b
.
isDefaultPrevented
()){
var
c
=
this
.
$parent
&&
this
.
$parent
.
find
(
"
> .panel > .in
"
);
if
(
c
&&
c
.
length
){
var
d
=
c
.
data
(
"
bs.collapse
"
);
if
(
d
&&
d
.
transitioning
)
return
;
c
.
collapse
(
"
hide
"
),
d
||
c
.
data
(
"
bs.collapse
"
,
null
)}
var
e
=
this
.
dimension
();
this
.
$element
.
removeClass
(
"
collapse
"
).
addClass
(
"
collapsing
"
)[
e
](
0
),
this
.
transitioning
=
1
;
var
f
=
function
(){
this
.
$element
.
removeClass
(
"
collapsing
"
).
addClass
(
"
collapse in
"
)[
e
](
"
auto
"
),
this
.
transitioning
=
0
,
this
.
$element
.
trigger
(
"
shown.bs.collapse
"
)};
if
(
!
a
.
support
.
transition
)
return
f
.
call
(
this
);
var
g
=
a
.
camelCase
([
"
scroll
"
,
e
].
join
(
"
-
"
));
this
.
$element
.
one
(
a
.
support
.
transition
.
end
,
a
.
proxy
(
f
,
this
)).
emulateTransitionEnd
(
350
)[
e
](
this
.
$element
[
0
][
g
])}}},
b
.
prototype
.
hide
=
function
(){
if
(
!
this
.
transitioning
&&
this
.
$element
.
hasClass
(
"
in
"
)){
var
b
=
a
.
Event
(
"
hide.bs.collapse
"
);
if
(
this
.
$element
.
trigger
(
b
),
!
b
.
isDefaultPrevented
()){
var
c
=
this
.
dimension
();
this
.
$element
[
c
](
this
.
$element
[
c
]())[
0
].
offsetHeight
,
this
.
$element
.
addClass
(
"
collapsing
"
).
removeClass
(
"
collapse
"
).
removeClass
(
"
in
"
),
this
.
transitioning
=
1
;
var
d
=
function
(){
this
.
transitioning
=
0
,
this
.
$element
.
trigger
(
"
hidden.bs.collapse
"
).
removeClass
(
"
collapsing
"
).
addClass
(
"
collapse
"
)};
return
a
.
support
.
transition
?
void
this
.
$element
[
c
](
0
).
one
(
a
.
support
.
transition
.
end
,
a
.
proxy
(
d
,
this
)).
emulateTransitionEnd
(
350
):
d
.
call
(
this
)}}},
b
.
prototype
.
toggle
=
function
(){
this
[
this
.
$element
.
hasClass
(
"
in
"
)?
"
hide
"
:
"
show
"
]()};
var
c
=
a
.
fn
.
collapse
;
a
.
fn
.
collapse
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
bs.collapse
"
),
f
=
a
.
extend
({},
b
.
DEFAULTS
,
d
.
data
(),
"
object
"
==
typeof
c
&&
c
);
!
e
&&
f
.
toggle
&&
"
show
"
==
c
&&
(
c
=!
c
),
e
||
d
.
data
(
"
bs.collapse
"
,
e
=
new
b
(
this
,
f
)),
"
string
"
==
typeof
c
&&
e
[
c
]()})},
a
.
fn
.
collapse
.
Constructor
=
b
,
a
.
fn
.
collapse
.
noConflict
=
function
(){
return
a
.
fn
.
collapse
=
c
,
this
},
a
(
document
).
on
(
"
click.bs.collapse.data-api
"
,
"
[data-toggle=collapse]
"
,
function
(
b
){
var
c
,
d
=
a
(
this
),
e
=
d
.
attr
(
"
data-target
"
)
||
b
.
preventDefault
()
||
(
c
=
d
.
attr
(
"
href
"
))
&&
c
.
replace
(
/.*
(?=
#
[^\s]
+$
)
/
,
""
),
f
=
a
(
e
),
g
=
f
.
data
(
"
bs.collapse
"
),
h
=
g
?
"
toggle
"
:
d
.
data
(),
i
=
d
.
attr
(
"
data-parent
"
),
j
=
i
&&
a
(
i
);
g
&&
g
.
transitioning
||
(
j
&&
j
.
find
(
'
[data-toggle=collapse][data-parent="
'
+
i
+
'
"]
'
).
not
(
d
).
addClass
(
"
collapsed
"
),
d
[
f
.
hasClass
(
"
in
"
)?
"
addClass
"
:
"
removeClass
"
](
"
collapsed
"
)),
f
.
collapse
(
h
)})}(
jQuery
),
+
function
(
a
){
"
use strict
"
;
function
b
(
b
){
a
(
d
).
remove
(),
a
(
e
).
each
(
function
(){
var
d
=
c
(
a
(
this
)),
e
=
{
relatedTarget
:
this
};
d
.
hasClass
(
"
open
"
)
&&
(
d
.
trigger
(
b
=
a
.
Event
(
"
hide.bs.dropdown
"
,
e
)),
b
.
isDefaultPrevented
()
||
d
.
removeClass
(
"
open
"
).
trigger
(
"
hidden.bs.dropdown
"
,
e
))})}
function
c
(
b
){
var
c
=
b
.
attr
(
"
data-target
"
);
c
||
(
c
=
b
.
attr
(
"
href
"
),
c
=
c
&&
/#
[
A-Za-z
]
/
.
test
(
c
)
&&
c
.
replace
(
/.*
(?=
#
[^\s]
*$
)
/
,
""
));
var
d
=
c
&&
a
(
c
);
return
d
&&
d
.
length
?
d
:
b
.
parent
()}
var
d
=
"
.dropdown-backdrop
"
,
e
=
"
[data-toggle=dropdown]
"
,
f
=
function
(
b
){
a
(
b
).
on
(
"
click.bs.dropdown
"
,
this
.
toggle
)};
f
.
prototype
.
toggle
=
function
(
d
){
var
e
=
a
(
this
);
if
(
!
e
.
is
(
"
.disabled, :disabled
"
)){
var
f
=
c
(
e
),
g
=
f
.
hasClass
(
"
open
"
);
if
(
b
(),
!
g
){
"
ontouchstart
"
in
document
.
documentElement
&&!
f
.
closest
(
"
.navbar-nav
"
).
length
&&
a
(
'
<div class="dropdown-backdrop"/>
'
).
insertAfter
(
a
(
this
)).
on
(
"
click
"
,
b
);
var
h
=
{
relatedTarget
:
this
};
if
(
f
.
trigger
(
d
=
a
.
Event
(
"
show.bs.dropdown
"
,
h
)),
d
.
isDefaultPrevented
())
return
;
f
.
toggleClass
(
"
open
"
).
trigger
(
"
shown.bs.dropdown
"
,
h
),
e
.
focus
()}
return
!
1
}},
f
.
prototype
.
keydown
=
function
(
b
){
if
(
/
(
38|40|27
)
/
.
test
(
b
.
keyCode
)){
var
d
=
a
(
this
);
if
(
b
.
preventDefault
(),
b
.
stopPropagation
(),
!
d
.
is
(
"
.disabled, :disabled
"
)){
var
f
=
c
(
d
),
g
=
f
.
hasClass
(
"
open
"
);
if
(
!
g
||
g
&&
27
==
b
.
keyCode
)
return
27
==
b
.
which
&&
f
.
find
(
e
).
focus
(),
d
.
click
();
var
h
=
"
li:not(.divider):visible a
"
,
i
=
f
.
find
(
"
[role=menu]
"
+
h
+
"
, [role=listbox]
"
+
h
);
if
(
i
.
length
){
var
j
=
i
.
index
(
i
.
filter
(
"
:focus
"
));
38
==
b
.
keyCode
&&
j
>
0
&&
j
--
,
40
==
b
.
keyCode
&&
j
<
i
.
length
-
1
&&
j
++
,
~
j
||
(
j
=
0
),
i
.
eq
(
j
).
focus
()}}}};
var
g
=
a
.
fn
.
dropdown
;
a
.
fn
.
dropdown
=
function
(
b
){
return
this
.
each
(
function
(){
var
c
=
a
(
this
),
d
=
c
.
data
(
"
bs.dropdown
"
);
d
||
c
.
data
(
"
bs.dropdown
"
,
d
=
new
f
(
this
)),
"
string
"
==
typeof
b
&&
d
[
b
].
call
(
c
)})},
a
.
fn
.
dropdown
.
Constructor
=
f
,
a
.
fn
.
dropdown
.
noConflict
=
function
(){
return
a
.
fn
.
dropdown
=
g
,
this
},
a
(
document
).
on
(
"
click.bs.dropdown.data-api
"
,
b
).
on
(
"
click.bs.dropdown.data-api
"
,
"
.dropdown form
"
,
function
(
a
){
a
.
stopPropagation
()}).
on
(
"
click.bs.dropdown.data-api
"
,
e
,
f
.
prototype
.
toggle
).
on
(
"
keydown.bs.dropdown.data-api
"
,
e
+
"
, [role=menu], [role=listbox]
"
,
f
.
prototype
.
keydown
)}(
jQuery
),
+
function
(
a
){
"
use strict
"
;
var
b
=
function
(
b
,
c
){
this
.
options
=
c
,
this
.
$element
=
a
(
b
),
this
.
$backdrop
=
this
.
isShown
=
null
,
this
.
options
.
remote
&&
this
.
$element
.
find
(
"
.modal-content
"
).
load
(
this
.
options
.
remote
,
a
.
proxy
(
function
(){
this
.
$element
.
trigger
(
"
loaded.bs.modal
"
)},
this
))};
b
.
DEFAULTS
=
{
backdrop
:
!
0
,
keyboard
:
!
0
,
show
:
!
0
},
b
.
prototype
.
toggle
=
function
(
a
){
return
this
[
this
.
isShown
?
"
hide
"
:
"
show
"
](
a
)},
b
.
prototype
.
show
=
function
(
b
){
var
c
=
this
,
d
=
a
.
Event
(
"
show.bs.modal
"
,{
relatedTarget
:
b
});
this
.
$element
.
trigger
(
d
),
this
.
isShown
||
d
.
isDefaultPrevented
()
||
(
this
.
isShown
=!
0
,
this
.
escape
(),
this
.
$element
.
on
(
"
click.dismiss.modal
"
,
'
[data-dismiss="modal"]
'
,
a
.
proxy
(
this
.
hide
,
this
)),
this
.
backdrop
(
function
(){
var
d
=
a
.
support
.
transition
&&
c
.
$element
.
hasClass
(
"
fade
"
);
c
.
$element
.
parent
().
length
||
c
.
$element
.
appendTo
(
document
.
body
),
c
.
$element
.
show
().
scrollTop
(
0
),
d
&&
c
.
$element
[
0
].
offsetWidth
,
c
.
$element
.
addClass
(
"
in
"
).
attr
(
"
aria-hidden
"
,
!
1
),
c
.
enforceFocus
();
var
e
=
a
.
Event
(
"
shown.bs.modal
"
,{
relatedTarget
:
b
});
d
?
c
.
$element
.
find
(
"
.modal-dialog
"
).
one
(
a
.
support
.
transition
.
end
,
function
(){
c
.
$element
.
focus
().
trigger
(
e
)}).
emulateTransitionEnd
(
300
):
c
.
$element
.
focus
().
trigger
(
e
)}))},
b
.
prototype
.
hide
=
function
(
b
){
b
&&
b
.
preventDefault
(),
b
=
a
.
Event
(
"
hide.bs.modal
"
),
this
.
$element
.
trigger
(
b
),
this
.
isShown
&&!
b
.
isDefaultPrevented
()
&&
(
this
.
isShown
=!
1
,
this
.
escape
(),
a
(
document
).
off
(
"
focusin.bs.modal
"
),
this
.
$element
.
removeClass
(
"
in
"
).
attr
(
"
aria-hidden
"
,
!
0
).
off
(
"
click.dismiss.modal
"
),
a
.
support
.
transition
&&
this
.
$element
.
hasClass
(
"
fade
"
)?
this
.
$element
.
one
(
a
.
support
.
transition
.
end
,
a
.
proxy
(
this
.
hideModal
,
this
)).
emulateTransitionEnd
(
300
):
this
.
hideModal
())},
b
.
prototype
.
enforceFocus
=
function
(){
a
(
document
).
off
(
"
focusin.bs.modal
"
).
on
(
"
focusin.bs.modal
"
,
a
.
proxy
(
function
(
a
){
this
.
$element
[
0
]
===
a
.
target
||
this
.
$element
.
has
(
a
.
target
).
length
||
this
.
$element
.
focus
()},
this
))},
b
.
prototype
.
escape
=
function
(){
this
.
isShown
&&
this
.
options
.
keyboard
?
this
.
$element
.
on
(
"
keyup.dismiss.bs.modal
"
,
a
.
proxy
(
function
(
a
){
27
==
a
.
which
&&
this
.
hide
()},
this
)):
this
.
isShown
||
this
.
$element
.
off
(
"
keyup.dismiss.bs.modal
"
)},
b
.
prototype
.
hideModal
=
function
(){
var
a
=
this
;
this
.
$element
.
hide
(),
this
.
backdrop
(
function
(){
a
.
removeBackdrop
(),
a
.
$element
.
trigger
(
"
hidden.bs.modal
"
)})},
b
.
prototype
.
removeBackdrop
=
function
(){
this
.
$backdrop
&&
this
.
$backdrop
.
remove
(),
this
.
$backdrop
=
null
},
b
.
prototype
.
backdrop
=
function
(
b
){
var
c
=
this
.
$element
.
hasClass
(
"
fade
"
)?
"
fade
"
:
""
;
if
(
this
.
isShown
&&
this
.
options
.
backdrop
){
var
d
=
a
.
support
.
transition
&&
c
;
if
(
this
.
$backdrop
=
a
(
'
<div class="modal-backdrop
'
+
c
+
'
" />
'
).
appendTo
(
document
.
body
),
this
.
$element
.
on
(
"
click.dismiss.modal
"
,
a
.
proxy
(
function
(
a
){
a
.
target
===
a
.
currentTarget
&&
(
"
static
"
==
this
.
options
.
backdrop
?
this
.
$element
[
0
].
focus
.
call
(
this
.
$element
[
0
]):
this
.
hide
.
call
(
this
))},
this
)),
d
&&
this
.
$backdrop
[
0
].
offsetWidth
,
this
.
$backdrop
.
addClass
(
"
in
"
),
!
b
)
return
;
d
?
this
.
$backdrop
.
one
(
a
.
support
.
transition
.
end
,
b
).
emulateTransitionEnd
(
150
):
b
()}
else
!
this
.
isShown
&&
this
.
$backdrop
?(
this
.
$backdrop
.
removeClass
(
"
in
"
),
a
.
support
.
transition
&&
this
.
$element
.
hasClass
(
"
fade
"
)?
this
.
$backdrop
.
one
(
a
.
support
.
transition
.
end
,
b
).
emulateTransitionEnd
(
150
):
b
()):
b
&&
b
()};
var
c
=
a
.
fn
.
modal
;
a
.
fn
.
modal
=
function
(
c
,
d
){
return
this
.
each
(
function
(){
var
e
=
a
(
this
),
f
=
e
.
data
(
"
bs.modal
"
),
g
=
a
.
extend
({},
b
.
DEFAULTS
,
e
.
data
(),
"
object
"
==
typeof
c
&&
c
);
f
||
e
.
data
(
"
bs.modal
"
,
f
=
new
b
(
this
,
g
)),
"
string
"
==
typeof
c
?
f
[
c
](
d
):
g
.
show
&&
f
.
show
(
d
)})},
a
.
fn
.
modal
.
Constructor
=
b
,
a
.
fn
.
modal
.
noConflict
=
function
(){
return
a
.
fn
.
modal
=
c
,
this
},
a
(
document
).
on
(
"
click.bs.modal.data-api
"
,
'
[data-toggle="modal"]
'
,
function
(
b
){
var
c
=
a
(
this
),
d
=
c
.
attr
(
"
href
"
),
e
=
a
(
c
.
attr
(
"
data-target
"
)
||
d
&&
d
.
replace
(
/.*
(?=
#
[^\s]
+$
)
/
,
""
)),
f
=
e
.
data
(
"
bs.modal
"
)?
"
toggle
"
:
a
.
extend
({
remote
:
!
/#/
.
test
(
d
)
&&
d
},
e
.
data
(),
c
.
data
());
c
.
is
(
"
a
"
)
&&
b
.
preventDefault
(),
e
.
modal
(
f
,
this
).
one
(
"
hide
"
,
function
(){
c
.
is
(
"
:visible
"
)
&&
c
.
focus
()})}),
a
(
document
).
on
(
"
show.bs.modal
"
,
"
.modal
"
,
function
(){
a
(
document
.
body
).
addClass
(
"
modal-open
"
)}).
on
(
"
hidden.bs.modal
"
,
"
.modal
"
,
function
(){
a
(
document
.
body
).
removeClass
(
"
modal-open
"
)})}(
jQuery
),
+
function
(
a
){
"
use strict
"
;
var
b
=
function
(
a
,
b
){
this
.
type
=
this
.
options
=
this
.
enabled
=
this
.
timeout
=
this
.
hoverState
=
this
.
$element
=
null
,
this
.
init
(
"
tooltip
"
,
a
,
b
)};
b
.
DEFAULTS
=
{
animation
:
!
0
,
placement
:
"
top
"
,
selector
:
!
1
,
template
:
'
<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>
'
,
trigger
:
"
hover focus
"
,
title
:
""
,
delay
:
0
,
html
:
!
1
,
container
:
!
1
},
b
.
prototype
.
init
=
function
(
b
,
c
,
d
){
this
.
enabled
=!
0
,
this
.
type
=
b
,
this
.
$element
=
a
(
c
),
this
.
options
=
this
.
getOptions
(
d
);
for
(
var
e
=
this
.
options
.
trigger
.
split
(
"
"
),
f
=
e
.
length
;
f
--
;){
var
g
=
e
[
f
];
if
(
"
click
"
==
g
)
this
.
$element
.
on
(
"
click.
"
+
this
.
type
,
this
.
options
.
selector
,
a
.
proxy
(
this
.
toggle
,
this
));
else
if
(
"
manual
"
!=
g
){
var
h
=
"
hover
"
==
g
?
"
mouseenter
"
:
"
focusin
"
,
i
=
"
hover
"
==
g
?
"
mouseleave
"
:
"
focusout
"
;
this
.
$element
.
on
(
h
+
"
.
"
+
this
.
type
,
this
.
options
.
selector
,
a
.
proxy
(
this
.
enter
,
this
)),
this
.
$element
.
on
(
i
+
"
.
"
+
this
.
type
,
this
.
options
.
selector
,
a
.
proxy
(
this
.
leave
,
this
))}}
this
.
options
.
selector
?
this
.
_options
=
a
.
extend
({},
this
.
options
,{
trigger
:
"
manual
"
,
selector
:
""
}):
this
.
fixTitle
()},
b
.
prototype
.
getDefaults
=
function
(){
return
b
.
DEFAULTS
},
b
.
prototype
.
getOptions
=
function
(
b
){
return
b
=
a
.
extend
({},
this
.
getDefaults
(),
this
.
$element
.
data
(),
b
),
b
.
delay
&&
"
number
"
==
typeof
b
.
delay
&&
(
b
.
delay
=
{
show
:
b
.
delay
,
hide
:
b
.
delay
}),
b
},
b
.
prototype
.
getDelegateOptions
=
function
(){
var
b
=
{},
c
=
this
.
getDefaults
();
return
this
.
_options
&&
a
.
each
(
this
.
_options
,
function
(
a
,
d
){
c
[
a
]
!=
d
&&
(
b
[
a
]
=
d
)}),
b
},
b
.
prototype
.
enter
=
function
(
b
){
var
c
=
b
instanceof
this
.
constructor
?
b
:
a
(
b
.
currentTarget
)[
this
.
type
](
this
.
getDelegateOptions
()).
data
(
"
bs.
"
+
this
.
type
);
return
clearTimeout
(
c
.
timeout
),
c
.
hoverState
=
"
in
"
,
c
.
options
.
delay
&&
c
.
options
.
delay
.
show
?
void
(
c
.
timeout
=
setTimeout
(
function
(){
"
in
"
==
c
.
hoverState
&&
c
.
show
()},
c
.
options
.
delay
.
show
)):
c
.
show
()},
b
.
prototype
.
leave
=
function
(
b
){
var
c
=
b
instanceof
this
.
constructor
?
b
:
a
(
b
.
currentTarget
)[
this
.
type
](
this
.
getDelegateOptions
()).
data
(
"
bs.
"
+
this
.
type
);
return
clearTimeout
(
c
.
timeout
),
c
.
hoverState
=
"
out
"
,
c
.
options
.
delay
&&
c
.
options
.
delay
.
hide
?
void
(
c
.
timeout
=
setTimeout
(
function
(){
"
out
"
==
c
.
hoverState
&&
c
.
hide
()},
c
.
options
.
delay
.
hide
)):
c
.
hide
()},
b
.
prototype
.
show
=
function
(){
var
b
=
a
.
Event
(
"
show.bs.
"
+
this
.
type
);
if
(
this
.
hasContent
()
&&
this
.
enabled
){
if
(
this
.
$element
.
trigger
(
b
),
b
.
isDefaultPrevented
())
return
;
var
c
=
this
,
d
=
this
.
tip
();
this
.
setContent
(),
this
.
options
.
animation
&&
d
.
addClass
(
"
fade
"
);
var
e
=
"
function
"
==
typeof
this
.
options
.
placement
?
this
.
options
.
placement
.
call
(
this
,
d
[
0
],
this
.
$element
[
0
]):
this
.
options
.
placement
,
f
=
/
\s?
auto
?\s?
/i
,
g
=
f
.
test
(
e
);
g
&&
(
e
=
e
.
replace
(
f
,
""
)
||
"
top
"
),
d
.
detach
().
css
({
top
:
0
,
left
:
0
,
display
:
"
block
"
}).
addClass
(
e
),
this
.
options
.
container
?
d
.
appendTo
(
this
.
options
.
container
):
d
.
insertAfter
(
this
.
$element
);
var
h
=
this
.
getPosition
(),
i
=
d
[
0
].
offsetWidth
,
j
=
d
[
0
].
offsetHeight
;
if
(
g
){
var
k
=
this
.
$element
.
parent
(),
l
=
e
,
m
=
document
.
documentElement
.
scrollTop
||
document
.
body
.
scrollTop
,
n
=
"
body
"
==
this
.
options
.
container
?
window
.
innerWidth
:
k
.
outerWidth
(),
o
=
"
body
"
==
this
.
options
.
container
?
window
.
innerHeight
:
k
.
outerHeight
(),
p
=
"
body
"
==
this
.
options
.
container
?
0
:
k
.
offset
().
left
;
e
=
"
bottom
"
==
e
&&
h
.
top
+
h
.
height
+
j
-
m
>
o
?
"
top
"
:
"
top
"
==
e
&&
h
.
top
-
m
-
j
<
0
?
"
bottom
"
:
"
right
"
==
e
&&
h
.
right
+
i
>
n
?
"
left
"
:
"
left
"
==
e
&&
h
.
left
-
i
<
p
?
"
right
"
:
e
,
d
.
removeClass
(
l
).
addClass
(
e
)}
var
q
=
this
.
getCalculatedOffset
(
e
,
h
,
i
,
j
);
this
.
applyPlacement
(
q
,
e
),
this
.
hoverState
=
null
;
var
r
=
function
(){
c
.
$element
.
trigger
(
"
shown.bs.
"
+
c
.
type
)};
a
.
support
.
transition
&&
this
.
$tip
.
hasClass
(
"
fade
"
)?
d
.
one
(
a
.
support
.
transition
.
end
,
r
).
emulateTransitionEnd
(
150
):
r
()}},
b
.
prototype
.
applyPlacement
=
function
(
b
,
c
){
var
d
,
e
=
this
.
tip
(),
f
=
e
[
0
].
offsetWidth
,
g
=
e
[
0
].
offsetHeight
,
h
=
parseInt
(
e
.
css
(
"
margin-top
"
),
10
),
i
=
parseInt
(
e
.
css
(
"
margin-left
"
),
10
);
isNaN
(
h
)
&&
(
h
=
0
),
isNaN
(
i
)
&&
(
i
=
0
),
b
.
top
=
b
.
top
+
h
,
b
.
left
=
b
.
left
+
i
,
a
.
offset
.
setOffset
(
e
[
0
],
a
.
extend
({
using
:
function
(
a
){
e
.
css
({
top
:
Math
.
round
(
a
.
top
),
left
:
Math
.
round
(
a
.
left
)})}},
b
),
0
),
e
.
addClass
(
"
in
"
);
var
j
=
e
[
0
].
offsetWidth
,
k
=
e
[
0
].
offsetHeight
;
if
(
"
top
"
==
c
&&
k
!=
g
&&
(
d
=!
0
,
b
.
top
=
b
.
top
+
g
-
k
),
/bottom|top/
.
test
(
c
)){
var
l
=
0
;
b
.
left
<
0
&&
(
l
=-
2
*
b
.
left
,
b
.
left
=
0
,
e
.
offset
(
b
),
j
=
e
[
0
].
offsetWidth
,
k
=
e
[
0
].
offsetHeight
),
this
.
replaceArrow
(
l
-
f
+
j
,
j
,
"
left
"
)}
else
this
.
replaceArrow
(
k
-
g
,
k
,
"
top
"
);
d
&&
e
.
offset
(
b
)},
b
.
prototype
.
replaceArrow
=
function
(
a
,
b
,
c
){
this
.
arrow
().
css
(
c
,
a
?
50
*
(
1
-
a
/
b
)
+
"
%
"
:
""
)},
b
.
prototype
.
setContent
=
function
(){
var
a
=
this
.
tip
(),
b
=
this
.
getTitle
();
a
.
find
(
"
.tooltip-inner
"
)[
this
.
options
.
html
?
"
html
"
:
"
text
"
](
b
),
a
.
removeClass
(
"
fade in top bottom left right
"
)},
b
.
prototype
.
hide
=
function
(){
function
b
(){
"
in
"
!=
c
.
hoverState
&&
d
.
detach
(),
c
.
$element
.
trigger
(
"
hidden.bs.
"
+
c
.
type
)}
var
c
=
this
,
d
=
this
.
tip
(),
e
=
a
.
Event
(
"
hide.bs.
"
+
this
.
type
);
return
this
.
$element
.
trigger
(
e
),
e
.
isDefaultPrevented
()?
void
0
:(
d
.
removeClass
(
"
in
"
),
a
.
support
.
transition
&&
this
.
$tip
.
hasClass
(
"
fade
"
)?
d
.
one
(
a
.
support
.
transition
.
end
,
b
).
emulateTransitionEnd
(
150
):
b
(),
this
.
hoverState
=
null
,
this
)},
b
.
prototype
.
fixTitle
=
function
(){
var
a
=
this
.
$element
;(
a
.
attr
(
"
title
"
)
||
"
string
"
!=
typeof
a
.
attr
(
"
data-original-title
"
))
&&
a
.
attr
(
"
data-original-title
"
,
a
.
attr
(
"
title
"
)
||
""
).
attr
(
"
title
"
,
""
)},
b
.
prototype
.
hasContent
=
function
(){
return
this
.
getTitle
()},
b
.
prototype
.
getPosition
=
function
(){
var
b
=
this
.
$element
[
0
];
return
a
.
extend
({},
"
function
"
==
typeof
b
.
getBoundingClientRect
?
b
.
getBoundingClientRect
():{
width
:
b
.
offsetWidth
,
height
:
b
.
offsetHeight
},
this
.
$element
.
offset
())},
b
.
prototype
.
getCalculatedOffset
=
function
(
a
,
b
,
c
,
d
){
return
"
bottom
"
==
a
?{
top
:
b
.
top
+
b
.
height
,
left
:
b
.
left
+
b
.
width
/
2
-
c
/
2
}:
"
top
"
==
a
?{
top
:
b
.
top
-
d
,
left
:
b
.
left
+
b
.
width
/
2
-
c
/
2
}:
"
left
"
==
a
?{
top
:
b
.
top
+
b
.
height
/
2
-
d
/
2
,
left
:
b
.
left
-
c
}:{
top
:
b
.
top
+
b
.
height
/
2
-
d
/
2
,
left
:
b
.
left
+
b
.
width
}},
b
.
prototype
.
getTitle
=
function
(){
var
a
,
b
=
this
.
$element
,
c
=
this
.
options
;
return
a
=
b
.
attr
(
"
data-original-title
"
)
||
(
"
function
"
==
typeof
c
.
title
?
c
.
title
.
call
(
b
[
0
]):
c
.
title
)},
b
.
prototype
.
tip
=
function
(){
return
this
.
$tip
=
this
.
$tip
||
a
(
this
.
options
.
template
)},
b
.
prototype
.
arrow
=
function
(){
return
this
.
$arrow
=
this
.
$arrow
||
this
.
tip
().
find
(
"
.tooltip-arrow
"
)},
b
.
prototype
.
validate
=
function
(){
this
.
$element
[
0
].
parentNode
||
(
this
.
hide
(),
this
.
$element
=
null
,
this
.
options
=
null
)},
b
.
prototype
.
enable
=
function
(){
this
.
enabled
=!
0
},
b
.
prototype
.
disable
=
function
(){
this
.
enabled
=!
1
},
b
.
prototype
.
toggleEnabled
=
function
(){
this
.
enabled
=!
this
.
enabled
},
b
.
prototype
.
toggle
=
function
(
b
){
var
c
=
b
?
a
(
b
.
currentTarget
)[
this
.
type
](
this
.
getDelegateOptions
()).
data
(
"
bs.
"
+
this
.
type
):
this
;
c
.
tip
().
hasClass
(
"
in
"
)?
c
.
leave
(
c
):
c
.
enter
(
c
)},
b
.
prototype
.
destroy
=
function
(){
clearTimeout
(
this
.
timeout
),
this
.
hide
().
$element
.
off
(
"
.
"
+
this
.
type
).
removeData
(
"
bs.
"
+
this
.
type
)};
var
c
=
a
.
fn
.
tooltip
;
a
.
fn
.
tooltip
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
bs.tooltip
"
),
f
=
"
object
"
==
typeof
c
&&
c
;(
e
||
"
destroy
"
!=
c
)
&&
(
e
||
d
.
data
(
"
bs.tooltip
"
,
e
=
new
b
(
this
,
f
)),
"
string
"
==
typeof
c
&&
e
[
c
]())})},
a
.
fn
.
tooltip
.
Constructor
=
b
,
a
.
fn
.
tooltip
.
noConflict
=
function
(){
return
a
.
fn
.
tooltip
=
c
,
this
}}(
jQuery
),
+
function
(
a
){
"
use strict
"
;
var
b
=
function
(
a
,
b
){
this
.
init
(
"
popover
"
,
a
,
b
)};
if
(
!
a
.
fn
.
tooltip
)
throw
new
Error
(
"
Popover requires tooltip.js
"
);
b
.
DEFAULTS
=
a
.
extend
({},
a
.
fn
.
tooltip
.
Constructor
.
DEFAULTS
,{
placement
:
"
right
"
,
trigger
:
"
click
"
,
content
:
""
,
template
:
'
<div class="popover"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>
'
}),
b
.
prototype
=
a
.
extend
({},
a
.
fn
.
tooltip
.
Constructor
.
prototype
),
b
.
prototype
.
constructor
=
b
,
b
.
prototype
.
getDefaults
=
function
(){
return
b
.
DEFAULTS
},
b
.
prototype
.
setContent
=
function
(){
var
a
=
this
.
tip
(),
b
=
this
.
getTitle
(),
c
=
this
.
getContent
();
a
.
find
(
"
.popover-title
"
)[
this
.
options
.
html
?
"
html
"
:
"
text
"
](
b
),
a
.
find
(
"
.popover-content
"
)[
this
.
options
.
html
?
"
string
"
==
typeof
c
?
"
html
"
:
"
append
"
:
"
text
"
](
c
),
a
.
removeClass
(
"
fade top bottom left right in
"
),
a
.
find
(
"
.popover-title
"
).
html
()
||
a
.
find
(
"
.popover-title
"
).
hide
()},
b
.
prototype
.
hasContent
=
function
(){
return
this
.
getTitle
()
||
this
.
getContent
()},
b
.
prototype
.
getContent
=
function
(){
var
a
=
this
.
$element
,
b
=
this
.
options
;
return
a
.
attr
(
"
data-content
"
)
||
(
"
function
"
==
typeof
b
.
content
?
b
.
content
.
call
(
a
[
0
]):
b
.
content
)},
b
.
prototype
.
arrow
=
function
(){
return
this
.
$arrow
=
this
.
$arrow
||
this
.
tip
().
find
(
"
.arrow
"
)},
b
.
prototype
.
tip
=
function
(){
return
this
.
$tip
||
(
this
.
$tip
=
a
(
this
.
options
.
template
)),
this
.
$tip
};
var
c
=
a
.
fn
.
popover
;
a
.
fn
.
popover
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
bs.popover
"
),
f
=
"
object
"
==
typeof
c
&&
c
;(
e
||
"
destroy
"
!=
c
)
&&
(
e
||
d
.
data
(
"
bs.popover
"
,
e
=
new
b
(
this
,
f
)),
"
string
"
==
typeof
c
&&
e
[
c
]())})},
a
.
fn
.
popover
.
Constructor
=
b
,
a
.
fn
.
popover
.
noConflict
=
function
(){
return
a
.
fn
.
popover
=
c
,
this
}}(
jQuery
),
+
function
(
a
){
"
use strict
"
;
function
b
(
c
,
d
){
var
e
,
f
=
a
.
proxy
(
this
.
process
,
this
);
this
.
$element
=
a
(
a
(
c
).
is
(
"
body
"
)?
window
:
c
),
this
.
$body
=
a
(
"
body
"
),
this
.
$scrollElement
=
this
.
$element
.
on
(
"
scroll.bs.scroll-spy.data-api
"
,
f
),
this
.
options
=
a
.
extend
({},
b
.
DEFAULTS
,
d
),
this
.
selector
=
(
this
.
options
.
target
||
(
e
=
a
(
c
).
attr
(
"
href
"
))
&&
e
.
replace
(
/.*
(?=
#
[^\s]
+$
)
/
,
""
)
||
""
)
+
"
.nav li > a
"
,
this
.
offsets
=
a
([]),
this
.
targets
=
a
([]),
this
.
activeTarget
=
null
,
this
.
refresh
(),
this
.
process
()}
b
.
DEFAULTS
=
{
offset
:
10
},
b
.
prototype
.
refresh
=
function
(){
var
b
=
this
.
$element
[
0
]
==
window
?
"
offset
"
:
"
position
"
;
this
.
offsets
=
a
([]),
this
.
targets
=
a
([]);{
var
c
=
this
;
this
.
$body
.
find
(
this
.
selector
).
map
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
target
"
)
||
d
.
attr
(
"
href
"
),
f
=
/^#./
.
test
(
e
)
&&
a
(
e
);
return
f
&&
f
.
length
&&
f
.
is
(
"
:visible
"
)
&&
[[
f
[
b
]().
top
+
(
!
a
.
isWindow
(
c
.
$scrollElement
.
get
(
0
))
&&
c
.
$scrollElement
.
scrollTop
()),
e
]]
||
null
}).
sort
(
function
(
a
,
b
){
return
a
[
0
]
-
b
[
0
]}).
each
(
function
(){
c
.
offsets
.
push
(
this
[
0
]),
c
.
targets
.
push
(
this
[
1
])})}},
b
.
prototype
.
process
=
function
(){
var
a
,
b
=
this
.
$scrollElement
.
scrollTop
()
+
this
.
options
.
offset
,
c
=
this
.
$scrollElement
[
0
].
scrollHeight
||
this
.
$body
[
0
].
scrollHeight
,
d
=
c
-
this
.
$scrollElement
.
height
(),
e
=
this
.
offsets
,
f
=
this
.
targets
,
g
=
this
.
activeTarget
;
if
(
b
>=
d
)
return
g
!=
(
a
=
f
.
last
()[
0
])
&&
this
.
activate
(
a
);
if
(
g
&&
b
<=
e
[
0
])
return
g
!=
(
a
=
f
[
0
])
&&
this
.
activate
(
a
);
for
(
a
=
e
.
length
;
a
--
;)
g
!=
f
[
a
]
&&
b
>=
e
[
a
]
&&
(
!
e
[
a
+
1
]
||
b
<=
e
[
a
+
1
])
&&
this
.
activate
(
f
[
a
])},
b
.
prototype
.
activate
=
function
(
b
){
this
.
activeTarget
=
b
,
a
(
this
.
selector
).
parentsUntil
(
this
.
options
.
target
,
"
.active
"
).
removeClass
(
"
active
"
);
var
c
=
this
.
selector
+
'
[data-target="
'
+
b
+
'
"],
'
+
this
.
selector
+
'
[href="
'
+
b
+
'
"]
'
,
d
=
a
(
c
).
parents
(
"
li
"
).
addClass
(
"
active
"
);
d
.
parent
(
"
.dropdown-menu
"
).
length
&&
(
d
=
d
.
closest
(
"
li.dropdown
"
).
addClass
(
"
active
"
)),
d
.
trigger
(
"
activate.bs.scrollspy
"
)};
var
c
=
a
.
fn
.
scrollspy
;
a
.
fn
.
scrollspy
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
bs.scrollspy
"
),
f
=
"
object
"
==
typeof
c
&&
c
;
e
||
d
.
data
(
"
bs.scrollspy
"
,
e
=
new
b
(
this
,
f
)),
"
string
"
==
typeof
c
&&
e
[
c
]()})},
a
.
fn
.
scrollspy
.
Constructor
=
b
,
a
.
fn
.
scrollspy
.
noConflict
=
function
(){
return
a
.
fn
.
scrollspy
=
c
,
this
},
a
(
window
).
on
(
"
load
"
,
function
(){
a
(
'
[data-spy="scroll"]
'
).
each
(
function
(){
var
b
=
a
(
this
);
b
.
scrollspy
(
b
.
data
())})})}(
jQuery
),
+
function
(
a
){
"
use strict
"
;
var
b
=
function
(
b
){
this
.
element
=
a
(
b
)};
b
.
prototype
.
show
=
function
(){
var
b
=
this
.
element
,
c
=
b
.
closest
(
"
ul:not(.dropdown-menu)
"
),
d
=
b
.
data
(
"
target
"
);
if
(
d
||
(
d
=
b
.
attr
(
"
href
"
),
d
=
d
&&
d
.
replace
(
/.*
(?=
#
[^\s]
*$
)
/
,
""
)),
!
b
.
parent
(
"
li
"
).
hasClass
(
"
active
"
)){
var
e
=
c
.
find
(
"
.active:last a
"
)[
0
],
f
=
a
.
Event
(
"
show.bs.tab
"
,{
relatedTarget
:
e
});
if
(
b
.
trigger
(
f
),
!
f
.
isDefaultPrevented
()){
var
g
=
a
(
d
);
this
.
activate
(
b
.
parent
(
"
li
"
),
c
),
this
.
activate
(
g
,
g
.
parent
(),
function
(){
b
.
trigger
({
type
:
"
shown.bs.tab
"
,
relatedTarget
:
e
})})}}},
b
.
prototype
.
activate
=
function
(
b
,
c
,
d
){
function
e
(){
f
.
removeClass
(
"
active
"
).
find
(
"
> .dropdown-menu > .active
"
).
removeClass
(
"
active
"
),
b
.
addClass
(
"
active
"
),
g
?(
b
[
0
].
offsetWidth
,
b
.
addClass
(
"
in
"
)):
b
.
removeClass
(
"
fade
"
),
b
.
parent
(
"
.dropdown-menu
"
)
&&
b
.
closest
(
"
li.dropdown
"
).
addClass
(
"
active
"
),
d
&&
d
()}
var
f
=
c
.
find
(
"
> .active
"
),
g
=
d
&&
a
.
support
.
transition
&&
f
.
hasClass
(
"
fade
"
);
g
?
f
.
one
(
a
.
support
.
transition
.
end
,
e
).
emulateTransitionEnd
(
150
):
e
(),
f
.
removeClass
(
"
in
"
)};
var
c
=
a
.
fn
.
tab
;
a
.
fn
.
tab
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
bs.tab
"
);
e
||
d
.
data
(
"
bs.tab
"
,
e
=
new
b
(
this
)),
"
string
"
==
typeof
c
&&
e
[
c
]()})},
a
.
fn
.
tab
.
Constructor
=
b
,
a
.
fn
.
tab
.
noConflict
=
function
(){
return
a
.
fn
.
tab
=
c
,
this
},
a
(
document
).
on
(
"
click.bs.tab.data-api
"
,
'
[data-toggle="tab"], [data-toggle="pill"]
'
,
function
(
b
){
b
.
preventDefault
(),
a
(
this
).
tab
(
"
show
"
)})}(
jQuery
),
+
function
(
a
){
"
use strict
"
;
var
b
=
function
(
c
,
d
){
this
.
options
=
a
.
extend
({},
b
.
DEFAULTS
,
d
),
this
.
$window
=
a
(
window
).
on
(
"
scroll.bs.affix.data-api
"
,
a
.
proxy
(
this
.
checkPosition
,
this
)).
on
(
"
click.bs.affix.data-api
"
,
a
.
proxy
(
this
.
checkPositionWithEventLoop
,
this
)),
this
.
$element
=
a
(
c
),
this
.
affixed
=
this
.
unpin
=
this
.
pinnedOffset
=
null
,
this
.
checkPosition
()};
b
.
RESET
=
"
affix affix-top affix-bottom
"
,
b
.
DEFAULTS
=
{
offset
:
0
},
b
.
prototype
.
getPinnedOffset
=
function
(){
if
(
this
.
pinnedOffset
)
return
this
.
pinnedOffset
;
this
.
$element
.
removeClass
(
b
.
RESET
).
addClass
(
"
affix
"
);
var
a
=
this
.
$window
.
scrollTop
(),
c
=
this
.
$element
.
offset
();
return
this
.
pinnedOffset
=
c
.
top
-
a
},
b
.
prototype
.
checkPositionWithEventLoop
=
function
(){
setTimeout
(
a
.
proxy
(
this
.
checkPosition
,
this
),
1
)},
b
.
prototype
.
checkPosition
=
function
(){
if
(
this
.
$element
.
is
(
"
:visible
"
)){
var
c
=
a
(
document
).
height
(),
d
=
this
.
$window
.
scrollTop
(),
e
=
this
.
$element
.
offset
(),
f
=
this
.
options
.
offset
,
g
=
f
.
top
,
h
=
f
.
bottom
;
"
top
"
==
this
.
affixed
&&
(
e
.
top
+=
d
),
"
object
"
!=
typeof
f
&&
(
h
=
g
=
f
),
"
function
"
==
typeof
g
&&
(
g
=
f
.
top
(
this
.
$element
)),
"
function
"
==
typeof
h
&&
(
h
=
f
.
bottom
(
this
.
$element
));
var
i
=
null
!=
this
.
unpin
&&
d
+
this
.
unpin
<=
e
.
top
?
!
1
:
null
!=
h
&&
e
.
top
+
this
.
$element
.
height
()
>=
c
-
h
?
"
bottom
"
:
null
!=
g
&&
g
>=
d
?
"
top
"
:
!
1
;
if
(
this
.
affixed
!==
i
){
this
.
unpin
&&
this
.
$element
.
css
(
"
top
"
,
""
);
var
j
=
"
affix
"
+
(
i
?
"
-
"
+
i
:
""
),
k
=
a
.
Event
(
j
+
"
.bs.affix
"
);
this
.
$element
.
trigger
(
k
),
k
.
isDefaultPrevented
()
||
(
this
.
affixed
=
i
,
this
.
unpin
=
"
bottom
"
==
i
?
this
.
getPinnedOffset
():
null
,
this
.
$element
.
removeClass
(
b
.
RESET
).
addClass
(
j
).
trigger
(
a
.
Event
(
j
.
replace
(
"
affix
"
,
"
affixed
"
))),
"
bottom
"
==
i
&&
this
.
$element
.
offset
({
top
:
c
-
h
-
this
.
$element
.
height
()}))}}};
var
c
=
a
.
fn
.
affix
;
a
.
fn
.
affix
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"
bs.affix
"
),
f
=
"
object
"
==
typeof
c
&&
c
;
e
||
d
.
data
(
"
bs.affix
"
,
e
=
new
b
(
this
,
f
)),
"
string
"
==
typeof
c
&&
e
[
c
]()})},
a
.
fn
.
affix
.
Constructor
=
b
,
a
.
fn
.
affix
.
noConflict
=
function
(){
return
a
.
fn
.
affix
=
c
,
this
},
a
(
window
).
on
(
"
load
"
,
function
(){
a
(
'
[data-spy="affix"]
'
).
each
(
function
(){
var
b
=
a
(
this
),
c
=
b
.
data
();
c
.
offset
=
c
.
offset
||
{},
c
.
offsetBottom
&&
(
c
.
offset
.
bottom
=
c
.
offsetBottom
),
c
.
offsetTop
&&
(
c
.
offset
.
top
=
c
.
offsetTop
),
b
.
affix
(
c
)})})}(
jQuery
);
\ No newline at end of file
This diff is collapsed.
Click to expand it.
docs/assets/js/customize.min.js
+
9
-
9
View file @
d07e8fec
No preview for this file type
This diff is collapsed.
Click to expand it.
docs/assets/js/docs.min.js
+
1
-
1
View file @
d07e8fec
...
...
@@ -7,7 +7,7 @@ Provided under the MIT License.
Commercial use requires attribution.
*/
var
Holder
=
Holder
||
{};
!
function
(
a
,
b
){
function
c
(
a
,
b
,
c
){
b
=
parseInt
(
b
,
10
),
a
=
parseInt
(
a
,
10
);
var
d
=
Math
.
max
(
b
,
a
),
e
=
Math
.
min
(
b
,
a
),
f
=
1
/
12
,
g
=
Math
.
min
(.
75
*
e
,.
75
*
d
*
f
);
return
{
height
:
Math
.
round
(
Math
.
max
(
c
.
size
,
g
))}}
function
d
(
a
){
var
b
=
[];
for
(
p
in
a
)
a
.
hasOwnProperty
(
p
)
&&
b
.
push
(
p
+
"
:
"
+
a
[
p
]);
return
b
.
join
(
"
;
"
)}
function
e
(
a
){
var
b
=
a
.
ctx
,
d
=
a
.
dimensions
,
e
=
a
.
template
,
f
=
a
.
ratio
,
g
=
a
.
holder
,
h
=
"
literal
"
==
g
.
textmode
,
i
=
"
exact
"
==
g
.
textmode
,
j
=
c
(
d
.
width
,
d
.
height
,
e
),
k
=
j
.
height
,
l
=
d
.
width
*
f
,
m
=
d
.
height
*
f
,
n
=
e
.
font
?
e
.
font
:
"
Arial,Helvetica,sans-serif
"
;
canvas
.
width
=
l
,
canvas
.
height
=
m
,
b
.
textAlign
=
"
center
"
,
b
.
textBaseline
=
"
middle
"
,
b
.
fillStyle
=
e
.
background
,
b
.
fillRect
(
0
,
0
,
l
,
m
),
b
.
fillStyle
=
e
.
foreground
,
b
.
font
=
"
bold
"
+
k
+
"
px
"
+
n
;
var
o
=
e
.
text
?
e
.
text
:
Math
.
floor
(
d
.
width
)
+
"
x
"
+
Math
.
floor
(
d
.
height
);
if
(
h
){
var
d
=
g
.
dimensions
;
o
=
d
.
width
+
"
x
"
+
d
.
height
}
else
if
(
i
&&
g
.
exact_dimensions
){
var
d
=
g
.
exact_dimensions
;
o
=
Math
.
floor
(
d
.
width
)
+
"
x
"
+
Math
.
floor
(
d
.
height
)}
var
p
=
b
.
measureText
(
o
).
width
;
return
p
/
l
>=
.
75
&&
(
k
=
Math
.
floor
(.
75
*
k
*
(
l
/
p
))),
b
.
font
=
"
bold
"
+
k
*
f
+
"
px
"
+
n
,
b
.
fillText
(
o
,
l
/
2
,
m
/
2
,
l
),
canvas
.
toDataURL
(
"
image/png
"
)}
function
f
(
a
){
var
b
=
a
.
dimensions
,
d
=
a
.
template
,
e
=
a
.
holder
,
f
=
"
literal
"
==
e
.
textmode
,
g
=
"
exact
"
==
e
.
textmode
,
h
=
c
(
b
.
width
,
b
.
height
,
d
),
i
=
h
.
height
,
j
=
b
.
width
,
k
=
b
.
height
,
l
=
d
.
font
?
d
.
font
:
"
Arial,Helvetica,sans-serif
"
,
m
=
d
.
text
?
d
.
text
:
Math
.
floor
(
b
.
width
)
+
"
x
"
+
Math
.
floor
(
b
.
height
);
if
(
f
){
var
b
=
e
.
dimensions
;
m
=
b
.
width
+
"
x
"
+
b
.
height
}
else
if
(
g
&&
e
.
exact_dimensions
){
var
b
=
e
.
exact_dimensions
;
m
=
Math
.
floor
(
b
.
width
)
+
"
x
"
+
Math
.
floor
(
b
.
height
)}
var
n
=
z
({
text
:
m
,
width
:
j
,
height
:
k
,
text_height
:
i
,
font
:
l
,
template
:
d
});
return
"
data:image/svg+xml;base64,
"
+
btoa
(
n
)}
function
g
(
a
){
return
r
.
use_canvas
&&!
r
.
use_svg
?
e
(
a
):
f
(
a
)}
function
h
(
a
,
b
,
c
,
d
){
var
e
=
c
.
dimensions
,
f
=
c
.
theme
,
h
=
c
.
text
?
decodeURIComponent
(
c
.
text
):
c
.
text
,
i
=
e
.
width
+
"
x
"
+
e
.
height
;
f
=
h
?
o
(
f
,{
text
:
h
}):
f
,
f
=
c
.
font
?
o
(
f
,{
font
:
c
.
font
}):
f
,
b
.
setAttribute
(
"
data-src
"
,
d
),
c
.
theme
=
f
,
b
.
holder_data
=
c
,
"
image
"
==
a
?(
b
.
setAttribute
(
"
alt
"
,
h
?
h
:
f
.
text
?
f
.
text
+
"
[
"
+
i
+
"
]
"
:
i
),(
r
.
use_fallback
||!
c
.
auto
)
&&
(
b
.
style
.
width
=
e
.
width
+
"
px
"
,
b
.
style
.
height
=
e
.
height
+
"
px
"
),
r
.
use_fallback
?
b
.
style
.
backgroundColor
=
f
.
background
:(
b
.
setAttribute
(
"
src
"
,
g
({
ctx
:
w
,
dimensions
:
e
,
template
:
f
,
ratio
:
x
,
holder
:
c
})),
c
.
textmode
&&
"
exact
"
==
c
.
textmode
&&
(
v
.
push
(
b
),
k
(
b
)))):
"
background
"
==
a
?
r
.
use_fallback
||
(
b
.
style
.
backgroundImage
=
"
url(
"
+
g
({
ctx
:
w
,
dimensions
:
e
,
template
:
f
,
ratio
:
x
,
holder
:
c
})
+
"
)
"
,
b
.
style
.
backgroundSize
=
e
.
width
+
"
px
"
+
e
.
height
+
"
px
"
):
"
fluid
"
==
a
&&
(
b
.
setAttribute
(
"
alt
"
,
h
?
h
:
f
.
text
?
f
.
text
+
"
[
"
+
i
+
"
]
"
:
i
),
"
%
"
==
e
.
height
.
slice
(
-
1
)?
b
.
style
.
height
=
e
.
height
:
null
!=
c
.
auto
&&
c
.
auto
||
(
b
.
style
.
height
=
e
.
height
+
"
px
"
),
"
%
"
==
e
.
width
.
slice
(
-
1
)?
b
.
style
.
width
=
e
.
width
:
null
!=
c
.
auto
&&
c
.
auto
||
(
b
.
style
.
width
=
e
.
width
+
"
px
"
),(
"
inline
"
==
b
.
style
.
display
||
""
===
b
.
style
.
display
||
"
none
"
==
b
.
style
.
display
)
&&
(
b
.
style
.
display
=
"
block
"
),
j
(
b
),
r
.
use_fallback
?
b
.
style
.
backgroundColor
=
f
.
background
:(
v
.
push
(
b
),
k
(
b
)))}
function
i
(
a
,
b
){
var
c
=
{
height
:
a
.
clientHeight
,
width
:
a
.
clientWidth
};
return
c
.
height
||
c
.
width
?(
a
.
removeAttribute
(
"
data-holder-invisible
"
),
c
):(
a
.
setAttribute
(
"
data-holder-invisible
"
,
!
0
),
b
.
call
(
this
,
a
)
,
void
0
)}
function
j
(
b
){
if
(
b
.
holder_data
){
var
c
=
i
(
b
,
a
.
invisible_error_fn
(
j
));
if
(
c
){
var
d
=
b
.
holder_data
;
d
.
initial_dimensions
=
c
,
d
.
fluid_data
=
{
fluid_height
:
"
%
"
==
d
.
dimensions
.
height
.
slice
(
-
1
),
fluid_width
:
"
%
"
==
d
.
dimensions
.
width
.
slice
(
-
1
),
mode
:
null
},
d
.
fluid_data
.
fluid_width
&&!
d
.
fluid_data
.
fluid_height
?(
d
.
fluid_data
.
mode
=
"
width
"
,
d
.
fluid_data
.
ratio
=
d
.
initial_dimensions
.
width
/
parseFloat
(
d
.
dimensions
.
height
)):
!
d
.
fluid_data
.
fluid_width
&&
d
.
fluid_data
.
fluid_height
&&
(
d
.
fluid_data
.
mode
=
"
height
"
,
d
.
fluid_data
.
ratio
=
parseFloat
(
d
.
dimensions
.
width
)
/
d
.
initial_dimensions
.
height
)}}}
function
k
(
b
){
var
c
;
c
=
null
==
b
.
nodeType
?
v
:[
b
];
for
(
var
d
in
c
)
if
(
c
.
hasOwnProperty
(
d
)){
var
e
=
c
[
d
];
if
(
e
.
holder_data
){
var
f
=
e
.
holder_data
,
h
=
i
(
e
,
a
.
invisible_error_fn
(
k
));
if
(
h
){
if
(
f
.
fluid
){
if
(
f
.
auto
)
switch
(
f
.
fluid_data
.
mode
){
case
"
width
"
:
h
.
height
=
h
.
width
/
f
.
fluid_data
.
ratio
;
break
;
case
"
height
"
:
h
.
width
=
h
.
height
*
f
.
fluid_data
.
ratio
}
e
.
setAttribute
(
"
src
"
,
g
({
ctx
:
w
,
dimensions
:
h
,
template
:
f
.
theme
,
ratio
:
x
,
holder
:
f
}))}
f
.
textmode
&&
"
exact
"
==
f
.
textmode
&&
(
f
.
exact_dimensions
=
h
,
e
.
setAttribute
(
"
src
"
,
g
({
ctx
:
w
,
dimensions
:
f
.
dimensions
,
template
:
f
.
theme
,
ratio
:
x
,
holder
:
f
})))}}}}
function
l
(
b
,
c
){
for
(
var
d
=
{
theme
:
o
(
y
.
themes
.
gray
,{})},
e
=!
1
,
f
=
b
.
length
,
g
=
0
;
f
>
g
;
g
++
){
var
h
=
b
[
g
];
a
.
flags
.
dimensions
.
match
(
h
)?(
e
=!
0
,
d
.
dimensions
=
a
.
flags
.
dimensions
.
output
(
h
)):
a
.
flags
.
fluid
.
match
(
h
)?(
e
=!
0
,
d
.
dimensions
=
a
.
flags
.
fluid
.
output
(
h
),
d
.
fluid
=!
0
):
a
.
flags
.
textmode
.
match
(
h
)?
d
.
textmode
=
a
.
flags
.
textmode
.
output
(
h
):
a
.
flags
.
colors
.
match
(
h
)?
d
.
theme
=
a
.
flags
.
colors
.
output
(
h
):
c
.
themes
[
h
]?
c
.
themes
.
hasOwnProperty
(
h
)
&&
(
d
.
theme
=
o
(
c
.
themes
[
h
],{})):
a
.
flags
.
font
.
match
(
h
)?
d
.
font
=
a
.
flags
.
font
.
output
(
h
):
a
.
flags
.
auto
.
match
(
h
)?
d
.
auto
=!
0
:
a
.
flags
.
text
.
match
(
h
)
&&
(
d
.
text
=
a
.
flags
.
text
.
output
(
h
))}
return
e
?
d
:
!
1
}
function
m
(
a
,
b
){
var
c
=
"
complete
"
,
d
=
"
readystatechange
"
,
e
=!
1
,
f
=
e
,
g
=!
0
,
h
=
a
.
document
,
i
=
h
.
documentElement
,
j
=
h
.
addEventListener
?
"
addEventListener
"
:
"
attachEvent
"
,
k
=
h
.
addEventListener
?
"
removeEventListener
"
:
"
detachEvent
"
,
l
=
h
.
addEventListener
?
""
:
"
on
"
,
m
=
function
(
g
){(
g
.
type
!=
d
||
h
.
readyState
==
c
)
&&
((
"
load
"
==
g
.
type
?
a
:
h
)[
k
](
l
+
g
.
type
,
m
,
e
),
!
f
&&
(
f
=!
0
)
&&
b
.
call
(
a
,
null
))},
n
=
function
(){
try
{
i
.
doScroll
(
"
left
"
)}
catch
(
a
){
return
setTimeout
(
n
,
50
)
,
void
0
}
m
(
"
poll
"
)};
if
(
h
.
readyState
==
c
)
b
.
call
(
a
,
"
lazy
"
);
else
{
if
(
h
.
createEventObject
&&
i
.
doScroll
){
try
{
g
=!
a
.
frameElement
}
catch
(
o
){}
g
&&
n
()}
h
[
j
](
l
+
"
DOMContentLoaded
"
,
m
,
e
),
h
[
j
](
l
+
d
,
m
,
e
),
a
[
j
](
l
+
"
load
"
,
m
,
e
)}}
function
n
(
a
,
b
){
var
a
=
a
.
match
(
/^
(\W)?(
.*
)
/
),
b
=
b
||
document
,
c
=
b
[
"
getElement
"
+
(
a
[
1
]?
"
#
"
==
a
[
1
]?
"
ById
"
:
"
sByClassName
"
:
"
sByTagName
"
)],
d
=
c
.
call
(
b
,
a
[
2
]),
e
=
[];
return
null
!==
d
&&
(
e
=
d
.
length
||
0
===
d
.
length
?
d
:[
d
]),
e
}
function
o
(
a
,
b
){
var
c
=
{};
for
(
var
d
in
a
)
a
.
hasOwnProperty
(
d
)
&&
(
c
[
d
]
=
a
[
d
]);
for
(
var
d
in
b
)
b
.
hasOwnProperty
(
d
)
&&
(
c
[
d
]
=
b
[
d
]);
return
c
}
var
q
=
{
use_svg
:
!
1
,
use_canvas
:
!
1
,
use_fallback
:
!
1
},
r
=
{},
s
=!
1
;
canvas
=
document
.
createElement
(
"
canvas
"
);
var
t
=
1
,
u
=
1
,
v
=
[];
if
(
canvas
.
getContext
)
if
(
canvas
.
toDataURL
(
"
image/png
"
).
indexOf
(
"
data:image/png
"
)
<
0
)
q
.
use_fallback
=!
0
;
else
var
w
=
canvas
.
getContext
(
"
2d
"
);
else
q
.
use_fallback
=!
0
;
document
.
createElementNS
&&
document
.
createElementNS
(
"
http://www.w3.org/2000/svg
"
,
"
svg
"
).
createSVGRect
&&
(
q
.
use_svg
=!
0
,
q
.
use_canvas
=!
1
),
q
.
use_fallback
||
(
t
=
window
.
devicePixelRatio
||
1
,
u
=
w
.
webkitBackingStorePixelRatio
||
w
.
mozBackingStorePixelRatio
||
w
.
msBackingStorePixelRatio
||
w
.
oBackingStorePixelRatio
||
w
.
backingStorePixelRatio
||
1
);
var
x
=
t
/
u
,
y
=
{
domain
:
"
holder.js
"
,
images
:
"
img
"
,
bgnodes
:
"
.holderjs
"
,
themes
:{
gray
:{
background
:
"
#eee
"
,
foreground
:
"
#aaa
"
,
size
:
12
},
social
:{
background
:
"
#3a5a97
"
,
foreground
:
"
#fff
"
,
size
:
12
},
industrial
:{
background
:
"
#434A52
"
,
foreground
:
"
#C2F200
"
,
size
:
12
},
sky
:{
background
:
"
#0D8FDB
"
,
foreground
:
"
#fff
"
,
size
:
12
},
vine
:{
background
:
"
#39DBAC
"
,
foreground
:
"
#1E292C
"
,
size
:
12
},
lava
:{
background
:
"
#F8591A
"
,
foreground
:
"
#1C2846
"
,
size
:
12
}},
stylesheet
:
""
};
a
.
flags
=
{
dimensions
:{
regex
:
/^
(\d
+
)
x
(\d
+
)
$/
,
output
:
function
(
a
){
var
b
=
this
.
regex
.
exec
(
a
);
return
{
width
:
+
b
[
1
],
height
:
+
b
[
2
]}}},
fluid
:{
regex
:
/^
([
0-9%
]
+
)
x
([
0-9%
]
+
)
$/
,
output
:
function
(
a
){
var
b
=
this
.
regex
.
exec
(
a
);
return
{
width
:
b
[
1
],
height
:
b
[
2
]}}},
colors
:{
regex
:
/#
([
0-9a-f
]{3,})\:
#
([
0-9a-f
]{3,})
/i
,
output
:
function
(
a
){
var
b
=
this
.
regex
.
exec
(
a
);
return
{
size
:
y
.
themes
.
gray
.
size
,
foreground
:
"
#
"
+
b
[
2
],
background
:
"
#
"
+
b
[
1
]}}},
text
:{
regex
:
/text
\:(
.*
)
/
,
output
:
function
(
a
){
return
this
.
regex
.
exec
(
a
)[
1
]}},
font
:{
regex
:
/font
\:(
.*
)
/
,
output
:
function
(
a
){
return
this
.
regex
.
exec
(
a
)[
1
]}},
auto
:{
regex
:
/^auto$/
},
textmode
:{
regex
:
/textmode
\:(
.*
)
/
,
output
:
function
(
a
){
return
this
.
regex
.
exec
(
a
)[
1
]}}};
var
z
=
function
(){
var
a
=
new
XMLSerializer
,
b
=
"
http://www.w3.org/2000/svg
"
,
c
=
document
.
createElementNS
(
b
,
"
svg
"
);
c
.
setAttribute
(
"
xmlns
"
,
"
http://www.w3.org/2000/svg
"
),
c
.
setAttribute
(
"
xmlns:xlink
"
,
"
http://www.w3.org/1999/xlink
"
);
var
e
=
document
.
createElementNS
(
b
,
"
rect
"
),
f
=
document
.
createElementNS
(
b
,
"
text
"
),
g
=
document
.
createTextNode
(
null
);
return
f
.
setAttribute
(
"
text-anchor
"
,
"
middle
"
),
f
.
appendChild
(
g
),
c
.
appendChild
(
e
),
c
.
appendChild
(
f
),
function
(
b
){
return
c
.
setAttribute
(
"
width
"
,
b
.
width
),
c
.
setAttribute
(
"
height
"
,
b
.
height
),
e
.
setAttribute
(
"
width
"
,
b
.
width
),
e
.
setAttribute
(
"
height
"
,
b
.
height
),
e
.
setAttribute
(
"
fill
"
,
b
.
template
.
background
),
f
.
setAttribute
(
"
x
"
,
b
.
width
/
2
),
f
.
setAttribute
(
"
y
"
,
b
.
height
/
2
),
g
.
nodeValue
=
b
.
text
,
f
.
setAttribute
(
"
style
"
,
d
({
fill
:
b
.
template
.
foreground
,
"
font-weight
"
:
"
bold
"
,
"
font-size
"
:
b
.
text_height
+
"
px
"
,
"
font-family
"
:
b
.
font
,
"
dominant-baseline
"
:
"
central
"
})),
a
.
serializeToString
(
c
)}}();
for
(
var
A
in
a
.
flags
)
a
.
flags
.
hasOwnProperty
(
A
)
&&
(
a
.
flags
[
A
].
match
=
function
(
a
){
return
a
.
match
(
this
.
regex
)});
a
.
invisible_error_fn
=
function
(){
return
function
(
a
){
if
(
a
.
hasAttribute
(
"
data-holder-invisible
"
))
throw
new
Error
(
"
Holder: invisible placeholder
"
)}},
a
.
add_theme
=
function
(
b
,
c
){
return
null
!=
b
&&
null
!=
c
&&
(
y
.
themes
[
b
]
=
c
),
a
},
a
.
add_image
=
function
(
b
,
c
){
var
d
=
n
(
c
);
if
(
d
.
length
)
for
(
var
e
=
0
,
f
=
d
.
length
;
f
>
e
;
e
++
){
var
g
=
document
.
createElement
(
"
img
"
);
g
.
setAttribute
(
"
data-src
"
,
b
),
d
[
e
].
appendChild
(
g
)}
return
a
},
a
.
run
=
function
(
b
){
r
=
o
({},
q
),
s
=!
0
;
var
c
=
o
(
y
,
b
),
d
=
[],
e
=
[],
f
=
[];
for
(
null
!=
c
.
use_canvas
&&
c
.
use_canvas
&&
(
r
.
use_canvas
=!
0
,
r
.
use_svg
=!
1
),
"
string
"
==
typeof
c
.
images
?
e
=
n
(
c
.
images
):
window
.
NodeList
&&
c
.
images
instanceof
window
.
NodeList
?
e
=
c
.
images
:
window
.
Node
&&
c
.
images
instanceof
window
.
Node
?
e
=
[
c
.
images
]:
window
.
HTMLCollection
&&
c
.
images
instanceof
window
.
HTMLCollection
&&
(
e
=
c
.
images
),
"
string
"
==
typeof
c
.
bgnodes
?
f
=
n
(
c
.
bgnodes
):
window
.
NodeList
&&
c
.
elements
instanceof
window
.
NodeList
?
f
=
c
.
bgnodes
:
window
.
Node
&&
c
.
bgnodes
instanceof
window
.
Node
&&
(
f
=
[
c
.
bgnodes
]),
k
=
0
,
j
=
e
.
length
;
j
>
k
;
k
++
)
d
.
push
(
e
[
k
]);
var
g
=
document
.
getElementById
(
"
holderjs-style
"
);
g
||
(
g
=
document
.
createElement
(
"
style
"
),
g
.
setAttribute
(
"
id
"
,
"
holderjs-style
"
),
g
.
type
=
"
text/css
"
,
document
.
getElementsByTagName
(
"
head
"
)[
0
].
appendChild
(
g
)),
c
.
nocss
||
(
g
.
styleSheet
?
g
.
styleSheet
.
cssText
+=
c
.
stylesheet
:
g
.
appendChild
(
document
.
createTextNode
(
c
.
stylesheet
)));
for
(
var
i
=
new
RegExp
(
c
.
domain
+
'
/(.*?)"?
\\
)
'
),
j
=
f
.
length
,
k
=
0
;
j
>
k
;
k
++
){
var
m
=
window
.
getComputedStyle
(
f
[
k
],
null
).
getPropertyValue
(
"
background-image
"
),
p
=
m
.
match
(
i
),
t
=
f
[
k
].
getAttribute
(
"
data-background-src
"
);
if
(
p
){
var
u
=
l
(
p
[
1
].
split
(
"
/
"
),
c
);
u
&&
h
(
"
background
"
,
f
[
k
],
u
,
m
)}
else
if
(
null
!=
t
){
var
u
=
l
(
t
.
substr
(
t
.
lastIndexOf
(
c
.
domain
)
+
c
.
domain
.
length
+
1
).
split
(
"
/
"
),
c
);
u
&&
h
(
"
background
"
,
f
[
k
],
u
,
m
)}}
for
(
j
=
d
.
length
,
k
=
0
;
j
>
k
;
k
++
){
var
v
,
w
;
w
=
v
=
m
=
null
;
try
{
w
=
d
[
k
].
getAttribute
(
"
src
"
),
attr_datasrc
=
d
[
k
].
getAttribute
(
"
data-src
"
)}
catch
(
x
){}
if
(
null
==
attr_datasrc
&&
w
&&
w
.
indexOf
(
c
.
domain
)
>=
0
?
m
=
w
:
attr_datasrc
&&
attr_datasrc
.
indexOf
(
c
.
domain
)
>=
0
&&
(
m
=
attr_datasrc
),
m
){
var
u
=
l
(
m
.
substr
(
m
.
lastIndexOf
(
c
.
domain
)
+
c
.
domain
.
length
+
1
).
split
(
"
/
"
),
c
);
u
&&
(
u
.
fluid
?
h
(
"
fluid
"
,
d
[
k
],
u
,
m
):
h
(
"
image
"
,
d
[
k
],
u
,
m
))}}
return
a
},
m
(
b
,
function
(){
window
.
addEventListener
?(
window
.
addEventListener
(
"
resize
"
,
k
,
!
1
),
window
.
addEventListener
(
"
orientationchange
"
,
k
,
!
1
)):
window
.
attachEvent
(
"
onresize
"
,
k
),
s
||
a
.
run
({})}),
"
function
"
==
typeof
define
&&
define
.
amd
&&
define
([],
function
(){
return
a
}),
function
(){
function
a
(
a
){
this
.
message
=
a
}
var
b
=
"
undefined
"
!=
typeof
exports
?
exports
:
this
,
c
=
"
ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=
"
;
a
.
prototype
=
Error
(),
a
.
prototype
.
name
=
"
InvalidCharacterError
"
,
b
.
btoa
||
(
b
.
btoa
=
function
(
b
){
for
(
var
d
,
e
,
f
=
0
,
g
=
c
,
h
=
""
;
b
.
charAt
(
0
|
f
)
||
(
g
=
"
=
"
,
f
%
1
);
h
+=
g
.
charAt
(
63
&
d
>>
8
-
8
*
(
f
%
1
))){
if
(
e
=
b
.
charCodeAt
(
f
+=
.
75
),
e
>
255
)
throw
new
a
(
"
'btoa' failed
"
);
d
=
d
<<
8
|
e
}
return
h
}),
b
.
atob
||
(
b
.
atob
=
function
(
b
){
if
(
b
=
b
.
replace
(
/=+$/
,
""
),
1
==
b
.
length
%
4
)
throw
new
a
(
"
'atob' failed
"
);
for
(
var
d
,
e
,
f
=
0
,
g
=
0
,
h
=
""
;
e
=
b
.
charAt
(
g
++
);
~
e
&&
(
d
=
f
%
4
?
64
*
d
+
e
:
e
,
f
++%
4
)?
h
+=
String
.
fromCharCode
(
255
&
d
>>
(
6
&-
2
*
f
)):
0
)
e
=
c
.
indexOf
(
e
);
return
h
})}(),
document
.
getElementsByClassName
||
(
document
.
getElementsByClassName
=
function
(
a
){
var
b
,
c
,
d
,
e
=
document
,
f
=
[];
if
(
e
.
querySelectorAll
)
return
e
.
querySelectorAll
(
"
.
"
+
a
);
if
(
e
.
evaluate
)
for
(
c
=
"
.//*[contains(concat(' ', @class, ' '), '
"
+
a
+
"
')]
"
,
b
=
e
.
evaluate
(
c
,
e
,
null
,
0
,
null
);
d
=
b
.
iterateNext
();)
f
.
push
(
d
);
else
for
(
b
=
e
.
getElementsByTagName
(
"
*
"
),
c
=
new
RegExp
(
"
(^|
\\
s)
"
+
a
+
"
(
\\
s|$)
"
),
d
=
0
;
d
<
b
.
length
;
d
++
)
c
.
test
(
b
[
d
].
className
)
&&
f
.
push
(
b
[
d
]);
return
f
}),
window
.
getComputedStyle
||
(
window
.
getComputedStyle
=
function
(
a
){
return
this
.
el
=
a
,
this
.
getPropertyValue
=
function
(
b
){
var
c
=
/
(\-([
a-z
]){1})
/g
;
return
"
float
"
==
b
&&
(
b
=
"
styleFloat
"
),
c
.
test
(
b
)
&&
(
b
=
b
.
replace
(
c
,
function
(){
return
arguments
[
2
].
toUpperCase
()})),
a
.
currentStyle
[
b
]?
a
.
currentStyle
[
b
]:
null
},
this
}),
Object
.
prototype
.
hasOwnProperty
||
(
Object
.
prototype
.
hasOwnProperty
=
function
(
a
){
var
b
=
this
.
__proto__
||
this
.
constructor
.
prototype
;
return
a
in
this
&&
(
!
(
a
in
b
)
||
b
[
a
]
!==
this
[
a
])})}(
Holder
,
window
),
/*!
var
Holder
=
Holder
||
{};
!
function
(
a
,
b
){
function
c
(
a
,
b
,
c
){
b
=
parseInt
(
b
,
10
),
a
=
parseInt
(
a
,
10
);
var
d
=
Math
.
max
(
b
,
a
),
e
=
Math
.
min
(
b
,
a
),
f
=
1
/
12
,
g
=
Math
.
min
(.
75
*
e
,.
75
*
d
*
f
);
return
{
height
:
Math
.
round
(
Math
.
max
(
c
.
size
,
g
))}}
function
d
(
a
){
var
b
=
[];
for
(
p
in
a
)
a
.
hasOwnProperty
(
p
)
&&
b
.
push
(
p
+
"
:
"
+
a
[
p
]);
return
b
.
join
(
"
;
"
)}
function
e
(
a
){
var
b
=
a
.
ctx
,
d
=
a
.
dimensions
,
e
=
a
.
template
,
f
=
a
.
ratio
,
g
=
a
.
holder
,
h
=
"
literal
"
==
g
.
textmode
,
i
=
"
exact
"
==
g
.
textmode
,
j
=
c
(
d
.
width
,
d
.
height
,
e
),
k
=
j
.
height
,
l
=
d
.
width
*
f
,
m
=
d
.
height
*
f
,
n
=
e
.
font
?
e
.
font
:
"
Arial,Helvetica,sans-serif
"
;
canvas
.
width
=
l
,
canvas
.
height
=
m
,
b
.
textAlign
=
"
center
"
,
b
.
textBaseline
=
"
middle
"
,
b
.
fillStyle
=
e
.
background
,
b
.
fillRect
(
0
,
0
,
l
,
m
),
b
.
fillStyle
=
e
.
foreground
,
b
.
font
=
"
bold
"
+
k
+
"
px
"
+
n
;
var
o
=
e
.
text
?
e
.
text
:
Math
.
floor
(
d
.
width
)
+
"
x
"
+
Math
.
floor
(
d
.
height
);
if
(
h
){
var
d
=
g
.
dimensions
;
o
=
d
.
width
+
"
x
"
+
d
.
height
}
else
if
(
i
&&
g
.
exact_dimensions
){
var
d
=
g
.
exact_dimensions
;
o
=
Math
.
floor
(
d
.
width
)
+
"
x
"
+
Math
.
floor
(
d
.
height
)}
var
p
=
b
.
measureText
(
o
).
width
;
return
p
/
l
>=
.
75
&&
(
k
=
Math
.
floor
(.
75
*
k
*
(
l
/
p
))),
b
.
font
=
"
bold
"
+
k
*
f
+
"
px
"
+
n
,
b
.
fillText
(
o
,
l
/
2
,
m
/
2
,
l
),
canvas
.
toDataURL
(
"
image/png
"
)}
function
f
(
a
){
var
b
=
a
.
dimensions
,
d
=
a
.
template
,
e
=
a
.
holder
,
f
=
"
literal
"
==
e
.
textmode
,
g
=
"
exact
"
==
e
.
textmode
,
h
=
c
(
b
.
width
,
b
.
height
,
d
),
i
=
h
.
height
,
j
=
b
.
width
,
k
=
b
.
height
,
l
=
d
.
font
?
d
.
font
:
"
Arial,Helvetica,sans-serif
"
,
m
=
d
.
text
?
d
.
text
:
Math
.
floor
(
b
.
width
)
+
"
x
"
+
Math
.
floor
(
b
.
height
);
if
(
f
){
var
b
=
e
.
dimensions
;
m
=
b
.
width
+
"
x
"
+
b
.
height
}
else
if
(
g
&&
e
.
exact_dimensions
){
var
b
=
e
.
exact_dimensions
;
m
=
Math
.
floor
(
b
.
width
)
+
"
x
"
+
Math
.
floor
(
b
.
height
)}
var
n
=
z
({
text
:
m
,
width
:
j
,
height
:
k
,
text_height
:
i
,
font
:
l
,
template
:
d
});
return
"
data:image/svg+xml;base64,
"
+
btoa
(
n
)}
function
g
(
a
){
return
r
.
use_canvas
&&!
r
.
use_svg
?
e
(
a
):
f
(
a
)}
function
h
(
a
,
b
,
c
,
d
){
var
e
=
c
.
dimensions
,
f
=
c
.
theme
,
h
=
c
.
text
?
decodeURIComponent
(
c
.
text
):
c
.
text
,
i
=
e
.
width
+
"
x
"
+
e
.
height
;
f
=
h
?
o
(
f
,{
text
:
h
}):
f
,
f
=
c
.
font
?
o
(
f
,{
font
:
c
.
font
}):
f
,
b
.
setAttribute
(
"
data-src
"
,
d
),
c
.
theme
=
f
,
b
.
holder_data
=
c
,
"
image
"
==
a
?(
b
.
setAttribute
(
"
alt
"
,
h
?
h
:
f
.
text
?
f
.
text
+
"
[
"
+
i
+
"
]
"
:
i
),(
r
.
use_fallback
||!
c
.
auto
)
&&
(
b
.
style
.
width
=
e
.
width
+
"
px
"
,
b
.
style
.
height
=
e
.
height
+
"
px
"
),
r
.
use_fallback
?
b
.
style
.
backgroundColor
=
f
.
background
:(
b
.
setAttribute
(
"
src
"
,
g
({
ctx
:
w
,
dimensions
:
e
,
template
:
f
,
ratio
:
x
,
holder
:
c
})),
c
.
textmode
&&
"
exact
"
==
c
.
textmode
&&
(
v
.
push
(
b
),
k
(
b
)))):
"
background
"
==
a
?
r
.
use_fallback
||
(
b
.
style
.
backgroundImage
=
"
url(
"
+
g
({
ctx
:
w
,
dimensions
:
e
,
template
:
f
,
ratio
:
x
,
holder
:
c
})
+
"
)
"
,
b
.
style
.
backgroundSize
=
e
.
width
+
"
px
"
+
e
.
height
+
"
px
"
):
"
fluid
"
==
a
&&
(
b
.
setAttribute
(
"
alt
"
,
h
?
h
:
f
.
text
?
f
.
text
+
"
[
"
+
i
+
"
]
"
:
i
),
"
%
"
==
e
.
height
.
slice
(
-
1
)?
b
.
style
.
height
=
e
.
height
:
null
!=
c
.
auto
&&
c
.
auto
||
(
b
.
style
.
height
=
e
.
height
+
"
px
"
),
"
%
"
==
e
.
width
.
slice
(
-
1
)?
b
.
style
.
width
=
e
.
width
:
null
!=
c
.
auto
&&
c
.
auto
||
(
b
.
style
.
width
=
e
.
width
+
"
px
"
),(
"
inline
"
==
b
.
style
.
display
||
""
===
b
.
style
.
display
||
"
none
"
==
b
.
style
.
display
)
&&
(
b
.
style
.
display
=
"
block
"
),
j
(
b
),
r
.
use_fallback
?
b
.
style
.
backgroundColor
=
f
.
background
:(
v
.
push
(
b
),
k
(
b
)))}
function
i
(
a
,
b
){
var
c
=
{
height
:
a
.
clientHeight
,
width
:
a
.
clientWidth
};
return
c
.
height
||
c
.
width
?(
a
.
removeAttribute
(
"
data-holder-invisible
"
),
c
):(
a
.
setAttribute
(
"
data-holder-invisible
"
,
!
0
),
void
b
.
call
(
this
,
a
))}
function
j
(
b
){
if
(
b
.
holder_data
){
var
c
=
i
(
b
,
a
.
invisible_error_fn
(
j
));
if
(
c
){
var
d
=
b
.
holder_data
;
d
.
initial_dimensions
=
c
,
d
.
fluid_data
=
{
fluid_height
:
"
%
"
==
d
.
dimensions
.
height
.
slice
(
-
1
),
fluid_width
:
"
%
"
==
d
.
dimensions
.
width
.
slice
(
-
1
),
mode
:
null
},
d
.
fluid_data
.
fluid_width
&&!
d
.
fluid_data
.
fluid_height
?(
d
.
fluid_data
.
mode
=
"
width
"
,
d
.
fluid_data
.
ratio
=
d
.
initial_dimensions
.
width
/
parseFloat
(
d
.
dimensions
.
height
)):
!
d
.
fluid_data
.
fluid_width
&&
d
.
fluid_data
.
fluid_height
&&
(
d
.
fluid_data
.
mode
=
"
height
"
,
d
.
fluid_data
.
ratio
=
parseFloat
(
d
.
dimensions
.
width
)
/
d
.
initial_dimensions
.
height
)}}}
function
k
(
b
){
var
c
;
c
=
null
==
b
.
nodeType
?
v
:[
b
];
for
(
var
d
in
c
)
if
(
c
.
hasOwnProperty
(
d
)){
var
e
=
c
[
d
];
if
(
e
.
holder_data
){
var
f
=
e
.
holder_data
,
h
=
i
(
e
,
a
.
invisible_error_fn
(
k
));
if
(
h
){
if
(
f
.
fluid
){
if
(
f
.
auto
)
switch
(
f
.
fluid_data
.
mode
){
case
"
width
"
:
h
.
height
=
h
.
width
/
f
.
fluid_data
.
ratio
;
break
;
case
"
height
"
:
h
.
width
=
h
.
height
*
f
.
fluid_data
.
ratio
}
e
.
setAttribute
(
"
src
"
,
g
({
ctx
:
w
,
dimensions
:
h
,
template
:
f
.
theme
,
ratio
:
x
,
holder
:
f
}))}
f
.
textmode
&&
"
exact
"
==
f
.
textmode
&&
(
f
.
exact_dimensions
=
h
,
e
.
setAttribute
(
"
src
"
,
g
({
ctx
:
w
,
dimensions
:
f
.
dimensions
,
template
:
f
.
theme
,
ratio
:
x
,
holder
:
f
})))}}}}
function
l
(
b
,
c
){
for
(
var
d
=
{
theme
:
o
(
y
.
themes
.
gray
,{})},
e
=!
1
,
f
=
b
.
length
,
g
=
0
;
f
>
g
;
g
++
){
var
h
=
b
[
g
];
a
.
flags
.
dimensions
.
match
(
h
)?(
e
=!
0
,
d
.
dimensions
=
a
.
flags
.
dimensions
.
output
(
h
)):
a
.
flags
.
fluid
.
match
(
h
)?(
e
=!
0
,
d
.
dimensions
=
a
.
flags
.
fluid
.
output
(
h
),
d
.
fluid
=!
0
):
a
.
flags
.
textmode
.
match
(
h
)?
d
.
textmode
=
a
.
flags
.
textmode
.
output
(
h
):
a
.
flags
.
colors
.
match
(
h
)?
d
.
theme
=
a
.
flags
.
colors
.
output
(
h
):
c
.
themes
[
h
]?
c
.
themes
.
hasOwnProperty
(
h
)
&&
(
d
.
theme
=
o
(
c
.
themes
[
h
],{})):
a
.
flags
.
font
.
match
(
h
)?
d
.
font
=
a
.
flags
.
font
.
output
(
h
):
a
.
flags
.
auto
.
match
(
h
)?
d
.
auto
=!
0
:
a
.
flags
.
text
.
match
(
h
)
&&
(
d
.
text
=
a
.
flags
.
text
.
output
(
h
))}
return
e
?
d
:
!
1
}
function
m
(
a
,
b
){
var
c
=
"
complete
"
,
d
=
"
readystatechange
"
,
e
=!
1
,
f
=
e
,
g
=!
0
,
h
=
a
.
document
,
i
=
h
.
documentElement
,
j
=
h
.
addEventListener
?
"
addEventListener
"
:
"
attachEvent
"
,
k
=
h
.
addEventListener
?
"
removeEventListener
"
:
"
detachEvent
"
,
l
=
h
.
addEventListener
?
""
:
"
on
"
,
m
=
function
(
g
){(
g
.
type
!=
d
||
h
.
readyState
==
c
)
&&
((
"
load
"
==
g
.
type
?
a
:
h
)[
k
](
l
+
g
.
type
,
m
,
e
),
!
f
&&
(
f
=!
0
)
&&
b
.
call
(
a
,
null
))},
n
=
function
(){
try
{
i
.
doScroll
(
"
left
"
)}
catch
(
a
){
return
void
setTimeout
(
n
,
50
)}
m
(
"
poll
"
)};
if
(
h
.
readyState
==
c
)
b
.
call
(
a
,
"
lazy
"
);
else
{
if
(
h
.
createEventObject
&&
i
.
doScroll
){
try
{
g
=!
a
.
frameElement
}
catch
(
o
){}
g
&&
n
()}
h
[
j
](
l
+
"
DOMContentLoaded
"
,
m
,
e
),
h
[
j
](
l
+
d
,
m
,
e
),
a
[
j
](
l
+
"
load
"
,
m
,
e
)}}
function
n
(
a
,
b
){
var
a
=
a
.
match
(
/^
(\W)?(
.*
)
/
),
b
=
b
||
document
,
c
=
b
[
"
getElement
"
+
(
a
[
1
]?
"
#
"
==
a
[
1
]?
"
ById
"
:
"
sByClassName
"
:
"
sByTagName
"
)],
d
=
c
.
call
(
b
,
a
[
2
]),
e
=
[];
return
null
!==
d
&&
(
e
=
d
.
length
||
0
===
d
.
length
?
d
:[
d
]),
e
}
function
o
(
a
,
b
){
var
c
=
{};
for
(
var
d
in
a
)
a
.
hasOwnProperty
(
d
)
&&
(
c
[
d
]
=
a
[
d
]);
for
(
var
d
in
b
)
b
.
hasOwnProperty
(
d
)
&&
(
c
[
d
]
=
b
[
d
]);
return
c
}
var
q
=
{
use_svg
:
!
1
,
use_canvas
:
!
1
,
use_fallback
:
!
1
},
r
=
{},
s
=!
1
;
canvas
=
document
.
createElement
(
"
canvas
"
);
var
t
=
1
,
u
=
1
,
v
=
[];
if
(
canvas
.
getContext
)
if
(
canvas
.
toDataURL
(
"
image/png
"
).
indexOf
(
"
data:image/png
"
)
<
0
)
q
.
use_fallback
=!
0
;
else
var
w
=
canvas
.
getContext
(
"
2d
"
);
else
q
.
use_fallback
=!
0
;
document
.
createElementNS
&&
document
.
createElementNS
(
"
http://www.w3.org/2000/svg
"
,
"
svg
"
).
createSVGRect
&&
(
q
.
use_svg
=!
0
,
q
.
use_canvas
=!
1
),
q
.
use_fallback
||
(
t
=
window
.
devicePixelRatio
||
1
,
u
=
w
.
webkitBackingStorePixelRatio
||
w
.
mozBackingStorePixelRatio
||
w
.
msBackingStorePixelRatio
||
w
.
oBackingStorePixelRatio
||
w
.
backingStorePixelRatio
||
1
);
var
x
=
t
/
u
,
y
=
{
domain
:
"
holder.js
"
,
images
:
"
img
"
,
bgnodes
:
"
.holderjs
"
,
themes
:{
gray
:{
background
:
"
#eee
"
,
foreground
:
"
#aaa
"
,
size
:
12
},
social
:{
background
:
"
#3a5a97
"
,
foreground
:
"
#fff
"
,
size
:
12
},
industrial
:{
background
:
"
#434A52
"
,
foreground
:
"
#C2F200
"
,
size
:
12
},
sky
:{
background
:
"
#0D8FDB
"
,
foreground
:
"
#fff
"
,
size
:
12
},
vine
:{
background
:
"
#39DBAC
"
,
foreground
:
"
#1E292C
"
,
size
:
12
},
lava
:{
background
:
"
#F8591A
"
,
foreground
:
"
#1C2846
"
,
size
:
12
}},
stylesheet
:
""
};
a
.
flags
=
{
dimensions
:{
regex
:
/^
(\d
+
)
x
(\d
+
)
$/
,
output
:
function
(
a
){
var
b
=
this
.
regex
.
exec
(
a
);
return
{
width
:
+
b
[
1
],
height
:
+
b
[
2
]}}},
fluid
:{
regex
:
/^
([
0-9%
]
+
)
x
([
0-9%
]
+
)
$/
,
output
:
function
(
a
){
var
b
=
this
.
regex
.
exec
(
a
);
return
{
width
:
b
[
1
],
height
:
b
[
2
]}}},
colors
:{
regex
:
/#
([
0-9a-f
]{3,})\:
#
([
0-9a-f
]{3,})
/i
,
output
:
function
(
a
){
var
b
=
this
.
regex
.
exec
(
a
);
return
{
size
:
y
.
themes
.
gray
.
size
,
foreground
:
"
#
"
+
b
[
2
],
background
:
"
#
"
+
b
[
1
]}}},
text
:{
regex
:
/text
\:(
.*
)
/
,
output
:
function
(
a
){
return
this
.
regex
.
exec
(
a
)[
1
]}},
font
:{
regex
:
/font
\:(
.*
)
/
,
output
:
function
(
a
){
return
this
.
regex
.
exec
(
a
)[
1
]}},
auto
:{
regex
:
/^auto$/
},
textmode
:{
regex
:
/textmode
\:(
.*
)
/
,
output
:
function
(
a
){
return
this
.
regex
.
exec
(
a
)[
1
]}}};
var
z
=
function
(){
var
a
=
new
XMLSerializer
,
b
=
"
http://www.w3.org/2000/svg
"
,
c
=
document
.
createElementNS
(
b
,
"
svg
"
);
c
.
setAttribute
(
"
xmlns
"
,
"
http://www.w3.org/2000/svg
"
),
c
.
setAttribute
(
"
xmlns:xlink
"
,
"
http://www.w3.org/1999/xlink
"
);
var
e
=
document
.
createElementNS
(
b
,
"
rect
"
),
f
=
document
.
createElementNS
(
b
,
"
text
"
),
g
=
document
.
createTextNode
(
null
);
return
f
.
setAttribute
(
"
text-anchor
"
,
"
middle
"
),
f
.
appendChild
(
g
),
c
.
appendChild
(
e
),
c
.
appendChild
(
f
),
function
(
b
){
return
c
.
setAttribute
(
"
width
"
,
b
.
width
),
c
.
setAttribute
(
"
height
"
,
b
.
height
),
e
.
setAttribute
(
"
width
"
,
b
.
width
),
e
.
setAttribute
(
"
height
"
,
b
.
height
),
e
.
setAttribute
(
"
fill
"
,
b
.
template
.
background
),
f
.
setAttribute
(
"
x
"
,
b
.
width
/
2
),
f
.
setAttribute
(
"
y
"
,
b
.
height
/
2
),
g
.
nodeValue
=
b
.
text
,
f
.
setAttribute
(
"
style
"
,
d
({
fill
:
b
.
template
.
foreground
,
"
font-weight
"
:
"
bold
"
,
"
font-size
"
:
b
.
text_height
+
"
px
"
,
"
font-family
"
:
b
.
font
,
"
dominant-baseline
"
:
"
central
"
})),
a
.
serializeToString
(
c
)}}();
for
(
var
A
in
a
.
flags
)
a
.
flags
.
hasOwnProperty
(
A
)
&&
(
a
.
flags
[
A
].
match
=
function
(
a
){
return
a
.
match
(
this
.
regex
)});
a
.
invisible_error_fn
=
function
(){
return
function
(
a
){
if
(
a
.
hasAttribute
(
"
data-holder-invisible
"
))
throw
new
Error
(
"
Holder: invisible placeholder
"
)}},
a
.
add_theme
=
function
(
b
,
c
){
return
null
!=
b
&&
null
!=
c
&&
(
y
.
themes
[
b
]
=
c
),
a
},
a
.
add_image
=
function
(
b
,
c
){
var
d
=
n
(
c
);
if
(
d
.
length
)
for
(
var
e
=
0
,
f
=
d
.
length
;
f
>
e
;
e
++
){
var
g
=
document
.
createElement
(
"
img
"
);
g
.
setAttribute
(
"
data-src
"
,
b
),
d
[
e
].
appendChild
(
g
)}
return
a
},
a
.
run
=
function
(
b
){
r
=
o
({},
q
),
s
=!
0
;
var
c
=
o
(
y
,
b
),
d
=
[],
e
=
[],
f
=
[];
for
(
null
!=
c
.
use_canvas
&&
c
.
use_canvas
&&
(
r
.
use_canvas
=!
0
,
r
.
use_svg
=!
1
),
"
string
"
==
typeof
c
.
images
?
e
=
n
(
c
.
images
):
window
.
NodeList
&&
c
.
images
instanceof
window
.
NodeList
?
e
=
c
.
images
:
window
.
Node
&&
c
.
images
instanceof
window
.
Node
?
e
=
[
c
.
images
]:
window
.
HTMLCollection
&&
c
.
images
instanceof
window
.
HTMLCollection
&&
(
e
=
c
.
images
),
"
string
"
==
typeof
c
.
bgnodes
?
f
=
n
(
c
.
bgnodes
):
window
.
NodeList
&&
c
.
elements
instanceof
window
.
NodeList
?
f
=
c
.
bgnodes
:
window
.
Node
&&
c
.
bgnodes
instanceof
window
.
Node
&&
(
f
=
[
c
.
bgnodes
]),
k
=
0
,
j
=
e
.
length
;
j
>
k
;
k
++
)
d
.
push
(
e
[
k
]);
var
g
=
document
.
getElementById
(
"
holderjs-style
"
);
g
||
(
g
=
document
.
createElement
(
"
style
"
),
g
.
setAttribute
(
"
id
"
,
"
holderjs-style
"
),
g
.
type
=
"
text/css
"
,
document
.
getElementsByTagName
(
"
head
"
)[
0
].
appendChild
(
g
)),
c
.
nocss
||
(
g
.
styleSheet
?
g
.
styleSheet
.
cssText
+=
c
.
stylesheet
:
g
.
appendChild
(
document
.
createTextNode
(
c
.
stylesheet
)));
for
(
var
i
=
new
RegExp
(
c
.
domain
+
'
/(.*?)"?
\\
)
'
),
j
=
f
.
length
,
k
=
0
;
j
>
k
;
k
++
){
var
m
=
window
.
getComputedStyle
(
f
[
k
],
null
).
getPropertyValue
(
"
background-image
"
),
p
=
m
.
match
(
i
),
t
=
f
[
k
].
getAttribute
(
"
data-background-src
"
);
if
(
p
){
var
u
=
l
(
p
[
1
].
split
(
"
/
"
),
c
);
u
&&
h
(
"
background
"
,
f
[
k
],
u
,
m
)}
else
if
(
null
!=
t
){
var
u
=
l
(
t
.
substr
(
t
.
lastIndexOf
(
c
.
domain
)
+
c
.
domain
.
length
+
1
).
split
(
"
/
"
),
c
);
u
&&
h
(
"
background
"
,
f
[
k
],
u
,
m
)}}
for
(
j
=
d
.
length
,
k
=
0
;
j
>
k
;
k
++
){
var
v
,
w
;
w
=
v
=
m
=
null
;
try
{
w
=
d
[
k
].
getAttribute
(
"
src
"
),
attr_datasrc
=
d
[
k
].
getAttribute
(
"
data-src
"
)}
catch
(
x
){}
if
(
null
==
attr_datasrc
&&
w
&&
w
.
indexOf
(
c
.
domain
)
>=
0
?
m
=
w
:
attr_datasrc
&&
attr_datasrc
.
indexOf
(
c
.
domain
)
>=
0
&&
(
m
=
attr_datasrc
),
m
){
var
u
=
l
(
m
.
substr
(
m
.
lastIndexOf
(
c
.
domain
)
+
c
.
domain
.
length
+
1
).
split
(
"
/
"
),
c
);
u
&&
(
u
.
fluid
?
h
(
"
fluid
"
,
d
[
k
],
u
,
m
):
h
(
"
image
"
,
d
[
k
],
u
,
m
))}}
return
a
},
m
(
b
,
function
(){
window
.
addEventListener
?(
window
.
addEventListener
(
"
resize
"
,
k
,
!
1
),
window
.
addEventListener
(
"
orientationchange
"
,
k
,
!
1
)):
window
.
attachEvent
(
"
onresize
"
,
k
),
s
||
a
.
run
({})}),
"
function
"
==
typeof
define
&&
define
.
amd
&&
define
([],
function
(){
return
a
}),
function
(){
function
a
(
a
){
this
.
message
=
a
}
var
b
=
"
undefined
"
!=
typeof
exports
?
exports
:
this
,
c
=
"
ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=
"
;
a
.
prototype
=
Error
(),
a
.
prototype
.
name
=
"
InvalidCharacterError
"
,
b
.
btoa
||
(
b
.
btoa
=
function
(
b
){
for
(
var
d
,
e
,
f
=
0
,
g
=
c
,
h
=
""
;
b
.
charAt
(
0
|
f
)
||
(
g
=
"
=
"
,
f
%
1
);
h
+=
g
.
charAt
(
63
&
d
>>
8
-
8
*
(
f
%
1
))){
if
(
e
=
b
.
charCodeAt
(
f
+=
.
75
),
e
>
255
)
throw
new
a
(
"
'btoa' failed
"
);
d
=
d
<<
8
|
e
}
return
h
}),
b
.
atob
||
(
b
.
atob
=
function
(
b
){
if
(
b
=
b
.
replace
(
/=+$/
,
""
),
1
==
b
.
length
%
4
)
throw
new
a
(
"
'atob' failed
"
);
for
(
var
d
,
e
,
f
=
0
,
g
=
0
,
h
=
""
;
e
=
b
.
charAt
(
g
++
);
~
e
&&
(
d
=
f
%
4
?
64
*
d
+
e
:
e
,
f
++%
4
)?
h
+=
String
.
fromCharCode
(
255
&
d
>>
(
6
&-
2
*
f
)):
0
)
e
=
c
.
indexOf
(
e
);
return
h
})}(),
document
.
getElementsByClassName
||
(
document
.
getElementsByClassName
=
function
(
a
){
var
b
,
c
,
d
,
e
=
document
,
f
=
[];
if
(
e
.
querySelectorAll
)
return
e
.
querySelectorAll
(
"
.
"
+
a
);
if
(
e
.
evaluate
)
for
(
c
=
"
.//*[contains(concat(' ', @class, ' '), '
"
+
a
+
"
')]
"
,
b
=
e
.
evaluate
(
c
,
e
,
null
,
0
,
null
);
d
=
b
.
iterateNext
();)
f
.
push
(
d
);
else
for
(
b
=
e
.
getElementsByTagName
(
"
*
"
),
c
=
new
RegExp
(
"
(^|
\\
s)
"
+
a
+
"
(
\\
s|$)
"
),
d
=
0
;
d
<
b
.
length
;
d
++
)
c
.
test
(
b
[
d
].
className
)
&&
f
.
push
(
b
[
d
]);
return
f
}),
window
.
getComputedStyle
||
(
window
.
getComputedStyle
=
function
(
a
){
return
this
.
el
=
a
,
this
.
getPropertyValue
=
function
(
b
){
var
c
=
/
(\-([
a-z
]){1})
/g
;
return
"
float
"
==
b
&&
(
b
=
"
styleFloat
"
),
c
.
test
(
b
)
&&
(
b
=
b
.
replace
(
c
,
function
(){
return
arguments
[
2
].
toUpperCase
()})),
a
.
currentStyle
[
b
]?
a
.
currentStyle
[
b
]:
null
},
this
}),
Object
.
prototype
.
hasOwnProperty
||
(
Object
.
prototype
.
hasOwnProperty
=
function
(
a
){
var
b
=
this
.
__proto__
||
this
.
constructor
.
prototype
;
return
a
in
this
&&
(
!
(
a
in
b
)
||
b
[
a
]
!==
this
[
a
])})}(
Holder
,
window
),
/*!
* JavaScript for Bootstrap's docs (http://getbootstrap.com)
* Copyright 2011-2014 Twitter, Inc.
* Licensed under the Creative Commons Attribution 3.0 Unported License. For
...
...
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