253 lines
		
	
	
		
			7.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			253 lines
		
	
	
		
			7.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
/*
 | 
						|
 * jQuery UI Position 1.8.10
 | 
						|
 *
 | 
						|
 * 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/Position
 | 
						|
 */
 | 
						|
(function( $, undefined ) {
 | 
						|
 | 
						|
$.ui = $.ui || {};
 | 
						|
 | 
						|
var horizontalPositions = /left|center|right/,
 | 
						|
	verticalPositions = /top|center|bottom/,
 | 
						|
	center = "center",
 | 
						|
	_position = $.fn.position,
 | 
						|
	_offset = $.fn.offset;
 | 
						|
 | 
						|
$.fn.position = function( options ) {
 | 
						|
	if ( !options || !options.of ) {
 | 
						|
		return _position.apply( this, arguments );
 | 
						|
	}
 | 
						|
 | 
						|
	// make a copy, we don't want to modify arguments
 | 
						|
	options = $.extend( {}, options );
 | 
						|
 | 
						|
	var target = $( options.of ),
 | 
						|
		targetElem = target[0],
 | 
						|
		collision = ( options.collision || "flip" ).split( " " ),
 | 
						|
		offset = options.offset ? options.offset.split( " " ) : [ 0, 0 ],
 | 
						|
		targetWidth,
 | 
						|
		targetHeight,
 | 
						|
		basePosition;
 | 
						|
 | 
						|
	if ( targetElem.nodeType === 9 ) {
 | 
						|
		targetWidth = target.width();
 | 
						|
		targetHeight = target.height();
 | 
						|
		basePosition = { top: 0, left: 0 };
 | 
						|
	// TODO: use $.isWindow() in 1.9
 | 
						|
	} else if ( targetElem.setTimeout ) {
 | 
						|
		targetWidth = target.width();
 | 
						|
		targetHeight = target.height();
 | 
						|
		basePosition = { top: target.scrollTop(), left: target.scrollLeft() };
 | 
						|
	} else if ( targetElem.preventDefault ) {
 | 
						|
		// force left top to allow flipping
 | 
						|
		options.at = "left top";
 | 
						|
		targetWidth = targetHeight = 0;
 | 
						|
		basePosition = { top: options.of.pageY, left: options.of.pageX };
 | 
						|
	} else {
 | 
						|
		targetWidth = target.outerWidth();
 | 
						|
		targetHeight = target.outerHeight();
 | 
						|
		basePosition = target.offset();
 | 
						|
	}
 | 
						|
 | 
						|
	// force my and at to have valid horizontal and veritcal positions
 | 
						|
	// if a value is missing or invalid, it will be converted to center 
 | 
						|
	$.each( [ "my", "at" ], function() {
 | 
						|
		var pos = ( options[this] || "" ).split( " " );
 | 
						|
		if ( pos.length === 1) {
 | 
						|
			pos = horizontalPositions.test( pos[0] ) ?
 | 
						|
				pos.concat( [center] ) :
 | 
						|
				verticalPositions.test( pos[0] ) ?
 | 
						|
					[ center ].concat( pos ) :
 | 
						|
					[ center, center ];
 | 
						|
		}
 | 
						|
		pos[ 0 ] = horizontalPositions.test( pos[0] ) ? pos[ 0 ] : center;
 | 
						|
		pos[ 1 ] = verticalPositions.test( pos[1] ) ? pos[ 1 ] : center;
 | 
						|
		options[ this ] = pos;
 | 
						|
	});
 | 
						|
 | 
						|
	// normalize collision option
 | 
						|
	if ( collision.length === 1 ) {
 | 
						|
		collision[ 1 ] = collision[ 0 ];
 | 
						|
	}
 | 
						|
 | 
						|
	// normalize offset option
 | 
						|
	offset[ 0 ] = parseInt( offset[0], 10 ) || 0;
 | 
						|
	if ( offset.length === 1 ) {
 | 
						|
		offset[ 1 ] = offset[ 0 ];
 | 
						|
	}
 | 
						|
	offset[ 1 ] = parseInt( offset[1], 10 ) || 0;
 | 
						|
 | 
						|
	if ( options.at[0] === "right" ) {
 | 
						|
		basePosition.left += targetWidth;
 | 
						|
	} else if ( options.at[0] === center ) {
 | 
						|
		basePosition.left += targetWidth / 2;
 | 
						|
	}
 | 
						|
 | 
						|
	if ( options.at[1] === "bottom" ) {
 | 
						|
		basePosition.top += targetHeight;
 | 
						|
	} else if ( options.at[1] === center ) {
 | 
						|
		basePosition.top += targetHeight / 2;
 | 
						|
	}
 | 
						|
 | 
						|
	basePosition.left += offset[ 0 ];
 | 
						|
	basePosition.top += offset[ 1 ];
 | 
						|
 | 
						|
	return this.each(function() {
 | 
						|
		var elem = $( this ),
 | 
						|
			elemWidth = elem.outerWidth(),
 | 
						|
			elemHeight = elem.outerHeight(),
 | 
						|
			marginLeft = parseInt( $.curCSS( this, "marginLeft", true ) ) || 0,
 | 
						|
			marginTop = parseInt( $.curCSS( this, "marginTop", true ) ) || 0,
 | 
						|
			collisionWidth = elemWidth + marginLeft +
 | 
						|
				( parseInt( $.curCSS( this, "marginRight", true ) ) || 0 ),
 | 
						|
			collisionHeight = elemHeight + marginTop +
 | 
						|
				( parseInt( $.curCSS( this, "marginBottom", true ) ) || 0 ),
 | 
						|
			position = $.extend( {}, basePosition ),
 | 
						|
			collisionPosition;
 | 
						|
 | 
						|
		if ( options.my[0] === "right" ) {
 | 
						|
			position.left -= elemWidth;
 | 
						|
		} else if ( options.my[0] === center ) {
 | 
						|
			position.left -= elemWidth / 2;
 | 
						|
		}
 | 
						|
 | 
						|
		if ( options.my[1] === "bottom" ) {
 | 
						|
			position.top -= elemHeight;
 | 
						|
		} else if ( options.my[1] === center ) {
 | 
						|
			position.top -= elemHeight / 2;
 | 
						|
		}
 | 
						|
 | 
						|
		// prevent fractions (see #5280)
 | 
						|
		position.left = Math.round( position.left );
 | 
						|
		position.top = Math.round( position.top );
 | 
						|
 | 
						|
		collisionPosition = {
 | 
						|
			left: position.left - marginLeft,
 | 
						|
			top: position.top - marginTop
 | 
						|
		};
 | 
						|
 | 
						|
		$.each( [ "left", "top" ], function( i, dir ) {
 | 
						|
			if ( $.ui.position[ collision[i] ] ) {
 | 
						|
				$.ui.position[ collision[i] ][ dir ]( position, {
 | 
						|
					targetWidth: targetWidth,
 | 
						|
					targetHeight: targetHeight,
 | 
						|
					elemWidth: elemWidth,
 | 
						|
					elemHeight: elemHeight,
 | 
						|
					collisionPosition: collisionPosition,
 | 
						|
					collisionWidth: collisionWidth,
 | 
						|
					collisionHeight: collisionHeight,
 | 
						|
					offset: offset,
 | 
						|
					my: options.my,
 | 
						|
					at: options.at
 | 
						|
				});
 | 
						|
			}
 | 
						|
		});
 | 
						|
 | 
						|
		if ( $.fn.bgiframe ) {
 | 
						|
			elem.bgiframe();
 | 
						|
		}
 | 
						|
		elem.offset( $.extend( position, { using: options.using } ) );
 | 
						|
	});
 | 
						|
};
 | 
						|
 | 
						|
$.ui.position = {
 | 
						|
	fit: {
 | 
						|
		left: function( position, data ) {
 | 
						|
			var win = $( window ),
 | 
						|
				over = data.collisionPosition.left + data.collisionWidth - win.width() - win.scrollLeft();
 | 
						|
			position.left = over > 0 ? position.left - over : Math.max( position.left - data.collisionPosition.left, position.left );
 | 
						|
		},
 | 
						|
		top: function( position, data ) {
 | 
						|
			var win = $( window ),
 | 
						|
				over = data.collisionPosition.top + data.collisionHeight - win.height() - win.scrollTop();
 | 
						|
			position.top = over > 0 ? position.top - over : Math.max( position.top - data.collisionPosition.top, position.top );
 | 
						|
		}
 | 
						|
	},
 | 
						|
 | 
						|
	flip: {
 | 
						|
		left: function( position, data ) {
 | 
						|
			if ( data.at[0] === center ) {
 | 
						|
				return;
 | 
						|
			}
 | 
						|
			var win = $( window ),
 | 
						|
				over = data.collisionPosition.left + data.collisionWidth - win.width() - win.scrollLeft(),
 | 
						|
				myOffset = data.my[ 0 ] === "left" ?
 | 
						|
					-data.elemWidth :
 | 
						|
					data.my[ 0 ] === "right" ?
 | 
						|
						data.elemWidth :
 | 
						|
						0,
 | 
						|
				atOffset = data.at[ 0 ] === "left" ?
 | 
						|
					data.targetWidth :
 | 
						|
					-data.targetWidth,
 | 
						|
				offset = -2 * data.offset[ 0 ];
 | 
						|
			position.left += data.collisionPosition.left < 0 ?
 | 
						|
				myOffset + atOffset + offset :
 | 
						|
				over > 0 ?
 | 
						|
					myOffset + atOffset + offset :
 | 
						|
					0;
 | 
						|
		},
 | 
						|
		top: function( position, data ) {
 | 
						|
			if ( data.at[1] === center ) {
 | 
						|
				return;
 | 
						|
			}
 | 
						|
			var win = $( window ),
 | 
						|
				over = data.collisionPosition.top + data.collisionHeight - win.height() - win.scrollTop(),
 | 
						|
				myOffset = data.my[ 1 ] === "top" ?
 | 
						|
					-data.elemHeight :
 | 
						|
					data.my[ 1 ] === "bottom" ?
 | 
						|
						data.elemHeight :
 | 
						|
						0,
 | 
						|
				atOffset = data.at[ 1 ] === "top" ?
 | 
						|
					data.targetHeight :
 | 
						|
					-data.targetHeight,
 | 
						|
				offset = -2 * data.offset[ 1 ];
 | 
						|
			position.top += data.collisionPosition.top < 0 ?
 | 
						|
				myOffset + atOffset + offset :
 | 
						|
				over > 0 ?
 | 
						|
					myOffset + atOffset + offset :
 | 
						|
					0;
 | 
						|
		}
 | 
						|
	}
 | 
						|
};
 | 
						|
 | 
						|
// offset setter from jQuery 1.4
 | 
						|
if ( !$.offset.setOffset ) {
 | 
						|
	$.offset.setOffset = function( elem, options ) {
 | 
						|
		// set position first, in-case top/left are set even on static elem
 | 
						|
		if ( /static/.test( $.curCSS( elem, "position" ) ) ) {
 | 
						|
			elem.style.position = "relative";
 | 
						|
		}
 | 
						|
		var curElem   = $( elem ),
 | 
						|
			curOffset = curElem.offset(),
 | 
						|
			curTop    = parseInt( $.curCSS( elem, "top",  true ), 10 ) || 0,
 | 
						|
			curLeft   = parseInt( $.curCSS( elem, "left", true ), 10)  || 0,
 | 
						|
			props     = {
 | 
						|
				top:  (options.top  - curOffset.top)  + curTop,
 | 
						|
				left: (options.left - curOffset.left) + curLeft
 | 
						|
			};
 | 
						|
		
 | 
						|
		if ( 'using' in options ) {
 | 
						|
			options.using.call( elem, props );
 | 
						|
		} else {
 | 
						|
			curElem.css( props );
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	$.fn.offset = function( options ) {
 | 
						|
		var elem = this[ 0 ];
 | 
						|
		if ( !elem || !elem.ownerDocument ) { return null; }
 | 
						|
		if ( options ) { 
 | 
						|
			return this.each(function() {
 | 
						|
				$.offset.setOffset( this, options );
 | 
						|
			});
 | 
						|
		}
 | 
						|
		return _offset.call( this );
 | 
						|
	};
 | 
						|
}
 | 
						|
 | 
						|
}( jQuery ));
 |