aboutsummaryrefslogtreecommitdiffstats
path: root/ui/jquery.effects.drop.js
blob: 4265b737b4e50bc381b9de3e6e5abf3582d13a9d (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
/*
 * jQuery UI Effects Drop @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/Drop
 *
 * Depends:
 *	jquery.effects.core.js
 */
(function( $, undefined ) {

$.effects.effect.drop = function( o ) {

	return this.queue( function() {

		var el = $( this ), 
			props = [ 'position', 'top', 'bottom', 'left', 'right', 'opacity', "height", "width" ],
			mode = $.effects.setMode( el, o.mode || 'hide' ),
			direction = o.direction || 'left',
			ref = ( direction == 'up' || direction == 'down' ) ? 'top' : 'left',
			motion = ( direction == 'up' || direction == 'left' ) ? 'pos' : 'neg',
			animation = {
				opacity: mode == 'show' ? 1 : 0
			},
			distance;

		// Adjust
		$.effects.save( el, props ); 
		el.show(); 
		$.effects.createWrapper( el ); 

		distance = o.distance || el[ ref == 'top' ? 'outerHeight': 'outerWidth' ]({ margin: true }) / 2;

		if ( mode == 'show' ) {
			el
				.css( 'opacity', 0 )
				.css( ref, motion == 'pos' ? -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() {
				mode == 'hide' && el.hide();
				$.effects.restore( el, props ); 
				$.effects.removeWrapper( el ); 
				$.isFunction( o.complete ) && o.complete.apply(this, arguments);
				el.dequeue();
			}
		});

	});

};

})(jQuery);