aboutsummaryrefslogtreecommitdiffstats
path: root/ui/jquery.effects.shake.js
blob: 5e8875abebaef95beefea2bc5c45c10c61f4482a (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 Shake @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/Shake
 *
 * Depends:
 *	jquery.effects.core.js
 */
(function( $, undefined ) {

$.effects.shake = function( o ) {

	return this.queue( function() {

		var el = $( this ),
			props = [ 'position', 'top', 'bottom', 'left', 'right' ],
			mode = $.effects.setMode( el, o.mode || 'effect' ),
			direction = o.direction || 'left',
			distance = o.distance || 20,
			times = o.times || 3,
			speed = o.duration || 140,
			ref = (direction == 'up' || direction == 'down') ? 'top' : 'left',
			motion = (direction == 'up' || direction == 'left') ? 'pos' : 'neg',
			animation = {},
			animation1 = {},
			animation2 = {},
			i; 

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

		// Animation
		animation[ ref ] = ( motion == 'pos' ? '-=' : '+=' ) + distance;
		animation1[ ref ] = ( motion == 'pos' ? '+=' : '-=' ) + distance * 2;
		animation2[ ref ] = ( motion == 'pos' ? '-=' : '+=' ) + distance * 2;

		// Animate
		el.animate( animation, speed, o.easing );

		// Shakes
		for ( i = 1; i < times; i++ ) { 
			el.animate( animation1, speed, o.easing ).animate( animation2, speed, o.easing );
		};
		el
			.animate( animation1, speed, o.easing )
			.animate( animation, speed / 2, o.easing, function() { 

				// Last shake
				$.effects.restore( el, props ); 
				$.effects.removeWrapper( el ); 
				$.isFunction( o.complete ) && o.complete.apply( this, arguments ); 
			})
			.dequeue();
	});

};

})(jQuery);