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

인테리어 위키
둘러보기로 이동 검색으로 이동
편집 요약 없음
편집 요약 없음
2번째 줄: 2번째 줄:


/* =========================
/* =========================
   h2/h3/h4 기본 접기/펼치기
   h2 / h3 / h4 접기/펼치기
   - 헤더 바로 아래 콘텐츠만 토글
   - 기본 상태: 펼침
   - 다음 heading(h1~h6) 나오면 종료
   - 아이콘 회전으로 상태 표현
   ========================= */
   ========================= */


18번째 줄: 18번째 줄:
     if ($heading.data('fold-ready')) return;
     if ($heading.data('fold-ready')) return;
     $heading.data('fold-ready', true);
     $heading.data('fold-ready', true);
    // 아이콘 추가
    const $icon = $('<span class="mw-fold-icon">▶</span>');
    $heading.prepend($icon);


     // wrapper 생성
     // wrapper 생성
23번째 줄: 27번째 줄:
     let $next = $heading.next();
     let $next = $heading.next();


     // 바로 아래 콘텐츠만 수집 (heading 나오면 종료)
     // 바로 아래 콘텐츠만 수집 (다음 heading 나오면 종료)
     while ($next.length && !$next.is(STOP_SELECTOR)) {
     while ($next.length && !$next.is(STOP_SELECTOR)) {
       const $current = $next;
       const $current = $next;
30번째 줄: 34번째 줄:
     }
     }


     // 접을 콘텐츠 없으면 스킵
     // 접을 콘텐츠 없으면 아이콘 제거
     if ($wrapper.children().length === 0) return;
     if ($wrapper.children().length === 0) {
      $icon.remove();
      return;
    }


     // DOM 반영
     // DOM 반영
     $heading.after($wrapper);
     $heading.after($wrapper);


     // 상태
     /* 기본 상태 = 펼침 */
     let collapsed = false;
     let expanded = true;
    // (초기 클래스는 아무 것도 붙이지 않음)


     // 제목 클릭 토글
     // 클릭 토글
     $heading.on('click', function () {
     $heading.on('click', function () {
       collapsed = !collapsed;
       expanded = !expanded;


       if (collapsed) {
       if (expanded) {
         $heading.addClass('mw-fold-collapsed');
        $heading.removeClass('mw-fold-collapsed'); // ▶ 아래
        $wrapper.stop(true, true).slideDown(150);
      } else {
         $heading.addClass('mw-fold-collapsed');   // ▶ 오른쪽
         $wrapper.stop(true, true).slideUp(150);
         $wrapper.stop(true, true).slideUp(150);
      } else {
        $heading.removeClass('mw-fold-collapsed');
        $wrapper.stop(true, true).slideDown(150);
       }
       }
     });
     });

2026년 1월 15일 (목) 07:20 판

/* 이 자바스크립트 설정은 모든 문서, 모든 사용자에게 적용됩니다. */

/* =========================
   h2 / h3 / h4 접기/펼치기
   - 기본 상태: 펼침
   - 아이콘 회전으로 상태 표현
   ========================= */

mw.hook('wikipage.content').add(function ($content) {

  const HEADING_SELECTOR = 'h2, h3, h4';
  const STOP_SELECTOR = 'h1, h2, h3, h4, h5, h6';

  $content.find(HEADING_SELECTOR).each(function () {
    const $heading = $(this);

    // 중복 처리 방지
    if ($heading.data('fold-ready')) return;
    $heading.data('fold-ready', true);

    // 아이콘 추가
    const $icon = $('<span class="mw-fold-icon">▶</span>');
    $heading.prepend($icon);

    // wrapper 생성
    const $wrapper = $('<div class="mw-fold-content"></div>');
    let $next = $heading.next();

    // 바로 아래 콘텐츠만 수집 (다음 heading 나오면 종료)
    while ($next.length && !$next.is(STOP_SELECTOR)) {
      const $current = $next;
      $next = $next.next();
      $wrapper.append($current);
    }

    // 접을 콘텐츠 없으면 아이콘 제거
    if ($wrapper.children().length === 0) {
      $icon.remove();
      return;
    }

    // DOM 반영
    $heading.after($wrapper);

    /* 기본 상태 = 펼침 */
    let expanded = true;
    // (초기 클래스는 아무 것도 붙이지 않음)

    // 클릭 토글
    $heading.on('click', function () {
      expanded = !expanded;

      if (expanded) {
        $heading.removeClass('mw-fold-collapsed'); // ▶ 아래
        $wrapper.stop(true, true).slideDown(150);
      } else {
        $heading.addClass('mw-fold-collapsed');    // ▶ 오른쪽
        $wrapper.stop(true, true).slideUp(150);
      }
    });
  });

});