mirror of
https://github.com/jquery/jquery-ui.git
synced 2025-01-07 20:34:24 +00:00
0c860b0d92
jQuery positional selectors () have been deprecated in [jQuery 3.4.0](https://blog.jquery.com/2019/04/10/jquery-3-4-0-released/) and they'll be removed in jQuery 4.0.0. This PR removes their usage. Most of the changes were possible without changing public API. However, dropping `:even` usage required a change to the [`header` option](https://api.jqueryui.com/accordion/#option-header) of the accordion widget. I made it an optional function; this will need to be documented. The polyfill for `.even()` & `.odd()` is added for jQuery <3.5.0. There was no usage of the :odd selector in the code but the `.odd()` method is also polyfilled for completeness. Closes gh-1904
105 lines
2.8 KiB
JavaScript
105 lines
2.8 KiB
JavaScript
var duration = 1000,
|
|
wait = 500;
|
|
|
|
function effect( elem, name, options ) {
|
|
$.extend( options, {
|
|
easing: "easeOutQuint"
|
|
} );
|
|
|
|
$( elem ).on( "click", function() {
|
|
$( this )
|
|
.addClass( "current" )
|
|
|
|
// delaying the initial animation makes sure that the queue stays in tact
|
|
.delay( 10 )
|
|
.hide( name, options, duration )
|
|
.delay( wait )
|
|
.show( name, options, duration, function() {
|
|
$( this ).removeClass( "current" );
|
|
} );
|
|
} );
|
|
}
|
|
|
|
$( "#hide" ).on( "click", function() {
|
|
$( this )
|
|
.addClass( "current" )
|
|
.hide( duration )
|
|
.delay( wait )
|
|
.show( duration, function() {
|
|
$( this ).removeClass( "current" );
|
|
} );
|
|
} );
|
|
|
|
effect( "#blindLeft", "blind", { direction: "left" } );
|
|
effect( "#blindUp", "blind", { direction: "up" } );
|
|
effect( "#blindRight", "blind", { direction: "right" } );
|
|
effect( "#blindDown", "blind", { direction: "down" } );
|
|
|
|
effect( "#bounce3times", "bounce", { times: 3 } );
|
|
|
|
effect( "#clipHorizontally", "clip", { direction: "horizontal" } );
|
|
effect( "#clipVertically", "clip", { direction: "vertical" } );
|
|
|
|
effect( "#dropDown", "drop", { direction: "down" } );
|
|
effect( "#dropUp", "drop", { direction: "up" } );
|
|
effect( "#dropLeft", "drop", { direction: "left" } );
|
|
effect( "#dropRight", "drop", { direction: "right" } );
|
|
|
|
effect( "#explode9", "explode", {} );
|
|
effect( "#explode36", "explode", { pieces: 36 } );
|
|
|
|
effect( "#fade", "fade", {} );
|
|
|
|
effect( "#fold", "fold", { size: 50 } );
|
|
|
|
effect( "#highlight", "highlight", {} );
|
|
|
|
effect( "#pulsate", "pulsate", { times: 2 } );
|
|
|
|
effect( "#puff", "puff", {} );
|
|
effect( "#scale", "scale", {} );
|
|
effect( "#size", "size", {} );
|
|
$( "#sizeToggle" ).on( "click", function() {
|
|
var options = { to: { width: 300, height: 300 } };
|
|
$( this )
|
|
.addClass( "current" )
|
|
.toggle( "size", options, duration )
|
|
.delay( wait )
|
|
.toggle( "size", options, duration, function() {
|
|
$( this ).removeClass( "current" );
|
|
} );
|
|
} );
|
|
|
|
$( "#shake" ).on( "click", function() {
|
|
$( this )
|
|
.addClass( "current" )
|
|
.effect( "shake", {}, 100, function() {
|
|
$( this ).removeClass( "current" );
|
|
} );
|
|
} );
|
|
|
|
effect( "#slideDown", "slide", { direction: "down" } );
|
|
effect( "#slideUp", "slide", { direction: "up" } );
|
|
effect( "#slideLeft", "slide", { direction: "left" } );
|
|
effect( "#slideRight", "slide", { direction: "right" } );
|
|
|
|
$( "#transfer" ).on( "click", function() {
|
|
$( this )
|
|
.addClass( "current" )
|
|
.effect( "transfer", { to: $( "div" ).eq( 0 ) }, 1000, function() {
|
|
$( this ).removeClass( "current" );
|
|
} );
|
|
} );
|
|
|
|
$( "#addClass" ).on( "click", function() {
|
|
$( this ).addClass( "current", duration, function() {
|
|
$( this ).removeClass( "current" );
|
|
} );
|
|
} );
|
|
$( "#removeClass" ).on( "click", function() {
|
|
$( this ).addClass( "current" ).removeClass( "current", duration );
|
|
} );
|
|
$( "#toggleClass" ).on( "click", function() {
|
|
$( this ).toggleClass( "current", duration );
|
|
} );
|