this.validateTitle = config.validateTitle !== undefined ? config.validateTitle : true;
this.cache = config.cache;
this.api = config.api || new mw.Api();
+ // Supports: IE10, FF28, Chrome23
+ this.compare = window.Intl && Intl.Collator ?
+ new Intl.Collator( mw.config.get( 'wgContentLanguage' ), { sensitivity: 'base' } ).compare :
+ null;
// Initialization
this.$element.addClass( 'mw-widget-titleWidget' );
cache[ key ] = api.get( {
action: 'query',
meta: 'siteinfo',
- siprop: 'interwikimap'
+ siprop: 'interwikimap',
+ // Cache client-side for a day since this info is mostly static
+ maxage: 60 * 60 * 24,
+ smaxage: 60 * 60 * 24,
+ // Workaround T97096 by setting uselang=content
+ uselang: 'content'
} ).then( function ( data ) {
return $.map( data.query.interwikimap, function ( interwiki ) {
return interwiki.prefix;
if ( mw.Title.newFromText( query ) ) {
return this.getInterwikiPrefixesPromise().then( function ( interwikiPrefixes ) {
- var params,
- interwiki = query.substring( 0, query.indexOf( ':' ) );
+ var interwiki = query.substring( 0, query.indexOf( ':' ) );
if (
interwiki && interwiki !== '' &&
interwikiPrefixes.indexOf( interwiki ) !== -1
} ]
} } ).promise( promiseAbortObject );
} else {
- params = {
- action: 'query',
- prop: [ 'info', 'pageprops' ],
- generator: 'prefixsearch',
- gpssearch: query,
- gpsnamespace: widget.namespace !== null ? widget.namespace : undefined,
- gpslimit: widget.limit,
- ppprop: 'disambiguation'
- };
- if ( widget.showRedirectTargets ) {
- params.redirects = true;
- }
- if ( widget.showImages ) {
- params.prop.push( 'pageimages' );
- params.pithumbsize = 80;
- params.pilimit = widget.limit;
- }
- if ( widget.showDescriptions ) {
- params.prop.push( 'pageterms' );
- params.wbptterms = 'description';
- }
- req = api.get( params );
+ req = api.get( widget.getApiParams( query ) );
promiseAbortObject.abort = req.abort.bind( req ); // TODO ew
return req.then( function ( ret ) {
if ( ret.query === undefined ) {
}
};
+ /**
+ * Get API params for a given query
+ *
+ * @param {string} query User query
+ * @return {Object} API params
+ */
+ mw.widgets.TitleWidget.prototype.getApiParams = function ( query ) {
+ var params = {
+ action: 'query',
+ prop: [ 'info', 'pageprops' ],
+ generator: 'prefixsearch',
+ gpssearch: query,
+ gpsnamespace: this.namespace !== null ? this.namespace : undefined,
+ gpslimit: this.limit,
+ ppprop: 'disambiguation'
+ };
+ if ( this.showRedirectTargets ) {
+ params.redirects = true;
+ }
+ if ( this.showImages ) {
+ params.prop.push( 'pageimages' );
+ params.pithumbsize = 80;
+ params.pilimit = this.limit;
+ }
+ if ( this.showDescriptions ) {
+ params.prop.push( 'pageterms' );
+ params.wbptterms = 'description';
+ }
+ return params;
+ };
+
/**
* Get the API object for title requests
*
imageUrl: OO.getProp( suggestionPage, 'thumbnail', 'source' ),
description: OO.getProp( suggestionPage, 'terms', 'description' ),
// Sort index
- index: suggestionPage.index
+ index: suggestionPage.index,
+ originalData: suggestionPage
};
// Throw away pages from wrong namespaces. This can happen when 'showRedirectTargets' is true
disambiguation: false,
description: mw.msg( 'mw-widgets-titleinput-description-redirect', suggestionPage.title ),
// Sort index, just below its target
- index: suggestionPage.index + 0.5
+ index: suggestionPage.index + 0.5,
+ originalData: suggestionPage
};
titles.push( redirects[ i ] );
}
} );
// If not found, run value through mw.Title to avoid treating a match as a
- // mismatch where normalisation would make them matching (bug 48476)
+ // mismatch where normalisation would make them matching (T50476)
pageExistsExact = (
Object.prototype.hasOwnProperty.call( pageData, this.getQueryValue() ) &&
for ( i = 0, len = titles.length; i < len; i++ ) {
page = pageData[ titles[ i ] ] || {};
- items.push( new mw.widgets.TitleOptionWidget( this.getOptionWidgetData( titles[ i ], page ) ) );
+ items.push( this.createOptionWidget( this.getOptionWidgetData( titles[ i ], page ) ) );
}
return items;
};
+ /**
+ * Create a menu option widget with specified data
+ *
+ * @param {Object} data Data for option widget
+ * @return {OO.ui.MenuOptionWidget} Data for option widget
+ */
+ mw.widgets.TitleWidget.prototype.createOptionWidget = function ( data ) {
+ return new mw.widgets.TitleOptionWidget( data );
+ };
+
/**
* Get menu option widget data from the title and page data
*
mwTitle.getRelativeText( this.namespace ) :
title,
url: mwTitle.getUrl(),
+ showImages: this.showImages,
imageUrl: this.showImages ? data.imageUrl : null,
description: this.showDescriptions ? description : null,
missing: data.missing,
redirect: data.redirect,
disambiguation: data.disambiguation,
- query: this.getQueryValue()
+ query: this.getQueryValue(),
+ compare: this.compare
};
};