참고: 설정을 저장한 후에 바뀐 점을 확인하기 위해서는 브라우저의 캐시를 새로 고쳐야 합니다.

  • 파이어폭스 / 사파리: Shift 키를 누르면서 새로 고침을 클릭하거나, Ctrl-F5 또는 Ctrl-R을 입력 (Mac에서는 ⌘-R)
  • 구글 크롬: Ctrl-Shift-R키를 입력 (Mac에서는 ⌘-Shift-R)
  • 인터넷 익스플로러 / 엣지: Ctrl 키를 누르면서 새로 고침을 클릭하거나, Ctrl-F5를 입력.
  • 오페라: Ctrl-F5를 입력.
$(document).ready(function() {
    // .toggle-collapse 클릭 이벤트 핸들러 수정
    $('.toggle-collapse').click(function() {
        var $this = $(this);
        var rowsToToggle = parseInt($this.data('rows')) || 1;
        var isCollapsed = $this.data('collapsed') === true;
        var $row = $this.closest('tr');

        // 사용자 정의 텍스트 확인
        var expandText = $this.data('expand-text') || '펼치기';
        var collapseText = $this.data('collapse-text') || expandText;

        // 지정된 행 수만큼 다음 행을 슬라이드 애니메이션으로 표시/숨김
        $row.nextAll().each(function(index) {
            if (index < rowsToToggle) {
                var $currentRow = $(this);
                if (isCollapsed) {
                    // 펼침 애니메이션
                    $currentRow
                        .css({
                            display: 'table-row',
                            overflow: 'hidden',
                            maxHeight: 0,
                            maxWidth: 0
                        })
                        .animate({
                            maxHeight: $currentRow.prop('scrollHeight'),
                            maxWidth: $currentRow.prop('scrollWidth'),
                            opacity: 1
                        }, 600);
                } else {
                    // 접기 애니메이션
                    $currentRow
                        .animate({
                            maxHeight: 0,
                            maxWidth: 0,
                            opacity: 0
                        }, 600, function() {
                            $currentRow.css('display', 'none');
                        });
                }
            }
        });

        // 상태 토글
        $this.data('collapsed', !isCollapsed);
        $this.text($this.data('collapsed') ? expandText : collapseText);
    });

    // 페이지 로드 시 기본 상태 설정
    $('.toggle-collapse').each(function() {
        var $this = $(this);
        var rowsToToggle = parseInt($this.data('rows')) || 1;
        var isCollapsed = $this.data('collapsed') === true;

        // 사용자 정의 텍스트 확인
        var expandText = $this.data('expand-text') || '펼치기';
        var collapseText = $this.data('collapse-text') || expandText;

        if (isCollapsed) {
            var $row = $this.closest('tr');
            $row.nextAll().each(function(index) {
                if (index < rowsToToggle) {
                    $(this).css({
                        display: 'none',
                        maxHeight: 0,
                        maxWidth: 0
                    });
                }
            });
            $this.text(expandText);
        } else {
            $this.text(collapseText);
        }
    });

    // <nolinkstyle> 태그를 .nolinkstyle 클래스로 변환
    $('nolinkstyle').each(function() {
        var $this = $(this);
        var content = $this.html();
        $this.replaceWith('<span class="nolinkstyle">' + content + '</span>');
    });
});