[이윰] View 페이지에서 이전글, 다음글 버튼에 제목과 썸네일을 가져오기

페이지 정보

shadow2fox 1,603 2 2 2021.01.10 13:18

평점

  • 평점 : 5점 (2명 참여)

본문

View 페이지에서 이전글, 다음글 버튼에 제목과 썸네일을 가져오기
전체목록보이기 사용 체크 유무에 상관없이 View 페이지에서 이전글, 다음글의 버튼이 보이고 각 버튼에 마우스를 올렸을 때 첨부된 이미지, 에디터 이미지, 동영상 썸네일, 외부 이미지 썸네일이 나오도록 해 보자.
 
외부 이미지의 썸네일도 보여지도록 아래 링크의 선행작업이 필요하다.
https://yadolee.com/bbs/board.php?bo_table=tip&wr_id=817


1. 그누보드/bbs/view.php를 열어 if (!$board['bo_use_list_view']) {를 검색하여 아래와 같이 수정한다.

수정 전

if (!$board['bo_use_list_view']) {
    if ($sql_search)
        $sql_search = " and " . $sql_search;

    // 윗글을 얻음
    $sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num = '{$write['wr_num']}' and wr_reply < '{$write['wr_reply']}' {$sql_search} order by wr_num desc, wr_reply desc limit 1 ";
    $prev = sql_fetch($sql);
    // 위의 쿼리문으로 값을 얻지 못했다면
    if (! (isset($prev['wr_id']) && $prev['wr_id'])) {
        $sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num < '{$write['wr_num']}' {$sql_search} order by wr_num desc, wr_reply desc limit 1 ";
        $prev = sql_fetch($sql);
    }

    // 아래글을 얻음
    $sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num = '{$write['wr_num']}' and wr_reply > '{$write['wr_reply']}' {$sql_search} order by wr_num, wr_reply limit 1 ";
    $next = sql_fetch($sql);
    // 위의 쿼리문으로 값을 얻지 못했다면
    if (! (isset($next['wr_id']) && $next['wr_id'])) {
        $sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num > '{$write['wr_num']}' {$sql_search} order by wr_num, wr_reply limit 1 ";
        $next = sql_fetch($sql);
    }
}
수정 후

// 주석처리, 전체목록보이기 체크시에도 이전글 다음글 버튼 나타내기
//if (!$board['bo_use_list_view']) {
    if ($sql_search)
        $sql_search = " and " . $sql_search;

    // 윗글을 얻음
    //$sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num = '{$write['wr_num']}' and wr_reply < '{$write['wr_reply']}' {$sql_search} order by wr_num desc, wr_reply desc limit 1 ";
    //추가, 여분필드도 가져오기
    $sql = " select wr_id, wr_subject, wr_datetime, wr_4 from {$write_table} where wr_is_comment = 0 and wr_num = '{$write['wr_num']}' and wr_reply < '{$write['wr_reply']}' {$sql_search} order by wr_num desc, wr_reply desc limit 1 ";
    $prev = sql_fetch($sql);
    // 위의 쿼리문으로 값을 얻지 못했다면
    if (! (isset($prev['wr_id']) && $prev['wr_id'])) {
        //$sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num < '{$write['wr_num']}' {$sql_search} order by wr_num desc, wr_reply desc limit 1 ";
        //추가, 여분필드도 가져오기
        $sql = " select wr_id, wr_subject, wr_datetime, wr_4 from {$write_table} where wr_is_comment = 0 and wr_num < '{$write['wr_num']}' {$sql_search} order by wr_num desc, wr_reply desc limit 1 ";
        $prev = sql_fetch($sql);
    }

    // 아래글을 얻음
    //$sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num = '{$write['wr_num']}' and wr_reply > '{$write['wr_reply']}' {$sql_search} order by wr_num, wr_reply limit 1 ";
    //추가, 여분필드도 가져오기
    $sql = " select wr_id, wr_subject, wr_datetime, wr_4 from {$write_table} where wr_is_comment = 0 and wr_num = '{$write['wr_num']}' and wr_reply > '{$write['wr_reply']}' {$sql_search} order by wr_num, wr_reply limit 1 ";
    $next = sql_fetch($sql);
    // 위의 쿼리문으로 값을 얻지 못했다면
    if (! (isset($next['wr_id']) && $next['wr_id'])) {
        //$sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num > '{$write['wr_num']}' {$sql_search} order by wr_num, wr_reply limit 1 ";
        //추가, 여분필드도 가져오기
        $sql = " select wr_id, wr_subject, wr_datetime, wr_4 from {$write_table} where wr_is_comment = 0 and wr_num > '{$write['wr_num']}' {$sql_search} order by wr_num, wr_reply limit 1 ";
        $next = sql_fetch($sql);
    }
//}

2. 그누보드5/eyoom/user_program/board/view.skin.php를 열어 적당한 위치에 아래 소스를 넣는다.


// 이전글 프리뷰
if (isset($prev['wr_id']) && $prev['wr_id']) {
    $prev_img = get_list_thumbnail($bo_table, $prev['wr_id'], $board['bo_gallery_width'], $board['bo_gallery_height']);
    if($prev_img['src']) {
        $prev['img_content'] = "<img class='img-responsive' src='".$prev_img['src']."' alt='".$prev_img['alt']."'>";
        $prev['img_src'] = $prev_img['src'];
    } else {
        // wr_4 unserialize
        $prev_wr_4 = unserialize($prev['wr_4']);
        if(!$prev_wr_4) $prev_wr_4 = array();
        if($prev['wr_4']) {
            $prev_img['src'] = $prev_wr_4['thumb_src'];
            if($prev_img['src']) {
                $prev['img_content'] = "<img class='img-responsive' src='".$prev_img['src']."'>";
                $prev['img_src'] = $prev_img['src'];
            } else {
                $prev_img['src'] = $prev_wr_4['extimg_thumb'];
                if($prev_img) {
                    $prev['img_content'] = "<img class='img-responsive' src='".$prev_img['src']."'>";
                    $prev['img_src'] = $prev_img['src'];
                }
            }
        }
    }
}

// 다음글 프리뷰
if (isset($next['wr_id']) && $next['wr_id']) {
    $next_img = get_list_thumbnail($bo_table, $next['wr_id'], $board['bo_gallery_width'], $board['bo_gallery_height']);
    if($next_img['src']) {
        $next['img_content'] = "<img class='img-responsive' src='".$next_img['src']."' alt='".$next_img['alt']."'>";
        $next['img_src'] = $next_img['src'];
    } else {
        // wr_4 unserialize
        $next_wr_4 = unserialize($next['wr_4']);
        if(!$next_wr_4) $next_wr_4 = array();
        if($next['wr_4']) {
            $next_img['src'] = $next_wr_4['thumb_src'];
            if($next_img['src']) {
                $next['img_content'] = "<img class='img-responsive' src='".$next_img['src']."'>";
                $next['img_src'] = $next_img['src'];
            } else {
                $next_img['src'] = $next_wr_4['extimg_thumb'];
                if($next_img) {
                    $next['img_content'] = "<img class='img-responsive' src='".$next_img['src']."'>";
                    $next['img_src'] = $next_img['src'];
                }
            }
        }
    }
}

3. 변경하고자 하는 스킨의 view.skin.html을 열어 이전글과 다음글을 아래와 같이 수정한다.

수정 전

            <!--{? _prev_href}--><li><a href="{_prev_href}" class="btn-e btn-e-light-grey" type="button">이전글</a></li><!--{/}-->
            <!--{? _next_href}--><li><a href="{_next_href}" class="btn-e btn-e-light-grey" type="button">다음글</a></li><!--{/}-->
수정 후

            <!--{? _prev_href}--><li><a href="{_prev_href}" class="btn btn-danger" type="button"{? !C.G5_IS_MOBILE} data-trigger="hover" data-placement="top auto" title="<i class='far fa-arrow-alt-circle-up'></i> {_prev_wr_subject}" data-toggle="popover" {? _prev_img}data-content="<div class='prev-img'>{_prev.img_content}</div>"{/}{/}>다음글</a></li><!--{/}-->
            <!--{? _next_href}--><li><a href="{_next_href}" class="btn btn-warning" type="button"{? !C.G5_IS_MOBILE} data-trigger="hover" data-placement="top auto" title="<i class='far fa-arrow-alt-circle-down'></i> {_next_wr_subject}" data-toggle="popover" {? _next_img}data-content="<div class='next-img'>{_next.img_content}</div>"{/}{/}>이전글</a></li><!--{/}-->
참고로 위 다음글과 이전글의 버튼 문구가 뒤바뀐 걸 알 수 있는데 버튼 위치나 순서상의 선택이니 본인 판단에 따르도록 하자.

팝업 스타일 정의하도록 view.skin.html 상단에 아래 css를 넣는다.

.popover{max-width:174px}
{? !_prev_img && !_next_img}.popover-content{display:none}{:}.popover-content{display:contents}{/}
.popover-title{font-size:11px;letter-spacing:-1px;line-height:1em;text-overflow:ellipsis;white-space:nowrap;word-wrap:normal;overflow:hidden;background:#fff;border-bottom:none}
.popover-content .prev-img, .popover-content .next-img{overflow:hidden;max-height:125px;border-bottom-left-radius:5px;border-bottom-right-radius:5px}

마우스 오버 시 팝업이 작동하도록 view.skin.html 하단 쪽에 아래 스크립트를 넣는다.

$(document).ready(function(){
    $('[data-toggle="popover"]').popover({html:true,container:'.board-view-atc',delay:{show:0,hide:0},animation:false});
    $('[data-toggle="popover"]').on('shown.bs.popover', function () {
        $('.popover-content .prev-img').addClass('animated flipInX');
        $('.popover-content .next-img').addClass('animated flipInX');
    })
});
추천인 2
  • 내사랑
  • 하늘구장
10
shadow2fox - 회원등급 : 자연/Level 143 - 포인트 : 2,551,952
레벨 143
경험치 3,057,244

Progress Bar 27%

- 가입일 : 2015-03-10 12:21:44
- 서명 : 인간에게 가장 큰 선물은 자기 자신에게 기회를 주는 것이다. - 크리스 가드너, Chris Gardner -
- 자기소개 : There's never a shortcut to happiness.

댓글2

하늘구장님의 댓글

하늘구장 2021.01.10 22:50
와우 감사합니다 좋아요

내사랑님의 댓글

내사랑 2021.01.10 14:23
멋진 팁 감사합니다 무조건 추천 적용해 보았는데 외부 이미지가 들어간 과거의 게시글은 여분필드 wr_4에 정보가 없어서 안나오더라구요 그래서 노가다로 작업하느라 진이 다 빠졌네요

축하합니다. 첫 댓글로 19경험치를 획득하였습니다.

Total 242113 페이지
제목 글쓴이 날짜 조회 추천
이윰  🏆 일반 회원과 특정 레벨 회원을 나타내는 변수 루루아빠 2015.04.23 2,740 0
이윰  🔒 특정 페이지 혹은 게시판에서 사이드 메뉴를 사용치 않기 루루아빠 2015.05.23 5 0
이윰  🏆 Eyoom Builder 1.1.3 패치 루루아빠 2015.06.05 3,538 0
이윰  🏆 스크린 사이즈에 따른 미디어 쿼리(container 크기 변화) 루루아빠 2015.06.25 3,278 0
이윰  🏆 Eyoom Builder 1.1.9 - 그누보드 5.1.0 테마버전 지원 루루아빠 2015.08.05 3,143 0
이윰  댓글+2🏆 쪽지 보낼때 캡챠코드 사용하지 않기 - 오류 루루아빠 2015.09.24 3,296 0
이윰  🏆 🎞️ Eyoom Builder 1.1.17 패치 (Start of the Season2) 루루아빠 2015.12.08 3,003 0
이윰  🏆 본문 내용 추출시 특정 태그 제거하기 루루아빠 2016.05.09 2,535 0
이윰  🏆 태그 클릭시 관련된 게시글 페이지당 노출 갯수 정하기 루루아빠 2016.10.09 2,509 0
이윰  🏆 Eyoom Builder 1.3.1 패치 루루아빠 2017.11.21 2,237 0
이윰  🏆 특정 게시판을 메인 홈으로 보여주기 루루아빠 2017.12.13 2,648 0
이윰  🏆 이윰빌더 최신글 본문 추출시 엔터, 띄어쓰기 태그를 스페이스(한 칸 띄우기)로 바꾸기 shadow2fox 2018.07.12 1,962 0
이윰  🏆 이윰 조건문 변수 모음 루루아빠 2015.04.23 2,777 0
이윰  🏆 EBL Respond·Memo·Connect 최신글 스킨 배포 루루아빠 2015.05.23 2,834 0
이윰  🏆 이윰빌더 1.1.4 패치 루루아빠 2015.06.08 3,335 0
이윰  🏆 사운드클라우드와 게시글 정보와의 간격 조정 루루아빠 2015.06.28 3,542 0
이윰  댓글+1🏆 게시판 본문 보기시 제목 글자 수 늘리기 루루아빠 2015.08.06 2,989 0
이윰  🏆 SNS 아이콘 툴팁 추가와 효과 바꾸기 루루아빠 2015.10.01 3,471 0
이윰  댓글+1🏆 이미지 리사이징 기능 끄기 (큰 이미지가 커졌다가 작아지는 문제 해결) 루루아빠 2015.12.18 3,949 0
이윰  댓글+1🏆 SELF-HOSTED로 Jwplayer7.x 사용시 외부 링크(jwpcdn.com)에서 스킨 가져오는 문제 루루아빠 2016.05.11 3,910 0