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

큰숲백과, 나무를 보지 말고 큰 숲을 보라.
편집 요약 없음
(버전 테스트)
 
(같은 사용자의 중간 판 29개는 보이지 않습니다)
7번째 줄: 7번째 줄:
  * 스크립트를 넣을 때는 충분한 설명, 출처를 넣어주세요! 이후 관리가 어려워집니다.
  * 스크립트를 넣을 때는 충분한 설명, 출처를 넣어주세요! 이후 관리가 어려워집니다.
  **/
  **/
   
 
$(document.head).append('<link href="https://cdn.jsdelivr.net/npm/font-awesome@4.7.0/css/font-awesome.min.css" rel="stylesheet">');
/**
* 아이콘 로드
*
  **/
 
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 */
59번째 줄: 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월#스크립트 추가 요청]]) */
318번째 줄: 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;
324번째 줄: 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;
343번째 줄: 354번째 줄:
         $(this).html( $("#title-meta").html()).css('text-align', $("#title-align").text())
         $(this).html( $("#title-meta").html()).css('text-align', $("#title-align").text())
     })
     })
}
});
$(rewriteTitle);




358번째 줄: 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();


/**
/**
373번째 줄: 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"; } ' );
}
}
}
);
 


/* 사용자 문서에 기여 내역 리스트 추가 */
/* 사용자 문서에 기여 내역 리스트 추가 */
395번째 줄: 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 }
406번째 줄: 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('//bigforest.a2hosted.com/w/index.php?title=mediawiki:HTMLSandbox/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 */

2025년 8월 7일 (목) 12:44 기준 최신판

/* 이 자바스크립트 설정은 모든 문서, 모든 사용자에게 적용됩니다. 리브레 위키 본관->자유위키에서 가져왔습니다. */

/**
 * 이 스크립트는 큰숲백과 전체에 적용되며, 위키백과, 리브레 위키에서 가져온 것도 있습니다. 고칠 때는 주의해주세요.
 * [[위키백과:위키프로젝트 시스템]] 참고
 *
 * 스크립트를 넣을 때는 충분한 설명, 출처를 넣어주세요! 이후 관리가 어려워집니다.
 **/

/**
 * 아이콘 로드
 *
 **/

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 */
 
/**
 * Map addPortletLink to mw.util 
 *
 * @deprecated: Use mw.util.addPortletLink instead.
 */
mw.log.deprecate( window, 'addPortletLink', mw.util.addPortletLink,
 'Use mw.util.addPortletLink instead' );
 
/**
 * Extract a URL parameter from the current URL
 *
 * @deprecated: Use mw.util.getParamValue with proper escaping
 */
mw.log.deprecate( window, 'getURLParamValue', mw.util.getParamValue, 'Use mw.util.getParamValue instead' );
 
/** 
 * Test if an element has a certain class
 *
 * @deprecated:  Use $(element).hasClass() instead.
 */
mw.log.deprecate( window, 'hasClass', function ( element, className ) {
    return $( element ).hasClass( className );
}, 'Use jQuery.hasClass() instead' );
 
/**
 * @source www.mediawiki.org/wiki/Snippets/Load_JS_and_CSS_by_URL
 * @rev 5
 */
// CSS
var extraCSS = mw.util.getParamValue( 'withCSS' );
if ( extraCSS ) {
	if ( extraCSS.match( /^MediaWiki:[^&<>=%#]*\.css$/ ) ) {
		importStylesheet( extraCSS );
	} else {
		mw.notify( 'Only pages from the MediaWiki namespace are allowed.', { title: 'Invalid withCSS value' } );
	}
}
 
// JS
var extraJS = mw.util.getParamValue( 'withJS' );
if ( extraJS ) {
	if ( extraJS.match( /^MediaWiki:[^&<>=%#]*\.js$/ ) ) {
		importScript( extraJS );
	} else {
		mw.notify( 'Only pages from the MediaWiki namespace are allowed.', { title: 'Invalid withJS value' } );
	}
}

/**
 * Import more specific scripts if necessary - Not used in bigforestwiki
 */
 
/* ([[위키백과:관리자 요청/2007년 5월#스크립트 추가 요청]]) */
/** Collapsible tables *********************************************************
 *
 *  Description: Allows tables to be collapsed, showing only the header. See
 *               [[:en:Wikipedia:NavFrame]].
 *  Maintainers: [[:en:User:R. Koot]]
 */
 
var autoCollapse = 2;
var collapseCaption = '숨기기';
var expandCaption = '보이기';
 
window.collapseTable = function ( tableIndex ) {
    var Button = document.getElementById( 'collapseButton' + tableIndex );
    var Table = document.getElementById( 'collapsibleTable' + tableIndex );
 
    if ( !Table || !Button ) {
        return false;
    }
 
    var Rows = Table.rows;
    var i;
 
    if ( Button.firstChild.data === collapseCaption ) {
        for ( i = 1; i < Rows.length; i++ ) {
            Rows[i].style.display = 'none';
        }
        Button.firstChild.data = expandCaption;
    } else {
        for ( i = 1; i < Rows.length; i++ ) {
            Rows[i].style.display = Rows[0].style.display;
        }
        Button.firstChild.data = collapseCaption;
    }
};
 
function createCollapseButtons() {
    var tableIndex = 0;
    var NavigationBoxes = {};
    var Tables = document.getElementsByTagName( 'table' );
    var i;
 
    function handleButtonLink( index, e ) {
        window.collapseTable( index );
        e.preventDefault();
    }
 
    for ( i = 0; i < Tables.length; i++ ) {
        if ( $( Tables[i] ).hasClass( 'collapsible' ) ) {
 
            /* only add button and increment count if there is a header row to work with */
            var HeaderRow = Tables[i].getElementsByTagName( 'tr' )[0];
            if ( !HeaderRow ) continue;
            var Header = HeaderRow.getElementsByTagName( 'th' )[0];
            if ( !Header ) continue;
 
            NavigationBoxes[ tableIndex ] = Tables[i];
            Tables[i].setAttribute( 'id', 'collapsibleTable' + tableIndex );
 
            var Button     = document.createElement( 'span' );
            var ButtonLink = document.createElement( 'a' );
            var ButtonText = document.createTextNode( collapseCaption );
 
            Button.className = 'collapseButton';  /* Styles are declared in Common.css */
 
            ButtonLink.style.color = Header.style.color;
            ButtonLink.setAttribute( 'id', 'collapseButton' + tableIndex );
            ButtonLink.setAttribute( 'href', '#' );
            $( ButtonLink ).on( 'click', $.proxy( handleButtonLink, ButtonLink, tableIndex ) );
            ButtonLink.appendChild( ButtonText );
 
            Button.appendChild( document.createTextNode( '[' ) );
            Button.appendChild( ButtonLink );
            Button.appendChild( document.createTextNode( ']' ) );
 
            Header.insertBefore( Button, Header.firstChild );
            tableIndex++;
        }
    }
 
    for ( i = 0;  i < tableIndex; i++ ) {
        if ( $( NavigationBoxes[i] ).hasClass( 'collapsed' ) || ( tableIndex >= autoCollapse && $( NavigationBoxes[i] ).hasClass( 'autocollapse' ) ) ) {
            window.collapseTable( i );
        } 
        else if ( $( NavigationBoxes[i] ).hasClass ( 'innercollapse' ) ) {
            var element = NavigationBoxes[i];
            while ((element = element.parentNode)) {
                if ( $( element ).hasClass( 'outercollapse' ) ) {
                    window.collapseTable ( i );
                    break;
                }
            }
        }
    }
}
 
mw.hook( 'wikipage.content' ).add( createCollapseButtons );
 
/* ([[위키백과:관리자 요청/2007년 5월#스크립트 추가 요청]]) */
/** Dynamic Navigation Bars (experimental) *************************************
 *
 *  Description: See [[:en:Wikipedia:NavFrame]].
 *  Maintainers: UNMAINTAINED
 */
 
// set up the words in your language
/* set up the words in your language */
var NavigationBarHide = '[' + collapseCaption + ']';
var NavigationBarShow = '[' + expandCaption + ']';
 
/**
 * Shows and hides content and picture (if available) of navigation bars
 * Parameters:
 *     indexNavigationBar: the index of navigation bar to be toggled
 **/
window.toggleNavigationBar = function ( indexNavigationBar, event ) {
    var NavToggle = document.getElementById( 'NavToggle' + indexNavigationBar );
    var NavFrame = document.getElementById( 'NavFrame' + indexNavigationBar );
    var NavChild;
 
    if ( !NavFrame || !NavToggle ) {
        return false;
    }
 
    /* if shown now */
    if ( NavToggle.firstChild.data === NavigationBarHide ) {
        for ( NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) {
            if ( $( NavChild ).hasClass( 'NavContent' ) || $( NavChild ).hasClass( 'NavPic' ) ) {
                NavChild.style.display = 'none';
            }
        }
    NavToggle.firstChild.data = NavigationBarShow;
 
    /* if hidden now */
    } else if ( NavToggle.firstChild.data === NavigationBarShow ) {
        for ( NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) {
            if ( $( NavChild ).hasClass( 'NavContent' ) || $( NavChild ).hasClass( 'NavPic' ) ) {
                NavChild.style.display = 'block';
            }
        }
        NavToggle.firstChild.data = NavigationBarHide;
    }
 
    event.preventDefault();
};
 
/* adds show/hide-button to navigation bars */
function createNavigationBarToggleButton() {
    var indexNavigationBar = 0;
    var NavFrame;
    var NavChild;
    /* iterate over all < div >-elements */
    var divs = document.getElementsByTagName( 'div' );
    for ( var i = 0; (NavFrame = divs[i]); i++ ) {
        /* if found a navigation bar */
        if ( $( NavFrame ).hasClass( 'NavFrame' ) ) {
 
            indexNavigationBar++;
            var NavToggle = document.createElement( 'a' );
            NavToggle.className = 'NavToggle';
            NavToggle.setAttribute( 'id', 'NavToggle' + indexNavigationBar );
            NavToggle.setAttribute( 'href', '#' );
            $( NavToggle ).on( 'click', $.proxy( window.toggleNavigationBar, window, indexNavigationBar ) );
 
            var isCollapsed = $( NavFrame ).hasClass( 'collapsed' );
            /**
             * Check if any children are already hidden.  This loop is here for backwards compatibility:
             * the old way of making NavFrames start out collapsed was to manually add style="display:none"
             * to all the NavPic/NavContent elements.  Since this was bad for accessibility (no way to make
             * the content visible without JavaScript support), the new recommended way is to add the class
             * "collapsed" to the NavFrame itself, just like with collapsible tables.
             */
            for ( NavChild = NavFrame.firstChild; NavChild != null && !isCollapsed; NavChild = NavChild.nextSibling ) {
                if ( $( NavChild ).hasClass( 'NavPic' ) || $( NavChild ).hasClass( 'NavContent' ) ) {
                    if ( NavChild.style.display === 'none' ) {
                        isCollapsed = true;
                    }
                }
            }
            if ( isCollapsed ) {
                for ( NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) {
                    if ( $( NavChild ).hasClass( 'NavPic' ) || $( NavChild ).hasClass( 'NavContent' ) ) {
                        NavChild.style.display = 'none';
                    }
                }
            }
            var NavToggleText = document.createTextNode( isCollapsed ? NavigationBarShow : NavigationBarHide );
            NavToggle.appendChild( NavToggleText );
 
            /* Find the NavHead and attach the toggle link (Must be this complicated because Moz's firstChild handling is borked) */
            for( var j = 0; j < NavFrame.childNodes.length; j++ ) {
                if ( $( NavFrame.childNodes[j] ).hasClass( 'NavHead' ) ) {
                    NavToggle.style.color = NavFrame.childNodes[j].style.color;
                    NavFrame.childNodes[j].appendChild( NavToggle );
                }
            }
            NavFrame.setAttribute( 'id', 'NavFrame' + indexNavigationBar );
        }
    }
}
 
mw.hook( 'wikipage.content' ).add( createNavigationBarToggleButton );
 
/* 대문의 "프로젝트" 탭을 "대문"으로 바꿉니다.
- 영어 위키백과 common.js의 main page 스크립트를 약간 변형 */
 
/***** 그림 정보 틀을 자동으로 불러옴 ********
 * Adds a link to subpages of current page
 * from commons.wikimedia.org
 *  Maintainers: [[User:Yonidebest]], [[User:Dschwen]]
 *  [[사용자:Kwj2772]]가 수정
 *  JSconfig items: bool 'loadAutoInformationTemplate'
 *                       (true=enabled (default), false=disabled)
 * JSConfig를 사용하지 않도록 수정함. --[[사용자:Klutzy|klutzy]] ([[사용자토론:Klutzy|토론]]) 2009년 9월 27일 (일) 20:33 (KST)
 ****/
/**
 * 파일 라이선스 체계화 150726 - 큰숲백과에서는 사용하지 않음.
 */

/* 인터랙티브 지도. 영어 위키백과에서 가져옴. -- [[사용자:ChongDae]] 2010년 3월 28일 (일) 02:08 (KST) */
/**
 * WikiMiniAtlas
 *
 * Description: WikiMiniAtlas is a popup click and drag world map.
 *              This script causes all of our coordinate links to display the WikiMiniAtlas popup button.
 *              The script itself is located on meta because it is used by many projects.
 *              See [[Meta:WikiMiniAtlas]] for more information. 
 * Maintainers: [[User:Dschwen]]
 */
( function () {
    var require_wikiminiatlas = false;
    var coord_filter = /geohack/;
    $( function () {
        $( 'a.external.text' ).each( function( key, link ) {
            if ( link.href && coord_filter.exec( link.href ) ) {
                require_wikiminiatlas = true;
                // break from loop
                return false;
            }
        } );
        if ( $( 'div.kmldata' ).length ) {
            require_wikiminiatlas = true;
        }
        if ( require_wikiminiatlas ) {
            mw.loader.load( '//meta.wikimedia.org/w/index.php?title=MediaWiki:Wikiminiatlas.js&action=raw&ctype=text/javascript' );
        }
    } );
} )();

/** [[틀:USERNAME]]에서 사용하는 바꿔치기 함수
  * 작성자: 백괴사전 Peremen
*/
$(function () {
    if (typeof(disableUsernameReplace) != 'undefined' && disableUsernameReplace) return;
    if (!document.getElementById('pt-userpage')) return;
    $("span.insertusername").each(function(i) {
        $(this).text(mw.config.get('wgUserName'))
    })
})

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


/** 문서가 존재하는지 존재하지 않는지 판단하여 탭 색을 바꾸는 함수. **/
 
function checkDocumentExistency(documentTitle,tabId) {
  $.getJSON("/w/api.php",
    {action:"query", titles:documentTitle, format:"json"},
    function(d) {
      if(d.query.pages["-1"].missing != undefined) $("#"+tabId).addClass("new");
    }
  );
}

/**
* 안티-반달리즘 필터
*/
$("#mw-content-text [style*='fixed'], #mw-content-text [style*='absolute']").remove();

/**
 * HTTPS에서만 보이는 요소
 */
if (location.protocol == "https:") $(".view-https").show();

/**
 * 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"; } ' );
}


/* 사용자 문서에 기여 내역 리스트 추가 */
/*
if (document.querySelector("body.ns-2")) {
    // 사용자 이름 찾기
    var userName = document.getElementById('firstHeading').innerText.split('\n')[0].split('/')[0].split(':')[1];
    // 사용자 메뉴 찾기
    var cMenu = document.querySelector("nav#p-cactions ul.vector-menu-content-list");
    
    var aUserContrib = document.createElement("a");
    aUserContrib.setAttribute("href", "/wiki/특수:기여/"+userName);
    aUserContrib.innerHTML = "기여 내역";
    var userContrib = document.createElement("li")
    userContrib.id="ca-contribs";
    userContrib.appendChild(aUserContrib);
    cMenu.appendChild(userContrib);
}
*//* {하위문서목록}에서 하위문서의 개수에 따라 열 개수 자동 조절 */
document.querySelectorAll(".subpage-list .mw-prefixindex-body").forEach(function (item) {
	var elementNumber = item.childNodes[0].childElementCount;
    if ( elementNumber > 20 ) { item.style.columnCount = 2 }
    else if ( elementNumber <= 20 ) { item.style.columnCount = 1, item.style.width = "max-content"; }
});

/**
 * [[틀:리브레탭]]용
 */
document.querySelectorAll('.libre-tab').forEach(function (libretab) {
    const $libretab = $(libretab);
    var $btns = $libretab.children('.libre-tab-btns');
    var $content = $libretab.children('.libre-tab-main');
    $btns.children('.libre-tab-btn').on('click', function () {
        if (this.classList.contains('.libre-tab-btn-active')) return;
        $btns.children('.libre-tab-btn-active').removeClass('libre-tab-btn-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));

		var imgbox = document.createElement('div');
		imgbox.classList.add("good-articles-imgbox")
		box.prepend(imgbox)

		goodArticlesContents.append(box);

		(function (imgbox) {
			new mw.Api().get({
				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;

				var img = document.createElement('img');
				img.src = page.thumbnail.source;

				console.log(this)

				imgbox.prepend(img)
			})
		})(imgbox)
	}
})

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