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

편집 요약 없음
태그: 되돌려진 기여
편집 요약 없음
태그: 수동 되돌리기
1번째 줄: 1번째 줄:
/* All JavaScript here will be loaded for users of the MinervaNeue skin */
/* All JavaScript here will be loaded for users of the MinervaNeue skin */
// 링크 생성 함수
function wikiLink(title) {
function wikiLink(title) {
     return mw.config.get('wgServer') + '/' + title.replace(/ /g, '_');
     return mw.config.get('wgServer') + '/' + title.replace(/ /g, '_');
}
}


// 메뉴 UI 삽입
document
document
     .querySelector('#mw-mf-page-left #p-navigation')
     .querySelector('#mw-mf-page-left #p-navigation')
12번째 줄: 9번째 줄:
         'afterend',
         'afterend',
         '<ul id="p-main-categories" class="recommended-open">' +
         '<ul id="p-main-categories" class="recommended-open">' +
             '<li class="title-recommended"><a><span>추천문서</span></a><span class="ico-arrow"></span></li>' +
             '<li class="title-recommended open"><a><span>추천문서</span></a><span class="ico-arrow"></span></li>' +
             '<li class="recommended"><a href="/"><span>하나님의 교회</span></a></li>' +
             '<li class="recommended"><a href="/"><span>하나님의 교회</span></a></li>' +
             '<li class="recommended"><a href="'+wikiLink("안상홍")+'"><span>그리스도 안상홍님</span></a></li>' +
             '<li class="recommended"><a href="'+wikiLink("안상홍")+'"><span>그리스도 안상홍님</span></a></li>' +
20번째 줄: 17번째 줄:
             '<li class="recommended"><a href="'+wikiLink("복음과 새 언약")+'"><span>복음과 새 언약</span></a></li>' +
             '<li class="recommended"><a href="'+wikiLink("복음과 새 언약")+'"><span>복음과 새 언약</span></a></li>' +
             '<li class="recommended"><a href="'+wikiLink("하나님의 교회 마지막 종교개혁")+'"><span>마지막 종교개혁</span></a></li>' +
             '<li class="recommended"><a href="'+wikiLink("하나님의 교회 마지막 종교개혁")+'"><span>마지막 종교개혁</span></a></li>' +
           
             '<li class="title-category"><a><span>카테고리 둘러보기</span></a><span class="ico-arrow"></span></li>' +
             '<li class="title-category"><a><span>카테고리 둘러보기</span></a><span class="ico-arrow"></span></li>' +
            '<li class="category"><a href="'+wikiLink("분류:하나님의 교회")+'"><span>하나님의 교회</span></a></li>' +
'<li class="category"><a href="'+wikiLink("분류:하나님의 교회")+'"><span>하나님의 교회</span></a></li>' +
             '<li class="category"><a href="'+wikiLink("분류:아버지")+'"><span>아버지 하나님</span></a></li>' +
             '<li class="category"><a href="'+wikiLink("분류:아버지")+'"><span>아버지 하나님</span></a></li>' +
             '<li class="category"><a href="'+wikiLink("분류:어머니")+'"><span>어머니 하나님</span></a></li>' +
             '<li class="category"><a href="'+wikiLink("분류:어머니")+'"><span>어머니 하나님</span></a></li>' +
30번째 줄: 26번째 줄:
             '<li class="category"><a href="'+wikiLink("분류:사회 공헌")+'"><span>사회 공헌</span></a></li>' +
             '<li class="category"><a href="'+wikiLink("분류:사회 공헌")+'"><span>사회 공헌</span></a></li>' +
             '<li class="category"><a href="'+wikiLink("분류:국제 협력")+'"><span>국제 협력</span></a></li>' +
             '<li class="category"><a href="'+wikiLink("분류:국제 협력")+'"><span>국제 협력</span></a></li>' +
            '</ul>'
    );


            '<li class="title-family"><a><span>패밀리 사이트</span></a><span class="ico-arrow"></span></li>' +
// Recommended Documents 토글
            '<li class="family"><a href="https://watv.org/"><span>하나님의교회 공식사이트</span></a></li>' +
document.querySelector('#p-main-categories .title-recommended')
            '<li class="family"><a href="https://ahnsahnghong.com/"><span>그리스도 안상홍님</span></a></li>' +
    .addEventListener('click', function (event) {
            '<li class="family"><a href="https://jerusalemmother.com/"><span>어머니 하나님</span></a></li>' +
        event.stopPropagation(); // 사이드바 닫힘 방지
            '<li class="family"><a href="https://watvseminar.org/"><span>국제 성경 세미나</span></a></li>' +
        openList(this, '.recommended');
            '<li class="family"><a href="https://webinar.watv.org/ko/"><span>WATV Webinar</span></a></li>' +
    });
            '<li class="family"><a href="https://ukzion.watv.org/"><span>영국 여왕상 수상</span></a></li>' +
            '<li class="family"><a href="https://watvaward.org/"><span>수상내역 스페셜</span></a></li>' +
            '<li class="family"><a href="https://watvpress.org/"><span>전 세계 언론보도</span></a></li>' +


            '<li class="title-youtube"><a><span>유튜브 채널</span></a><span class="ico-arrow"></span></li>' +
// Browse by Category 토글
            '<li class="youtube"><a href="https://www.youtube.com/c/WMSCOGTV"><span>하나님의교회 공식유튜브</span></a></li>' +
document.querySelector('#p-main-categories .title-category')
            '<li class="youtube"><a href="https://www.youtube.com/c/WorldMissionSocietyChurchofGod"><span>하나님의교회 소개영상</span></a></li>' +
    .addEventListener('click', function (event) {
            '<li class="youtube"><a href="https://www.youtube.com/channel/UC5eMiMT79Q9dBNjC0ZGjqxQ"><span>그리스도 안상홍님</span></a></li>' +
        event.stopPropagation(); // 사이드바 닫힘 방지
            '<li class="youtube"><a href="https://www.youtube.com/@JerusalemMother"><span>어머니 하나님</span></a></li>' +
         openList(this, '.category');
            '<li class="youtube"><a href="https://www.youtube.com/channel/UCYJ3ZTBXsk1XIfjACZRE4yg"><span>하나님의교회 미디어</span></a></li>' +
            '<li class="youtube"><a href="https://www.youtube.com/c/ChurchofGodNEWSONG"><span>하나님의교회 새노래</span></a></li>' +
            '<li class="youtube"><a href="https://www.youtube.com/channel/UCygKTjdV8ULvNT2cPANTE9A"><span>Church of God TUBE</span></a></li>' +
            '<li class="youtube"><a href="https://www.youtube.com/channel/UCYLPtSHjJeyoXYaYTG0J_Gw"><span>사막에 뜨는 별</span></a></li>' +
        '</ul>'
    );
 
// ------ 카테고리별 리스트를 기본 접힘(숨김) 상태로 만듦
['.recommended', '.category', '.family', '.youtube'].forEach(function(cls){
    document.querySelectorAll('#p-main-categories ' + cls).forEach(function(li){
         li.style.display = 'none';
     });
     });
});
// 타이틀 항목 open 클래스 제거 (초기엔 모두 닫힘)
['.title-recommended', '.title-category', '.title-family', '.title-youtube'].forEach(function(cls){
    var el = document.querySelector('#p-main-categories ' + cls);
    if(el) el.classList.remove('open');
});


// 토글 함수 (카테고리 제목 클릭 시 리스트 펼침/접힘)
function openList(titleLi, selector) {
function openList(titleLi, selector) {
     titleLi.classList.toggle('open');
     titleLi.classList.toggle('open');
    let isOpen = titleLi.classList.contains('open');
     let next = titleLi.nextElementSibling;
     let next = titleLi.nextElementSibling;
    // 다음 제목 전까지만 토글
     while (next && !next.classList.contains('title-recommended') && !next.classList.contains('title-category')) {
     while (next && !next.classList.contains('title-recommended') &&
                  !next.classList.contains('title-category') &&
                  !next.classList.contains('title-family') &&
                  !next.classList.contains('title-youtube')) {
         if (next.matches(selector)) {
         if (next.matches(selector)) {
             next.style.display = isOpen ? 'block' : 'none';
             next.style.display = (next.style.display === 'none' || next.style.display === '') ? 'block' : 'none';
         }
         }
         next = next.nextElementSibling;
         next = next.nextElementSibling;
82번째 줄: 54번째 줄:
}
}


// 각 카테고리 타이틀에 토글 이벤트 바인딩
// 유튜브 썸네일
[
    {class: '.title-recommended', sel: '.recommended'},
    {class: '.title-category', sel: '.category'},
    {class: '.title-family', sel: '.family'},
    {class: '.title-youtube', sel: '.youtube'}
].forEach(function(row) {
    var el = document.querySelector('#p-main-categories ' + row.class);
    if (el) el.addEventListener('click', function (event) {
        event.stopPropagation(); // 모바일 미네르바 스킨 메뉴 자동 닫힘 방지
        openList(this, row.sel);
    });
});
 
// 유튜브 썸네일, 모달 등 기존 부가 기능
document.querySelectorAll('iframe').forEach(function (iframe) {
document.querySelectorAll('iframe').forEach(function (iframe) {
     var $container = iframe.parentElement;
     var $container = iframe.parentElement;
103번째 줄: 61번째 줄:
     iframe.parentElement.classList.add('video-wrap');
     iframe.parentElement.classList.add('video-wrap');
});
});
mw.loader.using(['jquery']).then(function() {
mw.loader.using(['jquery']).then(function() {
     $(function() {
     $(function() {
         var modal = $('#myLayer');
         var modal = $('#myLayer');
         var btn = $('#selectLanguage');
         var btn = $('#selectLanguage'); // jQuery 선택자 사용
         var span = $('.close-button').first();
         var span = $('.close-button').first();
         btn.click(function() {
         btn.click(function() {
             modal.show();
             modal.show();
         });
         });
         span.click(function() {
         span.click(function() {
             modal.hide();
             modal.hide();
         });
         });
         $(window).click(function(event) {
         $(window).click(function(event) {
             if ($(event.target).is(modal)) {
             if ($(event.target).is(modal)) {