aboutsummaryrefslogtreecommitdiffstats
path: root/ui/jquery.effects.slide.js
blob: eeba117cf85ee8e349c0cd67b66f3533ca4ba46a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
/*
 * jQuery UI Effects Slide @VERSION
 *
 * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
 * Dual licensed under the MIT or GPL Version 2 licenses.
 * http://jquery.org/license
 *
 * http://docs.jquery.com/UI/Effects/Slide
 *
 * Depends:
 *	jquery.effects.core.js
 */
(function( $, undefined ) {

$.effects.slide = function( o ) {

	return this.queue( function() {

		// Create element
		var el = $( this ),
			props = ['position','top','bottom','left','right'],
			mode = $.effects.setMode( el, o.mode || 'show' ),
			direction = o.direction || 'left',
			ref = (direction == 'up' || direction == 'down') ? 'top' : 'left',
			motion = (direction == 'up' || direction == 'left') ? 'pos' : 'neg',
			distance,
			animation = {}; 

		// Adjust
		$.effects.save( el, props ); 
		el.show();
		$.effects.createWrapper( el ).css({
			overflow: 'hidden'
		}); 
		
		distance = o.distance || el[ ref == 'top' ? "outerHeight" : "outerWidth" ]({ 
			margin: true 
		});
		if (mode == 'show') {
			el.css( ref, motion == 'pos' ? (isNaN(distance) ? "-" + distance : -distance) : distance );
		}

		// Animation
		animation[ ref ] = ( mode == 'show' ? 
			(motion == 'pos' ? '+=' : '-=') : 
			(motion == 'pos' ? '-=' : '+=')) 
			+ distance;

		// Animate
		el.animate( animation, { 
			queue: false, 
			duration: o.duration, 
			easing: o.easing, 
			complete: function() {
				if ( mode == 'hide' ) {
					el.hide(); 
				}
				$.effects.restore( el, props );
				$.effects.removeWrapper( el );
				$.isFunction(o.complete) && o.complete.apply( this, arguments ); 
				el.dequeue();
			}
		});

	});

};

})(jQuery);