Simplify code for updating tooltips with accesskey tips
[lhc/web/wiklou.git] / resources / src / mediawiki / page / ready.js
1 ( function ( mw, $ ) {
2 var supportsPlaceholder = 'placeholder' in document.createElement( 'input' );
3
4 // Break out of framesets
5 if ( mw.config.get( 'wgBreakFrames' ) ) {
6 // Note: In IE < 9 strict comparison to window is non-standard (the standard didn't exist yet)
7 // it works only comparing to window.self or window.window (http://stackoverflow.com/q/4850978/319266)
8 if ( window.top !== window.self ) {
9 // Un-trap us from framesets
10 window.top.location.href = location.href;
11 }
12 }
13
14 mw.hook( 'wikipage.content' ).add( function ( $content ) {
15 var $sortableTables;
16
17 // Run jquery.placeholder polyfill if placeholder is not supported
18 if ( !supportsPlaceholder ) {
19 $content.find( 'input[placeholder]' ).placeholder();
20 }
21
22 // Run jquery.makeCollapsible
23 $content.find( '.mw-collapsible' ).makeCollapsible();
24
25 // Lazy load jquery.tablesorter
26 $sortableTables = $content.find( 'table.sortable' );
27 if ( $sortableTables.length ) {
28 mw.loader.using( 'jquery.tablesorter', function () {
29 $sortableTables.tablesorter();
30 } );
31 }
32
33 // Run jquery.checkboxShiftClick
34 $content.find( 'input[type="checkbox"]:not(.noshiftselect)' ).checkboxShiftClick();
35 } );
36
37 // Things outside the wikipage content
38 $( function () {
39 var $nodes, $oouiNodes;
40
41 if ( !supportsPlaceholder ) {
42 // Exclude content to avoid hitting it twice for the (first) wikipage content
43 $( 'input[placeholder]' ).not( '#mw-content-text input' ).placeholder();
44 }
45
46 // Add accesskey hints to the tooltips
47 $( '[accesskey]' ).updateTooltipAccessKeys();
48
49 // Infuse OOUI widgets, if any are present
50 $oouiNodes = $( '[data-ooui]' );
51 if ( $oouiNodes.length ) {
52 // FIXME: We should only load the widgets that are being infused
53 mw.loader.using( [
54 'mediawiki.widgets',
55 'mediawiki.widgets.UserInputWidget',
56 'mediawiki.widgets.SearchInputWidget'
57 ] ).done( function () {
58 $oouiNodes.each( function () {
59 OO.ui.infuse( this );
60 } );
61 } );
62 }
63
64 $nodes = $( '.catlinks[data-mw="interface"]' );
65 if ( $nodes.length ) {
66 /**
67 * Fired when categories are being added to the DOM
68 *
69 * It is encouraged to fire it before the main DOM is changed (when $content
70 * is still detached). However, this order is not defined either way, so you
71 * should only rely on $content itself.
72 *
73 * This includes the ready event on a page load (including post-edit loads)
74 * and when content has been previewed with LivePreview.
75 *
76 * @event wikipage_categories
77 * @member mw.hook
78 * @param {jQuery} $content The most appropriate element containing the content,
79 * such as .catlinks
80 */
81 mw.hook( 'wikipage.categories' ).fire( $nodes );
82 }
83 } );
84
85 }( mediaWiki, jQuery ) );