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

WONGO
둘러보기로 이동 검색으로 이동
편집 요약 없음
태그: 되돌려진 기여
잔글편집 요약 없음
 
(같은 사용자의 중간 판 16개는 보이지 않습니다)
1번째 줄: 1번째 줄:
mw.hook('wikipage.content').add(function ($content) {
mw.hook('wikipage.content').add(function ($content) {
     // ----------------------------------------
     // 목차(#toc)가 있는지 확인
    // 주석 팝업 처리
     const $toc = $content.find('#toc');
    // ----------------------------------------
    if ($toc.length) {
     const refs = $content.find('sup.reference'); // 주석 <sup> 태그 선택
        console.log('목차가 감지되었습니다.');


     refs.each(function () {
        // 목차 컨테이너 고정 위치 설정
        $toc.css({
            position: 'fixed',
            top: '80px',
            right: '20px',
            width: '250px',
            backgroundColor: '#f9f9f9',
            border: '1px solid #ddd',
            borderRadius: '4px',
            padding: '10px',
            boxShadow: '0 4px 8px rgba(0, 0, 0, 0.1)',
            zIndex: 1000,
            overflow: 'hidden', // 목차 전체 스크롤 제거
        });
 
        // 목차 내부 리스트 스크롤 활성화
        const $list = $toc.children('ul, ol');
        if ($list.length) {
            $list.css({
                maxHeight: '75vh', // 내부 리스트 최대 높이
                overflowY: 'auto', // 내부 리스트에만 스크롤 활성화
                margin: 0,
                padding: 0,
                listStyle: 'none',
                paddingRight: '10px', // 스크롤바 공간 확보
            });
        } else {
            console.warn('목차 내부에 리스트가 없습니다.');
        }
 
        // 페이지 내용 간 여백 조정
        $('#content').css('margin-right', '280px');
    } else {
        console.warn('목차가 없습니다.');
    }
});
 
 
 
mw.hook('wikipage.content').add(function($content) {
    // 모든 주석 <sup> 태그 선택
    const refs = $content.find('sup.reference');
 
     refs.each(function() {
         const $ref = $(this);
         const $ref = $(this);
         const refId = $ref.find('a').attr('href'); // 주석의 href 속성 가져오기
         const refId = $ref.find('a').attr('href'); // <a> 태그의 href 속성에서 ID 가져오기


         if (refId) {
         if (refId) {
             const refContent = $(refId).html(); // 주석 내용 가져오기
             const refContent = $(refId).html(); // 주석 내용 가져오기


             // 팝업 컨테이너 생성
             // 팝업용 컨테이너 생성
             const $tooltip = $('<div>')
             const $tooltip = $('<div>')
                 .addClass('ref-tooltip')
                 .addClass('ref-tooltip')
24번째 줄: 67번째 줄:
                     'z-index': 1000,
                     'z-index': 1000,
                     'box-shadow': '0 4px 8px rgba(0,0,0,0.1)',
                     'box-shadow': '0 4px 8px rgba(0,0,0,0.1)',
                    'max-width': '300px',
                    'overflow-wrap': 'break-word',
                 });
                 });


             // 팝업 DOM에 추가
             // 팝업을 DOM에 추가
             $('body').append($tooltip);
             $('body').append($tooltip);


             // 마우스 이벤트 처리
             // 마우스 이벤트 처리
             $ref.on('mouseenter', function (event) {
             $ref.on('mouseenter', function(event) {
                 $tooltip.css({
                 $tooltip.css({
                     top: event.pageY + 10,
                     top: event.pageY + 10,
39번째 줄: 80번째 줄:
             });
             });


             $ref.on('mousemove', function (event) {
             $ref.on('mousemove', function(event) {
                 $tooltip.css({
                 $tooltip.css({
                     top: event.pageY + 10,
                     top: event.pageY + 10,
46번째 줄: 87번째 줄:
             });
             });


             $ref.on('mouseleave', function () {
             $ref.on('mouseleave', function() {
                 $tooltip.fadeOut(200);
                 $tooltip.fadeOut(200);
             });
             });
         }
         }
     });
     });
});


    // ----------------------------------------
    // 링크 팝업 처리
    // ----------------------------------------
    const links = $content.find('a'); // 모든 링크 선택


    // 팝업 컨테이너 생성
mw.loader.using(['mediawiki.api', 'mediawiki.util'], function() {
    const $popup = $('<div>')
    // 메인 페이지 이름이 'Main_Page'라는 가정
        .addClass('link-preview-popup')
    // (현지화된 MediaWiki 설치에서는 다른 이름일 수 있으므로 환경에 맞게 수정)
        .css({
    if (mw.config.get('wgPageName') !== '대문') {
            display: 'none',
         return; // 메인 페이지가 아니면 실행하지 않음
            position: 'absolute',
     }
            border: '1px solid #ccc',
            background: '#fff',
            padding: '10px',
            'z-index': 1000,
            'box-shadow': '0 4px 8px rgba(0,0,0,0.1)',
            'max-width': '300px',
            'overflow-wrap': 'break-word',
         });
 
    // 팝업을 DOM에 추가
     $('body').append($popup);


     links.each(function () {
     // API 객체 생성
        const $link = $(this);
    var api = new mw.Api();


        // 내부 링크만 처리
    // 사이드바 영역 선택 (Vector 스킨 기준: #mw-panel, Vector 2022 스킨은 #mw-sidebar)
        if (
    // 사용하는 스킨에 맞추어 수정 가능
            $link.attr('href') &&
    var $sidebar = $('#mw-panel');
            ($link.attr('href').startsWith(mw.config.get('wgScriptPath') + '/index.php/') ||
    if (!$sidebar.length) {
                $link.attr('href').startsWith(mw.config.get('wgScriptPath') + '/wiki/'))
        // 예: Vector 2022 스킨인 경우
        ) {
        $sidebar = $('#mw-sidebar');
            $link.on('mouseenter', function (event) {
    }
                // 페이지 제목 추출
                const pageTitle = decodeURIComponent(
                    $link.attr('href')
                        .replace(mw.config.get('wgScriptPath') + '/index.php/', '')
                        .replace(mw.config.get('wgScriptPath') + '/wiki/', '')
                );


                // MediaWiki API 호출
     // 통계 표시용 박스 생성
                $.ajax({
     var $statsBox = $('<div>')
                    url: mw.util.wikiScript('api'),
         .attr('id', 'mw-site-stats-box')
                    data: {
                        action: 'query',
                        prop: 'extracts',
                        titles: pageTitle,
                        format: 'json',
                        exintro: true, // 첫 번째 문단만 가져오기
                        explaintext: true, // HTML 태그 제거
                    },
                    dataType: 'json',
                    success: function (data) {
                        const pages = data.query.pages;
                        const page = Object.values(pages)[0];
 
                        if (page && page.extract) {
                            $popup.html(page.extract);
                            $popup.css({
                                top: event.pageY + 10,
                                left: event.pageX + 10,
                            }).fadeIn(200);
                        } else {
                            $popup.html('내용을 가져올 수 없습니다.');
                        }
                    },
                    error: function () {
                        $popup.html('오류가 발생했습니다.');
                    },
                });
            });
 
            $link.on('mousemove', function (event) {
                $popup.css({
                    top: event.pageY + 10,
                    left: event.pageX + 10,
                });
            });
 
            $link.on('mouseleave', function () {
                $popup.fadeOut(200);
            });
        }
    });
});
 
mw.hook('wikipage.content').add(function ($content) {
     // 팝업 컨테이너 생성
     const $popup = $('<div>')
         .addClass('link-preview-popup')
         .css({
         .css({
             display: 'none',
             'margin': '1em 0',
             position: 'absolute',
             'padding': '0.5em',
             border: '1px solid #ccc',
             'border': '1px solid #ccc',
             background: '#fff',
             'border-radius': '4px',
            padding: '10px',
             'background': '#f9f9f9'
            'z-index': 1000,
         })
            'box-shadow': '0 4px 8px rgba(0,0,0,0.1)',
         .text('사이트 통계 불러오는 중...');
             'max-width': '300px',
            'overflow-wrap': 'break-word',
         });
 
    // 팝업 DOM에 추가
    $('body').append($popup);
 
    // 모든 내부 링크 처리
    $content.find('a').each(function () {
        const $link = $(this);
 
        // 내부 링크만 처리
         if (
            $link.attr('href') &&
            ($link.attr('href').startsWith(mw.config.get('wgScriptPath') + '/index.php/') ||
                $link.attr('href').startsWith(mw.config.get('wgScriptPath') + '/wiki/'))
        ) {
            $link.on('mouseenter', function (event) {
                // 페이지 제목 추출
                const pageTitle = decodeURIComponent(
                    $link.attr('href')
                        .replace(mw.config.get('wgScriptPath') + '/index.php/', '')
                        .replace(mw.config.get('wgScriptPath') + '/wiki/', '')
                );
 
                console.log('API 요청 :', pageTitle); // 디버깅용 로그
 
                // MediaWiki API 호출
                $.ajax({
                    url: mw.util.wikiScript('api'),
                    data: {
                        action: 'query',
                        prop: 'extracts',
                        titles: pageTitle,
                        format: 'json',
                        exintro: true, // 첫 번째 문단만 가져오기
                        explaintext: true, // HTML 태그 제거
                    },
                    dataType: 'json',
                    success: function (data) {
                        console.log('API 응답 데이터:', data); // 디버깅용 로그


                        const pages = data.query.pages;
    // 사이드바 맨 아래나 적절한 위치에 삽입
                        const page = Object.values(pages)[0]; // 첫 번째 문서 가져오기
    $sidebar.append($statsBox);


                        if (page && page.extract) {
    // 사이트 통계 API 호출
                            $popup.html(page.extract); // 팝업에 내용 삽입
    api.get({
                            $popup.css({
        action: 'query',
                                top: event.pageY + 10,
        meta: 'siteinfo',
                                left: event.pageX + 10,
        siprop: 'statistics',
                            }).fadeIn(200);
        format: 'json'
                        } else {
    }).done(function(data) {
                            $popup.html('내용을 가져올 수 없습니다.');
        if (data && data.query && data.query.statistics) {
                        }
            var stats = data.query.statistics;
                    },
            // 필요한 통계만 골라 표시(아래는 예시)
                    error: function (error) {
            // pages: 문서 수, edits: 편집 수, users: 등록 사용자 수 등
                        console.error('API 호출 실패:', error); // 디버깅용 로그
            var html = '<b>사이트 통계</b><br>' +
                        $popup.html('API 호출에 실패했습니다.');
                '문서 수: ' + stats.pages + '<br>' +
                    },
                '편집 수: ' + stats.edits + '<br>' +
                 });
                 '등록 사용자: ' + stats.activeusers + '<br>';
            });


             $link.on('mousemove', function (event) {
             $statsBox.html(html);
                $popup.css({
        } else {
                    top: event.pageY + 10,
             $statsBox.text('통계 정보를 가져올 수 없습니다.');
                    left: event.pageX + 10,
                });
            });
 
             $link.on('mouseleave', function () {
                $popup.fadeOut(200);
            });
         }
         }
    }).fail(function() {
        $statsBox.text('통계 정보를 불러오는 중 오류가 발생했습니다.');
     });
     });
});
});

2025년 2월 3일 (월) 19:02 기준 최신판

mw.hook('wikipage.content').add(function ($content) {
    // 목차(#toc)가 있는지 확인
    const $toc = $content.find('#toc');
    if ($toc.length) {
        console.log('목차가 감지되었습니다.');

        // 목차 컨테이너 고정 위치 설정
        $toc.css({
            position: 'fixed',
            top: '80px',
            right: '20px',
            width: '250px',
            backgroundColor: '#f9f9f9',
            border: '1px solid #ddd',
            borderRadius: '4px',
            padding: '10px',
            boxShadow: '0 4px 8px rgba(0, 0, 0, 0.1)',
            zIndex: 1000,
            overflow: 'hidden', // 목차 전체 스크롤 제거
        });

        // 목차 내부 리스트 스크롤 활성화
        const $list = $toc.children('ul, ol');
        if ($list.length) {
            $list.css({
                maxHeight: '75vh', // 내부 리스트 최대 높이
                overflowY: 'auto', // 내부 리스트에만 스크롤 활성화
                margin: 0,
                padding: 0,
                listStyle: 'none',
                paddingRight: '10px', // 스크롤바 공간 확보
            });
        } else {
            console.warn('목차 내부에 리스트가 없습니다.');
        }

        // 페이지 내용 간 여백 조정
        $('#content').css('margin-right', '280px');
    } else {
        console.warn('목차가 없습니다.');
    }
});



mw.hook('wikipage.content').add(function($content) {
    // 모든 주석 <sup> 태그 선택
    const refs = $content.find('sup.reference');

    refs.each(function() {
        const $ref = $(this);
        const refId = $ref.find('a').attr('href'); // <a> 태그의 href 속성에서 ID 가져오기

        if (refId) {
            const refContent = $(refId).html(); // 주석 내용 가져오기

            // 팝업용 컨테이너 생성
            const $tooltip = $('<div>')
                .addClass('ref-tooltip')
                .html(refContent)
                .css({
                    display: 'none',
                    position: 'absolute',
                    border: '1px solid #ccc',
                    background: '#fff',
                    padding: '10px',
                    'z-index': 1000,
                    'box-shadow': '0 4px 8px rgba(0,0,0,0.1)',
                });

            // 팝업을 DOM에 추가
            $('body').append($tooltip);

            // 마우스 이벤트 처리
            $ref.on('mouseenter', function(event) {
                $tooltip.css({
                    top: event.pageY + 10,
                    left: event.pageX + 10,
                }).fadeIn(200);
            });

            $ref.on('mousemove', function(event) {
                $tooltip.css({
                    top: event.pageY + 10,
                    left: event.pageX + 10,
                });
            });

            $ref.on('mouseleave', function() {
                $tooltip.fadeOut(200);
            });
        }
    });
});


mw.loader.using(['mediawiki.api', 'mediawiki.util'], function() {
    // 메인 페이지 이름이 'Main_Page'라는 가정
    // (현지화된 MediaWiki 설치에서는 다른 이름일 수 있으므로 환경에 맞게 수정)
    if (mw.config.get('wgPageName') !== '대문') {
        return; // 메인 페이지가 아니면 실행하지 않음
    }

    // API 객체 생성
    var api = new mw.Api();

    // 사이드바 영역 선택 (Vector 스킨 기준: #mw-panel, Vector 2022 스킨은 #mw-sidebar)
    // 사용하는 스킨에 맞추어 수정 가능
    var $sidebar = $('#mw-panel');
    if (!$sidebar.length) {
        // 예: Vector 2022 스킨인 경우
        $sidebar = $('#mw-sidebar');
    }

    // 통계 표시용 박스 생성
    var $statsBox = $('<div>')
        .attr('id', 'mw-site-stats-box')
        .css({
            'margin': '1em 0',
            'padding': '0.5em',
            'border': '1px solid #ccc',
            'border-radius': '4px',
            'background': '#f9f9f9'
        })
        .text('사이트 통계 불러오는 중...');

    // 사이드바 맨 아래나 적절한 위치에 삽입
    $sidebar.append($statsBox);

    // 사이트 통계 API 호출
    api.get({
        action: 'query',
        meta: 'siteinfo',
        siprop: 'statistics',
        format: 'json'
    }).done(function(data) {
        if (data && data.query && data.query.statistics) {
            var stats = data.query.statistics;
            // 필요한 통계만 골라 표시(아래는 예시)
            // pages: 문서 수, edits: 편집 수, users: 등록 사용자 수 등
            var html = '<b>사이트 통계</b><br>' +
                '문서 수: ' + stats.pages + '<br>' +
                '편집 수: ' + stats.edits + '<br>' +
                '등록 사용자: ' + stats.activeusers + '<br>';

            $statsBox.html(html);
        } else {
            $statsBox.text('통계 정보를 가져올 수 없습니다.');
        }
    }).fail(function() {
        $statsBox.text('통계 정보를 불러오는 중 오류가 발생했습니다.');
    });
});