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

편집 요약 없음
태그: 되돌려진 기여
편집 요약 없음
 
(사용자 2명의 중간 판 5개는 보이지 않습니다)
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, '_');
}
}
document
    .querySelector('#mw-mf-page-left #p-navigation')
    .insertAdjacentHTML(
        'afterend',
        '<ul id="p-main-categories" class="recommended-open">' +
            // open 클래스
            '<li class="title-recommended open"><a><span>추천문서</span></a><span class="ico-arrow"></span></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="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>' +
var nav = document.querySelector('#mw-mf-page-left #p-navigation');
            '<li class="category"><a href="'+wikiLink("분류:하나님의 교회")+'"><span>하나님의 교회</span></a></li>' +
if (!nav) return;
            '<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>' +
            '<li class="category"><a href="'+wikiLink("분류:국제 협력")+'"><span>국제 협력</span></a></li>' +


// 기존 메뉴 중복 방지
            '<li class="title-family"><a><span>패밀리 사이트</span></a><span class="ico-arrow"></span></li>' +
var oldMenu = document.getElementById('p-main-categories');
            '<li class="family"><a href="https://watv.org/"><span>하나님의교회 공식사이트</span></a></li>' +
if (oldMenu) oldMenu.remove();
            '<li class="family"><a href="https://ahnsahnghong.com/"><span>그리스도 안상홍님</span></a></li>' +
            '<li class="family"><a href="https://jerusalemmother.com/"><span>어머니 하나님</span></a></li>' +
            '<li class="family"><a href="https://watvseminar.org/"><span>국제 성경 세미나</span></a></li>' +
            '<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>' +


// 메뉴 UI 삽입
            '<li class="title-youtube"><a><span>유튜브 채널</span></a><span class="ico-arrow"></span></li>' +
nav.insertAdjacentHTML(
            '<li class="youtube"><a href="https://www.youtube.com/c/WMSCOGTV"><span>하나님의교회 공식유튜브</span></a></li>' +
    'afterend',
            '<li class="youtube"><a href="https://www.youtube.com/c/WorldMissionSocietyChurchofGod"><span>하나님의교회 소개영상</span></a></li>' +
    '<ul id="p-main-categories" class="recommended-open">' +
            '<li class="youtube"><a href="https://www.youtube.com/channel/UC5eMiMT79Q9dBNjC0ZGjqxQ"><span>그리스도 안상홍님</span></a></li>' +
        '<li class="title-recommended"><a><span>추천문서</span></a><span class="ico-arrow"></span></li>' +
            '<li class="youtube"><a href="https://www.youtube.com/@JerusalemMother"><span>어머니 하나님</span></a></li>' +
        '<li class="recommended"><a href="/"><span>하나님의 교회</span></a></li>' +
            '<li class="youtube"><a href="https://www.youtube.com/channel/UCYJ3ZTBXsk1XIfjACZRE4yg"><span>하나님의교회 미디어</span></a></li>' +
        '<li class="recommended"><a href="'+wikiLink("안상홍")+'"><span>그리스도 안상홍님</span></a></li>' +
            '<li class="youtube"><a href="https://www.youtube.com/c/ChurchofGodNEWSONG"><span>하나님의교회 새노래</span></a></li>' +
        '<li class="recommended"><a href="'+wikiLink("어머니 하나님")+'"><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="recommended"><a href="'+wikiLink("안식일")+'"><span>안식일</span></a></li>' +
            '<li class="youtube"><a href="https://www.youtube.com/channel/UCYLPtSHjJeyoXYaYTG0J_Gw"><span>사막에 뜨는 별</span></a></li>' +
        '<li class="recommended"><a href="'+wikiLink("유월절")+'"><span>유월절</span></a></li>' +
        '</ul>'
        '<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="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>' +
        '<li class="category"><a href="'+wikiLink("분류:사회 공헌")+'"><span>사회 공헌</span></a></li>' +
        '<li class="category"><a href="'+wikiLink("분류:국제 협력")+'"><span>국제 협력</span></a></li>' +
        '<li class="title-family"><a><span>패밀리 사이트</span></a><span class="ico-arrow"></span></li>' +
        '<li class="family"><a href="https://watv.org/"><span>하나님의교회 공식사이트</span></a></li>' +
        '<li class="family"><a href="https://ahnsahnghong.com/"><span>그리스도 안상홍님</span></a></li>' +
        '<li class="family"><a href="https://jerusalemmother.com/"><span>어머니 하나님</span></a></li>' +
        '<li class="family"><a href="https://watvseminar.org/"><span>국제 성경 세미나</span></a></li>' +
        '<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>' +
        '<li class="youtube"><a href="https://www.youtube.com/c/WMSCOGTV"><span>하나님의교회 공식유튜브</span></a></li>' +
        '<li class="youtube"><a href="https://www.youtube.com/c/WorldMissionSocietyChurchofGod"><span>하나님의교회 소개영상</span></a></li>' +
        '<li class="youtube"><a href="https://www.youtube.com/channel/UC5eMiMT79Q9dBNjC0ZGjqxQ"><span>그리스도 안상홍님</span></a></li>' +
        '<li class="youtube"><a href="https://www.youtube.com/@JerusalemMother"><span>어머니 하나님</span></a></li>' +
        '<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 .recommended').forEach(function(li){
     document.querySelectorAll('#p-main-categories ' + cls).forEach(function(li){
    li.style.display = 'block'; // 추천문서만 open
});
['.category', '.family', '.youtube'].forEach(function(selector) {
     document.querySelectorAll('#p-main-categories ' + selector).forEach(function(li) {
         li.style.display = 'none';
         li.style.display = 'none';
     });
     });
});
['.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');
});
});


// 토글 함수
// Recommended Documents 토글
document.querySelector('#p-main-categories .title-recommended')
    .addEventListener('click', function (event) {
        event.stopPropagation();
        openList(this, '.recommended');
    });
// Browse by Category 토글
document.querySelector('#p-main-categories .title-category')
    .addEventListener('click', function (event) {
        event.stopPropagation();
        openList(this, '.category');
    });
// Family Sites 토글
document.querySelector('#p-main-categories .title-family')
    .addEventListener('click', function (event) {
        event.stopPropagation();
        openList(this, '.family');
    });
// Youtube Channel 토글
document.querySelector('#p-main-categories .title-youtube')
    .addEventListener('click', function (event) {
        event.stopPropagation();
        openList(this, '.youtube');
    });
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 (
     while (
80번째 줄: 95번째 줄:
     ) {
     ) {
         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;
     }
     }
}
}
 
// 유튜브 썸네일
// 이벤트 바인딩
document.querySelectorAll('iframe').forEach(function (iframe) {
[
     var $container = iframe.parentElement;
    {class: '.title-recommended', sel: '.recommended'},
    var $videoWrap = $container.parentElement;
     {class: '.title-category', sel: '.category'},
     if ($videoWrap && $videoWrap.classList.contains('video-wrap')) return;
     {class: '.title-family', sel: '.family'},
    iframe.parentElement.classList.add('video-wrap');
    {class: '.title-youtube', sel: '.youtube'}
});
].forEach(function(row) {
mw.loader.using(['jquery']).then(function() {
     var el = document.querySelector('#p-main-categories ' + row.class);
     $(function() {
    if (el) el.addEventListener('click', function (event) {
        var modal = $('#myLayer');
        event.stopPropagation();
        var btn = $('#selectLanguage');
         openList(this, row.sel);
        var span = $('.close-button').first();
        btn.click(function() {
            modal.show();
        });
        span.click(function() {
            modal.hide();
        });
        $(window).click(function(event) {
            if ($(event.target).is(modal)) {
                modal.hide();
            }
         });
     });
     });
});
});
function fillMobileLanguageFromInterwiki() {
    var $mobileList = $('#mobile-language');
    // 인터위키 링크 읽기
    var $interwikiLinks = $('#p-lang ul.minerva-languages .interlanguage-link a');
    if (!$interwikiLinks.length) return;
    var langMap = {
        'ko': '한국어',
        'en': '영어',
        'es': '스페인어',
        'vi': '베트남어',
        'ne': '네팔어',
        'pt': '포르투갈어'
    };
    $mobileList.empty();
    $interwikiLinks.each(function () {
        var $a      = $(this);
        var href    = $a.attr('href');
        var langCode = $a.attr('lang');
        var autonym  = $a.find('span').text() || $a.text();  // English, Español ...
        var korean  = langMap[langCode] || '';
        var label    = korean ? (autonym + ' (' + korean + ')') : autonym;
        var $li  = $('<li>');
        var $new = $('<a>', { href: href, text: label });


// 유튜브 썸네일 기능(간단한 널체크 보완)
         $li.append($new);
document.querySelectorAll('iframe').forEach(function (iframe) {
         $mobileList.append($li);
    if (iframe.parentElement) {
     });
         var $container = iframe.parentElement;
}
        var $videoWrap = $container.parentElement;
         if (!($videoWrap && $videoWrap.classList.contains('video-wrap'))) {
            $container.classList.add('video-wrap');
        }
     }
});


// 모달 구현 (jQuery가 있다면)
mw.loader.using(['jquery']).then(function () {
if (window.jQuery) {
    $(function () {
    mw.loader.using(['jquery']).then(function() {
        // body DOM 변경 감시
        $(function() {
        var observer = new MutationObserver(function (mutations) {
            var modal = $('#myLayer');
             mutations.forEach(function (m) {
            var btn = $('#selectLanguage');
                 $(m.addedNodes).each(function () {
            var span = $('.close-button').first();
                    var $node = $(this);
             btn.click(function() {
                    if ($node.is('#mobile-language') || $node.find('#mobile-language').length) {
                 modal.show();
                        fillMobileLanguageFromInterwiki();
            });
                    }
            span.click(function() {
                 });
                modal.hide();
            });
            $(window).click(function(event) {
                if ($(event.target).is(modal)) {
                    modal.hide();
                 }
             });
             });
         });
         });
        observer.observe(document.body, {
            childList: true,
            subtree: true
        });
        // 혹시 이미 열려 있는 상태에서 로딩될 수도 있으니 한 번 시도
        fillMobileLanguageFromInterwiki();
     });
     });
}
});