XETOWN

호수 공원

XE 사용에 대한 여러가지 정보들을 공유할 수 있습니다.
XE 사용팁
2016.08.28 19:53

년월일별 아카이브 리스트 만들기

조회 수 111 추천 수 2 댓글 7
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부

0. 문서 아카이브 리스트를 만듭니다. 연도별, 월별, 일별로 몇 개의 문서가 있는지 count도 됩니다. 라이믹스에서 테스트했습니다.

 

 

1. 준비물:

- /modules/document/queries 폴더의

- getYearlyArchivedList.xml

- getMonthlyArchivedList.xml 

- getDailyArchivedList.xml

- /modules/document/queries 폴더의

- document.model.php

- /modules/board 폴더의

- board.class.php 

 

 

2. 단, getYearlyArchivedList.xml은 없으므로 다음과 같은 소스로 새로 만들어줘야 합니다.

<query id="getYearlyArchivedList" action="select">
    <tables>
        <table name="documents" />
    </tables>
    <columns>
        <column name="substr(regdate,1,4)" alias="year" />
        <column name="count(*)" alias="count" />
    </columns>
    <conditions>
        <condition operation="in" column="module_srl" var="module_srl" filter="number" />
        <condition operation="like_prefix" column="regdate" var="regdate" pipe="and" />
    </conditions>
    <groups>
        <group column="substr(regdate,1,4)" />
    </groups>
</query>

 

 

3. getDailyArchivedList.xml도 형식에 알맞게 수정해주면 좋습니다.

- 1행의 <query id="getMonthlyArchivedList" action="select">을 다음과 같이 수정

<query id="getDailyArchivedList" action="select">

- 6행의 <column name="substr(regdate,1,8)" alias="month" />을 다음과 같이 수정

<column name="substr(regdate,1,8)" alias="day" />

 

 

4. documet.model.php의 847행쯤(getDailyArchivedList 함수 다음 부분)에 다음을 삽입합니다.

/**
 * Bringing a year on the status of the yaerly posts
 * @param object $obj
 * @return object
 */
function getYearlyArchivedList($obj)
{
    if($obj->mid)
    {
        $oModuleModel = getModel('module');
        $obj->module_srl = $oModuleModel->getModuleSrlByMid($obj->mid);
        unset($obj->mid);
    }
    // Module_srl passed the array may be a check whether the array
    $args = new stdClass;
    if(is_array($obj->module_srl)) $args->module_srl = implode(',', $obj->module_srl);
    else $args->module_srl = $obj->module_srl;
    $args->regdate = $obj->regdate;

    $output = executeQuery('document.getYearlyArchivedList', $args);
    if(!$output->toBool()) return $output;

    if(!is_array($output->data)) $output->data = array($output->data);

    return $output;
}

 

 

5. board.class.php의 12행을 다음으로 교체합니다.

var $search_option = array('title_content','title','content','comment','user_name','nick_name','user_id','tag','regdate');

즉, array에 regdate를 추가해준 것이죠.

 

 

6. 이로써 모든 사전 준비가 끝났습니다.

 

 

7. 레이아웃 스킨이나 게시판 스킨 등의 적절한 위치에 다음의 소스를 삽입하고, 각자 취향에 따라 css나 js를 활용해서 스타일링하시면 됩니다.

{@
    $args = new stdClass;
    $args->module_srl = $module_info->module_srl;
    $oDocumentModel = &getModel('document');
    $year = $oDocumentModel->getYearlyArchivedList($args);
    $month = $oDocumentModel->getMonthlyArchivedList($args);
    $day = $oDocumentModel->getDailyArchivedList($args);
}
<div loop="array_reverse($year->data)=>$key1,$val1" class="archive-yearly">
    <a href="{getUrl('','mid',$mid,'search_target','regdate','search_keyword',$val1->year)}">
        {zdate($val1->year,'Y')}({number_format($val1->count)})
    </a>
    <div loop="array_reverse($month->data)=>$key2,$val2" cond="zdate($val2->month,'Y')==zdate($val1->year,'Y')" class="archive-monthly">
        <a href="{getUrl('','mid',$mid,'search_target','regdate','search_keyword',$val2->month)}">
            {zdate($val2->month,'F')}({number_format($val2->count)})
        </a>
        <div loop="array_reverse($day->data)=>$key3,$val3" cond="zdate($val3->day,'Ym')==zdate($val2->month,'Ym')" class="archive-daily">
            <a href="{getUrl('','mid',$mid,'search_target','regdate','search_keyword',$val3->day)}">
                {zdate($val3->day,'jS')}({number_format($val3->count)})
            </a>
        </div>
    </div>
</div>

- $args->module_srl 정의 부분에서 $module_info->module_srl은 현재 로딩된 모듈의 srl을 가져오는 것이므로, 다른 모듈을 불러오거나 포함하고 싶을 땐 본인 취향에 맞춰 응용하면 됩니다. 예: '143, 145' 로 하면 143번과 145번 모듈에서 문서를 가져 옵니다.

 

 

8. 스크린샷 : jQuery의 toggleClass와 slideToggle을 활용한 접기/펴기

01.jpg

 

02.jpg

 

00.jpg

 

 

- 이상입니다.

  • profile
    구름이 2016.08.28 21:41:53
    수고하셨습니다 ^^
  • profile
    윤삼 2016.08.28 22:22:24
    감사합니다~ ^^/
  • profile
    MIST 2016.08.29 10:30:35
    역시 산삼다음 고삼다음 윤삼님ㅎㅎㅎ
  • profile
    윤삼 2016.08.29 15:18:05
    아아, 아무리 생각해도 대적할 만한 드립이 떠오르질 않아요ㅠㅠㅋㅋㅋ
  • profile
    Sunup 2016.08.31 21:32:03
    와 해당 아카이브 리스트에서 태그들을 뽑아서 정리하면 좋은 데이터로 활용이 가능하겠네요~!
  • profile
    윤삼 2016.08.31 22:05:50
    그렇게 하면 확실히 멋들어지겠는데요. 기간별 인기 태그라든가, 핫이슈라든가 등등등
  • profile
    Sunup 2016.09.01 12:17:42
    사이트 운영에 엄청난 도움이 될거 같네요 ㅎㅎ

List of Articles
번호 분류 제목 글쓴이 날짜
공지 질문/답변 답변을 확실히 받기위한 질문자 지침서 20 람보 2015.12.31
3732 질문/답변 cname설정 방법아시는분 계신가요 2 Jack 2016.11.29
3731 질문/답변 DB관련 질문드립니다. 4 DIZAK 2016.11.29
3730 질문/답변 신고 가능한가요? 26 DIZAK 2016.11.29
3729 질문/답변 사업자 내야하나요? 15 DIZAK 2016.11.29
3728 질문/답변 추천있는 댓글이 있을 경우 글 목록에서 표시해 주는 팁 지금은 안되나요? 25 웹지기 2016.11.29
3727 질문/답변 특정 게시판에서만 글자 크기를 다르게 설정할 순 없나요? 3 Chronos 2016.11.29
3726 질문/답변 글을 수정하면 자동으로 줄 바꿈이 됩니다. Chronos 2016.11.29
3725 질문/답변 게시판에서 댓글을 삭제할 경우... 8 스트릿 2016.11.29
3724 아이디어 제안/공유 자신의 글 지우기 2 Jack 2016.11.28
3723 아이디어 제안/공유 네이버/다음 카페를 벤치마킹한 "전체글 보기"(전체게시판) 기능 제안 1 기븐 2016.11.28
3722 질문/답변 현재 xe관련 자료중에 이런게 있나요? 익명게시판 관련 기능인데 4 기븐 2016.11.28
3721 질문/답변 랜덤 배너 출력과 구글 애드센스 필터 애드온 충돌? 라그릿 2016.11.28
3720 질문/답변 혹시 스크린샷 게시판에 사용할 레이아웃이 있을까요? 2 torrent 2016.11.28
3719 질문/답변 집에서 안쓰는 컴퓨터 찾았습니다. 9 file DIZAK 2016.11.28
3718 질문/답변 정말 이상한 문제네요. 3 라그릿 2016.11.28
3717 질문/답변 게시판 글 작성시 확장변수 글자수 제한이 가능할까요? 2 holyachon 2016.11.28
3716 질문/답변 소셜XE로 로그인시 가져오는 연령대로 회원가입 제한 가능할까요? 4 keh**** 2016.11.28
3715 질문/답변 위젯코드가 이상하게 생성됩니다. 4 라그릿 2016.11.28
3714 질문/답변 XE가 크롬에서만 작동하지 않습니다. 2 Katze 2016.11.28
3713 질문/답변 구글 애널리틱스 문의드립니다. 5 이로운 2016.11.28
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 189 Next
/ 189
위로
서버에 요청 중입니다. 잠시만 기다려 주십시오...