2 * jQuery UI Effects Fold 1.8.24
4 * Copyright 2012, AUTHORS.txt (http://jqueryui.com/about)
5 * Dual licensed under the MIT or GPL Version 2 licenses.
6 * http://jquery.org/license
8 * http://docs.jquery.com/UI/Effects/Fold
11 * jquery.effects.core.js
13 (function( $, undefined ) {
15 $.effects
.fold = function(o
) {
17 return this.queue(function() {
20 var el
= $(this), props
= ['position','top','bottom','left','right'];
23 var mode
= $.effects
.setMode(el
, o
.options
.mode
|| 'hide'); // Set Mode
24 var size
= o
.options
.size
|| 15; // Default fold size
25 var horizFirst
= !(!o
.options
.horizFirst
); // Ensure a boolean value
26 var duration
= o
.duration
? o
.duration
/ 2 : $.fx
.speeds
._default
/ 2;
29 $.effects
.save(el
, props
); el
.show(); // Save & Show
30 var wrapper
= $.effects
.createWrapper(el
).css({overflow
:'hidden'}); // Create Wrapper
31 var widthFirst
= ((mode
== 'show') != horizFirst
);
32 var ref
= widthFirst
? ['width', 'height'] : ['height', 'width'];
33 var distance
= widthFirst
? [wrapper
.width(), wrapper
.height()] : [wrapper
.height(), wrapper
.width()];
34 var percent
= /([0-9]+)%/.exec(size
);
35 if(percent
) size
= parseInt(percent
[1],10) / 100 * distance
[mode
== 'hide' ? 0 : 1];
36 if(mode
== 'show') wrapper
.css(horizFirst
? {height
: 0, width
: size
} : {height
: size
, width
: 0}); // Shift
39 var animation1
= {}, animation2
= {};
40 animation1
[ref
[0]] = mode
== 'show' ? distance
[0] : size
;
41 animation2
[ref
[1]] = mode
== 'show' ? distance
[1] : 0;
44 wrapper
.animate(animation1
, duration
, o
.options
.easing
)
45 .animate(animation2
, duration
, o
.options
.easing
, function() {
46 if(mode
== 'hide') el
.hide(); // Hide
47 $.effects
.restore(el
, props
); $.effects
.removeWrapper(el
); // Restore
48 if(o
.callback
) o
.callback
.apply(el
[0], arguments
); // Callback