element.trigger( "blur" );
});
+test( "mixed events", function() {
+ expect( 2 );
+ var element = $( "#tooltipped1" ).tooltip();
+
+ element.one( "tooltipopen", function( event ) {
+ same( event.originalEvent.type, "focusin" );
+ });
+ element[0].focus();
+
+ element.one( "tooltipopen", function() {
+ ok( false, "open triggered while already open" );
+ });
+ element.trigger( "mouseover" );
+
+ element.bind( "tooltipclose", function( event ) {
+ ok( false, "close triggered while still focused" );
+ });
+ element.trigger( "mouseleave" );
+ element.unbind( "tooltipclose" );
+
+ element.one( "tooltipclose", function( event ) {
+ same( event.originalEvent.type, "blur" );
+ });
+ element[0].blur();
+});
+
}( jQuery ) );
target = $( event ? event.target : this.element )
.closest( this.options.items );
- if ( !target.length ) {
+ // if aria-describedby exists, then the tooltip is already open
+ if ( !target.length || target.attr( "aria-describedby" ) ) {
return;
}
target.attr( "title", target.data( "tooltip-title" ) );
}
- if ( this.options.disabled ) {
+ // don't close if the element has focus
+ // this prevents the tooltip from closing if you hover while focused
+ if ( this.options.disabled || document.activeElement === target[0] ) {
return;
}