2 * JavaScript for Special:Search
6 var $checkboxes, $headerLinks;
8 // Emulate HTML5 autofocus behavior in non HTML5 compliant browsers
9 if ( !( 'autofocus' in document.createElement( 'input' ) ) ) {
10 $( 'input[autofocus]' ).eq( 0 ).focus();
13 // Create check all/none button
14 $checkboxes = $( '#powersearch input[id^=mw-search-ns]' );
15 $( '#mw-search-togglebox' ).append(
17 .text( mw.msg( 'powersearch-togglelabel' ) )
19 $( '<input type="button" />' )
20 .attr( 'id', 'mw-search-toggleall' )
21 .prop( 'value', mw.msg( 'powersearch-toggleall' ) )
23 $checkboxes.prop( 'checked', true );
26 $( '<input type="button" />' )
27 .attr( 'id', 'mw-search-togglenone' )
28 .prop( 'value', mw.msg( 'powersearch-togglenone' ) )
30 $checkboxes.prop( 'checked', false );
34 // Change the header search links to what user entered
35 $headerLinks = $( '.search-types a' );
36 $( '#searchText, #powerSearchText' ).change( function () {
37 var searchterm = $( this ).val();
38 $headerLinks.each( function () {
39 var parts = $( this ).attr( 'href' ).split( 'search=' ),
42 if ( parts.length > 1 && parts[1].indexOf( '&' ) >= 0 ) {
43 lastpart = parts[1].substring( parts[1].indexOf( '&' ) );
47 this.href = parts[0] + prefix + encodeURIComponent( searchterm ) + lastpart;
49 } ).trigger( 'change' );
53 }( mediaWiki, jQuery ) );