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 )); |