Press n or j to go to the next uncovered block, b, p or k for the previous block.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | 1x 1x 1x 1x 1x 1x | const m = require( '../moduleLoaderSingleton' ), getDeviceLanguage = require( './getDeviceLanguage' ), Overlay = require( '../Overlay' ), promisedView = require( '../promisedView' ); /** * @ignore * @param {LanguageInfo} languageInfo * @param {boolean} showSuggestedLanguages If the suggested languages section * should be rendered. * @return {jQuery.Promise} Resolves to LanguageSearcher */ function loadLanguageInfoSearcher( languageInfo, showSuggestedLanguages ) { return mw.loader.using( 'mobile.languages.structured' ).then( () => languageInfo.getLanguages() ).then( ( data ) => { const LanguageSearcher = m.require( 'mobile.languages.structured/LanguageSearcher' ); return new LanguageSearcher( { languages: data.languages, variants: data.variants, showSuggestedLanguages, deviceLanguage: getDeviceLanguage( navigator ) } ); } ); } /** * Factory function that returns a language info featured instance of an Overlay * * @param {LanguageInfo} languageInfo * @param {boolean} showSuggestedLanguages If the suggested languages section * should be rendered. * @return {Overlay} */ function languageInfoOverlay( languageInfo, showSuggestedLanguages ) { return Overlay.make( { heading: mw.msg( 'mobile-frontend-language-heading' ), className: 'overlay language-info-overlay' }, promisedView( loadLanguageInfoSearcher( languageInfo, showSuggestedLanguages ) ) ); } // To make knowing when async logic has resolved easier in tests languageInfoOverlay.test = { loadLanguageInfoSearcher }; module.exports = languageInfoOverlay; |