aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFelix Nagel <info@felixnagel.com>2012-12-15 02:21:51 +0100
committerFelix Nagel <info@felixnagel.com>2012-12-15 02:21:51 +0100
commit57ecee889d1443b37f0cc2e870a5209292e0472b (patch)
tree696375f23f5760828decc62d780ea6969880410e
parent8aa24dd1d52fb1f2454905a2e3bb9b86c23cb4ad (diff)
downloadjquery-ui-57ecee889d1443b37f0cc2e870a5209292e0472b.tar.gz
jquery-ui-57ecee889d1443b37f0cc2e870a5209292e0472b.zip
Selectmenu: rework appendTo functionality
-rw-r--r--ui/jquery.ui.selectmenu.js26
1 files changed, 23 insertions, 3 deletions
diff --git a/ui/jquery.ui.selectmenu.js b/ui/jquery.ui.selectmenu.js
index 6427b6080..1bfcb56ab 100644
--- a/ui/jquery.ui.selectmenu.js
+++ b/ui/jquery.ui.selectmenu.js
@@ -20,7 +20,7 @@ $.widget( "ui.selectmenu", {
version: "@VERSION",
defaultElement: "<select>",
options: {
- appendTo: "body",
+ appendTo: null,
dropdown: true,
position: {
my: "left top",
@@ -118,7 +118,7 @@ $.widget( "ui.selectmenu", {
width: ( this.options.dropdown ) ? this.button.outerWidth() : this.buttonText.width() + parseFloat( this.buttonText.css( "padding-left" ) ) || 0 + parseFloat( this.buttonText.css( "margin-left") ) || 0
})
.append( this.menu )
- .appendTo( this.options.appendTo );
+ .appendTo( this._appendTo() );
// init menu widget
menuInstance = this.menu.menu({
@@ -405,7 +405,7 @@ $.widget( "ui.selectmenu", {
this._super( key, value );
if ( key === "appendTo" ) {
- this.menuWrap.appendTo( this.document.find( value || "body" )[0] );
+ this.menuWrap.appendTo( this._appendTo() );
}
if ( key === "disabled" ) {
this.menu.menu( "option", "disabled", value );
@@ -420,6 +420,26 @@ $.widget( "ui.selectmenu", {
}
},
+ _appendTo: function() {
+ var element = this.options.appendTo;
+
+ if ( element ) {
+ element = element.jquery || element.nodeType ?
+ $( element ) :
+ this.document.find( element ).eq( 0 );
+ }
+
+ if ( !element ) {
+ element = this.element.closest( ".ui-front" );
+ }
+
+ if ( !element.length ) {
+ element = this.document[0].body;
+ }
+
+ return element;
+ },
+
_toggleAttr: function(){
if ( this.options.dropdown ) {
this.button.toggleClass( "ui-corner-top", this.isOpen ).toggleClass( "ui-corner-all", !this.isOpen );