Merge "Improve sorting on SpecialWanted*-Pages"
[mediawiki.git] / resources / src / mediawiki.widgets / mw.widgets.TitleOptionWidget.js
blob37e6e1afa2a9f0c60a33d090ff14f2069f78c4ac
1 /*!
2  * MediaWiki Widgets - TitleOptionWidget class.
3  *
4  * @copyright 2011-2015 MediaWiki Widgets Team and others; see AUTHORS.txt
5  * @license The MIT License (MIT); see LICENSE.txt
6  */
7 ( function ( $, mw ) {
9         /**
10          * Creates a mw.widgets.TitleOptionWidget object.
11          *
12          * @class
13          * @extends OO.ui.MenuOptionWidget
14          *
15          * @constructor
16          * @param {Object} config Configuration options
17          * @cfg {string} data Label to display
18          * @cfg {string} url URL of page
19          * @cfg {string} [imageUrl] Thumbnail image URL with URL encoding
20          * @cfg {string} [description] Page description
21          * @cfg {boolean} [missing] Page doesn't exist
22          * @cfg {boolean} [redirect] Page is a redirect
23          * @cfg {boolean} [disambiguation] Page is a disambiguation page
24          * @cfg {string} [query] Matching query string
25          */
26         mw.widgets.TitleOptionWidget = function MwWidgetsTitleOptionWidget( config ) {
27                 var icon;
29                 if ( config.missing ) {
30                         icon = 'page-not-found';
31                 } else if ( config.redirect ) {
32                         icon = 'page-redirect';
33                 } else if ( config.disambiguation ) {
34                         icon = 'page-disambiguation';
35                 } else {
36                         icon = 'page-existing';
37                 }
39                 // Config initialization
40                 config = $.extend( {
41                         icon: icon,
42                         label: config.data,
43                         autoFitLabel: false,
44                         $label: $( '<a>' )
45                 }, config );
47                 // Parent constructor
48                 mw.widgets.TitleOptionWidget.parent.call( this, config );
50                 // Initialization
51                 this.$label.attr( 'href', config.url );
52                 this.$element.addClass( 'mw-widget-titleOptionWidget' );
54                 // OOUI OptionWidgets make an effort to not be tab accessible, but
55                 // adding a link inside them would undo that. So, explicitly make it
56                 // not tabbable.
57                 this.$label.attr( 'tabindex', '-1' );
59                 // Allow opening the link in new tab, but not regular navigation.
60                 this.$label.on( 'click', function ( e ) {
61                         // Don't interfere with special clicks (e.g. to open in new tab)
62                         if ( !( e.which !== 1 || e.altKey || e.ctrlKey || e.shiftKey || e.metaKey ) ) {
63                                 e.preventDefault();
64                         }
65                 } );
67                 // Highlight matching parts of link suggestion
68                 this.$label.autoEllipsis( { hasSpan: false, tooltip: true, matchText: config.query } );
70                 if ( config.missing ) {
71                         this.$label.addClass( 'new' );
72                 }
74                 if ( config.imageUrl ) {
75                         this.$icon
76                                 .addClass( 'mw-widget-titleOptionWidget-hasImage' )
77                                 .css( 'background-image', 'url(' + config.imageUrl + ')' );
78                 }
80                 if ( config.description ) {
81                         this.$element.append(
82                                 $( '<span>' )
83                                         .addClass( 'mw-widget-titleOptionWidget-description' )
84                                         .text( config.description )
85                                         .attr( 'title', config.description )
86                         );
87                 }
88         };
90         /* Setup */
92         OO.inheritClass( mw.widgets.TitleOptionWidget, OO.ui.MenuOptionWidget );
94 }( jQuery, mediaWiki ) );