미디어위키:Common.js: 두 판 사이의 차이

584 바이트 추가됨 ,  2025년 8월 7일 (목)
버전 테스트
큰숲백과>Utolee90
(소스 오류 수정)
(버전 테스트)
 
(사용자 3명의 중간 판 39개는 보이지 않습니다)
7번째 줄: 7번째 줄:
  * 스크립트를 넣을 때는 충분한 설명, 출처를 넣어주세요! 이후 관리가 어려워집니다.
  * 스크립트를 넣을 때는 충분한 설명, 출처를 넣어주세요! 이후 관리가 어려워집니다.
  **/
  **/
   
 
/**
  * 아이콘 로드
*
**/
 
mw.loader.using( [
'oojs-ui.styles.icons-movement',
'oojs-ui.styles.icons-content',
'oojs-ui.styles.icons-alerts',
'oojs-ui.styles.icons-interactions',
'oojs-ui.styles.icons-moderation',
'oojs-ui.styles.icons-editing-core',
'oojs-ui.styles.icons-editing-styling',
'oojs-ui.styles.icons-editing-list',
'oojs-ui.styles.icons-editing-advanced',
'oojs-ui.styles.icons-editing-citation',
'oojs-ui.styles.icons-media',
'oojs-ui.styles.icons-location',
'oojs-ui.styles.icons-user',
'oojs-ui.styles.icons-layout',
'oojs-ui.styles.icons-accessibility',
'oojs-ui.styles.icons-wikimedia',
]);


/* Begin of mw.loader.using callback */
/* Begin of mw.loader.using callback */
58번째 줄: 81번째 줄:
}
}
}
}
 
/**
/**
  * Import more specific scripts if necessary - Not used in bigforestwiki
  * Import more specific scripts if necessary - Not used in bigforestwiki
  */
  */
   
   
/* ([[위키백과:관리자 요청/2007년 5월#스크립트 추가 요청]]) */
/* ([[위키백과:관리자 요청/2007년 5월#스크립트 추가 요청]]) */
317번째 줄: 338번째 줄:
   * 작성자: 백괴사전 Peremen
   * 작성자: 백괴사전 Peremen
*/
*/
function UserNameReplace() {
$(function () {
     if (typeof(disableUsernameReplace) != 'undefined' && disableUsernameReplace) return;
     if (typeof(disableUsernameReplace) != 'undefined' && disableUsernameReplace) return;
     if (!document.getElementById('pt-userpage')) return;
     if (!document.getElementById('pt-userpage')) return;
323번째 줄: 344번째 줄:
         $(this).text(mw.config.get('wgUserName'))
         $(this).text(mw.config.get('wgUserName'))
     })
     })
}
})
$(UserNameReplace);
 
/**
* Fix for Windows XP Unicode font rendering
*/
if ( navigator.appVersion.search(/windows nt 5/i) !== -1 ) {
    mw.util.addCSS( '.IPA { font-family: "Lucida Sans Unicode", "Arial Unicode MS"; } ' +
                '.Unicode { font-family: "Arial Unicode MS", "Lucida Sans Unicode"; } ' );
}


/** [[틀:제목]]에서 사용하는 제목 바꿔치기 함수 **/
/** [[틀:제목]]에서 사용하는 제목 바꿔치기 함수 **/
   
   
function rewriteTitle() {
$(function () {
     if (typeof(disableTitleRewrite) != 'undefined' && disableTitleRewrite) return;
     if (typeof(disableTitleRewrite) != 'undefined' && disableTitleRewrite) return;
     if (!document.getElementById('title-meta')) return;
     if (!document.getElementById('title-meta')) return;
342번째 줄: 354번째 줄:
         $(this).html( $("#title-meta").html()).css('text-align', $("#title-align").text())
         $(this).html( $("#title-meta").html()).css('text-align', $("#title-align").text())
     })
     })
}
});
$(rewriteTitle);




357번째 줄: 368번째 줄:
}
}


$(function() {
/**
* 안티-반달리즘 필터
*/
$("#mw-content-text [style*='fixed'], #mw-content-text [style*='absolute']").remove();
 
/**
/**
  * HTTPS에서만 보이는 요소
  * HTTPS에서만 보이는 요소
  */
  */
if (location.protocol == "https:") $(".view-https").show();
if (location.protocol == "https:") $(".view-https").show();
/**
* 안티-반달리즘 필터
*/
$("#mw-content-text [style*='fixed'], #mw-content-text [style*='absolute']").remove();


/**
/**
372번째 줄: 382번째 줄:
  */
  */
if ( navigator.appVersion.search(/windows nt 5/i) !== -1 ) {
if ( navigator.appVersion.search(/windows nt 5/i) !== -1 ) {
     mw.util.addCSS( '.IPA { font-family: "Lucida Sans Unicode", "Arial Unicode MS"; } ' +
     mw.util.addCSS( '.IPA { font-family: "Lucida Sans Unicode", "Arial Unicode MS"; } \
    '.Unicode { font-family: "Arial Unicode MS", "Lucida Sans Unicode"; } ' );
.Unicode { font-family: "Arial Unicode MS", "Lucida Sans Unicode"; } ' );
}
}
}
);
 


/* 사용자 문서에 기여 내역 리스트 추가 */
/* 사용자 문서에 기여 내역 리스트 추가 */
394번째 줄: 403번째 줄:
     cMenu.appendChild(userContrib);
     cMenu.appendChild(userContrib);
}
}
*//* {하위문서 목록}에서 하위문서 개수에 따라 열 개수 자동 조절 */
*//* {하위문서목록}에서 하위문서의 개수에 따라 열 개수 자동 조절 */
var subpageLists = document.querySelectorAll(".subpage-list .mw-prefixindex-body");
document.querySelectorAll(".subpage-list .mw-prefixindex-body").forEach(function (item) {
subpageLists.forEach(function (item) {
var elementNumber = item.childNodes[0].childElementCount;
var elementNumber = item.childNodes[0].childElementCount;
     if ( elementNumber > 20 ) { item.style.columnCount = 2 }
     if ( elementNumber > 20 ) { item.style.columnCount = 2 }
405번째 줄: 413번째 줄:
  * [[틀:리브레탭]]용
  * [[틀:리브레탭]]용
  */
  */
$('.libre-tab .libre-tab-btn').click(function() {
document.querySelectorAll('.libre-tab').forEach(function (libretab) {
     if ($(this).hasClass('libre-tab-btn-active')) return;
     const $libretab = $(libretab);
     var $libretab = $(this).parents('.libre-tab');
    var $btns = $libretab.children('.libre-tab-btns');
    $libretab.find('.libre-tab-btn-active').removeClass('libre-tab-btn-active');
     var $content = $libretab.children('.libre-tab-main');
    $(this).addClass('libre-tab-btn-active');
    $btns.children('.libre-tab-btn').on('click', function () {
    var index = $(this).index();
        if (this.classList.contains('.libre-tab-btn-active')) return;
    $libretab.find('.libre-tab-main-content').removeClass('libre-tab-main-content-active');
        $btns.children('.libre-tab-btn-active').removeClass('libre-tab-btn-active');
    $libretab.find('.libre-tab-main-content').eq(index).addClass('libre-tab-main-content-active');
        this.classList.add('libre-tab-btn-active');
});
 
        var index = $(this).index();
        $content.children('.libre-tab-main-content-active').removeClass('libre-tab-main-content-active');
        $content.children('.libre-tab-main-content').eq(index).addClass('libre-tab-main-content-active');
    })
})
 
// HTML샌드박스 가동용 소스
mw.loader.load('//bigforest.a2hosted.com/w/index.php?title=mediawiki:HTMLSandbox/main.js&action=raw&ctype=text/javascript');
 
// 대문 좋은 문서 작동 코드
$(function () {
var goodArticlesContents = document.querySelector(".good-articles-contents");
 
if (!goodArticlesContents) return;
 
var listItems = goodArticlesContents.querySelectorAll("li");
 
for (var i = 0; i < listItems.length; i++) {
 
var node = listItems[i]
 
var a = node.firstChild


/**
var box = document.createElement('div');
* 대문숲 이달의 테마 문서 섬네일 이미지 띄우기
box.classList.add("page-box");
*/
box.append(a.cloneNode(true));
if (document.querySelector('.year-theme')) {
  var year_theme_title = document.querySelector('.year-theme-page-title').innerText.split('\n').pop();


  var apigeturl = mw.config.get('wgServer') + mw.config.get('wgScriptPath') + '/';
var imgbox = document.createElement('div');
  apigeturl += 'api.php?action=query&format=json&prop=pageimages&utf8=1&formatversion=latest&pithumbsize=100&titles=' + year_theme_title;
imgbox.classList.add("good-articles-imgbox")
box.prepend(imgbox)


  fetch(apigeturl).then(function(res) {
goodArticlesContents.append(box);
    res.json().then(function(json) {
      var page = json.query.pages[0];
      if (!page.thumbnail) return;


      var page_thumbnail = page.thumbnail;
(function (imgbox) {
      var img = document.createElement('img');
new mw.Api().get({
      img.src = page_thumbnail.source;
action: "query",
format: "json",
formatversion: "latest",
utf8: 1,
pithumbsize: 300,
prop: "pageimages",
titles: a.title,
}).then(function (data) {
var page = data.query.pages[0];
if (!page.thumbnail) return;


      if (document.querySelector('div.page_thumbnail'))
var img = document.createElement('img');
        document.querySelector('div.page_thumbnail').append(img);
img.src = page.thumbnail.source;


      else {
console.log(this)
        var thumbnail_box = document.createElement('div');
        thumbnail_box.append(img);
        document.body.append(thumbnail_box);
      }
    });
  })
}


// HTML샌드박스 가동용 소스
imgbox.prepend(img)
mw.loader.load('/w/index.php?title=작은숲:HTML샌드박스/main.js&action=raw&ctype=text/javascript');
})
})(imgbox)
}
})


mw.loader.load('/w/index.php?title=mediawiki:Responsive-arrow.js&action=raw&ctype=text/javascript');
/* DO NOT ADD CODE BELOW THIS LINE */
/* DO NOT ADD CODE BELOW THIS LINE */

편집

4,193