미디어위키:Gadget-dictionary.js: 두 판 사이의 차이

편집 요약 없음
편집 요약 없음
1번째 줄: 1번째 줄:
/* 모든 페이지에서 동작하게끔 Gadgets 정의 뒤, 아래 코드 저장 */
/* ▣ Dictionary gadget ▣
mw.loader.using(['mediawiki.util', 'oojs-ui-core'], function () {
  * 표(class="mw-dictionary")가 있는 페이지에만 작동
$(function () {
  * 검색창은 OOUI → 실패 시 HTML <input>로 폴백
/* ① 숨은 JSON 가져오기 */
-------------------------------------------------- */
var holder = document.getElementById('dictionary-json');
mw.loader.using( [
if (!holder) return;                        // 사전 없는 페이지는 건너뜀
    'mediawiki.util',
var dict  = JSON.parse(holder.textContent); // ← 그대로 파싱
    'oojs-ui-core',
    'oojs-ui.styles.icons-interactions'
], function () {


/* ② 표 찾고, 검색창 끼우고, 실시간 필터 */
    /* 페이지 내용이 처음 로드되거나, Ajax로 다시 삽입될 때마다 실행 */
var $table = $('.mw-dictionary').first();
    mw.hook( 'wikipage.content' ).add( function ( $content ) {
var $input  = new OO.ui.TextInputWidget({
placeholder: '단어·뜻 검색…',
icons: ['search'],
indicator: null
}).$element.css({ width: '100%', 'margin-bottom': '0.5em' });


$table.before($input);
        var $table = $content.find( '.mw-dictionary' ).first();
        if ( !$table.length ) return;                          // 표가 없다면 skip
        if ( $table.prev( '.dict-search-wrapper' ).length ) return; // 중복 생성 방지


// 3) 필터링 로직
        /* ---- 1) 검색창 만들기 ---- */
$input.on('input', function () {
        var $wrapper = $( '<div>' ).addClass( 'dict-search-wrapper' )
var q = $(this).val().trim().toLowerCase();
                                  .css( 'margin-bottom', '8px' );
$table.find('tr').each(function () {
 
var $row = $(this);
        var makeFilter = function ( getValue ) {
if ($row.find('th').length) return; // 헤더는 건너뜀
            return function () {
var term = $row.children('td').eq(0).text().toLowerCase();
                var q = getValue().trim().toLowerCase();
var def  = $row.children('td').eq(1).text().toLowerCase();
                $table.find( 'tr' ).each( function () {
$qMatch = !q || term.includes(q) || def.includes(q);
                    var $row = $( this );
$row.toggle($qMatch);
                    if ( $row.find( 'th' ).length ) return;   // 헤더 row
});
                    var term = $row.children( 'td' ).eq(0).text().toLowerCase();
});
                    var defi = $row.children( 'td' ).eq(1).text().toLowerCase();
});
                    $row.toggle( !q || term.includes( q ) || defi.includes( q ) );
});
                } );
            };
        };
 
        /* 1-A) OOUI 위젯 시도 */
        try {
            var widget = new OO.ui.TextInputWidget( {
                placeholder: '단어·뜻 검색…',
                icons: [ 'search' ],
                indicator: null
            } );
            widget.on( 'change', makeFilter( function () {
                return widget.getValue();
            } ) );
            $wrapper.append( widget.$element );
        } catch ( e ) {
            /* 1-B) 실패하면 순수 HTML 입력창 */
            var $input = $( '<input type="search" placeholder="검색…">' )
                          .css( { width: '100%', padding: '4px' } );
            $input.on( 'input', makeFilter( function () {
                return $input.val();
            } ) );
            $wrapper.append( $input );
        }
 
        $table.before( $wrapper );   // 표 앞에 검색창 끼우기
    } );
} );

2025년 6월 29일 (일) 03:05 판

/* ▣ Dictionary gadget ▣
   * 표(class="mw-dictionary")가 있는 페이지에만 작동
   * 검색창은 OOUI → 실패 시 HTML <input>로 폴백
-------------------------------------------------- */
mw.loader.using( [
    'mediawiki.util',
    'oojs-ui-core',
    'oojs-ui.styles.icons-interactions'
], function () {

    /* 페이지 내용이 처음 로드되거나, Ajax로 다시 삽입될 때마다 실행 */
    mw.hook( 'wikipage.content' ).add( function ( $content ) {

        var $table = $content.find( '.mw-dictionary' ).first();
        if ( !$table.length ) return;                          // 표가 없다면 skip
        if ( $table.prev( '.dict-search-wrapper' ).length ) return; // 중복 생성 방지

        /* ---- 1) 검색창 만들기 ---- */
        var $wrapper = $( '<div>' ).addClass( 'dict-search-wrapper' )
                                   .css( 'margin-bottom', '8px' );

        var makeFilter = function ( getValue ) {
            return function () {
                var q = getValue().trim().toLowerCase();
                $table.find( 'tr' ).each( function () {
                    var $row = $( this );
                    if ( $row.find( 'th' ).length ) return;    // 헤더 row
                    var term = $row.children( 'td' ).eq(0).text().toLowerCase();
                    var defi = $row.children( 'td' ).eq(1).text().toLowerCase();
                    $row.toggle( !q || term.includes( q ) || defi.includes( q ) );
                } );
            };
        };

        /* 1-A) OOUI 위젯 시도 */
        try {
            var widget = new OO.ui.TextInputWidget( {
                placeholder: '단어·뜻 검색…',
                icons: [ 'search' ],
                indicator: null
            } );
            widget.on( 'change', makeFilter( function () {
                return widget.getValue();
            } ) );
            $wrapper.append( widget.$element );
        } catch ( e ) {
            /* 1-B) 실패하면 순수 HTML 입력창 */
            var $input = $( '<input type="search" placeholder="검색…">' )
                          .css( { width: '100%', padding: '4px' } );
            $input.on( 'input', makeFilter( function () {
                return $input.val();
            } ) );
            $wrapper.append( $input );
        }

        $table.before( $wrapper );   // 표 앞에 검색창 끼우기
    } );
} );