aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFelix Nagel <info@felixnagel.com>2013-10-10 01:01:41 +0200
committerFelix Nagel <info@felixnagel.com>2013-10-10 01:01:41 +0200
commit7af3dab075b71b4a4b542e3e3201229399a56959 (patch)
treeb9aadb7e2170f7e5ed13e21fd32a673074a84548
parente26e0df3afdfe6c43ed9f904281abb7e38ba1df1 (diff)
downloadjquery-ui-7af3dab075b71b4a4b542e3e3201229399a56959.tar.gz
jquery-ui-7af3dab075b71b4a4b542e3e3201229399a56959.zip
Selectmenu: Remove links in menu items
-rw-r--r--tests/unit/selectmenu/selectmenu_core.js18
-rw-r--r--tests/unit/selectmenu/selectmenu_events.js6
-rw-r--r--themes/base/jquery.ui.selectmenu.css2
-rw-r--r--ui/jquery.ui.selectmenu.js16
4 files changed, 20 insertions, 22 deletions
diff --git a/tests/unit/selectmenu/selectmenu_core.js b/tests/unit/selectmenu/selectmenu_core.js
index d8b449828..60c350eb3 100644
--- a/tests/unit/selectmenu/selectmenu_core.js
+++ b/tests/unit/selectmenu/selectmenu_core.js
@@ -9,7 +9,7 @@ asyncTest( "accessibility", function() {
menu = element.selectmenu( "menuWidget" );
button.simulate( "focus" );
- links = menu.find( "li.ui-menu-item a" );
+ links = menu.find( "li.ui-menu-item" );
expect( 12 + links.length * 2 );
@@ -65,7 +65,7 @@ $.each([
button.simulate( "focus" );
setTimeout(function() {
- links = menu.find("li.ui-menu-item a");
+ links = menu.find("li.ui-menu-item");
button.simulate( "keydown", { keyCode: $.ui.keyCode.DOWN } );
equal(
@@ -98,10 +98,10 @@ $.each([
button.simulate( "focus" );
setTimeout(function() {
- links = menu.find("li.ui-menu-item a");
+ links = menu.find("li.ui-menu-item");
button.trigger( "click" );
- menu.find( "a" ).last().simulate( "mouseover" ).trigger( "click" );
+ menu.find( "li" ).last().simulate( "mouseover" ).trigger( "click" );
equal(
menu.attr( "aria-activedescendant" ),
links.eq( element[ 0 ].selectedIndex ).attr( "id" ),
@@ -135,7 +135,7 @@ $.each([
button.simulate( "focus" );
setTimeout(function() {
- links = menu.find( "li.ui-menu-item a" );
+ links = menu.find( "li.ui-menu-item" );
// open menu and click first item
button.trigger( "click" );
links.first().simulate( "mouseover" ).trigger( "click" );
@@ -169,7 +169,7 @@ $.each([
button.simulate( "focus" );
setTimeout(function() {
- links = menu.find( "li.ui-menu-item a" );
+ links = menu.find( "li.ui-menu-item" );
button.trigger( "click" );
links.first().simulate( "mouseover" ).trigger( "click" );
@@ -196,7 +196,7 @@ $.each([
button.simulate( "focus" );
setTimeout(function() {
- links = menu.find( "li.ui-menu-item a" );
+ links = menu.find( "li.ui-menu-item" );
button.trigger( "click" );
setTimeout(function() {
@@ -221,11 +221,11 @@ $.each([
}, 1 );
function checkItemClasses() {
- focusedItem = menu.find( "li.ui-menu-item a.ui-state-focus" );
+ focusedItem = menu.find( "li.ui-state-focus" );
equal( focusedItem.length, 1, "only one item has ui-state-focus class" );
equal( focusedItem.attr( "id" ), links.eq( element[ 0 ].selectedIndex ).attr( "id" ), "selected item has ui-state-focus class" );
- activeItem = menu.find( "li.ui-menu-item a.ui-state-active" );
+ activeItem = menu.find( "li.ui-state-active" );
equal( activeItem.length, 1, "only one item has ui-state-active class" );
equal( activeItem.attr( "id" ), links.eq( element[ 0 ].selectedIndex ).attr( "id" ), "selected item has ui-state-active class" );
}
diff --git a/tests/unit/selectmenu/selectmenu_events.js b/tests/unit/selectmenu/selectmenu_events.js
index 353780ee5..182c0cd1b 100644
--- a/tests/unit/selectmenu/selectmenu_events.js
+++ b/tests/unit/selectmenu/selectmenu_events.js
@@ -30,7 +30,7 @@ asyncTest( "change", function () {
setTimeout(function() {
button.trigger( "click" );
- menu.find( "a" ).eq( optionIndex ).simulate( "mouseover" ).trigger( "click" );
+ menu.find( "li" ).eq( optionIndex ).simulate( "mouseover" ).trigger( "click" );
start();
}, 1 );
});
@@ -79,7 +79,7 @@ asyncTest( "focus", function () {
button.simulate( "keydown", { keyCode: $.ui.keyCode.DOWN } );
button.trigger( "click" );
- links = menu.find( "li.ui-menu-item a" );
+ links = menu.find( "li.ui-menu-item" );
optionIndex = 0;
links.eq( optionIndex ).simulate( "mouseover" );
optionIndex += 1;
@@ -127,7 +127,7 @@ asyncTest( "select", function () {
setTimeout(function() {
button.trigger( "click" );
- menu.find( "a" ).eq( optionIndex ).simulate( "mouseover" ).trigger( "click" );
+ menu.find( "li" ).eq( optionIndex ).simulate( "mouseover" ).trigger( "click" );
start();
}, 1 );
});
diff --git a/themes/base/jquery.ui.selectmenu.css b/themes/base/jquery.ui.selectmenu.css
index c941ef0b1..804f96cfb 100644
--- a/themes/base/jquery.ui.selectmenu.css
+++ b/themes/base/jquery.ui.selectmenu.css
@@ -21,7 +21,7 @@
/* Support: IE7 */
overflow-x: hidden;
}
-.ui-selectmenu-menu .ui-menu-item a {
+.ui-selectmenu-menu .ui-menu-item {
padding: 0.3em 1em;
}
.ui-selectmenu-menu .ui-menu .ui-selectmenu-optgroup {
diff --git a/ui/jquery.ui.selectmenu.js b/ui/jquery.ui.selectmenu.js
index 7d7c3fb98..90dfce824 100644
--- a/ui/jquery.ui.selectmenu.js
+++ b/ui/jquery.ui.selectmenu.js
@@ -176,7 +176,7 @@ $.widget( "ui.selectmenu", {
this._renderMenu( this.menu, this.items );
this.menuInstance.refresh();
- this.menuItems = this.menu.find( "li" ).not( ".ui-selectmenu-optgroup" ).find( "a" );
+ this.menuItems = this.menu.find( "li" ).not( ".ui-selectmenu-optgroup" );
item = this._getSelectedItem();
@@ -250,7 +250,7 @@ $.widget( "ui.selectmenu", {
$.each( items, function( index, item ) {
if ( item.optgroup !== currentOptgroup ) {
$( "<li>", {
- "class": "ui-selectmenu-optgroup" +
+ "class": "ui-selectmenu-optgroup ui-menu-divider" +
( item.element.parent( "optgroup" ).attr( "disabled" ) ?
" ui-state-disabled" :
"" ),
@@ -268,15 +268,14 @@ $.widget( "ui.selectmenu", {
},
_renderItem: function( ul, item ) {
- var li = $( "<li>" ),
- a = $( "<a>", { href: "#" });
+ var li = $( "<li>" );
if ( item.disabled ) {
li.addClass( "ui-state-disabled" );
}
- this._setText( a, item.label );
+ this._setText( li, item.label );
- return li.append( a ).appendTo( ul );
+ return li.appendTo( ul );
},
_setText: function( element, value ) {
@@ -303,7 +302,7 @@ $.widget( "ui.selectmenu", {
},
_getSelectedItem: function() {
- return this.menuItems.eq( this.element[ 0 ].selectedIndex ).parent( "li" );
+ return this.menuItems.eq( this.element[ 0 ].selectedIndex );
},
_toggle: function( event ) {
@@ -407,8 +406,7 @@ $.widget( "ui.selectmenu", {
},
_setAria: function( item ) {
- var link = this.menuItems.eq( item.index ),
- id = link.attr( "id" );
+ var id = this.menuItems.eq( item.index ).attr( "id" );
this.button.attr({
"aria-labelledby": id,