LLWiki正在建设中,欢迎加入我们!
“MediaWiki:Gadget-MobileCategories.js”的版本间差异
跳转到导航
跳转到搜索
小 标签:移动版网页编辑 移动版编辑 |
小 |
||
第33行: | 第33行: | ||
categories.push( $('<li>').append( |
categories.push( $('<li>').append( |
||
$( '<a>' ).attr( 'href', mw.util.getUrl( element.title ) ) |
$( '<a>' ).attr( 'href', mw.util.getUrl( element.title ) ) |
||
.attr( 'title', title ) |
.attr( 'title', title.replace(/_/g, ' ') ) |
||
.append( document.createTextNode( title.getMainText() ) ) |
.append( document.createTextNode( title.getMainText() ) ) |
||
).get( 0 ) |
).get( 0 ) |
||
第41行: | 第41行: | ||
hiddenCats.push( $('<li>').append( |
hiddenCats.push( $('<li>').append( |
||
$( '<a>' ).attr( 'href', mw.util.getUrl( element.title ) ) |
$( '<a>' ).attr( 'href', mw.util.getUrl( element.title ) ) |
||
.attr( 'title', title ) |
.attr( 'title', title.replace(/_/g, ' ') ) |
||
.append( document.createTextNode( title.getMainText() ) ) |
.append( document.createTextNode( title.getMainText() ) ) |
||
).get( 0 ) |
).get( 0 ) |
2020年8月25日 (二) 20:27的版本
// 引自[[wikipedia:mediawiki:gadget-MobileCategories.js]] $(function() { if( mw.config.get('skin') == 'vector' || !["view","submit"].includes(mw.config.get('wgAction')) ) { return; } var showhiddencats = mw.user.options.get('showhiddencats'), api = new mw.Api(), apiRequest = api.get( { 'action':'query', 'titles': mw.config.get('wgPageName'), 'prop': 'categories', 'clprop': 'hidden', 'cllimit': 50, 'indexpageids': true, 'formatversion': 2 } ), apiRequest2 = api.loadMessagesIfMissing( [ 'pagecategories', 'colon-separator' ] ); $.when( apiRequest, apiRequest2 ).done( function( data ) { var categories = [], hiddenCats = [], response1Data = data[0], response2Data = data[1]; if( !response1Data.query.pages[0].categories ) { window.MobileCategoriesComplete = true; return; } function categoryHtmlGenerator(element, index, array) { var title = new mw.Title( element.title, mw.config.get( 'wgNamespaceIds' ).file ); if( !element.hidden ) { categories.push( $('<li>').append( $( '<a>' ).attr( 'href', mw.util.getUrl( element.title ) ) .attr( 'title', title.replace(/_/g, ' ') ) .append( document.createTextNode( title.getMainText() ) ) ).get( 0 ) ); } else if(showhiddencats) { hiddenCats.push( $('<li>').append( $( '<a>' ).attr( 'href', mw.util.getUrl( element.title ) ) .attr( 'title', title.replace(/_/g, ' ') ) .append( document.createTextNode( title.getMainText() ) ) ).get( 0 ) ); } } response1Data.query.pages[0].categories.forEach( categoryHtmlGenerator ); if( categories.length === 0 && hiddenCats.length === 0 ) { window.MobileCategoriesComplete = true; return; } var normalCatlinks, hiddenCatlinks; if(categories.length) { normalCatlinks = $( '<div>' ) .attr( 'id', 'mw-normal-catlinks' ) .addClass('mw-normal-catlinks') .append( $( '<ul>' ).append( categories ) ) .prepend( '<a href="/zh/Special:Categories" title="Special:页面分类">' + mw.message( 'pagecategories' ).escaped() + '</a>' + mw.message( 'colon-separator' ).escaped() ); } if(hiddenCats.length) { hiddenCatlinks = $( '<div>' ) .attr( 'id', 'mw-hidden-catlinks' ) .addClass(['mw-hidden-catlinks', 'mw-hidden-cats-user-shown']) .append( $( '<ul>' ).append( hiddenCats ) ) .prepend( wgULS("隐藏分类", "隱藏分類") + mw.message( 'colon-separator' ).escaped() ); } var catlinks = $( '<div>' ) .addClass( 'catlinks' ) .attr( 'id', 'catlinks' ) .data( 'mw', 'interface' ); if(normalCatlinks) { catlinks.append(normalCatlinks); } if(hiddenCatlinks) { catlinks.append(hiddenCatlinks); } $('.printfooter').after(catlinks); window.MobileCategoriesComplete = true; } ); } );