Make sure that jQuery works even when the individual modules are loaded separately...
[jquery.git] / src / dimensions.js
index d3c8418..de10832 100644 (file)
@@ -1,17 +1,19 @@
+(function( jQuery ) {
+
 // Create innerHeight, innerWidth, outerHeight and outerWidth methods
-jQuery.each([ "Height", "Width" ], function(i, name){
+jQuery.each([ "Height", "Width" ], function( i, name ) {
 
        var type = name.toLowerCase();
 
        // innerHeight and innerWidth
-       jQuery.fn["inner" + name] = function(){
+       jQuery.fn["inner" + name] = function() {
                return this[0] ?
                        jQuery.css( this[0], type, false, "padding" ) :
                        null;
        };
 
        // outerHeight and outerWidth
-       jQuery.fn["outer" + name] = function(margin) {
+       jQuery.fn["outer" + name] = function( margin ) {
                return this[0] ?
                        jQuery.css( this[0], type, false, margin ? "margin" : "border" ) :
                        null;
@@ -23,6 +25,13 @@ jQuery.each([ "Height", "Width" ], function(i, name){
                if ( !elem ) {
                        return size == null ? null : this;
                }
+               
+               if ( jQuery.isFunction( size ) ) {
+                       return this.each(function( i ) {
+                               var self = jQuery( this );
+                               self[ type ]( size.call( this, i, self[ type ]() ) );
+                       });
+               }
 
                return ("scrollTo" in elem && elem.document) ? // does it walk and quack like a window?
                        // Everyone else use document.documentElement or document.body depending on Quirks vs Standards mode
@@ -48,3 +57,5 @@ jQuery.each([ "Height", "Width" ], function(i, name){
        };
 
 });
+
+})( jQuery );