mirror of
https://github.com/jquery/jquery-ui.git
synced 2024-11-21 11:04:24 +00:00
dc67d2c5d2
For instance, this is useful for the jquery-ui-rails gem, which does not
use jQuery UI's own minification, but relies on Rails to minify the
files where necessary. Rails in turn uses UglifyJS for JS and YUI for
CSS, both of which respect the /*! ... */ convention.
(cherry picked from commit 37dcc3e21d
, dropped menu, spinner and tooltip)
50 lines
1.3 KiB
JavaScript
50 lines
1.3 KiB
JavaScript
/*!
|
|
* jQuery UI Effects Blind @VERSION
|
|
*
|
|
* Copyright 2012, 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/Blind
|
|
*
|
|
* Depends:
|
|
* jquery.effects.core.js
|
|
*/
|
|
(function( $, undefined ) {
|
|
|
|
$.effects.blind = function(o) {
|
|
|
|
return this.queue(function() {
|
|
|
|
// Create element
|
|
var el = $(this), props = ['position','top','bottom','left','right'];
|
|
|
|
// Set options
|
|
var mode = $.effects.setMode(el, o.options.mode || 'hide'); // Set Mode
|
|
var direction = o.options.direction || 'vertical'; // Default direction
|
|
|
|
// Adjust
|
|
$.effects.save(el, props); el.show(); // Save & Show
|
|
var wrapper = $.effects.createWrapper(el).css({overflow:'hidden'}); // Create Wrapper
|
|
var ref = (direction == 'vertical') ? 'height' : 'width';
|
|
var distance = (direction == 'vertical') ? wrapper.height() : wrapper.width();
|
|
if(mode == 'show') wrapper.css(ref, 0); // Shift
|
|
|
|
// Animation
|
|
var animation = {};
|
|
animation[ref] = mode == 'show' ? distance : 0;
|
|
|
|
// Animate
|
|
wrapper.animate(animation, o.duration, o.options.easing, function() {
|
|
if(mode == 'hide') el.hide(); // Hide
|
|
$.effects.restore(el, props); $.effects.removeWrapper(el); // Restore
|
|
if(o.callback) o.callback.apply(el[0], arguments); // Callback
|
|
el.dequeue();
|
|
});
|
|
|
|
});
|
|
|
|
};
|
|
|
|
})(jQuery);
|