2020-10-07 18:33:25 +02:00
|
|
|
/*!
|
2024-05-27 23:14:15 +02:00
|
|
|
* jQuery UI Effects Pulsate 1.13.3
|
|
|
|
* https://jqueryui.com
|
2020-10-07 18:33:25 +02:00
|
|
|
*
|
2024-05-27 23:14:15 +02:00
|
|
|
* Copyright OpenJS Foundation and other contributors
|
2020-10-07 18:33:25 +02:00
|
|
|
* Released under the MIT license.
|
2024-05-27 23:14:15 +02:00
|
|
|
* https://jquery.org/license
|
2020-10-07 18:33:25 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
//>>label: Pulsate Effect
|
|
|
|
//>>group: Effects
|
|
|
|
//>>description: Pulsates an element n times by changing the opacity to zero and back.
|
2024-05-27 23:14:15 +02:00
|
|
|
//>>docs: https://api.jqueryui.com/pulsate-effect/
|
|
|
|
//>>demos: https://jqueryui.com/effect/
|
2020-10-07 18:33:25 +02:00
|
|
|
|
|
|
|
( function( factory ) {
|
2021-09-10 02:02:59 +02:00
|
|
|
"use strict";
|
|
|
|
|
2020-10-07 18:33:25 +02:00
|
|
|
if ( typeof define === "function" && define.amd ) {
|
|
|
|
|
|
|
|
// AMD. Register as an anonymous module.
|
|
|
|
define( [
|
|
|
|
"jquery",
|
2024-05-27 23:14:15 +02:00
|
|
|
"../version",
|
|
|
|
"../effect"
|
2020-10-07 18:33:25 +02:00
|
|
|
], factory );
|
|
|
|
} else {
|
|
|
|
|
|
|
|
// Browser globals
|
|
|
|
factory( jQuery );
|
|
|
|
}
|
2021-09-10 02:02:59 +02:00
|
|
|
} )( function( $ ) {
|
|
|
|
"use strict";
|
2020-10-07 18:33:25 +02:00
|
|
|
|
|
|
|
return $.effects.define( "pulsate", "show", function( options, done ) {
|
|
|
|
var element = $( this ),
|
|
|
|
mode = options.mode,
|
|
|
|
show = mode === "show",
|
|
|
|
hide = mode === "hide",
|
|
|
|
showhide = show || hide,
|
|
|
|
|
|
|
|
// Showing or hiding leaves off the "last" animation
|
|
|
|
anims = ( ( options.times || 5 ) * 2 ) + ( showhide ? 1 : 0 ),
|
|
|
|
duration = options.duration / anims,
|
|
|
|
animateTo = 0,
|
|
|
|
i = 1,
|
|
|
|
queuelen = element.queue().length;
|
|
|
|
|
|
|
|
if ( show || !element.is( ":visible" ) ) {
|
|
|
|
element.css( "opacity", 0 ).show();
|
|
|
|
animateTo = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Anims - 1 opacity "toggles"
|
|
|
|
for ( ; i < anims; i++ ) {
|
|
|
|
element.animate( { opacity: animateTo }, duration, options.easing );
|
|
|
|
animateTo = 1 - animateTo;
|
|
|
|
}
|
|
|
|
|
|
|
|
element.animate( { opacity: animateTo }, duration, options.easing );
|
|
|
|
|
|
|
|
element.queue( done );
|
|
|
|
|
|
|
|
$.effects.unshift( element, queuelen, anims + 1 );
|
|
|
|
} );
|
|
|
|
|
2021-09-10 02:02:59 +02:00
|
|
|
} );
|